@aplus-frontend/ui 7.18.1 → 7.19.0-beta.0

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 (137) hide show
  1. package/es/src/ag-grid/context.mjs +1 -1
  2. package/es/src/ag-grid/editable/form-item.vue.d.ts +4 -2
  3. package/es/src/ag-grid/editable/index.vue.d.ts +4 -2
  4. package/es/src/ag-grid/hooks/use-pinned-row.mjs +2 -2
  5. package/es/src/ag-grid/index.vue.d.ts +4 -2
  6. package/es/src/ap-field/cascader/use-options.d.ts +4 -4
  7. package/es/src/ap-field/date/index.vue.d.ts +1 -0
  8. package/es/src/ap-field/date-range/index.vue.d.ts +1 -0
  9. package/es/src/ap-field/select/use-select-options.d.ts +2 -2
  10. package/es/src/ap-field/text/password.vue.d.ts +4 -4
  11. package/es/src/ap-field/tree-select/use-request.d.ts +4 -4
  12. package/es/src/ap-form/ap-form.vue.d.ts +2 -1
  13. package/es/src/ap-form/context.mjs +1 -1
  14. package/es/src/ap-form/drawer-form/index.vue.d.ts +4 -3
  15. package/es/src/ap-form/item/index.vue.d.ts +6 -6
  16. package/es/src/ap-form/item-group/helper.mjs +2 -2
  17. package/es/src/ap-form/items/date/index.vue.d.ts +11 -9
  18. package/es/src/ap-form/items/date-range/index.vue.d.ts +15 -13
  19. package/es/src/ap-form/items/number/index.vue.d.ts +3 -2
  20. package/es/src/ap-form/items/select/index.vue.d.ts +8 -8
  21. package/es/src/ap-form/modal-form/index.vue.d.ts +4 -3
  22. package/es/src/ap-form/provider/context.mjs +1 -1
  23. package/es/src/ap-form/search-form/index.vue.d.ts +4 -3
  24. package/es/src/ap-grid/editable/form-item.vue.d.ts +4 -2
  25. package/es/src/ap-grid/editable/index.vue.d.ts +4 -2
  26. package/es/src/ap-grid/index.vue.d.ts +4 -2
  27. package/es/src/ap-grid/utils/table.mjs +2 -2
  28. package/es/src/ap-list/index.vue.d.ts +4 -2
  29. package/es/src/ap-modal/utils/confirm.d.ts +1 -1
  30. package/es/src/ap-pro-card/components/card/index.vue2.mjs +2 -2
  31. package/es/src/ap-table/ap-table.vue.d.ts +4 -2
  32. package/es/src/ap-table/components/setting/context.mjs +1 -1
  33. package/es/src/ap-table/components/setting/sorter/context.mjs +1 -1
  34. package/es/src/ap-table/components/setting/template/edit-form.vue.d.ts +3 -2
  35. package/es/src/ap-table/constants.d.ts +22 -20
  36. package/es/src/ap-table/context.mjs +1 -1
  37. package/es/src/ap-table/hooks/use-table-template-storage.d.ts +9 -9
  38. package/es/src/ap-table/utils.mjs +1 -1
  39. package/es/src/business/ag-grid-modal/hooks/use-ag-grid-instance.mjs +1 -1
  40. package/es/src/business/ap-batch-action-group/index.d.ts +3 -3
  41. package/es/src/business/ap-download/hooks/index.mjs +1 -1
  42. package/es/src/business/ap-draggable-grid/ApDraggableGrid.vue.d.ts +1 -1
  43. package/es/src/business/ap-draggable-grid/ApDraggableGrid.vue2.mjs +3 -1
  44. package/es/src/business/ap-draggable-grid/index.d.ts +1 -1
  45. package/es/src/business/ap-expand-alert/ApExpandAlert.vue.d.ts +4 -2
  46. package/es/src/business/ap-keep-alive/hook.mjs +1 -1
  47. package/es/src/business/ap-keep-alive/utils.mjs +1 -1
  48. package/es/src/business/ap-select-layout/index.d.ts +4 -2
  49. package/es/src/business/ap-select-layout/select-layout.vue.d.ts +4 -2
  50. package/es/src/business/ap-table-modal/index.d.ts +5 -17
  51. package/es/src/business/ap-upload/components/MultipleFile.vue.d.ts +1 -1
  52. package/es/src/business/ap-value-select-card/index.vue.d.ts +4 -2
  53. package/es/src/business/ap-view/ap-view.vue.d.ts +5 -0
  54. package/es/src/business/ap-view/ap-view.vue2.mjs +142 -122
  55. package/es/src/business/ap-view/components/main-button-content.vue.d.ts +3 -2
  56. package/es/src/business/ap-view/components/menu-list-content.vue.d.ts +3 -2
  57. package/es/src/business/ap-view/hooks/use-send-to-url.d.ts +11 -0
  58. package/es/src/business/ap-view/hooks/use-send-to-url.mjs +38 -0
  59. package/es/src/business/ap-view/hooks/use-view-provide.mjs +1 -1
  60. package/es/src/business/ap-view/index.d.ts +13 -0
  61. package/es/src/business/ap-view/interface.d.ts +10 -0
  62. package/es/src/business/ap-view/utils/query.d.ts +4 -0
  63. package/es/src/business/ap-view/utils/query.mjs +26 -0
  64. package/es/src/check-card/context.mjs +1 -1
  65. package/es/src/config-provider/constants.mjs +1 -1
  66. package/es/src/config-provider/hooks/use-locale.mjs +1 -1
  67. package/es/src/config-provider/hooks/use-namespace.d.ts +1 -5
  68. package/es/src/config-provider/hooks/use-namespace.mjs +1 -1
  69. package/es/src/config-provider/hooks/use-token.mjs +1 -1
  70. package/es/src/editable-table/form-item.vue.d.ts +4 -2
  71. package/es/src/editable-table/index.vue.d.ts +4 -2
  72. package/es/src/editable-table/utils.mjs +1 -1
  73. package/es/src/scroll-view/index.vue.d.ts +5 -5
  74. package/es/src/tests/wrapper.d.ts +4 -4
  75. package/es/src/text/context.mjs +1 -1
  76. package/es/src/time-ago/useTimeAgo.mjs +1 -1
  77. package/es/src/utils/slot.mjs +1 -1
  78. package/es/src/version.d.ts +1 -1
  79. package/es/src/version.mjs +1 -1
  80. package/lib/src/ag-grid/editable/form-item.vue.d.ts +4 -2
  81. package/lib/src/ag-grid/editable/index.vue.d.ts +4 -2
  82. package/lib/src/ag-grid/hooks/use-pinned-row.js +1 -1
  83. package/lib/src/ag-grid/index.vue.d.ts +4 -2
  84. package/lib/src/ap-field/cascader/use-options.d.ts +4 -4
  85. package/lib/src/ap-field/date/index.vue.d.ts +1 -0
  86. package/lib/src/ap-field/date-range/index.vue.d.ts +1 -0
  87. package/lib/src/ap-field/select/use-select-options.d.ts +2 -2
  88. package/lib/src/ap-field/text/password.vue.d.ts +4 -4
  89. package/lib/src/ap-field/tree-select/use-request.d.ts +4 -4
  90. package/lib/src/ap-form/ap-form.vue.d.ts +2 -1
  91. package/lib/src/ap-form/drawer-form/index.vue.d.ts +4 -3
  92. package/lib/src/ap-form/item/index.vue.d.ts +6 -6
  93. package/lib/src/ap-form/items/date/index.vue.d.ts +11 -9
  94. package/lib/src/ap-form/items/date-range/index.vue.d.ts +15 -13
  95. package/lib/src/ap-form/items/number/index.vue.d.ts +3 -2
  96. package/lib/src/ap-form/items/select/index.vue.d.ts +8 -8
  97. package/lib/src/ap-form/modal-form/index.vue.d.ts +4 -3
  98. package/lib/src/ap-form/search-form/index.vue.d.ts +4 -3
  99. package/lib/src/ap-grid/editable/form-item.vue.d.ts +4 -2
  100. package/lib/src/ap-grid/editable/index.vue.d.ts +4 -2
  101. package/lib/src/ap-grid/index.vue.d.ts +4 -2
  102. package/lib/src/ap-grid/utils/table.js +1 -1
  103. package/lib/src/ap-list/index.vue.d.ts +4 -2
  104. package/lib/src/ap-modal/utils/confirm.d.ts +1 -1
  105. package/lib/src/ap-table/ap-table.vue.d.ts +4 -2
  106. package/lib/src/ap-table/components/setting/template/edit-form.vue.d.ts +3 -2
  107. package/lib/src/ap-table/constants.d.ts +22 -20
  108. package/lib/src/ap-table/hooks/use-table-template-storage.d.ts +9 -9
  109. package/lib/src/business/ap-batch-action-group/index.d.ts +3 -3
  110. package/lib/src/business/ap-draggable-grid/ApDraggableGrid.vue.d.ts +1 -1
  111. package/lib/src/business/ap-draggable-grid/ApDraggableGrid.vue2.js +1 -1
  112. package/lib/src/business/ap-draggable-grid/index.d.ts +1 -1
  113. package/lib/src/business/ap-expand-alert/ApExpandAlert.vue.d.ts +4 -2
  114. package/lib/src/business/ap-select-layout/index.d.ts +4 -2
  115. package/lib/src/business/ap-select-layout/select-layout.vue.d.ts +4 -2
  116. package/lib/src/business/ap-table-modal/index.d.ts +5 -17
  117. package/lib/src/business/ap-upload/components/MultipleFile.vue.d.ts +1 -1
  118. package/lib/src/business/ap-value-select-card/index.vue.d.ts +4 -2
  119. package/lib/src/business/ap-view/ap-view.vue.d.ts +5 -0
  120. package/lib/src/business/ap-view/ap-view.vue2.js +1 -1
  121. package/lib/src/business/ap-view/components/main-button-content.vue.d.ts +3 -2
  122. package/lib/src/business/ap-view/components/menu-list-content.vue.d.ts +3 -2
  123. package/lib/src/business/ap-view/hooks/use-send-to-url.d.ts +11 -0
  124. package/lib/src/business/ap-view/hooks/use-send-to-url.js +1 -0
  125. package/lib/src/business/ap-view/index.d.ts +13 -0
  126. package/lib/src/business/ap-view/interface.d.ts +10 -0
  127. package/lib/src/business/ap-view/utils/query.d.ts +4 -0
  128. package/lib/src/business/ap-view/utils/query.js +1 -0
  129. package/lib/src/config-provider/hooks/use-namespace.d.ts +1 -5
  130. package/lib/src/editable-table/form-item.vue.d.ts +4 -2
  131. package/lib/src/editable-table/index.vue.d.ts +4 -2
  132. package/lib/src/scroll-view/index.vue.d.ts +5 -5
  133. package/lib/src/tests/wrapper.d.ts +4 -4
  134. package/lib/src/time-ago/useTimeAgo.js +1 -1
  135. package/lib/src/version.d.ts +1 -1
  136. package/lib/src/version.js +1 -1
  137. package/package.json +3 -3
