taro-react-uilib 1.3.4-1 → 1.3.4-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.
Files changed (165) hide show
  1. package/CHANGELOG.md +193 -4
  2. package/dist/components/ActionSheet/index.js +2 -0
  3. package/dist/components/ActionSheet/index.js.map +1 -0
  4. package/dist/components/ActivityIndicator/index.js +2 -0
  5. package/dist/components/ActivityIndicator/index.js.map +1 -0
  6. package/dist/components/Button/index.js +1 -1
  7. package/dist/components/Button/index.js.map +1 -1
  8. package/dist/components/Captcha/index.js +1 -1
  9. package/dist/components/Captcha/index.js.map +1 -1
  10. package/dist/components/Cell/index.js +2 -0
  11. package/dist/components/Cell/index.js.map +1 -0
  12. package/dist/components/Dialog/Alert/index.js +1 -1
  13. package/dist/components/Dialog/Alert/index.js.map +1 -1
  14. package/dist/components/Dialog/Confirm/index.js +1 -1
  15. package/dist/components/Dialog/Confirm/index.js.map +1 -1
  16. package/dist/components/DialogComponent/index.js.map +1 -1
  17. package/dist/components/DialogRef/index.js +1 -1
  18. package/dist/components/DialogRef/index.js.map +1 -1
  19. package/dist/components/FormInput/index.js +1 -1
  20. package/dist/components/FormInput/index.js.map +1 -1
  21. package/dist/components/LinkMan/index.js +2 -0
  22. package/dist/components/LinkMan/index.js.map +1 -0
  23. package/dist/components/NumberKeyboard/index.js +1 -1
  24. package/dist/components/NumberKeyboard/index.js.map +1 -1
  25. package/dist/components/Progress/index.js +1 -1
  26. package/dist/components/Progress/index.js.map +1 -1
  27. package/dist/components/Radio/index.js +1 -1
  28. package/dist/components/Radio/index.js.map +1 -1
  29. package/dist/components/Rank/index.js +2 -0
  30. package/dist/components/Rank/index.js.map +1 -0
  31. package/dist/components/Result/images/result-empty.png.js +2 -0
  32. package/dist/components/Result/images/result-empty.png.js.map +1 -0
  33. package/dist/components/Result/images/result-fail.png.js +2 -0
  34. package/dist/components/Result/images/result-fail.png.js.map +1 -0
  35. package/dist/components/Result/images/result-networkErr.png.js +2 -0
  36. package/dist/components/Result/images/result-networkErr.png.js.map +1 -0
  37. package/dist/components/Result/images/result-submitted.png.js +2 -0
  38. package/dist/components/Result/images/result-submitted.png.js.map +1 -0
  39. package/dist/components/Result/images/result-success.png.js +2 -0
  40. package/dist/components/Result/images/result-success.png.js.map +1 -0
  41. package/dist/components/Result/images/result-wait.png.js +2 -0
  42. package/dist/components/Result/images/result-wait.png.js.map +1 -0
  43. package/dist/components/Result/index.js +2 -0
  44. package/dist/components/Result/index.js.map +1 -0
  45. package/dist/components/Result/statusMap.js +2 -0
  46. package/dist/components/Result/statusMap.js.map +1 -0
  47. package/dist/components/Step/Steps/index.js +1 -1
  48. package/dist/components/Step/Steps/index.js.map +1 -1
  49. package/dist/components/Step/index.js +1 -1
  50. package/dist/components/Step/index.js.map +1 -1
  51. package/dist/components/Switch/index.js +2 -0
  52. package/dist/components/Switch/index.js.map +1 -0
  53. package/dist/components/Tabbar/index.js.map +1 -1
  54. package/dist/components/Tabbar/tabbar/TabItem.js.map +1 -1
  55. package/dist/components/Tabbar/tabbar/Tabbar.js +1 -1
  56. package/dist/components/Tabbar/tabbar/Tabbar.js.map +1 -1
  57. package/dist/components/src/index.js +1 -1
  58. package/dist/index.js +6 -6
  59. package/dist/index.js.map +1 -1
  60. package/dist/index.umd.js +6 -6
  61. package/dist/index.umd.js.map +1 -1
  62. package/dist/styles/components/actionsheet.scss +122 -0
  63. package/dist/styles/components/activityindicator.scss +43 -0
  64. package/dist/styles/components/amountinput.scss +5 -6
  65. package/dist/styles/components/amountkeyboard.scss +30 -12
  66. package/dist/styles/components/badge.scss +0 -1
  67. package/dist/styles/components/bankicon.scss +1 -1
  68. package/dist/styles/components/button.scss +14 -7
  69. package/dist/styles/components/captcha.scss +9 -3
  70. package/dist/styles/components/cell.scss +119 -0
  71. package/dist/styles/components/checkbox.scss +4 -5
  72. package/dist/styles/components/dialog.scss +14 -14
  73. package/dist/styles/components/dialogref.scss +14 -30
  74. package/dist/styles/components/font/iconfont.ttf +0 -0
  75. package/dist/styles/components/font/iconfont.woff +0 -0
  76. package/dist/styles/components/font/iconfont.woff2 +0 -0
  77. package/dist/styles/components/forminput.scss +40 -28
  78. package/dist/styles/components/icon.scss +2 -2
  79. package/dist/styles/components/index.scss +7 -0
  80. package/dist/styles/components/linkman.scss +81 -0
  81. package/dist/styles/components/list.scss +17 -5
  82. package/dist/styles/components/loading.scss +1 -9
  83. package/dist/styles/components/mask.scss +1 -1
  84. package/dist/styles/components/navbar.scss +1 -0
  85. package/dist/styles/components/numberkeyboard.scss +47 -36
  86. package/dist/styles/components/page.scss +2 -2
  87. package/dist/styles/components/passwordinput.scss +1 -1
  88. package/dist/styles/components/picker.scss +0 -1
  89. package/dist/styles/components/popup.scss +2 -3
  90. package/dist/styles/components/progress.scss +45 -3
  91. package/dist/styles/components/radio.scss +5 -6
  92. package/dist/styles/components/rank.scss +50 -0
  93. package/dist/styles/components/result.scss +39 -0
  94. package/dist/styles/components/step.scss +9 -1
  95. package/dist/styles/components/switch.scss +40 -0
  96. package/dist/styles/components/tabbar.scss +3 -0
  97. package/dist/styles/components/toast.scss +0 -1
  98. package/dist/styles/themes/default.scss +17 -8
  99. package/dist/styles/themes/variable.scss +8 -0
  100. package/lib/components/ActionSheet/index.js +57 -0
  101. package/lib/components/ActionSheet/index.js.map +1 -0
  102. package/lib/components/ActivityIndicator/index.js +14 -0
  103. package/lib/components/ActivityIndicator/index.js.map +1 -0
  104. package/lib/components/Button/index.js +3 -2
  105. package/lib/components/Button/index.js.map +1 -1
  106. package/lib/components/Captcha/index.js +2 -2
  107. package/lib/components/Captcha/index.js.map +1 -1
  108. package/lib/components/Cell/index.js +27 -0
  109. package/lib/components/Cell/index.js.map +1 -0
  110. package/lib/components/Dialog/Alert/index.js +3 -3
  111. package/lib/components/Dialog/Alert/index.js.map +1 -1
  112. package/lib/components/Dialog/Confirm/index.js +2 -2
  113. package/lib/components/Dialog/Confirm/index.js.map +1 -1
  114. package/lib/components/DialogComponent/index.js +0 -2
  115. package/lib/components/DialogComponent/index.js.map +1 -1
  116. package/lib/components/DialogRef/index.js +6 -14
  117. package/lib/components/DialogRef/index.js.map +1 -1
  118. package/lib/components/FormInput/index.js +3 -2
  119. package/lib/components/FormInput/index.js.map +1 -1
  120. package/lib/components/LinkMan/index.js +358 -0
  121. package/lib/components/LinkMan/index.js.map +1 -0
  122. package/lib/components/NumberKeyboard/index.js +4 -2
  123. package/lib/components/NumberKeyboard/index.js.map +1 -1
  124. package/lib/components/Progress/index.js +15 -10
  125. package/lib/components/Progress/index.js.map +1 -1
  126. package/lib/components/Radio/index.js +1 -1
  127. package/lib/components/Radio/index.js.map +1 -1
  128. package/lib/components/Rank/index.js +22 -0
  129. package/lib/components/Rank/index.js.map +1 -0
  130. package/lib/components/Result/index.js +30 -0
  131. package/lib/components/Result/index.js.map +1 -0
  132. package/lib/components/Result/statusMap.js +15 -0
  133. package/lib/components/Result/statusMap.js.map +1 -0
  134. package/lib/components/Step/Steps/index.js +1 -0
  135. package/lib/components/Step/Steps/index.js.map +1 -1
  136. package/lib/components/Step/index.js +2 -1
  137. package/lib/components/Step/index.js.map +1 -1
  138. package/lib/components/Switch/index.js +26 -0
  139. package/lib/components/Switch/index.js.map +1 -0
  140. package/lib/components/Tabbar/index.js +1 -0
  141. package/lib/components/Tabbar/index.js.map +1 -1
  142. package/lib/components/Tabbar/tabbar/TabItem.js +0 -1
  143. package/lib/components/Tabbar/tabbar/TabItem.js.map +1 -1
  144. package/lib/components/Tabbar/tabbar/Tabbar.js +9 -8
  145. package/lib/components/Tabbar/tabbar/Tabbar.js.map +1 -1
  146. package/lib/index.js +7 -0
  147. package/lib/index.js.map +1 -1
  148. package/package.json +1 -1
  149. package/types/components/Button/index.d.ts +6 -1
  150. package/types/components/Captcha/index.d.ts +1 -1
  151. package/types/components/DialogRef/index.d.ts +2 -0
  152. package/types/components/LinkMan/index.d.ts +33 -0
  153. package/types/components/NumberKeyboard/index.d.ts +2 -0
  154. package/types/components/Progress/index.d.ts +4 -0
  155. package/types/components/Result/index.d.ts +16 -0
  156. package/types/components/Result/statusMap.d.ts +9 -0
  157. package/types/components/Step/index.d.ts +1 -0
  158. package/types/components/Tabbar/index.d.ts +1 -0
  159. package/types/components/Tabbar/tabbar/TabItem.d.ts +0 -1
  160. package/types/components/Tabbar/tabbar/Tabbar.d.ts +3 -2
  161. package/types/index.d.ts +7 -0
  162. package/dist/styles/components/images/backspace.png +0 -0
  163. package/dist/styles/components/images/closeKeyboard.png +0 -0
  164. package/dist/styles/components/images/icon-arrow-right.png +0 -0
  165. package/dist/styles/components/images/loading.png +0 -0
