@dktunited-techoff/techoff-suite-ui 1.8.1 → 1.8.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (350) hide show
  1. package/esm/assets/fonts/Montserrat-Medium.ttf +0 -0
  2. package/esm/assets/fonts/Roboto-Light.ttf +0 -0
  3. package/esm/components/TsButton/TsButton.css +121 -0
  4. package/esm/components/TsButton/TsButton.d.ts +5 -0
  5. package/esm/components/TsButton/TsButton.js +17 -0
  6. package/esm/components/TsButton/TsButton.js.map +1 -0
  7. package/esm/components/TsButton/TsButton.types.d.ts +9 -0
  8. package/esm/components/TsButton/TsButton.types.js +2 -0
  9. package/esm/components/TsButton/TsButton.types.js.map +1 -0
  10. package/esm/components/TsButton/__stories__/TsButton.stories.mdx +84 -0
  11. package/esm/components/TsCheckbox/TsCheckbox.css +64 -0
  12. package/esm/components/TsCheckbox/TsCheckbox.d.ts +4 -0
  13. package/esm/components/TsCheckbox/TsCheckbox.js +17 -0
  14. package/esm/components/TsCheckbox/TsCheckbox.js.map +1 -0
  15. package/esm/components/TsCheckbox/TsCheckbox.types.d.ts +7 -0
  16. package/esm/components/TsCheckbox/TsCheckbox.types.js +2 -0
  17. package/esm/components/TsCheckbox/TsCheckbox.types.js.map +1 -0
  18. package/esm/components/TsCheckbox/__stories__/TsCheckbox.stories.mdx +56 -0
  19. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.css +114 -0
  20. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.d.ts +4 -0
  21. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.js +100 -0
  22. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.js.map +1 -0
  23. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.tsx +165 -0
  24. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.types.d.ts +17 -0
  25. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.types.js +2 -0
  26. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.types.js.map +1 -0
  27. package/esm/components/TsDropdowns/TsDropdown/TsDropdown.types.ts +18 -0
  28. package/esm/components/TsDropdowns/TsDropdown/__stories__/TsDropdown.stories.mdx +85 -0
  29. package/esm/components/TsDropdowns/TsDropdown/__stories__/fruits.d.ts +4 -0
  30. package/esm/components/TsDropdowns/TsDropdown/__stories__/fruits.js +48 -0
  31. package/esm/components/TsDropdowns/TsDropdown/__stories__/fruits.js.map +1 -0
  32. package/esm/components/TsDropdowns/TsDropdown/__stories__/fruits.ts +47 -0
  33. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.css +83 -0
  34. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.d.ts +4 -0
  35. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.js +62 -0
  36. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.js.map +1 -0
  37. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.tsx +105 -0
  38. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.d.ts +8 -0
  39. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.js +2 -0
  40. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.js.map +1 -0
  41. package/esm/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.ts +8 -0
  42. package/esm/components/TsDropdowns/TsDropdownFilter/__stories__/TsDropdown.stories.mdx +69 -0
  43. package/esm/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.d.ts +4 -0
  44. package/esm/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.js +48 -0
  45. package/esm/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.js.map +1 -0
  46. package/esm/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.ts +47 -0
  47. package/esm/components/TsIcon/TsIcon.css +26 -0
  48. package/esm/components/TsIcon/TsIcon.d.ts +4 -0
  49. package/esm/components/TsIcon/TsIcon.js +12 -0
  50. package/esm/components/TsIcon/TsIcon.js.map +1 -0
  51. package/esm/components/TsIcon/TsIcon.types.d.ts +4 -0
  52. package/esm/components/TsIcon/TsIcon.types.js +2 -0
  53. package/esm/components/TsIcon/TsIcon.types.js.map +1 -0
  54. package/esm/components/TsIcon/__stories__/TsIcon.stories.mdx +89 -0
  55. package/esm/components/TsIcon/icons/add-circle.svg +1 -0
  56. package/esm/components/TsIcon/icons/add.svg +1 -0
  57. package/esm/components/TsIcon/icons/alert-circle-filled.svg +1 -0
  58. package/esm/components/TsIcon/icons/alert-circle.svg +1 -0
  59. package/esm/components/TsIcon/icons/alert-triangle-filled.svg +1 -0
  60. package/esm/components/TsIcon/icons/alert-triangle.svg +1 -0
  61. package/esm/components/TsIcon/icons/arrow-diagonal-collapse.svg +1 -0
  62. package/esm/components/TsIcon/icons/arrow-diagonal-expand.svg +1 -0
  63. package/esm/components/TsIcon/icons/arrow-down.svg +1 -0
  64. package/esm/components/TsIcon/icons/arrow-go-back.svg +1 -0
  65. package/esm/components/TsIcon/icons/arrow-left-right.svg +1 -0
  66. package/esm/components/TsIcon/icons/arrow-left.svg +1 -0
  67. package/esm/components/TsIcon/icons/arrow-right.svg +1 -0
  68. package/esm/components/TsIcon/icons/arrow-up-down.svg +1 -0
  69. package/esm/components/TsIcon/icons/arrow-up.svg +1 -0
  70. package/esm/components/TsIcon/icons/award.svg +1 -0
  71. package/esm/components/TsIcon/icons/check-circle-filled.svg +1 -0
  72. package/esm/components/TsIcon/icons/check-circle-timer.svg +7 -0
  73. package/esm/components/TsIcon/icons/check-circle.svg +1 -0
  74. package/esm/components/TsIcon/icons/check-square-filled.svg +1 -0
  75. package/esm/components/TsIcon/icons/check-square.svg +1 -0
  76. package/esm/components/TsIcon/icons/check.svg +1 -0
  77. package/esm/components/TsIcon/icons/chevron-down.svg +1 -0
  78. package/esm/components/TsIcon/icons/chevron-left.svg +1 -0
  79. package/esm/components/TsIcon/icons/chevron-right.svg +1 -0
  80. package/esm/components/TsIcon/icons/chevron-up.svg +1 -0
  81. package/esm/components/TsIcon/icons/circle.svg +1 -0
  82. package/esm/components/TsIcon/icons/close-circle.svg +1 -0
  83. package/esm/components/TsIcon/icons/close.svg +1 -0
  84. package/esm/components/TsIcon/icons/currency-euro.svg +1 -0
  85. package/esm/components/TsIcon/icons/download.svg +1 -0
  86. package/esm/components/TsIcon/icons/edit.svg +1 -0
  87. package/esm/components/TsIcon/icons/external-link.svg +1 -0
  88. package/esm/components/TsIcon/icons/filter-off.svg +1 -0
  89. package/esm/components/TsIcon/icons/filter.svg +1 -0
  90. package/esm/components/TsIcon/icons/flashlight-off.svg +1 -0
  91. package/esm/components/TsIcon/icons/flashlight.svg +1 -0
  92. package/esm/components/TsIcon/icons/header-bikestudio.svg +32 -0
  93. package/esm/components/TsIcon/icons/header-nsc-helmet.svg +32 -0
  94. package/esm/components/TsIcon/icons/header-opticost.svg +32 -0
  95. package/esm/components/TsIcon/icons/header-repairability.svg +32 -0
  96. package/esm/components/TsIcon/icons/header-techoff-suite.svg +32 -0
  97. package/esm/components/TsIcon/icons/heart-filled.svg +1 -0
  98. package/esm/components/TsIcon/icons/heart.svg +1 -0
  99. package/esm/components/TsIcon/icons/history.svg +1 -0
  100. package/esm/components/TsIcon/icons/home.svg +1 -0
  101. package/esm/components/TsIcon/icons/index.d.ts +3 -0
  102. package/esm/components/TsIcon/icons/index.js +62 -0
  103. package/esm/components/TsIcon/icons/index.js.map +1 -0
  104. package/esm/components/TsIcon/icons/index.ts +61 -0
  105. package/esm/components/TsIcon/icons/link.svg +1 -0
  106. package/esm/components/TsIcon/icons/list-settings.svg +1 -0
  107. package/esm/components/TsIcon/icons/lock.svg +1 -0
  108. package/esm/components/TsIcon/icons/loop-right.svg +1 -0
  109. package/esm/components/TsIcon/icons/percent.svg +1 -0
  110. package/esm/components/TsIcon/icons/question-circle.svg +1 -0
  111. package/esm/components/TsIcon/icons/save.svg +1 -0
  112. package/esm/components/TsIcon/icons/search.svg +1 -0
  113. package/esm/components/TsIcon/icons/seedling-circle.svg +12 -0
  114. package/esm/components/TsIcon/icons/square.svg +1 -0
  115. package/esm/components/TsIcon/icons/timer.svg +1 -0
  116. package/esm/components/TsIcon/icons/tools.svg +1 -0
  117. package/esm/components/TsIcon/icons/user.svg +1 -0
  118. package/esm/components/TsInput/TsInput/TsInput.css +92 -0
  119. package/esm/components/TsInput/TsInput/TsInput.d.ts +4 -0
  120. package/esm/components/TsInput/TsInput/TsInput.js +21 -0
  121. package/esm/components/TsInput/TsInput/TsInput.js.map +1 -0
  122. package/esm/components/TsInput/TsInput/TsInput.tsx +34 -0
  123. package/esm/components/TsInput/TsInput/TsInput.types.d.ts +8 -0
  124. package/esm/components/TsInput/TsInput/TsInput.types.js +2 -0
  125. package/esm/components/TsInput/TsInput/TsInput.types.js.map +1 -0
  126. package/esm/components/TsInput/TsInput/TsInput.types.tsx +9 -0
  127. package/esm/components/TsInput/TsInput/__stories__/TsInput.stories.mdx +77 -0
  128. package/esm/components/TsLoader/TsLoader.css +42 -0
  129. package/esm/components/TsLoader/TsLoader.d.ts +4 -0
  130. package/esm/components/TsLoader/TsLoader.js +6 -0
  131. package/esm/components/TsLoader/TsLoader.js.map +1 -0
  132. package/esm/components/TsLoader/TsLoader.types.d.ts +3 -0
  133. package/esm/components/TsLoader/TsLoader.types.js +2 -0
  134. package/esm/components/TsLoader/TsLoader.types.js.map +1 -0
  135. package/esm/components/TsLoader/__stories__/TsLoader.stories.mdx +30 -0
  136. package/esm/components/TsTabs/TsTabs.css +69 -0
  137. package/esm/components/TsTabs/TsTabs.d.ts +4 -0
  138. package/esm/components/TsTabs/TsTabs.js +30 -0
  139. package/esm/components/TsTabs/TsTabs.js.map +1 -0
  140. package/esm/components/TsTabs/TsTabs.types.d.ts +14 -0
  141. package/esm/components/TsTabs/TsTabs.types.js +2 -0
  142. package/esm/components/TsTabs/TsTabs.types.js.map +1 -0
  143. package/esm/components/TsTabs/__stories__/TsTabs.stories.mdx +50 -0
  144. package/esm/hooks/use-click-outside.d.ts +2 -0
  145. package/esm/hooks/use-click-outside.js +14 -0
  146. package/esm/hooks/use-click-outside.js.map +1 -0
  147. package/esm/index.d.ts +11 -0
  148. package/esm/index.js +12 -0
  149. package/esm/index.js.map +1 -0
  150. package/esm/layouts/TsHeader/TsHeader.css +186 -0
  151. package/esm/layouts/TsHeader/TsHeader.d.ts +4 -0
  152. package/esm/layouts/TsHeader/TsHeader.js +13 -0
  153. package/esm/layouts/TsHeader/TsHeader.js.map +1 -0
  154. package/esm/layouts/TsHeader/TsHeader.types.d.ts +23 -0
  155. package/esm/layouts/TsHeader/TsHeader.types.js +2 -0
  156. package/esm/layouts/TsHeader/TsHeader.types.js.map +1 -0
  157. package/esm/layouts/TsHeader/TsHeaderProfile.d.ts +5 -0
  158. package/esm/layouts/TsHeader/TsHeaderProfile.js +38 -0
  159. package/esm/layouts/TsHeader/TsHeaderProfile.js.map +1 -0
  160. package/esm/layouts/TsHeader/TsHeaderSearch.d.ts +3 -0
  161. package/esm/layouts/TsHeader/TsHeaderSearch.js +58 -0
  162. package/esm/layouts/TsHeader/TsHeaderSearch.js.map +1 -0
  163. package/esm/layouts/TsHeader/__stories__/TsHeader.stories.mdx +71 -0
  164. package/esm/layouts/TsNavigation/TsNavigation.css +72 -0
  165. package/esm/layouts/TsNavigation/TsNavigation.d.ts +7 -0
  166. package/esm/layouts/TsNavigation/TsNavigation.js +29 -0
  167. package/esm/layouts/TsNavigation/TsNavigation.js.map +1 -0
  168. package/esm/layouts/TsNavigation/TsNavigation.types.d.ts +10 -0
  169. package/esm/layouts/TsNavigation/TsNavigation.types.js +2 -0
  170. package/esm/layouts/TsNavigation/TsNavigation.types.js.map +1 -0
  171. package/esm/layouts/TsNavigation/__stories__/TsNavigation.stories.mdx +51 -0
  172. package/esm/utils/string.utils.d.ts +1 -0
  173. package/esm/utils/string.utils.js +2 -0
  174. package/esm/utils/string.utils.js.map +1 -0
  175. package/lib/assets/fonts/Montserrat-Medium.ttf +0 -0
  176. package/lib/assets/fonts/Roboto-Light.ttf +0 -0
  177. package/lib/components/TsButton/TsButton.css +121 -0
  178. package/lib/components/TsButton/TsButton.d.ts +5 -0
  179. package/lib/components/TsButton/TsButton.js +21 -0
  180. package/lib/components/TsButton/TsButton.js.map +1 -0
  181. package/lib/components/TsButton/TsButton.types.d.ts +9 -0
  182. package/lib/components/TsButton/TsButton.types.js +3 -0
  183. package/lib/components/TsButton/TsButton.types.js.map +1 -0
  184. package/lib/components/TsButton/__stories__/TsButton.stories.mdx +84 -0
  185. package/lib/components/TsCheckbox/TsCheckbox.css +64 -0
  186. package/lib/components/TsCheckbox/TsCheckbox.d.ts +4 -0
  187. package/lib/components/TsCheckbox/TsCheckbox.js +21 -0
  188. package/lib/components/TsCheckbox/TsCheckbox.js.map +1 -0
  189. package/lib/components/TsCheckbox/TsCheckbox.types.d.ts +7 -0
  190. package/lib/components/TsCheckbox/TsCheckbox.types.js +3 -0
  191. package/lib/components/TsCheckbox/TsCheckbox.types.js.map +1 -0
  192. package/lib/components/TsCheckbox/__stories__/TsCheckbox.stories.mdx +56 -0
  193. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.css +114 -0
  194. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.d.ts +4 -0
  195. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.js +104 -0
  196. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.js.map +1 -0
  197. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.tsx +165 -0
  198. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.types.d.ts +17 -0
  199. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.types.js +3 -0
  200. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.types.js.map +1 -0
  201. package/lib/components/TsDropdowns/TsDropdown/TsDropdown.types.ts +18 -0
  202. package/lib/components/TsDropdowns/TsDropdown/__stories__/TsDropdown.stories.mdx +85 -0
  203. package/lib/components/TsDropdowns/TsDropdown/__stories__/fruits.d.ts +4 -0
  204. package/lib/components/TsDropdowns/TsDropdown/__stories__/fruits.js +51 -0
  205. package/lib/components/TsDropdowns/TsDropdown/__stories__/fruits.js.map +1 -0
  206. package/lib/components/TsDropdowns/TsDropdown/__stories__/fruits.ts +47 -0
  207. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.css +83 -0
  208. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.d.ts +4 -0
  209. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.js +66 -0
  210. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.js.map +1 -0
  211. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.tsx +105 -0
  212. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.d.ts +8 -0
  213. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.js +3 -0
  214. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.js.map +1 -0
  215. package/lib/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.types.ts +8 -0
  216. package/lib/components/TsDropdowns/TsDropdownFilter/__stories__/TsDropdown.stories.mdx +69 -0
  217. package/lib/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.d.ts +4 -0
  218. package/lib/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.js +51 -0
  219. package/lib/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.js.map +1 -0
  220. package/lib/components/TsDropdowns/TsDropdownFilter/__stories__/fruits.ts +47 -0
  221. package/lib/components/TsIcon/TsIcon.css +26 -0
  222. package/lib/components/TsIcon/TsIcon.d.ts +4 -0
  223. package/lib/components/TsIcon/TsIcon.js +16 -0
  224. package/lib/components/TsIcon/TsIcon.js.map +1 -0
  225. package/lib/components/TsIcon/TsIcon.types.d.ts +4 -0
  226. package/lib/components/TsIcon/TsIcon.types.js +3 -0
  227. package/lib/components/TsIcon/TsIcon.types.js.map +1 -0
  228. package/lib/components/TsIcon/__stories__/TsIcon.stories.mdx +89 -0
  229. package/lib/components/TsIcon/icons/add-circle.svg +1 -0
  230. package/lib/components/TsIcon/icons/add.svg +1 -0
  231. package/lib/components/TsIcon/icons/alert-circle-filled.svg +1 -0
  232. package/lib/components/TsIcon/icons/alert-circle.svg +1 -0
  233. package/lib/components/TsIcon/icons/alert-triangle-filled.svg +1 -0
  234. package/lib/components/TsIcon/icons/alert-triangle.svg +1 -0
  235. package/lib/components/TsIcon/icons/arrow-diagonal-collapse.svg +1 -0
  236. package/lib/components/TsIcon/icons/arrow-diagonal-expand.svg +1 -0
  237. package/lib/components/TsIcon/icons/arrow-down.svg +1 -0
  238. package/lib/components/TsIcon/icons/arrow-go-back.svg +1 -0
  239. package/lib/components/TsIcon/icons/arrow-left-right.svg +1 -0
  240. package/lib/components/TsIcon/icons/arrow-left.svg +1 -0
  241. package/lib/components/TsIcon/icons/arrow-right.svg +1 -0
  242. package/lib/components/TsIcon/icons/arrow-up-down.svg +1 -0
  243. package/lib/components/TsIcon/icons/arrow-up.svg +1 -0
  244. package/lib/components/TsIcon/icons/award.svg +1 -0
  245. package/lib/components/TsIcon/icons/check-circle-filled.svg +1 -0
  246. package/lib/components/TsIcon/icons/check-circle-timer.svg +7 -0
  247. package/lib/components/TsIcon/icons/check-circle.svg +1 -0
  248. package/lib/components/TsIcon/icons/check-square-filled.svg +1 -0
  249. package/lib/components/TsIcon/icons/check-square.svg +1 -0
  250. package/lib/components/TsIcon/icons/check.svg +1 -0
  251. package/lib/components/TsIcon/icons/chevron-down.svg +1 -0
  252. package/lib/components/TsIcon/icons/chevron-left.svg +1 -0
  253. package/lib/components/TsIcon/icons/chevron-right.svg +1 -0
  254. package/lib/components/TsIcon/icons/chevron-up.svg +1 -0
  255. package/lib/components/TsIcon/icons/circle.svg +1 -0
  256. package/lib/components/TsIcon/icons/close-circle.svg +1 -0
  257. package/lib/components/TsIcon/icons/close.svg +1 -0
  258. package/lib/components/TsIcon/icons/currency-euro.svg +1 -0
  259. package/lib/components/TsIcon/icons/download.svg +1 -0
  260. package/lib/components/TsIcon/icons/edit.svg +1 -0
  261. package/lib/components/TsIcon/icons/external-link.svg +1 -0
  262. package/lib/components/TsIcon/icons/filter-off.svg +1 -0
  263. package/lib/components/TsIcon/icons/filter.svg +1 -0
  264. package/lib/components/TsIcon/icons/flashlight-off.svg +1 -0
  265. package/lib/components/TsIcon/icons/flashlight.svg +1 -0
  266. package/lib/components/TsIcon/icons/header-bikestudio.svg +32 -0
  267. package/lib/components/TsIcon/icons/header-nsc-helmet.svg +32 -0
  268. package/lib/components/TsIcon/icons/header-opticost.svg +32 -0
  269. package/lib/components/TsIcon/icons/header-repairability.svg +32 -0
  270. package/lib/components/TsIcon/icons/header-techoff-suite.svg +32 -0
  271. package/lib/components/TsIcon/icons/heart-filled.svg +1 -0
  272. package/lib/components/TsIcon/icons/heart.svg +1 -0
  273. package/lib/components/TsIcon/icons/history.svg +1 -0
  274. package/lib/components/TsIcon/icons/home.svg +1 -0
  275. package/lib/components/TsIcon/icons/index.d.ts +3 -0
  276. package/lib/components/TsIcon/icons/index.js +65 -0
  277. package/lib/components/TsIcon/icons/index.js.map +1 -0
  278. package/lib/components/TsIcon/icons/index.ts +61 -0
  279. package/lib/components/TsIcon/icons/link.svg +1 -0
  280. package/lib/components/TsIcon/icons/list-settings.svg +1 -0
  281. package/lib/components/TsIcon/icons/lock.svg +1 -0
  282. package/lib/components/TsIcon/icons/loop-right.svg +1 -0
  283. package/lib/components/TsIcon/icons/percent.svg +1 -0
  284. package/lib/components/TsIcon/icons/question-circle.svg +1 -0
  285. package/lib/components/TsIcon/icons/save.svg +1 -0
  286. package/lib/components/TsIcon/icons/search.svg +1 -0
  287. package/lib/components/TsIcon/icons/seedling-circle.svg +12 -0
  288. package/lib/components/TsIcon/icons/square.svg +1 -0
  289. package/lib/components/TsIcon/icons/timer.svg +1 -0
  290. package/lib/components/TsIcon/icons/tools.svg +1 -0
  291. package/lib/components/TsIcon/icons/user.svg +1 -0
  292. package/lib/components/TsInput/TsInput/TsInput.css +92 -0
  293. package/lib/components/TsInput/TsInput/TsInput.d.ts +4 -0
  294. package/lib/components/TsInput/TsInput/TsInput.js +25 -0
  295. package/lib/components/TsInput/TsInput/TsInput.js.map +1 -0
  296. package/lib/components/TsInput/TsInput/TsInput.tsx +34 -0
  297. package/lib/components/TsInput/TsInput/TsInput.types.d.ts +8 -0
  298. package/lib/components/TsInput/TsInput/TsInput.types.js +3 -0
  299. package/lib/components/TsInput/TsInput/TsInput.types.js.map +1 -0
  300. package/lib/components/TsInput/TsInput/TsInput.types.tsx +9 -0
  301. package/lib/components/TsInput/TsInput/__stories__/TsInput.stories.mdx +77 -0
  302. package/lib/components/TsLoader/TsLoader.css +42 -0
  303. package/lib/components/TsLoader/TsLoader.d.ts +4 -0
  304. package/lib/components/TsLoader/TsLoader.js +10 -0
  305. package/lib/components/TsLoader/TsLoader.js.map +1 -0
  306. package/lib/components/TsLoader/TsLoader.types.d.ts +3 -0
  307. package/lib/components/TsLoader/TsLoader.types.js +3 -0
  308. package/lib/components/TsLoader/TsLoader.types.js.map +1 -0
  309. package/lib/components/TsLoader/__stories__/TsLoader.stories.mdx +30 -0
  310. package/lib/components/TsTabs/TsTabs.css +69 -0
  311. package/lib/components/TsTabs/TsTabs.d.ts +4 -0
  312. package/lib/components/TsTabs/TsTabs.js +34 -0
  313. package/lib/components/TsTabs/TsTabs.js.map +1 -0
  314. package/lib/components/TsTabs/TsTabs.types.d.ts +14 -0
  315. package/lib/components/TsTabs/TsTabs.types.js +3 -0
  316. package/lib/components/TsTabs/TsTabs.types.js.map +1 -0
  317. package/lib/components/TsTabs/__stories__/TsTabs.stories.mdx +50 -0
  318. package/lib/hooks/use-click-outside.d.ts +2 -0
  319. package/lib/hooks/use-click-outside.js +18 -0
  320. package/lib/hooks/use-click-outside.js.map +1 -0
  321. package/lib/index.d.ts +11 -0
  322. package/lib/index.js +28 -0
  323. package/lib/index.js.map +1 -0
  324. package/lib/layouts/TsHeader/TsHeader.css +186 -0
  325. package/lib/layouts/TsHeader/TsHeader.d.ts +4 -0
  326. package/lib/layouts/TsHeader/TsHeader.js +17 -0
  327. package/lib/layouts/TsHeader/TsHeader.js.map +1 -0
  328. package/lib/layouts/TsHeader/TsHeader.types.d.ts +23 -0
  329. package/lib/layouts/TsHeader/TsHeader.types.js +3 -0
  330. package/lib/layouts/TsHeader/TsHeader.types.js.map +1 -0
  331. package/lib/layouts/TsHeader/TsHeaderProfile.d.ts +5 -0
  332. package/lib/layouts/TsHeader/TsHeaderProfile.js +43 -0
  333. package/lib/layouts/TsHeader/TsHeaderProfile.js.map +1 -0
  334. package/lib/layouts/TsHeader/TsHeaderSearch.d.ts +3 -0
  335. package/lib/layouts/TsHeader/TsHeaderSearch.js +62 -0
  336. package/lib/layouts/TsHeader/TsHeaderSearch.js.map +1 -0
  337. package/lib/layouts/TsHeader/__stories__/TsHeader.stories.mdx +71 -0
  338. package/lib/layouts/TsNavigation/TsNavigation.css +72 -0
  339. package/lib/layouts/TsNavigation/TsNavigation.d.ts +7 -0
  340. package/lib/layouts/TsNavigation/TsNavigation.js +35 -0
  341. package/lib/layouts/TsNavigation/TsNavigation.js.map +1 -0
  342. package/lib/layouts/TsNavigation/TsNavigation.types.d.ts +10 -0
  343. package/lib/layouts/TsNavigation/TsNavigation.types.js +3 -0
  344. package/lib/layouts/TsNavigation/TsNavigation.types.js.map +1 -0
  345. package/lib/layouts/TsNavigation/__stories__/TsNavigation.stories.mdx +51 -0
  346. package/lib/utils/string.utils.d.ts +1 -0
  347. package/lib/utils/string.utils.js +6 -0
  348. package/lib/utils/string.utils.js.map +1 -0
  349. package/package.json +1 -1
  350. package/src/components/TsDropdowns/TsDropdownFilter/TsDropdownFilter.tsx +1 -0