@@ -3,8 +3,8 @@ import { ButtonType, ButtonShape, ButtonSize } from '@aplus-frontend/antdv/es/bu
3
3
  import { ButtonHTMLType, ButtonIconPosition, ButtonVariantType } from '@aplus-frontend/antdv/es/button/buttonTypes';
4
4
  import { VueTypeValidableDef } from '../../../node_modules/vue-types';
5
5
  import { MouseEventHandler, FocusEventHandler } from '@aplus-frontend/antdv/es/_util/EventInterface';
6
+ import { ButtonProps, ItemType, MenuTheme, MenuMode, TableColumnsType } from '@aplus-frontend/antdv';
6
7
  import { DropdownArrowOptions, Trigger, Align } from '@aplus-frontend/antdv/es/dropdown/props';
7
- import { ItemType, MenuTheme, MenuMode, TableColumnsType, ButtonProps } from '@aplus-frontend/antdv';
8
8
  import { Key } from '@aplus-frontend/antdv/es/_util/type';
9
9
  import { CSSMotionProps } from '@aplus-frontend/antdv/es/_util/transition';
10
10
  import { BuiltinPlacements, TriggerSubMenuAction, SelectEventHandler, MenuClickEventHandler, PopupRender } from '@aplus-frontend/antdv/es/menu/src/interface';
