zhou zhou
11 小时以前 50e95b985a72fcec4a93a2470e9efdfb2620148a
rsf-design/src/views/basic-info/warehouse-areas/index.vue
@@ -12,7 +12,9 @@
      <ArtTableHeader v-model:columns="columnChecks" :loading="loading" @refresh="refreshData">
        <template #left>
          <ElSpace wrap>
            <ElButton v-auth="'add'" @click="openWarehouseAreasDialog('add')" v-ripple>新增库区</ElButton>
            <ElButton v-auth="'add'" @click="openWarehouseAreasDialog('add')" v-ripple>
              {{ t('common.actions.add') + t('pages.basicInfo.warehouseAreas.entity') }}
            </ElButton>
            <ElButton
              v-auth="'delete'"
              type="danger"
@@ -20,7 +22,7 @@
              @click="handleBatchDelete"
              v-ripple
            >
              批量删除
              {{ t('common.actions.batchDelete') }}
            </ElButton>
            <ListExportPrint
              class="inline-flex"
@@ -74,6 +76,7 @@
<script setup>
  import { computed, onMounted, ref } from 'vue'
  import { ElMessage } from 'element-plus'
  import { useI18n } from 'vue-i18n'
  import ListExportPrint from '@/components/biz/list-export-print/index.vue'
  import { useAuth } from '@/hooks/core/useAuth'
  import { useTable } from '@/hooks/core/useTable'
@@ -105,9 +108,9 @@
    buildWarehouseAreasSavePayload,
    buildWarehouseAreasSearchParams,
    createWarehouseAreasSearchState,
    getWarehouseAreasReportTitle,
    getWarehouseAreasPaginationKey,
    WAREHOUSE_AREAS_REPORT_STYLE,
    WAREHOUSE_AREAS_REPORT_TITLE,
    getWarehouseAreasStatusOptions,
    normalizeWarehouseAreasDetailRecord,
    normalizeWarehouseAreasListRow
@@ -115,6 +118,7 @@
  defineOptions({ name: 'WarehouseAreas' })
  const { t } = useI18n()
  const { hasAuth } = useAuth()
  const userStore = useUserStore()
@@ -132,16 +136,16 @@
  const searchItems = computed(() => [
    {
      label: '关键字',
      label: t('table.keyword'),
      key: 'condition',
      type: 'input',
      props: {
        clearable: true,
        placeholder: '请输入库区名称/编码/备注'
        placeholder: t('pages.basicInfo.warehouseAreas.search.conditionPlaceholder')
      }
    },
    {
      label: '仓库',
      label: t('pages.basicInfo.warehouseAreas.table.warehouseName'),
      key: 'warehouseId',
      type: 'select',
      props: {
@@ -151,25 +155,25 @@
      }
    },
    {
      label: '库区编码',
      label: t('pages.basicInfo.warehouseAreas.table.code'),
      key: 'code',
      type: 'input',
      props: {
        clearable: true,
        placeholder: '请输入库区编码'
        placeholder: t('pages.basicInfo.warehouseAreas.search.codePlaceholder')
      }
    },
    {
      label: '库区名称',
      label: t('pages.basicInfo.warehouseAreas.table.name'),
      key: 'name',
      type: 'input',
      props: {
        clearable: true,
        placeholder: '请输入库区名称'
        placeholder: t('pages.basicInfo.warehouseAreas.search.namePlaceholder')
      }
    },
    {
      label: '业务类型',
      label: t('pages.basicInfo.warehouseAreas.table.type'),
      key: 'type',
      type: 'select',
      props: {
@@ -179,17 +183,17 @@
      }
    },
    {
      label: '状态',
      label: t('table.status'),
      key: 'status',
      type: 'select',
      props: {
        clearable: true,
        options: getWarehouseAreasStatusOptions()
        options: getWarehouseAreasStatusOptions(t)
      }
    }
  ])
  const reportTitle = WAREHOUSE_AREAS_REPORT_TITLE
  const reportTitle = computed(() => getWarehouseAreasReportTitle(t))
  const reportQueryParams = computed(() => buildWarehouseAreasSearchParams(searchForm.value))
  async function openDetail(row) {
@@ -197,13 +201,13 @@
    detailLoading.value = true
    try {
      const detail = await guardRequestWithMessage(fetchWarehouseAreasDetail(row.id), {}, {
        timeoutMessage: '库区详情加载超时,已停止等待'
        timeoutMessage: t('pages.basicInfo.warehouseAreas.messages.detailTimeout')
      })
      detailData.value = normalizeWarehouseAreasDetailRecord(detail)
    } catch (error) {
      detailDrawerVisible.value = false
      detailData.value = {}
      ElMessage.error(error?.message || '获取库区详情失败')
      ElMessage.error(error?.message || t('pages.basicInfo.warehouseAreas.messages.detailFailed'))
    } finally {
      detailLoading.value = false
    }
@@ -213,11 +217,11 @@
    try {
      await ensureCompanyOptions()
      const detail = await guardRequestWithMessage(fetchWarehouseAreasDetail(row.id), {}, {
        timeoutMessage: '库区详情加载超时,已停止等待'
        timeoutMessage: t('pages.basicInfo.warehouseAreas.messages.detailTimeout')
      })
      showDialog('edit', detail)
    } catch (error) {
      ElMessage.error(error?.message || '获取库区详情失败')
      ElMessage.error(error?.message || t('pages.basicInfo.warehouseAreas.messages.detailFailed'))
    }
  }
