广丰卷烟厂数采质量分析系统
zhuguifei
2026-04-03 08114b7451615854cb01556a7c477e32e17f520e
ruoyi-plus-soybean/src/views/qm/judge/index.vue
@@ -15,7 +15,6 @@
  name: 'JudgeList'
});
const appStore = useAppStore();
const { download } = useDownload();
const { hasAuth } = useAuth();
@@ -33,225 +32,225 @@
const { columns, columnChecks, data, getData, getDataByPage, loading, mobilePagination, scrollX } =
  useNaivePaginatedTable({
  api: () => {
    const params = { ...searchParams.value };
    if (params.status === -1) {
      delete params.status;
    }
    return fetchGetJudgeList(params);
  },
  transform: response => defaultTransform(response),
  onPaginationParamsChange: params => {
    searchParams.value.pageNum = params.page;
    searchParams.value.pageSize = params.pageSize;
  },
  columns: () => [
    {
      type: 'selection',
      align: 'center',
      width: 48
    },
    {
      key: 'index',
      title: $t('common.index'),
      align: 'center',
      width: 64,
      render: (_, index) => index + 1
    },
    {
      key: 'judgeName',
      title: '判定名称',
      align: 'center',
      width: 200,
      render: row => (
        <NTooltip trigger="hover">
          {{
            trigger: () => (
              <div
                style={{
                  whiteSpace: 'nowrap',
                  overflow: 'hidden',
                  textOverflow: 'ellipsis'
                }}
              >
                {row.judgeName}
              </div>
            ),
            default: () => row.judgeName
          }}
        </NTooltip>
      )
    },
    {
      key: 'category',
      title: '物料类型',
      align: 'center',
      width: 100,
      render: row => {
        if (row.category === 0) {
          return '成品';
        }
        if (row.category === 1) {
          return '辅料';
        }
        return String(row.category);
    api: () => {
      const params = { ...searchParams.value };
      if (params.status === -1) {
        delete params.status;
      }
      return fetchGetJudgeList(params);
    },
    {
      key: 'typeName',
      title: '辅料类型',
      align: 'center',
      width: 100,
      render: row => (
        <NTooltip trigger="hover">
          {{
            trigger: () => (
              <div
                style={{
                  whiteSpace: 'nowrap',
                  overflow: 'hidden',
                  textOverflow: 'ellipsis'
                }}
              >
                {row.typeName}
              </div>
            ),
            default: () => row.typeName
          }}
        </NTooltip>
      )
    transform: response => defaultTransform(response),
    onPaginationParamsChange: params => {
      searchParams.value.pageNum = params.page;
      searchParams.value.pageSize = params.pageSize;
    },
    {
      key: 'matName',
      title: '物料牌号',
      align: 'center',
      width: 180,
      render: row => (
        <NTooltip trigger="hover">
          {{
            trigger: () => (
              <div
                style={{
                  whiteSpace: 'nowrap',
                  overflow: 'hidden',
                  textOverflow: 'ellipsis'
                }}
              >
                {row.matName}
              </div>
            ),
            default: () => row.matName
          }}
        </NTooltip>
      )
    },
    {
      key: 'matCode',
      title: '物料牌号代码',
      align: 'center',
      width: 150
    },
    {
      key: 'version',
      title: '版本号',
      align: 'center',
      width: 100
    },
    {
      key: 'status',
      title: '状态',
      align: 'center',
      width: 100,
      render: row => {
        if (row.status === 1) {
          return '启用';
        }
        if (row.status === 0) {
          return '归档';
        }
        return String(row.status);
      }
    },
    {
      key: 'stdName',
      title: '判定规程',
      align: 'center',
      width: 200
    },
    {
      key: 'cdate',
      title: '创建时间',
      align: 'center',
      width: 180
    },
    {
      key: 'oper',
      title: '操作人',
      align: 'center',
      width: 100
    },
    {
      key: 'des',
      title: '备注',
      align: 'center',
      width: 200
    },
    {
      key: 'operate',
      title: $t('common.operate'),
      align: 'center',
      fixed: 'right',
      width: 130,
      render: row => {
        const divider = () => {
          if (!hasAuth('qm:judge:edit') || !hasAuth('qm:judge:remove')) {
            return null;
    columns: () => [
      {
        type: 'selection',
        align: 'center',
        width: 48
      },
      {
        key: 'index',
        title: $t('common.index'),
        align: 'center',
        width: 64,
        render: (_, index) => index + 1
      },
      {
        key: 'judgeName',
        title: '判定名称',
        align: 'center',
        width: 200,
        render: row => (
          <NTooltip trigger="hover">
            {{
              trigger: () => (
                <div
                  style={{
                    whiteSpace: 'nowrap',
                    overflow: 'hidden',
                    textOverflow: 'ellipsis'
                  }}
                >
                  {row.judgeName}
                </div>
              ),
              default: () => row.judgeName
            }}
          </NTooltip>
        )
      },
      {
        key: 'category',
        title: '物料类型',
        align: 'center',
        width: 100,
        render: row => {
          if (row.category === 0) {
            return '成品';
          }
          return <NDivider vertical />;
        };
          if (row.category === 1) {
            return '辅料';
          }
          return String(row.category);
        }
      },
      {
        key: 'typeName',
        title: '辅料类型',
        align: 'center',
        width: 100,
        render: row => (
          <NTooltip trigger="hover">
            {{
              trigger: () => (
                <div
                  style={{
                    whiteSpace: 'nowrap',
                    overflow: 'hidden',
                    textOverflow: 'ellipsis'
                  }}
                >
                  {row.typeName}
                </div>
              ),
              default: () => row.typeName
            }}
          </NTooltip>
        )
      },
      {
        key: 'matName',
        title: '物料牌号',
        align: 'center',
        width: 180,
        render: row => (
          <NTooltip trigger="hover">
            {{
              trigger: () => (
                <div
                  style={{
                    whiteSpace: 'nowrap',
                    overflow: 'hidden',
                    textOverflow: 'ellipsis'
                  }}
                >
                  {row.matName}
                </div>
              ),
              default: () => row.matName
            }}
          </NTooltip>
        )
      },
      {
        key: 'matCode',
        title: '物料牌号代码',
        align: 'center',
        width: 150
      },
      {
        key: 'version',
        title: '版本号',
        align: 'center',
        width: 100
      },
      {
        key: 'status',
        title: '状态',
        align: 'center',
        width: 100,
        render: row => {
          if (row.status === 1) {
            return '启用';
          }
          if (row.status === 0) {
            return '归档';
          }
          return String(row.status);
        }
      },
      {
        key: 'stdName',
        title: '判定规程',
        align: 'center',
        width: 200
      },
      {
        key: 'cdate',
        title: '创建时间',
        align: 'center',
        width: 180
      },
      {
        key: 'oper',
        title: '操作人',
        align: 'center',
        width: 100
      },
      {
        key: 'des',
        title: '备注',
        align: 'center',
        width: 200
      },
      {
        key: 'operate',
        title: $t('common.operate'),
        align: 'center',
        fixed: 'right',
        width: 130,
        render: row => {
          const divider = () => {
            if (!hasAuth('qm:judge:edit') || !hasAuth('qm:judge:remove')) {
              return null;
            }
            return <NDivider vertical />;
          };
        const editBtn = () => {
          if (!hasAuth('qm:judge:edit')) {
            return null;
          }
          const editBtn = () => {
            if (!hasAuth('qm:judge:edit')) {
              return null;
            }
            return (
              <ButtonIcon
                text
                type="primary"
                icon="material-symbols:drive-file-rename-outline-outline"
                tooltipContent={$t('common.edit')}
                onClick={() => edit(row.id)}
              />
            );
          };
          const deleteBtn = () => {
            if (!hasAuth('qm:judge:remove')) {
              return null;
            }
            return (
              <ButtonIcon
                text
                type="error"
                icon="material-symbols:delete-outline"
                tooltipContent={$t('common.delete')}
                popconfirmContent={$t('common.confirmDelete')}
                onPositiveClick={() => handleDelete(row.id)}
              />
            );
          };
          return (
            <ButtonIcon
              text
              type="primary"
              icon="material-symbols:drive-file-rename-outline-outline"
              tooltipContent={$t('common.edit')}
              onClick={() => edit(row.id)}
            />
            <div class="flex-center gap-8px">
              {editBtn()}
              {divider()}
              {deleteBtn()}
            </div>
          );
        };
        const deleteBtn = () => {
          if (!hasAuth('qm:judge:remove')) {
            return null;
          }
          return (
            <ButtonIcon
              text
              type="error"
              icon="material-symbols:delete-outline"
              tooltipContent={$t('common.delete')}
              popconfirmContent={$t('common.confirmDelete')}
              onPositiveClick={() => handleDelete(row.id)}
            />
          );
        };
        return (
          <div class="flex-center gap-8px">
            {editBtn()}
            {divider()}
            {deleteBtn()}
          </div>
        );
        }
      }
    }
  ]
});
    ]
  });
const { drawerVisible, operateType, editingData, handleAdd, handleEdit, checkedRowKeys, onBatchDeleted, onDeleted } =
  useTableOperate(data, 'id', getData);