From 0864509e1eb593c3dedb66196ec19fe51437922b Mon Sep 17 00:00:00 2001
From: wankeda <Administrator@DESKTOP-HAU3ST3>
Date: 星期一, 26 五月 2025 10:25:42 +0800
Subject: [PATCH] 新增货位管理,PDA扫码生成任务烘烤出料,烘烤回炉,空托回流
---
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/WIDESEAWCS_TaskInfoService.csproj | 1
代码管理/NEWCode/WIDESEAWCS_PDA/pages.json | 18
代码管理/NEWCode/WIDESEAWCS_PDA/pages/叫料/空托回流.vue | 72 --
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Core/Enums/LocationEnum.cs | 48 ++
代码管理/NEWCode/WIDESEAWCS_Client/src/api/http.js | 12
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Dt_StationinfoService.cs | 19
代码管理/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue | 14
代码管理/NEWCode/WIDESEAWCS_PDA/pages/叫料/烘烤回炉.vue | 127 +++++
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs | 207 ++++++++
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/IDt_StationinfoService.cs | 14
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemRepository/IDt_StationinfoRepository.cs | 14
代码管理/NEWCode/WIDESEAWCS_Client/src/views/system/Dt_Stationinfo.vue | 207 +++++++++
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemRepository/Dt_StationinfoRepository.cs | 18
代码管理/NEWCode/WIDESEAWCS_PDA/pages/叫料/烘烤出料.vue | 111 ++++
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/SendTaskAGV.cs | 168 +------
代码管理/NEWCode/WIDESEAWCS_Client/src/router/viewGird.js | 4
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs | 11
代码管理/NEWCode/WIDESEAWCS_Client/src/extension/system/Dt_Stationinfo.js | 112 ++++
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs | 17
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Dt_StationinfoController.cs | 17
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/CommonAGVJob.cs | 5
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs | 27
代码管理/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Model/Models/System/Dt_Stationinfo.cs | 81 +++
23 files changed, 1,093 insertions(+), 231 deletions(-)
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/api/http.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/api/http.js"
index 6270482..84514c9 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/api/http.js"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/api/http.js"
@@ -12,17 +12,17 @@
let loadingInstance;
let loadingStatus = false;
if (process.env.NODE_ENV == 'development') {
- axios.defaults.baseURL = 'http://192.168.12.235:9291/';
- // axios.defaults.baseURL = 'http://127.0.0.1:9291/';
+ // axios.defaults.baseURL = 'http://192.168.12.235:9291/';
+ axios.defaults.baseURL = 'http://127.0.0.1:9291/';
}
else if (process.env.NODE_ENV == 'debug') {
- axios.defaults.baseURL = 'http://192.168.12.235:8098/';
- // axios.defaults.baseURL = 'http://127.0.0.1:9291/';
+ // axios.defaults.baseURL = 'http://192.168.12.235:8098/';
+ axios.defaults.baseURL = 'http://127.0.0.1:9291/';
}
else if (process.env.NODE_ENV == 'production') {
- axios.defaults.baseURL = 'http://192.168.12.235:9291/';
- // axios.defaults.baseURL = 'http://127.0.0.1:9291/';
+ // axios.defaults.baseURL = 'http://192.168.12.235:9291/';
+ axios.defaults.baseURL = 'http://127.0.0.1:9291/';
}
if (!axios.defaults.baseURL.endsWith('/')) {
axios.defaults.baseURL+="/";
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/extension/system/Dt_Stationinfo.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/extension/system/Dt_Stationinfo.js"
new file mode 100644
index 0000000..34578e2
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/extension/system/Dt_Stationinfo.js"
@@ -0,0 +1,112 @@
+//author:jxx
+//姝ゅ鏄琛ㄥ崟鐨勬柟娉曪紝缁勪欢锛屾潈闄愭搷浣滄寜閽瓑杩涜浠绘剰鎵╁睍(鏂规硶鎵╁睍鍙弬鐓ellOrder.js)
+let extension = {
+ components: {//鍔ㄦ�佹墿鍏呯粍浠舵垨缁勪欢璺緞
+ //琛ㄥ崟header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠�
+ gridHeader: '',//{ template: "<div>鎵╁睍缁剎x浠�</div>" },
+ gridBody: '',
+ gridFooter: '',
+ //寮瑰嚭妗�(淇敼銆佺紪杈戙�佹煡鐪�)header銆乧ontent銆乫ooter瀵瑰簲浣嶇疆鎵╁厖鐨勭粍浠�
+ modelHeader: '',
+ modelBody: '',
+ modelFooter: ''
+ },
+ buttons: { view: [], box: [], detail: [] },//鎵╁睍鐨勬寜閽�
+ methods: {//浜嬩欢鎵╁睍
+ onInit() {
+ this.pagination.order = "asc";
+
+ this.columns.forEach(row => {
+ if (row.field == "stationCode") {
+ row.sort = true;
+ } else if (row.field == "lastInTime") {
+ row.sort = true;
+ }
+
+ if (row.field == "getStatus") {
+ row.getColor = (row, column) => {
+ if (row.getStatus == -1) {
+ return "info";
+ } else if (row.getStatus == 0) {
+ return "success";
+ } else if (row.getStatus == 1) {
+ return "waring";
+ }
+ }
+ } else if (row.field == "enable") {
+ row.getColor = (row, column) => {
+ if (row.enable == 1) {
+ return "success";
+ } else {
+ return "error";
+ }
+ }
+ }
+ })
+ this.buttons.splice(1, 0, {
+ name: "鍙栨秷绂佺敤",
+ icon: 'md-refresh',
+ type: 'primary',
+ onClick: function () {
+ let rows = this.$refs.table.getSelected();
+ if (rows.length == 0) return this.$error("璇烽�夋嫨瑕佸彇娑堢鐢ㄧ殑鏁版嵁");
+
+ this.$confirm('纭瑕佸彇娑堢鐢ㄥ悧?', '璀﹀憡', {
+ confirmButtonText: '纭畾',
+ cancelButtonText: '鍙栨秷',
+ type: 'warning',
+ center: true
+ }).then(() => {
+ let data = [];
+ let parm = {
+ "data": data,
+ "type": "1"
+ }
+ rows.forEach(t => data.push(t.id))
+ this.http.post("/api/dt_stationinfo/SetStationEnable", parm, "鍙栨秷绂佺敤涓�...").then(x => {
+ if (x.status) {
+ this.$Message.success("鍙栨秷绂佺敤鎴愬姛!");
+ this.refresh();
+ } else {
+ this.$Message.error(x.message);
+ }
+ })
+ });
+ }
+ })
+
+ this.buttons.splice(1, 0, {
+ name: "绂佺敤",
+ icon: 'md-refresh',
+ type: 'danger',
+ onClick: function () {
+ let rows = this.$refs.table.getSelected();
+ if (rows.length == 0) return this.$error("璇烽�夋嫨瑕佺鐢ㄧ殑鏁版嵁");
+
+ this.$confirm('纭瑕佺鐢ㄥ悧?', '璀﹀憡', {
+ confirmButtonText: '纭畾',
+ cancelButtonText: '鍙栨秷',
+ type: 'warning',
+ center: true
+ }).then(() => {
+ let data = [];
+ let parm = {
+ "data": data,
+ "type": "0"
+ }
+ rows.forEach(t => data.push(t.id))
+ this.http.post("/api/dt_stationinfo/SetStationEnable", parm, "閿佸畾涓�...").then(x => {
+ if (x.status) {
+ this.$Message.success("绂佺敤鎴愬姛锛�");
+ this.refresh();
+ } else {
+ this.$Message.error(x.message);
+ }
+ })
+ });
+ }
+ })
+ }
+ }
+};
+export default extension;
\ No newline at end of file
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/router/viewGird.js" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/router/viewGird.js"
index d5dee3b..0826540 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/router/viewGird.js"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/router/viewGird.js"
@@ -61,6 +61,10 @@
path: '/router',
name: 'router',
component: () => import('@/views/basicinfo/router.vue')
+ }, {
+ path: '/Dt_Stationinfo',
+ name: 'Dt_Stationinfo',
+ component: () => import('@/views/system/Dt_Stationinfo.vue')
}]
export default viewgird
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/views/system/Dt_Stationinfo.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/views/system/Dt_Stationinfo.vue"
new file mode 100644
index 0000000..337a09a
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Client/src/views/system/Dt_Stationinfo.vue"
@@ -0,0 +1,207 @@
+<!--
+*Author锛歫xx
+ *Contact锛�283591387@qq.com
+ *浠g爜鐢辨鏋剁敓鎴�,浠讳綍鏇存敼閮藉彲鑳藉鑷磋浠g爜鐢熸垚鍣ㄨ鐩�
+ *涓氬姟璇峰湪@/extension/system/system/Base_routing_table.js姝ゅ缂栧啓
+ -->
+<template>
+ <view-grid
+ ref="grid"
+ :columns="columns"
+ :detail="detail"
+ :editFormFields="editFormFields"
+ :editFormOptions="editFormOptions"
+ :searchFormFields="searchFormFields"
+ :searchFormOptions="searchFormOptions"
+ :table="table"
+ :extend="extend"
+ >
+ </view-grid>
+</template>
+<script>
+import extend from "@/extension/system/Dt_Stationinfo.js";
+import { ref, defineComponent } from "vue";
+export default defineComponent({
+ setup() {
+ const table = ref({
+ key: "id",
+ footer: "Foots",
+ cnName: "绔欑偣鏌ヨ",
+ name: "/Dt_Stationinfo",
+ url: "/Dt_Stationinfo/",
+ sortName: "id",
+ });
+ const editFormFields = ref({
+ stationType: "",
+ location_state: "",
+ lastUpdateTime: "",
+ });
+ const editFormOptions = ref([
+ [
+ {
+ title: "绔欑偣鍦板潃",
+ required: true,
+ field: "stationCode",
+ type: "text",
+ disabled: true,
+ },
+ {
+ title: "鐗╂枡绫诲瀷",
+ field: "stationType",
+ type: "select",
+ dataKey: "materieInfo",
+ },
+ {
+ title: "缂撳瓨鏋剁姸鎬�",
+ required: false,
+ field: "location_state",
+ type: "select",
+ data: [
+ { key: "0", value: "绌烘嫋" },
+ { key: "1", value: "閿佸畾" },
+ { key: "2", value: "婊℃嫋" },
+ ],
+ },
+ ],
+ [
+ {
+ title: "澶囨敞",
+ field: "remark",
+ type: "text",
+ },
+ // {
+ // title: "鏈�鍚庢洿鏂版椂闂�",
+ // field: "lastUpdateTime",
+ // type: "datetime",
+ // },
+ ],
+ ]);
+ const searchFormFields = ref({
+ route_began: "",
+ route_end: "",
+ area: "",
+ });
+ const searchFormOptions = ref([
+ [
+ { title: "绔欑偣鍦板潃", field: "stationCode", type: "like" },
+ {
+ title: "鍖哄煙",
+ field: "area",
+ type: "select",
+ dataKey: "station_area",
+ },
+ ],
+ [
+ {
+ title: "缂撳瓨鏋剁姸鎬�",
+ field: "location_state",
+ data: [
+ { key: "0", value: "绌烘嫋" },
+ { key: "1", value: "閿佸畾" },
+ { key: "2", value: "婊℃嫋" },
+ ],
+ type: "select",
+ },
+ {
+ title: "鏄惁鍚敤",
+ field: "enable",
+ data: [
+ { key: "true", value: "鍚敤" },
+ { key: "false", value: "绂佺敤" },
+ ],
+ type: "select",
+ },
+ { title: "澶囨敞", field: "remark", type: "like" },
+ ],
+ ]);
+ const columns = ref([
+ {
+ field: "id",
+ title: "ID",
+ type: "guid",
+ width: 60,
+ hidden: true,
+ readonly: true,
+ require: true,
+ align: "left",
+ },
+ {
+ field: "stationCode",
+ title: "绔欑偣鍦板潃",
+ type: "string",
+ width: 110,
+ require: true,
+ align: "left",
+ },
+ {
+ field: "area",
+ title: "鍖哄煙",
+ type: "string",
+ width: 80,
+ align: "left",
+ bind: { data: [] },
+ },
+ {
+ field: "location_state",
+ title: "缂撳瓨鏋剁姸鎬�",
+ type: "string",
+ width: 90,
+ require: true,
+ align: "left",
+ bind: {
+ key: "",
+ data: [
+ { key: "0", value: "绌烘嫋" },
+ { key: "1", value: "閿佸畾" },
+ { key: "2", value: "婊℃嫋" },
+ ],
+ },
+ },
+ {
+ field: "lastUpdateTime",
+ title: "鏈�鍚庢洿鏂版椂闂�",
+ type: "string",
+ width: 120,
+ align: "left",
+ sort: true,
+ },
+ {
+ field: "enable",
+ title: "鏄惁鍚敤",
+ type: "string",
+ width: 60,
+ align: "left",
+ bind: {
+ data: [
+ { key: true, value: "鍚敤" },
+ { key: false, value: "绂佺敤" },
+ ],
+ },
+ },
+ {
+ field: "remark",
+ title: "澶囨敞",
+ type: "string",
+ width: 100,
+ align: "left",
+ },
+ ]);
+ const detail = ref({
+ cnName: "#detailCnName",
+ columns: [],
+ sortName: "",
+ key: "",
+ });
+ return {
+ table,
+ extend,
+ editFormFields,
+ editFormOptions,
+ searchFormFields,
+ searchFormOptions,
+ columns,
+ detail,
+ };
+ },
+});
+</script>
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json"
index 0f5533e..9a78c68 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages.json"
@@ -40,9 +40,23 @@
}
},
{
- "path": "pages/鍙枡/杈撻�佺嚎鍥炴祦",
+ "path": "pages/鍙枡/绌烘墭鍥炴祦",
"style": {
- "navigationBarTitleText": "杈撻�佺嚎鍥炴祦",
+ "navigationBarTitleText": "绌烘墭鍥炴祦",
+ "enablePullDownRefresh": false
+ }
+ },
+ {
+ "path": "pages/鍙枡/鐑樼儰鍥炵倝",
+ "style": {
+ "navigationBarTitleText": "鐑樼儰鍥炵倝",
+ "enablePullDownRefresh": false
+ }
+ },
+ {
+ "path": "pages/鍙枡/鐑樼儰鍑烘枡",
+ "style": {
+ "navigationBarTitleText": "鐑樼儰鍑烘枡",
"enablePullDownRefresh": false
}
},
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue"
index a784728..c302442 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/index/index.vue"
@@ -28,8 +28,18 @@
image: ""
},
{
- text: '涓夋ゼ杈撻�佺嚎鍥炴祦',
- url: 'pages/鍙枡/杈撻�佺嚎鍥炴祦',
+ text: '涓夋ゼ绌烘墭鍥炴祦',
+ url: 'pages/鍙枡/绌烘墭鍥炴祦',
+ image: ""
+ },
+ {
+ text: '涓夋ゼ鐑樼儰鍑烘枡',
+ url: 'pages/鍙枡/鐑樼儰鍑烘枡',
+ image: ""
+ },
+ {
+ text: '涓夋ゼ鐑樼儰鍥炵倝',
+ url: 'pages/鍙枡/鐑樼儰鍥炵倝',
image: ""
},
// {
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\207\272\346\226\231.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\207\272\346\226\231.vue"
new file mode 100644
index 0000000..8f2bca4
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\207\272\346\226\231.vue"
@@ -0,0 +1,111 @@
+<template>
+ <view>
+ <uni-segmented-control :current="current" :values="items" @clickItem="onClickItem">
+ </uni-segmented-control>
+ <view class="content">
+ <view v-if="current === 0" class="headerstyle">
+ <view class="itemstyle">
+ <uni-forms label-width="120">
+ <uni-forms-item label="鐑樼儰鍑烘枡缂栫爜">
+ <uni-easyinput type="text" :focus="!addressFocus" v-model="sourceAddress"
+ placeholder="璇锋壂鎻忕儤鐑ょ紪鐮�" ref='midInput' @input="inputChangebarcode" />
+ </uni-easyinput>
+ </uni-forms-item>
+ <button @click="inbound" type="primary" size="default" style="margin-top: 2%;">鎼繍纭</button>
+ </uni-forms-item>
+ </uni-forms>
+ </view>
+ </view>
+ </view>
+ <u-toast ref="uToast" />
+ </view>
+</template>
+
+<script>
+ const innerAudioContext = uni.createInnerAudioContext();
+ export default {
+ data() {
+ return {
+ items: ['杈撻�佺嚎鎼繍'],
+ current: 0,
+ label: "",
+ focus: false,
+ addressFocus: false,
+ sourceAddress: "",
+ }
+ },
+ methods: {
+ voiceSpeech(src) {
+ innerAudioContext.src = src; // '../../static/success.mp3';
+ innerAudioContext.play();
+ },
+ onClickItem(e) {
+ this.focus = false;
+ this.addressFocus = false;
+ if (this.current !== e.currentIndex) {
+ this.current = e.currentIndex;
+ if (this.current == 2) {
+ this.getData();
+ }
+ }
+ },
+ inbound() {
+ // 鎻愬彇杈撳叆妗嗙殑鍊�
+ const sourceAddress = this.sourceAddress;
+
+ if (sourceAddress == "") {
+ this.$t.message.toast('璇烽�夋嫨璧风偣浣嶇疆');
+ return;
+ }
+ // console.log(Exception);
+ this.$u.post('/api/PDA/OutBoundTask', sourceAddress).then(res => {
+ this.$t.message.closeLoading();
+ if (res.code == 0) {
+ this.$t.message.toast('鍛煎彨鎴愬姛');
+ this.sourceAddress = "";
+ // this.$refs.popup.close();
+ // this.submit();
+ } else {
+ this.$t.message.toast(res.message);
+ }
+ }).catch(err => {
+ this.$refs.uToast.show({
+ title: err.message,
+ type: "error"
+ })
+ })
+ },
+
+ inputChangebarcode() {
+ this.addressFocus = false;
+ this.$nextTick(function(x) {
+ if (this.sourceAddress != '') {
+ this.addressFocus = true;
+ }
+ })
+ },
+ }
+ }
+</script>
+<style lang="scss">
+ @import '@/common/uni-ui.scss';
+
+ .content {
+ display: flex;
+ height: 150px;
+ }
+
+ .content-text {
+ font-size: 14px;
+ color: #666;
+ }
+
+ .itemstyle {
+ margin-top: 30px;
+ margin-left: 5%;
+ }
+
+ .headerstyle {
+ width: 90%;
+ }
+</style>
\ No newline at end of file
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\233\236\347\202\211.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\233\236\347\202\211.vue"
new file mode 100644
index 0000000..241be68
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\203\230\347\203\244\345\233\236\347\202\211.vue"
@@ -0,0 +1,127 @@
+<template>
+ <view>
+ <uni-segmented-control :current="current" :values="items" @clickItem="onClickItem">
+ </uni-segmented-control>
+ <view class="content">
+ <view v-if="current === 0" class="headerstyle">
+ <view class="itemstyle">
+ <uni-forms label-width="120">
+ <uni-forms-item label="璧风偣缂撳瓨鏋跺湴鍧�">
+ <uni-easyinput type="text" :focus="!addressFocus" v-model="sourceAddress"
+ placeholder="璇锋壂鐬勮捣鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" />
+ <!-- <uni-data-select v-model="value" :localdata="rangs"></uni-data-select> -->
+ </uni-forms-item>
+ <uni-forms-item label="缁堢偣鐑樼儰鏈轰笂鏂欏湴鍧�">
+ <uni-easyinput type="text" :focus="!addressFocus" v-model="targetAddress"
+ placeholder="璇锋壂鎻忕粓鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" />
+ </uni-forms-item>
+ <button @click="inbound" type="primary" size="default" style="margin-top: 2%;">鎼繍纭</button>
+ </uni-forms-item>
+ </uni-forms>
+ </view>
+ </view>
+ </view>
+ <u-toast ref="uToast" />
+ </view>
+</template>
+
+<script>
+ const innerAudioContext = uni.createInnerAudioContext();
+ export default {
+ data() {
+ return {
+ items: ['杈撻�佺嚎鎼繍'],
+ current: 0,
+ label: "",
+ focus: false,
+ addressFocus: false,
+ sourceAddress: "",
+ targetAddress: ","
+ }
+ },
+ methods: {
+ voiceSpeech(src) {
+ innerAudioContext.src = src; // '../../static/success.mp3';
+ innerAudioContext.play();
+ },
+ onClickItem(e) {
+ this.focus = false;
+ this.addressFocus = false;
+ if (this.current !== e.currentIndex) {
+ this.current = e.currentIndex;
+ if (this.current == 2) {
+ this.getData();
+ }
+ }
+ },
+ inbound() {
+ // 鎻愬彇杈撳叆妗嗙殑鍊�
+ const sourceAddress = this.sourceAddress;
+ const targetAddress = this.targetAddress;
+ if (sourceAddress == "") {
+ this.$t.message.toast('璇锋壂鎻忚捣鐐逛綅缃�');
+ return;
+ }
+ if (targetAddress == "") {
+ this.$t.message.toast('璇锋壂鎻忕粓鐐逛綅缃�');
+ return;
+ }
+ var PostData = {
+ MainData: {
+ "sourceAddress": this.sourceAddress,
+ "targetAddress": this.targetAddress,
+ }
+ }
+ // console.log(Exception);
+ this.$u.post('/api/PDA/OutBoundTasks', PostData).then(res => {
+ this.$t.message.closeLoading();
+ if (res.code == 0) {
+ this.$t.message.toast('鍛煎彨鎴愬姛');
+ this.sourceAddress = "";
+ this.targetAddress="";
+ // this.$refs.popup.close();
+ // this.submit();
+ } else {
+ this.$t.message.toast(res.message);
+ }
+ }).catch(err => {
+ this.$refs.uToast.show({
+ title: err.message,
+ type: "error"
+ })
+ })
+ },
+
+ inputChangebarcode() {
+ this.addressFocus = false;
+ this.$nextTick(function(x) {
+ if (this.sourceAddress != '') {
+ this.addressFocus = true;
+ }
+ })
+ },
+ }
+ }
+</script>
+<style lang="scss">
+ @import '@/common/uni-ui.scss';
+
+ .content {
+ display: flex;
+ height: 150px;
+ }
+
+ .content-text {
+ font-size: 14px;
+ color: #666;
+ }
+
+ .itemstyle {
+ margin-top: 30px;
+ margin-left: 5%;
+ }
+
+ .headerstyle {
+ width: 90%;
+ }
+</style>
\ No newline at end of file
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\251\272\346\211\230\345\233\236\346\265\201.vue"
similarity index 70%
rename from "\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue"
rename to "\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\251\272\346\211\230\345\233\236\346\265\201.vue"
index 34f3873..814b56a 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\350\276\223\351\200\201\347\272\277\345\233\236\346\265\201.vue"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_PDA/pages/\345\217\253\346\226\231/\347\251\272\346\211\230\345\233\236\346\265\201.vue"
@@ -6,22 +6,14 @@
<view v-if="current === 0" class="headerstyle">
<view class="itemstyle">
<uni-forms label-width="120">
- <uni-forms-item label="璧风偣鍦板潃">
- <!-- <uni-easyinput type="text" :focus="!addressFocus" v-model="sourceAddress"
- placeholder="璇锋壂鐬勮捣鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" /> -->
- <uni-data-select v-model="value" :localdata="rangs"></uni-data-select>
+ <uni-forms-item label="璧风偣缂撳瓨鏋跺湴鍧�">
+ <uni-easyinput type="text" :focus="!addressFocus" v-model="sourceAddress"
+ placeholder="璇锋壂鐬勮捣鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" />
+ <!-- <uni-data-select v-model="value" :localdata="rangs"></uni-data-select> -->
</uni-forms-item>
- <uni-forms-item label="缁堢偣鍦板潃">
+ <uni-forms-item label="缁堢偣杈撻�佺嚎鍦板潃">
<uni-easyinput type="text" :focus="!addressFocus" v-model="targetAddress"
placeholder="璇锋壂鎻忕粓鐐瑰湴鍧�" ref='midInput' @input="inputChangebarcode" />
- </uni-forms-item>
- <uni-forms-item label="绗竴鎵樼洏鏉$爜">
- <uni-easyinput type="text" :focus="!addressFocus" v-model="pallcode" placeholder="璇锋壂鎻忔墭鐩樻潯鐮�"
- ref='midInput' @input="inputChangebarcode" />
- </uni-forms-item>
- <uni-forms-item label="绗簩鎵樼洏鏉$爜">
- <uni-easyinput type="text" :focus="!addressFocus" v-model="pallcode1" placeholder="璇锋壂鎻忔墭鐩樻潯鐮�"
- ref='midInput' @input="inputChangebarcode" />
</uni-forms-item>
<uni-forms-item>
<button @click="inbound" type="primary" size="default"
@@ -54,8 +46,6 @@
addressFocus: false,
targetAddress: "",
sourceAddress: "",
- pallcode: "",
- pallcode1: "",
Exception: "",
address: "",
check: true,
@@ -64,15 +54,6 @@
value2: "",
matTotals: [],
value: 0,
- rangs: [{
- value: "FJXL-KPHLX001",
- text: "FJXL-KPHLX001"
- },
- {
- value: "ZJXL-KPHLX001",
- text: "ZJXL-KPHLX001"
- },
- ],
// range: [],
}
},
@@ -136,13 +117,9 @@
},
inbound() {
// 鎻愬彇杈撳叆妗嗙殑鍊�
- const sourceAddress = this.value;
+ const sourceAddress = this.sourceAddress;
const targetAddress = this.targetAddress;
- // 鎻愬彇宸ュ崟缂栧彿
- const pallcode =this.pallcode;
- // 鎻愬彇鍨嬪彿
- const pallcode1 = this.pallcode1;
-
+
if (sourceAddress == "") {
this.$t.message.toast('璇烽�夋嫨璧风偣浣嶇疆');
return;
@@ -151,36 +128,25 @@
this.$t.message.toast('璇锋壂鐬勭粓鐐逛綅缃�');
return;
}
- // if (pallcode == "") {
- // this.$t.message.toast('璇锋壂鎻忕涓�鎷栫洏鏉$爜');
- // return;
- // }
- // if (pallcode1 == "") {
- // this.$t.message.toast('璇锋壂鎻忕浜屾嫋鐩樻潯鐮�');
- // return;
- // }
var postData = {
MainData: {
- "sourceAddress": this.value,
+ "sourceAddress": this.sourceAddress,
"targetAddress": this.targetAddress,
- "Exception": this.pallcode + "," + this.pallcode1
}
}
// console.log(Exception);
this.$u.post('/api/PDA/EmptyTask', postData).then(res => {
- this.$t.message.closeLoading();
- console.log(postData);
- if (res.code == 200) {
- this.$t.message.toast('鍛煎彨鎴愬姛');
- this.value="",
- this.targetAddress="",
- this.pallcode="",
- this.pallcode1="",
- this.$refs.popup.close();
- // this.submit();
- } else {
- this.$t.message.toast(res.message);
- }
+ this.$t.message.closeLoading();
+ console.log(postData);
+ if (res.code == 0) {
+ this.$t.message.toast('鍛煎彨鎴愬姛');
+ this.sourceAddress = "";
+ this.targetAddress = "";
+ // this.$refs.popup.close();
+ // this.submit();
+ } else {
+ this.$t.message.toast(res.message);
+ }
}).catch(err => {
this.$refs.uToast.show({
title: err.message,
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Core/Enums/LocationEnum.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Core/Enums/LocationEnum.cs"
new file mode 100644
index 0000000..0d23ff3
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Core/Enums/LocationEnum.cs"
@@ -0,0 +1,48 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.ComponentModel;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+
+namespace WIDESEA_Core.Enums
+{
+ /// <summary>
+ /// 璐т綅鐘舵��
+ /// </summary>
+ public enum LocationStatusEnum
+ {
+ /// <summary>
+ /// 绌洪棽
+ /// </summary>
+ [Description("绌洪棽")]
+ Free = 0,
+
+ /// <summary>
+ /// 閿佸畾
+ /// </summary>
+ [Description("閿佸畾")]
+ Lock = 1,
+
+ /// <summary>
+ /// 鏈夎揣
+ /// </summary>
+ [Description("鏈夎揣")]
+ InStock = 2,
+ }
+ public enum EnableStatusEnum
+ {
+ /// <summary>
+ /// 姝e父
+ /// </summary>
+ [Description("姝e父")]
+ Normal = 0,
+
+ /// <summary>
+ /// 绂佺敤
+ /// </summary>
+ [Description("绂佺敤")]
+ Disable = 1
+ }
+
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemRepository/IDt_StationinfoRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemRepository/IDt_StationinfoRepository.cs"
new file mode 100644
index 0000000..8af164d
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemRepository/IDt_StationinfoRepository.cs"
@@ -0,0 +1,14 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using WIDESEAWCS_Core.BaseRepository;
+using WIDESEAWCS_Model.Models;
+
+namespace WIDESEAWCS_ISystemRepository
+{
+ public interface IDt_StationinfoRepository : IRepository<Dt_Stationinfo>
+ {
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/IDt_StationinfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/IDt_StationinfoService.cs"
new file mode 100644
index 0000000..7be8ec8
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ISystemServices/IDt_StationinfoService.cs"
@@ -0,0 +1,14 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using WIDESEAWCS_Core.BaseServices;
+using WIDESEAWCS_Model.Models;
+
+namespace WIDESEAWCS_ISystemServices
+{
+ public interface IDt_StationinfoService : IService<Dt_Stationinfo>
+ {
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs"
index b80d4c2..e825057 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_ITaskInfoService/ITaskCZService.cs"
@@ -43,11 +43,24 @@
/// <returns></returns>
public Task<WebResponseContent> FinishTask(CZTaskFinshDto dto);
/// <summary>
- /// 杈撻�佺嚎鍥炴祦
+ /// 绌烘墭鍥炴祦
/// </summary>
/// <param name="dto"></param>
/// <returns></returns>
public Task<WebResponseContent> EmptyTask(SaveModel saveModel);
-
+ /// <summary>
+ /// 鐑樼儰鍑烘枡
+ /// </summary>
+ /// <param name="OutBoundTask"></param>
+ /// <returns></returns>
+ public Task<WebResponseContent> OutBoundTask(string sourceAddress);
+
+ /// <summary>
+ /// 鐑樼儰鍥炵倝
+ /// </summary>
+ /// <param name="OutBoundTask"></param>
+ /// <returns></returns>
+ public Task<WebResponseContent> OutBoundTasks(SaveModel saveModel);
+
}
}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Model/Models/System/Dt_Stationinfo.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Model/Models/System/Dt_Stationinfo.cs"
new file mode 100644
index 0000000..ca842e8
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Model/Models/System/Dt_Stationinfo.cs"
@@ -0,0 +1,81 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.ComponentModel.DataAnnotations;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using Magicodes.ExporterAndImporter.Core;
+using SqlSugar;
+using WIDESEAWCS_Core.DB.Models;
+using WIDESEAWCS_Core.Tenants;
+
+namespace WIDESEAWCS_Model.Models
+{
+ [SugarTable("Dt_Stationinfo", "绔欑偣淇℃伅"), MultiTenant]
+ public class Dt_Stationinfo : BaseEntity
+ {
+ /// <summary>
+ /// 涓婚敭
+ /// </summary>
+ [ImporterHeader(Name = "涓婚敭")]
+ [ExporterHeader(DisplayName = "涓婚敭")]
+ [SugarColumn(IsPrimaryKey = true, IsIdentity = true, ColumnDescription = "涓婚敭")]
+ public int id { get; set; }
+ /// <summary>
+ /// 缂撳瓨鏋剁紪鍙�
+ /// </summary>
+ [ImporterHeader(Name = "缂撳瓨鏋剁紪鍙�")]
+ [ExporterHeader(DisplayName = "缂撳瓨鏋剁紪鍙�")]
+ [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "缂撳瓨鏋剁紪鍙�")]
+ public string StationCode { get; set; }
+ /// <summary>
+ /// 缂撳瓨鏋剁姸鎬�
+ /// </summary>
+ [ImporterHeader(Name = "缂撳瓨鏋剁姸鎬�")]
+ [ExporterHeader(DisplayName = "缂撳瓨鏋剁姸鎬�")]
+ [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "缂撳瓨鏋剁姸鎬�")]
+ public int Location_state { get; set; }
+ /// <summary>
+ /// 鍖哄煙
+ /// </summary>
+ [ImporterHeader(Name = "鍖哄煙")]
+ [ExporterHeader(DisplayName = "鍖哄煙")]
+ [SugarColumn(IsNullable = false, Length = 20, ColumnDescription = "鍖哄煙")]
+ public string Area { get; set; }
+
+ /// <summary>
+ /// 鏄惁鍚敤
+ /// </summary>
+ public bool Enable { get; set; }
+ /// <summary>
+ /// 鏈�鍚庢斁鍏ユ垨鍙栬蛋鏃堕棿
+ /// </summary>
+ [ImporterHeader(Name = "鏈�鍚庢斁鍏ユ垨鍙栬蛋鏃堕棿")]
+ [ExporterHeader(DisplayName = "鏈�鍚庢斁鍏ユ垨鍙栬蛋鏃堕棿")]
+ [SugarColumn(IsNullable = true, ColumnDescription = "鏈�鍚庢斁鍏ユ垨鍙栬蛋鏃堕棿")]
+ public DateTime? LastUpdateTime { get; set; }
+
+ /// <summary>
+ /// 澶囨敞
+ /// </summary>
+ [ImporterHeader(Name = "澶囨敞")]
+ [ExporterHeader(DisplayName = "澶囨敞")]
+ [SugarColumn(IsNullable = true, Length = 255, ColumnDescription = "澶囨敞")]
+ public string Remark { get; set; }
+ /// <summary>
+ /// 鍒涘缓鑰�
+ /// </summary>
+ [ImporterHeader(IsIgnore = true)]
+ [ExporterHeader(DisplayName = "鍒涘缓鑰�")]
+ [SugarColumn(IsNullable = false, Length = 50, IsOnlyIgnoreUpdate = true, ColumnDescription = "鍒涘缓鑰�")]
+ public string Creater { get; set; }
+
+ /// <summary>
+ /// 鍒涘缓鏃堕棿
+ /// </summary>
+ [ImporterHeader(IsIgnore = true)]
+ [ExporterHeader(DisplayName = "鍒涘缓鏃堕棿")]
+ [SugarColumn(IsNullable = false, IsOnlyIgnoreUpdate = true, ColumnDescription = "鍒涘缓鏃堕棿")]
+ public DateTime CreateDate { get; set; } = DateTime.Now;
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs"
index 7e6581f..ff5666d 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/PDA/PDAController.cs"
@@ -49,5 +49,16 @@
{
return _taskCZService.EmptyTask(saveModel);
}
+ [HttpPost, Route("OutBoundTask"), AllowAnonymous]
+ public Task<WebResponseContent> OutBoundTask([FromBody] string sourceAddress)
+ {
+ return _taskCZService.OutBoundTask(sourceAddress);
+ }
+
+ [HttpPost, Route("OutBoundTasks"), AllowAnonymous]
+ public Task<WebResponseContent> OutBoundTasks([FromBody] SaveModel saveModel)
+ {
+ return _taskCZService.OutBoundTasks(saveModel);
+ }
}
}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Dt_StationinfoController.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Dt_StationinfoController.cs"
new file mode 100644
index 0000000..d5451b9
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Server/Controllers/System/Dt_StationinfoController.cs"
@@ -0,0 +1,17 @@
+锘縰sing Microsoft.AspNetCore.Http;
+using Microsoft.AspNetCore.Mvc;
+using WIDESEAWCS_Core.BaseController;
+using WIDESEAWCS_ISystemServices;
+using WIDESEAWCS_Model.Models;
+
+namespace WIDESEAWCS_Server.Controllers.System
+{
+ [Route("api/Dt_Stationinfo")]
+ [ApiController]
+ public class Dt_StationinfoController : ApiBaseController<IDt_StationinfoService, Dt_Stationinfo>
+ {
+ public Dt_StationinfoController(IDt_StationinfoService service) : base(service)
+ {
+ }
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemRepository/Dt_StationinfoRepository.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemRepository/Dt_StationinfoRepository.cs"
new file mode 100644
index 0000000..aa5c0ea
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemRepository/Dt_StationinfoRepository.cs"
@@ -0,0 +1,18 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using WIDESEAWCS_Core.BaseRepository;
+using WIDESEAWCS_ISystemRepository;
+using WIDESEAWCS_Model.Models;
+
+namespace WIDESEAWCS_SystemRepository
+{
+ public class Dt_StationinfoRepository : RepositoryBase<Dt_Stationinfo>, IDt_StationinfoRepository
+ {
+ public Dt_StationinfoRepository(IUnitOfWorkManage unitOfWorkManage) : base(unitOfWorkManage)
+ {
+ }
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Dt_StationinfoService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Dt_StationinfoService.cs"
new file mode 100644
index 0000000..0c7e906
--- /dev/null
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_SystemServices/Dt_StationinfoService.cs"
@@ -0,0 +1,19 @@
+锘縰sing System;
+using System.Collections.Generic;
+using System.Linq;
+using System.Text;
+using System.Threading.Tasks;
+using WIDESEAWCS_Core.BaseServices;
+using WIDESEAWCS_ISystemRepository;
+using WIDESEAWCS_ISystemServices;
+using WIDESEAWCS_Model.Models;
+
+namespace WIDESEAWCS_SystemServices
+{
+ public class Dt_StationinfoService : ServiceBase<Dt_Stationinfo, IDt_StationinfoRepository>, IDt_StationinfoService
+ {
+ public Dt_StationinfoService(IDt_StationinfoRepository BaseDal) : base(BaseDal)
+ {
+ }
+ }
+}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs"
index ea6bac0..b0f3247 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/TaskCZService.cs"
@@ -26,18 +26,26 @@
using WIDESEAWCS_ITaskInfoRepository;
using WIDESEAWCS_ITaskInfoService;
using WIDESEAWCS_Model.Models;
-
+using WIDESEAWCS_ISystemServices;
+using WIDESEAWCS_ISystemRepository;
+using WIDESEA_Common;
+using WIDESEA_Core.Enums;
+using SqlSugar.Extensions;
namespace WIDESEAWCS_TaskInfoService
{
public class TaskCZService : ServiceBase<DtCZTask, ITaskCZRepository>, ITaskCZService
{
private readonly ITaskRepository _taskRepository;
+ private readonly ITaskService _taskService;
private readonly ITaskCZDetailsRepository _detailsRepository;
+ private readonly IDt_StationinfoRepository _stationinfoRepository;
- public TaskCZService(ITaskCZRepository BaseDal, ITaskRepository taskRepository, ITaskCZDetailsRepository detailsRepository) : base(BaseDal)
+ public TaskCZService(ITaskCZRepository BaseDal, IDt_StationinfoRepository stationinfoRepository, ITaskService taskService, ITaskRepository taskRepository, ITaskCZDetailsRepository detailsRepository) : base(BaseDal)
{
_taskRepository = taskRepository;
_detailsRepository = detailsRepository;
+ _taskService = taskService;
+ _stationinfoRepository = stationinfoRepository;
}
public Task<WebResponseContent> AddTaskCZAsync(CZTaskDto dto)
@@ -165,7 +173,7 @@
}
/// <summary>
- /// 杈撻�佺嚎鍥炴祦
+ /// 绌烘墭鍥炴祦
/// </summary>
/// <param name="saveModel"></param>
/// <returns></returns>
@@ -174,23 +182,196 @@
WebResponseContent webResponseContent = new WebResponseContent();
try
{
+ //閫氳繃绔欑偣琛ㄥ垽鏂紦瀛樻灦鏄偅涓尯鍩熷幓閭f潯杈撻�佺嚎鍥炴祦鍙c�傘�傘�傘�傘�傘�傘�傘�傘�傘�傘��
string Saddress = saveModel.MainData["sourceAddress"].ToString();
string Taddress = saveModel.MainData["targetAddress"].ToString();
- string Exception = saveModel.MainData["Exception"].ToString();
- Dt_Task task = _taskRepository.QueryFirst(x => x.SourceAddress == Saddress && x.TaskState == (int)TaskInStatusEnum.InPending && x.TargetAddress == "WaitBind");
- if (task == null)
+ Dt_Task task = _taskRepository.QueryFirst(x => x.SourceAddress == Saddress);
+ if (task != null)
{
- webResponseContent.Error("浠诲姟涓嶅瓨鍦紒");
+ webResponseContent.Error("姝ょ紦瀛樻灦宸插瓨鍦ㄤ换鍔★紒");
return Task.FromResult(webResponseContent);
}
- task.TargetAddress = Taddress;
- task.ExceptionMessage = Exception;
- task.TaskState = (int)TaskInStatusEnum.InNew;
- var isTrue = _taskRepository.UpdateData(task);
- if (isTrue)
+ Dt_Stationinfo Stationinfo = _stationinfoRepository.QueryFirst(x => x.StationCode == Saddress);
+
+ Dt_Task dt_Task = new Dt_Task();
+ dt_Task.TaskNum = _taskService.GetTaskNum();
+ dt_Task.CreateDate = DateTime.Now;
+ dt_Task.Creater = "system";
+ dt_Task.CurrentAddress = Saddress;
+ dt_Task.SourceAddress = Saddress;
+ dt_Task.TaskState = (int)TaskInStatusEnum.InNew;
+ dt_Task.TaskType = (int)TaskOutboundTypeEnum.Outbound;
+ dt_Task.Grade = 1;
+ dt_Task.PalletCode = "";
+ if (Stationinfo.Area == "姝f瀬")
{
- webResponseContent.OK("浠诲姟涓嬪彂鎴愬姛锛�");
+ dt_Task.TargetAddress = "姝f瀬鍥炴祦杈撻�佺嚎鍏ュ彛";
}
+ else
+ {
+ dt_Task.TargetAddress = "璐熸瀬鍥炴祦杈撻�佺嚎鍏ュ彛";
+ }
+ dt_Task.NextAddress = dt_Task.TargetAddress;
+ dt_Task.Barcode = "";
+ dt_Task.Roadway = "AGV";
+ dt_Task.WMSId = 0;
+ dt_Task.Remark = "绌烘墭鍥炴祦";
+
+ Dt_Task dt_Tasks = new Dt_Task();
+ dt_Tasks.TaskNum = _taskService.GetTaskNum();
+ dt_Tasks.CreateDate = DateTime.Now;
+ dt_Tasks.Creater = "system";
+ if (Stationinfo.Area == "姝f瀬")
+ {
+ dt_Task.CurrentAddress = "姝f瀬鍥炴祦杈撻�佺嚎鍑哄彛";
+ }
+ else
+ {
+ dt_Task.CurrentAddress = "璐熸瀬鍥炴祦杈撻�佺嚎鍑哄彛";
+ }
+ dt_Tasks.SourceAddress = dt_Task.CurrentAddress;
+ dt_Tasks.TaskState = (int)TaskInStatusEnum.InPending;
+ dt_Tasks.TaskType = (int)TaskOutboundTypeEnum.Outbound;
+ dt_Tasks.Grade = 1;
+ dt_Tasks.PalletCode = "";
+ dt_Tasks.TargetAddress = Taddress;
+ dt_Tasks.NextAddress = Taddress;
+ dt_Tasks.Barcode = "";
+ dt_Tasks.Roadway = "AGV";
+ dt_Tasks.WMSId = 0;
+ dt_Tasks.Remark = "绌烘墭鍥炴祦";
+
+ var isTrue = _taskRepository.AddData(dt_Task);
+ var isTrue1 = _taskRepository.AddData(dt_Tasks);
+ webResponseContent.OK("浠诲姟涓嬪彂鎴愬姛锛�");
+ }
+ catch (Exception ex)
+ {
+ webResponseContent.Error(ex.Message);
+ }
+ return Task.FromResult(webResponseContent);
+ }
+ /// <summary>
+ /// 鐑樼儰鍑烘枡
+ /// </summary>
+ /// <param name="sourceAddress"></param>
+ /// <returns></returns>
+ public Task<WebResponseContent> OutBoundTask(string sourceAddress)
+ {
+ WebResponseContent webResponseContent = new WebResponseContent();
+ try
+ {
+ Dt_Task task = _taskRepository.QueryFirst(x => x.SourceAddress == sourceAddress);
+ if (task != null)
+ {
+ webResponseContent.Error("璧风偣宸插瓨鍦ㄤ换鍔★紒");
+ return Task.FromResult(webResponseContent);
+ }
+ Dt_Stationinfo stationinfo = _stationinfoRepository.QueryFirst(x => x.Location_state == LocationStatusEnum.Free.ObjToInt());
+ if (stationinfo == null)
+ {
+ webResponseContent.Error("鏈壘鍒扮┖缂撳瓨鏋舵斁缃紒");
+ return Task.FromResult(webResponseContent);
+ }
+ Dt_Task tasks = _taskRepository.QueryFirst(x => x.SourceAddress == stationinfo.StationCode || x.TargetAddress == stationinfo.StationCode);
+ if (tasks != null)
+ {
+ webResponseContent.Error("鏈壘鍒板彲鐢ㄧ紦瀛樻灦");
+ return Task.FromResult(webResponseContent);
+ }
+ Dt_Task dt_Task = new Dt_Task()
+ {
+ TaskNum = _taskService.GetTaskNum(),
+ CreateDate = DateTime.Now,
+ Creater = "system",
+ CurrentAddress = sourceAddress,
+ SourceAddress = sourceAddress,
+ TaskState = (int)TaskInStatusEnum.InNew,
+ TaskType = (int)TaskOutboundTypeEnum.Outbound,
+ Grade = 1,
+ PalletCode = "",
+ TargetAddress = stationinfo.StationCode,
+ NextAddress = stationinfo.StationCode,
+ Barcode = "",
+ Roadway = "AGV",
+ WMSId = 0,
+ Remark = "绌烘墭鍥炴祦"
+ };
+ var isTrue = _taskRepository.AddData(dt_Task);
+ webResponseContent.OK("浠诲姟涓嬪彂鎴愬姛锛�");
+ }
+ catch (Exception ex)
+ {
+ webResponseContent.Error(ex.Message);
+ }
+ return Task.FromResult(webResponseContent);
+ }
+ /// <summary>
+ /// 鐑樼儰鍥炵倝
+ /// </summary>
+ /// <param name="saveModel"></param>
+ /// <returns></returns>
+ public Task<WebResponseContent> OutBoundTasks(SaveModel saveModel)
+ {
+ WebResponseContent webResponseContent = new WebResponseContent();
+ try
+ {
+ //閫氳繃绔欑偣琛ㄥ垽鏂紦瀛樻灦鏄偅涓尯鍩熷幓閭f潯杈撻�佺嚎鍥炴祦鍙c�傘�傘�傘�傘�傘�傘�傘�傘�傘�傘��
+ string Saddress = saveModel.MainData["sourceAddress"].ToString();
+ string Taddress = saveModel.MainData["targetAddress"].ToString();
+
+ Dt_Stationinfo Stationinfo = _stationinfoRepository.QueryFirst(x => x.StationCode == Saddress);
+
+ Dt_Task dt_Task = new Dt_Task();
+ dt_Task.TaskNum = _taskService.GetTaskNum();
+ dt_Task.CreateDate = DateTime.Now;
+ dt_Task.Creater = "system";
+ dt_Task.CurrentAddress = Saddress;
+ dt_Task.SourceAddress = Saddress;
+ dt_Task.TaskState = (int)TaskInStatusEnum.InNew;
+ dt_Task.TaskType = (int)TaskOutboundTypeEnum.Outbound;
+ dt_Task.Grade = 1;
+ dt_Task.PalletCode = "";
+ if (Stationinfo.Area == "姝f瀬")
+ {
+ dt_Task.TargetAddress = "姝f瀬鍥炴祦杈撻�佺嚎鍏ュ彛";
+ }
+ else
+ {
+ dt_Task.TargetAddress = "璐熸瀬鍥炴祦杈撻�佺嚎鍏ュ彛";
+ }
+ dt_Task.NextAddress = dt_Task.TargetAddress;
+ dt_Task.Barcode = "";
+ dt_Task.Roadway = "AGV";
+ dt_Task.WMSId = 0;
+ dt_Task.Remark = "鐑樼儰鍥炵倝";
+
+ Dt_Task dt_Tasks = new Dt_Task();
+ dt_Tasks.TaskNum = _taskService.GetTaskNum();
+ dt_Tasks.CreateDate = DateTime.Now;
+ dt_Tasks.Creater = "system";
+ if (Stationinfo.Area == "姝f瀬")
+ {
+ dt_Task.CurrentAddress = "姝f瀬鍥炴祦杈撻�佺嚎鍑哄彛";
+ }
+ else
+ {
+ dt_Task.CurrentAddress = "璐熸瀬鍥炴祦杈撻�佺嚎鍑哄彛";
+ }
+ dt_Tasks.SourceAddress = dt_Task.CurrentAddress;
+ dt_Tasks.TaskState = (int)TaskInStatusEnum.InPending;
+ dt_Tasks.TaskType = (int)TaskOutboundTypeEnum.Outbound;
+ dt_Tasks.Grade = 1;
+ dt_Tasks.PalletCode = "";
+ dt_Tasks.TargetAddress = Taddress;
+ dt_Tasks.NextAddress = Taddress;
+ dt_Tasks.Barcode = "";
+ dt_Tasks.Roadway = "AGV";
+ dt_Tasks.WMSId = 0;
+ dt_Tasks.Remark = "鐑樼儰鍥炵倝";
+ var isTrue = _taskRepository.AddData(dt_Task);
+ var isTrue1 = _taskRepository.AddData(dt_Tasks);
+ webResponseContent.OK("浠诲姟涓嬪彂鎴愬姛锛�");
}
catch (Exception ex)
{
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/WIDESEAWCS_TaskInfoService.csproj" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/WIDESEAWCS_TaskInfoService.csproj"
index f1fe745..37fa1d4 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/WIDESEAWCS_TaskInfoService.csproj"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_TaskInfoService/WIDESEAWCS_TaskInfoService.csproj"
@@ -8,6 +8,7 @@
<ItemGroup>
<ProjectReference Include="..\WIDESEAWCS_BasicInfoService\WIDESEAWCS_BasicInfoService.csproj" />
+ <ProjectReference Include="..\WIDESEAWCS_ISystemServices\WIDESEAWCS_ISystemServices.csproj" />
<ProjectReference Include="..\WIDESEAWCS_ITaskInfoService\WIDESEAWCS_ITaskInfoService.csproj" />
</ItemGroup>
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/CommonAGVJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/CommonAGVJob.cs"
index 316b9fa..6673757 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/CommonAGVJob.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/CommonAGVJob.cs"
@@ -26,8 +26,9 @@
public Task Execute(IJobExecutionContext context)
{
AGV agv = (AGV)context.JobDetail.JobDataMap.Get("JobParams");
- SendTaskAGV.SendAGVTask(agv, _taskRepository);
- UpdateTaskAGV.UpdateTask(agv, _taskRepository, _taskCZRepository, _detailsRepository);
+ //SendTaskAGV.SendAGVTask1(_taskRepository);
+ //SendTaskAGV.SendAGVTask(agv, _taskRepository);
+ //UpdateTaskAGV.UpdateTask(agv, _taskRepository, _taskCZRepository, _detailsRepository);
return Task.CompletedTask;
}
}
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/SendTaskAGV.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/SendTaskAGV.cs"
index ffe6c58..4814dca 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/SendTaskAGV.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/AGVJob/SendTaskAGV.cs"
@@ -1,5 +1,6 @@
锘縰sing System.Diagnostics;
using System.Text;
+using Microsoft.Data.SqlClient;
using WIDESEAWCS_Common.AGVEnum;
using WIDESEAWCS_Common.TaskEnum;
using WIDESEAWCS_ITaskInfoRepository;
@@ -14,157 +15,46 @@
private static bool isTrue1 = false;
private static string name1 = "";
- public static void SendAGVTask1(AGV agv, ITaskRepository _taskRepository)
+ public static void SendAGVTask1(ITaskRepository _taskRepository)
{
- //TODO: Implement sending task to AGV
- try
- {
- if (agv == null)
- {
- return;
- }
- var taskInteractiveR = agv.DeviceProDTOs.Where(r => r.DeviceProParamName == TaskDBName.taskInteractiveR.ToString()).FirstOrDefault().DeviceProAddress;
- var taskInteractiveW = agv.DeviceProDTOs.Where(r => r.DeviceProParamName == TaskDBName.taskInteractiveW.ToString()).FirstOrDefault().DeviceProAddress;
- var resetTaskW = agv.DeviceProDTOs.Where(r => r.DeviceProParamName == TaskDBName.resetTaskInteractiveW.ToString()).FirstOrDefault().DeviceProAddress;
- var resetTaskInteractiveR = agv.DeviceProDTOs.Where(r => r.DeviceProParamName == TaskDBName.resetTaskInteractiveR.ToString()).FirstOrDefault().DeviceProAddress;
- var taskID = agv.DeviceProDTOs.Where(r => r.DeviceProParamName == TaskDBName.taskID.ToString()).FirstOrDefault().DeviceProAddress;
+ // 杩炴帴瀛楃涓� - 鏍规嵁浣犵殑鏈嶅姟鍣ㄤ俊鎭慨鏀�
+ string connectionString = "Data Source=.;Initial Catalog=WIDESEAWCS_GanFengLiYeNew;User ID=sa;Password=sa123456;Integrated Security=False;Connect Timeout=30;Encrypt=False;TrustServerCertificate=False;ApplicationIntent=ReadWrite;MultiSubnetFailover=False";
+ List<Dt_Task> dt_Tasks = _taskRepository.QueryData(x => x.TaskState == (int)TaskInStatusEnum.InNew);
+ foreach (Dt_Task task in dt_Tasks)
+ {
+ // 瑕佹彃鍏ョ殑SQL璇彞
+ string insertSql = "INSERT INTO Dt_Stationinfo (StationCode, Location_state,Area,Enable,LastUpdateTime,Remark) VALUES (@StationCode, @Location_state,@Area,@Enable,@LastUpdateTime,@Remark)";
- int TaskInteractive = agv.Communicator.Read<int>(taskInteractiveR);//1鏀跺埌
- int TaskInteractiveW = agv.Communicator.Read<int>(taskInteractiveW);//0鍒濆/1涓嬪彂/2鍙栨秷/3鏇存敼
- int resetTaskInteractiveW = agv.Communicator.Read<int>(resetTaskW);
- int resetTaskInteractiver = agv.Communicator.Read<int>(resetTaskInteractiveR);
- if (isTrue1 && name1 == agv.DeviceName)
+ try
{
- if (TaskInteractiveW != 0 || resetTaskInteractiveW != 0 || TaskInteractive != 0)
+ using (SqlConnection connection = new SqlConnection(connectionString))
{
- agv.Communicator.Write(resetTaskW, 1);
- Task.Delay(2000).Wait();
- resetTaskInteractiveW = agv.Communicator.Read<int>(resetTaskW);
- if (resetTaskInteractiveW == 1)
+ connection.Open();
+
+ using (SqlCommand command = new SqlCommand(insertSql, connection))
{
- agv.Communicator.Write(resetTaskW, 0);
- agv.Communicator.Write(taskInteractiveW, 0);
- Task.Delay(2000).Wait();
- }
- return;
- }
- else
- {
- isTrue1 = false;
- name1 = "";
- }
- }
- if (resetTaskInteractiver == 1)
- {
- agv.Communicator.Write(taskInteractiveW, 0);
- for (int i = 0; i < 5; i++)
- {
- Thread.Sleep(300);
- var agvnumber = Convert.ToInt32(agv.Communicator.Read<int>(taskInteractiveW));
- if (agvnumber != 0)
- {
- agv.Communicator.Write(taskInteractiveW, 0);
- }
- else
- {
- break;
+ // 娣诲姞鍙傛暟闃叉SQL娉ㄥ叆
+ command.Parameters.AddWithValue("StationCode", task.TaskNum);
+ command.Parameters.AddWithValue("Location_state", task.TaskNum);
+ command.Parameters.AddWithValue("Area", task.Roadway);
+ command.Parameters.AddWithValue("Enable", task.TaskNum);
+ command.Parameters.AddWithValue("LastUpdateTime", DateTime.Now);
+ command.Parameters.AddWithValue("Remark", task.Roadway);
+ command.Parameters.AddWithValue("Creater", "WCS");
+ command.Parameters.AddWithValue("CreateDate", DateTime.Now);
+
+ int rowsAffected = command.ExecuteNonQuery();
+ Console.WriteLine($"鎴愬姛鎻掑叆 {rowsAffected} 琛屾暟鎹�");
}
}
}
- if (0 == TaskInteractive && TaskInteractiveW == 0)
+ catch (Exception ex)
{
- Dt_Task agvTask = _taskRepository.QueryData(r => r.TaskState == (int)TaskInStatusEnum.InNew && r.Roadway == agv.DeviceName && r.TaskType == (int)TaskOutboundTypeEnum.Outbound).OrderBy(r => r.CreateDate).OrderByDescending(r => r.Grade).FirstOrDefault();
- if (null != agvTask)
- {
- //鍐欏叆浠诲姟淇℃伅
- string rel = TaskWrite(agv, agvTask, AGVJobEnum.newTaskEnum);
- Thread.Sleep(1000);
- string taskId = agv.Communicator.Read<string>(taskID).ToString();
- if (taskId != agvTask.TaskNum.ToString())
- {
- isTrue1 = true;
- name1 = agv.DeviceName;
- //WriteLog.Info("SendAGVTask").Write("缁橝GV鍐欏叆浠诲姟澶辫触," + agvTask.agv_tasknum + DateTime.Now, "SendAGVTask");
- throw new Exception(string.Format("缁橝GV鍐欏叆浠诲姟澶辫触,浠诲姟鍙穥0}", agvTask.TaskNum));
- }
- if (string.IsNullOrEmpty(rel))
- {
- //鍐欏叆浠诲姟纭1
- agv.Communicator.Write(taskInteractiveW, 1);
- Thread.Sleep(1000);
- //璇诲彇AGV淇″彿
- int ReadTask_1_OK = agv.Communicator.Read<int>(taskInteractiveR);
- if (ReadTask_1_OK == 1)
- {
- //鍐欏叆WCS纭淇″彿0
- agv.Communicator.Write(taskInteractiveW, 0);
- Thread.Sleep(2000);
- //璇诲彇AGV淇″彿鏄惁涓�0
- int ReadTask_0_OK = agv.Communicator.Read<int>(taskInteractiveR);
- if (ReadTask_0_OK == 0)
- {
- int nextStatus = agvTask.TaskState.GetNextNotCompletedStatus<TaskInStatusEnum>();
- agvTask.TaskState = nextStatus;
- agvTask.Dispatchertime = DateTime.Now;
- _taskRepository.UpdateData(agvTask);
- // 涓婁紶AGV杩愯鏁版嵁 by xiaoyang
- //SendMESTask.SendMesTask(agvTask, 0);
- }
- else
- {
- isTrue1 = true;
- name1 = agv.DeviceName;
- throw new Exception(string.Format("缁橝GV鍐欏叆浠诲姟纭0澶辫触,浠诲姟鍙穥0}", agvTask.TaskNum));
- }
- }
- else if (ReadTask_1_OK == 11)
- {
- agv.Communicator.Write(taskInteractiveW, 0);
- Thread.Sleep(2000);
- int ReadTask_0_Error = agv.Communicator.Read<int>(taskInteractiveR);
- if (ReadTask_0_Error == 0)
- {
- int nextStatus = agvTask.TaskState.GetNextNotCompletedStatus<TaskOutStatusEnum>();
- agvTask.TaskState = nextStatus;
- agvTask.Dispatchertime = DateTime.Now;
- _taskRepository.UpdateData(agvTask);
- }
- else
- {
- isTrue1 = true;
- name1 = agv.DeviceName;
- throw new Exception(string.Format("缁橝GV鍐欏叆浠诲姟寮傚父纭0澶辫触,浠诲姟鍙穥0}", agvTask.TaskNum));
- }
- }
- else
- {
- isTrue1 = true;
- name1 = agv.DeviceName;
- throw new Exception(string.Format("缁橝GV鍐欏叆浠诲姟纭1澶辫触,浠诲姟鍙穥0}", agvTask.TaskNum));
- }
- }
- else
- {
- isTrue1 = true;
- name1 = agv.DeviceName;
- throw new Exception(string.Format("缁橝GV鍐欏叆浠诲姟澶辫触,浠诲姟鍙穥0}" + rel, agvTask.TaskNum));
- }
- }
+ Console.WriteLine($"鍙戠敓閿欒: {ex.Message}");
}
}
- catch (Exception ex)
- {
- StackTrace sta = new StackTrace(ex, true);
- StackTrace st = new StackTrace(new StackFrame(true));
- StackFrame sf = sta.GetFrame(0);
- //WriteLog.Info("SendAGVTask").Write(ex.Message + "琛屽彿" + sf.GetFileLineNumber(), "SendAGVTask");
- }
- finally
- {
- // WriteLog.Info("SendAGVTask").Write(agv.PLCName+"\t"+DateTime.Now, "SendAGVTask");
- Interlocked.Exchange(ref _readSendAGVTaskSignalso, 0);
- }
+
}
public static void SendAGVTask(AGV agv, ITaskRepository _taskRepository)
diff --git "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs" "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
index 448e4f4..227329f 100644
--- "a/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
+++ "b/\344\273\243\347\240\201\347\256\241\347\220\206/NEWCode/WIDESEAWCS_Server/WIDESEAWCS_Tasks/ConveyorLineJob/CommonConveyorLineJob.cs"
@@ -55,7 +55,6 @@
}
public Task Execute(IJobExecutionContext context)
-
{
try
{
@@ -81,7 +80,7 @@
};
// 澶勭悊瀹炵洏鍏ュ簱璇锋眰
- ProcessRequests(conveyorLine, requests, "涓嬬嚎璇锋眰鍏ュ簱");
+ //ProcessRequests(conveyorLine, requests, "涓嬬嚎璇锋眰鍏ュ簱");
// 澶勭悊绌虹洏鍥炴祦璇锋眰
ProcessKpRequests(conveyorLine, requestsKP);
@@ -162,18 +161,22 @@
Dt_Task task = null;
if (isUpRequest)
{
- task = CreateTask(fromAdd, "WaitBind", "姝f瀬鐗╂祦绾�002鐨勪笂鏂欒姹�", "绌烘墭鐩�", taskType);
+ List<Dt_Task> dt_Task = _taskRepository.QueryData(x => x.SourceAddress == fromAdd && x.TaskState == (int)TaskInStatusEnum.InPending);
+ if (dt_Task.Count < 0) { continue; }
+ var tasks = dt_Task.Where(x => x.SourceAddress == fromAdd).OrderBy(t => t.CreateDate).First();
+ tasks.TaskState = (int)TaskInStatusEnum.InNew;
+ _taskService.UpdateData(tasks);
}
- else if (isGMRequest && isGMState == 1)
- {
- task = CreateTask(fromAdd, "WaitBind", "姝f瀬鐗╂祦绾�002鐨勪笂鏂欒姹�", "闅旇啘绌烘墭鐩�", taskType);
- }
+ //else if (isGMRequest && isGMState == 1)
+ //{
+ // task = CreateTask(fromAdd, "WaitBind", "姝f瀬鐗╂祦绾�002鐨勪笂鏂欒姹�", "闅旇啘绌烘墭鐩�", taskType);
+ //}
- // 娣诲姞浠诲姟鍒颁换鍔¤〃
- if (task != null)
- {
- _taskRepository.AddData(task);
- }
+ //// 娣诲姞浠诲姟鍒颁换鍔¤〃
+ //if (task != null)
+ //{
+ // _taskRepository.AddData(task);
+ //}
}
}
--
Gitblit v1.9.3