eco-vue-js 0.7.3 → 0.8.0

Sign up to get free protection for your applications and to get access to all the features.
Files changed (89) hide show
  1. package/dist/components/Button/WButtonGroup.vue.d.ts +5 -4
  2. package/dist/components/Button/WButtonGroup.vue.d.ts.map +1 -1
  3. package/dist/components/Button/WButtonGroup.vue.js +12 -4
  4. package/dist/components/Button/types.d.ts +17 -6
  5. package/dist/components/Button/types.d.ts.map +1 -1
  6. package/dist/components/Form/WFormValidator.vue.d.ts.map +1 -1
  7. package/dist/components/Form/WFormValidator.vue.js +3 -4
  8. package/dist/components/FormAsync/WFormAsyncButtonGroup.vue.d.ts +25 -0
  9. package/dist/components/FormAsync/WFormAsyncButtonGroup.vue.d.ts.map +1 -0
  10. package/dist/components/FormAsync/WFormAsyncButtonGroup.vue.js +101 -0
  11. package/dist/components/FormAsync/WFormAsyncButtonGroup.vue2.js +5 -0
  12. package/dist/components/FormAsync/WFormAsyncInput.vue.d.ts +26 -0
  13. package/dist/components/FormAsync/WFormAsyncInput.vue.d.ts.map +1 -0
  14. package/dist/components/FormAsync/WFormAsyncInput.vue.js +131 -0
  15. package/dist/components/FormAsync/WFormAsyncInput.vue2.js +5 -0
  16. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue.d.ts +27 -0
  17. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue.d.ts.map +1 -0
  18. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue.js +139 -0
  19. package/dist/components/FormAsync/WFormAsyncSelectSingle.vue2.js +5 -0
  20. package/dist/components/FormAsync/WFormAsyncToggle.vue.d.ts +22 -0
  21. package/dist/components/FormAsync/WFormAsyncToggle.vue.d.ts.map +1 -0
  22. package/dist/components/FormAsync/WFormAsyncToggle.vue.js +89 -0
  23. package/dist/components/FormAsync/WFormAsyncToggle.vue2.js +5 -0
  24. package/dist/components/FormAsync/types.d.ts +85 -0
  25. package/dist/components/FormAsync/types.d.ts.map +1 -0
  26. package/dist/components/InfiniteList/WInfiniteList.vue.d.ts +3 -3
  27. package/dist/components/InfiniteList/WInfiniteList.vue.d.ts.map +1 -1
  28. package/dist/components/InfiniteList/WInfiniteListPages.vue.d.ts +3 -3
  29. package/dist/components/InfiniteList/WInfiniteListPages.vue.d.ts.map +1 -1
  30. package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts +6 -6
  31. package/dist/components/InfiniteList/components/InfiniteListPage.vue.d.ts.map +1 -1
  32. package/dist/components/List/WList.vue.d.ts +2 -2
  33. package/dist/components/List/WList.vue.d.ts.map +1 -1
  34. package/dist/components/Select/WSelect.vue.d.ts +12 -13
  35. package/dist/components/Select/WSelect.vue.d.ts.map +1 -1
  36. package/dist/components/Select/WSelect.vue.js +44 -33
  37. package/dist/components/Select/WSelectAsync.vue.d.ts +4 -5
  38. package/dist/components/Select/WSelectAsync.vue.d.ts.map +1 -1
  39. package/dist/components/Select/WSelectAsync.vue.js +20 -15
  40. package/dist/components/Select/WSelectAsyncList.vue.d.ts +3 -3
  41. package/dist/components/Select/WSelectAsyncList.vue.d.ts.map +1 -1
  42. package/dist/components/Select/WSelectAsyncSingle.vue.d.ts +2 -5
  43. package/dist/components/Select/WSelectAsyncSingle.vue.d.ts.map +1 -1
  44. package/dist/components/Select/WSelectAsyncSingle.vue.js +4 -7
  45. package/dist/components/Select/WSelectSingle.vue.d.ts +8 -8
  46. package/dist/components/Select/WSelectSingle.vue.d.ts.map +1 -1
  47. package/dist/components/Select/WSelectSingle.vue.js +3 -2
  48. package/dist/components/Select/components/SelectAsyncList.vue.d.ts +3 -3
  49. package/dist/components/Select/components/SelectAsyncList.vue.d.ts.map +1 -1
  50. package/dist/components/Select/components/SelectAsyncPrefix.vue.d.ts +4 -2
  51. package/dist/components/Select/components/SelectAsyncPrefix.vue.d.ts.map +1 -1
  52. package/dist/components/Select/components/SelectAsyncPrefix.vue.js +2 -1
  53. package/dist/components/Select/components/SelectAsyncPrefixPage.vue.d.ts +4 -2
  54. package/dist/components/Select/components/SelectAsyncPrefixPage.vue.d.ts.map +1 -1
  55. package/dist/components/Select/components/SelectAsyncPrefixPage.vue.js +4 -2
  56. package/dist/components/Select/components/SelectOptionPrefix.vue.d.ts +2 -2
  57. package/dist/components/Select/components/SelectOptionPrefix.vue.d.ts.map +1 -1
  58. package/dist/components/Select/components/SelectOptionPrefix.vue.js +3 -1
  59. package/dist/components/Select/types.d.ts +22 -20
  60. package/dist/components/Select/types.d.ts.map +1 -1
  61. package/dist/components/Tabs/WTabs.vue.d.ts +2 -2
  62. package/dist/components/Tabs/WTabs.vue.d.ts.map +1 -1
  63. package/dist/components/Tabs/WTabs.vue.js +3 -3
  64. package/dist/components/Toggle/WToggle.vue.d.ts +3 -12
  65. package/dist/components/Toggle/WToggle.vue.d.ts.map +1 -1
  66. package/dist/components/Toggle/WToggle.vue.js +3 -1
  67. package/dist/components/Toggle/types.d.ts +13 -0
  68. package/dist/components/Toggle/types.d.ts.map +1 -0
  69. package/dist/imports/componentsPlugin.d.ts +5 -1
  70. package/dist/imports/componentsPlugin.d.ts.map +1 -1
  71. package/dist/main.d.ts +3 -0
  72. package/dist/main.d.ts.map +1 -1
  73. package/dist/main.js +8 -1
  74. package/dist/types/global.d.ts +98 -10
  75. package/dist/utils/api.d.ts +16 -0
  76. package/dist/utils/api.d.ts.map +1 -0
  77. package/dist/utils/api.js +28 -0
  78. package/dist/utils/useDefaultQuery.d.ts +2 -1
  79. package/dist/utils/useDefaultQuery.d.ts.map +1 -1
  80. package/dist/utils/useQueryUpdater.d.ts +12 -0
  81. package/dist/utils/useQueryUpdater.d.ts.map +1 -0
  82. package/dist/utils/useQueryUpdater.js +56 -0
  83. package/dist/utils/utils.d.ts +2 -0
  84. package/dist/utils/utils.d.ts.map +1 -1
  85. package/dist/utils/utils.js +13 -1
  86. package/dist/utils/validate.d.ts +2 -0
  87. package/dist/utils/validate.d.ts.map +1 -0
  88. package/dist/utils/validate.js +3 -0
  89. package/package.json +28 -1
