|
|
@@ -1,5 +1,5 @@
|
|
|
<template>
|
|
|
- <z-paging ref="paging" v-model="list" bgColor="#f7f7f7" @query="query" safe-area-inset-bottom>
|
|
|
+ <z-paging ref="paging" v-model="list" bgColor="#f7f7f7" @query="query" safe-area-inset-bottom hide-no-more-inside>
|
|
|
<template #top>
|
|
|
<up-navbar title="加工及包装赋码任务" :fixed="false"> </up-navbar>
|
|
|
</template>
|
|
|
@@ -23,59 +23,128 @@
|
|
|
</view>
|
|
|
</view>
|
|
|
<view class="pd-24">
|
|
|
- <view class="bg-#fff b-radius pd-24">
|
|
|
- <view class="mb-10">
|
|
|
- <span class="f-s-34 c-#333 f-w-500 mr-10">三七</span>
|
|
|
- <span class="f-s-24 c-#666">种子</span>
|
|
|
- </view>
|
|
|
- <view class="pd2-4-0 f-s-28">
|
|
|
- <span class="c-#666">加工批号:</span>
|
|
|
- <span class="c-#333 f-w-500">1231312312312312</span>
|
|
|
- </view>
|
|
|
- <view class="pd2-4-0 f-s-28">
|
|
|
- <span class="c-#666">执行标准:</span>
|
|
|
- <span class="c-#333 f-w-500"></span>
|
|
|
- </view>
|
|
|
- <view class="pd2-4-0 f-s-28">
|
|
|
- <span class="c-#666">加工工艺:</span>
|
|
|
- <span class="c-#333 f-w-500"></span>
|
|
|
- </view>
|
|
|
- <view class="pd2-4-0 f-s-28">
|
|
|
- <span class="c-#666">加工负责人:</span>
|
|
|
- <span class="c-#333 f-w-500"></span>
|
|
|
- </view>
|
|
|
- <view class="radius-10 bg-#f7f7f7 d-flex">
|
|
|
- <view class="bg-#EDF7F0 w-50 h-110 d-flex flex-cln a-c j-c c-primary f-w-5 f-s-24">
|
|
|
- <view class="">原</view>
|
|
|
- <view class="">料</view>
|
|
|
+ <template v-for="(item, index) in list" :key="index">
|
|
|
+ <view class="bg-#fff b-radius pd-24 p-rtv">
|
|
|
+ <view v-if="+item?.processType == 1 && +item?.stockType == 1" class="bg-#91C747 c-#fff f-w-5 pl-10 pr-10 f-s-20" style="border-radius: 16rpx 0 16rpx 0; width: max-content; position: relative; top: -24rpx; left: -24rpx">种子初加工</view>
|
|
|
+ <view v-if="+item?.processType == 1 && +item?.stockType == 2" class="bg-#C7A262 c-#fff f-w-5 pl-10 pr-10 f-s-20" style="border-radius: 16rpx 0 16rpx 0; width: max-content; position: relative; top: -24rpx; left: -24rpx">药材初加工</view>
|
|
|
+ <view v-if="+item?.processType == 2" class="bg-#37A954 c-#fff f-w-5 pl-10 pr-10 f-s-20" style="border-radius: 16rpx 0 16rpx 0; width: max-content; position: relative; top: -24rpx; left: -24rpx">趁鲜切制</view>
|
|
|
+ <view class="mb-10">
|
|
|
+ <span class="f-s-34 c-#333 f-w-500 mr-10">{{ item?.variety }}</span>
|
|
|
+ <span class="f-s-24 c-#666" v-if="+item?.stockType == 1">{{ selectDictLabel(pt_stock_type, item?.stockType) }}</span>
|
|
|
+ </view>
|
|
|
+ <view class="pd2-4-0 f-s-28">
|
|
|
+ <span class="c-#666">加工批号:</span>
|
|
|
+ <span class="c-#333 f-w-500">{{ item?.processCode }}</span>
|
|
|
</view>
|
|
|
- <view class="bg-#F5FBF7 flex1 d-flex a-c">
|
|
|
- <view class="d-flex flex1 f-s-26">
|
|
|
- <view class="c-#999 ml-16"> 暂无关联原料信息 </view>
|
|
|
- <view class="flex1"></view>
|
|
|
- <view class="c-primary d-flex a-c">
|
|
|
- <view>去关联</view>
|
|
|
- <up-icon name="arrow-right" size="26rpx"></up-icon>
|
|
|
+ <view class="pd2-4-0 f-s-28">
|
|
|
+ <span class="c-#666">执行标准:</span>
|
|
|
+ <span class="c-#333 f-w-500">{{ selectDictLabel(pt_standard_type, item?.standardType) }}</span>
|
|
|
+ <span class="c-#666" v-if="item?.standardDetailName">({{ item?.standardDetailName }})</span>
|
|
|
+ </view>
|
|
|
+ <view class="pd2-4-0 f-s-28">
|
|
|
+ <span class="c-#666">加工工艺:</span>
|
|
|
+ <template v-for="(items, indexs) in item?.ptech?.split(',')" :key="indexs">
|
|
|
+ <span v-if="indexs !== 0" class="c-#999 f-s-32 ml-10 mr-10">→ </span>
|
|
|
+ <span class="f-s-32">{{ items }}</span>
|
|
|
+ </template>
|
|
|
+ </view>
|
|
|
+ <view class="pd2-4-0 f-s-28">
|
|
|
+ <span class="c-#666">加工负责人:</span>
|
|
|
+ <span class="c-#333 f-w-500">{{ item?.contactName }}</span>
|
|
|
+ </view>
|
|
|
+ <view class="radius-10 bg-#f7f7f7 d-flex">
|
|
|
+ <view class="bg-#EDF7F0 w-50 h-110 d-flex flex-cln a-c j-c c-primary f-w-5 f-s-24">
|
|
|
+ <view class="">原</view>
|
|
|
+ <view class="">料</view>
|
|
|
+ </view>
|
|
|
+ <view class="bg-#F5FBF7 flex1 d-flex a-c">
|
|
|
+ <view class="d-flex flex1 f-s-26">
|
|
|
+ <view class="c-#999 ml-16"> 暂无关联原料信息 </view>
|
|
|
+ <view class="flex1"></view>
|
|
|
+ <view class="c-primary d-flex a-c">
|
|
|
+ <view>去关联</view>
|
|
|
+ <up-icon name="arrow-right" size="26rpx"></up-icon>
|
|
|
+ </view>
|
|
|
</view>
|
|
|
</view>
|
|
|
</view>
|
|
|
+ <Output />
|
|
|
</view>
|
|
|
- <Output />
|
|
|
- </view>
|
|
|
+ </template>
|
|
|
+ </view>
|
|
|
+ </template>
|
|
|
+ <view class="h-210" v-if="list?.length"></view>
|
|
|
+ <view v-if="list?.length" :style="{ height: `${safeAreaBottom}px` }"></view>
|
|
|
+ <template #empty>
|
|
|
+ <view class="d-flex flex-cln a-c">
|
|
|
+ <ut-empty class="mg-at" color="#ccc" size="28rpx" image="https://ta.zycpzs.cn/oss-file/smart-trace/szyy/images-plt/plant/noEmptyBase.png">暂无加工任务</ut-empty>
|
|
|
+ <text class="c-#ccc f-s-28">点击下方按钮去添加吧~</text>
|
|
|
</view>
|
|
|
</template>
|
|
|
<template #bottom>
|
|
|
<ut-tabar activeTab="processing"></ut-tabar>
|
|
|
</template>
|
|
|
</z-paging>
|
|
|
+ <ut-suspension v-if="sus?.left" :imageWidth="60" :imageHeight="60" :x="sus?.left" :y="sus?.bottom" :inertia="false" :snap-threshold="40">
|
|
|
+ <image src="https://ta.zycpzs.cn/oss-file/smart-trace/szyy/images-plt/common/btn_add_logo.png" mode="widthFix" class="w-120 h-120" @click="showDeleteDialog = true"></image>
|
|
|
+ </ut-suspension>
|
|
|
+ <ut-confirm-dialog v-model:show="showDeleteDialog" width="80vw" title="请选择要创建的任务类型" :confirmText="'确认选择'" :cancelText="'取消'" @confirm="handlechoseConfirm" @cancel="handleDeleteCancel">
|
|
|
+ <view class="" v-for="item in pt_process_type" :key="item?.value">
|
|
|
+ <view style="border: 1rpx solid" :style="{ backgroundColor: item?.value == basetype ? '#EBF6EE' : '#f7f7f7', borderColor: item?.value == basetype ? '#37A954' : 'transparent' }" class="pr-30 d-flex a-c mb-20 radius-100" @click="handlechose(item.value)">
|
|
|
+ <view class="radius-50% mg-8 bg-#F0F0F0" v-if="item?.value == '1'">
|
|
|
+ <up-avatar size="90rpx" src="https://ta.zycpzs.cn/oss-file/smart-trace/szyy/images-plt/plant/port/TaskType_plant.png"></up-avatar>
|
|
|
+ </view>
|
|
|
+ <view class="radius-50% mg-8 bg-#F0F0F0" v-if="item?.value == '2'">
|
|
|
+ <up-avatar size="90rpx" src="https://ta.zycpzs.cn/oss-file/smart-trace/szyy/images-plt/plant/port/TaskType_breeding.png"></up-avatar>
|
|
|
+ </view>
|
|
|
+ <view class="c-#333 f-s-34">
|
|
|
+ {{ item?.label }}
|
|
|
+ </view>
|
|
|
+ <view class="flex1"></view>
|
|
|
+ <view class="d-flex">
|
|
|
+ <img v-if="basetype === item.value" class="w-30 h-30" src="https://ta.zycpzs.cn/oss-file/smart-trace/szyy/images-plt/plant/chooseSuccessfully.png" mode="widthFix" alt="" />
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ </view>
|
|
|
+ </ut-confirm-dialog>
|
|
|
</template>
|
|
|
<script setup lang="ts">
|
|
|
+import { useClientRequest } from '@/utils/request';
|
|
|
import Output from './models/output.vue';
|
|
|
-
|
|
|
const { proxy } = getCurrentInstance() as ComponentInternalInstance;
|
|
|
-const { pt_process_type } = toRefs<any>(proxy?.useDict('pt_process_type'));
|
|
|
+const { pt_process_type, pt_stock_type, pt_standard_type } = toRefs<any>(proxy?.useDict('pt_process_type', 'pt_stock_type', 'pt_standard_type'));
|
|
|
+const sus = ref({
|
|
|
+ left: 0,
|
|
|
+ bottom: 0,
|
|
|
+});
|
|
|
+const systemInfo = uni.getSystemInfoSync();
|
|
|
+const windowInfo = uni.getWindowInfo();
|
|
|
+const safeAreaBottom = windowInfo.safeAreaInsets.bottom;
|
|
|
+sus.value.left = systemInfo.windowWidth - 10;
|
|
|
+sus.value.bottom = systemInfo.windowHeight - 200;
|
|
|
+const showDeleteDialog = ref(false);
|
|
|
+const basetype = ref();
|
|
|
+const handlechose = (item: string) => {
|
|
|
+ basetype.value = item;
|
|
|
+};
|
|
|
+// 处理取消
|
|
|
+const handleDeleteCancel = () => {
|
|
|
+ showDeleteDialog.value = false;
|
|
|
+ basetype.value = '';
|
|
|
+};
|
|
|
+const handlechoseConfirm = () => {
|
|
|
+ if (!basetype.value) {
|
|
|
+ uni.showToast({
|
|
|
+ title: '请选择要创建的任务类型',
|
|
|
+ icon: 'none',
|
|
|
+ duration: 2000,
|
|
|
+ });
|
|
|
+ return;
|
|
|
+ }
|
|
|
+ uni.$u.route({ type: 'navigateTo', url: '/plant/port/port-create/index', params: { taskType: basetype.value } });
|
|
|
+};
|
|
|
const paging = ref();
|
|
|
-const list = ref([]);
|
|
|
+const list = ref<any[]>([]);
|
|
|
const tabs = [
|
|
|
{
|
|
|
label: '加工',
|
|
|
@@ -86,12 +155,20 @@ const tabs = [
|
|
|
value: '1',
|
|
|
},
|
|
|
];
|
|
|
-const form = reactive({
|
|
|
+const form = ref({
|
|
|
restFlag: '0',
|
|
|
});
|
|
|
-const query = async (page: number, size: number) => {
|
|
|
- // const res = await getList(page, size);
|
|
|
- // return res;
|
|
|
+const query = async (pageNum: number, pageSize: number) => {
|
|
|
+ const params = {
|
|
|
+ pageNum,
|
|
|
+ pageSize,
|
|
|
+ ...form.value,
|
|
|
+ };
|
|
|
+ const res = await useClientRequest.get('/plt-api/app/processe/pageList', params);
|
|
|
+ if (res) {
|
|
|
+ const { rows } = res;
|
|
|
+ paging.value.complete(rows);
|
|
|
+ }
|
|
|
};
|
|
|
const onRefresh = () => {
|
|
|
paging.value?.complete();
|