@@ -72,7 +72,7 @@ declare const ApBatchActionGroup: {
72
72
  color: PropType<"default" | "blue" | "cyan" | "gold" | "green" | "lime" | "magenta" | "orange" | "pink" | "purple" | "red" | "yellow" | "volcano" | "geekblue" | "danger" | "primary">;
73
73
  variant: PropType<ButtonVariantType>;
74
74
  }>>, "type" | "onClick"> & {
75
- type?: ( ButtonType | undefined) | "borderLink";
75
+ type?: ButtonProps["type"] | "borderLink";
76
76
  borderLinkColor?: string;
77
77
  minWidth?: boolean | number | string;
78
78
  lazy?: boolean | number;
@@ -394,7 +394,7 @@ declare const ApBatchActionGroup: {
394
394
  color: PropType<"default" | "blue" | "cyan" | "gold" | "green" | "lime" | "magenta" | "orange" | "pink" | "purple" | "red" | "yellow" | "volcano" | "geekblue" | "danger" | "primary">;
395
395
  variant: PropType<ButtonVariantType>;
396
396
  }>>, "type" | "onClick"> & {
397
- type?: ( ButtonType | undefined) | "borderLink";
397
+ type?: ButtonProps["type"] | "borderLink";
398
398
  borderLinkColor?: string;
399
399
  minWidth?: boolean | number | string;
400
400
  lazy?: boolean | number;
@@ -10,7 +10,7 @@ declare function __VLS_template(): {
10
10
  span: number;
11
11
  row: number;
12
12
  col: number;
13
- showHeight?: number | string | undefined;
13
+ showHeight?: (number | string) | undefined;
14
14
  height: number | string;
15
15
  module: string;
16
16
  };
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("vue"),ee=require("@aplus-frontend/antdv"),w=require("../../utils/warning.js");require("../../config-provider/index.js");const re=require("./constans.js"),te=require("./style/index.js"),E=require("./utils/sortItemsByRowAndCol.js"),oe=require("../../config-provider/hooks/use-namespace.js"),ae=["data-span","data-index","data-row","data-col","data-height","data-module","draggable"],ne=t.defineComponent({__name:"ApDraggableGrid",props:re.ApDraggableGridProps(),emits:["onGridListChange"],setup(_,{expose:J,emit:z}){const c=_,{b:q,e:T,m:j}=oe.useNamespace("ap-draggable-grid"),U=te.default("ap-draggable-grid"),L=t.ref(!1),x=t.ref(!1),M=t.computed(()=>T("item")),H=t.computed(()=>T("dragging")),G=t.computed(()=>T("overlay")),V=t.computed(()=>c.customWrapper?`.${c.customWrapper} .${M.value}:not(.${H.value})`:`.${M.value}:not(.${H.value})`),K=z,g=t.useTemplateRef("gridContainer"),$=t.ref([]);t.watch(()=>c.gridList,e=>{Array.isArray(e)&&i(e)},{deep:!0,immediate:!0});function i(e){const a=[...e].sort((r,u)=>r.row-u.row);$.value=a.map(r=>({...r})),K("onGridListChange",JSON.parse(JSON.stringify($.value)))}const Q=e=>({gridColumn:`${e.col} / span ${e.span}`,gridRow:e.row,minHeight:e.showHeight?e.showHeight+"px":`${c.gridItemHeight}px`,height:e.showHeight?e.showHeight+"px":`${c.gridItemHeight}px`,boxShadow:c.gridItemShadow?c.gridItemShadow:"none"});async function k(){if(i([]),typeof c.request=="function")try{L.value=!0;const e=await c.request();Array.isArray(e)&&i(e),w.warning(Array.isArray(e),"ApDraggableGrid: 请求函数必须返回一个符合 ApDraggableGridItemBase 数组的格式")}catch(e){w.warning(!1,`ApDraggableGrid: 请求错误: ${e}`)}finally{L.value=!1}}let A=t.ref(null),C=t.ref(null),h=null,R=!1,b=null;const F=e=>{if(!R&&(R=!0,e.dataTransfer&&e.target instanceof HTMLElement)){const a=e.target.dataset;e.dataTransfer.setData("text/plain",a.module),e.dataTransfer.effectAllowed="move",A.value={span:Number(a.span),col:Number(a.col),row:Number(a.row),module:a.module,height:Number(a.height),index:Number(a.index)},h=e.target,h.style.opacity="0"}},O=e=>{if(e.preventDefault(),b&&clearTimeout(b),b=window.setTimeout(()=>{R=!1,b=null},300),e.dataTransfer&&e.target instanceof HTMLElement){const a=e.target.closest(V.value);if(!a)return;const r=a.dataset;document.querySelectorAll(`.${c.customWrapper} div[data-row="${r.row}"]`).forEach(l=>{l.classList.add(G.value)}),C.value={span:Number(r.span),col:Number(r.col),row:Number(r.row),module:r.module,height:Number(r.height),index:Number(r.index)}}},P=e=>{e.preventDefault(),h&&(h.style.opacity="1",h=null),X(A,C)&&Y(A,C),document.querySelectorAll(`.${G.value}`).forEach(a=>{a.classList.remove(G.value)}),A.value=null,C.value=null,x.value=!1},W=()=>{h&&(h.style.opacity="1",h=null),A.value=null,C.value=null,x.value=!1},X=(e,a)=>{const{span:r,module:u}=e.value,{span:l,module:f}=a.value;return!(u===f&&r===l)},Y=(e,a)=>{if(!e.value||!a.value)return;const{span:r,col:u,row:l,module:f,height:D,index:d}=e.value,{span:S,col:y,row:p,module:Z,height:B,index:m}=a.value;if(l===p&&u===y&&r===S&&D===B&&f===Z)return;let o=[...t.toRaw($.value)];const N=JSON.parse(JSON.stringify(o));if(l===p)if(d>m){d-m===1?(o[m].col=r+y,o[d].col=y):(o.forEach((v,n)=>{n<d&&n>=m&&(v.col+=S)}),o[d].col=y);const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局");return}i(s);return}else{m-d===1?(o[d].col=S+1,o[m].col=u):(o.forEach((v,n)=>{n>d&&n<=m&&(v.col-=S)}),o[d].col=y);const s=E.sortItemsByRowAndCol(o);if(!I(s)){i(N);return}i(s);return}else if(p<l){if(r===24){const s=[];for(let n=p;n<l;n++)s.push(n);o.forEach(n=>{s.includes(n.row)&&(n.row+=1)}),o[d].row=p;const v=E.sortItemsByRowAndCol(o);if(!I(v)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(v);return}if(r===S&&D===B){o[d].row=p,o[d].col=y,o[m].row=l,o[m].col=u;const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(s);return}}else{if(r===24){const s=[];for(let n=l+1;n<=p;n++)s.push(n);o.forEach(n=>{s.includes(n.row)&&(n.row-=1)}),o[d].row=p;const v=E.sortItemsByRowAndCol(o);if(!I(v)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(v);return}if(r===S&&D===B){o[d].row=p,o[d].col=y,o[m].row=l,o[m].col=u;const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(s);return}}},I=e=>{const a={};e.forEach(r=>{a[r.row]||(a[r.row]=[]),a[r.row].push(r)});for(const r in a){const u=a[r].sort((f,D)=>f.col-D.col);let l=1;for(const f of u){if(f.col<l)return w.note(!1,`行 ${r} 中的元素重叠: 元素 ${f.module} 在列 ${f.col}, 但当前列已经是 ${l}`),!1;if(l=f.col+f.span,l>25)return w.note(!1,`行 ${r} 中的元素超出界限: 元素 ${f.module} 在列 ${f.col} 跨度 ${f.span}`),!1}}return!0};return t.onMounted(async()=>{await k(),!c.disableDrag&&g.value&&(g.value.addEventListener("dragstart",F),g.value.addEventListener("dragover",O),g.value.addEventListener("drop",P),g.value.addEventListener("dragend",W))}),t.onUnmounted(()=>{g.value&&(g.value.removeEventListener("dragstart",F),g.value.removeEventListener("dragover",O),g.value.removeEventListener("drop",P),g.value.removeEventListener("dragend",W),b&&clearTimeout(b))}),J({setGridItems:e=>{i(e)},getGridItems:()=>JSON.parse(JSON.stringify($.value)),refreshGrid:()=>{(async()=>await k())()}}),(e,a)=>(t.openBlock(),t.createBlock(t.unref(ee.Spin),{spinning:L.value},{default:t.withCtx(()=>[t.createElementVNode("div",{ref_key:"gridContainer",ref:g,class:t.normalizeClass([L.value?t.unref(q)("loading"):t.unref(q)(),c.customWrapper,t.unref(U)]),style:t.normalizeStyle({width:typeof e.gridWidth=="number"?`${e.gridWidth}px`:e.gridWidth,gap:`${e.gapWidth}px`})},[(t.openBlock(!0),t.createElementBlock(t.Fragment,null,t.renderList($.value,(r,u)=>(t.openBlock(),t.createElementBlock("div",{key:u,class:t.normalizeClass([t.unref(T)("item"),c.disableDrag?"":t.unref(j)("canDrag")]),"data-span":r.span,"data-index":u,"data-row":r.row,"data-col":r.col,"data-height":r.height,"data-module":r.module,style:t.normalizeStyle([Q(r)]),draggable:!c.disableDrag},[t.renderSlot(e.$slots,"item",{item:r,index:u})],14,ae))),128))],6)]),_:3},8,["spinning"]))}});exports.default=ne;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("vue"),ee=require("@aplus-frontend/antdv"),w=require("../../utils/warning.js");require("../../config-provider/index.js");const re=require("./constans.js"),te=require("./style/index.js"),E=require("./utils/sortItemsByRowAndCol.js"),oe=require("../../config-provider/hooks/use-namespace.js"),ae=["data-span","data-index","data-row","data-col","data-height","data-module","draggable"],ne=t.defineComponent({__name:"ApDraggableGrid",props:re.ApDraggableGridProps(),emits:["onGridListChange"],setup(_,{expose:J,emit:z}){const c=_,{b:q,e:T,m:j}=oe.useNamespace("ap-draggable-grid"),U=te.default("ap-draggable-grid"),L=t.ref(!1),x=t.ref(!1),M=t.computed(()=>T("item")),H=t.computed(()=>T("dragging")),G=t.computed(()=>T("overlay")),V=t.computed(()=>c.customWrapper?`.${c.customWrapper} .${M.value}:not(.${H.value})`:`.${M.value}:not(.${H.value})`),K=z,g=t.useTemplateRef("gridContainer"),$=t.ref([]);t.watch(()=>c.gridList,e=>{Array.isArray(e)&&i(e)},{deep:!0,immediate:!0});function i(e){const a=[...e].sort((r,u)=>r.row-u.row);$.value=a.map(r=>({...r})),K("onGridListChange",JSON.parse(JSON.stringify($.value)))}const Q=e=>({gridColumn:`${e.col} / span ${e.span}`,gridRow:e.row,minHeight:e.showHeight?e.showHeight+"px":`${c.gridItemHeight}px`,height:e.showHeight?e.showHeight+"px":`${c.gridItemHeight}px`,boxShadow:c.gridItemShadow?c.gridItemShadow:"none"});async function k(){if(i([]),typeof c.request=="function")try{L.value=!0;const e=await c.request();Array.isArray(e)&&i(e),w.warning(Array.isArray(e),"ApDraggableGrid: 请求函数必须返回一个符合 ApDraggableGridItemBase 数组的格式")}catch(e){w.warning(!1,`ApDraggableGrid: 请求错误: ${e}`)}finally{L.value=!1}}let A=t.ref(null),C=t.ref(null),h=null,R=!1,b=null;const F=e=>{if(!R&&(R=!0,e.dataTransfer&&e.target instanceof HTMLElement)){const a=e.target.dataset;e.dataTransfer.setData("text/plain",a.module),e.dataTransfer.effectAllowed="move",A.value={span:Number(a.span),col:Number(a.col),row:Number(a.row),module:a.module,height:Number(a.height),index:Number(a.index)},h=e.target,h.style.opacity="0"}},O=e=>{if(e.preventDefault(),b&&clearTimeout(b),b=window.setTimeout(()=>{R=!1,b=null},300),e.dataTransfer&&e.target instanceof HTMLElement){const a=e.target.closest(V.value);if(!a)return;const r=a.dataset;document.querySelectorAll(`.${c.customWrapper} div[data-row="${r.row}"]`).forEach(l=>{l.classList.add(G.value)}),C.value={span:Number(r.span),col:Number(r.col),row:Number(r.row),module:r.module,height:Number(r.height),index:Number(r.index)}}},P=e=>{e.preventDefault(),h&&(h.style.opacity="1",h=null),X(A,C)&&Y(A,C),document.querySelectorAll(`.${G.value}`).forEach(a=>{a.classList.remove(G.value)}),A.value=null,C.value=null,x.value=!1},W=()=>{h&&(h.style.opacity="1",h=null),A.value=null,C.value=null,x.value=!1},X=(e,a)=>{const{span:r,module:u}=e.value,{span:l,module:f}=a.value;return!(u===f&&r===l)},Y=(e,a)=>{if(!e.value||!a.value)return;const{span:r,col:u,row:l,module:f,height:D,index:d}=e.value,{span:S,col:y,row:p,module:Z,height:B,index:m}=a.value;if(l===p&&u===y&&r===S&&D===B&&f===Z)return;let o=[...t.toRaw($.value)];const N=JSON.parse(JSON.stringify(o));if(l===p)if(d>m){d-m===1?(o[m].col=r+y,o[d].col=y):(o.forEach((v,n)=>{n<d&&n>=m&&(v.col+=S)}),o[d].col=y);const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局");return}i(s);return}else{m-d===1?(o[d].col=S+1,o[m].col=u):(o.forEach((v,n)=>{n>d&&n<=m&&(v.col-=S)}),o[d].col=y);const s=E.sortItemsByRowAndCol(o);if(!I(s)){i(N);return}i(s);return}else if(p<l){if(r===24){const s=[];for(let n=p;n<l;n++)s.push(n);o.forEach(n=>{s.includes(n.row)&&(n.row+=1)}),o[d].row=p;const v=E.sortItemsByRowAndCol(o);if(!I(v)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(v);return}if(r===S&&D===B){o[d].row=p,o[d].col=y,o[m].row=l,o[m].col=u;const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(s);return}}else{if(r===24){const s=[];for(let n=l+1;n<=p;n++)s.push(n);o.forEach(n=>{s.includes(n.row)&&(n.row-=1)}),o[d].row=p;const v=E.sortItemsByRowAndCol(o);if(!I(v)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(v);return}if(r===S&&D===B){o[d].row=p,o[d].col=y,o[m].row=l,o[m].col=u;const s=E.sortItemsByRowAndCol(o);if(!I(s)){w.note(!1,"交换后的布局无效,恢复原始布局"),i(N);return}i(s);return}}},I=e=>{const a={};e.forEach(r=>{a[r.row]||(a[r.row]=[]),a[r.row].push(r)});for(const r in a){const u=a[r].sort((f,D)=>f.col-D.col);let l=1;for(const f of u){if(f.col<l)return w.note(!1,`行 ${r} 中的元素重叠: 元素 ${f.module} 在列 ${f.col}, 但当前列已经是 ${l}`),!1;if(l=f.col+f.span,l>25)return w.note(!1,`行 ${r} 中的元素超出界限: 元素 ${f.module} 在列 ${f.col} 跨度 ${f.span}`),!1}}return!0};return t.onMounted(async()=>{await k(),!c.disableDrag&&g.value&&(g.value.addEventListener("dragstart",F),g.value.addEventListener("dragover",O),g.value.addEventListener("drop",P),g.value.addEventListener("dragend",W))}),t.onUnmounted(()=>{g.value&&(g.value.removeEventListener("dragstart",F),g.value.removeEventListener("dragover",O),g.value.removeEventListener("drop",P),g.value.removeEventListener("dragend",W),b&&clearTimeout(b))}),J({setGridItems:e=>{i(e)},getGridItems:()=>JSON.parse(JSON.stringify($.value)),refreshGrid:()=>{(async()=>{await k()})()}}),(e,a)=>(t.openBlock(),t.createBlock(t.unref(ee.Spin),{spinning:L.value},{default:t.withCtx(()=>[t.createElementVNode("div",{ref_key:"gridContainer",ref:g,class:t.normalizeClass([L.value?t.unref(q)("loading"):t.unref(q)(),c.customWrapper,t.unref(U)]),style:t.normalizeStyle({width:typeof e.gridWidth=="number"?`${e.gridWidth}px`:e.gridWidth,gap:`${e.gapWidth}px`})},[(t.openBlock(!0),t.createElementBlock(t.Fragment,null,t.renderList($.value,(r,u)=>(t.openBlock(),t.createElementBlock("div",{key:u,class:t.normalizeClass([t.unref(T)("item"),c.disableDrag?"":t.unref(j)("canDrag")]),"data-span":r.span,"data-index":u,"data-row":r.row,"data-col":r.col,"data-height":r.height,"data-module":r.module,style:t.normalizeStyle([Q(r)]),draggable:!c.disableDrag},[t.renderSlot(e.$slots,"item",{item:r,index:u})],14,ae))),128))],6)]),_:3},8,["spinning"]))}});exports.default=ne;
@@ -172,7 +172,7 @@ declare const ApDraggableGrid: {
172
172
  span: number;
173
173
  row: number;
174
174
  col: number;
175
- showHeight?: number | string | undefined;
175
+ showHeight?: (number | string) | undefined;
176
176
  height: number | string;
177
177
  module: string;
178
178
  };
@@ -1,5 +1,5 @@
1
1
  import { ApExpandAlertProps } from './interface';
2
- import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode } from 'vue';
2
+ import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode, RendererNode, RendererElement } from 'vue';
3
3
  declare const _default: <T extends Record<string, any>>(__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<{
4
4
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
5
5
  readonly onClose?: ((args_0: MouseEvent) => any) | undefined;
@@ -24,7 +24,9 @@ declare const _default: <T extends Record<string, any>>(__VLS_props: NonNullable
24
24
  }): any;
25
25
  };
