干燥机配套车间生产管理系统/云平台前端
baoshiwei
2024-10-25 6fcb00f27e80b38cea4ccb059112ad7cf99d8745
新增干草配方历史功能模块
已添加6个文件
已修改10个文件
1147 ■■■■ 文件已修改
src/components/Form/src/jeecg/components/JSearchSelect.vue 2 ●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/DryOrderList.vue 30 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/api/DryHerbInfo.api.ts 8 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/api/DryOrder.api.ts 19 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/common/prodRecordReport.vue 7 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/components/DryHerbFormulaModal.vue 5 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/components/dryOrder/DryOrderModal.vue 34 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/dataDefine/DryHerbFormula.data.ts 222 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/dataDefine/DryHerbInfo.data.ts 94 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/dataDefine/DryOrder.data.ts 42 ●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/DryHerbFormulaHis.api.ts 64 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/DryHerbFormulaHis.data.ts 285 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/DryHerbFormulaHisList.vue 173 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/DryHerbFormulaHis_menu_insert.sql 26 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/components/DryHerbFormulaHisForm.vue 70 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/views/dry/herbFormulaHis/components/DryHerbFormulaHisModal.vue 66 ●●●●● 补丁 | 查看 | 原始文档 | blame | 历史
src/components/Form/src/jeecg/components/JSearchSelect.vue
@@ -299,7 +299,7 @@
        }
      }
      //update-end-author:taoyan date:2022-8-15 for: VUEN-1971 ã€online ä¸“项测试】关联记录和他表字段 1
      return {
        attrs,
        options,
src/views/dry/DryOrderList.vue
@@ -5,6 +5,7 @@
            <!--插槽:table标题-->
            <template #tableTitle>
                <a-button type="primary" @click="handleAdd" preIcon="ant-design:plus-outlined"> æ–°å¢ž</a-button>
        <a-button type="primary" @click="handleSend" preIcon="ant-design:vertical-align-bottom-outlined"> ä¸‹å‘</a-button>
                <a-button type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> å¯¼å‡º</a-button>
                <j-upload-button type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>
                <a-dropdown v-if="selectedRowKeys.length > 0">
@@ -47,7 +48,7 @@
<script lang="ts" name="dry-dryOrder" setup>
    import { ref } from 'vue'
    import { batchDelete, deleteOne, getExportUrl, getImportUrl, list } from './api/DryOrder.api'
    import { batchDelete, deleteOne, getExportUrl, getImportUrl, list,batchSend } from './api/DryOrder.api'
    import DryOrderModal from './components/dryOrder/DryOrderModal.vue'
    import TrendModal from './components/dryOrder/TrendModal.vue'
    import { columns, searchFormSchema } from './dataDefine/DryOrder.data'
@@ -56,6 +57,7 @@
    import { useListPage } from '/@/hooks/system/useListPage'
    import { downloadFile } from '/@/utils/common/renderUtils'
    import { router } from '/@/router'
  import {message} from "ant-design-vue";
    const checkedKeys = ref<Array<string | number>>([])
    //注册model
@@ -91,7 +93,7 @@
        },
    })
    const [registerTable, { reload }, { rowSelection, selectedRowKeys }] = tableContext
    const [registerTable, { reload }, { rowSelection,selectedRows, selectedRowKeys }] = tableContext
    /**
     * æ–°å¢žäº‹ä»¶
@@ -102,7 +104,27 @@
            showFooter: true,
        })
    }
    /**
  /**
   * ä¸‹å‘工单
   */
  const handleSend = async () => {
    // åªæœ‰æ–°å»ºçŠ¶æ€çš„å·¥å•æ‰å…è®¸ä¸‹å‘ï¼Œæ ¹æ®å‹¾é€‰çš„è®°å½•id列表,遍历selectedRows,判断是不是新建工单,包含非新建工单进行提示
    if (selectedRowKeys.value.length > 0) {
      const newOrderList = selectedRows.value.filter(row => {
        return row.orderStatus > 0
      })
      if (newOrderList.length > 0) {
        message.warning('请选择新建状态的工单')
        return
      }else {
        await batchSend({ ids: selectedRowKeys.value }, handleSuccess)
      }
    }
  }
  /**
     * ç¼–辑事件
     */
    function handleEdit(record: Recordable) {
@@ -145,7 +167,7 @@
     */
    function getTableAction(record) {
        return [
            {
                label: '过程趋势',
                onClick: openProcessTendency.bind(null, record),
src/views/dry/api/DryHerbInfo.api.ts
@@ -7,6 +7,7 @@
  list = '/dry/dryHerbInfo/list',
  save='/dry/dryHerbInfo/add',
  edit='/dry/dryHerbInfo/edit',
  queryById = '/dry/dryHerbInfo/queryById',
  deleteOne = '/dry/dryHerbInfo/delete',
  deleteBatch = '/dry/dryHerbInfo/deleteBatch',
  importExcel = '/dry/dryHerbInfo/importExcel',
@@ -29,6 +30,13 @@
  defHttp.get({url: Api.list, params});
/**
 * åˆ—表接口
 * @param params
 */
export const queryById = (params) =>
  defHttp.get({url: Api.queryById, params});
/**
 * åˆ é™¤å•个
 */
export const deleteOne = (params,handleSuccess) => {
src/views/dry/api/DryOrder.api.ts
@@ -13,6 +13,7 @@
    deleteBatch = '/dry/dryOrder/deleteBatch',
    importExcel = '/dry/dryOrder/importExcel',
    exportXls = '/dry/dryOrder/exportXls',
  sendBatch = '/dry/dryOrder/sendBatch'
}
/**
 * å¯¼å‡ºapi
@@ -61,6 +62,24 @@
        },
    })
}
/**
 * æ‰¹é‡ä¸‹å‘工单
 */
export const batchSend = (params, handleSuccess) => {
  createConfirm({
    iconType: 'warning',
    title: '确认下发',
    content: '是否将选中工单下发到机台',
    okText: '下发',
    cancelText: '取消',
    onOk: () => {
      return defHttp.post({ url: Api.sendBatch, data: params }, { joinParamsToUrl: true }).then(() => {
        handleSuccess()
      })
    },
  })
}
/**
 * ä¿å­˜æˆ–者更新
 * @param params
src/views/dry/common/prodRecordReport.vue
@@ -5,9 +5,12 @@
<script setup lang="ts">
    import { onMounted, ref } from 'vue'
    import { router } from '/@/router'
    console.log(`output->router1`, router)
  import { getTenantId, getToken } from '/@/utils/auth'
  const token = getToken()
    const tenantId = getTenantId()
    console.log(`output->tenantId`, tenantId )
    const reportUrl = ref('')
    reportUrl.value = window._CONFIG['domianURL'] + '/jmreport/view/833110227445567488?batch=' + router.currentRoute.value.query.batch
    reportUrl.value = window._CONFIG['domianURL'] + '/jmreport/view/833110227445567488?batch=' + router.currentRoute.value.query.batch +'&token=' + token+'&tenantId=' + tenantId
    //reportUrl.value = 'www.baidu.com'
    console.log(`output->reportUrl.value`, reportUrl.value)
    // onMounted(() => {
src/views/dry/components/DryHerbFormulaModal.vue
@@ -20,6 +20,7 @@
        showActionButtonGroup: false,
        baseColProps: { span: 24 },
    })
    //表单赋值
    const [registerModal, { setModalProps, closeModal }] = useModalInner(async (data) => {
        //重置表单
@@ -35,6 +36,10 @@
        // éšè—åº•部时禁用整个表单
        setProps({ disabled: !data?.showFooter })
    })
  const updateNameValue = (v) => {
    console.log(v)
  }
    //设置标题
    const title = computed(() => (!unref(isUpdate) ? '新增' : '编辑'))
    //表单提交事件
src/views/dry/components/dryOrder/DryOrderModal.vue
@@ -5,6 +5,7 @@
</template>
<script lang="ts" setup>
import dayjs from 'dayjs';
    import { computed, ref, unref } from 'vue'
    import { saveOrUpdate } from '../../api/DryOrder.api'
    import { formSchema } from '../../dataDefine/DryOrder.data'
@@ -31,7 +32,15 @@
            await setFieldsValue({
                ...data.record,
            })
        }
        } else {
      await setFieldsValue({
        orderTime: dayjs(getDateStr(new Date()), 'YYYY-MM-DD'),
        code: getCodeByDate(new Date()),
        dryer: 1,
        feed: 16,
        orderStatus: 0,
            })
    }
        // éšè—åº•部时禁用整个表单
        setProps({ disabled: !data?.showFooter })
    })
@@ -41,6 +50,8 @@
    async function handleSubmit(v) {
        try {
            let values = await validate()
      values.orderTime = dayjs(values.orderTime).format('YYYY-MM-DD HH:mm:ss')
            setModalProps({ confirmLoading: true })
            //提交表单
            await saveOrUpdate(values, isUpdate.value)
@@ -52,6 +63,27 @@
            setModalProps({ confirmLoading: false })
        }
    }
  const getCodeByDate = (date) => {
    let year = date.getFullYear()
    let month = date.getMonth() + 1
    let day = date.getDate()
    let hour = date.getHours()
    let minute = date.getMinutes()
    let second = date.getSeconds()
    return `${year}${month}${day}${hour}${minute}${second}`
  }
  const getDateStr = (date) => {
    let year = date.getFullYear()
    let month = date.getMonth() + 1
    let day = date.getDate()
    if (month < 10) {
      month = '0' + month
    }
    if (day < 10) {
      day = '0' + day
    }
    return `${year}-${month}-${day}`
  }
</script>
<style lang="less" scoped>
src/views/dry/dataDefine/DryHerbFormula.data.ts
@@ -1,4 +1,7 @@
import { BasicColumn, FormSchema } from '/@/components/Table'
import {render} from "/@/utils/common/renderUtils";
import {rules} from "/@/utils/helper/validator";
import {queryById} from "/@/views/dry/api/DryHerbInfo.api"
//列表数据
export const columns: BasicColumn[] = [
    {
@@ -6,16 +9,24 @@
        align: 'center',
        dataIndex: 'herbId_dictText',
    },
    // {
    //     title: '药材名称',
    //     align: 'center',
    //     dataIndex: 'herbName',
    // },
    {
        title: '配方名称',
        align: 'center',
        dataIndex: 'name',
    },
    {
        title: '适用设备',
        align: 'center',
        dataIndex: 'eqpType_dictText',
    },
  {
    title: '配方分类',
    align: 'center',
    dataIndex: 'category',
    customRender: ({ text }) => {
      return render.renderDict(text, 'formula_category');
    },
  },
    {
        title: '目标含水率',
        align: 'center',
@@ -36,26 +47,41 @@
        align: 'center',
        dataIndex: 'windTemp',
    },
    {
        title: '环境温度',
        align: 'center',
        dataIndex: 'envTemp',
    },
    {
        title: '环境湿度',
        align: 'center',
        dataIndex: 'envHum',
    },
  {
    title: '风机初始频率',
    align: 'center',
    dataIndex: 'fanSpeed',
  },
    // {
    //     title: '环境温度',
    //     align: 'center',
    //     dataIndex: 'envTemp',
    // },
    // {
    //     title: '环境湿度',
    //     align: 'center',
    //     dataIndex: 'envHum',
    // },
    {
        title: '荡料延时ms',
        align: 'center',
        dataIndex: 'delay',
    },
    {
        title: '翻料次数',
        align: 'center',
        dataIndex: 'turn',
    },
    // {
    //     title: '翻料次数',
    //     align: 'center',
    //     dataIndex: 'turn',
    // },
  {
    title: '含水率补偿',
    align: 'center',
    dataIndex: 'moisOffset',
  },
  {
    title: '冷风时长',
    align: 'center',
    dataIndex: 'coolingDuration',
  },
    // {
    //     title: '租户id',
    //     align: 'center',
@@ -69,7 +95,7 @@
        field: 'herbId',
        component: 'JSearchSelect',
        componentProps: {
            dict: 'dry_herb,name,id',
            dict: 'dry_herb_info,name,id',
        },
        colProps: { span: 6 },
    },
@@ -80,18 +106,31 @@
        label: '药材',
        field: 'herbId',
        component: 'JSearchSelect',
        componentProps: {
            dict: 'dry_herb,name,id',
        componentProps: ({formModel})=>{
      return {
        dict: 'dry_herb_info,name,id',
        onChange: e => {
          let param = {
            id: e,
          }
          queryById(param).then(res => {
            formModel.name = res.name
          })
        },
      }
        },
        dynamicRules: ({ model, schema }) => {
            return [{ required: true, message: '请选择药材!' }]
        },
    },
    // {
    //     label: '药材名称',
    //     field: 'herbName',
    //     component: 'Input',
    // },
    {
        label: '配方名称',
        field: 'name',
        component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: true, message: '请输入配方名称!' }, { ...rules.duplicateCheckRule('dry_herb_formula', 'name', model, schema)[0] }]
    },
    },
    {
        label: '设备类型',
        field: 'eqpType',
@@ -103,6 +142,16 @@
            return [{ required: true, message: '请设备设备类型!' }]
        },
    },
  {
    label: '配方分类',
    field: 'category',
    component: 'JDictSelectTag',
    componentProps: {
      dictCode: 'formula_category',
      placeholder: '请选择配方分类',
      stringToNumber: true,
    },
  },
    {
        label: '目标含水率',
        field: 'target',
@@ -155,32 +204,45 @@
            }
        },
    },
    {
        label: '环境温度',
        field: 'envTemp',
        component: 'Input',
        dynamicRules: ({ model, schema }) => {
            return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
        },
        renderComponentContent: () => {
            return {
                suffix: () => '℃',
            }
        },
    },
    {
        label: '环境湿度',
        field: 'envHum',
        component: 'Input',
        dynamicRules: ({ model, schema }) => {
            return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
        },
        renderComponentContent: () => {
            return {
                suffix: () => 'rh',
            }
        },
    },
  {
    label: '风机初始频率',
    field: 'fanSpeed',
    component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    },
    renderComponentContent: () => {
      return {
        suffix: () => 'Hz',
      }
    },
  },
    // {
    //     label: '环境温度',
    //     field: 'envTemp',
    //     component: 'Input',
    //     dynamicRules: ({ model, schema }) => {
    //         return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    //     },
    //     renderComponentContent: () => {
    //         return {
    //             suffix: () => '℃',
    //         }
    //     },
    // },
    // {
    //     label: '环境湿度',
    //     field: 'envHum',
    //     component: 'Input',
    //     dynamicRules: ({ model, schema }) => {
    //         return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    //     },
    //     renderComponentContent: () => {
    //         return {
    //             suffix: () => 'rh',
    //         }
    //     },
    // },
    {
        label: '荡料延时',
        field: 'delay',
@@ -194,19 +256,45 @@
            }
        },
    },
    {
        label: '翻料次数',
        field: 'turn',
        component: 'Input',
        dynamicRules: ({ model, schema }) => {
            return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
        },
        renderComponentContent: () => {
            return {
                suffix: () => '次',
            }
        },
    },
    // {
    //     label: '翻料次数',
    //     field: 'turn',
    //     component: 'Input',
    //     dynamicRules: ({ model, schema }) => {
    //         return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    //     },
    //     renderComponentContent: () => {
    //         return {
    //             suffix: () => '次',
    //         }
    //     },
    // },
  {
    label: '含水率补偿',
    field: 'moisOffset',
    component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    },
    renderComponentContent: () => {
      return {
        suffix: () => '%',
      }
    },
  },
  {
    label: '冷风时长',
    field: 'coolingDuration',
    component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: false }, { pattern: /^-?\d+\.?\d*$/, message: '请输入数字!' }]
    },
    renderComponentContent: () => {
      return {
        suffix: () => 'min',
      }
    },
  },
    // TODO ä¸»é”®éšè—å­—段,目前写死为ID
    {
        label: '',
src/views/dry/dataDefine/DryHerbInfo.data.ts
@@ -1,5 +1,6 @@
import {BasicColumn} from '/@/components/Table';
import {FormSchema} from '/@/components/Table';
import {rules} from "/@/utils/helper/validator";
//列表数据
export const columns: BasicColumn[] = [
@@ -23,6 +24,11 @@
    align:"center",
    dataIndex: 'english'
   },
  {
    title: '药材分类',
    align: 'center',
    dataIndex: 'type_dictText',
  },
   {
    title: '药用部位',
    align:"center",
@@ -78,11 +84,11 @@
    align:"center",
    dataIndex: 'usageTaboo'
   },
   {
    title: '租户id',
    align:"center",
    dataIndex: 'tenantId'
   },
  //  {
  //   title: '租户id',
  //   align:"center",
  //   dataIndex: 'tenantId'
  //  },
];
//查询数据
export const searchFormSchema: FormSchema[] = [
@@ -104,24 +110,36 @@
      component: 'JInput',
      colProps: {span: 6},
     },
    {
      label: "英文名",
      field: 'english',
      component: 'JInput',
      colProps: {span: 6},
     },
    {
      label: "产地分布",
      field: 'origin',
      component: 'JInput',
      colProps: {span: 6},
     },
    {
      label: "功效与作用",
      field: 'efficacy',
      component: 'JInput',
      colProps: {span: 6},
     },
    // {
  //     label: "英文名",
  //     field: 'english',
  //     component: 'JInput',
  //     colProps: {span: 6},
     // },
    // {
  //     label: "产地分布",
  //     field: 'origin',
  //     component: 'JInput',
  //     colProps: {span: 6},
     // },
    // {
  //     label: "功效与作用",
  //     field: 'efficacy',
  //     component: 'JInput',
  //     colProps: {span: 6},
     // },
  {
    label: '药材分类',
    field: 'type',
    component: 'JTreeSelect',
    componentProps: {
      dict: 'dry_herb_type,name,id',
      pidField: 'pid',
      hasChildField: 'has_child',
      converIsLeafVal: 1,
    },
    colProps: { span: 6 },
  },
];
//表单数据
export const formSchema: FormSchema[] = [
@@ -129,11 +147,17 @@
    label: '中药名',
    field: 'name',
    component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: true, message: '请输入药材名称!' }, { ...rules.duplicateCheckRule('dry_herb_info', 'name', model, schema)[0] }]
    },
  },
  {
    label: '拼音',
    field: 'pinyin',
    component: 'Input',
    dynamicRules: ({ model, schema }) => {
      return [{ required: true, message: '请输入药材拼音!' }, { ...rules.duplicateCheckRule('dry_herb_info', 'pinyin', model, schema)[0] }]
    },
  },
  {
    label: '别名',
@@ -144,6 +168,20 @@
    label: '英文名',
    field: 'english',
    component: 'Input',
  },
  {
    label: '药材分类',
    field: 'type',
    component: 'JTreeSelect',
    componentProps: {
      dict: 'dry_herb_type,name,id',
      pidField: 'pid',
      hasChildField: 'has_child',
      converIsLeafVal: 1,
    },
    dynamicRules: ({ model, schema }) => {
      return [{ required: true, message: '请输入药材分类!' }]
    },
  },
  {
    label: '药用部位',
@@ -200,11 +238,11 @@
    field: 'usageTaboo',
    component: 'Input',
  },
  {
    label: '租户id',
    field: 'tenantId',
    component: 'InputNumber',
  },
  // {
  //   label: '租户id',
  //   field: 'tenantId',
  //   component: 'InputNumber',
  // },
    // TODO ä¸»é”®éšè—å­—段,目前写死为ID
    {
      label: '',
src/views/dry/dataDefine/DryOrder.data.ts
@@ -27,6 +27,11 @@
        align: 'center',
        dataIndex: 'equId_dictText',
    },
  {
    title: '工单状态',
    align: 'center',
    dataIndex: 'orderStatus_dictText',
  },
    // {
    //     title: '车间',
    //     align: 'center',
@@ -108,11 +113,7 @@
        dataIndex: 'remain',
    },
    {
        title: '工单状态',
        align: 'center',
        dataIndex: 'orderStatus',
    },
    {
        title: '操作人',
        align: 'center',
@@ -144,8 +145,7 @@
        field: 'orderTime',
        component: 'DatePicker',
        componentProps: {
            showTime: true,
            valueFormat: 'YYYY-MM-DD HH:mm:ss',
            valueFormat: 'YYYY-MM-DD',
        },
    },
    {
@@ -161,7 +161,7 @@
        field: 'herbId',
        component: 'JDictSelectTag',
        componentProps: {
            dictCode: 'dry_herb,name,id,tenant_id=' + getTenantId(),
            dictCode: 'dry_herb_formula,name,id,tenant_id=' + getTenantId(),
        },
    },
    // {
@@ -237,19 +237,23 @@
            dictCode: 'dry_equipment,name,id,tenant_id=' + getTenantId(),
        },
    },
    {
        label: '车间',
        field: 'shopId',
        component: 'JDictSelectTag',
        componentProps: {
            dictCode: 'dry_shop,name,id,tenant_id=' + getTenantId(),
        },
    },
    // {
    //     label: '工单状态',
    //     field: 'orderStatus',
    //     component: 'InputNumber',
    //     label: '车间',
    //     field: 'shopId',
    //     component: 'JDictSelectTag',
    //     componentProps: {
    //         dictCode: 'dry_shop,name,id,tenant_id=' + getTenantId(),
    //     },
    // },
    {
        label: '工单状态',
        field: 'orderStatus',
    component: 'JDictSelectTag',
    componentProps: {
      dictCode: 'dry_order_status',
      stringToNumber: true,
    },
    },
    // {
    //     label: '操作人',
    //     field: 'operator',
src/views/dry/herbFormulaHis/DryHerbFormulaHis.api.ts
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,64 @@
import {defHttp} from '/@/utils/http/axios';
import { useMessage } from "/@/hooks/web/useMessage";
const { createConfirm } = useMessage();
enum Api {
  list = '/dry/dryHerbFormulaHis/list',
  save='/dry/dryHerbFormulaHis/add',
  edit='/dry/dryHerbFormulaHis/edit',
  deleteOne = '/dry/dryHerbFormulaHis/delete',
  deleteBatch = '/dry/dryHerbFormulaHis/deleteBatch',
  importExcel = '/dry/dryHerbFormulaHis/importExcel',
  exportXls = '/dry/dryHerbFormulaHis/exportXls',
}
/**
 * å¯¼å‡ºapi
 * @param params
 */
export const getExportUrl = Api.exportXls;
/**
 * å¯¼å…¥api
 */
export const getImportUrl = Api.importExcel;
/**
 * åˆ—表接口
 * @param params
 */
export const list = (params) =>
  defHttp.get({url: Api.list, params});
/**
 * åˆ é™¤å•个
 */
export const deleteOne = (params,handleSuccess) => {
  return defHttp.delete({url: Api.deleteOne, params}, {joinParamsToUrl: true}).then(() => {
    handleSuccess();
  });
}
/**
 * æ‰¹é‡åˆ é™¤
 * @param params
 */
export const batchDelete = (params, handleSuccess) => {
  createConfirm({
    iconType: 'warning',
    title: '确认删除',
    content: '是否删除选中数据',
    okText: '确认',
    cancelText: '取消',
    onOk: () => {
      return defHttp.delete({url: Api.deleteBatch, data: params}, {joinParamsToUrl: true}).then(() => {
        handleSuccess();
      });
    }
  });
}
/**
 * ä¿å­˜æˆ–者更新
 * @param params
 */
export const saveOrUpdate = (params, isUpdate) => {
  let url = isUpdate ? Api.edit : Api.save;
  return defHttp.post({url: url, params});
}
src/views/dry/herbFormulaHis/DryHerbFormulaHis.data.ts
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,285 @@
import {BasicColumn} from '/@/components/Table';
import {FormSchema} from '/@/components/Table';
import { rules} from '/@/utils/helper/validator';
import { render } from '/@/utils/common/renderUtils';
//列表数据
export const columns: BasicColumn[] = [
   {
    title: '设备',
    align:"center",
    dataIndex: 'eqpId_dictText'
   },
   // {
   //  title: '工单号',
   //  align:"center",
   //  dataIndex: 'orderCode'
   // },
   {
    title: '时间',
    align:"center",
    sorter: true,
    dataIndex: 'orderTime',
    customRender:({text}) =>{
      return !text?"":(text.length>10?text.substr(0,10):text)
    },
   },
   {
    title: '索引',
    align:"center",
    sorter: true,
    dataIndex: 'formulaIndex'
   },
   {
    title: '编码',
    align:"center",
    dataIndex: 'code'
   },
   {
    title: '名称',
    align:"center",
    sorter: true,
    dataIndex: 'name'
   },
   {
    title: '类型',
    align:"center",
    sorter: true,
    dataIndex: 'typ'
   },
   {
    title: 'ab',
    align:"center",
    dataIndex: 'ab'
   },
   {
    title: '投料量(筐)',
    align:"center",
    dataIndex: 'weight1'
   },
   {
    title: '初始重量',
    align:"center",
    dataIndex: 'weight2'
   },
   {
    title: '热风温度',
    align:"center",
    dataIndex: 'temp1'
   },
   {
    title: '环境温度',
    align:"center",
    dataIndex: 'temp2'
   },
   {
    title: '环境湿度',
    align:"center",
    dataIndex: 'temp3'
   },
   {
    title: '荡料延时ms',
    align:"center",
    dataIndex: 'delay'
   },
   {
    title: '翻料次数',
    align:"center",
    dataIndex: 'turntime'
   },
   {
    title: '初始含水率',
    align:"center",
    dataIndex: 'moisture1'
   },
   {
    title: '目标含水率',
    align:"center",
    dataIndex: 'moisture3'
   },
   {
    title: '药材分类',
    align:"center",
    dataIndex: 'mtype'
   },
   {
    title: '含水率补偿',
    align:"center",
    dataIndex: 'moisoffset'
   },
   {
    title: '冷风时长',
    align:"center",
    dataIndex: 'coldwind'
   },
   {
    title: '租户id',
    align:"center",
    dataIndex: 'tenantId'
   },
];
//查询数据
export const searchFormSchema: FormSchema[] = [
    {
      label: "设备",
      field: 'eqpId',
      component: 'Input',
      colProps: {span: 6},
     },
    {
      label: "时间",
      field: 'orderTime',
      component: 'DatePicker',
      colProps: {span: 6},
     },
  {
    label: "名称",
    field: 'name',
    component: 'Input',
    colProps: {span: 6},
  },
    {
      label: "索引",
      field: 'formulaIndex',
      component: 'Input',
      colProps: {span: 6},
     },
    {
      label: "编码",
      field: 'code',
      component: 'Input',
      colProps: {span: 6},
     },
    {
      label: "类型",
      field: 'typ',
      component: 'Input',
      colProps: {span: 6},
     },
];
//表单数据
export const formSchema: FormSchema[] = [
  {
    label: '设备',
    field: 'eqpId',
    component: 'Input',
  },
  // {
  //   label: '工单号',
  //   field: 'orderCode',
  //   component: 'Input',
  // },
  {
    label: '时间',
    field: 'orderTime',
    component: 'DatePicker',
  },
  {
    label: '索引',
    field: 'formulaIndex',
    component: 'Input',
  },
  {
    label: '编码',
    field: 'code',
    component: 'Input',
  },
  {
    label: '名称',
    field: 'name',
    component: 'Input',
  },
  {
    label: '类型',
    field: 'typ',
    component: 'Input',
  },
  {
    label: 'ab',
    field: 'ab',
    component: 'Input',
  },
  {
    label: '投料量(筐)',
    field: 'weight1',
    component: 'InputNumber',
  },
  {
    label: '初始重量',
    field: 'weight2',
    component: 'InputNumber',
  },
  {
    label: '热风温度',
    field: 'temp1',
    component: 'InputNumber',
  },
  {
    label: '环境温度',
    field: 'temp2',
    component: 'InputNumber',
  },
  {
    label: '环境湿度',
    field: 'temp3',
    component: 'InputNumber',
  },
  {
    label: '荡料延时ms',
    field: 'delay',
    component: 'InputNumber',
  },
  {
    label: '翻料次数',
    field: 'turntime',
    component: 'InputNumber',
  },
  {
    label: '初始含水率',
    field: 'moisture1',
    component: 'InputNumber',
  },
  {
    label: '目标含水率',
    field: 'moisture3',
    component: 'InputNumber',
  },
  {
    label: '药材分类',
    field: 'mtype',
    component: 'InputNumber',
  },
  {
    label: '含水率补偿',
    field: 'moisoffset',
    component: 'InputNumber',
  },
  {
    label: '冷风时长',
    field: 'coldwind',
    component: 'InputNumber',
  },
  {
    label: '租户id',
    field: 'tenantId',
    component: 'InputNumber',
  },
    // TODO ä¸»é”®éšè—å­—段,目前写死为ID
    {
      label: '',
      field: 'id',
      component: 'Input',
      show: false
    },
];
/**
* æµç¨‹è¡¨å•调用这个方法获取formSchema
* @param param
*/
export function getBpmFormSchema(_formData): FormSchema[]{
  // é»˜è®¤å’ŒåŽŸå§‹è¡¨å•ä¿æŒä¸€è‡´ å¦‚果流程中配置了权限数据,这里需要单独处理formSchema
  return formSchema;
}
src/views/dry/herbFormulaHis/DryHerbFormulaHisList.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,173 @@
<template>
  <div>
    <!--引用表格-->
   <BasicTable @register="registerTable" :rowSelection="rowSelection">
     <!--插槽:table标题-->
      <template #tableTitle>
<!--          <a-button type="primary" @click="handleAdd" preIcon="ant-design:plus-outlined"> æ–°å¢ž</a-button>-->
          <a-button  type="primary" preIcon="ant-design:export-outlined" @click="onExportXls"> å¯¼å‡º</a-button>
<!--          <j-upload-button  type="primary" preIcon="ant-design:import-outlined" @click="onImportXls">导入</j-upload-button>-->
          <a-dropdown v-if="selectedRowKeys.length > 0">
              <template #overlay>
                <a-menu>
                  <a-menu-item key="1" @click="batchHandleDelete">
                    <Icon icon="ant-design:delete-outlined"></Icon>
                    åˆ é™¤
                  </a-menu-item>
                </a-menu>
              </template>
              <a-button>批量操作
                <Icon icon="mdi:chevron-down"></Icon>
              </a-button>
        </a-dropdown>
      </template>
       <!--操作栏-->
      <template #action="{ record }">
        <TableAction :actions="getTableAction(record)" :dropDownActions="getDropDownAction(record)"/>
      </template>
      <!--字段回显插槽-->
      <template #htmlSlot="{text}">
         <div v-html="text"></div>
      </template>
      <!--省市区字段回显插槽-->
      <template #pcaSlot="{text}">
         {{ getAreaTextByCode(text) }}
      </template>
      <template #fileSlot="{text}">
         <span v-if="!text" style="font-size: 12px;font-style: italic;">无文件</span>
         <a-button v-else :ghost="true" type="primary" preIcon="ant-design:download-outlined" size="small" @click="downloadFile(text)">下载</a-button>
      </template>
    </BasicTable>
    <!-- è¡¨å•区域 -->
    <DryHerbFormulaHisModal @register="registerModal" @success="handleSuccess"></DryHerbFormulaHisModal>
  </div>
</template>
<script lang="ts" name="dry-dryHerbFormulaHis" setup>
  import {ref, computed, unref} from 'vue';
  import {BasicTable, useTable, TableAction} from '/@/components/Table';
  import {useModal} from '/@/components/Modal';
  import { useListPage } from '/@/hooks/system/useListPage'
  import DryHerbFormulaHisModal from './components/DryHerbFormulaHisModal.vue'
  import {columns, searchFormSchema} from './DryHerbFormulaHis.data';
  import {list, deleteOne, batchDelete, getImportUrl,getExportUrl} from './DryHerbFormulaHis.api';
  import { downloadFile } from '/@/utils/common/renderUtils';
  const checkedKeys = ref<Array<string | number>>([]);
  //注册model
  const [registerModal, {openModal}] = useModal();
  //注册table数据
  const { prefixCls,tableContext,onExportXls,onImportXls } = useListPage({
      tableProps:{
           title: '配方记录',
           api: list,
           columns,
           canResize:false,
           formConfig: {
              //labelWidth: 120,
              schemas: searchFormSchema,
              autoSubmitOnEnter:true,
              showAdvancedButton:true,
              fieldMapToNumber: [
              ],
              fieldMapToTime: [
              ],
            },
           actionColumn: {
               width: 120,
               fixed:'right'
            },
      },
       exportConfig: {
            name:"配方记录",
            url: getExportUrl,
          },
          importConfig: {
            url: getImportUrl,
            success: handleSuccess
          },
  })
  const [registerTable, {reload},{ rowSelection, selectedRowKeys }] = tableContext
   /**
    * æ–°å¢žäº‹ä»¶
    */
  function handleAdd() {
     openModal(true, {
       isUpdate: false,
       showFooter: true,
     });
  }
   /**
    * ç¼–辑事件
    */
  function handleEdit(record: Recordable) {
     openModal(true, {
       record,
       isUpdate: true,
       showFooter: true,
     });
   }
   /**
    * è¯¦æƒ…
   */
  function handleDetail(record: Recordable) {
     openModal(true, {
       record,
       isUpdate: true,
       showFooter: false,
     });
   }
   /**
    * åˆ é™¤äº‹ä»¶
    */
  async function handleDelete(record) {
     await deleteOne({id: record.id}, handleSuccess);
   }
   /**
    * æ‰¹é‡åˆ é™¤äº‹ä»¶
    */
  async function batchHandleDelete() {
     await batchDelete({ids: selectedRowKeys.value}, handleSuccess);
   }
   /**
    * æˆåŠŸå›žè°ƒ
    */
  function handleSuccess() {
      (selectedRowKeys.value = []) && reload();
   }
   /**
      * æ“ä½œæ 
      */
  function getTableAction(record){
       return [
         {
           label: '编辑',
           onClick: handleEdit.bind(null, record),
         }
       ]
   }
     /**
        * ä¸‹æ‹‰æ“ä½œæ 
        */
  function getDropDownAction(record){
       return [
         {
           label: '详情',
           onClick: handleDetail.bind(null, record),
         }, {
           label: '删除',
           popConfirm: {
             title: '是否确认删除',
             confirm: handleDelete.bind(null, record),
           }
         }
       ]
   }
</script>
<style scoped>
</style>
src/views/dry/herbFormulaHis/DryHerbFormulaHis_menu_insert.sql
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,26 @@
-- æ³¨æ„ï¼šè¯¥é¡µé¢å¯¹åº”的前台目录为views/dry文件夹下
-- å¦‚果你想更改到其他目录,请修改sql中component字段对应的值
INSERT INTO sys_permission(id, parent_id, name, url, component, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_route, is_leaf, keep_alive, hidden, hide_tab, description, status, del_flag, rule_flag, create_by, create_time, update_by, update_time, internal_or_external)
VALUES ('2024081902069470350', NULL, '配方记录', '/dry/dryHerbFormulaHisList', 'dry/DryHerbFormulaHisList', NULL, NULL, 0, NULL, '1', 0.00, 0, NULL, 1, 0, 0, 0, 0, NULL, '1', 0, 0, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0);
-- æƒé™æŽ§åˆ¶sql
-- æ–°å¢ž
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470351', '2024081902069470350', '添加配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:add', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
-- ç¼–辑
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470352', '2024081902069470350', '编辑配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:edit', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
-- åˆ é™¤
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470353', '2024081902069470350', '删除配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:delete', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
-- æ‰¹é‡åˆ é™¤
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470354', '2024081902069470350', '批量删除配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:deleteBatch', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
-- å¯¼å‡ºexcel
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470355', '2024081902069470350', '导出excel_配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:exportXls', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
-- å¯¼å…¥excel
INSERT INTO sys_permission(id, parent_id, name, url, component, is_route, component_name, redirect, menu_type, perms, perms_type, sort_no, always_show, icon, is_leaf, keep_alive, hidden, hide_tab, description, create_by, create_time, update_by, update_time, del_flag, rule_flag, status, internal_or_external)
VALUES ('2024081902069470356', '2024081902069470350', '导入excel_配方记录', NULL, NULL, 0, NULL, NULL, 2, 'dry:dry_herb_formula_his:importExcel', '1', NULL, 0, NULL, 1, 0, 0, 0, NULL, 'admin', '2024-08-19 14:06:35', NULL, NULL, 0, 0, '1', 0);
src/views/dry/herbFormulaHis/components/DryHerbFormulaHisForm.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,70 @@
<template>
    <div style="min-height: 400px">
        <BasicForm @register="registerForm"></BasicForm>
        <div style="width: 100%;text-align: center" v-if="!formDisabled">
            <a-button @click="submitForm" pre-icon="ant-design:check" type="primary">提 äº¤</a-button>
        </div>
    </div>
</template>
<script lang="ts">
    import {BasicForm, useForm} from '/@/components/Form/index';
    import {computed, defineComponent} from 'vue';
    import {defHttp} from '/@/utils/http/axios';
    import { propTypes } from '/@/utils/propTypes';
    import {getBpmFormSchema} from '../DryHerbFormulaHis.data';
    import {saveOrUpdate} from '../DryHerbFormulaHis.api';
    export default defineComponent({
        name: "DryHerbFormulaHisForm",
        components:{
            BasicForm
        },
        props:{
            formData: propTypes.object.def({}),
            formBpm: propTypes.bool.def(true),
        },
        setup(props){
            const [registerForm, { setFieldsValue, setProps, getFieldsValue }] = useForm({
                labelWidth: 150,
                schemas: getBpmFormSchema(props.formData),
                showActionButtonGroup: false,
                baseColProps: {span: 24}
            });
            const formDisabled = computed(()=>{
                if(props.formData.disabled === false){
                    return false;
                }
                return true;
            });
            let formData = {};
            const queryByIdUrl = '/dry/dryHerbFormulaHis/queryById';
            async function initFormData(){
                let params = {id: props.formData.dataId};
                const data = await defHttp.get({url: queryByIdUrl, params});
                formData = {...data}
                //设置表单的值
                await setFieldsValue(formData);
                //默认是禁用
                await setProps({disabled: formDisabled.value})
            }
            async function submitForm() {
                let data = getFieldsValue();
                let params = Object.assign({}, formData, data);
                console.log('表单数据', params)
                await saveOrUpdate(params, true)
            }
            initFormData();
            return {
                registerForm,
                formDisabled,
                submitForm,
            }
        }
    });
</script>
src/views/dry/herbFormulaHis/components/DryHerbFormulaHisModal.vue
¶Ô±ÈÐÂÎļþ
@@ -0,0 +1,66 @@
<template>
  <BasicModal v-bind="$attrs" @register="registerModal" destroyOnClose :title="title" :width="800" @ok="handleSubmit">
      <BasicForm @register="registerForm"/>
  </BasicModal>
</template>
<script lang="ts" setup>
    import {ref, computed, unref} from 'vue';
    import {BasicModal, useModalInner} from '/@/components/Modal';
    import {BasicForm, useForm} from '/@/components/Form/index';
    import {formSchema} from '../DryHerbFormulaHis.data';
    import {saveOrUpdate} from '../DryHerbFormulaHis.api';
    // Emits声明
    const emit = defineEmits(['register','success']);
    const isUpdate = ref(true);
    //表单配置
    const [registerForm, {setProps,resetFields, setFieldsValue, validate}] = useForm({
        //labelWidth: 150,
        schemas: formSchema,
        showActionButtonGroup: false,
        baseColProps: {span: 24}
    });
    //表单赋值
    const [registerModal, {setModalProps, closeModal}] = useModalInner(async (data) => {
        //重置表单
        await resetFields();
        setModalProps({confirmLoading: false,showCancelBtn:!!data?.showFooter,showOkBtn:!!data?.showFooter});
        isUpdate.value = !!data?.isUpdate;
        if (unref(isUpdate)) {
            //表单赋值
            await setFieldsValue({
                ...data.record,
            });
        }
        // éšè—åº•部时禁用整个表单
       setProps({ disabled: !data?.showFooter })
    });
    //设置标题
    const title = computed(() => (!unref(isUpdate) ? '新增' : '编辑'));
    //表单提交事件
    async function handleSubmit(v) {
        try {
            let values = await validate();
            setModalProps({confirmLoading: true});
            //提交表单
            await saveOrUpdate(values, isUpdate.value);
            //关闭弹窗
            closeModal();
            //刷新列表
            emit('success');
        } finally {
            setModalProps({confirmLoading: false});
        }
    }
</script>
<style lang="less" scoped>
    /** æ—¶é—´å’Œæ•°å­—输入框样式 */
  :deep(.ant-input-number){
        width: 100%
    }
    :deep(.ant-calendar-picker){
        width: 100%
    }
</style>