@@ -0,0 +1,13 @@
1
+ import * as React from 'react';
2
+ import { icons } from '../../components/TsIcon/icons';
3
+ import './TsHeader.css';
4
+ export const TsHeader = ({ actions, appName }) => {
5
+ // #########
6
+ // Rendering
7
+ return (React.createElement("header", null,
8
+ React.createElement("div", { className: "ts-header-aside" },
9
+ React.createElement("div", { className: "ts-header-techoff", dangerouslySetInnerHTML: { __html: icons[`header-${appName}`] } })),
10
+ React.createElement("div", { className: "ts-header-aside ts-header-right-side" },
11
+ React.createElement("div", { className: "ts-header-actions" }, actions))));
12
+ };
13
+ //# sourceMappingURL=TsHeader.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsHeader.js","sourceRoot":"","sources":["../../../src/layouts/TsHeader/TsHeader.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAE,KAAK,EAAE,MAAM,+BAA+B,CAAC;AAEtD,OAAO,gBAAgB,CAAC;AAExB,MAAM,CAAC,MAAM,QAAQ,GAAG,CAAC,EAAE,OAAO,EAAE,OAAO,EAAiB,EAAE,EAAE;IAC9D,YAAY;IACZ,YAAY;IACZ,OAAO,CACL;QACE,6BAAK,SAAS,EAAC,iBAAiB;YAC9B,6BAAK,SAAS,EAAC,mBAAmB,EAAC,uBAAuB,EAAE,EAAE,MAAM,EAAE,KAAK,CAAC,UAAU,OAAO,EAAE,CAAC,EAAE,GAAI,CAClG;QAEN,6BAAK,SAAS,EAAC,sCAAsC;YACnD,6BAAK,SAAS,EAAC,mBAAmB,IAAE,OAAO,CAAO,CAC9C,CACC,CACV,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,23 @@
1
+ import { ReactElement } from 'react';
2
+ export type TsHeaderProps = {
3
+ actions: ReactElement;
4
+ appName: 'bikestudio' | 'nsc-helmet' | 'opticost' | 'repairability' | 'techoff-suite';
5
+ search?: ReactElement;
6
+ };
7
+ export type TsHeaderProfileItemProps = {
8
+ icon: string;
9
+ label: string;
10
+ link: string;
11
+ };
12
+ export type TsHeaderProfileProps = {
13
+ firstname: string;
14
+ lastname: string;
15
+ };
16
+ export type TsHeaderSearchProps = {
17
+ getItemLabel: (e: any) => string;
18
+ getItemValue: (e: any) => string;
19
+ loadItems: (search?: string) => Promise<any[]>;
20
+ noDataLabel?: string;
21
+ placeholder?: string;
22
+ onChange: (value: string) => void;
23
+ };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=TsHeader.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsHeader.types.js","sourceRoot":"","sources":["../../../src/layouts/TsHeader/TsHeader.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ import { TsHeaderProfileItemProps, TsHeaderProfileProps } from './TsHeader.types';
4
+ export declare const TsHeaderProfileItem: ({ icon, label, link }: TsHeaderProfileItemProps) => React.JSX.Element;
5
+ export declare const TsHeaderProfile: ({ children, firstname, lastname }: TsHeaderProfileProps & PropsWithChildren) => React.JSX.Element;
@@ -0,0 +1,38 @@
1
+ import * as React from 'react';
2
+ import { useState } from 'react';
3
+ import { TsIcon } from '../../components/TsIcon/TsIcon';
4
+ import { useClickOutside } from '../../hooks/use-click-outside';
5
+ import { capitalize } from '../../utils/string.utils';
6
+ export const TsHeaderProfileItem = ({ icon, label, link }) => {
7
+ // ########
8
+ // Handlers
9
+ const handleNavigate = () => window.open(link, '_blank', 'noreferrer');
10
+ // #########
11
+ // Rendering
12
+ return (React.createElement("div", { className: "ts-header-profile-menu-item", onClick: handleNavigate },
13
+ React.createElement("div", { className: "ts-header-profile-menu-item-icon" },
14
+ React.createElement(TsIcon, { name: icon, size: "16" })),
15
+ React.createElement("div", { className: "ts-header-profile-menu-item-label" }, label),
16
+ React.createElement("div", { className: "ts-header-profile-menu-item-icon" },
17
+ React.createElement(TsIcon, { name: "external-link", size: "16" }))));
18
+ };
19
+ export const TsHeaderProfile = ({ children, firstname, lastname }) => {
20
+ const [isOpen, setIsOpen] = useState(false);
21
+ const ref = useClickOutside(() => setIsOpen(false));
22
+ // #########
23
+ // Rendering
24
+ return (React.createElement("div", { className: "ts-header-profile-container", ref: ref },
25
+ React.createElement("div", { className: "ts-header-profile-dropdown", onClick: () => children && setIsOpen(prev => !prev) },
26
+ React.createElement("div", { className: "ts-header-profile-img-container" },
27
+ React.createElement("div", { className: "ts-header-profile-img-icon" },
28
+ React.createElement(TsIcon, { name: "user", size: "16" }))),
29
+ React.createElement("div", { className: "ts-header-profile-name" },
30
+ capitalize(firstname),
31
+ " ",
32
+ lastname.charAt(0).toUpperCase(),
33
+ "."),
34
+ children && (React.createElement("div", { className: "ts-header-profile-chevron" },
35
+ React.createElement(TsIcon, { name: isOpen ? 'chevron-up' : 'chevron-down', size: "16" })))),
36
+ isOpen && React.createElement("div", { className: "ts-header-profile-menu" }, children)));
37
+ };
38
+ //# sourceMappingURL=TsHeaderProfile.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsHeaderProfile.js","sourceRoot":"","sources":["../../../src/layouts/TsHeader/TsHeaderProfile.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAC/B,OAAO,EAAqB,QAAQ,EAAE,MAAM,OAAO,CAAC;AACpD,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AACxD,OAAO,EAAE,eAAe,EAAE,MAAM,+BAA+B,CAAC;AAChE,OAAO,EAAE,UAAU,EAAE,MAAM,0BAA0B,CAAC;AAGtD,MAAM,CAAC,MAAM,mBAAmB,GAAG,CAAC,EAAE,IAAI,EAAE,KAAK,EAAE,IAAI,EAA4B,EAAE,EAAE;IACrF,WAAW;IACX,WAAW;IACX,MAAM,cAAc,GAAG,GAAG,EAAE,CAAC,MAAM,CAAC,IAAI,CAAC,IAAI,EAAE,QAAQ,EAAE,YAAY,CAAC,CAAC;IAEvE,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,6BAA6B,EAAC,OAAO,EAAE,cAAc;QAClE,6BAAK,SAAS,EAAC,kCAAkC;YAC/C,oBAAC,MAAM,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,IAAI,GAAG,CAC5B;QACN,6BAAK,SAAS,EAAC,mCAAmC,IAAE,KAAK,CAAO;QAChE,6BAAK,SAAS,EAAC,kCAAkC;YAC/C,oBAAC,MAAM,IAAC,IAAI,EAAC,eAAe,EAAC,IAAI,EAAC,IAAI,GAAG,CACrC,CACF,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,eAAe,GAAG,CAAC,EAAE,QAAQ,EAAE,SAAS,EAAE,QAAQ,EAA4C,EAAE,EAAE;IAC7G,MAAM,CAAC,MAAM,EAAE,SAAS,CAAC,GAAG,QAAQ,CAAU,KAAK,CAAC,CAAC;IACrD,MAAM,GAAG,GAAG,eAAe,CAAC,GAAG,EAAE,CAAC,SAAS,CAAC,KAAK,CAAC,CAAC,CAAC;IAEpD,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,6BAA6B,EAAC,GAAG,EAAE,GAAG;QACnD,6BAAK,SAAS,EAAC,4BAA4B,EAAC,OAAO,EAAE,GAAG,EAAE,CAAC,QAAQ,IAAI,SAAS,CAAC,IAAI,CAAC,EAAE,CAAC,CAAC,IAAI,CAAC;YAC7F,6BAAK,SAAS,EAAC,iCAAiC;gBAC9C,6BAAK,SAAS,EAAC,4BAA4B;oBACzC,oBAAC,MAAM,IAAC,IAAI,EAAC,MAAM,EAAC,IAAI,EAAC,IAAI,GAAG,CAC5B,CACF;YACN,6BAAK,SAAS,EAAC,wBAAwB;gBACpC,UAAU,CAAC,SAAS,CAAC;;gBAAG,QAAQ,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE;oBACrD;YAEL,QAAQ,IAAI,CACX,6BAAK,SAAS,EAAC,2BAA2B;gBACxC,oBAAC,MAAM,IAAC,IAAI,EAAE,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,cAAc,EAAE,IAAI,EAAC,IAAI,GAAG,CAC9D,CACP,CACG;QAEL,MAAM,IAAI,6BAAK,SAAS,EAAC,wBAAwB,IAAE,QAAQ,CAAO,CAC/D,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,3 @@
1
+ import * as React from 'react';
2
+ import { TsHeaderSearchProps } from './TsHeader.types';
3
+ export declare const TsHeaderSearch: ({ getItemLabel, getItemValue, loadItems, noDataLabel, onChange, }: TsHeaderSearchProps) => React.JSX.Element;
@@ -0,0 +1,58 @@
1
+ import * as React from 'react';
2
+ import { useEffect, useState } from 'react';
3
+ // import { Input } from '../../components/Inputs/Input/Input';
4
+ import { TsLoader } from '../../components/TsLoader/TsLoader';
5
+ import { useClickOutside } from '../../hooks/use-click-outside';
6
+ export const TsHeaderSearch = ({ getItemLabel, getItemValue, loadItems, noDataLabel, onChange, }) => {
7
+ const [searchValue] = useState('');
8
+ const [items, setItems] = useState([]);
9
+ const [isLoading, setIsLoading] = useState(false);
10
+ const [showItems, setShowItems] = useState(false);
11
+ const ref = useClickOutside(() => setShowItems(false));
12
+ // #######
13
+ // Helpers
14
+ const getBeforeMatch = (item) => {
15
+ const label = getItemLabel(item);
16
+ const matchStartIndex = label.toLowerCase().indexOf(searchValue.toLowerCase());
17
+ return label.substring(0, matchStartIndex);
18
+ };
19
+ const getMatch = (item) => {
20
+ const label = getItemLabel(item);
21
+ const matchStartIndex = label.toLowerCase().indexOf(searchValue.toLowerCase());
22
+ const matchEndIndex = matchStartIndex + searchValue.length;
23
+ return label.substring(matchStartIndex, matchEndIndex);
24
+ };
25
+ const getAfterMatch = (item) => {
26
+ const label = getItemLabel(item);
27
+ const matchStartIndex = label.toLowerCase().indexOf(searchValue.toLowerCase());
28
+ const matchEndIndex = matchStartIndex + searchValue.length;
29
+ return label.substring(matchEndIndex);
30
+ };
31
+ // ########
32
+ // Watchers
33
+ useEffect(() => {
34
+ if (searchValue === '') {
35
+ setShowItems(false);
36
+ setItems([]);
37
+ setIsLoading(false);
38
+ }
39
+ else {
40
+ setShowItems(true);
41
+ setIsLoading(true);
42
+ loadItems(searchValue)
43
+ .then(setItems)
44
+ .finally(() => setIsLoading(false));
45
+ }
46
+ }, [searchValue]);
47
+ // #########
48
+ // Rendering
49
+ return (React.createElement("div", { className: "ts-header-search", ref: ref }, showItems && searchValue !== '' && (React.createElement("div", { className: "ts-header-search-items-container" },
50
+ isLoading && (React.createElement("div", { className: "ts-header-search-loading" },
51
+ React.createElement(TsLoader, { size: "sm" }))),
52
+ !isLoading && items.length === 0 && React.createElement("div", { className: "ts-header-search-no-items" }, noDataLabel),
53
+ !isLoading && items.length > 0 && (React.createElement("div", { className: "ts-header-search-items" }, items.map(item => (React.createElement("div", { className: "ts-header-search-item", onClick: () => onChange(getItemValue(item)) },
54
+ getBeforeMatch(item),
55
+ React.createElement("span", { className: "ts-header-search-item--match" }, getMatch(item)),
56
+ getAfterMatch(item))))))))));
57
+ };
58
+ //# sourceMappingURL=TsHeaderSearch.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsHeaderSearch.js","sourceRoot":"","sources":["../../../src/layouts/TsHeader/TsHeaderSearch.tsx"],"names":[],"mappings":"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"}
@@ -0,0 +1,71 @@
1
+ import React from 'react';
2
+ import { ArgsTable, Canvas, Meta, Story } from '@storybook/blocks';
3
+ import { TsHeader } from '../TsHeader';
4
+ import { TsHeaderProfile, TsHeaderProfileItem } from '../TsHeaderProfile';
5
+ import { TsHeaderSearch } from '../TsHeaderSearch';
6
+ import { TsButton } from '../../../components/TsButton/TsButton';
7
+
8
+ <Meta title="Layouts/Header" />
9
+
10
+ export const headerArgTypes = {
11
+ appName: {
12
+ control: 'select',
13
+ options: ['bikestudio', 'nsc-helmet', 'opticost', 'repairability', 'techoff-suite'],
14
+ description: 'Icon of the button.',
15
+ },
16
+ };
17
+
18
+ export const loadItems = () => {
19
+ return Promise.resolve([
20
+ { id: 1, label: 'Item 1' },
21
+ { id: 2, label: 'Item 2' },
22
+ { id: 3, label: 'Item 3' },
23
+ { id: 4, label: 'Item 4' },
24
+ { id: 5, label: 'Item 5' },
25
+ { id: 6, label: 'Item 6' },
26
+ { id: 7, label: 'Item 7' },
27
+ { id: 8, label: 'Item 8' },
28
+ { id: 9, label: 'Item 9' },
29
+ ]);
30
+ };
31
+
32
+ # Header
33
+
34
+ The header will allow users to quickly find the information they need at a glance but also make some actions. The header is therefore central in the design of each application: it contains all the essential information, obvious shortcuts, which will help boost Deacthlon Techoff brand image.
35
+
36
+ ## Overview
37
+
38
+ <Canvas>
39
+ <Story
40
+ name="Overview"
41
+ args={{
42
+ actions: (
43
+ <>
44
+ <TsButton icon="add" size="lg" variant="shadow" rounded />
45
+ <TsHeaderProfile firstname="John" lastname="Doe">
46
+ <TsHeaderProfileItem icon="alert-triangle" label="Contact support" link="" />
47
+ <TsHeaderProfileItem icon="award" label="Trainings" link="" />
48
+ </TsHeaderProfile>
49
+ </>
50
+ ),
51
+ appName: 'repairability',
52
+ search: (
53
+ <TsHeaderSearch
54
+ getItemLabel={item => item.label}
55
+ getItemValue={item => item.id}
56
+ loadItems={loadItems}
57
+ noDataLabel="No item found."
58
+ placeholder="Search something in the application"
59
+ onChange={() => {}}
60
+ />
61
+ ),
62
+ }}
63
+ argTypes={headerArgTypes}
64
+ >
65
+ {args => <TsHeader {...args} />}
66
+ </Story>
67
+ </Canvas>
68
+
69
+ ## Props
70
+
71
+ <ArgsTable story="Overview" of={TsHeader} />
@@ -0,0 +1,72 @@
1
+ .ts-navigation {
2
+ display: flex;
3
+ align-items: center;
4
+ height: 32px;
5
+ padding: 0 24px;
6
+ }
7
+
8
+ /* ############ */
9
+ /* BREADCRUMB */
10
+ .ts-breadcrumb {
11
+ display: flex;
12
+ align-items: center;
13
+ padding-right: 20px;
14
+ }
15
+ .ts-breadcrumb-container {
16
+ display: flex;
17
+ align-items: center;
18
+ }
19
+ .ts-breadcrumb-item {
20
+ display: flex;
21
+ align-items: center;
22
+ height: 32px;
23
+ padding: 0 10px;
24
+ border-radius: 9999px;
25
+ color: #3643ba;
26
+ }
27
+ .ts-breadcrumb-item--highlight {
28
+ padding: 0 20px;
29
+ box-shadow: 0px 6px 6px 0px #00537d1a;
30
+ background: linear-gradient(270deg, #3643ba 0%, rgba(54, 67, 186, 0.6) 100%);
31
+ color: #ffffff;
32
+ }
33
+ .ts-breadcrumb-item--link:hover {
34
+ background: #ebecf7;
35
+ cursor: pointer;
36
+ }
37
+ .ts-breadcrumb-item--icon {
38
+ padding-right: 8px;
39
+ }
40
+
41
+ /* ######### */
42
+ /* DIVIDER */
43
+ .ts-navigation-divider {
44
+ flex: 1;
45
+ height: 2px;
46
+ background: #ebecf7;
47
+ }
48
+ .ts-breadcrumb-chevron {
49
+ padding: 0 2px;
50
+ color: #3643ba;
51
+ }
52
+
53
+ /* ######### */
54
+ /* ACTIONS */
55
+ .ts-navigation-actions {
56
+ /* flex items-center [&>*]:ml-4 */
57
+ display: flex;
58
+ align-items: center;
59
+ }
60
+ .ts-navigation-actions > * {
61
+ margin-left: 16px;
62
+ }
63
+
64
+ /* ######### */
65
+ /* GLOBALS */
66
+ * {
67
+ font-size: 14px;
68
+ outline: none;
69
+ box-sizing: border-box;
70
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',
71
+ 'Helvetica Neue', sans-serif;
72
+ }
@@ -0,0 +1,7 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ import { TsNavigationBreadcrumbItemProps, TsNavigationProps } from './TsNavigation.types';
4
+ import './TsNavigation.css';
5
+ export declare const TsNavigationBreadcrumbDivider: () => React.JSX.Element;
6
+ export declare const TsNavigationBreadcrumbItem: ({ children, icon, highlight, onClick, }: PropsWithChildren<TsNavigationBreadcrumbItemProps>) => React.JSX.Element;
7
+ export declare const TsNavigation: ({ actions, breadcrumbs }: TsNavigationProps) => React.JSX.Element;
@@ -0,0 +1,29 @@
1
+ import * as React from 'react';
2
+ import { TsIcon } from '../../components/TsIcon/TsIcon';
3
+ import './TsNavigation.css';
4
+ export const TsNavigationBreadcrumbDivider = () => {
5
+ // #########
6
+ // Rendering
7
+ return (React.createElement("div", { className: "ts-breadcrumb-chevron" },
8
+ React.createElement(TsIcon, { name: "chevron-right" })));
9
+ };
10
+ export const TsNavigationBreadcrumbItem = ({ children, icon, highlight, onClick, }) => {
11
+ // #########
12
+ // Rendering
13
+ return (React.createElement("div", { className: `
14
+ ts-breadcrumb-item
15
+ ${highlight ? 'ts-breadcrumb-item--highlight' : ''} ${onClick ? 'ts-breadcrumb-item--link' : ''}
16
+ `, onClick: onClick },
17
+ icon && (React.createElement("div", { className: "ts-breadcrumb-item--icon" },
18
+ React.createElement(TsIcon, { name: icon, size: "16" }))),
19
+ children));
20
+ };
21
+ export const TsNavigation = ({ actions, breadcrumbs }) => {
22
+ // #########
23
+ // Rendering
24
+ return (React.createElement("div", { className: "ts-navigation" },
25
+ React.createElement("div", { className: "ts-breadcrumb" }, breadcrumbs),
26
+ React.createElement("div", { className: "ts-navigation-divider" }),
27
+ React.createElement("div", { className: "ts-navigation-actions" }, actions)));
28
+ };
29
+ //# sourceMappingURL=TsNavigation.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsNavigation.js","sourceRoot":"","sources":["../../../src/layouts/TsNavigation/TsNavigation.tsx"],"names":[],"mappings":"AAAA,OAAO,KAAK,KAAK,MAAM,OAAO,CAAC;AAE/B,OAAO,EAAE,MAAM,EAAE,MAAM,gCAAgC,CAAC;AAExD,OAAO,oBAAoB,CAAC;AAE5B,MAAM,CAAC,MAAM,6BAA6B,GAAG,GAAG,EAAE;IAChD,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,uBAAuB;QACpC,oBAAC,MAAM,IAAC,IAAI,EAAC,eAAe,GAAG,CAC3B,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,0BAA0B,GAAG,CAAC,EACzC,QAAQ,EACR,IAAI,EACJ,SAAS,EACT,OAAO,GAC4C,EAAE,EAAE;IACvD,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BACE,SAAS,EAAE;;UAEP,SAAS,CAAC,CAAC,CAAC,+BAA+B,CAAC,CAAC,CAAC,EAAE,IAAI,OAAO,CAAC,CAAC,CAAC,0BAA0B,CAAC,CAAC,CAAC,EAAE;OAChG,EACD,OAAO,EAAE,OAAO;QAEf,IAAI,IAAI,CACP,6BAAK,SAAS,EAAC,0BAA0B;YACvC,oBAAC,MAAM,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,IAAI,GAAG,CAC5B,CACP;QAEA,QAAQ,CACL,CACP,CAAC;AACJ,CAAC,CAAC;AAEF,MAAM,CAAC,MAAM,YAAY,GAAG,CAAC,EAAE,OAAO,EAAE,WAAW,EAAqB,EAAE,EAAE;IAC1E,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,6BAAK,SAAS,EAAC,eAAe;QAC5B,6BAAK,SAAS,EAAC,eAAe,IAAE,WAAW,CAAO;QAClD,6BAAK,SAAS,EAAC,uBAAuB,GAAG;QACzC,6BAAK,SAAS,EAAC,uBAAuB,IAAE,OAAO,CAAO,CAClD,CACP,CAAC;AACJ,CAAC,CAAC"}
@@ -0,0 +1,10 @@
1
+ import { ReactElement } from 'react';
2
+ export type TsNavigationProps = {
3
+ actions?: ReactElement;
4
+ breadcrumbs: ReactElement;
5
+ };
6
+ export type TsNavigationBreadcrumbItemProps = {
7
+ icon?: string;
8
+ highlight?: boolean;
9
+ onClick?: () => void;
10
+ };
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=TsNavigation.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsNavigation.types.js","sourceRoot":"","sources":["../../../src/layouts/TsNavigation/TsNavigation.types.ts"],"names":[],"mappings":""}
@@ -0,0 +1,51 @@
1
+ import React from 'react';
2
+ import { ArgsTable, Canvas, Meta, Story } from '@storybook/blocks';
3
+ import { TsNavigation, TsNavigationBreadcrumbItem, TsNavigationBreadcrumbDivider } from '../TsNavigation';
4
+ import { TsButton } from '../../../components/TsButton/TsButton';
5
+ import { icons } from '../../../components/TsIcon/icons';
6
+
7
+ <Meta title="Layouts/Navigation" />
8
+
9
+ # Navigation
10
+
11
+ Breadcrumbs are an important navigation component that shows content hierarchy. They allow users to be aware of their current location in the hierarchical structure of the application. Breadcrumbs enable users to quickly move up to a parent level. Moreover this navigation component allows user to make some actions.
12
+
13
+ ## Overview
14
+
15
+ <Canvas>
16
+ <Story
17
+ name="Overview"
18
+ args={{
19
+ actions: (
20
+ <>
21
+ <TsButton icon="check" onClick={() => {}}>
22
+ Action 1
23
+ </TsButton>
24
+ <TsButton icon="add" onClick={() => {}}>
25
+ Action 2
26
+ </TsButton>
27
+ </>
28
+ ),
29
+ breadcrumbs: (
30
+ <>
31
+ <TsNavigationBreadcrumbItem icon="home" onClick={() => {}}>
32
+ Home
33
+ </TsNavigationBreadcrumbItem>
34
+ <TsNavigationBreadcrumbDivider />
35
+ <TsNavigationBreadcrumbItem onClick={() => {}}>Menu Item 1</TsNavigationBreadcrumbItem>
36
+ <TsNavigationBreadcrumbDivider />
37
+ <TsNavigationBreadcrumbItem highlight>Menu Item 2</TsNavigationBreadcrumbItem>
38
+ </>
39
+ )
40
+ }}
41
+
42
+ >
43
+
44
+ {args => <TsNavigation {...args} />}
45
+
46
+ </Story>
47
+ </Canvas>
48
+
49
+ ## Props
50
+
51
+ <ArgsTable story="Overview" of={TsNavigation} />
@@ -0,0 +1 @@
1
+ export declare const capitalize: (str: string) => string;
@@ -0,0 +1,2 @@
1
+ export const capitalize = (str) => str.charAt(0).toUpperCase() + str.slice(1).toLowerCase();
2
+ //# sourceMappingURL=string.utils.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"string.utils.js","sourceRoot":"","sources":["../../src/utils/string.utils.ts"],"names":[],"mappings":"AAAA,MAAM,CAAC,MAAM,UAAU,GAAG,CAAC,GAAW,EAAE,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,GAAG,GAAG,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,WAAW,EAAE,CAAC"}
@@ -0,0 +1,121 @@
1
+ .ts-button {
2
+ display: flex;
3
+ align-items: center;
4
+ justify-content: center;
5
+ border: none;
6
+ font-size: 14px;
7
+ font-weight: 600;
8
+ line-height: 16px;
9
+ cursor: pointer;
10
+ transition: all ease 0.3s;
11
+ }
12
+ .ts-button > div {
13
+ margin-right: 8px;
14
+ }
15
+ .ts-button > div:last-child {
16
+ margin-right: 0px;
17
+ }
18
+ button:disabled {
19
+ cursor: not-allowed;
20
+ }
21
+ /* ####### */
22
+ /* BLOCK */
23
+ .ts-button--block {
24
+ width: 100%;
25
+ }
26
+ /* ####### */
27
+ /* SIZES */
28
+ .ts-button--md {
29
+ height: 32px;
30
+ padding: 0 14px;
31
+ }
32
+ .ts-button--md.ts-button--icon-only {
33
+ width: 32px;
34
+ padding: 0;
35
+ }
36
+ .ts-button--lg {
37
+ height: 40px;
38
+ padding: 0 16px;
39
+ }
40
+ .ts-button--lg.ts-button--icon-only {
41
+ width: 40px;
42
+ padding: 0;
43
+ }
44
+ /* ########## */
45
+ /* VARIANTS */
46
+ .ts-button--primary:not(:disabled) {
47
+ background: #3643ba;
48
+ color: #ffffff;
49
+ }
50
+ .ts-button--primary:not(:disabled):hover {
51
+ background: #2e3998;
52
+ }
53
+ .ts-button--primary:not(:disabled):active {
54
+ background: #272f76;
55
+ }
56
+ .ts-button--primary:disabled {
57
+ background: #3643ba61;
58
+ color: #ffffff;
59
+ }
60
+ .ts-button--secondary:not(:disabled) {
61
+ background: #ebecf7;
62
+ color: #3643ba;
63
+ }
64
+ .ts-button--secondary:not(:disabled):hover {
65
+ background: #e3e3f4;
66
+ }
67
+ .ts-button--secondary:not(:disabled):active {
68
+ background: #d7daf1;
69
+ }
70
+ .ts-button--secondary:disabled {
71
+ background: #3643ba0d;
72
+ color: #3643ba80;
73
+ }
74
+ .ts-button--success:not(:disabled) {
75
+ background: #02be8a;
76
+ color: #ffffff;
77
+ }
78
+ .ts-button--success:not(:disabled):hover {
79
+ background: #029e73;
80
+ }
81
+ .ts-button--success:not(:disabled):active {
82
+ background: #017f5c;
83
+ }
84
+ .ts-button--success:disabled {
85
+ background: #02be8a61;
86
+ color: #ffffff;
87
+ }
88
+ .ts-button--ghost:not(:disabled) {
89
+ background: #ffffff;
90
+ color: #3643ba;
91
+ }
92
+ .ts-button--ghost:not(:disabled):hover {
93
+ background: #ebecf7;
94
+ }
95
+ .ts-button--ghost:not(:disabled):active {
96
+ background: #e3e3f4;
97
+ }
98
+ .ts-button--ghost:disabled {
99
+ background: #ffffff61;
100
+ color: #1d1d1b61;
101
+ }
102
+ .ts-button--shadow {
103
+ box-shadow: 0px 12px 12px 0px #00537d1a;
104
+ background: #ffffff;
105
+ color: #4e5d6b;
106
+ }
107
+ /* ######### */
108
+ /* ROUNDED */
109
+ .ts-button--rounded {
110
+ border-radius: 9999px;
111
+ }
112
+
113
+ /* ######### */
114
+ /* GLOBALS */
115
+ * {
116
+ font-size: 14px;
117
+ outline: none;
118
+ box-sizing: border-box;
119
+ font-family: system-ui, -apple-system, BlinkMacSystemFont, 'Segoe UI', Roboto, Oxygen, Ubuntu, Cantarell, 'Open Sans',
120
+ 'Helvetica Neue', sans-serif;
121
+ }
@@ -0,0 +1,5 @@
1
+ import * as React from 'react';
2
+ import { PropsWithChildren } from 'react';
3
+ import { TsButtonProps } from './TsButton.types';
4
+ import './TsButton.css';
5
+ export declare const TsButton: ({ children, icon, iconDirection, size, variant, block, rounded, ...props }: PropsWithChildren<TsButtonProps>) => React.JSX.Element;
@@ -0,0 +1,21 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ exports.TsButton = void 0;
4
+ const React = require("react");
5
+ const TsIcon_1 = require("../TsIcon/TsIcon");
6
+ require("./TsButton.css");
7
+ const TsButton = ({ children, icon, iconDirection = 'left', size = 'md', variant = 'primary', block, rounded, ...props }) => {
8
+ // #########
9
+ // Rendering
10
+ return (React.createElement("button", { className: `
11
+ ts-button ts-button--${size} ts-button--${variant}
12
+ ${block ? 'ts-button--block' : ''}
13
+ ${rounded ? 'ts-button--rounded' : ''}
14
+ ${icon && !children ? 'ts-button--icon-only' : ''}
15
+ `, ...props },
16
+ icon && iconDirection === 'left' && React.createElement(TsIcon_1.TsIcon, { name: icon, size: "16" }),
17
+ children && React.createElement("div", null, children),
18
+ icon && iconDirection === 'right' && React.createElement(TsIcon_1.TsIcon, { name: icon, size: "16" })));
19
+ };
20
+ exports.TsButton = TsButton;
21
+ //# sourceMappingURL=TsButton.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsButton.js","sourceRoot":"","sources":["../../../src/components/TsButton/TsButton.tsx"],"names":[],"mappings":";;;AAAA,+BAA+B;AAE/B,6CAA0C;AAE1C,0BAAwB;AAEjB,MAAM,QAAQ,GAAG,CAAC,EACvB,QAAQ,EACR,IAAI,EACJ,aAAa,GAAG,MAAM,EACtB,IAAI,GAAG,IAAI,EACX,OAAO,GAAG,SAAS,EACnB,KAAK,EACL,OAAO,EACP,GAAG,KAAK,EACyB,EAAE,EAAE;IACrC,YAAY;IACZ,YAAY;IACZ,OAAO,CACL,gCACE,SAAS,EAAE;+BACc,IAAI,eAAe,OAAO;UAC/C,KAAK,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC,CAAC,EAAE;UAC/B,OAAO,CAAC,CAAC,CAAC,oBAAoB,CAAC,CAAC,CAAC,EAAE;UACnC,IAAI,IAAI,CAAC,QAAQ,CAAC,CAAC,CAAC,sBAAsB,CAAC,CAAC,CAAC,EAAE;OAClD,KACG,KAAK;QAER,IAAI,IAAI,aAAa,KAAK,MAAM,IAAI,oBAAC,eAAM,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,IAAI,GAAG;QACpE,QAAQ,IAAI,iCAAM,QAAQ,CAAO;QACjC,IAAI,IAAI,aAAa,KAAK,OAAO,IAAI,oBAAC,eAAM,IAAC,IAAI,EAAE,IAAI,EAAE,IAAI,EAAC,IAAI,GAAG,CAC/D,CACV,CAAC;AACJ,CAAC,CAAC;AA3BW,QAAA,QAAQ,YA2BnB"}
@@ -0,0 +1,9 @@
1
+ import { ButtonHTMLAttributes } from 'react';
2
+ export type TsButtonProps = {
3
+ icon?: string;
4
+ iconDirection?: 'left' | 'right';
5
+ size?: 'md' | 'lg';
6
+ variant?: 'primary' | 'secondary' | 'success' | 'ghost' | 'shadow';
7
+ block?: boolean;
8
+ rounded?: boolean;
9
+ } & ButtonHTMLAttributes<HTMLButtonElement>;
@@ -0,0 +1,3 @@
1
+ "use strict";
2
+ Object.defineProperty(exports, "__esModule", { value: true });
3
+ //# sourceMappingURL=TsButton.types.js.map
@@ -0,0 +1 @@
1
+ {"version":3,"file":"TsButton.types.js","sourceRoot":"","sources":["../../../src/components/TsButton/TsButton.types.ts"],"names":[],"mappings":""}