taro-react-uilib 1.0.2
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.esm.js +437 -0
- package/dist/index.esm.js.map +1 -0
- package/dist/index.js +453 -0
- package/dist/index.js.map +1 -0
- package/dist/index.umd.js +455 -0
- package/dist/index.umd.js.map +1 -0
- package/dist/styles/components/backIcon.scss +10 -0
- package/dist/styles/components/button.scss +99 -0
- package/dist/styles/components/captcha.scss +4 -0
- package/dist/styles/components/formInput.scss +120 -0
- package/dist/styles/components/image.scss +3 -0
- package/dist/styles/components/images/icon-arrow-right.png +0 -0
- package/dist/styles/components/images/loading.png +0 -0
- package/dist/styles/components/index.scss +9 -0
- package/dist/styles/components/list.scss +84 -0
- package/dist/styles/components/loading.scss +55 -0
- package/dist/styles/components/mask.scss +17 -0
- package/dist/styles/components/page.scss +9 -0
- package/dist/styles/index.scss +6 -0
- package/dist/styles/themes/base.scss +162 -0
- package/dist/styles/themes/default.scss +25 -0
- package/dist/styles/themes/variable.scss +20 -0
- package/lib/components/BankIcon/bank.js +33 -0
- package/lib/components/BankIcon/bank.js.map +1 -0
- package/lib/components/BankIcon/index.js +12 -0
- package/lib/components/BankIcon/index.js.map +1 -0
- package/lib/components/Button/index.js +36 -0
- package/lib/components/Button/index.js.map +1 -0
- package/lib/components/Captcha/index.js +60 -0
- package/lib/components/Captcha/index.js.map +1 -0
- package/lib/components/Dialog/Alert/index.js +35 -0
- package/lib/components/Dialog/Alert/index.js.map +1 -0
- package/lib/components/Dialog/Dialog/index.js +31 -0
- package/lib/components/Dialog/Dialog/index.js.map +1 -0
- package/lib/components/Dialog/index.js +6 -0
- package/lib/components/Dialog/index.js.map +1 -0
- package/lib/components/FormInput/index.js +55 -0
- package/lib/components/FormInput/index.js.map +1 -0
- package/lib/components/Image/index.js +33 -0
- package/lib/components/Image/index.js.map +1 -0
- package/lib/components/List/index.js +21 -0
- package/lib/components/List/index.js.map +1 -0
- package/lib/components/Loading/index.js +14 -0
- package/lib/components/Loading/index.js.map +1 -0
- package/lib/components/Mask/index.js +17 -0
- package/lib/components/Mask/index.js.map +1 -0
- package/lib/components/Page/index.js +15 -0
- package/lib/components/Page/index.js.map +1 -0
- package/lib/hooks/index.js +10 -0
- package/lib/hooks/index.js.map +1 -0
- package/lib/index.js +10 -0
- package/lib/index.js.map +1 -0
- package/lib/types/index.js +2 -0
- package/lib/types/index.js.map +1 -0
- package/lib/utils/index.js +51 -0
- package/lib/utils/index.js.map +1 -0
- package/package.json +132 -0
- package/readme.md +25 -0
- package/types/components/BankIcon/bank.d.ts +18 -0
- package/types/components/BankIcon/index.d.ts +11 -0
- package/types/components/Button/index.d.ts +41 -0
- package/types/components/Captcha/index.d.ts +17 -0
- package/types/components/Dialog/Alert/index.d.ts +10 -0
- package/types/components/Dialog/Dialog/index.d.ts +19 -0
- package/types/components/Dialog/index.d.ts +9 -0
- package/types/components/FormInput/index.d.ts +44 -0
- package/types/components/Image/index.d.ts +10 -0
- package/types/components/List/index.d.ts +14 -0
- package/types/components/Loading/index.d.ts +9 -0
- package/types/components/Mask/index.d.ts +10 -0
- package/types/components/Page/index.d.ts +10 -0
- package/types/hooks/index.d.ts +1 -0
- package/types/index.d.ts +9 -0
- package/types/types/index.d.ts +3 -0
- package/types/utils/index.d.ts +6 -0
package/dist/index.js
ADDED
|
@@ -0,0 +1,453 @@
|
|
|
1
|
+
'use strict';
|
|
2
|
+
|
|
3
|
+
Object.defineProperty(exports, '__esModule', { value: true });
|
|
4
|
+
|
|
5
|
+
var React = require('react');
|
|
6
|
+
var taro = require('@tarojs/taro');
|
|
7
|
+
var components = require('@tarojs/components');
|
|
8
|
+
|
|
9
|
+
function _interopDefaultLegacy (e) { return e && typeof e === 'object' && 'default' in e ? e : { 'default': e }; }
|
|
10
|
+
|
|
11
|
+
var React__default = /*#__PURE__*/_interopDefaultLegacy(React);
|
|
12
|
+
|
|
13
|
+
function createCommonjsModule(fn, basedir, module) {
|
|
14
|
+
return module = {
|
|
15
|
+
path: basedir,
|
|
16
|
+
exports: {},
|
|
17
|
+
require: function (path, base) {
|
|
18
|
+
return commonjsRequire(path, (base === undefined || base === null) ? module.path : base);
|
|
19
|
+
}
|
|
20
|
+
}, fn(module, module.exports), module.exports;
|
|
21
|
+
}
|
|
22
|
+
|
|
23
|
+
function commonjsRequire () {
|
|
24
|
+
throw new Error('Dynamic requires are not currently supported by @rollup/plugin-commonjs');
|
|
25
|
+
}
|
|
26
|
+
|
|
27
|
+
var classnames = createCommonjsModule(function (module) {
|
|
28
|
+
/*!
|
|
29
|
+
Copyright (c) 2018 Jed Watson.
|
|
30
|
+
Licensed under the MIT License (MIT), see
|
|
31
|
+
http://jedwatson.github.io/classnames
|
|
32
|
+
*/
|
|
33
|
+
/* global define */
|
|
34
|
+
|
|
35
|
+
(function () {
|
|
36
|
+
|
|
37
|
+
var hasOwn = {}.hasOwnProperty;
|
|
38
|
+
|
|
39
|
+
function classNames() {
|
|
40
|
+
var classes = [];
|
|
41
|
+
|
|
42
|
+
for (var i = 0; i < arguments.length; i++) {
|
|
43
|
+
var arg = arguments[i];
|
|
44
|
+
if (!arg) continue;
|
|
45
|
+
|
|
46
|
+
var argType = typeof arg;
|
|
47
|
+
|
|
48
|
+
if (argType === 'string' || argType === 'number') {
|
|
49
|
+
classes.push(arg);
|
|
50
|
+
} else if (Array.isArray(arg)) {
|
|
51
|
+
if (arg.length) {
|
|
52
|
+
var inner = classNames.apply(null, arg);
|
|
53
|
+
if (inner) {
|
|
54
|
+
classes.push(inner);
|
|
55
|
+
}
|
|
56
|
+
}
|
|
57
|
+
} else if (argType === 'object') {
|
|
58
|
+
if (arg.toString === Object.prototype.toString) {
|
|
59
|
+
for (var key in arg) {
|
|
60
|
+
if (hasOwn.call(arg, key) && arg[key]) {
|
|
61
|
+
classes.push(key);
|
|
62
|
+
}
|
|
63
|
+
}
|
|
64
|
+
} else {
|
|
65
|
+
classes.push(arg.toString());
|
|
66
|
+
}
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
return classes.join(' ');
|
|
71
|
+
}
|
|
72
|
+
|
|
73
|
+
if (module.exports) {
|
|
74
|
+
classNames.default = classNames;
|
|
75
|
+
module.exports = classNames;
|
|
76
|
+
} else {
|
|
77
|
+
window.classNames = classNames;
|
|
78
|
+
}
|
|
79
|
+
}());
|
|
80
|
+
});
|
|
81
|
+
|
|
82
|
+
/*! *****************************************************************************
|
|
83
|
+
Copyright (c) Microsoft Corporation.
|
|
84
|
+
|
|
85
|
+
Permission to use, copy, modify, and/or distribute this software for any
|
|
86
|
+
purpose with or without fee is hereby granted.
|
|
87
|
+
|
|
88
|
+
THE SOFTWARE IS PROVIDED "AS IS" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH
|
|
89
|
+
REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY
|
|
90
|
+
AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,
|
|
91
|
+
INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM
|
|
92
|
+
LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR
|
|
93
|
+
OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR
|
|
94
|
+
PERFORMANCE OF THIS SOFTWARE.
|
|
95
|
+
***************************************************************************** */
|
|
96
|
+
|
|
97
|
+
var __assign = function() {
|
|
98
|
+
__assign = Object.assign || function __assign(t) {
|
|
99
|
+
for (var s, i = 1, n = arguments.length; i < n; i++) {
|
|
100
|
+
s = arguments[i];
|
|
101
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];
|
|
102
|
+
}
|
|
103
|
+
return t;
|
|
104
|
+
};
|
|
105
|
+
return __assign.apply(this, arguments);
|
|
106
|
+
};
|
|
107
|
+
|
|
108
|
+
function __read(o, n) {
|
|
109
|
+
var m = typeof Symbol === "function" && o[Symbol.iterator];
|
|
110
|
+
if (!m) return o;
|
|
111
|
+
var i = m.call(o), r, ar = [], e;
|
|
112
|
+
try {
|
|
113
|
+
while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);
|
|
114
|
+
}
|
|
115
|
+
catch (error) { e = { error: error }; }
|
|
116
|
+
finally {
|
|
117
|
+
try {
|
|
118
|
+
if (r && !r.done && (m = i["return"])) m.call(i);
|
|
119
|
+
}
|
|
120
|
+
finally { if (e) throw e.error; }
|
|
121
|
+
}
|
|
122
|
+
return ar;
|
|
123
|
+
}
|
|
124
|
+
|
|
125
|
+
var useTaroEnv = function () {
|
|
126
|
+
var _a = __read(React.useState(""), 2), taroEnv = _a[0], setTaroEnv = _a[1];
|
|
127
|
+
React.useEffect(function () {
|
|
128
|
+
setTaroEnv(taro.getEnv());
|
|
129
|
+
}, []);
|
|
130
|
+
return taroEnv;
|
|
131
|
+
};
|
|
132
|
+
|
|
133
|
+
var XhButton = function (props) {
|
|
134
|
+
var _a = props.disabled, disabled = _a === void 0 ? false : _a, _b = props.type, type = _b === void 0 ? 'default' : _b, _c = props.size, size = _c === void 0 ? 'normal' : _c, _d = props.shape, shape = _d === void 0 ? 'round' : _d, children = props.children, className = props.className, htmlType = props.htmlType, formType = props.formType, text = props.text, openType = props.openType, lang = props.lang, sessionFrom = props.sessionFrom, sendMessageTitle = props.sendMessageTitle, sendMessagePath = props.sendMessagePath, sendMessageImg = props.sendMessageImg, showMessageCard = props.showMessageCard, appParameter = props.appParameter, onGetUserInfo = props.onGetUserInfo, onGetPhoneNumber = props.onGetPhoneNumber, onOpenSetting = props.onOpenSetting, onError = props.onError, onContact = props.onContact, onClick = props.onClick;
|
|
135
|
+
var state = useTaroEnv();
|
|
136
|
+
var classObj = classnames('xh-button', {
|
|
137
|
+
'xh-button-default': type === 'default',
|
|
138
|
+
'xh-button-primary': type === 'primary',
|
|
139
|
+
'xh-button-secondary': type === 'secondary',
|
|
140
|
+
'xh-button-warn': type === 'warn',
|
|
141
|
+
'xh-button-square': shape === 'square',
|
|
142
|
+
'xh-button-round': shape === 'round',
|
|
143
|
+
'xh-button-normal': size === 'normal',
|
|
144
|
+
'xh-button-small': size === 'mini',
|
|
145
|
+
'xh-button-full': size === 'full',
|
|
146
|
+
'xh-button-disabled': disabled,
|
|
147
|
+
'xh-button-webutton': state === 'WEAPP'
|
|
148
|
+
}, className);
|
|
149
|
+
var handleClick = function (e) {
|
|
150
|
+
state === 'WEB' && e.nativeEvent.stopImmediatePropagation();
|
|
151
|
+
e.preventDefault();
|
|
152
|
+
onClick && onClick(e);
|
|
153
|
+
};
|
|
154
|
+
var weButton = (React__default["default"].createElement(components.Button, { className: classObj, formType: formType, openType: openType, lang: lang, type: type, sessionFrom: sessionFrom, sendMessageTitle: sendMessageTitle, sendMessagePath: sendMessagePath, sendMessageImg: sendMessageImg, showMessageCard: showMessageCard, appParameter: appParameter, onGetUserInfo: onGetUserInfo, onGetPhoneNumber: onGetPhoneNumber, onOpenSetting: onOpenSetting, onError: onError, onContact: onContact, onClick: onClick, disabled: disabled }, children));
|
|
155
|
+
if (state === 'WEAPP') {
|
|
156
|
+
return weButton;
|
|
157
|
+
}
|
|
158
|
+
return (
|
|
159
|
+
// eslint-disable-next-line react/button-has-type
|
|
160
|
+
React__default["default"].createElement("button", { className: classObj, disabled: disabled, type: htmlType, onClick: disabled ? undefined : handleClick }, children || text));
|
|
161
|
+
};
|
|
162
|
+
|
|
163
|
+
var Mask = function (props) {
|
|
164
|
+
var _a = props.closeOnClickMask, closeOnClickMask = _a === void 0 ? true : _a, onClick = props.onClick, mask = props.mask;
|
|
165
|
+
var cls = classnames('xh-mask', {
|
|
166
|
+
'xh-mask-normal': mask === 'normal',
|
|
167
|
+
'xh-mask-transparent': mask === 'transparent',
|
|
168
|
+
});
|
|
169
|
+
function handleClick(e) {
|
|
170
|
+
closeOnClickMask && onClick && onClick(e);
|
|
171
|
+
}
|
|
172
|
+
return React__default["default"].createElement(components.View, { className: cls, onClick: handleClick });
|
|
173
|
+
};
|
|
174
|
+
|
|
175
|
+
var Loading = function (_a) {
|
|
176
|
+
var mask = _a.mask, className = _a.className;
|
|
177
|
+
var cls = classnames({ className: className });
|
|
178
|
+
return (React__default["default"].createElement(components.View, { className: "xh-loading" },
|
|
179
|
+
React__default["default"].createElement(Mask, { className: cls, mask: mask }),
|
|
180
|
+
React__default["default"].createElement(components.View, { className: "xh-loading-main" },
|
|
181
|
+
React__default["default"].createElement(components.View, { className: "xh-loading-icon" }))));
|
|
182
|
+
};
|
|
183
|
+
|
|
184
|
+
var Page = function (props) {
|
|
185
|
+
var children = props.children, _a = props.loading, loading = _a === void 0 ? false : _a, _b = props.className, className = _b === void 0 ? "" : _b, _c = props.mask, mask = _c === void 0 ? "normal" : _c;
|
|
186
|
+
var classObj = classnames("xh-page", className);
|
|
187
|
+
return (React__default["default"].createElement(components.View, { className: classObj },
|
|
188
|
+
loading && (React__default["default"].createElement(components.View, { className: "loading-wrapper" },
|
|
189
|
+
React__default["default"].createElement(Loading, { mask: mask }))),
|
|
190
|
+
children));
|
|
191
|
+
};
|
|
192
|
+
|
|
193
|
+
var XHImage = function (props) {
|
|
194
|
+
var _a = props.width, width = _a === void 0 ? "" : _a, _b = props.height, height = _b === void 0 ? "" : _b, src = props.src, className = props.className;
|
|
195
|
+
var _c = __read(React.useState({}), 2), defaultSize = _c[0], setDefaultSize = _c[1];
|
|
196
|
+
// const style = { width: `${width}px`, height: `${height}px` }
|
|
197
|
+
var state = useTaroEnv();
|
|
198
|
+
React.useEffect(function () {
|
|
199
|
+
if (state !== "WEB" && !className) {
|
|
200
|
+
taro.getImageInfo({
|
|
201
|
+
src: src,
|
|
202
|
+
success: function (res) {
|
|
203
|
+
if (res.errMsg === "getImageInfo:ok") {
|
|
204
|
+
console.log(res);
|
|
205
|
+
setDefaultSize({ width: res.width, height: res.height });
|
|
206
|
+
}
|
|
207
|
+
},
|
|
208
|
+
});
|
|
209
|
+
}
|
|
210
|
+
}, [state]);
|
|
211
|
+
var size = React.useMemo(function () {
|
|
212
|
+
if (width || height) {
|
|
213
|
+
return { width: width, height: height };
|
|
214
|
+
}
|
|
215
|
+
return defaultSize;
|
|
216
|
+
}, [width, height, defaultSize]);
|
|
217
|
+
return state !== "WEB" ? (React__default["default"].createElement(components.Image, { src: src, style: size, className: className })) : (React__default["default"].createElement("img", { src: src, alt: "", style: size, className: className }));
|
|
218
|
+
};
|
|
219
|
+
|
|
220
|
+
var img$e = "";
|
|
221
|
+
|
|
222
|
+
var img$d = "";
|
|
223
|
+
|
|
224
|
+
var img$c = "";
|
|
225
|
+
|
|
226
|
+
var img$b = "";
|
|
227
|
+
|
|
228
|
+
var img$a = "";
|
|
229
|
+
|
|
230
|
+
var img$9 = "";
|
|
231
|
+
|
|
232
|
+
var img$8 = "";
|
|
233
|
+
|
|
234
|
+
var img$7 = "";
|
|
235
|
+
|
|
236
|
+
var img$6 = "";
|
|
237
|
+
|
|
238
|
+
var img$5 = "";
|
|
239
|
+
|
|
240
|
+
var img$4 = "";
|
|
241
|
+
|
|
242
|
+
var img$3 = "";
|
|
243
|
+
|
|
244
|
+
var img$2 = "";
|
|
245
|
+
|
|
246
|
+
var img$1 = "";
|
|
247
|
+
|
|
248
|
+
var img = "";
|
|
249
|
+
|
|
250
|
+
var bankImage = {
|
|
251
|
+
'102': img$e,
|
|
252
|
+
'103': img$d,
|
|
253
|
+
'104': img$c,
|
|
254
|
+
'105': img$b,
|
|
255
|
+
'301': img$a,
|
|
256
|
+
'302': img$9,
|
|
257
|
+
'303': img$8,
|
|
258
|
+
'304': img$7,
|
|
259
|
+
'305': img$6,
|
|
260
|
+
'306': img$5,
|
|
261
|
+
'307': img$4,
|
|
262
|
+
'308': img$3,
|
|
263
|
+
'309': img$2,
|
|
264
|
+
'310': img$1,
|
|
265
|
+
'403': img
|
|
266
|
+
};
|
|
267
|
+
|
|
268
|
+
var XHBankIcon = function (props) {
|
|
269
|
+
var code = props.code, className = props.className, size = props.size;
|
|
270
|
+
var cls = classnames('xh-bank-icon', "item-".concat(size), className);
|
|
271
|
+
return (React__default["default"].createElement(XHImage, { src: bankImage[code], className: cls }));
|
|
272
|
+
};
|
|
273
|
+
|
|
274
|
+
var CountdownButton = React.forwardRef(function (props, fromRef) {
|
|
275
|
+
var timeout = props.timeout, _a = props.text, text = _a === void 0 ? "获取验证码" : _a, onClick = props.onClick, className = props.className;
|
|
276
|
+
var intervalRef = React.useRef();
|
|
277
|
+
var _b = __read(React.useState(0), 2), time = _b[0], setTime = _b[1];
|
|
278
|
+
var _c = __read(React.useState(false), 2), disabled = _c[0], setDisabled = _c[1];
|
|
279
|
+
var reset = function () {
|
|
280
|
+
intervalRef.current && clearInterval(intervalRef.current);
|
|
281
|
+
setTime(0);
|
|
282
|
+
setDisabled(false);
|
|
283
|
+
};
|
|
284
|
+
React.useImperativeHandle(fromRef, function () { return ({
|
|
285
|
+
reset: reset,
|
|
286
|
+
}); }, [intervalRef.current]);
|
|
287
|
+
React.useEffect(function () {
|
|
288
|
+
intervalRef.current && clearInterval(intervalRef.current);
|
|
289
|
+
return function () {
|
|
290
|
+
intervalRef.current && clearInterval(intervalRef.current);
|
|
291
|
+
};
|
|
292
|
+
}, []);
|
|
293
|
+
// 倒计时
|
|
294
|
+
var buttonText = React.useMemo(function () {
|
|
295
|
+
if (time) {
|
|
296
|
+
return "".concat(time, "\u79D2");
|
|
297
|
+
}
|
|
298
|
+
return text;
|
|
299
|
+
}, [time, text]);
|
|
300
|
+
var counter = function () {
|
|
301
|
+
var now = Date.now();
|
|
302
|
+
var nowStamp = now;
|
|
303
|
+
if (intervalRef.current) {
|
|
304
|
+
clearInterval(intervalRef.current);
|
|
305
|
+
}
|
|
306
|
+
setTime(timeout);
|
|
307
|
+
intervalRef.current = setInterval(function () {
|
|
308
|
+
nowStamp = Date.now();
|
|
309
|
+
var overTimeStamp = now + timeout * 1000 + 100;
|
|
310
|
+
var leftTime = Math.max(Math.floor((overTimeStamp - nowStamp) / 1000), 0);
|
|
311
|
+
if (leftTime === 0) {
|
|
312
|
+
intervalRef.current && clearInterval(intervalRef.current);
|
|
313
|
+
setDisabled(false);
|
|
314
|
+
}
|
|
315
|
+
setTime(leftTime);
|
|
316
|
+
}, 1000);
|
|
317
|
+
};
|
|
318
|
+
var handleClick = function () {
|
|
319
|
+
setDisabled(true);
|
|
320
|
+
var promise = onClick();
|
|
321
|
+
promise.then(counter).catch(function () {
|
|
322
|
+
console.log("callback reject....");
|
|
323
|
+
setDisabled(false);
|
|
324
|
+
});
|
|
325
|
+
};
|
|
326
|
+
return (React__default["default"].createElement(XhButton, __assign({}, props, { className: classnames("xh-downbutton", className), disabled: disabled, onClick: handleClick, ref: fromRef, type: "secondary", shape: "square", size: "mini" }), buttonText));
|
|
327
|
+
});
|
|
328
|
+
|
|
329
|
+
/**
|
|
330
|
+
* 禁止输入emoji表情
|
|
331
|
+
* @param {string} val - 输入内容
|
|
332
|
+
* @returns {boolean} - 校验结果 返回 true || false
|
|
333
|
+
*/
|
|
334
|
+
var inputRange = function (val) {
|
|
335
|
+
var iconRule1 = /[\uD83C|\uD83D|\uD83E][\uDC00-\uDFFF][\u200D|\uFE0F]|[\uD83C|\uD83D|\uD83E][\uDC00-\uDFFF]|[0-9|*|#]\uFE0F\u20E3|[0-9|#]\u20E3|[\u203C-\u3299]\uFE0F\u200D|[\u203C-\u3299]\uFE0F|[\u2122-\u2B55]|\u303D|[\A9|\AE]\u3030|\uA9|\uAE|\u3030/gi;
|
|
336
|
+
return val.replace(iconRule1, '');
|
|
337
|
+
};
|
|
338
|
+
// function Handler(fn) {
|
|
339
|
+
// this.handler = fn;
|
|
340
|
+
// this.next = null;
|
|
341
|
+
// }
|
|
342
|
+
// Handler.prototype.setNext = function setNext(h) {
|
|
343
|
+
// this.next = h;
|
|
344
|
+
// return h;
|
|
345
|
+
// };
|
|
346
|
+
// Handler.prototype.passRequest = function () {
|
|
347
|
+
// const ret = this.handler.apply(this, arguments);
|
|
348
|
+
// // 提前结束
|
|
349
|
+
// if (!ret) {
|
|
350
|
+
// return ret;
|
|
351
|
+
// }
|
|
352
|
+
// // 向后传递
|
|
353
|
+
// if (this.next) {
|
|
354
|
+
// return this.next.passRequest.apply(this.next, arguments);
|
|
355
|
+
// }
|
|
356
|
+
// return ret;
|
|
357
|
+
// };
|
|
358
|
+
// export class ChainHander {
|
|
359
|
+
// public hander: (s: string) => boolean
|
|
360
|
+
// public next
|
|
361
|
+
// constructor(fn: (str: string) => boolean) {
|
|
362
|
+
// this.hander = fn
|
|
363
|
+
// }
|
|
364
|
+
// public setNext(callback): () => boolean {
|
|
365
|
+
// this.next = callback
|
|
366
|
+
// return callback
|
|
367
|
+
// }
|
|
368
|
+
// public checkPass(...arg) {
|
|
369
|
+
// const result = this.hander.apply(this, arg)
|
|
370
|
+
// if (!result) {
|
|
371
|
+
// return result
|
|
372
|
+
// }
|
|
373
|
+
// if (this.next != null) {
|
|
374
|
+
// return this.next.checkPass.apply(this.next, arg)
|
|
375
|
+
// }
|
|
376
|
+
// return result
|
|
377
|
+
// }
|
|
378
|
+
// }
|
|
379
|
+
|
|
380
|
+
var FormInput = React__default["default"].forwardRef(function (props, formRef) {
|
|
381
|
+
var taroEnv = taro.getEnv();
|
|
382
|
+
var onChange = props.onChange, maxlength = props.maxlength, value = props.value, type = props.type, placeholder = props.placeholder, label = props.label, labelHtml = props.labelHtml, RightComponent = props.RightComponent, onBlur = props.onBlur, pattern = props.pattern, LeftComponent = props.LeftComponent, LeftIcon = props.LeftIcon, name = props.name, _a = props.readonly, readonly = _a === void 0 ? false : _a, _b = props.withArrow, withArrow = _b === void 0 ? false : _b, password = props.password;
|
|
383
|
+
function handleChange(e) {
|
|
384
|
+
var inputValue = inputRange(e.target.value);
|
|
385
|
+
e.target.value = inputValue;
|
|
386
|
+
onChange && onChange(inputValue);
|
|
387
|
+
}
|
|
388
|
+
function handleBlur(e) {
|
|
389
|
+
var inputValue = inputRange(e.target.value);
|
|
390
|
+
onBlur && onBlur(inputValue);
|
|
391
|
+
}
|
|
392
|
+
var inputRef = React.useRef(null);
|
|
393
|
+
React.useImperativeHandle(formRef, function () { return ({
|
|
394
|
+
focus: function () {
|
|
395
|
+
inputRef.current.focus();
|
|
396
|
+
},
|
|
397
|
+
}); });
|
|
398
|
+
if (taroEnv !== "WEB") {
|
|
399
|
+
return (React__default["default"].createElement(components.View, { className: "form-input" },
|
|
400
|
+
React__default["default"].createElement(components.View, { className: "form-input-left" },
|
|
401
|
+
label && (React__default["default"].createElement(components.View, { className: "form-input-left-label" },
|
|
402
|
+
label,
|
|
403
|
+
React__default["default"].createElement(components.View, { className: "form-input-left-label-icon" }, LeftIcon))),
|
|
404
|
+
labelHtml && (React__default["default"].createElement("label", { dangerouslySetInnerHTML: { __html: labelHtml }, className: "label" })),
|
|
405
|
+
React__default["default"].createElement(components.View, null, LeftComponent)),
|
|
406
|
+
React__default["default"].createElement(components.View, { className: "form-input-center" }, readonly ? (React__default["default"].createElement(components.Text, { className: classnames("form-input-readonly", {
|
|
407
|
+
"form-input-placeholder": !value,
|
|
408
|
+
}) }, value || placeholder)) : (React__default["default"].createElement(components.Input, { ref: inputRef, className: "form-input-center-native", maxlength: maxlength, name: name, placeholder: placeholder, type: type, value: value, onBlur: handleBlur, onInput: handleChange, password: password }))),
|
|
409
|
+
React__default["default"].createElement(components.View, { className: "form-input-right" },
|
|
410
|
+
RightComponent,
|
|
411
|
+
withArrow && React__default["default"].createElement(components.View, { className: "arrow" }))));
|
|
412
|
+
}
|
|
413
|
+
return (React__default["default"].createElement("div", { className: "form-input" },
|
|
414
|
+
React__default["default"].createElement("div", { className: "form-input-left" },
|
|
415
|
+
label && (React__default["default"].createElement("label", { className: "form-input-left-label" },
|
|
416
|
+
label,
|
|
417
|
+
React__default["default"].createElement(components.View, { className: "form-input-left-label-icon" }, LeftIcon))),
|
|
418
|
+
labelHtml && (React__default["default"].createElement("label", { dangerouslySetInnerHTML: { __html: labelHtml }, className: "label" })),
|
|
419
|
+
React__default["default"].createElement("div", null, LeftComponent)),
|
|
420
|
+
React__default["default"].createElement("div", { className: "form-input-center" }, readonly ? (React__default["default"].createElement("p", { className: classnames("form-input-readonly", {
|
|
421
|
+
"form-input-placeholder": !value,
|
|
422
|
+
}) }, value || placeholder)) : (React__default["default"].createElement("input", { ref: inputRef, className: "form-input-center-native", maxLength: maxlength, name: name, pattern: pattern, placeholder: placeholder, type: type, value: value, onBlur: handleBlur, onInput: handleChange }))),
|
|
423
|
+
React__default["default"].createElement("div", { className: "form-input-right" },
|
|
424
|
+
RightComponent,
|
|
425
|
+
withArrow && React__default["default"].createElement("i", { className: "arrow" }))));
|
|
426
|
+
});
|
|
427
|
+
|
|
428
|
+
var XHList = function (props) {
|
|
429
|
+
var _a = props.title, title = _a === void 0 ? '' : _a, _b = props.description, description = _b === void 0 ? '' : _b, icon = props.icon, _c = props.extra, extra = _c === void 0 ? '' : _c, _d = props.extraIcon, extraIcon = _d === void 0 ? '' : _d, arrow = props.arrow, _e = props.border, border = _e === void 0 ? true : _e, onClick = props.onClick;
|
|
430
|
+
var listcls = classnames('xh-list', { border: border });
|
|
431
|
+
var handleClick = function () {
|
|
432
|
+
onClick && onClick();
|
|
433
|
+
};
|
|
434
|
+
return (React__default["default"].createElement(components.View, { className: listcls, onClick: handleClick },
|
|
435
|
+
icon && React__default["default"].createElement(components.View, { className: 'xh-list-icon' }, icon),
|
|
436
|
+
React__default["default"].createElement(components.View, { className: 'xh-list-main' },
|
|
437
|
+
React__default["default"].createElement(components.Text, { className: 'xh-list-main-title' }, title),
|
|
438
|
+
React__default["default"].createElement(components.Text, { className: 'xh-list-main-description' }, description)),
|
|
439
|
+
React__default["default"].createElement(components.View, { className: "xh-list-extra" },
|
|
440
|
+
React__default["default"].createElement(components.View, { className: "xh-list-extra-info" }, extra),
|
|
441
|
+
React__default["default"].createElement(components.View, { className: "xh-list-extra-icon" }, extraIcon ? extraIcon : (arrow && React__default["default"].createElement(components.View, { className: "arrow" }))))));
|
|
442
|
+
};
|
|
443
|
+
|
|
444
|
+
exports.XHBankIcon = XHBankIcon;
|
|
445
|
+
exports.XHButton = XhButton;
|
|
446
|
+
exports.XHCaptcha = CountdownButton;
|
|
447
|
+
exports.XHFormInput = FormInput;
|
|
448
|
+
exports.XHImage = XHImage;
|
|
449
|
+
exports.XHList = XHList;
|
|
450
|
+
exports.XHLoading = Loading;
|
|
451
|
+
exports.XHMask = Mask;
|
|
452
|
+
exports.XHPage = Page;
|
|
453
|
+
//# sourceMappingURL=index.js.map
|