@webiny/ui 0.0.0-unstable.40876133bb → 0.0.0-unstable.496cf268ac

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 (394) hide show
  1. package/Accordion/Accordion.d.ts +1 -1
  2. package/Accordion/Accordion.js +5 -19
  3. package/Accordion/Accordion.js.map +1 -1
  4. package/Accordion/Accordion.stories.js +0 -8
  5. package/Accordion/Accordion.stories.js.map +1 -1
  6. package/Accordion/AccordionItem.d.ts +21 -2
  7. package/Accordion/AccordionItem.js +49 -71
  8. package/Accordion/AccordionItem.js.map +1 -1
  9. package/Accordion/AccordionItemActions.d.ts +8 -0
  10. package/Accordion/AccordionItemActions.js +28 -0
  11. package/Accordion/AccordionItemActions.js.map +1 -0
  12. package/Accordion/index.js +0 -4
  13. package/Accordion/index.js.map +1 -1
  14. package/Alert/Alert.d.ts +1 -1
  15. package/Alert/Alert.js +4 -11
  16. package/Alert/Alert.js.map +1 -1
  17. package/Alert/Alert.stories.js +0 -6
  18. package/Alert/Alert.stories.js.map +1 -1
  19. package/Alert/index.js +0 -2
  20. package/Alert/index.js.map +1 -1
  21. package/AutoComplete/AutoComplete.js +38 -88
  22. package/AutoComplete/AutoComplete.js.map +1 -1
  23. package/AutoComplete/AutoComplete.stories.js +0 -7
  24. package/AutoComplete/AutoComplete.stories.js.map +1 -1
  25. package/AutoComplete/MultiAutoComplete.js +52 -128
  26. package/AutoComplete/MultiAutoComplete.js.map +1 -1
  27. package/AutoComplete/MultiAutoComplete.stories.js +0 -8
  28. package/AutoComplete/MultiAutoComplete.stories.js.map +1 -1
  29. package/AutoComplete/index.js +0 -4
  30. package/AutoComplete/index.js.map +1 -1
  31. package/AutoComplete/styles.js +0 -2
  32. package/AutoComplete/styles.js.map +1 -1
  33. package/AutoComplete/utils.js +0 -8
  34. package/AutoComplete/utils.js.map +1 -1
  35. package/Avatar/Avatar.js +7 -18
  36. package/Avatar/Avatar.js.map +1 -1
  37. package/Avatar/Avatar.stories.js +0 -6
  38. package/Avatar/Avatar.stories.js.map +1 -1
  39. package/Avatar/index.js +0 -2
  40. package/Avatar/index.js.map +1 -1
  41. package/Button/Button.d.ts +30 -1
  42. package/Button/Button.js +39 -63
  43. package/Button/Button.js.map +1 -1
  44. package/Button/Button.stories.js +0 -10
  45. package/Button/Button.stories.js.map +1 -1
  46. package/Button/Button.styles.js +0 -2
  47. package/Button/Button.styles.js.map +1 -1
  48. package/Button/CopyButton/CopyButton.js +2 -12
  49. package/Button/CopyButton/CopyButton.js.map +1 -1
  50. package/Button/CopyButton/CopyButton.stories.js +0 -7
  51. package/Button/CopyButton/CopyButton.stories.js.map +1 -1
  52. package/Button/IconButton/IconButton.js +6 -12
  53. package/Button/IconButton/IconButton.js.map +1 -1
  54. package/Button/IconButton/IconButton.stories.js +0 -9
  55. package/Button/IconButton/IconButton.stories.js.map +1 -1
  56. package/Button/index.js +0 -6
  57. package/Button/index.js.map +1 -1
  58. package/Carousel/Carousel.js +0 -14
  59. package/Carousel/Carousel.js.map +1 -1
  60. package/Carousel/Carouser.stories.js +0 -7
  61. package/Carousel/Carouser.stories.js.map +1 -1
  62. package/Carousel/index.js +0 -2
  63. package/Carousel/index.js.map +1 -1
  64. package/Checkbox/Checkbox.d.ts +1 -0
  65. package/Checkbox/Checkbox.js +13 -31
  66. package/Checkbox/Checkbox.js.map +1 -1
  67. package/Checkbox/Checkbox.stories.js +0 -8
  68. package/Checkbox/Checkbox.stories.js.map +1 -1
  69. package/Checkbox/Checkbox.styles.js +0 -2
  70. package/Checkbox/Checkbox.styles.js.map +1 -1
  71. package/Checkbox/CheckboxGroup.js +7 -24
  72. package/Checkbox/CheckboxGroup.js.map +1 -1
  73. package/Checkbox/CheckboxGroup.stories.js +2 -10
  74. package/Checkbox/CheckboxGroup.stories.js.map +1 -1
  75. package/Checkbox/index.js +0 -3
  76. package/Checkbox/index.js.map +1 -1
  77. package/Chips/Chip.js +1 -8
  78. package/Chips/Chip.js.map +1 -1
  79. package/Chips/Chips.js +3 -13
  80. package/Chips/Chips.js.map +1 -1
  81. package/Chips/Chips.stories.js +0 -8
  82. package/Chips/Chips.stories.js.map +1 -1
  83. package/Chips/index.js +0 -4
  84. package/Chips/index.js.map +1 -1
  85. package/Chips/styles.js +0 -2
  86. package/Chips/styles.js.map +1 -1
  87. package/CodeEditor/CodeEditor.js +8 -36
  88. package/CodeEditor/CodeEditor.js.map +1 -1
  89. package/CodeEditor/CodeEditor.stories.js +0 -10
  90. package/CodeEditor/CodeEditor.stories.js.map +1 -1
  91. package/CodeEditor/index.js +0 -2
  92. package/CodeEditor/index.js.map +1 -1
  93. package/ColorPicker/ColorPicker.js +7 -31
  94. package/ColorPicker/ColorPicker.js.map +1 -1
  95. package/ColorPicker/ColorPicker.stories.js +0 -8
  96. package/ColorPicker/ColorPicker.stories.js.map +1 -1
  97. package/ColorPicker/index.js +0 -2
  98. package/ColorPicker/index.js.map +1 -1
  99. package/ConfirmationDialog/ConfirmationDialog.js +33 -65
  100. package/ConfirmationDialog/ConfirmationDialog.js.map +1 -1
  101. package/ConfirmationDialog/ConfirmationDialog.stories.js +0 -7
  102. package/ConfirmationDialog/ConfirmationDialog.stories.js.map +1 -1
  103. package/ConfirmationDialog/index.js +0 -4
  104. package/ConfirmationDialog/index.js.map +1 -1
  105. package/ConfirmationDialog/withConfirmation.js +0 -5
  106. package/ConfirmationDialog/withConfirmation.js.map +1 -1
  107. package/DataTable/DataTable.d.ts +16 -1
  108. package/DataTable/DataTable.js +62 -42
  109. package/DataTable/DataTable.js.map +1 -1
  110. package/DataTable/DataTable.stories.js +0 -6
  111. package/DataTable/DataTable.stories.js.map +1 -1
  112. package/DataTable/index.js +0 -2
  113. package/DataTable/index.js.map +1 -1
  114. package/DataTable/styled.d.ts +30 -1
  115. package/DataTable/styled.js +25 -7
  116. package/DataTable/styled.js.map +1 -1
  117. package/DelayedOnChange/DelayedOnChange.js +19 -35
  118. package/DelayedOnChange/DelayedOnChange.js.map +1 -1
  119. package/DelayedOnChange/index.js +0 -3
  120. package/DelayedOnChange/index.js.map +1 -1
  121. package/DelayedOnChange/withDelayedOnChange.js +3 -9
  122. package/DelayedOnChange/withDelayedOnChange.js.map +1 -1
  123. package/Dialog/Dialog.js +7 -39
  124. package/Dialog/Dialog.js.map +1 -1
  125. package/Dialog/Dialog.stories.js +0 -7
  126. package/Dialog/Dialog.stories.js.map +1 -1
  127. package/Dialog/index.js +0 -2
  128. package/Dialog/index.js.map +1 -1
  129. package/Drawer/Drawer.js +0 -9
  130. package/Drawer/Drawer.js.map +1 -1
  131. package/Drawer/Drawer.stories.js +0 -8
  132. package/Drawer/Drawer.stories.js.map +1 -1
  133. package/Drawer/index.js +0 -2
  134. package/Drawer/index.js.map +1 -1
  135. package/DynamicFieldset/Fieldset.js +7 -34
  136. package/DynamicFieldset/Fieldset.js.map +1 -1
  137. package/DynamicFieldset/index.js +0 -2
  138. package/DynamicFieldset/index.js.map +1 -1
  139. package/Elevation/Elevation.js +0 -5
  140. package/Elevation/Elevation.js.map +1 -1
  141. package/Elevation/Elevation.stories.js +0 -8
  142. package/Elevation/Elevation.stories.js.map +1 -1
  143. package/Elevation/index.js +0 -2
  144. package/Elevation/index.js.map +1 -1
  145. package/FormElementMessage/FormElementMessage.js +0 -5
  146. package/FormElementMessage/FormElementMessage.js.map +1 -1
  147. package/FormElementMessage/index.js +0 -1
  148. package/FormElementMessage/index.js.map +1 -1
  149. package/FullName/FullName.js +0 -7
  150. package/FullName/FullName.js.map +1 -1
  151. package/FullName/index.js +0 -2
  152. package/FullName/index.js.map +1 -1
  153. package/Grid/Grid.js +1 -9
  154. package/Grid/Grid.js.map +1 -1
  155. package/Grid/Grid.stories.js +0 -6
  156. package/Grid/Grid.stories.js.map +1 -1
  157. package/Grid/index.js +0 -2
  158. package/Grid/index.js.map +1 -1
  159. package/Helpers/ClassNames.js +0 -9
  160. package/Helpers/ClassNames.js.map +1 -1
  161. package/Helpers/index.js +0 -1
  162. package/Helpers/index.js.map +1 -1
  163. package/Icon/Icon.js +1 -7
  164. package/Icon/Icon.js.map +1 -1
  165. package/Icon/Icon.stories.js +0 -10
  166. package/Icon/Icon.stories.js.map +1 -1
  167. package/Icon/index.js +0 -2
  168. package/Icon/index.js.map +1 -1
  169. package/Image/Image.js +0 -8
  170. package/Image/Image.js.map +1 -1
  171. package/Image/Image.stories.js +0 -7
  172. package/Image/Image.stories.js.map +1 -1
  173. package/Image/index.js +0 -2
  174. package/Image/index.js.map +1 -1
  175. package/ImageEditor/ImageEditor.js +46 -107
  176. package/ImageEditor/ImageEditor.js.map +1 -1
  177. package/ImageEditor/index.js +0 -2
  178. package/ImageEditor/index.js.map +1 -1
  179. package/ImageEditor/toolbar/crop.js +1 -16
  180. package/ImageEditor/toolbar/crop.js.map +1 -1
  181. package/ImageEditor/toolbar/filter.js +11 -36
  182. package/ImageEditor/toolbar/filter.js.map +1 -1
  183. package/ImageEditor/toolbar/flip.js +0 -17
  184. package/ImageEditor/toolbar/flip.js.map +1 -1
  185. package/ImageEditor/toolbar/icons/index.js +0 -8
  186. package/ImageEditor/toolbar/icons/index.js.map +1 -1
  187. package/ImageEditor/toolbar/index.js +0 -5
  188. package/ImageEditor/toolbar/index.js.map +1 -1
  189. package/ImageEditor/toolbar/rotate.js +8 -43
  190. package/ImageEditor/toolbar/rotate.js.map +1 -1
  191. package/ImageUpload/Image.js +10 -34
  192. package/ImageUpload/Image.js.map +1 -1
  193. package/ImageUpload/ImageEditorDialog.js +11 -33
  194. package/ImageUpload/ImageEditorDialog.js.map +1 -1
  195. package/ImageUpload/MultiImageUpload.js +111 -175
  196. package/ImageUpload/MultiImageUpload.js.map +1 -1
  197. package/ImageUpload/MultiImageUpload.stories.js +0 -8
  198. package/ImageUpload/MultiImageUpload.stories.js.map +1 -1
  199. package/ImageUpload/SingleImageUpload.js +38 -79
  200. package/ImageUpload/SingleImageUpload.js.map +1 -1
  201. package/ImageUpload/SingleImageUpload.stories.js +0 -8
  202. package/ImageUpload/SingleImageUpload.stories.js.map +1 -1
  203. package/ImageUpload/index.js +0 -5
  204. package/ImageUpload/index.js.map +1 -1
  205. package/ImageUpload/styled.d.ts +27 -17
  206. package/ImageUpload/styled.js +0 -5
  207. package/ImageUpload/styled.js.map +1 -1
  208. package/Input/Input.d.ts +2 -12
  209. package/Input/Input.js +86 -149
  210. package/Input/Input.js.map +1 -1
  211. package/Input/Input.stories.js +0 -13
  212. package/Input/Input.stories.js.map +1 -1
  213. package/Input/__tests__/Input.test.js +4 -30
  214. package/Input/__tests__/Input.test.js.map +1 -1
  215. package/Input/index.js +0 -2
  216. package/Input/index.js.map +1 -1
  217. package/List/CollapsibleList/CollapsibleList.stories.js +0 -8
  218. package/List/CollapsibleList/CollapsibleList.stories.js.map +1 -1
  219. package/List/CollapsibleList/index.js +0 -6
  220. package/List/CollapsibleList/index.js.map +1 -1
  221. package/List/DataList/DataList.js +18 -97
  222. package/List/DataList/DataList.js.map +1 -1
  223. package/List/DataList/DataList.stories.js +2 -10
  224. package/List/DataList/DataList.stories.js.map +1 -1
  225. package/List/DataList/DataListModalOverlay/DataListModalOverlay.d.ts +8 -6
  226. package/List/DataList/DataListModalOverlay/DataListModalOverlay.js +5 -16
  227. package/List/DataList/DataListModalOverlay/DataListModalOverlay.js.map +1 -1
  228. package/List/DataList/DataListModalOverlay/DataListModalOverlayAction.js +3 -14
  229. package/List/DataList/DataListModalOverlay/DataListModalOverlayAction.js.map +1 -1
  230. package/List/DataList/DataListModalOverlay/DataListModalOverlayContext.js +3 -12
  231. package/List/DataList/DataListModalOverlay/DataListModalOverlayContext.js.map +1 -1
  232. package/List/DataList/DataListModalOverlay/index.js +0 -3
  233. package/List/DataList/DataListModalOverlay/index.js.map +1 -1
  234. package/List/DataList/DataListWithSections.js +4 -48
  235. package/List/DataList/DataListWithSections.js.map +1 -1
  236. package/List/DataList/Loader.js +0 -7
  237. package/List/DataList/Loader.js.map +1 -1
  238. package/List/DataList/NoData.js +0 -7
  239. package/List/DataList/NoData.js.map +1 -1
  240. package/List/DataList/icons/index.js +0 -29
  241. package/List/DataList/icons/index.js.map +1 -1
  242. package/List/DataList/index.js +0 -6
  243. package/List/DataList/index.js.map +1 -1
  244. package/List/List.js +0 -39
  245. package/List/List.js.map +1 -1
  246. package/List/List.stories.js +0 -12
  247. package/List/List.stories.js.map +1 -1
  248. package/List/icons/index.js +0 -3
  249. package/List/icons/index.js.map +1 -1
  250. package/List/index.js +0 -4
  251. package/List/index.js.map +1 -1
  252. package/Menu/Menu.js +2 -28
  253. package/Menu/Menu.js.map +1 -1
  254. package/Menu/Menu.stories.js +0 -7
  255. package/Menu/Menu.stories.js.map +1 -1
  256. package/Menu/index.js +0 -2
  257. package/Menu/index.js.map +1 -1
  258. package/Mosaic/Mosaic.js +3 -7
  259. package/Mosaic/Mosaic.js.map +1 -1
  260. package/Mosaic/Mosaic.stories.js +0 -6
  261. package/Mosaic/Mosaic.stories.js.map +1 -1
  262. package/Mosaic/index.js +0 -2
  263. package/Mosaic/index.js.map +1 -1
  264. package/Progress/CircularProgress.js +6 -14
  265. package/Progress/CircularProgress.js.map +1 -1
  266. package/Progress/index.js +0 -2
  267. package/Progress/index.js.map +1 -1
  268. package/Radio/Radio.js +9 -28
  269. package/Radio/Radio.js.map +1 -1
  270. package/Radio/Radio.styles.js +0 -2
  271. package/Radio/Radio.styles.js.map +1 -1
  272. package/Radio/RadioGroup.js +5 -21
  273. package/Radio/RadioGroup.js.map +1 -1
  274. package/Radio/RadioGroup.stories.js +2 -10
  275. package/Radio/RadioGroup.stories.js.map +1 -1
  276. package/Radio/index.js +0 -3
  277. package/Radio/index.js.map +1 -1
  278. package/RichTextEditor/RichTextEditor.js +30 -64
  279. package/RichTextEditor/RichTextEditor.js.map +1 -1
  280. package/RichTextEditor/RichTextEditor.stories.js +0 -7
  281. package/RichTextEditor/RichTextEditor.stories.js.map +1 -1
  282. package/RichTextEditor/createPropsFromConfig.js +0 -4
  283. package/RichTextEditor/createPropsFromConfig.js.map +1 -1
  284. package/RichTextEditor/index.js +0 -3
  285. package/RichTextEditor/index.js.map +1 -1
  286. package/Ripple/Ripple.js +0 -6
  287. package/Ripple/Ripple.js.map +1 -1
  288. package/Ripple/Ripple.stories.js +0 -12
  289. package/Ripple/Ripple.stories.js.map +1 -1
  290. package/Ripple/index.js +0 -2
  291. package/Ripple/index.js.map +1 -1
  292. package/Scrollbar/Scrollbar.js +0 -5
  293. package/Scrollbar/Scrollbar.js.map +1 -1
  294. package/Scrollbar/Scrollbar.stories.js +0 -6
  295. package/Scrollbar/Scrollbar.stories.js.map +1 -1
  296. package/Scrollbar/index.js +0 -2
  297. package/Scrollbar/index.js.map +1 -1
  298. package/Section/Section.stories.js +0 -7
  299. package/Section/Section.stories.js.map +1 -1
  300. package/Section/index.js +2 -12
  301. package/Section/index.js.map +1 -1
  302. package/Select/Select.js +9 -32
  303. package/Select/Select.js.map +1 -1
  304. package/Select/Select.stories.js +0 -8
  305. package/Select/Select.stories.js.map +1 -1
  306. package/Select/index.js +0 -2
  307. package/Select/index.js.map +1 -1
  308. package/Skeleton/Skeleton.d.ts +6 -2
  309. package/Skeleton/Skeleton.js +8 -11
  310. package/Skeleton/Skeleton.js.map +1 -1
  311. package/Skeleton/Skeleton.stories.js +0 -6
  312. package/Skeleton/Skeleton.stories.js.map +1 -1
  313. package/Skeleton/index.js +0 -2
  314. package/Skeleton/index.js.map +1 -1
  315. package/Slider/Slider.js +7 -29
  316. package/Slider/Slider.js.map +1 -1
  317. package/Slider/Slider.stories.js +1 -9
  318. package/Slider/Slider.stories.js.map +1 -1
  319. package/Slider/index.js +0 -2
  320. package/Slider/index.js.map +1 -1
  321. package/Snackbar/Snackbar.js +0 -19
  322. package/Snackbar/Snackbar.js.map +1 -1
  323. package/Snackbar/Snackbar.stories.js +0 -23
  324. package/Snackbar/Snackbar.stories.js.map +1 -1
  325. package/Snackbar/index.js +0 -1
  326. package/Snackbar/index.js.map +1 -1
  327. package/Switch/Switch.d.ts +1 -1
  328. package/Switch/Switch.js +5 -28
  329. package/Switch/Switch.js.map +1 -1
  330. package/Switch/Switch.stories.js +0 -8
  331. package/Switch/Switch.stories.js.map +1 -1
  332. package/Switch/index.js +0 -2
  333. package/Switch/index.js.map +1 -1
  334. package/Tabs/Tab.d.ts +1 -0
  335. package/Tabs/Tab.js +3 -9
  336. package/Tabs/Tab.js.map +1 -1
  337. package/Tabs/Tabs.d.ts +1 -0
  338. package/Tabs/Tabs.js +15 -28
  339. package/Tabs/Tabs.js.map +1 -1
  340. package/Tabs/Tabs.stories.js +0 -10
  341. package/Tabs/Tabs.stories.js.map +1 -1
  342. package/Tabs/index.js +0 -4
  343. package/Tabs/index.js.map +1 -1
  344. package/Tags/Tags.d.ts +8 -15
  345. package/Tags/Tags.js +77 -130
  346. package/Tags/Tags.js.map +1 -1
  347. package/Tags/Tags.stories.js +0 -8
  348. package/Tags/Tags.stories.js.map +1 -1
  349. package/Tags/index.js +0 -2
  350. package/Tags/index.js.map +1 -1
  351. package/Tooltip/Tooltip.js +0 -19
  352. package/Tooltip/Tooltip.js.map +1 -1
  353. package/Tooltip/Tooltip.stories.js +0 -6
  354. package/Tooltip/Tooltip.stories.js.map +1 -1
  355. package/Tooltip/index.js +0 -2
  356. package/Tooltip/index.js.map +1 -1
  357. package/TopAppBar/TopAppBar.js +1 -8
  358. package/TopAppBar/TopAppBar.js.map +1 -1
  359. package/TopAppBar/TopAppBar.stories.js +3 -16
  360. package/TopAppBar/TopAppBar.stories.js.map +1 -1
  361. package/TopAppBar/TopAppBarActionItem.js +0 -5
  362. package/TopAppBar/TopAppBarActionItem.js.map +1 -1
  363. package/TopAppBar/TopAppBarNavigationIcon.js +0 -5
  364. package/TopAppBar/TopAppBarNavigationIcon.js.map +1 -1
  365. package/TopAppBar/TopAppBarPrimary.js +1 -8
  366. package/TopAppBar/TopAppBarPrimary.js.map +1 -1
  367. package/TopAppBar/TopAppBarSecondary.js +3 -10
  368. package/TopAppBar/TopAppBarSecondary.js.map +1 -1
  369. package/TopAppBar/TopAppBarSection.js +1 -8
  370. package/TopAppBar/TopAppBarSection.js.map +1 -1
  371. package/TopAppBar/TopAppBarTitle.js +1 -8
  372. package/TopAppBar/TopAppBarTitle.js.map +1 -1
  373. package/TopAppBar/index.js +0 -14
  374. package/TopAppBar/index.js.map +1 -1
  375. package/TopProgressBar/TopProgressBar.js +0 -5
  376. package/TopProgressBar/TopProgressBar.js.map +1 -1
  377. package/TopProgressBar/TopProgressBar.stories.js +1 -8
  378. package/TopProgressBar/TopProgressBar.stories.js.map +1 -1
  379. package/TopProgressBar/hoc/index.js +0 -2
  380. package/TopProgressBar/hoc/index.js.map +1 -1
  381. package/TopProgressBar/hoc/withTopProgressBar.js +2 -8
  382. package/TopProgressBar/hoc/withTopProgressBar.js.map +1 -1
  383. package/TopProgressBar/index.js +0 -2
  384. package/TopProgressBar/index.js.map +1 -1
  385. package/Typography/Typography.d.ts +2 -2
  386. package/Typography/Typography.js +0 -5
  387. package/Typography/Typography.js.map +1 -1
  388. package/Typography/Typography.stories.js +0 -6
  389. package/Typography/Typography.stories.js.map +1 -1
  390. package/Typography/index.js +0 -2
  391. package/Typography/index.js.map +1 -1
  392. package/package.json +17 -15
  393. package/types.d.ts +3 -3
  394. package/types.js.map +1 -1
