qidian-vue-ui 1.1.31 → 1.1.33
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/card/props.mjs.map +1 -1
- package/dist/components/config-provider/config.mjs.map +1 -1
- package/dist/components/config-provider/useConfig.mjs.map +1 -1
- package/dist/components/crud/define.d.ts +2 -1
- package/dist/components/crud/define.mjs.map +1 -1
- package/dist/components/crud/index.d.ts +4 -5
- package/dist/components/crud/list/index.d.ts +2 -0
- package/dist/components/crud/list/index.vue.mjs +8 -0
- package/dist/components/crud/list/index.vue.mjs.map +1 -0
- package/dist/components/crud/{list.vue2.mjs → list/index.vue2.mjs} +10 -10
- package/dist/components/crud/list/index.vue2.mjs.map +1 -0
- package/dist/components/crud/list/props.d.ts +5 -0
- package/dist/components/crud/list/props.mjs +9 -0
- package/dist/components/crud/list/props.mjs.map +1 -0
- package/dist/components/crud/list/types.d.ts +9 -0
- package/dist/components/crud/search/index.d.ts +2 -0
- package/dist/components/crud/{search.vue.d.ts → search/index.vue.d.ts} +4 -4
- package/dist/components/crud/search/index.vue.mjs +8 -0
- package/dist/components/crud/search/index.vue.mjs.map +1 -0
- package/dist/components/crud/{search.vue2.mjs → search/index.vue2.mjs} +10 -10
- package/dist/components/crud/search/index.vue2.mjs.map +1 -0
- package/dist/components/crud/search/props.d.ts +26 -0
- package/dist/components/crud/search/props.mjs +19 -0
- package/dist/components/crud/search/props.mjs.map +1 -0
- package/dist/components/crud/search/types.d.ts +5 -0
- package/dist/components/crud/table/index.d.ts +2 -0
- package/dist/components/crud/table/index.vue.mjs +8 -0
- package/dist/components/crud/table/index.vue.mjs.map +1 -0
- package/dist/components/crud/{table.vue2.mjs → table/index.vue2.mjs} +23 -23
- package/dist/components/crud/table/index.vue2.mjs.map +1 -0
- package/dist/components/crud/{props.d.ts → table/props.d.ts} +0 -31
- package/dist/components/crud/table/props.mjs +16 -0
- package/dist/components/crud/table/props.mjs.map +1 -0
- package/dist/components/crud/{types.d.ts → table/types.d.ts} +6 -15
- package/dist/components/dict/checkbox-group/index.d.ts +2 -0
- package/dist/components/dict/checkbox-group/index.vue.mjs +8 -0
- package/dist/components/dict/checkbox-group/index.vue.mjs.map +1 -0
- package/dist/components/dict/{checkbox-group.vue2.mjs → checkbox-group/index.vue2.mjs} +14 -9
- package/dist/components/dict/checkbox-group/index.vue2.mjs.map +1 -0
- package/dist/components/dict/checkbox-group/props.d.ts +9 -0
- package/dist/components/dict/checkbox-group/props.mjs +13 -0
- package/dist/components/dict/checkbox-group/props.mjs.map +1 -0
- package/dist/components/dict/checkbox-group/types.d.ts +6 -0
- package/dist/components/dict/index.d.ts +4 -5
- package/dist/components/dict/radio-group/index.d.ts +2 -0
- package/dist/components/dict/radio-group/index.vue.mjs +8 -0
- package/dist/components/dict/radio-group/index.vue.mjs.map +1 -0
- package/dist/components/dict/{radio-group.vue2.mjs → radio-group/index.vue2.mjs} +6 -6
- package/dist/components/dict/radio-group/index.vue2.mjs.map +1 -0
- package/dist/components/dict/radio-group/props.d.ts +7 -0
- package/dist/components/dict/radio-group/props.mjs +11 -0
- package/dist/components/dict/radio-group/props.mjs.map +1 -0
- package/dist/components/dict/radio-group/types.d.ts +4 -0
- package/dist/components/dict/select/index.d.ts +2 -0
- package/dist/components/dict/{select.vue.mjs → select/index.vue.mjs} +8 -7
- package/dist/components/dict/select/index.vue.mjs.map +1 -0
- package/dist/components/dict/select/index.vue2.mjs +5 -0
- package/dist/components/dict/select/index.vue2.mjs.map +1 -0
- package/dist/components/dict/select/props.d.ts +11 -0
- package/dist/components/dict/select/props.mjs +15 -0
- package/dist/components/dict/select/props.mjs.map +1 -0
- package/dist/components/dict/select/types.d.ts +7 -0
- package/dist/components/dict/tag/index.d.ts +2 -0
- package/dist/components/dict/{tag.vue.d.ts → tag/index.vue.d.ts} +7 -7
- package/dist/components/dict/tag/index.vue.mjs +8 -0
- package/dist/components/dict/tag/index.vue.mjs.map +1 -0
- package/dist/components/dict/{tag.vue2.mjs → tag/index.vue2.mjs} +8 -8
- package/dist/components/dict/tag/index.vue2.mjs.map +1 -0
- package/dist/components/dict/tag/props.d.ts +5 -0
- package/dist/components/dict/tag/props.mjs +10 -0
- package/dist/components/dict/tag/props.mjs.map +1 -0
- package/dist/components/dict/tag/types.d.ts +9 -0
- package/dist/components/form/item.vue.mjs +1 -1
- package/dist/components/form/item.vue2.mjs +1 -1
- package/dist/components/form/item.vue2.mjs.map +1 -1
- package/dist/components/office/pdf/config.mjs.map +1 -1
- package/dist/components/org/index.d.ts +1 -2
- package/dist/components/org/select/index.d.ts +2 -0
- package/dist/components/org/select/index.vue.mjs +4 -4
- package/dist/components/org/select/props.mjs +1 -1
- package/dist/components/org/select/props.mjs.map +1 -1
- package/dist/components/service/dialog-table-select/index.d.ts +2 -0
- package/dist/components/service/dialog-table-select/index.vue.d.ts +27 -0
- package/dist/components/service/dialog-table-select/props.d.ts +32 -0
- package/dist/components/service/dialog-table-select/types.d.ts +5 -0
- package/dist/components/service/index.d.ts +3 -4
- package/dist/components/service/list/index.d.ts +2 -0
- package/dist/components/service/list/index.vue.mjs +8 -0
- package/dist/components/service/list/index.vue.mjs.map +1 -0
- package/dist/components/service/{list.vue2.mjs → list/index.vue2.mjs} +4 -4
- package/dist/components/service/list/index.vue2.mjs.map +1 -0
- package/dist/components/service/list/props.d.ts +4 -0
- package/dist/components/service/list/props.mjs +8 -0
- package/dist/components/service/list/props.mjs.map +1 -0
- package/dist/components/service/list/types.d.ts +15 -0
- package/dist/components/service/select/index.d.ts +2 -0
- package/dist/components/service/select/index.vue.mjs +8 -0
- package/dist/components/service/select/index.vue.mjs.map +1 -0
- package/dist/components/service/{select.vue2.mjs → select/index.vue2.mjs} +5 -5
- package/dist/components/service/select/index.vue2.mjs.map +1 -0
- package/dist/components/service/select/props.d.ts +19 -0
- package/dist/components/service/select/props.mjs +24 -0
- package/dist/components/service/select/props.mjs.map +1 -0
- package/dist/components/service/select/types.d.ts +15 -0
- package/dist/components/service/table/index.d.ts +2 -0
- package/dist/components/service/table/index.vue.mjs +8 -0
- package/dist/components/service/table/index.vue.mjs.map +1 -0
- package/dist/components/service/{table.vue2.mjs → table/index.vue2.mjs} +4 -4
- package/dist/components/service/table/index.vue2.mjs.map +1 -0
- package/dist/components/service/{props.d.ts → table/props.d.ts} +0 -23
- package/dist/components/service/{props.mjs → table/props.mjs} +0 -26
- package/dist/components/service/table/props.mjs.map +1 -0
- package/dist/components/service/table/types.d.ts +18 -0
- package/dist/components/upload/index.vue.mjs +1 -1
- package/dist/components/upload/index.vue2.mjs +36 -12
- package/dist/components/upload/index.vue2.mjs.map +1 -1
- package/dist/components/upload/props.d.ts +1 -0
- package/dist/components/upload/props.mjs +1 -0
- package/dist/components/upload/props.mjs.map +1 -1
- package/dist/components/upload/types.d.ts +4 -2
- package/dist/hooks/useModal.mjs.map +1 -1
- package/dist/index.mjs +18 -18
- package/dist/qidian-vue-ui.css +96 -85
- package/package.json +1 -1
- package/dist/components/crud/list.vue.mjs +0 -8
- package/dist/components/crud/list.vue.mjs.map +0 -1
- package/dist/components/crud/list.vue2.mjs.map +0 -1
- package/dist/components/crud/props.mjs +0 -37
- package/dist/components/crud/props.mjs.map +0 -1
- package/dist/components/crud/search.vue.mjs +0 -8
- package/dist/components/crud/search.vue.mjs.map +0 -1
- package/dist/components/crud/search.vue2.mjs.map +0 -1
- package/dist/components/crud/table.vue.mjs +0 -8
- package/dist/components/crud/table.vue.mjs.map +0 -1
- package/dist/components/crud/table.vue2.mjs.map +0 -1
- package/dist/components/dict/checkbox-group.vue.mjs +0 -8
- package/dist/components/dict/checkbox-group.vue.mjs.map +0 -1
- package/dist/components/dict/checkbox-group.vue2.mjs.map +0 -1
- package/dist/components/dict/props.d.ts +0 -32
- package/dist/components/dict/props.mjs +0 -40
- package/dist/components/dict/props.mjs.map +0 -1
- package/dist/components/dict/radio-group.vue.mjs +0 -8
- package/dist/components/dict/radio-group.vue.mjs.map +0 -1
- package/dist/components/dict/radio-group.vue2.mjs.map +0 -1
- package/dist/components/dict/select.vue.mjs.map +0 -1
- package/dist/components/dict/select.vue2.mjs +0 -5
- package/dist/components/dict/select.vue2.mjs.map +0 -1
- package/dist/components/dict/tag.vue.mjs +0 -8
- package/dist/components/dict/tag.vue.mjs.map +0 -1
- package/dist/components/dict/tag.vue2.mjs.map +0 -1
- package/dist/components/dict/types.d.ts +0 -22
- package/dist/components/service/list.vue.mjs +0 -8
- package/dist/components/service/list.vue.mjs.map +0 -1
- package/dist/components/service/list.vue2.mjs.map +0 -1
- package/dist/components/service/props.mjs.map +0 -1
- package/dist/components/service/select.vue.mjs +0 -8
- package/dist/components/service/select.vue.mjs.map +0 -1
- package/dist/components/service/select.vue2.mjs.map +0 -1
- package/dist/components/service/table.vue.mjs +0 -8
- package/dist/components/service/table.vue.mjs.map +0 -1
- package/dist/components/service/table.vue2.mjs.map +0 -1
- package/dist/components/service/types.d.ts +0 -44
- /package/dist/components/crud/{list.vue.d.ts → list/index.vue.d.ts} +0 -0
- /package/dist/components/crud/{table.vue.d.ts → table/index.vue.d.ts} +0 -0
- /package/dist/components/dict/{checkbox-group.vue.d.ts → checkbox-group/index.vue.d.ts} +0 -0
- /package/dist/components/dict/{radio-group.vue.d.ts → radio-group/index.vue.d.ts} +0 -0
- /package/dist/components/dict/{select.vue.d.ts → select/index.vue.d.ts} +0 -0
- /package/dist/components/service/{list.vue.d.ts → list/index.vue.d.ts} +0 -0
- /package/dist/components/service/{select.vue.d.ts → select/index.vue.d.ts} +0 -0
- /package/dist/components/service/{table.vue.d.ts → table/index.vue.d.ts} +0 -0
|
@@ -1,29 +1,3 @@
|
|
|
1
|
-
export declare const qdCrudSearchProps: {
|
|
2
|
-
readonly defaultClearable: true;
|
|
3
|
-
readonly grid: () => {
|
|
4
|
-
col: {
|
|
5
|
-
xs: number;
|
|
6
|
-
sm: number;
|
|
7
|
-
md: number;
|
|
8
|
-
lg: number;
|
|
9
|
-
xl: number;
|
|
10
|
-
xxl: number;
|
|
11
|
-
};
|
|
12
|
-
};
|
|
13
|
-
readonly gutter: () => number[];
|
|
14
|
-
readonly data: () => any;
|
|
15
|
-
readonly disabled: undefined;
|
|
16
|
-
readonly readonly: undefined;
|
|
17
|
-
readonly labelAlign: "top";
|
|
18
|
-
readonly labelWidth: "auto";
|
|
19
|
-
readonly requiredMarkPosition: "left";
|
|
20
|
-
readonly resetType: "initial";
|
|
21
|
-
readonly scrollToFirstError: "smooth";
|
|
22
|
-
readonly preventSubmitDefault: true;
|
|
23
|
-
readonly requiredMark: undefined;
|
|
24
|
-
readonly showErrorMessage: true;
|
|
25
|
-
readonly statusIcon: undefined;
|
|
26
|
-
};
|
|
27
1
|
export declare const qdCrudTableProps: {
|
|
28
2
|
readonly searchData: () => {};
|
|
29
3
|
readonly form: undefined;
|
|
@@ -63,8 +37,3 @@ export declare const qdCrudTableProps: {
|
|
|
63
37
|
readonly headerBg: true;
|
|
64
38
|
readonly loadingWithData: true;
|
|
65
39
|
};
|
|
66
|
-
export declare const qdCrudListProps: {
|
|
67
|
-
searchData: () => {};
|
|
68
|
-
data: () => never[];
|
|
69
|
-
loadingWithData: true;
|
|
70
|
-
};
|
|
@@ -0,0 +1,16 @@
|
|
|
1
|
+
import { qdServiceTableProps } from "../../service/table/props.mjs";
|
|
2
|
+
const qdCrudTableProps = {
|
|
3
|
+
...qdServiceTableProps,
|
|
4
|
+
searchData: () => ({}),
|
|
5
|
+
form: void 0,
|
|
6
|
+
add: void 0,
|
|
7
|
+
actions: void 0,
|
|
8
|
+
edit: void 0,
|
|
9
|
+
view: void 0,
|
|
10
|
+
del: void 0,
|
|
11
|
+
rowActions: void 0
|
|
12
|
+
};
|
|
13
|
+
export {
|
|
14
|
+
qdCrudTableProps
|
|
15
|
+
};
|
|
16
|
+
//# sourceMappingURL=props.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.mjs","sources":["../../../../src/components/crud/table/props.ts"],"sourcesContent":["import { qdServiceTableProps } from '../../service/table/props'\n\nexport const qdCrudTableProps = {\n ...qdServiceTableProps,\n\n searchData: () => ({}),\n form: undefined,\n add: undefined,\n actions: undefined,\n edit: undefined,\n view: undefined,\n del: undefined,\n rowActions: undefined\n} as const\n"],"names":[],"mappings":";AAEO,MAAM,mBAAmB;AAAA,EAC9B,GAAG;AAAA,EAEH,YAAY,OAAO,CAAA;AAAA,EACnB,MAAM;AAAA,EACN,KAAK;AAAA,EACL,SAAS;AAAA,EACT,MAAM;AAAA,EACN,MAAM;AAAA,EACN,KAAK;AAAA,EACL,YAAY;AACd;"}
|
|
@@ -1,13 +1,9 @@
|
|
|
1
1
|
import type { DialogOptions, PrimaryTableCellParams, TableRowData, TdButtonProps, TdLinkProps } from 'tdesign-vue-next';
|
|
2
2
|
import type { ServicePageParams, ServicePagination } from 'qidian-shared';
|
|
3
|
-
import type { QdDialogFormProps } from '
|
|
4
|
-
import type {
|
|
5
|
-
import type {
|
|
6
|
-
import type {
|
|
7
|
-
export interface QdSearchProps extends Omit<QdFormProps, 'onReset'> {
|
|
8
|
-
onSearch?: () => void;
|
|
9
|
-
onReset?: () => void;
|
|
10
|
-
}
|
|
3
|
+
import type { QdDialogFormProps } from '../../dialog';
|
|
4
|
+
import type { QdServiceTableProps, QdServiceTableInstanceFunctions } from '../../service';
|
|
5
|
+
import type { Qd2ConfigValue, QdComponentConfig } from '../../config-renderer';
|
|
6
|
+
import type { QdCrudSearchProps } from '../search';
|
|
11
7
|
export type TableDialogServiceRes = void | boolean | {
|
|
12
8
|
success: boolean;
|
|
13
9
|
message?: string;
|
|
@@ -54,8 +50,8 @@ export interface QdCrudTableDeleteAction<D extends TableRowData = TableRowData,
|
|
|
54
50
|
export interface QdCrudTableProps<D extends TableRowData = TableRowData, R = unknown, P = ServicePageParams, TP = P, Pag extends ServicePagination = ServicePagination> extends QdServiceTableProps<D, R, P, TP, Pag> {
|
|
55
51
|
title?: string;
|
|
56
52
|
permiPrefix?: string;
|
|
57
|
-
search?: Omit<
|
|
58
|
-
searchData?:
|
|
53
|
+
search?: Omit<QdCrudSearchProps, 'data'>;
|
|
54
|
+
searchData?: QdCrudSearchProps['data'];
|
|
59
55
|
form?: QdCrudTableWrapper['form'];
|
|
60
56
|
detail?: QdCrudDetail;
|
|
61
57
|
add?: false | QdCrudTableAction<D>;
|
|
@@ -66,8 +62,3 @@ export interface QdCrudTableProps<D extends TableRowData = TableRowData, R = unk
|
|
|
66
62
|
rowActions?: QdCrudTableRowAction<D>[];
|
|
67
63
|
}
|
|
68
64
|
export type QdCrudTableInstanceFunctions<D extends TableRowData = TableRowData, R = unknown, P = ServicePageParams, TP = P, Pag extends ServicePagination = ServicePagination> = QdServiceTableInstanceFunctions<D, R, P, TP, Pag>;
|
|
69
|
-
export interface QdCrudListProps<D extends TableRowData = TableRowData, R = unknown, P = ServicePageParams, TP = P, Pag extends ServicePagination = ServicePagination> extends QdServiceListProps<D, R, P, TP, Pag> {
|
|
70
|
-
search?: Omit<QdSearchProps, 'data'>;
|
|
71
|
-
searchData?: QdSearchProps['data'];
|
|
72
|
-
}
|
|
73
|
-
export type QdCrudListInstanceFunctions<D extends TableRowData = TableRowData, R = unknown, P = ServicePageParams, TP = P, Pag extends ServicePagination = ServicePagination> = QdServiceListInstanceFunctions<D, R, P, TP, Pag>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import _sfc_main from "./index.vue2.mjs";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import _export_sfc from "../../../_virtual/_plugin-vue_export-helper.mjs";
|
|
4
|
+
const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-56e2ef97"]]);
|
|
5
|
+
export {
|
|
6
|
+
index as default
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=index.vue.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
import { defineComponent, mergeDefaults, computed, toRef, withDirectives, createBlock, openBlock, unref, mergeProps } from "vue";
|
|
2
|
-
import { qdDictConvStrSeparator
|
|
2
|
+
import { qdDictConvStrSeparator } from "../tag/props.mjs";
|
|
3
|
+
import { qdDictCheckboxGroupProps } from "./props.mjs";
|
|
3
4
|
import { CheckboxGroup, LoadingDirective } from "tdesign-vue-next";
|
|
4
|
-
import { useVModels } from "
|
|
5
|
-
import "
|
|
6
|
-
import "
|
|
5
|
+
import { useVModels } from "../../../node_modules/.pnpm/@vueuse_core@14.0.0_vue@3.5.22_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.mjs";
|
|
6
|
+
import "../../../hooks/useAgentChat/index.mjs";
|
|
7
|
+
import "../../../locales/zh-CN.mjs";
|
|
7
8
|
import { isEmpty } from "qidian-shared";
|
|
8
|
-
import { useDictDynamic } from "
|
|
9
|
+
import { useDictDynamic } from "../../../hooks/useDict/index.mjs";
|
|
9
10
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
10
11
|
...{
|
|
11
12
|
name: "QdDictCheckboxGroup"
|
|
12
13
|
},
|
|
13
|
-
__name: "
|
|
14
|
+
__name: "index",
|
|
14
15
|
props: /* @__PURE__ */ mergeDefaults({
|
|
15
16
|
dictType: {},
|
|
16
17
|
convStr: { type: [Boolean, String] },
|
|
@@ -35,14 +36,18 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
35
36
|
if (isEmpty(modelValue.value)) return [];
|
|
36
37
|
if (typeof modelValue.value === "string") {
|
|
37
38
|
const { convStr } = reProps.value;
|
|
38
|
-
return modelValue.value.split(
|
|
39
|
+
return modelValue.value.split(
|
|
40
|
+
(typeof convStr === "string" ? convStr : "") || qdDictConvStrSeparator
|
|
41
|
+
);
|
|
39
42
|
}
|
|
40
43
|
return modelValue.value;
|
|
41
44
|
},
|
|
42
45
|
set: (val) => {
|
|
43
46
|
const { convStr } = reProps.value;
|
|
44
47
|
if (convStr) {
|
|
45
|
-
modelValue.value = val.join(
|
|
48
|
+
modelValue.value = val.join(
|
|
49
|
+
(typeof convStr === "string" ? convStr : "") || qdDictConvStrSeparator
|
|
50
|
+
);
|
|
46
51
|
} else {
|
|
47
52
|
modelValue.value = val;
|
|
48
53
|
}
|
|
@@ -75,4 +80,4 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
75
80
|
export {
|
|
76
81
|
_sfc_main as default
|
|
77
82
|
};
|
|
78
|
-
//# sourceMappingURL=
|
|
83
|
+
//# sourceMappingURL=index.vue2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue2.mjs","sources":["../../../../src/components/dict/checkbox-group/index.vue"],"sourcesContent":["<template>\n <t-checkbox-group\n v-model=\"reModelValue\"\n v-loading=\"{ loading: dictLoading, size: 'small' }\"\n class=\"qd-dict-checkbox-group\"\n v-bind=\"reProps.checkboxOptions\"\n :options=\"dictOptions\"\n />\n</template>\n\n<script setup lang=\"ts\">\n import type { QdDictCheckboxGroupProps } from './types'\n import { qdDictConvStrSeparator } from '../tag/props'\n import { qdDictCheckboxGroupProps } from './props'\n import { LoadingDirective, CheckboxGroup as TCheckboxGroup } from 'tdesign-vue-next'\n import { useVModels } from '@vueuse/core'\n import { computed, toRef } from 'vue'\n import { useDictDynamic } from '../../../hooks'\n import { isEmpty } from 'qidian-shared'\n\n defineOptions({\n name: 'QdDictCheckboxGroup'\n })\n\n const vLoading = LoadingDirective\n\n const props = withDefaults(defineProps<QdDictCheckboxGroupProps>(), qdDictCheckboxGroupProps)\n const emit = defineEmits<{\n 'update:modelValue': [QdDictCheckboxGroupProps['modelValue']]\n }>()\n\n const { modelValue } = useVModels(props, emit, { passive: true })\n\n const reModelValue = computed({\n get: () => {\n if (isEmpty(modelValue.value)) return []\n if (typeof modelValue.value === 'string') {\n const { convStr } = reProps.value\n return modelValue.value.split(\n (typeof convStr === 'string' ? convStr : '') || qdDictConvStrSeparator\n )\n }\n return modelValue.value\n },\n set: (val) => {\n const { convStr } = reProps.value\n if (convStr) {\n modelValue.value = val.join(\n (typeof convStr === 'string' ? convStr : '') || qdDictConvStrSeparator\n )\n } else {\n modelValue.value = val\n }\n }\n })\n\n const dictType = toRef(props, 'dictType')\n\n const reProps = computed(() => {\n const { modelValue, dictType, convStr, ...checkboxOptions } = props\n\n return {\n dictType,\n convStr,\n checkboxOptions,\n models: {\n modelValue\n }\n }\n })\n\n const { options: dictOptions, loading: dictLoading } = useDictDynamic(dictType)\n</script>\n\n<style lang=\"less\" scoped>\n .qd-dict-checkbox-group {\n :deep(.t-loading) {\n position: relative;\n }\n }\n</style>\n"],"names":["modelValue","dictType","_withDirectives","_openBlock","_createBlock","_unref","_mergeProps"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAwBE,UAAM,WAAW;AAEjB,UAAM,QAAQ;AACd,UAAM,OAAO;AAIb,UAAM,EAAE,eAAe,WAAW,OAAO,MAAM,EAAE,SAAS,MAAM;AAEhE,UAAM,eAAe,SAAS;AAAA,MAC5B,KAAK,MAAM;AACT,YAAI,QAAQ,WAAW,KAAK,UAAU,CAAA;AACtC,YAAI,OAAO,WAAW,UAAU,UAAU;AACxC,gBAAM,EAAE,YAAY,QAAQ;AAC5B,iBAAO,WAAW,MAAM;AAAA,aACrB,OAAO,YAAY,WAAW,UAAU,OAAO;AAAA,UAAA;AAAA,QAEpD;AACA,eAAO,WAAW;AAAA,MACpB;AAAA,MACA,KAAK,CAAC,QAAQ;AACZ,cAAM,EAAE,YAAY,QAAQ;AAC5B,YAAI,SAAS;AACX,qBAAW,QAAQ,IAAI;AAAA,aACpB,OAAO,YAAY,WAAW,UAAU,OAAO;AAAA,UAAA;AAAA,QAEpD,OAAO;AACL,qBAAW,QAAQ;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAED,UAAM,WAAW,MAAM,OAAO,UAAU;AAExC,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM,EAAE,YAAAA,aAAY,UAAAC,WAAU,SAAS,GAAG,oBAAoB;AAE9D,aAAO;AAAA,QACL,UAAAA;AAAAA,QACA;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,UACN,YAAAD;AAAAA,QAAA;AAAA,MACF;AAAA,IAEJ,CAAC;AAED,UAAM,EAAE,SAAS,aAAa,SAAS,YAAA,IAAgB,eAAe,QAAQ;;AAtE9E,aAAAE,gBAAAC,aAAAC,YAMEC,sBANFC,WAME;AAAA,oBALS,aAAA;AAAA,qEAAA,aAAY,QAAA;AAAA,QAErB,OAAM;AAAA,MAAA,GACE,QAAA,MAAQ,iBAAe,EAC9B,SAASD,MAAA,WAAA,EAAA,CAAW,GAAA,MAAA,IAAA,CAAA,cAAA,SAAA,CAAA,IAAA;AAAA,qCAHCA,MAAA,WAAA,GAAW,MAAA,QAAA,CAAA;AAAA,MAAA;;;;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
export declare const qdDictCheckboxGroupProps: {
|
|
2
|
+
readonly max: undefined;
|
|
3
|
+
readonly disabled: undefined;
|
|
4
|
+
readonly readonly: undefined;
|
|
5
|
+
readonly modelValue: () => never[];
|
|
6
|
+
readonly value: () => never[];
|
|
7
|
+
readonly defaultValue: () => never[];
|
|
8
|
+
readonly convStr: false;
|
|
9
|
+
};
|
|
@@ -0,0 +1,13 @@
|
|
|
1
|
+
const qdDictCheckboxGroupProps = {
|
|
2
|
+
max: void 0,
|
|
3
|
+
disabled: void 0,
|
|
4
|
+
readonly: void 0,
|
|
5
|
+
modelValue: () => [],
|
|
6
|
+
value: () => [],
|
|
7
|
+
defaultValue: () => [],
|
|
8
|
+
convStr: false
|
|
9
|
+
};
|
|
10
|
+
export {
|
|
11
|
+
qdDictCheckboxGroupProps
|
|
12
|
+
};
|
|
13
|
+
//# sourceMappingURL=props.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.mjs","sources":["../../../../src/components/dict/checkbox-group/props.ts"],"sourcesContent":["export const qdDictCheckboxGroupProps = {\n max: undefined,\n disabled: undefined,\n readonly: undefined,\n modelValue: () => [],\n value: () => [],\n defaultValue: () => [],\n convStr: false\n} as const\n"],"names":[],"mappings":"AAAO,MAAM,2BAA2B;AAAA,EACtC,KAAK;AAAA,EACL,UAAU;AAAA,EACV,UAAU;AAAA,EACV,YAAY,MAAM,CAAA;AAAA,EAClB,OAAO,MAAM,CAAA;AAAA,EACb,cAAc,MAAM,CAAA;AAAA,EACpB,SAAS;AACX;"}
|
|
@@ -0,0 +1,6 @@
|
|
|
1
|
+
import type { TdCheckboxGroupProps, CheckboxGroupValue } from 'tdesign-vue-next';
|
|
2
|
+
export interface QdDictCheckboxGroupProps extends Omit<TdCheckboxGroupProps, 'modelValue' | 'options'> {
|
|
3
|
+
dictType: string;
|
|
4
|
+
convStr?: boolean | string;
|
|
5
|
+
modelValue?: CheckboxGroupValue | string;
|
|
6
|
+
}
|
|
@@ -1,5 +1,4 @@
|
|
|
1
|
-
export
|
|
2
|
-
export
|
|
3
|
-
export
|
|
4
|
-
export
|
|
5
|
-
export type { QdDictSelectProps, QdDictRadioGroupProps, QdDictCheckboxGroupProps, QdDictTagProps } from './types';
|
|
1
|
+
export * from './checkbox-group';
|
|
2
|
+
export * from './radio-group';
|
|
3
|
+
export * from './select';
|
|
4
|
+
export * from './tag';
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import _sfc_main from "./index.vue2.mjs";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import _export_sfc from "../../../_virtual/_plugin-vue_export-helper.mjs";
|
|
4
|
+
const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-73c16860"]]);
|
|
5
|
+
export {
|
|
6
|
+
index as default
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=index.vue.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import { defineComponent, mergeDefaults, toRef, computed, withDirectives, createBlock, openBlock, unref, mergeProps, isRef } from "vue";
|
|
2
2
|
import { qdDictRadioGroupProps } from "./props.mjs";
|
|
3
3
|
import { RadioGroup, LoadingDirective } from "tdesign-vue-next";
|
|
4
|
-
import { useVModels } from "
|
|
5
|
-
import "
|
|
6
|
-
import "
|
|
4
|
+
import { useVModels } from "../../../node_modules/.pnpm/@vueuse_core@14.0.0_vue@3.5.22_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.mjs";
|
|
5
|
+
import "../../../hooks/useAgentChat/index.mjs";
|
|
6
|
+
import "../../../locales/zh-CN.mjs";
|
|
7
7
|
import "qidian-shared";
|
|
8
|
-
import { useDictDynamic } from "
|
|
8
|
+
import { useDictDynamic } from "../../../hooks/useDict/index.mjs";
|
|
9
9
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
10
10
|
...{
|
|
11
11
|
name: "QdDictRadioGroup"
|
|
12
12
|
},
|
|
13
|
-
__name: "
|
|
13
|
+
__name: "index",
|
|
14
14
|
props: /* @__PURE__ */ mergeDefaults({
|
|
15
15
|
dictType: {},
|
|
16
16
|
allowUncheck: { type: Boolean },
|
|
@@ -57,4 +57,4 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
57
57
|
export {
|
|
58
58
|
_sfc_main as default
|
|
59
59
|
};
|
|
60
|
-
//# sourceMappingURL=
|
|
60
|
+
//# sourceMappingURL=index.vue2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue2.mjs","sources":["../../../../src/components/dict/radio-group/index.vue"],"sourcesContent":["<template>\n <t-radio-group\n v-model=\"modelValue\"\n v-loading=\"{ loading: dictLoading, size: 'small' }\"\n class=\"qd-dict-radio-group\"\n v-bind=\"reProps.radioOptions\"\n :options=\"dictOptions\"\n />\n</template>\n\n<script setup lang=\"ts\">\n import type { QdDictRadioGroupProps } from './types'\n import { qdDictRadioGroupProps } from './props'\n import { LoadingDirective, RadioGroup as TRadioGroup } from 'tdesign-vue-next'\n import { useVModels } from '@vueuse/core'\n import { computed, toRef } from 'vue'\n import { useDictDynamic } from '../../../hooks'\n\n defineOptions({\n name: 'QdDictRadioGroup'\n })\n\n const vLoading = LoadingDirective\n\n const props = withDefaults(defineProps<QdDictRadioGroupProps>(), qdDictRadioGroupProps)\n const emit = defineEmits<{\n 'update:modelValue': [QdDictRadioGroupProps['modelValue']]\n }>()\n\n const { modelValue } = useVModels(props, emit, { passive: true })\n\n const dictType = toRef(props, 'dictType')\n\n const reProps = computed(() => {\n const { modelValue, dictType, ...radioOptions } = props\n\n return {\n dictType,\n radioOptions,\n models: {\n modelValue\n }\n }\n })\n\n const { options: dictOptions, loading: dictLoading } = useDictDynamic(dictType)\n</script>\n\n<style lang=\"less\" scoped>\n .qd-dict-radio-group {\n :deep(.t-loading) {\n position: relative;\n }\n }\n</style>\n"],"names":["modelValue","dictType","_withDirectives","_openBlock","_createBlock","_unref","_mergeProps"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAsBE,UAAM,WAAW;AAEjB,UAAM,QAAQ;AACd,UAAM,OAAO;AAIb,UAAM,EAAE,eAAe,WAAW,OAAO,MAAM,EAAE,SAAS,MAAM;AAEhE,UAAM,WAAW,MAAM,OAAO,UAAU;AAExC,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM,EAAE,YAAAA,aAAY,UAAAC,WAAU,GAAG,iBAAiB;AAElD,aAAO;AAAA,QACL,UAAAA;AAAAA,QACA;AAAA,QACA,QAAQ;AAAA,UACN,YAAAD;AAAAA,QAAA;AAAA,MACF;AAAA,IAEJ,CAAC;AAED,UAAM,EAAE,SAAS,aAAa,SAAS,YAAA,IAAgB,eAAe,QAAQ;;AA5C9E,aAAAE,gBAAAC,aAAAC,YAMEC,mBANFC,WAME;AAAA,oBALSD,MAAA,UAAA;AAAA,yFAAA,WAAU,QAAA,SAAA;AAAA,QAEnB,OAAM;AAAA,MAAA,GACE,QAAA,MAAQ,cAAY,EAC3B,SAASA,MAAA,WAAA,EAAA,CAAW,GAAA,MAAA,IAAA,CAAA,cAAA,SAAA,CAAA,IAAA;AAAA,qCAHCA,MAAA,WAAA,GAAW,MAAA,QAAA,CAAA;AAAA,MAAA;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.mjs","sources":["../../../../src/components/dict/radio-group/props.ts"],"sourcesContent":["export const qdDictRadioGroupProps = {\n allowUncheck: false,\n disabled: undefined,\n readonly: undefined,\n theme: 'radio',\n variant: 'outline'\n} as const\n"],"names":[],"mappings":"AAAO,MAAM,wBAAwB;AAAA,EACnC,cAAc;AAAA,EACd,UAAU;AAAA,EACV,UAAU;AAAA,EACV,OAAO;AAAA,EACP,SAAS;AACX;"}
|
|
@@ -1,16 +1,17 @@
|
|
|
1
1
|
import { defineComponent, mergeDefaults, computed, toRef, createBlock, openBlock, unref, mergeProps, isRef, createSlots, renderList, withCtx, renderSlot, normalizeProps, guardReactiveProps } from "vue";
|
|
2
|
-
import { qdDictConvStrSeparator
|
|
2
|
+
import { qdDictConvStrSeparator } from "../tag/props.mjs";
|
|
3
|
+
import { qdDictSelectProps } from "./props.mjs";
|
|
3
4
|
import { Select } from "tdesign-vue-next";
|
|
4
|
-
import { useVModels } from "
|
|
5
|
-
import "
|
|
6
|
-
import "
|
|
5
|
+
import { useVModels } from "../../../node_modules/.pnpm/@vueuse_core@14.0.0_vue@3.5.22_typescript@5.9.3_/node_modules/@vueuse/core/dist/index.mjs";
|
|
6
|
+
import "../../../hooks/useAgentChat/index.mjs";
|
|
7
|
+
import "../../../locales/zh-CN.mjs";
|
|
7
8
|
import { isEmpty } from "qidian-shared";
|
|
8
|
-
import { useDictDynamic } from "
|
|
9
|
+
import { useDictDynamic } from "../../../hooks/useDict/index.mjs";
|
|
9
10
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
10
11
|
...{
|
|
11
12
|
name: "QdDictSelect"
|
|
12
13
|
},
|
|
13
|
-
__name: "
|
|
14
|
+
__name: "index",
|
|
14
15
|
props: /* @__PURE__ */ mergeDefaults({
|
|
15
16
|
dictType: {},
|
|
16
17
|
defaultSelectFirst: { type: Boolean },
|
|
@@ -163,4 +164,4 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
163
164
|
export {
|
|
164
165
|
_sfc_main as default
|
|
165
166
|
};
|
|
166
|
-
//# sourceMappingURL=
|
|
167
|
+
//# sourceMappingURL=index.vue.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue.mjs","sources":["../../../../src/components/dict/select/index.vue"],"sourcesContent":["<template>\n <t-select\n v-model=\"reModelValue\"\n v-model:input-value=\"inputValue\"\n v-model:popup-visible=\"popupVisible\"\n v-bind=\"reProps.selectOptions\"\n :options=\"dictOptions\"\n :loading=\"dictLoading || reProps.loading\"\n >\n <template v-for=\"(_, name) in $slots\" #[name]=\"slotProps\">\n <slot :name=\"name\" v-bind=\"slotProps\" />\n </template>\n </t-select>\n</template>\n\n<script setup lang=\"ts\">\n import type { TdSelectProps } from 'tdesign-vue-next'\n import type { QdDictSelectProps } from './types'\n import { qdDictConvStrSeparator } from '../tag/props'\n import { qdDictSelectProps } from './props'\n import { Select as TSelect } from 'tdesign-vue-next'\n import { useVModels } from '@vueuse/core'\n import { computed, toRef } from 'vue'\n import { useDictDynamic } from '../../../hooks'\n import { isEmpty } from 'qidian-shared'\n\n defineOptions({\n name: 'QdDictSelect'\n })\n\n const props = withDefaults(defineProps<QdDictSelectProps>(), qdDictSelectProps)\n const emit = defineEmits<{\n 'update:modelValue': [QdDictSelectProps['modelValue']]\n 'update:inputValue': [QdDictSelectProps['inputValue']]\n 'update:popupVisible': [QdDictSelectProps['popupVisible']]\n }>()\n\n const { modelValue, inputValue, popupVisible } = useVModels(props, emit, { passive: true })\n\n const reModelValue = computed({\n get: () => {\n const { convStr, selectOptions } = reProps.value\n const { multiple, valueType } = selectOptions\n if (!multiple || valueType === 'object') return modelValue.value\n\n if (isEmpty(modelValue.value)) return []\n if (typeof modelValue.value === 'string') {\n return modelValue.value.split(\n (typeof convStr === 'string' ? convStr : '') || qdDictConvStrSeparator\n )\n }\n return modelValue.value\n },\n set: (val) => {\n const { convStr, selectOptions } = reProps.value\n const { multiple, valueType } = selectOptions\n if (!multiple || valueType === 'object') {\n modelValue.value = val\n return\n }\n\n if (convStr && Array.isArray(val)) {\n modelValue.value = val.join(\n (typeof convStr === 'string' ? convStr : '') || qdDictConvStrSeparator\n )\n } else {\n modelValue.value = val\n }\n }\n })\n\n const dictType = toRef(props, 'dictType')\n\n const reProps = computed(() => {\n const {\n convStr,\n modelValue,\n inputValue,\n popupVisible,\n dictType,\n loading,\n defaultSelectFirst,\n ...selectOptions\n } = props\n\n return {\n convStr,\n dictType,\n loading,\n defaultSelectFirst,\n selectOptions: selectOptions as TdSelectProps,\n models: {\n modelValue,\n inputValue,\n popupVisible\n }\n }\n })\n\n const { options: dictOptions, loading: dictLoading } = useDictDynamic(dictType, {\n onInit: (options) => {\n // 当 defaultSelectFirst 为 true 且 modelValue 为空时,默认选中第一个\n if (reProps.value.defaultSelectFirst && isEmpty(reModelValue.value) && options.length) {\n reModelValue.value = options[0]?.value\n }\n }\n })\n</script>\n"],"names":["modelValue","inputValue","popupVisible","dictType","_openBlock","_createBlock","_unref","_mergeProps","$slots","_withCtx","_renderSlot","_normalizeProps","_guardReactiveProps"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AA8BE,UAAM,QAAQ;AACd,UAAM,OAAO;AAMb,UAAM,EAAE,YAAY,YAAY,iBAAiB,WAAW,OAAO,MAAM,EAAE,SAAS,MAAM;AAE1F,UAAM,eAAe,SAAS;AAAA,MAC5B,KAAK,MAAM;AACT,cAAM,EAAE,SAAS,cAAA,IAAkB,QAAQ;AAC3C,cAAM,EAAE,UAAU,UAAA,IAAc;AAChC,YAAI,CAAC,YAAY,cAAc,iBAAiB,WAAW;AAE3D,YAAI,QAAQ,WAAW,KAAK,UAAU,CAAA;AACtC,YAAI,OAAO,WAAW,UAAU,UAAU;AACxC,iBAAO,WAAW,MAAM;AAAA,aACrB,OAAO,YAAY,WAAW,UAAU,OAAO;AAAA,UAAA;AAAA,QAEpD;AACA,eAAO,WAAW;AAAA,MACpB;AAAA,MACA,KAAK,CAAC,QAAQ;AACZ,cAAM,EAAE,SAAS,cAAA,IAAkB,QAAQ;AAC3C,cAAM,EAAE,UAAU,UAAA,IAAc;AAChC,YAAI,CAAC,YAAY,cAAc,UAAU;AACvC,qBAAW,QAAQ;AACnB;AAAA,QACF;AAEA,YAAI,WAAW,MAAM,QAAQ,GAAG,GAAG;AACjC,qBAAW,QAAQ,IAAI;AAAA,aACpB,OAAO,YAAY,WAAW,UAAU,OAAO;AAAA,UAAA;AAAA,QAEpD,OAAO;AACL,qBAAW,QAAQ;AAAA,QACrB;AAAA,MACF;AAAA,IAAA,CACD;AAED,UAAM,WAAW,MAAM,OAAO,UAAU;AAExC,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM;AAAA,QACJ;AAAA,QACA,YAAAA;AAAAA,QACA,YAAAC;AAAAA,QACA,cAAAC;AAAAA,QACA,UAAAC;AAAAA,QACA;AAAA,QACA;AAAA,QACA,GAAG;AAAA,MAAA,IACD;AAEJ,aAAO;AAAA,QACL;AAAA,QACA,UAAAA;AAAAA,QACA;AAAA,QACA;AAAA,QACA;AAAA,QACA,QAAQ;AAAA,UACN,YAAAH;AAAAA,UACA,YAAAC;AAAAA,UACA,cAAAC;AAAAA,QAAA;AAAA,MACF;AAAA,IAEJ,CAAC;AAED,UAAM,EAAE,SAAS,aAAa,SAAS,YAAA,IAAgB,eAAe,UAAU;AAAA,MAC9E,QAAQ,CAAC,YAAY;AAEnB,YAAI,QAAQ,MAAM,sBAAsB,QAAQ,aAAa,KAAK,KAAK,QAAQ,QAAQ;AACrF,uBAAa,QAAQ,QAAQ,CAAC,GAAG;AAAA,QACnC;AAAA,MACF;AAAA,IAAA,CACD;;AAzGD,aAAAE,aAAAC,YAWWC,eAXXC,WAWW;AAAA,oBAVA,aAAA;AAAA,qEAAA,aAAY,QAAA;AAAA,QACb,eAAaD,MAAA,UAAA;AAAA,yFAAA,WAAU,QAAA,SAAA;AAAA,QACvB,iBAAeA,MAAA,YAAA;AAAA,6FAAA,aAAY,QAAA,SAAA;AAAA,MAAA,GAC3B,QAAA,MAAQ,eAAa;AAAA,QAC5B,SAASA,MAAA,WAAA;AAAA,QACT,SAASA,MAAA,WAAA,KAAe,QAAA,MAAQ;AAAA,MAAA;mBAEHE,KAAAA,QAAM,CAAlB,GAAG,SAAI;;;YACvB,IAAAC,QAAA,CAD6C,cAAS;AAAA,cACtDC,WAAwC,KAAA,QAA3B,MAAIC,eAAAC,mBAAU,SAAS,CAAA,CAAA;AAAA,YAAA;;;;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue2.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";"}
|
|
@@ -0,0 +1,11 @@
|
|
|
1
|
+
export declare const qdDictSelectProps: {
|
|
2
|
+
readonly showArrow: true;
|
|
3
|
+
readonly filterable: true;
|
|
4
|
+
readonly popupVisible: undefined;
|
|
5
|
+
readonly disabled: undefined;
|
|
6
|
+
readonly clearable: false;
|
|
7
|
+
readonly readonly: undefined;
|
|
8
|
+
readonly valueType: "value";
|
|
9
|
+
readonly defaultSelectFirst: false;
|
|
10
|
+
readonly convStr: false;
|
|
11
|
+
};
|
|
@@ -0,0 +1,15 @@
|
|
|
1
|
+
const qdDictSelectProps = {
|
|
2
|
+
showArrow: true,
|
|
3
|
+
filterable: true,
|
|
4
|
+
popupVisible: void 0,
|
|
5
|
+
disabled: void 0,
|
|
6
|
+
clearable: false,
|
|
7
|
+
readonly: void 0,
|
|
8
|
+
valueType: "value",
|
|
9
|
+
defaultSelectFirst: false,
|
|
10
|
+
convStr: false
|
|
11
|
+
};
|
|
12
|
+
export {
|
|
13
|
+
qdDictSelectProps
|
|
14
|
+
};
|
|
15
|
+
//# sourceMappingURL=props.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.mjs","sources":["../../../../src/components/dict/select/props.ts"],"sourcesContent":["export const qdDictSelectProps = {\n showArrow: true,\n filterable: true,\n popupVisible: undefined,\n disabled: undefined,\n clearable: false,\n readonly: undefined,\n valueType: 'value',\n defaultSelectFirst: false,\n convStr: false\n} as const\n"],"names":[],"mappings":"AAAO,MAAM,oBAAoB;AAAA,EAC/B,WAAW;AAAA,EACX,YAAY;AAAA,EACZ,cAAc;AAAA,EACd,UAAU;AAAA,EACV,WAAW;AAAA,EACX,UAAU;AAAA,EACV,WAAW;AAAA,EACX,oBAAoB;AAAA,EACpB,SAAS;AACX;"}
|
|
@@ -0,0 +1,7 @@
|
|
|
1
|
+
import type { TdSelectProps } from 'tdesign-vue-next';
|
|
2
|
+
import type { QdDictItem } from '../../../hooks';
|
|
3
|
+
export interface QdDictSelectProps extends Omit<TdSelectProps<QdDictItem>, 'options'> {
|
|
4
|
+
dictType: string;
|
|
5
|
+
defaultSelectFirst?: boolean;
|
|
6
|
+
convStr?: boolean | string;
|
|
7
|
+
}
|
|
@@ -1,16 +1,16 @@
|
|
|
1
1
|
import type { QdDictTagProps } from './types';
|
|
2
2
|
declare var __VLS_1: {
|
|
3
|
-
item: import("
|
|
3
|
+
item: import("../../..").QdDictItem;
|
|
4
4
|
}, __VLS_3: {
|
|
5
|
-
item: import("
|
|
5
|
+
item: import("../../..").QdDictItem;
|
|
6
6
|
}, __VLS_5: {
|
|
7
|
-
item: import("
|
|
7
|
+
item: import("../../..").QdDictItem;
|
|
8
8
|
}, __VLS_11: {
|
|
9
|
-
item: import("
|
|
9
|
+
item: import("../../..").QdDictItem;
|
|
10
10
|
}, __VLS_13: {
|
|
11
|
-
item: import("
|
|
11
|
+
item: import("../../..").QdDictItem;
|
|
12
12
|
}, __VLS_15: {
|
|
13
|
-
item: import("
|
|
13
|
+
item: import("../../..").QdDictItem;
|
|
14
14
|
}, __VLS_17: {};
|
|
15
15
|
type __VLS_Slots = {} & {
|
|
16
16
|
prefix?: (props: typeof __VLS_1) => any;
|
|
@@ -28,7 +28,7 @@ type __VLS_Slots = {} & {
|
|
|
28
28
|
separator?: (props: typeof __VLS_17) => any;
|
|
29
29
|
};
|
|
30
30
|
declare const __VLS_component: import("vue").DefineComponent<QdDictTagProps, {}, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<QdDictTagProps> & Readonly<{}>, {
|
|
31
|
-
options: import("
|
|
31
|
+
options: import("../../..").QdDictItem[];
|
|
32
32
|
strict: boolean;
|
|
33
33
|
}, {}, {}, {}, string, import("vue").ComponentProvideOptions, false, {}, any>;
|
|
34
34
|
declare const _default: __VLS_WithSlots<typeof __VLS_component, __VLS_Slots>;
|
|
@@ -0,0 +1,8 @@
|
|
|
1
|
+
import _sfc_main from "./index.vue2.mjs";
|
|
2
|
+
/* empty css */
|
|
3
|
+
import _export_sfc from "../../../_virtual/_plugin-vue_export-helper.mjs";
|
|
4
|
+
const index = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-e1d28836"]]);
|
|
5
|
+
export {
|
|
6
|
+
index as default
|
|
7
|
+
};
|
|
8
|
+
//# sourceMappingURL=index.vue.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue.mjs","sources":[],"sourcesContent":[],"names":[],"mappings":";;;;"}
|
|
@@ -1,17 +1,17 @@
|
|
|
1
1
|
import { defineComponent, mergeDefaults, toRef, computed, resolveDirective, withDirectives, createElementBlock, openBlock, Fragment, renderList, createBlock, renderSlot, createCommentVNode, normalizeClass, createTextVNode, toDisplayString, unref, withCtx } from "vue";
|
|
2
2
|
import { Tag } from "tdesign-vue-next";
|
|
3
3
|
import { isEmpty } from "qidian-shared";
|
|
4
|
-
import { qdDictTagProps } from "./props.mjs";
|
|
5
|
-
import "
|
|
6
|
-
import "
|
|
7
|
-
import { useDictDynamic } from "
|
|
8
|
-
import isNumber from "
|
|
4
|
+
import { qdDictConvStrSeparator, qdDictTagProps } from "./props.mjs";
|
|
5
|
+
import "../../../hooks/useAgentChat/index.mjs";
|
|
6
|
+
import "../../../locales/zh-CN.mjs";
|
|
7
|
+
import { useDictDynamic } from "../../../hooks/useDict/index.mjs";
|
|
8
|
+
import isNumber from "../../../node_modules/.pnpm/lodash-es@4.17.21/node_modules/lodash-es/isNumber.mjs";
|
|
9
9
|
const _hoisted_1 = { class: "qd-dict-tag" };
|
|
10
10
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
11
11
|
...{
|
|
12
12
|
name: "QdDictTag"
|
|
13
13
|
},
|
|
14
|
-
__name: "
|
|
14
|
+
__name: "index",
|
|
15
15
|
props: /* @__PURE__ */ mergeDefaults({
|
|
16
16
|
value: {},
|
|
17
17
|
strict: { type: Boolean },
|
|
@@ -41,7 +41,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
41
41
|
if (isNumber(value)) {
|
|
42
42
|
return strict ? [value] : [value.toString()];
|
|
43
43
|
}
|
|
44
|
-
return String(value).split(
|
|
44
|
+
return String(value).split(qdDictConvStrSeparator);
|
|
45
45
|
});
|
|
46
46
|
const matchOptions = computed(() => {
|
|
47
47
|
const { options, strict } = reProps.value;
|
|
@@ -95,4 +95,4 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
95
95
|
export {
|
|
96
96
|
_sfc_main as default
|
|
97
97
|
};
|
|
98
|
-
//# sourceMappingURL=
|
|
98
|
+
//# sourceMappingURL=index.vue2.mjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.vue2.mjs","sources":["../../../../src/components/dict/tag/index.vue"],"sourcesContent":["<template>\n <div v-loading=\"{ loading: dictLoading, size: 'small' }\" class=\"qd-dict-tag\">\n <template v-for=\"(item, index) in matchOptions\">\n <span\n v-if=\"\n (!reProps.theme || reProps.theme === 'text') &&\n !variant &&\n (item.theme === 'text' || !item.theme)\n \"\n :key=\"item.value\"\n :class=\"item.class\"\n >\n <slot name=\"prefix\" :item=\"item\" />\n <slot :item=\"item\">{{ item.label }}</slot>\n <slot name=\"suffix\" :item=\"item\" />\n </span>\n\n <t-tag\n v-else\n :key=\"item.value + ''\"\n :index=\"index\"\n :size=\"reProps.size\"\n :shape=\"reProps.shape\"\n :theme=\"(reProps.theme || item.theme || 'default') as TdTagProps['theme']\"\n :variant=\"reProps.variant || item.variant || 'light'\"\n :class=\"item.class\"\n >\n <slot name=\"prefix\" :item=\"item\" />\n <slot :item=\"item\">{{ item.label }}</slot>\n <slot name=\"suffix\" :item=\"item\" />\n </t-tag>\n\n <template v-if=\"($slots.separator || separator) && matchOptions.length - 1 !== index\">\n <slot name=\"separator\">{{ separator }}</slot>\n </template>\n </template>\n </div>\n</template>\n\n<script setup lang=\"ts\">\n import type { TdTagProps } from 'tdesign-vue-next'\n import type { QdDictTagProps } from './types'\n import { computed, toRef } from 'vue'\n import { Tag as TTag } from 'tdesign-vue-next'\n import { isEmpty } from 'qidian-shared'\n import { isNumber } from 'lodash-es'\n import { qdDictConvStrSeparator, qdDictTagProps } from './props'\n import { useDictDynamic } from '../../../hooks'\n\n defineOptions({\n name: 'QdDictTag'\n })\n\n const props = withDefaults(defineProps<QdDictTagProps>(), qdDictTagProps)\n\n const dictType = toRef(props, 'dictType')\n\n const reProps = computed(() => {\n const { options, ...otherOptions } = props\n\n return {\n ...otherOptions,\n options: options || dictOptions.value || []\n }\n })\n\n const { options: dictOptions, loading: dictLoading } = useDictDynamic(dictType)\n\n const reValue = computed(() => {\n const { value, strict } = reProps.value\n\n if (isEmpty(value)) return []\n if (Array.isArray(value)) return value.map((item) => (strict ? item : item.toString()))\n if (isNumber(value)) {\n return strict ? [value] : [value.toString()]\n }\n return String(value).split(qdDictConvStrSeparator)\n })\n\n const matchOptions = computed(() => {\n const { options, strict } = reProps.value\n\n return options.filter((option) => {\n return reValue.value.includes(strict ? option.value : option.value.toString())\n })\n })\n</script>\n\n<style lang=\"less\" scoped>\n .qd-dict-tag {\n display: inline-flex;\n align-items: center;\n flex-wrap: wrap;\n }\n</style>\n"],"names":["_withDirectives","_openBlock","_createElementBlock","_Fragment","_renderList","_normalizeClass","_renderSlot","_createTextVNode","_toDisplayString","_createBlock","_unref","TTag","$slots"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAqDE,UAAM,QAAQ;AAEd,UAAM,WAAW,MAAM,OAAO,UAAU;AAExC,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM,EAAE,SAAS,GAAG,aAAA,IAAiB;AAErC,aAAO;AAAA,QACL,GAAG;AAAA,QACH,SAAS,WAAW,YAAY,SAAS,CAAA;AAAA,MAAC;AAAA,IAE9C,CAAC;AAED,UAAM,EAAE,SAAS,aAAa,SAAS,YAAA,IAAgB,eAAe,QAAQ;AAE9E,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM,EAAE,OAAO,OAAA,IAAW,QAAQ;AAElC,UAAI,QAAQ,KAAK,EAAG,QAAO,CAAA;AAC3B,UAAI,MAAM,QAAQ,KAAK,EAAG,QAAO,MAAM,IAAI,CAAC,SAAU,SAAS,OAAO,KAAK,UAAW;AACtF,UAAI,SAAS,KAAK,GAAG;AACnB,eAAO,SAAS,CAAC,KAAK,IAAI,CAAC,MAAM,UAAU;AAAA,MAC7C;AACA,aAAO,OAAO,KAAK,EAAE,MAAM,sBAAsB;AAAA,IACnD,CAAC;AAED,UAAM,eAAe,SAAS,MAAM;AAClC,YAAM,EAAE,SAAS,OAAA,IAAW,QAAQ;AAEpC,aAAO,QAAQ,OAAO,CAAC,WAAW;AAChC,eAAO,QAAQ,MAAM,SAAS,SAAS,OAAO,QAAQ,OAAO,MAAM,UAAU;AAAA,MAC/E,CAAC;AAAA,IACH,CAAC;;;AApFD,aAAAA,gBAAAC,UAAA,GAAAC,mBAmCM,OAnCN,YAmCM;AAAA,SAlCJD,UAAA,IAAA,GAAAC,mBAiCWC,UAAA,MAAAC,WAjCuB,aAAA,OAAY,CAA5B,MAAM,UAAK;;aAEN,CAAA,QAAA,MAAQ,SAAS,QAAA,MAAQ,UAAK,YAA2B,QAAA,YAAsB,KAAK,UAAK,UAAA,CAAgB,KAAK,uBADnIF,mBAYO,QAAA;AAAA,cANJ,KAAK,KAAK;AAAA,cACV,OAAKG,eAAE,KAAK,KAAK;AAAA,YAAA;cAElBC,WAAmC,KAAA,QAAA,UAAA,EAAd,KAAA,GAAU,QAAA,IAAA;AAAA,cAC/BA,WAA0C,KAAA,QAAA,WAAA,EAAnC,KAAA,GAAP,MAA0C;AAAA,gBAApBC,gBAAAC,gBAAA,KAAK,KAAK,GAAA,CAAA;AAAA,cAAA;cAChCF,WAAmC,KAAA,QAAA,UAAA,EAAd,KAAA,GAAU,QAAA,IAAA;AAAA,YAAA,uBAGjCG,YAaQC,MAAAC,GAAA,GAAA;AAAA,cAXL,KAAK,KAAK,QAAK;AAAA,cACf;AAAA,cACA,MAAM,QAAA,MAAQ;AAAA,cACd,OAAO,QAAA,MAAQ;AAAA,cACf,OAAQ,QAAA,MAAQ,SAAS,KAAK,SAAK;AAAA,cACnC,SAAS,QAAA,MAAQ,WAAW,KAAK,WAAO;AAAA,cACxC,OAAKN,eAAE,KAAK,KAAK;AAAA,YAAA;+BAElB,MAAmC;AAAA,gBAAnCC,WAAmC,KAAA,QAAA,UAAA,EAAd,KAAA,GAAU,QAAA,IAAA;AAAA,gBAC/BA,WAA0C,KAAA,QAAA,WAAA,EAAnC,KAAA,GAAP,MAA0C;AAAA,kBAApBC,gBAAAC,gBAAA,KAAK,KAAK,GAAA,CAAA;AAAA,gBAAA;gBAChCF,WAAmC,KAAA,QAAA,UAAA,EAAd,KAAA,GAAU,QAAA,IAAA;AAAA,cAAA;;;aAGhBM,KAAAA,OAAO,aAAa,QAAA,cAAc,aAAA,MAAa,SAAM,MAAS,QAC7EN,WAA6C,sCAA7C,MAA6C;AAAA,8CAAnB,QAAA,SAAS,GAAA,CAAA;AAAA,YAAA;;;;wCAhCdI,MAAA,WAAA,GAAW,MAAA,QAAA,CAAA;AAAA,MAAA;;;;"}
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"props.mjs","sources":["../../../../src/components/dict/tag/props.ts"],"sourcesContent":["export const qdDictConvStrSeparator = ','\n\nexport const qdDictTagProps = {\n options: undefined,\n strict: false\n} as const\n"],"names":[],"mappings":"AAAO,MAAM,yBAAyB;AAE/B,MAAM,iBAAiB;AAAA,EAC5B,SAAS;AAAA,EACT,QAAQ;AACV;"}
|
|
@@ -0,0 +1,9 @@
|
|
|
1
|
+
import type { QdDictItem } from '../../../hooks';
|
|
2
|
+
import type { TdTagProps } from 'tdesign-vue-next';
|
|
3
|
+
export interface QdDictTagProps extends Pick<TdTagProps, 'size' | 'shape'>, Pick<QdDictItem, 'theme' | 'variant'> {
|
|
4
|
+
value?: string | number | (string | number)[] | null;
|
|
5
|
+
strict?: boolean;
|
|
6
|
+
separator?: string;
|
|
7
|
+
options?: QdDictItem[];
|
|
8
|
+
dictType?: string;
|
|
9
|
+
}
|
|
@@ -1,7 +1,7 @@
|
|
|
1
1
|
import _sfc_main from "./item.vue2.mjs";
|
|
2
2
|
/* empty css */
|
|
3
3
|
import _export_sfc from "../../_virtual/_plugin-vue_export-helper.mjs";
|
|
4
|
-
const QdFormItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-
|
|
4
|
+
const QdFormItem = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-a17cd84f"]]);
|
|
5
5
|
export {
|
|
6
6
|
QdFormItem as default
|
|
7
7
|
};
|
|
@@ -62,7 +62,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
62
62
|
reRules.push({ required: true, message: `${messagePrefix}${formItemOptions.label}` });
|
|
63
63
|
}
|
|
64
64
|
}
|
|
65
|
-
component.placeholder = component.placeholder ?? (compName.search("picker") > -1 ? "" : `${messagePrefix}${formItemOptions.label}`);
|
|
65
|
+
component.placeholder = component.placeholder ?? (compName.search("picker") > -1 || compName.search("upload") > -1 ? "" : `${messagePrefix}${formItemOptions.label}`);
|
|
66
66
|
component.clearable = component.clearable ?? (required ? false : props.defaultClearable ?? true);
|
|
67
67
|
}
|
|
68
68
|
return {
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"item.vue2.mjs","sources":["../../../src/components/form/item.vue"],"sourcesContent":["<template>\n <qd-grid-item v-if=\"reIfRender !== false\" class=\"qd-form-item\" v-bind=\"reProps.gridItemOptions\">\n <t-form-item v-bind=\"reProps.formItemOptions\">\n <slot :crud-mode=\"reProps.formItemOptions.crudMode\" :context=\"context\">\n <qd-config-renderer\n v-if=\"reProps.configRendererOptions.config\"\n class=\"qd-form-item__component\"\n v-bind=\"reProps.configRendererOptions\"\n />\n </slot>\n </t-form-item>\n </qd-grid-item>\n</template>\n\n<script setup lang=\"ts\">\n import type { QdFormItemProps } from './types'\n import type {\n QdConfigRendererProps,\n QdComputeFunction,\n QdAsyncComputeOptions\n } from '../config-renderer'\n import { computed } from 'vue'\n import { FormItem as TFormItem } from 'tdesign-vue-next'\n import { QdGridItem } from '../grid'\n import { QdConfigRenderer } from '../config-renderer'\n import { qdFormItemProps } from './props'\n import { qdUseComputeValue } from '../config-renderer/compute'\n import { isEmpty } from 'qidian-shared'\n\n defineOptions({\n name: 'QdFormItem'\n })\n\n const props = withDefaults(defineProps<QdFormItemProps>(), qdFormItemProps)\n\n // 处理 ifRender\n const reIfRender = computed(() => {\n const ifRender = props.ifRender\n if (isEmpty(ifRender)) return true\n\n if (\n (ifRender as QdComputeFunction<boolean>)?.__qdCompute ||\n (ifRender as QdAsyncComputeOptions<boolean>)?.__qdAsyncCompute\n ) {\n const { result } = qdUseComputeValue(\n ifRender as QdComputeFunction<boolean> | QdAsyncComputeOptions<boolean>,\n computed(() => props.context || {})\n )\n return result.value\n }\n\n return ifRender as boolean\n })\n\n const reProps = computed(() => {\n const { col, row, context, component, required, rules, ...formItemOptions } = props\n const reRules = rules || []\n\n if (component) {\n const comp = component.is\n const compName = (\n typeof comp === 'string' ? comp : !comp ? '' : 'name' in comp ? comp.name || '' : ''\n ).toLowerCase()\n const messagePrefix =\n compName.search('select') > -1 ||\n compName.search('checkbox') > -1 ||\n compName.search('radio') > -1\n ? '请选择'\n : compName.search('upload') > -1\n ? '请上传'\n : '请输入'\n\n if (required && !reRules.some((item) => item.required)) {\n if (required && typeof required === 'string') {\n reRules.push({ required: true, message: required })\n } else {\n reRules.push({ required: true, message: `${messagePrefix}${formItemOptions.label}` })\n }\n }\n\n component.placeholder =\n component.placeholder ??\n (compName.search('picker') > -1 ? ''
|
|
1
|
+
{"version":3,"file":"item.vue2.mjs","sources":["../../../src/components/form/item.vue"],"sourcesContent":["<template>\n <qd-grid-item v-if=\"reIfRender !== false\" class=\"qd-form-item\" v-bind=\"reProps.gridItemOptions\">\n <t-form-item v-bind=\"reProps.formItemOptions\">\n <slot :crud-mode=\"reProps.formItemOptions.crudMode\" :context=\"context\">\n <qd-config-renderer\n v-if=\"reProps.configRendererOptions.config\"\n class=\"qd-form-item__component\"\n v-bind=\"reProps.configRendererOptions\"\n />\n </slot>\n </t-form-item>\n </qd-grid-item>\n</template>\n\n<script setup lang=\"ts\">\n import type { QdFormItemProps } from './types'\n import type {\n QdConfigRendererProps,\n QdComputeFunction,\n QdAsyncComputeOptions\n } from '../config-renderer'\n import { computed } from 'vue'\n import { FormItem as TFormItem } from 'tdesign-vue-next'\n import { QdGridItem } from '../grid'\n import { QdConfigRenderer } from '../config-renderer'\n import { qdFormItemProps } from './props'\n import { qdUseComputeValue } from '../config-renderer/compute'\n import { isEmpty } from 'qidian-shared'\n\n defineOptions({\n name: 'QdFormItem'\n })\n\n const props = withDefaults(defineProps<QdFormItemProps>(), qdFormItemProps)\n\n // 处理 ifRender\n const reIfRender = computed(() => {\n const ifRender = props.ifRender\n if (isEmpty(ifRender)) return true\n\n if (\n (ifRender as QdComputeFunction<boolean>)?.__qdCompute ||\n (ifRender as QdAsyncComputeOptions<boolean>)?.__qdAsyncCompute\n ) {\n const { result } = qdUseComputeValue(\n ifRender as QdComputeFunction<boolean> | QdAsyncComputeOptions<boolean>,\n computed(() => props.context || {})\n )\n return result.value\n }\n\n return ifRender as boolean\n })\n\n const reProps = computed(() => {\n const { col, row, context, component, required, rules, ...formItemOptions } = props\n const reRules = rules || []\n\n if (component) {\n const comp = component.is\n const compName = (\n typeof comp === 'string' ? comp : !comp ? '' : 'name' in comp ? comp.name || '' : ''\n ).toLowerCase()\n const messagePrefix =\n compName.search('select') > -1 ||\n compName.search('checkbox') > -1 ||\n compName.search('radio') > -1\n ? '请选择'\n : compName.search('upload') > -1\n ? '请上传'\n : '请输入'\n\n if (required && !reRules.some((item) => item.required)) {\n if (required && typeof required === 'string') {\n reRules.push({ required: true, message: required })\n } else {\n reRules.push({ required: true, message: `${messagePrefix}${formItemOptions.label}` })\n }\n }\n\n component.placeholder =\n component.placeholder ??\n (compName.search('picker') > -1 || compName.search('upload') > -1\n ? ''\n : `${messagePrefix}${formItemOptions.label}`)\n component.clearable =\n component.clearable ?? (required ? false : (props.defaultClearable ?? true))\n }\n\n return {\n formItemOptions: {\n ...formItemOptions,\n rules: reRules\n },\n gridItemOptions: { col, row },\n configRendererOptions: { context, config: component } as QdConfigRendererProps\n }\n })\n</script>\n\n<style lang=\"less\" scoped>\n .qd-form-item {\n & > :deep(.t-form__item) {\n & > .t-form__controls > .t-form__controls-content > * {\n width: 100%;\n }\n }\n\n &__component {\n width: 100%;\n }\n }\n</style>\n"],"names":["_openBlock","_createBlock","_unref","_mergeProps","_createVNode","TFormItem","_normalizeProps","_guardReactiveProps","_renderSlot"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAiCE,UAAM,QAAQ;AAGd,UAAM,aAAa,SAAS,MAAM;AAChC,YAAM,WAAW,MAAM;AACvB,UAAI,QAAQ,QAAQ,EAAG,QAAO;AAE9B,UACG,UAAyC,eACzC,UAA6C,kBAC9C;AACA,cAAM,EAAE,WAAW;AAAA,UACjB;AAAA,UACA,SAAS,MAAM,MAAM,WAAW,CAAA,CAAE;AAAA,QAAA;AAEpC,eAAO,OAAO;AAAA,MAChB;AAEA,aAAO;AAAA,IACT,CAAC;AAED,UAAM,UAAU,SAAS,MAAM;AAC7B,YAAM,EAAE,KAAK,KAAK,SAAS,WAAW,UAAU,OAAO,GAAG,gBAAA,IAAoB;AAC9E,YAAM,UAAU,SAAS,CAAA;AAEzB,UAAI,WAAW;AACb,cAAM,OAAO,UAAU;AACvB,cAAM,YACJ,OAAO,SAAS,WAAW,OAAO,CAAC,OAAO,KAAK,UAAU,OAAO,KAAK,QAAQ,KAAK,IAClF,YAAA;AACF,cAAM,gBACJ,SAAS,OAAO,QAAQ,IAAI,MAC5B,SAAS,OAAO,UAAU,IAAI,MAC9B,SAAS,OAAO,OAAO,IAAI,KACvB,QACA,SAAS,OAAO,QAAQ,IAAI,KAC1B,QACA;AAER,YAAI,YAAY,CAAC,QAAQ,KAAK,CAAC,SAAS,KAAK,QAAQ,GAAG;AACtD,cAAI,YAAY,OAAO,aAAa,UAAU;AAC5C,oBAAQ,KAAK,EAAE,UAAU,MAAM,SAAS,UAAU;AAAA,UACpD,OAAO;AACL,oBAAQ,KAAK,EAAE,UAAU,MAAM,SAAS,GAAG,aAAa,GAAG,gBAAgB,KAAK,GAAA,CAAI;AAAA,UACtF;AAAA,QACF;AAEA,kBAAU,cACR,UAAU,gBACT,SAAS,OAAO,QAAQ,IAAI,MAAM,SAAS,OAAO,QAAQ,IAAI,KAC3D,KACA,GAAG,aAAa,GAAG,gBAAgB,KAAK;AAC9C,kBAAU,YACR,UAAU,cAAc,WAAW,QAAS,MAAM,oBAAoB;AAAA,MAC1E;AAEA,aAAO;AAAA,QACL,iBAAiB;AAAA,UACf,GAAG;AAAA,UACH,OAAO;AAAA,QAAA;AAAA,QAET,iBAAiB,EAAE,KAAK,IAAA;AAAA,QACxB,uBAAuB,EAAE,SAAS,QAAQ,UAAA;AAAA,MAAU;AAAA,IAExD,CAAC;;aAhGmB,WAAA,UAAU,SAA9BA,UAAA,GAAAC,YAUeC,mBAVfC,WAUe;AAAA;QAV2B,OAAM;AAAA,MAAA,GAAuB,QAAA,MAAQ,eAAe,GAAA;AAAA,yBAC5F,MAQc;AAAA,UARdC,YAQcF,MAAAG,QAAA,GAAAC,eAAAC,mBARO,QAAA,MAAQ,eAAe,CAAA,GAAA;AAAA,6BAC1C,MAMO;AAAA,cANPC,WAMO,KAAA,QAAA,WAAA;AAAA,gBANA,UAAW,QAAA,MAAQ,gBAAgB;AAAA,gBAAW,SAAS,QAAA;AAAA,cAAA,GAA9D,MAMO;AAAA,gBAJG,QAAA,MAAQ,sBAAsB,UADtCR,aAAAC,YAIEC,oBAJFC,WAIE;AAAA;kBAFA,OAAM;AAAA,gBAAA,GACE,QAAA,MAAQ,qBAAqB,GAAA,MAAA,EAAA;;;;;;;;;;;"}
|