@@ -0,0 +1 @@
1
+ {"version":3,"file":"result-wait.png.js","sources":["../../../../src/components/Result/images/result-wait.png"],"sourcesContent":["var img = \"\";\n export default img;"],"names":["img"],"mappings":"AAAG,IAACA,EAAM"}
@@ -0,0 +1,2 @@
1
+ import e from"react";import{View as t,Image as s}from"@tarojs/components";import l from"classnames";import a from"../Button/index.js";import r from"./statusMap.js";var c=function(c){var m=c.className,o=c.status,n=c.title,u=c.desc,i=c.slot,f=c.action,h=c.onAction,p=c.full,x=l("xh-result",m,{full:void 0===p||p});return e.createElement(t,{className:x},"h5"===process.env.TARO_ENV?e.createElement("img",{src:r[o],alt:"",className:"xh-result-status"}):e.createElement(s,{src:r[o],className:"xh-result-status"}),e.createElement(t,{className:"xh-result-title"},n),e.createElement(t,{className:"xh-result-desc"},u),e.createElement(t,{className:"xh-result-slot"},i),f&&e.createElement(t,{className:l("xh-result-action",{hasSlot:i})},e.createElement(a,{onClick:function(){null==h||h()},hollow:!0,size:"full"},f)))};export{c as default};
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Result/index.tsx"],"sourcesContent":["import React, { ReactNode } from \"react\";\nimport { Image, View } from \"@tarojs/components\";\nimport classNames from \"classnames\";\nimport Button from \"../Button\";\nimport { XHComponentCommonProps } from \"../../types\";\nimport ImageMap from \"./statusMap\";\n\nimport \"./index.scss\";\n\nexport type ResultStatus = keyof typeof ImageMap;\n\nexport type ResultProps = {\n status: ResultStatus;\n title: ReactNode;\n desc?: ReactNode;\n slot?: ReactNode;\n action?: string;\n full?: boolean;\n onAction?: () => void;\n} & XHComponentCommonProps;\n\nconst Result: React.FC<ResultProps> = props => {\n const {\n className,\n status,\n title,\n desc,\n slot,\n action,\n onAction,\n full = true,\n } = props;\n\n const resultCls = classNames(\"xh-result\", className, { full });\n\n const renderImage = () => {\n if (process.env.TARO_ENV === \"h5\") {\n return <img src={ImageMap[status]} alt=\"\" className=\"xh-result-status\" />;\n } else {\n return <Image src={ImageMap[status]} className=\"xh-result-status\" />;\n }\n };\n\n const handleAction = () => {\n onAction?.();\n };\n\n return (\n <View className={resultCls}>\n {renderImage()}\n <View className=\"xh-result-title\">{title}</View>\n <View className=\"xh-result-desc\">{desc}</View>\n <View className=\"xh-result-slot\">{slot}</View>\n {action && (\n <View className={classNames(\"xh-result-action\", { hasSlot: slot })}>\n <Button onClick={handleAction} hollow size=\"full\">\n {action}\n </Button>\n </View>\n )}\n </View>\n );\n};\n\nexport default Result;\n"],"names":["Result","props","className","status","title","desc","slot","action","onAction","_a","full","resultCls","classNames","React","createElement","View","process","env","TARO_ENV","src","ImageMap","alt","Image","hasSlot","Button","onClick","hollow","size"],"mappings":"oKAqBM,IAAAA,EAAgC,SAAAC,GAElC,IAAAC,EAQED,YAPFE,EAOEF,EAAKE,OANPC,EAMEH,EANGG,MACLC,EAKEJ,OAJFK,EAIEL,EAAKK,KAHPC,EAGEN,EAHIM,OACNC,EAEEP,WADFQ,EACER,EADSS,KAGPC,EAAYC,EAAW,YAAaV,EAAW,CAAEQ,UAH9C,IAAAD,OAiBT,OACEI,EAACC,cAAAC,EAAK,CAAAb,UAAWS,GAZY,OAAzBK,QAAQC,IAAIC,SACPL,uBAAKM,IAAKC,EAASjB,GAASkB,IAAI,GAAGnB,UAAU,qBAE7CW,EAACC,cAAAQ,EAAM,CAAAH,IAAKC,EAASjB,GAASD,UAAU,qBAW/CW,EAAAC,cAACC,EAAK,CAAAb,UAAU,mBAAmBE,GACnCS,EAAAC,cAACC,EAAK,CAAAb,UAAU,kBAAkBG,GAClCQ,EAAAC,cAACC,EAAK,CAAAb,UAAU,kBAAkBI,GACjCC,GACCM,EAAAC,cAACC,EAAI,CAACb,UAAWU,EAAW,mBAAoB,CAAEW,QAASjB,KACzDO,EAAAC,cAACU,EAAO,CAAAC,QAZK,WACnBjB,SAAAA,GACF,EAUuCkB,QAAO,EAAAC,KAAK,QACxCpB,IAMb"}
@@ -0,0 +1,2 @@
1
+ import s from"./images/result-success.png.js";import r from"./images/result-empty.png.js";import t from"./images/result-fail.png.js";import e from"./images/result-networkErr.png.js";import m from"./images/result-submitted.png.js";import i from"./images/result-wait.png.js";var o={success:s,empty:r,fail:t,networkErr:e,submitted:m,wait:i};export{o as default};
2
+ //# sourceMappingURL=statusMap.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"statusMap.js","sources":["../../../src/components/Result/statusMap.ts"],"sourcesContent":["import success from \"./images/result-success.png\";\nimport empty from \"./images/result-empty.png\";\nimport fail from \"./images/result-fail.png\";\nimport networkErr from \"./images/result-networkErr.png\";\nimport submitted from \"./images/result-submitted.png\";\nimport wait from \"./images/result-wait.png\";\n\nexport default {\n success,\n empty,\n fail,\n networkErr,\n submitted,\n wait,\n};\n"],"names":["ImageMap","success","empty","fail","networkErr","submitted","wait"],"mappings":"iRAOA,IAAeA,EAAA,CACbC,QAAOA,EACPC,MAAKA,EACLC,KAAIA,EACJC,WAAUA,EACVC,UAASA,EACTC,KAAIA"}
@@ -1,2 +1,2 @@
1
- import t from"react";import e from"classnames";import{View as s}from"@tarojs/components";var a=t.createElement("span",{className:"".concat("xh-step","-icon-dot")}),r=function(r){var n=r.direction,o=void 0===n?"horizontal":n,c=r.current,i=void 0===c?0:c,l=r.style,m=r.className,p=e("xh-steps","".concat("xh-steps","-").concat(o),m);return t.createElement(s,{className:p,style:l},t.Children.map(r.children,(function(e,s){var r;if(!t.isValidElement(e))return e;var n=e.props,o=n.status||"wait";s<i?o=n.status||"finish":s===i&&(o=n.status||"process");var c=null!==(r=n.icon)&&void 0!==r?r:a;return t.cloneElement(e,{status:o,icon:c})})))};export{r as default};
1
+ import t from"react";import e from"classnames";import{View as s}from"@tarojs/components";var a=t.createElement("span",{className:"".concat("xh-step","-icon-dot")}),r=function(r){var n=r.direction,o=void 0===n?"horizontal":n,c=r.current,i=void 0===c?0:c,l=r.style,m=r.className,p=e("xh-steps","".concat("xh-steps","-").concat(o),m);return t.createElement(s,{className:p,style:l},t.Children.map(r.children,(function(e,s){var r;if(!t.isValidElement(e))return e;var n=e.props,c=n.status||"wait";s<i?c=n.status||"finish":s===i&&(c=n.status||"process");var l=null!==(r=n.icon)&&void 0!==r?r:a;return t.cloneElement(e,{status:c,icon:l,direction:o})})))};export{r as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../../src/components/Step/Steps/index.tsx"],"sourcesContent":["import React, { FC, ReactElement } from \"react\";\nimport classNames from \"classnames\";\nimport { View } from \"@tarojs/components\";\nimport type { XHComponentCommonProps } from \"../../../types\";\n\nimport { StepProps } from \"..\";\n\nconst classPrefix = `xh-steps`;\nconst stepClassPrefix = `xh-step`;\n\nconst defaultIcon = <span className={`${stepClassPrefix}-icon-dot`} />;\n\nexport type StepsProps = {\n current?: number;\n direction?: \"horizontal\" | \"vertical\";\n children?: React.ReactNode;\n style?: React.CSSProperties & {\n \"--line-to-next-color\"?: string;\n \"--color-primary\"?: string;\n };\n} & XHComponentCommonProps;\n\nconst Steps: FC<StepsProps> = props => {\n const { direction = \"horizontal\", current = 0, style, className } = props;\n const classString = classNames(\n classPrefix,\n `${classPrefix}-${direction}`,\n className\n );\n\n return (\n <View className={classString} style={style}>\n {React.Children.map(\n props.children,\n (child: ReactElement<StepProps>, index) => {\n if (!React.isValidElement(child)) {\n return child;\n }\n const props = child.props;\n let status = props.status || \"wait\";\n\n if (index < current) {\n status = props.status || \"finish\";\n } else if (index === current) {\n status = props.status || \"process\";\n }\n\n const icon = props.icon ?? defaultIcon;\n\n return React.cloneElement(child, {\n status,\n icon,\n });\n }\n )}\n </View>\n );\n};\n\nexport default Steps;\n"],"names":["defaultIcon","React","createElement","className","concat","Steps","props","_a","direction","_b","current","style","classString","classNames","View","Children","map","children","child","index","isValidElement","status","icon","cloneElement"],"mappings":"yFAOA,IAGMA,EAAcC,EAAMC,cAAA,OAAA,CAAAC,UAAW,GAAGC,OAFhB,UAE0C,eAY5DC,EAAwB,SAAAC,GACpB,IAAAC,EAA4DD,EAAKE,UAAjEA,OAAY,IAAAD,EAAA,aAAYA,EAAEE,EAAkCH,EAAvBI,QAAXA,OAAO,IAAAD,EAAG,EAACA,EAAEE,EAAqBL,EAAhBK,MAAER,EAAcG,EAAKH,UACnES,EAAcC,EAjBF,WAmBhB,GAAAT,OAnBgB,WAmBF,KAAAA,OAAII,GAClBL,GAGF,OACEF,EAACC,cAAAY,EAAK,CAAAX,UAAWS,EAAaD,MAAOA,GAClCV,EAAMc,SAASC,IACdV,EAAMW,UACN,SAACC,EAAgCC,SAC/B,IAAKlB,EAAMmB,eAAeF,GACxB,OAAOA,EAET,IAAMZ,EAAQY,EAAMZ,MAChBe,EAASf,EAAMe,QAAU,OAEzBF,EAAQT,EACVW,EAASf,EAAMe,QAAU,SAChBF,IAAUT,IACnBW,EAASf,EAAMe,QAAU,WAG3B,IAAMC,EAAiB,QAAVf,EAAAD,EAAMgB,YAAI,IAAAf,EAAAA,EAAIP,EAE3B,OAAOC,EAAMsB,aAAaL,EAAO,CAC/BG,OAAMA,EACNC,KAAIA,GAEP,IAIT"}
1
+ {"version":3,"file":"index.js","sources":["../../../../src/components/Step/Steps/index.tsx"],"sourcesContent":["import React, { FC, ReactElement } from \"react\";\nimport classNames from \"classnames\";\nimport { View } from \"@tarojs/components\";\nimport type { XHComponentCommonProps } from \"../../../types\";\n\nimport { StepProps } from \"..\";\n\nconst classPrefix = `xh-steps`;\nconst stepClassPrefix = `xh-step`;\n\nconst defaultIcon = <span className={`${stepClassPrefix}-icon-dot`} />;\n\nexport type StepsProps = {\n current?: number;\n direction?: \"horizontal\" | \"vertical\";\n children?: React.ReactNode;\n style?: React.CSSProperties & {\n \"--line-to-next-color\"?: string;\n \"--color-primary\"?: string;\n };\n} & XHComponentCommonProps;\n\nconst Steps: FC<StepsProps> = props => {\n const { direction = \"horizontal\", current = 0, style, className } = props;\n const classString = classNames(\n classPrefix,\n `${classPrefix}-${direction}`,\n className\n );\n\n return (\n <View className={classString} style={style}>\n {React.Children.map(\n props.children,\n (child: ReactElement<StepProps>, index) => {\n if (!React.isValidElement(child)) {\n return child;\n }\n const props = child.props;\n\n let status = props.status || \"wait\";\n if (index < current) {\n status = props.status || \"finish\";\n } else if (index === current) {\n status = props.status || \"process\";\n }\n\n const icon = props.icon ?? defaultIcon;\n\n return React.cloneElement(child, {\n status,\n icon,\n direction,\n });\n }\n )}\n </View>\n );\n};\n\nexport default Steps;\n"],"names":["defaultIcon","React","createElement","className","concat","Steps","props","_a","direction","_b","current","style","classString","classNames","View","Children","map","children","child","index","isValidElement","status","icon","cloneElement"],"mappings":"yFAOA,IAGMA,EAAcC,EAAMC,cAAA,OAAA,CAAAC,UAAW,GAAGC,OAFhB,UAE0C,eAY5DC,EAAwB,SAAAC,GACpB,IAAAC,EAA4DD,EAAKE,UAAjEA,OAAY,IAAAD,EAAA,aAAYA,EAAEE,EAAkCH,EAAvBI,QAAXA,OAAO,IAAAD,EAAG,EAACA,EAAEE,EAAqBL,EAAhBK,MAAER,EAAcG,EAAKH,UACnES,EAAcC,EAjBF,WAmBhB,GAAAT,OAnBgB,WAmBF,KAAAA,OAAII,GAClBL,GAGF,OACEF,EAACC,cAAAY,EAAK,CAAAX,UAAWS,EAAaD,MAAOA,GAClCV,EAAMc,SAASC,IACdV,EAAMW,UACN,SAACC,EAAgCC,SAC/B,IAAKlB,EAAMmB,eAAeF,GACxB,OAAOA,EAET,IAAMZ,EAAQY,EAAMZ,MAEhBe,EAASf,EAAMe,QAAU,OACzBF,EAAQT,EACVW,EAASf,EAAMe,QAAU,SAChBF,IAAUT,IACnBW,EAASf,EAAMe,QAAU,WAG3B,IAAMC,EAAiB,QAAVf,EAAAD,EAAMgB,YAAI,IAAAf,EAAAA,EAAIP,EAE3B,OAAOC,EAAMsB,aAAaL,EAAO,CAC/BG,OAAMA,EACNC,KAAIA,EACJd,UAASA,GAEZ,IAIT"}
@@ -1,2 +1,2 @@
1
- import t from"react";import e from"classnames";import{View as a}from"@tarojs/components";import c from"./Steps/index.js";var s=function(c){var s=c.title,n=c.description,o=c.icon,r=c.status,m=void 0===r?"wait":r,i=c.fancy,l=c.style,p=c.className;return t.createElement(a,{className:e("".concat("xh-step"),"".concat("xh-step","-status-").concat(m),p),style:l},t.createElement(a,{className:"".concat("xh-step","-indicator")},t.createElement(a,{className:e("".concat("xh-step","-icon-container"),{fancy:i})},o)),t.createElement(a,{className:"".concat("xh-step","-content")},t.createElement(a,{className:"".concat("xh-step","-title")},s),!!n&&t.createElement(a,{className:"".concat("xh-step","-description")},n)))};s.Steps=c;export{s as default};
1
+ import e from"react";import t from"classnames";import{View as a}from"@tarojs/components";import c from"./Steps/index.js";var s=function(c){var s=c.title,n=c.description,o=c.icon,r=c.status,m=void 0===r?"wait":r,i=c.fancy,l=c.style,p=c.className,x=c.direction,f=c.prefix;return e.createElement(a,{className:t("".concat("xh-step"),"".concat("xh-step","-status-").concat(m),p),style:l},"vertical"===x&&f&&e.createElement(a,{className:"".concat("xh-step","-prefix")},f),e.createElement(a,{className:"".concat("xh-step","-indicator")},e.createElement(a,{className:t("".concat("xh-step","-icon-container"),{fancy:i})},o)),e.createElement(a,{className:"".concat("xh-step","-content")},e.createElement(a,{className:"".concat("xh-step","-title")},s),!!n&&e.createElement(a,{className:"".concat("xh-step","-description")},n)))};s.Steps=c;export{s as default};
2
2
  //# sourceMappingURL=index.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/components/Step/index.tsx"],"sourcesContent":["import React, { ReactNode, ForwardRefExoticComponent } from \"react\";\nimport classNames from \"classnames\";\nimport { View } from \"@tarojs/components\";\nimport type { XHComponentCommonProps } from \"../../types\";\n\nimport Steps from \"./Steps\";\nimport \"./index.scss\";\n\nexport type StepProps = {\n icon?: string | ReactNode;\n title: string | ReactNode;\n description?: string | ReactNode;\n direction?: \"horizontal\" | \"vertical\";\n status?: \"wait\" | \"process\" | \"finish\" | \"error\";\n fancy?: boolean;\n style?: React.CSSProperties;\n} & XHComponentCommonProps;\n\nconst classPrefix = \"xh-step\";\n\nconst Step: React.FC<StepProps> = props => {\n const {\n title,\n description,\n icon,\n status = \"wait\",\n fancy,\n style,\n className,\n } = props;\n\n return (\n <View\n className={classNames(\n `${classPrefix}`,\n `${classPrefix}-status-${status}`,\n className\n )}\n style={style}\n >\n <View className={`${classPrefix}-indicator`}>\n <View\n className={classNames(`${classPrefix}-icon-container`, { fancy })}\n >\n {icon}\n </View>\n </View>\n <View className={`${classPrefix}-content`}>\n <View className={`${classPrefix}-title`}>{title}</View>\n {!!description && (\n <View className={`${classPrefix}-description`}>{description}</View>\n )}\n </View>\n </View>\n );\n};\n\nexport type HybridComponent = ForwardRefExoticComponent<StepProps> & {\n Steps: typeof Steps;\n};\n\nconst XHStep = Step as HybridComponent;\nXHStep.Steps = Steps;\n\nexport default XHStep;\n"],"names":["XHStep","props","title","description","icon","_a","status","fancy","style","className","React","View","classNames","concat","createElement","Steps"],"mappings":"yHAkBA,IA2CMA,EAzC4B,SAAAC,GAE9B,IAAAC,EAOED,EAPGC,MACLC,EAMEF,EANSE,YACXC,EAKEH,OAJFI,EAIEJ,EAJaK,OAAfA,OAAM,IAAAD,EAAG,OAAMA,EACfE,EAGEN,EAHGM,MACLC,EAEEP,EAFGO,MACLC,EACER,YAEJ,OACES,gBAACC,EAAI,CACHF,UAAWG,EACT,GAAAC,OAhBY,WAiBZ,GAAGA,OAjBS,UAiBa,YAAAA,OAAAP,GACzBG,GAEFD,MAAOA,GAEPE,EAAAI,cAACH,EAAK,CAAAF,UAAW,GAAAI,OAtBH,UAsB6B,eACzCH,EAAAI,cAACH,EACC,CAAAF,UAAWG,EAAW,UAxBZ,UAwB0B,mBAAmB,CAAEL,MAAKA,KAE7DH,IAGLM,EAAAI,cAACH,EAAK,CAAAF,UAAW,GAAAI,OA7BH,UA6B2B,aACvCH,EAACI,cAAAH,GAAKF,UAAW,UA9BL,UA8BmB,WAAWP,KACvCC,GACDO,EAACI,cAAAH,GAAKF,UAAW,UAhCP,UAgCqB,iBAAiBN,IAK1D,EAOAH,EAAOe,MAAQA"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Step/index.tsx"],"sourcesContent":["import React, { ReactNode, ForwardRefExoticComponent } from \"react\";\nimport classNames from \"classnames\";\nimport { View } from \"@tarojs/components\";\nimport type { XHComponentCommonProps } from \"../../types\";\n\nimport Steps from \"./Steps\";\nimport \"./index.scss\";\n\nexport type StepProps = {\n icon?: string | ReactNode;\n title: string | ReactNode;\n description?: string | ReactNode;\n direction?: \"horizontal\" | \"vertical\";\n status?: \"wait\" | \"process\" | \"finish\" | \"error\";\n fancy?: boolean;\n style?: React.CSSProperties;\n prefix?: ReactNode;\n} & XHComponentCommonProps;\n\nconst classPrefix = \"xh-step\";\n\nconst Step: React.FC<StepProps> = props => {\n const {\n title,\n description,\n icon,\n status = \"wait\",\n fancy,\n style,\n className,\n direction,\n prefix,\n } = props;\n\n return (\n <View\n className={classNames(\n `${classPrefix}`,\n `${classPrefix}-status-${status}`,\n className\n )}\n style={style}\n >\n {direction === \"vertical\" && prefix && (\n <View className={`${classPrefix}-prefix`}>{prefix}</View>\n )}\n <View className={`${classPrefix}-indicator`}>\n <View\n className={classNames(`${classPrefix}-icon-container`, { fancy })}\n >\n {icon}\n </View>\n </View>\n <View className={`${classPrefix}-content`}>\n <View className={`${classPrefix}-title`}>{title}</View>\n {!!description && (\n <View className={`${classPrefix}-description`}>{description}</View>\n )}\n </View>\n </View>\n );\n};\n\nexport type HybridComponent = ForwardRefExoticComponent<StepProps> & {\n Steps: typeof Steps;\n};\n\nconst XHStep = Step as HybridComponent;\nXHStep.Steps = Steps;\n\nexport default XHStep;\n"],"names":["XHStep","props","title","description","icon","_a","status","fancy","style","className","direction","prefix","React","View","classNames","concat","createElement","Steps"],"mappings":"yHAmBA,IAgDMA,EA9C4B,SAAAC,GAE9B,IAAAC,EASED,EAAKC,MARPC,EAQEF,EAAKE,YAPPC,EAOEH,EAAKG,KANPC,EAMEJ,SANFK,OAAS,IAAAD,EAAA,OAAMA,EACfE,EAKEN,QAJFO,EAIEP,EAAKO,MAHPC,EAGER,YAFFS,EAEET,EAAKS,UADPC,EACEV,EAAKU,OAET,OACEC,gBAACC,EAAI,CACHJ,UAAWK,EACT,GAAAC,OAlBY,WAmBZ,GAAGA,OAnBS,UAmBa,YAAAA,OAAAT,GACzBG,GAEFD,MAAOA,GAEQ,aAAdE,GAA4BC,GAC3BC,EAACI,cAAAH,EAAK,CAAAJ,UAAW,GAAGM,OAzBR,sBAyB+BJ,GAE7CC,EAAAI,cAACH,EAAK,CAAAJ,UAAW,GAAAM,OA3BH,UA2B6B,eACzCH,EAAAI,cAACH,EACC,CAAAJ,UAAWK,EAAW,UA7BZ,UA6B0B,mBAAmB,CAAEP,MAAKA,KAE7DH,IAGLQ,EAAAI,cAACH,EAAK,CAAAJ,UAAW,GAAAM,OAlCH,UAkC2B,aACvCH,EAACI,cAAAH,GAAKJ,UAAW,UAnCL,UAmCmB,WAAWP,KACvCC,GACDS,EAACI,cAAAH,GAAKJ,UAAW,UArCP,UAqCqB,iBAAiBN,IAK1D,EAOAH,EAAOiB,MAAQA"}