@@ -1,4 +1,4 @@
1
- import { ButtonGroupPropsForEntity, ButtonGroupPropsForModel } from './types';
1
+ import { ButtonGroupProps } from './types';
2
2
 
3
3
  declare const _default: <Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
4
4
  fn(value: Entity): Model;
@@ -7,13 +7,14 @@ declare const _default: <Model extends number | string | null | boolean, Entity
7
7
  "onUpdate:modelValue"?: ((value: Model) => any) | undefined;
8
8
  } & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & Readonly<import('vue').ExtractPropTypes<{}>> & {
9
9
  "onUpdate:modelValue"?: ((value: Model) => any) | undefined;
10
- }, never>, "onUpdate:modelValue"> & (ButtonGroupPropsForEntity<Model, Entity, ValueGetter> | ButtonGroupPropsForModel<Model, Entity, ValueGetter>)> & import('vue').PublicProps;
10
+ }, never>, "onUpdate:modelValue"> & ButtonGroupProps<Model, Entity, ValueGetter>> & import('vue').PublicProps;
11
11
  expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
12
12
  attrs: any;
13
13
  slots: ReturnType<() => {
14
14
  title?(_: {}): any;
15
- default?(_: {
16
- item: ValueGetter extends undefined ? Model : Entity;
15
+ option?(_: {
16
+ option: ValueGetter extends undefined ? Model : Entity;
17
+ selected: boolean;
17
18
  }): any;
18
19
  right?(_: {}): any;
19
20
  }>;
@@ -1 +1 @@
1
- {"version":3,"file":"WButtonGroup.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Button/WButtonGroup.vue"],"names":[],"mappings":"AA2EA,OAAO,KAAK,EAAC,yBAAyB,EAAE,wBAAwB,EAAC,MAAM,SAAS,CAAA;yBAG/D,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,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBACvF,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAkJxD,cAAc,CAAC;;;;sJAAyD,CAAC,4BAA2B;oBAC3F,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;WACH,UAAU;uBA1BO,GAAG;;;YACA,GAAG;uBACL,GAAG;MAwBY;UAClC,KA7IH,mBAAmB,SAAS,KAAK,KAAG,IAAI,MA6IG;;;;YAGL,OAAO,CAAC,OAAO,WAAW,CAAC;;AA5JvE,wBA4J4E;AAM5E,KAAK,cAAc,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":"AAsFA,OAAO,KAAK,EAAC,gBAAgB,EAAC,MAAM,SAAS,CAAA;yBAG5B,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,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBACvF,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WA+JxD,cAAc,CAAC;;;;oFAAyD,CAAC,4BAA2B;oBAC3F,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;WACH,UAAU;uBA1BO,GAAG;;;;YACD,GAAG;uBACJ,GAAG;MAwBY;UAClC,KA1JH,mBAAmB,SAAS,KAAK,KAAG,IAAI,MA0JG;;;;YAGL,OAAO,CAAC,OAAO,WAAW,CAAC;;AAzKvE,wBAyK4E;AAM5E,KAAK,cAAc,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -1,4 +1,4 @@
1
- import { defineComponent, openBlock, createBlock, mergeProps, createSlots, withCtx, createElementVNode, normalizeClass, createElementBlock, Fragment, renderList, unref, renderSlot } from 'vue';
1
+ import { defineComponent, openBlock, createBlock, mergeProps, createSlots, withCtx, createElementVNode, normalizeClass, createElementBlock, Fragment, renderList, unref, renderSlot, resolveDynamicComponent, createCommentVNode } from 'vue';
2
2
  import _sfc_main$2 from './WButton.vue.js';
3
3
  import { SemanticType } from '../../utils/SemanticType.js';
4
4
  import _sfc_main$1 from '../FieldWrapper/WFieldWrapper.vue.js';
@@ -9,6 +9,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
9
9
  props: {
10
10
  list: {},
11
11
  valueGetter: { type: Function },
12
+ optionComponent: {},
12
13
  modelValue: {},
13
14
  loading: {},
14
15
  minimize: { type: Boolean },
@@ -66,9 +67,16 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
66
67
  onClick: ($event) => (_ctx.alwaysEmit || getValue(item) !== _ctx.modelValue) && _ctx.$emit("update:modelValue", getValue(item))
67
68
  }, {
68
69
  default: withCtx(() => [
69
- renderSlot(_ctx.$slots, "default", {
70
- item
71
- })
70
+ renderSlot(_ctx.$slots, "option", {
71
+ option: item,
72
+ selected: getValue(item) === _ctx.modelValue
73
+ }, () => [
74
+ _ctx.optionComponent ? (openBlock(), createBlock(resolveDynamicComponent(_ctx.optionComponent), {
75
+ key: 0,
76
+ option: item,
77
+ selected: getValue(item) === _ctx.modelValue
78
+ }, null, 8, ["option", "selected"])) : createCommentVNode("", true)
79
+ ])
72
80
  ]),
73
81
  _: 2
74
82
  }, 1032, ["semantic-type", "loading", "disabled", "minimize", "join", "class", "onClick"]);
@@ -1,10 +1,16 @@
1
1
  import { FieldWrapperProps } from '../FieldWrapper/types';
2
2
  import { SemanticType } from '../../utils/SemanticType';
3
3
  import { DropdownMenuProps } from '../DropdownMenu/types';
4
+ import { Component } from 'vue';
4
5
 
5
- interface Props<Model extends number | string | null | boolean> extends Omit<FieldWrapperProps, 'modelValue'> {
6
+ export type ButtonGroupOptionProps<Option> = {
7
+ option: Option;
8
+ selected?: boolean;
9
+ };
10
+ export type ButtonGroupOptionComponent<Option> = Component<ButtonGroupOptionProps<Option>>;
11
+ interface ButtonGroupPropsBase<Model extends number | string | null | boolean> extends Omit<FieldWrapperProps, 'modelValue'> {
6
12
  modelValue: Model;
7
- loading?: number | string;
13
+ loading?: Model;
8
14
  minimize?: boolean;
9
15
  wrap?: boolean;
10
16
  col?: boolean;
@@ -12,18 +18,23 @@ interface Props<Model extends number | string | null | boolean> extends Omit<Fie
12
18
  stretch?: boolean;
13
19
  alwaysEmit?: boolean;
14
20
  }
15
- export interface ButtonGroupPropsForModel<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
21
+ interface ButtonGroupPropsForModel<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
16
22
  fn(value: Entity): Model;
17
- }['fn'] | undefined = undefined> extends Props<Model> {
23
+ }['fn'] | undefined = undefined> extends ButtonGroupPropsBase<Model> {
18
24
  list: Model[];
19
25
  valueGetter?: ValueGetter | undefined;
26
+ optionComponent?: ButtonGroupOptionComponent<Model>;
20
27
  }
21
- export interface ButtonGroupPropsForEntity<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
28
+ interface ButtonGroupPropsForEntity<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
22
29
  fn(value: Entity): Model;
23
- }['fn'] | undefined = undefined> extends Props<Model> {
30
+ }['fn'] | undefined = undefined> extends ButtonGroupPropsBase<Model> {
24
31
  list: Entity[];
25
32
  valueGetter: ValueGetter | ((value: Entity) => Model);
33
+ optionComponent?: ButtonGroupOptionComponent<Entity>;
26
34
  }
