eco-vue-js 0.10.5 → 0.10.7

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.
Files changed (96) hide show
  1. package/dist/components/Button/WButtonDropdown.vue.d.ts +1 -1
  2. package/dist/components/Button/WButtonDropdown.vue.d.ts.map +1 -1
  3. package/dist/components/Button/WButtonDropdown.vue.js +1 -12
  4. package/dist/components/Button/WButtonSelection.vue.d.ts +6 -5
  5. package/dist/components/Button/WButtonSelection.vue.d.ts.map +1 -1
  6. package/dist/components/Button/WButtonSelection.vue.js +10 -24
  7. package/dist/components/Checkbox/WCheckbox.vue.d.ts +0 -2
  8. package/dist/components/Checkbox/WCheckbox.vue.d.ts.map +1 -1
  9. package/dist/components/Checkbox/WCheckbox.vue.js +2 -8
  10. package/dist/components/FieldWrapper/WFieldWrapper.vue.js +1 -14
  11. package/dist/components/Form/WForm.vue.d.ts +2 -2
  12. package/dist/components/Form/WFormValidator.vue.d.ts +2 -2
  13. package/dist/components/Form/WFormValidator.vue.js +1 -14
  14. package/dist/components/Form/models/utils.js +0 -14
  15. package/dist/components/FormAsync/use/useFormAsync.d.ts.map +1 -1
  16. package/dist/components/FormAsync/use/useFormAsync.js +2 -14
  17. package/dist/components/HeaderBar/WHeaderBar.vue.js +2 -2
  18. package/dist/components/InfiniteList/WInfiniteList.vue.d.ts +3 -18
  19. package/dist/components/InfiniteList/WInfiniteList.vue.d.ts.map +1 -1
  20. package/dist/components/InfiniteList/WInfiniteList.vue.js +25 -83
  21. package/dist/components/InfiniteList/WInfiniteListWrapper.vue.js +1 -1
  22. package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts +0 -5
  23. package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts.map +1 -1
  24. package/dist/components/InfiniteList/components/InfiniteListPage.vue.js +8 -27
  25. package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts +1 -8
  26. package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts.map +1 -1
  27. package/dist/components/InfiniteList/components/InfiniteListPages.vue.js +10 -21
  28. package/dist/components/InfiniteList/use/useInfiniteListHeader.js +0 -13
  29. package/dist/components/Input/WInputSuggest.vue.js +3 -3
  30. package/dist/components/List/WList.vue.d.ts +3 -2
  31. package/dist/components/List/WList.vue.d.ts.map +1 -1
  32. package/dist/components/List/WList.vue.js +99 -112
  33. package/dist/components/List/WListCard.vue.d.ts +13 -11
  34. package/dist/components/List/WListCard.vue.d.ts.map +1 -1
  35. package/dist/components/List/WListCard.vue.js +79 -87
  36. package/dist/components/List/WListHeaderItem.vue.d.ts.map +1 -1
  37. package/dist/components/List/WListHeaderItem.vue.js +1 -1
  38. package/dist/components/List/components/HeaderSettings.vue.d.ts +3 -2
  39. package/dist/components/List/components/HeaderSettings.vue.d.ts.map +1 -1
  40. package/dist/components/List/components/HeaderSettings.vue.js +20 -24
  41. package/dist/components/List/components/HeaderSort.vue.d.ts +1 -1
  42. package/dist/components/List/components/HeaderSort.vue.d.ts.map +1 -1
  43. package/dist/components/List/components/HeaderSort.vue.js +0 -13
  44. package/dist/components/List/components/ListCardAction.vue.d.ts +23 -0
  45. package/dist/components/List/components/ListCardAction.vue.d.ts.map +1 -0
  46. package/dist/components/List/components/ListCardAction.vue.js +23 -0
  47. package/dist/components/List/components/ListCardAction.vue2.js +5 -0
  48. package/dist/components/List/types.d.ts +5 -0
  49. package/dist/components/List/types.d.ts.map +1 -1
  50. package/dist/components/List/use/useListConfig.d.ts +3 -10
  51. package/dist/components/List/use/useListConfig.d.ts.map +1 -1
  52. package/dist/components/List/use/useListConfig.js +20 -16
  53. package/dist/components/Modal/WModalStepper.vue.d.ts +26 -26
  54. package/dist/components/Nav/WNavItemExpand.vue.js +0 -13
  55. package/dist/components/Select/WSelect.vue.d.ts.map +1 -1
  56. package/dist/components/Select/WSelect.vue.js +2 -2
  57. package/dist/components/Select/WSelectAsync.vue.d.ts.map +1 -1
  58. package/dist/components/Select/WSelectAsync.vue.js +2 -2
  59. package/dist/components/Select/WSelectAsyncList.vue.d.ts +1 -1
  60. package/dist/components/Select/WSelectAsyncList.vue.d.ts.map +1 -1
  61. package/dist/components/Select/WSelectAsyncList.vue.js +0 -1
  62. package/dist/components/Select/components/SelectAsyncList.vue.d.ts.map +1 -1
  63. package/dist/components/Select/components/SelectAsyncList.vue.js +15 -11
  64. package/dist/components/Tabs/WTabs.vue.d.ts +24 -24
  65. package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
  66. package/dist/components/Tabs/WTabs.vue.js +4 -17
  67. package/dist/components/Tabs/WTabsColumns.vue.js +2 -2
  68. package/dist/components/Tabs/components/TabItem.vue.d.ts +12 -12
  69. package/dist/main.js +2 -2
  70. package/dist/types/global.d.ts +0 -11
  71. package/dist/utils/mobile.d.ts +3 -0
  72. package/dist/utils/mobile.d.ts.map +1 -1
  73. package/dist/utils/mobile.js +15 -2
  74. package/dist/utils/useSelected.d.ts +22 -10
  75. package/dist/utils/useSelected.d.ts.map +1 -1
  76. package/dist/utils/useSelected.js +177 -45
  77. package/dist/utils/utils.d.ts +5 -0
  78. package/dist/utils/utils.d.ts.map +1 -1
  79. package/dist/utils/utils.js +9 -1
  80. package/eslint/plugin.js +4 -0
  81. package/package.json +1 -1
  82. package/tailwind-base/plugins/default.ts +1 -0
  83. package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.d.ts +0 -31
  84. package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.d.ts.map +0 -1
  85. package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.js +0 -30
  86. package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue2.js +0 -5
  87. package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.d.ts +0 -27
  88. package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.d.ts.map +0 -1
  89. package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.js +0 -66
  90. package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue2.js +0 -5
  91. package/dist/components/InfiniteList/models/injection.d.ts +0 -16
  92. package/dist/components/InfiniteList/models/injection.d.ts.map +0 -1
  93. package/dist/components/InfiniteList/models/injection.js +0 -4
  94. package/dist/components/InfiniteList/use/useSelected.d.ts +0 -14
  95. package/dist/components/InfiniteList/use/useSelected.d.ts.map +0 -1
  96. package/dist/components/InfiniteList/use/useSelected.js +0 -151
