ll-plus 2.3.3 → 2.3.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/es/components/api-component/src/components/json-xml-table-row.vue2.mjs +1 -2
- package/es/components/api-component/src/components/json-xml-table-row.vue2.mjs.map +1 -1
- package/es/components/easy-cron/src/components/tabs/week-ui.vue.mjs +0 -1
- package/es/components/easy-cron/src/components/tabs/week-ui.vue.mjs.map +1 -1
- package/es/components/easy-cron/src/components/tabs/week-ui.vue2.mjs.map +1 -1
- package/es/components/key-value/src/components/key-value-item.vue2.mjs +1 -1
- package/es/components/key-value/src/components/key-value-item.vue2.mjs.map +1 -1
- package/es/components/table/src/components/main-table.vue2.mjs +14 -0
- package/es/components/table/src/components/main-table.vue2.mjs.map +1 -1
- package/es/components/table/src/table.vue2.mjs +21 -3
- package/es/components/table/src/table.vue2.mjs.map +1 -1
- package/index.full.js +37 -7
- package/index.full.min.js +17 -17
- package/index.full.min.js.map +1 -1
- package/index.full.min.mjs +18 -18
- package/index.full.min.mjs.map +1 -1
- package/index.full.mjs +37 -7
- package/lib/components/api-component/src/components/json-xml-table-row.vue2.js +1 -2
- package/lib/components/api-component/src/components/json-xml-table-row.vue2.js.map +1 -1
- package/lib/components/easy-cron/src/components/tabs/week-ui.vue.js +0 -1
- package/lib/components/easy-cron/src/components/tabs/week-ui.vue.js.map +1 -1
- package/lib/components/easy-cron/src/components/tabs/week-ui.vue2.js.map +1 -1
- package/lib/components/key-value/src/components/key-value-item.vue2.js +1 -1
- package/lib/components/key-value/src/components/key-value-item.vue2.js.map +1 -1
- package/lib/components/table/src/components/main-table.vue2.js +14 -0
- package/lib/components/table/src/components/main-table.vue2.js.map +1 -1
- package/lib/components/table/src/table.vue2.js +21 -3
- package/lib/components/table/src/table.vue2.js.map +1 -1
- package/package.json +1 -1
- package/theme-chalk/fonts/iconfont.js +1 -1
- package/theme-chalk/fonts/iconfont.json +1 -1
|
@@ -126,7 +126,6 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
126
126
|
const _component_a_col = resolveComponent("a-col");
|
|
127
127
|
const _component_ll_select = resolveComponent("ll-select");
|
|
128
128
|
const _component_ll_tooltip = resolveComponent("ll-tooltip");
|
|
129
|
-
const _component_ll_bitton = resolveComponent("ll-bitton");
|
|
130
129
|
const _component_ll_dropdown = resolveComponent("ll-dropdown");
|
|
131
130
|
const _component_a_popconfirm = resolveComponent("a-popconfirm");
|
|
132
131
|
const _component_a_row = resolveComponent("a-row");
|
|
@@ -329,7 +328,7 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
329
328
|
onClaimSelected: handleClaimSelected
|
|
330
329
|
}, {
|
|
331
330
|
default: withCtx(() => [
|
|
332
|
-
props.parentData && props.parentData.type === "object" && innerData.value.type === "object" ? (openBlock(), createBlock(
|
|
331
|
+
props.parentData && props.parentData.type === "object" && innerData.value.type === "object" ? (openBlock(), createBlock(_component_ll_button, {
|
|
333
332
|
key: 0,
|
|
334
333
|
class: normalizeClass(unref(bem).m("table-icon")),
|
|
335
334
|
disabled: unref(disabled),
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"json-xml-table-row.vue2.mjs","sources":["../../../../../../packages/components/api-component/src/components/json-xml-table-row.vue"],"sourcesContent":["<template>\n <a-row :gutter=\"20\" :class=\"bem.e('table-row')\">\n <a-col style=\"display: flex\" :span=\"7\" :class=\"bem.e('table-col')\">\n <p :style=\"{ width: 10 * props.layer + 'px' }\" />\n <div style=\"margin-right: 30px\" :class=\"bem.m('table-row-icon')\">\n <ll-button\n v-if=\"innerData.type === 'object' || innerData.type === 'array'\"\n type=\"link\"\n style=\"width: 10px\"\n :disabled=\"disabled\"\n @click=\"expanded = !expanded\"\n >\n <ll-icon\n v-if=\"!expanded\"\n style=\"font-size: 14px\"\n icon-name=\"icon-list-expand\"\n />\n <ll-icon\n v-else\n style=\"font-size: 14px\"\n icon-name=\"icon-list-retract\"\n />\n </ll-button>\n </div>\n\n <div v-if=\"!props.parentData\" :class=\"bem.m('table-row-tag')\">根节点</div>\n <template v-else>\n <div\n v-if=\"props.parentData.type === 'array'\"\n :class=\"bem.m('table-row-tag')\"\n >\n ITEMS\n </div>\n <ll-input\n v-if=\"props.parentData.type === 'object'\"\n v-model:value=\"innerData.name\"\n :disabled=\"disabled\"\n placeholder=\"添加字段名\"\n :bordered=\"false\"\n ></ll-input>\n </template>\n </a-col>\n <a-col :span=\"3\" :class=\"bem.e('table-col')\">\n <ll-select\n v-model:value=\"innerData.type\"\n :options=\"jsonXmlTypeOptions\"\n :disabled=\"disabled\"\n style=\"width: 100%\"\n @change=\"handleChange\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <click-input\n v-model:value=\"innerData.mock\"\n placeholder=\"Mock\"\n :disabled=\"innerData.type === 'object' || disabled\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <ll-input\n v-model:value=\"innerData.chineseName\"\n :disabled=\"disabled\"\n placeholder=\"中文名\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <click-input\n v-model:value=\"innerData.description\"\n :disabled=\"disabled\"\n placeholder=\"说明\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"2\">\n <div :class=\"bem.e('table-operation')\">\n <ll-tooltip\n v-if=\"\n (props.parentData &&\n props.parentData.type === 'object' &&\n innerData.type !== 'object') ||\n (!props.parentData && innerData.type === 'object')\n \"\n :tip=\"\n getTip(parentData, innerData) === 'child'\n ? '添加子节点'\n : '添加相邻节点'\n \"\n >\n <ll-button\n type=\"link\"\n :disabled=\"disabled\"\n :class=\"bem.m('table-icon')\"\n @click=\"\n handleAdd(\n getTip(parentData, innerData),\n props.parentData,\n innerData\n )\n \"\n >\n <ll-icon icon-name=\"icon-list-add\" />\n </ll-button>\n </ll-tooltip>\n\n <ll-dropdown\n :dropdown-items=\"customOverlay(props.parentData, innerData)\"\n placement=\"bottomRight\"\n @claim-selected=\"handleClaimSelected\"\n >\n <ll-bitton\n v-if=\"\n props.parentData &&\n props.parentData.type === 'object' &&\n innerData.type === 'object'\n \"\n :class=\"bem.m('table-icon')\"\n :disabled=\"disabled\"\n type=\"link\"\n >\n <ll-icon icon-name=\"icon-list-add\" />\n </ll-bitton>\n </ll-dropdown>\n\n <a-popconfirm\n v-if=\"props.parentData && props.parentData.type !== 'array'\"\n title=\"你确定要移除吗?\"\n ok-text=\"确认\"\n cancel-text=\"取消\"\n placement=\"topRight\"\n :overlay-class-name=\"bem.e('popconfirm')\"\n :disabled=\"disabled\"\n @confirm=\"handleConfirm(props.parentData, innerData)\"\n >\n <ll-button\n type=\"link\"\n :disabled=\"disabled\"\n :class=\"bem.m('table-icon')\"\n >\n <ll-icon icon-name=\"icon-remove\" />\n </ll-button>\n </a-popconfirm>\n </div>\n </a-col>\n </a-row>\n\n <template v-if=\"expanded\">\n <a-row\n v-if=\"\n innerData.type === 'object' &&\n innerData.children &&\n innerData.children.length === 0\n \"\n :gutter=\"20\"\n :class=\"bem.e('table-row')\"\n >\n <a-col style=\"display: flex\" :span=\"7\" :class=\"bem.e('table-col')\">\n <p :style=\"{ width: 10 * props.layer + 'px' }\" />\n <div style=\"margin-right: 30px\" :class=\"bem.m('table-row-icon')\" />\n <ll-input\n v-model:value=\"addValue\"\n placeholder=\"添加字段名\"\n :bordered=\"false\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n />\n </a-col>\n </a-row>\n\n <template v-if=\"innerData.children && innerData.children.length > 0\">\n <template v-for=\"(child, index) in innerData.children\" :key=\"index\">\n <table-row\n :parent-data=\"innerData\"\n :data=\"child\"\n :layer=\"props.layer + 1\"\n :tree-key=\"props.treeKey + '-' + (index + 1)\"\n @change=\"handleRowChange\"\n />\n </template>\n </template>\n </template>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, watch, inject } from 'vue'\n\nimport { createNamespace } from '@ll-plus/utils'\n\nimport {\n jsonXmlTypeOptions,\n jsonXmlTableRowProps,\n jsonXmlTableRowEmits\n} from '../config'\n\nimport TableRow from './json-xml-table-row.vue'\n\nimport ClickInput from './click-input.vue'\n\ndefineOptions({ name: 'LlJsonXmlTableRow' })\n\nconst bem = createNamespace('json-xml')\n\nconst props = defineProps(jsonXmlTableRowProps)\n\nconst emits = defineEmits(jsonXmlTableRowEmits)\n\nconst disabled = inject('disabled') as boolean\n\nconst innerData = ref(props.data)\n\nconst parentData = ref(props.parentData)\n\nconst expanded = ref(true)\n\nconst addValue = ref('')\n\nconst customOverlay = (parentData, innerData) => [\n {\n label: '添加子节点',\n type: 'child',\n parentData,\n innerData\n },\n {\n label: '添加相邻节点',\n type: 'next',\n parentData,\n innerData\n }\n]\n\nconst getTip = (parentData, innerData) => {\n if (\n !parentData ||\n (parentData.type === 'array' && innerData.type === 'object')\n ) {\n return 'child'\n }\n if (parentData.type === 'object' && innerData.type !== 'object') {\n return 'next'\n }\n}\n\nconst handleChange = () => {\n if (innerData.value.type === 'object' || innerData.value.type === 'array') {\n innerData.value.children = []\n if (innerData.value.type === 'array') {\n innerData.value.children[0] = {\n key: props.treeKey + '-1',\n name: 'ITEMS',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n }\n }\n } else {\n delete innerData.value.children\n }\n}\n\nconst handleConfirm = (parentData, innerData) => {\n const findIndex = parentData.children.findIndex(\n item => item.key === innerData.key\n )\n parentData.children.splice(findIndex, 1)\n}\n\nconst handleInput = () => {\n innerData.value.children = []\n innerData.value.children[0] = {\n key: props.treeKey + '-1',\n name: addValue.value,\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n }\n addValue.value = ''\n}\n\nconst handleAdd = (type, parentData, innerData) => {\n if (type === 'next') {\n parentData.children.push({\n key: `${parentData.children.length + 1}`,\n name: '',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n })\n } else {\n innerData.children.push({\n key: props.treeKey + `${innerData.children.length + 1}`,\n name: '',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n })\n }\n}\nconst handleClaimSelected = item => {\n const { type, parentData, innerData } = item\n handleAdd(type, parentData, innerData)\n}\n\nconst handleRowChange = () => {\n emits('change')\n}\nwatch(\n innerData,\n () => {\n emits('change')\n },\n {\n deep: true\n }\n)\n</script>\n"],"names":["parentData","innerData"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"json-xml-table-row.vue2.mjs","sources":["../../../../../../packages/components/api-component/src/components/json-xml-table-row.vue"],"sourcesContent":["<template>\n <a-row :gutter=\"20\" :class=\"bem.e('table-row')\">\n <a-col style=\"display: flex\" :span=\"7\" :class=\"bem.e('table-col')\">\n <p :style=\"{ width: 10 * props.layer + 'px' }\" />\n <div style=\"margin-right: 30px\" :class=\"bem.m('table-row-icon')\">\n <ll-button\n v-if=\"innerData.type === 'object' || innerData.type === 'array'\"\n type=\"link\"\n style=\"width: 10px\"\n :disabled=\"disabled\"\n @click=\"expanded = !expanded\"\n >\n <ll-icon\n v-if=\"!expanded\"\n style=\"font-size: 14px\"\n icon-name=\"icon-list-expand\"\n />\n <ll-icon\n v-else\n style=\"font-size: 14px\"\n icon-name=\"icon-list-retract\"\n />\n </ll-button>\n </div>\n\n <div v-if=\"!props.parentData\" :class=\"bem.m('table-row-tag')\">根节点</div>\n <template v-else>\n <div\n v-if=\"props.parentData.type === 'array'\"\n :class=\"bem.m('table-row-tag')\"\n >\n ITEMS\n </div>\n <ll-input\n v-if=\"props.parentData.type === 'object'\"\n v-model:value=\"innerData.name\"\n :disabled=\"disabled\"\n placeholder=\"添加字段名\"\n :bordered=\"false\"\n ></ll-input>\n </template>\n </a-col>\n <a-col :span=\"3\" :class=\"bem.e('table-col')\">\n <ll-select\n v-model:value=\"innerData.type\"\n :options=\"jsonXmlTypeOptions\"\n :disabled=\"disabled\"\n style=\"width: 100%\"\n @change=\"handleChange\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <click-input\n v-model:value=\"innerData.mock\"\n placeholder=\"Mock\"\n :disabled=\"innerData.type === 'object' || disabled\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <ll-input\n v-model:value=\"innerData.chineseName\"\n :disabled=\"disabled\"\n placeholder=\"中文名\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"4\" :class=\"bem.e('table-col')\">\n <click-input\n v-model:value=\"innerData.description\"\n :disabled=\"disabled\"\n placeholder=\"说明\"\n style=\"width: 100%\"\n />\n </a-col>\n <a-col :span=\"2\">\n <div :class=\"bem.e('table-operation')\">\n <ll-tooltip\n v-if=\"\n (props.parentData &&\n props.parentData.type === 'object' &&\n innerData.type !== 'object') ||\n (!props.parentData && innerData.type === 'object')\n \"\n :tip=\"\n getTip(parentData, innerData) === 'child'\n ? '添加子节点'\n : '添加相邻节点'\n \"\n >\n <ll-button\n type=\"link\"\n :disabled=\"disabled\"\n :class=\"bem.m('table-icon')\"\n @click=\"\n handleAdd(\n getTip(parentData, innerData),\n props.parentData,\n innerData\n )\n \"\n >\n <ll-icon icon-name=\"icon-list-add\" />\n </ll-button>\n </ll-tooltip>\n\n <ll-dropdown\n :dropdown-items=\"customOverlay(props.parentData, innerData)\"\n placement=\"bottomRight\"\n @claim-selected=\"handleClaimSelected\"\n >\n <ll-button\n v-if=\"\n props.parentData &&\n props.parentData.type === 'object' &&\n innerData.type === 'object'\n \"\n :class=\"bem.m('table-icon')\"\n :disabled=\"disabled\"\n type=\"link\"\n >\n <ll-icon icon-name=\"icon-list-add\" />\n </ll-button>\n </ll-dropdown>\n\n <a-popconfirm\n v-if=\"props.parentData && props.parentData.type !== 'array'\"\n title=\"你确定要移除吗?\"\n ok-text=\"确认\"\n cancel-text=\"取消\"\n placement=\"topRight\"\n :overlay-class-name=\"bem.e('popconfirm')\"\n :disabled=\"disabled\"\n @confirm=\"handleConfirm(props.parentData, innerData)\"\n >\n <ll-button\n type=\"link\"\n :disabled=\"disabled\"\n :class=\"bem.m('table-icon')\"\n >\n <ll-icon icon-name=\"icon-remove\" />\n </ll-button>\n </a-popconfirm>\n </div>\n </a-col>\n </a-row>\n\n <template v-if=\"expanded\">\n <a-row\n v-if=\"\n innerData.type === 'object' &&\n innerData.children &&\n innerData.children.length === 0\n \"\n :gutter=\"20\"\n :class=\"bem.e('table-row')\"\n >\n <a-col style=\"display: flex\" :span=\"7\" :class=\"bem.e('table-col')\">\n <p :style=\"{ width: 10 * props.layer + 'px' }\" />\n <div style=\"margin-right: 30px\" :class=\"bem.m('table-row-icon')\" />\n <ll-input\n v-model:value=\"addValue\"\n placeholder=\"添加字段名\"\n :bordered=\"false\"\n :disabled=\"disabled\"\n @input=\"handleInput\"\n />\n </a-col>\n </a-row>\n\n <template v-if=\"innerData.children && innerData.children.length > 0\">\n <template v-for=\"(child, index) in innerData.children\" :key=\"index\">\n <table-row\n :parent-data=\"innerData\"\n :data=\"child\"\n :layer=\"props.layer + 1\"\n :tree-key=\"props.treeKey + '-' + (index + 1)\"\n @change=\"handleRowChange\"\n />\n </template>\n </template>\n </template>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, watch, inject } from 'vue'\n\nimport { createNamespace } from '@ll-plus/utils'\n\nimport {\n jsonXmlTypeOptions,\n jsonXmlTableRowProps,\n jsonXmlTableRowEmits\n} from '../config'\n\nimport TableRow from './json-xml-table-row.vue'\n\nimport ClickInput from './click-input.vue'\n\ndefineOptions({ name: 'LlJsonXmlTableRow' })\n\nconst bem = createNamespace('json-xml')\n\nconst props = defineProps(jsonXmlTableRowProps)\n\nconst emits = defineEmits(jsonXmlTableRowEmits)\n\nconst disabled = inject('disabled') as boolean\n\nconst innerData = ref(props.data)\n\nconst parentData = ref(props.parentData)\n\nconst expanded = ref(true)\n\nconst addValue = ref('')\n\nconst customOverlay = (parentData, innerData) => [\n {\n label: '添加子节点',\n type: 'child',\n parentData,\n innerData\n },\n {\n label: '添加相邻节点',\n type: 'next',\n parentData,\n innerData\n }\n]\n\nconst getTip = (parentData, innerData) => {\n if (\n !parentData ||\n (parentData.type === 'array' && innerData.type === 'object')\n ) {\n return 'child'\n }\n if (parentData.type === 'object' && innerData.type !== 'object') {\n return 'next'\n }\n}\n\nconst handleChange = () => {\n if (innerData.value.type === 'object' || innerData.value.type === 'array') {\n innerData.value.children = []\n if (innerData.value.type === 'array') {\n innerData.value.children[0] = {\n key: props.treeKey + '-1',\n name: 'ITEMS',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n }\n }\n } else {\n delete innerData.value.children\n }\n}\n\nconst handleConfirm = (parentData, innerData) => {\n const findIndex = parentData.children.findIndex(\n item => item.key === innerData.key\n )\n parentData.children.splice(findIndex, 1)\n}\n\nconst handleInput = () => {\n innerData.value.children = []\n innerData.value.children[0] = {\n key: props.treeKey + '-1',\n name: addValue.value,\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n }\n addValue.value = ''\n}\n\nconst handleAdd = (type, parentData, innerData) => {\n if (type === 'next') {\n parentData.children.push({\n key: `${parentData.children.length + 1}`,\n name: '',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n })\n } else {\n innerData.children.push({\n key: props.treeKey + `${innerData.children.length + 1}`,\n name: '',\n type: 'string',\n value: '',\n chineseName: '',\n description: '',\n mock: ''\n })\n }\n}\nconst handleClaimSelected = item => {\n const { type, parentData, innerData } = item\n handleAdd(type, parentData, innerData)\n}\n\nconst handleRowChange = () => {\n emits('change')\n}\nwatch(\n innerData,\n () => {\n emits('change')\n },\n {\n deep: true\n }\n)\n</script>\n"],"names":["parentData","innerData"],"mappings":"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"}
|
|
@@ -151,7 +151,6 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
|
|
|
151
151
|
class: normalizeClass(`${_ctx.bem.m("item")} ${_ctx.bem.m("item-checkbox")}`)
|
|
152
152
|
},
|
|
153
153
|
[
|
|
154
|
-
createTextVNode(" > "),
|
|
155
154
|
createVNode(_component_Radio, mergeProps({
|
|
156
155
|
value: _ctx.TypeEnum.specify
|
|
157
156
|
}, _ctx.beforeRadioAttrs), {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"week-ui.vue.mjs","sources":["../../../../../../../packages/components/easy-cron/src/components/tabs/week-ui.vue"],"sourcesContent":["<template>\n <div :class=\"bem.b()\">\n <RadioGroup v-model:value=\"type\">\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.unset\" v-bind=\"beforeRadioAttrs\">\n 不设置\n </Radio>\n <span>日和周只能设置其中之一</span>\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.range\" v-bind=\"beforeRadioAttrs\"> 区间 </Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueRange.start\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n <span>至</span>\n <ASelect\n v-model:value=\"valueRange.end\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.loop\" v-bind=\"beforeRadioAttrs\">循环</Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueLoop.start\"\n :options=\"weekOptions\"\n v-bind=\"typeLoopSelectAttrs\"\n />\n <span>开始,间隔</span>\n <InputNumber\n v-model:value=\"valueLoop.interval\"\n v-bind=\"typeLoopAttrs\"\n />\n <span>天</span>\n </div>\n <div :class=\"`${bem.m('item')} ${bem.m('item-checkbox')}`\">\n
|
|
1
|
+
{"version":3,"file":"week-ui.vue.mjs","sources":["../../../../../../../packages/components/easy-cron/src/components/tabs/week-ui.vue"],"sourcesContent":["<template>\n <div :class=\"bem.b()\">\n <RadioGroup v-model:value=\"type\">\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.unset\" v-bind=\"beforeRadioAttrs\">\n 不设置\n </Radio>\n <span>日和周只能设置其中之一</span>\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.range\" v-bind=\"beforeRadioAttrs\"> 区间 </Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueRange.start\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n <span>至</span>\n <ASelect\n v-model:value=\"valueRange.end\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.loop\" v-bind=\"beforeRadioAttrs\">循环</Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueLoop.start\"\n :options=\"weekOptions\"\n v-bind=\"typeLoopSelectAttrs\"\n />\n <span>开始,间隔</span>\n <InputNumber\n v-model:value=\"valueLoop.interval\"\n v-bind=\"typeLoopAttrs\"\n />\n <span>天</span>\n </div>\n <div :class=\"`${bem.m('item')} ${bem.m('item-checkbox')}`\">\n <Radio :value=\"TypeEnum.specify\" v-bind=\"beforeRadioAttrs\">\n 指定\n </Radio>\n <div :class=\"[bem.e('list'), bem.is('cn')]\">\n <CheckboxGroup v-model:value=\"valueList\">\n <template v-for=\"opt in weekOptions\" :key=\"opt.value\">\n <Checkbox :value=\"opt.value\" v-bind=\"typeSpecifyAttrs\">\n {{ opt.label }}\n </Checkbox>\n </template>\n </CheckboxGroup>\n </div>\n </div>\n </RadioGroup>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, watch, defineComponent } from 'vue'\nimport {\n InputNumber,\n RadioGroup,\n Radio,\n CheckboxGroup,\n Checkbox,\n Select as ASelect\n} from 'ant-design-vue'\n\nimport {\n useTabProps,\n useTabEmits,\n useTabSetup,\n TypeEnum\n} from '../../config/use-tab-mixin'\n\nconst WEEK_MAP_EN = {\n '1': 'SUN',\n '2': 'MON',\n '3': 'TUE',\n '4': 'WED',\n '5': 'THU',\n '6': 'FRI',\n '7': 'SAT'\n}\n\nconst WEEK_MAP_CN = {\n '1': '周日',\n '2': '周一',\n '3': '周二',\n '4': '周三',\n '5': '周四',\n '6': '周五',\n '7': '周六'\n}\nexport default defineComponent({\n name: 'WeekUI',\n components: {\n InputNumber,\n RadioGroup,\n Radio,\n CheckboxGroup,\n Checkbox,\n ASelect\n },\n props: useTabProps({\n defaultValue: '?',\n props: {\n day: { type: String, default: '*' }\n }\n }),\n emits: useTabEmits(),\n setup(props, context) {\n const disabledChoice = computed(() => {\n return (props.day && props.day !== '?') || props.disabled\n })\n const setup = useTabSetup(props, context, {\n defaultType: TypeEnum.unset,\n defaultValue: '?',\n minValue: 1,\n maxValue: 7,\n // 0,7表示周日 1表示周一\n valueRange: { start: 1, end: 7 },\n valueLoop: { start: 2, interval: 1 },\n disabled: disabledChoice\n })\n const weekOptions = computed(() => {\n const options: { label: string; value: number }[] = []\n for (const weekKey of Object.keys(WEEK_MAP_CN)) {\n const weekName: string = WEEK_MAP_CN[weekKey]\n options.push({\n value: Number.parseInt(weekKey),\n label: weekName\n })\n }\n return options\n })\n\n const typeRangeSelectAttrs = computed(() => ({\n class: ['w100'],\n disabled: setup.typeRangeAttrs.value.disabled\n }))\n\n const typeLoopSelectAttrs = computed(() => ({\n class: ['w100'],\n disabled: setup.typeLoopAttrs.value.disabled\n }))\n\n watch(\n () => props.day,\n () => {\n setup.updateValue(disabledChoice.value ? '?' : setup.computeValue.value)\n }\n )\n\n return {\n ...setup,\n weekOptions,\n typeLoopSelectAttrs,\n typeRangeSelectAttrs,\n WEEK_MAP_CN,\n WEEK_MAP_EN\n }\n }\n})\n</script>\n"],"names":["_createElementVNode","_resolveComponent","_normalizeClass","_createVNode","_withCtx","beforeRadioAttrs","_mergeProps","_createTextVNode","weekOptions","typeRangeSelectAttrs","typeLoopSelectAttrs","typeLoopAttrs","bem","_openBlock","_createElementBlock","_Fragment","_renderList","_createBlock","typeSpecifyAttrs","_toDisplayString"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"week-ui.vue2.mjs","sources":["../../../../../../../packages/components/easy-cron/src/components/tabs/week-ui.vue"],"sourcesContent":["<template>\n <div :class=\"bem.b()\">\n <RadioGroup v-model:value=\"type\">\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.unset\" v-bind=\"beforeRadioAttrs\">\n 不设置\n </Radio>\n <span>日和周只能设置其中之一</span>\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.range\" v-bind=\"beforeRadioAttrs\"> 区间 </Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueRange.start\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n <span>至</span>\n <ASelect\n v-model:value=\"valueRange.end\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.loop\" v-bind=\"beforeRadioAttrs\">循环</Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueLoop.start\"\n :options=\"weekOptions\"\n v-bind=\"typeLoopSelectAttrs\"\n />\n <span>开始,间隔</span>\n <InputNumber\n v-model:value=\"valueLoop.interval\"\n v-bind=\"typeLoopAttrs\"\n />\n <span>天</span>\n </div>\n <div :class=\"`${bem.m('item')} ${bem.m('item-checkbox')}`\">\n
|
|
1
|
+
{"version":3,"file":"week-ui.vue2.mjs","sources":["../../../../../../../packages/components/easy-cron/src/components/tabs/week-ui.vue"],"sourcesContent":["<template>\n <div :class=\"bem.b()\">\n <RadioGroup v-model:value=\"type\">\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.unset\" v-bind=\"beforeRadioAttrs\">\n 不设置\n </Radio>\n <span>日和周只能设置其中之一</span>\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.range\" v-bind=\"beforeRadioAttrs\"> 区间 </Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueRange.start\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n <span>至</span>\n <ASelect\n v-model:value=\"valueRange.end\"\n :options=\"weekOptions\"\n v-bind=\"typeRangeSelectAttrs\"\n />\n </div>\n <div :class=\"bem.m('item')\">\n <Radio :value=\"TypeEnum.loop\" v-bind=\"beforeRadioAttrs\">循环</Radio>\n <span>从</span>\n <ASelect\n v-model:value=\"valueLoop.start\"\n :options=\"weekOptions\"\n v-bind=\"typeLoopSelectAttrs\"\n />\n <span>开始,间隔</span>\n <InputNumber\n v-model:value=\"valueLoop.interval\"\n v-bind=\"typeLoopAttrs\"\n />\n <span>天</span>\n </div>\n <div :class=\"`${bem.m('item')} ${bem.m('item-checkbox')}`\">\n <Radio :value=\"TypeEnum.specify\" v-bind=\"beforeRadioAttrs\">\n 指定\n </Radio>\n <div :class=\"[bem.e('list'), bem.is('cn')]\">\n <CheckboxGroup v-model:value=\"valueList\">\n <template v-for=\"opt in weekOptions\" :key=\"opt.value\">\n <Checkbox :value=\"opt.value\" v-bind=\"typeSpecifyAttrs\">\n {{ opt.label }}\n </Checkbox>\n </template>\n </CheckboxGroup>\n </div>\n </div>\n </RadioGroup>\n </div>\n</template>\n\n<script lang=\"ts\">\nimport { computed, watch, defineComponent } from 'vue'\nimport {\n InputNumber,\n RadioGroup,\n Radio,\n CheckboxGroup,\n Checkbox,\n Select as ASelect\n} from 'ant-design-vue'\n\nimport {\n useTabProps,\n useTabEmits,\n useTabSetup,\n TypeEnum\n} from '../../config/use-tab-mixin'\n\nconst WEEK_MAP_EN = {\n '1': 'SUN',\n '2': 'MON',\n '3': 'TUE',\n '4': 'WED',\n '5': 'THU',\n '6': 'FRI',\n '7': 'SAT'\n}\n\nconst WEEK_MAP_CN = {\n '1': '周日',\n '2': '周一',\n '3': '周二',\n '4': '周三',\n '5': '周四',\n '6': '周五',\n '7': '周六'\n}\nexport default defineComponent({\n name: 'WeekUI',\n components: {\n InputNumber,\n RadioGroup,\n Radio,\n CheckboxGroup,\n Checkbox,\n ASelect\n },\n props: useTabProps({\n defaultValue: '?',\n props: {\n day: { type: String, default: '*' }\n }\n }),\n emits: useTabEmits(),\n setup(props, context) {\n const disabledChoice = computed(() => {\n return (props.day && props.day !== '?') || props.disabled\n })\n const setup = useTabSetup(props, context, {\n defaultType: TypeEnum.unset,\n defaultValue: '?',\n minValue: 1,\n maxValue: 7,\n // 0,7表示周日 1表示周一\n valueRange: { start: 1, end: 7 },\n valueLoop: { start: 2, interval: 1 },\n disabled: disabledChoice\n })\n const weekOptions = computed(() => {\n const options: { label: string; value: number }[] = []\n for (const weekKey of Object.keys(WEEK_MAP_CN)) {\n const weekName: string = WEEK_MAP_CN[weekKey]\n options.push({\n value: Number.parseInt(weekKey),\n label: weekName\n })\n }\n return options\n })\n\n const typeRangeSelectAttrs = computed(() => ({\n class: ['w100'],\n disabled: setup.typeRangeAttrs.value.disabled\n }))\n\n const typeLoopSelectAttrs = computed(() => ({\n class: ['w100'],\n disabled: setup.typeLoopAttrs.value.disabled\n }))\n\n watch(\n () => props.day,\n () => {\n setup.updateValue(disabledChoice.value ? '?' : setup.computeValue.value)\n }\n )\n\n return {\n ...setup,\n weekOptions,\n typeLoopSelectAttrs,\n typeRangeSelectAttrs,\n WEEK_MAP_CN,\n WEEK_MAP_EN\n }\n }\n})\n</script>\n"],"names":["ASelect"],"mappings":"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"}
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"key-value-item.vue2.mjs","sources":["../../../../../../packages/components/key-value/src/components/key-value-item.vue"],"sourcesContent":["<template>\n <ll-form\n ref=\"form\"\n :form-columns=\"formColumns\"\n :form-data=\"props.value\"\n :form-options=\"formOptions\"\n >\n <template #formItem=\"{ item }\">\n <template v-if=\"item.key === 'other'\">\n <div :class=\"bem.e('item')\">\n <div v-if=\"props.keyValueType !== 'single'\" :class=\"bem.m('left')\">\n <ll-form-item\n :label=\"attrs['key-label']\"\n :label-col=\"{\n span: 24\n }\"\n :rules=\"
|
|
1
|
+
{"version":3,"file":"key-value-item.vue2.mjs","sources":["../../../../../../packages/components/key-value/src/components/key-value-item.vue"],"sourcesContent":["<template>\n <ll-form\n ref=\"form\"\n :form-columns=\"formColumns\"\n :form-data=\"props.value\"\n :form-options=\"formOptions\"\n >\n <template #formItem=\"{ item }\">\n <template v-if=\"item.key === 'other'\">\n <div :class=\"bem.e('item')\">\n <div v-if=\"props.keyValueType !== 'single'\" :class=\"bem.m('left')\">\n <ll-form-item\n :label=\"attrs['key-label']\"\n :label-col=\"{\n span: 24\n }\"\n :rules=\"getKeyType.rules || []\"\n name=\"key\"\n >\n <slot name=\"key\">\n <ll-select\n v-if=\"!isEmpty(props.keyTypes)\"\n v-model:value=\"innerValue['key']\"\n :options=\"props.keyTypes\"\n :disabled=\"getKeyDisabled\"\n placeholder=\"请选择\"\n allow-clear\n @change=\"handleChange\"\n />\n <component\n :is=\"`ll-${getKeyType.type}`\"\n v-else\n v-model:value=\"innerValue['key']\"\n v-bind=\"getKeyType\"\n :disabled=\"getKeyDisabled\"\n style=\"width: 100%\"\n >\n <template\n v-for=\"_item in Object.keys($slots)\"\n :key=\"_item\"\n #[_item]=\"data\"\n >\n <slot\n :name=\"_item\"\n v-bind=\"data || {}\"\n content=\"key\"\n ></slot>\n </template>\n </component>\n </slot>\n </ll-form-item>\n </div>\n\n <div\n v-if=\"props.keyValueType !== 'single'\"\n :class=\"bem.m('separator')\"\n :style=\"{\n 'margin-top':\n !!attrs['key-label'] || !!attrs['value-label'] ? '26px' : '0px'\n }\"\n >\n <slot name=\"separator\">~</slot>\n </div>\n\n <div :class=\"bem.m('right')\">\n <ll-form-item\n :label=\"attrs['value-label']\"\n :label-col=\"{\n span: 24\n }\"\n :rules=\"getValueType.rules || []\"\n name=\"value\"\n >\n <slot name=\"value-warapper\" v-bind=\"getValueType\">\n <component\n :is=\"`ll-${getValueType.type}`\"\n v-model:value=\"innerValue['value']\"\n :disabled=\"getValueDisabled\"\n style=\"width: 100%\"\n v-bind=\"getValueType\"\n >\n <template\n v-for=\"_item in Object.keys($slots)\"\n :key=\"_item\"\n #[_item]=\"data\"\n >\n <slot\n :name=\"_item\"\n v-bind=\"data || {}\"\n content=\"value\"\n ></slot>\n </template>\n </component>\n </slot>\n </ll-form-item>\n </div>\n\n <a-popconfirm\n title=\"你确定要移除吗?\"\n ok-text=\"确认\"\n cancel-text=\"取消\"\n placement=\"topRight\"\n :overlay-class-name=\"bem.m('popconfirm')\"\n :get-popup-container=\"(trigger: Element) => trigger.parentNode\"\n destroy-tooltip-on-hide\n @confirm=\"handleDelete\"\n >\n <div\n v-if=\"props.showDelete\"\n :class=\"bem.m('delete')\"\n :style=\"{\n 'margin-top':\n !!attrs['key-label'] || !!attrs['value-label']\n ? '26px'\n : '0px'\n }\"\n >\n <ll-button type=\"link\" :disabled=\"getDeleteDisabled\">\n <slot name=\"delete-icon\">\n <ll-icon icon-name=\"icon-remove\" class=\"delete\" />\n </slot>\n </ll-button>\n </div>\n </a-popconfirm>\n </div>\n </template>\n </template>\n </ll-form>\n</template>\n\n<script setup lang=\"ts\">\nimport { ref, computed, useAttrs, watch, nextTick } from 'vue'\nimport { isEmpty } from 'lodash-es'\nimport { createNamespace } from '@ll-plus/utils'\nimport type { FormInstance } from '@ll-plus/components'\nimport {\n keyValueItemProps,\n keyValueItemEmits,\n formColumns,\n formOptions\n} from '../config'\nimport { type FormColumn } from '@ll-plus/components'\n\ndefineOptions({\n name: 'LlKeyValueItem'\n})\n\nconst props = defineProps(keyValueItemProps)\nconst emits = defineEmits(keyValueItemEmits)\n\nconst attrs = useAttrs()\nconst bem = createNamespace('key-value')\nconst innerValue = ref(props.value)\n\nconst form = ref<FormInstance | null>()\n\nconst getKeyType = computed<FormColumn>(() => {\n const option = props.keyType\n return option\n})\nconst getValueType = computed<FormColumn>(() => {\n let option = props.valueType\n if (innerValue.value['key'] && !isEmpty(props.keyValueTypeDict)) {\n option = props.keyValueTypeDict[innerValue.value['key']]\n }\n return option\n})\n\nconst getKeyDisabled = computed(() => {\n return (\n props.disabledKey?.includes(props.idx) ||\n props.disabled ||\n getKeyType.value?.disabled\n )\n})\n\nconst getValueDisabled = computed(() => {\n return (\n props.disabledValue?.includes(props.idx) ||\n props.disabled ||\n getValueType.value?.disabled\n )\n})\n\nconst getDeleteDisabled = computed(() => {\n return props.disabledDelete?.includes(props.idx) || props.disabled\n})\n\nconst handleDelete = () => {\n emits('delete')\n}\n\nconst handleChange = () => {\n innerValue.value['value'] = null\n}\n\nconst validate = async () => {\n return await form.value?.validate()\n}\n\nconst resetFields = async () => {\n return await form.value?.resetFields()\n}\n\nwatch(\n innerValue,\n async val => {\n await nextTick().then(() => {\n try {\n emits('update:value', val)\n emits('change')\n } catch (error) {\n console.error(error)\n }\n })\n },\n {\n deep: true\n }\n)\n\ndefineExpose({\n validate,\n resetFields\n})\n</script>\n\n<style scoped></style>\n"],"names":[],"mappings":"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"}
|
|
@@ -566,6 +566,20 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
566
566
|
renderSlot(_ctx.$slots, "customFilterDropdown", normalizeProps(guardReactiveProps(slots)))
|
|
567
567
|
]),
|
|
568
568
|
key: "1"
|
|
569
|
+
} : void 0,
|
|
570
|
+
_ctx.$slots.customFilterIcon ? {
|
|
571
|
+
name: "customFilterIcon",
|
|
572
|
+
fn: withCtx((slots) => [
|
|
573
|
+
renderSlot(_ctx.$slots, "customFilterIcon", normalizeProps(guardReactiveProps(slots)))
|
|
574
|
+
]),
|
|
575
|
+
key: "2"
|
|
576
|
+
} : void 0,
|
|
577
|
+
_ctx.$slots.summary ? {
|
|
578
|
+
name: "summary",
|
|
579
|
+
fn: withCtx((slots) => [
|
|
580
|
+
renderSlot(_ctx.$slots, "summary", normalizeProps(guardReactiveProps(slots)))
|
|
581
|
+
]),
|
|
582
|
+
key: "3"
|
|
569
583
|
} : void 0
|
|
570
584
|
]), 1040, ["class", "columns", "data-source", "expanded-row-keys", "custom-row", "scroll", "onChange", "onExpandedRowsChange"]);
|
|
571
585
|
};
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"main-table.vue2.mjs","sources":["../../../../../../packages/components/table/src/components/main-table.vue"],"sourcesContent":["<template>\n <a-table\n :class=\"`${bem.e('main-content')}`\"\n row-key=\"id\"\n v-bind=\"attrs\"\n :columns=\"newColumns\"\n :data-source=\"newDataSource\"\n :expanded-row-keys=\"newExpandedRowKeys\"\n :custom-row=\"props.showDrag ? dragCustomRow : (customRowProps as any)\"\n :pagination=\"false\"\n show-header\n :scroll=\"{\n scrollToFirstRowOnChange: true,\n x: props?.scroll?.x ? props?.scroll?.x : 'max-content',\n y: props?.scroll?.y ? props?.scroll?.y : '100%'\n }\"\n @expand=\"handleExpand\"\n @resize-column=\"handleResizeColumn\"\n @change=\"props.change\"\n @expanded-rows-change=\"props.expandedRowsChange\"\n >\n <!-- 1.表头插槽 -->\n <template #headerCell=\"slots\">\n <template v-if=\"slots.column.key === 'operate' && showSetting\">\n <div :class=\"`${bem.e('operate')}`\">\n <span>{{ slots.column.title }}</span>\n <a-popover\n trigger=\"click\"\n placement=\"bottomRight\"\n :overlay-inner-style=\"{\n padding: '0'\n }\"\n >\n <template #content>\n <div :class=\"`${bem.e('setting-popover')}`\">\n <!-- 头部 -->\n <div :class=\"`${bem.e('setting-popover-header')}`\">\n <a-checkbox\n :indeterminate=\"isIndeterminate\"\n :checked=\"isAllCheck\"\n @change=\"handleAllColumnChange\"\n >\n 列展示\n </a-checkbox>\n <span\n :class=\"`${bem.e('setting-reset-btn')}`\"\n @click=\"handleClickResetBtn\"\n >\n 重置\n </span>\n </div>\n <!-- 内容 -->\n <div :class=\"`${bem.e('setting-popover-content')}`\">\n <div>\n <draggable\n :list=\"settingColumns\"\n item-key=\"key\"\n :group=\"{ name: 'g1' }\"\n @change=\"dragChange\"\n >\n <template #item=\"{ element }\">\n <div :class=\"`${bem.e('setting-popover-menu')}`\">\n <!-- 拖拽 -->\n <div\n :class=\"`flex items-center ${bem.e(\n 'setting-popover-menu-left'\n )}`\"\n >\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n :style=\"{\n marginright: '5px'\n }\"\n >\n <ll-icon\n icon-name=\"icon-move\"\n class-name=\"icon\"\n />\n </a-button>\n <a-checkbox\n :checked=\"element.isCheck\"\n @change=\"\n (e: any) => {\n handleColumnItemChange(\n e.target?.checked!,\n element\n )\n }\n \"\n >\n {{ element.title }}\n </a-checkbox>\n </div>\n <div\n :class=\"`flex items-center ${bem.e(\n 'setting-popover-menu-right'\n )}`\"\n >\n <!-- 左移 -->\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n @click=\"handleColumnMove(element, 'left')\"\n >\n <ll-icon\n icon-name=\"icon-zuoyi\"\n :class-name=\"`icon ${\n element.fixed === 'left'\n ? bem.e('setting-popover-menu-fixed-icon')\n : ''\n }`\"\n />\n </a-button>\n <a-divider type=\"vertical\" />\n <!-- 右移 -->\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n @click=\"handleColumnMove(element, 'right')\"\n >\n <ll-icon\n icon-name=\"icon-youyi\"\n :class-name=\"`icon ${\n element.fixed === 'right'\n ? bem.e('setting-popover-menu-fixed-icon')\n : ''\n }`\"\n />\n </a-button>\n </div>\n </div>\n </template>\n </draggable>\n </div>\n </div>\n </div>\n </template>\n <a-button type=\"text\" :class=\"`${bem.e('setting-icon')}`\">\n <ll-icon icon-name=\"icon-set-line\" />\n </a-button>\n </a-popover>\n </div>\n </template>\n <template v-else-if=\"has(slots.column, 'RC_TABLE_INTERNAL_COL_DEFINE')\">\n <slot name=\"expandedTitle\"></slot>\n </template>\n <template v-else>{{ slots.column.title }}</template>\n <!-- 额外header单元格的插槽内容 -->\n <slot name=\"tableHeaderCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- 2.表格内容插槽 -->\n <template #bodyCell=\"slots\">\n <!-- 添加序列列 -->\n <template v-if=\"slots.column.key === '#' && showIndexColumn\">\n {{ slots.index + 1 }}\n </template>\n <!-- 添加操作列 -->\n <template v-else-if=\"slots.column.key === 'operate'\">\n <slot name=\"tableOperate\" v-bind=\"slots\"></slot>\n </template>\n <!-- 额外Body单元格的插槽内容 -->\n <slot name=\"tableBodyCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- 3.空状态自定义插槽 -->\n <template #emptyText>\n <slot name=\"emptyText\">\n <ll-empty>\n <template #content>暂无数据</template>\n </ll-empty>\n </slot>\n </template>\n <!-- 4.表格自定义展开内容插槽 -->\n <template v-if=\"$slots.expandedRow\" #expandedRowRender=\"slots\">\n <slot name=\"expandedRow\" v-bind=\"slots\"> </slot>\n </template>\n <!-- 5.表格自定义列筛选 -->\n <template v-if=\"$slots.customFilterDropdown\" #customFilterDropdown=\"slots\">\n <slot name=\"customFilterDropdown\" v-bind=\"slots\"> </slot>\n </template>\n </a-table>\n</template>\n<script lang=\"ts\" setup>\nimport { ref, watch, computed, useAttrs } from 'vue'\n\nimport { createNamespace } from '@ll-plus/utils'\n\nimport draggable from 'vuedraggable'\n\nimport { has } from 'lodash-es'\n\nimport { mainTableProps, mainTableEmits } from '../config'\n\n// 1.defineOptions\ndefineOptions({\n name: 'MainTable'\n})\n\n// 2.props/emits\nconst props = defineProps(mainTableProps)\nconst emits = defineEmits(mainTableEmits)\n\n// 3.hooks\nconst attrs = useAttrs()\n\n// 3.ref/let/const\nconst newColumns: any = ref([]) // 显示在表格的columns\nconst settingColumns: any = ref([])\nconst newDataSource: any = ref([])\nconst newExpandedRowKeys: any = ref([]) //展开的id数组\nlet preIndex = -1 // 源目标数据序号\nlet nextIndex = -1 // 目标数据序号\nconst bem = createNamespace('table')\n\n// 往表格列中添加序号和操作\nconst handleAddSerialNumberAndOperateToColumns = () => {\n if (props.showIndexColumn) {\n newColumns.value.unshift({\n title: '#',\n dataIndex: '#',\n key: '#',\n width: 50,\n fixed: 'left',\n class: 'table-serial-number-cell'\n })\n }\n if (props.showOperate) {\n newColumns.value.push({\n title: '操作',\n dataIndex: '',\n key: 'operate',\n width: 120,\n fixed: 'right',\n class: 'table-serial-operate-cell'\n })\n }\n}\n// 处理表格列的左、右固定排序(letf放最左边,没有定位放中间,右边放right定位)\nconst handleColumnsSortByFixed = (list: any, isDrag?: boolean) => {\n const newList = list\n const leftFixedColumns: any = [],\n normalFixedColumns: any = [],\n rightFixedColumns: any = []\n newList.forEach((item: any) => {\n const fixed = item.fixed\n if (fixed === 'left') {\n leftFixedColumns.push(item)\n } else if (fixed === 'right') {\n rightFixedColumns.push(item)\n } else {\n normalFixedColumns.push(item)\n }\n })\n leftFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n normalFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n rightFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n newColumns.value = [\n ...leftFixedColumns,\n ...normalFixedColumns,\n ...rightFixedColumns\n ]\n if (isDrag) {\n handleAddSerialNumberAndOperateToColumns()\n }\n}\n\n// 4.watch\nwatch(\n () => props.dataSource,\n (newValue: any) => {\n newDataSource.value = [...newValue]\n },\n {\n deep: true,\n immediate: true\n }\n)\n// 从本地存储中获取columns/没有则用用户传的\nwatch(\n () => [\n props.columns,\n props.settingKey,\n props.showIndexColumn,\n props.showOperate\n ],\n (arr: any) => {\n const [newValue, key] = arr\n let newcolumns = []\n // 有key\n if (key && localStorage.getItem(key)) {\n const localStorageColumns = localStorage.getItem(key)\n if (localStorageColumns) {\n newcolumns = JSON.parse(localStorageColumns)\n }\n } else {\n // 没key\n newcolumns = newValue.map((item: any, index: number) => ({\n ...item,\n isCheck: true,\n columnSortIndex:\n item.columnSortIndex === 0 || item.columnSortIndex\n ? item.columnSortIndex\n : index\n }))\n }\n // 1.过滤掉没有选中的\n newColumns.value = [...newcolumns].filter((item: any) => item.isCheck)\n // 2.如果有设置序列和操作,则添加\n handleAddSerialNumberAndOperateToColumns()\n // 3.根据定位来排序\n handleColumnsSortByFixed(newColumns.value)\n settingColumns.value = [...newcolumns]\n },\n {\n deep: true,\n immediate: true\n }\n)\nwatch(\n () => props.expandedRowKeys,\n (newValue: any) => {\n if (Array.isArray(newValue)) {\n newExpandedRowKeys.value = [...newValue]\n }\n },\n {\n deep: true,\n immediate: true\n }\n)\n// 5.methods\n//重新定义树状展开关闭功能\nconst handleExpand = (expanded: boolean, record: any) => {\n if (expanded) {\n newExpandedRowKeys.value.push(record.id)\n } else {\n const index = newExpandedRowKeys.value.findIndex(\n (e: any) => e === record.id\n )\n newExpandedRowKeys.value.splice(index, 1)\n }\n props.expand && props.expand(expanded, record)\n}\n// 列拖拽\nconst handleResizeColumn = (w: any, col: any) => {\n col.width = w\n props.resizeColumn && props.resizeColumn(w, col)\n}\n// 拖动排序\nconst dragCustomRow = (_: any, index: number) => {\n const normalConfig = {\n props: {\n // draggable: 'true'\n },\n draggable: true,\n style: {\n cursor: 'pointer'\n },\n // 鼠标移入\n onMouseenter: (event: Event) => {\n const target = event.target as HTMLElement\n target.draggable = true // 让你要拖动的行可以拖动,默认不可以\n },\n // 开始拖拽\n onDragstart: (event: Event) => {\n event.stopPropagation()\n preIndex = index\n },\n // 拖动元素经过的元素\n onDragover: (event: Event) => {\n event.preventDefault()\n },\n // 鼠标松开\n onDrop: (event: Event) => {\n let sortSource: any[] = []\n event.stopPropagation()\n // 得到目标数据序号\n nextIndex = index\n const dataSource = newDataSource.value\n // 排序后两个sort互换\n const preItem = { ...dataSource[preIndex] }\n const nextItem = { ...dataSource[nextIndex] }\n const preSort = preItem.sort\n const nextSort = nextItem.sort\n preItem.sort = nextSort\n nextItem.sort = preSort\n\n dataSource[preIndex] = nextItem\n dataSource[nextIndex] = preItem\n sortSource = [...dataSource]\n emits('handleChangeDataSource', sortSource)\n props.dragChange && props.dragChange(sortSource)\n }\n }\n const extraConfig = props.customRowProps\n ? { ...props.customRowProps(_, index) }\n : {}\n return { ...normalConfig, ...extraConfig }\n}\n// 是否全选\nconst isAllCheck = computed(() => {\n return settingColumns.value.every((item: any) => item.isCheck)\n})\n// 是否全选\nconst isIndeterminate = computed(() => {\n const getIsChecks = settingColumns.value.filter((item: any) => item.isCheck)\n return getIsChecks.length === 0\n ? false\n : settingColumns.value.length > getIsChecks.length\n})\n// 单个checkbox的change\nconst handleChangeColumns = () => {\n const isCheckSettingColumns = settingColumns.value.filter(\n (item: any, index: number) => {\n item.columnSortIndex = index\n return item.isCheck\n }\n )\n handleColumnsSortByFixed(isCheckSettingColumns, true)\n}\n\nconst handleColumnItemChange = (value: boolean, item: any) => {\n const findSettingIndex = settingColumns.value.findIndex(\n (citem: any) => item.key === citem.key\n )\n\n if (findSettingIndex > -1) {\n settingColumns.value[findSettingIndex].isCheck = value\n handleChangeColumns()\n handleClickSubmitBtn()\n }\n}\n// 全选change\nconst handleAllColumnChange = (e: any) => {\n const checked = e.target.checked\n settingColumns.value.forEach((item: any) => (item.isCheck = checked))\n if (checked) {\n newColumns.value = [...props.columns]\n } else {\n newColumns.value = []\n }\n handleAddSerialNumberAndOperateToColumns()\n handleClickSubmitBtn()\n}\n// 拖拽change\nconst dragChange = () => {\n handleChangeColumns()\n handleClickSubmitBtn()\n}\n// 点击重置按钮\nconst handleClickResetBtn = () => {\n const newcolumns = props.columns.map((item: any, index: number) => ({\n ...item,\n isCheck: true,\n columnSortIndex: index\n }))\n newColumns.value = [...newcolumns]\n handleAddSerialNumberAndOperateToColumns()\n settingColumns.value = [...newcolumns]\n handleClickSubmitBtn()\n}\n// 点击保存按钮\nconst handleClickSubmitBtn = () => {\n if (props.settingKey) {\n localStorage.setItem(props.settingKey, JSON.stringify(settingColumns.value))\n }\n}\n// 处理column左固定和右固定\nconst handleColumnMove = (element: any, way: string) => {\n const fixed = element.fixed\n if (fixed === way) {\n element.fixed = false\n } else {\n element.fixed = way\n }\n handleColumnsSortByFixed(newColumns.value)\n handleClickSubmitBtn()\n}\n</script>\n../config/table\n"],"names":[],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"main-table.vue2.mjs","sources":["../../../../../../packages/components/table/src/components/main-table.vue"],"sourcesContent":["<template>\n <a-table\n :class=\"`${bem.e('main-content')}`\"\n row-key=\"id\"\n v-bind=\"attrs\"\n :columns=\"newColumns\"\n :data-source=\"newDataSource\"\n :expanded-row-keys=\"newExpandedRowKeys\"\n :custom-row=\"props.showDrag ? dragCustomRow : (customRowProps as any)\"\n :pagination=\"false\"\n show-header\n :scroll=\"{\n scrollToFirstRowOnChange: true,\n x: props?.scroll?.x ? props?.scroll?.x : 'max-content',\n y: props?.scroll?.y ? props?.scroll?.y : '100%'\n }\"\n @expand=\"handleExpand\"\n @resize-column=\"handleResizeColumn\"\n @change=\"props.change\"\n @expanded-rows-change=\"props.expandedRowsChange\"\n >\n <!-- 1.表头插槽 -->\n <template #headerCell=\"slots\">\n <template v-if=\"slots.column.key === 'operate' && showSetting\">\n <div :class=\"`${bem.e('operate')}`\">\n <span>{{ slots.column.title }}</span>\n <a-popover\n trigger=\"click\"\n placement=\"bottomRight\"\n :overlay-inner-style=\"{\n padding: '0'\n }\"\n >\n <template #content>\n <div :class=\"`${bem.e('setting-popover')}`\">\n <!-- 头部 -->\n <div :class=\"`${bem.e('setting-popover-header')}`\">\n <a-checkbox\n :indeterminate=\"isIndeterminate\"\n :checked=\"isAllCheck\"\n @change=\"handleAllColumnChange\"\n >\n 列展示\n </a-checkbox>\n <span\n :class=\"`${bem.e('setting-reset-btn')}`\"\n @click=\"handleClickResetBtn\"\n >\n 重置\n </span>\n </div>\n <!-- 内容 -->\n <div :class=\"`${bem.e('setting-popover-content')}`\">\n <div>\n <draggable\n :list=\"settingColumns\"\n item-key=\"key\"\n :group=\"{ name: 'g1' }\"\n @change=\"dragChange\"\n >\n <template #item=\"{ element }\">\n <div :class=\"`${bem.e('setting-popover-menu')}`\">\n <!-- 拖拽 -->\n <div\n :class=\"`flex items-center ${bem.e(\n 'setting-popover-menu-left'\n )}`\"\n >\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n :style=\"{\n marginright: '5px'\n }\"\n >\n <ll-icon\n icon-name=\"icon-move\"\n class-name=\"icon\"\n />\n </a-button>\n <a-checkbox\n :checked=\"element.isCheck\"\n @change=\"\n (e: any) => {\n handleColumnItemChange(\n e.target?.checked!,\n element\n )\n }\n \"\n >\n {{ element.title }}\n </a-checkbox>\n </div>\n <div\n :class=\"`flex items-center ${bem.e(\n 'setting-popover-menu-right'\n )}`\"\n >\n <!-- 左移 -->\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n @click=\"handleColumnMove(element, 'left')\"\n >\n <ll-icon\n icon-name=\"icon-zuoyi\"\n :class-name=\"`icon ${\n element.fixed === 'left'\n ? bem.e('setting-popover-menu-fixed-icon')\n : ''\n }`\"\n />\n </a-button>\n <a-divider type=\"vertical\" />\n <!-- 右移 -->\n <a-button\n type=\"text\"\n :class=\"`${bem.e('setting-popover-menu-icon')}`\"\n @click=\"handleColumnMove(element, 'right')\"\n >\n <ll-icon\n icon-name=\"icon-youyi\"\n :class-name=\"`icon ${\n element.fixed === 'right'\n ? bem.e('setting-popover-menu-fixed-icon')\n : ''\n }`\"\n />\n </a-button>\n </div>\n </div>\n </template>\n </draggable>\n </div>\n </div>\n </div>\n </template>\n <a-button type=\"text\" :class=\"`${bem.e('setting-icon')}`\">\n <ll-icon icon-name=\"icon-set-line\" />\n </a-button>\n </a-popover>\n </div>\n </template>\n <template v-else-if=\"has(slots.column, 'RC_TABLE_INTERNAL_COL_DEFINE')\">\n <slot name=\"expandedTitle\"></slot>\n </template>\n <template v-else>{{ slots.column.title }}</template>\n <!-- 额外header单元格的插槽内容 -->\n <slot name=\"tableHeaderCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- 2.表格内容插槽 -->\n <template #bodyCell=\"slots\">\n <!-- 添加序列列 -->\n <template v-if=\"slots.column.key === '#' && showIndexColumn\">\n {{ slots.index + 1 }}\n </template>\n <!-- 添加操作列 -->\n <template v-else-if=\"slots.column.key === 'operate'\">\n <slot name=\"tableOperate\" v-bind=\"slots\"></slot>\n </template>\n <!-- 额外Body单元格的插槽内容 -->\n <slot name=\"tableBodyCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- 3.空状态自定义插槽 -->\n <template #emptyText>\n <slot name=\"emptyText\">\n <ll-empty>\n <template #content>暂无数据</template>\n </ll-empty>\n </slot>\n </template>\n <!-- 4.表格自定义展开内容插槽 -->\n <template v-if=\"$slots.expandedRow\" #expandedRowRender=\"slots\">\n <slot name=\"expandedRow\" v-bind=\"slots\"> </slot>\n </template>\n <!-- 5.表格自定义列筛选 -->\n <template v-if=\"$slots.customFilterDropdown\" #customFilterDropdown=\"slots\">\n <slot name=\"customFilterDropdown\" v-bind=\"slots\"> </slot>\n </template>\n <!-- 6.表格自定义筛选图标 -->\n <template v-if=\"$slots.customFilterIcon\" #customFilterIcon=\"slots\">\n <slot name=\"customFilterIcon\" v-bind=\"slots\"> </slot>\n </template>\n <!-- 6.表格总结栏 -->\n <template v-if=\"$slots.summary\" #summary=\"slots\">\n <slot name=\"summary\" v-bind=\"slots\"> </slot>\n </template>\n </a-table>\n</template>\n<script lang=\"ts\" setup>\nimport { ref, watch, computed, useAttrs } from 'vue'\n\nimport { createNamespace } from '@ll-plus/utils'\n\nimport draggable from 'vuedraggable'\n\nimport { has } from 'lodash-es'\n\nimport { mainTableProps, mainTableEmits } from '../config'\n\n// 1.defineOptions\ndefineOptions({\n name: 'MainTable'\n})\n\n// 2.props/emits\nconst props = defineProps(mainTableProps)\nconst emits = defineEmits(mainTableEmits)\n\n// 3.hooks\nconst attrs = useAttrs()\n\n// 3.ref/let/const\nconst newColumns: any = ref([]) // 显示在表格的columns\nconst settingColumns: any = ref([])\nconst newDataSource: any = ref([])\nconst newExpandedRowKeys: any = ref([]) //展开的id数组\nlet preIndex = -1 // 源目标数据序号\nlet nextIndex = -1 // 目标数据序号\nconst bem = createNamespace('table')\n\n// 往表格列中添加序号和操作\nconst handleAddSerialNumberAndOperateToColumns = () => {\n if (props.showIndexColumn) {\n newColumns.value.unshift({\n title: '#',\n dataIndex: '#',\n key: '#',\n width: 50,\n fixed: 'left',\n class: 'table-serial-number-cell'\n })\n }\n if (props.showOperate) {\n newColumns.value.push({\n title: '操作',\n dataIndex: '',\n key: 'operate',\n width: 120,\n fixed: 'right',\n class: 'table-serial-operate-cell'\n })\n }\n}\n// 处理表格列的左、右固定排序(letf放最左边,没有定位放中间,右边放right定位)\nconst handleColumnsSortByFixed = (list: any, isDrag?: boolean) => {\n const newList = list\n const leftFixedColumns: any = [],\n normalFixedColumns: any = [],\n rightFixedColumns: any = []\n newList.forEach((item: any) => {\n const fixed = item.fixed\n if (fixed === 'left') {\n leftFixedColumns.push(item)\n } else if (fixed === 'right') {\n rightFixedColumns.push(item)\n } else {\n normalFixedColumns.push(item)\n }\n })\n leftFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n normalFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n rightFixedColumns.sort(\n (a: any, b: any) => a.columnSortIndex - b.columnSortIndex\n )\n newColumns.value = [\n ...leftFixedColumns,\n ...normalFixedColumns,\n ...rightFixedColumns\n ]\n if (isDrag) {\n handleAddSerialNumberAndOperateToColumns()\n }\n}\n\n// 4.watch\nwatch(\n () => props.dataSource,\n (newValue: any) => {\n newDataSource.value = [...newValue]\n },\n {\n deep: true,\n immediate: true\n }\n)\n// 从本地存储中获取columns/没有则用用户传的\nwatch(\n () => [\n props.columns,\n props.settingKey,\n props.showIndexColumn,\n props.showOperate\n ],\n (arr: any) => {\n const [newValue, key] = arr\n let newcolumns = []\n // 有key\n if (key && localStorage.getItem(key)) {\n const localStorageColumns = localStorage.getItem(key)\n if (localStorageColumns) {\n newcolumns = JSON.parse(localStorageColumns)\n }\n } else {\n // 没key\n newcolumns = newValue.map((item: any, index: number) => ({\n ...item,\n isCheck: true,\n columnSortIndex:\n item.columnSortIndex === 0 || item.columnSortIndex\n ? item.columnSortIndex\n : index\n }))\n }\n // 1.过滤掉没有选中的\n newColumns.value = [...newcolumns].filter((item: any) => item.isCheck)\n // 2.如果有设置序列和操作,则添加\n handleAddSerialNumberAndOperateToColumns()\n // 3.根据定位来排序\n handleColumnsSortByFixed(newColumns.value)\n settingColumns.value = [...newcolumns]\n },\n {\n deep: true,\n immediate: true\n }\n)\nwatch(\n () => props.expandedRowKeys,\n (newValue: any) => {\n if (Array.isArray(newValue)) {\n newExpandedRowKeys.value = [...newValue]\n }\n },\n {\n deep: true,\n immediate: true\n }\n)\n// 5.methods\n//重新定义树状展开关闭功能\nconst handleExpand = (expanded: boolean, record: any) => {\n if (expanded) {\n newExpandedRowKeys.value.push(record.id)\n } else {\n const index = newExpandedRowKeys.value.findIndex(\n (e: any) => e === record.id\n )\n newExpandedRowKeys.value.splice(index, 1)\n }\n props.expand && props.expand(expanded, record)\n}\n// 列拖拽\nconst handleResizeColumn = (w: any, col: any) => {\n col.width = w\n props.resizeColumn && props.resizeColumn(w, col)\n}\n// 拖动排序\nconst dragCustomRow = (_: any, index: number) => {\n const normalConfig = {\n props: {\n // draggable: 'true'\n },\n draggable: true,\n style: {\n cursor: 'pointer'\n },\n // 鼠标移入\n onMouseenter: (event: Event) => {\n const target = event.target as HTMLElement\n target.draggable = true // 让你要拖动的行可以拖动,默认不可以\n },\n // 开始拖拽\n onDragstart: (event: Event) => {\n event.stopPropagation()\n preIndex = index\n },\n // 拖动元素经过的元素\n onDragover: (event: Event) => {\n event.preventDefault()\n },\n // 鼠标松开\n onDrop: (event: Event) => {\n let sortSource: any[] = []\n event.stopPropagation()\n // 得到目标数据序号\n nextIndex = index\n const dataSource = newDataSource.value\n // 排序后两个sort互换\n const preItem = { ...dataSource[preIndex] }\n const nextItem = { ...dataSource[nextIndex] }\n const preSort = preItem.sort\n const nextSort = nextItem.sort\n preItem.sort = nextSort\n nextItem.sort = preSort\n\n dataSource[preIndex] = nextItem\n dataSource[nextIndex] = preItem\n sortSource = [...dataSource]\n emits('handleChangeDataSource', sortSource)\n props.dragChange && props.dragChange(sortSource)\n }\n }\n const extraConfig = props.customRowProps\n ? { ...props.customRowProps(_, index) }\n : {}\n return { ...normalConfig, ...extraConfig }\n}\n// 是否全选\nconst isAllCheck = computed(() => {\n return settingColumns.value.every((item: any) => item.isCheck)\n})\n// 是否全选\nconst isIndeterminate = computed(() => {\n const getIsChecks = settingColumns.value.filter((item: any) => item.isCheck)\n return getIsChecks.length === 0\n ? false\n : settingColumns.value.length > getIsChecks.length\n})\n// 单个checkbox的change\nconst handleChangeColumns = () => {\n const isCheckSettingColumns = settingColumns.value.filter(\n (item: any, index: number) => {\n item.columnSortIndex = index\n return item.isCheck\n }\n )\n handleColumnsSortByFixed(isCheckSettingColumns, true)\n}\n\nconst handleColumnItemChange = (value: boolean, item: any) => {\n const findSettingIndex = settingColumns.value.findIndex(\n (citem: any) => item.key === citem.key\n )\n\n if (findSettingIndex > -1) {\n settingColumns.value[findSettingIndex].isCheck = value\n handleChangeColumns()\n handleClickSubmitBtn()\n }\n}\n// 全选change\nconst handleAllColumnChange = (e: any) => {\n const checked = e.target.checked\n settingColumns.value.forEach((item: any) => (item.isCheck = checked))\n if (checked) {\n newColumns.value = [...props.columns]\n } else {\n newColumns.value = []\n }\n handleAddSerialNumberAndOperateToColumns()\n handleClickSubmitBtn()\n}\n// 拖拽change\nconst dragChange = () => {\n handleChangeColumns()\n handleClickSubmitBtn()\n}\n// 点击重置按钮\nconst handleClickResetBtn = () => {\n const newcolumns = props.columns.map((item: any, index: number) => ({\n ...item,\n isCheck: true,\n columnSortIndex: index\n }))\n newColumns.value = [...newcolumns]\n handleAddSerialNumberAndOperateToColumns()\n settingColumns.value = [...newcolumns]\n handleClickSubmitBtn()\n}\n// 点击保存按钮\nconst handleClickSubmitBtn = () => {\n if (props.settingKey) {\n localStorage.setItem(props.settingKey, JSON.stringify(settingColumns.value))\n }\n}\n// 处理column左固定和右固定\nconst handleColumnMove = (element: any, way: string) => {\n const fixed = element.fixed\n if (fixed === way) {\n element.fixed = false\n } else {\n element.fixed = way\n }\n handleColumnsSortByFixed(newColumns.value)\n handleClickSubmitBtn()\n}\n</script>\n../config/table\n"],"names":[],"mappings":"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"}
|
|
@@ -111,9 +111,6 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
111
111
|
emptyText: withCtx(() => [
|
|
112
112
|
renderSlot(_ctx.$slots, "emptyText")
|
|
113
113
|
]),
|
|
114
|
-
customFilterDropdown: withCtx(() => [
|
|
115
|
-
renderSlot(_ctx.$slots, "customFilterDropdown")
|
|
116
|
-
]),
|
|
117
114
|
_: 2
|
|
118
115
|
/* DYNAMIC */
|
|
119
116
|
}, [
|
|
@@ -123,6 +120,27 @@ var _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
123
120
|
renderSlot(_ctx.$slots, "expandedRow", normalizeProps(guardReactiveProps(slots)))
|
|
124
121
|
]),
|
|
125
122
|
key: "0"
|
|
123
|
+
} : void 0,
|
|
124
|
+
_ctx.$slots.customFilterDropdown ? {
|
|
125
|
+
name: "customFilterDropdown",
|
|
126
|
+
fn: withCtx((slots) => [
|
|
127
|
+
renderSlot(_ctx.$slots, "customFilterDropdown", normalizeProps(guardReactiveProps(slots)))
|
|
128
|
+
]),
|
|
129
|
+
key: "1"
|
|
130
|
+
} : void 0,
|
|
131
|
+
_ctx.$slots.customFilterIcon ? {
|
|
132
|
+
name: "customFilterIcon",
|
|
133
|
+
fn: withCtx((slots) => [
|
|
134
|
+
renderSlot(_ctx.$slots, "customFilterIcon", normalizeProps(guardReactiveProps(slots)))
|
|
135
|
+
]),
|
|
136
|
+
key: "2"
|
|
137
|
+
} : void 0,
|
|
138
|
+
_ctx.$slots.summary ? {
|
|
139
|
+
name: "summary",
|
|
140
|
+
fn: withCtx((slots) => [
|
|
141
|
+
renderSlot(_ctx.$slots, "summary", normalizeProps(guardReactiveProps(slots)))
|
|
142
|
+
]),
|
|
143
|
+
key: "3"
|
|
126
144
|
} : void 0
|
|
127
145
|
]),
|
|
128
146
|
1040
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"table.vue2.mjs","sources":["../../../../../packages/components/table/src/table.vue"],"sourcesContent":["<template>\n <a-spin :spinning=\"props.loading\" wrapper-class-name=\"ll-table-spin-wrapper\">\n <div :class=\"bem.b()\">\n <!-- 头部seach -->\n <header-search\n v-bind=\"headerSearchProps\"\n @change=\"handleSwitchMenuChange\"\n >\n <!-- header-slot -->\n <template #header>\n <slot name=\"header\" />\n </template>\n <slot name=\"header\"></slot>\n <!-- left-slot -->\n <template #headerLeft>\n <slot name=\"headerLeft\"></slot>\n </template>\n <!-- middle-slot -->\n <template #headerMiddle>\n <slot name=\"headerMiddle\"></slot>\n </template>\n <!-- right-slot -->\n <template #headerRight>\n <slot name=\"headerRight\"></slot>\n </template>\n </header-search>\n <!-- slot-content table和card默认table -->\n <div\n :class=\"[\n bem.m('fixed-height'),\n !newNaTableptions.dataSource!.length ? bem.m('empty') : ''\n ]\"\n >\n <slot :name=\"contentType\">\n <main-table\n v-bind=\"newNaTableptions\"\n @handle-change-data-source=\"handleChangeDataSource\"\n >\n <!-- tableHeaderCell-slot -->\n <template #tableHeaderCell=\"slots\">\n <slot name=\"tableHeaderCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- tableBodyCell-slot -->\n <template #tableBodyCell=\"slots\">\n <slot name=\"tableBodyCell\" v-bind=\"slots\"></slot>\n </template>\n <!--tableOperate-slot -->\n <template #tableOperate=\"slots\">\n <slot name=\"tableOperate\" v-bind=\"slots\"></slot>\n </template>\n <!-- tableRowExpand-slot -->\n <template v-if=\"$slots.expandedRow\" #expandedRow=\"slots\">\n <slot name=\"expandedRow\" v-bind=\"slots\"></slot>\n </template>\n <!-- expandColumnTitle-slot -->\n <template #expandedTitle>\n <slot name=\"expandedTitle\"> </slot>\n </template>\n <!-- empty-slot -->\n <template #emptyText>\n <slot name=\"emptyText\"></slot>\n </template>\n <!-- customFilterDropdown-slot -->\n <template
|
|
1
|
+
{"version":3,"file":"table.vue2.mjs","sources":["../../../../../packages/components/table/src/table.vue"],"sourcesContent":["<template>\n <a-spin :spinning=\"props.loading\" wrapper-class-name=\"ll-table-spin-wrapper\">\n <div :class=\"bem.b()\">\n <!-- 头部seach -->\n <header-search\n v-bind=\"headerSearchProps\"\n @change=\"handleSwitchMenuChange\"\n >\n <!-- header-slot -->\n <template #header>\n <slot name=\"header\" />\n </template>\n <slot name=\"header\"></slot>\n <!-- left-slot -->\n <template #headerLeft>\n <slot name=\"headerLeft\"></slot>\n </template>\n <!-- middle-slot -->\n <template #headerMiddle>\n <slot name=\"headerMiddle\"></slot>\n </template>\n <!-- right-slot -->\n <template #headerRight>\n <slot name=\"headerRight\"></slot>\n </template>\n </header-search>\n <!-- slot-content table和card默认table -->\n <div\n :class=\"[\n bem.m('fixed-height'),\n !newNaTableptions.dataSource!.length ? bem.m('empty') : ''\n ]\"\n >\n <slot :name=\"contentType\">\n <main-table\n v-bind=\"newNaTableptions\"\n @handle-change-data-source=\"handleChangeDataSource\"\n >\n <!-- tableHeaderCell-slot -->\n <template #tableHeaderCell=\"slots\">\n <slot name=\"tableHeaderCell\" v-bind=\"slots\"></slot>\n </template>\n <!-- tableBodyCell-slot -->\n <template #tableBodyCell=\"slots\">\n <slot name=\"tableBodyCell\" v-bind=\"slots\"></slot>\n </template>\n <!--tableOperate-slot -->\n <template #tableOperate=\"slots\">\n <slot name=\"tableOperate\" v-bind=\"slots\"></slot>\n </template>\n <!-- tableRowExpand-slot -->\n <template v-if=\"$slots.expandedRow\" #expandedRow=\"slots\">\n <slot name=\"expandedRow\" v-bind=\"slots\"></slot>\n </template>\n <!-- expandColumnTitle-slot -->\n <template #expandedTitle>\n <slot name=\"expandedTitle\"> </slot>\n </template>\n <!-- empty-slot -->\n <template #emptyText>\n <slot name=\"emptyText\"></slot>\n </template>\n <!-- customFilterDropdown-slot -->\n <template\n v-if=\"$slots.customFilterDropdown\"\n #customFilterDropdown=\"slots\"\n >\n <slot name=\"customFilterDropdown\" v-bind=\"slots\"></slot>\n </template>\n <!-- customFilterIcon-slot -->\n <template v-if=\"$slots.customFilterIcon\" #customFilterIcon=\"slots\">\n <slot name=\"customFilterIcon\" v-bind=\"slots\"></slot>\n </template>\n <!-- summary-slot -->\n <template v-if=\"$slots.summary\" #summary=\"slots\">\n <slot name=\"summary\" v-bind=\"slots\"></slot>\n </template>\n </main-table>\n </slot>\n </div>\n <!-- 底部分页 -->\n <template\n v-if=\"\n newNaTableptions.dataSource!.length &&\n !newNaTableptions.hiddenPagination\n \"\n >\n <pagination v-bind=\"paginationProps\" />\n </template>\n </div>\n </a-spin>\n</template>\n<script lang=\"ts\" setup>\nimport { ref, watch, provide } from 'vue'\n\nimport { ImenuSwitchType } from './config'\nimport { createNamespace } from '@ll-plus/utils'\n\nimport HeaderSearch from './components/header-search.vue'\nimport MainTable from './components/main-table.vue'\nimport Pagination from './components/pagination.vue'\n\nimport { tableProps } from './config'\n\n// 1.defineOptions\ndefineOptions({ name: 'LlTable' })\n\n// 2.props\nconst props = defineProps(tableProps)\n// 3.ref\n// 表格数据\nconst originDataSource = ref()\nconst newNaTableptions = ref<any>({\n dataSource: [],\n columns: []\n})\n// 菜单切换/内容插槽\nconst contentType = ref(ImenuSwitchType.TABLE) // 菜单切换\nconst bem = createNamespace('table')\n\n// 4.methods\n// 拖拽完成后获取拖拽后的数据\nconst handleChangeDataSource = (dataSource: any[]) => {\n newNaTableptions.value.dataSource = dataSource\n}\n// 切换菜单内容\nconst handleSwitchMenuChange = (v: ImenuSwitchType) => {\n contentType.value = v\n}\n\n// 5.watch\nwatch(\n () => props.tableProps,\n (newValue: any) => {\n if (newValue) {\n newNaTableptions.value = { ...newValue }\n originDataSource.value = [...newValue.dataSource]\n }\n },\n {\n deep: true,\n immediate: true\n }\n)\n// 6.其他\nprovide('contentType', contentType)\n</script>\n"],"names":[],"mappings":";;;;;;;;;;;;;;;;AA4GA,IAAA,MAAM,KAAQ,GAAA,OAAA,CAAA;AAGd,IAAA,MAAM,mBAAmB,GAAI,EAAA,CAAA;AAC7B,IAAA,MAAM,mBAAmB,GAAS,CAAA;AAAA,MAChC,YAAY,EAAC;AAAA,MACb,SAAS,EAAC;AAAA,KACX,CAAA,CAAA;AAED,IAAM,MAAA,WAAA,GAAc,GAAI,CAAA,eAAA,CAAgB,KAAK,CAAA,CAAA;AAC7C,IAAM,MAAA,GAAA,GAAM,gBAAgB,OAAO,CAAA,CAAA;AAInC,IAAM,MAAA,sBAAA,GAAyB,CAAC,UAAsB,KAAA;AACpD,MAAA,gBAAA,CAAiB,MAAM,UAAa,GAAA,UAAA,CAAA;AAAA,KACtC,CAAA;AAEA,IAAM,MAAA,sBAAA,GAAyB,CAAC,CAAuB,KAAA;AACrD,MAAA,WAAA,CAAY,KAAQ,GAAA,CAAA,CAAA;AAAA,KACtB,CAAA;AAGA,IAAA,KAAA;AAAA,MACE,MAAM,KAAM,CAAA,UAAA;AAAA,MACZ,CAAC,QAAkB,KAAA;AACjB,QAAA,IAAI,QAAU,EAAA;AACZ,UAAiB,gBAAA,CAAA,KAAA,GAAQ,EAAE,GAAG,QAAS,EAAA,CAAA;AACvC,UAAA,gBAAA,CAAiB,KAAQ,GAAA,CAAC,GAAG,QAAA,CAAS,UAAU,CAAA,CAAA;AAAA,SAClD;AAAA,OACF;AAAA,MACA;AAAA,QACE,IAAM,EAAA,IAAA;AAAA,QACN,SAAW,EAAA,IAAA;AAAA,OACb;AAAA,KACF,CAAA;AAEA,IAAA,OAAA,CAAQ,eAAe,WAAW,CAAA,CAAA;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;"}
|
package/index.full.js
CHANGED
|
@@ -3385,7 +3385,6 @@
|
|
|
3385
3385
|
const _component_a_col = require$$0.resolveComponent("a-col");
|
|
3386
3386
|
const _component_ll_select = require$$0.resolveComponent("ll-select");
|
|
3387
3387
|
const _component_ll_tooltip = require$$0.resolveComponent("ll-tooltip");
|
|
3388
|
-
const _component_ll_bitton = require$$0.resolveComponent("ll-bitton");
|
|
3389
3388
|
const _component_ll_dropdown = require$$0.resolveComponent("ll-dropdown");
|
|
3390
3389
|
const _component_a_popconfirm = require$$0.resolveComponent("a-popconfirm");
|
|
3391
3390
|
const _component_a_row = require$$0.resolveComponent("a-row");
|
|
@@ -3588,7 +3587,7 @@
|
|
|
3588
3587
|
onClaimSelected: handleClaimSelected
|
|
3589
3588
|
}, {
|
|
3590
3589
|
default: require$$0.withCtx(() => [
|
|
3591
|
-
props.parentData && props.parentData.type === "object" && innerData.value.type === "object" ? (require$$0.openBlock(), require$$0.createBlock(
|
|
3590
|
+
props.parentData && props.parentData.type === "object" && innerData.value.type === "object" ? (require$$0.openBlock(), require$$0.createBlock(_component_ll_button, {
|
|
3592
3591
|
key: 0,
|
|
3593
3592
|
class: require$$0.normalizeClass(require$$0.unref(bem).m("table-icon")),
|
|
3594
3593
|
disabled: require$$0.unref(disabled),
|
|
@@ -55906,7 +55905,6 @@
|
|
|
55906
55905
|
class: require$$0.normalizeClass(`${_ctx.bem.m("item")} ${_ctx.bem.m("item-checkbox")}`)
|
|
55907
55906
|
},
|
|
55908
55907
|
[
|
|
55909
|
-
require$$0.createTextVNode(" > "),
|
|
55910
55908
|
require$$0.createVNode(_component_Radio, require$$0.mergeProps({
|
|
55911
55909
|
value: _ctx.TypeEnum.specify
|
|
55912
55910
|
}, _ctx.beforeRadioAttrs), {
|
|
@@ -58438,7 +58436,7 @@
|
|
|
58438
58436
|
"label-col": {
|
|
58439
58437
|
span: 24
|
|
58440
58438
|
},
|
|
58441
|
-
rules:
|
|
58439
|
+
rules: getKeyType.value.rules || [],
|
|
58442
58440
|
name: "key"
|
|
58443
58441
|
}, {
|
|
58444
58442
|
default: require$$0.withCtx(() => [
|
|
@@ -69305,6 +69303,20 @@
|
|
|
69305
69303
|
require$$0.renderSlot(_ctx.$slots, "customFilterDropdown", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69306
69304
|
]),
|
|
69307
69305
|
key: "1"
|
|
69306
|
+
} : void 0,
|
|
69307
|
+
_ctx.$slots.customFilterIcon ? {
|
|
69308
|
+
name: "customFilterIcon",
|
|
69309
|
+
fn: require$$0.withCtx((slots) => [
|
|
69310
|
+
require$$0.renderSlot(_ctx.$slots, "customFilterIcon", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69311
|
+
]),
|
|
69312
|
+
key: "2"
|
|
69313
|
+
} : void 0,
|
|
69314
|
+
_ctx.$slots.summary ? {
|
|
69315
|
+
name: "summary",
|
|
69316
|
+
fn: require$$0.withCtx((slots) => [
|
|
69317
|
+
require$$0.renderSlot(_ctx.$slots, "summary", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69318
|
+
]),
|
|
69319
|
+
key: "3"
|
|
69308
69320
|
} : void 0
|
|
69309
69321
|
]), 1040, ["class", "columns", "data-source", "expanded-row-keys", "custom-row", "scroll", "onChange", "onExpandedRowsChange"]);
|
|
69310
69322
|
};
|
|
@@ -69444,9 +69456,6 @@
|
|
|
69444
69456
|
emptyText: require$$0.withCtx(() => [
|
|
69445
69457
|
require$$0.renderSlot(_ctx.$slots, "emptyText")
|
|
69446
69458
|
]),
|
|
69447
|
-
customFilterDropdown: require$$0.withCtx(() => [
|
|
69448
|
-
require$$0.renderSlot(_ctx.$slots, "customFilterDropdown")
|
|
69449
|
-
]),
|
|
69450
69459
|
_: 2
|
|
69451
69460
|
/* DYNAMIC */
|
|
69452
69461
|
}, [
|
|
@@ -69456,6 +69465,27 @@
|
|
|
69456
69465
|
require$$0.renderSlot(_ctx.$slots, "expandedRow", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69457
69466
|
]),
|
|
69458
69467
|
key: "0"
|
|
69468
|
+
} : void 0,
|
|
69469
|
+
_ctx.$slots.customFilterDropdown ? {
|
|
69470
|
+
name: "customFilterDropdown",
|
|
69471
|
+
fn: require$$0.withCtx((slots) => [
|
|
69472
|
+
require$$0.renderSlot(_ctx.$slots, "customFilterDropdown", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69473
|
+
]),
|
|
69474
|
+
key: "1"
|
|
69475
|
+
} : void 0,
|
|
69476
|
+
_ctx.$slots.customFilterIcon ? {
|
|
69477
|
+
name: "customFilterIcon",
|
|
69478
|
+
fn: require$$0.withCtx((slots) => [
|
|
69479
|
+
require$$0.renderSlot(_ctx.$slots, "customFilterIcon", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69480
|
+
]),
|
|
69481
|
+
key: "2"
|
|
69482
|
+
} : void 0,
|
|
69483
|
+
_ctx.$slots.summary ? {
|
|
69484
|
+
name: "summary",
|
|
69485
|
+
fn: require$$0.withCtx((slots) => [
|
|
69486
|
+
require$$0.renderSlot(_ctx.$slots, "summary", require$$0.normalizeProps(require$$0.guardReactiveProps(slots)))
|
|
69487
|
+
]),
|
|
69488
|
+
key: "3"
|
|
69459
69489
|
} : void 0
|
|
69460
69490
|
]),
|
|
69461
69491
|
1040
|