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.
Files changed (121) hide show
  1. package/CHANGELOG.md +38 -0
  2. package/dist/components/Checkbox/Group/index.js +2 -0
  3. package/dist/components/Checkbox/Group/index.js.map +1 -0
  4. package/dist/components/Checkbox/index.js +2 -0
  5. package/dist/components/Checkbox/index.js.map +1 -0
  6. package/dist/components/Picker/Picker.js +1 -1
  7. package/dist/components/Picker/Picker.js.map +1 -1
  8. package/dist/components/Picker/index.js +1 -1
  9. package/dist/components/Picker/index.js.map +1 -1
  10. package/dist/components/PickerSlot/index.js +2 -0
  11. package/dist/components/PickerSlot/index.js.map +1 -0
  12. package/dist/components/Radio/Group/index.js +2 -0
  13. package/dist/components/Radio/Group/index.js.map +1 -0
  14. package/dist/components/Radio/index.js +2 -0
  15. package/dist/components/Radio/index.js.map +1 -0
  16. package/dist/components/Space/Item.js +2 -0
  17. package/dist/components/Space/Item.js.map +1 -0
  18. package/dist/components/Space/config-provider.js +2 -0
  19. package/dist/components/Space/config-provider.js.map +1 -0
  20. package/dist/components/Space/index.js +2 -0
  21. package/dist/components/Space/index.js.map +1 -0
  22. package/dist/components/Step/Steps/index.js +2 -0
  23. package/dist/components/Step/Steps/index.js.map +1 -0
  24. package/dist/components/Step/index.js +2 -0
  25. package/dist/components/Step/index.js.map +1 -0
  26. package/dist/components/ThemeProvider/index.js +1 -1
  27. package/dist/components/ThemeProvider/index.js.map +1 -1
  28. package/dist/components/node_modules/css-vars-ponyfill/dist/css-vars-ponyfill.esm.js +172 -0
  29. package/dist/components/node_modules/css-vars-ponyfill/dist/css-vars-ponyfill.esm.js.map +1 -0
  30. package/dist/components/src/hooks/index.js +1 -1
  31. package/dist/components/src/hooks/index.js.map +1 -1
  32. package/dist/components/src/hooks/useFlexGapSupport.js +2 -0
  33. package/dist/components/src/hooks/useFlexGapSupport.js.map +1 -0
  34. package/dist/components/src/hooks/useGenerateId.js +2 -0
  35. package/dist/components/src/hooks/useGenerateId.js.map +1 -0
  36. package/dist/components/src/hooks/useRefs.js +2 -0
  37. package/dist/components/src/hooks/useRefs.js.map +1 -0
  38. package/dist/components/src/hooks/useTouch.js +2 -0
  39. package/dist/components/src/hooks/useTouch.js.map +1 -0
  40. package/dist/components/src/index.js +1 -1
  41. package/dist/components/src/utils/index.js +1 -1
  42. package/dist/components/src/utils/index.js.map +1 -1
  43. package/dist/index.js +173 -2
  44. package/dist/index.js.map +1 -1
  45. package/dist/index.umd.js +173 -2
  46. package/dist/index.umd.js.map +1 -1
  47. package/dist/styles/components/checkbox.scss +117 -0
  48. package/dist/styles/components/dialog.scss +2 -0
  49. package/dist/styles/components/font/.DS_Store +0 -0
  50. package/dist/styles/components/index.scss +5 -0
  51. package/dist/styles/components/numberkeyboard.scss +1 -3
  52. package/dist/styles/components/picker.scss +7 -112
  53. package/dist/styles/components/pickerslot.scss +98 -0
  54. package/dist/styles/components/radio.scss +102 -0
  55. package/dist/styles/components/space.scss +37 -0
  56. package/dist/styles/components/step.scss +173 -0
  57. package/dist/styles/components/themeprovider.scss +3 -0
  58. package/dist/styles/components/toast.scss +1 -1
  59. package/dist/styles/index.scss +1 -1
  60. package/dist/styles/themes/default.scss +13 -13
  61. package/dist/styles/themes/variable.scss +2 -0
  62. package/lib/components/Checkbox/Group/index.js +49 -0
  63. package/lib/components/Checkbox/Group/index.js.map +1 -0
  64. package/lib/components/Checkbox/index.js +43 -0
  65. package/lib/components/Checkbox/index.js.map +1 -0
  66. package/lib/components/Picker/Picker.js +192 -96
  67. package/lib/components/Picker/Picker.js.map +1 -1
  68. package/lib/components/Picker/index.js +2 -5
  69. package/lib/components/Picker/index.js.map +1 -1
  70. package/lib/components/PickerSlot/index.js +226 -0
  71. package/lib/components/PickerSlot/index.js.map +1 -0
  72. package/lib/components/Radio/Group/index.js +56 -0
  73. package/lib/components/Radio/Group/index.js.map +1 -0
  74. package/lib/components/Radio/index.js +43 -0
  75. package/lib/components/Radio/index.js.map +1 -0
  76. package/lib/components/Space/Item.js +25 -0
  77. package/lib/components/Space/Item.js.map +1 -0
  78. package/lib/components/Space/config-provider.js +8 -0
  79. package/lib/components/Space/config-provider.js.map +1 -0
  80. package/lib/components/Space/index.js +77 -0
  81. package/lib/components/Space/index.js.map +1 -0
  82. package/lib/components/Step/Steps/index.js +31 -0
  83. package/lib/components/Step/Steps/index.js.map +1 -0
  84. package/lib/components/Step/index.js +19 -0
  85. package/lib/components/Step/index.js.map +1 -0
  86. package/lib/components/ThemeProvider/index.js +4 -0
  87. package/lib/components/ThemeProvider/index.js.map +1 -1
  88. package/lib/hooks/index.js +0 -34
  89. package/lib/hooks/index.js.map +1 -1
  90. package/lib/hooks/useFlexGapSupport.js +10 -0
  91. package/lib/hooks/useFlexGapSupport.js.map +1 -0
  92. package/lib/hooks/useGenerateId.js +12 -0
  93. package/lib/hooks/useGenerateId.js.map +1 -0
  94. package/lib/hooks/useRefs.js +13 -0
  95. package/lib/hooks/useRefs.js.map +1 -0
  96. package/lib/hooks/useTouch.js +67 -0
  97. package/lib/hooks/useTouch.js.map +1 -0
  98. package/lib/index.js +4 -0
  99. package/lib/index.js.map +1 -1
  100. package/lib/utils/index.js +39 -2
  101. package/lib/utils/index.js.map +1 -1
  102. package/package.json +2 -1
  103. package/types/components/Checkbox/Group/index.d.ts +23 -0
  104. package/types/components/Checkbox/index.d.ts +29 -0
  105. package/types/components/Picker/Picker.d.ts +21 -20
  106. package/types/components/Picker/index.d.ts +6 -7
  107. package/types/components/PickerSlot/index.d.ts +24 -0
  108. package/types/components/Radio/Group/index.d.ts +26 -0
  109. package/types/components/Radio/index.d.ts +29 -0
  110. package/types/components/Space/Item.d.ts +11 -0
  111. package/types/components/Space/config-provider.d.ts +12 -0
  112. package/types/components/Space/index.d.ts +21 -0
  113. package/types/components/Step/Steps/index.d.ts +13 -0
  114. package/types/components/Step/index.d.ts +18 -0
  115. package/types/hooks/index.d.ts +0 -22
  116. package/types/hooks/useFlexGapSupport.d.ts +2 -0
  117. package/types/hooks/useGenerateId.d.ts +1 -0
  118. package/types/hooks/useRefs.d.ts +1 -0
  119. package/types/hooks/useTouch.d.ts +18 -0
  120. package/types/index.d.ts +4 -0
  121. package/types/utils/index.d.ts +6 -0
