@vipl520/dk-ui 1.0.25 → 1.0.27

Sign up to get free protection for your applications and to get access to all the features.
package/dist/index.mjs CHANGED
@@ -353,7 +353,6 @@ const request = (config, custom, loading) => {
353
353
  return config2;
354
354
  },
355
355
  (error) => {
356
- console.log("error", error);
357
356
  return Promise.reject(error);
358
357
  }
359
358
  );
@@ -24755,7 +24754,6 @@ const tableProps = {
24755
24754
  },
24756
24755
  type: Array
24757
24756
  }
24758
- // ...ElTableNext.props,
24759
24757
  };
24760
24758
 
24761
24759
  /**!
@@ -28100,6 +28098,7 @@ class dkTable {
28100
28098
  this.runAfter("getIndex", { res });
28101
28099
  }).finally(() => {
28102
28100
  this.table.loading = false;
28101
+ }).catch(() => {
28103
28102
  });
28104
28103
  };
28105
28104
  getTable = (cache = false) => {
@@ -28107,7 +28106,7 @@ class dkTable {
28107
28106
  return;
28108
28107
  this.table.columnLoading = true;
28109
28108
  if (cache) {
28110
- const cachedData = storage.get(this.url + "_table");
28109
+ const cachedData = storage.get(this.api.actionUrl.get("table") + "_table");
28111
28110
  if (cachedData) {
28112
28111
  const cachedTableData = JSON.parse(cachedData);
28113
28112
  this.table.column = cachedTableData.column;
@@ -28121,10 +28120,11 @@ class dkTable {
28121
28120
  if (res.data.pk) {
28122
28121
  this.table.pk = res.data.pk;
28123
28122
  }
28124
- storage.set(this.url + "_table", JSON.stringify(res.data));
28123
+ storage.set(this.api.actionUrl.get("table") + "_table", JSON.stringify(res.data));
28125
28124
  this.runAfter("getTable", { res });
28126
28125
  }).finally(() => {
28127
28126
  this.table.columnLoading = false;
28127
+ }).catch(() => {
28128
28128
  });
28129
28129
  }
28130
28130
  };
@@ -30504,6 +30504,7 @@ var _sfc_main$d = /* @__PURE__ */ defineComponent({
30504
30504
  loading: _ctx.row.loading,
30505
30505
  "inactive-value": "0",
30506
30506
  "active-value": "1",
30507
+ size: "small",
30507
30508
  onChange: onChangeField
30508
30509
  }, null, 8, ["model-value", "loading"])) : createCommentVNode("v-if", true),
30509
30510
  createCommentVNode(" \u5355\u56FE "),
@@ -2,7 +2,7 @@
2
2
  "$schema": "http://json.schemastore.org/web-types",
3
3
  "framework": "vue",
4
4
  "name": "dk",
5
- "version": "1.0.24",
5
+ "version": "1.0.26",
6
6
  "js-types-syntax": "typescript",
7
7
  "description-markup": "markdown",
8
8
  "contributions": {
@@ -104,6 +104,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
104
104
  loading: _ctx.row.loading,
105
105
  "inactive-value": "0",
106
106
  "active-value": "1",
107
+ size: "small",
107
108
  onChange: onChangeField
108
109
  }, null, 8, ["model-value", "loading"])) : createCommentVNode("v-if", true),
109
110
  createCommentVNode(" \u5355\u56FE "),
