eco-vue-js 0.10.20 → 0.10.21

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 (51) hide show
  1. package/dist/components/Button/WButton.vue.d.ts +3 -16
  2. package/dist/components/Button/WButton.vue.d.ts.map +1 -1
  3. package/dist/components/Button/WButton.vue.js +19 -18
  4. package/dist/components/Button/WButtonGroup.vue.d.ts.map +1 -1
  5. package/dist/components/Button/WButtonGroup.vue.js +16 -13
  6. package/dist/components/Button/types.d.ts +14 -4
  7. package/dist/components/Button/types.d.ts.map +1 -1
  8. package/dist/components/Checkbox/WCheckbox.vue.d.ts +5 -18
  9. package/dist/components/Checkbox/WCheckbox.vue.d.ts.map +1 -1
  10. package/dist/components/Checkbox/WCheckbox.vue.js +8 -8
  11. package/dist/components/Checkbox/WCheckboxGroup.vue.d.ts +28 -0
  12. package/dist/components/Checkbox/WCheckboxGroup.vue.d.ts.map +1 -0
  13. package/dist/components/Checkbox/WCheckboxGroup.vue.js +125 -0
  14. package/dist/components/Checkbox/WCheckboxGroup.vue2.js +5 -0
  15. package/dist/components/Checkbox/types.d.ts +50 -0
  16. package/dist/components/Checkbox/types.d.ts.map +1 -0
  17. package/dist/components/FieldWrapper/WFieldWrapper.vue.d.ts.map +1 -1
  18. package/dist/components/FieldWrapper/WFieldWrapper.vue.js +117 -116
  19. package/dist/components/FieldWrapper/types.d.ts +1 -0
  20. package/dist/components/FieldWrapper/types.d.ts.map +1 -1
  21. package/dist/components/FormAsync/WFormAsyncButtonGroup.vue.js +4 -3
  22. package/dist/components/FormAsync/WFormAsyncCheckboxGroup.vue.d.ts +26 -0
  23. package/dist/components/FormAsync/WFormAsyncCheckboxGroup.vue.d.ts.map +1 -0
  24. package/dist/components/FormAsync/WFormAsyncCheckboxGroup.vue.js +81 -0
  25. package/dist/components/FormAsync/WFormAsyncCheckboxGroup.vue2.js +5 -0
  26. package/dist/components/FormAsync/WFormAsyncInput.vue.js +1 -0
  27. package/dist/components/FormAsync/WFormAsyncSelect.vue.js +1 -0
  28. package/dist/components/FormAsync/WFormAsyncSelectInfiniteSingle.vue.js +1 -0
  29. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue.js +1 -0
  30. package/dist/components/FormAsync/WFormAsyncSelectStringified.vue.js +1 -0
  31. package/dist/components/FormAsync/types.d.ts +7 -0
  32. package/dist/components/FormAsync/types.d.ts.map +1 -1
  33. package/dist/components/Input/WInput.vue.js +2 -1
  34. package/dist/components/Input/WInputAsync.vue.js +2 -1
  35. package/dist/components/Input/WInputDate.vue.js +1 -0
  36. package/dist/components/Input/WInputOptions.vue.js +1 -0
  37. package/dist/components/Input/WInputSuggest.vue.js +1 -0
  38. package/dist/components/Select/WSelect.vue.js +1 -0
  39. package/dist/components/Select/WSelectAsync.vue.js +1 -0
  40. package/dist/components/Select/WSelectAsyncSingle.vue.js +1 -0
  41. package/dist/components/Select/WSelectSingle.vue.js +1 -0
  42. package/dist/components/Select/WSelectStringified.vue.js +1 -0
  43. package/dist/components/Select/components/SelectOptionPrefix.vue.js +1 -1
  44. package/dist/imports/componentsPlugin.d.ts +3 -1
  45. package/dist/imports/componentsPlugin.d.ts.map +1 -1
  46. package/dist/main.js +2 -0
  47. package/dist/utils/useSelected.d.ts.map +1 -1
  48. package/dist/utils/useSelected.js +16 -3
  49. package/eslint/rules/ui-kit-imports.js +11 -2
  50. package/package.json +10 -23
  51. package/tailwind-base/plugins/default.ts +0 -3
@@ -1,18 +1,5 @@
1
- import { LinkProps } from '../../types/types';
1
+ import { ButtonProps } from './types';
2
2
  import { SemanticType } from '../../utils/SemanticType';