@@ -1,61 +1,193 @@
1
- import { computed } from 'vue';
1
+ import { computed, ref, unref, watch, onBeforeUnmount } from 'vue';
2
2
  import { useRoute, useRouter } from 'vue-router';
3
- import { isPage, isIndex, isId } from './utils.js';
3
+ import { isIdArray, isIndex } from './utils.js';
4
4
 
5
- const keysLengthPage = 3;
6
- const isSelecionPage = (value) => {
7
- return value instanceof Object && Object.keys(value).length === keysLengthPage && "page" in value && isPage(value.page) && "index" in value && isIndex(value.index) && "id" in value && isId(value.id);
8
- };
9
- const stringifySelectedPage = (value) => value.page + ":" + value.index + ":" + value.id;
10
- const keysLengthRange = 2;
11
5
  const isSelectedRange = (value) => {
12
- return Array.isArray(value) && value.length === keysLengthRange && isSelecionPage(value[0]) && isSelecionPage(value[1]);
6
+ return Array.isArray(value) && value.length === 2 && value.every(isIndex) && value[0] <= value[1];
7
+ };
8
+ const keysLengthSelection = 3;
9
+ const isSelection = (value) => {
10
+ return value instanceof Object && Object.keys(value).length <= keysLengthSelection && ("range" in value && isSelectedRange(value.range) || "id__in" in value && isIdArray(value.id__in) || "id__not_in" in value && isIdArray(value.id__not_in));
13
11
  };
