@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
@@ -50,19 +50,19 @@ class LoginViewEngine extends ViewEngineBase {
50
50
  async login(args) {
51
51
  let rememberme;
52
52
  const headers = {};
53
+ const data = args.data[0] || {};
53
54
  if (this.AppLoginView.layoutPanel) {
54
55
  const panelData = this.AppLoginView.layoutPanel.data;
55
56
  if (typeof panelData.isRemember === "boolean") {
56
57
  rememberme = panelData.isRemember;
57
58
  }
58
- if (panelData.captcha) {
59
- Object.assign(headers, panelData.captcha);
59
+ if (data.captcha) {
60
+ Object.assign(headers, data.captcha);
60
61
  }
61
62
  if (panelData.srfheaders) {
62
63
  Object.assign(headers, panelData.srfheaders);
63
64
  }
64
65
  }
65
- const data = args.data[0] || {};
66
66
  let username = data.username;
67
67
  if (notNilEmpty(data.orgid)) {
68
68
  username = "".concat(data.username, "@").concat(data.orgid);
@@ -73,6 +73,7 @@ class LoginViewEngine extends ViewEngineBase {
73
73
  rememberme,
74
74
  headers
75
75
  );
76
+ this.view.hooks.afterLogin.call({ ok: bol });
76
77
  if (bol === true) {
77
78
  window.location.hash = this.route.query.ru || "/";
78
79
  window.location.reload();
@@ -10,6 +10,7 @@ import '../util/index.mjs';
10
10
  import './guard/index.mjs';
11
11
  import { UnauthorizedHandler } from './util/unauthorized-handler/unauthorized-handler.mjs';
12
12
  import { DynaAuthGuard } from './guard/auth-guard/dyna-auth-guard.mjs';
13
+ import { AppUtil } from '../util/app-util/app-util.mjs';
13
14
  import { OpenViewUtil } from '../util/open-view-util/open-view-util.mjs';
14
15
  import { RenderUtil } from '../util/render-util/render-util.mjs';
15
16
  import { MessageUtil } from '../util/message-util/message-util.mjs';
@@ -62,6 +63,7 @@ async function runApp(plugins, opts) {
62
63
  }
63
64
  AppRouter.setAuthGuard((notLogin) => authGuard.verify(notLogin));
64
65
  app.use(AppRouter.getRouter());
66
+ ibiz.appUtil = new AppUtil(AppRouter.getRouter());
65
67
  ibiz.openView = new OpenViewUtil(AppRouter.getRouter());
66
68
  ibiz.render = new RenderUtil();
67
69
  ibiz.message = new MessageUtil();
@@ -280,7 +280,7 @@ const AppMenuControl = /* @__PURE__ */ vue.defineComponent({
280
280
  "onSelect": this.onClick,
281
281
  "theme": "light",
282
282
  "mode": this.menuMode,
283
- "ellipsis": false
283
+ "ellipsis": this.menuMode === "horizontal"
284
284
  }, _isSlot(_slot = this.menus.map((item) => {
285
285
  var _a;
286
286
  if (((_a = item.children) == null ? void 0 : _a.length) > 0) {
@@ -55,18 +55,26 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
55
55
  const expandDetails = vue.ref([]);
56
56
  const groupDetails = vue.ref([]);
57
57
  const groupButtonRef = vue.ref();
58
+ const dropdownRef = vue.ref();
58
59
  const popoverVisible = vue.ref(false);
59
- if (actionDetails) {
60
- actionDetails == null ? void 0 : actionDetails.forEach((detail) => {
60
+ const transformLanguage = (items) => {
61
+ if (!Array.isArray(items)) {
62
+ return;
63
+ }
64
+ items.forEach((detail) => {
61
65
  if (detail.capLanguageRes && detail.capLanguageRes.lanResTag) {
62
66
  detail.caption = ibiz.i18n.t(detail.capLanguageRes.lanResTag, detail.caption);
63
67
  }
64
68
  if (detail.tooltipLanguageRes && detail.tooltipLanguageRes.lanResTag) {
65
69
  detail.tooltip = ibiz.i18n.t(detail.tooltipLanguageRes.lanResTag, detail.tooltip);
66
70
  }
71
+ transformLanguage(detail.detoolbarItems);
67
72
  });
73
+ };
74
+ if (actionDetails) {
75
+ transformLanguage(actionDetails);
68
76
  actionDetails.forEach((detail) => {
69
- if (props.groupLevelKeys.findIndex((item) => item === detail.actionLevel) !== -1) {
77
+ if (!detail.actionLevel || props.groupLevelKeys.findIndex((item) => item === detail.actionLevel) !== -1) {
70
78
  groupDetails.value.push(detail);
71
79
  } else {
72
80
  expandDetails.value.push(detail);
@@ -88,7 +96,13 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
88
96
  await c.calcButtonState(props.nodeData._deData || (props.nodeData.srfkey ? props.nodeData : void 0), props.nodeModel.appDataEntityId);
89
97
  });
90
98
  const handleClick = async (detail, e) => {
99
+ if (props.mode === "buttons") {
100
+ popoverVisible.value = false;
101
+ } else if (dropdownRef.value) {
102
+ dropdownRef.value.handleClose();
103
+ }
91
104
  e.stopPropagation();
105
+ popoverVisible.value = false;
92
106
  emit("action-click", detail, e);
93
107
  };
94
108
  return {
@@ -97,6 +111,7 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
97
111
  expandDetails,
98
112
  groupDetails,
99
113
  groupButtonRef,
114
+ dropdownRef,
100
115
  popoverVisible,
101
116
  handleClick,
102
117
  calcActionItemClass,
@@ -114,8 +129,14 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
114
129
  };
115
130
  const renderActions = (items, isExpand = true) => {
116
131
  return items.map((detail) => {
117
- var _a;
118
- if ((_a = this.c.state.buttonsState[detail.id]) == null ? void 0 : _a.visible) {
132
+ var _a, _b;
133
+ if (!((_a = this.c.state.buttonsState[detail.id]) == null ? void 0 : _a.visible)) {
134
+ return null;
135
+ }
136
+ if (detail.itemType === "SEPERATOR") {
137
+ return renderDivider(isExpand);
138
+ }
139
+ if (detail.itemType === "DEUIACTION" || detail.itemType === "ITEMS" && !((_b = detail.detoolbarItems) == null ? void 0 : _b.length)) {
119
140
  return [detail.addSeparator && renderDivider(isExpand), vue.createVNode(vue.resolveComponent("el-button"), {
120
141
  "text": true,
121
142
  "size": "small",
@@ -135,6 +156,40 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
135
156
  }, [detail.caption]) : ""])]
136
157
  })];
137
158
  }
159
+ if (detail.itemType === "ITEMS") {
160
+ return vue.createVNode(vue.resolveComponent("el-popover"), {
161
+ "placement": "right-start",
162
+ "popper-class": this.ns.e("popover"),
163
+ "teleported": false
164
+ }, {
165
+ reference: () => {
166
+ return [detail.addSeparator && renderDivider(isExpand), vue.createVNode(vue.resolveComponent("el-button"), {
167
+ "text": true,
168
+ "size": "small",
169
+ "onClick": (e) => this.handleClick(detail, e),
170
+ "title": detail.tooltip,
171
+ "disabled": this.c.state.buttonsState[detail.id].disabled,
172
+ "class": this.calcActionItemClass(detail)
173
+ }, {
174
+ default: () => [vue.createVNode("div", {
175
+ "class": this.ns.e("action-content")
176
+ }, [detail.showIcon && detail.sysImage && vue.createVNode("div", {
177
+ "class": this.ns.e("action-content-icon")
178
+ }, [vue.createVNode(vue.resolveComponent("iBizIcon"), {
179
+ "icon": detail.sysImage
180
+ }, null)]), detail.showCaption ? vue.createVNode("div", {
181
+ "class": [this.ns.e("action-content-caption"), this.ns.e("action-content-group-caption")]
182
+ }, [detail.caption]) : "", vue.createVNode("ion-icon", {
183
+ "class": this.ns.e("action-content-group-icon"),
184
+ "name": "chevron-forward-outline"
185
+ }, null)])]
186
+ })];
187
+ },
188
+ default: () => {
189
+ return renderActions(detail.detoolbarItems || [], isExpand);
190
+ }
191
+ });
192
+ }
138
193
  return null;
139
194
  });
140
195
  };
@@ -160,12 +215,14 @@ const ContextMenuControl = /* @__PURE__ */ vue.defineComponent({
160
215
  "visible": this.popoverVisible,
161
216
  "onUpdate:visible": ($event) => this.popoverVisible = $event,
162
217
  "popper-class": this.ns.e("popover"),
163
- "virtual-triggering": true
218
+ "virtual-triggering": true,
219
+ "transition": "none"
164
220
  }, _isSlot(_slot = renderActions(this.groupDetails, false)) ? _slot : {
165
221
  default: () => [_slot]
166
222
  })]]);
167
223
  }
168
224
  return vue.createVNode(vue.resolveComponent("el-dropdown"), {
225
+ "ref": "dropdownRef",
169
226
  "onCommand": (command) => this.handleClick(command, new MouseEvent("click")),
170
227
  "class": [this.ns.b(), this.ns.m("dropdown")]
171
228
  }, {
@@ -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}
@@ -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)}
@@ -18,10 +18,15 @@ const FormPage = /* @__PURE__ */ vue.defineComponent({
18
18
  required: true
19
19
  }
20
20
  },
21
- setup() {
21
+ setup(props) {
22
22
  const ns = vue3Util.useNamespace("form-page");
23
+ let position = "top";
24
+ if (props.modelData.tabHeaderPos) {
25
+ position = props.modelData.tabHeaderPos.toLowerCase();
26
+ }
23
27
  return {
24
- ns
28
+ ns,
29
+ position
25
30
  };
26
31
  },
27
32
  render() {
@@ -37,8 +42,9 @@ const FormPage = /* @__PURE__ */ vue.defineComponent({
37
42
  }, [defaultSlots]);
38
43
  }
39
44
  return vue.createVNode(vue.resolveComponent("el-tabs"), {
40
- "class": [this.ns.b(), this.ns.b("tab")],
41
- "model-value": (_d = defaultSlots[0]) == null ? void 0 : _d.key
45
+ "class": [this.ns.b(), this.ns.b("tab"), this.ns.e(this.position)],
46
+ "model-value": (_d = defaultSlots[0]) == null ? void 0 : _d.key,
47
+ "tab-position": this.position
42
48
  }, _isSlot(_slot = defaultSlots.map((slot) => {
43
49
  const props = slot.props;
44
50
  if (!props || !props.controller) {
@@ -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)}
@@ -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,73 @@
1
+ 'use strict';
2
+
3
+ var vue = require('vue');
4
+ var vue3Util = require('@ibiz-template/vue3-util');
5
+ require('./short-cut-button.css');
6
+
7
+ "use strict";
8
+ const IBizShortCutButton = /* @__PURE__ */ vue.defineComponent({
9
+ name: "IBizShortCutButton",
10
+ props: {
11
+ mode: {
12
+ type: String,
13
+ required: false
14
+ },
15
+ size: {
16
+ type: String,
17
+ required: false
18
+ },
19
+ item: {
20
+ type: Object,
21
+ required: true
22
+ },
23
+ controller: {
24
+ type: Object,
25
+ required: true
26
+ }
27
+ },
28
+ emits: ["click"],
29
+ setup(props, {
30
+ emit
31
+ }) {
32
+ var _a;
33
+ const ns = vue3Util.useNamespace("short-cut-button");
34
+ const ns2 = vue3Util.useNamespace("toolbar-item");
35
+ const onClick = (e) => {
36
+ emit("click", e);
37
+ };
38
+ const buttonType = (_a = props.item.buttonStyle) == null ? void 0 : _a.toLowerCase();
39
+ const buttonState = vue.computed(() => props.controller.state.buttonsState[props.item.id]);
40
+ const isShortCut = vue.computed(() => props.controller.view.state.isShortCut);
41
+ return {
42
+ ns,
43
+ ns2,
44
+ buttonState,
45
+ buttonType,
46
+ isShortCut,
47
+ onClick
48
+ };
49
+ },
50
+ render() {
51
+ return vue.createVNode("div", {
52
+ "class": [this.ns.b(), this.ns.is("short-cut", this.isShortCut)]
53
+ }, [vue.createVNode(vue.resolveComponent("el-button"), {
54
+ "title": this.isShortCut ? "".concat(ibiz.i18n.t("app.cancel")).concat(this.item.tooltip) : this.item.tooltip,
55
+ "size": this.size,
56
+ "text": Object.is(this.buttonType, "inverse"),
57
+ "type": this.buttonType,
58
+ "loading": this.buttonState.loading,
59
+ "disabled": this.buttonState.disabled,
60
+ "onClick": this.onClick
61
+ }, {
62
+ default: () => [this.item.showIcon && this.item.sysImage && vue.createVNode("span", {
63
+ "class": this.ns2.b("icon")
64
+ }, [vue.createVNode(vue.resolveComponent("iBizIcon"), {
65
+ "icon": this.item.sysImage
66
+ }, null)]), this.item.showCaption && vue.createVNode("span", {
67
+ "class": this.ns2.b("text")
68
+ }, [this.isShortCut ? "".concat(ibiz.i18n.t("app.cancel")).concat(this.item.caption) : this.item.caption])]
69
+ })]);
70
+ }
71
+ });
72
+
73
+ exports.IBizShortCutButton = IBizShortCutButton;
@@ -4,6 +4,7 @@ var vue = require('vue');
4
4
  var vue3Util = require('@ibiz-template/vue3-util');
5
5
  var runtime = require('@ibiz-template/runtime');
6
6
  var exportExcel = require('./export-excel/export-excel.cjs');
7
+ var shortCutButton = require('./short-cut-button/short-cut-button.cjs');
7
8
  require('./toolbar.css');
8
9
 
9
10
  "use strict";
@@ -204,6 +205,16 @@ const ToolbarControl = /* @__PURE__ */ vue.defineComponent({
204
205
  }
205
206
  }, null);
206
207
  }
208
+ if (actionId === "shortcut") {
209
+ return vue.createVNode(shortCutButton.IBizShortCutButton, {
210
+ "key": itemId,
211
+ "class": [ns.e("item"), ns.e("item-deuiaction"), ns.em("item", buttonType), calcCssName(item)],
212
+ "item": item,
213
+ "controller": c,
214
+ "size": btnSize.value,
215
+ "onClick": (e) => handleClick(item, e)
216
+ }, null);
217
+ }
207
218
  return vue.createVNode("div", {
208
219
  "key": itemId,
209
220
  "class": [ns.e("item"), ns.e("item-deuiaction"), ns.em("item", buttonType), calcCssName(item), ns.is("loading", c.state.buttonsState[itemId].loading)]
@@ -359,6 +359,15 @@ const IBizPickerSelectView = /* @__PURE__ */ vue.defineComponent({
359
359
  }
360
360
  }
361
361
  };
362
+ const arrow = () => {
363
+ return vue.createVNode("svg", {
364
+ "viewBox": "0 0 1024 1024",
365
+ "xmlns": "http://www.w3.org/2000/svg"
366
+ }, [vue.createVNode("path", {
367
+ "fill": "currentColor",
368
+ "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"
369
+ }, null)]);
370
+ };
362
371
  return {
363
372
  ns,
364
373
  c,
@@ -390,7 +399,8 @@ const IBizPickerSelectView = /* @__PURE__ */ vue.defineComponent({
390
399
  onVisibleChange,
391
400
  showView,
392
401
  selectedData,
393
- handleDropDownKeyDown
402
+ handleDropDownKeyDown,
403
+ arrow
394
404
  };
395
405
  },
396
406
  render() {
@@ -425,7 +435,9 @@ const IBizPickerSelectView = /* @__PURE__ */ vue.defineComponent({
425
435
  }, null), this.c.model.linkAppViewId && vue.createVNode("ion-icon", {
426
436
  "onClick": this.openLinkView,
427
437
  "name": "link-arrow"
428
- }, null)];
438
+ }, null), this.c.model.showTrigger && vue.createVNode("div", {
439
+ "class": [this.ns.e("arrow"), this.showView ? "overturn" : ""]
440
+ }, [this.arrow()])];
429
441
  }
430
442
  }) : vue.createVNode(vue.resolveComponent("el-select"), {
431
443
  "popper-class": this.ns.b("select-popover"),
@@ -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}
package/lib/index.cjs CHANGED
@@ -123,6 +123,7 @@ var overlayController = require('./util/overlay-controller/overlay-controller.cj
123
123
  var usePagination = require('./util/pagination/use-pagination.cjs');
124
124
  var noticeUtil = require('./util/notice-util/notice-util.cjs');
125
125
  var renderUtil = require('./util/render-util/render-util.cjs');
126
+ var appUtil = require('./util/app-util/app-util.cjs');
126
127
  var authGuard = require('./web-app/guard/auth-guard/auth-guard.cjs');
127
128
  var main = require('./web-app/main.cjs');
128
129
  var index$17 = require('./web-app/router/index.cjs');
@@ -252,6 +253,7 @@ exports.OverlayController = overlayController.OverlayController;
252
253
  exports.usePagination = usePagination.usePagination;
253
254
  exports.NoticeUtil = noticeUtil.NoticeUtil;
254
255
  exports.RenderUtil = renderUtil.RenderUtil;
256
+ exports.AppUtil = appUtil.AppUtil;
255
257
  exports.AuthGuard = authGuard.AuthGuard;
256
258
  exports.runApp = main.runApp;
257
259
  exports.AppRouter = index$17.AppRouter;
@@ -23,7 +23,7 @@ const AuthCaptcha = /* @__PURE__ */ vue.defineComponent({
23
23
  const c = props.controller;
24
24
  const classArr = vue.computed(() => {
25
25
  let result = [ns.b(), ns.m(c.model.id)];
26
- result = [...result, ...props.controller.containerClass, ns.is("hidden", !props.controller.state.visible)];
26
+ result = [...result, ...props.controller.containerClass, ns.is("hidden", !props.controller.state.visible), ns.is("error", !!c.state.error)];
27
27
  return result;
28
28
  });
29
29
  const onClick = () => {
@@ -31,11 +31,16 @@ const AuthCaptcha = /* @__PURE__ */ vue.defineComponent({
31
31
  c.loadCaptcha();
32
32
  }
33
33
  };
34
+ const onChange = () => {
35
+ c.onChange();
36
+ c.validate();
37
+ };
34
38
  return {
35
39
  c,
36
40
  ns,
37
41
  classArr,
38
- onClick
42
+ onClick,
43
+ onChange
39
44
  };
40
45
  },
41
46
  render() {
@@ -45,6 +50,8 @@ const AuthCaptcha = /* @__PURE__ */ vue.defineComponent({
45
50
  "modelValue": this.c.state.code,
46
51
  "onUpdate:modelValue": ($event) => this.c.state.code = $event,
47
52
  "class": this.ns.e("captcha"),
53
+ "onInput": this.onChange,
54
+ "onBlur": this.onChange,
48
55
  "placeholder": "\u9A8C\u8BC1\u7801"
49
56
  }, null), vue.withDirectives(vue.createVNode(vue.resolveComponent("el-image"), {
50
57
  "src": this.c.state.image,
@@ -58,7 +65,9 @@ const AuthCaptcha = /* @__PURE__ */ vue.defineComponent({
58
65
  "class": [this.ns.em("image", "hint"), this.ns.is("loading", this.c.state.loading)]
59
66
  }, [this.c.state.loading ? "\u52A0\u8F7D\u4E2D..." : "\u52A0\u8F7D\u5931\u8D25"]);
60
67
  }
61
- }), [[vue.resolveDirective("loading"), this.c.state.loading]])]);
68
+ }), [[vue.resolveDirective("loading"), this.c.state.loading]]), this.c.state.error && vue.createVNode("div", {
69
+ "class": this.ns.e("error")
70
+ }, [this.c.state.error])]);
62
71
  }
63
72
  });