35
+ export type ButtonGroupProps<Model extends number | string | null | boolean, Entity extends Record<string, unknown>, ValueGetter extends {
36
+ fn(value: Entity): Model;
37
+ }['fn'] | undefined = undefined> = ButtonGroupPropsForEntity<Model, Entity, ValueGetter> | ButtonGroupPropsForModel<Model, Entity, ValueGetter>;
27
38
  export interface ButtonDropdownProps extends Omit<DropdownMenuProps, 'isOpen' | 'updateAlign' | 'emitUpdate'> {
28
39
  semanticType?: SemanticType;
29
40
  leftToggle?: boolean;
@@ -1 +1 @@
1
- {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Button/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAA;AACtE,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,sBAAsB,CAAA;AACtD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAA;AAEtE,UAAU,KAAK,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,OAAO,CAC5D,SAAQ,IAAI,CAAC,iBAAiB,EAAE,YAAY,CAAC;IAC7C,UAAU,EAAE,KAAK,CAAA;IACjB,OAAO,CAAC,EAAE,MAAM,GAAG,MAAM,CAAA;IACzB,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,GAAG,CAAC,EAAE,OAAO,CAAA;IACb,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED,MAAM,WAAW,wBAAwB,CAAC,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,GAAG,SAAS,CAC5M,SAAQ,KAAK,CAAC,KAAK,CAAC;IACpB,IAAI,EAAE,KAAK,EAAE,CAAA;IACb,WAAW,CAAC,EAAE,WAAW,GAAG,SAAS,CAAA;CACtC;AAED,MAAM,WAAW,yBAAyB,CAAC,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,GAAG,SAAS,CAC7M,SAAQ,KAAK,CAAC,KAAK,CAAC;IACpB,IAAI,EAAE,MAAM,EAAE,CAAA;IACd,WAAW,EAAE,WAAW,GAAG,CAAC,CAAC,KAAK,EAAE,MAAM,KAAK,KAAK,CAAC,CAAA;CACtD;AAED,MAAM,WAAW,mBAAoB,SAAQ,IAAI,CAAC,iBAAiB,EAAE,QAAQ,GAAG,aAAa,GAAG,YAAY,CAAC;IAC3G,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB"}
1
+ {"version":3,"file":"types.d.ts","sourceRoot":"","sources":["../../../src/components/Button/types.ts"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAA;AACtE,OAAO,KAAK,EAAC,YAAY,EAAC,MAAM,sBAAsB,CAAA;AACtD,OAAO,KAAK,EAAC,iBAAiB,EAAC,MAAM,iCAAiC,CAAA;AACtE,OAAO,KAAK,EAAC,SAAS,EAAC,MAAM,KAAK,CAAA;AAElC,MAAM,MAAM,sBAAsB,CAAC,MAAM,IAAI;IAAC,MAAM,EAAE,MAAM,CAAC;IAAC,QAAQ,CAAC,EAAE,OAAO,CAAA;CAAC,CAAA;AAEjF,MAAM,MAAM,0BAA0B,CAAC,MAAM,IAAI,SAAS,CAAC,sBAAsB,CAAC,MAAM,CAAC,CAAC,CAAA;AAE1F,UAAU,oBAAoB,CAAC,KAAK,SAAS,MAAM,GAAG,MAAM,GAAG,IAAI,GAAG,OAAO,CAC3E,SAAQ,IAAI,CAAC,iBAAiB,EAAE,YAAY,CAAC;IAC7C,UAAU,EAAE,KAAK,CAAA;IACjB,OAAO,CAAC,EAAE,KAAK,CAAA;IACf,QAAQ,CAAC,EAAE,OAAO,CAAA;IAClB,IAAI,CAAC,EAAE,OAAO,CAAA;IACd,GAAG,CAAC,EAAE,OAAO,CAAA;IACb,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,OAAO,CAAC,EAAE,OAAO,CAAA;IACjB,UAAU,CAAC,EAAE,OAAO,CAAA;CACrB;AAED,UAAU,wBAAwB,CAAC,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,GAAG,SAAS,CACrM,SAAQ,oBAAoB,CAAC,KAAK,CAAC;IACnC,IAAI,EAAE,KAAK,EAAE,CAAA;IACb,WAAW,CAAC,EAAE,WAAW,GAAG,SAAS,CAAA;IACrC,eAAe,CAAC,EAAE,0BAA0B,CAAC,KAAK,CAAC,CAAA;CACpD;AAED,UAAU,yBAAyB,CAAC,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,GAAG,SAAS,CACtM,SAAQ,oBAAoB,CAAC,KAAK,CAAC;IACnC,IAAI,EAAE,MAAM,EAAE,CAAA;IACd,WAAW,EAAE,WAAW,GAAG,CAAC,CAAC,KAAK,EAAE,MAAM,KAAK,KAAK,CAAC,CAAA;IACrD,eAAe,CAAC,EAAE,0BAA0B,CAAC,MAAM,CAAC,CAAA;CACrD;AAED,MAAM,MAAM,gBAAgB,CAAC,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,GAAG,SAAS,IAAI,yBAAyB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,CAAC,GAAG,wBAAwB,CAAC,KAAK,EAAE,MAAM,EAAE,WAAW,CAAC,CAAA;AAEjT,MAAM,WAAW,mBAAoB,SAAQ,IAAI,CAAC,iBAAiB,EAAE,QAAQ,GAAG,aAAa,GAAG,YAAY,CAAC;IAC3G,YAAY,CAAC,EAAE,YAAY,CAAA;IAC3B,UAAU,CAAC,EAAE,OAAO,CAAA;IACpB,QAAQ,CAAC,EAAE,OAAO,CAAA;CACnB"}
@@ -1 +1 @@
1
- {"version":3,"file":"WFormValidator.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WFormValidator.vue"],"names":[],"mappings":"AA8iBA,iBAAS,cAAc;aAVZ,MAAM,IAAI;;aAAV,MAAM,IAAI;EA+GpB;AACD,QAAA,MAAM,eAAe;WApXZ,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;;;wBA+OC,MAAM;qBA/DN,IAAI;;;;;WArLjB,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;;;;UAuXnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAAvG,wBAAwG;AAOxG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACpC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC;AAEN,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;AAC5D,KAAK,uBAAuB,CAAC,CAAC,IAAI;KAChC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,SAAS,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GACpC;QAAE,IAAI,EAAE,OAAO,KAAK,EAAE,QAAQ,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;KAAE,GAC9D;QAAE,IAAI,EAAE,OAAO,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAAC,QAAQ,EAAE,IAAI,CAAA;KAAE;CACzD,CAAC"}
1
+ {"version":3,"file":"WFormValidator.vue.d.ts","sourceRoot":"","sources":["../../../src/components/Form/WFormValidator.vue"],"names":[],"mappings":"AA0iBA,iBAAS,cAAc;aAVZ,MAAM,IAAI;;aAAV,MAAM,IAAI;EA+GpB;AACD,QAAA,MAAM,eAAe;WAjXZ,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;;;wBA4OC,MAAM;qBA/DN,IAAI;;;;;WAlLjB,MAAM;YACL,MAAM;eACH,UAAU,GAAG,UAAU,EAAE;sBAClB,MAAM;sBACN,MAAM;gBACZ,OAAO;;;;UAoXnB,CAAC;wBACkB,uBAAuB,CAAC,OAAO,eAAe,EAAE,UAAU,CAAC,OAAO,cAAc,CAAC,CAAC;AAAvG,wBAAwG;AAOxG,KAAK,uBAAuB,CAAC,CAAC,EAAE,CAAC,IAAI,CAAC,GAAG;IACpC,QAAO;QACN,MAAM,EAAE,CAAC,CAAC;KAEV,CAAA;CACD,CAAC;AAEN,KAAK,sBAAsB,CAAC,CAAC,IAAI,CAAC,SAAS,SAAS,GAAG,KAAK,GAAG,CAAC,CAAC;AAC5D,KAAK,uBAAuB,CAAC,CAAC,IAAI;KAChC,CAAC,IAAI,MAAM,CAAC,CAAC,CAAC,GAAG,EAAE,SAAS,IAAI,CAAC,CAAC,EAAE,CAAC,CAAC,GACpC;QAAE,IAAI,EAAE,OAAO,KAAK,EAAE,QAAQ,CAAC,sBAAsB,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA;KAAE,GAC9D;QAAE,IAAI,EAAE,OAAO,KAAK,EAAE,QAAQ,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC,CAAC;QAAC,QAAQ,EAAE,IAAI,CAAA;KAAE;CACzD,CAAC"}
@@ -3,6 +3,7 @@ import { wFormTitleUpdater, wFormErrorMessageUpdater, wFormHasChangesUpdater, wF
3
3
  import { useTabActiveListener } from '../Tabs/use/useTabActiveListener.js';
4
4
  import { scrollToValidator } from './models/utils.js';
5
5
  import { useIsInsideTab } from '../Tabs/use/useIsInsideTab.js';
6
+ import { validateRequired } from '../../utils/validate.js';
6
7
 
7
8
  const _sfc_main = /* @__PURE__ */ defineComponent({
8
9
  __name: "WFormValidator",
@@ -61,10 +62,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
61
62
  }
62
63
  };
63
64
  const _validate = (value) => {
64
- if (required.value && !value) {
65
- const message2 = "A value is required";
66
- return message2;
67
- }
65
+ const requiredMessage = required.value ? validateRequired(value) : void 0;
66
+ if (requiredMessage) return requiredMessage;
68
67
  if (props.forbiddenRegexp && typeof value === "string") {
69
68
  const match = value.match(props.forbiddenRegexp);
70
69
  if (match?.length) {
@@ -0,0 +1,25 @@
1
+ import { FormAsyncButtonGroupProps } from './types';
2
+
3
+ declare const _default: <Model, FieldType extends string | number | boolean | null, QueryParams, Entity extends Record<string, unknown>, ValueGetter extends {
4
+ fn(value: Entity): FieldType;
5
+ }["fn"] | undefined = undefined>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_Prettify<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
6
+ props: __VLS_Prettify<Pick<Partial<{}> & Omit<{} & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & Readonly<import('vue').ExtractPropTypes<{}>>, never>, never> & FormAsyncButtonGroupProps<Model, FieldType, QueryParams, Entity, ValueGetter>> & import('vue').PublicProps;
7
+ expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
8
+ attrs: any;
9
+ slots: ReturnType<() => {
10
+ default?(_: {
11
+ option: FieldType | Entity | (ValueGetter extends undefined ? FieldType : Entity);
12
+ selected: boolean;
13
+ }): any;
14
+ }>;
15
+ emit: {};
16
+ }>) => import('vue').VNode<import('vue').RendererNode, import('vue').RendererElement, {
17
+ [key: string]: any;
18
+ }> & {
19
+ __ctx?: Awaited<typeof __VLS_setup>;
20
+ };
21
+ export default _default;
22
+ type __VLS_Prettify<T> = {
23
+ [K in keyof T]: T[K];
24
+ } & {};
25
+ //# sourceMappingURL=WFormAsyncButtonGroup.vue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WFormAsyncButtonGroup.vue.d.ts","sourceRoot":"","sources":["../../../src/components/FormAsync/WFormAsyncButtonGroup.vue"],"names":[],"mappings":"AA6FA,OAAO,KAAK,EAAC,yBAAyB,EAAC,MAAM,SAAS,CAAA;yBAOrC,KAAK,EAAE,SAAS,SAAS,MAAM,GAAG,MAAM,GAAG,OAAO,GAAG,IAAI,EAAE,WAAW,EAAE,MAAM,SAAS,MAAM,CAAC,MAAM,EAAE,OAAO,CAAC,EAAE,WAAW,SAAS;IAAC,EAAE,CAAC,KAAK,EAAE,MAAM,GAAG,SAAS,CAAA;CAAC,CAAC,IAAI,CAAC,GAAG,SAAS,2BACvL,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBACvF,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WAoKxD,cAAc,CAAC,+QAAyD,CAAC,4BAA2B;oBAC3F,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;WACH,UAAU;;;;YAzBS,GAAG;MAyBW;;;;;YAIC,OAAO,CAAC,OAAO,WAAW,CAAC;;AA9KvE,wBA8K4E;AAM5E,KAAK,cAAc,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -0,0 +1,101 @@
1
+ import { defineComponent, toRef, ref, computed, onBeforeUnmount, openBlock, createBlock, mergeProps, unref, createSlots, withCtx, renderSlot } from 'vue';
2
+ import { Notify } from '../../utils/Notify.js';
3
+ import _sfc_main$1 from '../Button/WButtonGroup.vue.js';
4
+ import { get, set } from '../../utils/utils.js';
5
+ import { handleApiError } from '../../utils/api.js';
6
+ import { Modal } from '../../utils/Modal.js';
7
+
8
+ const _sfc_main = /* @__PURE__ */ defineComponent({
9
+ __name: "WFormAsyncButtonGroup",
10
+ props: {
11
+ useQueryFn: {},
12
+ noParams: { type: Boolean },
13
+ queryParams: {},
14
+ queryEnabled: { type: Boolean },
15
+ field: {},
16
+ apiMethod: { type: Function },
17
+ confimGetter: { type: Function },
18
+ list: {},
19
+ valueGetter: { type: Function },
20
+ optionComponent: {},
21
+ minimize: { type: Boolean },
22
+ wrap: { type: Boolean },
23
+ col: { type: Boolean },
24
+ semanticType: {},
25
+ stretch: { type: Boolean },
26
+ alwaysEmit: { type: Boolean },
27
+ title: {},
28
+ description: {},
29
+ errorMessage: {},
30
+ tooltipText: {},
31
+ maxLength: {},
32
+ mono: { type: Boolean },
33
+ hasChanges: { type: Boolean },
34
+ skeleton: { type: Boolean },
35
+ disabled: { type: Boolean },
36
+ required: { type: Boolean },
37
+ noMargin: { type: Boolean },
38
+ allowCopy: { type: Boolean }
39
+ },
40
+ setup(__props) {
41
+ const props = __props;
42
+ const { data, setData, isLoadingError } = props.noParams === true ? props.useQueryFn({ enabled: toRef(props, "queryEnabled") }) : props.useQueryFn(toRef(props, "queryParams"), { enabled: toRef(props, "queryEnabled") });
43
+ const submittingItem = ref();
44
+ const modelValue = computed(() => get(data.value ?? {}, props.field) ?? null);
45
+ const save = (value) => {
46
+ if (submittingItem.value !== void 0) return;
47
+ submittingItem.value = value;
48
+ return props.apiMethod(set({}, props.field, value)).then((response) => {
49
+ setData(response.data);
50
+ Notify.success({ title: "Saved" });
51
+ }).catch((error) => handleApiError(error, void 0, props.field)).finally(() => {
52
+ submittingItem.value = void 0;
53
+ });
54
+ };
55
+ let closeModal = null;
56
+ const showModal = (value) => {
57
+ closeModal?.();
58
+ const confirmProps = props.confimGetter?.(value);
59
+ if (!confirmProps) {
60
+ save(value);
61
+ return;
62
+ }
63
+ closeModal = Modal.addConfirm({
64
+ ...confirmProps,
65
+ onAccept: () => {
66
+ return save(value);
67
+ }
68
+ }, () => closeModal = null);
69
+ };
70
+ onBeforeUnmount(() => {
71
+ closeModal?.();
72
+ closeModal = null;
73
+ });
74
+ return (_ctx, _cache) => {
75
+ return openBlock(), createBlock(_sfc_main$1, mergeProps({
76
+ ...props,
77
+ modelValue: modelValue.value,
78
+ list: _ctx.list,
79
+ optionComponent: _ctx.optionComponent,
80
+ loading: submittingItem.value,
81
+ disabled: _ctx.disabled || unref(isLoadingError),
82
+ skeleton: _ctx.skeleton || !unref(data)
83
+ }, {
84
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => showModal($event))
85
+ }), createSlots({ _: 2 }, [
86
+ _ctx.$slots.option ? {
87
+ name: "option",
88
+ fn: withCtx(({ option, selected }) => [
89
+ renderSlot(_ctx.$slots, "default", {
90
+ option,
91
+ selected
92
+ })
93
+ ]),
94
+ key: "0"
95
+ } : void 0
96
+ ]), 1040);
97
+ };
98
+ }
99
+ });
100
+
101
+ export { _sfc_main as default };
@@ -0,0 +1,5 @@
1
+ import _sfc_main from './WFormAsyncButtonGroup.vue.js';
2
+
3
+
4
+
5
+ export { _sfc_main as default };
@@ -0,0 +1,26 @@
1
+ import { FormAsyncInputProps } from './types';
2
+
3
+ declare const _default: <Model, FieldType extends string | number, QueryParams>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_Prettify<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
4
+ props: __VLS_Prettify<Pick<Partial<{}> & Omit<{
5
+ onSuccess?: ((value: Model) => any) | undefined;
6
+ } & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & Readonly<import('vue').ExtractPropTypes<{}>> & {
7
+ onSuccess?: ((value: Model) => any) | undefined;
8
+ }, never>, "onSuccess"> & FormAsyncInputProps<Model, FieldType, QueryParams>> & import('vue').PublicProps;
9
+ expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
10
+ attrs: any;
11
+ slots: ReturnType<() => {
12
+ title?(_: {}): any;
13
+ subtitle?(_: {}): any;
14
+ right?(_: {}): any;
15
+ }>;
16
+ emit: ((e: "success", value: Model) => void) & {};
17
+ }>) => import('vue').VNode<import('vue').RendererNode, import('vue').RendererElement, {
18
+ [key: string]: any;
19
+ }> & {
20
+ __ctx?: Awaited<typeof __VLS_setup>;
21
+ };
22
+ export default _default;
23
+ type __VLS_Prettify<T> = {
24
+ [K in keyof T]: T[K];
25
+ } & {};
26
+ //# sourceMappingURL=WFormAsyncInput.vue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WFormAsyncInput.vue.d.ts","sourceRoot":"","sources":["../../../src/components/FormAsync/WFormAsyncInput.vue"],"names":[],"mappings":"AA8HA,OAAO,KAAK,EAAC,mBAAmB,EAAC,MAAM,SAAS,CAAA;yBAI/B,KAAK,EAAE,SAAS,SAAS,MAAM,GAAG,MAAM,EAAE,WAAW,eACxD,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBACvF,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WA8MxD,cAAc,CAAC;;;;gFAAyD,CAAC,4BAA2B;oBAC3F,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;WACH,UAAU;uBA7BO,GAAG;0BACA,GAAG;uBACN,GAAG;MA2Ba;UAClC,KAzMH,SAAS,SAAS,KAAK,KAAG,IAAI,MAyMO;;;;YAGC,OAAO,CAAC,OAAO,WAAW,CAAC;;AAxNvE,wBAwN4E;AAM5E,KAAK,cAAc,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -0,0 +1,131 @@
1
+ import { defineComponent, toRef, ref, computed, onBeforeUnmount, openBlock, createBlock, mergeProps, unref, createSlots, withCtx, renderSlot } from 'vue';
2
+ import _sfc_main$1 from '../Input/WInputAsync.vue.js';
3
+ import { Notify } from '../../utils/Notify.js';
4
+ import { validateRequired } from '../../utils/validate.js';
5
+ import { Modal } from '../../utils/Modal.js';
6
+ import { handleApiError } from '../../utils/api.js';
7
+ import { get, set } from '../../utils/utils.js';
8
+
9
+ const _sfc_main = /* @__PURE__ */ defineComponent({
10
+ __name: "WFormAsyncInput",
11
+ props: {
12
+ useQueryFn: {},
13
+ noParams: { type: Boolean },
14
+ queryParams: {},
15
+ queryEnabled: { type: Boolean },
16
+ field: {},
17
+ apiMethod: { type: Function },
18
+ confimGetter: { type: Function },
19
+ validate: {},
20
+ type: {},
21
+ textarea: { type: Boolean },
22
+ resize: { type: Boolean },
23
+ placeholder: {},
24
+ icon: {},
25
+ size: {},
26
+ maxLength: {},
27
+ name: {},
28
+ autocomplete: {},
29
+ autofocus: { type: Boolean },
30
+ readonly: { type: Boolean },
31
+ disabledActions: { type: Boolean },
32
+ loading: { type: Boolean },
33
+ spellcheck: { type: Boolean },
34
+ customBackspaceHandle: { type: Boolean },
35
+ textSecure: { type: Boolean },
36
+ allowClear: { type: Boolean },
37
+ allowPaste: { type: Boolean },
38
+ hideInput: { type: Boolean },
39
+ title: {},
40
+ description: {},
41
+ errorMessage: {},
42
+ tooltipText: {},
43
+ mono: { type: Boolean },
44
+ hasChanges: { type: Boolean },
45
+ skeleton: { type: Boolean },
46
+ disabled: { type: Boolean },
47
+ required: { type: Boolean },
48
+ noMargin: { type: Boolean },
49
+ allowCopy: { type: Boolean }
50
+ },
51
+ emits: ["success"],
52
+ setup(__props, { emit: __emit }) {
53
+ const props = __props;
54
+ const emit = __emit;
55
+ const { data, setData, isLoadingError } = props.noParams === true ? props.useQueryFn({ enabled: toRef(props, "queryEnabled") }) : props.useQueryFn(toRef(props, "queryParams"), { enabled: toRef(props, "queryEnabled") });
56
+ const submitting = ref(false);
57
+ const modelValue = computed(() => get(data.value ?? {}, props.field));
58
+ const validateFn = computed(() => {
59
+ const result = Array.isArray(props.validate) ? props.validate.slice() : props.validate ? [props.validate] : [];
60
+ if (props.required && !props.textSecure) result.push(validateRequired);
61
+ return result;
62
+ });
63
+ const save = (value) => {
64
+ if (submitting.value) return;
65
+ submitting.value = true;
66
+ return props.apiMethod(set({}, props.field, value ?? null)).then((response) => {
67
+ setData(response.data);
68
+ Notify.success({ title: "Saved" });
69
+ emit("success", response.data);
70
+ }).catch((error) => handleApiError(error, void 0, props.field)).finally(() => {
71
+ submitting.value = false;
72
+ });
73
+ };
74
+ let closeModal = null;
75
+ const showModal = (value) => {
76
+ closeModal?.();
77
+ const confirmProps = props.confimGetter?.(value);
78
+ if (!confirmProps) {
79
+ save(value);
80
+ return;
81
+ }
82
+ closeModal = Modal.addConfirm({
83
+ ...confirmProps,
84
+ onAccept: () => {
85
+ return save(value);
86
+ }
87
+ }, () => closeModal = null);
88
+ };
89
+ onBeforeUnmount(() => {
90
+ closeModal?.();
91
+ closeModal = null;
92
+ });
93
+ return (_ctx, _cache) => {
94
+ return openBlock(), createBlock(_sfc_main$1, mergeProps({
95
+ ...props,
96
+ modelValue: _ctx.textSecure ? void 0 : modelValue.value,
97
+ skeleton: _ctx.skeleton || !unref(data),
98
+ disabled: _ctx.disabled || unref(isLoadingError),
99
+ loading: _ctx.loading || submitting.value,
100
+ validate: validateFn.value,
101
+ placeholderSecure: _ctx.textSecure ? !!modelValue.value : void 0
102
+ }, {
103
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => showModal($event))
104
+ }), createSlots({ _: 2 }, [
105
+ _ctx.$slots.title ? {
106
+ name: "title",
107
+ fn: withCtx(() => [
108
+ renderSlot(_ctx.$slots, "title")
109
+ ]),
110
+ key: "0"
111
+ } : void 0,
112
+ _ctx.$slots.subtitle ? {
113
+ name: "subtitle",
114
+ fn: withCtx(() => [
115
+ renderSlot(_ctx.$slots, "subtitle")
116
+ ]),
117
+ key: "1"
118
+ } : void 0,
119
+ _ctx.$slots.right ? {
120
+ name: "right",
121
+ fn: withCtx(() => [
122
+ renderSlot(_ctx.$slots, "right")
123
+ ]),
124
+ key: "2"
125
+ } : void 0
126
+ ]), 1040);
127
+ };
128
+ }
129
+ });
130
+
131
+ export { _sfc_main as default };
@@ -0,0 +1,5 @@
1
+ import _sfc_main from './WFormAsyncInput.vue.js';
2
+
3
+
4
+
5
+ export { _sfc_main as default };
@@ -0,0 +1,27 @@
1
+ import { FormAsyncSelectProps } from './types';
2
+ import { SelectOptionComponent } from '../Select/types';
3
+
4
+ declare const _default: <Model, FieldType extends string | number, QueryParams, Data extends DefaultData, OptionComponent extends SelectOptionComponent<Data>, AllowClear extends boolean = false>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: __VLS_Prettify<Pick<NonNullable<Awaited<typeof __VLS_setup>>, "attrs" | "emit" | "slots">>, __VLS_expose?: NonNullable<Awaited<typeof __VLS_setup>>["expose"], __VLS_setup?: Promise<{
5
+ props: __VLS_Prettify<Pick<Partial<{}> & Omit<{
6
+ onSuccess?: ((value: Model) => any) | undefined;
7
+ } & import('vue').VNodeProps & import('vue').AllowedComponentProps & import('vue').ComponentCustomProps & Readonly<import('vue').ExtractPropTypes<{}>> & {
8
+ onSuccess?: ((value: Model) => any) | undefined;
9
+ }, never>, "onSuccess"> & FormAsyncSelectProps<Model, FieldType, QueryParams, Data, OptionComponent, AllowClear>> & import('vue').PublicProps;
10
+ expose(exposed: import('vue').ShallowUnwrapRef<{}>): void;
11
+ attrs: any;
12
+ slots: ReturnType<() => {
13
+ title?(_: {}): any;
14
+ subtitle?(_: {}): any;
15
+ right?(_: {}): any;
16
+ }>;
17
+ emit: ((e: "success", value: 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_Prettify<T> = {
25
+ [K in keyof T]: T[K];
26
+ } & {};
27
+ //# sourceMappingURL=WFormAsyncSelectSingle.vue.d.ts.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"WFormAsyncSelectSingle.vue.d.ts","sourceRoot":"","sources":["../../../src/components/FormAsync/WFormAsyncSelectSingle.vue"],"names":[],"mappings":"AA0GA,OAAO,KAAK,EAAC,oBAAoB,EAAC,MAAM,SAAS,CAAA;AACjD,OAAO,KAAK,EAAC,qBAAqB,EAAC,MAAM,2BAA2B,CAAA;yBAQnD,KAAK,EAAE,SAAS,SAAS,MAAM,GAAG,MAAM,EAAE,WAAW,EAAE,IAAI,SAAS,WAAW,EAAE,eAAe,SAAS,qBAAqB,CAAC,IAAI,CAAC,EAAE,UAAU,SAAS,OAAO,uBACnK,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,OAAO,CAAC,cAClD,cAAc,CAAC,IAAI,CAAC,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,EAAE,OAAO,GAAG,MAAM,GAAG,OAAO,CAAC,CAAC,iBACvF,WAAW,CAAC,OAAO,CAAC,OAAO,WAAW,CAAC,CAAC,CAAC,QAAQ,CAAC;WA2LxD,cAAc,CAAC;;;;oHAAyD,CAAC,4BAA2B;oBAC3F,OAAO,KAAK,EAAE,gBAAgB,CAAC,EAAE,CAAC,GAAG,IAAI;WAClD,GAAG;WACH,UAAU;uBA5BO,GAAG;0BACA,GAAG;uBACN,GAAG;MA0Ba;UAClC,KAtLH,SAAS,SAAS,KAAK,KAAG,IAAI,MAsLO;;;;YAGC,OAAO,CAAC,OAAO,WAAW,CAAC;;AArMvE,wBAqM4E;AAM5E,KAAK,cAAc,CAAC,CAAC,IAAI;KAAG,CAAC,IAAI,MAAM,CAAC,GAAG,CAAC,CAAC,CAAC,CAAC;CAAG,GAAG,EAAE,CAAC"}
@@ -0,0 +1,139 @@
1
+ import { defineComponent, toRef, ref, computed, onBeforeUnmount, openBlock, createBlock, mergeProps, unref, createSlots, withCtx, renderSlot } from 'vue';
2
+ import _sfc_main$1 from '../Select/WSelectSingle.vue.js';
3
+ import { get, set } from '../../utils/utils.js';
4
+ import { Notify } from '../../utils/Notify.js';
5
+ import { handleApiError } from '../../utils/api.js';
6
+ import { Modal } from '../../utils/Modal.js';
7
+
8
+ const _sfc_main = /* @__PURE__ */ defineComponent({
9
+ __name: "WFormAsyncSelectSingle",
10
+ props: {
11
+ useQueryFn: {},
12
+ noParams: { type: Boolean },
13
+ queryParams: {},
14
+ queryEnabled: { type: Boolean },
15
+ field: {},
16
+ apiMethod: { type: Function },
17
+ confimGetter: { type: Function },
18
+ allowClear: { type: Boolean },
19
+ searchModel: { type: Boolean },
20
+ useQueryFnOptions: {},
21
+ valueGetter: { type: Function },
22
+ searchFn: { type: Function },
23
+ emptyStub: {},
24
+ hidePrefix: { type: Boolean },
25
+ allowCreate: { type: Boolean },
26
+ hideOptionIcon: { type: Boolean },
27
+ mobileTitle: {},
28
+ persist: { type: Boolean },
29
+ type: {},
30
+ textarea: { type: Boolean },
31
+ resize: { type: Boolean },
32
+ placeholder: {},
33
+ icon: {},
34
+ size: {},
35
+ maxLength: {},
36
+ name: {},
37
+ autocomplete: {},
38
+ autofocus: { type: Boolean },
39
+ readonly: { type: Boolean },
40
+ disabledActions: { type: Boolean },
41
+ loading: { type: Boolean },
42
+ spellcheck: { type: Boolean },
43
+ customBackspaceHandle: { type: Boolean },
44
+ textSecure: { type: Boolean },
45
+ placeholderSecure: { type: Boolean },
46
+ allowPaste: { type: Boolean },
47
+ title: {},
48
+ description: {},
49
+ errorMessage: {},
50
+ tooltipText: {},
51
+ mono: { type: Boolean },
52
+ hasChanges: { type: Boolean },
53
+ skeleton: { type: Boolean },
54
+ disabled: { type: Boolean },
55
+ required: { type: Boolean },
56
+ noMargin: { type: Boolean },
57
+ allowCopy: { type: Boolean },
58
+ teleport: { type: Boolean },
59
+ noZIndex: { type: Boolean },
60
+ maxHeight: {},
61
+ maxWidth: {},
62
+ horizontalAlign: {},
63
+ optionComponent: {},
64
+ optionComponentProps: {}
65
+ },
66
+ emits: ["success"],
67
+ setup(__props, { emit: __emit }) {
68
+ const props = __props;
69
+ const emit = __emit;
70
+ const { data, setData, isLoadingError } = props.noParams === true ? props.useQueryFn({ enabled: toRef(props, "queryEnabled") }) : props.useQueryFn(toRef(props, "queryParams"), { enabled: toRef(props, "queryEnabled") });
71
+ const submitting = ref(false);
72
+ const modelValue = computed(() => get(data.value ?? {}, props.field) ?? null);
73
+ const save = (value) => {
74
+ if (submitting.value) return;
75
+ submitting.value = true;
76
+ return props.apiMethod(set({}, props.field, value)).then((response) => {
77
+ setData(response.data);
78
+ Notify.success({ title: "Saved" });
79
+ emit("success", response.data);
80
+ }).catch((error) => handleApiError(error, void 0, props.field)).finally(() => {
81
+ submitting.value = false;
82
+ });
83
+ };
84
+ let closeModal = null;
85
+ const showModal = (value) => {
86
+ closeModal?.();
87
+ const confirmProps = props.confimGetter?.(value);
88
+ if (!confirmProps) {
89
+ save(value);
90
+ return;
91
+ }
92
+ closeModal = Modal.addConfirm({
93
+ ...confirmProps,
94
+ onAccept: () => {
95
+ return save(value);
96
+ }
97
+ }, () => closeModal = null);
98
+ };
99
+ onBeforeUnmount(() => {
100
+ closeModal?.();
101
+ closeModal = null;
102
+ });
103
+ return (_ctx, _cache) => {
104
+ return openBlock(), createBlock(_sfc_main$1, mergeProps({
105
+ ...props,
106
+ modelValue: modelValue.value,
107
+ skeleton: _ctx.skeleton || !unref(data),
108
+ disabled: _ctx.disabled || unref(isLoadingError),
109
+ loading: _ctx.loading || submitting.value
110
+ }, {
111
+ "onUpdate:modelValue": _cache[0] || (_cache[0] = ($event) => showModal($event ?? null))
112
+ }), createSlots({ _: 2 }, [
113
+ _ctx.$slots.title ? {
114
+ name: "title",
115
+ fn: withCtx(() => [
116
+ renderSlot(_ctx.$slots, "title")
117
+ ]),
118
+ key: "0"
119
+ } : void 0,
120
+ _ctx.$slots.subtitle ? {
121
+ name: "subtitle",
122
+ fn: withCtx(() => [
123
+ renderSlot(_ctx.$slots, "subtitle")
124
+ ]),
125
+ key: "1"
126
+ } : void 0,
127
+ _ctx.$slots.right ? {
128
+ name: "right",
129
+ fn: withCtx(() => [
130
+ renderSlot(_ctx.$slots, "right")
131
+ ]),
132
+ key: "2"
133
+ } : void 0
134
+ ]), 1040);
135
+ };
136
+ }
137
+ });
138
+
139
+ export { _sfc_main as default };
@@ -0,0 +1,5 @@
1
+ import _sfc_main from './WFormAsyncSelectSingle.vue.js';
2
+
3
+
4
+
5
+ export { _sfc_main as default };