@pautena/react-design-system 0.0.1

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 (409) hide show
  1. package/.eslintrc.js +26 -0
  2. package/.github/workflows/ci.yml +23 -0
  3. package/.github/workflows/deploy-storybook.yaml +23 -0
  4. package/.github/workflows/publish.yml +31 -0
  5. package/.husky/pre-commit +5 -0
  6. package/.prettierignore +4 -0
  7. package/.prettierrc.js +5 -0
  8. package/.storybook/main.js +10 -0
  9. package/.storybook/preview.js +36 -0
  10. package/README.md +7 -0
  11. package/babel.config.js +3 -0
  12. package/dist/cjs/index.js +278 -0
  13. package/dist/cjs/index.js.map +1 -0
  14. package/dist/cjs/types/components/app-bar/app-bar.d.ts +2 -0
  15. package/dist/cjs/types/components/app-bar/app-bar.types.d.ts +13 -0
  16. package/dist/cjs/types/components/app-bar/index.d.ts +3 -0
  17. package/dist/cjs/types/components/app-bar/mini-app-bar/index.d.ts +1 -0
  18. package/dist/cjs/types/components/app-bar/mini-app-bar/mini-app-bar.d.ts +2 -0
  19. package/dist/cjs/types/components/bullet/bullet.d.ts +14 -0
  20. package/dist/cjs/types/components/bullet/index.d.ts +1 -0
  21. package/dist/cjs/types/components/center-container/center-container.d.ts +9 -0
  22. package/dist/cjs/types/components/center-container/index.d.ts +1 -0
  23. package/dist/cjs/types/components/drawer/drawer.context.d.ts +9 -0
  24. package/dist/cjs/types/components/drawer/drawer.d.ts +2 -0
  25. package/dist/cjs/types/components/drawer/drawer.mixins.d.ts +4 -0
  26. package/dist/cjs/types/components/drawer/drawer.mock.d.ts +3 -0
  27. package/dist/cjs/types/components/drawer/drawer.provider.d.ts +6 -0
  28. package/dist/cjs/types/components/drawer/drawer.types.d.ts +44 -0
  29. package/dist/cjs/types/components/drawer/index.d.ts +5 -0
  30. package/dist/cjs/types/components/drawer/mini-drawer/index.d.ts +1 -0
  31. package/dist/cjs/types/components/drawer/mini-drawer/mini-drawer.d.ts +1 -0
  32. package/dist/cjs/types/components/drawer-content/drawer-content.d.ts +5 -0
  33. package/dist/cjs/types/components/drawer-content/index.d.ts +1 -0
  34. package/dist/cjs/types/components/drawer-item/drawer-item.d.ts +33 -0
  35. package/dist/cjs/types/components/drawer-item/index.d.ts +1 -0
  36. package/dist/cjs/types/components/drawer-section/drawer-section.d.ts +16 -0
  37. package/dist/cjs/types/components/drawer-section/drawer-section.mock.d.ts +2 -0
  38. package/dist/cjs/types/components/drawer-section/index.d.ts +1 -0
  39. package/dist/cjs/types/components/header/header.d.ts +65 -0
  40. package/dist/cjs/types/components/header/header.dummy.d.ts +4 -0
  41. package/dist/cjs/types/components/header/index.d.ts +1 -0
  42. package/dist/cjs/types/components/index.d.ts +17 -0
  43. package/dist/cjs/types/components/label/index.d.ts +1 -0
  44. package/dist/cjs/types/components/label/label.d.ts +18 -0
  45. package/dist/cjs/types/components/link/index.d.ts +1 -0
  46. package/dist/cjs/types/components/link/link.d.ts +7 -0
  47. package/dist/cjs/types/components/loading-area/index.d.ts +1 -0
  48. package/dist/cjs/types/components/loading-area/loading-area.d.ts +4 -0
  49. package/dist/cjs/types/components/placeholder/index.d.ts +1 -0
  50. package/dist/cjs/types/components/placeholder/placeholder.d.ts +21 -0
  51. package/dist/cjs/types/components/placeholder/placeholder.mock.d.ts +2 -0
  52. package/dist/cjs/types/components/query-container/index.d.ts +1 -0
  53. package/dist/cjs/types/components/query-container/query-container.d.ts +39 -0
  54. package/dist/cjs/types/components/sign-in/index.d.ts +1 -0
  55. package/dist/cjs/types/components/sign-in/sign-in.d.ts +9 -0
  56. package/dist/cjs/types/components/tab/index.d.ts +3 -0
  57. package/dist/cjs/types/components/tab/tab-card/index.d.ts +1 -0
  58. package/dist/cjs/types/components/tab/tab-card/tab-card.d.ts +7 -0
  59. package/dist/cjs/types/components/tab/tab-card/tab-card.dummy.d.ts +7 -0
  60. package/dist/cjs/types/components/tab/tab-panel/index.d.ts +1 -0
  61. package/dist/cjs/types/components/tab/tab-panel/tab-panel.d.ts +7 -0
  62. package/dist/cjs/types/components/tab/tab.context.d.ts +4 -0
  63. package/dist/cjs/types/components/table/enhanced-remote-table/enhanced-remote-table.d.ts +13 -0
  64. package/dist/cjs/types/components/table/enhanced-remote-table/enhanced-remote-table.mock.d.ts +11 -0
  65. package/dist/cjs/types/components/table/enhanced-remote-table/index.d.ts +1 -0
  66. package/dist/cjs/types/components/table/enhanced-table/enhanced-table-head.d.ts +16 -0
  67. package/dist/cjs/types/components/table/enhanced-table/enhanced-table.d.ts +18 -0
  68. package/dist/cjs/types/components/table/enhanced-table/enhanced-table.mock.d.ts +17 -0
  69. package/dist/cjs/types/components/table/enhanced-table/index.d.ts +2 -0
  70. package/dist/cjs/types/components/table/index.d.ts +2 -0
  71. package/dist/cjs/types/components/table-list/index.d.ts +1 -0
  72. package/dist/cjs/types/components/table-list/table-list.d.ts +21 -0
  73. package/dist/cjs/types/components/value-displays/group-value-card/group-value-card.d.ts +15 -0
  74. package/dist/cjs/types/components/value-displays/group-value-card/group-value-card.mock.d.ts +1 -0
  75. package/dist/cjs/types/components/value-displays/group-value-card/index.d.ts +1 -0
  76. package/dist/cjs/types/components/value-displays/index.d.ts +4 -0
  77. package/dist/cjs/types/components/value-displays/value-boolean/index.d.ts +1 -0
  78. package/dist/cjs/types/components/value-displays/value-boolean/value-boolean.d.ts +14 -0
  79. package/dist/cjs/types/components/value-displays/value-card/index.d.ts +1 -0
  80. package/dist/cjs/types/components/value-displays/value-card/value-card.d.ts +6 -0
  81. package/dist/cjs/types/components/value-displays/value-text/index.d.ts +1 -0
  82. package/dist/cjs/types/components/value-displays/value-text/value-text.d.ts +14 -0
  83. package/dist/cjs/types/generators/generators.mock.d.ts +3 -0
  84. package/dist/cjs/types/generators/generators.model.d.ts +33 -0
  85. package/dist/cjs/types/generators/index.d.ts +4 -0
  86. package/dist/cjs/types/generators/model-form/index.d.ts +1 -0
  87. package/dist/cjs/types/generators/model-form/model-form.d.ts +8 -0
  88. package/dist/cjs/types/generators/model-router/index.d.ts +1 -0
  89. package/dist/cjs/types/generators/model-router/model-router.d.ts +35 -0
  90. package/dist/cjs/types/generators/model-router/screens/add-screen.d.ts +2 -0
  91. package/dist/cjs/types/generators/model-router/screens/details-screen.d.ts +2 -0
  92. package/dist/cjs/types/generators/model-router/screens/index.d.ts +4 -0
  93. package/dist/cjs/types/generators/model-router/screens/list-screen.d.ts +2 -0
  94. package/dist/cjs/types/generators/model-router/screens/update-screen.d.ts +2 -0
  95. package/dist/cjs/types/generators/object-details/index.d.ts +1 -0
  96. package/dist/cjs/types/generators/object-details/object-details.d.ts +6 -0
  97. package/dist/cjs/types/index.d.ts +4 -0
  98. package/dist/cjs/types/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.d.ts +10 -0
  99. package/dist/cjs/types/layouts/app-bar-with-drawer-layout/index.d.ts +1 -0
  100. package/dist/cjs/types/layouts/data-table-layout/data-table-layout.d.ts +12 -0
  101. package/dist/cjs/types/layouts/data-table-layout/index.d.ts +1 -0
  102. package/dist/cjs/types/layouts/details-layout/details-layout.d.ts +12 -0
  103. package/dist/cjs/types/layouts/details-layout/index.d.ts +1 -0
  104. package/dist/cjs/types/layouts/form-layout/form-layout.d.ts +8 -0
  105. package/dist/cjs/types/layouts/form-layout/index.d.ts +1 -0
  106. package/dist/cjs/types/layouts/header-layout/header-layout.d.ts +8 -0
  107. package/dist/cjs/types/layouts/header-layout/index.d.ts +1 -0
  108. package/dist/cjs/types/layouts/index.d.ts +7 -0
  109. package/dist/cjs/types/layouts/list-layout/index.d.ts +1 -0
  110. package/dist/cjs/types/layouts/list-layout/list-layout.d.ts +8 -0
  111. package/dist/cjs/types/layouts/tab-layout/index.d.ts +1 -0
  112. package/dist/cjs/types/layouts/tab-layout/tab-layout.d.ts +7 -0
  113. package/dist/cjs/types/providers/index.d.ts +1 -0
  114. package/dist/cjs/types/providers/notification-center/index.d.ts +1 -0
  115. package/dist/cjs/types/providers/notification-center/notification-center.context.d.ts +16 -0
  116. package/dist/cjs/types/providers/notification-center/notification-center.provider.d.ts +5 -0
  117. package/dist/cjs/types/utils/arrays.d.ts +5 -0
  118. package/dist/cjs/types/utils/arrays.test.d.ts +1 -0
  119. package/dist/cjs/types/utils/index.d.ts +2 -0
  120. package/dist/cjs/types/utils/theme.d.ts +4 -0
  121. package/dist/esm/index.js +278 -0
  122. package/dist/esm/index.js.map +1 -0
  123. package/dist/esm/types/components/app-bar/app-bar.d.ts +2 -0
  124. package/dist/esm/types/components/app-bar/app-bar.types.d.ts +13 -0
  125. package/dist/esm/types/components/app-bar/index.d.ts +3 -0
  126. package/dist/esm/types/components/app-bar/mini-app-bar/index.d.ts +1 -0
  127. package/dist/esm/types/components/app-bar/mini-app-bar/mini-app-bar.d.ts +2 -0
  128. package/dist/esm/types/components/bullet/bullet.d.ts +14 -0
  129. package/dist/esm/types/components/bullet/index.d.ts +1 -0
  130. package/dist/esm/types/components/center-container/center-container.d.ts +9 -0
  131. package/dist/esm/types/components/center-container/index.d.ts +1 -0
  132. package/dist/esm/types/components/drawer/drawer.context.d.ts +9 -0
  133. package/dist/esm/types/components/drawer/drawer.d.ts +2 -0
  134. package/dist/esm/types/components/drawer/drawer.mixins.d.ts +4 -0
  135. package/dist/esm/types/components/drawer/drawer.mock.d.ts +3 -0
  136. package/dist/esm/types/components/drawer/drawer.provider.d.ts +6 -0
  137. package/dist/esm/types/components/drawer/drawer.types.d.ts +44 -0
  138. package/dist/esm/types/components/drawer/index.d.ts +5 -0
  139. package/dist/esm/types/components/drawer/mini-drawer/index.d.ts +1 -0
  140. package/dist/esm/types/components/drawer/mini-drawer/mini-drawer.d.ts +1 -0
  141. package/dist/esm/types/components/drawer-content/drawer-content.d.ts +5 -0
  142. package/dist/esm/types/components/drawer-content/index.d.ts +1 -0
  143. package/dist/esm/types/components/drawer-item/drawer-item.d.ts +33 -0
  144. package/dist/esm/types/components/drawer-item/index.d.ts +1 -0
  145. package/dist/esm/types/components/drawer-section/drawer-section.d.ts +16 -0
  146. package/dist/esm/types/components/drawer-section/drawer-section.mock.d.ts +2 -0
  147. package/dist/esm/types/components/drawer-section/index.d.ts +1 -0
  148. package/dist/esm/types/components/header/header.d.ts +65 -0
  149. package/dist/esm/types/components/header/header.dummy.d.ts +4 -0
  150. package/dist/esm/types/components/header/index.d.ts +1 -0
  151. package/dist/esm/types/components/index.d.ts +17 -0
  152. package/dist/esm/types/components/label/index.d.ts +1 -0
  153. package/dist/esm/types/components/label/label.d.ts +18 -0
  154. package/dist/esm/types/components/link/index.d.ts +1 -0
  155. package/dist/esm/types/components/link/link.d.ts +7 -0
  156. package/dist/esm/types/components/loading-area/index.d.ts +1 -0
  157. package/dist/esm/types/components/loading-area/loading-area.d.ts +4 -0
  158. package/dist/esm/types/components/placeholder/index.d.ts +1 -0
  159. package/dist/esm/types/components/placeholder/placeholder.d.ts +21 -0
  160. package/dist/esm/types/components/placeholder/placeholder.mock.d.ts +2 -0
  161. package/dist/esm/types/components/query-container/index.d.ts +1 -0
  162. package/dist/esm/types/components/query-container/query-container.d.ts +39 -0
  163. package/dist/esm/types/components/sign-in/index.d.ts +1 -0
  164. package/dist/esm/types/components/sign-in/sign-in.d.ts +9 -0
  165. package/dist/esm/types/components/tab/index.d.ts +3 -0
  166. package/dist/esm/types/components/tab/tab-card/index.d.ts +1 -0
  167. package/dist/esm/types/components/tab/tab-card/tab-card.d.ts +7 -0
  168. package/dist/esm/types/components/tab/tab-card/tab-card.dummy.d.ts +7 -0
  169. package/dist/esm/types/components/tab/tab-panel/index.d.ts +1 -0
  170. package/dist/esm/types/components/tab/tab-panel/tab-panel.d.ts +7 -0
  171. package/dist/esm/types/components/tab/tab.context.d.ts +4 -0
  172. package/dist/esm/types/components/table/enhanced-remote-table/enhanced-remote-table.d.ts +13 -0
  173. package/dist/esm/types/components/table/enhanced-remote-table/enhanced-remote-table.mock.d.ts +11 -0
  174. package/dist/esm/types/components/table/enhanced-remote-table/index.d.ts +1 -0
  175. package/dist/esm/types/components/table/enhanced-table/enhanced-table-head.d.ts +16 -0
  176. package/dist/esm/types/components/table/enhanced-table/enhanced-table.d.ts +18 -0
  177. package/dist/esm/types/components/table/enhanced-table/enhanced-table.mock.d.ts +17 -0
  178. package/dist/esm/types/components/table/enhanced-table/index.d.ts +2 -0
  179. package/dist/esm/types/components/table/index.d.ts +2 -0
  180. package/dist/esm/types/components/table-list/index.d.ts +1 -0
  181. package/dist/esm/types/components/table-list/table-list.d.ts +21 -0
  182. package/dist/esm/types/components/value-displays/group-value-card/group-value-card.d.ts +15 -0
  183. package/dist/esm/types/components/value-displays/group-value-card/group-value-card.mock.d.ts +1 -0
  184. package/dist/esm/types/components/value-displays/group-value-card/index.d.ts +1 -0
  185. package/dist/esm/types/components/value-displays/index.d.ts +4 -0
  186. package/dist/esm/types/components/value-displays/value-boolean/index.d.ts +1 -0
  187. package/dist/esm/types/components/value-displays/value-boolean/value-boolean.d.ts +14 -0
  188. package/dist/esm/types/components/value-displays/value-card/index.d.ts +1 -0
  189. package/dist/esm/types/components/value-displays/value-card/value-card.d.ts +6 -0
  190. package/dist/esm/types/components/value-displays/value-text/index.d.ts +1 -0
  191. package/dist/esm/types/components/value-displays/value-text/value-text.d.ts +14 -0
  192. package/dist/esm/types/generators/generators.mock.d.ts +3 -0
  193. package/dist/esm/types/generators/generators.model.d.ts +33 -0
  194. package/dist/esm/types/generators/index.d.ts +4 -0
  195. package/dist/esm/types/generators/model-form/index.d.ts +1 -0
  196. package/dist/esm/types/generators/model-form/model-form.d.ts +8 -0
  197. package/dist/esm/types/generators/model-router/index.d.ts +1 -0
  198. package/dist/esm/types/generators/model-router/model-router.d.ts +35 -0
  199. package/dist/esm/types/generators/model-router/screens/add-screen.d.ts +2 -0
  200. package/dist/esm/types/generators/model-router/screens/details-screen.d.ts +2 -0
  201. package/dist/esm/types/generators/model-router/screens/index.d.ts +4 -0
  202. package/dist/esm/types/generators/model-router/screens/list-screen.d.ts +2 -0
  203. package/dist/esm/types/generators/model-router/screens/update-screen.d.ts +2 -0
  204. package/dist/esm/types/generators/object-details/index.d.ts +1 -0
  205. package/dist/esm/types/generators/object-details/object-details.d.ts +6 -0
  206. package/dist/esm/types/index.d.ts +4 -0
  207. package/dist/esm/types/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.d.ts +10 -0
  208. package/dist/esm/types/layouts/app-bar-with-drawer-layout/index.d.ts +1 -0
  209. package/dist/esm/types/layouts/data-table-layout/data-table-layout.d.ts +12 -0
  210. package/dist/esm/types/layouts/data-table-layout/index.d.ts +1 -0
  211. package/dist/esm/types/layouts/details-layout/details-layout.d.ts +12 -0
  212. package/dist/esm/types/layouts/details-layout/index.d.ts +1 -0
  213. package/dist/esm/types/layouts/form-layout/form-layout.d.ts +8 -0
  214. package/dist/esm/types/layouts/form-layout/index.d.ts +1 -0
  215. package/dist/esm/types/layouts/header-layout/header-layout.d.ts +8 -0
  216. package/dist/esm/types/layouts/header-layout/index.d.ts +1 -0
  217. package/dist/esm/types/layouts/index.d.ts +7 -0
  218. package/dist/esm/types/layouts/list-layout/index.d.ts +1 -0
  219. package/dist/esm/types/layouts/list-layout/list-layout.d.ts +8 -0
  220. package/dist/esm/types/layouts/tab-layout/index.d.ts +1 -0
  221. package/dist/esm/types/layouts/tab-layout/tab-layout.d.ts +7 -0
  222. package/dist/esm/types/providers/index.d.ts +1 -0
  223. package/dist/esm/types/providers/notification-center/index.d.ts +1 -0
  224. package/dist/esm/types/providers/notification-center/notification-center.context.d.ts +16 -0
  225. package/dist/esm/types/providers/notification-center/notification-center.provider.d.ts +5 -0
  226. package/dist/esm/types/utils/arrays.d.ts +5 -0
  227. package/dist/esm/types/utils/arrays.test.d.ts +1 -0
  228. package/dist/esm/types/utils/index.d.ts +2 -0
  229. package/dist/esm/types/utils/theme.d.ts +4 -0
  230. package/dist/index.d.ts +594 -0
  231. package/jest.config.js +14 -0
  232. package/jest.setup.ts +5 -0
  233. package/package.json +98 -0
  234. package/rollup.config.js +40 -0
  235. package/src/components/app-bar/app-bar.stories.tsx +54 -0
  236. package/src/components/app-bar/app-bar.test.tsx +142 -0
  237. package/src/components/app-bar/app-bar.tsx +150 -0
  238. package/src/components/app-bar/app-bar.types.ts +16 -0
  239. package/src/components/app-bar/index.ts +3 -0
  240. package/src/components/app-bar/mini-app-bar/index.ts +1 -0
  241. package/src/components/app-bar/mini-app-bar/mini-app-bar.tsx +31 -0
  242. package/src/components/bullet/bullet.stories.tsx +43 -0
  243. package/src/components/bullet/bullet.test.tsx +24 -0
  244. package/src/components/bullet/bullet.tsx +30 -0
  245. package/src/components/bullet/index.ts +1 -0
  246. package/src/components/center-container/center-container.stories.tsx +50 -0
  247. package/src/components/center-container/center-container.test.tsx +16 -0
  248. package/src/components/center-container/center-container.tsx +32 -0
  249. package/src/components/center-container/index.ts +1 -0
  250. package/src/components/drawer/__snapshots__/drawer.test.tsx.snap +20 -0
  251. package/src/components/drawer/drawer.context.ts +20 -0
  252. package/src/components/drawer/drawer.mixins.ts +24 -0
  253. package/src/components/drawer/drawer.mock.tsx +100 -0
  254. package/src/components/drawer/drawer.provider.tsx +23 -0
  255. package/src/components/drawer/drawer.test.tsx +97 -0
  256. package/src/components/drawer/drawer.tsx +30 -0
  257. package/src/components/drawer/drawer.types.ts +53 -0
  258. package/src/components/drawer/index.ts +5 -0
  259. package/src/components/drawer/mini-drawer/index.ts +1 -0
  260. package/src/components/drawer/mini-drawer/mini-drawer.stories.tsx +34 -0
  261. package/src/components/drawer/mini-drawer/mini-drawer.tsx +67 -0
  262. package/src/components/drawer-content/drawer-content.stories.tsx +29 -0
  263. package/src/components/drawer-content/drawer-content.test.tsx +34 -0
  264. package/src/components/drawer-content/drawer-content.tsx +18 -0
  265. package/src/components/drawer-content/index.ts +1 -0
  266. package/src/components/drawer-item/drawer-item.stories.tsx +62 -0
  267. package/src/components/drawer-item/drawer-item.test.tsx +119 -0
  268. package/src/components/drawer-item/drawer-item.tsx +69 -0
  269. package/src/components/drawer-item/index.ts +1 -0
  270. package/src/components/drawer-section/drawer-section.mock.tsx +39 -0
  271. package/src/components/drawer-section/drawer-section.stories.tsx +28 -0
  272. package/src/components/drawer-section/drawer-section.test.tsx +44 -0
  273. package/src/components/drawer-section/drawer-section.tsx +40 -0
  274. package/src/components/drawer-section/index.ts +1 -0
  275. package/src/components/header/header.dummy.ts +55 -0
  276. package/src/components/header/header.stories.tsx +116 -0
  277. package/src/components/header/header.test.tsx +167 -0
  278. package/src/components/header/header.tsx +185 -0
  279. package/src/components/header/index.ts +1 -0
  280. package/src/components/index.ts +17 -0
  281. package/src/components/label/index.ts +1 -0
  282. package/src/components/label/label.stories.tsx +49 -0
  283. package/src/components/label/label.test.tsx +30 -0
  284. package/src/components/label/label.tsx +60 -0
  285. package/src/components/link/index.ts +1 -0
  286. package/src/components/link/link.tsx +17 -0
  287. package/src/components/loading-area/index.ts +1 -0
  288. package/src/components/loading-area/loading-area.stories.tsx +17 -0
  289. package/src/components/loading-area/loading-area.test.tsx +11 -0
  290. package/src/components/loading-area/loading-area.tsx +13 -0
  291. package/src/components/placeholder/index.ts +1 -0
  292. package/src/components/placeholder/placeholder.mock.ts +15 -0
  293. package/src/components/placeholder/placeholder.stories.tsx +44 -0
  294. package/src/components/placeholder/placeholder.test.tsx +76 -0
  295. package/src/components/placeholder/placeholder.tsx +75 -0
  296. package/src/components/query-container/index.ts +1 -0
  297. package/src/components/query-container/query-container.stories.tsx +68 -0
  298. package/src/components/query-container/query-container.test.tsx +95 -0
  299. package/src/components/query-container/query-container.tsx +71 -0
  300. package/src/components/sign-in/index.ts +1 -0
  301. package/src/components/sign-in/sign-in.stories.tsx +36 -0
  302. package/src/components/sign-in/sign-in.test.tsx +95 -0
  303. package/src/components/sign-in/sign-in.tsx +97 -0
  304. package/src/components/tab/index.ts +3 -0
  305. package/src/components/tab/tab-card/index.ts +1 -0
  306. package/src/components/tab/tab-card/tab-card.dummy.tsx +27 -0
  307. package/src/components/tab/tab-card/tab-card.stories.tsx +22 -0
  308. package/src/components/tab/tab-card/tab-card.test.tsx +53 -0
  309. package/src/components/tab/tab-card/tab-card.tsx +30 -0
  310. package/src/components/tab/tab-panel/index.ts +1 -0
  311. package/src/components/tab/tab-panel/tab-panel.test.tsx +26 -0
  312. package/src/components/tab/tab-panel/tab-panel.tsx +27 -0
  313. package/src/components/tab/tab.context.ts +5 -0
  314. package/src/components/table/enhanced-remote-table/enhanced-remote-table.mock.tsx +27 -0
  315. package/src/components/table/enhanced-remote-table/enhanced-remote-table.stories.tsx +24 -0
  316. package/src/components/table/enhanced-remote-table/enhanced-remote-table.test.tsx +77 -0
  317. package/src/components/table/enhanced-remote-table/enhanced-remote-table.tsx +74 -0
  318. package/src/components/table/enhanced-remote-table/index.ts +1 -0
  319. package/src/components/table/enhanced-table/enhanced-table-head.tsx +58 -0
  320. package/src/components/table/enhanced-table/enhanced-table.mock.tsx +93 -0
  321. package/src/components/table/enhanced-table/enhanced-table.stories.tsx +21 -0
  322. package/src/components/table/enhanced-table/enhanced-table.test.tsx +107 -0
  323. package/src/components/table/enhanced-table/enhanced-table.tsx +136 -0
  324. package/src/components/table/enhanced-table/index.ts +2 -0
  325. package/src/components/table/index.ts +2 -0
  326. package/src/components/table-list/index.ts +1 -0
  327. package/src/components/table-list/table-list.stories.tsx +75 -0
  328. package/src/components/table-list/table-list.test.tsx +283 -0
  329. package/src/components/table-list/table-list.tsx +131 -0
  330. package/src/components/value-displays/group-value-card/group-value-card.mock.tsx +35 -0
  331. package/src/components/value-displays/group-value-card/group-value-card.stories.tsx +26 -0
  332. package/src/components/value-displays/group-value-card/group-value-card.test.tsx +58 -0
  333. package/src/components/value-displays/group-value-card/group-value-card.tsx +65 -0
  334. package/src/components/value-displays/group-value-card/index.ts +1 -0
  335. package/src/components/value-displays/index.ts +4 -0
  336. package/src/components/value-displays/value-boolean/index.ts +1 -0
  337. package/src/components/value-displays/value-boolean/value-boolean.stories.tsx +25 -0
  338. package/src/components/value-displays/value-boolean/value-boolean.test.tsx +27 -0
  339. package/src/components/value-displays/value-boolean/value-boolean.tsx +33 -0
  340. package/src/components/value-displays/value-card/index.ts +1 -0
  341. package/src/components/value-displays/value-card/value-card.stories.tsx +22 -0
  342. package/src/components/value-displays/value-card/value-card.test.tsx +18 -0
  343. package/src/components/value-displays/value-card/value-card.tsx +12 -0
  344. package/src/components/value-displays/value-text/index.ts +1 -0
  345. package/src/components/value-displays/value-text/value-test.test.tsx +21 -0
  346. package/src/components/value-displays/value-text/value-text.stories.tsx +26 -0
  347. package/src/components/value-displays/value-text/value-text.tsx +32 -0
  348. package/src/generators/generators.mock.ts +215 -0
  349. package/src/generators/generators.model.ts +41 -0
  350. package/src/generators/index.ts +4 -0
  351. package/src/generators/model-form/index.ts +1 -0
  352. package/src/generators/model-form/model-form.stories.tsx +30 -0
  353. package/src/generators/model-form/model-form.test.tsx +98 -0
  354. package/src/generators/model-form/model-form.tsx +97 -0
  355. package/src/generators/model-router/index.ts +1 -0
  356. package/src/generators/model-router/model-router.stories.tsx +160 -0
  357. package/src/generators/model-router/model-router.test.tsx +633 -0
  358. package/src/generators/model-router/model-router.tsx +54 -0
  359. package/src/generators/model-router/screens/add-screen.tsx +52 -0
  360. package/src/generators/model-router/screens/details-screen.tsx +53 -0
  361. package/src/generators/model-router/screens/index.ts +4 -0
  362. package/src/generators/model-router/screens/list-screen.tsx +81 -0
  363. package/src/generators/model-router/screens/update-screen.tsx +62 -0
  364. package/src/generators/object-details/index.ts +1 -0
  365. package/src/generators/object-details/object-details.stories.tsx +20 -0
  366. package/src/generators/object-details/object-details.test.tsx +21 -0
  367. package/src/generators/object-details/object-details.tsx +70 -0
  368. package/src/index.ts +4 -0
  369. package/src/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.stories.tsx +29 -0
  370. package/src/layouts/app-bar-with-drawer-layout/app-bar-with-drawer-layout.tsx +34 -0
  371. package/src/layouts/app-bar-with-drawer-layout/index.ts +1 -0
  372. package/src/layouts/data-table-layout/data-table-layout.stories.tsx +94 -0
  373. package/src/layouts/data-table-layout/data-table-layout.tsx +30 -0
  374. package/src/layouts/data-table-layout/index.ts +1 -0
  375. package/src/layouts/details-layout/details-layout.stories.tsx +81 -0
  376. package/src/layouts/details-layout/details-layout.tsx +33 -0
  377. package/src/layouts/details-layout/index.ts +1 -0
  378. package/src/layouts/form-layout/form-layout.stories.tsx +65 -0
  379. package/src/layouts/form-layout/form-layout.tsx +18 -0
  380. package/src/layouts/form-layout/index.ts +1 -0
  381. package/src/layouts/header-layout/header-layout.stories.tsx +68 -0
  382. package/src/layouts/header-layout/header-layout.tsx +24 -0
  383. package/src/layouts/header-layout/index.ts +1 -0
  384. package/src/layouts/index.ts +7 -0
  385. package/src/layouts/list-layout/index.ts +1 -0
  386. package/src/layouts/list-layout/list-layout.stories.tsx +102 -0
  387. package/src/layouts/list-layout/list-layout.tsx +36 -0
  388. package/src/layouts/tab-layout/index.ts +1 -0
  389. package/src/layouts/tab-layout/tab-layout.stories.tsx +88 -0
  390. package/src/layouts/tab-layout/tab-layout.tsx +11 -0
  391. package/src/providers/index.ts +1 -0
  392. package/src/providers/notification-center/index.ts +1 -0
  393. package/src/providers/notification-center/notification-center.context.ts +37 -0
  394. package/src/providers/notification-center/notification-center.provider.tsx +51 -0
  395. package/src/providers/notification-center/notification-center.stories.tsx +52 -0
  396. package/src/providers/notification-center/notification-center.test.tsx +112 -0
  397. package/src/storybook.tsx +56 -0
  398. package/src/tests/assertions.ts +72 -0
  399. package/src/tests/components.tsx +60 -0
  400. package/src/tests/content-placeholder.stories.tsx +16 -0
  401. package/src/tests/index.ts +3 -0
  402. package/src/tests/skeleton-card.stories.tsx +18 -0
  403. package/src/tests/testing-library.tsx +65 -0
  404. package/src/utils/arrays.test.ts +9 -0
  405. package/src/utils/arrays.ts +7 -0
  406. package/src/utils/index.ts +2 -0
  407. package/src/utils/theme.ts +6 -0
  408. package/tsconfig.json +27 -0
  409. package/tsconfig.rollup.json +26 -0