package/Tabs/Tabs.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":["disabledStyles","opacity","pointerEvents","TabsContext","createContext","undefined","Tabs","forwardRef","props","ref","useState","activeTabIndex","setActiveIndex","tabs","setTabs","activeIndex","value","activateTabIndex","useCallback","index","updateValue","useImperativeHandle","switchTab","tabIndex","useEffect","disabled","tabBar","map","tab","id","join","evt","detail","onActivate","item","style","Object","assign","icon","label","content","children","display","context","useMemo","addTab","existingIndex","findIndex","slice","removeTab","filter","classNames","className","displayName"],"sources":["Tabs.tsx"],"sourcesContent":["import React, {\n createContext,\n forwardRef,\n PropsWithChildren,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useState\n} from \"react\";\nimport classNames from \"classnames\";\nimport { TabBar, Tab as RmwcTab } from \"@rmwc/tabs\";\nimport { TabProps } from \"./Tab\";\n\nexport type TabsProps = PropsWithChildren<{\n /**\n * Append a class name.\n */\n className?: string;\n\n /**\n * Callback to execute when a tab is changed.\n */\n onActivate?: (index: number) => void;\n\n /**\n * Active tab index value.\n */\n value?: number;\n\n /**\n * Function to change active tab.\n */\n updateValue?: (index: number) => void;\n /**\n * Tab ID for the testing.\n */\n \"data-testid\"?: string;\n}>;\n\nconst disabledStyles: Record<string, string | number> = {\n opacity: 0.5,\n pointerEvents: \"none\"\n};\n\ninterface TabItem extends TabProps {\n id: string;\n}\n\ninterface TabsContext {\n addTab(props: TabItem): void;\n removeTab(id: string): void;\n}\n\nexport const TabsContext = createContext<TabsContext | undefined>(undefined);\n\nexport interface TabsImperativeApi {\n switchTab(index: number): void;\n}\n/**\n * Use Tabs component to display a list of choices, once the handler is triggered.\n */\nexport const Tabs = forwardRef<TabsImperativeApi | undefined, TabsProps>((props, ref) => {\n const [activeTabIndex, setActiveIndex] = useState(0);\n const [tabs, setTabs] = useState<TabItem[]>([]);\n\n const activeIndex = props.value !== undefined ? props.value : activeTabIndex;\n\n const activateTabIndex = useCallback((index: number) => {\n if (typeof props.updateValue === \"function\") {\n props.updateValue(index);\n return;\n }\n\n setActiveIndex(index);\n }, []);\n\n useImperativeHandle(ref, () => ({\n switchTab(tabIndex: number) {\n activateTabIndex(tabIndex);\n }\n }));\n\n /**\n * This effect will make sure that disabled tabs automatically switch to the first tab.\n */\n useEffect(() => {\n if (tabs[activeIndex]?.disabled) {\n activateTabIndex(0);\n }\n });\n\n /* We need to generate a key like this to trigger a proper component re-render when child tabs change. */\n const tabBar = (\n <TabBar\n key={tabs.map(tab => tab.id).join(\";\")}\n className=\"webiny-ui-tabs__tab-bar\"\n activeTabIndex={activeIndex}\n onActivate={evt => {\n if (typeof props.updateValue === \"function\") {\n props.updateValue(evt.detail.index);\n } else {\n setActiveIndex(evt.detail.index);\n }\n props.onActivate && props.onActivate(evt.detail.index);\n }}\n >\n {tabs.map(item => {\n const style = item.style || {};\n if (item.disabled) {\n Object.assign(style, disabledStyles);\n }\n\n return (\n <RmwcTab\n tag={\"div\"}\n style={style}\n key={item.id}\n data-testid={item[\"data-testid\"]}\n {...(item.icon ? { icon: item.icon } : {})}\n >\n {item.label}\n </RmwcTab>\n );\n })}\n </TabBar>\n );\n\n const content = tabs.map((tab, index) => {\n if (activeIndex === index) {\n return <div key={index}>{tab.children}</div>;\n } else {\n return (\n <div key={index} style={{ display: \"none\" }}>\n {tab.children}\n </div>\n );\n }\n });\n\n const context: TabsContext = useMemo(\n () => ({\n addTab(props) {\n setTabs(tabs => {\n const existingIndex = tabs.findIndex(tab => tab.id === props.id);\n if (existingIndex > -1) {\n return [\n ...tabs.slice(0, existingIndex),\n props,\n ...tabs.slice(existingIndex + 1)\n ];\n }\n return [...tabs, props];\n });\n },\n removeTab(id) {\n setTabs(tabs => tabs.filter(tab => tab.id === id));\n }\n }),\n [setTabs]\n );\n\n return (\n <div className={classNames(\"webiny-ui-tabs\", props.className)}>\n {tabBar}\n <div className={\"webiny-ui-tabs__content mdc-tab-content\"}>{content}</div>\n <TabsContext.Provider value={context}>{props.children}</TabsContext.Provider>\n </div>\n );\n});\n\nTabs.displayName = \"Tabs\";\n"],"mappings":"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"}
1
+ {"version":3,"names":["disabledStyles","opacity","pointerEvents","TabsContext","createContext","undefined","Tabs","forwardRef","props","ref","useState","activeTabIndex","setActiveIndex","tabs","setTabs","activeIndex","value","activateTabIndex","useCallback","index","updateValue","useImperativeHandle","getActiveIndex","switchTab","tabIndex","useEffect","disabled","tabBar","map","tab","id","join","evt","detail","onActivate","item","visible","style","Object","assign","icon","label","content","filter","Boolean","children","display","context","useMemo","addTab","existingIndex","findIndex","slice","removeTab","classNames","className","displayName"],"sources":["Tabs.tsx"],"sourcesContent":["import React, {\n createContext,\n forwardRef,\n PropsWithChildren,\n useCallback,\n useEffect,\n useImperativeHandle,\n useMemo,\n useState\n} from \"react\";\nimport classNames from \"classnames\";\nimport { TabBar, Tab as RmwcTab } from \"@rmwc/tabs\";\nimport { TabProps } from \"./Tab\";\n\nexport type TabsProps = PropsWithChildren<{\n /**\n * Append a class name.\n */\n className?: string;\n\n /**\n * Callback to execute when a tab is changed.\n */\n onActivate?: (index: number) => void;\n\n /**\n * Active tab index value.\n */\n value?: number;\n\n /**\n * Function to change active tab.\n */\n updateValue?: (index: number) => void;\n /**\n * Tab ID for the testing.\n */\n \"data-testid\"?: string;\n}>;\n\nconst disabledStyles: Record<string, string | number> = {\n opacity: 0.5,\n pointerEvents: \"none\"\n};\n\ninterface TabItem extends TabProps {\n id: string;\n}\n\ninterface TabsContext {\n addTab(props: TabItem): void;\n removeTab(id: string): void;\n}\n\nexport const TabsContext = createContext<TabsContext | undefined>(undefined);\n\nexport interface TabsImperativeApi {\n switchTab(index: number): void;\n getActiveIndex(): number;\n}\n/**\n * Use Tabs component to display a list of choices, once the handler is triggered.\n */\nexport const Tabs = forwardRef<TabsImperativeApi | undefined, TabsProps>((props, ref) => {\n const [activeTabIndex, setActiveIndex] = useState(0);\n const [tabs, setTabs] = useState<TabItem[]>([]);\n\n const activeIndex = props.value !== undefined ? props.value : activeTabIndex;\n\n const activateTabIndex = useCallback((index: number) => {\n if (typeof props.updateValue === \"function\") {\n props.updateValue(index);\n return;\n }\n\n setActiveIndex(index);\n }, []);\n\n useImperativeHandle(ref, () => ({\n getActiveIndex() {\n return activeIndex;\n },\n switchTab(tabIndex: number) {\n activateTabIndex(tabIndex);\n }\n }));\n\n /**\n * This effect will make sure that disabled tabs automatically switch to the first tab.\n */\n useEffect(() => {\n if (tabs[activeIndex]?.disabled) {\n activateTabIndex(0);\n }\n });\n\n /* We need to generate a key like this to trigger a proper component re-render when child tabs change. */\n const tabBar = (\n <TabBar\n key={tabs.map(tab => tab.id).join(\";\")}\n className=\"webiny-ui-tabs__tab-bar\"\n activeTabIndex={activeIndex}\n onActivate={evt => {\n if (typeof props.updateValue === \"function\") {\n props.updateValue(evt.detail.index);\n } else {\n setActiveIndex(evt.detail.index);\n }\n props.onActivate && props.onActivate(evt.detail.index);\n }}\n >\n {tabs.map(item => {\n if (!item.visible) {\n return null;\n }\n\n const style = item.style || {};\n if (item.disabled) {\n Object.assign(style, disabledStyles);\n }\n\n return (\n <RmwcTab\n tag={\"div\"}\n style={style}\n key={item.id}\n data-testid={item[\"data-testid\"]}\n {...(item.icon ? { icon: item.icon } : {})}\n >\n {item.label}\n </RmwcTab>\n );\n })}\n </TabBar>\n );\n\n const content = tabs.filter(Boolean).map((tab, index) => {\n if (activeIndex === index) {\n return <div key={index}>{tab.children}</div>;\n } else {\n return (\n <div key={index} style={{ display: \"none\" }}>\n {tab.children}\n </div>\n );\n }\n });\n\n const context: TabsContext = useMemo(\n () => ({\n addTab(props) {\n setTabs(tabs => {\n const existingIndex = tabs.findIndex(tab => tab.id === props.id);\n if (existingIndex > -1) {\n return [\n ...tabs.slice(0, existingIndex),\n props,\n ...tabs.slice(existingIndex + 1)\n ];\n }\n return [...tabs, props];\n });\n },\n removeTab(id) {\n setTabs(tabs => tabs.filter(tab => tab.id === id));\n }\n }),\n [setTabs]\n );\n\n return (\n <div className={classNames(\"webiny-ui-tabs\", props.className)}>\n {tabBar}\n <div className={\"webiny-ui-tabs__content mdc-tab-content\"}>{content}</div>\n <TabsContext.Provider value={context}>{props.children}</TabsContext.Provider>\n </div>\n );\n});\n\nTabs.displayName = \"Tabs\";\n"],"mappings":"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"}
@@ -1,23 +1,14 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@storybook/react");
8
-
9
6
  var _Story = require("@webiny/storybook-utils/Story");
