@ditari/bsui 5.1.20 → 5.1.23

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 (91) hide show
  1. package/dist/cjs/components/action-bar/ActionBar.vue.d.ts +2 -1
  2. package/dist/cjs/components/action-bar/ActionBar.vue2.cjs +1 -1
  3. package/dist/cjs/components/action-bar/ActionBar.vue2.cjs.map +1 -1
  4. package/dist/cjs/components/card/Card.cjs +9 -3
  5. package/dist/cjs/components/card/Card.cjs.map +1 -1
  6. package/dist/cjs/components/card/style.cjs +10 -3
  7. package/dist/cjs/components/card/style.cjs.map +1 -1
  8. package/dist/cjs/components/card/style.d.ts +1 -0
  9. package/dist/cjs/components/desensitize/Desensitize.cjs +99 -0
  10. package/dist/cjs/components/desensitize/Desensitize.cjs.map +1 -0
  11. package/dist/cjs/components/desensitize/Desensitize.d.ts +60 -0
  12. package/dist/cjs/components/desensitize/index.cjs +15 -0
  13. package/dist/cjs/components/desensitize/index.cjs.map +1 -0
  14. package/dist/cjs/components/desensitize/index.d.ts +4 -0
  15. package/dist/cjs/components/desensitize/style.cjs +22 -0
  16. package/dist/cjs/components/desensitize/style.cjs.map +1 -0
  17. package/dist/cjs/components/desensitize/style.d.ts +6 -0
  18. package/dist/cjs/components/dic/DicReplace.cjs +2 -1
  19. package/dist/cjs/components/dic/DicReplace.cjs.map +1 -1
  20. package/dist/cjs/components/layout/AppContext.cjs.map +1 -1
  21. package/dist/cjs/components/layout/AppLayout.cjs.map +1 -1
  22. package/dist/cjs/components/layout/List.cjs.map +1 -1
  23. package/dist/cjs/components/layout/Show.cjs.map +1 -1
  24. package/dist/cjs/components/layout/components/layout/RouterContentName.vue2.cjs.map +1 -1
  25. package/dist/cjs/components/layout/components/mobile/MobileList.cjs.map +1 -1
  26. package/dist/cjs/components/layout/style.cjs.map +1 -1
  27. package/dist/cjs/components/select/Select.vue2.cjs.map +1 -1
  28. package/dist/cjs/components/table-form/TableForm.cjs.map +1 -1
  29. package/dist/cjs/components/table-form/TableFormItem.cjs.map +1 -1
  30. package/dist/cjs/components/table-form/index.cjs.map +1 -1
  31. package/dist/cjs/components/table-form/interface.cjs.map +1 -1
  32. package/dist/cjs/components/table-form/style.cjs +4 -2
  33. package/dist/cjs/components/table-form/style.cjs.map +1 -1
  34. package/dist/cjs/hooks/useDesign.cjs.map +1 -1
  35. package/dist/cjs/index.cjs +0 -1
  36. package/dist/cjs/index.cjs.map +1 -1
  37. package/dist/cjs/utils/withInstall.cjs.map +1 -1
  38. package/dist/esm/components/action-bar/ActionBar.vue.d.ts +2 -1
  39. package/dist/esm/components/action-bar/ActionBar.vue2.mjs +2 -2
  40. package/dist/esm/components/action-bar/ActionBar.vue2.mjs.map +1 -1
  41. package/dist/esm/components/card/Card.mjs +9 -3
  42. package/dist/esm/components/card/Card.mjs.map +1 -1
  43. package/dist/esm/components/card/style.d.ts +1 -0
  44. package/dist/esm/components/card/style.mjs +10 -3
  45. package/dist/esm/components/card/style.mjs.map +1 -1
  46. package/dist/esm/components/desensitize/Desensitize.d.ts +60 -0
  47. package/dist/esm/components/desensitize/Desensitize.mjs +97 -0
  48. package/dist/esm/components/desensitize/Desensitize.mjs.map +1 -0
  49. package/dist/esm/components/desensitize/index.d.ts +4 -0
  50. package/dist/esm/components/desensitize/index.mjs +10 -0
  51. package/dist/esm/components/desensitize/index.mjs.map +1 -0
  52. package/dist/esm/components/desensitize/style.d.ts +6 -0
  53. package/dist/esm/components/desensitize/style.mjs +20 -0
  54. package/dist/esm/components/desensitize/style.mjs.map +1 -0
  55. package/dist/esm/components/dic/DicReplace.mjs +2 -1
  56. package/dist/esm/components/dic/DicReplace.mjs.map +1 -1
  57. package/dist/esm/components/layout/AppContext.mjs.map +1 -1
  58. package/dist/esm/components/layout/AppLayout.mjs.map +1 -1
  59. package/dist/esm/components/layout/List.mjs.map +1 -1
  60. package/dist/esm/components/layout/Show.mjs.map +1 -1
  61. package/dist/esm/components/layout/components/layout/RouterContentName.vue2.mjs.map +1 -1
  62. package/dist/esm/components/layout/components/mobile/MobileList.mjs.map +1 -1
  63. package/dist/esm/components/layout/style.mjs.map +1 -1
  64. package/dist/esm/components/select/Select.vue2.mjs.map +1 -1
  65. package/dist/esm/components/table-form/TableForm.mjs.map +1 -1
  66. package/dist/esm/components/table-form/TableFormItem.mjs.map +1 -1
  67. package/dist/esm/components/table-form/index.mjs.map +1 -1
  68. package/dist/esm/components/table-form/interface.mjs.map +1 -1
  69. package/dist/esm/components/table-form/style.mjs +4 -2
  70. package/dist/esm/components/table-form/style.mjs.map +1 -1
  71. package/dist/esm/hooks/useDesign.mjs.map +1 -1
  72. package/dist/esm/index.mjs +0 -1
  73. package/dist/esm/index.mjs.map +1 -1
  74. package/dist/esm/utils/withInstall.mjs.map +1 -1
  75. package/dist/types/components/action-bar/ActionBar.vue.d.ts +2 -1
  76. package/dist/types/components/action-bar/ActionBar.vue.d.ts.map +1 -1
  77. package/dist/types/components/card/Card.d.ts.map +1 -1
  78. package/dist/types/components/card/style.d.ts +1 -0
  79. package/dist/types/components/card/style.d.ts.map +1 -1
  80. package/dist/types/components/desensitize/Desensitize.d.ts +60 -0
  81. package/dist/types/components/desensitize/Desensitize.d.ts.map +1 -0
  82. package/dist/types/components/desensitize/index.d.ts +4 -0
  83. package/dist/types/components/desensitize/index.d.ts.map +1 -0
  84. package/dist/types/components/desensitize/style.d.ts +6 -0
  85. package/dist/types/components/desensitize/style.d.ts.map +1 -0
  86. package/dist/types/components/dic/DicReplace.d.ts.map +1 -1
  87. package/dist/types/components/layout/components/layout/RouterContentName.vue.d.ts.map +1 -1
  88. package/dist/types/components/table-form/style.d.ts.map +1 -1
  89. package/dist/types/index.d.ts.map +1 -1
  90. package/package.json +3 -3
  91. package/src/index.ts +0 -1