@@ -234,6 +238,7 @@
        paginationKey: getWarehouseAreasPaginationKey(),
        columnsFactory: () =>
          createWarehouseAreasTableColumns({
            t,
            handleView: openDetail,
            handleEdit: hasAuth('update') ? openEditDialog : null,
            handleDelete: hasAuth('delete') ? (row) => handleDeleteAction?.(row) : null,
@@ -268,7 +273,7 @@
    saveRequest: fetchSaveWarehouseAreas,
    updateRequest: fetchUpdateWarehouseAreas,
    deleteRequest: fetchDeleteWarehouseAreas,
    entityName: '库区',
    entityName: t('pages.basicInfo.warehouseAreas.entity'),
    resolveRecordLabel: (record) => record?.name || record?.code || record?.id,
    refreshCreate,
    refreshUpdate,
@@ -283,6 +288,7 @@
      printedAt: now.toLocaleString('zh-CN', { hour12: false }),
      operator: userStore.getUserInfo?.name || userStore.getUserInfo?.username || '',
      count: rows.length,
      reportTitle: reportTitle.value,
      reportStyle: { ...WAREHOUSE_AREAS_REPORT_STYLE }
    }
  }
@@ -322,7 +328,7 @@
  const resolvedPreviewMeta = computed(() => ({
    ...previewMeta.value,
    reportTitle,
    reportTitle: reportTitle.value,
    count: previewRows.value.length || previewMeta.value?.count || 0,
    reportStyle: {
      ...WAREHOUSE_AREAS_REPORT_STYLE,
@@ -352,19 +358,19 @@
    companyOptionsLoading.value = (async () => {
      const records = await guardRequestWithMessage(fetchCompanysList(), [], {
        timeoutMessage: '往来企业选项加载超时,已停止等待'
        timeoutMessage: t('pages.basicInfo.warehouseAreas.messages.companyOptionsTimeout')
      })
      const normalizedRecords = defaultResponseAdapter(records).records
      shipperOptions.value = normalizedRecords
        .filter((item) => item.type === 'shipper')
        .map((item) => ({
          label: item.name || item.code || `货主 ${item.id}`,
          label: item.name || item.code || `${t('pages.basicInfo.warehouseAreas.table.shipperName')} ${item.id}`,
          value: item.id
        }))
      supplierOptions.value = normalizedRecords
        .filter((item) => item.type === 'supplier')
        .map((item) => ({
          label: item.name || item.code || `供应商 ${item.id}`,
          label: item.name || item.code || `${t('pages.basicInfo.warehouseAreas.table.supplierName')} ${item.id}`,
          value: item.id
        }))
      companyOptionsLoaded.value = true
@@ -379,10 +385,10 @@
  async function loadWarehouseOptions() {
    const records = await guardRequestWithMessage(fetchWarehouseList(), [], {
      timeoutMessage: '仓库选项加载超时,已停止等待'
      timeoutMessage: t('pages.basicInfo.warehouseAreas.messages.warehouseOptionsTimeout')
    })
    warehouseOptions.value = defaultResponseAdapter(records).records.map((item) => ({
      label: item.name || item.code || `仓库 ${item.id}`,
      label: item.name || item.code || `${t('pages.basicInfo.warehouseAreas.table.warehouseName')} ${item.id}`,
      value: item.id
    }))
  }
@@ -396,7 +402,7 @@
        status: 1
      }),
      { records: [] },
      { timeoutMessage: '业务类型加载超时,已停止等待' }
      { timeoutMessage: t('pages.basicInfo.warehouseAreas.messages.typeOptionsTimeout') }
    )
    typeOptions.value = defaultResponseAdapter(response).records.map((item) => ({
      label: item.label || item.name || item.value,