3
- interface Props extends Partial<LinkProps> {
4
- semanticType?: SemanticType;
5
- disabled?: boolean;
6
- loading?: boolean;
7
- tag?: 'a' | 'button';
8
- type?: string;
9
- replace?: boolean;
10
- href?: string;
11
- target?: '_self' | '_blank' | '_parent' | '_top';
12
- minimize?: boolean;
13
- join?: boolean;
14
- semanticTypeMap?: Partial<Record<SemanticType, string>>;
15
- }
16
3
  declare function __VLS_template(): {
17
4
  attrs: Partial<{}>;
18
5
  slots: {
@@ -22,9 +9,9 @@ declare function __VLS_template(): {
22
9
  rootEl: any;
23
10
  };
24
11
  type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
25
- declare const __VLS_component: import('vue').DefineComponent<Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
12
+ declare const __VLS_component: import('vue').DefineComponent<ButtonProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
26
13
  click: (event: MouseEvent | KeyboardEvent) => any;
27
- }, string, import('vue').PublicProps, Readonly<Props> & Readonly<{
14
+ }, string, import('vue').PublicProps, Readonly<ButtonProps> & Readonly<{
28
15
  onClick?: ((event: MouseEvent | KeyboardEvent) => any) | undefined;
29
16
  }>, {
30
17
  type: string;
@@ -1 +1 @@
1
- {"version":3,"file":"WButton.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/WButton.vue"],"names":[],"mappings":"AA+CA;AAkGA,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,eAAe,CAAA;AAM5C,OAAO,EAAC,YAAY,EAAC,MAAM,sBAAsB,CAAA;AAIjD,UAAU,KAAM,SAAQ,OAAO,CAAC,SAAS,CAAC;IACxC,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,GAAG,CAAC,EAAE,GAAG,GAAG,QAAQ,CAAA;IACpB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,IAAI,CAAC,EAAE,MAAM,CAAA;IACb,MAAM,CAAC,EAAE,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM,CAAA;IAChD,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,eAAe,CAAC,EAAE,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC,CAAA;CACxD;AAsCD,iBAAS,cAAc;WAuGT,OAAO,IAA6B;;yBAVpB,GAAG;;;;EAehC;AAeD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;UAzKZ,MAAM;;SADP,GAAG,GAAG,QAAQ;kBAHL,YAAY;YAOlB,OAAO,GAAG,QAAQ,GAAG,SAAS,GAAG,MAAM;UADzC,MAAM;qBAIK,OAAO,CAAC,MAAM,CAAC,YAAY,EAAE,MAAM,CAAC,CAAC;6EA4KvD,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAapG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WButton.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/WButton.vue"],"names":[],"mappings":"AAuDA;AA+FA,OAAO,KAAK,EAAC,WAAW,EAAC,MAAM,SAAS,CAAA;AAOxC,OAAO,EAAC,YAAY,EAAC,MAAM,sBAAsB,CAAA;AA0CjD,iBAAS,cAAc;WAsHT,OAAO,IAA6B;;yBAVrB,GAAG;;;;EAe/B;AAeD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;;;;;6EAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAapG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -5,6 +5,7 @@ import { SemanticType } from '../../utils/SemanticType.js';
5
5
  import { semanticTypeButtonBorderStylesMap, semanticTypeButtonStylesMap } from './models/semanticTypeStylesMap.js';
6
6
 
7
7
  const _sfc_main = /* @__PURE__ */ defineComponent({
8
+ ...{ inheritAttrs: false },
8
9
  __name: "WButton",
9
10
  props: {
10
11
  semanticType: { default: SemanticType.PRIMARY },
@@ -15,7 +16,6 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
15
16
  replace: { type: Boolean },
16
17
  href: { default: void 0 },
17
18
  target: { default: void 0 },
18
- minimize: { type: Boolean },
19
19
  join: { type: Boolean },
20
20
  semanticTypeMap: { default: void 0 },
21
21
  to: { default: void 0 }
@@ -29,23 +29,24 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
29
29
  emit("click", event);
30
30
  };
31
31
  return (_ctx, _cache) => {
32
- return openBlock(), createBlock(resolveDynamicComponent(_ctx.to !== void 0 ? _ctx.disabled ? "a" : unref(RouterLink) : _ctx.tag), mergeProps(
33
- _ctx.disabled ? void 0 : _ctx.tag === "a" ? { href: _ctx.href, target: _ctx.target } : _ctx.to !== void 0 ? { to: _ctx.to, replace: _ctx.replace } : void 0,
34
- {
35
- class: ["w-ripple-rounded-[calc(var(--w-button-rounded,1rem)-0.0625rem)] relative isolate flex h-[--w-button-height,2.75rem] min-h-[--w-button-height,2.75rem] select-none items-center justify-center whitespace-nowrap rounded-[--w-button-rounded,1rem] px-[--w-button-rounded,1rem] font-medium outline-none", {
36
- [_ctx.semanticTypeMap?.[_ctx.semanticType] ?? unref(semanticTypeButtonStylesMap)[_ctx.semanticType]]: true,
37
- [_ctx.semanticTypeMap?.[_ctx.semanticType] ?? unref(semanticTypeButtonBorderStylesMap)[_ctx.semanticType]]: true,
38
- "w-ripple w-ripple-hover before:text-black-default w-ripple-opacity-20 dark:w-ripple-opacity-30 cursor-pointer": !_ctx.loading && !_ctx.disabled,
39
- "cursor-progress": _ctx.loading,
40
- "cursor-not-allowed opacity-70": _ctx.disabled,
41
- "[&:not(:first-child)]:rounded-l-none [&:not(:first-child)]:border-l-0 [&:not(:first-child)]:before:rounded-l-none [&:not(:last-child)]:rounded-r-none [&:not(:last-child)]:border-r-0 [&:not(:last-child)]:before:rounded-r-none": _ctx.join
42
- }],
43
- disabled: !_ctx.loading && _ctx.disabled,
44
- type: _ctx.type,
45
- onClick: click,
46
- onKeypress: withKeys(withModifiers(click, ["stop", "prevent"]), ["enter"])
47
- }
48
- ), {
32
+ return openBlock(), createBlock(resolveDynamicComponent(_ctx.to !== void 0 ? _ctx.disabled ? "a" : unref(RouterLink) : _ctx.tag), mergeProps({
33
+ class: _ctx.$attrs.class,
34
+ style: _ctx.$attrs.style,
35
+ ..._ctx.disabled ? {} : _ctx.tag === "a" ? { href: _ctx.href, target: _ctx.target } : _ctx.to !== void 0 ? { to: _ctx.to, replace: _ctx.replace } : {}
36
+ }, {
37
+ class: ["w-ripple-rounded-[calc(var(--w-button-rounded,1rem)-0.0625rem)] relative isolate flex min-h-[--w-button-height,2.75rem] select-none items-center justify-center whitespace-nowrap rounded-[--w-button-rounded,1rem] px-[--w-button-rounded,1rem] font-medium outline-none", {
38
+ [_ctx.semanticTypeMap?.[_ctx.semanticType] ?? unref(semanticTypeButtonStylesMap)[_ctx.semanticType]]: true,
39
+ [_ctx.semanticTypeMap?.[_ctx.semanticType] ?? unref(semanticTypeButtonBorderStylesMap)[_ctx.semanticType]]: true,
40
+ "w-ripple w-ripple-hover before:text-black-default w-ripple-opacity-20 dark:w-ripple-opacity-30 cursor-pointer": !_ctx.loading && !_ctx.disabled,
41
+ "cursor-progress": _ctx.loading,
42
+ "cursor-not-allowed opacity-70": _ctx.disabled,
43
+ "first-not:rounded-l-none first-not:border-l-0 first-not:before:rounded-l-none last-not:rounded-r-none last-not:border-r-0 last-not:before:rounded-r-none": _ctx.join
44
+ }],
45
+ disabled: !_ctx.loading && _ctx.disabled,
46
+ type: _ctx.type,
47
+ onClick: click,
48
+ onKeypress: withKeys(withModifiers(click, ["stop", "prevent"]), ["enter"])
49
+ }), {
49
50
  default: withCtx(() => [
50
51
  createElementVNode("div", {
51
52
  class: normalizeClass(["z-10 flex flex-1 items-center justify-center gap-2", {
@@ -1 +1 @@
1
- {"version":3,"file":"WButtonGroup.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/WButtonGroup.vue"],"names":[],"mappings":"AA2DA;AAqGA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,SAAS,CAAA;yBAU5B,KAAK,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,OAAO,EAAE,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,SAAS;IAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAA;CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,2BAC3J,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;WAuL1D,mBAAmB,CAAC;;yMAAkE,CAAC,4BAA2B;oBACzG,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;;uBApCgB,GAAG;;;;YACD,GAAG;uBACJ,GAAG;;cA/IzB,oBAAoB,SAAS,KAAK,KAAG,IAAI;;;;YAsLH,OAAO,CAAC,OAAO,WAAW,CAAC;;AAjMvE,wBAiM4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
1
+ {"version":3,"file":"WButtonGroup.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/WButtonGroup.vue"],"names":[],"mappings":"AA4DA;AAsGA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,SAAS,CAAA;yBAU5B,KAAK,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,OAAO,EAAE,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,SAAS;IAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAA;CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,2BAC3J,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;WAyL1D,mBAAmB,CAAC;;yMAAkE,CAAC,4BAA2B;oBACzG,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;;uBApCgB,GAAG;;;;YACD,GAAG;uBACJ,GAAG;;cAjJzB,oBAAoB,SAAS,KAAK,KAAG,IAAI;;;;YAwLH,OAAO,CAAC,OAAO,WAAW,CAAC;;AAnMvE,wBAmM4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -11,14 +11,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
11
11
  valueGetter: { type: Function },
12
12
  optionComponent: {},
13
13
  modelValue: {},
14
- loading: { type: Boolean },
15
- minimize: { type: Boolean },
16
14
  wrap: { type: Boolean },
17
15
  col: { type: Boolean },
18
16
  semanticType: {},
19
17
  stretch: { type: Boolean },
20
18
  allowClear: { type: Boolean },
21
- semanticTypeMap: {},
22
19
  title: {},
23
20
  description: {},
24
21
  errorMessage: {},
@@ -35,7 +32,11 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
35
32
  emptyValue: {},
36
33
  leftError: { type: Boolean },
37
34
  filterField: {},
38
- filterValue: {}
35
+ filterValue: {},
36
+ subgrid: { type: Boolean },
37
+ loading: { type: Boolean },
38
+ semanticTypeMap: {},
39
+ to: {}
39
40
  },
40
41
  emits: ["update:model-value"],
41
42
  setup(__props, { emit: __emit }) {
@@ -70,19 +71,21 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
70
71
  }])
71
72
  }, [
72
73
  (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.list, (item, index) => {
73
- return openBlock(), createBlock(_sfc_main$2, {
74
+ return openBlock(), createBlock(_sfc_main$2, mergeProps({
74
75
  key: index,
75
- "semantic-type": getValue(item) === _ctx.modelValue ? _ctx.semanticType ?? unref(SemanticType).PRIMARY : unref(SemanticType).SECONDARY,
76
+ ref_for: true
77
+ }, {
78
+ ...props,
79
+ semanticType: getValue(item) === _ctx.modelValue ? _ctx.semanticType ?? unref(SemanticType).PRIMARY : unref(SemanticType).SECONDARY,
76
80
  loading: _ctx.loading && getValue(item) === loadingItem.value,
77
81
  disabled: _ctx.disabled || _ctx.loading && getValue(item) !== loadingItem.value,
78
- minimize: _ctx.minimize,
79
- join: !_ctx.wrap && !_ctx.col,
80
- "semantic-type-map": _ctx.semanticTypeMap,
81
- class: normalizeClass({
82
+ join: !_ctx.wrap && !_ctx.col
83
+ }, {
84
+ class: {
82
85
  "flex-1": _ctx.stretch
83
- }),
86
+ },
84
87
  onClick: ($event) => updateModelValue(getValue(item))
85
- }, {
88
+ }), {
86
89
  default: withCtx(() => [
87
90
  renderSlot(_ctx.$slots, "option", {
88
91
  option: item,
@@ -96,7 +99,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
96
99
  ])
97
100
  ]),
98
101
  _: 2
99
- }, 1032, ["semantic-type", "loading", "disabled", "minimize", "join", "semantic-type-map", "class", "onClick"]);
102
+ }, 1040, ["class", "onClick"]);
100
103
  }), 128))
101
104
  ], 2)
102
105
  ]),
@@ -1,22 +1,32 @@
1
1
  import { DropdownMenuProps } from '../DropdownMenu/types';
2
2
  import { FieldWrapperProps } from '../FieldWrapper/types';
3
+ import { LinkProps } from '../../types/types';
3
4
  import { SemanticType } from '../../utils/SemanticType';
4
5
  import { Component } from 'vue';
6
+ export interface ButtonProps extends Partial<LinkProps> {
7
+ semanticType?: SemanticType;
8
+ disabled?: boolean;
9
+ loading?: boolean;
10
+ tag?: 'a' | 'button';
11
+ type?: string;
12
+ replace?: boolean;
13
+ href?: string;
14
+ target?: '_self' | '_blank' | '_parent' | '_top';
15
+ join?: boolean;
16
+ semanticTypeMap?: Partial<Record<SemanticType, string>>;
17
+ }
5
18
  export type ButtonGroupOptionProps<Option> = {
6
19
  option: Option;
7
20
  selected?: boolean;
8
21
  };
9
22
  export type ButtonGroupOptionComponent<Option> = Component<ButtonGroupOptionProps<Option>>;
10
- interface ButtonGroupPropsBase<Model extends number | string | null | boolean> extends Omit<FieldWrapperProps, 'modelValue'> {
23
+ interface ButtonGroupPropsBase<Model extends number | string | null | boolean> extends Omit<FieldWrapperProps, 'modelValue'>, Omit<ButtonProps, 'tag' | 'type' | 'replace' | 'href' | 'target' | 'join'> {
11
24
  modelValue: Model;
12
- loading?: boolean;
13
- minimize?: boolean;
14
25
  wrap?: boolean;
15
26
  col?: boolean;
16
27
  semanticType?: SemanticType;
17
28
  stretch?: boolean;
18
29
  allowClear?: boolean;
19
- semanticTypeMap?: Partial<Record<SemanticType, string>>;
20
30
  }
21
31
  interface ButtonGroupPropsForModel<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
22
32
  fn(value: Entity): Model;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/types.ts"],"names":[],"mappings":"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"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/Button/types.ts"],"names":[],"mappings":"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"}
@@ -1,15 +1,4 @@
1
- type __VLS_Props = {
2
- modelValue: boolean | null;
3
- title?: string;
4
- disabled?: boolean;
5
- readonly?: boolean;
6
- icon?: SVGComponent;
7
- radio?: boolean;
8
- loading?: boolean;
9
- intermediate?: boolean;
10
- tooltipText?: string;
11
- alignTop?: boolean;
12
- };
1
+ import { CheckboxProps } from './types';
13
2
  declare function __VLS_template(): {
14
3
  attrs: Partial<{}>;
15
4
  slots: {
@@ -18,18 +7,16 @@ declare function __VLS_template(): {
18
7
  refs: {
19
8
  element: HTMLButtonElement;
20
9
  };
21
- rootEl: HTMLButtonElement;
10
+ rootEl: any;
22
11
  };
23
12
  type __VLS_TemplateResult = ReturnType<typeof __VLS_template>;
24
- declare const __VLS_component: import('vue').DefineComponent<__VLS_Props, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
13
+ declare const __VLS_component: import('vue').DefineComponent<CheckboxProps, {}, {}, {}, {}, import('vue').ComponentOptionsMixin, import('vue').ComponentOptionsMixin, {} & {
25
14
  "update:modelValue": (value: boolean) => any;
26
- "update-shift:modelValue": (value: boolean) => any;
27
- }, string, import('vue').PublicProps, Readonly<__VLS_Props> & Readonly<{
15
+ }, string, import('vue').PublicProps, Readonly<CheckboxProps> & Readonly<{
28
16
  "onUpdate:modelValue"?: ((value: boolean) => any) | undefined;
29
- "onUpdate-shift:modelValue"?: ((value: boolean) => any) | undefined;
30
17
  }>, {}, {}, {}, {}, string, import('vue').ComponentProvideOptions, false, {
31
18
  element: HTMLButtonElement;
32
- }, HTMLButtonElement>;
19
+ }, any>;
33
20
  declare const _default: __VLS_WithTemplateSlots<typeof __VLS_component, __VLS_TemplateResult["slots"]>;
34
21
  export default _default;
35
22
  type __VLS_WithTemplateSlots<T, S> = T & {
@@ -1 +1 @@
1
- {"version":3,"file":"WCheckbox.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Checkbox/WCheckbox.vue"],"names":[],"mappings":"AAoFA;AAgIA,KAAK,WAAW,GAAG;IACjB,UAAU,EAAE,OAAO,GAAG,IAAI,CAAA;IAC1B,KAAK,CAAC,EAAE,MAAM,CAAA;IACd,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,IAAI,CAAC,EAAE,YAAY,CAAA;IACnB,KAAK,CAAC,EAAE,OAAO,CAAA;IACf,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,YAAY,CAAC,EAAE,OAAO,CAAA;IACtB,WAAW,CAAC,EAAE,MAAM,CAAA;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB,CAAC;AAmBF,iBAAS,cAAc;WAuIT,OAAO,IAA6B;;yBAXpB,GAAG;;;;;;EAgBhC;AAaD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;;;qBASnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WCheckbox.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Checkbox/WCheckbox.vue"],"names":[],"mappings":"AAqFA;AAkHA,OAAO,KAAK,EAAC,aAAa,EAAC,MAAM,SAAS,CAAA;AA6B1C,iBAAS,cAAc;WAwIT,OAAO,IAA6B;;yBAXpB,GAAG;;;;;;EAgBhC;AAaD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;OAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, useTemplateRef, createElementBlock, openBlock, normalizeClass, createElementVNode, createCommentVNode, withKeys, withModifiers, createVNode, createBlock, withDirectives, Transition, withCtx, vShow, resolveDynamicComponent, unref, renderSlot, createTextVNode, toDisplayString } from 'vue';
1
+ import { defineComponent, useTemplateRef, createElementBlock, openBlock, mergeProps, createElementVNode, createCommentVNode, withKeys, normalizeClass, withModifiers, createVNode, createBlock, withDirectives, Transition, withCtx, vShow, resolveDynamicComponent, unref, renderSlot, createTextVNode, toDisplayString } from 'vue';
2
2
  import WSpinner from '../Spinner/WSpinner.vue.js';
3
3
  import _sfc_main$1 from '../Tooltip/WTooltip.vue.js';
4
4
  import IconCheck from '../../assets/icons/default/IconCheck.svg.js';
@@ -9,6 +9,7 @@ const _hoisted_2 = {
9
9
  class: "text-accent flex items-center gap-1"
10
10
  };
11
11
  const _sfc_main = /* @__PURE__ */ defineComponent({
12
+ ...{ inheritAttrs: false },
12
13
  __name: "WCheckbox",
13
14
  props: {
14
15
  modelValue: { type: [Boolean, null] },
@@ -22,7 +23,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
22
23
  tooltipText: {},
23
24
  alignTop: { type: Boolean }
24
25
  },
25
- emits: ["update:modelValue", "update-shift:modelValue"],
26
+ emits: ["update:modelValue"],
26
27
  setup(__props, { emit: __emit }) {
27
28
  const props = __props;
28
29
  const emit = __emit;
@@ -32,17 +33,16 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
32
33
  emit("update:modelValue", !props.modelValue);
33
34
  };
34
35
  return (_ctx, _cache) => {
35
- return openBlock(), createElementBlock("button", {
36
- ref: "element",
37
- class: normalizeClass(["w-ripple-trigger w-hover-circle-trigger w-hover-circle-opacity-[0.08] flex cursor-pointer select-none gap-2 outline-none", {
36
+ return openBlock(), createElementBlock("button", mergeProps({ ref: "element" }, { class: _ctx.$attrs.class, style: _ctx.$attrs.style }, {
37
+ class: ["w-ripple-trigger w-hover-circle-trigger w-hover-circle-opacity-[0.08] flex cursor-pointer select-none gap-2 outline-none", {
38
38
  "cursor-progress": _ctx.loading,
39
39
  "cursor-not-allowed opacity-70": _ctx.disabled,
40
40
  "pb-4 pt-1": _ctx.title,
41
41
  "items-start": _ctx.alignTop,
42
42
  "items-center": !_ctx.alignTop
43
- }]),
43
+ }],
44
44
  onClick: toggle
45
- }, [
45
+ }), [
46
46
  createElementVNode("div", {
47
47
  class: normalizeClass(["square-[1.5em] bg-default dark:bg-default-dark relative isolate flex items-center justify-center border border-solid [font-size:--w-checkbox-size]", {
48
48
  "text-default dark:text-default-dark": _ctx.modelValue && !_ctx.disabled,
@@ -103,7 +103,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
103
103
  createTextVNode(toDisplayString(_ctx.title), 1)
104
104
  ])
105
105
  ])) : createCommentVNode("", true)
106
- ], 2);
106
+ ], 16);
107
107
  };
108
108
  }
109
109
  });
@@ -0,0 +1,28 @@
1
+ import { CheckboxGroupProps } from './types';
2
+ declare const _default: <Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
3
+ fn(value: Entity): Model;
4
+ }["fn"] | undefined = undefined>(__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<{
5
+ props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
6
+ readonly "onUpdate:model-value"?: ((value: Model) => any) | undefined;
7
+ } & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps, never>, "onUpdate:model-value"> & CheckboxGroupProps<Model, Entity, ValueGetter> & Partial<{}>> & import('vue').PublicProps;
8
+ expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
9
+ attrs: any;
10
+ slots: {
11
+ title?(_: {}): any;
12
+ option?(_: {
13
+ option: ValueGetter extends undefined ? Model : Entity;
14
+ selected: boolean;
15
+ }): any;
16
+ right?(_: {}): any;
17
+ };
18
+ emit: (e: "update:model-value", value: Model) => void;
19
+ }>) => import('vue').VNode<import('vue').RendererNode, import('vue').RendererElement, {
20
+ [key: string]: any;
21
+ }> & {
22
+ __ctx?: Awaited<typeof __VLS_setup>;
23
+ };
24
+ export default _default;
25
+ type __VLS_PrettifyLocal<T> = {
26
+ [K in keyof T]: T[K];
27
+ } & {};
28
+ //# sourceMappingURL=WCheckboxGroup.vue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WCheckboxGroup.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/Checkbox/WCheckboxGroup.vue"],"names":[],"mappings":"AAwDA;AAgGA,OAAO,KAAK,EAAC,kBAAkB,EAAwB,MAAM,SAAS,CAAA;yBAQrD,KAAK,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,OAAO,EAAE,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,SAAS;IAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,KAAK,CAAA;CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,2BAC3J,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;WAqL1D,mBAAmB,CAAC;;2MAAkE,CAAC,4BAA2B;oBACzG,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;;uBAnCgB,GAAG;;;;YACD,GAAG;uBACJ,GAAG;;cA9IzB,oBAAoB,SAAS,KAAK,KAAG,IAAI;;;;YAoLH,OAAO,CAAC,OAAO,WAAW,CAAC;;AA/LvE,wBA+L4E;AAC5E,KAAK,mBAAmB,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -0,0 +1,125 @@
1
+ import { defineComponent, ref, createBlock, openBlock, mergeProps, createSlots, withCtx, createElementBlock, Fragment, renderList, renderSlot, createCommentVNode, resolveDynamicComponent } from 'vue';
2
+ import _sfc_main$1 from '../FieldWrapper/WFieldWrapper.vue.js';
3
+ import _sfc_main$2 from './WCheckbox.vue.js';
4
+
5
+ const _sfc_main = /* @__PURE__ */ defineComponent({
6
+ ...{ inheritAttrs: false },
7
+ __name: "WCheckboxGroup",
8
+ props: {
9
+ list: {},
10
+ valueGetter: { type: Function },
11
+ optionComponent: {},
12
+ modelValue: {},
13
+ wrap: { type: Boolean },
14
+ col: { type: Boolean },
15
+ stretch: { type: Boolean },
16
+ allowClear: { type: Boolean },
17
+ iconMap: {},
18
+ titleMap: {},
19
+ tooltipTextMap: {},
20
+ classMap: {},
21
+ title: {},
22
+ description: {},
23
+ errorMessage: {},
24
+ tooltipText: {},
25
+ maxLength: {},
26
+ mono: { type: Boolean },
27
+ hasChanges: { type: Boolean },
28
+ skeleton: { type: Boolean },
29
+ disabled: { type: Boolean },
30
+ required: { type: Boolean },
31
+ mandatory: { type: Boolean },
32
+ noMargin: { type: Boolean },
33
+ allowCopy: { type: Boolean },
34
+ emptyValue: {},
35
+ leftError: { type: Boolean },
36
+ filterField: {},
37
+ filterValue: {},
38
+ subgrid: { type: Boolean },
39
+ readonly: { type: Boolean },
40
+ radio: { type: Boolean },
41
+ loading: { type: Boolean },
42
+ alignTop: { type: Boolean }
43
+ },
44
+ emits: ["update:model-value"],
45
+ setup(__props, { emit: __emit }) {
46
+ const props = __props;
47
+ const emit = __emit;
48
+ const loadingItem = ref(void 0);
49
+ const getValue = (item) => {
50
+ if (props.valueGetter && typeof item === "object") {
51
+ return props.valueGetter(item);
52
+ } else {
53
+ return item;
54
+ }
55
+ };
56
+ const emitUpdateModelValue = (value) => {
57
+ loadingItem.value = value;
58
+ emit("update:model-value", value);
59
+ };
60
+ const updateModelValue = (value) => {
61
+ if (value !== props.modelValue) emitUpdateModelValue(value);
62
+ else if (props.allowClear) emitUpdateModelValue(null);
63
+ };
64
+ return (_ctx, _cache) => {
65
+ return openBlock(), createBlock(_sfc_main$1, mergeProps(props, {
66
+ class: _ctx.$attrs.class
67
+ }), createSlots({
68
+ field: withCtx(() => [
69
+ (openBlock(true), createElementBlock(Fragment, null, renderList(_ctx.list, (item, index) => {
70
+ return openBlock(), createBlock(_sfc_main$2, mergeProps({
71
+ key: index,
72
+ ref_for: true
73
+ }, {
74
+ ...props,
75
+ modelValue: getValue(item) === _ctx.modelValue,
76
+ title: _ctx.titleMap?.[getValue(item).toString()],
77
+ tooltipText: _ctx.tooltipTextMap?.[getValue(item).toString()],
78
+ icon: _ctx.iconMap?.[getValue(item).toString()],
79
+ loading: _ctx.loading && getValue(item) === loadingItem.value,
80
+ disabled: _ctx.disabled || _ctx.loading && getValue(item) !== loadingItem.value
81
+ }, {
82
+ class: _ctx.classMap?.[getValue(item).toString()],
83
+ "onUpdate:modelValue": ($event) => updateModelValue(getValue(item))
84
+ }), createSlots({ _: 2 }, [
85
+ _ctx.$slots.option || _ctx.optionComponent ? {
86
+ name: "default",
87
+ fn: withCtx(() => [
88
+ renderSlot(_ctx.$slots, "option", {
89
+ option: item,
90
+ selected: getValue(item) === _ctx.modelValue
91
+ }, () => [
92
+ _ctx.optionComponent ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.optionComponent), {
93
+ key: 0,
94
+ option: item,
95
+ selected: getValue(item) === _ctx.modelValue
96
+ }, null, 8, ["option", "selected"])) : createCommentVNode("", true)
97
+ ])
98
+ ]),
99
+ key: "0"
100
+ } : void 0
101
+ ]), 1040, ["class", "onUpdate:modelValue"]);
102
+ }), 128))
103
+ ]),
104
+ _: 2
105
+ }, [
106
+ _ctx.$slots.title ? {
107
+ name: "title",
108
+ fn: withCtx(() => [
109
+ renderSlot(_ctx.$slots, "title")
110
+ ]),
111
+ key: "0"
112
+ } : void 0,
113
+ _ctx.$slots.right ? {
114
+ name: "right",
115
+ fn: withCtx(() => [
116
+ renderSlot(_ctx.$slots, "right")
117
+ ]),
118
+ key: "1"
119
+ } : void 0
120
+ ]), 1040, ["class"]);
121
+ };
122
+ }
123
+ });
124
+
125
+ export { _sfc_main as default };
@@ -0,0 +1,5 @@
1
+ import _sfc_main from './WCheckboxGroup.vue.js';
2
+
3
+
4
+
5
+ export { _sfc_main as default };
@@ -0,0 +1,50 @@
1
+ import { FieldWrapperProps } from '../FieldWrapper/types';
2
+ import { Component } from 'vue';
3
+ export interface CheckboxProps {
4
+ modelValue: boolean | null;
5
+ title?: string;
6
+ disabled?: boolean;
7
+ readonly?: boolean;
8
+ icon?: SVGComponent;
9
+ radio?: boolean;
10
+ loading?: boolean;
11
+ intermediate?: boolean;
12
+ tooltipText?: string;
13
+ alignTop?: boolean;
14
+ }
15
+ export type CheckboxGroupOptionProps<Option> = {
16
+ option: Option;
17
+ selected?: boolean;
18
+ };
19
+ export type CheckboxGroupOptionComponent<Option> = Component<CheckboxGroupOptionProps<Option>>;
20
+ export type GroupModelStringified<Model> = Exclude<Model, null | boolean> | (Model extends boolean ? 'true' | 'false' : never) | (Model extends null ? 'null' : never);
21
+ interface CheckboxGroupPropsBase<Model extends number | string | null | boolean> extends Omit<FieldWrapperProps, 'modelValue'>, Omit<CheckboxProps, 'modelValue' | 'title' | 'icon' | 'intermediate' | 'tooltipText'> {
22
+ modelValue: Model;
23
+ wrap?: boolean;
24
+ col?: boolean;
25
+ stretch?: boolean;
26
+ allowClear?: boolean;
27
+ iconMap?: Record<GroupModelStringified<Model>, SVGComponent>;
28
+ titleMap?: Record<GroupModelStringified<Model>, string>;
29
+ tooltipTextMap?: Record<GroupModelStringified<Model>, string>;
30
+ classMap?: Record<GroupModelStringified<Model>, string>;
31
+ }
32
+ interface CheckboxGroupPropsForModel<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
33
+ fn(value: Entity): Model;
34
+ }['fn'] | undefined = undefined> extends CheckboxGroupPropsBase<Model> {
35
+ list: Model[];
36
+ valueGetter?: ValueGetter | undefined;
37
+ optionComponent?: CheckboxGroupOptionComponent<Model>;
38
+ }
39
+ interface CheckboxGroupPropsForEntity<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
40
+ fn(value: Entity): Model;
41
+ }['fn'] | undefined = undefined> extends CheckboxGroupPropsBase<Model> {
42
+ list: Entity[];
43
+ valueGetter: ValueGetter | ((value: Entity) => Model);
44
+ optionComponent?: CheckboxGroupOptionComponent<Entity>;
45
+ }
46
+ export type CheckboxGroupProps<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
47
+ fn(value: Entity): Model;
48
+ }['fn'] | undefined = undefined> = CheckboxGroupPropsForEntity<Model, Entity, ValueGetter> | CheckboxGroupPropsForModel<Model, Entity, ValueGetter>;
49
+ export {};
50
+ //# sourceMappingURL=types.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../../src/components/Checkbox/types.ts"],"names":[],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"WFieldWrapper.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/FieldWrapper/WFieldWrapper.vue"],"names":[],"mappings":"AA+KA;AAsNA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AAuC9C,iBAAS,cAAc;WA6QT,OAAO,IAA6B;;uBAfvB,GAAG;0BACC,GAAG;;;gCArQP,OAAO,KAAG,IAAI;;YAsQb,GAAG;;;gCAtQJ,OAAO,KAAG,IAAI;;YAuQX,GAAG;uBACL,GAAG;;;;;;EAgB9B;AAkBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;OAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}
1
+ {"version":3,"file":"WFieldWrapper.vue.d.ts","sourceRoot":"","sources":["../../../../src/components/FieldWrapper/WFieldWrapper.vue"],"names":[],"mappings":"AAgLA;AAuNA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,SAAS,CAAA;AAuC9C,iBAAS,cAAc;WA+QT,OAAO,IAA6B;;uBAfvB,GAAG;0BACC,GAAG;;;gCAvQP,OAAO,KAAG,IAAI;;YAwQb,GAAG;;;gCAxQJ,OAAO,KAAG,IAAI;;YAyQX,GAAG;uBACL,GAAG;;;;;;EAgB9B;AAkBD,KAAK,oBAAoB,GAAG,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAC9D,QAAA,MAAM,eAAe;;;;;;OAQnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,oBAAoB,CAAC,OAAO,CAAC,CAAC;AAAnG,wBAAoG;AAQpG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACxC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC"}