@@ -0,0 +1,136 @@
1
+ /* eslint-disable @typescript-eslint/no-explicit-any */
2
+ import React from "react";
3
+ import { ReactNode, useState } from "react";
4
+ import {
5
+ Box,
6
+ TableContainer,
7
+ TextField,
8
+ TableBody,
9
+ InputAdornment,
10
+ Table,
11
+ CircularProgress,
12
+ TableCell,
13
+ TableRow,
14
+ } from "@mui/material";
15
+ import Search from "@mui/icons-material/Search";
16
+ import { EnhancedTableHead, HeadCell, Order } from "./enhanced-table-head";
17
+
18
+ function getFilter<T>(columns: HeadCell[], search: string) {
19
+ return (d: T) => {
20
+ return (
21
+ !search ||
22
+ columns.some((col) => {
23
+ let value = (d as any)[col.id];
24
+ if (value?.toLowerCase) {
25
+ value = value.toLowerCase();
26
+ }
27
+ return value?.toString().includes(search.toLowerCase());
28
+ })
29
+ );
30
+ };
31
+ }
32
+
33
+ function getComparator(order: Order, orderBy: any): (a: any, b: any) => number {
34
+ return order === "desc"
35
+ ? (a, b) => descendingComparator(a, b, orderBy)
36
+ : (a, b) => -descendingComparator(a, b, orderBy);
37
+ }
38
+ function descendingComparator<T>(a: T, b: T, orderBy: keyof T) {
39
+ if (b[orderBy] < a[orderBy]) {
40
+ return -1;
41
+ }
42
+ if (b[orderBy] > a[orderBy]) {
43
+ return 1;
44
+ }
45
+ return 0;
46
+ }
47
+
48
+ interface Props<T> {
49
+ readonly data: T[];
50
+ search?: boolean;
51
+ defaultSort: string;
52
+ defaultOrder?: Order;
53
+ loading?: boolean;
54
+ columns: HeadCell[];
55
+ children: (data: T[]) => ReactNode;
56
+ }
57
+
58
+ export const EnhancedTable = <T,>({
59
+ children,
60
+ data,
61
+ search,
62
+ columns,
63
+ defaultSort,
64
+ defaultOrder = "asc",
65
+ loading = false,
66
+ }: Props<T>) => {
67
+ const [searchFilter, setSearchFilter] = useState<string>("");
68
+ const [order, setOrder] = useState<Order>(defaultOrder);
69
+ const [orderBy, setOrderBy] = useState(defaultSort);
70
+
71
+ const handleRequestSort = (property: string) => {
72
+ const isAsc = orderBy === property && order === "asc";
73
+ setOrder(isAsc ? "desc" : "asc");
74
+ setOrderBy(property);
75
+ };
76
+
77
+ const filteredData = data
78
+ .slice()
79
+ .filter(getFilter<T>(columns, searchFilter))
80
+ .sort(getComparator(order, orderBy));
81
+
82
+ return (
83
+ <>
84
+ <Box sx={{ paddingX: 1, paddingBottom: 2 }}>
85
+ {search && (
86
+ <Box paddingY={2}>
87
+ <TextField
88
+ fullWidth
89
+ placeholder="Search"
90
+ InputProps={{
91
+ role: "search",
92
+ startAdornment: (
93
+ <InputAdornment position="start">
94
+ <Search />
95
+ </InputAdornment>
96
+ ),
97
+ }}
98
+ onChange={(e) => setSearchFilter(e.target.value)}
99
+ />
100
+ </Box>
101
+ )}
102
+ <TableContainer>
103
+ <Table>
104
+ <EnhancedTableHead
105
+ order={order}
106
+ orderBy={orderBy}
107
+ headCells={columns}
108
+ onRequestSort={handleRequestSort}
109
+ />
110
+ <TableBody>
111
+ {loading ? (
112
+ <TableRow>
113
+ <TableCell colSpan={columns.length} sx={{ textAlign: "center" }}>
114
+ <CircularProgress />
115
+ </TableCell>
116
+ </TableRow>
117
+ ) : filteredData.length === 0 ? (
118
+ <TableRow>
119
+ <TableCell colSpan={columns.length} sx={{ textAlign: "center" }}>
120
+ No data
121
+ </TableCell>
122
+ </TableRow>
123
+ ) : (
124
+ children(filteredData)
125
+ )}
126
+ </TableBody>
127
+ </Table>
128
+ </TableContainer>
129
+ </Box>
130
+ </>
131
+ );
132
+ };
133
+
134
+ EnhancedTable.defaultProps = {
135
+ defaultOrder: "asc",
136
+ };
@@ -0,0 +1,2 @@
1
+ export * from "./enhanced-table";
2
+ export * from "./enhanced-table-head";
@@ -0,0 +1,2 @@
1
+ export * from "./enhanced-table";
2
+ export * from "./enhanced-remote-table";
@@ -0,0 +1 @@
1
+ export * from "./table-list";
@@ -0,0 +1,75 @@
1
+ import React from "react";
2
+ import { useDemoData } from "@mui/x-data-grid-generator";
3
+ import { ComponentMeta } from "@storybook/react";
4
+ import { createTemplate } from "../../storybook";
5
+ import { TableList } from "./table-list";
6
+ import { action } from "@storybook/addon-actions";
7
+
8
+ const maxColumns = 3;
9
+
10
+ export default {
11
+ title: "Tables/TableList",
12
+ component: TableList,
13
+ parameters: {
14
+ layout: "fullscreen",
15
+ },
16
+ } as ComponentMeta<typeof TableList>;
17
+
18
+ const Template = createTemplate(({ dataSetType, size, ...rest }) => {
19
+ const { data } = useDemoData({
20
+ dataSet: dataSetType,
21
+ rowLength: size,
22
+ maxColumns,
23
+ });
24
+ const { rows } = data;
25
+ const columns = data.columns.map(({ field, headerName }) => ({
26
+ id: field,
27
+ label: headerName,
28
+ sort: true,
29
+ disablePadding: false,
30
+ numeric: false,
31
+ }));
32
+
33
+ return <TableList {...rest} columns={columns} data={rows} onClick={action("onClick row")} />;
34
+ });
35
+
36
+ export const Default = Template.bind({});
37
+ Default.args = {
38
+ size: 40,
39
+ dataSetType: "Commodity",
40
+ search: true,
41
+ };
42
+
43
+ export const Loading = Template.bind({});
44
+ Loading.args = {
45
+ size: 40,
46
+ dataSetType: "Commodity",
47
+ search: true,
48
+ loading: true,
49
+ };
50
+
51
+ export const WihtoutSearch = Template.bind({});
52
+ WihtoutSearch.args = {
53
+ size: 40,
54
+ dataSetType: "Commodity",
55
+ search: false,
56
+ };
57
+
58
+ export const WithOptions = Template.bind({});
59
+ WithOptions.args = {
60
+ size: 40,
61
+ dataSetType: "Commodity",
62
+ search: false,
63
+ options: [
64
+ {
65
+ id: "edit",
66
+ label: "Edit",
67
+ onClick: action("Option edit"),
68
+ },
69
+ {
70
+ id: "remove",
71
+ label: "Remove",
72
+ onClick: action("Option remove"),
73
+ },
74
+ ],
75
+ };
@@ -0,0 +1,283 @@
1
+ import React from "react";
2
+ import { expectProgressIndicator, render } from "../../tests";
3
+ import { screen } from "@testing-library/react";
4
+ import userEvents from "@testing-library/user-event";
5
+ import { BasicData, TableRowOption, TableList } from "./table-list";
6
+ import { HeadCell } from "../table/enhanced-table";
7
+
8
+ const columns: HeadCell[] = [
9
+ {
10
+ id: "id",
11
+ numeric: true,
12
+ disablePadding: false,
13
+ label: "Item ID",
14
+ sort: false,
15
+ },
16
+ {
17
+ id: "name",
18
+ numeric: false,
19
+ disablePadding: false,
20
+ label: "Name",
21
+ sort: true,
22
+ },
23
+ {
24
+ id: "value",
25
+ numeric: true,
26
+ disablePadding: false,
27
+ label: "Value",
28
+ sort: true,
29
+ },
30
+ ];
31
+ const data: BasicData[] = [
32
+ {
33
+ id: "item-c",
34
+ name: "fg Item 1",
35
+ value: 1,
36
+ },
37
+ {
38
+ id: "item-a",
39
+ name: "aa Item 2",
40
+ value: 2,
41
+ },
42
+ {
43
+ id: "item-l",
44
+ name: "ba Item 3",
45
+ value: 3,
46
+ },
47
+ {
48
+ id: "item-j",
49
+ name: "aa Item 4",
50
+ value: 4,
51
+ },
52
+ {
53
+ id: "item-w",
54
+ name: "cd Item 5",
55
+ value: 5,
56
+ },
57
+ ];
58
+
59
+ const options = [
60
+ {
61
+ id: "edit",
62
+ label: "Edit",
63
+ onClick: jest.fn(),
64
+ },
65
+ {
66
+ id: "remove",
67
+ label: "Remove",
68
+ onClick: jest.fn(),
69
+ },
70
+ ];
71
+
72
+ describe("TableList", () => {
73
+ const renderInstance = ({
74
+ search = false,
75
+ defaultSort = "value",
76
+ loading = false,
77
+ options = undefined,
78
+ }: {
79
+ defaultSort?: string;
80
+ loading?: boolean;
81
+ search?: boolean;
82
+ options?: TableRowOption<any>[];
83
+ } = {}) => {
84
+ const onClick = jest.fn();
85
+ const instance = render(
86
+ <TableList
87
+ search={search}
88
+ data={data}
89
+ columns={columns}
90
+ defaultSort={defaultSort}
91
+ defaultOrder="asc"
92
+ loading={loading}
93
+ options={options}
94
+ onClick={onClick}
95
+ />,
96
+ );
97
+
98
+ return { ...instance, onClick };
99
+ };
100
+
101
+ const openOptionsMenu = async (index = 0) => {
102
+ await userEvents.click(screen.getAllByTestId("MoreVertIcon")[index]);
103
+ };
104
+
105
+ it("would render all items and its values", () => {
106
+ renderInstance();
107
+
108
+ data.forEach(({ id, name, value }) => {
109
+ expect(screen.getByRole("cell", { name: id })).toBeInTheDocument();
110
+ expect(screen.getByRole("cell", { name: name })).toBeInTheDocument();
111
+ expect(screen.getByRole("cell", { name: value })).toBeInTheDocument();
112
+ });
113
+ });
114
+
115
+ it("all items are rendered in the correct default order", async () => {
116
+ renderInstance();
117
+
118
+ [/item 1/i, /item 2/i, /item 3/i, /item 4/i, /item 5/i].forEach((item, index) => {
119
+ expect(screen.getByRole("cell", { name: item })).toHaveAttribute(
120
+ "aria-rowindex",
121
+ index.toString(),
122
+ );
123
+ });
124
+ });
125
+
126
+ it("loading is true a loading indicator is displayed", () => {
127
+ renderInstance({ loading: true });
128
+
129
+ expectProgressIndicator();
130
+ });
131
+
132
+ describe("search", () => {
133
+ it("would render a search input if search is true", () => {
134
+ renderInstance({ search: true });
135
+
136
+ expect(screen.getByRole("search")).toBeInTheDocument();
137
+ });
138
+
139
+ it("wouldn't render a search input if search is false", () => {
140
+ renderInstance({ search: false });
141
+
142
+ expect(screen.queryByRole("search")).not.toBeInTheDocument();
143
+ });
144
+ });
145
+
146
+ describe("if I search an 'a'", () => {
147
+ it("would render the items 2,3 and 4", async () => {
148
+ renderInstance({ search: true });
149
+
150
+ await userEvents.type(screen.getByPlaceholderText(/search/i), "a");
151
+
152
+ expect(screen.getByText(/item 2/i)).toBeInTheDocument();
153
+ expect(screen.getByText(/item 3/i)).toBeInTheDocument();
154
+ expect(screen.getByText(/item 4/i)).toBeInTheDocument();
155
+
156
+ expect(screen.queryByText(/item 1/i)).not.toBeInTheDocument();
157
+ expect(screen.queryByText(/item 5/i)).not.toBeInTheDocument();
158
+ });
159
+
160
+ it("would render all the items if I remove the search", async () => {
161
+ renderInstance({ search: true });
162
+
163
+ const search = screen.getByPlaceholderText(/search/i);
164
+ await userEvents.type(search, "a");
165
+ await userEvents.clear(search);
166
+
167
+ expect(screen.getByText(/item 1/i)).toBeInTheDocument();
168
+ expect(screen.getByText(/item 2/i)).toBeInTheDocument();
169
+ expect(screen.getByText(/item 3/i)).toBeInTheDocument();
170
+ expect(screen.getByText(/item 4/i)).toBeInTheDocument();
171
+ expect(screen.getByText(/item 5/i)).toBeInTheDocument();
172
+ });
173
+ });
174
+
175
+ describe("sort by a sortable column", () => {
176
+ it("once it will be asc sorted", async () => {
177
+ renderInstance();
178
+
179
+ await userEvents.click(screen.getByText(/name/i));
180
+
181
+ expect(screen.getByRole("cell", { name: /item 2/i })).toHaveAttribute("aria-rowindex", "0");
182
+ expect(screen.getByRole("cell", { name: /item 4/i })).toHaveAttribute("aria-rowindex", "1");
183
+ expect(screen.getByRole("cell", { name: /item 3/i })).toHaveAttribute("aria-rowindex", "2");
184
+ expect(screen.getByRole("cell", { name: /item 5/i })).toHaveAttribute("aria-rowindex", "3");
185
+ expect(screen.getByRole("cell", { name: /item 1/i })).toHaveAttribute("aria-rowindex", "4");
186
+ });
187
+
188
+ it("two times it will be desc sorted", async () => {
189
+ renderInstance();
190
+
191
+ await userEvents.click(screen.getByText(/name/i));
192
+ await userEvents.click(screen.getByText(/name/i));
193
+
194
+ expect(screen.getByRole("cell", { name: /item 1/i })).toHaveAttribute("aria-rowindex", "0");
195
+ expect(screen.getByRole("cell", { name: /item 5/i })).toHaveAttribute("aria-rowindex", "1");
196
+ expect(screen.getByRole("cell", { name: /item 3/i })).toHaveAttribute("aria-rowindex", "2");
197
+ expect(screen.getByRole("cell", { name: /item 4/i })).toHaveAttribute("aria-rowindex", "3");
198
+ expect(screen.getByRole("cell", { name: /item 2/i })).toHaveAttribute("aria-rowindex", "4");
199
+ });
200
+ });
201
+
202
+ it("sort a non sortable column", async () => {
203
+ renderInstance();
204
+
205
+ await userEvents.click(screen.getByText(/id/i));
206
+
207
+ expect(screen.getByRole("cell", { name: /item 1/i })).toHaveAttribute("aria-rowindex", "0");
208
+ expect(screen.getByRole("cell", { name: /item 2/i })).toHaveAttribute("aria-rowindex", "1");
209
+ expect(screen.getByRole("cell", { name: /item 3/i })).toHaveAttribute("aria-rowindex", "2");
210
+ expect(screen.getByRole("cell", { name: /item 4/i })).toHaveAttribute("aria-rowindex", "3");
211
+ expect(screen.getByRole("cell", { name: /item 5/i })).toHaveAttribute("aria-rowindex", "4");
212
+ });
213
+
214
+ it("would call onClick if a row is clicked", async () => {
215
+ const { onClick } = renderInstance();
216
+
217
+ await userEvents.click(screen.getByRole("row", { name: /item 3/i }));
218
+
219
+ expect(onClick).toHaveBeenCalledTimes(1);
220
+ expect(onClick).toHaveBeenCalledWith(data[2]);
221
+ });
222
+
223
+ describe("options menu", () => {
224
+ it("would render a button to open the menu if doesn't have options", () => {
225
+ renderInstance({ options: undefined });
226
+
227
+ expect(screen.queryByTestId("MoreVertIcon")).not.toBeInTheDocument();
228
+ });
229
+
230
+ it("would render a button to open the menu if has options", () => {
231
+ renderInstance({ options });
232
+
233
+ screen.getAllByTestId("MoreVertIcon");
234
+ });
235
+
236
+ it("would render a menu if has options", async () => {
237
+ renderInstance({ options });
238
+
239
+ await openOptionsMenu();
240
+
241
+ expect(await screen.findByRole("menu")).toBeInTheDocument();
242
+ });
243
+
244
+ it.each([
245
+ [/edit/i, 0],
246
+ [/remove/i, 1],
247
+ ])("would call the option onClick with the row if %s option is clicked", async (name, i) => {
248
+ const index = 1;
249
+ const item = data[index];
250
+ const option = options[i];
251
+
252
+ renderInstance({ options });
253
+
254
+ await openOptionsMenu(index);
255
+
256
+ await userEvents.click(screen.getByRole("menuitem", { name }));
257
+
258
+ expect(option.onClick).toHaveBeenCalledTimes(1);
259
+ expect(option.onClick).toHaveBeenCalledWith(item);
260
+ });
261
+
262
+ it("would close the menu when an option is clicked", async () => {
263
+ const index = 1;
264
+
265
+ renderInstance({ options });
266
+
267
+ await openOptionsMenu(index);
268
+ await userEvents.click(screen.getByRole("menuitem", { name: /edit/i }));
269
+
270
+ expect(screen.queryByRole("menu")).not.toBeInTheDocument();
271
+ });
272
+
273
+ it("wouldn't call the component onClick if an option if clicked", async () => {
274
+ const { onClick } = renderInstance({ options });
275
+
276
+ await openOptionsMenu();
277
+
278
+ await userEvents.click(screen.getByRole("menuitem", { name: /edit/i }));
279
+
280
+ expect(onClick).not.toHaveBeenCalled();
281
+ });
282
+ });
283
+ });
@@ -0,0 +1,131 @@
1
+ import { TableRow, TableCell, IconButton, MenuItem, Menu } from "@mui/material";
2
+ import React from "react";
3
+ import { EnhancedTable, HeadCell, Order } from "../table/enhanced-table";
4
+ import MoreVertIcon from "@mui/icons-material/MoreVert";
5
+
6
+ const OptionsId = "__options";
7
+
8
+ export interface BasicData {
9
+ id: string;
10
+ [key: string]: any;
11
+ }
12
+
13
+ export interface TableRowOption<T extends BasicData> {
14
+ id: string;
15
+ label: string;
16
+ onClick: (item: T) => void;
17
+ }
18
+
19
+ export interface TableListProps<T extends BasicData> {
20
+ columns: HeadCell[];
21
+ data: T[];
22
+ search?: boolean;
23
+ defaultSort: string;
24
+ defaultOrder?: Order;
25
+ loading?: boolean;
26
+ options?: TableRowOption<T>[];
27
+ onClick?: (d: T) => void;
28
+ }
29
+
30
+ export const TableList = <T extends BasicData>({
31
+ columns: columnsProp,
32
+ options,
33
+ data,
34
+ onClick = () => null,
35
+ search,
36
+ defaultSort,
37
+ defaultOrder,
38
+ loading,
39
+ }: TableListProps<T>) => {
40
+ const columns = columnsProp;
41
+ const [anchorMenuEl, setAnchorMenuEl] = React.useState<null | { item: T; anchor: HTMLElement }>(
42
+ null,
43
+ );
44
+ if (options && !columns.some((c) => c.id === OptionsId)) {
45
+ columns.push({
46
+ id: OptionsId,
47
+ label: "",
48
+ disablePadding: false,
49
+ numeric: false,
50
+ sort: false,
51
+ });
52
+ }
53
+
54
+ return (
55
+ <>
56
+ <EnhancedTable<T>
57
+ columns={columns}
58
+ data={data}
59
+ search={search}
60
+ defaultSort={defaultSort}
61
+ defaultOrder={defaultOrder}
62
+ loading={loading}
63
+ >
64
+ {(filteredData) =>
65
+ filteredData.map((row, i) => {
66
+ return (
67
+ <TableRow
68
+ key={row.id}
69
+ onClick={() => onClick(row)}
70
+ role="row"
71
+ aria-rowindex={i}
72
+ sx={{ cursor: "pointer" }}
73
+ >
74
+ {columns.map(({ id }, j) => (
75
+ <TableCell role="cell" scope="row" key={id} aria-rowindex={i} aria-colindex={j}>
76
+ {row[id]}
77
+ </TableCell>
78
+ ))}
79
+ {options && (
80
+ <TableCell>
81
+ <IconButton
82
+ data-testid={`options-${row.id}`}
83
+ onClick={(event) => {
84
+ event.stopPropagation();
85
+ setAnchorMenuEl({
86
+ item: row,
87
+ anchor: event.currentTarget,
88
+ });
89
+ }}
90
+ >
91
+ <MoreVertIcon />
92
+ </IconButton>
93
+ </TableCell>
94
+ )}
95
+ </TableRow>
96
+ );
97
+ })
98
+ }
99
+ </EnhancedTable>
100
+ {options && (
101
+ <Menu
102
+ anchorEl={anchorMenuEl?.anchor}
103
+ open={!!anchorMenuEl}
104
+ onClose={() => setAnchorMenuEl(null)}
105
+ anchorOrigin={{
106
+ vertical: "top",
107
+ horizontal: "left",
108
+ }}
109
+ transformOrigin={{
110
+ vertical: "top",
111
+ horizontal: "left",
112
+ }}
113
+ >
114
+ {options.map(({ id, label, onClick }) => (
115
+ <MenuItem
116
+ key={id}
117
+ onClick={() => {
118
+ if (anchorMenuEl) {
119
+ onClick(anchorMenuEl?.item);
120
+ }
121
+ setAnchorMenuEl(null);
122
+ }}
123
+ >
124
+ {label}
125
+ </MenuItem>
126
+ ))}
127
+ </Menu>
128
+ )}
129
+ </>
130
+ );
131
+ };
@@ -0,0 +1,35 @@
1
+ import React from "react";
2
+ import { ValueBoolean } from "../value-boolean/value-boolean";
3
+ import { ValueText } from "../value-text";
4
+ import { GroupValueCard, GroupValueItem } from "./group-value-card";
5
+
6
+ export const GroupValueCardDummy = (props) => {
7
+ return (
8
+ <GroupValueCard {...props}>
9
+ <GroupValueItem xs={12} sm={6} md={4}>
10
+ <ValueText label="Hello world" value="Lorem ipsum sit amet" />
11
+ </GroupValueItem>
12
+ <GroupValueItem xs={12} sm={6} md={2}>
13
+ <ValueBoolean label="Enabled" value />
14
+ </GroupValueItem>
15
+ <GroupValueItem xs={12} sm={6} md={3}>
16
+ <ValueText label="Quantity" value="1200" />
17
+ </GroupValueItem>
18
+ <GroupValueItem xs={12} sm={6} md={3}>
19
+ <ValueText label="Currency" value="EUR" />
20
+ </GroupValueItem>
21
+ <GroupValueItem xs={12} sm={6} md={6}>
22
+ <ValueText
23
+ label="I am Batman"
24
+ value=" Does it come in black? It's ends here. Hero can be anyone"
25
+ />
26
+ </GroupValueItem>
27
+ <GroupValueItem xs={12} sm={6} md={3}>
28
+ <ValueText label="Status" value="Open" />
29
+ </GroupValueItem>
30
+ <GroupValueItem xs={12} sm={6} md={3}>
31
+ <ValueText label="Level" value="2144" />
32
+ </GroupValueItem>
33
+ </GroupValueCard>
34
+ );
35
+ };
@@ -0,0 +1,26 @@
1
+ import { ComponentMeta } from "@storybook/react";
2
+ import { GroupValueCard } from "./group-value-card";
3
+ import { createTemplate, withPadding } from "../../../storybook";
4
+ import { GroupValueCardDummy } from "./group-value-card.mock";
5
+
6
+ export default {
7
+ title: "Value displays/GroupValueCard",
8
+ component: GroupValueCard,
9
+ decorators: [withPadding(2)],
10
+ parameters: {
11
+ layout: "fullscreen",
12
+ },
13
+ } as ComponentMeta<typeof GroupValueCard>;
14
+
15
+ const Template = createTemplate(GroupValueCardDummy);
16
+
17
+ export const Default = Template.bind({});
18
+ Default.args = {
19
+ title: "Hello world",
20
+ subtitle: "Lorem ipsum sit amet",
21
+ };
22
+
23
+ export const WihtoutSubtitle = Template.bind({});
24
+ WihtoutSubtitle.args = {
25
+ title: "Hello world",
26
+ };