eco-vue-js 0.10.4 → 0.10.6
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/dist/components/Button/WButtonDropdown.vue.d.ts +1 -1
- package/dist/components/Button/WButtonDropdown.vue.d.ts.map +1 -1
- package/dist/components/Button/WButtonDropdown.vue.js +1 -12
- package/dist/components/Button/WButtonSelection.vue.d.ts +6 -5
- package/dist/components/Button/WButtonSelection.vue.d.ts.map +1 -1
- package/dist/components/Button/WButtonSelection.vue.js +10 -24
- package/dist/components/Checkbox/WCheckbox.vue.d.ts +0 -2
- package/dist/components/Checkbox/WCheckbox.vue.d.ts.map +1 -1
- package/dist/components/Checkbox/WCheckbox.vue.js +2 -8
- package/dist/components/FieldWrapper/WFieldWrapper.vue.js +1 -14
- package/dist/components/Form/WForm.vue.d.ts +2 -2
- package/dist/components/Form/WFormValidator.vue.d.ts +2 -2
- package/dist/components/Form/WFormValidator.vue.js +1 -14
- package/dist/components/Form/models/utils.js +0 -14
- package/dist/components/FormAsync/use/useFormAsync.d.ts.map +1 -1
- package/dist/components/FormAsync/use/useFormAsync.js +2 -14
- package/dist/components/HeaderBar/WHeaderBar.vue.js +2 -2
- package/dist/components/InfiniteList/WInfiniteList.vue.d.ts +3 -18
- package/dist/components/InfiniteList/WInfiniteList.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/WInfiniteList.vue.js +25 -83
- package/dist/components/InfiniteList/WInfiniteListWrapper.vue.js +1 -1
- package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts +0 -5
- package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/components/InfiniteListPage.vue.js +8 -27
- package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts +1 -8
- package/dist/components/InfiniteList/components/InfiniteListPages.vue.d.ts.map +1 -1
- package/dist/components/InfiniteList/components/InfiniteListPages.vue.js +10 -21
- package/dist/components/InfiniteList/use/useInfiniteListHeader.js +0 -13
- package/dist/components/Input/WInputSuggest.vue.js +3 -3
- package/dist/components/List/WList.vue.d.ts +3 -0
- package/dist/components/List/WList.vue.d.ts.map +1 -1
- package/dist/components/List/WList.vue.js +230 -245
- package/dist/components/List/WListCard.vue.d.ts +15 -9
- package/dist/components/List/WListCard.vue.d.ts.map +1 -1
- package/dist/components/List/WListCard.vue.js +79 -84
- package/dist/components/List/WListHeaderItem.vue.d.ts.map +1 -1
- package/dist/components/List/WListHeaderItem.vue.js +1 -1
- package/dist/components/List/components/HeaderSettings.vue.d.ts +3 -2
- package/dist/components/List/components/HeaderSettings.vue.d.ts.map +1 -1
- package/dist/components/List/components/HeaderSettings.vue.js +21 -25
- package/dist/components/List/components/HeaderSort.vue.d.ts +1 -1
- package/dist/components/List/components/HeaderSort.vue.d.ts.map +1 -1
- package/dist/components/List/components/HeaderSort.vue.js +0 -13
- package/dist/components/List/components/ListCardAction.vue.d.ts +23 -0
- package/dist/components/List/components/ListCardAction.vue.d.ts.map +1 -0
- package/dist/components/List/components/ListCardAction.vue.js +23 -0
- package/dist/components/List/components/ListCardAction.vue2.js +5 -0
- package/dist/components/List/components/ListCardFieldNested.vue.d.ts +2 -0
- package/dist/components/List/components/ListCardFieldNested.vue.d.ts.map +1 -1
- package/dist/components/List/components/ListCardFieldNested.vue.js +2 -1
- package/dist/components/List/types.d.ts +5 -0
- package/dist/components/List/types.d.ts.map +1 -1
- package/dist/components/List/use/useListConfig.d.ts +3 -10
- package/dist/components/List/use/useListConfig.d.ts.map +1 -1
- package/dist/components/List/use/useListConfig.js +20 -16
- package/dist/components/List/use/useOrdering.js +3 -3
- package/dist/components/Modal/WModalStepper.vue.d.ts +26 -26
- package/dist/components/Nav/WNavItemExpand.vue.js +0 -13
- package/dist/components/Select/WSelect.vue.d.ts.map +1 -1
- package/dist/components/Select/WSelect.vue.js +2 -2
- package/dist/components/Select/WSelectAsync.vue.d.ts.map +1 -1
- package/dist/components/Select/WSelectAsync.vue.js +2 -2
- package/dist/components/Select/WSelectAsyncList.vue.d.ts +1 -1
- package/dist/components/Select/WSelectAsyncList.vue.d.ts.map +1 -1
- package/dist/components/Select/WSelectAsyncList.vue.js +0 -1
- package/dist/components/Select/components/SelectAsyncList.vue.d.ts.map +1 -1
- package/dist/components/Select/components/SelectAsyncList.vue.js +15 -11
- package/dist/components/Tabs/WTabs.vue.d.ts +24 -24
- package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
- package/dist/components/Tabs/WTabs.vue.js +4 -17
- package/dist/components/Tabs/WTabsColumns.vue.js +2 -2
- package/dist/components/Tabs/components/TabItem.vue.d.ts +12 -12
- package/dist/main.js +2 -2
- package/dist/types/global.d.ts +0 -11
- package/dist/utils/mobile.d.ts +3 -0
- package/dist/utils/mobile.d.ts.map +1 -1
- package/dist/utils/mobile.js +15 -2
- package/dist/utils/useSelected.d.ts +22 -10
- package/dist/utils/useSelected.d.ts.map +1 -1
- package/dist/utils/useSelected.js +172 -45
- package/dist/utils/utils.d.ts +5 -0
- package/dist/utils/utils.d.ts.map +1 -1
- package/dist/utils/utils.js +9 -1
- package/eslint/plugin.js +4 -0
- package/package.json +1 -1
- package/tailwind-base/plugins/default.ts +5 -2
- package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.d.ts +0 -31
- package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.d.ts.map +0 -1
- package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue.js +0 -30
- package/dist/components/InfiniteList/components/InfiniteListPageSelectItem.vue2.js +0 -5
- package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.d.ts +0 -27
- package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.d.ts.map +0 -1
- package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue.js +0 -66
- package/dist/components/InfiniteList/components/InfiniteListPageSelection.vue2.js +0 -5
- package/dist/components/InfiniteList/models/injection.d.ts +0 -16
- package/dist/components/InfiniteList/models/injection.d.ts.map +0 -1
- package/dist/components/InfiniteList/models/injection.js +0 -4
- package/dist/components/InfiniteList/use/useSelected.d.ts +0 -14
- package/dist/components/InfiniteList/use/useSelected.d.ts.map +0 -1
- package/dist/components/InfiniteList/use/useSelected.js +0 -151
@@ -1,61 +1,188 @@
|
|
1
|
-
import { computed } from 'vue';
|
1
|
+
import { computed, ref, unref, onMounted, onBeforeUnmount } from 'vue';
|
2
2
|
import { useRoute, useRouter } from 'vue-router';
|
3
|
-
import {
|
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 ===
|
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
|
15
|
-
return
|
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 = (
|
18
|
-
return (
|
19
|
+
const getPosition = (page, index, pageLength) => {
|
20
|
+
return (page - 1) * pageLength + index;
|
19
21
|
};
|
20
|
-
const
|
21
|
-
const
|
22
|
-
const useSelected = () => {
|
22
|
+
const isEmpty = (value) => Object.values(value).every((item) => !item);
|
23
|
+
const useSelected = (count) => {
|
23
24
|
const route = useRoute();
|
24
25
|
const router = useRouter();
|
25
|
-
const
|
26
|
-
if (!route.hash
|
27
|
-
|
28
|
-
const
|
29
|
-
|
30
|
-
|
31
|
-
|
32
|
-
|
33
|
-
|
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 disabled = ref(false);
|
51
|
+
const allowSelectHover = computed(() => 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
|
36
|
-
|
37
|
-
|
38
|
-
|
39
|
-
|
40
|
-
|
41
|
-
|
42
|
-
|
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
|
45
|
-
|
46
|
-
|
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
|
49
|
-
|
96
|
+
const hoverSelected = (position) => {
|
97
|
+
if (disabled.value) return;
|
98
|
+
hoverValue.value = position;
|
50
99
|
};
|
100
|
+
const toggleSelected = (id, position) => {
|
101
|
+
if (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
|
+
onMounted(() => {
|
167
|
+
window.addEventListener("keydown", setIsSelecting);
|
168
|
+
window.addEventListener("keyup", resetIsSelecting);
|
169
|
+
});
|
170
|
+
onBeforeUnmount(() => {
|
171
|
+
disabled.value = true;
|
172
|
+
window.removeEventListener("keydown", setIsSelecting);
|
173
|
+
window.removeEventListener("keyup", resetIsSelecting);
|
174
|
+
});
|
51
175
|
return {
|
52
|
-
|
53
|
-
|
54
|
-
|
55
|
-
|
56
|
-
|
57
|
-
|
176
|
+
allowSelectHover,
|
177
|
+
selectionCount,
|
178
|
+
selectAllValue,
|
179
|
+
getIsSelected,
|
180
|
+
hoverSelected,
|
181
|
+
toggleSelected,
|
182
|
+
selectAll,
|
183
|
+
resetSelection,
|
184
|
+
getQueryParams
|
58
185
|
};
|
59
186
|
};
|
60
187
|
|
61
|
-
export { getPosition,
|
188
|
+
export { getPosition, useSelected };
|
package/dist/utils/utils.d.ts
CHANGED
@@ -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"}
|
package/dist/utils/utils.js
CHANGED
@@ -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
package/package.json
CHANGED
@@ -121,8 +121,10 @@ const pluginDefault = plugin(function ({matchUtilities, addVariant, addUtilities
|
|
121
121
|
addVariant('resizer', '&::-webkit-resizer')
|
122
122
|
addVariant('last-not', '&:not(:last-child)')
|
123
123
|
addVariant('first-not', '&:not(:first-child)')
|
124
|
-
addVariant('card', ['.w-card &'
|
125
|
-
addVariant('
|
124
|
+
addVariant('card', ['.w-card &'])
|
125
|
+
addVariant('card-l', ['&.w-card'])
|
126
|
+
addVariant('list', ['.w-list &'])
|
127
|
+
addVariant('list-l', ['&.w-list'])
|
126
128
|
|
127
129
|
addBase({
|
128
130
|
'.w-input': {
|
@@ -487,6 +489,7 @@ const pluginDefault = plugin(function ({matchUtilities, addVariant, addUtilities
|
|
487
489
|
'w-skeleton-rounded': value => ({'--w-skeleton-rounded': value}),
|
488
490
|
'w-ripple-rounded': value => ({'--w-ripple-rounded': value}),
|
489
491
|
'w-list-rounded': value => ({'--w-list-rounded': value}),
|
492
|
+
'w-option-rounded': value => ({'--w-option-rounded': value}),
|
490
493
|
},
|
491
494
|
{
|
492
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,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,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,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"}
|