@@ -1 +1 @@
1
- {"version":3,"file":"FieldRender.vue2.mjs","sources":["../../../../src/table/src/components/FieldRender.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as __MACROS_defineComponent } from \"vue\";\nexport default /*#__PURE__*/ __MACROS_defineComponent({\n name: 'DkFieldRender',\n});\n</script>\n<template>\n <!--图标-->\n <div v-if=\"field.render == 'icon'\">\n <dk-icon v-if=\"fieldValue || field.default\" :icon=\"fieldValue ? fieldValue : field.default\" />\n <span v-else>-</span>\n </div>\n\n <!--开关-->\n <el-switch\n v-if=\"field.render == 'switch' && fieldValue !== ''\"\n :model-value=\"fieldValue.toString()\"\n :loading=\"row.loading\"\n inactive-value=\"0\"\n active-value=\"1\"\n @change=\"onChangeField\"\n ></el-switch>\n\n <!-- 单图 -->\n <div v-if=\"field.render == 'image' && fieldValue\" class=\"ba-render-image\">\n <el-image\n :hide-on-click-modal=\"true\"\n :preview-teleported=\"true\"\n :preview-src-list=\"[fieldValue]\"\n :src=\"fieldValue\"\n fit=\"cover\"\n style=\"width: 50px; height: 50px\"\n ></el-image>\n </div>\n\n <!--多图片-->\n <div v-if=\"field.render == 'images'\" class=\"ba-render-image\">\n <template v-if=\"Array.isArray(fieldValue) && fieldValue.length\">\n <el-image\n v-for=\"(item, idx) in fieldValue\"\n :key=\"idx\"\n :initial-index=\"idx\"\n :preview-teleported=\"true\"\n :preview-src-list=\"fieldValue\"\n class=\"images-item\"\n :src=\"item\"\n style=\"width: 50px; height: 50px\"\n :hide-on-click-modal=\"true\"\n ></el-image>\n </template>\n </div>\n\n <div v-if=\"field.render == 'tag' && fieldValue !== ''\">\n <el-tag\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] : fieldValue }}\n </el-tag>\n </div>\n\n <!-- tags -->\n <div v-if=\"field.render == 'tags'\">\n <template v-if=\"Array.isArray(fieldValue)\">\n <template v-for=\"(tag, idx) in fieldValue\" :key=\"idx\">\n <el-tag\n v-if=\"tag !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(tag, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[tag] ?? tag : tag }}</el-tag\n >\n </template>\n </template>\n <template v-else>\n <el-tag\n v-if=\"fieldValue !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] ?? fieldValue : fieldValue }}\n </el-tag>\n </template>\n </div>\n\n <!-- url -->\n <div v-if=\"field.render == 'url' && fieldValue\">\n <el-input :model-value=\"fieldValue\" placeholder=\"链接地址\">\n <template #append>\n <el-button\n @click=\"\n typeof field.click == 'function'\n ? field.click(row, field, fieldValue, column, index)\n : openUrl(fieldValue, field.target)\n \"\n >\n <dk-icon :color=\"'#606266'\" icon=\"Position\" />\n </el-button>\n </template>\n </el-input>\n </div>\n\n <!-- datetime -->\n <div v-if=\"field.render == 'datetime'\">\n {{ !fieldValue ? '-' : timeFormat(fieldValue, field.timeFormat ?? undefined) }}\n </div>\n\n <div v-if=\"field.render == 'time'\">\n {{ fieldValue }}\n </div>\n <div v-if=\"field.render == 'year'\">\n {{ fieldValue }}\n </div>\n <!-- color -->\n <div v-if=\"field.render == 'color'\">\n <div :style=\"{ background: fieldValue }\" class=\"dk-render-color\"></div>\n </div>\n\n <!-- 自定义组件/函数渲染 -->\n <component\n :is=\"field.customRender\"\n v-if=\"field.render == 'customRender'\"\n :render-row=\"row\"\n :render-field=\"field\"\n :render-value=\"fieldValue\"\n :render-column=\"column\"\n :render-index=\"index\"\n />\n\n <!-- 按钮组 -->\n <!-- 只对默认的编辑、删除、排序按钮进行鉴权,其他按钮请通过 display 属性控制按钮是否显示 -->\n <div v-if=\"field.render == 'buttons' && field.buttons\">\n <template v-for=\"(btn, idx) in field.buttons\" :key=\"idx\">\n <template v-if=\"btn.display ? btn.display(row, field) : true\">\n <!-- 常规按钮 未使用-->\n <el-button\n v-if=\"btn.render == 'basicButton'\"\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n\n <!-- 带提示信息的按钮 -->\n <el-tooltip\n v-if=\"btn.render == 'tipButton' && ((btn.name == 'edit' && DkTable.auth('edit')) || btn.name != 'edit')\"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n placement=\"top\"\n :hide-after=\"0\"\n :show-after=\"100\"\n >\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n\n <!-- 带确认框的按钮 -->\n <el-popconfirm\n v-if=\"\n btn.render == 'confirmButton' && ((btn.name == 'delete' && DkTable.auth('del')) || btn.name != 'delete')\n \"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.popconfirm\"\n :hide-after=\"0\"\n :show-after=\"100\"\n @confirm=\"onButtonClick(btn)\"\n >\n <template #reference>\n <div class=\"dk-tooltip-button\">\n <el-tooltip :disabled=\"!btn.title\" :content=\"btn.title ?? ''\" placement=\"top\">\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">\n {{ btn.text }}\n </div>\n </el-button>\n </el-tooltip>\n </div>\n </template>\n </el-popconfirm>\n\n <!-- 带提示的可拖拽按钮 -->\n <el-tooltip\n v-if=\"\n btn.render == 'moveButton' &&\n ((btn.name == 'weigh-sort' && DkTable.auth('sortable')) || btn.name != 'weigh-sort')\n \"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n :hide-after=\"0\"\n :show-after=\"100\"\n placement=\"top\"\n >\n <el-button\n :class=\"btn.class\"\n class=\"table-operate move-button\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n size=\"small\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n </template>\n </template>\n </div>\n</template>\n<script setup lang=\"ts\">\nimport { inject, ref } from 'vue'\nimport type { TableColumnCtx, TagProps } from 'element-plus'\nimport { openUrl, timeFormat } from '@vipl520/utils'\nimport type dkTable from '../../utils/dkTable'\n\nconst DkTable = inject('DkTable') as dkTable\n\ninterface Props {\n row: TableRow\n field: TableColumn\n column: TableColumnCtx<TableRow>\n index: number\n}\nconst props = defineProps<Props>()\n\nconst fieldName: any = ref(props.field.prop)\nconst fieldValue = ref(props.row[fieldName.value] ?? '')\n\nif (fieldName.value && fieldName.value.indexOf('.') > -1) {\n const fieldNameArr = fieldName.value.split('.')\n const val: any = ref(props.row[fieldNameArr[0]])\n for (let index = 1; index < fieldNameArr.length; index++) {\n val.value = val.value ? val.value[fieldNameArr[index]] ?? '' : ''\n }\n fieldValue.value = val.value\n}\n\nconst getTagType = (value: string, custom: any): TagProps['type'] => {\n return custom && custom[value] ? custom[value] : ''\n}\n\nconst onChangeField = (value: any) => {\n DkTable.onTableAction('field-change', {\n ...props,\n value,\n })\n}\n\nconst onButtonClick = (btn: OptButton) => {\n if (typeof btn.click === 'function') {\n btn.click(props.row, props.field)\n return\n }\n DkTable.onTableAction(btn.name, props)\n}\n</script>\n<style scoped></style>\n"],"names":["__MACROS_defineComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAA6B,cAAAA,eAAyB,CAAA;AAAA,EACpD,IAAM,EAAA,eAAA;AACR,CAAC,CAAA,CAAA;;;;;;;;;;;AA+OD,IAAM,MAAA,OAAA,GAAU,OAAO,SAAS,CAAA,CAAA;AAUhC,IAAA,MAAM,SAAiB,GAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,IAAI,CAAA,CAAA;AAC3C,IAAA,MAAM,aAAa,GAAI,CAAA,KAAA,CAAM,IAAI,SAAU,CAAA,KAAK,KAAK,EAAE,CAAA,CAAA;AAEvD,IAAA,IAAI,UAAU,KAAS,IAAA,SAAA,CAAU,MAAM,OAAQ,CAAA,GAAG,IAAI,CAAI,CAAA,EAAA;AACxD,MAAA,MAAM,YAAe,GAAA,SAAA,CAAU,KAAM,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC9C,MAAA,MAAM,MAAW,GAAI,CAAA,KAAA,CAAM,IAAI,YAAa,CAAA,CAAC,CAAC,CAAC,CAAA,CAAA;AAC/C,MAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,YAAA,CAAa,QAAQ,KAAS,EAAA,EAAA;AACxD,QAAI,GAAA,CAAA,KAAA,GAAQ,IAAI,KAAQ,GAAA,GAAA,CAAI,MAAM,YAAa,CAAA,KAAK,CAAC,CAAA,IAAK,EAAK,GAAA,EAAA,CAAA;AAAA,OACjE;AACA,MAAA,UAAA,CAAW,QAAQ,GAAI,CAAA,KAAA,CAAA;AAAA,KACzB;AAEA,IAAM,MAAA,UAAA,GAAa,CAAC,KAAA,EAAe,MAAkC,KAAA;AACnE,MAAA,OAAO,UAAU,MAAO,CAAA,KAAK,CAAI,GAAA,MAAA,CAAO,KAAK,CAAI,GAAA,EAAA,CAAA;AAAA,KACnD,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,KAAe,KAAA;AACpC,MAAA,OAAA,CAAQ,cAAc,cAAgB,EAAA;AAAA,QACpC,GAAG,KAAA;AAAA,QACH,KAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACH,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,GAAmB,KAAA;AACxC,MAAI,IAAA,OAAO,GAAI,CAAA,KAAA,KAAU,UAAY,EAAA;AACnC,QAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,GAAK,EAAA,KAAA,CAAM,KAAK,CAAA,CAAA;AAChC,QAAA,OAAA;AAAA,OACF;AACA,MAAQ,OAAA,CAAA,aAAA,CAAc,GAAI,CAAA,IAAA,EAAM,KAAK,CAAA,CAAA;AAAA,KACvC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"FieldRender.vue2.mjs","sources":["../../../../src/table/src/components/FieldRender.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as __MACROS_defineComponent } from \"vue\";\nexport default /*#__PURE__*/ __MACROS_defineComponent({\n name: 'DkFieldRender',\n});\n</script>\n<template>\n <!--图标-->\n <div v-if=\"field.render == 'icon'\">\n <dk-icon v-if=\"fieldValue || field.default\" :icon=\"fieldValue ? fieldValue : field.default\" />\n <span v-else>-</span>\n </div>\n\n <!--开关-->\n <el-switch\n v-if=\"field.render == 'switch' && fieldValue !== ''\"\n :model-value=\"fieldValue.toString()\"\n :loading=\"row.loading\"\n inactive-value=\"0\"\n active-value=\"1\"\n size=\"small\"\n @change=\"onChangeField\"\n ></el-switch>\n\n <!-- 单图 -->\n <div v-if=\"field.render == 'image' && fieldValue\" class=\"ba-render-image\">\n <el-image\n :hide-on-click-modal=\"true\"\n :preview-teleported=\"true\"\n :preview-src-list=\"[fieldValue]\"\n :src=\"fieldValue\"\n fit=\"cover\"\n style=\"width: 50px; height: 50px\"\n ></el-image>\n </div>\n\n <!--多图片-->\n <div v-if=\"field.render == 'images'\" class=\"ba-render-image\">\n <template v-if=\"Array.isArray(fieldValue) && fieldValue.length\">\n <el-image\n v-for=\"(item, idx) in fieldValue\"\n :key=\"idx\"\n :initial-index=\"idx\"\n :preview-teleported=\"true\"\n :preview-src-list=\"fieldValue\"\n class=\"images-item\"\n :src=\"item\"\n style=\"width: 50px; height: 50px\"\n :hide-on-click-modal=\"true\"\n ></el-image>\n </template>\n </div>\n\n <div v-if=\"field.render == 'tag' && fieldValue !== ''\">\n <el-tag\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] : fieldValue }}\n </el-tag>\n </div>\n\n <!-- tags -->\n <div v-if=\"field.render == 'tags'\">\n <template v-if=\"Array.isArray(fieldValue)\">\n <template v-for=\"(tag, idx) in fieldValue\" :key=\"idx\">\n <el-tag\n v-if=\"tag !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(tag, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[tag] ?? tag : tag }}</el-tag\n >\n </template>\n </template>\n <template v-else>\n <el-tag\n v-if=\"fieldValue !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] ?? fieldValue : fieldValue }}\n </el-tag>\n </template>\n </div>\n\n <!-- url -->\n <div v-if=\"field.render == 'url' && fieldValue\">\n <el-input :model-value=\"fieldValue\" placeholder=\"链接地址\">\n <template #append>\n <el-button\n @click=\"\n typeof field.click == 'function'\n ? field.click(row, field, fieldValue, column, index)\n : openUrl(fieldValue, field.target)\n \"\n >\n <dk-icon :color=\"'#606266'\" icon=\"Position\" />\n </el-button>\n </template>\n </el-input>\n </div>\n\n <!-- datetime -->\n <div v-if=\"field.render == 'datetime'\">\n {{ !fieldValue ? '-' : timeFormat(fieldValue, field.timeFormat ?? undefined) }}\n </div>\n\n <div v-if=\"field.render == 'time'\">\n {{ fieldValue }}\n </div>\n <div v-if=\"field.render == 'year'\">\n {{ fieldValue }}\n </div>\n <!-- color -->\n <div v-if=\"field.render == 'color'\">\n <div :style=\"{ background: fieldValue }\" class=\"dk-render-color\"></div>\n </div>\n\n <!-- 自定义组件/函数渲染 -->\n <component\n :is=\"field.customRender\"\n v-if=\"field.render == 'customRender'\"\n :render-row=\"row\"\n :render-field=\"field\"\n :render-value=\"fieldValue\"\n :render-column=\"column\"\n :render-index=\"index\"\n />\n\n <!-- 按钮组 -->\n <!-- 只对默认的编辑、删除、排序按钮进行鉴权,其他按钮请通过 display 属性控制按钮是否显示 -->\n <div v-if=\"field.render == 'buttons' && field.buttons\">\n <template v-for=\"(btn, idx) in field.buttons\" :key=\"idx\">\n <template v-if=\"btn.display ? btn.display(row, field) : true\">\n <!-- 常规按钮 未使用-->\n <el-button\n v-if=\"btn.render == 'basicButton'\"\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n\n <!-- 带提示信息的按钮 -->\n <el-tooltip\n v-if=\"btn.render == 'tipButton' && ((btn.name == 'edit' && DkTable.auth('edit')) || btn.name != 'edit')\"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n placement=\"top\"\n :hide-after=\"0\"\n :show-after=\"100\"\n >\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n\n <!-- 带确认框的按钮 -->\n <el-popconfirm\n v-if=\"\n btn.render == 'confirmButton' && ((btn.name == 'delete' && DkTable.auth('del')) || btn.name != 'delete')\n \"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.popconfirm\"\n :hide-after=\"0\"\n :show-after=\"100\"\n @confirm=\"onButtonClick(btn)\"\n >\n <template #reference>\n <div class=\"dk-tooltip-button\">\n <el-tooltip :disabled=\"!btn.title\" :content=\"btn.title ?? ''\" placement=\"top\">\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">\n {{ btn.text }}\n </div>\n </el-button>\n </el-tooltip>\n </div>\n </template>\n </el-popconfirm>\n\n <!-- 带提示的可拖拽按钮 -->\n <el-tooltip\n v-if=\"\n btn.render == 'moveButton' &&\n ((btn.name == 'weigh-sort' && DkTable.auth('sortable')) || btn.name != 'weigh-sort')\n \"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n :hide-after=\"0\"\n :show-after=\"100\"\n placement=\"top\"\n >\n <el-button\n :class=\"btn.class\"\n class=\"table-operate move-button\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n size=\"small\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n </template>\n </template>\n </div>\n</template>\n<script setup lang=\"ts\">\nimport { inject, ref } from 'vue'\nimport type { TableColumnCtx, TagProps } from 'element-plus'\nimport { openUrl, timeFormat } from '@vipl520/utils'\nimport type dkTable from '../../utils/dkTable'\n\nconst DkTable = inject('DkTable') as dkTable\n\ninterface Props {\n row: TableRow\n field: TableColumn\n column: TableColumnCtx<TableRow>\n index: number\n}\nconst props = defineProps<Props>()\n\nconst fieldName: any = ref(props.field.prop)\nconst fieldValue = ref(props.row[fieldName.value] ?? '')\n\nif (fieldName.value && fieldName.value.indexOf('.') > -1) {\n const fieldNameArr = fieldName.value.split('.')\n const val: any = ref(props.row[fieldNameArr[0]])\n for (let index = 1; index < fieldNameArr.length; index++) {\n val.value = val.value ? val.value[fieldNameArr[index]] ?? '' : ''\n }\n fieldValue.value = val.value\n}\n\nconst getTagType = (value: string, custom: any): TagProps['type'] => {\n return custom && custom[value] ? custom[value] : ''\n}\n\nconst onChangeField = (value: any) => {\n DkTable.onTableAction('field-change', {\n ...props,\n value,\n })\n}\n\nconst onButtonClick = (btn: OptButton) => {\n if (typeof btn.click === 'function') {\n btn.click(props.row, props.field)\n return\n }\n DkTable.onTableAction(btn.name, props)\n}\n</script>\n<style scoped></style>\n"],"names":["__MACROS_defineComponent"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAA6B,cAAAA,eAAyB,CAAA;AAAA,EACpD,IAAM,EAAA,eAAA;AACR,CAAC,CAAA,CAAA;;;;;;;;;;;AAgPD,IAAM,MAAA,OAAA,GAAU,OAAO,SAAS,CAAA,CAAA;AAUhC,IAAA,MAAM,SAAiB,GAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,IAAI,CAAA,CAAA;AAC3C,IAAA,MAAM,aAAa,GAAI,CAAA,KAAA,CAAM,IAAI,SAAU,CAAA,KAAK,KAAK,EAAE,CAAA,CAAA;AAEvD,IAAA,IAAI,UAAU,KAAS,IAAA,SAAA,CAAU,MAAM,OAAQ,CAAA,GAAG,IAAI,CAAI,CAAA,EAAA;AACxD,MAAA,MAAM,YAAe,GAAA,SAAA,CAAU,KAAM,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC9C,MAAA,MAAM,MAAW,GAAI,CAAA,KAAA,CAAM,IAAI,YAAa,CAAA,CAAC,CAAC,CAAC,CAAA,CAAA;AAC/C,MAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,YAAA,CAAa,QAAQ,KAAS,EAAA,EAAA;AACxD,QAAI,GAAA,CAAA,KAAA,GAAQ,IAAI,KAAQ,GAAA,GAAA,CAAI,MAAM,YAAa,CAAA,KAAK,CAAC,CAAA,IAAK,EAAK,GAAA,EAAA,CAAA;AAAA,OACjE;AACA,MAAA,UAAA,CAAW,QAAQ,GAAI,CAAA,KAAA,CAAA;AAAA,KACzB;AAEA,IAAM,MAAA,UAAA,GAAa,CAAC,KAAA,EAAe,MAAkC,KAAA;AACnE,MAAA,OAAO,UAAU,MAAO,CAAA,KAAK,CAAI,GAAA,MAAA,CAAO,KAAK,CAAI,GAAA,EAAA,CAAA;AAAA,KACnD,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,KAAe,KAAA;AACpC,MAAA,OAAA,CAAQ,cAAc,cAAgB,EAAA;AAAA,QACpC,GAAG,KAAA;AAAA,QACH,KAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACH,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,GAAmB,KAAA;AACxC,MAAI,IAAA,OAAO,GAAI,CAAA,KAAA,KAAU,UAAY,EAAA;AACnC,QAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,GAAK,EAAA,KAAA,CAAM,KAAK,CAAA,CAAA;AAChC,QAAA,OAAA;AAAA,OACF;AACA,MAAQ,OAAA,CAAA,aAAA,CAAc,GAAI,CAAA,IAAA,EAAM,KAAK,CAAA,CAAA;AAAA,KACvC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -25,7 +25,6 @@ const tableProps = {
25
25
  },
26
26
  type: Array
27
27
  }