26
26
  emit: ((evt: "close", args_0: MouseEvent) => void) & ((evt: "expand", args_0: "collapse" | "expand") => void) & ((evt: "choose", args_0: T) => void);
27
- }>) => VNode & {
27
+ }>) => VNode<RendererNode, RendererElement, {
28
+ [key: string]: any;
29
+ }> & {
28
30
  __ctx?: Awaited<typeof __VLS_setup>;
29
31
  };
30
32
  export default _default;
@@ -1,5 +1,5 @@
1
1
  import { ApSelectItem } from './interface';
2
- import { PublicProps, ShallowUnwrapRef, VNode, Plugin } from 'vue';
2
+ import { PublicProps, ShallowUnwrapRef, VNode, RendererNode, RendererElement, Plugin } from 'vue';
3
3
  export * from './interface';
4
4
  declare const ApSelectLayout: (<T extends ApSelectItem>(__VLS_props: NonNullable<Awaited<typeof __VLS_setup>>["props"], __VLS_ctx?: {
5
5
  attrs: any;
@@ -38,7 +38,9 @@ declare const ApSelectLayout: (<T extends ApSelectItem>(__VLS_props: NonNullable
38
38
  (event: "afterEnter", el: Element): void;
39
39
  (event: "afterLeave", el: Element): void;
40
40
  };
41
- }>) => VNode & {
41
+ }>) => VNode<RendererNode, RendererElement, {
42
+ [key: string]: any;
43
+ }> & {
42
44
  __ctx?: Awaited<typeof __VLS_setup>;
43
45
  }) & ( Plugin & (new (...args: any[]) => {
44
46
  $props: {
@@ -1,5 +1,5 @@
1
1
  import { ApSelectItem, ApSelectLayoutProps } from './interface';
2
- import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode } from 'vue';
2
+ import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode, RendererNode, RendererElement } from 'vue';
3
3
  declare const _default: <T extends ApSelectItem>(__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<{
4
4
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
5
5
  readonly onOnSelect?: ((value: T) => any) | undefined;
@@ -19,7 +19,9 @@ declare const _default: <T extends ApSelectItem>(__VLS_props: NonNullable<Awaite
19
19
  (event: "afterEnter", el: Element): void;
20
20
  (event: "afterLeave", el: Element): void;
21
21
  };
22
- }>) => VNode & {
22
+ }>) => VNode<RendererNode, RendererElement, {
23
+ [key: string]: any;
24
+ }> & {
23
25
  __ctx?: Awaited<typeof __VLS_setup>;
24
26
  };
25
27
  export default _default;
@@ -4,9 +4,9 @@ import { CreateComponentPublicInstanceWithMixins, ComponentOptionsMixin, PublicP
4
4
  import { ApTableModalProps, OpenOptions, OpenReturnType } from './interface';
5
5
  import { Recordable } from '../../type';
6
6
  import { TableColumnsType } from '@aplus-frontend/antdv';
7
+ import { InternalPagingType } from '../../ap-table/hooks/use-table-paging-ng';
7
8
  import { ApFormSearchFormPopoverSorterItem } from '../..';
8
9
  import { MaskType } from '@aplus-frontend/antdv/es/_util/hooks/useMergedMask';
9
- import { InternalPagingType } from '../../ap-table/hooks/use-table-paging-ng';
10
10
  /**
11
11
  *
12
12
  */
@@ -44,14 +44,8 @@ declare const ApTableModal: {
44
44
  };
45
45
  y: undefined;
46
46
  };
47
- getPaging: () => Partial<{
48
- current: number;
49
- pageSize: number;
50
- }>;
51
- setPaging: (nextPaging: Partial<{
52
- current: number;
53
- pageSize: number;
54
- }>, refreshImmediately?: boolean) => void;
47
+ getPaging: () => InternalPagingType;
48
+ setPaging: (nextPaging: InternalPagingType, refreshImmediately?: boolean) => void;
55
49
  getSearchFormSorterItems: () => ApFormSearchFormPopoverSorterItem[];
56
50
  setSearchFormSorterItems: (sortedItems: ApFormSearchFormPopoverSorterItem[]) => void;
57
51
  resetSearchFormSorterItems: () => void;
@@ -156,14 +150,8 @@ declare const ApTableModal: {
156
150
  };
157
151
  y: undefined;
158
152
  };
159
- getPaging: () => Partial<{
160
- current: number;
161
- pageSize: number;
162
- }>;
163
- setPaging: (nextPaging: Partial<{
164
- current: number;
165
- pageSize: number;
166
- }>, refreshImmediately?: boolean) => void;
153
+ getPaging: () => InternalPagingType;
154
+ setPaging: (nextPaging: InternalPagingType, refreshImmediately?: boolean) => void;
167
155
  getSearchFormSorterItems: () => ApFormSearchFormPopoverSorterItem[];
168
156
  setSearchFormSorterItems: (sortedItems: ApFormSearchFormPopoverSorterItem[]) => void;
169
157
  resetSearchFormSorterItems: () => void;
@@ -1,6 +1,6 @@
1
1
  import { UploadFile, UploadChangeParam } from '@aplus-frontend/antdv';
2
2
  import { DefineComponent, ComponentOptionsMixin, PublicProps, ComponentProvideOptions, CreateComponentPublicInstanceWithMixins, ExtractPropTypes, PropType, GlobalComponents, GlobalDirectives } from 'vue';
3
- import { UploadType, UploadFile, FileType, HttpRequestHeader, ShowUploadListInterface, UploadListType, UploadLocale, UploadListProgressProps, ItemRender } from '@aplus-frontend/antdv/es/upload/interface';
3
+ import { UploadType, UploadFile, FileType, HttpRequestHeader, ShowUploadListInterface, UploadChangeParam, UploadListType, UploadLocale, UploadListProgressProps, ItemRender } from '@aplus-frontend/antdv/es/upload/interface';
4
4
  import { AcceptConfig, UploadRequestOption } from '@aplus-frontend/antdv/es/vc-upload/interface';
5
5
  import { VueNode } from '@aplus-frontend/antdv/es/_util/type';
6
6
  declare function setValue(val: (string | Record<string, any>)[]): void;
@@ -1,5 +1,5 @@
1
1
  import { ApValueSelectCardProps, ApValueSelectCardOption } from './interface';
