@maketribe/ms-app 4.0.2 → 4.0.5
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/cjs/{404-BzBweGOF.cjs → 404-gNESfO3I.cjs} +2 -2
- package/dist/cjs/{404-BzBweGOF.cjs.map → 404-gNESfO3I.cjs.map} +1 -1
- package/dist/cjs/{Editor-bMCthOeH.cjs → Editor-CllkwGIA.cjs} +2 -2
- package/dist/cjs/{Editor-bMCthOeH.cjs.map → Editor-CllkwGIA.cjs.map} +1 -1
- package/dist/cjs/{Editor-iH1ADXAU.cjs → Editor-DLwEPepL.cjs} +2 -2
- package/dist/cjs/{Editor-iH1ADXAU.cjs.map → Editor-DLwEPepL.cjs.map} +1 -1
- package/dist/cjs/{PermissionManage-Cki8nwBK.cjs → PermissionManage-CWAb1I4K.cjs} +2 -2
- package/dist/cjs/{PermissionManage-Cki8nwBK.cjs.map → PermissionManage-CWAb1I4K.cjs.map} +1 -1
- package/dist/cjs/{ResourceSelectInput-0fNS5jwl.cjs → ResourceSelectInput-BojlQdE6.cjs} +2 -2
- package/dist/cjs/{ResourceSelectInput-0fNS5jwl.cjs.map → ResourceSelectInput-BojlQdE6.cjs.map} +1 -1
- package/dist/cjs/{dialog-Cdj76tas.cjs → dialog-CBFYKYQy.cjs} +2 -2
- package/dist/cjs/{dialog-Cdj76tas.cjs.map → dialog-CBFYKYQy.cjs.map} +1 -1
- package/dist/cjs/{dialog-Cy7Bs9dF.cjs → dialog-CIabDtKI.cjs} +2 -2
- package/dist/cjs/{dialog-Cy7Bs9dF.cjs.map → dialog-CIabDtKI.cjs.map} +1 -1
- package/dist/cjs/{dialog-Dz1L7TX3.cjs → dialog-CW7fSms9.cjs} +2 -2
- package/dist/cjs/{dialog-Dz1L7TX3.cjs.map → dialog-CW7fSms9.cjs.map} +1 -1
- package/dist/cjs/{edit-1gCoQ31b.cjs → edit-GFdL0Ol4.cjs} +2 -2
- package/dist/cjs/{edit-1gCoQ31b.cjs.map → edit-GFdL0Ol4.cjs.map} +1 -1
- package/dist/cjs/{index-DGiFGZKA.cjs → index-7kACaw1B.cjs} +2 -2
- package/dist/cjs/{index-DGiFGZKA.cjs.map → index-7kACaw1B.cjs.map} +1 -1
- package/dist/cjs/{index-q5ZcYIGf.cjs → index-B-FGM893.cjs} +3 -3
- package/dist/cjs/{index-q5ZcYIGf.cjs.map → index-B-FGM893.cjs.map} +1 -1
- package/dist/cjs/{index-BYuSOhTm.cjs → index-B8FdzrWM.cjs} +2 -2
- package/dist/cjs/{index-BYuSOhTm.cjs.map → index-B8FdzrWM.cjs.map} +1 -1
- package/dist/cjs/{index-Czx9_lbI.cjs → index-BESPkXUX.cjs} +2 -2
- package/dist/cjs/{index-Czx9_lbI.cjs.map → index-BESPkXUX.cjs.map} +1 -1
- package/dist/cjs/{index-DMPcHjIW.cjs → index-BKQWAX6y.cjs} +2 -2
- package/dist/cjs/{index-DMPcHjIW.cjs.map → index-BKQWAX6y.cjs.map} +1 -1
- package/dist/cjs/{index-ciVhGIFQ.cjs → index-BQLf5c_E.cjs} +2 -2
- package/dist/cjs/{index-ciVhGIFQ.cjs.map → index-BQLf5c_E.cjs.map} +1 -1
- package/dist/cjs/{index-Dk5UVwXG.cjs → index-BZwAFUUB.cjs} +2 -2
- package/dist/cjs/{index-Dk5UVwXG.cjs.map → index-BZwAFUUB.cjs.map} +1 -1
- package/dist/cjs/{index-DsQhIJX7.cjs → index-Bcp0AiYW.cjs} +2 -2
- package/dist/cjs/{index-DsQhIJX7.cjs.map → index-Bcp0AiYW.cjs.map} +1 -1
- package/dist/cjs/{index-DAT2JM8p.cjs → index-BcppI_PT.cjs} +3 -3
- package/dist/cjs/{index-DAT2JM8p.cjs.map → index-BcppI_PT.cjs.map} +1 -1
- package/dist/cjs/{index-BL8-hr87.cjs → index-BfukvC5d.cjs} +2 -2
- package/dist/cjs/index-BfukvC5d.cjs.map +1 -0
- package/dist/cjs/{index-BRfd1LUE.cjs → index-BhwtJaI1.cjs} +2 -2
- package/dist/cjs/{index-BRfd1LUE.cjs.map → index-BhwtJaI1.cjs.map} +1 -1
- package/dist/cjs/{index-DiKA1TtB.cjs → index-CMOI-s1h.cjs} +4 -4
- package/dist/cjs/{index-DiKA1TtB.cjs.map → index-CMOI-s1h.cjs.map} +1 -1
- package/dist/cjs/{index-3iut24np.cjs → index-C_ZS5GYU.cjs} +2 -2
- package/dist/cjs/index-C_ZS5GYU.cjs.map +1 -0
- package/dist/cjs/{index-Dg1ZJyCn.cjs → index-ChFaO3MB.cjs} +2 -2
- package/dist/cjs/{index-Dg1ZJyCn.cjs.map → index-ChFaO3MB.cjs.map} +1 -1
- package/dist/cjs/{index-Dp9l72_d.cjs → index-Csy2ZzvU.cjs} +2 -2
- package/dist/cjs/{index-Dp9l72_d.cjs.map → index-Csy2ZzvU.cjs.map} +1 -1
- package/dist/cjs/{index-n3pRRELn.cjs → index-CuMMTa6L.cjs} +3 -3
- package/dist/cjs/{index-n3pRRELn.cjs.map → index-CuMMTa6L.cjs.map} +1 -1
- package/dist/cjs/{index-DZnFlm3J.cjs → index-D8-ao1yb.cjs} +2 -2
- package/dist/cjs/{index-DZnFlm3J.cjs.map → index-D8-ao1yb.cjs.map} +1 -1
- package/dist/cjs/{index-B88lgxOz.cjs → index-DISEE4zL.cjs} +3 -3
- package/dist/cjs/{index-B88lgxOz.cjs.map → index-DISEE4zL.cjs.map} +1 -1
- package/dist/cjs/{index-Bxh6IWG5.cjs → index-DJ_34JJF.cjs} +173 -147
- package/dist/cjs/index-DJ_34JJF.cjs.map +1 -0
- package/dist/cjs/{index-5imLoogO.cjs → index-DMeyL0Ds.cjs} +2 -2
- package/dist/cjs/{index-5imLoogO.cjs.map → index-DMeyL0Ds.cjs.map} +1 -1
- package/dist/cjs/{index-BqgJHW9m.cjs → index-DOCIGs3Q.cjs} +2 -2
- package/dist/cjs/{index-BqgJHW9m.cjs.map → index-DOCIGs3Q.cjs.map} +1 -1
- package/dist/cjs/{index-DAM_Rnjb.cjs → index-DTNe9sfj.cjs} +11 -10
- package/dist/cjs/{index-DAM_Rnjb.cjs.map → index-DTNe9sfj.cjs.map} +1 -1
- package/dist/cjs/{index-DRvRUiiK.cjs → index-DbbdzTyd.cjs} +2 -2
- package/dist/cjs/{index-DRvRUiiK.cjs.map → index-DbbdzTyd.cjs.map} +1 -1
- package/dist/cjs/{index-C4Q5vBG0.cjs → index-DoOkomzO.cjs} +2 -2
- package/dist/cjs/{index-C4Q5vBG0.cjs.map → index-DoOkomzO.cjs.map} +1 -1
- package/dist/cjs/{index-Dog0iG-F.cjs → index-DsPfPfRT.cjs} +2 -2
- package/dist/cjs/{index-Dog0iG-F.cjs.map → index-DsPfPfRT.cjs.map} +1 -1
- package/dist/cjs/{index-DiEsVAGI.cjs → index-Ye6Bi6Ra.cjs} +3 -3
- package/dist/cjs/{index-DiEsVAGI.cjs.map → index-Ye6Bi6Ra.cjs.map} +1 -1
- package/dist/cjs/{index-CNLioxH1.cjs → index-i1q4YuQ3.cjs} +2 -2
- package/dist/cjs/{index-CNLioxH1.cjs.map → index-i1q4YuQ3.cjs.map} +1 -1
- package/dist/cjs/{index-C5baOIR5.cjs → index-iY88UCO-.cjs} +2 -2
- package/dist/cjs/{index-C5baOIR5.cjs.map → index-iY88UCO-.cjs.map} +1 -1
- package/dist/cjs/index.js +1 -1
- package/dist/cjs/{normal-BwSBWIg9.cjs → normal-9Sd74y0U.cjs} +2 -2
- package/dist/cjs/{normal-BwSBWIg9.cjs.map → normal-9Sd74y0U.cjs.map} +1 -1
- package/dist/cjs/{normal-B04U6sXI.cjs → normal-KHnEJfJ2.cjs} +2 -2
- package/dist/cjs/{normal-B04U6sXI.cjs.map → normal-KHnEJfJ2.cjs.map} +1 -1
- package/dist/cjs/style.css +104 -38
- package/dist/cjs/{table-B23qE9vq.cjs → table-HezbJnJc.cjs} +2 -2
- package/dist/cjs/{table-B23qE9vq.cjs.map → table-HezbJnJc.cjs.map} +1 -1
- package/dist/esm/{404-CGMBvWJC.js → 404-D3_BuVvI.js} +2 -2
- package/dist/esm/{404-CGMBvWJC.js.map → 404-D3_BuVvI.js.map} +1 -1
- package/dist/esm/{Editor-BFuTvPav.js → Editor-Bhig_S4J.js} +2 -2
- package/dist/esm/{Editor-BFuTvPav.js.map → Editor-Bhig_S4J.js.map} +1 -1
- package/dist/esm/{Editor-DOawxd-8.js → Editor-DMU6Iped.js} +2 -2
- package/dist/esm/{Editor-DOawxd-8.js.map → Editor-DMU6Iped.js.map} +1 -1
- package/dist/esm/{PermissionManage-B27OtbZ4.js → PermissionManage-D8GnoFjV.js} +2 -2
- package/dist/esm/{PermissionManage-B27OtbZ4.js.map → PermissionManage-D8GnoFjV.js.map} +1 -1
- package/dist/esm/{ResourceSelectInput-BV4JLs2Z.js → ResourceSelectInput-_DpkQhgI.js} +2 -2
- package/dist/esm/{ResourceSelectInput-BV4JLs2Z.js.map → ResourceSelectInput-_DpkQhgI.js.map} +1 -1
- package/dist/esm/{dialog-TKihxlfv.js → dialog-CXKCj4dG.js} +2 -2
- package/dist/esm/{dialog-TKihxlfv.js.map → dialog-CXKCj4dG.js.map} +1 -1
- package/dist/esm/{dialog-B9x1BWVN.js → dialog-CrY554IQ.js} +2 -2
- package/dist/esm/{dialog-B9x1BWVN.js.map → dialog-CrY554IQ.js.map} +1 -1
- package/dist/esm/{dialog-u_uBgACo.js → dialog-DTdQYzsb.js} +2 -2
- package/dist/esm/{dialog-u_uBgACo.js.map → dialog-DTdQYzsb.js.map} +1 -1
- package/dist/esm/{edit-uWpOC3Nq.js → edit-CnW1vav_.js} +2 -2
- package/dist/esm/{edit-uWpOC3Nq.js.map → edit-CnW1vav_.js.map} +1 -1
- package/dist/esm/{index-40hRlNvx.js → index-6pAFW8Vh.js} +2 -2
- package/dist/esm/{index-40hRlNvx.js.map → index-6pAFW8Vh.js.map} +1 -1
- package/dist/esm/{index-Dum31xvp.js → index-B5WnSJ0l.js} +174 -148
- package/dist/esm/index-B5WnSJ0l.js.map +1 -0
- package/dist/esm/{index-BmkkhAqz.js → index-BL1Thi0L.js} +2 -2
- package/dist/esm/{index-BmkkhAqz.js.map → index-BL1Thi0L.js.map} +1 -1
- package/dist/esm/{index-BtPosd_V.js → index-BMsQ9MZO.js} +2 -2
- package/dist/esm/index-BMsQ9MZO.js.map +1 -0
- package/dist/esm/{index-CkxCpEYV.js → index-BO9igopw.js} +2 -2
- package/dist/esm/{index-CkxCpEYV.js.map → index-BO9igopw.js.map} +1 -1
- package/dist/esm/{index-Dx45vSXF.js → index-BR74s8xj.js} +2 -2
- package/dist/esm/{index-Dx45vSXF.js.map → index-BR74s8xj.js.map} +1 -1
- package/dist/esm/{index-hxtDa_tq.js → index-BibfPxyE.js} +2 -2
- package/dist/esm/{index-hxtDa_tq.js.map → index-BibfPxyE.js.map} +1 -1
- package/dist/esm/{index-Cysh8rM8.js → index-Bm_WLjtq.js} +2 -2
- package/dist/esm/index-Bm_WLjtq.js.map +1 -0
- package/dist/esm/{index-D32Y2j9j.js → index-CGBy2JBa.js} +2 -2
- package/dist/esm/{index-D32Y2j9j.js.map → index-CGBy2JBa.js.map} +1 -1
- package/dist/esm/{index-PEg2TZWA.js → index-CH7WN-BC.js} +2 -2
- package/dist/esm/{index-PEg2TZWA.js.map → index-CH7WN-BC.js.map} +1 -1
- package/dist/esm/{index-us02rfFp.js → index-CYqfkhll.js} +2 -2
- package/dist/esm/{index-us02rfFp.js.map → index-CYqfkhll.js.map} +1 -1
- package/dist/esm/{index-CEdBWrqr.js → index-CaT1yBkN.js} +2 -2
- package/dist/esm/{index-CEdBWrqr.js.map → index-CaT1yBkN.js.map} +1 -1
- package/dist/esm/{index-DgNzfAbG.js → index-CbofgtMb.js} +2 -2
- package/dist/esm/{index-DgNzfAbG.js.map → index-CbofgtMb.js.map} +1 -1
- package/dist/esm/{index-C0i3n5Hu.js → index-CkrS77t9.js} +3 -3
- package/dist/esm/{index-C0i3n5Hu.js.map → index-CkrS77t9.js.map} +1 -1
- package/dist/esm/{index-BIgutj3A.js → index-CrnR0ENO.js} +2 -2
- package/dist/esm/{index-BIgutj3A.js.map → index-CrnR0ENO.js.map} +1 -1
- package/dist/esm/{index-BLR8H0G7.js → index-Cys5Stbp.js} +2 -2
- package/dist/esm/{index-BLR8H0G7.js.map → index-Cys5Stbp.js.map} +1 -1
- package/dist/esm/{index-DJGMjPB9.js → index-D30VkiUw.js} +4 -4
- package/dist/esm/{index-DJGMjPB9.js.map → index-D30VkiUw.js.map} +1 -1
- package/dist/esm/{index-Bp-zi0tQ.js → index-D5tBMykg.js} +2 -2
- package/dist/esm/{index-Bp-zi0tQ.js.map → index-D5tBMykg.js.map} +1 -1
- package/dist/esm/{index-sRMYMeLU.js → index-D8AhTxEQ.js} +2 -2
- package/dist/esm/{index-sRMYMeLU.js.map → index-D8AhTxEQ.js.map} +1 -1
- package/dist/esm/{index-IwN_2M4P.js → index-DBYf3N_H.js} +2 -2
- package/dist/esm/{index-IwN_2M4P.js.map → index-DBYf3N_H.js.map} +1 -1
- package/dist/esm/{index-BmCIBx6p.js → index-DQ858uj-.js} +2 -2
- package/dist/esm/{index-BmCIBx6p.js.map → index-DQ858uj-.js.map} +1 -1
- package/dist/esm/{index-gM_MzZ4F.js → index-DdH6OCKp.js} +3 -3
- package/dist/esm/{index-gM_MzZ4F.js.map → index-DdH6OCKp.js.map} +1 -1
- package/dist/esm/{index-Ss6jaMiD.js → index-Dx_DWZka.js} +3 -3
- package/dist/esm/{index-Ss6jaMiD.js.map → index-Dx_DWZka.js.map} +1 -1
- package/dist/esm/{index-DxdoerPE.js → index-SdxgZQLS.js} +8 -7
- package/dist/esm/{index-DxdoerPE.js.map → index-SdxgZQLS.js.map} +1 -1
- package/dist/esm/{index-CQpOTEvB.js → index-WAZn782k.js} +3 -3
- package/dist/esm/{index-CQpOTEvB.js.map → index-WAZn782k.js.map} +1 -1
- package/dist/esm/{index-dyVqrVB3.js → index-ZmRbK5N3.js} +2 -2
- package/dist/esm/{index-dyVqrVB3.js.map → index-ZmRbK5N3.js.map} +1 -1
- package/dist/esm/{index-BpaEWy1u.js → index-eBGdQshs.js} +2 -2
- package/dist/esm/{index-BpaEWy1u.js.map → index-eBGdQshs.js.map} +1 -1
- package/dist/esm/{index-CrGyN4bm.js → index-pCgDKrHr.js} +3 -3
- package/dist/esm/{index-CrGyN4bm.js.map → index-pCgDKrHr.js.map} +1 -1
- package/dist/esm/index.js +1 -1
- package/dist/esm/{normal-BYM_Qh87.js → normal-CPxIocMG.js} +2 -2
- package/dist/esm/{normal-BYM_Qh87.js.map → normal-CPxIocMG.js.map} +1 -1
- package/dist/esm/{normal-lbysXNk5.js → normal-GrSzV1bh.js} +2 -2
- package/dist/esm/{normal-lbysXNk5.js.map → normal-GrSzV1bh.js.map} +1 -1
- package/dist/esm/style.css +104 -38
- package/dist/esm/{table-BcFdzeOC.js → table-D7IlWlB-.js} +2 -2
- package/dist/esm/{table-BcFdzeOC.js.map → table-D7IlWlB-.js.map} +1 -1
- package/dist/types/components/abstract/abstract-select/abstract-select-options.d.ts +1 -0
- package/dist/types/components/abstract/abstract-select/abstract-select.d.ts +4 -0
- package/dist/types/components/abstract/abstract-select/index.d.ts +4 -0
- package/dist/types/components/basic/DataSelect/DataSelect.d.ts +3 -0
- package/dist/types/components/basic/DataSelect/index.d.ts +3 -0
- package/dist/types/components/basic/DataSelect/options.d.ts +1 -0
- package/dist/types/components/basic/DataTableSelect/DataTableSelect.d.ts +3 -0
- package/dist/types/components/basic/DataTableSelect/index.d.ts +3 -0
- package/dist/types/components/basic/DataTableSelect/options.d.ts +1 -0
- package/dist/types/components/basic/DataTreeSelect/DataTreeSelect.d.ts +3 -0
- package/dist/types/components/basic/DataTreeSelect/index.d.ts +3 -0
- package/dist/types/components/basic/DataTreeSelect/options.d.ts +1 -0
- package/dist/types/components/layouts/PagePanel/index.d.ts +1 -0
- package/dist/types/components/layouts/PagePanel/index.vue.d.ts +1 -0
- package/dist/types/dataviews/department/DepartmentTree.d.ts +1 -1
- package/dist/types/dataviews/ms-message/MsMessageNotifyTable.d.ts +1 -1
- package/dist/types/dataviews/ms-role/MsRolePermissionConfigTable.d.ts +1 -1
- package/dist/types/dataviews/ms-role/ms-role-permission-point/MsRolePermissionPointTable.d.ts +1 -1
- package/dist/types/dataviews/ms-role/ms-role-route/MsRoleRouteTable.d.ts +1 -1
- package/package.json +5 -5
- package/dist/cjs/index-3iut24np.cjs.map +0 -1
- package/dist/cjs/index-BL8-hr87.cjs.map +0 -1
- package/dist/cjs/index-Bxh6IWG5.cjs.map +0 -1
- package/dist/esm/index-BtPosd_V.js.map +0 -1
- package/dist/esm/index-Cysh8rM8.js.map +0 -1
- package/dist/esm/index-Dum31xvp.js.map +0 -1
|
@@ -2,7 +2,7 @@ var __defProp = Object.defineProperty;
|
|
|
2
2
|
var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
|
|
3
3
|
var __publicField = (obj, key, value) => __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
|
|
4
4
|
var _a, _b, _c, _d, _e, _f, _g, _h, _i, _j, _k, _l, _m, _n, _o, _p, _q, _r, _s, _t, _u, _v, _w, _x, _y, _z, _A, _B, _C, _D, _E, _F, _G, _H, _I, _J, _K, _L, _M, _N, _O, _P, _Q, _R, _S, _T, _U, _V, _W, _X, _Y, _Z, __, _$, _aa, _ba, _ca, _da, _ea, _fa, _ga, _ha, _ia, _ja;
|
|
5
|
-
import { defineAsyncComponent, reactive, ref, getCurrentInstance, inject, computed, unref, provide, defineComponent, createVNode, renderSlot, isVNode, watch, isRef, onBeforeUnmount, resolveComponent, openBlock, createBlock, withCtx, createTextVNode, createElementVNode, createElementBlock, Fragment, renderList, createCommentVNode, normalizeClass, normalizeStyle, onMounted, h, shallowReactive, withModifiers, watchEffect, onUnmounted, readonly, useSlots, toRaw, mergeProps, nextTick,
|
|
5
|
+
import { defineAsyncComponent, reactive, ref, getCurrentInstance, inject, computed, unref, provide, defineComponent, createVNode, renderSlot, isVNode, watch, isRef, onBeforeUnmount, resolveComponent, openBlock, createBlock, withCtx, createTextVNode, createElementVNode, createElementBlock, Fragment, renderList, createCommentVNode, normalizeClass, normalizeStyle, withDirectives, resolveDirective, onMounted, h, shallowReactive, withModifiers, watchEffect, onUnmounted, readonly, useSlots, toRaw, mergeProps, nextTick, createSlots, toDisplayString, Suspense, resolveDynamicComponent, shallowRef, Teleport, pushScopeId, popScopeId, Transition, render, toHandlers, TransitionGroup, vShow, onBeforeUpdate, withKeys, vModelText, normalizeProps, guardReactiveProps, onErrorCaptured, KeepAlive } from "vue";
|
|
6
6
|
import { Components, Operator, DataTable as DataTable$1, DataForm as DataForm$1, ComponentsCombine, isWhereFilter, Dialoger, Messager, FormColumn, DataTree, RefreshButton, AddButton, TableHeaderItem as TableHeaderItem$1, FilterColumn, TableColumn, TableActionColumn, DataFormType, ActionButton, EditButton, DeleteButton, TableSelectCacheColumn, LoadingManager, FormDetailColumn, TableHeaderButton, Notificationer, SkeletonMessageSender, SkeletonDialoger } from "@maketribe/dm";
|
|
7
7
|
import { ElInput, ElInputNumber, ElConfigProvider, ElButton, ElSelect, ElOption, ElPagination, ElDatePicker, useFormItem as useFormItem$1, ElPopover, ElScrollbar, ElTooltip, ElForm, ElFormItem, ElCollapse, ElCollapseItem, useFormDisabled, ElCard, ElTableColumn, ElTable, ElEmpty, ElTag, ElTree, ElMessageBox, ElIcon, ElMessage, ElImage, ElTabs, ElTabPane, ElRow, ElCol, ElLoading, ElDialog, ElAlert, ElProgress, ElCheckbox, ElNotification, ElUpload, ElDrawer, ElButtonGroup, ElBadge } from "element-plus";
|
|
8
8
|
import { Disposable, Event, createDisposable, md5, buildProps, withInstall, aesEncrypt, aesDecrypt, fileSelect, base64ToBlob, postTraverse, makeInstaller } from "@maketribe/utils";
|
|
@@ -153,84 +153,84 @@ class DataTableComponents extends Components {
|
|
|
153
153
|
name: "MKColumnAction",
|
|
154
154
|
title: "操作",
|
|
155
155
|
component: defineAsyncComponent(
|
|
156
|
-
async () => import("./index-
|
|
156
|
+
async () => import("./index-BibfPxyE.js")
|
|
157
157
|
)
|
|
158
158
|
});
|
|
159
159
|
this.registerComponent({
|
|
160
160
|
name: "MKColumnText",
|
|
161
161
|
title: "文本",
|
|
162
162
|
component: defineAsyncComponent(
|
|
163
|
-
async () => import("./index-
|
|
163
|
+
async () => import("./index-pCgDKrHr.js")
|
|
164
164
|
)
|
|
165
165
|
});
|
|
166
166
|
this.registerComponent({
|
|
167
167
|
name: "MKColumnObjectMappingText",
|
|
168
168
|
title: "对象映射文本",
|
|
169
169
|
component: defineAsyncComponent(
|
|
170
|
-
async () => import("./index-
|
|
170
|
+
async () => import("./index-CkrS77t9.js")
|
|
171
171
|
)
|
|
172
172
|
});
|
|
173
173
|
this.registerComponent({
|
|
174
174
|
name: "MKColumnImage",
|
|
175
175
|
title: "图片",
|
|
176
176
|
component: defineAsyncComponent(
|
|
177
|
-
async () => import("./index-
|
|
177
|
+
async () => import("./index-CYqfkhll.js")
|
|
178
178
|
)
|
|
179
179
|
});
|
|
180
180
|
this.registerComponent({
|
|
181
181
|
name: "MKColumnSelect",
|
|
182
182
|
title: "行选择",
|
|
183
183
|
component: defineAsyncComponent(
|
|
184
|
-
async () => import("./index-
|
|
184
|
+
async () => import("./index-6pAFW8Vh.js")
|
|
185
185
|
)
|
|
186
186
|
});
|
|
187
187
|
this.registerComponent({
|
|
188
188
|
name: "MKColumnJson",
|
|
189
189
|
title: "JSON",
|
|
190
190
|
component: defineAsyncComponent(
|
|
191
|
-
async () => import("./index-
|
|
191
|
+
async () => import("./index-CrnR0ENO.js")
|
|
192
192
|
)
|
|
193
193
|
});
|
|
194
194
|
this.registerComponent({
|
|
195
195
|
name: "MKColumnDate",
|
|
196
196
|
title: "日期时间",
|
|
197
197
|
component: defineAsyncComponent(
|
|
198
|
-
async () => import("./index-
|
|
198
|
+
async () => import("./index-D30VkiUw.js")
|
|
199
199
|
)
|
|
200
200
|
});
|
|
201
201
|
this.registerComponent({
|
|
202
202
|
name: "MKColumnSwitch",
|
|
203
203
|
title: "开关",
|
|
204
204
|
component: defineAsyncComponent(
|
|
205
|
-
async () => import("./index-
|
|
205
|
+
async () => import("./index-DQ858uj-.js")
|
|
206
206
|
)
|
|
207
207
|
});
|
|
208
208
|
this.registerComponent({
|
|
209
209
|
name: "MKColumnTag",
|
|
210
210
|
title: "标签",
|
|
211
211
|
component: defineAsyncComponent(
|
|
212
|
-
async () => import("./index-
|
|
212
|
+
async () => import("./index-CbofgtMb.js")
|
|
213
213
|
)
|
|
214
214
|
});
|
|
215
215
|
this.registerComponent({
|
|
216
216
|
name: "MKColumnLink",
|
|
217
217
|
title: "链接",
|
|
218
218
|
component: defineAsyncComponent(
|
|
219
|
-
async () => import("./index-
|
|
219
|
+
async () => import("./index-Dx_DWZka.js")
|
|
220
220
|
)
|
|
221
221
|
});
|
|
222
222
|
this.registerComponent({
|
|
223
223
|
name: "MKColumnSort",
|
|
224
224
|
title: "拖拽排序",
|
|
225
225
|
component: defineAsyncComponent(
|
|
226
|
-
async () => import("./index-
|
|
226
|
+
async () => import("./index-CH7WN-BC.js")
|
|
227
227
|
)
|
|
228
228
|
});
|
|
229
229
|
this.registerComponent({
|
|
230
230
|
name: "MKColumnIcon",
|
|
231
231
|
title: "图标",
|
|
232
232
|
component: defineAsyncComponent(
|
|
233
|
-
async () => import("./index-
|
|
233
|
+
async () => import("./index-WAZn782k.js")
|
|
234
234
|
)
|
|
235
235
|
});
|
|
236
236
|
}
|
|
@@ -256,14 +256,14 @@ class DataTableHeaderComponents extends Components {
|
|
|
256
256
|
name: "MKBatchOpt",
|
|
257
257
|
title: "批量操作",
|
|
258
258
|
component: defineAsyncComponent(
|
|
259
|
-
async () => import("./index-
|
|
259
|
+
async () => import("./index-D8AhTxEQ.js")
|
|
260
260
|
)
|
|
261
261
|
});
|
|
262
262
|
this.registerComponent({
|
|
263
263
|
name: "MKTableFilter",
|
|
264
264
|
title: "筛选",
|
|
265
265
|
component: defineAsyncComponent(
|
|
266
|
-
async () => import("./index-
|
|
266
|
+
async () => import("./index-DdH6OCKp.js")
|
|
267
267
|
)
|
|
268
268
|
});
|
|
269
269
|
}
|
|
@@ -341,7 +341,7 @@ class DataFormComponents extends Components {
|
|
|
341
341
|
name: "MKFormDetail",
|
|
342
342
|
title: "明细",
|
|
343
343
|
component: defineAsyncComponent(
|
|
344
|
-
() => import("./index-
|
|
344
|
+
() => import("./index-ZmRbK5N3.js")
|
|
345
345
|
)
|
|
346
346
|
});
|
|
347
347
|
this.registerComponent({
|
|
@@ -362,14 +362,14 @@ class DataFormComponents extends Components {
|
|
|
362
362
|
name: "MKDataTreeSelect",
|
|
363
363
|
title: "树选择器",
|
|
364
364
|
component: defineAsyncComponent(
|
|
365
|
-
() => import("./index-
|
|
365
|
+
() => import("./index-CGBy2JBa.js")
|
|
366
366
|
)
|
|
367
367
|
});
|
|
368
368
|
this.registerComponent({
|
|
369
369
|
name: "MKResourceSelectInput",
|
|
370
370
|
title: "资源选择输入框",
|
|
371
371
|
component: defineAsyncComponent(
|
|
372
|
-
() => import("./ResourceSelectInput-
|
|
372
|
+
() => import("./ResourceSelectInput-_DpkQhgI.js")
|
|
373
373
|
)
|
|
374
374
|
});
|
|
375
375
|
this.registerComponent({
|
|
@@ -405,7 +405,7 @@ class DataFilterComponents extends Components {
|
|
|
405
405
|
title: "下拉框",
|
|
406
406
|
defaultOperator: Operator.IN,
|
|
407
407
|
component: defineAsyncComponent(
|
|
408
|
-
() => import("./index-
|
|
408
|
+
() => import("./index-BL1Thi0L.js")
|
|
409
409
|
)
|
|
410
410
|
});
|
|
411
411
|
this.registerComponent({
|
|
@@ -413,7 +413,7 @@ class DataFilterComponents extends Components {
|
|
|
413
413
|
title: "树形下拉框",
|
|
414
414
|
defaultOperator: Operator.IN,
|
|
415
415
|
component: defineAsyncComponent(
|
|
416
|
-
() => import("./index-
|
|
416
|
+
() => import("./index-CGBy2JBa.js")
|
|
417
417
|
)
|
|
418
418
|
});
|
|
419
419
|
this.registerComponent({
|
|
@@ -846,7 +846,7 @@ class Router extends Disposable {
|
|
|
846
846
|
vueRouter.addRoute("mk-ms-layout", {
|
|
847
847
|
name: defaultPageRoute.name,
|
|
848
848
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
849
|
-
component: () => import("./normal-
|
|
849
|
+
component: () => import("./normal-CPxIocMG.js"),
|
|
850
850
|
meta
|
|
851
851
|
});
|
|
852
852
|
break;
|
|
@@ -854,7 +854,7 @@ class Router extends Disposable {
|
|
|
854
854
|
vueRouter.addRoute("mk-ms-layout", {
|
|
855
855
|
name: defaultPageRoute.name,
|
|
856
856
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
857
|
-
component: () => import("./dialog-
|
|
857
|
+
component: () => import("./dialog-DTdQYzsb.js"),
|
|
858
858
|
meta
|
|
859
859
|
});
|
|
860
860
|
break;
|
|
@@ -866,7 +866,7 @@ class Router extends Disposable {
|
|
|
866
866
|
vueRouter.addRoute("mk-ms-layout", {
|
|
867
867
|
name: defaultPageRoute.name,
|
|
868
868
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
869
|
-
component: () => import("./dialog-
|
|
869
|
+
component: () => import("./dialog-CrY554IQ.js"),
|
|
870
870
|
meta
|
|
871
871
|
});
|
|
872
872
|
break;
|
|
@@ -878,7 +878,7 @@ class Router extends Disposable {
|
|
|
878
878
|
vueRouter.addRoute("mk-ms-layout", {
|
|
879
879
|
name: defaultPageRoute.name,
|
|
880
880
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
881
|
-
component: () => import("./dialog-
|
|
881
|
+
component: () => import("./dialog-CXKCj4dG.js"),
|
|
882
882
|
meta
|
|
883
883
|
});
|
|
884
884
|
break;
|
|
@@ -886,7 +886,7 @@ class Router extends Disposable {
|
|
|
886
886
|
vueRouter.addRoute("mk-ms-layout", {
|
|
887
887
|
name: defaultPageRoute.name,
|
|
888
888
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
889
|
-
component: () => import("./normal-
|
|
889
|
+
component: () => import("./normal-GrSzV1bh.js"),
|
|
890
890
|
meta
|
|
891
891
|
});
|
|
892
892
|
}
|
|
@@ -896,7 +896,7 @@ class Router extends Disposable {
|
|
|
896
896
|
vueRouter.addRoute("mk-ms-layout", {
|
|
897
897
|
name: defaultPageRoute.name,
|
|
898
898
|
path: defaultPageRoute.route || `/dv/${name}`,
|
|
899
|
-
component: () => import("./table-
|
|
899
|
+
component: () => import("./table-D7IlWlB-.js"),
|
|
900
900
|
meta
|
|
901
901
|
});
|
|
902
902
|
break;
|
|
@@ -904,7 +904,7 @@ class Router extends Disposable {
|
|
|
904
904
|
vueRouter.addRoute("mk-ms-layout", {
|
|
905
905
|
name: defaultPageRoute.name,
|
|
906
906
|
path: defaultPageRoute.route || `/dv/${name}/edit/:id?`,
|
|
907
|
-
component: () => import("./edit-
|
|
907
|
+
component: () => import("./edit-CnW1vav_.js"),
|
|
908
908
|
meta
|
|
909
909
|
});
|
|
910
910
|
break;
|
|
@@ -1846,7 +1846,7 @@ class PageManager {
|
|
|
1846
1846
|
this.addNormalPage({
|
|
1847
1847
|
name: "mk-ms-layout",
|
|
1848
1848
|
path: "/",
|
|
1849
|
-
component: () => import("./index-
|
|
1849
|
+
component: () => import("./index-BMsQ9MZO.js")
|
|
1850
1850
|
});
|
|
1851
1851
|
this.addNormalPage({
|
|
1852
1852
|
name: "login",
|
|
@@ -1854,7 +1854,7 @@ class PageManager {
|
|
|
1854
1854
|
meta: {
|
|
1855
1855
|
isAuthorization: false
|
|
1856
1856
|
},
|
|
1857
|
-
component: () => import("./index-
|
|
1857
|
+
component: () => import("./index-Cys5Stbp.js")
|
|
1858
1858
|
});
|
|
1859
1859
|
this.addNormalPage({
|
|
1860
1860
|
name: "signup",
|
|
@@ -1862,7 +1862,7 @@ class PageManager {
|
|
|
1862
1862
|
meta: {
|
|
1863
1863
|
isAuthorization: false
|
|
1864
1864
|
},
|
|
1865
|
-
component: () => import("./index-
|
|
1865
|
+
component: () => import("./index-SdxgZQLS.js")
|
|
1866
1866
|
});
|
|
1867
1867
|
this.afterInitdEvent.emit();
|
|
1868
1868
|
this.msAppClientChangeEvent.on(({ msAppClient }) => {
|
|
@@ -1914,7 +1914,7 @@ class PageManager {
|
|
|
1914
1914
|
this.addExtendsPage({
|
|
1915
1915
|
name: "notFound",
|
|
1916
1916
|
path: "/:pathMatch(.*)*",
|
|
1917
|
-
component: () => import("./404-
|
|
1917
|
+
component: () => import("./404-D3_BuVvI.js")
|
|
1918
1918
|
});
|
|
1919
1919
|
}
|
|
1920
1920
|
userSession.register(
|
|
@@ -3168,7 +3168,7 @@ const abstractSelectProps = buildProps({
|
|
|
3168
3168
|
formatOptions: {
|
|
3169
3169
|
type: Function,
|
|
3170
3170
|
default: (item) => {
|
|
3171
|
-
const value = item.value ?? item.id ?? item.name;
|
|
3171
|
+
const value = item.value ?? item.id ?? item.code ?? item.name;
|
|
3172
3172
|
const label = item.label ?? item.desc ?? item.title ?? item.name;
|
|
3173
3173
|
return { value, label };
|
|
3174
3174
|
}
|
|
@@ -3176,6 +3176,10 @@ const abstractSelectProps = buildProps({
|
|
|
3176
3176
|
additional: {
|
|
3177
3177
|
type: Boolean,
|
|
3178
3178
|
default: true
|
|
3179
|
+
},
|
|
3180
|
+
queryMode: {
|
|
3181
|
+
type: String,
|
|
3182
|
+
default: "condition"
|
|
3179
3183
|
}
|
|
3180
3184
|
});
|
|
3181
3185
|
const abstractSelectEmits = {
|
|
@@ -3194,15 +3198,15 @@ const AbstractSelect = defineComponent({
|
|
|
3194
3198
|
}
|
|
3195
3199
|
});
|
|
3196
3200
|
const selections = computed(() => {
|
|
3197
|
-
|
|
3198
|
-
const _modelValue = unref(modelValue);
|
|
3201
|
+
var _a2, _b2;
|
|
3199
3202
|
if (props.objectValue) {
|
|
3200
|
-
return props.multiple ? (
|
|
3203
|
+
return props.multiple ? ((_a2 = modelValue.value) == null ? void 0 : _a2.map((item) => item[primaryKey.value])) ?? [] : ((_b2 = modelValue.value) == null ? void 0 : _b2[primaryKey.value]) ?? "";
|
|
3201
3204
|
}
|
|
3202
|
-
return
|
|
3205
|
+
return modelValue.value;
|
|
3203
3206
|
});
|
|
3204
3207
|
const innerSelections = ref(unref(modelValue));
|
|
3205
3208
|
const selectRecords = ref([]);
|
|
3209
|
+
const dataLoading = ref(true);
|
|
3206
3210
|
const primaryKey = computed(
|
|
3207
3211
|
() => {
|
|
3208
3212
|
var _a2;
|
|
@@ -3210,19 +3214,19 @@ const AbstractSelect = defineComponent({
|
|
|
3210
3214
|
}
|
|
3211
3215
|
);
|
|
3212
3216
|
const formatOptions = computed(() => {
|
|
3213
|
-
let
|
|
3217
|
+
let value;
|
|
3214
3218
|
if (props.labelFieldName) {
|
|
3215
|
-
|
|
3219
|
+
value = (item) => {
|
|
3216
3220
|
return {
|
|
3217
3221
|
value: item[unref(primaryKey)],
|
|
3218
3222
|
label: item[props.labelFieldName]
|
|
3219
3223
|
};
|
|
3220
3224
|
};
|
|
3221
3225
|
} else {
|
|
3222
|
-
|
|
3226
|
+
value = props.formatOptions;
|
|
3223
3227
|
}
|
|
3224
3228
|
const innerFormatOptions = (item) => {
|
|
3225
|
-
const options2 =
|
|
3229
|
+
const options2 = value(item);
|
|
3226
3230
|
options2.data = item;
|
|
3227
3231
|
if (Array.isArray(item.children)) {
|
|
3228
3232
|
options2.children = item.children.map(innerFormatOptions);
|
|
@@ -3233,16 +3237,15 @@ const AbstractSelect = defineComponent({
|
|
|
3233
3237
|
});
|
|
3234
3238
|
const options = computed(() => {
|
|
3235
3239
|
let options2 = [];
|
|
3236
|
-
const _formatOptions = unref(formatOptions);
|
|
3237
3240
|
if (props.dataTable) {
|
|
3238
|
-
options2 = props.dataTable.getList().map((item) =>
|
|
3241
|
+
options2 = props.dataTable.getList().map((item) => formatOptions.value.call(null, item));
|
|
3239
3242
|
} else if (Array.isArray(props.options)) {
|
|
3240
|
-
options2 = props.options.map((item) =>
|
|
3243
|
+
options2 = props.options.map((item) => formatOptions.value.call(null, item));
|
|
3241
3244
|
}
|
|
3242
3245
|
const optionValues = options2.map((options3) => options3.value);
|
|
3243
3246
|
let additionOptions = [];
|
|
3244
3247
|
if (props.additional) {
|
|
3245
|
-
additionOptions = unref(selectRecords).map(
|
|
3248
|
+
additionOptions = unref(selectRecords).map(formatOptions.value).filter(
|
|
3246
3249
|
(additionOption) => !optionValues.includes(additionOption.value)
|
|
3247
3250
|
);
|
|
3248
3251
|
}
|
|
@@ -3251,63 +3254,63 @@ const AbstractSelect = defineComponent({
|
|
|
3251
3254
|
watch(
|
|
3252
3255
|
modelValue,
|
|
3253
3256
|
async (modelValue2) => {
|
|
3254
|
-
let
|
|
3257
|
+
let values;
|
|
3255
3258
|
if (props.objectValue) {
|
|
3256
|
-
|
|
3259
|
+
values = props.multiple ? (modelValue2 == null ? void 0 : modelValue2.map((item) => item[unref(primaryKey)])) ?? [] : (modelValue2 == null ? void 0 : modelValue2[unref(primaryKey)]) ?? null;
|
|
3257
3260
|
} else {
|
|
3258
|
-
|
|
3261
|
+
values = modelValue2;
|
|
3259
3262
|
}
|
|
3260
|
-
if (!isEqual(
|
|
3261
|
-
innerSelections.value =
|
|
3263
|
+
if (!isEqual(values, unref(innerSelections))) {
|
|
3264
|
+
innerSelections.value = values;
|
|
3262
3265
|
}
|
|
3263
3266
|
},
|
|
3264
3267
|
{ immediate: true }
|
|
3265
3268
|
);
|
|
3266
3269
|
const getSelectDataOptions = async () => {
|
|
3267
|
-
const
|
|
3268
|
-
const
|
|
3269
|
-
const recordIds = Array.isArray(_selections) ? _selections : _selections ? [_selections] : [];
|
|
3270
|
+
const selections2 = unref(innerSelections);
|
|
3271
|
+
const recordIds = Array.isArray(innerSelections) ? selections2 : selections2 ? [selections2] : [];
|
|
3270
3272
|
if (props.dataTable) {
|
|
3271
3273
|
const dataTable = props.dataTable;
|
|
3272
3274
|
let existingRecords = unref(options).filter((option) => recordIds.includes(option.value)).map((item) => item.data);
|
|
3273
3275
|
if (existingRecords.length !== recordIds.length) {
|
|
3274
3276
|
const notExistingRecords = recordIds.filter(
|
|
3275
|
-
(id) => !existingRecords.find((item) => item[
|
|
3277
|
+
(id) => !existingRecords.find((item) => item[primaryKey.value] === id)
|
|
3276
3278
|
);
|
|
3277
|
-
const
|
|
3278
|
-
|
|
3279
|
-
|
|
3280
|
-
|
|
3281
|
-
|
|
3282
|
-
|
|
3283
|
-
|
|
3284
|
-
|
|
3285
|
-
|
|
3279
|
+
const loadParams = {};
|
|
3280
|
+
if (props.queryMode == "condition") {
|
|
3281
|
+
dataTable.useCondition((where) => {
|
|
3282
|
+
if (props.multiple) {
|
|
3283
|
+
where.clear().addCondition(unref(primaryKey), "in", `${notExistingRecords.join(",")}`);
|
|
3284
|
+
} else {
|
|
3285
|
+
where.clear().addCondition(unref(primaryKey), "=", notExistingRecords[0]);
|
|
3286
|
+
}
|
|
3287
|
+
});
|
|
3288
|
+
} else {
|
|
3289
|
+
loadParams[primaryKey.value] = props.multiple ? notExistingRecords : notExistingRecords[0];
|
|
3290
|
+
}
|
|
3291
|
+
const response = await dataTable.loadRequest(loadParams);
|
|
3286
3292
|
if (response.data.code === 200) {
|
|
3287
3293
|
existingRecords = [...existingRecords, ...response.data.data];
|
|
3288
3294
|
}
|
|
3289
3295
|
}
|
|
3290
|
-
return recordIds.map((id) => existingRecords.find((item) => item[
|
|
3296
|
+
return recordIds.map((id) => existingRecords.find((item) => item[primaryKey.value] === id)).filter(Boolean);
|
|
3291
3297
|
} else if (Array.isArray(props.options)) {
|
|
3292
|
-
|
|
3293
|
-
return _options.filter((option) => recordIds.includes(option.value)).map((item) => item.data);
|
|
3298
|
+
return unref(options).filter((option) => recordIds.includes(option.value)).map((item) => item.data);
|
|
3294
3299
|
}
|
|
3295
3300
|
return [];
|
|
3296
3301
|
};
|
|
3297
|
-
watch(
|
|
3298
|
-
|
|
3299
|
-
|
|
3300
|
-
|
|
3301
|
-
|
|
3302
|
-
|
|
3303
|
-
|
|
3304
|
-
|
|
3305
|
-
|
|
3306
|
-
}
|
|
3302
|
+
watch(innerSelections, async (selections2) => {
|
|
3303
|
+
dataLoading.value = true;
|
|
3304
|
+
selectRecords.value = await getSelectDataOptions();
|
|
3305
|
+
dataLoading.value = false;
|
|
3306
|
+
if (modelValue.value !== selections2) {
|
|
3307
|
+
if (props.objectValue) {
|
|
3308
|
+
modelValue.value = props.multiple ? [...selectRecords.value] : selectRecords.value[0] ?? null;
|
|
3309
|
+
} else {
|
|
3310
|
+
modelValue.value = selections2;
|
|
3307
3311
|
}
|
|
3308
|
-
}
|
|
3309
|
-
|
|
3310
|
-
);
|
|
3312
|
+
}
|
|
3313
|
+
}, { immediate: true });
|
|
3311
3314
|
const setSelections = (v) => {
|
|
3312
3315
|
innerSelections.value = v;
|
|
3313
3316
|
};
|
|
@@ -3316,7 +3319,8 @@ const AbstractSelect = defineComponent({
|
|
|
3316
3319
|
selections,
|
|
3317
3320
|
selectRecords,
|
|
3318
3321
|
setSelections,
|
|
3319
|
-
formatOptions
|
|
3322
|
+
formatOptions,
|
|
3323
|
+
dataLoading
|
|
3320
3324
|
};
|
|
3321
3325
|
},
|
|
3322
3326
|
render() {
|
|
@@ -3326,7 +3330,8 @@ const AbstractSelect = defineComponent({
|
|
|
3326
3330
|
selections: this.selections,
|
|
3327
3331
|
selectRecords: this.selectRecords,
|
|
3328
3332
|
setSelections: this.setSelections,
|
|
3329
|
-
formatOptions: this.formatOptions
|
|
3333
|
+
formatOptions: this.formatOptions,
|
|
3334
|
+
dataLoading: this.dataLoading
|
|
3330
3335
|
});
|
|
3331
3336
|
}
|
|
3332
3337
|
});
|
|
@@ -3527,10 +3532,8 @@ const DataTableSelect = /* @__PURE__ */ defineComponent({
|
|
|
3527
3532
|
if (props.disabled) {
|
|
3528
3533
|
return;
|
|
3529
3534
|
}
|
|
3530
|
-
const
|
|
3531
|
-
|
|
3532
|
-
const selections = props.multiple ? _selections ?? [] : _selections ? [_selections] : [];
|
|
3533
|
-
_dataTable.setSelection(selections);
|
|
3535
|
+
const selections = (_a2 = unref(abstractSelectInstance)) == null ? void 0 : _a2.selections;
|
|
3536
|
+
dataTable.value.setSelection(props.multiple ? selections ?? [] : selections ? [selections] : []);
|
|
3534
3537
|
const result = await Dialoger.dataTableSelectDialog(unref(dataTable));
|
|
3535
3538
|
if (result.isConfirm) {
|
|
3536
3539
|
(_b2 = unref(abstractSelectInstance)) == null ? void 0 : _b2.setSelections(props.multiple ? result.selections : result.selections[0]);
|
|
@@ -3539,7 +3542,7 @@ const DataTableSelect = /* @__PURE__ */ defineComponent({
|
|
|
3539
3542
|
return () => {
|
|
3540
3543
|
return createVNode("div", {
|
|
3541
3544
|
"class": "mk-data-table-select",
|
|
3542
|
-
"
|
|
3545
|
+
"onClick": handleMousedown
|
|
3543
3546
|
}, [createVNode(MKAbstractSelect, {
|
|
3544
3547
|
"modelValue": unref(modelValue),
|
|
3545
3548
|
"onUpdate:model-value": (v) => {
|
|
@@ -3551,21 +3554,23 @@ const DataTableSelect = /* @__PURE__ */ defineComponent({
|
|
|
3551
3554
|
"multiple": props.multiple,
|
|
3552
3555
|
"labelFieldName": props.labelFieldName,
|
|
3553
3556
|
"primaryFieldName": props.primaryFieldName,
|
|
3554
|
-
"formatOptions": props.formatOptions
|
|
3557
|
+
"formatOptions": props.formatOptions,
|
|
3558
|
+
"queryMode": props.queryMode
|
|
3555
3559
|
}, {
|
|
3556
3560
|
default: ({
|
|
3557
3561
|
selectRecords,
|
|
3558
|
-
formatOptions
|
|
3562
|
+
formatOptions,
|
|
3563
|
+
dataLoading
|
|
3559
3564
|
}) => {
|
|
3560
3565
|
const options = selectRecords.map(formatOptions);
|
|
3561
|
-
return createVNode(ElSelect, {
|
|
3566
|
+
return withDirectives(createVNode("div", null, [createVNode(ElSelect, {
|
|
3562
3567
|
"disabled": props.disabled,
|
|
3563
3568
|
"multiple": props.multiple,
|
|
3564
3569
|
"suffixIcon": Grid,
|
|
3565
3570
|
"popperClass": "mk-data-table-select__popper",
|
|
3566
3571
|
"clearable": true,
|
|
3567
3572
|
"modelValue": props.multiple ? options : options[0] ?? null
|
|
3568
|
-
}, null);
|
|
3573
|
+
}, null)]), [[resolveDirective("loading"), dataLoading]]);
|
|
3569
3574
|
}
|
|
3570
3575
|
})]);
|
|
3571
3576
|
};
|
|
@@ -3644,7 +3649,6 @@ const DataSelect = /* @__PURE__ */ defineComponent({
|
|
|
3644
3649
|
group.addCondition(fieldName, "like", `%${value}%`);
|
|
3645
3650
|
}
|
|
3646
3651
|
});
|
|
3647
|
-
props.dataTable.dataFilter;
|
|
3648
3652
|
await props.dataTable.load();
|
|
3649
3653
|
return;
|
|
3650
3654
|
}
|
|
@@ -3765,7 +3769,7 @@ const index$5 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.definePrope
|
|
|
3765
3769
|
default: MKCodeEditor
|
|
3766
3770
|
}, Symbol.toStringTag, { value: "Module" }));
|
|
3767
3771
|
const MKJsonEditor = withInstall(
|
|
3768
|
-
defineAsyncComponent(() => import("./Editor-
|
|
3772
|
+
defineAsyncComponent(() => import("./Editor-DMU6Iped.js"))
|
|
3769
3773
|
);
|
|
3770
3774
|
const index$4 = /* @__PURE__ */ Object.freeze(/* @__PURE__ */ Object.defineProperty({
|
|
3771
3775
|
__proto__: null,
|
|
@@ -6537,7 +6541,7 @@ const _sfc_main$P = /* @__PURE__ */ defineComponent({
|
|
|
6537
6541
|
createVNode(_component_el_page_header, {
|
|
6538
6542
|
class: "bg-[#fff] p-[10px]",
|
|
6539
6543
|
icon: null
|
|
6540
|
-
}, {
|
|
6544
|
+
}, createSlots({
|
|
6541
6545
|
title: withCtx(() => [
|
|
6542
6546
|
createElementVNode("div", _hoisted_2$t, [
|
|
6543
6547
|
renderSlot(_ctx.$slots, "back"),
|
|
@@ -6559,8 +6563,16 @@ const _sfc_main$P = /* @__PURE__ */ defineComponent({
|
|
|
6559
6563
|
extra: withCtx(() => [
|
|
6560
6564
|
renderSlot(_ctx.$slots, "extra")
|
|
6561
6565
|
]),
|
|
6562
|
-
_:
|
|
6563
|
-
}
|
|
6566
|
+
_: 2
|
|
6567
|
+
}, [
|
|
6568
|
+
_ctx.$slots["header-content"] ? {
|
|
6569
|
+
name: "default",
|
|
6570
|
+
fn: withCtx(() => [
|
|
6571
|
+
renderSlot(_ctx.$slots, "header-content")
|
|
6572
|
+
]),
|
|
6573
|
+
key: "0"
|
|
6574
|
+
} : void 0
|
|
6575
|
+
]), 1024)
|
|
6564
6576
|
]),
|
|
6565
6577
|
renderSlot(_ctx.$slots, "body", {}, () => [
|
|
6566
6578
|
createElementVNode("div", _hoisted_4$j, [
|
|
@@ -6851,9 +6863,9 @@ const useQueryParams = (dataTable) => {
|
|
|
6851
6863
|
const query2 = {};
|
|
6852
6864
|
if (pagination) {
|
|
6853
6865
|
Object.assign(query2, {
|
|
6854
|
-
...route.query
|
|
6855
|
-
currentPage: pagination.currentPage,
|
|
6856
|
-
pageSize: pagination.pageSize
|
|
6866
|
+
...route.query
|
|
6867
|
+
// currentPage: pagination.currentPage,
|
|
6868
|
+
// pageSize: pagination.pageSize,
|
|
6857
6869
|
});
|
|
6858
6870
|
}
|
|
6859
6871
|
const hasParams = Reflect.ownKeys(params).filter(
|
|
@@ -7442,7 +7454,6 @@ const _sfc_main$N = /* @__PURE__ */ defineComponent({
|
|
|
7442
7454
|
props: dataTableProps,
|
|
7443
7455
|
setup(__props) {
|
|
7444
7456
|
const props = __props;
|
|
7445
|
-
useRouter();
|
|
7446
7457
|
const dataTableEl = ref(null);
|
|
7447
7458
|
const dataTable = computed(() => {
|
|
7448
7459
|
if (props.dataTable instanceof DataTable$1) {
|
|
@@ -7532,7 +7543,7 @@ const _sfc_main$N = /* @__PURE__ */ defineComponent({
|
|
|
7532
7543
|
};
|
|
7533
7544
|
}
|
|
7534
7545
|
});
|
|
7535
|
-
const DataTable = /* @__PURE__ */ _export_sfc(_sfc_main$N, [["__scopeId", "data-v-
|
|
7546
|
+
const DataTable = /* @__PURE__ */ _export_sfc(_sfc_main$N, [["__scopeId", "data-v-5865c4ac"]]);
|
|
7536
7547
|
const tableTreeProps = buildProps({
|
|
7537
7548
|
dataTree: {
|
|
7538
7549
|
type: DataTree
|
|
@@ -8859,13 +8870,14 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
|
|
|
8859
8870
|
}
|
|
8860
8871
|
});
|
|
8861
8872
|
let panel = createVNode(ElTabs, {
|
|
8862
|
-
"
|
|
8873
|
+
"class": "h-full",
|
|
8863
8874
|
"modelValue": activeTabName.value,
|
|
8864
8875
|
"onUpdate:modelValue": ($event) => activeTabName.value = $event
|
|
8865
8876
|
}, {
|
|
8866
8877
|
default: () => [createVNode(ElTabPane, {
|
|
8867
8878
|
"label": "本地选择",
|
|
8868
|
-
"name": "l"
|
|
8879
|
+
"name": "l",
|
|
8880
|
+
"class": "h-full overflow-y-auto"
|
|
8869
8881
|
}, {
|
|
8870
8882
|
default: () => [createVNode(ElButton, {
|
|
8871
8883
|
"icon": UploadFilled,
|
|
@@ -8877,12 +8889,13 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
|
|
|
8877
8889
|
}), ImageView]
|
|
8878
8890
|
}), createVNode(ElTabPane, {
|
|
8879
8891
|
"label": "素材库选择",
|
|
8880
|
-
"name": "m"
|
|
8892
|
+
"name": "m",
|
|
8893
|
+
"class": "h-full"
|
|
8881
8894
|
}, {
|
|
8882
8895
|
default: () => [unref(materialPanelVisible) ? createVNode(MKAsyncComponentView, null, {
|
|
8883
8896
|
default: () => [createVNode(MKMaterialList, {
|
|
8884
8897
|
"style": {
|
|
8885
|
-
height: "
|
|
8898
|
+
height: "100%"
|
|
8886
8899
|
},
|
|
8887
8900
|
"selectable": true,
|
|
8888
8901
|
"onSelect": handleMaterialSelect,
|
|
@@ -8891,7 +8904,8 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
|
|
|
8891
8904
|
}) : null]
|
|
8892
8905
|
}), createVNode(ElTabPane, {
|
|
8893
8906
|
"label": "网络图片",
|
|
8894
|
-
"name": "n"
|
|
8907
|
+
"name": "n",
|
|
8908
|
+
"class": "h-full overflow-y-auto"
|
|
8895
8909
|
}, {
|
|
8896
8910
|
default: () => [createVNode(ElInput, {
|
|
8897
8911
|
"modelValue": attrs.src,
|
|
@@ -8904,7 +8918,8 @@ const ImageEditPanelComponent = /* @__PURE__ */ defineComponent({
|
|
|
8904
8918
|
});
|
|
8905
8919
|
if (selectState.value == "attrs") {
|
|
8906
8920
|
panel = createVNode(ElRow, {
|
|
8907
|
-
"gutter": 20
|
|
8921
|
+
"gutter": 20,
|
|
8922
|
+
"class": "h-full overflow-y-auto"
|
|
8908
8923
|
}, {
|
|
8909
8924
|
default: () => [createVNode(ElCol, {
|
|
8910
8925
|
"span": 14
|
|
@@ -12013,7 +12028,7 @@ const markdownEditorProps = buildProps({
|
|
|
12013
12028
|
const markdownEditorEmits = {
|
|
12014
12029
|
"update:model-value": (modelValue) => true
|
|
12015
12030
|
};
|
|
12016
|
-
const _MarkdownEditor = defineAsyncComponent(() => import("./Editor-
|
|
12031
|
+
const _MarkdownEditor = defineAsyncComponent(() => import("./Editor-Bhig_S4J.js"));
|
|
12017
12032
|
const MKMarkdownEditor = withInstall(_MarkdownEditor);
|
|
12018
12033
|
const _hoisted_1$s = { class: "mk-rich-text-toolbar" };
|
|
12019
12034
|
const _hoisted_2$n = { class: "mk-rich-text-editor__stage_warp" };
|
|
@@ -12109,28 +12124,32 @@ const Dialogs = /* @__PURE__ */ defineComponent({
|
|
|
12109
12124
|
};
|
|
12110
12125
|
return () => {
|
|
12111
12126
|
const dialogs = unref(dialogInstances).map((dialogInstance) => {
|
|
12112
|
-
|
|
12113
|
-
|
|
12114
|
-
|
|
12115
|
-
|
|
12116
|
-
|
|
12117
|
-
|
|
12118
|
-
|
|
12119
|
-
|
|
12120
|
-
|
|
12121
|
-
|
|
12122
|
-
footer: () => {
|
|
12123
|
-
var _a3;
|
|
12124
|
-
return isFunction(dialogInstance.footer) ? (_a3 = dialogInstance.footer) == null ? void 0 : _a3.call(dialogInstance) : createVNode(Fragment, null, [createVNode(ElButton, {
|
|
12125
|
-
"onClick": () => handleCancel(dialogInstance)
|
|
12126
|
-
}, {
|
|
12127
|
-
default: () => [dialogInstance.cancelButtonText ?? "取消"]
|
|
12128
|
-
}), createVNode(ElButton, {
|
|
12129
|
-
"type": "primary",
|
|
12130
|
-
"onClick": () => handleConfirm(dialogInstance)
|
|
12127
|
+
return createVNode(MKConfigProvider, null, {
|
|
12128
|
+
default: () => {
|
|
12129
|
+
var _a2;
|
|
12130
|
+
return [createVNode(ElDialog, {
|
|
12131
|
+
"class": dialogInstance.class,
|
|
12132
|
+
"width": dialogInstance.width,
|
|
12133
|
+
"modelValue": dialogInstance.visible,
|
|
12134
|
+
"onUpdate:model-value": (visible) => dialogInstance.visible = visible,
|
|
12135
|
+
"onClose": () => handleClose(dialogInstance),
|
|
12136
|
+
"title": isFunction(dialogInstance.header) ? (_a2 = dialogInstance.header) == null ? void 0 : _a2.call(dialogInstance) : dialogInstance.title || ""
|
|
12131
12137
|
}, {
|
|
12132
|
-
default: () =>
|
|
12133
|
-
|
|
12138
|
+
default: () => dialogInstance.body(),
|
|
12139
|
+
footer: () => {
|
|
12140
|
+
var _a3;
|
|
12141
|
+
return isFunction(dialogInstance.footer) ? (_a3 = dialogInstance.footer) == null ? void 0 : _a3.call(dialogInstance) : createVNode(Fragment, null, [createVNode(ElButton, {
|
|
12142
|
+
"onClick": () => handleCancel(dialogInstance)
|
|
12143
|
+
}, {
|
|
12144
|
+
default: () => [dialogInstance.cancelButtonText ?? "取消"]
|
|
12145
|
+
}), createVNode(ElButton, {
|
|
12146
|
+
"type": "primary",
|
|
12147
|
+
"onClick": () => handleConfirm(dialogInstance)
|
|
12148
|
+
}, {
|
|
12149
|
+
default: () => [dialogInstance.confirmButtonText ?? "确认"]
|
|
12150
|
+
})]);
|
|
12151
|
+
}
|
|
12152
|
+
})];
|
|
12134
12153
|
}
|
|
12135
12154
|
});
|
|
12136
12155
|
});
|
|
@@ -15384,13 +15403,15 @@ const _MsMenuTree = class _MsMenuTree extends (_F = DataTree, _E = DATA_MODEL_NA
|
|
|
15384
15403
|
}) => {
|
|
15385
15404
|
const allowBindRoute = row.data.type === MenuType.Menu && row.data.urlType == MenuUrlType.Inner;
|
|
15386
15405
|
const loading = ref(false);
|
|
15387
|
-
return allowBindRoute ? createVNode("div",
|
|
15406
|
+
return allowBindRoute ? createVNode("div", {
|
|
15407
|
+
"class": "flex items-center"
|
|
15408
|
+
}, [row.data.routeTitle, row.data.targetUrl ? createVNode(MKText, {
|
|
15388
15409
|
"copy": true
|
|
15389
15410
|
}, {
|
|
15390
15411
|
default: () => [createVNode("span", {
|
|
15391
15412
|
"class": "color-[#4090ee] font-[14px] mx-1"
|
|
15392
15413
|
}, [row.data.targetUrl])]
|
|
15393
|
-
}), createVNode(ElPopover, {
|
|
15414
|
+
}) : null, createVNode(ElPopover, {
|
|
15394
15415
|
"placement": "right",
|
|
15395
15416
|
"width": "400",
|
|
15396
15417
|
"trigger": "click"
|
|
@@ -16965,11 +16986,7 @@ class DepartmentTable extends DataTable$1 {
|
|
|
16965
16986
|
}
|
|
16966
16987
|
class DepartmentTree extends DataTree {
|
|
16967
16988
|
constructor(options = {}) {
|
|
16968
|
-
super({
|
|
16969
|
-
name: "ms-dept",
|
|
16970
|
-
...options,
|
|
16971
|
-
props: { label: "name", ...options.props }
|
|
16972
|
-
});
|
|
16989
|
+
super({ name: "ms-dept", ...options, props: { label: "name", ...options.props } });
|
|
16973
16990
|
}
|
|
16974
16991
|
async loadRequest(params) {
|
|
16975
16992
|
const response = await super.loadRequest(params);
|
|
@@ -17697,41 +17714,41 @@ class MSAppClient {
|
|
|
17697
17714
|
this.pageManager.addExtendsPage({
|
|
17698
17715
|
name: "dv/ms-material/list",
|
|
17699
17716
|
path: "/sys/materials",
|
|
17700
|
-
component: () => import("./index-
|
|
17717
|
+
component: () => import("./index-Bm_WLjtq.js"),
|
|
17701
17718
|
meta: { name: "ms-material" }
|
|
17702
17719
|
});
|
|
17703
17720
|
this.pageManager.addExtendsPage({
|
|
17704
17721
|
name: "dv/ms-role/single/list/dialog",
|
|
17705
17722
|
path: "/sys/roles",
|
|
17706
|
-
component: () => import("./index-
|
|
17723
|
+
component: () => import("./index-CaT1yBkN.js"),
|
|
17707
17724
|
meta: { name: "ms-role" }
|
|
17708
17725
|
});
|
|
17709
17726
|
this.pageManager.addExtendsPage({
|
|
17710
17727
|
name: "dv/ms-role/permission",
|
|
17711
17728
|
path: "/sys/roles/:id/permission",
|
|
17712
|
-
component: () => import("./PermissionManage-
|
|
17729
|
+
component: () => import("./PermissionManage-D8GnoFjV.js")
|
|
17713
17730
|
});
|
|
17714
17731
|
this.pageManager.addExtendsPage({
|
|
17715
17732
|
name: "dv/local-log/single/tree/dialog",
|
|
17716
17733
|
path: "/log/local",
|
|
17717
|
-
component: () => import("./index-
|
|
17734
|
+
component: () => import("./index-BR74s8xj.js"),
|
|
17718
17735
|
meta: { name: "local-log" }
|
|
17719
17736
|
});
|
|
17720
17737
|
this.pageManager.addExtendsPage({
|
|
17721
17738
|
name: "dv/ms-menu/list",
|
|
17722
17739
|
path: "/sys/menus",
|
|
17723
|
-
component: () => import("./index-
|
|
17740
|
+
component: () => import("./index-BO9igopw.js"),
|
|
17724
17741
|
meta: { name: "ms-menu" }
|
|
17725
17742
|
});
|
|
17726
17743
|
this.pageManager.addExtendsPage({
|
|
17727
17744
|
name: "icons/list",
|
|
17728
17745
|
path: "/sys/icons",
|
|
17729
|
-
component: () => import("./index-
|
|
17746
|
+
component: () => import("./index-D5tBMykg.js")
|
|
17730
17747
|
});
|
|
17731
17748
|
this.pageManager.addExtendsPage({
|
|
17732
17749
|
name: "dv/ms-todo/single/list/dialog",
|
|
17733
17750
|
path: "/dv/todo",
|
|
17734
|
-
component: () => import("./index-
|
|
17751
|
+
component: () => import("./index-DBYf3N_H.js")
|
|
17735
17752
|
});
|
|
17736
17753
|
for (let internalModule of internalModules) {
|
|
17737
17754
|
for (let item of internalModule.normalPages) {
|
|
@@ -17923,6 +17940,7 @@ class DialogerImpl extends SkeletonDialoger {
|
|
|
17923
17940
|
const dialogInstance = this.customRender({
|
|
17924
17941
|
class: "mk-data-table-select-dialog",
|
|
17925
17942
|
width: "80%",
|
|
17943
|
+
title: dataTable.title ?? "选择",
|
|
17926
17944
|
body: () => {
|
|
17927
17945
|
return createVNode("div", {
|
|
17928
17946
|
"class": "mk-data-table-select-dialog__main"
|
|
@@ -21178,11 +21196,13 @@ const _hoisted_3 = { class: "main-container" };
|
|
|
21178
21196
|
const _hoisted_4 = { class: "main" };
|
|
21179
21197
|
const _hoisted_5 = { class: "main-content" };
|
|
21180
21198
|
const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
21181
|
-
...{
|
|
21182
|
-
name: "Layout"
|
|
21183
|
-
},
|
|
21199
|
+
...{ name: "Layout" },
|
|
21184
21200
|
__name: "index",
|
|
21185
21201
|
setup(__props) {
|
|
21202
|
+
const pageErrorInfo = ref("");
|
|
21203
|
+
onErrorCaptured((err, instance, info) => {
|
|
21204
|
+
pageErrorInfo.value = info == "setup function" ? err.message : "";
|
|
21205
|
+
});
|
|
21186
21206
|
const routeInfo = useRoute();
|
|
21187
21207
|
const settingsStore = useSettingsStore();
|
|
21188
21208
|
const keepAliveStore = useKeepAliveStore();
|
|
@@ -21205,6 +21225,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
21205
21225
|
watch(
|
|
21206
21226
|
() => routeInfo.path,
|
|
21207
21227
|
() => {
|
|
21228
|
+
pageErrorInfo.value = "";
|
|
21208
21229
|
if (settingsStore.mode === "mobile") {
|
|
21209
21230
|
settingsStore.$patch((state) => {
|
|
21210
21231
|
state.settings.menu.subMenuCollapse = true;
|
|
@@ -21253,8 +21274,8 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
21253
21274
|
return `${actualWidth}px`;
|
|
21254
21275
|
});
|
|
21255
21276
|
return (_ctx, _cache) => {
|
|
21277
|
+
const _component_el_result = resolveComponent("el-result");
|
|
21256
21278
|
const _component_RouterView = resolveComponent("RouterView");
|
|
21257
|
-
resolveComponent("MKSvgIcon");
|
|
21258
21279
|
return openBlock(), createBlock(unref(SystemProvider), null, {
|
|
21259
21280
|
default: withCtx(() => [
|
|
21260
21281
|
createElementVNode("div", {
|
|
@@ -21292,7 +21313,12 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
21292
21313
|
(openBlock(), createBlock(KeepAlive, {
|
|
21293
21314
|
include: unref(keepAliveStore).list
|
|
21294
21315
|
}, [
|
|
21295
|
-
|
|
21316
|
+
unref(pageErrorInfo) ? (openBlock(), createBlock(_component_el_result, {
|
|
21317
|
+
key: 0,
|
|
21318
|
+
icon: "error",
|
|
21319
|
+
title: "系统提示",
|
|
21320
|
+
"sub-title": unref(pageErrorInfo)
|
|
21321
|
+
}, null, 8, ["sub-title"])) : !unref(isLink) ? (openBlock(), createBlock(unref(MKAsyncComponentView), {
|
|
21296
21322
|
component: Component,
|
|
21297
21323
|
key: route.fullPath
|
|
21298
21324
|
}, null, 8, ["component"])) : createCommentVNode("", true)
|
|
@@ -21321,7 +21347,7 @@ const _sfc_main = /* @__PURE__ */ defineComponent({
|
|
|
21321
21347
|
};
|
|
21322
21348
|
}
|
|
21323
21349
|
});
|
|
21324
|
-
const Layout$1 = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-
|
|
21350
|
+
const Layout$1 = /* @__PURE__ */ _export_sfc(_sfc_main, [["__scopeId", "data-v-7f84212b"]]);
|
|
21325
21351
|
const Layout = /* @__PURE__ */ defineComponent({
|
|
21326
21352
|
name: "MKLayout",
|
|
21327
21353
|
setup() {
|
|
@@ -21772,4 +21798,4 @@ export {
|
|
|
21772
21798
|
MsRouteTable as y,
|
|
21773
21799
|
useSingleView as z
|
|
21774
21800
|
};
|
|
21775
|
-
//# sourceMappingURL=index-
|
|
21801
|
+
//# sourceMappingURL=index-B5WnSJ0l.js.map
|