28
- // ...ElTableNext.props,
29
28
  };
30
29
 
31
30
  export { tableProps };
@@ -1 +1 @@
1
- {"version":3,"file":"props.mjs","sources":["../../../src/table/src/props.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n// import ElTableNext from 'el-table-next'\n\nexport const tableProps = {\n tableApi: {\n default: '',\n type: String,\n },\n cacheTable: {\n default: true,\n type: Boolean,\n },\n tableBefore: {\n default: () => {\n return {}\n },\n type: Object,\n },\n tableAfter: {\n default: () => {\n return {}\n },\n type: Object,\n },\n buttons: {\n default: () => {\n return ['refresh', 'add', 'export_csv', 'edit', 'delete', 'comSearch', 'quickSearch', 'columnDisplay']\n },\n type: Array,\n },\n // ...ElTableNext.props,\n}\n\nexport type TableProps = ExtractPropTypes<typeof tableProps>\n"],"names":[],"mappings":"AAGO,MAAM,UAAa,GAAA;AAAA,EACxB,QAAU,EAAA;AAAA,IACR,OAAS,EAAA,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,OAAS,EAAA,IAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,GACR;AAAA,EACA,WAAa,EAAA;AAAA,IACX,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,OAAS,EAAA;AAAA,IACP,SAAS,MAAM;AACb,MAAO,OAAA,CAAC,WAAW,KAAO,EAAA,YAAA,EAAc,QAAQ,QAAU,EAAA,WAAA,EAAa,eAAe,eAAe,CAAA,CAAA;AAAA,KACvG;AAAA,IACA,IAAM,EAAA,KAAA;AAAA,GACR;AAAA;AAEF;;;;"}
1
+ {"version":3,"file":"props.mjs","sources":["../../../src/table/src/props.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n// import ElTableNext from 'el-table-next'\n\nexport const tableProps = {\n tableApi: {\n default: '',\n type: String,\n },\n cacheTable: {\n default: true,\n type: Boolean,\n },\n tableBefore: {\n default: () => {\n return {}\n },\n type: Object,\n },\n tableAfter: {\n default: () => {\n return {}\n },\n type: Object,\n },\n buttons: {\n default: () => {\n return ['refresh', 'add', 'export_csv', 'edit', 'delete', 'comSearch', 'quickSearch', 'columnDisplay']\n },\n type: Array,\n },\n}\n\nexport type TableProps = ExtractPropTypes<typeof tableProps>\n"],"names":[],"mappings":"AAGO,MAAM,UAAa,GAAA;AAAA,EACxB,QAAU,EAAA;AAAA,IACR,OAAS,EAAA,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,OAAS,EAAA,IAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,GACR;AAAA,EACA,WAAa,EAAA;AAAA,IACX,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,OAAS,EAAA;AAAA,IACP,SAAS,MAAM;AACb,MAAO,OAAA,CAAC,WAAW,KAAO,EAAA,YAAA,EAAc,QAAQ,QAAU,EAAA,WAAA,EAAa,eAAe,eAAe,CAAA,CAAA;AAAA,KACvG;AAAA,IACA,IAAM,EAAA,KAAA;AAAA,GACR;AACF;;;;"}
@@ -110,6 +110,7 @@ class dkTable {
110
110
  this.runAfter("getIndex", { res });
111
111
  }).finally(() => {
112
112
  this.table.loading = false;
113
+ }).catch(() => {
113
114
  });
114
115
  };