64
73
 
@@ -1,11 +1,31 @@
1
1
  'use strict';
2
2
 
3
+ var vue = require('vue');
3
4
  var runtime = require('@ibiz-template/runtime');
4
5
  var axios = require('axios');
5
6
  var authCaptcha_state = require('./auth-captcha.state.cjs');
6
7
 
7
8
  "use strict";
9
+ var __defProp = Object.defineProperty;
10
+ var __defNormalProp = (obj, key, value) => key in obj ? __defProp(obj, key, { enumerable: true, configurable: true, writable: true, value }) : obj[key] = value;
11
+ var __publicField = (obj, key, value) => {
12
+ __defNormalProp(obj, typeof key !== "symbol" ? key + "" : key, value);
13
+ return value;
14
+ };
8
15
  class AuthCaptchaController extends runtime.PanelItemController {
16
+ constructor() {
17
+ super(...arguments);
18
+ /**
19
+ * 验证码数据
20
+ *
21
+ * @private
22
+ * @memberof AuthCaptchaController
23
+ */
24
+ __publicField(this, "captcha", vue.reactive({
25
+ "Captcha-State": "",
26
+ "Captcha-Code": ""
27
+ }));
28
+ }
9
29
  createState() {
10
30
  var _a;
11
31
  return new authCaptcha_state.AuthCaptchaState((_a = this.parent) == null ? void 0 : _a.state);
@@ -19,17 +39,7 @@ class AuthCaptchaController extends runtime.PanelItemController {
19
39
  */
20
40
  async panelStateNotify(_state) {
21
41
  super.panelStateNotify(_state);
22
- const that = this;
23
- Object.defineProperty(that.panel.state.data, "captcha", {
24
- enumerable: true,
25
- configurable: true,
26
- get() {
27
- return {
28
- captcha_state: that.state.state,
29
- captcha_code: that.state.code
30
- };
31
- }
32
- });
42
+ this.data.captcha = this.captcha;
33
43
  }
34
44
  /**
35
45
  * 初始化
@@ -41,6 +51,43 @@ class AuthCaptchaController extends runtime.PanelItemController {
41
51
  async onInit() {
42
52
  super.onInit();
43
53
  await this.loadCaptcha();
54
+ const view = this.panel.view;
55
+ view.hooks.beforeLogin.tapPromise(async (context) => {
56
+ if (!context.parentId || context.parentId === this.dataParent.model.id) {
57
+ context.validate = context.validate && await this.validate();
58
+ }
59
+ });
60
+ view.hooks.afterLogin.tap((context) => {
61
+ if (!context.ok) {
62
+ this.loadCaptcha();
63
+ this.state.code = "";
64
+ }
65
+ });
66
+ }
67
+ /**
68
+ * 值校验
69
+ *
70
+ * @return {*} {Promise<boolean>}
71
+ * @memberof AuthCaptchaController
72
+ */
73
+ async validate() {
74
+ if (this.state.code) {
75
+ this.state.error = void 0;
76
+ return true;
77
+ }
78
+ this.state.error = "\u8BF7\u8F93\u5165\u9A8C\u8BC1\u7801";
79
+ return false;
80
+ }
81
+ /**
82
+ * 值改变
83
+ *
84
+ * @memberof AuthCaptchaController
85
+ */
86
+ onChange() {
87
+ Object.assign(this.captcha, {
88
+ "Captcha-State": this.state.state,
89
+ "Captcha-Code": this.state.code
90
+ });
44
91
  }
45
92
  /**
46
93
  * 加载验证码
@@ -59,12 +106,19 @@ class AuthCaptchaController extends runtime.PanelItemController {
59
106
  },
60
107
  data: {}
61
108
  };
62
- const res = await axios(requestConfig);
63
- if (res.status === 200 && res.data) {
64
- this.state.state = res.data.state;
65
- this.state.image = res.data.image;
109
+ try {
110
+ const res = await axios(requestConfig);
111
+ if (res.status === 200 && res.data) {
112
+ this.state.state = res.data.state;
113
+ this.state.image = res.data.image;
114
+ }
115
+ } catch (error) {
116
+ this.state.state = "";
117
+ this.state.image = "";
118
+ } finally {
119
+ this.state.loading = false;
120
+ this.onChange();
66
121
  }
67
- this.state.loading = false;
68
122
  }
69
123
  }
70
124
 
@@ -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}
@@ -40,6 +40,13 @@ class AuthCaptchaState extends runtime.PanelItemState {
40
40
  * @memberof AuthCaptchaState
41
41
  */
42
42
  __publicField(this, "loading", false);
43
+ /**
44
+ * 错误信息
45
+ *
46
+ * @type {string}
47
+ * @memberof AuthCaptchaState
48
+ */
49
+ __publicField(this, "error");
43
50
  }
44
51
  }
45
52
 
@@ -35,13 +35,8 @@ const AuthUserinfo = /* @__PURE__ */ vue.defineComponent({
35
35
  }
36
36
  return "LEFT";
37
37
  });