2
- import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, Ref, ComputedRef, VNode } from 'vue';
2
+ import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, Ref, ComputedRef, VNode, RendererNode, RendererElement } from 'vue';
3
3
  declare const _default: <T extends Record<string, any> = Record<string, any>>(__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<{
4
4
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
5
5
  readonly onChange?: ((keys: (string | number)[]) => any) | undefined;
@@ -45,7 +45,9 @@ declare const _default: <T extends Record<string, any> = Record<string, any>>(__
45
45
  (e: "remove", key: string | number): void;
46
46
  (e: "highlight", keys: (string | number)[]): void;
47
47
  };
48
- }>) => VNode & {
48
+ }>) => VNode<RendererNode, RendererElement, {
49
+ [key: string]: any;
50
+ }> & {
49
51
  __ctx?: Awaited<typeof __VLS_setup>;
50
52
  };
51
53
  export default _default;
@@ -1,11 +1,16 @@
1
+ import { Recordable } from '../../type';
1
2
  import { ApViewProps } from './interface';
2
3
  import { DefineComponent, ComponentOptionsMixin, PublicProps, ComponentProvideOptions } from 'vue';
3
4
  declare const _default: DefineComponent<ApViewProps, {
4
5
  setFirstDefaultSystemView: (value: boolean) => void;
6
+ setInitToUrl: (value: boolean) => void;
7
+ mountedData: Recordable;
5
8
  }, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, PublicProps, Readonly<ApViewProps> & Readonly<{}>, {
6
9
  manual: boolean;
7
10
  maxViewNum: number;
11
+ sendToUrl: boolean;
8
12
  isDefaultSystemView: boolean;
9
13
  isFirstDefaultSystemView: boolean;
14
+ initToUrl: boolean;
10
15
  }, {}, {}, {}, string, ComponentProvideOptions, false, {}, any>;
11
16
  export default _default;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const t=require("vue"),B=require("@aplus-frontend/utils"),j=require("../../ap-table/context.js");require("../../config-provider/index.js");const k=require("../ap-batch-action-group/index.js");require("./components/main-button-content.vue.js");require("./components/menu-list-content.vue.js");const A=require("./hooks/use-view-provide.js"),G=require("./icons/line-down.vue.js"),U=require("./style/index.js"),m=require("./utils/enum.js"),$=require("../../config-provider/hooks/use-global-config.js"),z=require("../../config-provider/hooks/use-namespace.js"),R=require("../../config-provider/hooks/use-locale.js"),H=require("./components/main-button-content.vue2.js"),J=require("./components/menu-list-content.vue2.js"),Q=t.defineComponent({name:"ApView",__name:"ap-view",props:{tableKey:{},saveDataSource:{},viewCacheOption:{},maxViewNum:{default:20},isDefaultSystemView:{type:Boolean,default:!1},isFirstDefaultSystemView:{type:Boolean,default:!1},manual:{type:Boolean,default:!1},emptyData:{},extraParams:{}},setup(g,{expose:C}){const r=g,D=$.useGlobalConfig("viewCacheOption"),{b:d}=z.useNamespace("ap-view"),{t:E}=R.useLocale(),_=U.default("ap-view"),y=t.computed(()=>({viewKey:m.SYSTEM_VIEW_KEY,viewName:E("ap.apView.systemView")})),{getSearchFormValues:q,setSearchFormValues:F,submit:I,reset:N,submitWith:Y,getSearchFormSorterItems:x,setSearchFormSorterItems:O,resetSearchFormSorterItems:T}=j.useInjectApTable(),L=t.ref(!1),V=t.ref(!1),w=t.ref("");let f=!1,K=!1;const W={dropdownType:"dropdown",content:t.createVNode(H.default,{maxViewNum:r.maxViewNum},null)},s=t.ref([y.value]),M=t.computed(()=>s.value.map(a=>({id:a.viewKey,content:t.createVNode(J.default,{view:a},null)}))),o={getSearchFormValues:q,setSearchFormValues:F,submit:I,reset:N,submitWith:Y,getSearchFormSorterItems:x,setSearchFormSorterItems:O,resetSearchFormSorterItems:T,...r.saveDataSource},p={...D.value,...r.viewCacheOption},h=()=>r.isDefaultSystemView||(r.isFirstDefaultSystemView||K)&&f?m.SYSTEM_VIEW_KEY:s.value.find(i=>i.isDefault)?.viewKey??m.SYSTEM_VIEW_KEY,l=a=>{w.value=a;const i=s.value.find(e=>e.viewKey===w.value);i&&setTimeout(()=>{i.viewKey===m.SYSTEM_VIEW_KEY?f?r.manual||o?.submitWith?.():r.manual||(o?.resetSearchFormSorterItems?.(),o?.reset?.()):(o?.setSearchFormValues?.({...Object.fromEntries(Object.keys(o?.getSearchFormValues?.()??{}).map(e=>[e,void 0]))??{},...r?.emptyData??{},...[...o?.getSearchFormSorterItems?.()??[],...r?.extraParams?.map(e=>({name:e}))??[]].reduce((e,n)=>(i.viewConfig?.searchForm?.[n.name]&&(e[n.name]=i.viewConfig?.searchForm?.[n.name]),e),{})??{}}),o?.setSearchFormSorterItems?.(i.viewConfig?.sorterItems??[]),f?r.manual||o?.submitWith?.():o?.submit?.()),f=!1})},b={getViewList:async a=>{try{const{tableKey:i}=a,e=await p?.getViewList?.({tableKey:i});return s.value=[y.value,...e??[]],l(h()),s.value}catch{return s.value=[y.value],l(m.SYSTEM_VIEW_KEY),s.value}},addView:async a=>{const{tableKey:i,viewKey:e,viewName:n,isDefault:u,viewConfig:v}=a;await p?.addView?.({tableKey:i,viewKey:e,viewName:n,isDefault:u,viewConfig:v}),u&&(s.value=s.value.map(c=>({...c,isDefault:!1}))),s.value=[...s.value,{viewKey:e,viewName:n,isDefault:u,viewConfig:v}],l(e)},changeView:async a=>{const{tableKey:i,viewKey:e,viewName:n,isDefault:u,viewConfig:v}=a;await p?.changeView?.({tableKey:i,viewKey:e,viewName:n,isDefault:u,viewConfig:v}),u&&(s.value=s.value.map(S=>({...S,isDefault:!1})));const c=s.value.find(S=>S.viewKey===e);c&&(c.viewName=n,c.isDefault=u,c.viewConfig=v),l(e)},removeView:async a=>{const{tableKey:i,viewKey:e}=a;await p?.removeView?.({tableKey:i,viewKey:e}),s.value=s.value.filter(n=>n.viewKey!==e),e===w.value&&l(h())}},P={tableKey:t.computed(()=>r.tableKey),currentViewKey:w,changeCurrentViewKey:l,popoverOpen:L,menuOpen:V,viewList:s,viewListCRUD:b,saveDataSource:o};return A.useViewProvide(P),t.watch(()=>r.tableKey,a=>{B.isValid(a)&&(f=!0,b?.getViewList?.({tableKey:a}))},{immediate:!0}),C({setFirstDefaultSystemView:a=>{K=a}}),(a,i)=>(t.openBlock(),t.createBlock(t.unref(k.ApBatchActionGroup),t.mergeProps({...a.$attrs},{open:V.value,"onUpdate:open":i[0]||(i[0]=e=>V.value=e),class:[t.unref(d)(),t.unref(_)],"button-props":W,"menu-list":M.value,"overlay-class-name":[t.unref(d)("overlay"),t.unref(_)],trigger:"click",placement:"bottom"}),{icon:t.withCtx(()=>[t.createElementVNode("div",{class:t.normalizeClass([t.unref(d)("icon")])},[t.createVNode(G.default)],2)]),_:1},16,["open","class","menu-list","overlay-class-name"]))}});exports.default=Q;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e=require("vue"),k=require("@aplus-frontend/utils"),A=require("../../ap-table/context.js");require("../../config-provider/index.js");const G=require("../ap-batch-action-group/index.js");require("./components/main-button-content.vue.js");require("./components/menu-list-content.vue.js");const $=require("./hooks/use-send-to-url.js"),z=require("./hooks/use-view-provide.js"),R=require("./icons/line-down.vue.js"),H=require("./style/index.js"),v=require("./utils/enum.js"),J=require("../../config-provider/hooks/use-global-config.js"),Q=require("../../config-provider/hooks/use-namespace.js"),X=require("../../config-provider/hooks/use-locale.js"),Z=require("./components/main-button-content.vue2.js"),ee=require("./components/menu-list-content.vue2.js"),te=e.defineComponent({name:"ApView",__name:"ap-view",props:{tableKey:{},saveDataSource:{},viewCacheOption:{},maxViewNum:{default:20},isDefaultSystemView:{type:Boolean,default:!1},isFirstDefaultSystemView:{type:Boolean,default:!1},manual:{type:Boolean,default:!1},emptyData:{},extraParams:{},sendToUrl:{type:Boolean,default:!0},initToUrl:{type:Boolean,default:!0}},setup(C,{expose:E}){const i=C,F=J.useGlobalConfig("viewCacheOption"),{b:p}=Q.useNamespace("ap-view"),{t:q}=X.useLocale(),h=H.default("ap-view"),y=e.computed(()=>({viewKey:v.SYSTEM_VIEW_KEY,viewName:q("ap.apView.systemView")})),{getSearchFormValues:I,setSearchFormValues:U,submit:N,reset:Y,submitWith:x,getSearchFormSorterItems:O,setSearchFormSorterItems:B,resetSearchFormSorterItems:L}=A.useInjectApTable(),M=e.ref(!1),V=e.ref(!1),w=e.ref("");let l=!1,b=!1,S=!0;const W={dropdownType:"dropdown",content:e.createVNode(Z.default,{maxViewNum:i.maxViewNum},null)},r=e.ref([y.value]),P=e.computed(()=>r.value.map(a=>({id:a.viewKey,content:e.createVNode(ee.default,{view:a},null)}))),o={getSearchFormValues:I,setSearchFormValues:U,submit:N,reset:Y,submitWith:x,getSearchFormSorterItems:O,setSearchFormSorterItems:B,resetSearchFormSorterItems:L,...i.saveDataSource},d={...F.value,...i.viewCacheOption},{mountedData:_,isValidMountedData:g}=$.useSendToUrl({saveDataSource:o,sendToUrl:e.computed(()=>i.sendToUrl),tableKey:e.computed(()=>i.tableKey)}),D=()=>i.isDefaultSystemView||(i.isFirstDefaultSystemView||b)&&l?v.SYSTEM_VIEW_KEY:r.value.find(s=>s.isDefault)?.viewKey??v.SYSTEM_VIEW_KEY,c=a=>{w.value=a;const s=r.value.find(t=>t.viewKey===w.value);s&&setTimeout(()=>{s.viewKey===v.SYSTEM_VIEW_KEY?l?i.manual||(i.sendToUrl&&S&&i.initToUrl&&g.value&&o?.setSearchFormValues?.(_.value),o?.submitWith?.()):i.manual||(o?.resetSearchFormSorterItems?.(),o?.reset?.()):(i.sendToUrl&&S&&i.initToUrl&&g.value&&l?o?.setSearchFormValues?.(_.value):o?.setSearchFormValues?.({...Object.fromEntries(Object.keys(o?.getSearchFormValues?.()??{}).map(t=>[t,void 0]))??{},...i?.emptyData??{},...[...o?.getSearchFormSorterItems?.()??[],...i?.extraParams?.map(t=>({name:t}))??[]].reduce((t,n)=>(s.viewConfig?.searchForm?.[n.name]&&(t[n.name]=s.viewConfig?.searchForm?.[n.name]),t),{})??{}}),o?.setSearchFormSorterItems?.(s.viewConfig?.sorterItems??[]),l?i.manual||o?.submitWith?.():o?.submit?.()),l=!1})},T={getViewList:async a=>{try{const{tableKey:s}=a,t=await d?.getViewList?.({tableKey:s});return r.value=[y.value,...t??[]],c(D()),r.value}catch{return r.value=[y.value],c(v.SYSTEM_VIEW_KEY),r.value}},addView:async a=>{const{tableKey:s,viewKey:t,viewName:n,isDefault:u,viewConfig:f}=a;await d?.addView?.({tableKey:s,viewKey:t,viewName:n,isDefault:u,viewConfig:f}),u&&(r.value=r.value.map(m=>({...m,isDefault:!1}))),r.value=[...r.value,{viewKey:t,viewName:n,isDefault:u,viewConfig:f}],c(t)},changeView:async a=>{const{tableKey:s,viewKey:t,viewName:n,isDefault:u,viewConfig:f}=a;await d?.changeView?.({tableKey:s,viewKey:t,viewName:n,isDefault:u,viewConfig:f}),u&&(r.value=r.value.map(K=>({...K,isDefault:!1})));const m=r.value.find(K=>K.viewKey===t);m&&(m.viewName=n,m.isDefault=u,m.viewConfig=f),c(t)},removeView:async a=>{const{tableKey:s,viewKey:t}=a;await d?.removeView?.({tableKey:s,viewKey:t}),r.value=r.value.filter(n=>n.viewKey!==t),t===w.value&&c(D())}},j={tableKey:e.computed(()=>i.tableKey),currentViewKey:w,changeCurrentViewKey:c,popoverOpen:M,menuOpen:V,viewList:r,viewListCRUD:T,saveDataSource:o};return z.useViewProvide(j),e.watch(()=>i.tableKey,a=>{k.isValid(a)&&(l=!0,T?.getViewList?.({tableKey:a}))},{immediate:!0}),E({setFirstDefaultSystemView:a=>{b=a},setInitToUrl:a=>{S=a},mountedData:e.computed(()=>_.value)}),(a,s)=>(e.openBlock(),e.createBlock(e.unref(G.ApBatchActionGroup),e.mergeProps({...a.$attrs},{open:V.value,"onUpdate:open":s[0]||(s[0]=t=>V.value=t),class:[e.unref(p)(),e.unref(h)],"button-props":W,"menu-list":P.value,"overlay-class-name":[e.unref(p)("overlay"),e.unref(h)],trigger:"click",placement:"bottom"}),{icon:e.withCtx(()=>[e.createElementVNode("div",{class:e.normalizeClass([e.unref(p)("icon")])},[e.createVNode(R.default)],2)]),_:1},16,["open","class","menu-list","overlay-class-name"]))}});exports.default=te;