@@ -1,4 +1,4 @@
1
- import { type VNode } from "vue";
1
+ import { isVNode, type VNode } from "vue";
2
2
  interface ButtonItem {
3
3
  title: string | VNode;
4
4
  status?: boolean | ((record: {
@@ -29,6 +29,7 @@ declare const _default: import("vue").DefineComponent<import("vue").ExtractPropT
29
29
  isShow: (item: ButtonItem) => boolean;
30
30
  visibleButtons: import("vue").ComputedRef<ButtonItem[]>;
31
31
  showDivider: (item: ButtonItem) => boolean;
32
+ isVNode: typeof isVNode;
32
33
  }, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
33
34
  buttonGroups: {
34
35
  type: ArrayConstructor;
@@ -75,7 +75,7 @@ var _sfc_main = /* @__PURE__ */ vue.defineComponent(__spreadProps(__spreadValues
75
75
  return (_a = item.onClick || item.onEvent) == null ? void 0 : _a(__props.record);
76
76
  }, ["stop"])
77
77
  }, [
78
- item.title instanceof Object ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.title), {
78
+ vue.isVNode(item.title) ? (vue.openBlock(), vue.createBlock(vue.resolveDynamicComponent(item.title), {
79
79
  key: 0,
80
80
  record: __props.record
81
81
  }, null, 8, ["record"])) : (vue.openBlock(), vue.createElementBlock(
@@ -1 +1 @@
1
- {"version":3,"file":"ActionBar.vue2.cjs","sources":["../../../../src/components/action-bar/ActionBar.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\n import { computed, type VNode } from \"vue\";\r\n\r\n defineOptions({\r\n name: \"DActionBar\"\r\n });\r\n\r\n interface ButtonItem {\r\n title: string | VNode;\r\n status?: boolean | ((record: { [key: string]: unknown }) => boolean);\r\n onClick?: (record: { [key: string]: unknown }) => void;\r\n onEvent?: (record: { [key: string]: unknown }) => void; // 别名,为了向后兼容\r\n }\r\n\r\n // 2. 普通的 Props 声明\r\n const props = defineProps({\n buttonGroups: { type: Array, required: false },\n actions: { type: Array, required: false },\n record: { type: Object, required: true }\n});\r\n\r\n /**\r\n * 判断按钮是否显示\r\n */\r\n const isShow = (item: ButtonItem): boolean => {\r\n if (typeof item.status === \"function\") {\r\n return item.status(props.record);\r\n }\r\n return item.status ?? true;\r\n };\r\n\r\n /**\r\n * 过滤出当前真正显示的按钮列表\r\n */\r\n const visibleButtons = computed(() => {\r\n const groups: ButtonItem[] = props.actions || props.buttonGroups || [];\r\n return groups.filter((item: ButtonItem) => isShow(item));\r\n });\r\n\r\n /**\r\n * 判断分隔线状态\r\n */\r\n const showDivider = (item: ButtonItem): boolean => {\r\n if (!isShow(item)) {\r\n return false;\r\n }\r\n\r\n // 逻辑保持不变:在可见列表里找自己\r\n const visibleIndex = visibleButtons.value.findIndex((v: ButtonItem) => v.title === item.title);\r\n return visibleIndex !== -1 && visibleIndex < visibleButtons.value.length - 1;\r\n };\r\n</script>\r\n\r\n<template>\r\n <div @click.stop>\r\n <template v-for=\"(item, index) in actions || buttonGroups || []\" :key=\"index\">\r\n <a v-if=\"isShow(item)\" @click.stop=\"(item.onClick || item.onEvent)?.(record)\">\r\n <template v-if=\"item.title instanceof Object\">\r\n <component :is=\"item.title\" :record=\"record\" />\r\n </template>\r\n <template v-else>\r\n {{ item.title }}\r\n </template>\r\n </a>\r\n <a-divider\r\n v-if=\"showDivider(item)\"\r\n type=\"vertical\"\r\n style=\"border-color: #3e7fff; border-width: 2px\"\r\n />\r\n </template>\r\n </div>\r\n</template>\r\n"],"names":["computed","_createElementBlock","_openBlock","_Fragment","_withModifiers","_createBlock","_resolveDynamicComponent","_createTextVNode","_toDisplayString"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeE,IAAA,MAAM,KAAA,GAAQ,OAAA;AASd,IAAA,MAAM,MAAA,GAAS,CAAC,IAAA,KAA8B;;AAC5C,MAAA,IAAI,OAAO,IAAA,CAAK,MAAA,KAAW,UAAA,EAAY;AACrC,QAAA,OAAO,IAAA,CAAK,MAAA,CAAO,KAAA,CAAM,MAAM,CAAA;AAAA,MACjC;AACA,MAAA,OAAA,CAAO,EAAA,GAAA,IAAA,CAAK,WAAL,IAAA,GAAA,EAAA,GAAe,IAAA;AAAA,IACxB,CAAA;AAKA,IAAA,MAAM,cAAA,GAAiBA,aAAS,MAAM;AACpC,MAAA,MAAM,MAAA,GAAuB,KAAA,CAAM,OAAA,IAAW,KAAA,CAAM,gBAAgB,EAAC;AACrE,MAAA,OAAO,OAAO,MAAA,CAAO,CAAC,IAAA,KAAqB,MAAA,CAAO,IAAI,CAAC,CAAA;AAAA,IACzD,CAAC,CAAA;AAKD,IAAA,MAAM,WAAA,GAAc,CAAC,IAAA,KAA8B;AACjD,MAAA,IAAI,CAAC,MAAA,CAAO,IAAI,CAAA,EAAG;AACjB,QAAA,OAAO,KAAA;AAAA,MACT;AAGA,MAAA,MAAM,YAAA,GAAe,eAAe,KAAA,CAAM,SAAA,CAAU,CAAC,CAAA,KAAkB,CAAA,CAAE,KAAA,KAAU,IAAA,CAAK,KAAK,CAAA;AAC7F,MAAA,OAAO,YAAA,KAAiB,CAAA,CAAA,IAAM,YAAA,GAAe,cAAA,CAAe,MAAM,MAAA,GAAS,CAAA;AAAA,IAC7E,CAAA;;;8BAIAC,sBAAA,CAgBM,KAAA,EAAA;AAAA,QAhBA,OAAA,8CAAD,MAAA;AAAA,QAAA,CAAA,EAAW,CAAA,MAAA,CAAA,CAAA;AAAA;SACdC,aAAA,CAAA,IAAA,CAAA,EAAAD,sBAAA;AAAA,UAcWE,YAAA;AAAA;yBAduB,QAAA,OAAA,IAAW,OAAA,iBAAY,EAAA,EAAA,CAAvC,IAAA,EAAM,KAAA,KAAK;;;qBAA0C,KAAA,EAAK;AAAA,cAAA;AAAA,gBACjE,OAAO,IAAI,CAAA,qBAApBF,uBAOI,GAAA,EAAA;AAAA;kBAPoB,OAAA,EAAKG,iBAAA,CAAA,CAAA,MAAA,KAAA;;AAAQ,oBAAA,OAAA,CAAA,EAAA,GAAA,IAAA,CAAK,OAAA,IAAW,IAAA,CAAK,OAAA,KAArB,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAgC,OAAA,CAAA,MAAA,CAAA;AAAA,kBAAA,CAAA,EAAM,CAAA,MAAA,CAAA;AAAA;kBACzD,IAAA,CAAK,iBAAiB,MAAA,qBACpCC,eAAA,CAA+CC,2BAAA,CAA/B,IAAA,CAAK,KAAK,CAAA,EAAA;AAAA;oBAAG,QAAQ,OAAA,CAAA;AAAA,+DAEvCL,sBAAA;AAAA,oBAEWE,YAAA;AAAA,oBAAA,EAAA,KAAA,CAAA,EAAA;AAAA,oBAAA;AAAA,sBADNI,mBAAA;AAAA,wBAAAC,mBAAA,CAAA,KAAK,KAAK,CAAA;AAAA,wBAAA;AAAA;AAAA;AAAA;;;;;gBAIT,YAAY,IAAI,CAAA,qBADxBH,gBAIE,oBAAA,EAAA;AAAA;kBAFA,IAAA,EAAK,UAAA;AAAA,kBACL,KAAA,EAAA,EAAA,cAAA,EAAA,SAAA,EAAA,gBAAA,KAAA;AAAA;;;;;;;;;;;;;;;;"}
1
+ {"version":3,"file":"ActionBar.vue2.cjs","sources":["../../../../src/components/action-bar/ActionBar.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\n import { computed, isVNode, type VNode } from \"vue\";\r\n\r\n defineOptions({\r\n name: \"DActionBar\"\r\n });\r\n\r\n interface ButtonItem {\r\n title: string | VNode;\r\n status?: boolean | ((record: { [key: string]: unknown }) => boolean);\r\n onClick?: (record: { [key: string]: unknown }) => void;\r\n onEvent?: (record: { [key: string]: unknown }) => void; // 别名,为了向后兼容\r\n }\r\n\r\n // 2. 普通的 Props 声明\r\n const props = defineProps({\n buttonGroups: { type: Array, required: false },\n actions: { type: Array, required: false },\n record: { type: Object, required: true }\n});\r\n\r\n /**\r\n * 判断按钮是否显示\r\n */\r\n const isShow = (item: ButtonItem): boolean => {\r\n if (typeof item.status === \"function\") {\r\n return item.status(props.record);\r\n }\r\n return item.status ?? true;\r\n };\r\n\r\n /**\r\n * 过滤出当前真正显示的按钮列表\r\n */\r\n const visibleButtons = computed(() => {\r\n const groups: ButtonItem[] = props.actions || props.buttonGroups || [];\r\n return groups.filter((item: ButtonItem) => isShow(item));\r\n });\r\n\r\n /**\r\n * 判断分隔线状态\r\n */\r\n const showDivider = (item: ButtonItem): boolean => {\r\n if (!isShow(item)) {\r\n return false;\r\n }\r\n\r\n // 逻辑保持不变:在可见列表里找自己\r\n const visibleIndex = visibleButtons.value.findIndex((v: ButtonItem) => v.title === item.title);\r\n return visibleIndex !== -1 && visibleIndex < visibleButtons.value.length - 1;\r\n };\r\n</script>\r\n\r\n<template>\r\n <div @click.stop>\r\n <template v-for=\"(item, index) in actions || buttonGroups || []\" :key=\"index\">\r\n <a v-if=\"isShow(item)\" @click.stop=\"(item.onClick || item.onEvent)?.(record)\">\r\n <template v-if=\"isVNode(item.title)\">\r\n <component :is=\"item.title\" :record=\"record\" />\r\n </template>\r\n <template v-else>\r\n {{ item.title }}\r\n </template>\r\n </a>\r\n <a-divider\r\n v-if=\"showDivider(item)\"\r\n type=\"vertical\"\r\n style=\"border-color: #3e7fff; border-width: 2px\"\r\n />\r\n </template>\r\n </div>\r\n</template>\r\n"],"names":["computed","_createElementBlock","_openBlock","_Fragment","_withModifiers","isVNode","_createBlock","_resolveDynamicComponent","_createTextVNode","_toDisplayString"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAeE,IAAA,MAAM,KAAA,GAAQ,OAAA;AASd,IAAA,MAAM,MAAA,GAAS,CAAC,IAAA,KAA8B;;AAC5C,MAAA,IAAI,OAAO,IAAA,CAAK,MAAA,KAAW,UAAA,EAAY;AACrC,QAAA,OAAO,IAAA,CAAK,MAAA,CAAO,KAAA,CAAM,MAAM,CAAA;AAAA,MACjC;AACA,MAAA,OAAA,CAAO,EAAA,GAAA,IAAA,CAAK,WAAL,IAAA,GAAA,EAAA,GAAe,IAAA;AAAA,IACxB,CAAA;AAKA,IAAA,MAAM,cAAA,GAAiBA,aAAS,MAAM;AACpC,MAAA,MAAM,MAAA,GAAuB,KAAA,CAAM,OAAA,IAAW,KAAA,CAAM,gBAAgB,EAAC;AACrE,MAAA,OAAO,OAAO,MAAA,CAAO,CAAC,IAAA,KAAqB,MAAA,CAAO,IAAI,CAAC,CAAA;AAAA,IACzD,CAAC,CAAA;AAKD,IAAA,MAAM,WAAA,GAAc,CAAC,IAAA,KAA8B;AACjD,MAAA,IAAI,CAAC,MAAA,CAAO,IAAI,CAAA,EAAG;AACjB,QAAA,OAAO,KAAA;AAAA,MACT;AAGA,MAAA,MAAM,YAAA,GAAe,eAAe,KAAA,CAAM,SAAA,CAAU,CAAC,CAAA,KAAkB,CAAA,CAAE,KAAA,KAAU,IAAA,CAAK,KAAK,CAAA;AAC7F,MAAA,OAAO,YAAA,KAAiB,CAAA,CAAA,IAAM,YAAA,GAAe,cAAA,CAAe,MAAM,MAAA,GAAS,CAAA;AAAA,IAC7E,CAAA;;;8BAIAC,sBAAA,CAgBM,KAAA,EAAA;AAAA,QAhBA,OAAA,8CAAD,MAAA;AAAA,QAAA,CAAA,EAAW,CAAA,MAAA,CAAA,CAAA;AAAA;SACdC,aAAA,CAAA,IAAA,CAAA,EAAAD,sBAAA;AAAA,UAcWE,YAAA;AAAA;yBAduB,QAAA,OAAA,IAAW,OAAA,iBAAY,EAAA,EAAA,CAAvC,IAAA,EAAM,KAAA,KAAK;;;qBAA0C,KAAA,EAAK;AAAA,cAAA;AAAA,gBACjE,OAAO,IAAI,CAAA,qBAApBF,uBAOI,GAAA,EAAA;AAAA;kBAPoB,OAAA,EAAKG,iBAAA,CAAA,CAAA,MAAA,KAAA;;AAAQ,oBAAA,OAAA,CAAA,EAAA,GAAA,IAAA,CAAK,OAAA,IAAW,IAAA,CAAK,OAAA,KAArB,IAAA,GAAA,KAAA,CAAA,GAAA,EAAA,CAAgC,OAAA,CAAA,MAAA,CAAA;AAAA,kBAAA,CAAA,EAAM,CAAA,MAAA,CAAA;AAAA;kBACzDC,WAAA,CAAQ,IAAA,CAAK,KAAK,CAAA,qBAChCC,eAAA,CAA+CC,2BAAA,CAA/B,IAAA,CAAK,KAAK,CAAA,EAAA;AAAA;oBAAG,QAAQ,OAAA,CAAA;AAAA,+DAEvCN,sBAAA;AAAA,oBAEWE,YAAA;AAAA,oBAAA,EAAA,KAAA,CAAA,EAAA;AAAA,oBAAA;AAAA,sBADNK,mBAAA;AAAA,wBAAAC,mBAAA,CAAA,KAAK,KAAK,CAAA;AAAA,wBAAA;AAAA;AAAA;AAAA;;;;;gBAIT,YAAY,IAAI,CAAA,qBADxBH,gBAIE,oBAAA,EAAA;AAAA;kBAFA,IAAA,EAAK,UAAA;AAAA,kBACL,KAAA,EAAA,EAAA,cAAA,EAAA,SAAA,EAAA,gBAAA,KAAA;AAAA;;;;;;;;;;;;;;;;"}
@@ -1,10 +1,10 @@
1
1
  'use strict';
2
2
 
3
3
  var vue = require('vue');
4
+ var style = require('./style.cjs');
4
5
  var css = require('@emotion/css');
5
6
  var useDesign = require('../../hooks/useDesign.cjs');
6
7
  var withInstall = require('../../utils/withInstall.cjs');
7
- var style = require('./style.cjs');
8
8
 
9
9
  "use strict";
10
10
  const _Card = /* @__PURE__ */ vue.defineComponent({
@@ -22,7 +22,9 @@ const _Card = /* @__PURE__ */ vue.defineComponent({
22
22
  return () => {
23
23
  var _a;
24
24
  const rootCls = getPrefixCls();
25
+ const headerWrapperCls = getPrefixCls("head-wrapper");
25
26
  const headerCls = getPrefixCls("head");
27
+ const headerExctraCls = getPrefixCls("extra");
26
28
  const iconCls = getPrefixCls("icon");
27
29
  const titleCls = getPrefixCls("title");
28
30
  const actionCls = getPrefixCls("action");
@@ -30,12 +32,16 @@ const _Card = /* @__PURE__ */ vue.defineComponent({
30
32
  return vue.createVNode("div", {
31
33
  "class": css.cx(rootCls, styles.container)
32
34
  }, [vue.createVNode("div", {
33
- "class": css.cx(headerCls, styles.header)
35
+ "class": css.cx(headerWrapperCls, styles.header)
36
+ }, [vue.createVNode("div", {
37
+ "class": css.cx(headerCls, styles.headerLeft)
34
38
  }, [slots.icon && vue.createVNode("div", {
35
39
  "class": css.cx(iconCls, styles.icon)
36
40
  }, [slots.icon()]), vue.createVNode("div", {
37
41
  "class": css.cx(titleCls, styles.header_title)
38
- }, [props.title])]), slots.action && vue.createVNode("div", {
42
+ }, [props.title])]), slots.extra && vue.createVNode("div", {
43
+ "class": css.cx(headerExctraCls)
44
+ }, [slots.extra()])]), slots.action && vue.createVNode("div", {
39
45
  "class": css.cx(actionCls, styles.action)
40
46
  }, [slots.action()]), vue.createVNode("div", {
41
47
  "class": css.cx(bodyCls, styles.body)
@@ -1 +1 @@
1
- {"version":3,"file":"Card.cjs","sources":["../../../../src/components/card/Card.tsx"],"sourcesContent":["// components/card/index.tsx\nimport { defineComponent } from \"vue\";\n\nimport { cx } from \"@emotion/css\"; // 引入 cx\n\nimport { useDesign } from \"../../hooks/useDesign\"; // 引入我们刚才写的 hook\nimport { withInstall } from \"../../utils/withInstall\";\n\nimport { useStyle } from \"./style\";\n\nconst _Card = defineComponent({\n name: \"DCard\",\n props: {\n title: String\n },\n setup(props, { slots }) {\n // 初始化 Design Hook,传入组件名 'card'\n const { getPrefixCls } = useDesign(\"card\");\n\n // 初始化 Emotion 样式\n const styles = useStyle();\n\n return () => {\n // 生成语义化类名\n const rootCls = getPrefixCls();\n const headerCls = getPrefixCls(\"head\");\n const iconCls = getPrefixCls(\"icon\");\n const titleCls = getPrefixCls(\"title\");\n const actionCls = getPrefixCls(\"action\");\n const bodyCls = getPrefixCls(\"body\");\n\n return (\n <div class={cx(rootCls, styles.container)}>\n {/* Header 区域 */}\n <div class={cx(headerCls, styles.header)}>\n {slots.icon && (\n <div class={cx(iconCls, styles.icon)}>\n {slots.icon()}\n </div>\n )}\n <div class={cx(titleCls, styles.header_title)}>\n {props.title}\n </div>\n </div>\n {/*action*/}\n {slots.action && (\n <div class={cx(actionCls, styles.action)}>\n {slots.action()}\n </div>\n )}\n\n {/* Body 区域 */}\n <div class={cx(bodyCls, styles.body)}>\n {slots.default?.()}\n </div>\n </div>\n );\n };\n }\n});\n\nexport const Card = withInstall(_Card);\n"],"names":["_Card","defineComponent","name","props","title","String","setup","slots","getPrefixCls","useDesign","styles","useStyle","rootCls","headerCls","iconCls","titleCls","actionCls","bodyCls","_createVNode","cx","container","header","icon","header_title","action","body","default","Card","withInstall"],"mappings":";;;;;;;;;AAUA,MAAMA,wBAAQC,mBAAAA,CAAgB;AAAA,EAC5BC,IAAAA,EAAM,OAAA;AAAA,EACNC,KAAAA,EAAO;AAAA,IACLC,KAAAA,EAAOC;AAAAA,GACT;AAAA,EACAC,MAAMH,KAAAA,EAAO;AAAA,IAAEI;AAAAA,GAAM,EAAG;AAEtB,IAAA,MAAM;AAAA,MAAEC;AAAAA,KAAa,GAAIC,oBAAU,MAAM,CAAA;AAGzC,IAAA,MAAMC,SAASC,cAAAA,EAAS;AAExB,IAAA,OAAO,MAAM;AAtBjB,MAAA,IAAA,EAAA;AAwBM,MAAA,MAAMC,UAAUJ,YAAAA,EAAa;AAC7B,MAAA,MAAMK,SAAAA,GAAYL,aAAa,MAAM,CAAA;AACrC,MAAA,MAAMM,OAAAA,GAAUN,aAAa,MAAM,CAAA;AACnC,MAAA,MAAMO,QAAAA,GAAWP,aAAa,OAAO,CAAA;AACrC,MAAA,MAAMQ,SAAAA,GAAYR,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMS,OAAAA,GAAUT,aAAa,MAAM,CAAA;AAEnC,MAAA,OAAAU,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACcC,MAAAA,CAAGP,OAAAA,EAASF,MAAAA,CAAOU,SAAS;AAAA,OAAC,EAAA,CAAAF,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EAE3BC,MAAAA,CAAGN,SAAAA,EAAWH,MAAAA,CAAOW,MAAM;AAAA,OAAC,EAAA,CACrCd,KAAAA,CAAMe,IAAAA,IAAIJ,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACGC,MAAAA,CAAGL,OAAAA,EAASJ,MAAAA,CAAOY,IAAI;AAAA,OAAC,EAAA,CACjCf,KAAAA,CAAMe,IAAAA,EAAM,CAAA,CAAA,EAEhBJ,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACWC,MAAAA,CAAGJ,QAAAA,EAAUL,MAAAA,CAAOa,YAAY;AAAA,OAAC,EAAA,CAC1CpB,KAAAA,CAAMC,KAAK,CAAA,CAAA,CAAA,CAAA,EAIfG,KAAAA,CAAMiB,MAAAA,IAAMN,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACCC,MAAAA,CAAGH,SAAAA,EAAWN,MAAAA,CAAOc,MAAM;AAAA,OAAC,EAAA,CACrCjB,KAAAA,CAAMiB,MAAAA,EAAQ,CAAA,CAAA,EAElBN,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EAGWC,MAAAA,CAAGF,OAAAA,EAASP,MAAAA,CAAOe,IAAI;AAAA,SAAC,CAAA,CACjClB,EAAAA,GAAAA,KAAAA,CAAMmB,YAANnB,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAiB,CAAA,CAAA,CAAA,CAAA;AAAA,IAI1B,CAAA;AAAA,EACF;AACF,CAAC,CAAA;AAEM,MAAMoB,IAAAA,GAAOC,wBAAY5B,KAAK;;;;"}
1
+ {"version":3,"file":"Card.cjs","sources":["../../../../src/components/card/Card.tsx"],"sourcesContent":["// components/card/index.tsx\r\nimport { defineComponent } from \"vue\";\r\n\r\nimport { useStyle } from \"./style\";\r\nimport { cx } from \"@emotion/css\"; // 引入 cx\r\n\r\nimport { useDesign } from \"../../hooks/useDesign\"; // 引入我们刚才写的 hook\r\n\r\nimport { withInstall } from \"../../utils/withInstall\";\r\n\r\nconst _Card = defineComponent({\r\n name: \"DCard\",\r\n props: {\r\n title: String\r\n },\r\n setup(props, { slots }) {\r\n // 初始化 Design Hook,传入组件名 'card'\r\n const { getPrefixCls } = useDesign(\"card\");\r\n\r\n // 初始化 Emotion 样式\r\n const styles = useStyle();\r\n\r\n return () => {\r\n // 生成语义化类名\r\n const rootCls = getPrefixCls();\r\n const headerWrapperCls = getPrefixCls(\"head-wrapper\");\r\n const headerCls = getPrefixCls(\"head\");\r\n const headerExctraCls = getPrefixCls(\"extra\");\r\n const iconCls = getPrefixCls(\"icon\");\r\n const titleCls = getPrefixCls(\"title\");\r\n const actionCls = getPrefixCls(\"action\");\r\n const bodyCls = getPrefixCls(\"body\");\r\n\r\n return (\r\n <div class={cx(rootCls, styles.container)}>\r\n {/* Header 区域 */}\r\n <div class={cx(headerWrapperCls, styles.header)}>\r\n <div class={cx(headerCls, styles.headerLeft)}>\r\n {slots.icon && (\r\n <div class={cx(iconCls, styles.icon)}>\r\n {slots.icon()}\r\n </div>\r\n )}\r\n <div\r\n class={cx(titleCls, styles.header_title)}\r\n >\r\n {props.title}\r\n </div>\r\n </div>\r\n {slots.extra && (\r\n <div class={cx(headerExctraCls)}>\r\n {slots.extra()}\r\n </div>\r\n )}\r\n </div>\r\n {/*action*/}\r\n {slots.action && (\r\n <div class={cx(actionCls, styles.action)}>\r\n {slots.action()}\r\n </div>\r\n )}\r\n\r\n {/* Body 区域 */}\r\n <div class={cx(bodyCls, styles.body)}>\r\n {slots.default?.()}\r\n </div>\r\n </div>\r\n );\r\n };\r\n }\r\n});\r\n\r\nexport const Card = withInstall(_Card);\r\n"],"names":["_Card","defineComponent","name","props","title","String","setup","slots","getPrefixCls","useDesign","styles","useStyle","rootCls","headerWrapperCls","headerCls","headerExctraCls","iconCls","titleCls","actionCls","bodyCls","_createVNode","cx","container","header","headerLeft","icon","header_title","extra","action","body","default","Card","withInstall"],"mappings":";;;;;;;;;AAUA,MAAMA,wBAAQC,mBAAAA,CAAgB;AAAA,EAC5BC,IAAAA,EAAM,OAAA;AAAA,EACNC,KAAAA,EAAO;AAAA,IACLC,KAAAA,EAAOC;AAAAA,GACT;AAAA,EACAC,MAAMH,KAAAA,EAAO;AAAA,IAAEI;AAAAA,GAAM,EAAG;AAEtB,IAAA,MAAM;AAAA,MAAEC;AAAAA,KAAa,GAAIC,oBAAU,MAAM,CAAA;AAGzC,IAAA,MAAMC,SAASC,cAAAA,EAAS;AAExB,IAAA,OAAO,MAAM;AAtBjB,MAAA,IAAA,EAAA;AAwBM,MAAA,MAAMC,UAAUJ,YAAAA,EAAa;AAC7B,MAAA,MAAMK,gBAAAA,GAAmBL,aAAa,cAAc,CAAA;AACpD,MAAA,MAAMM,SAAAA,GAAYN,aAAa,MAAM,CAAA;AACrC,MAAA,MAAMO,eAAAA,GAAkBP,aAAa,OAAO,CAAA;AAC5C,MAAA,MAAMQ,OAAAA,GAAUR,aAAa,MAAM,CAAA;AACnC,MAAA,MAAMS,QAAAA,GAAWT,aAAa,OAAO,CAAA;AACrC,MAAA,MAAMU,SAAAA,GAAYV,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMW,OAAAA,GAAUX,aAAa,MAAM,CAAA;AAEnC,MAAA,OAAAY,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACcC,MAAAA,CAAGT,OAAAA,EAASF,MAAAA,CAAOY,SAAS;AAAA,OAAC,EAAA,CAAAF,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EAE3BC,MAAAA,CAAGR,gBAAAA,EAAkBH,MAAAA,CAAOa,MAAM;AAAA,OAAC,EAAA,CAAAH,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACjCC,MAAAA,CAAGP,SAAAA,EAAWJ,MAAAA,CAAOc,UAAU;AAAA,OAAC,EAAA,CACzCjB,KAAAA,CAAMkB,IAAAA,IAAIL,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACGC,MAAAA,CAAGL,OAAAA,EAASN,MAAAA,CAAOe,IAAI;AAAA,OAAC,EAAA,CACjClB,KAAAA,CAAMkB,IAAAA,EAAM,CAAA,CAAA,EAEhBL,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EAEQC,MAAAA,CAAGJ,QAAAA,EAAUP,MAAAA,CAAOgB,YAAY;AAAA,OAAC,EAAA,CAEvCvB,KAAAA,CAAMC,KAAK,CAAA,CAAA,CAAA,CAAA,EAGfG,KAAAA,CAAMoB,KAAAA,IAAKP,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACEC,OAAGN,eAAe;AAAA,OAAC,EAAA,CAC5BR,KAAAA,CAAMoB,KAAAA,EAAO,CAAA,CAEjB,CAAA,CAAA,EAGFpB,KAAAA,CAAMqB,MAAAA,IAAMR,eAAAA,CAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACCC,MAAAA,CAAGH,SAAAA,EAAWR,MAAAA,CAAOkB,MAAM;AAAA,OAAC,EAAA,CACrCrB,KAAAA,CAAMqB,MAAAA,EAAQ,CAAA,CAAA,EAElBR,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EAGWC,MAAAA,CAAGF,OAAAA,EAAST,MAAAA,CAAOmB,IAAI;AAAA,SAAC,CAAA,CACjCtB,EAAAA,GAAAA,KAAAA,CAAMuB,YAANvB,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAiB,CAAA,CAAA,CAAA,CAAA;AAAA,IAI1B,CAAA;AAAA,EACF;AACF,CAAC,CAAA;AAEM,MAAMwB,IAAAA,GAAOC,wBAAYhC,KAAK;;;;"}
@@ -12,10 +12,17 @@ const useStyle = () => {
12
12
  `,
13
13
  header: css.css`
14
14
  display: flex;
15
- margin-bottom: 20px;
15
+ padding: 10px;
16
+ align-items: center;
17
+ justify-content: space-between;
18
+ border-bottom: 1px solid #d9d9d9;
19
+ `,
20
+ headerLeft: css.css`
21
+ display: flex;
22
+ align-items: center;
16
23
  `,
17
24
  header_title: css.css`
18
- line-height: 1.5;
25
+ //line-height: 1.5;
19
26
  /* 如果标题过长,防止换行破坏布局,可以加这行 */
20
27
  white-space: nowrap;
21
28
  `,
@@ -27,7 +34,7 @@ const useStyle = () => {
27
34
  flex-shrink: 0; /* 防止标题过长时挤压图标 */
28
35
  `,
29
36
  action: css.css`
30
- margin-bottom: 10px;
37
+ padding: 10px;
31
38
  `,
32
39
  body: css.css`
33
40
  display: flex;
@@ -1 +1 @@
1
- {"version":3,"file":"style.cjs","sources":["../../../../src/components/card/style.ts"],"sourcesContent":["import { css } from \"@emotion/css\";\n\nexport const useStyle = () => {\n return {\n container: css`\n display: flex;\n flex-direction: column;\n background-color: #fff;\n `,\n header: css`\n display: flex;\n margin-bottom: 20px;\n `,\n header_title: css`\n line-height: 1.5;\n /* 如果标题过长,防止换行破坏布局,可以加这行 */\n white-space: nowrap;\n `,\n // 可选:如果你需要对 icon 容器做特殊处理(例如防止图标被压缩)\n icon: css`\n margin-right: 10px;\n display: inline-flex;\n align-items: center;\n flex-shrink: 0; /* 防止标题过长时挤压图标 */\n `,\n action: css`\n margin-bottom: 10px;\n `,\n body: css`\n display: flex;\n flex-direction: column;\n `\n };\n};\n"],"names":["css"],"mappings":";;;;;AAEO,MAAM,WAAW,MAAM;AAC5B,EAAA,OAAO;AAAA,IACL,SAAA,EAAWA,OAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAKX,MAAA,EAAQA,OAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAIR,YAAA,EAAcA,OAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA;AAAA,IAMd,IAAA,EAAMA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAMN,MAAA,EAAQA,OAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAGR,IAAA,EAAMA,OAAA;AAAA;AAAA;AAAA,IAAA;AAAA,GAIR;AACF;;;;"}
1
+ {"version":3,"file":"style.cjs","sources":["../../../../src/components/card/style.ts"],"sourcesContent":["import { css } from \"@emotion/css\";\r\n\r\nexport const useStyle = () => {\r\n return {\r\n container: css`\r\n display: flex;\r\n flex-direction: column;\r\n background-color: #fff;\r\n `,\r\n header: css`\r\n display: flex;\r\n padding: 10px;\r\n align-items: center;\r\n justify-content: space-between;\r\n border-bottom: 1px solid #d9d9d9;\r\n `,\r\n headerLeft: css`\r\n display: flex;\r\n align-items: center;\r\n `,\r\n header_title: css`\r\n //line-height: 1.5;\r\n /* 如果标题过长,防止换行破坏布局,可以加这行 */\r\n white-space: nowrap;\r\n `,\r\n // 可选:如果你需要对 icon 容器做特殊处理(例如防止图标被压缩)\r\n icon: css`\r\n margin-right: 10px;\r\n display: inline-flex;\r\n align-items: center;\r\n flex-shrink: 0; /* 防止标题过长时挤压图标 */\r\n `,\r\n action: css`\r\n padding: 10px;\r\n `,\r\n body: css`\r\n display: flex;\r\n flex-direction: column;\r\n `\r\n };\r\n};\r\n"],"names":["css"],"mappings":";;;;;AAEO,MAAM,WAAW,MAAM;AAC5B,EAAA,OAAO;AAAA,IACL,SAAA,EAAWA,OAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAKX,MAAA,EAAQA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAOR,UAAA,EAAYA,OAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAIZ,YAAA,EAAcA,OAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA;AAAA,IAMd,IAAA,EAAMA,OAAA;AAAA;AAAA;AAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAMN,MAAA,EAAQA,OAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAGR,IAAA,EAAMA,OAAA;AAAA;AAAA;AAAA,IAAA;AAAA,GAIR;AACF;;;;"}
@@ -1,6 +1,7 @@
1
1
  export declare const useStyle: () => {
2
2
  container: string;
3
3
  header: string;
4
+ headerLeft: string;
4
5
  header_title: string;
5
6
  icon: string;
6
7
  action: string;
@@ -0,0 +1,99 @@
1
+ 'use strict';
2
+
3
+ var vue = require('vue');
4
+ var iconsVue = require('@ant-design/icons-vue');
5
+ var css = require('@emotion/css');
6
+ var useDesign = require('../../hooks/useDesign.cjs');
7
+ var withInstall = require('../../utils/withInstall.cjs');
8
+ var style = require('./style.cjs');
9
+
10
+ "use strict";
11
+ const _Desensitize = /* @__PURE__ */ vue.defineComponent({
12
+ name: "DDesensitize",
13
+ components: {
14
+ EyeOutlined: iconsVue.EyeOutlined,
15
+ EyeInvisibleOutlined: iconsVue.EyeInvisibleOutlined
16
+ },
17
+ props: {
18
+ value: {
19
+ // type: [string,number] 可以使用PropType 来声明对象类型
20
+ // type: String as () => string | number,
21
+ type: String,
22
+ required: true
23
+ },
24
+ // 替换样式
25
+ style: {
26
+ type: String,
27
+ default: "*"
28
+ },
29
+ // 替换规则 id 和mobile
30
+ rule: {
31
+ type: String,
32
+ required: true
33
+ },
34
+ // 正则表达式
35
+ regex: {
36
+ type: String,
37
+ default: ""
38
+ },
39
+ // 替换方式
40
+ regexValue: {
41
+ type: String,
42
+ default: ""
43
+ },
44
+ eye: {
45
+ type: Boolean,
46
+ default: false
47
+ }
48
+ },
49
+ setup(props) {
50
+ const {
51
+ getPrefixCls
52
+ } = useDesign.useDesign("desensitize");
53
+ const styles = style.useStyle();
54
+ const invisible = vue.ref(true);
55
+ const desensitizedString = vue.computed(() => {
56
+ const value = props.value;
57
+ const rule = props.rule;
58
+ const regex = props.regex;
59
+ const regexValue = props.regexValue;
60
+ let str = "";
61
+ if (!value) {
62
+ return "";
63
+ }
64
+ if (rule) {
65
+ switch (rule) {
66
+ case "mobile":
67
+ str = value.replace(/(\d{3})\d{4}(\d{4})/, "$1*****$2");
68
+ break;
69
+ case "id":
70
+ str = value.replace(/(\d{4})\d{10}(\w{4})/, "$1*****$2");
71
+ break;
72
+ }
73
+ } else {
74
+ str = value.replace(regex, regexValue);
75
+ }
76
+ return str;
77
+ });
78
+ return () => {
79
+ const rootCls = getPrefixCls();
80
+ const valueCls = getPrefixCls("value");
81
+ const iconCls = getPrefixCls("icon");
82
+ return vue.createVNode("div", {
83
+ "class": css.cx(rootCls, styles.container)
84
+ }, [vue.createVNode("span", {
85
+ "class": css.cx(valueCls, styles.value)
86
+ }, [invisible.value ? desensitizedString.value : props.value]), props.eye ? vue.createVNode("span", {
87
+ "class": css.cx(iconCls, styles.icon)
88
+ }, [vue.withDirectives(vue.createVNode(vue.resolveComponent("eye-outlined"), {
89
+ "onClick": () => invisible.value = !invisible.value
90
+ }, null), [[vue.vShow, !invisible.value]]), vue.withDirectives(vue.createVNode(vue.resolveComponent("eye-invisible-outlined"), {
91
+ "onClick": () => invisible.value = !invisible.value
92
+ }, null), [[vue.vShow, invisible.value]])]) : void 0]);
93
+ };
94
+ }
95
+ });
96
+ const Desensitize = withInstall.withInstall(_Desensitize);
97
+
98
+ exports.Desensitize = Desensitize;
99
+ //# sourceMappingURL=Desensitize.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"Desensitize.cjs","sources":["../../../../src/components/desensitize/Desensitize.tsx"],"sourcesContent":["/**\r\n * 脱敏\r\n * @author 余春林\r\n */\r\nimport { defineComponent, computed, ref } from \"vue\";\r\nimport { EyeOutlined, EyeInvisibleOutlined } from \"@ant-design/icons-vue\";\r\nimport { cx } from \"@emotion/css\";\r\n\r\nimport { useDesign } from \"../../hooks/useDesign\";\r\nimport { withInstall } from \"../../utils/withInstall\";\r\n\r\nimport { useStyle } from \"./style\";\r\n\r\nconst _Desensitize = defineComponent({\r\n name: \"DDesensitize\",\r\n components: {\r\n EyeOutlined,\r\n EyeInvisibleOutlined\r\n },\r\n props: {\r\n value: {\r\n // type: [string,number] 可以使用PropType 来声明对象类型\r\n // type: String as () => string | number,\r\n type: String as () => string | undefined,\r\n required: true\r\n },\r\n // 替换样式\r\n style: {\r\n type: String,\r\n default: \"*\"\r\n },\r\n // 替换规则 id 和mobile\r\n rule: {\r\n type: String,\r\n required: true\r\n },\r\n // 正则表达式\r\n regex: {\r\n type: String,\r\n default: \"\"\r\n },\r\n // 替换方式\r\n regexValue: {\r\n type: String,\r\n default: \"\"\r\n },\r\n eye: {\r\n type: Boolean,\r\n default: false\r\n }\r\n },\r\n setup(props) {\r\n const { getPrefixCls } = useDesign(\"desensitize\");\r\n const styles = useStyle();\r\n\r\n // 控制显示隐藏脱敏或者不脱敏\r\n const invisible = ref(true);\r\n const desensitizedString = computed(() => {\r\n const value = props.value;\r\n const rule = props.rule;\r\n const regex = props.regex;\r\n const regexValue = props.regexValue;\r\n let str = \"\";\r\n if (!value) {\r\n return \"\";\r\n }\r\n if (rule) {\r\n switch (rule) {\r\n case \"mobile\":\r\n str = value.replace(/(\\d{3})\\d{4}(\\d{4})/, \"$1*****$2\");\r\n break;\r\n case \"id\":\r\n str = value.replace(/(\\d{4})\\d{10}(\\w{4})/, \"$1*****$2\");\r\n break;\r\n }\r\n } else {\r\n str = value.replace(regex, regexValue);\r\n }\r\n return str;\r\n });\r\n return () => {\r\n const rootCls = getPrefixCls();\r\n const valueCls = getPrefixCls(\"value\");\r\n const iconCls = getPrefixCls(\"icon\");\r\n\r\n return (\r\n <div class={cx(rootCls, styles.container)}>\r\n <span class={cx(valueCls, styles.value)}>\r\n {invisible.value ? desensitizedString.value : props.value}\r\n </span>\r\n {props.eye ? (\r\n <span class={cx(iconCls, styles.icon)}>\r\n <eye-outlined\r\n onClick={() => (invisible.value = !invisible.value)}\r\n v-show={!invisible.value}\r\n />\r\n <eye-invisible-outlined\r\n onClick={() => (invisible.value = !invisible.value)}\r\n v-show={invisible.value}\r\n />\r\n </span>\r\n ) : undefined}\r\n </div>\r\n );\r\n };\r\n }\r\n});\r\n\r\nexport const Desensitize = withInstall(_Desensitize);\r\n"],"names":["_Desensitize","defineComponent","name","components","EyeOutlined","EyeInvisibleOutlined","props","value","type","String","required","style","default","rule","regex","regexValue","eye","Boolean","setup","getPrefixCls","useDesign","styles","useStyle","invisible","ref","desensitizedString","computed","str","replace","rootCls","valueCls","iconCls","_createVNode","cx","container","icon","_withDirectives","_resolveComponent","onClick","_vShow","undefined","Desensitize","withInstall"],"mappings":"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"}
@@ -0,0 +1,60 @@
1
+ export declare const Desensitize: import("../../utils/withInstall").SFCWithInstall<import("vue").DefineComponent<import("vue").ExtractPropTypes<{
2
+ value: {
3
+ type: () => string | undefined;
4
+ required: true;
5
+ };
6
+ style: {
7
+ type: StringConstructor;
8
+ default: string;
9
+ };
10
+ rule: {
11
+ type: StringConstructor;
12
+ required: true;
13
+ };
14
+ regex: {
15
+ type: StringConstructor;
16
+ default: string;
17
+ };
18
+ regexValue: {
19
+ type: StringConstructor;
20
+ default: string;
21
+ };
22
+ eye: {
23
+ type: BooleanConstructor;
24
+ default: boolean;
25
+ };
26
+ }>, () => import("vue/jsx-runtime").JSX.Element, {}, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").PublicProps, Readonly<import("vue").ExtractPropTypes<{
27
+ value: {
28
+ type: () => string | undefined;
29
+ required: true;
30
+ };
31
+ style: {
32
+ type: StringConstructor;
33
+ default: string;
34
+ };
35
+ rule: {
36
+ type: StringConstructor;
37
+ required: true;
38
+ };
39
+ regex: {
40
+ type: StringConstructor;
41
+ default: string;
42
+ };
43
+ regexValue: {
44
+ type: StringConstructor;
45
+ default: string;
46
+ };
47
+ eye: {
48
+ type: BooleanConstructor;
49
+ default: boolean;
50
+ };
51
+ }>> & Readonly<{}>, {
52
+ style: string;
53
+ regex: string;
54
+ regexValue: string;
55
+ eye: boolean;
56
+ }, {}, {
57
+ EyeOutlined: import("@ant-design/icons-vue/lib/icons/EyeOutlined").EyeOutlinedIconType;
58
+ EyeInvisibleOutlined: import("@ant-design/icons-vue/lib/icons/EyeInvisibleOutlined").EyeInvisibleOutlinedIconType;
59
+ }, {}, string, import("vue").ComponentProvideOptions, true, {}, any>>;
60
+ //# sourceMappingURL=Desensitize.d.ts.map
@@ -0,0 +1,15 @@
1
+ 'use strict';
2
+
3
+ Object.defineProperty(exports, '__esModule', { value: true });
4
+
5
+ var Desensitize = require('./Desensitize.cjs');
6
+
7
+ "use strict";
8
+ Desensitize.Desensitize.install = function(app) {
9
+ app.component(Desensitize.Desensitize.name, Desensitize.Desensitize);
10
+ return app;
11
+ };
12
+
13
+ exports.Desensitize = Desensitize.Desensitize;
14
+ exports.default = Desensitize.Desensitize;
15
+ //# sourceMappingURL=index.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.cjs","sources":["../../../../src/components/desensitize/index.ts"],"sourcesContent":["import type { App } from \"vue\";\r\nimport { Desensitize } from \"./Desensitize\";\r\n\r\nDesensitize.install = function (app: App) {\r\n app.component(Desensitize.name!, Desensitize);\r\n return app;\r\n};\r\n\r\nexport { Desensitize };\r\n\r\nexport default Desensitize;\r\n"],"names":["Desensitize"],"mappings":";;;;;;;AAGAA,uBAAA,CAAY,OAAA,GAAU,SAAU,GAAA,EAAU;AACxC,EAAA,GAAA,CAAI,SAAA,CAAUA,uBAAA,CAAY,IAAA,EAAOA,uBAAW,CAAA;AAC5C,EAAA,OAAO,GAAA;AACT,CAAA;;;;;"}
@@ -0,0 +1,4 @@
1
+ import { Desensitize } from "./Desensitize";
2
+ export { Desensitize };
3
+ export default Desensitize;
4
+ //# sourceMappingURL=index.d.ts.map
@@ -0,0 +1,22 @@
1
+ 'use strict';
2
+
3
+ var css = require('@emotion/css');
4
+
5
+ "use strict";
6
+ const useStyle = () => {
7
+ return {
8
+ container: css.css`
9
+ display: inline-block;
10
+ `,
11
+ value: css.css`
12
+ padding: 0 4px;
13
+ `,
14
+ icon: css.css`
15
+ cursor: pointer;
16
+ margin-left: 4px;
17
+ `
18
+ };
19
+ };
20
+
21
+ exports.useStyle = useStyle;
22
+ //# sourceMappingURL=style.cjs.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"style.cjs","sources":["../../../../src/components/desensitize/style.ts"],"sourcesContent":["import { css } from \"@emotion/css\";\r\n\r\nexport const useStyle = () => {\r\n return {\r\n container: css`\r\n display: inline-block;\r\n `,\r\n value: css`\r\n padding: 0 4px;\r\n `,\r\n icon: css`\r\n cursor: pointer;\r\n margin-left: 4px;\r\n `\r\n };\r\n};\r\n"],"names":["css"],"mappings":";;;;;AAEO,MAAM,WAAW,MAAM;AAC5B,EAAA,OAAO;AAAA,IACL,SAAA,EAAWA,OAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAGX,KAAA,EAAOA,OAAA;AAAA;AAAA,IAAA,CAAA;AAAA,IAGP,IAAA,EAAMA,OAAA;AAAA;AAAA;AAAA,IAAA;AAAA,GAIR;AACF;;;;"}
@@ -0,0 +1,6 @@
1
+ export declare const useStyle: () => {
2
+ container: string;
3
+ value: string;
4
+ icon: string;
5
+ };
6
+ //# sourceMappingURL=style.d.ts.map
@@ -76,7 +76,8 @@ var DicReplace = /* @__PURE__ */ vue.defineComponent({
76
76
  }
77
77
  });
78
78
  }
79
- loadDicData().then(() => console.log("success load dic"));
79
+ loadDicData().then(() => {
80
+ });
80
81
  vue.watch(() => props.value, (val) => {
81
82
  replace(val);
82
83
  }, {
@@ -1 +1 @@
1
- {"version":3,"file":"DicReplace.cjs","sources":["../../../../src/components/dic/DicReplace.tsx"],"sourcesContent":["/**\n * 字典替换\n * 根据字典名字及对应的value替换成中文或者人能看懂的文字\n * @author 余春林\n */\nimport {\n defineComponent,\n inject,\n onActivated,\n onMounted,\n ref,\n watch\n} from \"vue\";\nimport { useRoute } from \"vue-router\";\nimport { storeToRefs } from \"pinia\";\n\nimport { useDicStore, useNavTabStore } from \"@ditari/store\";\n\nexport default defineComponent({\n name: \"DicRep\",\n props: {\n // 字典名称\n name: {\n type: String,\n default: \"\"\n },\n // 值\n value: {\n type: [String, Number],\n default: \"\"\n }\n },\n setup(props) {\n const { list } = storeToRefs(useNavTabStore());\n const { getDicTextByValue } = useDicStore();\n const route = useRoute();\n // 判断使用组件的页面是否被缓存\n const isKeepAlive = list.value.some(\n item =>\n item.fullPath === route.fullPath &&\n item.meta?.keepAlive\n );\n const dicValueTxt = ref<string>(\"\");\n\n // 注入 fetchDic,提供默认值\n const fetchDic = inject<\n (name: string) => Promise<unknown[]>\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\n >(\"fetchDic\", async (_name: string) => {\n // console.warn(\n // `fetchDic 未注入,使用默认实现,name: ${name}`\n // );\n return [];\n });\n\n onActivated(async () => {\n // 缓存页面被激活的时候调用\n await loadDicData();\n });\n\n onMounted(async () => {\n if (!isKeepAlive) {\n // 未缓存页面 挂载的时候调用\n await loadDicData();\n }\n });\n\n // 请求字典数据的函数\n async function loadDicData() {\n try {\n // 调用注入进来的fetchDic方法\n await fetchDic(props.name);\n replace(props.value);\n } catch (error) {\n console.error(\"获取字典数据失败:\", error);\n }\n }\n\n loadDicData().then(() =>\n console.log(\"success load dic\")\n );\n\n watch(\n () => props.value,\n (val: string | number) => {\n replace(val);\n },\n {\n immediate: true\n }\n );\n\n function replace(val: string | number) {\n const value = val;\n const name = props.name;\n dicValueTxt.value = getDicTextByValue(\n name,\n value?.toString()\n );\n }\n\n return () => (\n <span class={\"d-dic\"}>{dicValueTxt.value}</span>\n );\n }\n});\n"],"names":["name","props","type","String","default","value","Number","setup","list","storeToRefs","useNavTabStore","getDicTextByValue","useDicStore","route","useRoute","isKeepAlive","some","item","fullPath","meta","keepAlive","dicValueTxt","ref","fetchDic","inject","_name","onActivated","loadDicData","onMounted","replace","error","console","then","log","watch","val","immediate","toString","_createVNode"],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;;;;;AAkBA,qDAA+B;AAAA,EAC7BA,IAAAA,EAAM,QAAA;AAAA,EACNC,KAAAA,EAAO;AAAA;AAAA,IAELD,IAAAA,EAAM;AAAA,MACJE,IAAAA,EAAMC,MAAAA;AAAAA,MACNC,OAAAA,EAAS;AAAA,KACX;AAAA;AAAA,IAEAC,KAAAA,EAAO;AAAA,MACLH,IAAAA,EAAM,CAACC,MAAAA,EAAQG,MAAM,CAAA;AAAA,MACrBF,OAAAA,EAAS;AAAA;AACX,GACF;AAAA,EACAG,MAAMN,KAAAA,EAAO;AACX,IAAA,MAAM;AAAA,MAAEO;AAAAA,KAAK,GAAIC,iBAAAA,CAAYC,oBAAAA,EAAgB,CAAA;AAC7C,IAAA,MAAM;AAAA,MAAEC;AAAAA,QAAsBC,iBAAAA,EAAY;AAC1C,IAAA,MAAMC,QAAQC,kBAAAA,EAAS;AAEvB,IAAA,MAAMC,WAAAA,GAAcP,IAAAA,CAAKH,KAAAA,CAAMW,IAAAA,CAC7BC,CAAAA,IAAAA,KAAI;AAtCV,MAAA,IAAA,EAAA;AAuCQA,MAAAA,OAAAA,IAAAA,CAAKC,QAAAA,KAAaL,KAAAA,CAAMK,QAAAA,KAAAA,CACxBD,EAAAA,GAAAA,IAAAA,CAAKE,SAALF,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAWG,SAAAA,CAAAA;AAAAA,IAAAA,CACf,CAAA;AACA,IAAA,MAAMC,WAAAA,GAAcC,QAAY,EAAE,CAAA;AAGlC,IAAA,MAAMC,QAAAA,GAAWC,UAAAA,CAGf,UAAA,EAAY,CAAOC,KAAAA,KAAkB,OAAA,CAAA,IAAA,EAAA,IAAA,EAAA,aAAA;AAIrC,MAAA,OAAO,EAAA;AAAA,IACT,CAAA,CAAC,CAAA;AAEDC,IAAAA,eAAAA,CAAY,MAAY,OAAA,CAAA,IAAA,EAAA,IAAA,EAAA,aAAA;AAEtB,MAAA,MAAMC,WAAAA,EAAY;AAAA,IACpB,CAAA,CAAC,CAAA;AAEDC,IAAAA,aAAAA,CAAU,MAAY,OAAA,CAAA,IAAA,EAAA,IAAA,EAAA,aAAA;AACpB,MAAA,IAAI,CAACb,WAAAA,EAAa;AAEhB,QAAA,MAAMY,WAAAA,EAAY;AAAA,MACpB;AAAA,IACF,CAAA,CAAC,CAAA;AAGD,IAAA,SAAeA,WAAAA,GAAc;AAAA,MAAA,OAAA,OAAA,CAAA,IAAA,EAAA,IAAA,EAAA,aAAA;AAC3B,QAAA,IAAI;AAEF,UAAA,MAAMJ,QAAAA,CAAStB,MAAMD,IAAI,CAAA;AACzB6B,UAAAA,OAAAA,CAAQ5B,MAAMI,KAAK,CAAA;AAAA,QACrB,SAASyB,KAAAA,EAAO;AACdC,UAAAA,OAAAA,CAAQD,KAAAA,CAAM,qDAAaA,KAAK,CAAA;AAAA,QAClC;AAAA,MACF,CAAA,CAAA;AAAA,IAAA;AAEAH,IAAAA,WAAAA,GAAcK,IAAAA,CAAK,MACjBD,OAAAA,CAAQE,GAAAA,CAAI,kBAAkB,CAChC,CAAA;AAEAC,IAAAA,SAAAA,CACE,MAAMjC,KAAAA,CAAMI,KAAAA,EACX8B,CAAAA,GAAAA,KAAyB;AACxBN,MAAAA,OAAAA,CAAQM,GAAG,CAAA;AAAA,IACb,CAAA,EACA;AAAA,MACEC,SAAAA,EAAW;AAAA,KAEf,CAAA;AAEA,IAAA,SAASP,QAAQM,GAAAA,EAAsB;AACrC,MAAA,MAAM9B,KAAAA,GAAQ8B,GAAAA;AACd,MAAA,MAAMnC,OAAOC,KAAAA,CAAMD,IAAAA;AACnBqB,MAAAA,WAAAA,CAAYhB,KAAAA,GAAQM,iBAAAA,CAClBX,IAAAA,EACAK,KAAAA,IAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,KAAAA,CAAOgC,QAAAA,EACT,CAAA;AAAA,IACF;AAEA,IAAA,OAAO,MAAAC,gBAAA,MAAA,EAAA;AAAA,MAAA,OAAA,EACQ;AAAA,KAAO,EAAA,CAAGjB,WAAAA,CAAYhB,KAAK,CAAA,CAAA;AAAA,EAE5C;AACF,CAAC,CAAA;;;;"}
1
+ {"version":3,"file":"DicReplace.cjs","sources":["../../../../src/components/dic/DicReplace.tsx"],"sourcesContent":["/**\r\n * 字典替换\r\n * 根据字典名字及对应的value替换成中文或者人能看懂的文字\r\n * @author 余春林\r\n */\r\nimport {\r\n defineComponent,\r\n inject,\r\n onActivated,\r\n onMounted,\r\n ref,\r\n watch\r\n} from \"vue\";\r\nimport { useRoute } from \"vue-router\";\r\nimport { storeToRefs } from \"pinia\";\r\n\r\nimport { useDicStore, useNavTabStore } from \"@ditari/store\";\r\n\r\nexport default defineComponent({\r\n name: \"DicRep\",\r\n props: {\r\n // 字典名称\r\n name: {\r\n type: String,\r\n default: \"\"\r\n },\r\n // 值\r\n value: {\r\n type: [String, Number],\r\n default: \"\"\r\n }\r\n },\r\n setup(props) {\r\n const { list } = storeToRefs(useNavTabStore());\r\n const { getDicTextByValue } = useDicStore();\r\n const route = useRoute();\r\n // 判断使用组件的页面是否被缓存\r\n const isKeepAlive = list.value.some(\r\n item =>\r\n item.fullPath === route.fullPath &&\r\n item.meta?.keepAlive\r\n );\r\n const dicValueTxt = ref<string>(\"\");\r\n\r\n // 注入 fetchDic,提供默认值\r\n const fetchDic = inject<\r\n (name: string) => Promise<unknown[]>\r\n // eslint-disable-next-line @typescript-eslint/no-unused-vars\r\n >(\"fetchDic\", async (_name: string) => {\r\n // console.warn(\r\n // `fetchDic 未注入,使用默认实现,name: ${name}`\r\n // );\r\n return [];\r\n });\r\n\r\n onActivated(async () => {\r\n // 缓存页面被激活的时候调用\r\n await loadDicData();\r\n });\r\n\r\n onMounted(async () => {\r\n if (!isKeepAlive) {\r\n // 未缓存页面 挂载的时候调用\r\n await loadDicData();\r\n }\r\n });\r\n\r\n // 请求字典数据的函数\r\n async function loadDicData() {\r\n try {\r\n // 调用注入进来的fetchDic方法\r\n await fetchDic(props.name);\r\n replace(props.value);\r\n } catch (error) {\r\n console.error(\"获取字典数据失败:\", error);\r\n }\r\n }\r\n\r\n loadDicData().then(() =>{\r\n // console.log(\"success load dic\")\r\n }\r\n );\r\n\r\n watch(\r\n () => props.value,\r\n (val: string | number) => {\r\n replace(val);\r\n },\r\n {\r\n immediate: true\r\n }\r\n );\r\n\r\n function replace(val: string | number) {\r\n const value = val;\r\n const name = props.name;\r\n dicValueTxt.value = getDicTextByValue(\r\n name,\r\n value?.toString()\r\n );\r\n }\r\n\r\n return () => (\r\n <span class={\"d-dic\"}>{dicValueTxt.value}</span>\r\n );\r\n }\r\n});\r\n"],"names":["name","props","type","String","default","value","Number","setup","list","storeToRefs","useNavTabStore","getDicTextByValue","useDicStore","route","useRoute","isKeepAlive","some","item","fullPath","meta","keepAlive","dicValueTxt","ref","fetchDic","inject","_name","onActivated","loadDicData","onMounted","replace","error","console","then","watch","val","immediate","toString","_createVNode"],"mappings":"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"}
@@ -1 +1 @@
1
- {"version":3,"file":"AppContext.cjs","sources":["../../../../src/components/layout/AppContext.ts"],"sourcesContent":["import { ComputedRef, VNode } from \"vue\";\n\nexport const AppContextKey = Symbol(\"d-bsui-context\");\nexport interface AppContext {\n // 水印\n watermarkContent?: ComputedRef<{ content: string }>;\n renderMenuIcon?: (item: {\n icon: string;\n }) => VNode | VNode[];\n // 缓存方式 Name:组件名称 Path:路径缓\n keepAliveMode: \"Name\" | \"Path\";\n // 多标签重载\n onReloadPage?: (item: { [key: string]: unknown }) => void;\n // 多标签是否开启右键菜单\n enableTabContextMenu?: boolean;\n}\n"],"names":[],"mappings":";;;AAEO,MAAM,aAAA,GAAgB,OAAO,gBAAgB;;;;"}
1
+ {"version":3,"file":"AppContext.cjs","sources":["../../../../src/components/layout/AppContext.ts"],"sourcesContent":["import { ComputedRef, VNode } from \"vue\";\r\n\r\nexport const AppContextKey = Symbol(\"d-bsui-context\");\r\nexport interface AppContext {\r\n // 水印\r\n watermarkContent?: ComputedRef<{ content: string }>;\r\n renderMenuIcon?: (item: {\r\n icon: string;\r\n }) => VNode | VNode[];\r\n // 缓存方式 Name:组件名称 Path:路径缓\r\n keepAliveMode: \"Name\" | \"Path\";\r\n // 多标签重载\r\n onReloadPage?: (item: { [key: string]: unknown }) => void;\r\n // 多标签是否开启右键菜单\r\n enableTabContextMenu?: boolean;\r\n}\r\n"],"names":[],"mappings":";;;AAEO,MAAM,aAAA,GAAgB,OAAO,gBAAgB;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"AppLayout.cjs","sources":["../../../../src/components/layout/AppLayout.tsx"],"sourcesContent":["import { defineComponent } from \"vue\";\nimport { storeToRefs } from \"pinia\";\n\nimport { useAppLayoutStyle } from \"./style\";\nimport { useDeviceStore } from \"@ditari/store\";\nimport { cx } from \"@emotion/css\";\n\nimport { useDesign } from \"../../hooks/useDesign\";\n\nconst DAppLayout = defineComponent({\n name: \"DAppLayout\",\n setup(_, { slots }) {\n const deviceStore = useDeviceStore();\n // 使用 storeToRefs 解构出响应式引用\n const { isMobile, isTablet, isDesktop } =\n storeToRefs(deviceStore);\n\n const { getPrefixCls } = useDesign(\"app-layout\");\n const styles = useAppLayoutStyle();\n\n return () => {\n const rootCls = getPrefixCls();\n const mobileCls = getPrefixCls(\"mobile\");\n const tabletCls = getPrefixCls(\"tablet\");\n const desktopCls = getPrefixCls(\"desktop\");\n\n let layoutContent;\n if (isMobile.value) {\n layoutContent = slots.mobile ? (\n <div class={cx(mobileCls, styles.mobile)}>\n {slots.mobile()}\n </div>\n ) : undefined;\n } else if (isTablet.value) {\n layoutContent = slots.tablet ? (\n <div class={cx(tabletCls)}>{slots.tablet()}</div>\n ) : undefined;\n } else {\n layoutContent = slots.desktop ? (\n <div class={cx(desktopCls)}>\n {slots.desktop()}\n </div>\n ) : undefined;\n }\n\n return (\n <div class={cx(rootCls, styles.appLayout)}>\n {layoutContent}\n </div>\n );\n };\n }\n});\n\nexport default DAppLayout;\n"],"names":["DAppLayout","defineComponent","name","setup","_","slots","deviceStore","useDeviceStore","isMobile","isTablet","isDesktop","storeToRefs","getPrefixCls","useDesign","styles","useAppLayoutStyle","rootCls","mobileCls","tabletCls","desktopCls","layoutContent","value","mobile","_createVNode","cx","undefined","tablet","desktop","appLayout"],"mappings":";;;;;;;;;;;;AASA,MAAMA,6BAAaC,mBAAAA,CAAgB;AAAA,EACjCC,IAAAA,EAAM,YAAA;AAAA,EACNC,MAAMC,CAAAA,EAAG;AAAA,IAAEC;AAAAA,GAAM,EAAG;AAClB,IAAA,MAAMC,cAAcC,oBAAAA,EAAe;AAEnC,IAAA,MAAM;AAAA,MAAEC,QAAAA;AAAAA,MAAUC,QAAAA;AAAAA,MAAUC;AAAAA,KAAU,GACpCC,kBAAYL,WAAW,CAAA;AAEzB,IAAA,MAAM;AAAA,MAAEM;AAAAA,KAAa,GAAIC,oBAAU,YAAY,CAAA;AAC/C,IAAA,MAAMC,SAASC,uBAAAA,EAAkB;AAEjC,IAAA,OAAO,MAAM;AACX,MAAA,MAAMC,UAAUJ,YAAAA,EAAa;AAC7B,MAAA,MAAMK,SAAAA,GAAYL,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMM,SAAAA,GAAYN,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMO,UAAAA,GAAaP,aAAa,SAAS,CAAA;AAEzC,MAAA,IAAIQ,aAAAA;AACJ,MAAA,IAAIZ,SAASa,KAAAA,EAAO;AAClBD,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMiB,MAAAA,GAAMC,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACdC,MAAAA,CAAGP,SAAAA,EAAWH,MAAAA,CAAOQ,MAAM;AAAA,WAAC,CACrCjB,KAAAA,CAAMiB,MAAAA,EAAQ,KAEfG,KAAAA,CAAAA;AAAAA,MACN,CAAA,MAAA,IAAWhB,SAASY,KAAAA,EAAO;AACzBD,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMqB,MAAAA,GAAMH,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACdC,OAAGN,SAAS;AAAA,WAAC,CAAGb,KAAAA,CAAMqB,MAAAA,EAAQ,KACxCD,KAAAA,CAAAA;AAAAA,MACN,CAAA,MAAO;AACLL,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMsB,OAAAA,GAAOJ,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACfC,OAAGL,UAAU;AAAA,WAAC,CACvBd,KAAAA,CAAMsB,OAAAA,EAAS,KAEhBF,KAAAA,CAAAA;AAAAA,MACN;AAEA,MAAA,OAAAF,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACcC,MAAAA,CAAGR,OAAAA,EAASF,MAAAA,CAAOc,SAAS;AAAA,OAAC,EAAA,CACtCR,aAAa,CAAA,CAAA;AAAA,IAGpB,CAAA;AAAA,EACF;AACF,CAAC;;;;"}
1
+ {"version":3,"file":"AppLayout.cjs","sources":["../../../../src/components/layout/AppLayout.tsx"],"sourcesContent":["import { defineComponent } from \"vue\";\r\nimport { storeToRefs } from \"pinia\";\r\n\r\nimport { useAppLayoutStyle } from \"./style\";\r\nimport { useDeviceStore } from \"@ditari/store\";\r\nimport { cx } from \"@emotion/css\";\r\n\r\nimport { useDesign } from \"../../hooks/useDesign\";\r\n\r\nconst DAppLayout = defineComponent({\r\n name: \"DAppLayout\",\r\n setup(_, { slots }) {\r\n const deviceStore = useDeviceStore();\r\n // 使用 storeToRefs 解构出响应式引用\r\n const { isMobile, isTablet, isDesktop } =\r\n storeToRefs(deviceStore);\r\n\r\n const { getPrefixCls } = useDesign(\"app-layout\");\r\n const styles = useAppLayoutStyle();\r\n\r\n return () => {\r\n const rootCls = getPrefixCls();\r\n const mobileCls = getPrefixCls(\"mobile\");\r\n const tabletCls = getPrefixCls(\"tablet\");\r\n const desktopCls = getPrefixCls(\"desktop\");\r\n\r\n let layoutContent;\r\n if (isMobile.value) {\r\n layoutContent = slots.mobile ? (\r\n <div class={cx(mobileCls, styles.mobile)}>\r\n {slots.mobile()}\r\n </div>\r\n ) : undefined;\r\n } else if (isTablet.value) {\r\n layoutContent = slots.tablet ? (\r\n <div class={cx(tabletCls)}>{slots.tablet()}</div>\r\n ) : undefined;\r\n } else {\r\n layoutContent = slots.desktop ? (\r\n <div class={cx(desktopCls)}>\r\n {slots.desktop()}\r\n </div>\r\n ) : undefined;\r\n }\r\n\r\n return (\r\n <div class={cx(rootCls, styles.appLayout)}>\r\n {layoutContent}\r\n </div>\r\n );\r\n };\r\n }\r\n});\r\n\r\nexport default DAppLayout;\r\n"],"names":["DAppLayout","defineComponent","name","setup","_","slots","deviceStore","useDeviceStore","isMobile","isTablet","isDesktop","storeToRefs","getPrefixCls","useDesign","styles","useAppLayoutStyle","rootCls","mobileCls","tabletCls","desktopCls","layoutContent","value","mobile","_createVNode","cx","undefined","tablet","desktop","appLayout"],"mappings":";;;;;;;;;;;;AASA,MAAMA,6BAAaC,mBAAAA,CAAgB;AAAA,EACjCC,IAAAA,EAAM,YAAA;AAAA,EACNC,MAAMC,CAAAA,EAAG;AAAA,IAAEC;AAAAA,GAAM,EAAG;AAClB,IAAA,MAAMC,cAAcC,oBAAAA,EAAe;AAEnC,IAAA,MAAM;AAAA,MAAEC,QAAAA;AAAAA,MAAUC,QAAAA;AAAAA,MAAUC;AAAAA,KAAU,GACpCC,kBAAYL,WAAW,CAAA;AAEzB,IAAA,MAAM;AAAA,MAAEM;AAAAA,KAAa,GAAIC,oBAAU,YAAY,CAAA;AAC/C,IAAA,MAAMC,SAASC,uBAAAA,EAAkB;AAEjC,IAAA,OAAO,MAAM;AACX,MAAA,MAAMC,UAAUJ,YAAAA,EAAa;AAC7B,MAAA,MAAMK,SAAAA,GAAYL,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMM,SAAAA,GAAYN,aAAa,QAAQ,CAAA;AACvC,MAAA,MAAMO,UAAAA,GAAaP,aAAa,SAAS,CAAA;AAEzC,MAAA,IAAIQ,aAAAA;AACJ,MAAA,IAAIZ,SAASa,KAAAA,EAAO;AAClBD,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMiB,MAAAA,GAAMC,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACdC,MAAAA,CAAGP,SAAAA,EAAWH,MAAAA,CAAOQ,MAAM;AAAA,WAAC,CACrCjB,KAAAA,CAAMiB,MAAAA,EAAQ,KAEfG,KAAAA,CAAAA;AAAAA,MACN,CAAA,MAAA,IAAWhB,SAASY,KAAAA,EAAO;AACzBD,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMqB,MAAAA,GAAMH,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACdC,OAAGN,SAAS;AAAA,WAAC,CAAGb,KAAAA,CAAMqB,MAAAA,EAAQ,KACxCD,KAAAA,CAAAA;AAAAA,MACN,CAAA,MAAO;AACLL,QAAAA,aAAAA,GAAgBf,KAAAA,CAAMsB,OAAAA,GAAOJ,eAAAA,CAAA,KAAA,EAAA;AAAA,UAAA,OAAA,EACfC,OAAGL,UAAU;AAAA,WAAC,CACvBd,KAAAA,CAAMsB,OAAAA,EAAS,KAEhBF,KAAAA,CAAAA;AAAAA,MACN;AAEA,MAAA,OAAAF,gBAAA,KAAA,EAAA;AAAA,QAAA,OAAA,EACcC,MAAAA,CAAGR,OAAAA,EAASF,MAAAA,CAAOc,SAAS;AAAA,OAAC,EAAA,CACtCR,aAAa,CAAA,CAAA;AAAA,IAGpB,CAAA;AAAA,EACF;AACF,CAAC;;;;"}
@@ -1 +1 @@
1
- {"version":3,"file":"List.cjs","sources":["../../../../src/components/layout/List.tsx"],"sourcesContent":["import {\n computed,\n defineComponent,\n inject,\n nextTick,\n onActivated,\n onDeactivated,\n onMounted,\n onUnmounted,\n ref,\n watch,\n type WatchStopHandle\n} from \"vue\";\nimport { useRoute } from \"vue-router\";\nimport {\n Card,\n Flex,\n Space,\n Watermark\n} from \"ant-design-vue\";\nimport { storeToRefs } from \"pinia\";\nimport { useElementSize } from \"@vueuse/core\";\n\nimport { AppContext, AppContextKey } from \"./AppContext\";\nimport MobileList from \"./components/mobile/MobileList\";\nimport { useAppStore, useDeviceStore } from \"@ditari/store\";\nimport { css } from \"@emotion/css\";\n\nconst tableRootStyle = css`\n height: 100%;\n position: relative;\n overflow: hidden;\n`;\n\nconst list = defineComponent({\n name: \"DListLayout\",\n emits: [\"refresh\"],\n setup(_, { slots, emit }) {\n const appContext = inject<AppContext | null>(\n AppContextKey,\n null\n );\n\n const watermarkContent = computed(\n () => appContext?.watermarkContent?.value.content\n );\n\n const route = useRoute();\n const { refresh } = storeToRefs(useAppStore());\n const {\n tableRef,\n height,\n tableVisible,\n playTableHeight\n } = useTableHeight();\n const { formRef } = useForm();\n useReload();\n // 使用 computed 来动态计算样式\n const maskDivStyle = computed(() => {\n return css`\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n z-index: 1;\n background: white;\n display: ${tableVisible.value ? \"block\" : \"none\"};\n `;\n });\n\n const tableWrapperStyle = css`\n position: absolute;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n overflow: hidden;\n `;\n\n const cardStyle = css`\n box-shadow: none !important;\n `;\n\n const leftCardStyle = css`\n .ant-card-body {\n overflow-y: scroll;\n -ms-overflow-style: none; /* 对 IE 和 Edge 生效 */\n scrollbar-width: none; /* 对 Firefox 生效 */\n\n /* Webkit 浏览器 */\n\n ::-webkit-scrollbar {\n display: none;\n }\n }\n `;\n\n const listStyle = computed(\n () => css`\n padding: 10px;\n height: 100%;\n //height: calc(100vh - 44px);\n `\n );\n\n onMounted(() => {\n playTableHeight();\n });\n\n function useTableHeight() {\n const tableRef = ref();\n const height = ref(0);\n const tableVisible = ref(false);\n\n // 使用 ResizeObserver 响应式监听容器大小变化\n const containerEl = computed(() => tableRef.value?.$el);\n const { height: containerHeight } = useElementSize(containerEl);\n\n // 监听容器高度变化\n watch(\n containerHeight,\n newHeight => {\n if (newHeight > 0) {\n height.value = newHeight;\n }\n },\n { immediate: true }\n );\n\n function playTableHeight() {\n nextTick(() => {\n const el = tableRef.value?.$el;\n if (el && el.offsetHeight > 0) {\n height.value = el.offsetHeight;\n }\n });\n }\n\n return {\n tableRef,\n height,\n tableVisible,\n playTableHeight\n };\n }\n\n function useForm() {\n const formRef = ref<{ $el: HTMLElement } | null>(null);\n\n // 使用 computed 获取 DOM 元素,解决 useElementSize 需要监听 DOM 的问题\n const formEl = computed(() => formRef.value?.$el);\n const { height: formHeight } = useElementSize(formEl);\n\n watch(\n () => formHeight.value,\n () => {\n nextTick(() => {\n playTableHeight();\n });\n }\n );\n\n return {\n formRef\n };\n }\n\n // 处理标签重载\n function useReload() {\n let stopHandleWatch: WatchStopHandle;\n if (!route.name && !route.meta.keepAlive) {\n stopHandleWatch = _useWatch();\n // 卸载未缓存的组件\n onUnmounted(() => {\n stopHandleWatch?.();\n });\n } else {\n // 激活缓存页面\n onActivated(() => {\n if (refresh.value) {\n refresh.value = false;\n emit(\"refresh\");\n }\n stopHandleWatch = _useWatch();\n });\n // 离开缓存页面\n onDeactivated(() => {\n stopHandleWatch?.();\n });\n }\n\n function _useWatch() {\n //点击了标签重载图标\n return watch(\n () => refresh.value,\n val => {\n if (val) {\n // 发送刷新事件到列表页面\n emit(\"refresh\");\n }\n }\n );\n }\n }\n\n function useLayout() {\n function formLayout() {\n return () =>\n slots.form && (\n <Card\n class={cardStyle}\n ref={formRef}\n style={{ marginBottom: \"10px\" }}\n bodyStyle={{ padding: \"10px 10px 0 10px\" }}\n bordered={false}\n >\n {slots.form()}\n </Card>\n );\n }\n\n function tableLayout() {\n return () => (\n <Flex flex={1} vertical={true}>\n <Card\n class={cardStyle}\n style={{ height: \"100%\" }}\n bodyStyle={{\n height: \"100%\",\n padding: \"10px\"\n }}\n bordered={false}\n >\n <Flex\n style={{ height: \"100%\" }}\n vertical={true}\n >\n <Space style={{ marginBottom: \"6px\" }}>\n {slots.tools?.()}\n </Space>\n <Flex\n ref={tableRef}\n flex={1}\n style={{ height: \"100%\" }}\n vertical={true}\n >\n <div class={tableRootStyle}>\n <div class={maskDivStyle.value}></div>\n <div class={tableWrapperStyle}>\n {slots.table?.({\n height: height.value\n })}\n </div>\n </div>\n </Flex>\n </Flex>\n </Card>\n </Flex>\n );\n }\n\n return (\n <Watermark\n style={{ height: \"100%\" }}\n content={watermarkContent.value}\n >\n <Flex\n class={[listStyle.value, \"app-list\"]}\n gap={10}\n >\n {slots.left ? (\n <Card\n class={[cardStyle, leftCardStyle]}\n bordered={false}\n bodyStyle={{\n height: \"100%\",\n padding: \"10px\"\n }}\n >\n {slots.left?.()}\n </Card>\n ) : null}\n <Flex vertical={true} flex={1}>\n {formLayout()()}\n {tableLayout()()}\n </Flex>\n </Flex>\n {slots.extra?.()}\n </Watermark>\n );\n }\n\n return () => {\n const deviceStore = useDeviceStore();\n // 使用 storeToRefs 解构出响应式引用\n const { isMobile, isTablet, isDesktop } =\n storeToRefs(deviceStore);\n\n if (isMobile.value) {\n return (\n <MobileList>\n {{\n table: () => slots.table?.()\n }}\n </MobileList>\n );\n }\n\n if (isDesktop.value || isTablet.value) {\n return useLayout();\n }\n };\n }\n});\n\nexport default list;\n"],"names":["_isSlot","s","Object","prototype","toString","call","_isVNode","tableRootStyle","css","list","defineComponent","name","emits","setup","_","slots","emit","appContext","inject","AppContextKey","watermarkContent","computed","value","content","route","useRoute","refresh","storeToRefs","useAppStore","tableRef","height","tableVisible","playTableHeight","useTableHeight","formRef","useForm","useReload","maskDivStyle","tableWrapperStyle","cardStyle","leftCardStyle","listStyle","onMounted","ref","containerEl","$el","containerHeight","useElementSize","watch","newHeight","immediate","nextTick","el","offsetHeight","formEl","formHeight","stopHandleWatch","meta","keepAlive","_useWatch","onUnmounted","onActivated","onDeactivated","val","useLayout","formLayout","_slot","form","_createVNode","Card","marginBottom","padding","default","tableLayout","Flex","Space","tools","table","Watermark","left","_a","extra","deviceStore","useDeviceStore","isMobile","isTablet","isDesktop","MobileList"],"mappings":";;;;;;;;;;;;;;;AA0BmC,SAAAA,QAAAC,CAAAA,EAAA;AAAA,EAAA,OAAA,OAAAA,CAAAA,KAAA,UAAA,IAAAC,MAAAA,CAAAC,SAAAA,CAAAC,QAAAA,CAAAC,IAAAA,CAAAJ,CAAA,CAAA,KAAA,iBAAA,IAAA,CAAAK,WAAAA,CAAAL,CAAA,CAAA;AAAA;AAEnC,MAAMM,cAAAA,GAAiBC,OAAAA;AAAAA;AAAAA;AAAAA;AAAAA,CAAAA;AAMvB,MAAMC,uBAAOC,mBAAAA,CAAgB;AAAA,EAC3BC,IAAAA,EAAM,aAAA;AAAA,EACNC,KAAAA,EAAO,CAAC,SAAS,CAAA;AAAA,EACjBC,MAAMC,CAAAA,EAAG;AAAA,IAAEC,KAAAA;AAAAA,IAAOC;AAAAA,GAAK,EAAG;AACxB,IAAA,MAAMC,UAAAA,GAAaC,UAAAA,CACjBC,wBAAAA,EACA,IACF,CAAA;AAEA,IAAA,MAAMC,gBAAAA,GAAmBC,aACvB,MAAA;AA5CN,MAAA,IAAA,EAAA;AA4CYJ,MAAAA,OAAAA,CAAAA,EAAAA,GAAAA,UAAAA,IAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,UAAAA,CAAYG,gBAAAA,KAAZH,mBAA8BK,KAAAA,CAAMC,OAAAA;AAAAA,IAAAA,CAC5C,CAAA;AAEA,IAAA,MAAMC,QAAQC,kBAAAA,EAAS;AACvB,IAAA,MAAM;AAAA,MAAEC;AAAAA,KAAQ,GAAIC,iBAAAA,CAAYC,iBAAAA,EAAa,CAAA;AAC7C,IAAA,MAAM;AAAA,MACJC,QAAAA;AAAAA,MACAC,MAAAA;AAAAA,MACAC,YAAAA;AAAAA,MACAC;AAAAA,QACEC,cAAAA,EAAe;AACnB,IAAA,MAAM;AAAA,MAAEC;AAAAA,QAAYC,OAAAA,EAAQ;AAC5BC,IAAAA,SAAAA,EAAU;AAEV,IAAA,MAAMC,YAAAA,GAAehB,aAAS,MAAM;AAClC,MAAA,OAAOb,OAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,iBAAAA,EAQMuB,YAAAA,CAAaT,KAAAA,GAAQ,OAAA,GAAU,MAAM,CAAA;AAAA,MAAA,CAAA;AAAA,IAEpD,CAAC,CAAA;AAED,IAAA,MAAMgB,iBAAAA,GAAoB9B,OAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAAAA,CAAAA;AAS1B,IAAA,MAAM+B,SAAAA,GAAY/B,OAAAA;AAAAA;AAAAA,IAAAA,CAAAA;AAIlB,IAAA,MAAMgC,aAAAA,GAAgBhC,OAAAA;AAAAA;AAAAA;AAAAA;AAAAA;;AAAAA;;AAAAA;AAAAA;AAAAA;AAAAA;AAAAA,IAAAA,CAAAA;AActB,IAAA,MAAMiC,SAAAA,GAAYpB,aAChB,MAAMb,OAAAA;AAAAA;AAAAA;AAAAA;AAAAA,MAAAA,CAKR,CAAA;AAEAkC,IAAAA,aAAAA,CAAU,MAAM;AACdV,MAAAA,eAAAA,EAAgB;AAAA,IAClB,CAAC,CAAA;AAED,IAAA,SAASC,cAAAA,GAAiB;AACxB,MAAA,MAAMJ,YAAWc,OAAAA,EAAI;AACrB,MAAA,MAAMb,OAAAA,GAASa,QAAI,CAAC,CAAA;AACpB,MAAA,MAAMZ,aAAAA,GAAeY,QAAI,KAAK,CAAA;AAG9B,MAAA,MAAMC,WAAAA,GAAcvB,aAAS,MAAA;AApHnC,QAAA,IAAA,EAAA;AAoHyCQ,QAAAA,OAAAA,CAAAA,EAAAA,GAAAA,SAAAA,CAASP,UAATO,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAgBgB,GAAAA;AAAAA,MAAAA,CAAG,CAAA;AACtD,MAAA,MAAM;AAAA,QAAEf,MAAAA,EAAQgB;AAAAA,OAAgB,GAAIC,oBAAeH,WAAW,CAAA;AAG9DI,MAAAA,SAAAA,CACEF,iBACAG,CAAAA,SAAAA,KAAa;AACX,QAAA,IAAIA,YAAY,CAAA,EAAG;AACjBnB,UAAAA,QAAOR,KAAAA,GAAQ2B,SAAAA;AAAAA,QACjB;AAAA,MACF,CAAA,EACA;AAAA,QAAEC,SAAAA,EAAW;AAAA,OACf,CAAA;AAEA,MAAA,SAASlB,gBAAAA,GAAkB;AACzBmB,QAAAA,YAAAA,CAAS,MAAM;AAnIvB,UAAA,IAAA,EAAA;AAoIU,UAAA,MAAMC,EAAAA,GAAAA,CAAKvB,EAAAA,GAAAA,SAAAA,CAASP,KAAAA,KAATO,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAgBgB,GAAAA;AAC3B,UAAA,IAAIO,EAAAA,IAAMA,EAAAA,CAAGC,YAAAA,GAAe,CAAA,EAAG;AAC7BvB,YAAAA,OAAAA,CAAOR,QAAQ8B,EAAAA,CAAGC,YAAAA;AAAAA,UACpB;AAAA,QACF,CAAC,CAAA;AAAA,MACH;AAEA,MAAA,OAAO;AAAA,QACLxB,QAAAA,EAAAA,SAAAA;AAAAA,QACAC,MAAAA,EAAAA,OAAAA;AAAAA,QACAC,YAAAA,EAAAA,aAAAA;AAAAA,QACAC,eAAAA,EAAAA;AAAAA,OACF;AAAA,IACF;AAEA,IAAA,SAASG,OAAAA,GAAU;AACjB,MAAA,MAAMD,QAAAA,GAAUS,QAAiC,IAAI,CAAA;AAGrD,MAAA,MAAMW,MAAAA,GAASjC,aAAS,MAAA;AAvJ9B,QAAA,IAAA,EAAA;AAuJoCa,QAAAA,OAAAA,CAAAA,EAAAA,GAAAA,QAAAA,CAAQZ,UAARY,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAeW,GAAAA;AAAAA,MAAAA,CAAG,CAAA;AAChD,MAAA,MAAM;AAAA,QAAEf,MAAAA,EAAQyB;AAAAA,OAAW,GAAIR,oBAAeO,MAAM,CAAA;AAEpDN,MAAAA,SAAAA,CACE,MAAMO,UAAAA,CAAWjC,KAAAA,EACjB,MAAM;AACJ6B,QAAAA,YAAAA,CAAS,MAAM;AACbnB,UAAAA,eAAAA,EAAgB;AAAA,QAClB,CAAC,CAAA;AAAA,MACH,CACF,CAAA;AAEA,MAAA,OAAO;AAAA,QACLE,OAAAA,EAAAA;AAAAA,OACF;AAAA,IACF;AAGA,IAAA,SAASE,SAAAA,GAAY;AACnB,MAAA,IAAIoB,eAAAA;AACJ,MAAA,IAAI,CAAChC,KAAAA,CAAMb,IAAAA,IAAQ,CAACa,KAAAA,CAAMiC,KAAKC,SAAAA,EAAW;AACxCF,QAAAA,eAAAA,GAAkBG,SAAAA,EAAU;AAE5BC,QAAAA,eAAAA,CAAY,MAAM;AAChBJ,UAAAA,eAAAA,IAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,eAAAA,EAAAA;AAAAA,QACF,CAAC,CAAA;AAAA,MACH,CAAA,MAAO;AAELK,QAAAA,eAAAA,CAAY,MAAM;AAChB,UAAA,IAAInC,QAAQJ,KAAAA,EAAO;AACjBI,YAAAA,OAAAA,CAAQJ,KAAAA,GAAQ,KAAA;AAChBN,YAAAA,IAAAA,CAAK,SAAS,CAAA;AAAA,UAChB;AACAwC,UAAAA,eAAAA,GAAkBG,SAAAA,EAAU;AAAA,QAC9B,CAAC,CAAA;AAEDG,QAAAA,iBAAAA,CAAc,MAAM;AAClBN,UAAAA,eAAAA,IAAAA,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,eAAAA,EAAAA;AAAAA,QACF,CAAC,CAAA;AAAA,MACH;AAEA,MAAA,SAASG,SAAAA,GAAY;AAEnB,QAAA,OAAOX,SAAAA,CACL,MAAMtB,OAAAA,CAAQJ,KAAAA,EACdyC,CAAAA,GAAAA,KAAO;AACL,UAAA,IAAIA,GAAAA,EAAK;AAEP/C,YAAAA,IAAAA,CAAK,SAAS,CAAA;AAAA,UAChB;AAAA,QACF,CACF,CAAA;AAAA,MACF;AAAA,IACF;AAEA,IAAA,SAASgD,SAAAA,GAAY;AACnB,MAAA,SAASC,UAAAA,GAAa;AACpB,QAAA,OAAO,MAAA;AAAA,UAAA,IAAAC,KAAAA;AAAA,UAAA,OACLnD,KAAAA,CAAMoD,IAAAA,IAAIC,eAAAA,CAAAC,iBAAAA,EAAA;AAAA,YAAA,OAAA,EAEC9B,SAAAA;AAAAA,YAAS,KAAA,EACXL,OAAAA;AAAAA,YAAO,OAAA,EACL;AAAA,cAAEoC,YAAAA,EAAc;AAAA,aAAO;AAAA,YAAC,WAAA,EACpB;AAAA,cAAEC,OAAAA,EAAS;AAAA,aAAmB;AAAA,YAAC,UAAA,EAChC;AAAA,aAAKvE,OAAAA,CAAAkE,KAAAA,GAEdnD,MAAMoD,IAAAA,EAAM,IAAAD,KAAAA,GAAA;AAAA,YAAAM,OAAAA,EAAAA,MAAA,CAAAN,KAAA;AAAA,WAAA,CAAA;AAAA,QAEhB,CAAA;AAAA,MACL;AAEA,MAAA,SAASO,WAAAA,GAAc;AACrB,QAAA,OAAO,MAAAL,gBAAAM,iBAAAA,EAAA;AAAA,UAAA,MAAA,EACO,CAAA;AAAA,UAAC,UAAA,EAAY;AAAA,SAAI,EAAA;AAAA,UAAAF,OAAAA,EAAAA,MAAA,CAAAJ,eAAAA,CAAAC,iBAAAA,EAAA;AAAA,YAAA,OAAA,EAElB9B,SAAAA;AAAAA,YAAS,OAAA,EACT;AAAA,cAAET,MAAAA,EAAQ;AAAA,aAAO;AAAA,YAAC,WAAA,EACd;AAAA,cACTA,MAAAA,EAAQ,MAAA;AAAA,cACRyC,OAAAA,EAAS;AAAA,aACX;AAAA,YAAC,UAAA,EACS;AAAA,WAAK,EAAA;AAAA,YAAAC,OAAAA,EAAAA,MAAA,CAAAJ,eAAAA,CAAAM,iBAAAA,EAAA;AAAA,cAAA,OAAA,EAGN;AAAA,gBAAE5C,MAAAA,EAAQ;AAAA,eAAO;AAAA,cAAC,UAAA,EACf;AAAA,aAAI,EAAA;AAAA,cAAA0C,OAAAA,EAAAA,MAAA,CAAAJ,eAAAA,CAAAO,kBAAAA,EAAA;AAAA,gBAAA,OAAA,EAEA;AAAA,kBAAEL,YAAAA,EAAc;AAAA;AAAM,eAAC,EAAA;AAAA,gBAAAE,SAAAA,MAAA;AA9OrD,kBAAA,IAAA,EAAA;AA8OqD,kBAAA,OAAA,CAAA,CAClCzD,EAAAA,GAAAA,KAAAA,CAAM6D,UAAN7D,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAe,CAAA;AAAA,gBAAA;AAAA,eAAA,CAAA,EAAAqD,eAAAA,CAAAM,iBAAAA,EAAA;AAAA,gBAAA,KAAA,EAGX7C,QAAAA;AAAAA,gBAAQ,MAAA,EACP,CAAA;AAAA,gBAAC,OAAA,EACA;AAAA,kBAAEC,MAAAA,EAAQ;AAAA,iBAAO;AAAA,gBAAC,UAAA,EACf;AAAA,eAAI,EAAA;AAAA,gBAAA0C,SAAAA,MAAA;AArPhC,kBAAA,IAAA,EAAA;AAqPgC,kBAAA,OAAA,CAAAJ,gBAAA,KAAA,EAAA;AAAA,oBAAA,OAAA,EAEF7D;AAAAA,mBAAc,EAAA,CAAA6D,eAAAA,CAAA,KAAA,EAAA;AAAA,oBAAA,SACZ/B,YAAAA,CAAaf;AAAAA,mBAAK,EAAA,IAAA,CAAA,EAAA8C,eAAAA,CAAA,KAAA,EAAA;AAAA,oBAAA,OAAA,EAClB9B;AAAAA,mBAAiB,EAAA,CAAA,CAC1BvB,EAAAA,GAAAA,KAAAA,CAAM8D,KAAAA,KAAN9D,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,EAAc;AAAA,oBACbe,QAAQA,MAAAA,CAAOR;AAAAA,mBACjB,CAAE,CAAA,CAAA,CAAA,CAAA,CAAA;AAAA,gBAAA;AAAA,eAAA,CAAA;AAAA,aAAA,CAAA;AAAA,WAAA,CAAA;AAAA,SAAA,CAAA;AAAA,MAQlB;AAEA,MAAA,OAAA8C,gBAAAU,sBAAAA,EAAA;AAAA,QAAA,OAAA,EAEW;AAAA,UAAEhD,MAAAA,EAAQ;AAAA,SAAO;AAAA,QAAC,WAChBV,gBAAAA,CAAiBE;AAAAA,OAAK,EAAA;AAAA,QAAAkD,SAAAA,MAAA;AAzQzC,UAAA,IAAA,EAAA;AAyQyC,UAAA,OAAA,CAAAJ,gBAAAM,iBAAAA,EAAA;AAAA,YAAA,OAAA,EAGtB,CAACjC,SAAAA,CAAUnB,KAAAA,EAAO,UAAU,CAAA;AAAA,YAAC,KAAA,EAC/B;AAAA,WAAE,EAAA;AAAA,YAAAkD,SAAAA,MAAA,CAENzD,KAAAA,CAAMgE,IAAAA,GAAIX,gBAAAC,iBAAAA,EAAA;AAAA,cAAA,OAAA,EAEA,CAAC9B,SAAAA,EAAWC,aAAa,CAAA;AAAA,cAAC,UAAA,EACvB,KAAA;AAAA,cAAK,WAAA,EACJ;AAAA,gBACTV,MAAAA,EAAQ,MAAA;AAAA,gBACRyC,OAAAA,EAAS;AAAA;AACX,aAAC,EAAA;AAAA,cAAAC,SAAAA,MAAA;AAtRjB,gBAAA,IAAAQ,GAAAA;AAsRiB,gBAAA,OAAA,CAAA,CAEAjE,GAAAA,GAAAA,KAAAA,CAAMgE,IAAAA,KAANhE,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,IAAAA,IAAAA,CAAAA,KAAAA,CAAc,CAAA;AAAA,cAAA;AAAA,aAAA,CAAA,GAEf,IAAA,EAAIqD,eAAAA,CAAAM,iBAAAA,EAAA;AAAA,cAAA,UAAA,EACQ,IAAA;AAAA,cAAI,MAAA,EAAQ;AAAA,aAAC,EAAA;AAAA,cAAAF,OAAAA,EAAAA,MAAA,CAC1BP,UAAAA,IAAa,EACbQ,WAAAA,IAAe;AAAA,aAAA,CAAA;AAAA,WAAA,CAAA,EAAA,CAGnB1D,EAAAA,GAAAA,KAAAA,CAAMkE,KAAAA,KAANlE,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAe,CAAA;AAAA,QAAA;AAAA,OAAA,CAAA;AAAA,IAGtB;AAEA,IAAA,OAAO,MAAM;AACX,MAAA,MAAMmE,cAAcC,oBAAAA,EAAe;AAEnC,MAAA,MAAM;AAAA,QAAEC,QAAAA;AAAAA,QAAUC,QAAAA;AAAAA,QAAUC;AAAAA,OAAU,GACpC3D,kBAAYuD,WAAW,CAAA;AAEzB,MAAA,IAAIE,SAAS9D,KAAAA,EAAO;AAClB,QAAA,OAAA8C,eAAAA,CAAAmB,oBAAA,IAAA,EAAA;AAAA,UAGMV,OAAOA,MAAA;AA/SrB,YAAA,IAAA,EAAA;AA+S2B9D,YAAAA,OAAAA,CAAAA,EAAAA,GAAAA,KAAAA,CAAM8D,KAAAA,KAAN9D,IAAAA,GAAAA,KAAAA,CAAAA,GAAAA,EAAAA,CAAAA,IAAAA,CAAAA,KAAAA,CAAAA;AAAAA,UAAAA;AAAAA,SAAe,CAAA;AAAA,MAIpC;AAEA,MAAA,IAAIuE,SAAAA,CAAUhE,KAAAA,IAAS+D,QAAAA,CAAS/D,KAAAA,EAAO;AACrC,QAAA,OAAO0C,SAAAA,EAAU;AAAA,MACnB;AAAA,IACF,CAAA;AAAA,EACF;AACF,CAAC;;;;"}
1
+ {"version":3,"file":"List.cjs","sources":["../../../../src/components/layout/List.tsx"],"sourcesContent":["import {\r\n computed,\r\n defineComponent,\r\n inject,\r\n nextTick,\r\n onActivated,\r\n onDeactivated,\r\n onMounted,\r\n onUnmounted,\r\n ref,\r\n watch,\r\n type WatchStopHandle\r\n} from \"vue\";\r\nimport { useRoute } from \"vue-router\";\r\nimport {\r\n Card,\r\n Flex,\r\n Space,\r\n Watermark\r\n} from \"ant-design-vue\";\r\nimport { storeToRefs } from \"pinia\";\r\nimport { useElementSize } from \"@vueuse/core\";\r\n\r\nimport { AppContext, AppContextKey } from \"./AppContext\";\r\nimport MobileList from \"./components/mobile/MobileList\";\r\nimport { useAppStore, useDeviceStore } from \"@ditari/store\";\r\nimport { css } from \"@emotion/css\";\r\n\r\nconst tableRootStyle = css`\r\n height: 100%;\r\n position: relative;\r\n overflow: hidden;\r\n`;\r\n\r\nconst list = defineComponent({\r\n name: \"DListLayout\",\r\n emits: [\"refresh\"],\r\n setup(_, { slots, emit }) {\r\n const appContext = inject<AppContext | null>(\r\n AppContextKey,\r\n null\r\n );\r\n\r\n const watermarkContent = computed(\r\n () => appContext?.watermarkContent?.value.content\r\n );\r\n\r\n const route = useRoute();\r\n const { refresh } = storeToRefs(useAppStore());\r\n const {\r\n tableRef,\r\n height,\r\n tableVisible,\r\n playTableHeight\r\n } = useTableHeight();\r\n const { formRef } = useForm();\r\n useReload();\r\n // 使用 computed 来动态计算样式\r\n const maskDivStyle = computed(() => {\r\n return css`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n z-index: 1;\r\n background: white;\r\n display: ${tableVisible.value ? \"block\" : \"none\"};\r\n `;\r\n });\r\n\r\n const tableWrapperStyle = css`\r\n position: absolute;\r\n top: 0;\r\n right: 0;\r\n bottom: 0;\r\n left: 0;\r\n overflow: hidden;\r\n `;\r\n\r\n const cardStyle = css`\r\n box-shadow: none !important;\r\n `;\r\n\r\n const leftCardStyle = css`\r\n .ant-card-body {\r\n overflow-y: scroll;\r\n -ms-overflow-style: none; /* 对 IE 和 Edge 生效 */\r\n scrollbar-width: none; /* 对 Firefox 生效 */\r\n\r\n /* Webkit 浏览器 */\r\n\r\n ::-webkit-scrollbar {\r\n display: none;\r\n }\r\n }\r\n `;\r\n\r\n const listStyle = computed(\r\n () => css`\r\n padding: 10px;\r\n height: 100%;\r\n //height: calc(100vh - 44px);\r\n `\r\n );\r\n\r\n onMounted(() => {\r\n playTableHeight();\r\n });\r\n\r\n function useTableHeight() {\r\n const tableRef = ref();\r\n const height = ref(0);\r\n const tableVisible = ref(false);\r\n\r\n // 使用 ResizeObserver 响应式监听容器大小变化\r\n const containerEl = computed(() => tableRef.value?.$el);\r\n const { height: containerHeight } = useElementSize(containerEl);\r\n\r\n // 监听容器高度变化\r\n watch(\r\n containerHeight,\r\n newHeight => {\r\n if (newHeight > 0) {\r\n height.value = newHeight;\r\n }\r\n },\r\n { immediate: true }\r\n );\r\n\r\n function playTableHeight() {\r\n nextTick(() => {\r\n const el = tableRef.value?.$el;\r\n if (el && el.offsetHeight > 0) {\r\n height.value = el.offsetHeight;\r\n }\r\n });\r\n }\r\n\r\n return {\r\n tableRef,\r\n height,\r\n tableVisible,\r\n playTableHeight\r\n };\r\n }\r\n\r\n function useForm() {\r\n const formRef = ref<{ $el: HTMLElement } | null>(null);\r\n\r\n // 使用 computed 获取 DOM 元素,解决 useElementSize 需要监听 DOM 的问题\r\n const formEl = computed(() => formRef.value?.$el);\r\n const { height: formHeight } = useElementSize(formEl);\r\n\r\n watch(\r\n () => formHeight.value,\r\n () => {\r\n nextTick(() => {\r\n playTableHeight();\r\n });\r\n }\r\n );\r\n\r\n return {\r\n formRef\r\n };\r\n }\r\n\r\n // 处理标签重载\r\n function useReload() {\r\n let stopHandleWatch: WatchStopHandle;\r\n if (!route.name && !route.meta.keepAlive) {\r\n stopHandleWatch = _useWatch();\r\n // 卸载未缓存的组件\r\n onUnmounted(() => {\r\n stopHandleWatch?.();\r\n });\r\n } else {\r\n // 激活缓存页面\r\n onActivated(() => {\r\n if (refresh.value) {\r\n refresh.value = false;\r\n emit(\"refresh\");\r\n }\r\n stopHandleWatch = _useWatch();\r\n });\r\n // 离开缓存页面\r\n onDeactivated(() => {\r\n stopHandleWatch?.();\r\n });\r\n }\r\n\r\n function _useWatch() {\r\n //点击了标签重载图标\r\n return watch(\r\n () => refresh.value,\r\n val => {\r\n if (val) {\r\n // 发送刷新事件到列表页面\r\n emit(\"refresh\");\r\n }\r\n }\r\n );\r\n }\r\n }\r\n\r\n function useLayout() {\r\n function formLayout() {\r\n return () =>\r\n slots.form && (\r\n <Card\r\n class={cardStyle}\r\n ref={formRef}\r\n style={{ marginBottom: \"10px\" }}\r\n bodyStyle={{ padding: \"10px 10px 0 10px\" }}\r\n bordered={false}\r\n >\r\n {slots.form()}\r\n </Card>\r\n );\r\n }\r\n\r\n function tableLayout() {\r\n return () => (\r\n <Flex flex={1} vertical={true}>\r\n <Card\r\n class={cardStyle}\r\n style={{ height: \"100%\" }}\r\n bodyStyle={{\r\n height: \"100%\",\r\n padding: \"10px\"\r\n }}\r\n bordered={false}\r\n >\r\n <Flex\r\n style={{ height: \"100%\" }}\r\n vertical={true}\r\n >\r\n <Space style={{ marginBottom: \"6px\" }}>\r\n {slots.tools?.()}\r\n </Space>\r\n <Flex\r\n ref={tableRef}\r\n flex={1}\r\n style={{ height: \"100%\" }}\r\n vertical={true}\r\n >\r\n <div class={tableRootStyle}>\r\n <div class={maskDivStyle.value}></div>\r\n <div class={tableWrapperStyle}>\r\n {slots.table?.({\r\n height: height.value\r\n })}\r\n </div>\r\n </div>\r\n </Flex>\r\n </Flex>\r\n </Card>\r\n </Flex>\r\n );\r\n }\r\n\r\n return (\r\n <Watermark\r\n style={{ height: \"100%\" }}\r\n content={watermarkContent.value}\r\n >\r\n <Flex\r\n class={[listStyle.value, \"app-list\"]}\r\n gap={10}\r\n >\r\n {slots.left ? (\r\n <Card\r\n class={[cardStyle, leftCardStyle]}\r\n bordered={false}\r\n bodyStyle={{\r\n height: \"100%\",\r\n padding: \"10px\"\r\n }}\r\n >\r\n {slots.left?.()}\r\n </Card>\r\n ) : null}\r\n <Flex vertical={true} flex={1}>\r\n {formLayout()()}\r\n {tableLayout()()}\r\n </Flex>\r\n </Flex>\r\n {slots.extra?.()}\r\n </Watermark>\r\n );\r\n }\r\n\r\n return () => {\r\n const deviceStore = useDeviceStore();\r\n // 使用 storeToRefs 解构出响应式引用\r\n const { isMobile, isTablet, isDesktop } =\r\n storeToRefs(deviceStore);\r\n\r\n if (isMobile.value) {\r\n return (\r\n <MobileList>\r\n {{\r\n table: () => slots.table?.()\r\n }}\r\n </MobileList>\r\n );\r\n }\r\n\r\n if (isDesktop.value || isTablet.value) {\r\n return useLayout();\r\n }\r\n };\r\n }\r\n});\r\n\r\nexport default list;\r\n"],"names":["_isSlot","s","Object","prototype","toString","call","_isVNode","tableRootStyle","css","list","defineComponent","name","emits","setup","_","slots","emit","appContext","inject","AppContextKey","watermarkContent","computed","value","content","route","useRoute","refresh","storeToRefs","useAppStore","tableRef","height","tableVisible","playTableHeight","useTableHeight","formRef","useForm","useReload","maskDivStyle","tableWrapperStyle","cardStyle","leftCardStyle","listStyle","onMounted","ref","containerEl","$el","containerHeight","useElementSize","watch","newHeight","immediate","nextTick","el","offsetHeight","formEl","formHeight","stopHandleWatch","meta","keepAlive","_useWatch","onUnmounted","onActivated","onDeactivated","val","useLayout","formLayout","_slot","form","_createVNode","Card","marginBottom","padding","default","tableLayout","Flex","Space","tools","table","Watermark","left","_a","extra","deviceStore","useDeviceStore","isMobile","isTablet","isDesktop","MobileList"],"mappings":"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"}