@qin-ui/antd-vue-pro 1.1.9 → 1.1.11

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/LICENSE ADDED
@@ -0,0 +1,9 @@
1
+ MIT License
2
+
3
+ Copyright (c) 2023-present pro-components
4
+
5
+ Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:
6
+
7
+ The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.
8
+
9
+ THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
@@ -15714,7 +15714,7 @@ Form$1.install = function(app) {
15714
15714
  app.component(FormItemRest.name, FormItemRest);
15715
15715
  return app;
15716
15716
  };
15717
- const FORM_ITEM_SLOT_KEYS = ["label", "extra", "help"];
15717
+ const FORM_ITEM_SLOT_KEYS = ["label", "extra", "help", "tooltip"];
15718
15718
  const COMPONENT_MAP = /* @__PURE__ */ new Map([
15719
15719
  ["input", Input],
15720
15720
  ["textarea", Textarea],
@@ -15738,6 +15738,7 @@ const UPDATE_FORM_DATA = Symbol(
15738
15738
  "updateFormData"
15739
15739
  );
15740
15740
  const UPDATE_REFS = Symbol("updateRefs");
15741
+ const GET_REF = Symbol("getRef");
15741
15742
  const COMMAND = Symbol("command");
15742
15743
  const UPDATE_ACTIVE_PATH = Symbol(
15743
15744
  "setActivePath"
@@ -15787,7 +15788,7 @@ const _sfc_main$4 = /* @__PURE__ */ defineComponent({
15787
15788
  if (!el)
15788
15789
  return;
15789
15790
  const path = getPath(field.key);
15790
- updateRefs == null ? void 0 : updateRefs(path, el, "formItemRefs");
15791
+ updateRefs == null ? void 0 : updateRefs("formItemRefs", path, el);
15791
15792
  };
15792
15793
  const proFormPropKeys = computed(() => {
15793
15794
  return [
@@ -16160,7 +16161,6 @@ async function validateConditions(conditions, baseParam) {
16160
16161
  return result;
16161
16162
  }
16162
16163
  async function runRules(rules2, baseParam) {
16163
- var _a, _b;
16164
16164
  const { form, run, refs, message: message2, logQueue } = baseParam;
16165
16165
  logQueue.push([[`逻辑执行规则: `, ["purple", "indent2"]]]);
16166
16166
  for (let ruleIndex = 0; ruleIndex < rules2.length; ruleIndex += 1) {
@@ -16235,10 +16235,8 @@ async function runRules(rules2, baseParam) {
16235
16235
  form.setField(path, (preField) => ({ ...preField, ...value }));
16236
16236
  break;
16237
16237
  case "validate":
16238
- (_a = refs.formItemRefs[path]) == null ? void 0 : _a.validate();
16239
16238
  break;
16240
16239
  case "clearValidate":
16241
- (_b = refs.formItemRefs[path]) == null ? void 0 : _b.restoreValidation();
16242
16240
  break;
16243
16241
  case "message":
16244
16242
  message2.info(value);
@@ -16366,9 +16364,16 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
16366
16364
  const formData = inject(FORM_DATA);
16367
16365
  const updateFormData = inject(UPDATE_FORM_DATA);
16368
16366
  const updateRefs = inject(UPDATE_REFS);
16367
+ const getRef = inject(GET_REF);
16369
16368
  const command = inject(COMMAND);
16370
16369
  const updateActivePath = inject(UPDATE_ACTIVE_PATH);
16371
16370
  const { getInitProps } = useInitProps();
16371
+ const triggerRefChange = () => {
16372
+ if (typeof props.component === "string" && COMPONENT_MAP.has(props.component))
16373
+ return;
16374
+ const formItemRef = getRef == null ? void 0 : getRef("formItemRefs", props.path);
16375
+ formItemRef == null ? void 0 : formItemRef.onFieldChange();
16376
+ };
16372
16377
  const value = computed({
16373
16378
  get() {
16374
16379
  return get$1(formData == null ? void 0 : formData.value, props.path);
@@ -16380,6 +16385,7 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
16380
16385
  return;
16381
16386
  }
16382
16387
  updateFormData == null ? void 0 : updateFormData(props.path, val);
16388
+ triggerRefChange();
16383
16389
  }
16384
16390
  });
16385
16391
  const forceUpdateKey = ref(0);
@@ -16445,7 +16451,7 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
16445
16451
  const setComponentRef = (el) => {
16446
16452
  if (!el)
16447
16453
  return;
16448
- updateRefs == null ? void 0 : updateRefs(props.path, el, "fieldRefs");
16454
+ updateRefs == null ? void 0 : updateRefs("fieldRefs", props.path, el);
16449
16455
  };
16450
16456
  onMounted(() => {
16451
16457
  var _a, _b, _c;
@@ -16491,7 +16497,7 @@ const _sfc_main$3 = /* @__PURE__ */ defineComponent({
16491
16497
  };
16492
16498
  }
16493
16499
  });
16494
- const index_vue_vue_type_style_index_0_scoped_060ffbee_lang = "";
16500
+ const index_vue_vue_type_style_index_0_scoped_9a3bf1a0_lang = "";
16495
16501
  const _export_sfc = (sfc, props) => {
16496
16502
  const target = sfc.__vccOpts || sfc;
16497
16503
  for (const [key, val] of props) {
@@ -16499,7 +16505,7 @@ const _export_sfc = (sfc, props) => {
16499
16505
  }
16500
16506
  return target;
16501
16507
  };
16502
- const BaseField = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-060ffbee"]]);
16508
+ const BaseField = /* @__PURE__ */ _export_sfc(_sfc_main$3, [["__scopeId", "data-v-9a3bf1a0"]]);
16503
16509
  const _sfc_main$2 = /* @__PURE__ */ defineComponent({
16504
16510
  ...{
16505
16511
  name: "ContainerFragment",
@@ -16560,12 +16566,15 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
16560
16566
  formItemRefs: {},
16561
16567
  fieldRefs: {}
16562
16568
  };
16563
- const updateRefs = (path, childRef, type4) => {
16569
+ const updateRefs = (type4, path, childRef) => {
16564
16570
  if (!path)
16565
16571
  return;
16566
16572
  refs[type4][path] = childRef;
16567
16573
  };
16568
- const exposed = shallowReactive({ refs });
16574
+ const getRef = (type4, path) => {
16575
+ return refs[type4][path];
16576
+ };
16577
+ const exposed = shallowReactive({ refs, getRef });
16569
16578
  const updateActivePath = (path) => {
16570
16579
  var _a, _b;
16571
16580
  if (props.form) {
@@ -16610,6 +16619,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
16610
16619
  provide(FORM_DATA, _formData);
16611
16620
  provide(UPDATE_FORM_DATA, updateFormData);
16612
16621
  provide(UPDATE_REFS, updateRefs);
16622
+ provide(GET_REF, getRef);
16613
16623
  provide(COMMAND, command);
16614
16624
  provide(UPDATE_ACTIVE_PATH, updateActivePath);
16615
16625
  __expose(exposed);
@@ -16637,6 +16647,7 @@ export {
16637
16647
  BaseField as B,
16638
16648
  COMPONENT_MAP as C,
16639
16649
  FORM_ITEM_SLOT_KEYS as F,
16650
+ GET_REF as G,
16640
16651
  RULE_TYPE_MAP as R,
16641
16652
  UPDATE_FORM_DATA as U,
16642
16653
  _sfc_main as _,
package/es/form/index.js CHANGED
@@ -1,4 +1,4 @@
1
- import { l, B, d, i, C, b, f, F, k, R, e, j, U, h, _, m, p, n, s, q, u, r, t } from "./index-3d705aab.js";
1
+ import { l, B, d, i, C, b, f, F, k, G, R, e, j, U, h, _, m, p, n, s, q, u, r, t } from "./index-2a04ad4a.js";
2
2
  import "vue";
3
3
  import "ant-design-vue";
4
4
  import "../component-provider/index.js";
@@ -12,6 +12,7 @@ export {
12
12
  f as FORM_DATA,
13
13
  F as FORM_ITEM_SLOT_KEYS,
14
14
  k as FunctionRegexp,
15
+ G as GET_REF,
15
16
  R as RULE_TYPE_MAP,
16
17
  e as SlotComponent,
17
18
  j as UPDATE_ACTIVE_PATH,
package/es/index.d.ts CHANGED
@@ -25,6 +25,7 @@ import { ExpandedRowRender } from 'ant-design-vue/es/vc-table/interface';
25
25
  import { ExtractPropTypes } from 'vue';
26
26
  import { FieldData } from 'ant-design-vue/es/form/interface';
27
27
  import { FilterValue } from 'ant-design-vue/es/table/interface';
28
+ import type { FormItemInstance } from 'ant-design-vue';
28
29
  import type { FormItemProps } from 'ant-design-vue';
29
30
  import { FormLabelAlign } from 'ant-design-vue/es/form/interface';
30
31
  import { FormProps as FormProps_2 } from 'ant-design-vue';
@@ -58,7 +59,7 @@ import type { Select } from 'ant-design-vue';
58
59
  import { SelectProps } from 'ant-design-vue';
59
60
  import { ShallowUnwrapRef } from 'vue';
60
61
  import { SliderProps } from 'ant-design-vue';
61
- import { Slot as Slot_2 } from 'vue';
62
+ import { Slot } from 'vue';
62
63
  import { SorterResult } from 'ant-design-vue/es/table/interface';
63
64
  import { SortOrder } from 'ant-design-vue/es/table/interface';
64
65
  import { SwitchProps } from 'ant-design-vue';
@@ -377,6 +378,7 @@ declare const _default_2: __VLS_WithTemplateSlots<DefineComponent<__VLS_WithDefa
377
378
  activePath: undefined;
378
379
  }>, {
379
380
  refs: Refs;
381
+ getRef: GetRef;
380
382
  resetFields: (name?: NamePath | undefined) => void;
381
383
  clearValidate: (name?: NamePath | undefined) => void;
382
384
  validateFields: (nameList?: string | NamePath[] | undefined, options?: ValidateOptions | undefined) => Promise<{
@@ -1851,10 +1853,12 @@ export declare type FieldType = {
1851
1853
  /** 穿梭框 */
1852
1854
  'transfer': {
1853
1855
  component: 'transfer';
1856
+ slots?: TransferSlots;
1854
1857
  } & TransferProps;
1855
1858
  /** 自定义组件 */
1856
1859
  'custom': {
1857
1860
  component?: RenderComponentType | Raw<RenderComponentType>;
1861
+ slots?: Slots;
1858
1862
  } & Record<string, any>;
1859
1863
  };
1860
1864
 
@@ -1862,7 +1866,7 @@ export declare type Form<D extends FormData_2 = FormData_2> = ReturnType<UseForm
1862
1866
 
1863
1867
  export declare const FORM_DATA: InjectionKey<Record<string, any>>;
1864
1868
 
1865
- export declare const FORM_ITEM_SLOT_KEYS: readonly ["label", "extra", "help"];
1869
+ export declare const FORM_ITEM_SLOT_KEYS: readonly ["label", "extra", "help", "tooltip"];
1866
1870
 
1867
1871
  declare type FormData_2 = {
1868
1872
  [key: string]: any;
@@ -1878,6 +1882,8 @@ declare interface FormProps extends FormProps_2 {
1878
1882
  */
1879
1883
  export declare const FunctionRegexp: RegExp;
1880
1884
 
1885
+ export declare const GET_REF: InjectionKey<GetRef>;
1886
+
1881
1887
  export declare type GetField = (path?: string) => Field | undefined;
1882
1888
 
1883
1889
  export declare type GetFieldPath = (path?: string) => string | undefined;
@@ -1886,6 +1892,11 @@ export declare type GetFormData = (path?: string) => DeepReadonly<any>;
1886
1892
 
1887
1893
  export declare type GetParentField = (path?: string) => Field | undefined;
1888
1894
 
1895
+ export declare type GetRef = {
1896
+ (type: 'formItemRefs', path: string): FormItemInstance;
1897
+ (type: 'fieldRefs', path: string): any;
1898
+ };
1899
+
1889
1900
  export declare type Grid = boolean | RowProps;
1890
1901
 
1891
1902
  export declare const INIT_PROPS_MAP: Map<symbol, {
@@ -2672,7 +2683,7 @@ export declare const ProComponentProvider: SFCWithInstall<{
2672
2683
  [x: string]: unknown;
2673
2684
  };
2674
2685
  $slots: Readonly<{
2675
- [name: string]: Slot_2<any> | undefined;
2686
+ [name: string]: Slot<any> | undefined;
2676
2687
  }>;
2677
2688
  $root: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}> | null;
2678
2689
  $parent: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}> | null;
@@ -3992,7 +4003,7 @@ export declare const ProForm: SFCWithInstall<{
3992
4003
  [x: string]: unknown;
3993
4004
  };
3994
4005
  $slots: Readonly<{
3995
- [name: string]: Slot_2<any> | undefined;
4006
+ [name: string]: Slot<any> | undefined;
3996
4007
  }>;
3997
4008
  $root: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}> | null;
3998
4009
  $parent: ComponentPublicInstance<{}, {}, {}, {}, {}, {}, {}, {}, false, ComponentOptionsBase<any, any, any, any, any, any, any, any, any, {}, {}, string, {}>, {}, {}> | null;
@@ -4168,6 +4179,7 @@ export declare const ProForm: SFCWithInstall<{
4168
4179
  "onUpdate:activePath"?: ((val: string | undefined) => any) | undefined;
4169
4180
  }, {
4170
4181
  refs: Refs;
4182
+ getRef: GetRef;
4171
4183
  resetFields: (name?: NamePath | undefined) => void;
4172
4184
  clearValidate: (name?: NamePath | undefined) => void;
4173
4185
  validateFields: (nameList?: string | NamePath[] | undefined, options?: ValidateOptions | undefined) => Promise<{
@@ -4380,6 +4392,7 @@ export declare const ProForm: SFCWithInstall<{
4380
4392
  "onUpdate:activePath"?: ((val: string | undefined) => any) | undefined;
4381
4393
  } & ShallowUnwrapRef<{
4382
4394
  refs: Refs;
4395
+ getRef: GetRef;
4383
4396
  resetFields: (name?: NamePath | undefined) => void;
4384
4397
  clearValidate: (name?: NamePath | undefined) => void;
4385
4398
  validateFields: (nameList?: string | NamePath[] | undefined, options?: ValidateOptions | undefined) => Promise<{
@@ -4566,6 +4579,7 @@ export declare const ProForm: SFCWithInstall<{
4566
4579
  "onUpdate:activePath"?: ((val: string | undefined) => any) | undefined;
4567
4580
  }, {
4568
4581
  refs: Refs;
4582
+ getRef: GetRef;
4569
4583
  resetFields: (name?: NamePath | undefined) => void;
4570
4584
  clearValidate: (name?: NamePath | undefined) => void;
4571
4585
  validateFields: (nameList?: string | NamePath[] | undefined, options?: ValidateOptions | undefined) => Promise<{
@@ -5971,7 +5985,7 @@ export declare type ProTableInstance = ComponentExposed<typeof _default_3>;
5971
5985
  declare type RangePickerSlots = FieldSlot<'dateRender' | 'renderExtraFooter' | 'separator'>;
5972
5986
 
5973
5987
  export declare type Refs = {
5974
- formItemRefs: Record<string, any>;
5988
+ formItemRefs: Record<string, FormItemInstance>;
5975
5989
  fieldRefs: Record<string, any>;
5976
5990
  };
5977
5991
 
@@ -6026,15 +6040,14 @@ declare type SFCWithInstall<T> = T & Plugin_2;
6026
6040
 
6027
6041
  declare type SliderSlots = FieldSlot<'mark'>;
6028
6042
 
6029
- export declare type Slot = {
6030
- name: string;
6031
- component: SlotComponentType;
6032
- };
6033
-
6034
6043
  export declare const SlotComponent: DefineComponent<__VLS_TypePropsToRuntimeProps_5<Props_5>, {}, unknown, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, VNodeProps & AllowedComponentProps & ComponentCustomProps, Readonly<ExtractPropTypes<__VLS_TypePropsToRuntimeProps_5<Props_5>>>, {}, {}>;
6035
6044
 
6036
6045
  export declare type SlotComponentType = string | Component<DefaultProps>;
6037
6046
 
6047
+ export declare type Slots = {
6048
+ [name: string]: SlotComponentType;
6049
+ };
6050
+
6038
6051
  declare type SwitchSlots = FieldSlot<'checkedChildren' | 'unCheckedChildren'>;
6039
6052
 
6040
6053
  export declare type Table<D extends Data = Data> = {
@@ -6048,6 +6061,8 @@ export declare type Table<D extends Data = Data> = {
6048
6061
 
6049
6062
  declare type TimePickerSlots = FieldSlot<'clearIcon' | 'renderExtraFooter' | 'suffixIcon'>;
6050
6063
 
6064
+ declare type TransferSlots = FieldSlot<'footer' | 'render'>;
6065
+
6051
6066
  declare type TreeSelectSlots = FieldSlot<'maxTagPlaceholder' | 'notFoundContent' | 'placeholder' | 'searchPlaceholder' | 'suffixIcon' | 'tagRender' | 'title'>;
6052
6067
 
6053
6068
  export declare const UPDATE_ACTIVE_PATH: InjectionKey<SetActivePath>;
@@ -6058,7 +6073,7 @@ export declare const UPDATE_REFS: InjectionKey<UpdateRefs>;
6058
6073
 
6059
6074
  export declare type UpdateFormData = (path: string, value: any) => void;
6060
6075
 
6061
- export declare type UpdateRefs = (path: string, childRef: Record<string, any>, type: keyof Refs) => void;
6076
+ export declare type UpdateRefs = (type: keyof Refs, path: string, childRef: Record<string, any>) => void;
6062
6077
 
6063
6078
  export declare type UseCommand = (param: {
6064
6079
  refs: Refs;
package/es/index.js CHANGED
@@ -1,6 +1,6 @@
1
1
  import "./style.css";
2
- import { _ as _sfc_main } from "./form/index-3d705aab.js";
3
- import { l, B, d, i, C, b, f, F, k, R, e, j, U, h, m, p, n, s, q, u, r, t } from "./form/index-3d705aab.js";
2
+ import { _ as _sfc_main } from "./form/index-2a04ad4a.js";
3
+ import { l, B, d, i, C, b, f, F, k, G, R, e, j, U, h, m, p, n, s, q, u, r, t } from "./form/index-2a04ad4a.js";
4
4
  import BaseTable from "./table/index.js";
5
5
  import { useTable } from "./table/index.js";
6
6
  import _sfc_main$1 from "./component-provider/index.js";
@@ -34,6 +34,7 @@ export {
34
34
  f as FORM_DATA,
35
35
  F as FORM_ITEM_SLOT_KEYS,
36
36
  k as FunctionRegexp,
37
+ G as GET_REF,
37
38
  INIT_PROPS_MAP,
38
39
  INJECT_KEYS,
39
40
  ProComponentProvider,
package/es/style.css CHANGED
@@ -1,7 +1,7 @@
1
1
  .ant-form-item:has(> [hide-feedback='true']) {
2
2
  margin-bottom: 0;
3
3
  }
4
- .field-component[data-v-060ffbee]:not(.ant-switch) {
4
+ .field-component[data-v-9a3bf1a0]:not(.ant-switch) {
5
5
  width: 100%;
6
6
  min-width: 120px;
7
7
  }
package/es/table/index.js CHANGED
@@ -1,7 +1,7 @@
1
1
  import { createVNode, defineComponent, ref, onMounted, openBlock, createElementBlock, unref, normalizeStyle, createElementVNode, withCtx, createTextVNode, createBlock, toDisplayString, createCommentVNode, mergeModels, useModel, computed, watch, Fragment, renderList, withModifiers, renderSlot, useAttrs, useSlots, mergeProps, createSlots, normalizeProps, guardReactiveProps, nextTick } from "vue";
2
2
  import { Button, Space, Dropdown, Menu, MenuItem, Checkbox, MenuDivider, Table } from "ant-design-vue";
3
3
  import { useInjectProps, INJECT_KEYS } from "../component-provider/index.js";
4
- import { A as AntdIcon, _ as _sfc_main$6, g as get, a as _export_sfc, o as omit, b as _sfc_main$7, c as cloneDeep, u as useForm } from "../form/index-3d705aab.js";
4
+ import { A as AntdIcon, _ as _sfc_main$6, g as get, a as _export_sfc, o as omit, b as _sfc_main$7, c as cloneDeep, u as useForm } from "../form/index-2a04ad4a.js";
5
5
  var ColumnHeightOutlined$2 = { "icon": { "tag": "svg", "attrs": { "viewBox": "64 64 896 896", "focusable": "false" }, "children": [{ "tag": "path", "attrs": { "d": "M840 836H184c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h656c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zm0-724H184c-4.4 0-8 3.6-8 8v60c0 4.4 3.6 8 8 8h656c4.4 0 8-3.6 8-8v-60c0-4.4-3.6-8-8-8zM610.8 378c6 0 9.4-7 5.7-11.7L515.7 238.7a7.14 7.14 0 00-11.3 0L403.6 366.3a7.23 7.23 0 005.7 11.7H476v268h-62.8c-6 0-9.4 7-5.7 11.7l100.8 127.5c2.9 3.7 8.5 3.7 11.3 0l100.8-127.5c3.7-4.7.4-11.7-5.7-11.7H548V378h62.8z" } }] }, "name": "column-height", "theme": "outlined" };
6
6
  const ColumnHeightOutlinedSvg = ColumnHeightOutlined$2;
7
7
  function _objectSpread$2(target) {
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@qin-ui/antd-vue-pro",
3
- "version": "1.1.9",
3
+ "version": "1.1.11",
4
4
  "description": "二次封装antd vue组件",
5
5
  "type": "module",
6
6
  "main": "",
@@ -14,9 +14,6 @@
14
14
  "type": "git",
15
15
  "url": "git+https://github.com/dufan3715/pro-components.git"
16
16
  },
17
- "scripts": {
18
- "build": "vue-tsc && vite build"
19
- },
20
17
  "keywords": [
21
18
  "vue",
22
19
  "ant-design-vue",
@@ -38,5 +35,8 @@
38
35
  },
39
36
  "dependencies": {
40
37
  "@ant-design/icons-vue": "^7.0.1"
38
+ },
39
+ "scripts": {
40
+ "build": "vue-tsc && vite build"
41
41
  }
42
- }
42
+ }