@@ -1,12 +1,13 @@
1
1
  import { ApFormProps, UpdateModelOptimizeFn, ApFormInternalInstance, WatchFunc } from '../../../ap-form';
2
2
  import { DefineComponent, ComponentOptionsMixin, PublicProps, ComponentProvideOptions, ComponentInternalInstance, ExtractPropTypes, PropType, HTMLAttributes, VNodeProps, AllowedComponentProps, ComponentCustomProps, CreateComponentPublicInstanceWithMixins, GlobalComponents, GlobalDirectives, Slot, ComponentPublicInstance, ComponentOptionsBase, DebuggerEvent, nextTick, WatchOptions, WatchStopHandle, ShallowUnwrapRef, ComponentCustomProperties } from 'vue';
3
3
  import { ColSize } from '@aplus-frontend/antdv/es/grid';
4
- import { FormLabelAlign, ValidateMessages, FieldData, ValidateErrorEntity, NamePath, ValidateOptions, InternalNamePath } from '@aplus-frontend/antdv/es/form/interface';
4
+ import { FormLabelAlign, ValidateMessages, FieldData, ValidateErrorEntity, NamePath, RuleObject, ValidateOptions, InternalNamePath } from '@aplus-frontend/antdv/es/form/interface';
5
5
  import { RequiredMark } from '@aplus-frontend/antdv/es/form/Form';
6
6
  import { RuleObject } from '@aplus-frontend/antdv/es/form';
7
7
  import { Options } from '../../../../node_modules/scroll-into-view-if-needed';
8
8
  import { Recordable } from '../../../type';
9
9
  import { VueTypeDef, VueTypeValidableDef } from '../../../../node_modules/vue-types';
10
+ import { SizeType } from '@aplus-frontend/antdv/es/config-provider';
10
11
  import { SizeType } from '@aplus-frontend/antdv/es/button';
11
12
  import { VueNode } from '@aplus-frontend/antdv/es/_util/type';
12
13
  import { OnCleanup } from '@vue/reactivity';
@@ -109,7 +110,7 @@ declare const _default: DefineComponent<__VLS_Props, {}, {}, {}, {}, ComponentOp
109
110
  readonly onValidate?: ((name: string | number | string[] | number[], status: boolean, errors: string[]) => void) | undefined;
110
111
  readonly initialValues?: Recordable | undefined;
111
112
  readonly onValuesChange?: ((changedValues: Recordable, allValues: Recordable, fieldName: NamePath) => void) | undefined;
112
- readonly syncToUrl?: boolean | ((values: Recordable, type: "get" | "set") => Recordable) | undefined;
113
+ readonly syncToUrl?: (boolean | ((values: Recordable, type: "get" | "set") => Recordable)) | undefined;
113
114
  readonly syncToUrlPriority?: boolean | undefined;
114
115
  readonly autoFocusFirstInput?: boolean | undefined;
115
116
  } & VNodeProps & AllowedComponentProps & ComponentCustomProps;
@@ -1,12 +1,13 @@
1
1
  import { ViewListModel } from '../interface';
2
2
  import { DefineComponent, ComponentOptionsMixin, PublicProps, ComponentProvideOptions, ComponentInternalInstance, ExtractPropTypes, PropType, HTMLAttributes, VNodeProps, AllowedComponentProps, ComponentCustomProps, CreateComponentPublicInstanceWithMixins, GlobalComponents, GlobalDirectives, Slot, ComponentPublicInstance, ComponentOptionsBase, DebuggerEvent, nextTick, WatchOptions, WatchStopHandle, ShallowUnwrapRef, ComponentCustomProperties } from 'vue';
3
3
  import { ColSize } from '@aplus-frontend/antdv/es/grid';
4
- import { FormLabelAlign, ValidateMessages, FieldData, ValidateErrorEntity, NamePath, ValidateOptions, InternalNamePath } from '@aplus-frontend/antdv/es/form/interface';
4
+ import { FormLabelAlign, ValidateMessages, FieldData, ValidateErrorEntity, NamePath, RuleObject, ValidateOptions, InternalNamePath } from '@aplus-frontend/antdv/es/form/interface';
5
5
  import { RequiredMark } from '@aplus-frontend/antdv/es/form/Form';
6
6
  import { RuleObject } from '@aplus-frontend/antdv/es/form';
7
7
  import { Options } from '../../../../node_modules/scroll-into-view-if-needed';
8
8
  import { Recordable } from '../../../type';
