@ibiz-template/vue3-components 0.7.12 → 0.7.13

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 (73) hide show
  1. package/dist/index-5IjaPupj.js +4 -0
  2. package/dist/index.min.css +1 -1
  3. package/dist/index.system.min.js +1 -1
  4. package/dist/{xlsx-util-Zf9d2PeX.js → xlsx-util-8i01yifN.js} +1 -1
  5. package/es/control/app-menu/app-menu.mjs +1 -1
  6. package/es/control/context-menu/context-menu.css +1 -1
  7. package/es/control/context-menu/context-menu.d.ts +1 -0
  8. package/es/control/context-menu/context-menu.mjs +63 -6
  9. package/es/control/context-menu/index.d.ts +1 -0
  10. package/es/control/form/form/form.css +1 -1
  11. package/es/control/form/form-detail/form-page/form-page.css +1 -1
  12. package/es/control/form/form-detail/form-page/form-page.d.ts +1 -0
  13. package/es/control/form/form-detail/form-page/form-page.mjs +10 -4
  14. package/es/control/form/form-detail/form-page/index.d.ts +1 -0
  15. package/es/control/toolbar/export-excel/export-excel.css +1 -1
  16. package/es/control/toolbar/short-cut-button/short-cut-button.css +0 -0
  17. package/es/control/toolbar/short-cut-button/short-cut-button.d.ts +48 -0
  18. package/es/control/toolbar/short-cut-button/short-cut-button.mjs +71 -0
  19. package/es/control/toolbar/toolbar.mjs +11 -0
  20. package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.css +1 -1
  21. package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.d.ts +1 -0
  22. package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.mjs +15 -3
  23. package/es/index.mjs +1 -0
  24. package/es/panel-component/auth-captcha/auth-captcha.controller.d.ts +20 -0
  25. package/es/panel-component/auth-captcha/auth-captcha.controller.mjs +70 -16
  26. package/es/panel-component/auth-captcha/auth-captcha.css +1 -1
  27. package/es/panel-component/auth-captcha/auth-captcha.d.ts +1 -0
  28. package/es/panel-component/auth-captcha/auth-captcha.mjs +12 -3
  29. package/es/panel-component/auth-captcha/auth-captcha.state.d.ts +7 -0
  30. package/es/panel-component/auth-captcha/auth-captcha.state.mjs +7 -0
  31. package/es/panel-component/auth-captcha/index.d.ts +1 -0
  32. package/es/panel-component/auth-userinfo/auth-userinfo.d.ts +1 -1
  33. package/es/panel-component/auth-userinfo/auth-userinfo.mjs +2 -7
  34. package/es/panel-component/auth-userinfo/index.d.ts +1 -1
  35. package/es/panel-component/panel-button/panel-button.controller.mjs +7 -1
  36. package/es/panel-component/short-cut/index.d.ts +21 -4
  37. package/es/panel-component/short-cut/short-cut.css +1 -1
  38. package/es/panel-component/short-cut/short-cut.d.ts +21 -4
  39. package/es/panel-component/short-cut/short-cut.mjs +45 -28
  40. package/es/util/app-util/app-util.d.ts +90 -0
  41. package/es/util/app-util/app-util.mjs +152 -0
  42. package/es/util/index.d.ts +1 -0
  43. package/es/util/index.mjs +1 -0
  44. package/es/view-engine/login-view.engine.d.ts +3 -1
  45. package/es/view-engine/login-view.engine.mjs +4 -3
  46. package/es/web-app/main.mjs +2 -0
  47. package/lib/control/app-menu/app-menu.cjs +1 -1
  48. package/lib/control/context-menu/context-menu.cjs +63 -6
  49. package/lib/control/context-menu/context-menu.css +1 -1
  50. package/lib/control/form/form/form.css +1 -1
  51. package/lib/control/form/form-detail/form-page/form-page.cjs +10 -4
  52. package/lib/control/form/form-detail/form-page/form-page.css +1 -1
  53. package/lib/control/toolbar/export-excel/export-excel.css +1 -1
  54. package/lib/control/toolbar/short-cut-button/short-cut-button.cjs +73 -0
  55. package/lib/control/toolbar/short-cut-button/short-cut-button.css +0 -0
  56. package/lib/control/toolbar/toolbar.cjs +11 -0
  57. package/lib/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.cjs +14 -2
  58. package/lib/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.css +1 -1
  59. package/lib/index.cjs +2 -0
  60. package/lib/panel-component/auth-captcha/auth-captcha.cjs +12 -3
  61. package/lib/panel-component/auth-captcha/auth-captcha.controller.cjs +70 -16
  62. package/lib/panel-component/auth-captcha/auth-captcha.css +1 -1
  63. package/lib/panel-component/auth-captcha/auth-captcha.state.cjs +7 -0
  64. package/lib/panel-component/auth-userinfo/auth-userinfo.cjs +2 -7
  65. package/lib/panel-component/panel-button/panel-button.controller.cjs +7 -1
  66. package/lib/panel-component/short-cut/short-cut.cjs +44 -27
  67. package/lib/panel-component/short-cut/short-cut.css +1 -1
  68. package/lib/util/app-util/app-util.cjs +154 -0
  69. package/lib/util/index.cjs +2 -0
  70. package/lib/view-engine/login-view.engine.cjs +4 -3
  71. package/lib/web-app/main.cjs +2 -0
  72. package/package.json +4 -4
  73. package/dist/index-3xonNDdv.js +0 -4