10
-
11
7
  var _README = _interopRequireDefault(require("./../Tabs/README.md"));
12
-
13
8
  var _baselineDelete24px = require("./svg/baseline-delete-24px.svg");
14
-
15
9
  var _baselineDone24px = require("./svg/baseline-done-24px.svg");
16
-
17
10
  var _addonKnobs = require("@storybook/addon-knobs");
18
-
19
11
  var _index = require("./index");
20
-
21
12
  var story = (0, _react2.storiesOf)("Components/Tabs", module);
22
13
  story.addDecorator(_addonKnobs.withKnobs);
23
14
  story.add("usage", function () {
@@ -28,7 +19,6 @@ story.add("usage", function () {
28
19
  }
29
20
  }, props.children);
30
21
  };
31
-
32
22
  return /*#__PURE__*/_react.default.createElement(_Story.Story, null, /*#__PURE__*/_react.default.createElement(_Story.StoryReadme, null, _README.default), /*#__PURE__*/_react.default.createElement(_Story.StorySandbox, {
33
23
  title: "Tabs example"
34
24
  }, /*#__PURE__*/_react.default.createElement(_Story.StorySandboxExample, null, /*#__PURE__*/_react.default.createElement("div", {
@@ -1 +1 @@
1
- {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","Div","props","padding","children","readme","overflow","info","propTables","Tabs","Tab"],"sources":["Tabs.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport readme from \"./../Tabs/README.md\";\n\nimport { ReactComponent as DeleteIcon } from \"./svg/baseline-delete-24px.svg\";\nimport { ReactComponent as DoneIcon } from \"./svg/baseline-done-24px.svg\";\nimport { withKnobs } from \"@storybook/addon-knobs\";\nimport { Tabs, Tab } from \"./index\";\n\nconst story = storiesOf(\"Components/Tabs\", module);\n\nstory.addDecorator(withKnobs);\nstory.add(\n \"usage\",\n () => {\n const Div: React.FC = props => {\n return <div style={{ padding: 50 }}>{props.children}</div>;\n };\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox title={\"Tabs example\"}>\n <StorySandboxExample>\n <div style={{ overflow: \"hidden\" }}>\n <Tabs>\n <Tab label=\"Tab 1\" icon={<DeleteIcon />}>\n <Div>Tab 1 content.</Div>\n </Tab>\n <Tab label=\"Tab 2\" icon={<DoneIcon />}>\n <Div>Tab 2 content.</Div>\n </Tab>\n <Tab label=\"Tab 3\">\n <Div>Tab 3 content - header without icon.</Div>\n </Tab>\n <Tab icon={<DoneIcon />}>\n <Div>Tab 4 content - header without label.</Div>\n </Tab>\n </Tabs>\n </div>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Tabs>\n <Tab label=\"Tab 1\" icon={<DeleteIcon />}>\n <Div>Tab 1 content.</Div>\n </Tab>\n <Tab label=\"Tab 2\" icon={<DoneIcon />}>\n <Div>Tab 2 content.</Div>\n </Tab>\n <Tab label=\"Tab 3\">\n <Div>Tab 3 content - header without icon.</Div>\n </Tab>\n <Tab icon={<DoneIcon />}>\n <Div>Tab 4 content - header without label.</Div>\n </Tab>\n </Tabs>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Tabs, Tab] } }\n);\n"],"mappings":";;;;AAAA;;AACA;;AACA;;AAOA;;AAEA;;AACA;;AACA;;AACA;;AAEA,IAAMA,KAAK,GAAG,IAAAC,iBAAA,EAAU,iBAAV,EAA6BC,MAA7B,CAAd;AAEAF,KAAK,CAACG,YAAN,CAAmBC,qBAAnB;AACAJ,KAAK,CAACK,GAAN,CACI,OADJ,EAEI,YAAM;EACF,IAAMC,GAAa,GAAG,SAAhBA,GAAgB,CAAAC,KAAK,EAAI;IAC3B,oBAAO;MAAK,KAAK,EAAE;QAAEC,OAAO,EAAE;MAAX;IAAZ,GAA8BD,KAAK,CAACE,QAApC,CAAP;EACH,CAFD;;EAIA,oBACI,6BAAC,YAAD,qBACI,6BAAC,kBAAD,QAAcC,eAAd,CADJ,eAEI,6BAAC,mBAAD;IAAc,KAAK,EAAE;EAArB,gBACI,6BAAC,0BAAD,qBACI;IAAK,KAAK,EAAE;MAAEC,QAAQ,EAAE;IAAZ;EAAZ,gBACI,6BAAC,WAAD,qBACI,6BAAC,UAAD;IAAK,KAAK,EAAC,OAAX;IAAmB,IAAI,eAAE,6BAAC,kCAAD;EAAzB,gBACI,6BAAC,GAAD,yBADJ,CADJ,eAII,6BAAC,UAAD;IAAK,KAAK,EAAC,OAAX;IAAmB,IAAI,eAAE,6BAAC,gCAAD;EAAzB,gBACI,6BAAC,GAAD,yBADJ,CAJJ,eAOI,6BAAC,UAAD;IAAK,KAAK,EAAC;EAAX,gBACI,6BAAC,GAAD,+CADJ,CAPJ,eAUI,6BAAC,UAAD;IAAK,IAAI,eAAE,6BAAC,gCAAD;EAAX,gBACI,6BAAC,GAAD,gDADJ,CAVJ,CADJ,CADJ,CADJ,eAmBI,6BAAC,uBAAD,i0BAnBJ,CAFJ,CADJ;AA2CH,CAlDL,EAmDI;EAAEC,IAAI,EAAE;IAAEC,UAAU,EAAE,CAACC,WAAD,EAAOC,UAAP;EAAd;AAAR,CAnDJ"}
1
+ {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","Div","props","padding","children","readme","overflow","info","propTables","Tabs","Tab"],"sources":["Tabs.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport readme from \"./../Tabs/README.md\";\n\nimport { ReactComponent as DeleteIcon } from \"./svg/baseline-delete-24px.svg\";\nimport { ReactComponent as DoneIcon } from \"./svg/baseline-done-24px.svg\";\nimport { withKnobs } from \"@storybook/addon-knobs\";\nimport { Tabs, Tab } from \"./index\";\n\nconst story = storiesOf(\"Components/Tabs\", module);\n\nstory.addDecorator(withKnobs);\nstory.add(\n \"usage\",\n () => {\n const Div: React.FC = props => {\n return <div style={{ padding: 50 }}>{props.children}</div>;\n };\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox title={\"Tabs example\"}>\n <StorySandboxExample>\n <div style={{ overflow: \"hidden\" }}>\n <Tabs>\n <Tab label=\"Tab 1\" icon={<DeleteIcon />}>\n <Div>Tab 1 content.</Div>\n </Tab>\n <Tab label=\"Tab 2\" icon={<DoneIcon />}>\n <Div>Tab 2 content.</Div>\n </Tab>\n <Tab label=\"Tab 3\">\n <Div>Tab 3 content - header without icon.</Div>\n </Tab>\n <Tab icon={<DoneIcon />}>\n <Div>Tab 4 content - header without label.</Div>\n </Tab>\n </Tabs>\n </div>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Tabs>\n <Tab label=\"Tab 1\" icon={<DeleteIcon />}>\n <Div>Tab 1 content.</Div>\n </Tab>\n <Tab label=\"Tab 2\" icon={<DoneIcon />}>\n <Div>Tab 2 content.</Div>\n </Tab>\n <Tab label=\"Tab 3\">\n <Div>Tab 3 content - header without icon.</Div>\n </Tab>\n <Tab icon={<DoneIcon />}>\n <Div>Tab 4 content - header without label.</Div>\n </Tab>\n </Tabs>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Tabs, Tab] } }\n);\n"],"mappings":";;;AAAA;AACA;AACA;AAOA;AAEA;AACA;AACA;AACA;AAEA,IAAMA,KAAK,GAAG,IAAAC,iBAAS,EAAC,iBAAiB,EAAEC,MAAM,CAAC;AAElDF,KAAK,CAACG,YAAY,CAACC,qBAAS,CAAC;AAC7BJ,KAAK,CAACK,GAAG,CACL,OAAO,EACP,YAAM;EACF,IAAMC,GAAa,GAAG,SAAhBA,GAAa,CAAGC,KAAK,EAAI;IAC3B,oBAAO;MAAK,KAAK,EAAE;QAAEC,OAAO,EAAE;MAAG;IAAE,GAAED,KAAK,CAACE,QAAQ,CAAO;EAC9D,CAAC;EAED,oBACI,6BAAC,YAAK,qBACF,6BAAC,kBAAW,QAAEC,eAAM,CAAe,eACnC,6BAAC,mBAAY;IAAC,KAAK,EAAE;EAAe,gBAChC,6BAAC,0BAAmB,qBAChB;IAAK,KAAK,EAAE;MAAEC,QAAQ,EAAE;IAAS;EAAE,gBAC/B,6BAAC,WAAI,qBACD,6BAAC,UAAG;IAAC,KAAK,EAAC,OAAO;IAAC,IAAI,eAAE,6BAAC,kCAAU;EAAI,gBACpC,6BAAC,GAAG,QAAC,gBAAc,CAAM,CACvB,eACN,6BAAC,UAAG;IAAC,KAAK,EAAC,OAAO;IAAC,IAAI,eAAE,6BAAC,gCAAQ;EAAI,gBAClC,6BAAC,GAAG,QAAC,gBAAc,CAAM,CACvB,eACN,6BAAC,UAAG;IAAC,KAAK,EAAC;EAAO,gBACd,6BAAC,GAAG,QAAC,sCAAoC,CAAM,CAC7C,eACN,6BAAC,UAAG;IAAC,IAAI,eAAE,6BAAC,gCAAQ;EAAI,gBACpB,6BAAC,GAAG,QAAC,uCAAqC,CAAM,CAC9C,CACH,CACL,CACY,eACtB,6BAAC,uBAAgB,i0BAiBE,CACR,CACX;AAEhB,CAAC,EACD;EAAEC,IAAI,EAAE;IAAEC,UAAU,EAAE,CAACC,WAAI,EAAEC,UAAG;EAAE;AAAE,CAAC,CACxC"}
package/Tabs/index.js CHANGED
@@ -3,9 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
-
7
6
  var _Tabs = require("./Tabs");
8
-
9
7
  Object.keys(_Tabs).forEach(function (key) {
10
8
  if (key === "default" || key === "__esModule") return;
11
9
  if (key in exports && exports[key] === _Tabs[key]) return;
@@ -16,9 +14,7 @@ Object.keys(_Tabs).forEach(function (key) {
16
14
  }
17
15
  });
18
16
  });
19
-
20
17
  var _Tab = require("./Tab");
21
-
22
18
  Object.keys(_Tab).forEach(function (key) {
23
19
  if (key === "default" || key === "__esModule") return;
24
20
  if (key in exports && exports[key] === _Tab[key]) return;
package/Tabs/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Tabs\";\nexport * from \"./Tab\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;;AACA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Tabs\";\nexport * from \"./Tab\";\n"],"mappings":";;;;;AAAA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA;AACA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
package/Tags/Tags.d.ts CHANGED
@@ -1,6 +1,6 @@
1
1
  import React from "react";
2
2
  import { FormComponentProps } from "../types";
3
- declare type TagsProps = FormComponentProps & {
3
+ interface TagsProps extends FormComponentProps {
4
4
  /**
5
5
  * Component label.
6
6
  */
@@ -22,12 +22,9 @@ declare type TagsProps = FormComponentProps & {
22
22
  */
23
23
  className?: string;
24
24
  /**
25
- * Default structure of value, an object consisting of "id" and "name" keys. Different keys can be set using "valueProp" and "textProp" props.
25
+ * A list of tags.
26
26
  */
27
- value?: {
28
- id: string;
29
- name: string;
30
- };
27
+ value?: string[];
31
28
  /**
32
29
  * Callback that gets executed on change of input value.
33
30
  */
@@ -40,14 +37,10 @@ declare type TagsProps = FormComponentProps & {
40
37
  * Automatically focus on the tags input.
41
38
  */
42
39
  autoFocus?: boolean;
43
- };
44
- interface TagsState {
45
- inputValue: string;
46
- }
47
- export declare class Tags extends React.Component<TagsProps, TagsState> {
48
- state: {
49
- inputValue: string;
50
- };
51
- render(): JSX.Element;
40
+ /**
41
+ * Protected tags cannot be removed by the user.
42
+ */
43
+ protectedTags?: string[];
52
44
  }
45
+ export declare const Tags: React.FC<TagsProps>;
53
46
  export default Tags;
package/Tags/Tags.js CHANGED
@@ -1,45 +1,24 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
4
+ var _interopRequireWildcard = require("@babel/runtime/helpers/interopRequireWildcard").default;
5
5
  Object.defineProperty(exports, "__esModule", {
6
6
  value: true
7
7
  });
8
8
  exports.default = exports.Tags = void 0;
9
-
10
9
  var _toConsumableArray2 = _interopRequireDefault(require("@babel/runtime/helpers/toConsumableArray"));
11
-
12
10
  var _objectSpread2 = _interopRequireDefault(require("@babel/runtime/helpers/objectSpread2"));
13
-
14
11
  var _objectWithoutProperties2 = _interopRequireDefault(require("@babel/runtime/helpers/objectWithoutProperties"));
15
-
16
- var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
17
-
18
- var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
19
-
20
- var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
21
-
22
- var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
23
-
24
- var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
25
-
26
- var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
27
-
28
- var _react = _interopRequireDefault(require("react"));
29
-
30
- var _Input = require("../Input");
31
-
32
- var _Chips = require("../Chips");
33
-
12
+ var _slicedToArray2 = _interopRequireDefault(require("@babel/runtime/helpers/slicedToArray"));
13
+ var _react = _interopRequireWildcard(require("react"));
34
14
  var _emotion = require("emotion");
35
-
36
15
  var _keycode = _interopRequireDefault(require("keycode"));
37
-
16
+ var _minimatch = _interopRequireDefault(require("minimatch"));
17
+ var _Input = require("../Input");
18
+ var _Chips = require("../Chips");
38
19
  var _baselineClose24px = require("./icons/baseline-close-24px.svg");
39
-
40
20
  var _FormElementMessage = require("../FormElementMessage");
41
-
42
- var _excluded = ["validation", "value", "disabled", "onChange", "description"];
21
+ var _excluded = ["validation", "value", "disabled", "onChange", "description", "protectedTags"];
43
22
  var tagsStyle = /*#__PURE__*/(0, _emotion.css)({
44
23
  position: "relative",
45
24
  ".mdc-elevation--z1": {
@@ -61,112 +40,80 @@ var tagsStyle = /*#__PURE__*/(0, _emotion.css)({
61
40
  }
62
41
  }
63
42
  }, "label:tagsStyle;");
64
-
65
- var Tags = /*#__PURE__*/function (_React$Component) {
66
- (0, _inherits2.default)(Tags, _React$Component);
67
-
68
- var _super = (0, _createSuper2.default)(Tags);
69
-
70
- function Tags() {
71
- var _this;
72
-
73
- (0, _classCallCheck2.default)(this, Tags);
74
-
75
- for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
76
- args[_key] = arguments[_key];
77
- }
78
-
79
- _this = _super.call.apply(_super, [this].concat(args));
80
- (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {
81
- inputValue: ""
43
+ var Tags = function Tags(props) {
44
+ var _useState = (0, _react.useState)(""),
45
+ _useState2 = (0, _slicedToArray2.default)(_useState, 2),
46
+ inputValue = _useState2[0],
47
+ setInputValue = _useState2[1];
48
+ var validation = props.validation,
49
+ value = props.value,
50
+ disabled = props.disabled,
51
+ onChange = props.onChange,
52
+ description = props.description,
53
+ _props$protectedTags = props.protectedTags,
54
+ protectedTags = _props$protectedTags === void 0 ? [] : _props$protectedTags,
55
+ otherInputProps = (0, _objectWithoutProperties2.default)(props, _excluded);
56
+ var isProtected = (0, _react.useCallback)(function (tag) {
57
+ return protectedTags.some(function (pattern) {
58
+ return (0, _minimatch.default)(tag, pattern);
82
59
  });
83
- return _this;
84
- }
85
-
86
- (0, _createClass2.default)(Tags, [{
87
- key: "render",
88
- value: function render() {
89
- var _this2 = this;
90
-
91
- var _this$props = this.props,
92
- validation = _this$props.validation,
93
- value = _this$props.value,
94
- disabled = _this$props.disabled,
95
- onChange = _this$props.onChange,
96
- description = _this$props.description,
97
- otherInputProps = (0, _objectWithoutProperties2.default)(_this$props, _excluded);
98
- var inputProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, otherInputProps), {}, {
99
- value: this.state.inputValue,
100
- onChange: function onChange(inputValue) {
101
- _this2.setState({
102
- inputValue: inputValue
103
- });
104
- },
105
- onKeyDown: function onKeyDown(ev) {
106
- if (!onChange) {
107
- return;
108
- }
109
-
110
- var newValue = Array.isArray(value) ? (0, _toConsumableArray2.default)(value) : [];
111
- var inputValue = _this2.state.inputValue || "";
112
- /**
113
- * We must cast as keycode only works with Event | string type.
114
- */
115
-
116
- switch ((0, _keycode.default)(ev)) {
117
- case "enter":
118
- if (inputValue) {
119
- newValue.push(inputValue);
120
- onChange(newValue);
121
-
122
- _this2.setState({
123
- inputValue: ""
124
- });
125
- }
126
-
127
- break;
128
-
129
- case "backspace":
130
- if (newValue.length && !inputValue) {
131
- newValue.splice(-1, 1);
132
- onChange(newValue);
133
- break;
134
- }
135
-
60
+ }, [protectedTags]);
61
+ var inputProps = (0, _objectSpread2.default)((0, _objectSpread2.default)({}, otherInputProps), {}, {
62
+ value: inputValue,
63
+ onChange: function onChange(inputValue) {
64
+ setInputValue(inputValue);
65
+ },
66
+ onKeyDown: function onKeyDown(ev) {
67
+ if (!onChange) {
68
+ return;
69
+ }
70
+ var newValue = Array.isArray(value) ? (0, _toConsumableArray2.default)(value) : [];
71
+
72
+ /**
73
+ * We must cast as keycode only works with Event | string type.
74
+ */
75
+ switch ((0, _keycode.default)(ev)) {
76
+ case "enter":
77
+ if (inputValue) {
78
+ newValue.push(inputValue);
79
+ onChange(newValue);
80
+ setInputValue("");
136
81
  }
137
- }
138
- });
139
-
140
- var _ref = validation || {},
141
- validationIsValid = _ref.isValid,
142
- validationMessage = _ref.message;
143
-
144
- return /*#__PURE__*/_react.default.createElement("div", {
145
- className: tagsStyle
146
- }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Input.Input, inputProps), validationIsValid === false && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, {
147
- error: true
148
- }, validationMessage), validationIsValid !== false && description && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, null, description), Array.isArray(value) && value.length ? /*#__PURE__*/_react.default.createElement(_Chips.Chips, {
149
- disabled: disabled
150
- }, value.map(function (item, index) {
151
- return /*#__PURE__*/_react.default.createElement(_Chips.Chip, {
152
- label: item,
153
- trailingIcon: /*#__PURE__*/_react.default.createElement(_baselineClose24px.ReactComponent, null),
154
- key: "".concat(item, "-").concat(index),
155
- onRemove: function onRemove() {
156
- // On removal, let's update the value and call "onChange" callback.
157
- if (onChange) {
158
- var newValue = (0, _toConsumableArray2.default)(value);
159
- newValue.splice(index, 1);
160
- onChange(newValue);
161
- }
82
+ break;
83
+ case "backspace":
84
+ if (newValue.length && !inputValue) {
85
+ newValue.splice(-1, 1);
86
+ onChange(newValue);
87
+ break;
162
88
  }
163
- });
164
- })) : null));
89
+ }
165
90
  }
166
- }]);
167
- return Tags;
168
- }(_react.default.Component);
169
-
91
+ });
92
+ var _ref = validation || {},
93
+ validationIsValid = _ref.isValid,
94
+ validationMessage = _ref.message;
95
+ return /*#__PURE__*/_react.default.createElement("div", {
96
+ className: tagsStyle
97
+ }, /*#__PURE__*/_react.default.createElement("div", null, /*#__PURE__*/_react.default.createElement(_Input.Input, inputProps), validationIsValid === false && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, {
98
+ error: true
99
+ }, validationMessage), validationIsValid !== false && description && /*#__PURE__*/_react.default.createElement(_FormElementMessage.FormElementMessage, null, description), Array.isArray(value) && value.length ? /*#__PURE__*/_react.default.createElement(_Chips.Chips, {
100
+ disabled: disabled
101
+ }, value.map(function (item, index) {
102
+ return /*#__PURE__*/_react.default.createElement(_Chips.Chip, {
103
+ label: item,
104
+ trailingIcon: isProtected(item) ? null : /*#__PURE__*/_react.default.createElement(_baselineClose24px.ReactComponent, null),
105
+ key: "".concat(item, "-").concat(index),
106
+ onRemove: function onRemove() {
107
+ // On removal, let's update the value and call "onChange" callback.
108
+ if (onChange) {
109
+ var newValue = (0, _toConsumableArray2.default)(value);
110
+ newValue.splice(index, 1);
111
+ onChange(newValue);
112
+ }
113
+ }
114
+ });
115
+ })) : null));
116
+ };
170
117
  exports.Tags = Tags;
171
118
  var _default = Tags;
172
119
  exports.default = _default;
package/Tags/Tags.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":["tagsStyle","css","position","width","left","top","zIndex","maxHeight","overflowY","backgroundColor","ul","listStyle","padding","li","Tags","inputValue","props","validation","value","disabled","onChange","description","otherInputProps","inputProps","state","setState","onKeyDown","ev","newValue","Array","isArray","keycode","push","length","splice","validationIsValid","isValid","validationMessage","message","map","item","index","React","Component"],"sources":["Tags.tsx"],"sourcesContent":["import React from \"react\";\nimport { Input, InputProps } from \"~/Input\";\nimport { Chips, Chip } from \"../Chips\";\nimport { FormComponentProps } from \"~/types\";\nimport { css } from \"emotion\";\nimport keycode from \"keycode\";\nimport { ReactComponent as BaselineCloseIcon } from \"./icons/baseline-close-24px.svg\";\nimport { FormElementMessage } from \"~/FormElementMessage\";\nimport { SyntheticEvent } from \"react\";\n\ntype TagsProps = FormComponentProps & {\n /**\n * Component label.\n */\n label?: string;\n\n /**\n * Are input and chosen tags disabled?\n */\n disabled?: boolean;\n\n /**\n * Placeholder text for the form control. Set to a blank string to create a non-floating placeholder label.\n */\n placeholder?: string;\n\n /**\n * Description beneath the input.\n */\n description?: string;\n\n /**\n * A className for the root element.\n */\n className?: string;\n\n /**\n * Default structure of value, an object consisting of \"id\" and \"name\" keys. Different keys can be set using \"valueProp\" and \"textProp\" props.\n */\n value?: { id: string; name: string };\n\n /**\n * Callback that gets executed on change of input value.\n */\n onInput?: Function;\n\n /**\n * Callback that gets executed when the input is focused.\n */\n onFocus?: Function;\n\n /**\n * Automatically focus on the tags input.\n */\n autoFocus?: boolean;\n};\n\ninterface TagsState {\n inputValue: string;\n}\n\nconst tagsStyle = css({\n position: \"relative\",\n \".mdc-elevation--z1\": {\n position: \"absolute\",\n width: \"calc(100% - 2px)\",\n left: 1,\n top: 56,\n zIndex: 10,\n maxHeight: 200,\n overflowY: \"scroll\",\n backgroundColor: \"var(--mdc-theme-surface)\"\n },\n ul: {\n listStyle: \"none\",\n width: \"100%\",\n padding: 0,\n li: {\n padding: 10\n }\n }\n});\n\nexport class Tags extends React.Component<TagsProps, TagsState> {\n public override state = {\n inputValue: \"\"\n };\n\n public override render() {\n const { validation, value, disabled, onChange, description, ...otherInputProps } =\n this.props;\n\n const inputProps: InputProps = {\n ...otherInputProps,\n value: this.state.inputValue,\n onChange: (inputValue: string) => {\n this.setState({ inputValue });\n },\n onKeyDown: (ev: SyntheticEvent) => {\n if (!onChange) {\n return;\n }\n\n const newValue = Array.isArray(value) ? [...value] : [];\n const inputValue = this.state.inputValue || \"\";\n /**\n * We must cast as keycode only works with Event | string type.\n */\n switch (keycode(ev as unknown as Event)) {\n case \"enter\":\n if (inputValue) {\n newValue.push(inputValue);\n onChange(newValue);\n this.setState({ inputValue: \"\" });\n }\n break;\n case \"backspace\":\n if (newValue.length && !inputValue) {\n newValue.splice(-1, 1);\n onChange(newValue);\n break;\n }\n }\n }\n };\n\n const { isValid: validationIsValid, message: validationMessage } = validation || {};\n\n return (\n <div className={tagsStyle}>\n <div>\n <Input {...inputProps} />\n\n {validationIsValid === false && (\n <FormElementMessage error>{validationMessage}</FormElementMessage>\n )}\n {validationIsValid !== false && description && (\n <FormElementMessage>{description}</FormElementMessage>\n )}\n\n {Array.isArray(value) && value.length ? (\n <Chips disabled={disabled}>\n {value.map((item, index) => (\n <Chip\n label={item}\n trailingIcon={<BaselineCloseIcon />}\n key={`${item}-${index}`}\n onRemove={() => {\n // On removal, let's update the value and call \"onChange\" callback.\n if (onChange) {\n const newValue = [...value];\n newValue.splice(index, 1);\n onChange(newValue);\n }\n }}\n />\n ))}\n </Chips>\n ) : null}\n </div>\n </div>\n );\n }\n}\n\nexport default Tags;\n"],"mappings":"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"}
1
+ {"version":3,"names":["tagsStyle","css","position","width","left","top","zIndex","maxHeight","overflowY","backgroundColor","ul","listStyle","padding","li","Tags","props","useState","inputValue","setInputValue","validation","value","disabled","onChange","description","protectedTags","otherInputProps","isProtected","useCallback","tag","some","pattern","minimatch","inputProps","onKeyDown","ev","newValue","Array","isArray","keycode","push","length","splice","validationIsValid","isValid","validationMessage","message","map","item","index"],"sources":["Tags.tsx"],"sourcesContent":["import React, { SyntheticEvent, useCallback, useState } from \"react\";\nimport { css } from \"emotion\";\nimport keycode from \"keycode\";\nimport minimatch from \"minimatch\";\nimport { Input, InputProps } from \"~/Input\";\nimport { Chips, Chip } from \"~/Chips\";\nimport { FormComponentProps } from \"~/types\";\nimport { ReactComponent as BaselineCloseIcon } from \"./icons/baseline-close-24px.svg\";\nimport { FormElementMessage } from \"~/FormElementMessage\";\n\ninterface TagsProps extends FormComponentProps {\n /**\n * Component label.\n */\n label?: string;\n\n /**\n * Are input and chosen tags disabled?\n */\n disabled?: boolean;\n\n /**\n * Placeholder text for the form control. Set to a blank string to create a non-floating placeholder label.\n */\n placeholder?: string;\n\n /**\n * Description beneath the input.\n */\n description?: string;\n\n /**\n * A className for the root element.\n */\n className?: string;\n\n /**\n * A list of tags.\n */\n value?: string[];\n\n /**\n * Callback that gets executed on change of input value.\n */\n onInput?: Function;\n\n /**\n * Callback that gets executed when the input is focused.\n */\n onFocus?: Function;\n\n /**\n * Automatically focus on the tags input.\n */\n autoFocus?: boolean;\n\n /**\n * Protected tags cannot be removed by the user.\n */\n protectedTags?: string[];\n}\n\nconst tagsStyle = css({\n position: \"relative\",\n \".mdc-elevation--z1\": {\n position: \"absolute\",\n width: \"calc(100% - 2px)\",\n left: 1,\n top: 56,\n zIndex: 10,\n maxHeight: 200,\n overflowY: \"scroll\",\n backgroundColor: \"var(--mdc-theme-surface)\"\n },\n ul: {\n listStyle: \"none\",\n width: \"100%\",\n padding: 0,\n li: {\n padding: 10\n }\n }\n});\n\nexport const Tags: React.FC<TagsProps> = props => {\n const [inputValue, setInputValue] = useState(\"\");\n\n const {\n validation,\n value,\n disabled,\n onChange,\n description,\n protectedTags = [],\n ...otherInputProps\n } = props;\n\n const isProtected = useCallback(\n (tag: string) => protectedTags.some(pattern => minimatch(tag, pattern)),\n [protectedTags]\n );\n\n const inputProps: InputProps<string> = {\n ...otherInputProps,\n value: inputValue,\n onChange: inputValue => {\n setInputValue(inputValue);\n },\n onKeyDown: (ev: SyntheticEvent) => {\n if (!onChange) {\n return;\n }\n\n const newValue = Array.isArray(value) ? [...value] : [];\n\n /**\n * We must cast as keycode only works with Event | string type.\n */\n switch (keycode(ev as unknown as Event)) {\n case \"enter\":\n if (inputValue) {\n newValue.push(inputValue);\n onChange(newValue);\n setInputValue(\"\");\n }\n break;\n case \"backspace\":\n if (newValue.length && !inputValue) {\n newValue.splice(-1, 1);\n onChange(newValue);\n break;\n }\n }\n }\n };\n\n const { isValid: validationIsValid, message: validationMessage } = validation || {};\n\n return (\n <div className={tagsStyle}>\n <div>\n <Input {...inputProps} />\n\n {validationIsValid === false && (\n <FormElementMessage error>{validationMessage}</FormElementMessage>\n )}\n {validationIsValid !== false && description && (\n <FormElementMessage>{description}</FormElementMessage>\n )}\n\n {Array.isArray(value) && value.length ? (\n <Chips disabled={disabled}>\n {value.map((item, index) => {\n return (\n <Chip\n label={item}\n trailingIcon={isProtected(item) ? null : <BaselineCloseIcon />}\n key={`${item}-${index}`}\n onRemove={() => {\n // On removal, let's update the value and call \"onChange\" callback.\n if (onChange) {\n const newValue = [...value];\n newValue.splice(index, 1);\n onChange(newValue);\n }\n }}\n />\n );\n })}\n </Chips>\n ) : null}\n </div>\n </div>\n );\n};\n\nexport default Tags;\n"],"mappings":"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"}
@@ -1,21 +1,13 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  var _react = _interopRequireDefault(require("react"));
6
-
7
5
  var _react2 = require("@storybook/react");
8
-
9
6
  var _Story = require("@webiny/storybook-utils/Story");
10
-
11
7
  var _addonKnobs = require("@storybook/addon-knobs");
12
-
13
8
  var _README = _interopRequireDefault(require("./README.md"));
14
-
15
9
  var _form = require("@webiny/form");
16
-
17
10
  var _Tags = require("./Tags");
18
-
19
11
  var story = (0, _react2.storiesOf)("Components/Tags", module);
20
12
  story.addDecorator(_addonKnobs.withKnobs);
21
13
  story.add("usage", function () {
@@ -1 +1 @@
1
- {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","disabled","boolean","readme","tags","Bind","info","propTables","Tags"],"sources":["Tags.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport { withKnobs, boolean } from \"@storybook/addon-knobs\";\nimport readme from \"./README.md\";\n\nimport { Form } from \"@webiny/form\";\nimport { Tags } from \"./Tags\";\n\nconst story = storiesOf(\"Components/Tags\", module);\nstory.addDecorator(withKnobs);\n\nstory.add(\n \"usage\",\n () => {\n const disabled = boolean(\"Disabled\", false);\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox>\n <StorySandboxExample title={\"Single value\"}>\n <Form data={{ tags: [\"animals\", \"dogs\", \"food\"] }}>\n {({ Bind }) => (\n <Bind name=\"tags\">\n <Tags\n label=\"Tags\"\n disabled={disabled}\n description=\"Choose your tags\"\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form data={{ tags: ['animals', 'dogs', 'food'] }}>\n {({ Bind }) => (\n <Bind name=\"tags\">\n <Tags\n label=\"Tags\"\n disabled={disabled}\n description=\"Choose your tags\"\n />\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Tags] } }\n);\n"],"mappings":";;;;AAAA;;AACA;;AACA;;AAOA;;AACA;;AAEA;;AACA;;AAEA,IAAMA,KAAK,GAAG,IAAAC,iBAAA,EAAU,iBAAV,EAA6BC,MAA7B,CAAd;AACAF,KAAK,CAACG,YAAN,CAAmBC,qBAAnB;AAEAJ,KAAK,CAACK,GAAN,CACI,OADJ,EAEI,YAAM;EACF,IAAMC,QAAQ,GAAG,IAAAC,mBAAA,EAAQ,UAAR,EAAoB,KAApB,CAAjB;EAEA,oBACI,6BAAC,YAAD,qBACI,6BAAC,kBAAD,QAAcC,eAAd,CADJ,eAEI,6BAAC,mBAAD,qBACI,6BAAC,0BAAD;IAAqB,KAAK,EAAE;EAA5B,gBACI,6BAAC,UAAD;IAAM,IAAI,EAAE;MAAEC,IAAI,EAAE,CAAC,SAAD,EAAY,MAAZ,EAAoB,MAApB;IAAR;EAAZ,GACK;IAAA,IAAGC,IAAH,QAAGA,IAAH;IAAA,oBACG,6BAAC,IAAD;MAAM,IAAI,EAAC;IAAX,gBACI,6BAAC,UAAD;MACI,KAAK,EAAC,MADV;MAEI,QAAQ,EAAEJ,QAFd;MAGI,WAAW,EAAC;IAHhB,EADJ,CADH;EAAA,CADL,CADJ,CADJ,eAcI,6BAAC,uBAAD,miBAdJ,CAFJ,CADJ;AAmCH,CAxCL,EAyCI;EAAEK,IAAI,EAAE;IAAEC,UAAU,EAAE,CAACC,UAAD;EAAd;AAAR,CAzCJ"}
1
+ {"version":3,"names":["story","storiesOf","module","addDecorator","withKnobs","add","disabled","boolean","readme","tags","Bind","info","propTables","Tags"],"sources":["Tags.stories.tsx"],"sourcesContent":["import React from \"react\";\nimport { storiesOf } from \"@storybook/react\";\nimport {\n Story,\n StoryReadme,\n StorySandboxCode,\n StorySandbox,\n StorySandboxExample\n} from \"@webiny/storybook-utils/Story\";\nimport { withKnobs, boolean } from \"@storybook/addon-knobs\";\nimport readme from \"./README.md\";\n\nimport { Form } from \"@webiny/form\";\nimport { Tags } from \"./Tags\";\n\nconst story = storiesOf(\"Components/Tags\", module);\nstory.addDecorator(withKnobs);\n\nstory.add(\n \"usage\",\n () => {\n const disabled = boolean(\"Disabled\", false);\n\n return (\n <Story>\n <StoryReadme>{readme}</StoryReadme>\n <StorySandbox>\n <StorySandboxExample title={\"Single value\"}>\n <Form data={{ tags: [\"animals\", \"dogs\", \"food\"] }}>\n {({ Bind }) => (\n <Bind name=\"tags\">\n <Tags\n label=\"Tags\"\n disabled={disabled}\n description=\"Choose your tags\"\n />\n </Bind>\n )}\n </Form>\n </StorySandboxExample>\n <StorySandboxCode>\n {`\n <Form data={{ tags: ['animals', 'dogs', 'food'] }}>\n {({ Bind }) => (\n <Bind name=\"tags\">\n <Tags\n label=\"Tags\"\n disabled={disabled}\n description=\"Choose your tags\"\n />\n </Bind>\n )}\n </Form>\n `}\n </StorySandboxCode>\n </StorySandbox>\n </Story>\n );\n },\n { info: { propTables: [Tags] } }\n);\n"],"mappings":";;;AAAA;AACA;AACA;AAOA;AACA;AAEA;AACA;AAEA,IAAMA,KAAK,GAAG,IAAAC,iBAAS,EAAC,iBAAiB,EAAEC,MAAM,CAAC;AAClDF,KAAK,CAACG,YAAY,CAACC,qBAAS,CAAC;AAE7BJ,KAAK,CAACK,GAAG,CACL,OAAO,EACP,YAAM;EACF,IAAMC,QAAQ,GAAG,IAAAC,mBAAO,EAAC,UAAU,EAAE,KAAK,CAAC;EAE3C,oBACI,6BAAC,YAAK,qBACF,6BAAC,kBAAW,QAAEC,eAAM,CAAe,eACnC,6BAAC,mBAAY,qBACT,6BAAC,0BAAmB;IAAC,KAAK,EAAE;EAAe,gBACvC,6BAAC,UAAI;IAAC,IAAI,EAAE;MAAEC,IAAI,EAAE,CAAC,SAAS,EAAE,MAAM,EAAE,MAAM;IAAE;EAAE,GAC7C;IAAA,IAAGC,IAAI,QAAJA,IAAI;IAAA,oBACJ,6BAAC,IAAI;MAAC,IAAI,EAAC;IAAM,gBACb,6BAAC,UAAI;MACD,KAAK,EAAC,MAAM;MACZ,QAAQ,EAAEJ,QAAS;MACnB,WAAW,EAAC;IAAkB,EAChC,CACC;EAAA,CACV,CACE,CACW,eACtB,6BAAC,uBAAgB,miBAcE,CACR,CACX;AAEhB,CAAC,EACD;EAAEK,IAAI,EAAE;IAAEC,UAAU,EAAE,CAACC,UAAI;EAAE;AAAE,CAAC,CACnC"}
package/Tags/index.js CHANGED
@@ -3,9 +3,7 @@
3
3
  Object.defineProperty(exports, "__esModule", {
4
4
  value: true
5
5
  });
6
-
7
6
  var _Tags = require("./Tags");
8
-
9
7
  Object.keys(_Tags).forEach(function (key) {
10
8
  if (key === "default" || key === "__esModule") return;
11
9
  if (key in exports && exports[key] === _Tags[key]) return;
package/Tags/index.js.map CHANGED
@@ -1 +1 @@
1
- {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Tags\";\n"],"mappings":";;;;;;AAAA;;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
1
+ {"version":3,"names":[],"sources":["index.ts"],"sourcesContent":["export * from \"./Tags\";\n"],"mappings":";;;;;AAAA;AAAA;EAAA;EAAA;EAAA;IAAA;IAAA;MAAA;IAAA;EAAA;AAAA"}
@@ -1,49 +1,32 @@
1
1
  "use strict";
2
2
 
3
3
  var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault").default;
4
-
5
4
  Object.defineProperty(exports, "__esModule", {
6
5
  value: true
7
6
  });
8
7
  exports.Tooltip = void 0;
9
-
10
8
  var _classCallCheck2 = _interopRequireDefault(require("@babel/runtime/helpers/classCallCheck"));
11
-
12
9
  var _createClass2 = _interopRequireDefault(require("@babel/runtime/helpers/createClass"));
13
-
14
10
  var _assertThisInitialized2 = _interopRequireDefault(require("@babel/runtime/helpers/assertThisInitialized"));
15
-
16
11
  var _inherits2 = _interopRequireDefault(require("@babel/runtime/helpers/inherits"));
17
-
18
12
  var _createSuper2 = _interopRequireDefault(require("@babel/runtime/helpers/createSuper"));
19
-
20
13
  var _defineProperty2 = _interopRequireDefault(require("@babel/runtime/helpers/defineProperty"));
21
-
22
14
  var _react = _interopRequireDefault(require("react"));
23
-
24
15
  var _rcTooltip = _interopRequireDefault(require("rc-tooltip"));
25
-
26
16
  require("rc-tooltip/assets/bootstrap_white.css");
27
-
28
17
  require("./style.scss");
29
-
30
18
  /**
31
19
  * Use Tooltip component to display a list of choices, once the handler is triggered.
32
20
  */
33
21
  var Tooltip = /*#__PURE__*/function (_React$Component) {
34
22
  (0, _inherits2.default)(Tooltip, _React$Component);
35
-
36
23
  var _super = (0, _createSuper2.default)(Tooltip);
37
-
38
24
  function Tooltip() {
39
25
  var _this;
40
-
41
26
  (0, _classCallCheck2.default)(this, Tooltip);
42
-
43
27
  for (var _len = arguments.length, args = new Array(_len), _key = 0; _key < _len; _key++) {
44
28
  args[_key] = arguments[_key];
45
29
  }
46
-
47
30
  _this = _super.call.apply(_super, [this].concat(args));
48
31
  (0, _defineProperty2.default)((0, _assertThisInitialized2.default)(_this), "state", {
49
32
  tooltipIsOpen: false
@@ -55,7 +38,6 @@ var Tooltip = /*#__PURE__*/function (_React$Component) {
55
38
  });
56
39
  return _this;
57
40
  }
58
-
59
41
  (0, _createClass2.default)(Tooltip, [{
60
42
  key: "render",
61
43
  value: function render() {
@@ -75,5 +57,4 @@ var Tooltip = /*#__PURE__*/function (_React$Component) {
75
57
  }]);
76
58
  return Tooltip;
77
59
  }(_react.default.Component);
78
-
79
60
  exports.Tooltip = Tooltip;