el-plus 0.0.18 → 0.0.19
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/CHANGELOG.md +6 -0
- package/dist/index.css +1 -1
- package/dist/index.full.js +227 -104
- package/dist/index.full.min.js +1 -1
- package/dist/index.full.min.js.map +1 -1
- package/dist/index.full.min.mjs +1 -1
- package/dist/index.full.min.mjs.map +1 -1
- package/dist/index.full.mjs +226 -104
- package/es/components/date-picker-range/index.d.ts +3 -3
- package/es/components/date-picker-range/src/date-picker-range.vue.d.ts +1 -1
- package/es/components/form/src/form-item-vue.d.ts +2 -2
- package/es/components/form/src/form-item.d.ts +1 -1
- package/es/components/form/src/form-item.mjs.map +1 -1
- package/es/components/form/src/hooks/use-form-item.mjs +3 -1
- package/es/components/form/src/hooks/use-form-item.mjs.map +1 -1
- package/es/components/index.d.ts +1 -0
- package/es/components/index.mjs +2 -0
- package/es/components/index.mjs.map +1 -1
- package/es/components/input/style/css.d.ts +1 -1
- package/es/components/input/style/css.mjs +1 -1
- package/es/components/input/style/index.d.ts +1 -1
- package/es/components/input/style/index.mjs +1 -1
- package/es/components/link/index.d.ts +118 -0
- package/es/components/link/index.mjs +8 -0
- package/es/components/link/index.mjs.map +1 -0
- package/es/components/link/src/link.d.ts +30 -0
- package/es/components/link/src/link.mjs +19 -0
- package/es/components/link/src/link.mjs.map +1 -0
- package/es/components/link/src/link.vue.d.ts +73 -0
- package/es/components/link/src/link.vue.mjs +6 -0
- package/es/components/link/src/link.vue.mjs.map +1 -0
- package/es/components/link/src/link.vue2.mjs +52 -0
- package/es/components/link/src/link.vue2.mjs.map +1 -0
- package/es/components/link/style/css.d.ts +2 -0
- package/es/components/link/style/css.mjs +5 -0
- package/es/components/link/style/css.mjs.map +1 -0
- package/es/components/link/style/index.d.ts +2 -0
- package/es/components/link/style/index.mjs +5 -0
- package/es/components/link/style/index.mjs.map +1 -0
- package/es/components/search-list-page/index.d.ts +51 -30
- package/es/components/search-list-page/src/search-list-page.d.ts +1 -1
- package/es/components/search-list-page/src/search-list-page.mjs +3 -3
- package/es/components/search-list-page/src/search-list-page.mjs.map +1 -1
- package/es/components/search-list-page/src/search-list-page.vue.d.ts +16 -11
- package/es/components/search-list-page/src/search-list-page.vue2.mjs +4 -3
- package/es/components/search-list-page/src/search-list-page.vue2.mjs.map +1 -1
- package/es/components/search-list-page/src/use-search-list-page.d.ts +15 -9
- package/es/components/search-list-page/src/use-search-list-page.mjs +4 -4
- package/es/components/search-list-page/src/use-search-list-page.mjs.map +1 -1
- package/es/components/table/index.d.ts +11 -6
- package/es/components/table/src/table.d.ts +2 -1
- package/es/components/table/src/table.mjs +2 -2
- package/es/components/table/src/table.mjs.map +1 -1
- package/es/components/table/src/table.vue.d.ts +4 -3
- package/es/components/table/src/table.vue2.mjs +4 -3
- package/es/components/table/src/table.vue2.mjs.map +1 -1
- package/es/components/table/src/use-table.d.ts +71 -12
- package/es/components/table/src/use-table.mjs +84 -27
- package/es/components/table/src/use-table.mjs.map +1 -1
- package/es/components.mjs +3 -1
- package/es/components.mjs.map +1 -1
- package/es/hooks/dialog/use-dialog.d.ts +2 -0
- package/es/hooks/dialog/use-dialog.mjs +4 -3
- package/es/hooks/dialog/use-dialog.mjs.map +1 -1
- package/es/index.mjs +2 -0
- package/es/index.mjs.map +1 -1
- package/es/package.json.mjs +1 -1
- package/es/utils/file.d.ts +18 -0
- package/es/utils/file.mjs +133 -0
- package/es/utils/file.mjs.map +1 -0
- package/es/utils/http/core/types.d.ts +1 -0
- package/global.d.ts +6 -4
- package/lib/components/date-picker-range/index.d.ts +3 -3
- package/lib/components/date-picker-range/src/date-picker-range.vue.d.ts +1 -1
- package/lib/components/form/src/form-item-vue.d.ts +2 -2
- package/lib/components/form/src/form-item.d.ts +1 -1
- package/lib/components/form/src/form-item.js.map +1 -1
- package/lib/components/form/src/hooks/use-form-item.js +3 -1
- package/lib/components/form/src/hooks/use-form-item.js.map +1 -1
- package/lib/components/index.d.ts +1 -0
- package/lib/components/index.js +4 -0
- package/lib/components/index.js.map +1 -1
- package/lib/components/input/style/css.d.ts +1 -1
- package/lib/components/input/style/css.js +1 -1
- package/lib/components/input/style/index.d.ts +1 -1
- package/lib/components/input/style/index.js +1 -1
- package/lib/components/link/index.d.ts +118 -0
- package/lib/components/link/index.js +14 -0
- package/lib/components/link/index.js.map +1 -0
- package/lib/components/link/src/link.d.ts +30 -0
- package/lib/components/link/src/link.js +21 -0
- package/lib/components/link/src/link.js.map +1 -0
- package/lib/components/link/src/link.vue.d.ts +73 -0
- package/lib/components/link/src/link.vue.js +10 -0
- package/lib/components/link/src/link.vue.js.map +1 -0
- package/lib/components/link/src/link.vue2.js +56 -0
- package/lib/components/link/src/link.vue2.js.map +1 -0
- package/lib/components/link/style/css.d.ts +2 -0
- package/lib/components/link/style/css.js +7 -0
- package/lib/components/link/style/css.js.map +1 -0
- package/lib/components/link/style/index.d.ts +2 -0
- package/lib/components/link/style/index.js +7 -0
- package/lib/components/link/style/index.js.map +1 -0
- package/lib/components/search-list-page/index.d.ts +51 -30
- package/lib/components/search-list-page/src/search-list-page.d.ts +1 -1
- package/lib/components/search-list-page/src/search-list-page.js +3 -3
- package/lib/components/search-list-page/src/search-list-page.js.map +1 -1
- package/lib/components/search-list-page/src/search-list-page.vue.d.ts +16 -11
- package/lib/components/search-list-page/src/search-list-page.vue2.js +3 -2
- package/lib/components/search-list-page/src/search-list-page.vue2.js.map +1 -1
- package/lib/components/search-list-page/src/use-search-list-page.d.ts +15 -9
- package/lib/components/search-list-page/src/use-search-list-page.js +4 -4
- package/lib/components/search-list-page/src/use-search-list-page.js.map +1 -1
- package/lib/components/table/index.d.ts +11 -6
- package/lib/components/table/src/table.d.ts +2 -1
- package/lib/components/table/src/table.js +2 -2
- package/lib/components/table/src/table.js.map +1 -1
- package/lib/components/table/src/table.vue.d.ts +4 -3
- package/lib/components/table/src/table.vue2.js +4 -3
- package/lib/components/table/src/table.vue2.js.map +1 -1
- package/lib/components/table/src/use-table.d.ts +71 -12
- package/lib/components/table/src/use-table.js +83 -26
- package/lib/components/table/src/use-table.js.map +1 -1
- package/lib/components.js +3 -1
- package/lib/components.js.map +1 -1
- package/lib/hooks/dialog/use-dialog.d.ts +2 -0
- package/lib/hooks/dialog/use-dialog.js +4 -3
- package/lib/hooks/dialog/use-dialog.js.map +1 -1
- package/lib/index.js +10 -6
- package/lib/index.js.map +1 -1
- package/lib/package.json.js +1 -1
- package/lib/utils/file.d.ts +18 -0
- package/lib/utils/file.js +136 -0
- package/lib/utils/file.js.map +1 -0
- package/lib/utils/http/core/types.d.ts +1 -0
- package/package.json +1 -1
- package/theme-chalk/custom-column.css +1 -1
- package/theme-chalk/index.css +1 -1
- package/theme-chalk/link.css +1 -0
- package/theme-chalk/src/custom-column.scss +6 -4
- package/theme-chalk/src/index.scss +2 -1
- package/theme-chalk/src/link.scss +6 -0
- package/theme-chalk/src/table.scss +20 -1
- package/theme-chalk/table.css +1 -1
|
@@ -130,25 +130,83 @@ export declare const useTableColumn: (props: TableProps, tableData: Ref<TablePro
|
|
|
130
130
|
disabled?: boolean | ((scope: TableScope) => boolean) | undefined;
|
|
131
131
|
props?: Record<string, any> | undefined;
|
|
132
132
|
filter?: boolean | undefined;
|
|
133
|
+
editable?: boolean | ((formData: Record<string, any>) => void) | undefined;
|
|
133
134
|
show?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
134
135
|
hide?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
135
136
|
};
|
|
136
|
-
columnList: import("vue").ComputedRef<
|
|
137
|
-
[
|
|
138
|
-
|
|
139
|
-
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
137
|
+
columnList: import("vue").ComputedRef<{
|
|
138
|
+
[x: string]: any;
|
|
139
|
+
id?: string | undefined;
|
|
140
|
+
realWidth?: number | null | undefined;
|
|
141
|
+
type?: string | undefined;
|
|
142
|
+
label?: string | undefined;
|
|
143
|
+
className?: string | undefined;
|
|
144
|
+
labelClassName?: string | undefined;
|
|
145
|
+
property?: string | undefined;
|
|
146
|
+
prop?: string | undefined;
|
|
147
|
+
width?: string | number | undefined;
|
|
148
|
+
minWidth?: string | number | undefined;
|
|
149
|
+
renderHeader?: ((data: {
|
|
150
|
+
column: import("element-plus").TableColumnCtx<import("element-plus/es/components/table/src/table/defaults").DefaultRow>;
|
|
151
|
+
$index: number;
|
|
152
|
+
store: import("element-plus/es/components/table/src/store").Store<import("element-plus/es/components/table/src/table/defaults").DefaultRow>;
|
|
153
|
+
_self: any;
|
|
154
|
+
}) => import("vue").VNode) | undefined;
|
|
155
|
+
sortable?: string | boolean | undefined;
|
|
156
|
+
sortMethod?: ((a: import("element-plus/es/components/table/src/table/defaults").DefaultRow, b: import("element-plus/es/components/table/src/table/defaults").DefaultRow) => number) | undefined;
|
|
157
|
+
sortBy?: string | string[] | ((row: import("element-plus/es/components/table/src/table/defaults").DefaultRow, index: number, array?: import("element-plus/es/components/table/src/table/defaults").DefaultRow[] | undefined) => string) | undefined;
|
|
158
|
+
resizable?: boolean | undefined;
|
|
159
|
+
columnKey?: string | undefined;
|
|
160
|
+
rawColumnKey?: string | undefined;
|
|
161
|
+
align?: string | undefined;
|
|
162
|
+
headerAlign?: string | undefined;
|
|
163
|
+
showOverflowTooltip?: (boolean | import("element-plus/es/components/table/src/util").TableOverflowTooltipOptions) | undefined;
|
|
164
|
+
tooltipFormatter?: import("element-plus/es/components/table/src/util").TableOverflowTooltipFormatter<import("element-plus/es/components/table/src/table/defaults").DefaultRow> | undefined;
|
|
165
|
+
fixed?: string | boolean | undefined;
|
|
166
|
+
formatter?: ((row: import("element-plus/es/components/table/src/table/defaults").DefaultRow, column: import("element-plus").TableColumnCtx<import("element-plus/es/components/table/src/table/defaults").DefaultRow>, cellValue: any, index: number) => import("vue").VNode | string) | undefined;
|
|
167
|
+
selectable?: ((row: import("element-plus/es/components/table/src/table/defaults").DefaultRow, index: number) => boolean) | undefined;
|
|
168
|
+
reserveSelection?: boolean | undefined;
|
|
169
|
+
filterMethod?: import("element-plus/es/components/table/src/table-column/defaults").FilterMethods<import("element-plus/es/components/table/src/table/defaults").DefaultRow> | undefined;
|
|
170
|
+
filteredValue?: string[] | undefined;
|
|
171
|
+
filters?: import("element-plus/es/components/table/src/table-column/defaults").Filters | undefined;
|
|
172
|
+
filterPlacement?: string | undefined;
|
|
173
|
+
filterMultiple?: boolean | undefined;
|
|
174
|
+
filterClassName?: string | undefined;
|
|
175
|
+
index?: number | ((index: number) => number) | undefined;
|
|
176
|
+
sortOrders?: (import("element-plus/es/components/table/src/table/defaults").TableSortOrder | null)[] | undefined;
|
|
177
|
+
renderCell?: ((data: any) => import("vue").VNode | import("vue").VNode[]) | undefined;
|
|
178
|
+
colSpan?: number | undefined;
|
|
179
|
+
rowSpan?: number | undefined;
|
|
180
|
+
children?: import("element-plus").TableColumnCtx<import("element-plus/es/components/table/src/table/defaults").DefaultRow>[] | undefined;
|
|
181
|
+
level?: number | undefined;
|
|
182
|
+
filterable?: boolean | import("element-plus/es/components/table/src/table-column/defaults").FilterMethods<import("element-plus/es/components/table/src/table/defaults").DefaultRow> | import("element-plus/es/components/table/src/table-column/defaults").Filters | undefined;
|
|
183
|
+
order?: import("element-plus/es/components/table/src/table/defaults").TableSortOrder | null | undefined;
|
|
184
|
+
isColumnGroup?: boolean | undefined;
|
|
185
|
+
isSubColumn?: boolean | undefined;
|
|
186
|
+
columns?: import("element-plus").TableColumnCtx<import("element-plus/es/components/table/src/table/defaults").DefaultRow>[] | undefined;
|
|
187
|
+
getColumnIndex?: (() => number) | undefined;
|
|
188
|
+
no?: number | undefined;
|
|
189
|
+
filterOpened?: boolean | undefined;
|
|
190
|
+
renderFilterIcon?: ((scope: any) => import("vue").VNode) | undefined;
|
|
191
|
+
renderExpand?: ((scope: any) => import("vue").VNode) | undefined;
|
|
192
|
+
required?: boolean | (() => boolean) | undefined;
|
|
193
|
+
cellRequired?: ((scope: TableScope) => boolean) | undefined;
|
|
194
|
+
headerRender?: ((data: {
|
|
195
|
+
column: import("element-plus").TableColumnCtx<import("element-plus/es/components/table/src/table/defaults").DefaultRow>;
|
|
196
|
+
$index: number;
|
|
197
|
+
store: import("element-plus/es/components/table/src/store").Store<import("element-plus/es/components/table/src/table/defaults").DefaultRow>;
|
|
198
|
+
_self: any;
|
|
199
|
+
}) => import("vue").VNode) | undefined;
|
|
200
|
+
disabled?: boolean | ((scope: TableScope) => boolean) | undefined;
|
|
201
|
+
props?: Record<string, any> | undefined;
|
|
202
|
+
filter?: boolean | undefined;
|
|
203
|
+
editable?: boolean | ((formData: Record<string, any>) => void) | undefined;
|
|
146
204
|
show?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
147
205
|
hide?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
148
|
-
}
|
|
206
|
+
}[]>;
|
|
149
207
|
};
|
|
150
208
|
export declare const useTableFormItem: (props: TableProps) => {
|
|
151
|
-
formItemProps: (scope: TableScope,
|
|
209
|
+
formItemProps: (scope: TableScope, rawItem: TableColumn) => {
|
|
152
210
|
isShowLabel: boolean;
|
|
153
211
|
required: boolean | undefined;
|
|
154
212
|
hideRequiredAsterisk: boolean | undefined;
|
|
@@ -218,6 +276,7 @@ export declare const useTableFormItem: (props: TableProps) => {
|
|
|
218
276
|
}) => import("vue").VNode) | undefined;
|
|
219
277
|
disabled?: boolean | ((scope: TableScope) => boolean) | undefined;
|
|
220
278
|
filter?: boolean | undefined;
|
|
279
|
+
editable?: boolean | ((formData: Record<string, any>) => void) | undefined;
|
|
221
280
|
show?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
222
281
|
hide?: (boolean | ((T: unknown) => boolean)) | undefined;
|
|
223
282
|
};
|
|
@@ -1,6 +1,10 @@
|
|
|
1
|
-
import { useTemplateRef, ref, computed, reactive, createVNode, createTextVNode } from 'vue';
|
|
1
|
+
import { useTemplateRef, ref, useAttrs, getCurrentInstance, computed, reactive, createVNode, createTextVNode, toRaw } from 'vue';
|
|
2
2
|
import { useRequest } from '../../../hooks/use-request.mjs';
|
|
3
3
|
import { prepareProps } from '../../../utils/props.mjs';
|
|
4
|
+
import { cloneDeep } from 'lodash-unified';
|
|
5
|
+
import { EditPen } from '@element-plus/icons-vue';
|
|
6
|
+
import { ElIcon } from 'element-plus';
|
|
7
|
+
import { useFormDialog } from '../../../hooks/dialog/use-form-dialog.mjs';
|
|
4
8
|
import { bus } from '../../../utils/mitt.mjs';
|
|
5
9
|
|
|
6
10
|
const useTable = (props) => {
|
|
@@ -38,7 +42,12 @@ const useTable = (props) => {
|
|
|
38
42
|
}
|
|
39
43
|
});
|
|
40
44
|
const customColumns = ref([]);
|
|
45
|
+
const attrs = useAttrs();
|
|
41
46
|
const search = async (init = false, isPagination = false) => {
|
|
47
|
+
const beforeSearch = attrs["before-search"];
|
|
48
|
+
if (typeof beforeSearch === "function") {
|
|
49
|
+
await beforeSearch?.();
|
|
50
|
+
}
|
|
42
51
|
if (init) {
|
|
43
52
|
pagination.pageNo = 1;
|
|
44
53
|
}
|
|
@@ -72,6 +81,7 @@ const useTable = (props) => {
|
|
|
72
81
|
if (props.customColumnModule) {
|
|
73
82
|
loading.value = true;
|
|
74
83
|
const columns = await bus.once("loadedCustomColumn");
|
|
84
|
+
loading.value = false;
|
|
75
85
|
customColumns.value = columns;
|
|
76
86
|
bus.on("loadedCustomColumn", (columns2) => {
|
|
77
87
|
customColumns.value = columns2;
|
|
@@ -143,6 +153,7 @@ const usePagination = function(props, search) {
|
|
|
143
153
|
};
|
|
144
154
|
};
|
|
145
155
|
const useTableColumn = (props, tableData, customColumns) => {
|
|
156
|
+
const instance = getCurrentInstance();
|
|
146
157
|
const columnProps = (column) => {
|
|
147
158
|
const attrs = {
|
|
148
159
|
"show-overflow-tooltip": true,
|
|
@@ -155,16 +166,50 @@ const useTableColumn = (props, tableData, customColumns) => {
|
|
|
155
166
|
if (typeof column.required === "function") {
|
|
156
167
|
required = column.required();
|
|
157
168
|
}
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
"
|
|
165
|
-
},
|
|
166
|
-
|
|
167
|
-
|
|
169
|
+
const editable = column.editable;
|
|
170
|
+
attrs["renderHeader"] = () => {
|
|
171
|
+
return createVNode("span", null, [required ? createVNode("span", {
|
|
172
|
+
"style": "color:var(--el-color-danger)"
|
|
173
|
+
}, [createTextVNode(" * ")]) : "", createVNode("span", {
|
|
174
|
+
"class": {
|
|
175
|
+
"is-edit": editable
|
|
176
|
+
},
|
|
177
|
+
"onClick": editable ? async () => {
|
|
178
|
+
const cloneColumn = {
|
|
179
|
+
...column
|
|
180
|
+
};
|
|
181
|
+
delete cloneColumn.editable;
|
|
182
|
+
const rawRender = cloneColumn.render;
|
|
183
|
+
const formData = reactive({});
|
|
184
|
+
if (rawRender) {
|
|
185
|
+
cloneColumn.render = () => {
|
|
186
|
+
return rawRender({
|
|
187
|
+
row: formData
|
|
188
|
+
});
|
|
189
|
+
};
|
|
190
|
+
}
|
|
191
|
+
const formDialog = useFormDialog({
|
|
192
|
+
title: cloneColumn.label,
|
|
193
|
+
dialogProps: {
|
|
194
|
+
destroyOnClose: true,
|
|
195
|
+
instance
|
|
196
|
+
},
|
|
197
|
+
formItemList: [cloneColumn],
|
|
198
|
+
formData
|
|
199
|
+
// formData: reactive({}),
|
|
200
|
+
});
|
|
201
|
+
const data = await formDialog.open();
|
|
202
|
+
(tableData.value || []).forEach((item) => {
|
|
203
|
+
item[column.prop] = data[column.prop];
|
|
204
|
+
});
|
|
205
|
+
if (typeof editable === "function") {
|
|
206
|
+
editable(toRaw(data));
|
|
207
|
+
}
|
|
208
|
+
} : void 0
|
|
209
|
+
}, [column.label, editable ? createVNode(ElIcon, null, {
|
|
210
|
+
default: () => [createVNode(EditPen, null, null)]
|
|
211
|
+
}) : ""])]);
|
|
212
|
+
};
|
|
168
213
|
}
|
|
169
214
|
if (column.filter) {
|
|
170
215
|
const arr = tableData.value.map((item) => item[column.prop]);
|
|
@@ -178,29 +223,31 @@ const useTableColumn = (props, tableData, customColumns) => {
|
|
|
178
223
|
return row[column.prop] === value;
|
|
179
224
|
};
|
|
180
225
|
}
|
|
226
|
+
if (column.type === "EpLink") {
|
|
227
|
+
attrs.className = "table-column-link";
|
|
228
|
+
}
|
|
181
229
|
return {
|
|
182
230
|
...attrs,
|
|
183
231
|
...prepareProps(column)
|
|
184
232
|
};
|
|
185
233
|
};
|
|
186
234
|
const columnList = computed(() => {
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
|
|
190
|
-
|
|
191
|
-
|
|
192
|
-
if (props.
|
|
193
|
-
const
|
|
194
|
-
if (
|
|
195
|
-
|
|
196
|
-
|
|
197
|
-
|
|
198
|
-
list: [linkColumn],
|
|
199
|
-
type: "text",
|
|
200
|
-
...column.props
|
|
235
|
+
const columns = props.customColumnModule ? customColumns.value : props.columns;
|
|
236
|
+
return columns.map((column) => {
|
|
237
|
+
let newColumn = {
|
|
238
|
+
...column
|
|
239
|
+
};
|
|
240
|
+
if (props.formatColumns.length) {
|
|
241
|
+
const formatColumn = props.formatColumns.find((item) => item.prop === column.prop);
|
|
242
|
+
if (formatColumn) {
|
|
243
|
+
newColumn = {
|
|
244
|
+
...newColumn,
|
|
245
|
+
...formatColumn
|
|
201
246
|
};
|
|
202
247
|
}
|
|
203
248
|
}
|
|
249
|
+
return newColumn;
|
|
250
|
+
}).filter((column) => {
|
|
204
251
|
if ("show" in column) {
|
|
205
252
|
return typeof column.show === "function" ? column.show(column) : column.show;
|
|
206
253
|
} else if ("hide" in column) {
|
|
@@ -215,7 +262,8 @@ const useTableColumn = (props, tableData, customColumns) => {
|
|
|
215
262
|
};
|
|
216
263
|
};
|
|
217
264
|
const useTableFormItem = (props) => {
|
|
218
|
-
const formItemProps = (scope,
|
|
265
|
+
const formItemProps = (scope, rawItem) => {
|
|
266
|
+
const item = cloneDeep(rawItem);
|
|
219
267
|
let required = item.required;
|
|
220
268
|
if (typeof required === "function") {
|
|
221
269
|
required = required();
|
|
@@ -250,10 +298,19 @@ const useTableFormItem = (props) => {
|
|
|
250
298
|
}
|
|
251
299
|
});
|
|
252
300
|
}
|
|
301
|
+
if (item.type === "EpLink") {
|
|
302
|
+
(item.props ? item.props : item.props = {}).content = item.props.content || scope.row[item.prop];
|
|
303
|
+
}
|
|
253
304
|
for (const key in item) {
|
|
254
305
|
if (key.startsWith("on") && typeof item[key] === "function") {
|
|
255
306
|
const fn = item[key];
|
|
256
|
-
item[key] = (...args) =>
|
|
307
|
+
item[key] = (...args) => {
|
|
308
|
+
let event;
|
|
309
|
+
if (args[0] instanceof Event) {
|
|
310
|
+
event = args.shift();
|
|
311
|
+
}
|
|
312
|
+
return fn(...args, scope, event);
|
|
313
|
+
};
|
|
257
314
|
}
|
|
258
315
|
}
|
|
259
316
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-table.mjs","sources":["../../../../../../packages/components/table/src/use-table.tsx"],"sourcesContent":["import type { FormInstance, TableInstance, FormItemProp } from 'element-plus'\nimport { ref, computed, type Ref, reactive, useTemplateRef } from 'vue'\nimport { useRequest } from '@el-plus/hooks/use-request'\nimport type { TableColumn, TableProps, TableScope } from './table'\nimport type { ButtonProps } from '@el-plus/components/buttons'\nimport { bus } from '@el-plus/utils'\nimport {\n prepareProps,\n prepareEvents,\n prepareClassNames,\n prepareStyles,\n} from '@el-plus/utils/props'\nexport type ISearch = (init: boolean, isPagination?: boolean) => void\nexport const useTable = (props: TableProps) => {\n const elFormRef = useTemplateRef<FormInstance>('elFormRef')\n const elTableRef = useTemplateRef<TableInstance>('elTableRef')\n const customData = ref<Record<string, unknown>[]>([])\n const { loading, requestFn } = useRequest({\n api: props.api,\n method: props.method,\n reqData: props.reqData,\n reqParams: props.reqParams,\n reqBefore: props.reqBefore,\n reqAfter: props.reqAfter,\n cancelToken: true,\n hooks: {\n success(data) {\n if (Array.isArray(data)) {\n customData.value = data\n } else if (data && typeof data === 'object') {\n const rawData = data as Record<string, any>\n customData.value = rawData?.list || rawData?.data || []\n } else {\n customData.value = []\n }\n if (props.showPagination) {\n pagination.total =\n (props.isFrontPage\n ? customData.value.length\n : (data as { total: number }).total) || 0\n }\n },\n fail(error) {\n console.error(error)\n },\n },\n })\n // 自定义列\n const customColumns = ref<TableColumn[]>([])\n // 加载列表\n const search: ISearch = async (init = false, isPagination = false) => {\n if (init) {\n pagination.pageNo = 1\n }\n // 前端分页\n if (isPagination && props.isFrontPage) {\n const { pageNo, pageSize } = pagination\n const data = customData.value.filter((item, index) => {\n return index < pageNo * pageSize && index >= (pageNo - 1) * pageSize\n })\n customData.value = data\n } else {\n if (props.api) {\n requestFn!({\n pageNo: pagination.pageNo,\n pageSize: pagination.pageSize,\n pageNum: pagination.pageNo,\n })\n } else if (props.data?.length) {\n customData.value = props.data\n }\n }\n }\n const { pagination, paginationProps } = usePagination(props, search)\n ;(async () => {\n if (props.isInitSearch) {\n if (props.customColumnModule) {\n loading!.value = true\n const columns = await bus.once('loadedCustomColumn')\n customColumns.value = columns\n bus.on('loadedCustomColumn', (columns: TableColumn[]) => {\n customColumns.value = columns\n })\n }\n search(true)\n }\n })()\n\n // 校验\n const validate = () => {\n return elFormRef.value!.validate()\n }\n // 重置校验\n const resetFields = (props: FormItemProp) => {\n return elFormRef.value!.resetFields(props)\n }\n // 清理某个字段的表单验证信息\n const clearValidate = (props: FormItemProp) => {\n return elFormRef.value!.clearValidate(props)\n }\n // 格式化操作按钮\n const formatActionButtons = (list: ButtonProps[], scope: TableScope) => {\n return list.map((item) => {\n if (item.onClick) {\n item.onClick = item.onClick.bind(null, scope)\n }\n return item\n })\n }\n\n return {\n loading,\n data: customData,\n search,\n pagination,\n paginationProps,\n validate,\n resetFields,\n clearValidate,\n elFormRef,\n elTableRef,\n formatActionButtons,\n customColumns: customColumns as unknown as Ref<TableColumn[]>,\n }\n}\nconst usePagination = function (props: TableProps, search: ISearch) {\n const pageSizes = [20, 50, 100, 200]\n const pagination = reactive({\n total: 0,\n pageNo: 1,\n pageSize: pageSizes[0],\n })\n const paginationProps = computed(() => {\n const defaultPaginationProps = props.paginationProps || {}\n const onSizeChange = defaultPaginationProps.onSizeChange\n const onCurrentChange = defaultPaginationProps.onCurrentChange\n return {\n ...defaultPaginationProps,\n pageSizes,\n layout: 'total, sizes, prev, pager, next, jumper',\n onSizeChange: (value: number) => {\n onSizeChange && onSizeChange(value)\n search(true, true)\n },\n onCurrentChange: (value: number) => {\n onCurrentChange && onCurrentChange(value)\n search(false, true)\n },\n }\n })\n return {\n pagination,\n paginationProps,\n }\n}\n\nexport const useTableColumn = (\n props: TableProps,\n tableData: Ref<TableProps['data']>,\n customColumns: Ref<TableColumn[]>,\n) => {\n const columnProps = (column: TableColumn) => {\n const attrs = {\n 'show-overflow-tooltip': true,\n align: column.align || props.align,\n minWidth: column.minWidth || props.minWidth,\n // ...prepareEvents<TableEmits>(emit, tableEmits),\n } as TableColumn\n if (!column.renderHeader) {\n let required = column.required\n if (typeof column.required === 'function') {\n required = column.required()\n }\n if (required) {\n attrs['renderHeader'] = (data) => {\n const { column } = data\n return (\n <span>\n <span style=\"color:var(--el-color-danger)\"> * </span>\n {column.label}\n </span>\n )\n }\n }\n }\n if (column.filter) {\n const arr = tableData.value!.map((item) => item[column.prop!])\n attrs.filters = [...new Set(arr)].map((item) => {\n return {\n text: item,\n value: item,\n }\n })\n attrs.filterMethod = (value, row) => {\n return row[column.prop!] === value\n }\n }\n return {\n ...attrs,\n ...prepareProps(column),\n }\n }\n const columnList = computed(() => {\n let columns = props.columns\n if (props.customColumnModule) {\n columns = customColumns.value\n }\n return columns!.filter((column: TableColumn) => {\n if (props.linkProps!.length) {\n const linkColumn = props.linkProps!.find(\n (item) => item.prop === column.prop,\n )\n if (linkColumn) {\n column.type = 'EpButtons'\n column.className = 'table-column-link'\n column.props = {\n list: [linkColumn],\n type: 'text',\n ...column.props,\n }\n }\n }\n if ('show' in column) {\n return typeof column.show === 'function'\n ? column.show(column)\n : column.show\n } else if ('hide' in column) {\n return typeof column.hide === 'function'\n ? !column.hide(column)\n : !column.hide\n }\n return true\n })\n })\n return {\n columnProps,\n columnList,\n }\n}\n\nexport const useTableFormItem = (props: TableProps) => {\n const formItemProps = (scope: TableScope, item: TableColumn) => {\n let required = item.required\n if (typeof required === 'function') {\n required = required()\n }\n if (item.cellRequired) {\n required = item.cellRequired(scope)\n }\n let disabled = props.disabled\n if ('disabled' in item) {\n if (typeof item.disabled === 'function') {\n disabled = item.disabled(scope)\n } else {\n disabled = item.disabled || false\n }\n }\n if (item.type === 'EpSelect' && item.props) {\n if ('options' in item.props && typeof item.props.options === 'function') {\n item.props.options = item.props.options(scope)\n }\n if (\n 'disabledOption' in item.props &&\n typeof item.props.disabledOption === 'function'\n ) {\n const disabledOption = item.props.disabledOption\n item.props.disabledOption = (...args: unknown[]) =>\n disabledOption(...args, scope)\n }\n }\n\n if (item.type === 'EpButtons' && item.props) {\n item.props.list.forEach((btnItem: ButtonProps) => {\n if (btnItem.prop) {\n btnItem.name = scope.row[btnItem.prop] as string\n }\n if (btnItem.onClick) {\n btnItem.onClick = btnItem.onClick.bind(null, scope)\n }\n })\n }\n for (const key in item) {\n if (key.startsWith('on') && typeof item[key] === 'function') {\n const fn = item[key]\n item[key] = (...args: unknown[]) => fn(...args, scope)\n }\n }\n return {\n ...prepareProps(item),\n isShowLabel: false,\n required,\n hideRequiredAsterisk: 'cellRequired' in item ? false : required,\n prop: `table.${scope.$index}.${item.prop}`,\n tableProp: item.prop, // table里的表单需要绑定的prop\n props: {\n ...item.props,\n disabled,\n },\n }\n }\n return {\n formItemProps,\n }\n}\n"],"names":["useTable","props","elFormRef","useTemplateRef","elTableRef","customData","ref","loading","requestFn","useRequest","api","method","reqData","reqParams","reqBefore","reqAfter","cancelToken","hooks","success","data","Array","isArray","value","rawData","list","showPagination","pagination","total","isFrontPage","length","fail","error","console","customColumns","search","init","isPagination","pageNo","pageSize","filter","item","index","pageNum","paginationProps","usePagination","isInitSearch","customColumnModule","columns","bus","once","on","validate","resetFields","clearValidate","formatActionButtons","scope","map","onClick","bind","pageSizes","reactive","computed","defaultPaginationProps","onSizeChange","onCurrentChange","layout","useTableColumn","tableData","columnProps","column","attrs","align","minWidth","renderHeader","required","_createVNode","_createTextVNode","label","arr","prop","filters","Set","text","filterMethod","row","prepareProps","columnList","linkProps","linkColumn","find","type","className","show","hide","useTableFormItem","formItemProps","cellRequired","disabled","options","disabledOption","args","forEach","btnItem","name","key","startsWith","fn","isShowLabel","hideRequiredAsterisk","$index","tableProp"],"mappings":"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"}
|
|
1
|
+
{"version":3,"file":"use-table.mjs","sources":["../../../../../../packages/components/table/src/use-table.tsx"],"sourcesContent":["import type { FormInstance, TableInstance, FormItemProp } from 'element-plus'\nimport {\n ref,\n computed,\n type Ref,\n reactive,\n useTemplateRef,\n getCurrentInstance,\n toRaw,\n useAttrs,\n} from 'vue'\nimport { useRequest } from '@el-plus/hooks/use-request'\nimport type { TableColumn, TableProps, TableScope } from './table'\nimport type { ButtonProps } from '@el-plus/components/buttons'\nimport type { FormProps } from '@el-plus/components/form'\nimport { bus } from '@el-plus/utils'\nimport {\n prepareProps,\n prepareEvents,\n prepareClassNames,\n prepareStyles,\n} from '@el-plus/utils/props'\nimport { cloneDeep } from 'lodash-unified'\nimport { EditPen } from '@element-plus/icons-vue'\nimport { ElIcon } from 'element-plus'\nimport { useFormDialog } from '@el-plus/hooks/dialog/use-form-dialog'\n\nexport type ISearch = (init: boolean, isPagination?: boolean) => void\nexport const useTable = (props: TableProps) => {\n const elFormRef = useTemplateRef<FormInstance>('elFormRef')\n const elTableRef = useTemplateRef<TableInstance>('elTableRef')\n const customData = ref<Record<string, unknown>[]>([])\n const { loading, requestFn } = useRequest({\n api: props.api,\n method: props.method,\n reqData: props.reqData,\n reqParams: props.reqParams,\n reqBefore: props.reqBefore,\n reqAfter: props.reqAfter,\n cancelToken: true,\n hooks: {\n success(data) {\n if (Array.isArray(data)) {\n customData.value = data\n } else if (data && typeof data === 'object') {\n const rawData = data as Record<string, any>\n customData.value = rawData?.list || rawData?.data || []\n } else {\n customData.value = []\n }\n if (props.showPagination) {\n pagination.total =\n (props.isFrontPage\n ? customData.value.length\n : (data as { total: number }).total) || 0\n }\n },\n fail(error) {\n console.error(error)\n },\n },\n })\n // 自定义列\n const customColumns = ref<TableColumn[]>([])\n // 加载列表\n const attrs = useAttrs()\n const search: ISearch = async (init = false, isPagination = false) => {\n const beforeSearch = attrs['before-search']\n if (typeof beforeSearch === 'function') {\n await beforeSearch?.()\n }\n if (init) {\n pagination.pageNo = 1\n }\n // 前端分页\n if (isPagination && props.isFrontPage) {\n const { pageNo, pageSize } = pagination\n const data = customData.value.filter((item, index) => {\n return index < pageNo * pageSize && index >= (pageNo - 1) * pageSize\n })\n customData.value = data\n } else {\n if (props.api) {\n requestFn!({\n pageNo: pagination.pageNo,\n pageSize: pagination.pageSize,\n pageNum: pagination.pageNo,\n })\n } else if (props.data?.length) {\n customData.value = props.data\n }\n }\n }\n const { pagination, paginationProps } = usePagination(props, search)\n\n // 初始化加载\n ;(async () => {\n if (props.isInitSearch) {\n if (props.customColumnModule) {\n loading!.value = true\n const columns = await bus.once('loadedCustomColumn')\n loading!.value = false\n customColumns.value = columns\n bus.on('loadedCustomColumn', (columns: TableColumn[]) => {\n customColumns.value = columns\n })\n }\n search(true)\n }\n })()\n\n // 校验\n const validate = () => {\n return elFormRef.value!.validate()\n }\n // 重置校验\n const resetFields = (props: FormItemProp) => {\n return elFormRef.value!.resetFields(props)\n }\n // 清理某个字段的表单验证信息\n const clearValidate = (props: FormItemProp) => {\n return elFormRef.value!.clearValidate(props)\n }\n // 格式化操作按钮\n const formatActionButtons = (list: ButtonProps[], scope: TableScope) => {\n return list.map((item) => {\n if (item.onClick) {\n item.onClick = item.onClick.bind(null, scope)\n }\n return item\n })\n }\n\n return {\n loading,\n data: customData,\n search,\n pagination,\n paginationProps,\n validate,\n resetFields,\n clearValidate,\n elFormRef,\n elTableRef,\n formatActionButtons,\n customColumns: customColumns as unknown as Ref<TableColumn[]>,\n }\n}\nconst usePagination = function (props: TableProps, search: ISearch) {\n const pageSizes = [20, 50, 100, 200]\n const pagination = reactive({\n total: 0,\n pageNo: 1,\n pageSize: pageSizes[0],\n })\n const paginationProps = computed(() => {\n const defaultPaginationProps = props.paginationProps || {}\n const onSizeChange = defaultPaginationProps.onSizeChange\n const onCurrentChange = defaultPaginationProps.onCurrentChange\n return {\n ...defaultPaginationProps,\n pageSizes,\n layout: 'total, sizes, prev, pager, next, jumper',\n onSizeChange: (value: number) => {\n onSizeChange && onSizeChange(value)\n search(true, true)\n },\n onCurrentChange: (value: number) => {\n onCurrentChange && onCurrentChange(value)\n search(false, true)\n },\n }\n })\n return {\n pagination,\n paginationProps,\n }\n}\n\nexport const useTableColumn = (\n props: TableProps,\n tableData: Ref<TableProps['data']>,\n customColumns: Ref<TableColumn[]>,\n) => {\n const instance = getCurrentInstance()\n const columnProps = (column: TableColumn) => {\n const attrs = {\n 'show-overflow-tooltip': true,\n align: column.align || props.align,\n minWidth: column.minWidth || props.minWidth,\n // ...prepareEvents<TableEmits>(emit, tableEmits),\n } as TableColumn\n if (!column.renderHeader) {\n // 必填\n let required = column.required\n if (typeof column.required === 'function') {\n required = column.required()\n }\n // 批量编辑\n const editable = column.editable\n attrs['renderHeader'] = () => {\n return (\n <span>\n {required ? (\n <span style=\"color:var(--el-color-danger)\"> * </span>\n ) : (\n ''\n )}\n <span\n class={{ 'is-edit': editable }}\n onClick={\n editable\n ? async () => {\n const cloneColumn = { ...column }\n delete cloneColumn.editable\n const rawRender = cloneColumn.render\n const formData = reactive({})\n if (rawRender) {\n cloneColumn.render = () => {\n return rawRender({\n row: formData,\n })\n }\n }\n const formDialog = useFormDialog({\n title: cloneColumn.label,\n dialogProps: {\n destroyOnClose: true,\n instance,\n },\n formItemList: [\n cloneColumn,\n ] as FormProps['formItemList'],\n formData,\n // formData: reactive({}),\n })\n const data = (await formDialog.open()) as Record<\n string,\n any\n >\n ;(tableData.value || []).forEach((item) => {\n item[column.prop!] = data![column.prop!]\n })\n if (typeof editable === 'function') {\n editable(toRaw(data))\n }\n }\n : void 0\n }\n >\n {column.label}\n {editable ? (\n <ElIcon>\n <EditPen />\n </ElIcon>\n ) : (\n ''\n )}\n </span>\n </span>\n )\n }\n }\n if (column.filter) {\n const arr = tableData.value!.map((item) => item[column.prop!])\n attrs.filters = [...new Set(arr)].map((item) => {\n return {\n text: item,\n value: item,\n }\n })\n attrs.filterMethod = (value, row) => {\n return row[column.prop!] === value\n }\n }\n if (column.type === 'EpLink') {\n attrs.className = 'table-column-link'\n }\n\n return {\n ...attrs,\n ...prepareProps(column),\n }\n }\n const columnList = computed(() => {\n const columns = props.customColumnModule\n ? customColumns.value\n : props.columns\n return columns!\n .map((column: TableColumn) => {\n let newColumn = { ...column }\n if (props.formatColumns!.length) {\n const formatColumn = props.formatColumns!.find(\n (item) => item.prop === column.prop,\n )\n if (formatColumn) {\n newColumn = { ...newColumn, ...formatColumn }\n }\n }\n return newColumn\n })\n .filter((column) => {\n if ('show' in column) {\n return typeof column.show === 'function'\n ? column.show(column)\n : column.show\n } else if ('hide' in column) {\n return typeof column.hide === 'function'\n ? !column.hide(column)\n : !column.hide\n }\n return true\n })\n })\n return {\n columnProps,\n columnList,\n }\n}\n\nexport const useTableFormItem = (props: TableProps) => {\n const formItemProps = (scope: TableScope, rawItem: TableColumn) => {\n const item = cloneDeep(rawItem)\n let required = item.required\n if (typeof required === 'function') {\n required = required()\n }\n if (item.cellRequired) {\n required = item.cellRequired(scope)\n }\n let disabled = props.disabled\n if ('disabled' in item) {\n if (typeof item.disabled === 'function') {\n disabled = item.disabled(scope)\n } else {\n disabled = item.disabled || false\n }\n }\n if (item.type === 'EpSelect' && item.props) {\n if ('options' in item.props && typeof item.props.options === 'function') {\n item.props.options = item.props.options(scope)\n }\n if (\n 'disabledOption' in item.props &&\n typeof item.props.disabledOption === 'function'\n ) {\n const disabledOption = item.props.disabledOption\n item.props.disabledOption = (...args: unknown[]) =>\n disabledOption(...args, scope)\n }\n }\n\n if (item.type === 'EpButtons' && item.props) {\n item.props.list.forEach((btnItem: ButtonProps) => {\n if (btnItem.prop) {\n btnItem.name = scope.row[btnItem.prop] as string\n }\n if (btnItem.onClick) {\n btnItem.onClick = btnItem.onClick.bind(null, scope)\n }\n })\n }\n if (item.type === 'EpLink') {\n ;(item.props ? item.props : (item.props = {})).content =\n item.props.content || scope.row[item.prop!]\n }\n for (const key in item) {\n if (key.startsWith('on') && typeof item[key] === 'function') {\n const fn = item[key]\n item[key] = (...args: unknown[]) => {\n let event: Event | unknown\n if (args[0] instanceof Event) {\n // 删除 event\n event = args.shift()\n }\n return fn(...args, scope, event)\n }\n }\n }\n return {\n ...prepareProps(item),\n isShowLabel: false,\n required,\n hideRequiredAsterisk: 'cellRequired' in item ? false : required,\n prop: `table.${scope.$index}.${item.prop}`,\n tableProp: item.prop, // table里的表单需要绑定的prop\n props: {\n ...item.props,\n disabled,\n },\n }\n }\n return {\n formItemProps,\n }\n}\n"],"names":["useTable","props","elFormRef","useTemplateRef","elTableRef","customData","ref","loading","requestFn","useRequest","api","method","reqData","reqParams","reqBefore","reqAfter","cancelToken","hooks","success","data","Array","isArray","value","rawData","list","showPagination","pagination","total","isFrontPage","length","fail","error","console","customColumns","attrs","useAttrs","search","init","isPagination","beforeSearch","pageNo","pageSize","filter","item","index","pageNum","paginationProps","usePagination","isInitSearch","customColumnModule","columns","bus","once","on","validate","resetFields","clearValidate","formatActionButtons","scope","map","onClick","bind","pageSizes","reactive","computed","defaultPaginationProps","onSizeChange","onCurrentChange","layout","useTableColumn","tableData","instance","getCurrentInstance","columnProps","column","align","minWidth","renderHeader","required","editable","_createVNode","_createTextVNode","cloneColumn","rawRender","render","formData","row","formDialog","useFormDialog","title","label","dialogProps","destroyOnClose","formItemList","open","forEach","prop","toRaw","ElIcon","default","EditPen","arr","filters","Set","text","filterMethod","type","className","prepareProps","columnList","newColumn","formatColumns","formatColumn","find","show","hide","useTableFormItem","formItemProps","rawItem","cloneDeep","cellRequired","disabled","options","disabledOption","args","btnItem","name","content","key","startsWith","fn","event","Event","shift","isShowLabel","hideRequiredAsterisk","$index","tableProp"],"mappings":"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"}
|
package/es/components.mjs
CHANGED
|
@@ -8,6 +8,7 @@ import { EpTitle } from './components/title/index.mjs';
|
|
|
8
8
|
import { EpHeader } from './components/header/index.mjs';
|
|
9
9
|
import { EpDatePickerRange } from './components/date-picker-range/index.mjs';
|
|
10
10
|
import { EpCustomColumn } from './components/custom-column/index.mjs';
|
|
11
|
+
import { EpLink } from './components/link/index.mjs';
|
|
11
12
|
|
|
12
13
|
var components = [
|
|
13
14
|
EpButtons,
|
|
@@ -19,7 +20,8 @@ var components = [
|
|
|
19
20
|
EpTitle,
|
|
20
21
|
EpHeader,
|
|
21
22
|
EpDatePickerRange,
|
|
22
|
-
EpCustomColumn
|
|
23
|
+
EpCustomColumn,
|
|
24
|
+
EpLink
|
|
23
25
|
];
|
|
24
26
|
|
|
25
27
|
export { components as default };
|
package/es/components.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"components.mjs","sources":["../../../packages/el-plus/components.ts"],"sourcesContent":["import type { Plugin } from 'vue'\nimport Buttons from '@el-plus/components/buttons'\nimport Form from '@el-plus/components/form'\nimport Input from '@el-plus/components/input'\nimport SearchListPage from '@el-plus/components/search-list-page'\nimport Select from '@el-plus/components/select'\nimport Table from '@el-plus/components/table'\nimport Title from '@el-plus/components/title'\nimport Header from '@el-plus/components/header'\nimport DatePickerRange from '@el-plus/components/date-picker-range'\nimport CustomColumn from '@el-plus/components/custom-column'\n\nexport default [\n Buttons,\n Form,\n Input,\n SearchListPage,\n Select,\n Table,\n Title,\n Header,\n DatePickerRange,\n CustomColumn,\n] as Plugin[]\n"],"names":["Buttons","Form","Input","SearchListPage","Select","Table","Title","Header","DatePickerRange","CustomColumn"],"mappings":"
|
|
1
|
+
{"version":3,"file":"components.mjs","sources":["../../../packages/el-plus/components.ts"],"sourcesContent":["import type { Plugin } from 'vue'\nimport Buttons from '@el-plus/components/buttons'\nimport Form from '@el-plus/components/form'\nimport Input from '@el-plus/components/input'\nimport SearchListPage from '@el-plus/components/search-list-page'\nimport Select from '@el-plus/components/select'\nimport Table from '@el-plus/components/table'\nimport Title from '@el-plus/components/title'\nimport Header from '@el-plus/components/header'\nimport DatePickerRange from '@el-plus/components/date-picker-range'\nimport CustomColumn from '@el-plus/components/custom-column'\nimport Link from '@el-plus/components/link'\n\nexport default [\n Buttons,\n Form,\n Input,\n SearchListPage,\n Select,\n Table,\n Title,\n Header,\n DatePickerRange,\n CustomColumn,\n Link,\n] as Plugin[]\n"],"names":["Buttons","Form","Input","SearchListPage","Select","Table","Title","Header","DatePickerRange","CustomColumn","Link"],"mappings":";;;;;;;;;;;;AAaA,iBAAe;AAAA,EACbA,SAAA;AAAA,EACAC,MAAA;AAAA,EACAC,OAAA;AAAA,EACAC,gBAAA;AAAA,EACAC,QAAA;AAAA,EACAC,OAAA;AAAA,EACAC,OAAA;AAAA,EACAC,QAAA;AAAA,EACAC,iBAAA;AAAA,EACAC,cAAA;AAAA,EACAC;AACF,CAAA;;;;"}
|
|
@@ -1,6 +1,8 @@
|
|
|
1
|
+
import type { ComponentInternalInstance } from 'vue';
|
|
1
2
|
import type { VNode } from 'vue';
|
|
2
3
|
import type { DialogProps } from 'element-plus';
|
|
3
4
|
export type DialogOptions = Partial<DialogProps & {
|
|
5
|
+
instance: ComponentInternalInstance | null;
|
|
4
6
|
render: (props: any) => VNode;
|
|
5
7
|
scopedSlots: Record<string, (props: any) => VNode>;
|
|
6
8
|
class: string;
|
|
@@ -15,6 +15,7 @@ const useDialog = (options = {}) => {
|
|
|
15
15
|
} = useLocale();
|
|
16
16
|
const {
|
|
17
17
|
scopedSlots = {},
|
|
18
|
+
instance,
|
|
18
19
|
render: render$1,
|
|
19
20
|
destroyOnClose,
|
|
20
21
|
onConfirm,
|
|
@@ -90,10 +91,10 @@ const useDialog = (options = {}) => {
|
|
|
90
91
|
});
|
|
91
92
|
if (render$1) {
|
|
92
93
|
const container = document.createElement("div");
|
|
93
|
-
const
|
|
94
|
+
const newInstance = instance || getCurrentInstance();
|
|
94
95
|
const vnode = h(Dialog);
|
|
95
|
-
if (
|
|
96
|
-
vnode.appContext =
|
|
96
|
+
if (newInstance && newInstance.appContext) {
|
|
97
|
+
vnode.appContext = newInstance.appContext;
|
|
97
98
|
}
|
|
98
99
|
render(vnode, container);
|
|
99
100
|
document.body.appendChild(container);
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"use-dialog.mjs","sources":["../../../../../packages/hooks/dialog/use-dialog.tsx"],"sourcesContent":["import { useTemplatePromise } from '../use-template-promise'\nimport {\n h,\n getCurrentInstance,\n render as vRender,\n markRaw,\n ref,\n useTemplateRef,\n} from 'vue'\nimport { ElDialog, ElButton } from 'element-plus'\nimport type { VNode } from 'vue'\nimport type { DialogProps } from 'element-plus'\nimport { createNameSpace } from '@el-plus/utils/bem'\nimport EpForm from '@el-plus/components/form'\nimport type { FormProps } from '@el-plus/components/form'\nimport {\n prepareProps,\n prepareEvents,\n prepareClassNames,\n prepareStyles,\n} from '@el-plus/utils/props'\nimport { useLocale } from '../use-locale'\n\nexport type DialogOptions = Partial<\n DialogProps & {\n render: (props) => VNode\n scopedSlots: Record<string, (props) => VNode>\n class: string\n onCancel: (reject) => void\n onConfirm: (resolve) => void\n showFooter: boolean\n }\n>\nexport type ExpandDialogOptions = {\n title?: string\n dialogProps?: DialogOptions\n}\nconst bem = createNameSpace('dialog')\n\nexport const useDialog = (options: DialogOptions = {}) => {\n const { t } = useLocale()\n const {\n scopedSlots = {},\n render,\n destroyOnClose,\n onConfirm,\n onCancel,\n showFooter = true,\n ...dialogProps\n } = options\n\n const Dialog = useTemplatePromise({\n destroy: destroyOnClose,\n render: (promiseOptions, ctx) => {\n // 插槽参数增加promiseOptions\n for (const key in scopedSlots) {\n scopedSlots[key] = scopedSlots[key].bind(null, promiseOptions)\n }\n const { resolve, reject, isResolving } = promiseOptions\n const renderFunc = () => {\n return render\n ? render(promiseOptions)\n : ctx.slots.default?.(promiseOptions)\n }\n const slots: DialogOptions['scopedSlots'] = {}\n if (showFooter) {\n slots.footer = () => (\n <div class={bem.e('footer')}>\n {scopedSlots.footerPrepend?.(promiseOptions)}\n <ElButton\n size=\"default\"\n onClick={() => {\n if (onCancel) {\n onCancel(reject)\n } else {\n reject('cancel')\n }\n }}\n >\n {t('ep.dialog.cancel')}\n </ElButton>\n {scopedSlots.footerInner?.(promiseOptions)}\n <ElButton\n type=\"primary\"\n onClick={async () => {\n if (onConfirm) {\n onConfirm(resolve)\n } else {\n resolve('confirm')\n }\n }}\n loading={isResolving}\n >\n {t('ep.dialog.confirm')}\n </ElButton>\n {scopedSlots.footerAppend?.(promiseOptions)}\n </div>\n )\n }\n return (\n <ElDialog\n class={bem.b()}\n modelValue={true}\n {...{\n closeOnClickModal: false,\n closeOnPressEscape: false,\n title: t('ep.dialog.title'),\n center: false,\n // 'append-to-body': true,\n beforeClose: () => {\n reject('cancel')\n },\n ...prepareProps(dialogProps, ['modelValue']),\n }}\n v-slots={{\n ...slots,\n ...scopedSlots,\n }}\n >\n {renderFunc()}\n </ElDialog>\n )\n },\n })\n if (render) {\n // const app = createApp(component)\n // Object.assign(app._context, parentInstance.appContext)\n // app.mount(container)\n const container = document.createElement('div')\n // container.setAttribute('id', 'ep-dialog-container')\n const
|
|
1
|
+
{"version":3,"file":"use-dialog.mjs","sources":["../../../../../packages/hooks/dialog/use-dialog.tsx"],"sourcesContent":["import { useTemplatePromise } from '../use-template-promise'\nimport {\n h,\n getCurrentInstance,\n render as vRender,\n markRaw,\n ref,\n useTemplateRef,\n} from 'vue'\nimport type { ComponentInternalInstance } from 'vue'\nimport { ElDialog, ElButton } from 'element-plus'\nimport type { AppContext, VNode } from 'vue'\nimport type { DialogProps } from 'element-plus'\nimport { createNameSpace } from '@el-plus/utils/bem'\nimport EpForm from '@el-plus/components/form'\nimport type { FormProps } from '@el-plus/components/form'\nimport {\n prepareProps,\n prepareEvents,\n prepareClassNames,\n prepareStyles,\n} from '@el-plus/utils/props'\nimport { useLocale } from '../use-locale'\n\nexport type DialogOptions = Partial<\n DialogProps & {\n instance: ComponentInternalInstance | null\n render: (props) => VNode\n scopedSlots: Record<string, (props) => VNode>\n class: string\n onCancel: (reject) => void\n onConfirm: (resolve) => void\n showFooter: boolean\n }\n>\nexport type ExpandDialogOptions = {\n title?: string\n dialogProps?: DialogOptions\n}\nconst bem = createNameSpace('dialog')\n\nexport const useDialog = (options: DialogOptions = {}) => {\n const { t } = useLocale()\n const {\n scopedSlots = {},\n instance,\n render,\n destroyOnClose,\n onConfirm,\n onCancel,\n showFooter = true,\n ...dialogProps\n } = options\n\n const Dialog = useTemplatePromise({\n destroy: destroyOnClose,\n render: (promiseOptions, ctx) => {\n // 插槽参数增加promiseOptions\n for (const key in scopedSlots) {\n scopedSlots[key] = scopedSlots[key].bind(null, promiseOptions)\n }\n const { resolve, reject, isResolving } = promiseOptions\n const renderFunc = () => {\n return render\n ? render(promiseOptions)\n : ctx.slots.default?.(promiseOptions)\n }\n const slots: DialogOptions['scopedSlots'] = {}\n if (showFooter) {\n slots.footer = () => (\n <div class={bem.e('footer')}>\n {scopedSlots.footerPrepend?.(promiseOptions)}\n <ElButton\n size=\"default\"\n onClick={() => {\n if (onCancel) {\n onCancel(reject)\n } else {\n reject('cancel')\n }\n }}\n >\n {t('ep.dialog.cancel')}\n </ElButton>\n {scopedSlots.footerInner?.(promiseOptions)}\n <ElButton\n type=\"primary\"\n onClick={async () => {\n if (onConfirm) {\n onConfirm(resolve)\n } else {\n resolve('confirm')\n }\n }}\n loading={isResolving}\n >\n {t('ep.dialog.confirm')}\n </ElButton>\n {scopedSlots.footerAppend?.(promiseOptions)}\n </div>\n )\n }\n return (\n <ElDialog\n class={bem.b()}\n modelValue={true}\n {...{\n closeOnClickModal: false,\n closeOnPressEscape: false,\n title: t('ep.dialog.title'),\n center: false,\n // 'append-to-body': true,\n beforeClose: () => {\n reject('cancel')\n },\n ...prepareProps(dialogProps, ['modelValue']),\n }}\n v-slots={{\n ...slots,\n ...scopedSlots,\n }}\n >\n {renderFunc()}\n </ElDialog>\n )\n },\n })\n if (render) {\n // const app = createApp(component)\n // Object.assign(app._context, parentInstance.appContext)\n // app.mount(container)\n const container = document.createElement('div')\n // container.setAttribute('id', 'ep-dialog-container')\n const newInstance = instance || getCurrentInstance()\n const vnode = h(Dialog)\n if (newInstance && newInstance.appContext) {\n // 强制继承父应用的全局组件、指令和插件\n vnode.appContext = newInstance.appContext\n }\n vRender(vnode, container)\n document.body.appendChild(container)\n }\n\n return Dialog\n}\n"],"names":["_isSlot","s","Object","prototype","toString","call","_isVNode","bem","createNameSpace","useDialog","options","t","useLocale","scopedSlots","instance","render","destroyOnClose","onConfirm","onCancel","showFooter","dialogProps","Dialog","useTemplatePromise","destroy","promiseOptions","ctx","key","bind","resolve","reject","isResolving","renderFunc","slots","default","footer","_slot","_slot2","_createVNode","e","footerPrepend","ElButton","onClick","footerInner","footerAppend","ElDialog","_mergeProps","b","closeOnClickModal","closeOnPressEscape","title","center","beforeClose","prepareProps","container","document","createElement","newInstance","getCurrentInstance","vnode","h","appContext","vRender","body","appendChild"],"mappings":"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"}
|
package/es/index.mjs
CHANGED
|
@@ -25,6 +25,8 @@ export { datePickerRangeEmits, datePickerRangeProps } from './components/date-pi
|
|
|
25
25
|
export { EpDatePickerRange } from './components/date-picker-range/index.mjs';
|
|
26
26
|
export { customColumnEmits, customColumnProps } from './components/custom-column/src/custom-column.mjs';
|
|
27
27
|
export { EpCustomColumn } from './components/custom-column/index.mjs';
|
|
28
|
+
export { linkProps } from './components/link/src/link.mjs';
|
|
29
|
+
export { EpLink } from './components/link/index.mjs';
|
|
28
30
|
export { useRequest } from './hooks/use-request.mjs';
|
|
29
31
|
export { useTemplatePromise } from './hooks/use-template-promise.mjs';
|
|
30
32
|
export { useDialog } from './hooks/dialog/use-dialog.mjs';
|
package/es/index.mjs.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.mjs","sources":["../../../packages/el-plus/index.ts"],"sourcesContent":["import type { App, Plugin } from 'vue'\nimport components from './components'\nimport { version } from './package.json'\nimport * as plugins from './plugins'\n// import type { RouteRecordRaw } from 'vue-router'\n\nconst INSTALLED_KEY = Symbol('INSTALLED_KEY')\nconst provideGlobalConfig = (config, app) => {}\nexport type EpOptions = {\n // routes?: RouteRecordRaw\n}\nexport const install = (app: App, options?: EpOptions) => {\n if (app[INSTALLED_KEY]) return // 防止多次use导致重复安装注册,控制台警告\n app[INSTALLED_KEY] = true\n components.forEach((c) => app.use(c))\n Object.values(plugins).forEach((p) => app.use(p))\n if (options) {\n provideGlobalConfig(options, app)\n }\n}\n\nconst plugin: Plugin & { version: string } = {\n install,\n version,\n}\nexport default plugin\nexport * from '@el-plus/components/index'\nexport * from '@el-plus/hooks'\nexport * from '@el-plus/directives'\n"],"names":["plugins"],"mappings":"
|
|
1
|
+
{"version":3,"file":"index.mjs","sources":["../../../packages/el-plus/index.ts"],"sourcesContent":["import type { App, Plugin } from 'vue'\nimport components from './components'\nimport { version } from './package.json'\nimport * as plugins from './plugins'\n// import type { RouteRecordRaw } from 'vue-router'\n\nconst INSTALLED_KEY = Symbol('INSTALLED_KEY')\nconst provideGlobalConfig = (config, app) => {}\nexport type EpOptions = {\n // routes?: RouteRecordRaw\n}\nexport const install = (app: App, options?: EpOptions) => {\n if (app[INSTALLED_KEY]) return // 防止多次use导致重复安装注册,控制台警告\n app[INSTALLED_KEY] = true\n components.forEach((c) => app.use(c))\n Object.values(plugins).forEach((p) => app.use(p))\n if (options) {\n provideGlobalConfig(options, app)\n }\n}\n\nconst plugin: Plugin & { version: string } = {\n install,\n version,\n}\nexport default plugin\nexport * from '@el-plus/components/index'\nexport * from '@el-plus/hooks'\nexport * from '@el-plus/directives'\n"],"names":["plugins"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAMA,MAAM,aAAA,0BAAuB,eAAe,CAAA;AAKrC,MAAM,OAAA,GAAU,CAAC,GAAA,EAAU,OAAA,KAAwB;AACxD,EAAA,IAAI,GAAA,CAAI,aAAa,CAAA,EAAG;AACxB,EAAA,GAAA,CAAI,aAAa,CAAA,GAAI,IAAA;AACrB,EAAA,UAAA,CAAW,QAAQ,CAAC,CAAA,KAAM,GAAA,CAAI,GAAA,CAAI,CAAC,CAAC,CAAA;AACpC,EAAA,MAAA,CAAO,MAAA,CAAOA,KAAO,CAAA,CAAE,OAAA,CAAQ,CAAC,CAAA,KAAM,GAAA,CAAI,GAAA,CAAI,CAAC,CAAC,CAAA;AAIlD;AAEA,MAAM,MAAA,GAAuC;AAAA,EAC3C,OAAA;AAAA,EACA;AACF;;;;"}
|
package/es/package.json.mjs
CHANGED
|
@@ -0,0 +1,18 @@
|
|
|
1
|
+
export declare function downloadFile({ api, blob, data, src, fileName, config, }: {
|
|
2
|
+
api?: string;
|
|
3
|
+
blob?: boolean;
|
|
4
|
+
data?: Record<string, any>;
|
|
5
|
+
src?: string;
|
|
6
|
+
fileName?: string;
|
|
7
|
+
config?: Record<string, any>;
|
|
8
|
+
}): Promise<void>;
|
|
9
|
+
interface ImportFileOptions {
|
|
10
|
+
accept?: string;
|
|
11
|
+
multiple?: boolean;
|
|
12
|
+
fieldName?: string;
|
|
13
|
+
api?: string;
|
|
14
|
+
failedFileName?: string;
|
|
15
|
+
extraData?: Record<string, any>;
|
|
16
|
+
}
|
|
17
|
+
export declare const importFile: ({ accept, multiple, fieldName, failedFileName, extraData, api, }: ImportFileOptions) => Promise<unknown>;
|
|
18
|
+
export {};
|