115
116
  getTable = (cache = false) => {
@@ -117,7 +118,7 @@ class dkTable {
117
118
  return;
118
119
  this.table.columnLoading = true;
119
120
  if (cache) {
120
- const cachedData = storage.get(this.url + "_table");
121
+ const cachedData = storage.get(this.api.actionUrl.get("table") + "_table");
121
122
  if (cachedData) {
122
123
  const cachedTableData = JSON.parse(cachedData);
123
124
  this.table.column = cachedTableData.column;
@@ -131,10 +132,11 @@ class dkTable {
131
132
  if (res.data.pk) {
132
133
  this.table.pk = res.data.pk;
133
134
  }
134
- storage.set(this.url + "_table", JSON.stringify(res.data));
135
+ storage.set(this.api.actionUrl.get("table") + "_table", JSON.stringify(res.data));
135
136
  this.runAfter("getTable", { res });
136
137
  }).finally(() => {
137
138
  this.table.columnLoading = false;
139
+ }).catch(() => {
138
140
  });
139
141
  }
140
142
  };
@@ -1 +1 @@
1
- {"version":3,"file":"dkTable.mjs","sources":["../../../src/table/utils/dkTable.ts"],"sourcesContent":["import { findIndexRow, getArrayKey, storage } from '@vipl520/utils'\nimport { reactive, ref } from 'vue'\nimport Sortable from 'sortablejs'\nimport { ElNotification } from 'element-plus'\nimport type { TableColumnCtx } from 'element-plus'\nimport { dkTableApi } from './dkTableApi'\n// import { DkTable } from '../../../types/table'\nexport default class dkTable {\n public url\n\n public api: dkTableApi\n\n public buttonCallback: (event: string, data: any) => void\n\n public table: DkTable = reactive({\n ref: undefined,\n pk: 'id',\n data: [],\n remark: null,\n loading: true,\n columnLoading: true,\n selection: [],\n column: [],\n total: 0,\n filter: {},\n dragSortLimitField: 'pid',\n acceptQuery: true,\n showComSearch: false,\n dblClickNotEditColumn: [undefined],\n expandAll: false,\n extend: {},\n })\n\n // BaTable前置处理函数列表(前置埋点)\n public before: BaTableBefore\n\n // BaTable后置处理函数列表(后置埋点)\n public after: BaTableAfter\n\n public form: DkForm = reactive({\n ref: undefined,\n operateIds: [], // 被编辑的IDs\n edit_id: 0,\n })\n\n public recycleTable: RecycleTable = reactive({\n ref: undefined,\n pk: 'id',\n data: [],\n loading: true,\n columnLoading: true,\n selection: [],\n column: [],\n total: 0,\n filter: {},\n showDialog: false,\n showDialogLoading: false,\n dragSortLimitField: 'pid',\n acceptQuery: true,\n showComSearch: false,\n dblClickNotEditColumn: [undefined],\n expandAll: false,\n extend: {},\n })\n\n // 通用搜索数据\n public comSearch: ComSearch = reactive({\n form: {},\n fieldData: new Map(),\n })\n\n constructor(url: string, before: BaTableBefore = {}, after: BaTableAfter = {}) {\n this.url = url\n // eslint-disable-next-line new-cap\n this.api = new dkTableApi(url)\n this.before = before\n this.after = after\n this.buttonCallback = (event, data) => {\n console.warn('请调用onClickButton((event,data)=>{})', event, data)\n }\n }\n\n /**\n * 表格内部鉴权方法\n * 此方法在表头或表行组件内部自动调用,传递权限节点名,如:add、edit\n * 若需自定义表格内部鉴权,重写此方法即可\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n auth(node: string) {\n // return auth(node)\n // TODO\n return true\n }\n\n /**\n * 运行前置函数\n * @param funName 函数名\n * @param args 参数\n */\n runBefore(funName: string, args: any = {}) {\n if (this.before && this.before[funName] && typeof this.before[funName] === 'function') {\n return this.before[funName]!({ ...args }) !== false\n }\n return true\n }\n\n /**\n * 运行后置函数\n * @param funName 函数名\n * @param args 参数\n */\n runAfter(funName: string, args: any = {}) {\n if (this.after && this.after[funName] && typeof this.after[funName] === 'function') {\n return this.after[funName]!({ ...args }) !== false\n }\n return true\n }\n\n getIndex = () => {\n if (!this.runBefore('getIndex')) return\n this.table.loading = true\n return this.api\n .index(this.table.filter)\n .then((res) => {\n this.table.data = res.data.list\n this.table.total = res.data.total\n this.runAfter('getIndex', { res })\n })\n .finally(() => {\n this.table.loading = false\n })\n }\n\n getTable = (cache = false) => {\n if (!this.runBefore('getTable')) return\n\n this.table.columnLoading = true\n\n // 如果允许使用缓存\n if (cache) {\n // 尝试从 localStorage 获取缓存数据\n const cachedData = storage.get(this.url + '_table')\n\n // 如果缓存存在且有效,使用缓存数据\n if (cachedData) {\n const cachedTableData = JSON.parse(cachedData)\n this.table.column = cachedTableData.column\n this.table.columnLoading = false // 加载完成\n this.runAfter('getTable', { res: cachedTableData }) // 使用缓存数据作为响应\n return Promise.resolve(cachedTableData) // 返回一个已解决的 Promise\n }\n } else {\n // 缓存不存在或不使用缓存时,调用 API\n return this.api\n .table()\n .then((res) => {\n this.table.column = res.data.column\n if (res.data.pk) {\n this.table.pk = res.data.pk\n }\n // 如果允许缓存,将数据存储到 localStorage\n // if (cache) {\n storage.set(this.url + '_table', JSON.stringify(res.data))\n // }\n this.runAfter('getTable', { res })\n })\n .finally(() => {\n this.table.columnLoading = false\n })\n }\n }\n\n /**\n * 显示回收站\n */\n async showRecycle() {\n if (!this.runBefore('getRecycleTable')) return\n this.recycleTable.showDialogLoading = true\n if (this.recycleTable.column.length <= 0) {\n await this.getRecycleTable()\n }\n await this.getRecycleIndex()\n this.recycleTable.showDialog = true\n this.recycleTable.showDialogLoading = false\n }\n\n /**\n * 获取回收站列表\n */\n getRecycleIndex = () => {\n if (!this.runBefore('getRecycleIndex')) return\n this.recycleTable.loading = true\n return this.api\n .recycle(this.recycleTable.filter)\n .then((res) => {\n this.recycleTable.data = res.data.list\n this.recycleTable.total = res.data.total\n })\n .finally(() => {\n this.recycleTable.loading = false\n })\n }\n\n /**\n * 获取回收站表格\n * @param cache\n */\n getRecycleTable = (cache = false) => {\n if (!this.runBefore('getTable')) return\n\n this.recycleTable.columnLoading = true\n\n // 如果允许使用缓存\n if (cache) {\n // 尝试从 localStorage 获取缓存数据\n const cachedData = storage.get(this.url + '_recycleTable')\n\n // 如果缓存存在且有效,使用缓存数据\n if (cachedData) {\n const cachedTableData = JSON.parse(cachedData)\n this.recycleTable.column = cachedTableData.column\n this.recycleTable.columnLoading = false // 加载完成\n return Promise.resolve(cachedTableData) // 返回一个已解决的 Promise\n }\n } else {\n // 缓存不存在或不使用缓存时,调用 API\n return this.api\n .recycleTable()\n .then((res) => {\n this.recycleTable.column = res.data.column\n // 如果允许缓存,将数据存储到 localStorage\n // if (cache) {\n storage.set(this.url + '_recycleTable', JSON.stringify(res.data))\n // }\n })\n .finally(() => {\n this.recycleTable.columnLoading = false\n })\n }\n }\n\n /**\n * 获取表格选择项的id数组\n */\n getSelectionIds(): number[] {\n const ids: number[] = []\n this.table.selection?.forEach((item) => {\n ids.push(item[this.table.pk!])\n })\n return ids\n }\n\n onClickButton(callback: (event: string, data: any) => void) {\n this.buttonCallback = callback\n }\n\n /**\n * 表格内的事件统一响应\n * @param event 事件:selection-change=选中项改变,page-size-change=每页数量改变,current-page-change=翻页,sort-change=排序,edit=编辑,delete=删除,field-change=单元格值改变,com-search=公共搜索\n * @param data 携带数据\n */\n onTableAction = (event: string, data: anyObj) => {\n if (!this.runBefore('onTableAction', { event, data })) return\n const actionFun = new Map([\n [\n 'selection-change',\n () => {\n this.table.selection = data as TableRow[]\n },\n ],\n [\n 'selection-recycle-change',\n () => {\n this.recycleTable.selection = data as TableRow[]\n },\n ],\n [\n 'page-size-change',\n () => {\n this.table.filter!.limit = data.size\n this.onTableHeaderAction('refresh', {\n event: 'page-size-change',\n ...data,\n })\n },\n ],\n [\n 'current-page-change',\n () => {\n this.table.filter!.page = data.page\n this.onTableHeaderAction('refresh', {\n event: 'current-page-change',\n ...data,\n })\n },\n ],\n [\n 'sort-change',\n () => {\n let newOrder: string | undefined\n if (data.prop && data.order) {\n newOrder = data.prop + ',' + data.order\n }\n if (newOrder != this.table.filter!.order) {\n this.table.filter!.order = newOrder\n this.onTableHeaderAction('refresh', {\n event: 'sort-change',\n ...data,\n })\n }\n },\n ],\n [\n 'edit',\n () => {\n this.toggleForm('Edit', [data.row[this.table.pk!]])\n },\n ],\n [\n 'delete',\n () => {\n this.postDel([data.row[this.table.pk!]])\n },\n ],\n [\n 'field-change',\n () => {\n if (data.field.render == 'switch') {\n if (!data.row || !data.field.prop) return\n if (Object.keys(data.row).length === 0) {\n // return\n }\n data.row.loading = true\n this.api\n .postData('edit', {\n [this.table.pk!]: data.row[this.table.pk!],\n [data.field.prop]: data.value,\n })\n .then(() => {\n data.row.loading = false\n data.row[data.field.prop] = data.value\n })\n .catch(() => {\n data.row.loading = false\n })\n }\n },\n ],\n [\n 'com-search',\n () => {\n this.table.filter!.search = data as comSearchData[]\n this.onTableHeaderAction('refresh', {\n event: 'com-search',\n data,\n })\n },\n ],\n [\n 'default',\n () => {\n this.buttonCallback(event, data)\n },\n ],\n ])\n\n const action = actionFun.get(event) || actionFun.get('default')\n action!.call(this)\n return this.runAfter('onTableAction', { event, data })\n }\n\n // 删除\n postDel = (ids: number[]) => {\n if (!this.runBefore('postDel', { ids })) return\n this.api.del(ids).then((res) => {\n this.onTableHeaderAction('refresh', {})\n this.runAfter('postDel', { res })\n })\n }\n\n /**\n * 双击表格\n * @param row 行数据\n * @param column 列上下文数据\n */\n onTableDblclick = (row: TableRow, column: TableColumnCtx<TableRow>) => {\n if (\n !this.table.dblClickNotEditColumn!.includes('all') &&\n !this.table.dblClickNotEditColumn!.includes(column.property)\n ) {\n if (!this.runBefore('onTableDblclick', { row, column })) return\n this.toggleForm('Edit', [row[this.table.pk!]])\n this.runAfter('onTableDblclick', { row, column })\n }\n }\n\n exportCsv = () => {\n const header = this.table.column\n const headerMap = new Map(\n header\n .filter((item) => item !== undefined && item.label !== undefined && item.export)\n .map((item) => [item.label, item.prop])\n )\n const headerLabels = Array.from(headerMap.keys())\n function jsonToCsv(data: any) {\n let csvContent = headerLabels.join(',') + '\\n'\n data.forEach((row: any) => {\n const line: string[] = []\n headerLabels.forEach((label: string) => {\n const prop: any = headerMap.get(label)\n let value = ''\n if (prop && prop.indexOf('.') > -1) {\n const fieldNameArr = prop.split('.')\n value = row[fieldNameArr[0]] || {}\n for (let index = 1; index < fieldNameArr.length; index++) {\n value = value ? value[fieldNameArr[index]] ?? '' : ''\n }\n } else {\n value = String(row[prop])\n }\n line.push(`\"${value.replace(/\"/g, '\"\"').replace(/[\\n\\r]/g, ' ')}\"`)\n })\n csvContent += line.join(',') + '\\n'\n })\n return csvContent\n }\n\n function downloadCsv(csvContent: string, fileName: string) {\n const link = document.createElement('a')\n link.setAttribute('href', 'data:text/csv;charset=utf-8,' + encodeURIComponent(csvContent))\n link.setAttribute('download', fileName + '.csv')\n document.body.appendChild(link)\n link.click()\n document.body.removeChild(link)\n }\n const csvStr = jsonToCsv(this.table.selection)\n downloadCsv(csvStr, 'export_data')\n }\n\n /**\n * 打开表单\n * @param operate 操作:Add=添加,Edit=编辑\n * @param operateIds 被操作项的数组:Add=[],Edit=[1,2,...]\n */\n toggleForm = (operate = '', operateIds: number[] = []) => {\n if (operate === 'Edit') {\n this.form.edit_id = operateIds[0]\n operateIds.splice(0, 1)\n this.form.operateIds = operateIds\n } else {\n this.form.edit_id = 0\n }\n this.api\n .form(this.form.edit_id)\n .then((res) => {\n this.form.ref.setFormData(res.data)\n this.form.ref.show()\n })\n .catch((res) => {\n console.log('catch', res)\n })\n }\n\n onSubmit = () => {\n if (this.form.operateIds!.length > 0) {\n this.toggleForm('Edit', this.form.operateIds)\n }\n this.getIndex()\n }\n\n /**\n * 排序\n */\n dragSort = () => {\n const buttonsKey = getArrayKey(this.table.column, 'render', 'buttons')\n if (buttonsKey === false) return\n const moveButton = getArrayKey(this.table.column[buttonsKey]?.buttons, 'render', 'moveButton')\n if (moveButton === false) return\n\n if (!this.table.ref) {\n console.warn(\n 'Failed to initialize drag sort because table ref is not defined. Please assign table ref when onMounted'\n )\n return\n }\n const el = this.table.ref.$el.querySelector('.el-table__body-wrapper .el-table__body tbody')\n const disabledTip = this.table.column[buttonsKey].buttons![moveButton].disabledTip\n Sortable.create(el, {\n animation: 200,\n handle: '.table-row-weigh-sort',\n ghostClass: 'ba-table-row',\n onStart: () => {\n this.table.column[buttonsKey].buttons![moveButton].disabledTip = true\n },\n onEnd: (evt: Sortable.SortableEvent) => {\n this.table.column[buttonsKey].buttons![moveButton].disabledTip = disabledTip\n // 找到对应行id\n const moveRow = findIndexRow(this.table.data!, evt.oldIndex!) as TableRow\n const replaceRow = findIndexRow(this.table.data!, evt.newIndex!) as TableRow\n if (\n this.table.dragSortLimitField &&\n moveRow[this.table.dragSortLimitField] != replaceRow[this.table.dragSortLimitField]\n ) {\n this.onTableHeaderAction('refresh', {})\n ElNotification({\n type: 'error',\n message: 'utils.The moving position is beyond the movable range!',\n })\n return\n }\n\n this.api.sortableApi(moveRow[this.table.pk!], replaceRow[this.table.pk!]).finally(() => {\n this.onTableHeaderAction('refresh', {})\n })\n },\n })\n }\n\n /**\n * 表格顶栏按钮事件统一响应\n * @param event 事件:refresh=刷新,edit=编辑,delete=删除,quick-search=快速查询,unfold=折叠/展开,change-show-column=调整列显示状态\n * @param data 携带数据\n */\n onTableHeaderAction = (event: string, data?: anyObj) => {\n if (!this.runBefore('onTableHeaderAction', { event, data })) return\n const actionFun = new Map([\n [\n 'refresh',\n () => {\n // 刷新表格在大多数情况下无需置空 data,但任需防范表格列组件的 :key 不会被更新的问题,比如关联表的数据列\n this.table.data = []\n this.getIndex()\n },\n ],\n [\n 'add',\n () => {\n this.toggleForm('Add')\n },\n ],\n [\n 'export_csv',\n () => {\n this.exportCsv()\n },\n ],\n [\n 'edit',\n () => {\n this.toggleForm('Edit', this.getSelectionIds())\n },\n ],\n [\n 'delete',\n () => {\n this.postDel(this.getSelectionIds())\n },\n ],\n [\n 'unfold',\n () => {\n if (!this.table.ref) {\n console.warn(\n 'Collapse/expand failed because table ref is not defined. Please assign table ref when onMounted'\n )\n return\n }\n this.table.expandAll = data!.unfold\n this.table.ref.unFoldAll(data!.unfold)\n },\n ],\n [\n 'quick-search',\n () => {\n this.onTableHeaderAction('refresh', {\n event: 'quick-search',\n ...data,\n })\n },\n ],\n [\n 'change-show-column',\n () => {\n const columnKey = getArrayKey(this.table.column, 'prop', data!.field)\n this.table.column[columnKey].show = data!.value\n if (this.url) {\n const key = this.url + 'show_column'\n const cachedData = storage.get(key) || '{}'\n const cachedTableData = JSON.parse(cachedData)\n cachedTableData[data!.field] = data!.value\n storage.set(key, JSON.stringify(cachedTableData))\n }\n },\n ],\n [\n 'default',\n () => {\n console.warn('No action defined')\n },\n ],\n [\n 'recycle',\n () => {\n this.showRecycle()\n },\n ],\n [\n 'quick-recycle-search',\n () => {\n this.onTableHeaderAction('refreshRecycle', {\n event: 'refreshRecycle',\n ...data,\n })\n },\n ],\n [\n 'refreshRecycle',\n () => {\n // 刷新表格在大多数情况下无需置空 data,但任需防范表格列组件的 :key 不会被更新的问题,比如关联表的数据列\n this.recycleTable.data = []\n this.getRecycleIndex()\n },\n ],\n ])\n\n const action = actionFun.get(event) || actionFun.get('default')\n action!.call(this)\n return this.runAfter('onTableHeaderAction', { event, data })\n }\n\n /**\n * 通用搜索初始化\n * @param query 要搜索的数据\n */\n initComSearch = (query: anyObj = {}) => {\n const form: anyObj = {}\n const field = this.table.column\n\n if (field.length <= 0) {\n return\n }\n\n for (const key in field) {\n if (field[key].operator === false) {\n continue\n }\n const prop = field[key].prop\n if (typeof field[key].operator === 'undefined') {\n field[key].operator = 'eq'\n }\n if (prop) {\n if (field[key].operator == 'RANGE' || field[key].operator == 'NOT RANGE') {\n form[prop] = ''\n form[prop + '-start'] = ''\n form[prop + '-end'] = ''\n } else if (field[key].operator == 'NULL' || field[key].operator == 'NOT NULL') {\n form[prop] = false\n } else {\n form[prop] = ''\n }\n\n // 初始化来自query中的默认值\n if (this.table.acceptQuery && typeof query[prop] !== 'undefined') {\n const queryProp = (query[prop] as string) ?? ''\n if (field[key].operator == 'RANGE' || field[key].operator == 'NOT RANGE') {\n const range = queryProp.split(',')\n if (field[key].render == 'datetime') {\n if (range && range.length >= 2) {\n form[prop + '-default'] = [new Date(range[0]), new Date(range[1])]\n }\n } else {\n form[prop + '-start'] = range[0] ?? ''\n form[prop + '-end'] = range[1] ?? ''\n }\n } else if (field[key].operator == 'NULL' || field[key].operator == 'NOT NULL') {\n form[prop] = !!queryProp\n } else if (field[key].render == 'datetime') {\n form[prop + '-default'] = new Date(queryProp)\n } else {\n form[prop] = queryProp\n }\n }\n\n this.comSearch.fieldData.set(prop, {\n operator: field[key].operator,\n render: field[key].render,\n comSearchRender: field[key].comSearchRender,\n })\n }\n }\n\n // 接受query再搜索\n if (this.table.acceptQuery) {\n const comSearchData: comSearchData[] = []\n for (const key in query) {\n const fieldDataTemp = this.comSearch.fieldData.get(key)\n if (fieldDataTemp) {\n comSearchData.push({\n field: key,\n val: query[key] as string,\n operator: fieldDataTemp.operator,\n render: fieldDataTemp.render,\n })\n }\n }\n this.table.filter!.search = comSearchData\n }\n\n this.comSearch.form = Object.assign(this.comSearch.form, form)\n }\n}\n"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"dkTable.mjs","sources":["../../../src/table/utils/dkTable.ts"],"sourcesContent":["import { findIndexRow, getArrayKey, storage } from '@vipl520/utils'\nimport { reactive, ref } from 'vue'\nimport Sortable from 'sortablejs'\nimport { ElNotification } from 'element-plus'\nimport type { TableColumnCtx } from 'element-plus'\nimport { dkTableApi } from './dkTableApi'\n// import { DkTable } from '../../../types/table'\nexport default class dkTable {\n public url\n\n public api: dkTableApi\n\n public buttonCallback: (event: string, data: any) => void\n\n public table: DkTable = reactive({\n ref: undefined,\n pk: 'id',\n data: [],\n remark: null,\n loading: true,\n columnLoading: true,\n selection: [],\n column: [],\n total: 0,\n filter: {},\n dragSortLimitField: 'pid',\n acceptQuery: true,\n showComSearch: false,\n dblClickNotEditColumn: [undefined],\n expandAll: false,\n extend: {},\n })\n\n // BaTable前置处理函数列表(前置埋点)\n public before: BaTableBefore\n\n // BaTable后置处理函数列表(后置埋点)\n public after: BaTableAfter\n\n public form: DkForm = reactive({\n ref: undefined,\n operateIds: [], // 被编辑的IDs\n edit_id: 0,\n })\n\n public recycleTable: RecycleTable = reactive({\n ref: undefined,\n pk: 'id',\n data: [],\n loading: true,\n columnLoading: true,\n selection: [],\n column: [],\n total: 0,\n filter: {},\n showDialog: false,\n showDialogLoading: false,\n dragSortLimitField: 'pid',\n acceptQuery: true,\n showComSearch: false,\n dblClickNotEditColumn: [undefined],\n expandAll: false,\n extend: {},\n })\n\n // 通用搜索数据\n public comSearch: ComSearch = reactive({\n form: {},\n fieldData: new Map(),\n })\n\n constructor(url: string, before: BaTableBefore = {}, after: BaTableAfter = {}) {\n this.url = url\n // eslint-disable-next-line new-cap\n this.api = new dkTableApi(url)\n this.before = before\n this.after = after\n this.buttonCallback = (event, data) => {\n console.warn('请调用onClickButton((event,data)=>{})', event, data)\n }\n }\n\n /**\n * 表格内部鉴权方法\n * 此方法在表头或表行组件内部自动调用,传递权限节点名,如:add、edit\n * 若需自定义表格内部鉴权,重写此方法即可\n */\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n auth(node: string) {\n // return auth(node)\n // TODO\n return true\n }\n\n /**\n * 运行前置函数\n * @param funName 函数名\n * @param args 参数\n */\n runBefore(funName: string, args: any = {}) {\n if (this.before && this.before[funName] && typeof this.before[funName] === 'function') {\n return this.before[funName]!({ ...args }) !== false\n }\n return true\n }\n\n /**\n * 运行后置函数\n * @param funName 函数名\n * @param args 参数\n */\n runAfter(funName: string, args: any = {}) {\n if (this.after && this.after[funName] && typeof this.after[funName] === 'function') {\n return this.after[funName]!({ ...args }) !== false\n }\n return true\n }\n\n getIndex = () => {\n if (!this.runBefore('getIndex')) return\n this.table.loading = true\n return this.api\n .index(this.table.filter)\n .then((res) => {\n this.table.data = res.data.list\n this.table.total = res.data.total\n this.runAfter('getIndex', { res })\n })\n .finally(() => {\n this.table.loading = false\n })\n .catch(() => {})\n }\n\n getTable = (cache = false) => {\n if (!this.runBefore('getTable')) return\n\n this.table.columnLoading = true\n // 如果允许使用缓存\n if (cache) {\n // 尝试从 localStorage 获取缓存数据\n const cachedData = storage.get(this.api.actionUrl.get('table') + '_table')\n\n // 如果缓存存在且有效,使用缓存数据\n if (cachedData) {\n const cachedTableData = JSON.parse(cachedData)\n this.table.column = cachedTableData.column\n this.table.columnLoading = false // 加载完成\n this.runAfter('getTable', { res: cachedTableData }) // 使用缓存数据作为响应\n return Promise.resolve(cachedTableData) // 返回一个已解决的 Promise\n }\n } else {\n // 缓存不存在或不使用缓存时,调用 API\n return this.api\n .table()\n .then((res) => {\n this.table.column = res.data.column\n if (res.data.pk) {\n this.table.pk = res.data.pk\n }\n // 如果允许缓存,将数据存储到 localStorage\n storage.set(this.api.actionUrl.get('table') + '_table', JSON.stringify(res.data))\n this.runAfter('getTable', { res })\n })\n .finally(() => {\n this.table.columnLoading = false\n })\n .catch(() => {})\n }\n }\n\n /**\n * 显示回收站\n */\n async showRecycle() {\n if (!this.runBefore('getRecycleTable')) return\n this.recycleTable.showDialogLoading = true\n if (this.recycleTable.column.length <= 0) {\n await this.getRecycleTable()\n }\n await this.getRecycleIndex()\n this.recycleTable.showDialog = true\n this.recycleTable.showDialogLoading = false\n }\n\n /**\n * 获取回收站列表\n */\n getRecycleIndex = () => {\n if (!this.runBefore('getRecycleIndex')) return\n this.recycleTable.loading = true\n return this.api\n .recycle(this.recycleTable.filter)\n .then((res) => {\n this.recycleTable.data = res.data.list\n this.recycleTable.total = res.data.total\n })\n .finally(() => {\n this.recycleTable.loading = false\n })\n }\n\n /**\n * 获取回收站表格\n * @param cache\n */\n getRecycleTable = (cache = false) => {\n if (!this.runBefore('getTable')) return\n\n this.recycleTable.columnLoading = true\n\n // 如果允许使用缓存\n if (cache) {\n // 尝试从 localStorage 获取缓存数据\n const cachedData = storage.get(this.url + '_recycleTable')\n\n // 如果缓存存在且有效,使用缓存数据\n if (cachedData) {\n const cachedTableData = JSON.parse(cachedData)\n this.recycleTable.column = cachedTableData.column\n this.recycleTable.columnLoading = false // 加载完成\n return Promise.resolve(cachedTableData) // 返回一个已解决的 Promise\n }\n } else {\n // 缓存不存在或不使用缓存时,调用 API\n return this.api\n .recycleTable()\n .then((res) => {\n this.recycleTable.column = res.data.column\n // 如果允许缓存,将数据存储到 localStorage\n // if (cache) {\n storage.set(this.url + '_recycleTable', JSON.stringify(res.data))\n // }\n })\n .finally(() => {\n this.recycleTable.columnLoading = false\n })\n }\n }\n\n /**\n * 获取表格选择项的id数组\n */\n getSelectionIds(): number[] {\n const ids: number[] = []\n this.table.selection?.forEach((item) => {\n ids.push(item[this.table.pk!])\n })\n return ids\n }\n\n onClickButton(callback: (event: string, data: any) => void) {\n this.buttonCallback = callback\n }\n\n /**\n * 表格内的事件统一响应\n * @param event 事件:selection-change=选中项改变,page-size-change=每页数量改变,current-page-change=翻页,sort-change=排序,edit=编辑,delete=删除,field-change=单元格值改变,com-search=公共搜索\n * @param data 携带数据\n */\n onTableAction = (event: string, data: anyObj) => {\n if (!this.runBefore('onTableAction', { event, data })) return\n const actionFun = new Map([\n [\n 'selection-change',\n () => {\n this.table.selection = data as TableRow[]\n },\n ],\n [\n 'selection-recycle-change',\n () => {\n this.recycleTable.selection = data as TableRow[]\n },\n ],\n [\n 'page-size-change',\n () => {\n this.table.filter!.limit = data.size\n this.onTableHeaderAction('refresh', {\n event: 'page-size-change',\n ...data,\n })\n },\n ],\n [\n 'current-page-change',\n () => {\n this.table.filter!.page = data.page\n this.onTableHeaderAction('refresh', {\n event: 'current-page-change',\n ...data,\n })\n },\n ],\n [\n 'sort-change',\n () => {\n let newOrder: string | undefined\n if (data.prop && data.order) {\n newOrder = data.prop + ',' + data.order\n }\n if (newOrder != this.table.filter!.order) {\n this.table.filter!.order = newOrder\n this.onTableHeaderAction('refresh', {\n event: 'sort-change',\n ...data,\n })\n }\n },\n ],\n [\n 'edit',\n () => {\n this.toggleForm('Edit', [data.row[this.table.pk!]])\n },\n ],\n [\n 'delete',\n () => {\n this.postDel([data.row[this.table.pk!]])\n },\n ],\n [\n 'field-change',\n () => {\n if (data.field.render == 'switch') {\n if (!data.row || !data.field.prop) return\n if (Object.keys(data.row).length === 0) {\n // return\n }\n data.row.loading = true\n this.api\n .postData('edit', {\n [this.table.pk!]: data.row[this.table.pk!],\n [data.field.prop]: data.value,\n })\n .then(() => {\n data.row.loading = false\n data.row[data.field.prop] = data.value\n })\n .catch(() => {\n data.row.loading = false\n })\n }\n },\n ],\n [\n 'com-search',\n () => {\n this.table.filter!.search = data as comSearchData[]\n this.onTableHeaderAction('refresh', {\n event: 'com-search',\n data,\n })\n },\n ],\n [\n 'default',\n () => {\n this.buttonCallback(event, data)\n },\n ],\n ])\n\n const action = actionFun.get(event) || actionFun.get('default')\n action!.call(this)\n return this.runAfter('onTableAction', { event, data })\n }\n\n // 删除\n postDel = (ids: number[]) => {\n if (!this.runBefore('postDel', { ids })) return\n this.api.del(ids).then((res) => {\n this.onTableHeaderAction('refresh', {})\n this.runAfter('postDel', { res })\n })\n }\n\n /**\n * 双击表格\n * @param row 行数据\n * @param column 列上下文数据\n */\n onTableDblclick = (row: TableRow, column: TableColumnCtx<TableRow>) => {\n if (\n !this.table.dblClickNotEditColumn!.includes('all') &&\n !this.table.dblClickNotEditColumn!.includes(column.property)\n ) {\n if (!this.runBefore('onTableDblclick', { row, column })) return\n this.toggleForm('Edit', [row[this.table.pk!]])\n this.runAfter('onTableDblclick', { row, column })\n }\n }\n\n exportCsv = () => {\n const header = this.table.column\n const headerMap = new Map(\n header\n .filter((item) => item !== undefined && item.label !== undefined && item.export)\n .map((item) => [item.label, item.prop])\n )\n const headerLabels = Array.from(headerMap.keys())\n function jsonToCsv(data: any) {\n let csvContent = headerLabels.join(',') + '\\n'\n data.forEach((row: any) => {\n const line: string[] = []\n headerLabels.forEach((label: string) => {\n const prop: any = headerMap.get(label)\n let value = ''\n if (prop && prop.indexOf('.') > -1) {\n const fieldNameArr = prop.split('.')\n value = row[fieldNameArr[0]] || {}\n for (let index = 1; index < fieldNameArr.length; index++) {\n value = value ? value[fieldNameArr[index]] ?? '' : ''\n }\n } else {\n value = String(row[prop])\n }\n line.push(`\"${value.replace(/\"/g, '\"\"').replace(/[\\n\\r]/g, ' ')}\"`)\n })\n csvContent += line.join(',') + '\\n'\n })\n return csvContent\n }\n\n function downloadCsv(csvContent: string, fileName: string) {\n const link = document.createElement('a')\n link.setAttribute('href', 'data:text/csv;charset=utf-8,' + encodeURIComponent(csvContent))\n link.setAttribute('download', fileName + '.csv')\n document.body.appendChild(link)\n link.click()\n document.body.removeChild(link)\n }\n const csvStr = jsonToCsv(this.table.selection)\n downloadCsv(csvStr, 'export_data')\n }\n\n /**\n * 打开表单\n * @param operate 操作:Add=添加,Edit=编辑\n * @param operateIds 被操作项的数组:Add=[],Edit=[1,2,...]\n */\n toggleForm = (operate = '', operateIds: number[] = []) => {\n if (operate === 'Edit') {\n this.form.edit_id = operateIds[0]\n operateIds.splice(0, 1)\n this.form.operateIds = operateIds\n } else {\n this.form.edit_id = 0\n }\n this.api\n .form(this.form.edit_id)\n .then((res) => {\n this.form.ref.setFormData(res.data)\n this.form.ref.show()\n })\n .catch((res) => {\n console.log('catch', res)\n })\n }\n\n onSubmit = () => {\n if (this.form.operateIds!.length > 0) {\n this.toggleForm('Edit', this.form.operateIds)\n }\n this.getIndex()\n }\n\n /**\n * 排序\n */\n dragSort = () => {\n const buttonsKey = getArrayKey(this.table.column, 'render', 'buttons')\n if (buttonsKey === false) return\n const moveButton = getArrayKey(this.table.column[buttonsKey]?.buttons, 'render', 'moveButton')\n if (moveButton === false) return\n\n if (!this.table.ref) {\n console.warn(\n 'Failed to initialize drag sort because table ref is not defined. Please assign table ref when onMounted'\n )\n return\n }\n const el = this.table.ref.$el.querySelector('.el-table__body-wrapper .el-table__body tbody')\n const disabledTip = this.table.column[buttonsKey].buttons![moveButton].disabledTip\n Sortable.create(el, {\n animation: 200,\n handle: '.table-row-weigh-sort',\n ghostClass: 'ba-table-row',\n onStart: () => {\n this.table.column[buttonsKey].buttons![moveButton].disabledTip = true\n },\n onEnd: (evt: Sortable.SortableEvent) => {\n this.table.column[buttonsKey].buttons![moveButton].disabledTip = disabledTip\n // 找到对应行id\n const moveRow = findIndexRow(this.table.data!, evt.oldIndex!) as TableRow\n const replaceRow = findIndexRow(this.table.data!, evt.newIndex!) as TableRow\n if (\n this.table.dragSortLimitField &&\n moveRow[this.table.dragSortLimitField] != replaceRow[this.table.dragSortLimitField]\n ) {\n this.onTableHeaderAction('refresh', {})\n ElNotification({\n type: 'error',\n message: 'utils.The moving position is beyond the movable range!',\n })\n return\n }\n\n this.api.sortableApi(moveRow[this.table.pk!], replaceRow[this.table.pk!]).finally(() => {\n this.onTableHeaderAction('refresh', {})\n })\n },\n })\n }\n\n /**\n * 表格顶栏按钮事件统一响应\n * @param event 事件:refresh=刷新,edit=编辑,delete=删除,quick-search=快速查询,unfold=折叠/展开,change-show-column=调整列显示状态\n * @param data 携带数据\n */\n onTableHeaderAction = (event: string, data?: anyObj) => {\n if (!this.runBefore('onTableHeaderAction', { event, data })) return\n const actionFun = new Map([\n [\n 'refresh',\n () => {\n // 刷新表格在大多数情况下无需置空 data,但任需防范表格列组件的 :key 不会被更新的问题,比如关联表的数据列\n this.table.data = []\n this.getIndex()\n },\n ],\n [\n 'add',\n () => {\n this.toggleForm('Add')\n },\n ],\n [\n 'export_csv',\n () => {\n this.exportCsv()\n },\n ],\n [\n 'edit',\n () => {\n this.toggleForm('Edit', this.getSelectionIds())\n },\n ],\n [\n 'delete',\n () => {\n this.postDel(this.getSelectionIds())\n },\n ],\n [\n 'unfold',\n () => {\n if (!this.table.ref) {\n console.warn(\n 'Collapse/expand failed because table ref is not defined. Please assign table ref when onMounted'\n )\n return\n }\n this.table.expandAll = data!.unfold\n this.table.ref.unFoldAll(data!.unfold)\n },\n ],\n [\n 'quick-search',\n () => {\n this.onTableHeaderAction('refresh', {\n event: 'quick-search',\n ...data,\n })\n },\n ],\n [\n 'change-show-column',\n () => {\n const columnKey = getArrayKey(this.table.column, 'prop', data!.field)\n this.table.column[columnKey].show = data!.value\n if (this.url) {\n const key = this.url + 'show_column'\n const cachedData = storage.get(key) || '{}'\n const cachedTableData = JSON.parse(cachedData)\n cachedTableData[data!.field] = data!.value\n storage.set(key, JSON.stringify(cachedTableData))\n }\n },\n ],\n [\n 'default',\n () => {\n console.warn('No action defined')\n },\n ],\n [\n 'recycle',\n () => {\n this.showRecycle()\n },\n ],\n [\n 'quick-recycle-search',\n () => {\n this.onTableHeaderAction('refreshRecycle', {\n event: 'refreshRecycle',\n ...data,\n })\n },\n ],\n [\n 'refreshRecycle',\n () => {\n // 刷新表格在大多数情况下无需置空 data,但任需防范表格列组件的 :key 不会被更新的问题,比如关联表的数据列\n this.recycleTable.data = []\n this.getRecycleIndex()\n },\n ],\n ])\n\n const action = actionFun.get(event) || actionFun.get('default')\n action!.call(this)\n return this.runAfter('onTableHeaderAction', { event, data })\n }\n\n /**\n * 通用搜索初始化\n * @param query 要搜索的数据\n */\n initComSearch = (query: anyObj = {}) => {\n const form: anyObj = {}\n const field = this.table.column\n\n if (field.length <= 0) {\n return\n }\n\n for (const key in field) {\n if (field[key].operator === false) {\n continue\n }\n const prop = field[key].prop\n if (typeof field[key].operator === 'undefined') {\n field[key].operator = 'eq'\n }\n if (prop) {\n if (field[key].operator == 'RANGE' || field[key].operator == 'NOT RANGE') {\n form[prop] = ''\n form[prop + '-start'] = ''\n form[prop + '-end'] = ''\n } else if (field[key].operator == 'NULL' || field[key].operator == 'NOT NULL') {\n form[prop] = false\n } else {\n form[prop] = ''\n }\n\n // 初始化来自query中的默认值\n if (this.table.acceptQuery && typeof query[prop] !== 'undefined') {\n const queryProp = (query[prop] as string) ?? ''\n if (field[key].operator == 'RANGE' || field[key].operator == 'NOT RANGE') {\n const range = queryProp.split(',')\n if (field[key].render == 'datetime') {\n if (range && range.length >= 2) {\n form[prop + '-default'] = [new Date(range[0]), new Date(range[1])]\n }\n } else {\n form[prop + '-start'] = range[0] ?? ''\n form[prop + '-end'] = range[1] ?? ''\n }\n } else if (field[key].operator == 'NULL' || field[key].operator == 'NOT NULL') {\n form[prop] = !!queryProp\n } else if (field[key].render == 'datetime') {\n form[prop + '-default'] = new Date(queryProp)\n } else {\n form[prop] = queryProp\n }\n }\n\n this.comSearch.fieldData.set(prop, {\n operator: field[key].operator,\n render: field[key].render,\n comSearchRender: field[key].comSearchRender,\n })\n }\n }\n\n // 接受query再搜索\n if (this.table.acceptQuery) {\n const comSearchData: comSearchData[] = []\n for (const key in query) {\n const fieldDataTemp = this.comSearch.fieldData.get(key)\n if (fieldDataTemp) {\n comSearchData.push({\n field: key,\n val: query[key] as string,\n operator: fieldDataTemp.operator,\n render: fieldDataTemp.render,\n })\n }\n }\n this.table.filter!.search = comSearchData\n }\n\n this.comSearch.form = Object.assign(this.comSearch.form, form)\n }\n}\n"],"names":[],"mappings":"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"}
@@ -108,6 +108,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent({
108
108
  loading: _ctx.row.loading,
109
109
  "inactive-value": "0",
110
110
  "active-value": "1",
111
+ size: "small",
111
112
  onChange: onChangeField
112
113
  }, null, 8, ["model-value", "loading"])) : vue.createCommentVNode("v-if", true),
113
114
  vue.createCommentVNode(" \u5355\u56FE "),
@@ -1 +1 @@
1
- {"version":3,"file":"FieldRender.vue2.js","sources":["../../../../src/table/src/components/FieldRender.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as __MACROS_defineComponent } from \"vue\";\nexport default /*#__PURE__*/ __MACROS_defineComponent({\n name: 'DkFieldRender',\n});\n</script>\n<template>\n <!--图标-->\n <div v-if=\"field.render == 'icon'\">\n <dk-icon v-if=\"fieldValue || field.default\" :icon=\"fieldValue ? fieldValue : field.default\" />\n <span v-else>-</span>\n </div>\n\n <!--开关-->\n <el-switch\n v-if=\"field.render == 'switch' && fieldValue !== ''\"\n :model-value=\"fieldValue.toString()\"\n :loading=\"row.loading\"\n inactive-value=\"0\"\n active-value=\"1\"\n @change=\"onChangeField\"\n ></el-switch>\n\n <!-- 单图 -->\n <div v-if=\"field.render == 'image' && fieldValue\" class=\"ba-render-image\">\n <el-image\n :hide-on-click-modal=\"true\"\n :preview-teleported=\"true\"\n :preview-src-list=\"[fieldValue]\"\n :src=\"fieldValue\"\n fit=\"cover\"\n style=\"width: 50px; height: 50px\"\n ></el-image>\n </div>\n\n <!--多图片-->\n <div v-if=\"field.render == 'images'\" class=\"ba-render-image\">\n <template v-if=\"Array.isArray(fieldValue) && fieldValue.length\">\n <el-image\n v-for=\"(item, idx) in fieldValue\"\n :key=\"idx\"\n :initial-index=\"idx\"\n :preview-teleported=\"true\"\n :preview-src-list=\"fieldValue\"\n class=\"images-item\"\n :src=\"item\"\n style=\"width: 50px; height: 50px\"\n :hide-on-click-modal=\"true\"\n ></el-image>\n </template>\n </div>\n\n <div v-if=\"field.render == 'tag' && fieldValue !== ''\">\n <el-tag\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] : fieldValue }}\n </el-tag>\n </div>\n\n <!-- tags -->\n <div v-if=\"field.render == 'tags'\">\n <template v-if=\"Array.isArray(fieldValue)\">\n <template v-for=\"(tag, idx) in fieldValue\" :key=\"idx\">\n <el-tag\n v-if=\"tag !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(tag, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[tag] ?? tag : tag }}</el-tag\n >\n </template>\n </template>\n <template v-else>\n <el-tag\n v-if=\"fieldValue !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] ?? fieldValue : fieldValue }}\n </el-tag>\n </template>\n </div>\n\n <!-- url -->\n <div v-if=\"field.render == 'url' && fieldValue\">\n <el-input :model-value=\"fieldValue\" placeholder=\"链接地址\">\n <template #append>\n <el-button\n @click=\"\n typeof field.click == 'function'\n ? field.click(row, field, fieldValue, column, index)\n : openUrl(fieldValue, field.target)\n \"\n >\n <dk-icon :color=\"'#606266'\" icon=\"Position\" />\n </el-button>\n </template>\n </el-input>\n </div>\n\n <!-- datetime -->\n <div v-if=\"field.render == 'datetime'\">\n {{ !fieldValue ? '-' : timeFormat(fieldValue, field.timeFormat ?? undefined) }}\n </div>\n\n <div v-if=\"field.render == 'time'\">\n {{ fieldValue }}\n </div>\n <div v-if=\"field.render == 'year'\">\n {{ fieldValue }}\n </div>\n <!-- color -->\n <div v-if=\"field.render == 'color'\">\n <div :style=\"{ background: fieldValue }\" class=\"dk-render-color\"></div>\n </div>\n\n <!-- 自定义组件/函数渲染 -->\n <component\n :is=\"field.customRender\"\n v-if=\"field.render == 'customRender'\"\n :render-row=\"row\"\n :render-field=\"field\"\n :render-value=\"fieldValue\"\n :render-column=\"column\"\n :render-index=\"index\"\n />\n\n <!-- 按钮组 -->\n <!-- 只对默认的编辑、删除、排序按钮进行鉴权,其他按钮请通过 display 属性控制按钮是否显示 -->\n <div v-if=\"field.render == 'buttons' && field.buttons\">\n <template v-for=\"(btn, idx) in field.buttons\" :key=\"idx\">\n <template v-if=\"btn.display ? btn.display(row, field) : true\">\n <!-- 常规按钮 未使用-->\n <el-button\n v-if=\"btn.render == 'basicButton'\"\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n\n <!-- 带提示信息的按钮 -->\n <el-tooltip\n v-if=\"btn.render == 'tipButton' && ((btn.name == 'edit' && DkTable.auth('edit')) || btn.name != 'edit')\"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n placement=\"top\"\n :hide-after=\"0\"\n :show-after=\"100\"\n >\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n\n <!-- 带确认框的按钮 -->\n <el-popconfirm\n v-if=\"\n btn.render == 'confirmButton' && ((btn.name == 'delete' && DkTable.auth('del')) || btn.name != 'delete')\n \"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.popconfirm\"\n :hide-after=\"0\"\n :show-after=\"100\"\n @confirm=\"onButtonClick(btn)\"\n >\n <template #reference>\n <div class=\"dk-tooltip-button\">\n <el-tooltip :disabled=\"!btn.title\" :content=\"btn.title ?? ''\" placement=\"top\">\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">\n {{ btn.text }}\n </div>\n </el-button>\n </el-tooltip>\n </div>\n </template>\n </el-popconfirm>\n\n <!-- 带提示的可拖拽按钮 -->\n <el-tooltip\n v-if=\"\n btn.render == 'moveButton' &&\n ((btn.name == 'weigh-sort' && DkTable.auth('sortable')) || btn.name != 'weigh-sort')\n \"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n :hide-after=\"0\"\n :show-after=\"100\"\n placement=\"top\"\n >\n <el-button\n :class=\"btn.class\"\n class=\"table-operate move-button\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n size=\"small\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n </template>\n </template>\n </div>\n</template>\n<script setup lang=\"ts\">\nimport { inject, ref } from 'vue'\nimport type { TableColumnCtx, TagProps } from 'element-plus'\nimport { openUrl, timeFormat } from '@vipl520/utils'\nimport type dkTable from '../../utils/dkTable'\n\nconst DkTable = inject('DkTable') as dkTable\n\ninterface Props {\n row: TableRow\n field: TableColumn\n column: TableColumnCtx<TableRow>\n index: number\n}\nconst props = defineProps<Props>()\n\nconst fieldName: any = ref(props.field.prop)\nconst fieldValue = ref(props.row[fieldName.value] ?? '')\n\nif (fieldName.value && fieldName.value.indexOf('.') > -1) {\n const fieldNameArr = fieldName.value.split('.')\n const val: any = ref(props.row[fieldNameArr[0]])\n for (let index = 1; index < fieldNameArr.length; index++) {\n val.value = val.value ? val.value[fieldNameArr[index]] ?? '' : ''\n }\n fieldValue.value = val.value\n}\n\nconst getTagType = (value: string, custom: any): TagProps['type'] => {\n return custom && custom[value] ? custom[value] : ''\n}\n\nconst onChangeField = (value: any) => {\n DkTable.onTableAction('field-change', {\n ...props,\n value,\n })\n}\n\nconst onButtonClick = (btn: OptButton) => {\n if (typeof btn.click === 'function') {\n btn.click(props.row, props.field)\n return\n }\n DkTable.onTableAction(btn.name, props)\n}\n</script>\n<style scoped></style>\n"],"names":["__MACROS_defineComponent","inject","ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAA6B,cAAAA,mBAAyB,CAAA;AAAA,EACpD,IAAM,EAAA,eAAA;AACR,CAAC,CAAA,CAAA;;;;;;;;;;;AA+OD,IAAM,MAAA,OAAA,GAAUC,WAAO,SAAS,CAAA,CAAA;AAUhC,IAAA,MAAM,SAAiB,GAAAC,OAAA,CAAI,KAAM,CAAA,KAAA,CAAM,IAAI,CAAA,CAAA;AAC3C,IAAA,MAAM,aAAaA,OAAI,CAAA,KAAA,CAAM,IAAI,SAAU,CAAA,KAAK,KAAK,EAAE,CAAA,CAAA;AAEvD,IAAA,IAAI,UAAU,KAAS,IAAA,SAAA,CAAU,MAAM,OAAQ,CAAA,GAAG,IAAI,CAAI,CAAA,EAAA;AACxD,MAAA,MAAM,YAAe,GAAA,SAAA,CAAU,KAAM,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC9C,MAAA,MAAM,MAAWA,OAAI,CAAA,KAAA,CAAM,IAAI,YAAa,CAAA,CAAC,CAAC,CAAC,CAAA,CAAA;AAC/C,MAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,YAAA,CAAa,QAAQ,KAAS,EAAA,EAAA;AACxD,QAAI,GAAA,CAAA,KAAA,GAAQ,IAAI,KAAQ,GAAA,GAAA,CAAI,MAAM,YAAa,CAAA,KAAK,CAAC,CAAA,IAAK,EAAK,GAAA,EAAA,CAAA;AAAA,OACjE;AACA,MAAA,UAAA,CAAW,QAAQ,GAAI,CAAA,KAAA,CAAA;AAAA,KACzB;AAEA,IAAM,MAAA,UAAA,GAAa,CAAC,KAAA,EAAe,MAAkC,KAAA;AACnE,MAAA,OAAO,UAAU,MAAO,CAAA,KAAK,CAAI,GAAA,MAAA,CAAO,KAAK,CAAI,GAAA,EAAA,CAAA;AAAA,KACnD,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,KAAe,KAAA;AACpC,MAAA,OAAA,CAAQ,cAAc,cAAgB,EAAA;AAAA,QACpC,GAAG,KAAA;AAAA,QACH,KAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACH,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,GAAmB,KAAA;AACxC,MAAI,IAAA,OAAO,GAAI,CAAA,KAAA,KAAU,UAAY,EAAA;AACnC,QAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,GAAK,EAAA,KAAA,CAAM,KAAK,CAAA,CAAA;AAChC,QAAA,OAAA;AAAA,OACF;AACA,MAAQ,OAAA,CAAA,aAAA,CAAc,GAAI,CAAA,IAAA,EAAM,KAAK,CAAA,CAAA;AAAA,KACvC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"FieldRender.vue2.js","sources":["../../../../src/table/src/components/FieldRender.vue"],"sourcesContent":["<script lang=\"ts\">\nimport { defineComponent as __MACROS_defineComponent } from \"vue\";\nexport default /*#__PURE__*/ __MACROS_defineComponent({\n name: 'DkFieldRender',\n});\n</script>\n<template>\n <!--图标-->\n <div v-if=\"field.render == 'icon'\">\n <dk-icon v-if=\"fieldValue || field.default\" :icon=\"fieldValue ? fieldValue : field.default\" />\n <span v-else>-</span>\n </div>\n\n <!--开关-->\n <el-switch\n v-if=\"field.render == 'switch' && fieldValue !== ''\"\n :model-value=\"fieldValue.toString()\"\n :loading=\"row.loading\"\n inactive-value=\"0\"\n active-value=\"1\"\n size=\"small\"\n @change=\"onChangeField\"\n ></el-switch>\n\n <!-- 单图 -->\n <div v-if=\"field.render == 'image' && fieldValue\" class=\"ba-render-image\">\n <el-image\n :hide-on-click-modal=\"true\"\n :preview-teleported=\"true\"\n :preview-src-list=\"[fieldValue]\"\n :src=\"fieldValue\"\n fit=\"cover\"\n style=\"width: 50px; height: 50px\"\n ></el-image>\n </div>\n\n <!--多图片-->\n <div v-if=\"field.render == 'images'\" class=\"ba-render-image\">\n <template v-if=\"Array.isArray(fieldValue) && fieldValue.length\">\n <el-image\n v-for=\"(item, idx) in fieldValue\"\n :key=\"idx\"\n :initial-index=\"idx\"\n :preview-teleported=\"true\"\n :preview-src-list=\"fieldValue\"\n class=\"images-item\"\n :src=\"item\"\n style=\"width: 50px; height: 50px\"\n :hide-on-click-modal=\"true\"\n ></el-image>\n </template>\n </div>\n\n <div v-if=\"field.render == 'tag' && fieldValue !== ''\">\n <el-tag\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] : fieldValue }}\n </el-tag>\n </div>\n\n <!-- tags -->\n <div v-if=\"field.render == 'tags'\">\n <template v-if=\"Array.isArray(fieldValue)\">\n <template v-for=\"(tag, idx) in fieldValue\" :key=\"idx\">\n <el-tag\n v-if=\"tag !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(tag, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[tag] ?? tag : tag }}</el-tag\n >\n </template>\n </template>\n <template v-else>\n <el-tag\n v-if=\"fieldValue !== ''\"\n class=\"m-1px\"\n :type=\"getTagType(fieldValue, field.custom)\"\n :effect=\"field.effect ?? 'light'\"\n :size=\"field.size ?? 'default'\"\n >\n {{ field.replaceValue ? field.replaceValue[fieldValue] ?? fieldValue : fieldValue }}\n </el-tag>\n </template>\n </div>\n\n <!-- url -->\n <div v-if=\"field.render == 'url' && fieldValue\">\n <el-input :model-value=\"fieldValue\" placeholder=\"链接地址\">\n <template #append>\n <el-button\n @click=\"\n typeof field.click == 'function'\n ? field.click(row, field, fieldValue, column, index)\n : openUrl(fieldValue, field.target)\n \"\n >\n <dk-icon :color=\"'#606266'\" icon=\"Position\" />\n </el-button>\n </template>\n </el-input>\n </div>\n\n <!-- datetime -->\n <div v-if=\"field.render == 'datetime'\">\n {{ !fieldValue ? '-' : timeFormat(fieldValue, field.timeFormat ?? undefined) }}\n </div>\n\n <div v-if=\"field.render == 'time'\">\n {{ fieldValue }}\n </div>\n <div v-if=\"field.render == 'year'\">\n {{ fieldValue }}\n </div>\n <!-- color -->\n <div v-if=\"field.render == 'color'\">\n <div :style=\"{ background: fieldValue }\" class=\"dk-render-color\"></div>\n </div>\n\n <!-- 自定义组件/函数渲染 -->\n <component\n :is=\"field.customRender\"\n v-if=\"field.render == 'customRender'\"\n :render-row=\"row\"\n :render-field=\"field\"\n :render-value=\"fieldValue\"\n :render-column=\"column\"\n :render-index=\"index\"\n />\n\n <!-- 按钮组 -->\n <!-- 只对默认的编辑、删除、排序按钮进行鉴权,其他按钮请通过 display 属性控制按钮是否显示 -->\n <div v-if=\"field.render == 'buttons' && field.buttons\">\n <template v-for=\"(btn, idx) in field.buttons\" :key=\"idx\">\n <template v-if=\"btn.display ? btn.display(row, field) : true\">\n <!-- 常规按钮 未使用-->\n <el-button\n v-if=\"btn.render == 'basicButton'\"\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n\n <!-- 带提示信息的按钮 -->\n <el-tooltip\n v-if=\"btn.render == 'tipButton' && ((btn.name == 'edit' && DkTable.auth('edit')) || btn.name != 'edit')\"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n placement=\"top\"\n :hide-after=\"0\"\n :show-after=\"100\"\n >\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n @click=\"onButtonClick(btn)\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n\n <!-- 带确认框的按钮 -->\n <el-popconfirm\n v-if=\"\n btn.render == 'confirmButton' && ((btn.name == 'delete' && DkTable.auth('del')) || btn.name != 'delete')\n \"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.popconfirm\"\n :hide-after=\"0\"\n :show-after=\"100\"\n @confirm=\"onButtonClick(btn)\"\n >\n <template #reference>\n <div class=\"dk-tooltip-button\">\n <el-tooltip :disabled=\"!btn.title\" :content=\"btn.title ?? ''\" placement=\"top\">\n <el-button\n v-blur\n :class=\"btn.class\"\n class=\"table-operate\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">\n {{ btn.text }}\n </div>\n </el-button>\n </el-tooltip>\n </div>\n </template>\n </el-popconfirm>\n\n <!-- 带提示的可拖拽按钮 -->\n <el-tooltip\n v-if=\"\n btn.render == 'moveButton' &&\n ((btn.name == 'weigh-sort' && DkTable.auth('sortable')) || btn.name != 'weigh-sort')\n \"\n :disabled=\"!(btn.title && !btn.disabledTip)\"\n :content=\"btn.title ?? ''\"\n :hide-after=\"0\"\n :show-after=\"100\"\n placement=\"top\"\n >\n <el-button\n :class=\"btn.class\"\n class=\"table-operate move-button\"\n :type=\"btn.type\"\n :disabled=\"btn.disabled && btn.disabled(row, field)\"\n v-bind=\"btn.attr\"\n size=\"small\"\n >\n <dk-icon :icon=\"btn.icon\" />\n <div v-if=\"btn.text\" class=\"table-operate-text\">{{ btn.text }}</div>\n </el-button>\n </el-tooltip>\n </template>\n </template>\n </div>\n</template>\n<script setup lang=\"ts\">\nimport { inject, ref } from 'vue'\nimport type { TableColumnCtx, TagProps } from 'element-plus'\nimport { openUrl, timeFormat } from '@vipl520/utils'\nimport type dkTable from '../../utils/dkTable'\n\nconst DkTable = inject('DkTable') as dkTable\n\ninterface Props {\n row: TableRow\n field: TableColumn\n column: TableColumnCtx<TableRow>\n index: number\n}\nconst props = defineProps<Props>()\n\nconst fieldName: any = ref(props.field.prop)\nconst fieldValue = ref(props.row[fieldName.value] ?? '')\n\nif (fieldName.value && fieldName.value.indexOf('.') > -1) {\n const fieldNameArr = fieldName.value.split('.')\n const val: any = ref(props.row[fieldNameArr[0]])\n for (let index = 1; index < fieldNameArr.length; index++) {\n val.value = val.value ? val.value[fieldNameArr[index]] ?? '' : ''\n }\n fieldValue.value = val.value\n}\n\nconst getTagType = (value: string, custom: any): TagProps['type'] => {\n return custom && custom[value] ? custom[value] : ''\n}\n\nconst onChangeField = (value: any) => {\n DkTable.onTableAction('field-change', {\n ...props,\n value,\n })\n}\n\nconst onButtonClick = (btn: OptButton) => {\n if (typeof btn.click === 'function') {\n btn.click(props.row, props.field)\n return\n }\n DkTable.onTableAction(btn.name, props)\n}\n</script>\n<style scoped></style>\n"],"names":["__MACROS_defineComponent","inject","ref"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAEA,MAA6B,cAAAA,mBAAyB,CAAA;AAAA,EACpD,IAAM,EAAA,eAAA;AACR,CAAC,CAAA,CAAA;;;;;;;;;;;AAgPD,IAAM,MAAA,OAAA,GAAUC,WAAO,SAAS,CAAA,CAAA;AAUhC,IAAA,MAAM,SAAiB,GAAAC,OAAA,CAAI,KAAM,CAAA,KAAA,CAAM,IAAI,CAAA,CAAA;AAC3C,IAAA,MAAM,aAAaA,OAAI,CAAA,KAAA,CAAM,IAAI,SAAU,CAAA,KAAK,KAAK,EAAE,CAAA,CAAA;AAEvD,IAAA,IAAI,UAAU,KAAS,IAAA,SAAA,CAAU,MAAM,OAAQ,CAAA,GAAG,IAAI,CAAI,CAAA,EAAA;AACxD,MAAA,MAAM,YAAe,GAAA,SAAA,CAAU,KAAM,CAAA,KAAA,CAAM,GAAG,CAAA,CAAA;AAC9C,MAAA,MAAM,MAAWA,OAAI,CAAA,KAAA,CAAM,IAAI,YAAa,CAAA,CAAC,CAAC,CAAC,CAAA,CAAA;AAC/C,MAAA,KAAA,IAAS,KAAQ,GAAA,CAAA,EAAG,KAAQ,GAAA,YAAA,CAAa,QAAQ,KAAS,EAAA,EAAA;AACxD,QAAI,GAAA,CAAA,KAAA,GAAQ,IAAI,KAAQ,GAAA,GAAA,CAAI,MAAM,YAAa,CAAA,KAAK,CAAC,CAAA,IAAK,EAAK,GAAA,EAAA,CAAA;AAAA,OACjE;AACA,MAAA,UAAA,CAAW,QAAQ,GAAI,CAAA,KAAA,CAAA;AAAA,KACzB;AAEA,IAAM,MAAA,UAAA,GAAa,CAAC,KAAA,EAAe,MAAkC,KAAA;AACnE,MAAA,OAAO,UAAU,MAAO,CAAA,KAAK,CAAI,GAAA,MAAA,CAAO,KAAK,CAAI,GAAA,EAAA,CAAA;AAAA,KACnD,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,KAAe,KAAA;AACpC,MAAA,OAAA,CAAQ,cAAc,cAAgB,EAAA;AAAA,QACpC,GAAG,KAAA;AAAA,QACH,KAAA;AAAA,OACD,CAAA,CAAA;AAAA,KACH,CAAA;AAEA,IAAM,MAAA,aAAA,GAAgB,CAAC,GAAmB,KAAA;AACxC,MAAI,IAAA,OAAO,GAAI,CAAA,KAAA,KAAU,UAAY,EAAA;AACnC,QAAA,GAAA,CAAI,KAAM,CAAA,KAAA,CAAM,GAAK,EAAA,KAAA,CAAM,KAAK,CAAA,CAAA;AAChC,QAAA,OAAA;AAAA,OACF;AACA,MAAQ,OAAA,CAAA,aAAA,CAAc,GAAI,CAAA,IAAA,EAAM,KAAK,CAAA,CAAA;AAAA,KACvC,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
@@ -27,7 +27,6 @@ const tableProps = {
27
27
  },
28
28
  type: Array
29
29
  }
30
- // ...ElTableNext.props,
31
30
  };
32
31
 
33
32
  exports.tableProps = tableProps;
@@ -1 +1 @@
1
- {"version":3,"file":"props.js","sources":["../../../src/table/src/props.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n// import ElTableNext from 'el-table-next'\n\nexport const tableProps = {\n tableApi: {\n default: '',\n type: String,\n },\n cacheTable: {\n default: true,\n type: Boolean,\n },\n tableBefore: {\n default: () => {\n return {}\n },\n type: Object,\n },\n tableAfter: {\n default: () => {\n return {}\n },\n type: Object,\n },\n buttons: {\n default: () => {\n return ['refresh', 'add', 'export_csv', 'edit', 'delete', 'comSearch', 'quickSearch', 'columnDisplay']\n },\n type: Array,\n },\n // ...ElTableNext.props,\n}\n\nexport type TableProps = ExtractPropTypes<typeof tableProps>\n"],"names":[],"mappings":";;AAGO,MAAM,UAAa,GAAA;AAAA,EACxB,QAAU,EAAA;AAAA,IACR,OAAS,EAAA,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,OAAS,EAAA,IAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,GACR;AAAA,EACA,WAAa,EAAA;AAAA,IACX,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,OAAS,EAAA;AAAA,IACP,SAAS,MAAM;AACb,MAAO,OAAA,CAAC,WAAW,KAAO,EAAA,YAAA,EAAc,QAAQ,QAAU,EAAA,WAAA,EAAa,eAAe,eAAe,CAAA,CAAA;AAAA,KACvG;AAAA,IACA,IAAM,EAAA,KAAA;AAAA,GACR;AAAA;AAEF;;;;"}
1
+ {"version":3,"file":"props.js","sources":["../../../src/table/src/props.ts"],"sourcesContent":["import type { ExtractPropTypes } from 'vue'\n// import ElTableNext from 'el-table-next'\n\nexport const tableProps = {\n tableApi: {\n default: '',\n type: String,\n },\n cacheTable: {\n default: true,\n type: Boolean,\n },\n tableBefore: {\n default: () => {\n return {}\n },\n type: Object,\n },\n tableAfter: {\n default: () => {\n return {}\n },\n type: Object,\n },\n buttons: {\n default: () => {\n return ['refresh', 'add', 'export_csv', 'edit', 'delete', 'comSearch', 'quickSearch', 'columnDisplay']\n },\n type: Array,\n },\n}\n\nexport type TableProps = ExtractPropTypes<typeof tableProps>\n"],"names":[],"mappings":";;AAGO,MAAM,UAAa,GAAA;AAAA,EACxB,QAAU,EAAA;AAAA,IACR,OAAS,EAAA,EAAA;AAAA,IACT,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,OAAS,EAAA,IAAA;AAAA,IACT,IAAM,EAAA,OAAA;AAAA,GACR;AAAA,EACA,WAAa,EAAA;AAAA,IACX,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,UAAY,EAAA;AAAA,IACV,SAAS,MAAM;AACb,MAAA,OAAO,EAAC,CAAA;AAAA,KACV;AAAA,IACA,IAAM,EAAA,MAAA;AAAA,GACR;AAAA,EACA,OAAS,EAAA;AAAA,IACP,SAAS,MAAM;AACb,MAAO,OAAA,CAAC,WAAW,KAAO,EAAA,YAAA,EAAc,QAAQ,QAAU,EAAA,WAAA,EAAa,eAAe,eAAe,CAAA,CAAA;AAAA,KACvG;AAAA,IACA,IAAM,EAAA,KAAA;AAAA,GACR;AACF;;;;"}
@@ -114,6 +114,7 @@ class dkTable {
114
114
  this.runAfter("getIndex", { res });
115
115
  }).finally(() => {
116
116
  this.table.loading = false;
117
+ }).catch(() => {
117
118
  });
118
119
  };
119
120
  getTable = (cache = false) => {
@@ -121,7 +122,7 @@ class dkTable {
121
122
  return;
122
123
  this.table.columnLoading = true;
123
124
  if (cache) {
124
- const cachedData = utils.storage.get(this.url + "_table");
125
+ const cachedData = utils.storage.get(this.api.actionUrl.get("table") + "_table");
125
126
  if (cachedData) {
126
127
  const cachedTableData = JSON.parse(cachedData);
127
128
  this.table.column = cachedTableData.column;
@@ -135,10 +136,11 @@ class dkTable {
135
136
  if (res.data.pk) {
136
137
  this.table.pk = res.data.pk;
137
138
  }
138
- utils.storage.set(this.url + "_table", JSON.stringify(res.data));
139
+ utils.storage.set(this.api.actionUrl.get("table") + "_table", JSON.stringify(res.data));
139
140
  this.runAfter("getTable", { res });
140
141
  }).finally(() => {
141
142
  this.table.columnLoading = false;
143
+ }).catch(() => {
142
144
  });
143
145
  }
144
146
  };