@@ -278,7 +278,7 @@ const AppMenuControl = /* @__PURE__ */ defineComponent({
278
278
  "onSelect": this.onClick,
279
279
  "theme": "light",
280
280
  "mode": this.menuMode,
281
- "ellipsis": false
281
+ "ellipsis": this.menuMode === "horizontal"
282
282
  }, _isSlot(_slot = this.menus.map((item) => {
283
283
  var _a;
284
284
  if (((_a = item.children) == null ? void 0 : _a.length) > 0) {
@@ -1 +1 @@
1
- @charset "UTF-8";.ibiz-context-menu{--ibiz-context-menu-item-margin:0 0 0 4px;--ibiz-context-menu-separator-height:20px;--ibiz-context-menu-separator-width:2px;--ibiz-context-menu-separator-color:var(--ibiz-color-border);--ibiz-context-menu-popover-padding:8px 0;--ibiz-context-menu-popover-button-padding:8px 20px;--ibiz-context-menu-popover-button-color:var(--ibiz-color-text-2);--ibiz-context-menu-popover-button-hover-bg:var(--ibiz-color-bg-0)}.ibiz-context-menu__item{padding:var(--ibiz-spacing-extra-tight) 0}.ibiz-context-menu__item+.ibiz-context-menu__item{margin:var(--ibiz-context-menu-item-margin)}.ibiz-context-menu__item .ibiz-context-menu__action-content-icon{margin-right:3px}.ibiz-context-menu__action-content{display:flex}.ibiz-context-menu__action-content-icon{display:flex;align-items:center;justify-content:center;width:20px}.ibiz-context-menu__action-content-caption{display:flex;align-items:center;justify-content:center}.ibiz-context-menu__popover{--ibiz-context-menu-item-margin:0 0 0 4px;--ibiz-context-menu-separator-height:20px;--ibiz-context-menu-separator-width:2px;--ibiz-context-menu-separator-color:var(--ibiz-color-border);--ibiz-context-menu-popover-padding:8px 0;--ibiz-context-menu-popover-button-padding:8px 20px;--ibiz-context-menu-popover-button-color:var(--ibiz-color-text-2);--ibiz-context-menu-popover-button-hover-bg:var(--ibiz-color-bg-0);width:auto!important;min-width:150px;--el-popover-padding:var(--ibiz-context-menu-popover-padding)}.ibiz-context-menu__popover .el-button{--el-button-size:40px;display:block;width:100%;padding:var(--ibiz-context-menu-popover-button-padding);margin:0;font-size:14px;color:var(--ibiz-context-menu-popover-button-color);text-align:left;border-radius:0}.ibiz-context-menu__popover .el-button:hover{background-color:var(--ibiz-context-menu-popover-button-hover-bg)}.ibiz-context-menu__popover .el-button .ibiz-context-menu__action-content-icon{margin-right:6px}.ibiz-context-menu__separator{margin:0}.ibiz-context-menu--dropdown .ibiz-context-menu__caption{cursor:pointer}.ibiz-context-menu--dropdown .ibiz-context-menu__caption-icon{vertical-align:bottom}
1
+ @charset "UTF-8";.ibiz-context-menu{--ibiz-context-menu-item-margin:0 0 0 4px;--ibiz-context-menu-separator-height:20px;--ibiz-context-menu-separator-width:2px;--ibiz-context-menu-separator-color:var(--ibiz-color-border);--ibiz-context-menu-popover-padding:8px 0;--ibiz-context-menu-popover-button-padding:8px 20px;--ibiz-context-menu-popover-button-color:var(--ibiz-color-text-2);--ibiz-context-menu-popover-button-hover-bg:var(--ibiz-color-bg-0)}.ibiz-context-menu__item{padding:var(--ibiz-spacing-extra-tight) 0}.ibiz-context-menu__item+.ibiz-context-menu__item{margin:var(--ibiz-context-menu-item-margin)}.ibiz-context-menu__item .ibiz-context-menu__action-content-icon{margin-right:3px}.ibiz-context-menu__action-content{display:flex}.ibiz-context-menu__action-content-icon{display:flex;align-items:center;justify-content:center;width:20px}.ibiz-context-menu__action-content-caption{display:flex;align-items:center;justify-content:center}.ibiz-context-menu__popover{--ibiz-context-menu-item-margin:0 0 0 4px;--ibiz-context-menu-separator-height:20px;--ibiz-context-menu-separator-width:2px;--ibiz-context-menu-separator-color:var(--ibiz-color-border);--ibiz-context-menu-popover-padding:8px 0;--ibiz-context-menu-popover-button-padding:8px 20px;--ibiz-context-menu-popover-button-color:var(--ibiz-color-text-2);--ibiz-context-menu-popover-button-hover-bg:var(--ibiz-color-bg-0);width:auto!important;min-width:150px;--el-popover-padding:var(--ibiz-context-menu-popover-padding)}.ibiz-context-menu__popover .el-button{--el-button-size:40px;display:block;width:100%;padding:var(--ibiz-context-menu-popover-button-padding);margin:0;font-size:14px;color:var(--ibiz-context-menu-popover-button-color);text-align:left;border-radius:0}.ibiz-context-menu__popover .el-button:hover{background-color:var(--ibiz-context-menu-popover-button-hover-bg)}.ibiz-context-menu__popover .el-button .ibiz-context-menu__action-content-icon{margin-right:6px}.ibiz-context-menu__popover .el-button .ibiz-context-menu__action-content-group-caption{margin-right:var(--ibiz-spacing-base-loose)}.ibiz-context-menu__popover .el-button .ibiz-context-menu__action-content-group-icon{position:absolute;right:var(--ibiz-spacing-base-loose);font-size:var(--ibiz-font-size-header-6)}.ibiz-context-menu__separator{margin:0}.ibiz-context-menu__separator.el-divider--horizontal{width:calc(100% - 2 * var(--ibiz-spacing-base-loose));margin:var(--ibiz-spacing-extra-tight) var(--ibiz-spacing-base-loose)}.ibiz-context-menu--dropdown .ibiz-context-menu__caption{cursor:pointer}.ibiz-context-menu--dropdown .ibiz-context-menu__caption-icon{vertical-align:bottom}
@@ -37,6 +37,7 @@ export declare const ContextMenuControl: import("vue").DefineComponent<{
37
37
  expandDetails: Ref<IDETBUIActionItem[]>;
38
38
  groupDetails: Ref<IDETBUIActionItem[]>;
39
39
  groupButtonRef: Ref<any>;
40
+ dropdownRef: Ref<any>;
40
41
  popoverVisible: Ref<boolean>;
41
42
  handleClick: (detail: IDETBUIActionItem, e: MouseEvent) => Promise<void>;
42
43
  calcActionItemClass: (item: IDETBUIActionItem) => string[];
@@ -53,18 +53,26 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
53
53
  const expandDetails = ref([]);
54
54
  const groupDetails = ref([]);
55
55
  const groupButtonRef = ref();
56
+ const dropdownRef = ref();
56
57
  const popoverVisible = ref(false);
57
- if (actionDetails) {
58
- actionDetails == null ? void 0 : actionDetails.forEach((detail) => {
58
+ const transformLanguage = (items) => {
59
+ if (!Array.isArray(items)) {
60
+ return;
61
+ }
62
+ items.forEach((detail) => {
59
63
  if (detail.capLanguageRes && detail.capLanguageRes.lanResTag) {
60
64
  detail.caption = ibiz.i18n.t(detail.capLanguageRes.lanResTag, detail.caption);
61
65
  }
62
66
  if (detail.tooltipLanguageRes && detail.tooltipLanguageRes.lanResTag) {
63
67
  detail.tooltip = ibiz.i18n.t(detail.tooltipLanguageRes.lanResTag, detail.tooltip);
64
68
  }
69
+ transformLanguage(detail.detoolbarItems);
65
70
  });
71
+ };
72
+ if (actionDetails) {
73
+ transformLanguage(actionDetails);
66
74
  actionDetails.forEach((detail) => {
67
- if (props.groupLevelKeys.findIndex((item) => item === detail.actionLevel) !== -1) {
75
+ if (!detail.actionLevel || props.groupLevelKeys.findIndex((item) => item === detail.actionLevel) !== -1) {
68
76
  groupDetails.value.push(detail);
69
77
  } else {
70
78
  expandDetails.value.push(detail);
@@ -86,7 +94,13 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
86
94
  await c.calcButtonState(props.nodeData._deData || (props.nodeData.srfkey ? props.nodeData : void 0), props.nodeModel.appDataEntityId);
87
95
  });
88
96
  const handleClick = async (detail, e) => {
97
+ if (props.mode === "buttons") {
98
+ popoverVisible.value = false;
99
+ } else if (dropdownRef.value) {
100
+ dropdownRef.value.handleClose();
101
+ }
89
102
  e.stopPropagation();
103
+ popoverVisible.value = false;
90
104
  emit("action-click", detail, e);
91
105
  };
92
106
  return {
@@ -95,6 +109,7 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
95
109
  expandDetails,
96
110
  groupDetails,
97
111
  groupButtonRef,
112
+ dropdownRef,
98
113
  popoverVisible,
99
114
  handleClick,
100
115
  calcActionItemClass,
@@ -112,8 +127,14 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
112
127
  };
113
128
  const renderActions = (items, isExpand = true) => {
114
129
  return items.map((detail) => {
115
- var _a;
116
- if ((_a = this.c.state.buttonsState[detail.id]) == null ? void 0 : _a.visible) {
130
+ var _a, _b;
131
+ if (!((_a = this.c.state.buttonsState[detail.id]) == null ? void 0 : _a.visible)) {
132
+ return null;
133
+ }
134
+ if (detail.itemType === "SEPERATOR") {
135
+ return renderDivider(isExpand);
136
+ }
137
+ if (detail.itemType === "DEUIACTION" || detail.itemType === "ITEMS" && !((_b = detail.detoolbarItems) == null ? void 0 : _b.length)) {
117
138
  return [detail.addSeparator && renderDivider(isExpand), createVNode(resolveComponent("el-button"), {
118
139
  "text": true,
119
140
  "size": "small",
@@ -133,6 +154,40 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
133
154
  }, [detail.caption]) : ""])]
134
155
  })];
135
156
  }
157
+ if (detail.itemType === "ITEMS") {
158
+ return createVNode(resolveComponent("el-popover"), {
159
+ "placement": "right-start",
160
+ "popper-class": this.ns.e("popover"),
161
+ "teleported": false
162
+ }, {
163
+ reference: () => {
164
+ return [detail.addSeparator && renderDivider(isExpand), createVNode(resolveComponent("el-button"), {
165
+ "text": true,
166
+ "size": "small",
167
+ "onClick": (e) => this.handleClick(detail, e),
168
+ "title": detail.tooltip,
169
+ "disabled": this.c.state.buttonsState[detail.id].disabled,
170
+ "class": this.calcActionItemClass(detail)
171
+ }, {
172
+ default: () => [createVNode("div", {
173
+ "class": this.ns.e("action-content")
174
+ }, [detail.showIcon && detail.sysImage && createVNode("div", {
175
+ "class": this.ns.e("action-content-icon")
176
+ }, [createVNode(resolveComponent("iBizIcon"), {
177
+ "icon": detail.sysImage
178
+ }, null)]), detail.showCaption ? createVNode("div", {
179
+ "class": [this.ns.e("action-content-caption"), this.ns.e("action-content-group-caption")]
180
+ }, [detail.caption]) : "", createVNode("ion-icon", {
181
+ "class": this.ns.e("action-content-group-icon"),
182
+ "name": "chevron-forward-outline"
183
+ }, null)])]
184
+ })];
185
+ },
186
+ default: () => {
187
+ return renderActions(detail.detoolbarItems || [], isExpand);
188
+ }
189
+ });
190
+ }
136
191
  return null;
137
192
  });
138
193
  };
@@ -158,12 +213,14 @@ const ContextMenuControl = /* @__PURE__ */ defineComponent({
158
213
  "visible": this.popoverVisible,
159
214
  "onUpdate:visible": ($event) => this.popoverVisible = $event,
160
215
  "popper-class": this.ns.e("popover"),
161
- "virtual-triggering": true
216
+ "virtual-triggering": true,
217
+ "transition": "none"
162
218
  }, _isSlot(_slot = renderActions(this.groupDetails, false)) ? _slot : {
163
219
  default: () => [_slot]
164
220
  })]]);
165
221
  }
166
222
  return createVNode(resolveComponent("el-dropdown"), {
223
+ "ref": "dropdownRef",
167
224
  "onCommand": (command) => this.handleClick(command, new MouseEvent("click")),
168
225
  "class": [this.ns.b(), this.ns.m("dropdown")]
169
226
  }, {
@@ -33,6 +33,7 @@ export declare const IBizContextMenuControl: import("@ibiz-template/vue3-util").
33
33
  expandDetails: import("vue").Ref<import("@ibiz/model-core").IDETBUIActionItem[]>;
34
34
  groupDetails: import("vue").Ref<import("@ibiz/model-core").IDETBUIActionItem[]>;
35
35
  groupButtonRef: import("vue").Ref<any>;
36
+ dropdownRef: import("vue").Ref<any>;
36
37
  popoverVisible: import("vue").Ref<boolean>;
37
38
  handleClick: (detail: import("@ibiz/model-core").IDETBUIActionItem, e: MouseEvent) => Promise<void>;
38
39
  calcActionItemClass: (item: import("@ibiz/model-core").IDETBUIActionItem) => string[];
@@ -1 +1 @@
1
- .ibiz-control-form{width:100%;padding-bottom:var(--ibiz-spacing-tight)}
1
+ .ibiz-control-form{width:100%;height:100%;padding-bottom:var(--ibiz-spacing-tight)}
@@ -1 +1 @@
1
- .ibiz-form-page{--ibiz-form-page-font-size:var(--ibiz-font-size-header-4);--ibiz-form-page-header-border-color:var(--ibiz-color-border);--ibiz-form-page-text-color:var(--ibiz-color-text-2);--ibiz-form-page-bg-color:transparent;--ibiz-form-page-hover-text-color:var(--ibiz-color-primary);--ibiz-form-page-hover-bg-color:transparent;--ibiz-form-page-active-text-color:var(--ibiz-color-primary);--ibiz-form-page-active-bg-color:transparent;--ibiz-form-page-active-border-color:var(--ibiz-color-primary)}.ibiz-form-page--no-tab-header .ibiz-form-page-item{padding-top:0}.ibiz-form-page-tab>.el-tabs__header.is-top{margin-bottom:var(--ibiz-spacing-tight)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top{font-size:var(--ibiz-form-page-font-size);color:var(--ibiz-form-page-text-color);background-color:var(--ibiz-form-page-bg-color)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top:hover{color:var(--ibiz-form-page-hover-text-color);background-color:var(--ibiz-form-page-hover-bg-color)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top.is-active{color:var(--ibiz-form-page-active-text-color);background-color:var(--ibiz-form-page-active-bg-color)}.ibiz-form-page-tab .el-tabs__nav-wrap::after{background-color:var(--ibiz-form-page-header-border-color)}.ibiz-form-page-tab .el-tabs__active-bar{background-color:var(--ibiz-form-page-active-border-color)}.ibiz-form-page-item{padding-top:var(--ibiz-padding-top)}.ibiz-form-page-item-child{margin-bottom:var(--ibiz-margin-bottom)}
1
+ .ibiz-form-page{--ibiz-form-page-font-size:var(--ibiz-font-size-header-4);--ibiz-form-page-header-border-color:var(--ibiz-color-border);--ibiz-form-page-text-color:var(--ibiz-color-text-2);--ibiz-form-page-bg-color:transparent;--ibiz-form-page-hover-text-color:var(--ibiz-color-primary);--ibiz-form-page-hover-bg-color:transparent;--ibiz-form-page-active-text-color:var(--ibiz-color-primary);--ibiz-form-page-active-bg-color:transparent;--ibiz-form-page-active-border-color:var(--ibiz-color-primary)}.ibiz-form-page__left{height:100%}.ibiz-form-page__left>.el-tabs__header{height:100%}.ibiz-form-page__left>.el-tabs__content{height:100%;overflow:auto}.ibiz-form-page__right{height:100%}.ibiz-form-page__right>.el-tabs__header{height:100%}.ibiz-form-page__right>.el-tabs__content{height:100%;overflow:auto}.ibiz-form-page--no-tab-header .ibiz-form-page-item{padding-top:0}.ibiz-form-page-tab>.el-tabs__header.is-top{margin-bottom:var(--ibiz-spacing-tight)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top{font-size:var(--ibiz-form-page-font-size);color:var(--ibiz-form-page-text-color);background-color:var(--ibiz-form-page-bg-color)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top:hover{color:var(--ibiz-form-page-hover-text-color);background-color:var(--ibiz-form-page-hover-bg-color)}.ibiz-form-page-tab>.el-tabs__header.is-top .el-tabs__item.is-top.is-active{color:var(--ibiz-form-page-active-text-color);background-color:var(--ibiz-form-page-active-bg-color)}.ibiz-form-page-tab .el-tabs__nav-wrap::after{background-color:var(--ibiz-form-page-header-border-color)}.ibiz-form-page-tab .el-tabs__active-bar{background-color:var(--ibiz-form-page-active-border-color)}.ibiz-form-page-item{padding-top:var(--ibiz-padding-top)}.ibiz-form-page-item-child{margin-bottom:var(--ibiz-margin-bottom)}
@@ -8,6 +8,7 @@ export declare const FormPage: import("vue").DefineComponent<{
8
8
  };
9
9
  }, {
10
10
  ns: import("@ibiz-template/core").Namespace;
11
+ position: string;
11
12
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
12
13
  modelData: {
13
14
  type: PropType<IDEForm>;
@@ -14,10 +14,15 @@ const FormPage = /* @__PURE__ */ defineComponent({
14
14
  required: true
15
15
  }
16
16
  },
17
- setup() {
17
+ setup(props) {
18
18
  const ns = useNamespace("form-page");
19
+ let position = "top";
20
+ if (props.modelData.tabHeaderPos) {
21
+ position = props.modelData.tabHeaderPos.toLowerCase();
22
+ }
19
23
  return {
20
- ns
24
+ ns,
25
+ position
21
26
  };
22
27
  },
23
28
  render() {
@@ -33,8 +38,9 @@ const FormPage = /* @__PURE__ */ defineComponent({
33
38
  }, [defaultSlots]);
34
39
  }
35
40
  return createVNode(resolveComponent("el-tabs"), {
36
- "class": [this.ns.b(), this.ns.b("tab")],
37
- "model-value": (_d = defaultSlots[0]) == null ? void 0 : _d.key
41
+ "class": [this.ns.b(), this.ns.b("tab"), this.ns.e(this.position)],
42
+ "model-value": (_d = defaultSlots[0]) == null ? void 0 : _d.key,
43
+ "tab-position": this.position
38
44
  }, _isSlot(_slot = defaultSlots.map((slot) => {
39
45
  const props = slot.props;
40
46
  if (!props || !props.controller) {
@@ -6,6 +6,7 @@ export declare const IBizFormPage: import("@ibiz-template/vue3-util").TypeWithIn
6
6
  };
7
7
  }, {
8
8
  ns: import("@ibiz-template/core").Namespace;
9
+ position: string;
9
10
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
10
11
  modelData: {
11
12
  type: import("vue").PropType<import("@ibiz/model-core").IDEForm>;
@@ -1 +1 @@
1
- .ibiz-export-excel{width:270px}.ibiz-export-excel__custom{display:flex;align-items:center;justify-content:center}.ibiz-export-excel__custom>*+*{margin-left:10px}.ibiz-export-excel__custom.el-dropdown-menu__item:focus{color:var(--el-text-color-regular);background-color:transparent}.ibiz-export-excel__custom .el-input{--el-input-text-color:var(--ibiz-color-white)}.ibiz-export-excel__button{display:flex;align-items:center;justify-content:center;padding:var(--ibiz-spacing-tight) var(--ibiz-spacing-base)}.ibiz-export-excel__button>span{display:flex;align-items:center;justify-content:center;font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon{display:flex;align-items:center;justify-content:center;width:var(--ibiz-control-toolbar-icon-max-width);height:var(--ibiz-control-toolbar-icon-max-height)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon .ibiz-icon{display:flex;align-items:center;justify-content:center}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon i{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon img{display:inline-block;width:100%;height:100%}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon+.ibiz-toolbar-item-text{margin:var(--ibiz-control-toolbar-text-margin)}.ibiz-export-excel-submenu-button{justify-content:flex-start;width:100%;height:36px;padding:0 10px;border-radius:0}.ibiz-export-excel-submenu-button>span{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon{display:flex;align-items:center;justify-content:center;width:var(--ibiz-control-toolbar-icon-max-width);height:var(--ibiz-control-toolbar-icon-max-height)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon .ibiz-icon{display:flex;align-items:center;justify-content:center}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon i{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon img{display:inline-block;width:100%;height:100%}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon+.ibiz-toolbar-item-text{margin:var(--ibiz-control-toolbar-text-margin)}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu .el-sub-menu__title{padding:0}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu .el-sub-menu__title .el-sub-menu__icon-arrow{display:none}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu.hover{color:var(--ibiz-color-primary-hover-text);background-color:var(--ibiz-color-primary-hover)}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu .ibiz-export-excel-submenu-popper{width:270px;color:var(--ibiz-color-primary-text);background-color:var(--ibiz-color-primary)}
1
+ .ibiz-export-excel{width:270px}.ibiz-export-excel__custom{display:flex;align-items:center;justify-content:center}.ibiz-export-excel__custom>*+*{margin-left:10px}.ibiz-export-excel__custom.el-dropdown-menu__item:focus{color:var(--el-text-color-regular);background-color:transparent}.ibiz-export-excel__custom .el-input{--el-input-text-color:var(--ibiz-color-white)}.ibiz-export-excel__button{display:flex;align-items:center;justify-content:center;padding:var(--ibiz-spacing-tight) var(--ibiz-spacing-base)}.ibiz-export-excel__button>span{display:flex;align-items:center;justify-content:center;font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon{display:flex;align-items:center;justify-content:center;width:var(--ibiz-control-toolbar-icon-max-width);height:var(--ibiz-control-toolbar-icon-max-height)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon .ibiz-icon{display:flex;align-items:center;justify-content:center}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon i{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon img{display:inline-block;width:100%;height:100%}.ibiz-export-excel__button>span .ibiz-toolbar-item-icon+.ibiz-toolbar-item-text{margin:var(--ibiz-control-toolbar-text-margin)}.ibiz-export-excel-submenu-button{justify-content:flex-start;width:100%;height:36px;padding:0 10px;border-radius:0}.ibiz-export-excel-submenu-button>span{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon{display:flex;align-items:center;justify-content:center;width:var(--ibiz-control-toolbar-icon-max-width);height:var(--ibiz-control-toolbar-icon-max-height)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon .ibiz-icon{display:flex;align-items:center;justify-content:center}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon i{font-size:var(--ibiz-font-size-regular)}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon img{display:inline-block;width:100%;height:100%}.ibiz-export-excel-submenu-button>span .ibiz-toolbar-item-icon+.ibiz-toolbar-item-text{margin:var(--ibiz-control-toolbar-text-margin)}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu .el-sub-menu__title{padding:0}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu.hover{color:var(--ibiz-color-primary-hover-text);background-color:var(--ibiz-color-primary-hover)}.ibiz-control-toolbar-submenu-popper .ibiz-export-excel-submenu .ibiz-export-excel-submenu-popper{width:270px;color:var(--ibiz-color-primary-text);background-color:var(--ibiz-color-primary)}
@@ -0,0 +1,48 @@
1
+ import { IDETBUIActionItem } from '@ibiz/model-core';
2
+ import { PropType } from 'vue';
3
+ import { IToolbarController } from '@ibiz-template/runtime';
4
+ import './short-cut-button.scss';
5
+ export declare const IBizShortCutButton: import("vue").DefineComponent<{
6
+ mode: {
7
+ type: StringConstructor;
8
+ required: false;
9
+ };
10
+ size: {
11
+ type: StringConstructor;
12
+ required: false;
13
+ };
14
+ item: {
15
+ type: PropType<IDETBUIActionItem>;
16
+ required: true;
17
+ };
18
+ controller: {
19
+ type: PropType<IToolbarController<import("@ibiz/model-core").IDEToolbar, import("@ibiz-template/runtime").IToolbarState, import("@ibiz-template/runtime").IToolbarEvent>>;
20
+ required: true;
21
+ };
22
+ }, {
23
+ ns: import("@ibiz-template/core").Namespace;
24
+ ns2: import("@ibiz-template/core").Namespace;
25
+ buttonState: import("vue").ComputedRef<any>;
26
+ buttonType: string | undefined;
27
+ isShortCut: import("vue").ComputedRef<boolean>;
28
+ onClick: (e: MouseEvent) => void;
29
+ }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, "click"[], "click", import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
30
+ mode: {
31
+ type: StringConstructor;
32
+ required: false;
33
+ };
34
+ size: {
35
+ type: StringConstructor;
36
+ required: false;
37
+ };
38
+ item: {
39
+ type: PropType<IDETBUIActionItem>;
40
+ required: true;
41
+ };
42
+ controller: {
43
+ type: PropType<IToolbarController<import("@ibiz/model-core").IDEToolbar, import("@ibiz-template/runtime").IToolbarState, import("@ibiz-template/runtime").IToolbarEvent>>;
44
+ required: true;
45
+ };
46
+ }>> & {
47
+ onClick?: ((...args: any[]) => any) | undefined;
48
+ }, {}, {}>;
@@ -0,0 +1,71 @@
1
+ import { computed, resolveComponent, createVNode, defineComponent } from 'vue';
2
+ import { useNamespace } from '@ibiz-template/vue3-util';
3
+ import './short-cut-button.css';
4
+
5
+ "use strict";
6
+ const IBizShortCutButton = /* @__PURE__ */ defineComponent({
7
+ name: "IBizShortCutButton",
8
+ props: {
9
+ mode: {
10
+ type: String,
11
+ required: false
12
+ },
13
+ size: {
14
+ type: String,
15
+ required: false
16
+ },
17
+ item: {
18
+ type: Object,
19
+ required: true
20
+ },
21
+ controller: {
22
+ type: Object,
23
+ required: true
24
+ }
25
+ },
26
+ emits: ["click"],
27
+ setup(props, {
28
+ emit
29
+ }) {
30
+ var _a;
31
+ const ns = useNamespace("short-cut-button");
32
+ const ns2 = useNamespace("toolbar-item");
33
+ const onClick = (e) => {
34
+ emit("click", e);
35
+ };
36
+ const buttonType = (_a = props.item.buttonStyle) == null ? void 0 : _a.toLowerCase();
37
+ const buttonState = computed(() => props.controller.state.buttonsState[props.item.id]);
38
+ const isShortCut = computed(() => props.controller.view.state.isShortCut);
39
+ return {
40
+ ns,
41
+ ns2,
42
+ buttonState,
43
+ buttonType,
44
+ isShortCut,
45
+ onClick
46
+ };
47
+ },
48
+ render() {
49
+ return createVNode("div", {
50
+ "class": [this.ns.b(), this.ns.is("short-cut", this.isShortCut)]
51
+ }, [createVNode(resolveComponent("el-button"), {
52
+ "title": this.isShortCut ? "".concat(ibiz.i18n.t("app.cancel")).concat(this.item.tooltip) : this.item.tooltip,
53
+ "size": this.size,
54
+ "text": Object.is(this.buttonType, "inverse"),
55
+ "type": this.buttonType,
56
+ "loading": this.buttonState.loading,
57
+ "disabled": this.buttonState.disabled,
58
+ "onClick": this.onClick
59
+ }, {
60
+ default: () => [this.item.showIcon && this.item.sysImage && createVNode("span", {
61
+ "class": this.ns2.b("icon")
62
+ }, [createVNode(resolveComponent("iBizIcon"), {
63
+ "icon": this.item.sysImage
64
+ }, null)]), this.item.showCaption && createVNode("span", {
65
+ "class": this.ns2.b("text")
66
+ }, [this.isShortCut ? "".concat(ibiz.i18n.t("app.cancel")).concat(this.item.caption) : this.item.caption])]
67
+ })]);
68
+ }
69
+ });
70
+
71
+ export { IBizShortCutButton };
@@ -2,6 +2,7 @@ import { isVNode, resolveComponent, createVNode, ref, createTextVNode, defineCom
2
2
  import { useNamespace, useControlController } from '@ibiz-template/vue3-util';
3
3
  import { ToolbarController } from '@ibiz-template/runtime';
4
4
  import { IBizExportExcel } from './export-excel/export-excel.mjs';
5
+ import { IBizShortCutButton } from './short-cut-button/short-cut-button.mjs';
5
6
  import './toolbar.css';
6
7
 
7
8
  "use strict";
@@ -202,6 +203,16 @@ const ToolbarControl = /* @__PURE__ */ defineComponent({
202
203
  }
203
204
  }, null);
204
205
  }
206
+ if (actionId === "shortcut") {
207
+ return createVNode(IBizShortCutButton, {
208
+ "key": itemId,
209
+ "class": [ns.e("item"), ns.e("item-deuiaction"), ns.em("item", buttonType), calcCssName(item)],
210
+ "item": item,
211
+ "controller": c,
212
+ "size": btnSize.value,
213
+ "onClick": (e) => handleClick(item, e)
214
+ }, null);
215
+ }
205
216
  return createVNode("div", {
206
217
  "key": itemId,
207
218
  "class": [ns.e("item"), ns.e("item-deuiaction"), ns.em("item", buttonType), calcCssName(item), ns.is("loading", c.state.buttonsState[itemId].loading)]
@@ -1 +1 @@
1
- .ibiz-picker-select-view{width:100%}.ibiz-picker-select-view .el-dropdown{width:100%}.ibiz-picker-select-view .el-select{width:100%}.ibiz-picker-select-view--readonly{font-size:var(--ibiz-form-item-font-size);line-height:var(--ibiz-editor-default-line-height);color:var(--ibiz-form-item-readonly-color)}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper{width:100%;min-height:100px;max-height:500px;overflow:auto}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper .el-scrollbar .el-dropdown__list{background:var(--ibiz-color-primary-text)}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper .el-scrollbar .el-dropdown__list .el-dropdown-menu{background:var(--ibiz-color-primary-text)}.ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default:hover .ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default:hover .ibiz-picker-select-view-select{display:block}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-form-default-content{display:flex;align-items:center;width:100%;height:var(--ibiz-editor-default-line-height);padding:var(--ibiz-form-item-hover-edit-padding);font-family:Arial,sans-serif;font-size:var(--ibiz-form-item-font-size);line-height:var(--ibiz-editor-default-line-height);color:var(--ibiz-form-item-text-color)}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-form-default-content .ibiz-picker-select-view-content-item{height:22px;padding:0 9px;margin:2px 6px 2px 0;font-size:var(--ibiz-font-size-small);line-height:22px;color:var(--ibiz-editor-default-text-color);background-color:var(--ibiz-color-fill-0);border:1px solid transparent;border-radius:var(--ibiz-border-radius-small)}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-select{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default.is-editable .ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default.is-editable .ibiz-picker-select-view-select{display:block}.ibiz-picker-select-view-select-popover{display:none}
1
+ .ibiz-picker-select-view{width:100%}.ibiz-picker-select-view .el-dropdown{width:100%}.ibiz-picker-select-view .el-select{width:100%}.ibiz-picker-select-view__arrow{display:flex;transition:transform .3s;transform:rotateZ(0);transform-origin:center center}.ibiz-picker-select-view__arrow>svg{width:14px;height:14px}.ibiz-picker-select-view__arrow.overturn{transform:rotateZ(-180deg)}.ibiz-picker-select-view--readonly{font-size:var(--ibiz-form-item-font-size);line-height:var(--ibiz-editor-default-line-height);color:var(--ibiz-form-item-readonly-color)}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper{width:100%;min-height:100px;max-height:500px;overflow:auto}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper .el-scrollbar .el-dropdown__list{background:var(--ibiz-color-primary-text)}.ibiz-picker-select-view-popper.el-popper.el-dropdown__popper .el-scrollbar .el-dropdown__list .el-dropdown-menu{background:var(--ibiz-color-primary-text)}.ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default:hover .ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default:hover .ibiz-picker-select-view-select{display:block}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-form-default-content{display:flex;align-items:center;width:100%;height:var(--ibiz-editor-default-line-height);padding:var(--ibiz-form-item-hover-edit-padding);font-family:Arial,sans-serif;font-size:var(--ibiz-form-item-font-size);line-height:var(--ibiz-editor-default-line-height);color:var(--ibiz-form-item-text-color)}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-form-default-content .ibiz-picker-select-view-content-item{height:22px;padding:0 9px;margin:2px 6px 2px 0;font-size:var(--ibiz-font-size-small);line-height:22px;color:var(--ibiz-editor-default-text-color);background-color:var(--ibiz-color-fill-0);border:1px solid transparent;border-radius:var(--ibiz-border-radius-small)}.ibiz-form-item .ibiz-picker-select-view.is-show-default .ibiz-picker-select-view-select{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default.is-editable .ibiz-picker-select-view-form-default-content{display:none}.ibiz-form-item .ibiz-picker-select-view.is-show-default.is-editable .ibiz-picker-select-view-select{display:block}.ibiz-picker-select-view-select-popover{display:none}
@@ -56,6 +56,7 @@ export declare const IBizPickerSelectView: import("vue").DefineComponent<{
56
56
  showView: Ref<boolean>;
57
57
  selectedData: Ref<IData[]>;
58
58
  handleDropDownKeyDown: (e: KeyboardEvent) => void;
59
+ arrow: () => JSX.Element;
59
60
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {
60
61
  change: (_value: unknown, _name?: string | undefined) => boolean;
61
62
  blur: (_event?: IData | undefined) => boolean;
@@ -1,4 +1,4 @@
1
- import { isVNode, ref, watch, computed, onMounted, resolveComponent, createVNode, h, defineComponent } from 'vue';
1
+ import { isVNode, ref, watch, computed, onMounted, createVNode, resolveComponent, h, defineComponent } from 'vue';
2
2
  import { getDataPickerProps, getEditorEmits, useNamespace, useFocusAndBlur } from '@ibiz-template/vue3-util';
3
3
  import './ibiz-picker-select-view.css';
4
4
  import { ViewMode, Modal } from '@ibiz-template/runtime';
@@ -357,6 +357,15 @@ const IBizPickerSelectView = /* @__PURE__ */ defineComponent({
357
357
  }
358
358
  }
359
359
  };
360
+ const arrow = () => {
361
+ return createVNode("svg", {
362
+ "viewBox": "0 0 1024 1024",
363
+ "xmlns": "http://www.w3.org/2000/svg"
364
+ }, [createVNode("path", {
365
+ "fill": "currentColor",
366
+ "d": "M831.872 340.864 512 652.672 192.128 340.864a30.592 30.592 0 0 0-42.752 0 29.12 29.12 0 0 0 0 41.6L489.664 714.24a32 32 0 0 0 44.672 0l340.288-331.712a29.12 29.12 0 0 0 0-41.728 30.592 30.592 0 0 0-42.752 0z"
367
+ }, null)]);
368
+ };
360
369
  return {
361
370
  ns,
362
371
  c,
@@ -388,7 +397,8 @@ const IBizPickerSelectView = /* @__PURE__ */ defineComponent({
388
397
  onVisibleChange,
389
398
  showView,
390
399
  selectedData,
391
- handleDropDownKeyDown
400
+ handleDropDownKeyDown,
401
+ arrow
392
402
  };
393
403
  },
394
404
  render() {
@@ -423,7 +433,9 @@ const IBizPickerSelectView = /* @__PURE__ */ defineComponent({
423
433
  }, null), this.c.model.linkAppViewId && createVNode("ion-icon", {
424
434
  "onClick": this.openLinkView,
425
435
  "name": "link-arrow"
426
- }, null)];
436
+ }, null), this.c.model.showTrigger && createVNode("div", {
437
+ "class": [this.ns.e("arrow"), this.showView ? "overturn" : ""]
438
+ }, [this.arrow()])];
427
439
  }
428
440
  }) : createVNode(resolveComponent("el-select"), {
429
441
  "popper-class": this.ns.b("select-popover"),
package/es/index.mjs CHANGED
@@ -121,6 +121,7 @@ export { OverlayController } from './util/overlay-controller/overlay-controller.
121
121
  export { usePagination } from './util/pagination/use-pagination.mjs';
122
122
  export { NoticeUtil } from './util/notice-util/notice-util.mjs';
123
123
  export { RenderUtil } from './util/render-util/render-util.mjs';
124
+ export { AppUtil } from './util/app-util/app-util.mjs';
124
125
  export { AuthGuard } from './web-app/guard/auth-guard/auth-guard.mjs';
125
126
  export { runApp } from './web-app/main.mjs';
126
127
  export { AppRouter } from './web-app/router/index.mjs';
@@ -10,6 +10,13 @@ import { AuthCaptchaState } from './auth-captcha.state';
10
10
  */
11
11
  export declare class AuthCaptchaController extends PanelItemController<IPanelRawItem> {
12
12
  state: AuthCaptchaState;
13
+ /**
14
+ * 验证码数据
15
+ *
16
+ * @private
17
+ * @memberof AuthCaptchaController
18
+ */
19
+ private captcha;
13
20
  protected createState(): AuthCaptchaState;
14
21
  /**
15
22
  * 面板状态变更通知
@@ -27,6 +34,19 @@ export declare class AuthCaptchaController extends PanelItemController<IPanelRaw
27
34
  * @memberof AuthCaptchaController
28
35
  */
29
36
  protected onInit(): Promise<void>;
37
+ /**
38
+ * 值校验
39
+ *
40
+ * @return {*} {Promise<boolean>}
41
+ * @memberof AuthCaptchaController
42
+ */
43
+ validate(): Promise<boolean>;
44
+ /**
45
+ * 值改变
46
+ *
47
+ * @memberof AuthCaptchaController
48
+ */
49
+ onChange(): void;
30
50
  /**
31
51
  * 加载验证码
32
52
  *
@@ -1,9 +1,29 @@
1
+ import { reactive } from 'vue';
1
2
  import { PanelItemController } from '@ibiz-template/runtime';
2
3
  import axios from 'axios';
3
4
  import { AuthCaptchaState } from './auth-captcha.state.mjs';
4
5
 
5
6
  "use strict";
7
+ var __defProp = Object.defineProperty;
8
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
9
+ var __publicField = (obj, key, value) => {
10
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
11
+ return value;
12
+ };
6
13
  class AuthCaptchaController extends PanelItemController {
14
+ constructor() {
15
+ super(...arguments);
16
+ /**
17
+ * 验证码数据
18
+ *
19
+ * @private
20
+ * @memberof AuthCaptchaController
21
+ */
22
+ __publicField(this, "captcha", reactive({
23
+ "Captcha-State": "",
24
+ "Captcha-Code": ""
25
+ }));
26
+ }
7
27
  createState() {
8
28
  var _a;
9
29
  return new AuthCaptchaState((_a = this.parent) == null ? void 0 : _a.state);
@@ -17,17 +37,7 @@ class AuthCaptchaController extends PanelItemController {
17
37
  */
18
38
  async panelStateNotify(_state) {
19
39
  super.panelStateNotify(_state);
20
- const that = this;
21
- Object.defineProperty(that.panel.state.data, "captcha", {
22
- enumerable: true,
23
- configurable: true,
24
- get() {
25
- return {
26
- captcha_state: that.state.state,
27
- captcha_code: that.state.code
28
- };
29
- }
30
- });
40
+ this.data.captcha = this.captcha;
31
41
  }
32
42
  /**
33
43
  * 初始化
@@ -39,6 +49,43 @@ class AuthCaptchaController extends PanelItemController {
39
49
  async onInit() {
40
50
  super.onInit();
41
51
  await this.loadCaptcha();
52
+ const view = this.panel.view;
53
+ view.hooks.beforeLogin.tapPromise(async (context) => {
54
+ if (!context.parentId || context.parentId === this.dataParent.model.id) {
55
+ context.validate = context.validate && await this.validate();
56
+ }
57
+ });
58
+ view.hooks.afterLogin.tap((context) => {
59
+ if (!context.ok) {
60
+ this.loadCaptcha();
61
+ this.state.code = "";
62
+ }
63
+ });
64
+ }
65
+ /**
66
+ * 值校验
67
+ *
68
+ * @return {*} {Promise<boolean>}
69
+ * @memberof AuthCaptchaController
70
+ */
71
+ async validate() {
72
+ if (this.state.code) {
73
+ this.state.error = void 0;
74
+ return true;
75
+ }
76
+ this.state.error = "\u8BF7\u8F93\u5165\u9A8C\u8BC1\u7801";
77
+ return false;
78
+ }
79
+ /**
80
+ * 值改变
81
+ *
82
+ * @memberof AuthCaptchaController
83
+ */
84
+ onChange() {
85
+ Object.assign(this.captcha, {
86
+ "Captcha-State": this.state.state,
87
+ "Captcha-Code": this.state.code
88
+ });
42
89
  }
43
90
  /**
44
91
  * 加载验证码
@@ -57,12 +104,19 @@ class AuthCaptchaController extends PanelItemController {
57
104
  },
58
105
  data: {}
59
106
  };
60
- const res = await axios(requestConfig);
61
- if (res.status === 200 && res.data) {
62
- this.state.state = res.data.state;
63
- this.state.image = res.data.image;
107
+ try {
108
+ const res = await axios(requestConfig);
109
+ if (res.status === 200 && res.data) {
110
+ this.state.state = res.data.state;
111
+ this.state.image = res.data.image;
112
+ }
113
+ } catch (error) {
114
+ this.state.state = "";
115
+ this.state.image = "";
116
+ } finally {
117
+ this.state.loading = false;
118
+ this.onChange();
64
119
  }
65
- this.state.loading = false;
66
120
  }
67
121
  }
68
122
 
@@ -1 +1 @@
1
- .ibiz-auth-captcha{display:flex}.ibiz-auth-captcha__captcha{width:calc(100% - 120px)}.ibiz-auth-captcha__image{flex-shrink:0;width:120px;height:100%;cursor:pointer}.ibiz-auth-captcha__image--hint{display:flex;align-items:center;justify-content:center;width:100%;height:100%}
1
+ .ibiz-auth-captcha{display:flex;position:relative}.ibiz-auth-captcha__captcha{width:calc(100% - 120px)}.ibiz-auth-captcha__image{flex-shrink:0;width:120px;height:100%;cursor:pointer}.ibiz-auth-captcha__image--hint{width:100%;height:100%;display:flex;align-items:center;justify-content:center;color:var(--ibiz-color-text-3);background-color:var(--ibiz-color-fill-0)}.ibiz-auth-captcha__error{left:0;top:100%;line-height:1;font-size:12px;padding-top:2px;position:absolute;color:var(--ibiz-color-danger)}.ibiz-auth-captcha.is-error .el-input__wrapper{box-shadow:0 0 0 1px var(--ibiz-color-danger) inset}
@@ -16,6 +16,7 @@ export declare const AuthCaptcha: import("vue").DefineComponent<{
16
16
  ns: import("@ibiz-template/core").Namespace;
17
17
  classArr: import("vue").ComputedRef<(string | false)[]>;
18
18
  onClick: () => void;
19
+ onChange: () => void;
19
20
  }, unknown, {}, {}, import("vue").ComponentOptionsMixin, import("vue").ComponentOptionsMixin, {}, string, import("vue").VNodeProps & import("vue").AllowedComponentProps & import("vue").ComponentCustomProps, Readonly<import("vue").ExtractPropTypes<{
20
21
  modelData: {
21
22
  type: PropType<IPanelRawItem>;