zhou zhou
10 小时以前 c579731e0c206d6062f8442ec9df70ca781b26f6
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
import { h } from 'vue'
import { ElTag } from 'element-plus'
import ArtButtonMore from '@/components/core/forms/art-button-more/index.vue'
import { getMatnrGroupStatusMeta } from './matnrGroupPage.helpers'
 
export function createMatnrGroupTableColumns({
  handleView,
  handleEdit,
  handleDelete,
  resolveParentLabel,
  canEdit = true,
  canDelete = true
}) {
  const operations = [{ key: 'view', label: '详情', icon: 'ri:eye-line' }]
 
  if (canEdit && handleEdit) {
    operations.push({ key: 'edit', label: '编辑', icon: 'ri:pencil-line' })
  }
 
  if (canDelete && handleDelete) {
    operations.push({ key: 'delete', label: '删除', icon: 'ri:delete-bin-5-line', color: 'var(--art-error)' })
  }
 
  return [
    {
      type: 'selection',
      width: 48,
      align: 'center'
    },
    {
      type: 'globalIndex',
      label: '序号',
      width: 72,
      align: 'center'
    },
    {
      prop: 'name',
      label: '分组名称',
      minWidth: 180,
      showOverflowTooltip: true
    },
    {
      prop: 'code',
      label: '分组编码',
      minWidth: 150,
      showOverflowTooltip: true
    },
    {
      prop: 'parentLabel',
      label: '上级分组',
      minWidth: 160,
      showOverflowTooltip: true,
      formatter: (row) => {
        if (typeof resolveParentLabel === 'function') {
          const resolved = resolveParentLabel(row.parentId)
          if (resolved) {
            return resolved
          }
        }
        return row.parentLabel || (Number(row.parentId) === 0 ? '顶级分组' : '--')
      }
    },
    {
      prop: 'parCode',
      label: '上级编码',
      minWidth: 160,
      showOverflowTooltip: true
    },
    {
      prop: 'sort',
      label: '排序',
      width: 90,
      align: 'center'
    },
    {
      prop: 'status',
      label: '状态',
      width: 100,
      align: 'center',
      formatter: (row) => {
        const statusMeta = getMatnrGroupStatusMeta(row.statusBool ?? row.status)
        return h(ElTag, { type: statusMeta.type, effect: 'light' }, () => statusMeta.text)
      }
    },
    {
      prop: 'memo',
      label: '备注',
      minWidth: 180,
      showOverflowTooltip: true
    },
    {
      prop: 'createByText',
      label: '创建人',
      minWidth: 120,
      showOverflowTooltip: true
    },
    {
      prop: 'createTimeText',
      label: '创建时间',
      minWidth: 170,
      showOverflowTooltip: true
    },
    {
      prop: 'updateByText',
      label: '更新人',
      minWidth: 120,
      showOverflowTooltip: true
    },
    {
      prop: 'updateTimeText',
      label: '更新时间',
      minWidth: 170,
      showOverflowTooltip: true
    },
    {
      prop: 'operation',
      label: '操作',
      width: 120,
      align: 'center',
      fixed: 'right',
      formatter: (row) =>
        h(ArtButtonMore, {
          list: operations,
          onClick: (item) => {
            if (item.key === 'view') handleView?.(row)
            if (item.key === 'edit') handleEdit?.(row)
            if (item.key === 'delete') handleDelete?.(row)
          }
        })
    }
  ]
}