taro-react-uilib 1.1.0 → 1.2.0
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/CHANGELOG.md +38 -0
- package/dist/components/Checkbox/Group/index.js +2 -0
- package/dist/components/Checkbox/Group/index.js.map +1 -0
- package/dist/components/Checkbox/index.js +2 -0
- package/dist/components/Checkbox/index.js.map +1 -0
- package/dist/components/Picker/Picker.js +1 -1
- package/dist/components/Picker/Picker.js.map +1 -1
- package/dist/components/Picker/index.js +1 -1
- package/dist/components/Picker/index.js.map +1 -1
- package/dist/components/PickerSlot/index.js +2 -0
- package/dist/components/PickerSlot/index.js.map +1 -0
- package/dist/components/Radio/Group/index.js +2 -0
- package/dist/components/Radio/Group/index.js.map +1 -0
- package/dist/components/Radio/index.js +2 -0
- package/dist/components/Radio/index.js.map +1 -0
- package/dist/components/Space/Item.js +2 -0
- package/dist/components/Space/Item.js.map +1 -0
- package/dist/components/Space/config-provider.js +2 -0
- package/dist/components/Space/config-provider.js.map +1 -0
- package/dist/components/Space/index.js +2 -0
- package/dist/components/Space/index.js.map +1 -0
- package/dist/components/Step/Steps/index.js +2 -0
- package/dist/components/Step/Steps/index.js.map +1 -0
- package/dist/components/Step/index.js +2 -0
- package/dist/components/Step/index.js.map +1 -0
- package/dist/components/ThemeProvider/index.js +1 -1
- package/dist/components/ThemeProvider/index.js.map +1 -1
- package/dist/components/node_modules/css-vars-ponyfill/dist/css-vars-ponyfill.esm.js +172 -0
- package/dist/components/node_modules/css-vars-ponyfill/dist/css-vars-ponyfill.esm.js.map +1 -0
- package/dist/components/src/hooks/index.js +1 -1
- package/dist/components/src/hooks/index.js.map +1 -1
- package/dist/components/src/hooks/useFlexGapSupport.js +2 -0
- package/dist/components/src/hooks/useFlexGapSupport.js.map +1 -0
- package/dist/components/src/hooks/useGenerateId.js +2 -0
- package/dist/components/src/hooks/useGenerateId.js.map +1 -0
- package/dist/components/src/hooks/useRefs.js +2 -0
- package/dist/components/src/hooks/useRefs.js.map +1 -0
- package/dist/components/src/hooks/useTouch.js +2 -0
- package/dist/components/src/hooks/useTouch.js.map +1 -0
- package/dist/components/src/index.js +1 -1
- package/dist/components/src/utils/index.js +1 -1
- package/dist/components/src/utils/index.js.map +1 -1
- package/dist/index.js +173 -2
- package/dist/index.js.map +1 -1
- package/dist/index.umd.js +173 -2
- package/dist/index.umd.js.map +1 -1
- package/dist/styles/components/checkbox.scss +117 -0
- package/dist/styles/components/dialog.scss +2 -0
- package/dist/styles/components/font/.DS_Store +0 -0
- package/dist/styles/components/index.scss +5 -0
- package/dist/styles/components/numberkeyboard.scss +1 -3
- package/dist/styles/components/picker.scss +7 -112
- package/dist/styles/components/pickerslot.scss +98 -0
- package/dist/styles/components/radio.scss +102 -0
- package/dist/styles/components/space.scss +37 -0
- package/dist/styles/components/step.scss +173 -0
- package/dist/styles/components/themeprovider.scss +3 -0
- package/dist/styles/components/toast.scss +1 -1
- package/dist/styles/index.scss +1 -1
- package/dist/styles/themes/default.scss +13 -13
- package/dist/styles/themes/variable.scss +2 -0
- package/lib/components/Checkbox/Group/index.js +49 -0
- package/lib/components/Checkbox/Group/index.js.map +1 -0
- package/lib/components/Checkbox/index.js +43 -0
- package/lib/components/Checkbox/index.js.map +1 -0
- package/lib/components/Picker/Picker.js +192 -96
- package/lib/components/Picker/Picker.js.map +1 -1
- package/lib/components/Picker/index.js +2 -5
- package/lib/components/Picker/index.js.map +1 -1
- package/lib/components/PickerSlot/index.js +226 -0
- package/lib/components/PickerSlot/index.js.map +1 -0
- package/lib/components/Radio/Group/index.js +56 -0
- package/lib/components/Radio/Group/index.js.map +1 -0
- package/lib/components/Radio/index.js +43 -0
- package/lib/components/Radio/index.js.map +1 -0
- package/lib/components/Space/Item.js +25 -0
- package/lib/components/Space/Item.js.map +1 -0
- package/lib/components/Space/config-provider.js +8 -0
- package/lib/components/Space/config-provider.js.map +1 -0
- package/lib/components/Space/index.js +77 -0
- package/lib/components/Space/index.js.map +1 -0
- package/lib/components/Step/Steps/index.js +31 -0
- package/lib/components/Step/Steps/index.js.map +1 -0
- package/lib/components/Step/index.js +19 -0
- package/lib/components/Step/index.js.map +1 -0
- package/lib/components/ThemeProvider/index.js +4 -0
- package/lib/components/ThemeProvider/index.js.map +1 -1
- package/lib/hooks/index.js +0 -34
- package/lib/hooks/index.js.map +1 -1
- package/lib/hooks/useFlexGapSupport.js +10 -0
- package/lib/hooks/useFlexGapSupport.js.map +1 -0
- package/lib/hooks/useGenerateId.js +12 -0
- package/lib/hooks/useGenerateId.js.map +1 -0
- package/lib/hooks/useRefs.js +13 -0
- package/lib/hooks/useRefs.js.map +1 -0
- package/lib/hooks/useTouch.js +67 -0
- package/lib/hooks/useTouch.js.map +1 -0
- package/lib/index.js +4 -0
- package/lib/index.js.map +1 -1
- package/lib/utils/index.js +39 -2
- package/lib/utils/index.js.map +1 -1
- package/package.json +2 -1
- package/types/components/Checkbox/Group/index.d.ts +23 -0
- package/types/components/Checkbox/index.d.ts +29 -0
- package/types/components/Picker/Picker.d.ts +21 -20
- package/types/components/Picker/index.d.ts +6 -7
- package/types/components/PickerSlot/index.d.ts +24 -0
- package/types/components/Radio/Group/index.d.ts +26 -0
- package/types/components/Radio/index.d.ts +29 -0
- package/types/components/Space/Item.d.ts +11 -0
- package/types/components/Space/config-provider.d.ts +12 -0
- package/types/components/Space/index.d.ts +21 -0
- package/types/components/Step/Steps/index.d.ts +13 -0
- package/types/components/Step/index.d.ts +18 -0
- package/types/hooks/index.d.ts +0 -22
- package/types/hooks/useFlexGapSupport.d.ts +2 -0
- package/types/hooks/useGenerateId.d.ts +1 -0
- package/types/hooks/useRefs.d.ts +1 -0
- package/types/hooks/useTouch.d.ts +18 -0
- package/types/index.d.ts +4 -0
- package/types/utils/index.d.ts +6 -0
package/dist/styles/index.scss
CHANGED
|
@@ -5,28 +5,28 @@ $color-disabled: #d5d5d5;
|
|
|
5
5
|
$color-warning: #ff512d;
|
|
6
6
|
$color-warning-light: #ff5a66;
|
|
7
7
|
|
|
8
|
-
$background-color: #f6f6f6;
|
|
8
|
+
$background-color: #f6f6f6 !default;
|
|
9
9
|
|
|
10
|
-
$body-background-color: $background-color;
|
|
11
|
-
$component-background-color: $background-color;
|
|
10
|
+
$body-background-color: $background-color !default;
|
|
11
|
+
$component-background-color: $background-color !default;
|
|
12
12
|
|
|
13
|
-
$font-color: #333;
|
|
14
|
-
$font-color-secondary: #666;
|
|
15
|
-
$font-color-tertiary: #999;
|
|
13
|
+
$font-color: #333 !default;
|
|
14
|
+
$font-color-secondary: #666 !default;
|
|
15
|
+
$font-color-tertiary: #999 !default;
|
|
16
16
|
|
|
17
|
-
$border-color: #e6e6e6;
|
|
17
|
+
$border-color: #e6e6e6 !default;
|
|
18
18
|
|
|
19
19
|
$btn-font-size: 34px;
|
|
20
20
|
|
|
21
21
|
$btn-color: linear-gradient(90deg, $color-primary 0%, $color-primary-dark 100%);
|
|
22
22
|
$btn-shadow-primary: 0 10px 20px rgba(247, 174, 5, 0.3);
|
|
23
23
|
|
|
24
|
-
$mask-color: rgba(0, 0, 0, 0.3);
|
|
24
|
+
$mask-color: rgba(0, 0, 0, 0.3) !default;
|
|
25
25
|
|
|
26
|
-
$toast-bg-light: #4c4c4c;
|
|
27
|
-
$toast-bg-dark: #4c4c4c;
|
|
26
|
+
$toast-bg-light: #4c4c4c !default;
|
|
27
|
+
$toast-bg-dark: #4c4c4c !default;
|
|
28
28
|
|
|
29
|
-
$dialog-color-dark: #fff;
|
|
30
|
-
$dialog-color-light: rgba(255, 255, 255, 0.9);
|
|
29
|
+
$dialog-color-dark: #fff !default;
|
|
30
|
+
$dialog-color-light: rgba(255, 255, 255, 0.9) !default;
|
|
31
31
|
|
|
32
|
-
$border-radius: 10px;
|
|
32
|
+
$border-radius: 10px !default;
|
|
@@ -19,6 +19,7 @@ $xh-prefix: ".xh";
|
|
|
19
19
|
--mask-color: #{$mask-color};
|
|
20
20
|
--toast-bg-color: #{$toast-bg-light};
|
|
21
21
|
--dialog-color: #{$dialog-color-light};
|
|
22
|
+
--btn-font-size: #{$btn-font-size};
|
|
22
23
|
}
|
|
23
24
|
|
|
24
25
|
@media (prefers-color-scheme: dark) {
|
|
@@ -40,5 +41,6 @@ $xh-prefix: ".xh";
|
|
|
40
41
|
--mask-color: #{$mask-color};
|
|
41
42
|
--toast-bg-color: #{$toast-bg-dark};
|
|
42
43
|
--dialog-color: #{$dialog-color-dark};
|
|
44
|
+
--btn-font-size: #{$btn-font-size};
|
|
43
45
|
}
|
|
44
46
|
}
|
|
@@ -0,0 +1,49 @@
|
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import React, { useMemo, useState } from "react";
|
|
13
|
+
import classNames from "classnames";
|
|
14
|
+
import CheckBox from "..";
|
|
15
|
+
const CheckboxGroup = props => {
|
|
16
|
+
const { option, onChange, defaultChecked, padding, border, style, checkboxStyle } = props, rest = __rest(props, ["option", "onChange", "defaultChecked", "padding", "border", "style", "checkboxStyle"]);
|
|
17
|
+
const getOpions = useMemo(() => {
|
|
18
|
+
return option.map((item) => {
|
|
19
|
+
let checkedItem = typeof defaultChecked === "string" ? [defaultChecked] : defaultChecked;
|
|
20
|
+
if (typeof item === "string") {
|
|
21
|
+
return {
|
|
22
|
+
label: item,
|
|
23
|
+
value: item,
|
|
24
|
+
checked: checkedItem === null || checkedItem === void 0 ? void 0 : checkedItem.includes(item),
|
|
25
|
+
};
|
|
26
|
+
}
|
|
27
|
+
else {
|
|
28
|
+
if (checkedItem === null || checkedItem === void 0 ? void 0 : checkedItem.includes(item.value)) {
|
|
29
|
+
item.checked = true;
|
|
30
|
+
}
|
|
31
|
+
return item;
|
|
32
|
+
}
|
|
33
|
+
});
|
|
34
|
+
}, [option, defaultChecked]);
|
|
35
|
+
const [innerOption, setInnerOption] = useState(getOpions);
|
|
36
|
+
const handleChange = (checked, index) => {
|
|
37
|
+
const newoption = [...innerOption];
|
|
38
|
+
newoption[index].checked = checked;
|
|
39
|
+
setInnerOption(newoption);
|
|
40
|
+
const newValue = newoption.filter(k => k.checked).map(item => item.value);
|
|
41
|
+
onChange === null || onChange === void 0 ? void 0 : onChange(newValue);
|
|
42
|
+
};
|
|
43
|
+
const cls = classNames("xh-checkbox-group", { padding }, { border });
|
|
44
|
+
return (React.createElement("div", { className: cls, style: style }, innerOption.map((item, index) => {
|
|
45
|
+
return (React.createElement(CheckBox, Object.assign({ label: item.label, value: item.value, disabled: item.disabled, checked: item.checked, key: index, style: checkboxStyle, onChange: checked => handleChange(checked, index) }, rest)));
|
|
46
|
+
})));
|
|
47
|
+
};
|
|
48
|
+
export default CheckboxGroup;
|
|
49
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../../src/components/Checkbox/Group/index.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EAAa,OAAO,EAAE,QAAQ,EAAE,MAAM,OAAO,CAAC;AAC5D,OAAO,UAAU,MAAM,YAAY,CAAC;AAEpC,OAAO,QAAQ,MAAM,IAAI,CAAC;AAuB1B,MAAM,aAAa,GAAiC,KAAK,CAAC,EAAE;IAC1D,MAAM,EACJ,MAAM,EACN,QAAQ,EACR,cAAc,EACd,OAAO,EACP,MAAM,EACN,KAAK,EACL,aAAa,KAEX,KAAK,EADJ,IAAI,UACL,KAAK,EATH,uFASL,CAAQ,CAAC;IAEV,MAAM,SAAS,GAAG,OAAO,CAAC,GAAG,EAAE;QAC7B,OAAO,MAAM,CAAC,GAAG,CAAC,CAAC,IAA+B,EAAE,EAAE;YACpD,IAAI,WAAW,GACb,OAAO,cAAc,KAAK,QAAQ,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC,CAAC,CAAC,CAAC,cAAc,CAAC;YACzE,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;gBAC5B,OAAO;oBACL,KAAK,EAAE,IAAI;oBACX,KAAK,EAAE,IAAI;oBACX,OAAO,EAAE,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAC,IAAI,CAAC;iBACrC,CAAC;aACH;iBAAM;gBACL,IAAI,WAAW,aAAX,WAAW,uBAAX,WAAW,CAAE,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,EAAE;oBACrC,IAAI,CAAC,OAAO,GAAG,IAAI,CAAC;iBACrB;gBACD,OAAO,IAAI,CAAC;aACb;QACH,CAAC,CAAC,CAAC;IACL,CAAC,EAAE,CAAC,MAAM,EAAE,cAAc,CAAC,CAAC,CAAC;IAE7B,MAAM,CAAC,WAAW,EAAE,cAAc,CAAC,GAAG,QAAQ,CAAC,SAAS,CAAC,CAAC;IAE1D,MAAM,YAAY,GAAG,CAAC,OAAO,EAAE,KAAK,EAAE,EAAE;QACtC,MAAM,SAAS,GAAG,CAAC,GAAG,WAAW,CAAC,CAAC;QACnC,SAAS,CAAC,KAAK,CAAC,CAAC,OAAO,GAAG,OAAO,CAAC;QACnC,cAAc,CAAC,SAAS,CAAC,CAAC;QAC1B,MAAM,QAAQ,GAAG,SAAS,CAAC,MAAM,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,GAAG,CAAC,IAAI,CAAC,EAAE,CAAC,IAAI,CAAC,KAAK,CAAC,CAAC;QAC1E,QAAQ,aAAR,QAAQ,uBAAR,QAAQ,CAAG,QAAQ,CAAC,CAAC;IACvB,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,UAAU,CAAC,mBAAmB,EAAE,EAAE,OAAO,EAAE,EAAE,EAAE,MAAM,EAAE,CAAC,CAAC;IACrE,OAAO,CACL,6BAAK,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK,IAC9B,WAAW,CAAC,GAAG,CAAC,CAAC,IAAI,EAAE,KAAK,EAAE,EAAE;QAC/B,OAAO,CACL,oBAAC,QAAQ,kBACP,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,KAAK,EAAE,IAAI,CAAC,KAAK,EACjB,QAAQ,EAAE,IAAI,CAAC,QAAQ,EACvB,OAAO,EAAE,IAAI,CAAC,OAAO,EACrB,GAAG,EAAE,KAAK,EACV,KAAK,EAAE,aAAa,EACpB,QAAQ,EAAE,OAAO,CAAC,EAAE,CAAC,YAAY,CAAC,OAAO,EAAE,KAAK,CAAC,IAC7C,IAAI,EACR,CACH,CAAC;IACJ,CAAC,CAAC,CACE,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,aAAa,CAAC"}
|
|
@@ -0,0 +1,43 @@
|
|
|
1
|
+
import React from "react";
|
|
2
|
+
import classNames from "classnames";
|
|
3
|
+
import { CheckboxGroup } from "@tarojs/components";
|
|
4
|
+
import useGenerateId from "@/hooks/useGenerateId";
|
|
5
|
+
import Group from "./Group";
|
|
6
|
+
import "./index.scss";
|
|
7
|
+
const XHCheckbox = props => {
|
|
8
|
+
const { className, name, label, id, circle, onChange, align, direction, justify, checked, disabled, value, style, color = "#f6ab00", } = props;
|
|
9
|
+
const finalId = useGenerateId(id, "xh-checkbox-id");
|
|
10
|
+
const handleOnchange = e => {
|
|
11
|
+
let finalchecked = checked || false;
|
|
12
|
+
let value = "";
|
|
13
|
+
if (process.env.TARO_ENV === "h5") {
|
|
14
|
+
finalchecked = e.target.checked;
|
|
15
|
+
value = e.target.value;
|
|
16
|
+
}
|
|
17
|
+
else {
|
|
18
|
+
finalchecked = e.detail.value.length > 0;
|
|
19
|
+
value = e.detail.value[0];
|
|
20
|
+
}
|
|
21
|
+
onChange && onChange(finalchecked, value);
|
|
22
|
+
};
|
|
23
|
+
const cls = classNames("xh-checkbox", className, align, direction, justify, {
|
|
24
|
+
h5: process.env.TARO_ENV === "h5",
|
|
25
|
+
});
|
|
26
|
+
if (process.env.TARO_ENV !== "h5") {
|
|
27
|
+
return (React.createElement(CheckboxGroup, { onChange: handleOnchange },
|
|
28
|
+
React.createElement("label", { htmlFor: finalId, className: cls, style: style },
|
|
29
|
+
React.createElement("input", { type: "checkbox", id: finalId, name: name, className: classNames("xh-checkbox-input", {
|
|
30
|
+
tt: process.env.TARO_ENV === "tt",
|
|
31
|
+
}), onChange: handleOnchange, disabled: disabled, value: value, checked: checked, color: color }),
|
|
32
|
+
React.createElement("span", { className: classNames("xh-checkbox-input-fake", circle && "circle", { tt: process.env.TARO_ENV === "tt" }) }),
|
|
33
|
+
React.createElement("span", { className: "xh-checkbox-label" }, label))));
|
|
34
|
+
}
|
|
35
|
+
return (React.createElement("label", { htmlFor: finalId, className: cls, style: style },
|
|
36
|
+
React.createElement("input", { type: "checkbox", id: finalId, name: name, className: "xh-checkbox-input", onChange: handleOnchange, value: value, defaultChecked: checked }),
|
|
37
|
+
React.createElement("span", { className: classNames("xh-checkbox-input-fake", circle && "circle") }),
|
|
38
|
+
React.createElement("span", { className: "xh-checkbox-label" }, label)));
|
|
39
|
+
};
|
|
40
|
+
const CheckBox = XHCheckbox;
|
|
41
|
+
CheckBox.Group = Group;
|
|
42
|
+
export default CheckBox;
|
|
43
|
+
//# sourceMappingURL=index.js.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Checkbox/index.tsx"],"names":[],"mappings":"AACA,OAAO,KAAwB,MAAM,OAAO,CAAC;AAC7C,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;AACnD,OAAO,aAAa,MAAM,uBAAuB,CAAC;AAClD,OAAO,KAAK,MAAM,SAAS,CAAC;AAC5B,OAAO,cAAc,CAAC;AA6BtB,MAAM,UAAU,GAAwB,KAAK,CAAC,EAAE;IAC9C,MAAM,EACJ,SAAS,EACT,IAAI,EACJ,KAAK,EACL,EAAE,EACF,MAAM,EACN,QAAQ,EACR,KAAK,EACL,SAAS,EACT,OAAO,EACP,OAAO,EACP,QAAQ,EACR,KAAK,EACL,KAAK,EACL,KAAK,GAAG,SAAS,GAClB,GAAG,KAAK,CAAC;IAEV,MAAM,OAAO,GAAG,aAAa,CAAC,EAAE,EAAE,gBAAgB,CAAC,CAAC;IAEpD,MAAM,cAAc,GAAG,CAAC,CAAC,EAAE;QACzB,IAAI,YAAY,GAAG,OAAO,IAAI,KAAK,CAAC;QACpC,IAAI,KAAK,GAAG,EAAE,CAAC;QACf,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI,EAAE;YACjC,YAAY,GAAG,CAAC,CAAC,MAAM,CAAC,OAAO,CAAC;YAChC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC;SACxB;aAAM;YACL,YAAY,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,MAAM,GAAG,CAAC,CAAC;YACzC,KAAK,GAAG,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC;SAC3B;QACD,QAAQ,IAAI,QAAQ,CAAC,YAAY,EAAE,KAAK,CAAC,CAAC;IAC5C,CAAC,CAAC;IAEF,MAAM,GAAG,GAAG,UAAU,CAAC,aAAa,EAAE,SAAS,EAAE,KAAK,EAAE,SAAS,EAAE,OAAO,EAAE;QAC1E,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI;KAClC,CAAC,CAAC;IACH,IAAI,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI,EAAE;QACjC,OAAO,CACL,oBAAC,aAAa,IAAC,QAAQ,EAAE,cAAc;YACrC,+BAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK;gBACnD,+BACE,IAAI,EAAC,UAAU,EACf,EAAE,EAAE,OAAO,EACX,IAAI,EAAE,IAAI,EACV,SAAS,EAAE,UAAU,CAAC,mBAAmB,EAAE;wBACzC,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI;qBAClC,CAAC,EACF,QAAQ,EAAE,cAAc,EACxB,QAAQ,EAAE,QAAQ,EAClB,KAAK,EAAE,KAAK,EACZ,OAAO,EAAE,OAAO,EAChB,KAAK,EAAE,KAAK,GACZ;gBACF,8BACE,SAAS,EAAE,UAAU,CACnB,wBAAwB,EACxB,MAAM,IAAI,QAAQ,EAClB,EAAE,EAAE,EAAE,OAAO,CAAC,GAAG,CAAC,QAAQ,KAAK,IAAI,EAAE,CACtC,GACK;gBACR,8BAAM,SAAS,EAAC,mBAAmB,IAAE,KAAK,CAAQ,CAC5C,CACM,CACjB,CAAC;KACH;IAED,OAAO,CACL,+BAAO,OAAO,EAAE,OAAO,EAAE,SAAS,EAAE,GAAG,EAAE,KAAK,EAAE,KAAK;QACnD,+BACE,IAAI,EAAC,UAAU,EACf,EAAE,EAAE,OAAO,EACX,IAAI,EAAE,IAAI,EACV,SAAS,EAAC,mBAAmB,EAC7B,QAAQ,EAAE,cAAc,EACxB,KAAK,EAAE,KAAK,EACZ,cAAc,EAAE,OAAO,GACvB;QACF,8BACE,SAAS,EAAE,UAAU,CAAC,wBAAwB,EAAE,MAAM,IAAI,QAAQ,CAAC,GAC7D;QACR,8BAAM,SAAS,EAAC,mBAAmB,IAAE,KAAK,CAAQ,CAC5C,CACT,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,QAAQ,GAAG,UAAiC,CAAC;AACnD,QAAQ,CAAC,KAAK,GAAG,KAAK,CAAC;AAEvB,eAAe,QAAQ,CAAC"}
|
|
@@ -1,109 +1,205 @@
|
|
|
1
|
-
|
|
2
|
-
|
|
1
|
+
var __rest = (this && this.__rest) || function (s, e) {
|
|
2
|
+
var t = {};
|
|
3
|
+
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)
|
|
4
|
+
t[p] = s[p];
|
|
5
|
+
if (s != null && typeof Object.getOwnPropertySymbols === "function")
|
|
6
|
+
for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {
|
|
7
|
+
if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))
|
|
8
|
+
t[p[i]] = s[p[i]];
|
|
9
|
+
}
|
|
10
|
+
return t;
|
|
11
|
+
};
|
|
12
|
+
import React, { useState, useEffect, useRef, } from "react";
|
|
3
13
|
import classNames from "classnames";
|
|
4
14
|
import Popup from "../Popup";
|
|
5
|
-
import
|
|
6
|
-
import
|
|
7
|
-
const
|
|
8
|
-
const { visible, title,
|
|
9
|
-
const [
|
|
10
|
-
const
|
|
11
|
-
const
|
|
12
|
-
const [
|
|
13
|
-
const
|
|
14
|
-
const
|
|
15
|
-
|
|
16
|
-
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
15
|
+
import PickerSlot from "../PickerSlot";
|
|
16
|
+
import useRefs from "../../hooks/useRefs";
|
|
17
|
+
const InternalPicker = (props, ref) => {
|
|
18
|
+
const { visible, title, data = [], defaultValueData, onConfirm, onClose, onCloseUpdate, onChange, className, style, mode, swipeDuration } = props, rest = __rest(props, ["visible", "title", "data", "defaultValueData", "onConfirm", "onClose", "onCloseUpdate", "onChange", "className", "style", "mode", "swipeDuration"]);
|
|
19
|
+
const [chooseValueData, setchooseValueData] = useState([]); // 选择的数据的 value 值, 每一条数据的 value 值
|
|
20
|
+
const [columnIndex, setcolumnIndex] = useState(0); // 选中列
|
|
21
|
+
const pickerRef = useRef(null);
|
|
22
|
+
const [refs, setRefs] = useRefs();
|
|
23
|
+
const [columnsList, setColumnsList] = useState([]); // 格式化后每一列的数据
|
|
24
|
+
const isConfirmEvent = useRef(false);
|
|
25
|
+
// 默认值修改
|
|
26
|
+
useEffect(() => {
|
|
27
|
+
if (defaultValueData &&
|
|
28
|
+
defaultValueData.length !== 0 &&
|
|
29
|
+
defaultValueData.toString() !== chooseValueData.toString()) {
|
|
30
|
+
const data = [...defaultValueData];
|
|
31
|
+
setchooseValueData(data);
|
|
32
|
+
setColumnsList(normalListData());
|
|
33
|
+
}
|
|
34
|
+
}, [defaultValueData]);
|
|
35
|
+
// 选中值进行修改
|
|
36
|
+
useEffect(() => {
|
|
37
|
+
onChange && onChange(columnIndex, chooseValueData, selectedOptions());
|
|
38
|
+
if (isConfirmEvent.current) {
|
|
39
|
+
isConfirmEvent.current = false;
|
|
40
|
+
onConfirm && onConfirm(selectedOptions(), columnIndex);
|
|
41
|
+
}
|
|
42
|
+
}, [chooseValueData]);
|
|
43
|
+
// 列表格式修改
|
|
44
|
+
useEffect(() => {
|
|
45
|
+
init();
|
|
46
|
+
}, [data]);
|
|
47
|
+
const closeActionSheet = e => {
|
|
48
|
+
e.stopPropagation();
|
|
49
|
+
onClose && onClose();
|
|
50
|
+
// onCloseUpdate &&
|
|
51
|
+
// onCloseUpdate(chooseValueData, selectedOptions(), pickerRef);
|
|
52
|
+
};
|
|
53
|
+
// 点击确定
|
|
54
|
+
const confirm = e => {
|
|
55
|
+
e.stopPropagation();
|
|
56
|
+
let movings = false;
|
|
57
|
+
refs.forEach((_ref) => {
|
|
58
|
+
if (_ref.moving)
|
|
59
|
+
movings = true;
|
|
60
|
+
_ref.stopMomentum();
|
|
61
|
+
});
|
|
62
|
+
if (movings) {
|
|
63
|
+
isConfirmEvent.current = true;
|
|
64
|
+
}
|
|
65
|
+
else {
|
|
66
|
+
onConfirm && onConfirm(selectedOptions(), columnIndex);
|
|
67
|
+
}
|
|
68
|
+
onClose && onClose();
|
|
69
|
+
setTimeout(() => {
|
|
70
|
+
isConfirmEvent.current = false;
|
|
71
|
+
}, 0);
|
|
72
|
+
};
|
|
73
|
+
const selectedOptions = () => {
|
|
74
|
+
const optins = [];
|
|
75
|
+
columnsList.map((column, index) => {
|
|
76
|
+
let currOptions = [];
|
|
77
|
+
currOptions = column.filter(item => (typeof item === "object" ? item.value : item) ===
|
|
78
|
+
chooseValueData[index]);
|
|
79
|
+
if (currOptions[0]) {
|
|
80
|
+
optins.push(currOptions[0]);
|
|
81
|
+
}
|
|
82
|
+
else {
|
|
83
|
+
column[0] && optins.push(column[0]);
|
|
84
|
+
}
|
|
85
|
+
return column;
|
|
23
86
|
});
|
|
87
|
+
return optins;
|
|
24
88
|
};
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
89
|
+
// 选择每一列的数据
|
|
90
|
+
const chooseItem = (option, columnIndex) => {
|
|
91
|
+
if (option && Object.keys(option).length) {
|
|
92
|
+
// 移动后是否与之前有差异
|
|
93
|
+
if (chooseValueData[columnIndex] !==
|
|
94
|
+
(typeof option === "string" ? option : option.value)) {
|
|
95
|
+
if (columnsType() === "cascade") {
|
|
96
|
+
chooseValueData[columnIndex] =
|
|
97
|
+
typeof option === "object" ? option.value : option || "";
|
|
98
|
+
setchooseValueData([...chooseValueData]);
|
|
99
|
+
let index = columnIndex;
|
|
100
|
+
let cursor = option;
|
|
101
|
+
while (typeof cursor === "object" &&
|
|
102
|
+
cursor &&
|
|
103
|
+
cursor.children &&
|
|
104
|
+
cursor.children[0]) {
|
|
105
|
+
chooseValueData[index + 1] = cursor.children[0].value;
|
|
106
|
+
setchooseValueData([...chooseValueData]);
|
|
107
|
+
index++;
|
|
108
|
+
cursor = cursor.children[0];
|
|
109
|
+
}
|
|
110
|
+
// 当前改变列的下一列 children 值为空
|
|
111
|
+
if (typeof cursor === "object" && cursor && cursor.children) {
|
|
112
|
+
chooseValueData[index + 1] = "";
|
|
113
|
+
setchooseValueData([...chooseValueData]);
|
|
114
|
+
}
|
|
115
|
+
setColumnsList(normalListData());
|
|
116
|
+
}
|
|
117
|
+
else {
|
|
118
|
+
setchooseValueData(data => {
|
|
119
|
+
const cdata = [...data];
|
|
120
|
+
cdata[columnIndex] =
|
|
121
|
+
(typeof option === "string" ? option : option.value) || "";
|
|
122
|
+
return cdata;
|
|
123
|
+
});
|
|
124
|
+
}
|
|
125
|
+
setcolumnIndex(columnIndex);
|
|
126
|
+
}
|
|
127
|
+
}
|
|
30
128
|
};
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
129
|
+
// 传入的数据格式化
|
|
130
|
+
const normalListData = () => {
|
|
131
|
+
const type = columnsType();
|
|
132
|
+
switch (type) {
|
|
133
|
+
case "multiple":
|
|
134
|
+
return data;
|
|
135
|
+
case "cascade":
|
|
136
|
+
// 级联数据处理
|
|
137
|
+
return formatCascade(data, chooseValueData);
|
|
138
|
+
default:
|
|
139
|
+
return [data];
|
|
36
140
|
}
|
|
37
|
-
}, [visible, data.length]);
|
|
38
|
-
function handleSelect(index, e) {
|
|
39
|
-
setSelectIndex(index);
|
|
40
|
-
handleConfirm(e, index);
|
|
41
|
-
}
|
|
42
|
-
function getValue(index) {
|
|
43
|
-
return data[index];
|
|
44
|
-
}
|
|
45
|
-
function handleCancel(e) {
|
|
46
|
-
setSelectIndex(selectIndex);
|
|
47
|
-
onCancel && onCancel(e);
|
|
48
|
-
onClose && onClose(e);
|
|
49
|
-
}
|
|
50
|
-
function handleConfirm(e, index = selectIndex) {
|
|
51
|
-
const value = getValue(index);
|
|
52
|
-
onConfirm && onConfirm(value, index);
|
|
53
|
-
onClose && onClose(e);
|
|
54
|
-
}
|
|
55
|
-
const handleToucMove = (e) => {
|
|
56
|
-
e.preventDefault();
|
|
57
|
-
e.stopPropagation();
|
|
58
|
-
// 试验
|
|
59
|
-
touch.touchmove(e);
|
|
60
|
-
const distanceY = touch.touchMoveDistance.y;
|
|
61
|
-
if (distanceY === 0)
|
|
62
|
-
return; // 点击事件
|
|
63
|
-
console.log(distanceY);
|
|
64
|
-
console.log("distanceY");
|
|
65
|
-
let finaltrans = distanceY + lastTranslateY.current;
|
|
66
|
-
if (Math.abs(finaltrans) < perItemHeight / 3)
|
|
67
|
-
return;
|
|
68
|
-
if (finaltrans >= perItemHeight)
|
|
69
|
-
return;
|
|
70
|
-
if (finaltrans <= -perItemHeight * data.length - threshold)
|
|
71
|
-
return;
|
|
72
|
-
setTransformDistance(finaltrans);
|
|
73
141
|
};
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
78
|
-
|
|
142
|
+
// 每一列的类型
|
|
143
|
+
const columnsType = () => {
|
|
144
|
+
const firstColumn = data[0];
|
|
145
|
+
if (firstColumn) {
|
|
146
|
+
if (Array.isArray(firstColumn)) {
|
|
147
|
+
return "multiple";
|
|
148
|
+
}
|
|
149
|
+
if (typeof firstColumn === "object" && "children" in firstColumn) {
|
|
150
|
+
return "cascade";
|
|
151
|
+
}
|
|
152
|
+
}
|
|
153
|
+
return "single";
|
|
154
|
+
};
|
|
155
|
+
// 级联数据格式化
|
|
156
|
+
const formatCascade = (columns, defaultValues) => {
|
|
157
|
+
const formatted = [];
|
|
158
|
+
let cursor = {
|
|
159
|
+
text: "",
|
|
160
|
+
value: "",
|
|
161
|
+
children: columns,
|
|
162
|
+
};
|
|
163
|
+
let columnIndex = 0;
|
|
164
|
+
while (cursor && cursor.children) {
|
|
165
|
+
const options = cursor.children;
|
|
166
|
+
const value = defaultValues[columnIndex];
|
|
167
|
+
let index = options.findIndex(columnItem => columnItem.value === value);
|
|
168
|
+
if (index === -1)
|
|
169
|
+
index = 0;
|
|
170
|
+
cursor = cursor.children[index];
|
|
171
|
+
columnIndex++;
|
|
172
|
+
formatted.push(options);
|
|
173
|
+
}
|
|
174
|
+
return formatted;
|
|
175
|
+
};
|
|
176
|
+
const init = () => {
|
|
177
|
+
const data = [];
|
|
178
|
+
const normalData = normalListData();
|
|
179
|
+
setColumnsList(normalData);
|
|
180
|
+
normalData.length > 0 &&
|
|
181
|
+
normalData.forEach(item => {
|
|
182
|
+
const perItem = item[0];
|
|
183
|
+
perItem &&
|
|
184
|
+
data.push(typeof perItem === "string" ? perItem : perItem.value);
|
|
185
|
+
});
|
|
186
|
+
if (!defaultValueData && chooseValueData.length === 0) {
|
|
187
|
+
setchooseValueData([...data]);
|
|
188
|
+
}
|
|
79
189
|
};
|
|
80
|
-
const
|
|
81
|
-
|
|
82
|
-
|
|
83
|
-
|
|
84
|
-
|
|
85
|
-
Math.round((total - Math.abs(transformDistance)) / perItemHeight);
|
|
86
|
-
if (index < 0 ||
|
|
87
|
-
(transformDistance > 0 && transformDistance <= perItemHeight) // 如果往上滚动到顶
|
|
88
|
-
)
|
|
89
|
-
index = 0;
|
|
90
|
-
if (index > data.length - 1)
|
|
91
|
-
index = data.length - 1;
|
|
92
|
-
setTransformDistance(-(index * perItemHeight));
|
|
93
|
-
setSelectIndex(index);
|
|
190
|
+
const renderToolbar = () => {
|
|
191
|
+
return (React.createElement("div", { className: "xh-picker-header" },
|
|
192
|
+
React.createElement("span", { className: "xh-picker-header-button picker-cancel", onClick: closeActionSheet }, "\u53D6\u6D88"),
|
|
193
|
+
React.createElement("div", { className: "xh-picker-header-title" }, title || ""),
|
|
194
|
+
React.createElement("span", { className: "xh-picker-header-button picker-confirm", onClick: confirm }, "\u786E\u5B9A")));
|
|
94
195
|
};
|
|
95
196
|
return (React.createElement(Popup, { visible: visible },
|
|
96
|
-
React.createElement(
|
|
97
|
-
|
|
98
|
-
React.createElement(
|
|
99
|
-
React.createElement(
|
|
100
|
-
|
|
101
|
-
}, "catch-move": true }, renderItem()),
|
|
102
|
-
React.createElement(View, { className: "xh-picker-body-mask" },
|
|
103
|
-
React.createElement(View, { className: "xh-picker-body-mask-top" }),
|
|
104
|
-
React.createElement(View, { className: "xh-picker-body-mask-middle" }),
|
|
105
|
-
React.createElement(View, { className: "xh-picker-body-mask-bottom" }))),
|
|
106
|
-
React.createElement(View, { className: "xh-picker-footer" }, Footer))));
|
|
197
|
+
React.createElement("div", Object.assign({ className: classNames("xh-picker", className), style: style, ref: ref }, rest),
|
|
198
|
+
renderToolbar(),
|
|
199
|
+
React.createElement("div", { className: "xh-picker-panel", ref: pickerRef }, columnsList === null || columnsList === void 0 ? void 0 : columnsList.map((item, index) => {
|
|
200
|
+
return (React.createElement(PickerSlot, { ref: setRefs(index), defaultValue: chooseValueData === null || chooseValueData === void 0 ? void 0 : chooseValueData[index], data: item, mode: mode, onConfirm: chooseItem, swipeDuration: swipeDuration, key: index, keyIndex: index }));
|
|
201
|
+
})))));
|
|
107
202
|
};
|
|
203
|
+
const Picker = React.forwardRef(InternalPicker);
|
|
108
204
|
export default Picker;
|
|
109
205
|
//# sourceMappingURL=Picker.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"Picker.js","sourceRoot":"","sources":["../../../src/components/Picker/Picker.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,EAAE,
|
|
1
|
+
{"version":3,"file":"Picker.js","sourceRoot":"","sources":["../../../src/components/Picker/Picker.tsx"],"names":[],"mappings":"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"}
|
|
@@ -21,15 +21,12 @@ const PickerField = (props) => {
|
|
|
21
21
|
return;
|
|
22
22
|
setVisible(true);
|
|
23
23
|
}
|
|
24
|
-
function handleClose(
|
|
25
|
-
e.stopPropagation();
|
|
24
|
+
function handleClose() {
|
|
26
25
|
setVisible(false);
|
|
27
26
|
}
|
|
28
27
|
return (React.createElement("div", { className: classNames("xh-picker-field", className), onClick: handleClick },
|
|
29
28
|
children,
|
|
30
|
-
React.createElement(Picker, Object.assign({ visible: visible }, rest, {
|
|
31
|
-
// onCancel={handleClose}
|
|
32
|
-
onClose: handleClose }))));
|
|
29
|
+
React.createElement(Picker, Object.assign({ visible: visible }, rest, { onCancel: handleClose, onClose: handleClose }))));
|
|
33
30
|
};
|
|
34
31
|
export default PickerField;
|
|
35
32
|
//# sourceMappingURL=index.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Picker/index.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EACZ,QAAQ,
|
|
1
|
+
{"version":3,"file":"index.js","sourceRoot":"","sources":["../../../src/components/Picker/index.tsx"],"names":[],"mappings":";;;;;;;;;;;AAAA,OAAO,KAAK,EAAE,EACZ,QAAQ,GAIT,MAAM,OAAO,CAAC;AACf,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,MAAM,MAAM,UAAU,CAAC;AAE9B,OAAO,cAAc,CAAC;AAatB,MAAM,WAAW,GAAG,CAClB,KAA0B,EACZ,EAAE;IAChB,MAAM,EAAE,SAAS,EAAE,QAAQ,KAAc,KAAK,EAAd,IAAI,UAAK,KAAK,EAAxC,yBAAgC,CAAQ,CAAC;IAC/C,MAAM,CAAC,OAAO,EAAE,UAAU,CAAC,GAAG,QAAQ,CAAC,KAAK,CAAC,CAAC;IAE9C,SAAS,WAAW;QAClB,IAAI,IAAI,CAAC,IAAI,CAAC,MAAM,IAAI,CAAC;YAAE,OAAO;QAClC,UAAU,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC;IAED,SAAS,WAAW;QAClB,UAAU,CAAC,KAAK,CAAC,CAAC;IACpB,CAAC;IAED,OAAO,CACL,6BACE,SAAS,EAAE,UAAU,CAAC,iBAAiB,EAAE,SAAS,CAAC,EACnD,OAAO,EAAE,WAAW;QAEnB,QAAQ;QACT,oBAAC,MAAM,kBACL,OAAO,EAAE,OAAO,IACZ,IAAI,IACR,QAAQ,EAAE,WAAW,EACrB,OAAO,EAAE,WAAW,IACpB,CACE,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
|