14
- const isRightOrder = (value) => {
15
- return value[0].page < value[1].page || value[0].page === value[1].page && value[0].index <= value[1].index;
12
+ const parseSelection = (value) => {
13
+ return {
14
+ range: isSelectedRange(value.range) ? value.range : void 0,
15
+ id__in: isIdArray(value.id__in) ? value.id__in : void 0,
16
+ id__not_in: isIdArray(value.id__not_in) ? value.id__not_in : void 0
17
+ };
16
18
  };
17
- const getPosition = (range, pageLength) => {
18
- return (range.page - 1) * pageLength + range.index;
19
+ const getPosition = (page, index, pageLength) => {
20
+ return (page - 1) * pageLength + index;
19
21
  };
20
- const stringifySelectedRange = (value) => stringifySelectedPage(value[0]) + "-" + stringifySelectedPage(value[1]);
21
- const DIVIDER = ",";
22
- const useSelected = () => {
22
+ const isEmpty = (value) => Object.values(value).every((item) => !item);
23
+ const useSelected = (count, disabled) => {
23
24
  const route = useRoute();
24
25
  const router = useRouter();
25
- const selectedRange = computed(() => {
26
- if (!route.hash.includes("-")) return void 0;
27
- const parsed = route.hash.substring(1).split("-").map((item) => {
28
- const [page, index, id] = item.split(":").map((value) => Number.parseInt(value));
29
- return { page, index, id };
30
- });
31
- if (!isSelectedRange(parsed)) return void 0;
32
- if (!isRightOrder(parsed)) parsed.reverse();
33
- return parsed;
26
+ const selection = computed(() => {
27
+ if (!route.hash) return {};
28
+ try {
29
+ const parsed = JSON.parse(route.hash.substring(1));
30
+ if (!(parsed instanceof Object)) return {};
31
+ const value = parseSelection(parsed);
32
+ if (isSelection(value)) return value;
33
+ } catch {
34
+ }
35
+ return {};
36
+ });
37
+ const resetSelection = () => {
38
+ router.replace({ query: route.query, hash: "#" });
39
+ };
40
+ const updateSelection = (value) => {
41
+ if (isEmpty(value)) resetSelection();
42
+ router.replace({ query: route.query, hash: `#${JSON.stringify(value)}` });
43
+ };
44
+ const selectAll = () => {
45
+ updateSelection({ id__not_in: [] });
46
+ };
47
+ const isShift = ref(false);
48
+ const hoverValue = ref(null);
49
+ const preselectValue = ref(null);
50
+ const unmounted = ref(false);
51
+ const allowSelectHover = computed(() => !disabled.value && isShift.value);
52
+ const hoverAllowed = computed(() => allowSelectHover.value ? hoverValue.value : null);
53
+ const upValue = computed(() => {
54
+ if (selection.value.range) {
55
+ return Math.min(
56
+ hoverAllowed.value ?? selection.value.range[0],
57
+ preselectValue.value ?? selection.value.range[0]
58
+ );
59
+ } else if (hoverAllowed.value !== null && preselectValue.value !== null) {
60
+ return Math.min(
61
+ hoverAllowed.value,
62
+ preselectValue.value
63
+ );
64
+ }
65
+ return null;
34
66
  });
35
- const setSelectedRange = (value) => {
36
- router.replace({ query: route.query, hash: `#${stringifySelectedRange(value)}` });
37
- };
38
- const selected = computed(() => {
39
- if (typeof route.hash !== "string") return [];
40
- if (route.hash.includes("-")) return [];
41
- const substring = route.hash[1] === "!" ? route.hash.substring(2) : route.hash.substring(1);
42
- return substring.split(DIVIDER).map((item) => Number.parseInt(item)).filter((item) => !isNaN(item));
67
+ const downValue = computed(() => {
68
+ if (selection.value.range) {
69
+ if (hoverAllowed.value !== null && hoverAllowed.value < selection.value.range[0]) return selection.value.range[1];
70
+ return Math.max(
71
+ hoverAllowed.value ?? selection.value.range[1],
72
+ preselectValue.value ?? selection.value.range[0]
73
+ );
74
+ } else if (hoverAllowed.value !== null && preselectValue.value !== null) {
75
+ return Math.max(
76
+ hoverAllowed.value,
77
+ preselectValue.value
78
+ );
79
+ }
80
+ return null;
43
81
  });
44
- const reverse = computed(() => typeof route.hash === "string" && route.hash[1] === "!");
45
- const setSelected = (value) => {
46
- router.replace({ query: route.query, hash: `#${value.join(DIVIDER)}` });
82
+ const getIsSelected = (id, position) => {
83
+ if (hoverAllowed.value === position) return true;
84
+ if (upValue.value !== null && downValue.value !== null) {
85
+ if (upValue.value <= position && downValue.value >= position) return true;
86
+ if (allowSelectHover.value) return false;
87
+ }
88
+ if (selection.value.id__in) {
89
+ if (selection.value.id__in.includes(id)) return true;
90
+ }
91
+ if (selection.value.id__not_in) {
92
+ if (!selection.value.id__not_in.includes(id)) return true;
93
+ }
94
+ return false;
47
95
  };
48
- const setSelectedReverse = (value) => {
49
- router.replace({ query: route.query, hash: `#!${value.join(DIVIDER)}` });
96
+ const hoverSelected = (position) => {
97
+ if (unmounted.value || disabled.value) return;
98
+ hoverValue.value = position;
50
99
  };
100
+ const toggleSelected = (id, position) => {
101
+ if (unmounted.value || disabled.value) return;
102
+ if (upValue.value !== null && downValue.value !== null) {
103
+ let range;
104
+ if (allowSelectHover.value) {
105
+ range = [Math.min(position, upValue.value), Math.max(position, downValue.value)];
106
+ resetIsSelecting();
107
+ preselectValue.value = null;
108
+ } else if (downValue.value === position && upValue.value === position) {
109
+ return resetSelection();
110
+ } else if (upValue.value === position) {
111
+ range = [position + 1, downValue.value];
112
+ } else if (downValue.value === position) {
113
+ range = [upValue.value, position - 1];
114
+ } else if (upValue.value - 1 === position) {
115
+ range = [position, downValue.value];
116
+ } else if (downValue.value + 1 === position) {
117
+ range = [upValue.value, position];
118
+ }
119
+ if (range) {
120
+ updateSelection({ range });
121
+ return;
122
+ }
123
+ }
124
+ preselectValue.value = position;
125
+ const key = selection.value.id__not_in ? "id__not_in" : "id__in";
126
+ const newValue = selection.value[key]?.slice() ?? [];
127
+ const index = newValue.indexOf(id);
128
+ if (index === -1) newValue.push(id);
129
+ else newValue.splice(index, 1);
130
+ updateSelection({ [key]: newValue });
131
+ if (selection.value.id__in) {
132
+ if (index === -1) preselectValue.value = position;
133
+ else if (preselectValue.value === position) preselectValue.value = null;
134
+ }
135
+ };
136
+ const selectionCount = computed(() => {
137
+ if (selection.value.range) return selection.value.range[1] - selection.value.range[0] + 1;
138
+ const _count = unref(count);
139
+ return selection.value.id__not_in && _count !== void 0 ? Math.max(_count - selection.value.id__not_in.length, 0) : selection.value.id__in?.length ?? 0;
140
+ });
141
+ const selectAllValue = computed(() => {
142
+ if (selection.value.range) return null;
143
+ const _count = unref(count);
144
+ if (_count === 0) return false;
145
+ if (selection.value.id__not_in) {
146
+ return selection.value.id__not_in.length === 0 ? true : null;
147
+ } else {
148
+ return selection.value.id__in?.length ? null : false;
149
+ }
150
+ });
151
+ const setIsSelecting = (event) => {
152
+ if (!event.shiftKey) return;
153
+ isShift.value = true;
154
+ };
155
+ const resetIsSelecting = () => {
156
+ isShift.value = false;
157
+ };
158
+ const getQueryParams = () => {
159
+ if (isEmpty(selection.value)) return void 0;
160
+ const result = {};
161
+ if (selection.value.range) result.slice_indexes = selection.value.range.slice();
162
+ if (selection.value.id__not_in) result.id__not_in = selection.value.id__not_in.slice();
163
+ if (selection.value.id__in) result.id__in = selection.value.id__in.slice();
164
+ return result;
165
+ };
166
+ watch(disabled, (value) => {
167
+ if (value) {
168
+ window.removeEventListener("keydown", setIsSelecting);
169
+ window.removeEventListener("keyup", resetIsSelecting);
170
+ } else {
171
+ window.addEventListener("keydown", setIsSelecting);
172
+ window.addEventListener("keyup", resetIsSelecting);
173
+ }
174
+ }, { immediate: true });
175
+ onBeforeUnmount(() => {
176
+ unmounted.value = true;
177
+ window.removeEventListener("keydown", setIsSelecting);
178
+ window.removeEventListener("keyup", resetIsSelecting);
179
+ });
51
180
  return {
52
- selectedRange,
53
- setSelectedRange,
54
- selected,
55
- reverse,
56
- setSelected,
57
- setSelectedReverse
181
+ allowSelectHover,
182
+ selectionCount,
183
+ selectAllValue,
184
+ getIsSelected,
185
+ hoverSelected,
186
+ toggleSelected,
187
+ selectAll,
188
+ resetSelection,
189
+ getQueryParams
58
190
  };
59
191
  };
60
192
 
61
- export { getPosition, isSelecionPage, isSelectedRange, useSelected };
193
+ export { getPosition, useSelected };
@@ -14,6 +14,7 @@ export declare const numberFormatter: Pick<Intl.NumberFormat, "format">;
14
14
  export declare const isClientSide: boolean;
15
15
  export declare const genId: () => number;
16
16
  export declare const isId: (value: unknown) => value is number;
17
+ export declare const isIdArray: (value: unknown) => value is number[];
17
18
  export declare const parseId: (value: unknown) => number;
18
19
  export declare const isPage: (value: unknown) => value is number;
19
20
  export declare const isIndex: (value: unknown) => value is number;
@@ -21,5 +22,9 @@ export declare const parseIndex: (value: unknown) => number;
21
22
  export declare const get: <FieldType, Data>(data: Data, path: keyof ObjectPaths<Data, FieldType>) => FieldType | undefined;
22
23
  export declare const set: <FieldType, Data>(data: Data, path: keyof ObjectPaths<Data, FieldType>, value: FieldType) => Data;
23
24
  export declare const getDefaultFieldConfigMap: <Fields extends ListFields<any, any>>(fields: Fields, visible: true extends IsTuple<Fields> ? GetFieldLabels<Fields>[] : string[]) => FieldConfigMap<Fields>;
25
+ export declare enum ListMode {
26
+ TABLE = "table",
27
+ GRID = "grid"
28
+ }
24
29
  export {};
25
30
  //# sourceMappingURL=utils.d.ts.map
@@ -1 +1 @@
1
- {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,cAAc,EAAE,cAAc,EAAE,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAYpG,eAAO,MAAM,eAAe,SAAU,OAAO,KAAG,OAAO,GAAG,IAKhD,CAAA;AAEV,eAAO,MAAM,mBAAmB,UAAW,OAAO,mBAAa,KAAK,CAAC,OAAO,CAa3E,CAAA;AAED,eAAO,MAAM,SAAS,WAAY,OAAO,WAAW,OAAO,KAAG,OAI7D,CAAA;AAGD,KAAK,UAAU,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAA;AAE1C,wBAAgB,QAAQ,CAAC,CAAC,SAAS,UAAU,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,SAAM,GAAG,CAAC,CAWpE;AAED,wBAAgB,QAAQ,CAAC,CAAC,SAAS,UAAU,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,SAAM,GAAG,CAAC,CAYpE;AAED,eAAO,MAAM,UAAU,SAAU,OAAO,EAAE,QAAQ,OAAO,EAAE,KAAG,OAE7D,CAAA;AAED,eAAO,MAAM,UAAU,SAAU,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,YAAY,MAAM,EAAE,YAAY,MAAM,EAAE,KAAG,OAWjI,CAAA;AAQD,eAAO,MAAM,uBAAuB,mBAAmE,CAAA;AACvG,eAAO,MAAM,gBAAgB,mCAAsF,CAAA;AAEnH,eAAO,MAAM,sBAAsB,mBAAiD,CAAA;AACpF,eAAO,MAAM,eAAe,mCAAoE,CAAA;AAEhG,eAAO,MAAM,YAAY,EAAE,OAAuC,CAAA;AAIlE,eAAO,MAAM,KAAK,cAEjB,CAAA;AAED,eAAO,MAAM,IAAI,UAAW,OAAO,KAAG,KAAK,IAAI,MAE9C,CAAA;AAED,eAAO,MAAM,OAAO,UAAW,OAAO,KAAG,MAUxC,CAAA;AAED,eAAO,MAAM,MAAM,UAAW,OAAO,KAAG,KAAK,IAAI,MAAqB,CAAA;AAEtE,eAAO,MAAM,OAAO,UAAW,OAAO,KAAG,KAAK,IAAI,MAEjD,CAAA;AAED,eAAO,MAAM,UAAU,UAAW,OAAO,KAAG,MAU3C,CAAA;AAED,eAAO,MAAM,GAAG,GAAI,SAAS,EAAE,IAAI,QAAQ,IAAI,QAAQ,MAAM,WAAW,CAAC,IAAI,EAAE,SAAS,CAAC,KAAG,SAAS,GAAG,SAA2J,CAAA;AAEnQ,eAAO,MAAM,GAAG,GAAI,SAAS,EAAE,IAAI,QAAQ,IAAI,QAAQ,MAAM,WAAW,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,SAAS,KAAG,IAe7G,CAAA;AAGD,eAAO,MAAM,wBAAwB,GAAI,MAAM,SAAS,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,MAAM,WAAW,IAAI,SAAS,OAAO,CAAC,MAAM,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,EAAE,GAAG,MAAM,EAAE,KAAG,cAAc,CAAC,MAAM,CAiBhM,CAAA"}
1
+ {"version":3,"file":"utils.d.ts","sourceRoot":"","sources":["../../src/utils/utils.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAc,cAAc,EAAE,cAAc,EAAE,UAAU,EAAC,MAAM,yBAAyB,CAAA;AAYpG,eAAO,MAAM,eAAe,SAAU,OAAO,KAAG,OAAO,GAAG,IAKhD,CAAA;AAEV,eAAO,MAAM,mBAAmB,UAAW,OAAO,mBAAa,KAAK,CAAC,OAAO,CAa3E,CAAA;AAED,eAAO,MAAM,SAAS,WAAY,OAAO,WAAW,OAAO,KAAG,OAI7D,CAAA;AAGD,KAAK,UAAU,GAAG,CAAC,GAAG,IAAI,EAAE,GAAG,EAAE,KAAK,IAAI,CAAA;AAE1C,wBAAgB,QAAQ,CAAC,CAAC,SAAS,UAAU,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,SAAM,GAAG,CAAC,CAWpE;AAED,wBAAgB,QAAQ,CAAC,CAAC,SAAS,UAAU,EAAE,EAAE,EAAE,CAAC,EAAE,KAAK,SAAM,GAAG,CAAC,CAYpE;AAED,eAAO,MAAM,UAAU,SAAU,OAAO,EAAE,QAAQ,OAAO,EAAE,KAAG,OAE7D,CAAA;AAED,eAAO,MAAM,UAAU,SAAU,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,QAAQ,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,YAAY,MAAM,EAAE,YAAY,MAAM,EAAE,KAAG,OAWjI,CAAA;AAQD,eAAO,MAAM,uBAAuB,mBAAmE,CAAA;AACvG,eAAO,MAAM,gBAAgB,mCAAsF,CAAA;AAEnH,eAAO,MAAM,sBAAsB,mBAAiD,CAAA;AACpF,eAAO,MAAM,eAAe,mCAAoE,CAAA;AAEhG,eAAO,MAAM,YAAY,EAAE,OAAuC,CAAA;AAIlE,eAAO,MAAM,KAAK,cAEjB,CAAA;AAED,eAAO,MAAM,IAAI,UAAW,OAAO,KAAG,KAAK,IAAI,MAE9C,CAAA;AAED,eAAO,MAAM,SAAS,UAAW,OAAO,KAAG,KAAK,IAAI,MAAM,EAEzD,CAAA;AAED,eAAO,MAAM,OAAO,UAAW,OAAO,KAAG,MAUxC,CAAA;AAED,eAAO,MAAM,MAAM,UAAW,OAAO,KAAG,KAAK,IAAI,MAAqB,CAAA;AAEtE,eAAO,MAAM,OAAO,UAAW,OAAO,KAAG,KAAK,IAAI,MAEjD,CAAA;AAED,eAAO,MAAM,UAAU,UAAW,OAAO,KAAG,MAU3C,CAAA;AAED,eAAO,MAAM,GAAG,GAAI,SAAS,EAAE,IAAI,QAAQ,IAAI,QAAQ,MAAM,WAAW,CAAC,IAAI,EAAE,SAAS,CAAC,KAAG,SAAS,GAAG,SAA2J,CAAA;AAEnQ,eAAO,MAAM,GAAG,GAAI,SAAS,EAAE,IAAI,QAAQ,IAAI,QAAQ,MAAM,WAAW,CAAC,IAAI,EAAE,SAAS,CAAC,SAAS,SAAS,KAAG,IAe7G,CAAA;AAGD,eAAO,MAAM,wBAAwB,GAAI,MAAM,SAAS,UAAU,CAAC,GAAG,EAAE,GAAG,CAAC,UAAU,MAAM,WAAW,IAAI,SAAS,OAAO,CAAC,MAAM,CAAC,GAAG,cAAc,CAAC,MAAM,CAAC,EAAE,GAAG,MAAM,EAAE,KAAG,cAAc,CAAC,MAAM,CAiBhM,CAAA;AAED,oBAAY,QAAQ;IAClB,KAAK,UAAU;IACf,IAAI,SAAS;CACd"}
@@ -67,6 +67,9 @@ const genId = () => {
67
67
  const isId = (value) => {
68
68
  return typeof value === "number" && Number.isInteger(value) && value > 0;
69
69
  };
70
+ const isIdArray = (value) => {
71
+ return Array.isArray(value) && value.every(isId);
72
+ };
70
73
  const parseId = (value) => {
71
74
  if (typeof value === "number" && isId(value)) return value;
72
75
  if (typeof value !== "string") return NaN;
@@ -113,5 +116,10 @@ const getDefaultFieldConfigMap = (fields, visible) => {
113
116
  processFields(fields);
114
117
  return result;
115
118
  };
119
+ var ListMode = /* @__PURE__ */ ((ListMode2) => {
120
+ ListMode2["TABLE"] = "table";
121
+ ListMode2["GRID"] = "grid";
122
+ return ListMode2;
123
+ })(ListMode || {});
116
124
 
117
- export { debounce, genId, get, getAllScrollParents, getDefaultFieldConfigMap, getScrollParent, hasParent, isClientSide, isEqualArr, isEqualObj, isId, isIndex, isPage, numberCompactFormatter, numberFormatter, parseId, parseIndex, percentCompactFormatter, percentFormatter, set, throttle };
125
+ export { ListMode, debounce, genId, get, getAllScrollParents, getDefaultFieldConfigMap, getScrollParent, hasParent, isClientSide, isEqualArr, isEqualObj, isId, isIdArray, isIndex, isPage, numberCompactFormatter, numberFormatter, parseId, parseIndex, percentCompactFormatter, percentFormatter, set, throttle };
package/eslint/plugin.js CHANGED
@@ -35,6 +35,10 @@ plugin.configs.recommended = [
35
35
  name: 'eco-vue-js',
36
36
  message: 'Use import eco-vue-js/dist/',
37
37
  },
38
+ {
39
+ name: '@/main',
40
+ message: 'Import direcrlty',
41
+ },
38
42
  ],
39
43
  },
40
44
  },
package/package.json CHANGED
@@ -4,7 +4,7 @@
4
4
  "type": "git",
5
5
  "url": "https://github.com/rsmple/eco-vue-js.git"
6
6
  },
7
- "version": "0.10.5",
7
+ "version": "0.10.7",
8
8
  "scripts": {
9
9
  "build": "run-p type-check \"build-only {@}\" --",
10
10
  "preview": "vite preview",
@@ -489,6 +489,7 @@ const pluginDefault = plugin(function ({matchUtilities, addVariant, addUtilities
489
489
  'w-skeleton-rounded': value => ({'--w-skeleton-rounded': value}),
490
490
  'w-ripple-rounded': value => ({'--w-ripple-rounded': value}),
491
491
  'w-list-rounded': value => ({'--w-list-rounded': value}),
492
+ 'w-option-rounded': value => ({'--w-option-rounded': value}),
492
493
  },
493
494
  {
494
495
  values: theme('borderRadius'),
@@ -1,31 +0,0 @@
1
- declare function __VLS_template(): {
2
- slots: {
3
- default?(_: {}): any;
4
- };
5
- refs: {};
6
- attrs: Partial<{}>;
7
- };
8
- type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
9
- declare const __VLS_component: import('vue').DefineComponent<{
10
- selected?: boolean;
11
- selectedBetween?: boolean;
12
- }, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
13
- "update:selected": (value: boolean) => any;
14
- "update:selected-range": () => any;
15
- "update:selected-range-hover": () => any;
16
- }, string, import('vue').PublicProps, Readonly<{
17
- selected?: boolean;
18
- selectedBetween?: boolean;
19
- }> & Readonly<{
20
- "onUpdate:selected"?: ((value: boolean) => any) | undefined;
21
- "onUpdate:selected-range"?: (() => any) | undefined;
22
- "onUpdate:selected-range-hover"?: (() => any) | undefined;
23
- }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {}, any>;
24
- declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
25
- export default _default;
26
- type __VLS_WithTemplateSlots<T, S> = T & {
27
- new (): {
28
- $slots: S;
29
- };
30
- };
31
- //# sourceMappingURL=InfiniteListPageSelectItem.vue.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"InfiniteListPageSelectItem.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPageSelectItem.vue"],"names":[],"mappings":"AA0EA,iBAAS,cAAc;;yBAyBM,GAAG;;;WASlB,OAAO,IAA6B;EAEjD;AAaD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;eAnFR,OAAO;sBACA,OAAO;;;;;;eADd,OAAO;sBACA,OAAO;;;;;kFA6FzB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAWpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,30 +0,0 @@
1
- import { defineComponent, provide, toRef, onUnmounted, renderSlot } from 'vue';
2
- import { wInfiniteListSelectionItem } from '../models/injection.js';
3
-
4
- const _sfc_main = /* @__PURE__ */ defineComponent({
5
- __name: "InfiniteListPageSelectItem",
6
- props: {
7
- selected: { type: Boolean },
8
- selectedBetween: { type: Boolean }
9
- },
10
- emits: ["update:selected", "update:selected-range", "update:selected-range-hover"],
11
- setup(__props, { emit: __emit }) {
12
- const props = __props;
13
- const emit = __emit;
14
- provide(wInfiniteListSelectionItem, {
15
- selected: toRef(props, "selected"),
16
- selectedBetween: toRef(props, "selectedBetween"),
17
- updateSelected: (value) => emit("update:selected", value),
18
- updateSelectedRange: () => emit("update:selected-range"),
19
- updateSelectedRangeHover: () => emit("update:selected-range-hover")
20
- });
21
- onUnmounted(() => {
22
- if (props.selected) emit("update:selected", false);
23
- });
24
- return (_ctx, _cache) => {
25
- return renderSlot(_ctx.$slots, "default");
26
- };
27
- }
28
- });
29
-
30
- export { _sfc_main as default };
@@ -1,5 +0,0 @@
1
- import _sfc_main from './InfiniteListPageSelectItem.vue.js';
2
-
3
-
4
-
5
- export { _sfc_main as default };
@@ -1,27 +0,0 @@
1
- declare const _default: <Model extends number | string, Data extends DefaultData>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_PrettifyLocal<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
2
- props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
3
- readonly "onUpdate:selected"?: ((values: Model[]) => any) | undefined;
4
- } & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps, never>, "onUpdate:selected"> & {
5
- selected: Model[];
6
- items: Data[];
7
- disabled?: boolean;
8
- tooltipTextPersisted?: boolean;
9
- selectOnly?: boolean;
10
- unselectOnly?: boolean;
11
- reverse?: boolean;
12
- valueGetter: (data: Data) => Model;
13
- }> & import('vue').PublicProps;
14
- expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
15
- attrs: any;
16
- slots: {};
17
- emit: (e: "update:selected", values: Model[]) => void;
18
- }>) => import('vue').VNode<import('vue').RendererNode, import('vue').RendererElement, {
19
- [key: string]: any;
20
- }> & {
21
- __ctx?: Awaited<typeof __VLS_setup>;
22
- };
23
- export default _default;
24
- type __VLS_PrettifyLocal<T> = {
25
- [K in keyof T]: T[K];
26
- } & {};
27
- //# sourceMappingURL=InfiniteListPageSelection.vue.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"InfiniteListPageSelection.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/components/InfiniteListPageSelection.vue"],"names":[],"mappings":"yBA4EiB,KAAK,SAAS,MAAM,GAAG,MAAM,EAAE,IAAI,SAAS,WAAW,eAC1D,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,mBAAmB,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBAC5F,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAiKxD,mBAAmB,CAAC;;;kBA7JlB,KAAK,EAAE;eACV,IAAI,EAAE;mBACF,OAAO;+BACK,OAAO;qBACjB,OAAO;uBACL,OAAO;kBACZ,OAAO;qBACJ,CAAC,IAAI,EAAE,IAAI,KAAK,KAAK;KAsJmD,CAAC,4BAA2B;oBAChG,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;;cAnJP,iBAAiB,UAAU,KAAK,EAAE,KAAG,IAAI;;;;YAwJH,OAAO,CAAC,OAAO,WAAW,CAAC;;AA3KvE,wBA2K4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -1,66 +0,0 @@
1
- import { defineComponent, computed, createBlock, openBlock, withCtx, createTextVNode, toDisplayString } from 'vue';
2
- import _sfc_main$1 from '../../Checkbox/WCheckbox.vue.js';
3
-
4
- const _sfc_main = /* @__PURE__ */ defineComponent({
5
- __name: "InfiniteListPageSelection",
6
- props: {
7
- selected: {},
8
- items: {},
9
- disabled: { type: Boolean },
10
- tooltipTextPersisted: { type: Boolean },
11
- selectOnly: { type: Boolean },
12
- unselectOnly: { type: Boolean },
13
- reverse: { type: Boolean },
14
- valueGetter: { type: Function }
15
- },
16
- emits: ["update:selected"],
17
- setup(__props, { emit: __emit }) {
18
- const props = __props;
19
- const emit = __emit;
20
- const models = computed(() => props.items.map((item) => props.valueGetter(item)));
21
- const selectedItems = computed(() => models.value.filter((item) => props.selected.includes(item)));
22
- const hasSelected = computed(() => selectedItems.value.length !== 0);
23
- const chekboxValue = computed(() => {
24
- if (props.selectOnly) return false;
25
- if (props.unselectOnly) return true;
26
- if (selectedItems.value.length === props.items.length) {
27
- return hasSelected.value;
28
- } else {
29
- return hasSelected.value ? null : false;
30
- }
31
- });
32
- const chekboxValueReversed = computed(() => props.disabled ? false : chekboxValue.value === null ? null : props.reverse ? !chekboxValue.value : chekboxValue.value);
33
- const tooltipText = computed(() => `${chekboxValueReversed.value === true ? "Unselect" : "Select"} page (${props.items.length} item${props.items.length === 1 ? "" : "s"})`);
34
- const selectOrUnselect = (isSelect) => {
35
- if (props.reverse ? !isSelect : isSelect) {
36
- emit("update:selected", [...props.selected, ...models.value].filter((item, index, arr) => arr.indexOf(item) === index));
37
- } else {
38
- emit("update:selected", props.selected.filter((item) => !models.value.includes(item)));
39
- }
40
- };
41
- return (_ctx, _cache) => {
42
- return _ctx.tooltipTextPersisted ? (openBlock(), createBlock(_sfc_main$1, {
43
- key: 0,
44
- "model-value": chekboxValueReversed.value,
45
- disabled: _ctx.disabled,
46
- intermediate: "",
47
- class: "w-full",
48
- "onUpdate:modelValue": selectOrUnselect
49
- }, {
50
- default: withCtx(() => [
51
- createTextVNode(toDisplayString(tooltipText.value), 1)
52
- ]),
53
- _: 1
54
- }, 8, ["model-value", "disabled"])) : (openBlock(), createBlock(_sfc_main$1, {
55
- key: 1,
56
- "model-value": chekboxValueReversed.value,
57
- disabled: _ctx.disabled,
58
- "tooltip-text": tooltipText.value,
59
- intermediate: "",
60
- "onUpdate:modelValue": selectOrUnselect
61
- }, null, 8, ["model-value", "disabled", "tooltip-text"]));
62
- };
63
- }
64
- });
65
-
66
- export { _sfc_main as default };
@@ -1,5 +0,0 @@
1
- import _sfc_main from './InfiniteListPageSelection.vue.js';
2
-
3
-
4
-
5
- export { _sfc_main as default };
@@ -1,16 +0,0 @@
1
- import { InjectionKey, Ref } from 'vue';
2
- export declare const wInfiniteListSelection: InjectionKey<{
3
- allowSelect?: Ref<boolean>;
4
- allowSelectRange?: Ref<boolean>;
5
- allowSelectHover?: Ref<boolean>;
6
- selectedCount?: Ref<number>;
7
- clearSelected?(): void;
8
- }>;
9
- export declare const wInfiniteListSelectionItem: InjectionKey<{
10
- selected?: Ref<boolean>;
11
- selectedBetween?: Ref<boolean>;
12
- updateSelected?(value: boolean): void;
13
- updateSelectedRange?(): void;
14
- updateSelectedRangeHover?(): void;
15
- }>;
16
- //# sourceMappingURL=injection.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"injection.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/models/injection.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,YAAY,EAAE,GAAG,EAAC,MAAM,KAAK,CAAA;AAE1C,eAAO,MAAM,sBAAsB,EAAuC,YAAY,CAAC;IACrF,WAAW,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;IAC1B,gBAAgB,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;IAC/B,gBAAgB,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;IAC/B,aAAa,CAAC,EAAE,GAAG,CAAC,MAAM,CAAC,CAAA;IAE3B,aAAa,CAAC,IAAI,IAAI,CAAA;CACvB,CAAC,CAAA;AAEF,eAAO,MAAM,0BAA0B,EAA2C,YAAY,CAAC;IAC7F,QAAQ,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;IACvB,eAAe,CAAC,EAAE,GAAG,CAAC,OAAO,CAAC,CAAA;IAE9B,cAAc,CAAC,CAAC,KAAK,EAAE,OAAO,GAAG,IAAI,CAAA;IACrC,mBAAmB,CAAC,IAAI,IAAI,CAAA;IAC5B,wBAAwB,CAAC,IAAI,IAAI,CAAA;CAClC,CAAC,CAAA"}
@@ -1,4 +0,0 @@
1
- const wInfiniteListSelection = Symbol("wInfiniteListSelection");
2
- const wInfiniteListSelectionItem = Symbol("wInfiniteListSelectionItem");
3
-
4
- export { wInfiniteListSelection, wInfiniteListSelectionItem };
@@ -1,14 +0,0 @@
1
- import { Ref } from 'vue';
2
- export declare const useSelected: <Value>(count: Ref<number | undefined>, pageLength: Ref<number>, selected: Ref<Value[]>, reverse: Ref<boolean>, selectedRange: Ref<SelectedRange<Value> | undefined>, select: (value: Value[]) => void, selectReverse: (value: Value[]) => void, selectRange: (value: SelectedRange<Value>) => void) => {
3
- setSelectedRange: (value: SelectedPage<Value>) => void;
4
- getIsSelected: (id: Value) => boolean;
5
- getIsSelectedBetween: (id: Value, page: number, index: number) => boolean;
6
- setRangeHover: (value: SelectedPage<Value>) => void;
7
- allowSelectHover: import('vue').ComputedRef<boolean>;
8
- selectionRangeCount: import('vue').ComputedRef<number | undefined>;
9
- setSelectedCursor: (value: SelectedPage<Value> | null) => void;
10
- toggleSelected: (id: Value, value: boolean) => void;
11
- selectedCount: import('vue').ComputedRef<number>;
12
- selectAllValue: import('vue').ComputedRef<boolean | null>;
13
- };
14
- //# sourceMappingURL=useSelected.d.ts.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"useSelected.d.ts","sourceRoot":"","sources":["../../../../src/components/InfiniteList/use/useSelected.ts"],"names":[],"mappings":"AAAA,OAAO,EAAC,KAAK,GAAG,EAAwC,MAAM,KAAK,CAAA;AA6BnE,eAAO,MAAM,WAAW,GAAI,KAAK,SACxB,GAAG,CAAC,MAAM,GAAG,SAAS,CAAC,cAClB,GAAG,CAAC,MAAM,CAAC,YACb,GAAG,CAAC,KAAK,EAAE,CAAC,WACb,GAAG,CAAC,OAAO,CAAC,iBACN,GAAG,CAAC,aAAa,CAAC,KAAK,CAAC,GAAG,SAAS,CAAC,UAE5C,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,iBACjB,CAAC,KAAK,EAAE,KAAK,EAAE,KAAK,IAAI,eAC1B,CAAC,KAAK,EAAE,aAAa,CAAC,KAAK,CAAC,KAAK,IAAI;8BAqBjB,YAAY,CAAC,KAAK,CAAC;wBA4CzB,KAAK;+BAYE,KAAK,QAAQ,MAAM,SAAS,MAAM;2BAhBtC,YAAY,CAAC,KAAK,CAAC;;;+BAsCf,YAAY,CAAC,KAAK,CAAC,GAAG,IAAI;yBAIhC,KAAK,SAAS,OAAO,KAAG,IAAI;;;CA4EzD,CAAA"}