@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.
- package/dist/index-5IjaPupj.js +4 -0
- package/dist/index.min.css +1 -1
- package/dist/index.system.min.js +1 -1
- package/dist/{xlsx-util-Zf9d2PeX.js → xlsx-util-8i01yifN.js} +1 -1
- package/es/control/app-menu/app-menu.mjs +1 -1
- package/es/control/context-menu/context-menu.css +1 -1
- package/es/control/context-menu/context-menu.d.ts +1 -0
- package/es/control/context-menu/context-menu.mjs +63 -6
- package/es/control/context-menu/index.d.ts +1 -0
- package/es/control/form/form/form.css +1 -1
- package/es/control/form/form-detail/form-page/form-page.css +1 -1
- package/es/control/form/form-detail/form-page/form-page.d.ts +1 -0
- package/es/control/form/form-detail/form-page/form-page.mjs +10 -4
- package/es/control/form/form-detail/form-page/index.d.ts +1 -0
- package/es/control/toolbar/export-excel/export-excel.css +1 -1
- package/es/control/toolbar/short-cut-button/short-cut-button.css +0 -0
- package/es/control/toolbar/short-cut-button/short-cut-button.d.ts +48 -0
- package/es/control/toolbar/short-cut-button/short-cut-button.mjs +71 -0
- package/es/control/toolbar/toolbar.mjs +11 -0
- package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.css +1 -1
- package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.d.ts +1 -0
- package/es/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.mjs +15 -3
- package/es/index.mjs +1 -0
- package/es/panel-component/auth-captcha/auth-captcha.controller.d.ts +20 -0
- package/es/panel-component/auth-captcha/auth-captcha.controller.mjs +70 -16
- package/es/panel-component/auth-captcha/auth-captcha.css +1 -1
- package/es/panel-component/auth-captcha/auth-captcha.d.ts +1 -0
- package/es/panel-component/auth-captcha/auth-captcha.mjs +12 -3
- package/es/panel-component/auth-captcha/auth-captcha.state.d.ts +7 -0
- package/es/panel-component/auth-captcha/auth-captcha.state.mjs +7 -0
- package/es/panel-component/auth-captcha/index.d.ts +1 -0
- package/es/panel-component/auth-userinfo/auth-userinfo.d.ts +1 -1
- package/es/panel-component/auth-userinfo/auth-userinfo.mjs +2 -7
- package/es/panel-component/auth-userinfo/index.d.ts +1 -1
- package/es/panel-component/panel-button/panel-button.controller.mjs +7 -1
- package/es/panel-component/short-cut/index.d.ts +21 -4
- package/es/panel-component/short-cut/short-cut.css +1 -1
- package/es/panel-component/short-cut/short-cut.d.ts +21 -4
- package/es/panel-component/short-cut/short-cut.mjs +45 -28
- package/es/util/app-util/app-util.d.ts +90 -0
- package/es/util/app-util/app-util.mjs +152 -0
- package/es/util/index.d.ts +1 -0
- package/es/util/index.mjs +1 -0
- package/es/view-engine/login-view.engine.d.ts +3 -1
- package/es/view-engine/login-view.engine.mjs +4 -3
- package/es/web-app/main.mjs +2 -0
- package/lib/control/app-menu/app-menu.cjs +1 -1
- package/lib/control/context-menu/context-menu.cjs +63 -6
- package/lib/control/context-menu/context-menu.css +1 -1
- package/lib/control/form/form/form.css +1 -1
- package/lib/control/form/form-detail/form-page/form-page.cjs +10 -4
- package/lib/control/form/form-detail/form-page/form-page.css +1 -1
- package/lib/control/toolbar/export-excel/export-excel.css +1 -1
- package/lib/control/toolbar/short-cut-button/short-cut-button.cjs +73 -0
- package/lib/control/toolbar/short-cut-button/short-cut-button.css +0 -0
- package/lib/control/toolbar/toolbar.cjs +11 -0
- package/lib/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.cjs +14 -2
- package/lib/editor/data-picker/ibiz-picker-select-view/ibiz-picker-select-view.css +1 -1
- package/lib/index.cjs +2 -0
- package/lib/panel-component/auth-captcha/auth-captcha.cjs +12 -3
- package/lib/panel-component/auth-captcha/auth-captcha.controller.cjs +70 -16
- package/lib/panel-component/auth-captcha/auth-captcha.css +1 -1
- package/lib/panel-component/auth-captcha/auth-captcha.state.cjs +7 -0
- package/lib/panel-component/auth-userinfo/auth-userinfo.cjs +2 -7
- package/lib/panel-component/panel-button/panel-button.controller.cjs +7 -1
- package/lib/panel-component/short-cut/short-cut.cjs +44 -27
- package/lib/panel-component/short-cut/short-cut.css +1 -1
- package/lib/util/app-util/app-util.cjs +154 -0
- package/lib/util/index.cjs +2 -0
- package/lib/view-engine/login-view.engine.cjs +4 -3
- package/lib/web-app/main.cjs +2 -0
- package/package.json +4 -4
- 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 (
|
|
59
|
-
Object.assign(headers,
|
|
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();
|
package/es/web-app/main.mjs
CHANGED
|
@@ -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":
|
|
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
|
-
|
|
60
|
-
|
|
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
|
|
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;
|
|
File without changes
|
|
@@ -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
|
-
|
|
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
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
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;
|
|
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 =
|
|
39
|
-
|
|
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
|
|
116
|
+
view,
|
|
111
117
|
event,
|
|
112
118
|
noWaitRoute: true
|
|
113
119
|
},
|