9
9
  import { VueTypeDef, VueTypeValidableDef } from '../../../../node_modules/vue-types';
10
+ import { SizeType } from '@aplus-frontend/antdv/es/config-provider';
10
11
  import { SizeType } from '@aplus-frontend/antdv/es/button';
11
12
  import { VueNode } from '@aplus-frontend/antdv/es/_util/type';
12
13
  import { ApFormProps, UpdateModelOptimizeFn, ApFormInternalInstance, WatchFunc } from '../../../ap-form';
@@ -110,7 +111,7 @@ declare const _default: DefineComponent<__VLS_Props, {}, {}, {}, {}, ComponentOp
110
111
  readonly onValidate?: ((name: string | number | string[] | number[], status: boolean, errors: string[]) => void) | undefined;
111
112
  readonly initialValues?: Recordable | undefined;
112
113
  readonly onValuesChange?: ((changedValues: Recordable, allValues: Recordable, fieldName: NamePath) => void) | undefined;
113
- readonly syncToUrl?: boolean | ((values: Recordable, type: "get" | "set") => Recordable) | undefined;
114
+ readonly syncToUrl?: (boolean | ((values: Recordable, type: "get" | "set") => Recordable)) | undefined;
114
115
  readonly syncToUrlPriority?: boolean | undefined;
115
116
  readonly autoFocusFirstInput?: boolean | undefined;
116
117
  } & VNodeProps & AllowedComponentProps & ComponentCustomProps;
@@ -0,0 +1,11 @@
1
+ import { ComputedRef } from 'vue';
2
+ import { Recordable } from '../../../type';
3
+ import { SaveDataSource } from '../interface';
4
+ export declare const useSendToUrl: (option: {
5
+ saveDataSource: SaveDataSource;
6
+ sendToUrl: ComputedRef<boolean>;
7
+ tableKey: ComputedRef<string>;
8
+ }) => {
9
+ mountedData: ComputedRef<Recordable>;
10
+ isValidMountedData: ComputedRef<boolean>;
11
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});const d=require("@aplus-frontend/utils"),e=require("vue"),l=require("../utils/query.js"),v=s=>{const{saveDataSource:c,sendToUrl:i,tableKey:n}=s;let r,t,u=!1;const a=e.ref({});return e.onMounted(()=>{if(i?.value){try{a.value=JSON.parse(atob(l.getUrlQuery()[n.value]??""))}catch{a.value={}}r=setInterval(()=>{try{const o=btoa(JSON.stringify(c?.getSearchFormValues?.()??{}));o!==t&&(t=o,u=!0)}catch{t=""}u&&(l.setUrlQuery({[n.value]:t}),u=!1)},500)}}),e.onUnmounted(()=>{r&&clearInterval(r)}),{mountedData:e.computed(()=>a.value),isValidMountedData:e.computed(()=>d.isObjectWithContent(a.value))}};exports.useSendToUrl=v;
@@ -1,14 +1,19 @@
1
1
  import { CreateComponentPublicInstanceWithMixins, ComponentOptionsMixin, PublicProps, GlobalComponents, GlobalDirectives, ComponentProvideOptions, ComponentOptionsBase, VNodeProps, AllowedComponentProps, ComponentCustomProps, Plugin } from 'vue';
2
2
  import { ApViewProps } from './interface';
3
+ import { Recordable } from '../../type';
3
4
  export * from './interface';
4
5
  declare const ApView: {
5
6
  new (...args: any[]): CreateComponentPublicInstanceWithMixins<Readonly< ApViewProps> & Readonly<{}>, {
6
7
  setFirstDefaultSystemView: (value: boolean) => void;
8
+ setInitToUrl: (value: boolean) => void;
9
+ mountedData: Recordable;
7
10
  }, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, PublicProps, {
8
11
  manual: boolean;
9
12
  maxViewNum: number;
13
+ sendToUrl: boolean;
10
14
  isDefaultSystemView: boolean;
11
15
  isFirstDefaultSystemView: boolean;
16
+ initToUrl: boolean;
12
17
  }, false, {}, {}, GlobalComponents, GlobalDirectives, string, {}, any, ComponentProvideOptions, {
13
18
  P: {};
14
19
  B: {};
@@ -18,22 +23,30 @@ declare const ApView: {
18
23
  Defaults: {};
19
24
  }, Readonly< ApViewProps> & Readonly<{}>, {
20
25
  setFirstDefaultSystemView: (value: boolean) => void;
26
+ setInitToUrl: (value: boolean) => void;
27
+ mountedData: Recordable;
21
28
  }, {}, {}, {}, {
22
29
  manual: boolean;
23
30
  maxViewNum: number;
31
+ sendToUrl: boolean;
24
32
  isDefaultSystemView: boolean;
25
33
  isFirstDefaultSystemView: boolean;
34
+ initToUrl: boolean;
26
35
  }>;
27
36
  __isFragment?: never;
28
37
  __isTeleport?: never;
29
38
  __isSuspense?: never;
30
39
  } & ComponentOptionsBase<Readonly< ApViewProps> & Readonly<{}>, {
31
40
  setFirstDefaultSystemView: (value: boolean) => void;
41
+ setInitToUrl: (value: boolean) => void;
42
+ mountedData: Recordable;
32
43
  }, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, {
33
44
  manual: boolean;
34
45
  maxViewNum: number;
46
+ sendToUrl: boolean;
35
47
  isDefaultSystemView: boolean;
36
48
  isFirstDefaultSystemView: boolean;
49
+ initToUrl: boolean;
37
50
  }, {}, string, {}, GlobalComponents, GlobalDirectives, string, ComponentProvideOptions> & VNodeProps & AllowedComponentProps & ComponentCustomProps & ( Plugin & (new (...args: any[]) => {
38
51
  $props: {
39
52
  onClick?: () => void;
@@ -90,7 +90,17 @@ export interface ApViewProps {
90
90
  * 视图额外需要被设置的参数Key
91
91
  */
92
92
  extraParams?: string[];
93
+ /**
94
+ * 是否将参数保存在url,默认为 true,设置为 false 后,searchForm 将不会将参数保存在url上
95
+ */
96
+ sendToUrl?: boolean;
97
+ /**
98
+ * 是否在第一次进入页面时将参数保存在url回显在 searchForm,默认为 true,设置为 false 后,第一次进入页面时 searchForm 将不会将参数保存在url上
99
+ */
100
+ initToUrl?: boolean;
93
101
  }
94
102
  export interface ApViewExpose {
95
103
  setFirstDefaultSystemView: (value: boolean) => void;
104
+ setInitToUrl: (value: boolean) => void;
105
+ mountedData: Recordable;
96
106
  }
@@ -0,0 +1,4 @@
1
+ export declare function setUrlQuery(params: Record<string, string>): void;
2
+ export declare function getUrlQuery(): {
3
+ [k: string]: string;
4
+ };
@@ -0,0 +1 @@
1
+ "use strict";Object.defineProperty(exports,Symbol.toStringTag,{value:"Module"});function i(e){const t=new URL(window.location.href);if(window.location.hash.startsWith("#/")){const[r,n=""]=window.location.hash.split("?"),s=new URLSearchParams(n);Object.entries(e).forEach(([a,c])=>{s.set(a,c)});const o=`${r}?${s.toString()}`;window.history.replaceState(null,"",o)}else Object.entries(e).forEach(([r,n])=>{t.searchParams.set(r,n)}),window.history.replaceState(null,"",t.toString())}function h(){const e=window.location.hash;if(e.includes("?")){const t=e.split("?")[1];return Object.fromEntries(new URLSearchParams(t))}return Object.fromEntries(new URLSearchParams(window.location.search))}exports.getUrlQuery=h;exports.setUrlQuery=i;
@@ -2,11 +2,7 @@ import { InjectionKey, Ref, ComputedRef } from 'vue';
2
2
  export declare const defaultNamespace = "aplus";
3
3
  export declare const namespaceContextKey: InjectionKey<Ref<string | undefined>>;
4
4
  export declare const useGetDerivedNamespace: (namespaceOverrides?: Ref<string | undefined>) => ComputedRef<string>;
5
- export declare const useNamespace: (
6
- /**
7
- * 块 一般是指组件名
8
- */
9
- block: string, namespaceOverrides?: Ref<string | undefined>) => {
5
+ export declare const useNamespace: (block: string, namespaceOverrides?: Ref<string | undefined>) => {
10
6
  namespace: ComputedRef<string>;
11
7
  b: (blockSuffix?: string) => string;
12
8
  e: (element?: string) => string;
@@ -1,5 +1,5 @@
1
1
  import { EditableColumnType, EditableTableFormItemExpose, EditableTableFormItemProps } from './interface';
2
- import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode } from 'vue';
2
+ import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode, RendererNode, RendererElement } from 'vue';
3
3
  declare const _default: <RecordType = any>(__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<{
4
4
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{} & VNodeProps & AllowedComponentProps & ComponentCustomProps, never>, never> & EditableTableFormItemProps<RecordType> & Partial<{}>> & PublicProps;
5
5
  expose(exposed: ShallowUnwrapRef<EditableTableFormItemExpose>): void;
@@ -36,7 +36,9 @@ declare const _default: <RecordType = any>(__VLS_props: NonNullable<Awaited<type
36
36
  }) => void;
37
37
  };
38
38
  emit: {};
39
- }>) => VNode & {
39
+ }>) => VNode<RendererNode, RendererElement, {
40
+ [key: string]: any;
41
+ }> & {
40
42
  __ctx?: Awaited<typeof __VLS_setup>;
41
43
  };
42
44
  export default _default;
@@ -1,6 +1,6 @@
1
1
  import { Recordable } from '../type';
2
2
  import { EditableTableProps, EditableColumnType, EditableTableExpose } from './interface';
3
- import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode } from 'vue';
3
+ import { VNodeProps, AllowedComponentProps, ComponentCustomProps, PublicProps, ShallowUnwrapRef, VNode, RendererNode, RendererElement } from 'vue';
4
4
  declare const _default: <RecordType extends Recordable = any>(__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
5
  props: __VLS_PrettifyLocal<Pick<Partial<{}> & Omit<{
6
6
  readonly "onUpdate:value"?: ((...args: any[]) => any) | undefined;
@@ -39,7 +39,9 @@ declare const _default: <RecordType extends Recordable = any>(__VLS_props: NonNu
39
39
  }) => void;
40
40
  };
41
41
  emit: (event: "update:value", ...args: any[]) => void;
42
- }>) => VNode & {
42
+ }>) => VNode<RendererNode, RendererElement, {
43
+ [key: string]: any;
44
+ }> & {
43
45
  __ctx?: Awaited<typeof __VLS_setup>;
44
46
  };