@@ -0,0 +1,2 @@
1
+ import{__read as e}from"../node_modules/tslib/tslib.es6.js";import{View as t}from"@tarojs/components";import c,{useState as n,useMemo as o}from"react";import r from"classnames";var s=function(s){var a=s.checked,i=void 0!==a&&a,l=s.checkedText,m=void 0===l?"":l,d=s.uncheckedText,h=void 0===d?"":d,u=s.onChange,f=s.className,p=s.disabled,x=e(n(i),2),k=x[0],v=x[1],b=o((function(){return k?m:h}),[k,m,h]);return c.createElement(t,{className:r("xh-switch",{checked:k},{disabled:p},f),onClick:function(){p||v((function(e){return null==u||u(!e),!e}))}},c.createElement(t,{className:"xh-switch-control"}),c.createElement(t,{className:"xh-switch-inner"},b))};export{s as default};
2
+ //# sourceMappingURL=index.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Switch/index.tsx"],"sourcesContent":["import { View } from \"@tarojs/components\";\nimport React, { ReactNode, useMemo, useState } from \"react\";\nimport classNames from \"classnames\";\n\nimport \"./index.scss\";\nimport { XHComponentCommonProps } from \"../../types\";\n\nexport type SwitchProps = {\n checked?: boolean;\n checkedText?: ReactNode;\n uncheckedText?: ReactNode;\n onChange?: (checked: boolean) => void;\n disabled?: boolean;\n} & XHComponentCommonProps;\n\nconst Switch: React.FC<SwitchProps> = props => {\n const {\n checked = false,\n checkedText = \"\",\n uncheckedText = \"\",\n onChange,\n className,\n disabled,\n } = props;\n\n const [innerChecked, setInnerChecked] = useState(checked);\n\n const handleCheckedChange = () => {\n if (disabled) return;\n setInnerChecked(old => {\n onChange?.(!old);\n return !old;\n });\n };\n\n const checkedInner = useMemo(() => {\n if (innerChecked) return checkedText;\n return uncheckedText;\n }, [innerChecked, checkedText, uncheckedText]);\n\n return (\n <View\n className={classNames(\n \"xh-switch\",\n { checked: innerChecked },\n { disabled },\n className\n )}\n onClick={handleCheckedChange}\n >\n <View className=\"xh-switch-control\"></View>\n <View className=\"xh-switch-inner\">{checkedInner}</View>\n </View>\n );\n};\n\nexport default Switch;\n"],"names":["Switch","props","_a","checked","_b","checkedText","_c","uncheckedText","onChange","className","disabled","_d","__read","useState","innerChecked","setInnerChecked","checkedInner","useMemo","React","createElement","View","classNames","onClick","old"],"mappings":"iLAeM,IAAAA,EAAgC,SAAAC,GAElC,IAAAC,EAMED,EAAKE,QANPA,OAAO,IAAAD,GAAQA,EACfE,EAKEH,cALFI,aAAc,GAAED,EAChBE,EAIEL,EAJgBM,cAAlBA,OAAgB,IAAAD,EAAA,KAChBE,EAGEP,EAAKO,SAFPC,EAEER,EAFOQ,UACTC,EACET,WAEEU,EAAAC,EAAkCC,EAASV,GAAQ,GAAlDW,EAAYH,EAAA,GAAEI,OAUfC,EAAeC,GAAQ,WAC3B,OAAIH,EAAqBT,EAClBE,CACR,GAAE,CAACO,EAAcT,EAAaE,IAE/B,OACEW,EAACC,cAAAC,EACC,CAAAX,UAAWY,EACT,YACA,CAAElB,QAASW,GACX,CAAEJ,SAAQA,GACVD,GAEFa,QArBwB,WACtBZ,GACJK,GAAgB,SAAAQ,GAEd,OADAf,SAAAA,GAAYe,IACJA,CACV,GACF,GAiBIL,EAAAC,cAACC,EAAI,CAACX,UAAU,sBAChBS,EAACC,cAAAC,EAAK,CAAAX,UAAU,mBAAmBO,GAGzC"}
@@ -1 +1 @@
1
- {"version":3,"file":"index.js","sources":["../../../src/components/Tabbar/index.tsx"],"sourcesContent":["import TabBarComponent, { TabProps } from \"./tabbar/Tabbar\";\nimport TabBarItem from \"./tabbar/TabItem\";\n\nexport interface TabBarComponent<P = {}> extends React.FC<P> {\n Item: typeof TabBarItem;\n}\n\nconst TabBar = TabBarComponent as TabBarComponent<TabProps>;\n\nTabBar.Item = TabBarItem;\n\nexport default TabBar;\n"],"names":["TabBar","TabBarComponent","Item","TabBarItem"],"mappings":"qEAOM,IAAAA,EAASC,EAEfD,EAAOE,KAAOC"}
1
+ {"version":3,"file":"index.js","sources":["../../../src/components/Tabbar/index.tsx"],"sourcesContent":["import TabBarComponent, { TabProps } from \"./tabbar/Tabbar\";\nimport TabBarItem from \"./tabbar/TabItem\";\n\nimport \"./index.scss\";\n\nexport interface TabBarComponent<P = {}> extends React.FC<P> {\n Item: typeof TabBarItem;\n}\n\nconst TabBar = TabBarComponent as TabBarComponent<TabProps>;\n\nTabBar.Item = TabBarItem;\n\nexport default TabBar;\n"],"names":["TabBar","TabBarComponent","Item","TabBarItem"],"mappings":"qEASM,IAAAA,EAASC,EAEfD,EAAOE,KAAOC"}
@@ -1 +1 @@
1
- {"version":3,"file":"TabItem.js","sources":["../../../../src/components/Tabbar/tabbar/TabItem.tsx"],"sourcesContent":["import React, { PropsWithChildren, ReactNode } from \"react\";\n\nimport \"./index.scss\";\n\nexport interface TabItemProps extends PropsWithChildren<{}> {\n title?: string;\n TabItemComponent?: ReactNode;\n children?: ReactNode;\n}\n\nconst TabItem = (props: TabItemProps) => {\n const { children, title, TabItemComponent } = props;\n\n return (\n <div className=\"xh-tabbar-item\">\n {TabItemComponent ? TabItemComponent : title}\n {children}\n </div>\n );\n};\n\nexport default TabItem;\n"],"names":["TabItem","props","children","title","TabItemComponent","React","createElement","className"],"mappings":"qBAUM,IAAAA,EAAU,SAACC,GACP,IAAAC,EAAsCD,EAAKC,SAAjCC,EAA4BF,EAAKE,MAA1BC,EAAqBH,mBAE9C,OACEI,EAAAC,cAAA,MAAA,CAAKC,UAAU,kBACZH,GAAsCD,EACtCD,EAGP"}
1
+ {"version":3,"file":"TabItem.js","sources":["../../../../src/components/Tabbar/tabbar/TabItem.tsx"],"sourcesContent":["import React, { PropsWithChildren, ReactNode } from \"react\";\n\nexport interface TabItemProps extends PropsWithChildren<{}> {\n title?: string;\n TabItemComponent?: ReactNode;\n children?: ReactNode;\n}\n\nconst TabItem = (props: TabItemProps) => {\n const { children, title, TabItemComponent } = props;\n\n return (\n <div className=\"xh-tabbar-item\">\n {TabItemComponent ? TabItemComponent : title}\n {children}\n </div>\n );\n};\n\nexport default TabItem;\n"],"names":["TabItem","props","children","title","TabItemComponent","React","createElement","className"],"mappings":"qBAQM,IAAAA,EAAU,SAACC,GACP,IAAAC,EAAsCD,EAAKC,SAAjCC,EAA4BF,EAAKE,MAA1BC,EAAqBH,mBAE9C,OACEI,EAAAC,cAAA,MAAA,CAAKC,UAAU,kBACZH,GAAsCD,EACtCD,EAGP"}
@@ -1,2 +1,2 @@
1
- import{__read as t}from"../../node_modules/tslib/tslib.es6.js";import e,{useState as a,useEffect as n}from"react";import{createSelectorQuery as o}from"@tarojs/taro";import{View as r}from"@tarojs/components";import i from"classnames";import c from"./TabItem.js";var l=function(c){var l=c.children,m=void 0===l?[]:l,s=c.animated,b=void 0!==s&&s,v=c.initIndex,h=void 0===v?0:v,p=c.lineColor,f=void 0===p?"#F6AB00":p,u=c.titleActiveColor,d=void 0===u?"#333":u,x=c.titleInctiveColor,C=void 0===x?"#999":x,g=c.onChange,y=t(a(h),2),E=y[0],I=y[1],N=t(a(0),2),T=N[0],k=N[1],A=t(a(0),2),j=A[0],R=A[1];n((function(){var t=setTimeout((function(){var e=o();e.selectAll(".xh-tabbar-nav-item").boundingClientRect(),e.selectAll(".xh-tabbar-content-item").boundingClientRect(),e.exec((function(e){if(e[0][E]){var a=e[0][E].width;if(k(a),e[1][E]){var n=e[1][E].height;R(n),clearTimeout(t)}}}))}),300)}),[E,m]);var X;return e.createElement(r,{className:"xh-tabbar"},e.createElement(r,{className:"xh-tabbar-nav"},m.map((function(t,a){return e.createElement(r,{key:a,className:"xh-tabbar-nav-item",style:{color:E===a?d:C},onClick:function(){return function(t){I(t);var e=o();e.selectAll(".xh-tabbar-content-item").boundingClientRect(),e.exec((function(e){if(e[0][t]){var a=e[0][t].height;R(a)}})),g&&g(t)}(a)}},t.props.TabItemComponent?t.props.TabItemComponent:t.props.title)})),(X=T/2+E*T,e.createElement("div",{className:i("xh-tabbar-nav-line",{"xh-tabbar-nav-line-active":b}),style:{background:"".concat(f),transform:"translateX(".concat(X,"px) translate(-50%, -50%)"),WebkitTransform:"translateX(".concat(X,"px) translate(-50%, -50%)")}}))),e.createElement(r,{className:"xh-tabbar-content",style:{width:"".concat(100*m.length,"%"),height:j?"".concat(j,"px"):"auto"}},m.map((function(t,a){return e.createElement(r,{key:a,className:i("xh-tabbar-content-item",{"xh-tabbar-content-item-dispaly":E!==a&&!b,"xh-tabbar-content-item-active":E===a}),style:{transform:b?"translateX(-".concat(100*E,"%)"):""}},t.props.children)}))))};l.Item=c;export{l as default};
1
+ import{__read as t}from"../../node_modules/tslib/tslib.es6.js";import e,{useState as a,useEffect as n}from"react";import{createSelectorQuery as o}from"@tarojs/taro";import{View as r}from"@tarojs/components";import i from"classnames";import c from"./TabItem.js";var l=function(c){var l=c.children,m=void 0===l?[]:l,s=c.animated,b=void 0!==s&&s,v=c.initIndex,h=void 0===v?0:v,p=c.lineColor,u=void 0===p?"#F6AB00":p,f=c.titleActiveColor,d=void 0===f?"#333":f,x=c.titleInctiveColor,C=void 0===x?"#999":x,g=c.onChange,y=c.content,E=t(a(h),2),I=E[0],N=E[1],T=t(a(0),2),k=T[0],A=T[1],j=t(a(0),2),R=j[0],X=j[1];n((function(){var t=setTimeout((function(){var e=o();e.selectAll(".xh-tabbar-nav-item").boundingClientRect(),e.selectAll(".xh-tabbar-content-item").boundingClientRect(),e.exec((function(e){if(e[0][I]){var a=e[0][I].width;if(A(a),e[1][I]){var n=e[1][I].height;X(n),clearTimeout(t)}}}))}),300)}),[I,m]);var w;return e.createElement(r,{className:"xh-tabbar"},e.createElement(r,{className:"xh-tabbar-nav"},m.map((function(t,a){return e.createElement(r,{key:a,className:"xh-tabbar-nav-item",style:{color:I===a?d:C},onClick:function(){return function(t){N(t);var e=o();e.selectAll(".xh-tabbar-content-item").boundingClientRect(),e.exec((function(e){if(e[0][t]){var a=e[0][t].height;X(a)}})),g&&g(t)}(a)}},t.props.TabItemComponent?t.props.TabItemComponent:t.props.title)})),(w=k/2+I*k,e.createElement("div",{className:i("xh-tabbar-nav-line",{"xh-tabbar-nav-line-active":b}),style:{background:"".concat(u),transform:"translateX(".concat(w,"px) translate(-50%, -50%)"),WebkitTransform:"translateX(".concat(w,"px) translate(-50%, -50%)")}}))),e.createElement(r,{className:"xh-tabbar-content",style:{width:"".concat(100*m.length,"%"),height:R?"".concat(R,"px"):"auto"}},y&&e.createElement(r,null,y),m.map((function(t,a){return e.createElement(r,{key:a,className:i("xh-tabbar-content-item",{"xh-tabbar-content-item-dispaly":I!==a&&!b,"xh-tabbar-content-item-active":I===a}),style:{transform:b?"translateX(-".concat(100*I,"%)"):""}},t.props.children)}))))};l.Item=c;export{l as default};
2
2
  //# sourceMappingURL=Tabbar.js.map