@@ -0,0 +1,3 @@
1
+ .nothing-enpty {
2
+ color: unset;
3
+ }
@@ -54,9 +54,9 @@
54
54
  align-items: center;
55
55
  justify-content: center;
56
56
  font-size: 14PX;
57
+ z-index: 1000;
57
58
  &-content {
58
59
  position: absolute;
59
- z-index: 998;
60
60
  min-width: 250px;
61
61
  box-sizing: border-box;
62
62
  border-radius: 10px;
@@ -1,5 +1,5 @@
1
1
  @import "./themes/variable.scss";
2
- @import "./themes/default.scss";
2
+ // @import "./themes/default.scss";
3
3
  @import "./themes/base.scss";
4
4
  @import "./themes/animation.scss";
5
5
 
@@ -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":"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"}
@@ -1,109 +1,205 @@
1
- import React, { useRef, useState, } from "react";
2
- import { View } from "@tarojs/components";
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 Button from "../Button";
6
- import { useAsyncEffect, useTouch } from "../../hooks";
7
- const Picker = (props) => {
8
- const { visible, title, ItemComponent, Footer, data, onCancel, onConfirm, onClose, cancelText = "取消", confirmText = "确定", } = props;
9
- const [selectIndex, setSelectIndex] = useState(0);
10
- const rootRef = useRef(null);
11
- const threshold = 30; // 可拉超出的最高距离
12
- const [transformDistance, setTransformDistance] = useState(0); // 滚动区域translateY
13
- const lastTranslateY = useRef(0);
14
- const [perItemHeight, setPerItemHeight] = useState(0); // 每个item的高度
15
- const touch = useTouch();
16
- const renderItem = () => {
17
- return data.map((item, index) => {
18
- let text = typeof item === "string" ? item : item.text;
19
- const itemClass = classNames("xh-picker-body-view-item", {
20
- active: selectIndex === index,
21
- });
22
- return (React.createElement(View, { className: itemClass, onClick: e => handleSelect(index, e), key: index }, ItemComponent ? ItemComponent({ data: item }) : text));
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
- const renderHeader = () => {
26
- return (React.createElement(React.Fragment, null,
27
- React.createElement(Button, { className: "xh-picker-header-button picker-cancel", shape: "square", size: "mini", type: "ghost", onClick: handleCancel }, cancelText),
28
- title && React.createElement("div", { className: "xh-picker-header-title" }, title),
29
- React.createElement(Button, { className: "xh-picker-header-button picker-confirm", shape: "square", size: "mini", type: "ghost", onClick: handleConfirm }, confirmText)));
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
- useAsyncEffect(async () => {
32
- if (visible) {
33
- const { height } = await rootRef.current.getBoundingClientRect();
34
- const perheight = height / data.length;
35
- setPerItemHeight(perheight);
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
- const handleTouchStart = (e) => {
75
- e.preventDefault();
76
- lastTranslateY.current = transformDistance; // end的时候记录最后一次transiton
77
- // shiyan
78
- touch.touchstart(e);
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 handleTouchEnd = (e) => {
81
- touch.touchend(e);
82
- e.preventDefault();
83
- const total = perItemHeight * data.length;
84
- let index = data.length -
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(View, { className: "xh-picker" },
97
- React.createElement(View, { className: "xh-picker-header" }, renderHeader()),
98
- React.createElement(View, { className: "xh-picker-body" },
99
- React.createElement(View, { className: "xh-picker-body-view", ref: rootRef, onTouchStart: handleTouchStart, onTouchMove: handleToucMove, onTouchEnd: handleTouchEnd, style: {
100
- transform: `translateY(${transformDistance}px)`,
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":"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"}
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(e) {
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,GAKT,MAAM,OAAO,CAAC;AACf,OAAO,UAAU,MAAM,YAAY,CAAC;AACpC,OAAO,MAAuB,MAAM,UAAU,CAAC;AAE/C,OAAO,cAAc,CAAC;AAYtB,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;QAElC,UAAU,CAAC,IAAI,CAAC,CAAC;IACnB,CAAC;IAED,SAAS,WAAW,CAAC,CAAa;QAChC,CAAC,CAAC,eAAe,EAAE,CAAC;QACpB,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;YACR,yBAAyB;YACzB,OAAO,EAAE,WAAW,IACpB,CACE,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,eAAe,WAAW,CAAC"}
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"}