38
- const onClick = async () => {
39
- const bol = await ibiz.hub.controller.logout();
40
- if (bol) {
41
- await router.push("/login?ru=".concat(encodeURIComponent(window.location.hash.replace("#/", "/"))));
42
- ibiz.util.showAppLoading();
43
- window.location.reload();
44
- }
38
+ const onClick = () => {
39
+ ibiz.hub.controller.logout();
45
40
  };
46
41
  const isCollapse = vue.computed(() => {
47
42
  return c.panel.view.state.isCollapse;
@@ -101,13 +101,19 @@ class PanelButtonController extends runtime.PanelItemController {
101
101
  }
102
102
  event.stopPropagation();
103
103
  event.preventDefault();
104
+ const view = this.panel.view;
105
+ if (actionType === "UIACTION" && uiactionId === "login" && view.model.viewType === "APPLOGINVIEW" && !await view.validate(
106
+ this.dataParent.model.id
107
+ )) {
108
+ return;
109
+ }
104
110
  await runtime.UIActionUtil.execAndResolved(
105
111
  uiactionId,
106
112
  {
107
113
  context: this.panel.context,
108
114
  params: this.panel.params,
109
115
  data: [this.data],
110
- view: this.panel.view,
116
+ view,
111
117
  event,
112
118
  noWaitRoute: true
113
119
  },