@@ -1 +1 @@
1
- {"version":3,"file":"Tabbar.js","sources":["../../../../src/components/Tabbar/tabbar/Tabbar.tsx"],"sourcesContent":["import React, { FC, ReactElement, useEffect, useState } from \"react\";\nimport { createSelectorQuery } from \"@tarojs/taro\";\nimport { View } from \"@tarojs/components\";\nimport classNames from \"classnames\";\nimport Item from \"./TabItem\";\n\nimport \"./index.scss\";\n\n/**\n * Tab切换\n *\n * @param children //子组件\n * @param animated //是否开启转场动画\n * @param selectIndex //默认选中第几个\n * @param lineColor //下划线颜色\n * @param titleActiveColor //标题选中态颜色\n * @param titleInctiveColor //标题默认态颜色\n * @param onChange //切换回调事件\n *\n */\n\nexport interface TabProps {\n children: ReactElement[];\n animated?: boolean;\n initIndex?: number;\n lineColor?: string;\n titleActiveColor?: string;\n titleInctiveColor?: string;\n onChange?: (index: number) => void;\n}\n\nexport interface TabsComponent<P = {}> extends FC<P> {\n Item: typeof Item;\n}\n\nconst XHTabs: TabsComponent<TabProps> = props => {\n const {\n children = [],\n animated = false,\n initIndex = 0,\n lineColor = \"#F6AB00\",\n titleActiveColor = \"#333\",\n titleInctiveColor = \"#999\",\n onChange,\n } = props;\n\n const [selectIndex, setSelectIndex] = useState(initIndex);\n const [tabWdith, setTabWdith] = useState(0);\n const [tabContentHeight, setTabContentHeight] = useState(0);\n\n useEffect(() => {\n const timer = setTimeout(() => {\n const query = createSelectorQuery();\n query.selectAll(\".xh-tabbar-nav-item\").boundingClientRect();\n query.selectAll(\".xh-tabbar-content-item\").boundingClientRect();\n\n query.exec(res => {\n if (!res[0][selectIndex]) return;\n const width: number = res[0][selectIndex].width;\n setTabWdith(width);\n\n if (!res[1][selectIndex]) return;\n const height: number = res[1][selectIndex].height;\n setTabContentHeight(height);\n clearTimeout(timer);\n });\n }, 300);\n console.log(children.length);\n }, [selectIndex, children]);\n\n const handleClick = (index: number): void => {\n setSelectIndex(index);\n const query = createSelectorQuery();\n query.selectAll(\".xh-tabbar-content-item\").boundingClientRect();\n query.exec(res => {\n if (!res[0][index]) return;\n const height: number = res[0][index].height;\n setTabContentHeight(height);\n });\n\n onChange && onChange(index);\n };\n\n function renderLine(): ReactElement | null {\n const left: number = tabWdith / 2 + selectIndex * tabWdith;\n return (\n <div\n className={classNames(\"xh-tabbar-nav-line\", {\n \"xh-tabbar-nav-line-active\": animated,\n })}\n style={{\n background: `${lineColor}`,\n transform: `translateX(${left}px) translate(-50%, -50%)`,\n WebkitTransform: `translateX(${left}px) translate(-50%, -50%)`,\n }}\n />\n );\n }\n\n return (\n <View className=\"xh-tabbar\">\n <View className=\"xh-tabbar-nav\">\n {children.map((child, index) => (\n <View\n key={index}\n className=\"xh-tabbar-nav-item\"\n style={{\n color:\n selectIndex === index ? titleActiveColor : titleInctiveColor,\n }}\n onClick={() => handleClick(index)}\n >\n {child.props.TabItemComponent\n ? child.props.TabItemComponent\n : child.props.title}\n </View>\n ))}\n {renderLine()}\n </View>\n <View\n className=\"xh-tabbar-content\"\n style={{\n width: `${children.length * 100}%`,\n height: tabContentHeight ? `${tabContentHeight}px` : \"auto\",\n }}\n >\n {children.map((child, index) => (\n <View\n key={index}\n className={classNames(\"xh-tabbar-content-item\", {\n \"xh-tabbar-content-item-dispaly\":\n selectIndex !== index && !animated,\n \"xh-tabbar-content-item-active\": selectIndex === index,\n })}\n style={{\n transform: animated ? `translateX(-${selectIndex * 100}%)` : \"\",\n }}\n >\n {child.props.children}\n </View>\n ))}\n </View>\n </View>\n );\n};\n\nXHTabs.Item = Item;\n\nexport default XHTabs;\nexport const TabItem = Item;\n"],"names":["XHTabs","props","_a","children","_b","animated","_c","initIndex","_d","lineColor","_e","titleActiveColor","_f","titleInctiveColor","onChange","_g","__read","useState","selectIndex","setSelectIndex","_h","tabWdith","setTabWdith","_j","tabContentHeight","setTabContentHeight","useEffect","timer","setTimeout","query","createSelectorQuery","selectAll","boundingClientRect","exec","res","width","height","clearTimeout","left","React","createElement","View","className","map","child","index","key","style","color","onClick","handleClick","TabItemComponent","title","classNames","background","concat","transform","WebkitTransform","length","Item"],"mappings":"qQAmCM,IAAAA,EAAkC,SAAAC,GAEpC,IAAAC,EAOED,EAAKE,SAPPA,OAAW,IAAAD,EAAA,GAAEA,EACbE,EAMEH,EANcI,SAAhBA,OAAQ,IAAAD,GAAQA,EAChBE,EAKEL,EAAKM,UALPA,OAAY,IAAAD,EAAA,EAACA,EACbE,EAIEP,YAJFQ,OAAY,IAAAD,EAAA,UAASA,EACrBE,EAGET,EAHuBU,iBAAzBA,OAAgB,IAAAD,EAAG,OAAMA,EACzBE,EAEEX,EAAKY,kBAFPA,OAAoB,IAAAD,EAAA,OAAMA,EAC1BE,EACEb,EAAKa,SAEHC,EAAAC,EAAgCC,EAASV,GAAU,GAAlDW,EAAWH,EAAA,GAAEI,OACdC,EAAAJ,EAA0BC,EAAS,GAAE,GAApCI,EAAQD,EAAA,GAAEE,OACXC,EAAAP,EAA0CC,EAAS,GAAE,GAApDO,EAAgBD,EAAA,GAAEE,OAEzBC,GAAU,WACR,IAAMC,EAAQC,YAAW,WACvB,IAAMC,EAAQC,IACdD,EAAME,UAAU,uBAAuBC,qBACvCH,EAAME,UAAU,2BAA2BC,qBAE3CH,EAAMI,MAAK,SAAAC,GACT,GAAKA,EAAI,GAAGhB,GAAZ,CACA,IAAMiB,EAAgBD,EAAI,GAAGhB,GAAaiB,MAG1C,GAFAb,EAAYa,GAEPD,EAAI,GAAGhB,GAAZ,CACA,IAAMkB,EAAiBF,EAAI,GAAGhB,GAAakB,OAC3CX,EAAoBW,GACpBC,aAAaV,EAHoB,CAJA,CAQnC,GACD,GAAE,IAEL,GAAG,CAACT,EAAaf,IAEjB,IAcQmC,EAeR,OACEC,EAACC,cAAAC,EAAK,CAAAC,UAAU,aACdH,EAAAC,cAACC,EAAI,CAACC,UAAU,iBACbvC,EAASwC,KAAI,SAACC,EAAOC,GAAU,OAC9BN,EAAAC,cAACC,EACC,CAAAK,IAAKD,EACLH,UAAU,qBACVK,MAAO,CACLC,MACE9B,IAAgB2B,EAAQlC,EAAmBE,GAE/CoC,QAAS,WAAM,OAxCL,SAACJ,GACnB1B,EAAe0B,GACf,IAAMhB,EAAQC,IACdD,EAAME,UAAU,2BAA2BC,qBAC3CH,EAAMI,MAAK,SAAAC,GACT,GAAKA,EAAI,GAAGW,GAAZ,CACA,IAAMT,EAAiBF,EAAI,GAAGW,GAAOT,OACrCX,EAAoBW,EAFO,CAG7B,IAEAtB,GAAYA,EAAS+B,EACvB,CA6ByBK,CAAYL,KAE1BD,EAAM3C,MAAMkD,iBACTP,EAAM3C,MAAMkD,iBACZP,EAAM3C,MAAMmD,WA9BlBd,EAAejB,EAAW,EAAIH,EAAcG,EAEhDkB,EACEC,cAAA,MAAA,CAAAE,UAAWW,EAAW,qBAAsB,CAC1C,4BAA6BhD,IAE/B0C,MAAO,CACLO,WAAY,GAAGC,OAAA9C,GACf+C,UAAW,cAAcD,OAAAjB,EAA+B,6BACxDmB,gBAAiB,cAAcF,OAAAjB,EAA+B,kCA0BlEC,EAAAC,cAACC,EACC,CAAAC,UAAU,oBACVK,MAAO,CACLZ,MAAO,GAAGoB,OAAkB,IAAlBpD,EAASuD,OAAe,KAClCtB,OAAQZ,EAAmB,GAAG+B,OAAA/B,EAAoB,MAAG,SAGtDrB,EAASwC,KAAI,SAACC,EAAOC,GAAU,OAC9BN,gBAACE,EAAI,CACHK,IAAKD,EACLH,UAAWW,EAAW,yBAA0B,CAC9C,iCACEnC,IAAgB2B,IAAUxC,EAC5B,gCAAiCa,IAAgB2B,IAEnDE,MAAO,CACLS,UAAWnD,EAAW,eAAAkD,OAA6B,IAAdrC,EAAiB,MAAO,KAG9D0B,EAAM3C,MAAME,SAEhB,KAIT,EAEAH,EAAO2D,KAAOA"}
1
+ {"version":3,"file":"Tabbar.js","sources":["../../../../src/components/Tabbar/tabbar/Tabbar.tsx"],"sourcesContent":["import React, { FC, ReactElement, useEffect, useState, ReactNode } from \"react\";\nimport { createSelectorQuery } from \"@tarojs/taro\";\nimport { View } from \"@tarojs/components\";\nimport classNames from \"classnames\";\nimport Item from \"./TabItem\";\n\n/**\n * Tab切换\n *\n * @param children //子组件\n * @param animated //是否开启转场动画\n * @param selectIndex //默认选中第几个\n * @param lineColor //下划线颜色\n * @param titleActiveColor //标题选中态颜色\n * @param titleInctiveColor //标题默认态颜色\n * @param onChange //切换回调事件\n * @param content //item公共节点\n *\n */\n\nexport interface TabProps {\n children: ReactElement[];\n animated?: boolean;\n initIndex?: number;\n lineColor?: string;\n titleActiveColor?: string;\n titleInctiveColor?: string;\n onChange?: (index: number) => void;\n content?: string | ReactNode;\n}\n\nexport interface TabsComponent<P = {}> extends FC<P> {\n Item: typeof Item;\n}\n\nconst XHTabs: TabsComponent<TabProps> = props => {\n const {\n children = [],\n animated = false,\n initIndex = 0,\n lineColor = \"#F6AB00\",\n titleActiveColor = \"#333\",\n titleInctiveColor = \"#999\",\n onChange,\n content,\n } = props;\n\n const [selectIndex, setSelectIndex] = useState(initIndex);\n const [tabWdith, setTabWdith] = useState(0);\n const [tabContentHeight, setTabContentHeight] = useState(0);\n\n useEffect(() => {\n const timer = setTimeout(() => {\n const query = createSelectorQuery();\n query.selectAll(\".xh-tabbar-nav-item\").boundingClientRect();\n query.selectAll(\".xh-tabbar-content-item\").boundingClientRect();\n\n query.exec(res => {\n if (!res[0][selectIndex]) return;\n const width: number = res[0][selectIndex].width;\n setTabWdith(width);\n\n if (!res[1][selectIndex]) return;\n const height: number = res[1][selectIndex].height;\n setTabContentHeight(height);\n clearTimeout(timer);\n });\n }, 300);\n console.log(children.length);\n }, [selectIndex, children]);\n\n const handleClick = (index: number): void => {\n setSelectIndex(index);\n const query = createSelectorQuery();\n query.selectAll(\".xh-tabbar-content-item\").boundingClientRect();\n query.exec(res => {\n if (!res[0][index]) return;\n const height: number = res[0][index].height;\n setTabContentHeight(height);\n });\n\n onChange && onChange(index);\n };\n\n function renderLine(): ReactElement | null {\n const left: number = tabWdith / 2 + selectIndex * tabWdith;\n return (\n <div\n className={classNames(\"xh-tabbar-nav-line\", {\n \"xh-tabbar-nav-line-active\": animated,\n })}\n style={{\n background: `${lineColor}`,\n transform: `translateX(${left}px) translate(-50%, -50%)`,\n WebkitTransform: `translateX(${left}px) translate(-50%, -50%)`,\n }}\n />\n );\n }\n\n return (\n <View className=\"xh-tabbar\">\n <View className=\"xh-tabbar-nav\">\n {children.map((child, index) => (\n <View\n key={index}\n className=\"xh-tabbar-nav-item\"\n style={{\n color:\n selectIndex === index ? titleActiveColor : titleInctiveColor,\n }}\n onClick={() => handleClick(index)}\n >\n {child.props.TabItemComponent\n ? child.props.TabItemComponent\n : child.props.title}\n </View>\n ))}\n {renderLine()}\n </View>\n <View\n className=\"xh-tabbar-content\"\n style={{\n width: `${children.length * 100}%`,\n height: tabContentHeight ? `${tabContentHeight}px` : \"auto\",\n }}\n >\n {content && <View>{content}</View>}\n {children.map((child, index) => (\n <View\n key={index}\n className={classNames(\"xh-tabbar-content-item\", {\n \"xh-tabbar-content-item-dispaly\":\n selectIndex !== index && !animated,\n \"xh-tabbar-content-item-active\": selectIndex === index,\n })}\n style={{\n transform: animated ? `translateX(-${selectIndex * 100}%)` : \"\",\n }}\n >\n {child.props.children}\n </View>\n ))}\n </View>\n </View>\n );\n};\n\nXHTabs.Item = Item;\n\nexport default XHTabs;\nexport const TabItem = Item;\n"],"names":["XHTabs","props","_a","children","_b","animated","_c","initIndex","_d","lineColor","_e","titleActiveColor","_f","titleInctiveColor","onChange","content","_g","__read","useState","selectIndex","setSelectIndex","_h","tabWdith","setTabWdith","_j","tabContentHeight","setTabContentHeight","useEffect","timer","setTimeout","query","createSelectorQuery","selectAll","boundingClientRect","exec","res","width","height","clearTimeout","left","React","createElement","View","className","map","child","index","key","style","color","onClick","handleClick","TabItemComponent","title","classNames","background","concat","transform","WebkitTransform","length","Item"],"mappings":"qQAmCM,IAAAA,EAAkC,SAAAC,GAEpC,IAAAC,EAQED,EARWE,SAAbA,OAAQ,IAAAD,EAAG,GAAEA,EACbE,EAOEH,EAAKI,SAPPA,OAAW,IAAAD,GAAKA,EAChBE,EAMEL,EANWM,UAAbA,OAAS,IAAAD,EAAG,EAACA,EACbE,EAKEP,EALmBQ,UAArBA,OAAS,IAAAD,EAAG,UAASA,EACrBE,EAIET,EAAKU,iBAJPA,OAAmB,IAAAD,EAAA,OAAMA,EACzBE,EAGEX,EAAKY,kBAHPA,OAAoB,IAAAD,EAAA,OAAMA,EAC1BE,EAEEb,EAAKa,SADPC,EACEd,UAEEe,EAAAC,EAAgCC,EAASX,GAAU,GAAlDY,EAAWH,EAAA,GAAEI,OACdC,EAAAJ,EAA0BC,EAAS,GAAE,GAApCI,EAAQD,EAAA,GAAEE,OACXC,EAAAP,EAA0CC,EAAS,GAAE,GAApDO,EAAgBD,EAAA,GAAEE,OAEzBC,GAAU,WACR,IAAMC,EAAQC,YAAW,WACvB,IAAMC,EAAQC,IACdD,EAAME,UAAU,uBAAuBC,qBACvCH,EAAME,UAAU,2BAA2BC,qBAE3CH,EAAMI,MAAK,SAAAC,GACT,GAAKA,EAAI,GAAGhB,GAAZ,CACA,IAAMiB,EAAgBD,EAAI,GAAGhB,GAAaiB,MAG1C,GAFAb,EAAYa,GAEPD,EAAI,GAAGhB,GAAZ,CACA,IAAMkB,EAAiBF,EAAI,GAAGhB,GAAakB,OAC3CX,EAAoBW,GACpBC,aAAaV,EAHoB,CAJA,CAQnC,GACD,GAAE,IAEL,GAAG,CAACT,EAAahB,IAEjB,IAcQoC,EAeR,OACEC,EAACC,cAAAC,EAAK,CAAAC,UAAU,aACdH,EAAAC,cAACC,EAAI,CAACC,UAAU,iBACbxC,EAASyC,KAAI,SAACC,EAAOC,GAAU,OAC9BN,EAAAC,cAACC,EACC,CAAAK,IAAKD,EACLH,UAAU,qBACVK,MAAO,CACLC,MACE9B,IAAgB2B,EAAQnC,EAAmBE,GAE/CqC,QAAS,WAAM,OAxCL,SAACJ,GACnB1B,EAAe0B,GACf,IAAMhB,EAAQC,IACdD,EAAME,UAAU,2BAA2BC,qBAC3CH,EAAMI,MAAK,SAAAC,GACT,GAAKA,EAAI,GAAGW,GAAZ,CACA,IAAMT,EAAiBF,EAAI,GAAGW,GAAOT,OACrCX,EAAoBW,EAFO,CAG7B,IAEAvB,GAAYA,EAASgC,EACvB,CA6ByBK,CAAYL,KAE1BD,EAAM5C,MAAMmD,iBACTP,EAAM5C,MAAMmD,iBACZP,EAAM5C,MAAMoD,WA9BlBd,EAAejB,EAAW,EAAIH,EAAcG,EAEhDkB,EACEC,cAAA,MAAA,CAAAE,UAAWW,EAAW,qBAAsB,CAC1C,4BAA6BjD,IAE/B2C,MAAO,CACLO,WAAY,GAAGC,OAAA/C,GACfgD,UAAW,cAAcD,OAAAjB,EAA+B,6BACxDmB,gBAAiB,cAAcF,OAAAjB,EAA+B,kCA0BlEC,EAAAC,cAACC,EACC,CAAAC,UAAU,oBACVK,MAAO,CACLZ,MAAO,GAAGoB,OAAkB,IAAlBrD,EAASwD,OAAe,KAClCtB,OAAQZ,EAAmB,GAAG+B,OAAA/B,EAAoB,MAAG,SAGtDV,GAAWyB,EAAAC,cAACC,EAAI,KAAE3B,GAClBZ,EAASyC,KAAI,SAACC,EAAOC,GAAU,OAC9BN,EAAAC,cAACC,EACC,CAAAK,IAAKD,EACLH,UAAWW,EAAW,yBAA0B,CAC9C,iCACEnC,IAAgB2B,IAAUzC,EAC5B,gCAAiCc,IAAgB2B,IAEnDE,MAAO,CACLS,UAAWpD,EAAW,eAAAmD,OAA6B,IAAdrC,EAAiB,MAAO,KAG9D0B,EAAM5C,MAAME,SAEhB,KAIT,EAEAH,EAAO4D,KAAOA"}
@@ -1,2 +1,2 @@
1
- export{default as XHButton}from"../Button/index.js";export{default as XHPage}from"../Page/index.js";export{default as XHLoading}from"../Loading/index.js";export{default as XHBankIcon}from"../BankIcon/index.js";export{default as XHCaptcha}from"../Captcha/index.js";export{default as XHFormInput}from"../FormInput/index.js";export{default as XHList}from"../List/index.js";export{default as XHMask}from"../Mask/index.js";export{default as XHImage}from"../Image/index.js";export{default as XHDialog}from"../Dialog/index.js";export{default as XHNumberKeyboard}from"../NumberKeyboard/index.js";export{default as XHPasswordInput}from"../PasswordInput/index.js";export{default as XHProgress}from"../Progress/index.js";export{default as XHToast}from"../Toast/index.js";export{default as XHDialogRef}from"../DialogRef/index.js";export{default as XHTabbar}from"../Tabbar/index.js";export{default as XHPopup}from"../Popup/index.js";export{default as XHPicker}from"../Picker/index.js";export{default as XHSpace}from"../Space/index.js";export{default as ThemeProvider}from"../ThemeProvider/index.js";export{default as XHCheckbox}from"../Checkbox/index.js";export{default as XHRadio}from"../Radio/index.js";export{default as XHStep}from"../Step/index.js";export{default as XHBadge}from"../Badge/index.js";export{default as XHAmountInput}from"../AmountInput/index.js";export{default as XHAmountKeyboard}from"../AmountKeyboard/index.js";export{default as XHCollapse}from"../Collapse/index.js";export{default as XHNavBar}from"../NavBar/index.js";export{default as XHIcon}from"../Icon/index.js";
1
+ export{default as XHButton}from"../Button/index.js";export{default as XHPage}from"../Page/index.js";export{default as XHLoading}from"../Loading/index.js";export{default as XHBankIcon}from"../BankIcon/index.js";export{default as XHCaptcha}from"../Captcha/index.js";export{default as XHFormInput}from"../FormInput/index.js";export{default as XHList}from"../List/index.js";export{default as XHMask}from"../Mask/index.js";export{default as XHImage}from"../Image/index.js";export{default as XHDialog}from"../Dialog/index.js";export{default as XHNumberKeyboard}from"../NumberKeyboard/index.js";export{default as XHPasswordInput}from"../PasswordInput/index.js";export{default as XHProgress}from"../Progress/index.js";export{default as XHToast}from"../Toast/index.js";export{default as XHDialogRef}from"../DialogRef/index.js";export{default as XHTabbar}from"../Tabbar/index.js";export{default as XHPopup}from"../Popup/index.js";export{default as XHPicker}from"../Picker/index.js";export{default as XHSpace}from"../Space/index.js";export{default as ThemeProvider}from"../ThemeProvider/index.js";export{default as XHCheckbox}from"../Checkbox/index.js";export{default as XHRadio}from"../Radio/index.js";export{default as XHStep}from"../Step/index.js";export{default as XHBadge}from"../Badge/index.js";export{default as XHAmountInput}from"../AmountInput/index.js";export{default as XHAmountKeyboard}from"../AmountKeyboard/index.js";export{default as XHCollapse}from"../Collapse/index.js";export{default as XHNavBar}from"../NavBar/index.js";export{default as XHIcon}from"../Icon/index.js";export{default as XHActionSheet}from"../ActionSheet/index.js";export{default as XHRank}from"../Rank/index.js";export{default as XHCell}from"../Cell/index.js";export{default as XHActivityIndicator}from"../ActivityIndicator/index.js";export{default as XHSwitch}from"../Switch/index.js";export{default as XHLinkMan}from"../LinkMan/index.js";export{default as XHResult}from"../Result/index.js";
2
2
  //# sourceMappingURL=index.js.map