45
47
  export default _default;
@@ -1,4 +1,4 @@
1
- import { ScrollBarDirection, InternalScrollBarProps } from '../scroll-bar';
1
+ import { ScrollBarDirection, InternalScrollBarProps, ColorType } from '../scroll-bar';
2
2
  import { ScrollOptions, ScrollViewProps } from './interface';
3
3
  import { CreateComponentPublicInstanceWithMixins, Ref, ShallowRef, ComponentOptionsMixin, PublicProps, GlobalComponents, GlobalDirectives, ComponentProvideOptions, DefineComponent, ComputedRef } from 'vue';
4
4
  declare function scroll(x?: number, y?: number): void;
@@ -106,8 +106,8 @@ declare const __VLS_component: DefineComponent<ScrollViewProps, {
106
106
  onScroll?: ((percent: number) => void) | undefined;
107
107
  disabled?: boolean | undefined;
108
108
  trackSpeed?: number | undefined;
109
- barColor?: import("csstype").Property.BackgroundColor | undefined;
110
- trackColor?: import("csstype").Property.BackgroundColor | undefined;
109
+ barColor?: ColorType;
110
+ trackColor?: ColorType;
111
111
  trackWidth?: number | undefined;
112
112
  showTrack?: boolean | undefined;
113
113
  onScrollStart?: ((percent: number) => void) | undefined;
@@ -118,8 +118,8 @@ declare const __VLS_component: DefineComponent<ScrollViewProps, {
118
118
  onScroll?: ((percent: number) => void) | undefined;
119
119
  disabled?: boolean | undefined;
120
120
  trackSpeed?: number | undefined;
121
- barColor?: import("csstype").Property.BackgroundColor | undefined;
122
- trackColor?: import("csstype").Property.BackgroundColor | undefined;
121
+ barColor?: ColorType;
122
+ trackColor?: ColorType;
123
123
  trackWidth?: number | undefined;
124
124
  showTrack?: boolean | undefined;
125
125
  onScrollStart?: ((percent: number) => void) | undefined;
@@ -1,8 +1,8 @@
1
1
  import { DefineComponent, ComponentOptionsMixin, PublicProps, ComponentProvideOptions } from 'vue';
2
2
  export declare const Wrapper: DefineComponent<{
3
- uiMode?: "admin" | "aplus" | undefined;
4
- lang?: "en" | "zh-cn" | undefined;
3
+ uiMode?: ("admin" | "aplus") | undefined;
4
+ lang?: ("en" | "zh-cn") | undefined;
5
5
  }, () => import("vue/jsx-runtime").JSX.Element, {}, {}, {}, ComponentOptionsMixin, ComponentOptionsMixin, {}, string, PublicProps, Readonly<{
6
- uiMode?: "admin" | "aplus" | undefined;
7
- lang?: "en" | "zh-cn" | undefined;
6
+ uiMode?: ("admin" | "aplus") | undefined;
7
+ lang?: ("en" | "zh-cn") | undefined;
8
8
  }> & Readonly<{}>, {}, {}, {}, {}, string, ComponentProvideOptions, true, {}, any>;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const h=require("dayjs"),r=require("vue"),b=require("./utils.js");function s(n,u){const t=Math.abs(n-u),e={diffMs:t,type:n<u?"ago":"late",diffFormatted:b.formatDuration(t)};return t<60*1e3?(e.unit="s",e.count=Math.round(t/1e3)):t<3600*1e3?(e.unit="m",e.count=Math.round(t/(60*1e3))):t<1440*60*1e3?(e.unit="h",e.count=Math.round(t/(3600*1e3))):t<720*60*60*1e3?(e.unit="d",e.count=Math.round(t/(1440*60*1e3))):t<365*24*60*60*1e3?(e.unit="M",e.count=Math.round(t/(720*60*60*1e3))):(e.unit="y",e.count=Math.round(t/365/(1440*60*1e3))),e}function i(n){return h(n).valueOf()}let p=1;function v(){return p++}const o=new Map;let l,c;function M(n,u){o.set(n,u),o.size&&!c&&(clearInterval(l),l=setInterval(()=>{c=!0;const t=Date.now();o.forEach(e=>{e.interval&&Math.abs(t-e.updated-e.interval)<50&&(e.timeAgo.value=s(e.ts,t),e.updated=t)})},5e3))}function m(n){o.delete(n),o.size||(clearInterval(l),c=!1)}const T=(n,u,t)=>{const e=v(),a=r.ref(s(i(n.value),i(u))),f={ts:i(n.value),timeAgo:a,interval:t.value,updated:Date.now()};return r.watch(()=>n.value,g=>{const d=i(g);f.ts=d,a.value=s(d,i(u))}),M(e,f),r.onBeforeUnmount(()=>{m(e)}),a};exports.default=T;exports.getId=v;exports.getTimeAgo=s;exports.subscribe=M;exports.unsubscribe=m;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const h=require("dayjs"),r=require("vue"),b=require("./utils.js");function s(n,u){const t=Math.abs(n-u),e={diffMs:t,type:n<u?"ago":"late",diffFormatted:b.formatDuration(t)};return t<60*1e3?(e.unit="s",e.count=Math.round(t/1e3)):t<60*60*1e3?(e.unit="m",e.count=Math.round(t/(60*1e3))):t<24*60*60*1e3?(e.unit="h",e.count=Math.round(t/(60*60*1e3))):t<30*24*60*60*1e3?(e.unit="d",e.count=Math.round(t/(24*60*60*1e3))):t<365*24*60*60*1e3?(e.unit="M",e.count=Math.round(t/(30*24*60*60*1e3))):(e.unit="y",e.count=Math.round(t/365/(24*60*60*1e3))),e}function i(n){return h(n).valueOf()}let p=1;function v(){return p++}const o=new Map;let l,c;function M(n,u){o.set(n,u),o.size&&!c&&(clearInterval(l),l=setInterval(()=>{c=!0;const t=Date.now();o.forEach(e=>{e.interval&&Math.abs(t-e.updated-e.interval)<50&&(e.timeAgo.value=s(e.ts,t),e.updated=t)})},5e3))}function m(n){o.delete(n),o.size||(clearInterval(l),c=!1)}const T=(n,u,t)=>{const e=v(),a=r.ref(s(i(n.value),i(u))),f={ts:i(n.value),timeAgo:a,interval:t.value,updated:Date.now()};return r.watch(()=>n.value,g=>{const d=i(g);f.ts=d,a.value=s(d,i(u))}),M(e,f),r.onBeforeUnmount(()=>{m(e)}),a};exports.default=T;exports.getId=v;exports.getTimeAgo=s;exports.subscribe=M;exports.unsubscribe=m;
@@ -1,2 +1,2 @@
1
- declare const _default: "7.18.1";
1
+ declare const _default: "7.19.0-beta.0";
2
2
  export default _default;
@@ -1 +1 @@
1
- "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="7.18.1";exports.default=e;
1
+ "use strict";Object.defineProperties(exports,{__esModule:{value:!0},[Symbol.toStringTag]:{value:"Module"}});const e="7.19.0-beta.0";exports.default=e;
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@aplus-frontend/ui",
3
- "version": "7.18.1",
3
+ "version": "7.19.0-beta.0",
4
4
  "main": "./lib/index.js",
5
5
  "type": "module",
6
6
  "typings": "./lib/index.d.ts",
@@ -41,8 +41,8 @@
41
41
  "scroll-into-view-if-needed": "^3.1.0",
42
42
  "vue-virtual-scroller": "2.0.0-beta.8",
43
43
  "vuedraggable": "^4.1.0",
44
- "@aplus-frontend/utils": "1.0.66",
45
- "@aplus-frontend/hooks": "1.0.7"
44
+ "@aplus-frontend/hooks": "1.0.7",
45
+ "@aplus-frontend/utils": "1.0.66"
46
46
  },
47
47
  "peerDependencies": {
48
48
  "@aplus-frontend/antdv": "^2.1.4",