iglooform 2.3.9 → 2.3.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/es/form/element/index.js +6 -1
- package/es/form/login/index.js +3 -2
- package/es/free-form/element/index.js +8 -3
- package/es/free-form/page/index.js +2 -0
- package/es/layout/footer.d.ts +12 -0
- package/es/layout/footer.js +270 -0
- package/es/layout/header.d.ts +30 -0
- package/es/layout/header.js +231 -0
- package/es/layout/index.d.ts +31 -23
- package/es/layout/index.js +46 -461
- package/es/select/attached-select.js +16 -4
- package/es/table/style/index.less +5 -0
- package/lib/form/element/index.js +6 -1
- package/lib/form/login/index.js +3 -2
- package/lib/free-form/element/index.js +8 -3
- package/lib/free-form/page/index.js +2 -0
- package/lib/layout/footer.d.ts +12 -0
- package/lib/layout/footer.js +288 -0
- package/lib/layout/header.d.ts +30 -0
- package/lib/layout/header.js +258 -0
- package/lib/layout/index.d.ts +31 -23
- package/lib/layout/index.js +45 -473
- package/lib/select/attached-select.js +16 -4
- package/lib/table/style/index.less +5 -0
- package/package.json +1 -1
|
@@ -99,7 +99,8 @@ var Element = function Element(_ref) {
|
|
|
99
99
|
asserts = config.asserts,
|
|
100
100
|
copyValue = config.copyValue,
|
|
101
101
|
selectValue = config.selectValue,
|
|
102
|
-
shouldRender = config.shouldRender
|
|
102
|
+
shouldRender = config.shouldRender,
|
|
103
|
+
dependField = config.dependField;
|
|
103
104
|
var dependentField = dependencies || [];
|
|
104
105
|
|
|
105
106
|
if (asserts && asserts.length) {
|
|
@@ -124,6 +125,10 @@ var Element = function Element(_ref) {
|
|
|
124
125
|
dependentField.push('SUBSCRIBE_ALL');
|
|
125
126
|
}
|
|
126
127
|
|
|
128
|
+
if (dependField) {
|
|
129
|
+
dependentField.push(dependField);
|
|
130
|
+
}
|
|
131
|
+
|
|
127
132
|
registerDependencies(dependentField, dispatch);
|
|
128
133
|
}, []);
|
|
129
134
|
(0, _invariant.default)(type !== 'Pages' && type !== 'Page', "".concat(type, " should not be inner form item"));
|
package/lib/form/login/index.js
CHANGED
|
@@ -47,7 +47,8 @@ var Login = function Login(_ref) {
|
|
|
47
47
|
|
|
48
48
|
var _useContext = (0, _react.useContext)(_context.default),
|
|
49
49
|
submitText = _useContext.submitText,
|
|
50
|
-
submitting = _useContext.submitting
|
|
50
|
+
submitting = _useContext.submitting,
|
|
51
|
+
showSubmitButton = _useContext.showSubmitButton;
|
|
51
52
|
|
|
52
53
|
var _useContext2 = (0, _react.useContext)(_locale.LocaleContext),
|
|
53
54
|
formatMessage = _useContext2.formatMessage;
|
|
@@ -73,7 +74,7 @@ var Login = function Login(_ref) {
|
|
|
73
74
|
}, index);
|
|
74
75
|
})
|
|
75
76
|
}), void 0)
|
|
76
|
-
}), void 0), (0, _jsxRuntime.jsx)(_form.default.Item, {
|
|
77
|
+
}), void 0), showSubmitButton && (0, _jsxRuntime.jsx)(_form.default.Item, {
|
|
77
78
|
children: (0, _jsxRuntime.jsx)(_button.default, Object.assign({
|
|
78
79
|
type: "primary",
|
|
79
80
|
htmlType: "submit",
|
|
@@ -89,7 +89,8 @@ var Element = function Element(props) {
|
|
|
89
89
|
asserts = props.asserts,
|
|
90
90
|
copyValue = props.copyValue,
|
|
91
91
|
selectValue = props.selectValue,
|
|
92
|
-
shouldRender = props.shouldRender
|
|
92
|
+
shouldRender = props.shouldRender,
|
|
93
|
+
dependField = props.dependField;
|
|
93
94
|
var dependentField = dependencies || [];
|
|
94
95
|
|
|
95
96
|
if (asserts && asserts.length) {
|
|
@@ -114,6 +115,10 @@ var Element = function Element(props) {
|
|
|
114
115
|
dependentField.push('SUBSCRIBE_ALL');
|
|
115
116
|
}
|
|
116
117
|
|
|
118
|
+
if (dependField) {
|
|
119
|
+
dependentField.push(dependField);
|
|
120
|
+
}
|
|
121
|
+
|
|
117
122
|
registerDependencies(dependentField, dispatch);
|
|
118
123
|
}, []);
|
|
119
124
|
var extraConfig = (0, _react.useMemo)(function () {
|
|
@@ -125,7 +130,7 @@ var Element = function Element(props) {
|
|
|
125
130
|
children === null || children === void 0 ? void 0 : (_children$type2 = children.type) === null || _children$type2 === void 0 ? void 0 : _children$type2.formItemPropsHandler(props) : {};
|
|
126
131
|
}, [children]);
|
|
127
132
|
|
|
128
|
-
var _calcFormItemProps = (0, _utils.calcFormItemProps)(props, _objectSpread(_objectSpread({}, extraConfig), {}, {
|
|
133
|
+
var _calcFormItemProps = (0, _utils.calcFormItemProps)((0, _omit.default)(props, ['children', 'parentName']), _objectSpread(_objectSpread({}, extraConfig), {}, {
|
|
129
134
|
requiredMark: requiredMark
|
|
130
135
|
}), form, parentName),
|
|
131
136
|
colProps = _calcFormItemProps.colProps,
|
|
@@ -194,7 +199,7 @@ var Element = function Element(props) {
|
|
|
194
199
|
|
|
195
200
|
var transformChildren = function transformChildren() {
|
|
196
201
|
if (! /*#__PURE__*/(0, _react.isValidElement)(children)) return children;
|
|
197
|
-
return /*#__PURE__*/(0, _react.cloneElement)(children, _objectSpread(_objectSpread({}, children.props), {}, {
|
|
202
|
+
return /*#__PURE__*/(0, _react.cloneElement)(children, _objectSpread(_objectSpread(_objectSpread({}, children.props), elementProps), {}, {
|
|
198
203
|
disabled: elementProps.disabled || disabled,
|
|
199
204
|
containerRef: ref,
|
|
200
205
|
setFieldError: setFieldError,
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import { FC, ReactNode } from 'react';
|
|
2
|
+
import './style';
|
|
3
|
+
interface ILayoutFooter {
|
|
4
|
+
companyInfoRender?: () => any;
|
|
5
|
+
copyRightRender?: (origin: ReactNode) => any;
|
|
6
|
+
tel?: string;
|
|
7
|
+
email?: string;
|
|
8
|
+
workTime?: any;
|
|
9
|
+
address?: string;
|
|
10
|
+
}
|
|
11
|
+
declare const LayoutFooter: FC<ILayoutFooter>;
|
|
12
|
+
export default LayoutFooter;
|
|
@@ -0,0 +1,288 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
require("antd/es/space/style");
|
|
9
|
+
|
|
10
|
+
var _space = _interopRequireDefault(require("antd/es/space"));
|
|
11
|
+
|
|
12
|
+
require("antd/es/grid/style");
|
|
13
|
+
|
|
14
|
+
var _grid = _interopRequireDefault(require("antd/es/grid"));
|
|
15
|
+
|
|
16
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
17
|
+
|
|
18
|
+
var _iglooicon = require("iglooicon");
|
|
19
|
+
|
|
20
|
+
var _typography = _interopRequireDefault(require("../typography"));
|
|
21
|
+
|
|
22
|
+
var _button = _interopRequireDefault(require("../button"));
|
|
23
|
+
|
|
24
|
+
require("./style");
|
|
25
|
+
|
|
26
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
27
|
+
|
|
28
|
+
var LayoutFooter = function LayoutFooter(_ref) {
|
|
29
|
+
var companyInfoRender = _ref.companyInfoRender,
|
|
30
|
+
copyRightRender = _ref.copyRightRender,
|
|
31
|
+
tel = _ref.tel,
|
|
32
|
+
email = _ref.email,
|
|
33
|
+
workTime = _ref.workTime,
|
|
34
|
+
address = _ref.address;
|
|
35
|
+
var useBreakpoint = _grid.default.useBreakpoint;
|
|
36
|
+
|
|
37
|
+
var _useBreakpoint = useBreakpoint(),
|
|
38
|
+
md = _useBreakpoint.md;
|
|
39
|
+
|
|
40
|
+
var topRightContent = companyInfoRender ? companyInfoRender() : (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
41
|
+
children: [(0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
42
|
+
className: "no-address-info"
|
|
43
|
+
}, {
|
|
44
|
+
children: [tel && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
45
|
+
className: "info-container",
|
|
46
|
+
style: {
|
|
47
|
+
alignItems: 'center'
|
|
48
|
+
}
|
|
49
|
+
}, {
|
|
50
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.PhoneOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
51
|
+
children: typeof tel === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
52
|
+
level: "body2",
|
|
53
|
+
className: "info-span"
|
|
54
|
+
}, {
|
|
55
|
+
children: tel
|
|
56
|
+
}), void 0) : tel
|
|
57
|
+
}, void 0)]
|
|
58
|
+
}), void 0), email && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
59
|
+
className: "info-container",
|
|
60
|
+
style: {
|
|
61
|
+
alignItems: 'center'
|
|
62
|
+
}
|
|
63
|
+
}, {
|
|
64
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.EmailOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
65
|
+
children: typeof email === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
66
|
+
level: "body2",
|
|
67
|
+
className: "info-span"
|
|
68
|
+
}, {
|
|
69
|
+
children: email
|
|
70
|
+
}), void 0) : email
|
|
71
|
+
}, void 0)]
|
|
72
|
+
}), void 0), workTime && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
73
|
+
className: "info-container"
|
|
74
|
+
}, {
|
|
75
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.TimeOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
76
|
+
children: typeof workTime === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
77
|
+
level: "body2",
|
|
78
|
+
className: "info-span"
|
|
79
|
+
}, {
|
|
80
|
+
children: workTime
|
|
81
|
+
}), void 0) : workTime
|
|
82
|
+
}, void 0)]
|
|
83
|
+
}), void 0)]
|
|
84
|
+
}), void 0), address && (0, _jsxRuntime.jsxs)(_space.default, Object.assign({
|
|
85
|
+
size: 16,
|
|
86
|
+
align: "start"
|
|
87
|
+
}, {
|
|
88
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.LocationOutlined, {
|
|
89
|
+
style: {
|
|
90
|
+
fontSize: 24
|
|
91
|
+
}
|
|
92
|
+
}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
93
|
+
children: typeof address === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
94
|
+
level: "body2",
|
|
95
|
+
className: "info-span"
|
|
96
|
+
}, {
|
|
97
|
+
children: address
|
|
98
|
+
}), void 0) : address
|
|
99
|
+
}, void 0)]
|
|
100
|
+
}), void 0)]
|
|
101
|
+
}, void 0);
|
|
102
|
+
|
|
103
|
+
if (md) {
|
|
104
|
+
return (0, _jsxRuntime.jsx)("div", Object.assign({
|
|
105
|
+
className: "igloo-layout-footer"
|
|
106
|
+
}, {
|
|
107
|
+
children: (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
108
|
+
className: "footer-content"
|
|
109
|
+
}, {
|
|
110
|
+
children: [(0, _jsxRuntime.jsxs)(_space.default, Object.assign({
|
|
111
|
+
size: 32,
|
|
112
|
+
align: "start",
|
|
113
|
+
className: "footer-top"
|
|
114
|
+
}, {
|
|
115
|
+
children: [(0, _jsxRuntime.jsx)("div", Object.assign({
|
|
116
|
+
className: "top-left"
|
|
117
|
+
}, {
|
|
118
|
+
children: (0, _jsxRuntime.jsx)("div", {
|
|
119
|
+
className: "igloo-logo"
|
|
120
|
+
}, void 0)
|
|
121
|
+
}), void 0), topRightContent]
|
|
122
|
+
}), void 0), (0, _jsxRuntime.jsx)("div", {
|
|
123
|
+
className: "footer-divider"
|
|
124
|
+
}, void 0), (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
125
|
+
className: "footer-bottom"
|
|
126
|
+
}, {
|
|
127
|
+
children: [copyRightRender ? copyRightRender("\xA9 ".concat(new Date().getFullYear(), " Powered by Axinan Pte Ltd. All Rights Reserved.")) : (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
128
|
+
level: "body3"
|
|
129
|
+
}, {
|
|
130
|
+
children: "\xA9 ".concat(new Date().getFullYear(), " Powered by Axinan Pte Ltd. All Rights Reserved.")
|
|
131
|
+
}), void 0), (0, _jsxRuntime.jsxs)(_typography.default, Object.assign({
|
|
132
|
+
level: "body3"
|
|
133
|
+
}, {
|
|
134
|
+
children: [(0, _jsxRuntime.jsx)(_button.default, Object.assign({
|
|
135
|
+
type: "text",
|
|
136
|
+
onClick: function onClick() {
|
|
137
|
+
return window.open('https://contents.iglooinsure.com/privacypolicy');
|
|
138
|
+
}
|
|
139
|
+
}, {
|
|
140
|
+
children: (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
141
|
+
level: "body3"
|
|
142
|
+
}, {
|
|
143
|
+
children: "Privacy Policy"
|
|
144
|
+
}), void 0)
|
|
145
|
+
}), void 0), ' ', (0, _jsxRuntime.jsx)("span", Object.assign({
|
|
146
|
+
style: {
|
|
147
|
+
margin: '0px 16px'
|
|
148
|
+
}
|
|
149
|
+
}, {
|
|
150
|
+
children: "|"
|
|
151
|
+
}), void 0), (0, _jsxRuntime.jsx)(_button.default, Object.assign({
|
|
152
|
+
type: "text",
|
|
153
|
+
onClick: function onClick() {
|
|
154
|
+
return window.open('https://contents.iglooinsure.com/termsofservice');
|
|
155
|
+
}
|
|
156
|
+
}, {
|
|
157
|
+
children: (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
158
|
+
level: "body3"
|
|
159
|
+
}, {
|
|
160
|
+
children: "Terms of Service"
|
|
161
|
+
}), void 0)
|
|
162
|
+
}), void 0)]
|
|
163
|
+
}), void 0)]
|
|
164
|
+
}), void 0)]
|
|
165
|
+
}), void 0)
|
|
166
|
+
}), void 0);
|
|
167
|
+
} else {
|
|
168
|
+
return (0, _jsxRuntime.jsx)("div", Object.assign({
|
|
169
|
+
className: "igloo-layout-footer"
|
|
170
|
+
}, {
|
|
171
|
+
children: (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
172
|
+
className: "footer-content"
|
|
173
|
+
}, {
|
|
174
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
175
|
+
className: "igloo-logo"
|
|
176
|
+
}, void 0), (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
177
|
+
className: "compony-info"
|
|
178
|
+
}, {
|
|
179
|
+
children: [tel && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
180
|
+
className: "info-item"
|
|
181
|
+
}, {
|
|
182
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.PhoneOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
183
|
+
children: typeof tel === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
184
|
+
level: "body3",
|
|
185
|
+
className: "info-span"
|
|
186
|
+
}, {
|
|
187
|
+
children: tel
|
|
188
|
+
}), void 0) : tel
|
|
189
|
+
}, void 0)]
|
|
190
|
+
}), void 0), email && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
191
|
+
className: "info-item"
|
|
192
|
+
}, {
|
|
193
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.EmailOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
194
|
+
children: typeof email === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
195
|
+
level: "body3",
|
|
196
|
+
className: "info-span"
|
|
197
|
+
}, {
|
|
198
|
+
children: email
|
|
199
|
+
}), void 0) : email
|
|
200
|
+
}, void 0)]
|
|
201
|
+
}), void 0), workTime && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
202
|
+
className: "info-item"
|
|
203
|
+
}, {
|
|
204
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.TimeOutlined, {}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
205
|
+
children: typeof workTime === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
206
|
+
level: "body3",
|
|
207
|
+
className: "info-span"
|
|
208
|
+
}, {
|
|
209
|
+
children: workTime
|
|
210
|
+
}), void 0) : workTime
|
|
211
|
+
}, void 0)]
|
|
212
|
+
}), void 0), address && (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
213
|
+
className: "info-item"
|
|
214
|
+
}, {
|
|
215
|
+
children: [(0, _jsxRuntime.jsx)(_iglooicon.LocationOutlined, {
|
|
216
|
+
style: {
|
|
217
|
+
fontSize: 24
|
|
218
|
+
}
|
|
219
|
+
}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
220
|
+
children: typeof address === 'string' ? (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
221
|
+
level: "body3",
|
|
222
|
+
className: "info-span"
|
|
223
|
+
}, {
|
|
224
|
+
children: address
|
|
225
|
+
}), void 0) : address
|
|
226
|
+
}, void 0)]
|
|
227
|
+
}), void 0)]
|
|
228
|
+
}), void 0), (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
229
|
+
className: "footer-bottom"
|
|
230
|
+
}, {
|
|
231
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
232
|
+
children: copyRightRender ? copyRightRender((0, _jsxRuntime.jsxs)("div", {
|
|
233
|
+
children: [(0, _jsxRuntime.jsxs)("div", {
|
|
234
|
+
children: ["\xA9 ", new Date().getFullYear(), " Powered by Axinan Pte Ltd."]
|
|
235
|
+
}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
236
|
+
children: "All Rights Reserved."
|
|
237
|
+
}, void 0)]
|
|
238
|
+
}, void 0)) : (0, _jsxRuntime.jsxs)(_typography.default, Object.assign({
|
|
239
|
+
level: "body3"
|
|
240
|
+
}, {
|
|
241
|
+
children: ["\xA9 ".concat(new Date().getFullYear(), " Powered by Axinan Pte Ltd."), (0, _jsxRuntime.jsx)("div", {
|
|
242
|
+
children: "All Rights Reserved."
|
|
243
|
+
}, void 0)]
|
|
244
|
+
}), void 0)
|
|
245
|
+
}, void 0), (0, _jsxRuntime.jsx)("div", {
|
|
246
|
+
children: (0, _jsxRuntime.jsxs)(_typography.default, Object.assign({
|
|
247
|
+
level: "body3"
|
|
248
|
+
}, {
|
|
249
|
+
children: [(0, _jsxRuntime.jsx)(_button.default, Object.assign({
|
|
250
|
+
type: "text",
|
|
251
|
+
onClick: function onClick() {
|
|
252
|
+
return window.open('https://contents.iglooinsure.com/privacypolicy');
|
|
253
|
+
}
|
|
254
|
+
}, {
|
|
255
|
+
children: (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
256
|
+
level: "body3"
|
|
257
|
+
}, {
|
|
258
|
+
children: "Privacy Policy"
|
|
259
|
+
}), void 0)
|
|
260
|
+
}), void 0), ' ', (0, _jsxRuntime.jsx)("span", Object.assign({
|
|
261
|
+
style: {
|
|
262
|
+
margin: '0px 16px'
|
|
263
|
+
}
|
|
264
|
+
}, {
|
|
265
|
+
children: "|"
|
|
266
|
+
}), void 0), ' ', (0, _jsxRuntime.jsx)(_button.default, Object.assign({
|
|
267
|
+
type: "text",
|
|
268
|
+
onClick: function onClick() {
|
|
269
|
+
return window.open('https://contents.iglooinsure.com/termsofservice');
|
|
270
|
+
}
|
|
271
|
+
}, {
|
|
272
|
+
children: (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
273
|
+
level: "body3"
|
|
274
|
+
}, {
|
|
275
|
+
children: "Terms of Service"
|
|
276
|
+
}), void 0)
|
|
277
|
+
}), void 0)]
|
|
278
|
+
}), void 0)
|
|
279
|
+
}, void 0)]
|
|
280
|
+
}), void 0)]
|
|
281
|
+
}), void 0)
|
|
282
|
+
}), void 0);
|
|
283
|
+
}
|
|
284
|
+
};
|
|
285
|
+
|
|
286
|
+
LayoutFooter.displayName = 'LayoutFooter';
|
|
287
|
+
var _default = LayoutFooter;
|
|
288
|
+
exports.default = _default;
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
import { FC } from 'react';
|
|
2
|
+
import { BadgeProps } from 'antd';
|
|
3
|
+
import './style/index';
|
|
4
|
+
interface Menu {
|
|
5
|
+
title: string;
|
|
6
|
+
key: string;
|
|
7
|
+
badge?: 'dot' | number | string | BadgeProps | (() => any);
|
|
8
|
+
}
|
|
9
|
+
interface Info {
|
|
10
|
+
title: string;
|
|
11
|
+
value: string;
|
|
12
|
+
}
|
|
13
|
+
interface Action {
|
|
14
|
+
title: string;
|
|
15
|
+
onClick?: () => void;
|
|
16
|
+
}
|
|
17
|
+
interface ILayoutHeader {
|
|
18
|
+
menus?: Menu[];
|
|
19
|
+
defaultSelected?: string;
|
|
20
|
+
selectedKey?: string;
|
|
21
|
+
onMenuChange?: (menuItem: any) => any;
|
|
22
|
+
dropMenuConfig?: {
|
|
23
|
+
customInfos: Info[];
|
|
24
|
+
actions: Action[];
|
|
25
|
+
};
|
|
26
|
+
userName?: string;
|
|
27
|
+
userAvatar?: string;
|
|
28
|
+
}
|
|
29
|
+
declare const LayoutHeader: FC<ILayoutHeader>;
|
|
30
|
+
export default LayoutHeader;
|
|
@@ -0,0 +1,258 @@
|
|
|
1
|
+
"use strict";
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, "__esModule", {
|
|
4
|
+
value: true
|
|
5
|
+
});
|
|
6
|
+
exports.default = void 0;
|
|
7
|
+
|
|
8
|
+
require("antd/es/avatar/style");
|
|
9
|
+
|
|
10
|
+
var _avatar = _interopRequireDefault(require("antd/es/avatar"));
|
|
11
|
+
|
|
12
|
+
require("antd/es/space/style");
|
|
13
|
+
|
|
14
|
+
var _space = _interopRequireDefault(require("antd/es/space"));
|
|
15
|
+
|
|
16
|
+
require("antd/es/col/style");
|
|
17
|
+
|
|
18
|
+
var _col = _interopRequireDefault(require("antd/es/col"));
|
|
19
|
+
|
|
20
|
+
require("antd/es/row/style");
|
|
21
|
+
|
|
22
|
+
var _row = _interopRequireDefault(require("antd/es/row"));
|
|
23
|
+
|
|
24
|
+
require("antd/es/badge/style");
|
|
25
|
+
|
|
26
|
+
var _badge = _interopRequireDefault(require("antd/es/badge"));
|
|
27
|
+
|
|
28
|
+
require("antd/es/grid/style");
|
|
29
|
+
|
|
30
|
+
var _grid = _interopRequireDefault(require("antd/es/grid"));
|
|
31
|
+
|
|
32
|
+
var _jsxRuntime = require("react/jsx-runtime");
|
|
33
|
+
|
|
34
|
+
var _react = require("react");
|
|
35
|
+
|
|
36
|
+
var _classnames = _interopRequireDefault(require("classnames"));
|
|
37
|
+
|
|
38
|
+
var _typography = _interopRequireDefault(require("../typography"));
|
|
39
|
+
|
|
40
|
+
var _index = _interopRequireDefault(require("../home-menu/index"));
|
|
41
|
+
|
|
42
|
+
var _avatar2 = _interopRequireDefault(require("./style/avatar.svg"));
|
|
43
|
+
|
|
44
|
+
require("./style/index");
|
|
45
|
+
|
|
46
|
+
function _interopRequireDefault(obj) { return obj && obj.__esModule ? obj : { default: obj }; }
|
|
47
|
+
|
|
48
|
+
function _typeof(obj) { "@babel/helpers - typeof"; if (typeof Symbol === "function" && typeof Symbol.iterator === "symbol") { _typeof = function _typeof(obj) { return typeof obj; }; } else { _typeof = function _typeof(obj) { return obj && typeof Symbol === "function" && obj.constructor === Symbol && obj !== Symbol.prototype ? "symbol" : typeof obj; }; } return _typeof(obj); }
|
|
49
|
+
|
|
50
|
+
function _slicedToArray(arr, i) { return _arrayWithHoles(arr) || _iterableToArrayLimit(arr, i) || _unsupportedIterableToArray(arr, i) || _nonIterableRest(); }
|
|
51
|
+
|
|
52
|
+
function _nonIterableRest() { throw new TypeError("Invalid attempt to destructure non-iterable instance.\nIn order to be iterable, non-array objects must have a [Symbol.iterator]() method."); }
|
|
53
|
+
|
|
54
|
+
function _unsupportedIterableToArray(o, minLen) { if (!o) return; if (typeof o === "string") return _arrayLikeToArray(o, minLen); var n = Object.prototype.toString.call(o).slice(8, -1); if (n === "Object" && o.constructor) n = o.constructor.name; if (n === "Map" || n === "Set") return Array.from(o); if (n === "Arguments" || /^(?:Ui|I)nt(?:8|16|32)(?:Clamped)?Array$/.test(n)) return _arrayLikeToArray(o, minLen); }
|
|
55
|
+
|
|
56
|
+
function _arrayLikeToArray(arr, len) { if (len == null || len > arr.length) len = arr.length; for (var i = 0, arr2 = new Array(len); i < len; i++) { arr2[i] = arr[i]; } return arr2; }
|
|
57
|
+
|
|
58
|
+
function _iterableToArrayLimit(arr, i) { var _i = arr == null ? null : typeof Symbol !== "undefined" && arr[Symbol.iterator] || arr["@@iterator"]; if (_i == null) return; var _arr = []; var _n = true; var _d = false; var _s, _e; try { for (_i = _i.call(arr); !(_n = (_s = _i.next()).done); _n = true) { _arr.push(_s.value); if (i && _arr.length === i) break; } } catch (err) { _d = true; _e = err; } finally { try { if (!_n && _i["return"] != null) _i["return"](); } finally { if (_d) throw _e; } } return _arr; }
|
|
59
|
+
|
|
60
|
+
function _arrayWithHoles(arr) { if (Array.isArray(arr)) return arr; }
|
|
61
|
+
|
|
62
|
+
var LayoutHeader = function LayoutHeader(_ref) {
|
|
63
|
+
var _ref$menus = _ref.menus,
|
|
64
|
+
menus = _ref$menus === void 0 ? [] : _ref$menus,
|
|
65
|
+
_ref$defaultSelected = _ref.defaultSelected,
|
|
66
|
+
defaultSelected = _ref$defaultSelected === void 0 ? '' : _ref$defaultSelected,
|
|
67
|
+
selectedKey = _ref.selectedKey,
|
|
68
|
+
onMenuChange = _ref.onMenuChange,
|
|
69
|
+
dropMenuConfig = _ref.dropMenuConfig,
|
|
70
|
+
userName = _ref.userName,
|
|
71
|
+
_ref$userAvatar = _ref.userAvatar,
|
|
72
|
+
userAvatar = _ref$userAvatar === void 0 ? _avatar2.default : _ref$userAvatar;
|
|
73
|
+
var useBreakpoint = _grid.default.useBreakpoint;
|
|
74
|
+
|
|
75
|
+
var _useBreakpoint = useBreakpoint(),
|
|
76
|
+
md = _useBreakpoint.md;
|
|
77
|
+
|
|
78
|
+
var _useState = (0, _react.useState)(selectedKey),
|
|
79
|
+
_useState2 = _slicedToArray(_useState, 2),
|
|
80
|
+
selectedMenu = _useState2[0],
|
|
81
|
+
setSelectedMenu = _useState2[1];
|
|
82
|
+
|
|
83
|
+
var _useState3 = (0, _react.useState)(defaultSelected),
|
|
84
|
+
_useState4 = _slicedToArray(_useState3, 2),
|
|
85
|
+
activeMenu = _useState4[0],
|
|
86
|
+
setActiveMenu = _useState4[1];
|
|
87
|
+
|
|
88
|
+
(0, _react.useEffect)(function () {
|
|
89
|
+
if (selectedKey) {
|
|
90
|
+
setSelectedMenu(selectedKey);
|
|
91
|
+
}
|
|
92
|
+
}, [selectedKey]);
|
|
93
|
+
|
|
94
|
+
var defaultMenuOnClick = function defaultMenuOnClick(menuConfig) {
|
|
95
|
+
var key = menuConfig.key;
|
|
96
|
+
setActiveMenu(key);
|
|
97
|
+
};
|
|
98
|
+
|
|
99
|
+
function getMenuDom(activeMenu, menuInfo) {
|
|
100
|
+
var badge = menuInfo.badge;
|
|
101
|
+
|
|
102
|
+
switch (_typeof(badge)) {
|
|
103
|
+
case 'string':
|
|
104
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
105
|
+
children: [(0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
106
|
+
className: (0, _classnames.default)({
|
|
107
|
+
'active-menu': activeMenu === menuInfo.key
|
|
108
|
+
}),
|
|
109
|
+
level: activeMenu === menuInfo.key ? 'h4' : 'body1'
|
|
110
|
+
}, {
|
|
111
|
+
children: menuInfo.title
|
|
112
|
+
}), void 0), (0, _jsxRuntime.jsx)(_badge.default, {
|
|
113
|
+
dot: true,
|
|
114
|
+
color: '#F52209'
|
|
115
|
+
}, void 0)]
|
|
116
|
+
}, void 0);
|
|
117
|
+
|
|
118
|
+
case 'number':
|
|
119
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
120
|
+
children: [(0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
121
|
+
className: (0, _classnames.default)({
|
|
122
|
+
'active-menu': activeMenu === menuInfo.key
|
|
123
|
+
}),
|
|
124
|
+
level: activeMenu === menuInfo.key ? 'h4' : 'body1'
|
|
125
|
+
}, {
|
|
126
|
+
children: menuInfo.title
|
|
127
|
+
}), void 0), (0, _jsxRuntime.jsx)(_badge.default, {
|
|
128
|
+
count: badge,
|
|
129
|
+
style: {
|
|
130
|
+
backgroundColor: '#F52209'
|
|
131
|
+
}
|
|
132
|
+
}, void 0)]
|
|
133
|
+
}, void 0);
|
|
134
|
+
|
|
135
|
+
case 'object':
|
|
136
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
137
|
+
children: [(0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
138
|
+
className: (0, _classnames.default)({
|
|
139
|
+
'active-menu': activeMenu === menuInfo.key
|
|
140
|
+
}),
|
|
141
|
+
level: activeMenu === menuInfo.key ? 'h4' : 'body1'
|
|
142
|
+
}, {
|
|
143
|
+
children: menuInfo.title
|
|
144
|
+
}), void 0), (0, _jsxRuntime.jsx)(_badge.default, Object.assign({}, badge), void 0)]
|
|
145
|
+
}, void 0);
|
|
146
|
+
|
|
147
|
+
case 'undefined':
|
|
148
|
+
return (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
149
|
+
className: (0, _classnames.default)({
|
|
150
|
+
'active-menu': activeMenu === menuInfo.key
|
|
151
|
+
}),
|
|
152
|
+
level: activeMenu === menuInfo.key ? 'h4' : 'body1'
|
|
153
|
+
}, {
|
|
154
|
+
children: menuInfo.title
|
|
155
|
+
}), void 0);
|
|
156
|
+
|
|
157
|
+
case 'function':
|
|
158
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
159
|
+
children: [(0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
160
|
+
className: (0, _classnames.default)({
|
|
161
|
+
'active-menu': activeMenu === menuInfo.key
|
|
162
|
+
}),
|
|
163
|
+
level: activeMenu === menuInfo.key ? 'h4' : 'body1'
|
|
164
|
+
}, {
|
|
165
|
+
children: menuInfo.title
|
|
166
|
+
}), void 0), badge()]
|
|
167
|
+
}, void 0);
|
|
168
|
+
}
|
|
169
|
+
}
|
|
170
|
+
|
|
171
|
+
if (md) {
|
|
172
|
+
return (0, _jsxRuntime.jsx)("div", Object.assign({
|
|
173
|
+
className: (0, _classnames.default)({
|
|
174
|
+
'igloo-layout-header': true,
|
|
175
|
+
'igloo-layout-header-fix': Boolean(menus === null || menus === void 0 ? void 0 : menus.length) || Boolean(dropMenuConfig)
|
|
176
|
+
})
|
|
177
|
+
}, {
|
|
178
|
+
children: (0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
179
|
+
className: "header-content"
|
|
180
|
+
}, {
|
|
181
|
+
children: [(0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
182
|
+
className: "header-left"
|
|
183
|
+
}, {
|
|
184
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
185
|
+
className: "igloo-logo"
|
|
186
|
+
}, void 0), Boolean(menus === null || menus === void 0 ? void 0 : menus.length) && (0, _jsxRuntime.jsx)(_row.default, {
|
|
187
|
+
children: menus.map(function (menu) {
|
|
188
|
+
return (0, _jsxRuntime.jsx)(_col.default, Object.assign({
|
|
189
|
+
className: (0, _classnames.default)('menu-item'),
|
|
190
|
+
onClick: function onClick() {
|
|
191
|
+
onMenuChange ? onMenuChange(menu) : defaultMenuOnClick(menu);
|
|
192
|
+
}
|
|
193
|
+
}, {
|
|
194
|
+
children: getMenuDom(selectedMenu || activeMenu, menu)
|
|
195
|
+
}), menu.key);
|
|
196
|
+
})
|
|
197
|
+
}, void 0)]
|
|
198
|
+
}), void 0), dropMenuConfig && (0, _jsxRuntime.jsxs)(_space.default, Object.assign({
|
|
199
|
+
size: 8
|
|
200
|
+
}, {
|
|
201
|
+
children: [(0, _jsxRuntime.jsx)(_avatar.default, {
|
|
202
|
+
size: 32,
|
|
203
|
+
src: userAvatar
|
|
204
|
+
}, void 0), (0, _jsxRuntime.jsx)(_typography.default, Object.assign({
|
|
205
|
+
level: "body1",
|
|
206
|
+
style: {
|
|
207
|
+
color: '#666666'
|
|
208
|
+
}
|
|
209
|
+
}, {
|
|
210
|
+
children: userName
|
|
211
|
+
}), void 0), dropMenuConfig && (0, _jsxRuntime.jsx)(_index.default, Object.assign({}, dropMenuConfig), void 0)]
|
|
212
|
+
}), void 0)]
|
|
213
|
+
}), void 0)
|
|
214
|
+
}), void 0);
|
|
215
|
+
} else {
|
|
216
|
+
return (0, _jsxRuntime.jsxs)(_jsxRuntime.Fragment, {
|
|
217
|
+
children: [(0, _jsxRuntime.jsxs)("div", Object.assign({
|
|
218
|
+
className: (0, _classnames.default)({
|
|
219
|
+
'igloo-layout-header': true,
|
|
220
|
+
'igloo-layout-header-fix': Boolean(menus === null || menus === void 0 ? void 0 : menus.length) || Boolean(dropMenuConfig)
|
|
221
|
+
})
|
|
222
|
+
}, {
|
|
223
|
+
children: [(0, _jsxRuntime.jsx)("div", {
|
|
224
|
+
className: "igloo-logo"
|
|
225
|
+
}, void 0), dropMenuConfig && (0, _jsxRuntime.jsx)(_index.default, Object.assign({
|
|
226
|
+
userAvatar: userAvatar,
|
|
227
|
+
userName: userName
|
|
228
|
+
}, dropMenuConfig), void 0)]
|
|
229
|
+
}), void 0), Boolean(menus === null || menus === void 0 ? void 0 : menus.length) && (0, _jsxRuntime.jsx)(_row.default, Object.assign({
|
|
230
|
+
className: "igloo-layout-menu"
|
|
231
|
+
}, {
|
|
232
|
+
children: menus.map(function (menu) {
|
|
233
|
+
var span = 24 / menus.length;
|
|
234
|
+
return (0, _jsxRuntime.jsx)(_col.default, Object.assign({
|
|
235
|
+
span: span,
|
|
236
|
+
className: (0, _classnames.default)('menu-item'),
|
|
237
|
+
onClick: function onClick() {
|
|
238
|
+
onMenuChange ? onMenuChange(menu) : defaultMenuOnClick(menu);
|
|
239
|
+
}
|
|
240
|
+
}, {
|
|
241
|
+
children: (0, _jsxRuntime.jsx)("div", Object.assign({
|
|
242
|
+
style: {
|
|
243
|
+
display: 'flex',
|
|
244
|
+
alignItems: 'flex-start'
|
|
245
|
+
}
|
|
246
|
+
}, {
|
|
247
|
+
children: getMenuDom(selectedMenu || activeMenu, menu)
|
|
248
|
+
}), void 0)
|
|
249
|
+
}), menu.key);
|
|
250
|
+
})
|
|
251
|
+
}), void 0)]
|
|
252
|
+
}, void 0);
|
|
253
|
+
}
|
|
254
|
+
};
|
|
255
|
+
|
|
256
|
+
LayoutHeader.displayName = 'LayoutHeader';
|
|
257
|
+
var _default = LayoutHeader;
|
|
258
|
+
exports.default = _default;
|