josenanodev-react-components-library 1.0.3 → 1.0.4

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 (301) hide show
  1. package/dist/cjs/Services/MulticalendarStatesAndSettings.d.ts +34 -0
  2. package/dist/cjs/Services/MulticalendarStatesAndSettings.js +55 -0
  3. package/dist/cjs/Services/accessToken.d.ts +3 -0
  4. package/dist/cjs/Services/accessToken.js +15 -0
  5. package/dist/cjs/common/constants.d.ts +5 -0
  6. package/dist/cjs/common/constants.js +8 -0
  7. package/dist/cjs/common/turboSuiteUrls.d.ts +7 -0
  8. package/dist/cjs/common/turboSuiteUrls.js +9 -0
  9. package/dist/cjs/common/types.d.ts +113 -0
  10. package/dist/cjs/components/BubbleMenu/BubbleMenu.d.ts +12 -0
  11. package/dist/cjs/components/BubbleMenu/BubbleMenu.js +60 -0
  12. package/dist/cjs/components/BubbleMenu/BubbleMenu.module.scss +113 -0
  13. package/dist/cjs/components/CalendarDatePicker/CalendarDatePicker.d.ts +19 -0
  14. package/dist/cjs/components/CalendarDatePicker/CalendarDatePicker.js +191 -0
  15. package/dist/cjs/components/CalendarDatePicker/CalendarDatePicker.module.scss +104 -0
  16. package/dist/cjs/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.d.ts +15 -0
  17. package/dist/cjs/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.js +300 -0
  18. package/dist/cjs/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.module.scss +151 -0
  19. package/dist/cjs/components/ExportToExcelButton/ExportToExcelButton.css +31 -0
  20. package/dist/cjs/components/ExportToExcelButton/ExportToExcelButton.d.ts +5 -0
  21. package/dist/cjs/components/ExportToExcelButton/ExportToExcelButton.js +45 -0
  22. package/dist/cjs/components/ExportToExcelButton/ExportToExcelButtonOwnFunctions.d.ts +6 -0
  23. package/dist/cjs/components/ExportToExcelButton/ExportToExcelButtonOwnFunctions.js +75 -0
  24. package/dist/cjs/components/ExportToExcelButton/types.d.ts +44 -0
  25. package/dist/cjs/components/InputBoxWithConfirmation/InputBoxWithConfirmation.d.ts +17 -0
  26. package/dist/cjs/components/InputBoxWithConfirmation/InputBoxWithConfirmation.js +137 -0
  27. package/dist/cjs/components/InputBoxWithConfirmation/InputBoxWithConfirmation.module.scss +52 -0
  28. package/dist/cjs/components/IntegerControl/IntegerControl.d.ts +10 -0
  29. package/dist/cjs/components/IntegerControl/IntegerControl.js +52 -0
  30. package/dist/cjs/components/IntegerControl/IntegerControl.module.scss +46 -0
  31. package/dist/cjs/components/LabeledInput/LabeledInput.d.ts +15 -0
  32. package/dist/cjs/components/LabeledInput/LabeledInput.js +47 -0
  33. package/dist/cjs/components/LabeledInput/LabeledInput.module.scss +74 -0
  34. package/dist/cjs/components/Modal/Modal.css +43 -0
  35. package/dist/cjs/components/Modal/Modal.d.ts +5 -0
  36. package/dist/cjs/components/Modal/Modal.js +82 -0
  37. package/dist/cjs/components/Modal/types.d.ts +8 -0
  38. package/dist/cjs/components/Multicalendar/Multicalendar.css +191 -0
  39. package/dist/cjs/components/Multicalendar/Multicalendar.d.ts +5 -0
  40. package/dist/cjs/components/Multicalendar/Multicalendar.js +369 -0
  41. package/dist/cjs/components/Multicalendar/MulticalendarOwnFunctions.d.ts +86 -0
  42. package/dist/cjs/components/Multicalendar/MulticalendarOwnFunctions.js +192 -0
  43. package/dist/cjs/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.css +5 -0
  44. package/dist/cjs/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.d.ts +5 -0
  45. package/dist/cjs/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.js +20 -0
  46. package/dist/cjs/components/Multicalendar/subcomponents/composites/CellsRow/types.d.ts +11 -0
  47. package/dist/cjs/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.css +6 -0
  48. package/dist/cjs/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.d.ts +5 -0
  49. package/dist/cjs/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.js +20 -0
  50. package/dist/cjs/components/Multicalendar/subcomponents/composites/DatesGrid/types.d.ts +13 -0
  51. package/dist/cjs/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.css +3 -0
  52. package/dist/cjs/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.d.ts +5 -0
  53. package/dist/cjs/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.js +15 -0
  54. package/dist/cjs/components/Multicalendar/subcomponents/composites/ListElementsColumn/types.d.ts +9 -0
  55. package/dist/cjs/components/Multicalendar/subcomponents/individuals/Cell/Cell.css +6 -0
  56. package/dist/cjs/components/Multicalendar/subcomponents/individuals/Cell/Cell.d.ts +5 -0
  57. package/dist/cjs/components/Multicalendar/subcomponents/individuals/Cell/Cell.js +12 -0
  58. package/dist/cjs/components/Multicalendar/subcomponents/individuals/Cell/types.d.ts +10 -0
  59. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.css +60 -0
  60. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.d.ts +5 -0
  61. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.js +56 -0
  62. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DatesRow/types.d.ts +11 -0
  63. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.css +14 -0
  64. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.d.ts +5 -0
  65. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.js +13 -0
  66. package/dist/cjs/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/types.d.ts +6 -0
  67. package/dist/cjs/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.css +14 -0
  68. package/dist/cjs/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.d.ts +5 -0
  69. package/dist/cjs/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.js +14 -0
  70. package/dist/cjs/components/Multicalendar/subcomponents/individuals/ListElement/types.d.ts +7 -0
  71. package/dist/cjs/components/Multicalendar/types.d.ts +48 -0
  72. package/dist/cjs/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.css +40 -0
  73. package/dist/cjs/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.d.ts +5 -0
  74. package/dist/cjs/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.js +48 -0
  75. package/dist/cjs/components/MultipleJoinedButtonsBar/types.d.ts +6 -0
  76. package/dist/cjs/components/ParallelSelectionList/ParallelSelectionList.css +244 -0
  77. package/dist/cjs/components/ParallelSelectionList/ParallelSelectionList.d.ts +5 -0
  78. package/dist/cjs/components/ParallelSelectionList/ParallelSelectionList.js +147 -0
  79. package/dist/cjs/components/ParallelSelectionList/types.d.ts +22 -0
  80. package/dist/cjs/components/PopUp/PopUp.css +15 -0
  81. package/dist/cjs/components/PopUp/PopUp.d.ts +5 -0
  82. package/dist/cjs/components/PopUp/PopUp.js +50 -0
  83. package/dist/cjs/components/PopUp/types.d.ts +9 -0
  84. package/dist/cjs/components/ProgressBar/ProgressBar.css +39 -0
  85. package/dist/cjs/components/ProgressBar/ProgressBar.d.ts +5 -0
  86. package/dist/cjs/components/ProgressBar/ProgressBar.js +56 -0
  87. package/dist/cjs/components/ProgressBar/types.d.ts +7 -0
  88. package/dist/cjs/components/ScreenSteps/ScreenSteps.d.ts +14 -0
  89. package/dist/cjs/components/ScreenSteps/ScreenSteps.js +66 -0
  90. package/dist/cjs/components/ScreenSteps/ScreenSteps.module.scss +68 -0
  91. package/dist/cjs/components/ScrollSnapGallery/ScrollSnapGallery.d.ts +14 -0
  92. package/dist/cjs/components/ScrollSnapGallery/ScrollSnapGallery.js +98 -0
  93. package/dist/cjs/components/ScrollSnapGallery/ScrollSnapGallery.module.scss +67 -0
  94. package/dist/cjs/components/SearchBar/SearchBar.css +35 -0
  95. package/dist/cjs/components/SearchBar/SearchBar.d.ts +5 -0
  96. package/dist/cjs/components/SearchBar/SearchBar.js +54 -0
  97. package/dist/cjs/components/SearchBar/types.d.ts +10 -0
  98. package/dist/cjs/components/SideBar/SideBar.css +53 -0
  99. package/dist/cjs/components/SideBar/SideBar.d.ts +8 -0
  100. package/dist/cjs/components/SideBar/SideBar.js +70 -0
  101. package/dist/cjs/components/SideBar/types.d.ts +8 -0
  102. package/dist/cjs/components/Slider/Slider.css +55 -0
  103. package/dist/cjs/components/Slider/Slider.d.ts +5 -0
  104. package/dist/cjs/components/Slider/Slider.js +173 -0
  105. package/dist/cjs/components/Slider/SliderOwnFunctions.d.ts +2 -0
  106. package/dist/cjs/components/Slider/SliderOwnFunctions.js +11 -0
  107. package/dist/cjs/components/Slider/types.d.ts +14 -0
  108. package/dist/cjs/hooks/useIntersectionObserver.d.ts +9 -0
  109. package/dist/cjs/hooks/useIntersectionObserver.js +28 -0
  110. package/dist/cjs/hooks/useOutsideClick.d.ts +3 -0
  111. package/dist/cjs/hooks/useOutsideClick.js +19 -0
  112. package/dist/cjs/hooks/useResizeObserver.d.ts +7 -0
  113. package/dist/cjs/hooks/useResizeObserver.js +30 -0
  114. package/dist/cjs/hooks/useWindowsSize.d.ts +6 -0
  115. package/dist/cjs/hooks/useWindowsSize.js +20 -0
  116. package/dist/cjs/index.css +79 -0
  117. package/dist/cjs/index.d.ts +20 -0
  118. package/dist/cjs/index.js +45 -0
  119. package/dist/cjs/languages/en-EN.d.ts +3 -0
  120. package/dist/cjs/languages/en-EN.js +25 -0
  121. package/dist/cjs/languages/es-ES.d.ts +3 -0
  122. package/dist/cjs/languages/es-ES.js +25 -0
  123. package/dist/cjs/languages/it-IT.d.ts +3 -0
  124. package/dist/cjs/languages/it-IT.js +25 -0
  125. package/dist/cjs/languages/types.d.ts +22 -0
  126. package/dist/cjs/mocks/ReactComponentMocksForTesting/CellChildrenMock.d.ts +4 -0
  127. package/dist/cjs/mocks/ReactComponentMocksForTesting/CellChildrenMock.js +13 -0
  128. package/dist/cjs/mocks/ReactComponentMocksForTesting/ListElementChildrenMock.d.ts +4 -0
  129. package/dist/cjs/mocks/ReactComponentMocksForTesting/ListElementChildrenMock.js +10 -0
  130. package/dist/cjs/react-app-env.d.ts +1 -0
  131. package/dist/cjs/setupTests.d.ts +2 -0
  132. package/dist/cjs/setupTests.js +8 -0
  133. package/dist/cjs/stories/CalendarDatePickerMask.d.ts +4 -0
  134. package/dist/cjs/stories/CalendarDatePickerMask.js +21 -0
  135. package/dist/cjs/utils/datesArray.d.ts +8 -0
  136. package/dist/cjs/utils/datesArray.js +23 -0
  137. package/dist/cjs/utils/dayOfTheWeekStartingOnMonday.d.ts +7 -0
  138. package/dist/cjs/utils/dayOfTheWeekStartingOnMonday.js +11 -0
  139. package/dist/cjs/utils/jsToSqlDate.d.ts +7 -0
  140. package/dist/cjs/utils/jsToSqlDate.js +22 -0
  141. package/dist/cjs/utils/monthYearString.d.ts +3 -0
  142. package/dist/cjs/utils/monthYearString.js +27 -0
  143. package/dist/cjs/utils/numberOfDaysInAMonth.d.ts +6 -0
  144. package/dist/cjs/utils/numberOfDaysInAMonth.js +12 -0
  145. package/dist/cjs/utils/numberOfWeeksInAMonth.d.ts +7 -0
  146. package/dist/cjs/utils/numberOfWeeksInAMonth.js +25 -0
  147. package/dist/cjs/utils/sqlToJsDate.d.ts +7 -0
  148. package/dist/cjs/utils/sqlToJsDate.js +14 -0
  149. package/dist/esm/Services/MulticalendarStatesAndSettings.d.ts +34 -0
  150. package/dist/esm/Services/MulticalendarStatesAndSettings.js +46 -0
  151. package/dist/esm/Services/accessToken.d.ts +3 -0
  152. package/dist/esm/Services/accessToken.js +9 -0
  153. package/dist/esm/common/constants.d.ts +5 -0
  154. package/dist/esm/common/constants.js +5 -0
  155. package/dist/esm/common/turboSuiteUrls.d.ts +7 -0
  156. package/dist/esm/common/turboSuiteUrls.js +7 -0
  157. package/dist/esm/common/types.d.ts +113 -0
  158. package/dist/esm/components/BubbleMenu/BubbleMenu.d.ts +12 -0
  159. package/dist/esm/components/BubbleMenu/BubbleMenu.js +32 -0
  160. package/dist/esm/components/BubbleMenu/BubbleMenu.module.scss +113 -0
  161. package/dist/esm/components/CalendarDatePicker/CalendarDatePicker.d.ts +19 -0
  162. package/dist/esm/components/CalendarDatePicker/CalendarDatePicker.js +163 -0
  163. package/dist/esm/components/CalendarDatePicker/CalendarDatePicker.module.scss +104 -0
  164. package/dist/esm/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.d.ts +15 -0
  165. package/dist/esm/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.js +272 -0
  166. package/dist/esm/components/CalendarDatePicker/subcomponents/CalendarScrollableSection.module.scss +151 -0
  167. package/dist/esm/components/ExportToExcelButton/ExportToExcelButton.css +31 -0
  168. package/dist/esm/components/ExportToExcelButton/ExportToExcelButton.d.ts +5 -0
  169. package/dist/esm/components/ExportToExcelButton/ExportToExcelButton.js +17 -0
  170. package/dist/esm/components/ExportToExcelButton/ExportToExcelButtonOwnFunctions.d.ts +6 -0
  171. package/dist/esm/components/ExportToExcelButton/ExportToExcelButtonOwnFunctions.js +48 -0
  172. package/dist/esm/components/ExportToExcelButton/types.d.ts +44 -0
  173. package/dist/esm/components/InputBoxWithConfirmation/InputBoxWithConfirmation.d.ts +17 -0
  174. package/dist/esm/components/InputBoxWithConfirmation/InputBoxWithConfirmation.js +109 -0
  175. package/dist/esm/components/InputBoxWithConfirmation/InputBoxWithConfirmation.module.scss +52 -0
  176. package/dist/esm/components/IntegerControl/IntegerControl.d.ts +10 -0
  177. package/dist/esm/components/IntegerControl/IntegerControl.js +24 -0
  178. package/dist/esm/components/IntegerControl/IntegerControl.module.scss +46 -0
  179. package/dist/esm/components/LabeledInput/LabeledInput.d.ts +15 -0
  180. package/dist/esm/components/LabeledInput/LabeledInput.js +19 -0
  181. package/dist/esm/components/LabeledInput/LabeledInput.module.scss +74 -0
  182. package/dist/esm/components/Modal/Modal.css +43 -0
  183. package/dist/esm/components/Modal/Modal.d.ts +5 -0
  184. package/dist/esm/components/Modal/Modal.js +54 -0
  185. package/dist/esm/components/Modal/types.d.ts +8 -0
  186. package/dist/esm/components/Multicalendar/Multicalendar.css +191 -0
  187. package/dist/esm/components/Multicalendar/Multicalendar.d.ts +5 -0
  188. package/dist/esm/components/Multicalendar/Multicalendar.js +341 -0
  189. package/dist/esm/components/Multicalendar/MulticalendarOwnFunctions.d.ts +86 -0
  190. package/dist/esm/components/Multicalendar/MulticalendarOwnFunctions.js +176 -0
  191. package/dist/esm/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.css +5 -0
  192. package/dist/esm/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.d.ts +5 -0
  193. package/dist/esm/components/Multicalendar/subcomponents/composites/CellsRow/CellsRow.js +15 -0
  194. package/dist/esm/components/Multicalendar/subcomponents/composites/CellsRow/types.d.ts +11 -0
  195. package/dist/esm/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.css +6 -0
  196. package/dist/esm/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.d.ts +5 -0
  197. package/dist/esm/components/Multicalendar/subcomponents/composites/DatesGrid/DatesGrid.js +15 -0
  198. package/dist/esm/components/Multicalendar/subcomponents/composites/DatesGrid/types.d.ts +13 -0
  199. package/dist/esm/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.css +3 -0
  200. package/dist/esm/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.d.ts +5 -0
  201. package/dist/esm/components/Multicalendar/subcomponents/composites/ListElementsColumn/ListElementsColumn.js +10 -0
  202. package/dist/esm/components/Multicalendar/subcomponents/composites/ListElementsColumn/types.d.ts +9 -0
  203. package/dist/esm/components/Multicalendar/subcomponents/individuals/Cell/Cell.css +6 -0
  204. package/dist/esm/components/Multicalendar/subcomponents/individuals/Cell/Cell.d.ts +5 -0
  205. package/dist/esm/components/Multicalendar/subcomponents/individuals/Cell/Cell.js +7 -0
  206. package/dist/esm/components/Multicalendar/subcomponents/individuals/Cell/types.d.ts +10 -0
  207. package/dist/esm/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.css +60 -0
  208. package/dist/esm/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.d.ts +5 -0
  209. package/dist/esm/components/Multicalendar/subcomponents/individuals/DatesRow/DatesRow.js +51 -0
  210. package/dist/esm/components/Multicalendar/subcomponents/individuals/DatesRow/types.d.ts +11 -0
  211. package/dist/esm/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.css +14 -0
  212. package/dist/esm/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.d.ts +5 -0
  213. package/dist/esm/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/DropdownMonthNavigation.js +8 -0
  214. package/dist/esm/components/Multicalendar/subcomponents/individuals/DropdownMonthNavigation/types.d.ts +6 -0
  215. package/dist/esm/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.css +14 -0
  216. package/dist/esm/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.d.ts +5 -0
  217. package/dist/esm/components/Multicalendar/subcomponents/individuals/ListElement/ListElement.js +9 -0
  218. package/dist/esm/components/Multicalendar/subcomponents/individuals/ListElement/types.d.ts +7 -0
  219. package/dist/esm/components/Multicalendar/types.d.ts +48 -0
  220. package/dist/esm/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.css +40 -0
  221. package/dist/esm/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.d.ts +5 -0
  222. package/dist/esm/components/MultipleJoinedButtonsBar/MultipleJoinedButtonsBar.js +23 -0
  223. package/dist/esm/components/MultipleJoinedButtonsBar/types.d.ts +6 -0
  224. package/dist/esm/components/ParallelSelectionList/ParallelSelectionList.css +244 -0
  225. package/dist/esm/components/ParallelSelectionList/ParallelSelectionList.d.ts +5 -0
  226. package/dist/esm/components/ParallelSelectionList/ParallelSelectionList.js +142 -0
  227. package/dist/esm/components/ParallelSelectionList/types.d.ts +22 -0
  228. package/dist/esm/components/PopUp/PopUp.css +15 -0
  229. package/dist/esm/components/PopUp/PopUp.d.ts +5 -0
  230. package/dist/esm/components/PopUp/PopUp.js +22 -0
  231. package/dist/esm/components/PopUp/types.d.ts +9 -0
  232. package/dist/esm/components/ProgressBar/ProgressBar.css +39 -0
  233. package/dist/esm/components/ProgressBar/ProgressBar.d.ts +5 -0
  234. package/dist/esm/components/ProgressBar/ProgressBar.js +31 -0
  235. package/dist/esm/components/ProgressBar/types.d.ts +7 -0
  236. package/dist/esm/components/ScreenSteps/ScreenSteps.d.ts +14 -0
  237. package/dist/esm/components/ScreenSteps/ScreenSteps.js +38 -0
  238. package/dist/esm/components/ScreenSteps/ScreenSteps.module.scss +68 -0
  239. package/dist/esm/components/ScrollSnapGallery/ScrollSnapGallery.d.ts +14 -0
  240. package/dist/esm/components/ScrollSnapGallery/ScrollSnapGallery.js +70 -0
  241. package/dist/esm/components/ScrollSnapGallery/ScrollSnapGallery.module.scss +67 -0
  242. package/dist/esm/components/SearchBar/SearchBar.css +35 -0
  243. package/dist/esm/components/SearchBar/SearchBar.d.ts +5 -0
  244. package/dist/esm/components/SearchBar/SearchBar.js +29 -0
  245. package/dist/esm/components/SearchBar/types.d.ts +10 -0
  246. package/dist/esm/components/SideBar/SideBar.css +53 -0
  247. package/dist/esm/components/SideBar/SideBar.d.ts +8 -0
  248. package/dist/esm/components/SideBar/SideBar.js +42 -0
  249. package/dist/esm/components/SideBar/types.d.ts +8 -0
  250. package/dist/esm/components/Slider/Slider.css +55 -0
  251. package/dist/esm/components/Slider/Slider.d.ts +5 -0
  252. package/dist/esm/components/Slider/Slider.js +148 -0
  253. package/dist/esm/components/Slider/SliderOwnFunctions.d.ts +2 -0
  254. package/dist/esm/components/Slider/SliderOwnFunctions.js +6 -0
  255. package/dist/esm/components/Slider/types.d.ts +14 -0
  256. package/dist/esm/hooks/useIntersectionObserver.d.ts +9 -0
  257. package/dist/esm/hooks/useIntersectionObserver.js +26 -0
  258. package/dist/esm/hooks/useOutsideClick.d.ts +3 -0
  259. package/dist/esm/hooks/useOutsideClick.js +17 -0
  260. package/dist/esm/hooks/useResizeObserver.d.ts +7 -0
  261. package/dist/esm/hooks/useResizeObserver.js +28 -0
  262. package/dist/esm/hooks/useWindowsSize.d.ts +6 -0
  263. package/dist/esm/hooks/useWindowsSize.js +18 -0
  264. package/dist/esm/index.css +79 -0
  265. package/dist/esm/index.d.ts +20 -0
  266. package/dist/esm/index.js +19 -0
  267. package/dist/esm/languages/en-EN.d.ts +3 -0
  268. package/dist/esm/languages/en-EN.js +23 -0
  269. package/dist/esm/languages/es-ES.d.ts +3 -0
  270. package/dist/esm/languages/es-ES.js +23 -0
  271. package/dist/esm/languages/it-IT.d.ts +3 -0
  272. package/dist/esm/languages/it-IT.js +23 -0
  273. package/dist/esm/languages/types.d.ts +22 -0
  274. package/dist/esm/mocks/ReactComponentMocksForTesting/CellChildrenMock.d.ts +4 -0
  275. package/dist/esm/mocks/ReactComponentMocksForTesting/CellChildrenMock.js +8 -0
  276. package/dist/esm/mocks/ReactComponentMocksForTesting/ListElementChildrenMock.d.ts +4 -0
  277. package/dist/esm/mocks/ReactComponentMocksForTesting/ListElementChildrenMock.js +5 -0
  278. package/dist/esm/react-app-env.d.ts +1 -0
  279. package/dist/esm/setupTests.d.ts +2 -0
  280. package/dist/esm/setupTests.js +6 -0
  281. package/dist/esm/stories/CalendarDatePickerMask.d.ts +4 -0
  282. package/dist/esm/stories/CalendarDatePickerMask.js +16 -0
  283. package/dist/esm/utils/datesArray.d.ts +8 -0
  284. package/dist/esm/utils/datesArray.js +21 -0
  285. package/dist/esm/utils/dayOfTheWeekStartingOnMonday.d.ts +7 -0
  286. package/dist/esm/utils/dayOfTheWeekStartingOnMonday.js +9 -0
  287. package/dist/esm/utils/jsToSqlDate.d.ts +7 -0
  288. package/dist/esm/utils/jsToSqlDate.js +20 -0
  289. package/dist/esm/utils/monthYearString.d.ts +3 -0
  290. package/dist/esm/utils/monthYearString.js +25 -0
  291. package/dist/esm/utils/numberOfDaysInAMonth.d.ts +6 -0
  292. package/dist/esm/utils/numberOfDaysInAMonth.js +8 -0
  293. package/dist/esm/utils/numberOfWeeksInAMonth.d.ts +7 -0
  294. package/dist/esm/utils/numberOfWeeksInAMonth.js +20 -0
  295. package/dist/esm/utils/sqlToJsDate.d.ts +7 -0
  296. package/dist/esm/utils/sqlToJsDate.js +12 -0
  297. package/package.json +10 -22
  298. package/dist/index.d.ts +0 -1
  299. package/dist/index.mjs +0 -20188
  300. package/dist/index.umd.js +0 -196
  301. package/dist/style.css +0 -1
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import "./ListElement.css";
3
+ import { ListElementPropsType } from "./types";
4
+ declare const _default: React.MemoExoticComponent<({ listElementId, ReactListElementChildren, height, }: ListElementPropsType) => React.JSX.Element>;
5
+ export default _default;
@@ -0,0 +1,14 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ require("./ListElement.css");
8
+ const ListElement = ({ listElementId, ReactListElementChildren, height, }) => {
9
+ return (react_1.default.createElement("div", { className: "list-element", style: {
10
+ height: height,
11
+ } },
12
+ react_1.default.createElement(ReactListElementChildren, { listElementId: listElementId })));
13
+ };
14
+ exports.default = react_1.default.memo(ListElement);
@@ -0,0 +1,7 @@
1
+ import { ReactListElementChildrenType } from "../../../types";
2
+
3
+ export interface ListElementPropsType {
4
+ listElementId: string | number;
5
+ ReactListElementChildren: ReactListElementChildrenType;
6
+ height: number;
7
+ }
@@ -0,0 +1,48 @@
1
+ import { languageType } from "../../languages/types";
2
+
3
+ export interface MulticalendarPropsType {
4
+ multicalendarId: string;
5
+ ReactCellChildren: ReactCellChildrenType;
6
+ ReactListElementChildren: ReactListElementChildrenType;
7
+ listElementsIdsArray: string[] | number[];
8
+ language: languageType;
9
+ pastDatesVisible?: boolean;
10
+ cellsWidth?: number;
11
+ cellsHeight?: number;
12
+ verticalAxisWidth?: number;
13
+ horizontalAxisHeight?: number;
14
+ pastDaysInitialQuantity?: number;
15
+ futureDaysInitialQuantity?: number;
16
+ chunkRenderX?: number;
17
+ chunkRenderY?: number;
18
+ authomaticScrollOnDraggingOverEdges?: boolean;
19
+ dynamicDaysQuantity?: boolean;
20
+ waitTimeForCalls?: number;
21
+ callsOnInitialView?: (visibleIds: string[] | number[], visibleDates: Date[]) => void;
22
+ callsOnScrollingStops?: (visibleIds: string[] | number[], visibleDates: Date[]) => void;
23
+ aditionalControlsComponents?: JSX.Element | JSX.Element[];
24
+ upperLeftComponent?: JSX.Element;
25
+ autoSavePosition?: boolean;
26
+ onScrollTopChanges?: (scrollTop: number) => void
27
+ onScrollLeftChanges?: (scrollLeft: number) => void
28
+ }
29
+
30
+ export interface RenderCoordinatesType {
31
+ x: number;
32
+ y: number;
33
+ }
34
+
35
+ export type ReactCellChildrenType = React.ElementType<CellChildrenPropsType>;
36
+
37
+ export type ReactListElementChildrenType =
38
+ React.ElementType<ListElementChildrenPropsType>;
39
+
40
+ export type CellChildrenPropsType = { [key: string]: any } & {
41
+ /**Date in SQL format, i.e. 1993-03-29 */
42
+ date: string;
43
+ listElementId: string | number;
44
+ };
45
+
46
+ export type ListElementChildrenPropsType = { [key: string]: any } & {
47
+ listElementId: string | number;
48
+ };
@@ -0,0 +1,40 @@
1
+ .trc-multiple-joined-buttons-bar {
2
+ display: flex;
3
+ align-items: stretch;
4
+ justify-content: center;
5
+ }
6
+
7
+ .trc-multiple-joined-buttons-bar button {
8
+ border: var(--primary-color) solid 2px;
9
+ border-left-width: 1px;
10
+ border-right-width: 1px;
11
+ color: var(--primary-color);
12
+ background-color: rgb(255, 255, 255);
13
+ padding: 5px 15px;
14
+ box-sizing: border-box;
15
+ font-weight: 600;
16
+ font-size: 16px;
17
+ cursor: pointer;
18
+ transition: all 0.3s;
19
+ }
20
+
21
+ .trc-multiple-joined-buttons-bar button:hover {
22
+ background-color: rgb(240, 240, 240);
23
+ }
24
+
25
+ .trc-multiple-joined-buttons-bar button.selected {
26
+ background-color: var(--primary-color);
27
+ color: white;
28
+ }
29
+
30
+ .trc-multiple-joined-buttons-bar button.left-side-button {
31
+ border-left-width: 2px;
32
+ border-top-left-radius: 6px;
33
+ border-bottom-left-radius: 6px;
34
+ }
35
+
36
+ .trc-multiple-joined-buttons-bar button.right-side-button {
37
+ border-right-width: 2px;
38
+ border-top-right-radius: 6px;
39
+ border-bottom-right-radius: 6px;
40
+ }
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import "./MultipleJoinedButtonsBar.css";
3
+ import { MultipleJoinedButtonsBarPropsType } from "./types";
4
+ declare const MultipleJoinedButtonsBar: ({ options, onSelectOption, initialSelectedValue, externalSelectedValue, }: MultipleJoinedButtonsBarPropsType<any>) => React.JSX.Element;
5
+ export default MultipleJoinedButtonsBar;
@@ -0,0 +1,48 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ Object.defineProperty(exports, "__esModule", { value: true });
26
+ const react_1 = __importStar(require("react"));
27
+ require("./MultipleJoinedButtonsBar.css");
28
+ const MultipleJoinedButtonsBar = ({ options, onSelectOption, initialSelectedValue, externalSelectedValue, }) => {
29
+ //States
30
+ const [selectedValue, setSelectedValue] = (0, react_1.useState)(initialSelectedValue);
31
+ //Effects
32
+ (0, react_1.useEffect)(() => {
33
+ if (externalSelectedValue &&
34
+ options.map((option) => option._id).includes(externalSelectedValue)) {
35
+ setSelectedValue(externalSelectedValue);
36
+ }
37
+ }, [externalSelectedValue]);
38
+ return (react_1.default.createElement("div", { className: "trc-multiple-joined-buttons-bar" }, options.map((option, index) => (react_1.default.createElement("button", { key: option._id, className: (selectedValue === option._id ? "selected" : "") +
39
+ (index === 0
40
+ ? " left-side-button"
41
+ : index === options.length - 1
42
+ ? " right-side-button"
43
+ : ""), onClick: () => {
44
+ setSelectedValue(option._id);
45
+ onSelectOption(option._id);
46
+ } }, option.visibleValue)))));
47
+ };
48
+ exports.default = MultipleJoinedButtonsBar;
@@ -0,0 +1,6 @@
1
+ export interface MultipleJoinedButtonsBarPropsType<T> {
2
+ options: { _id: T; visibleValue: string }[];
3
+ onSelectOption: (selectedValue: T) => void;
4
+ initialSelectedValue?: T;
5
+ externalSelectedValue?: T;
6
+ }
@@ -0,0 +1,244 @@
1
+ .trc-parallel-selection-list {
2
+ display: flex;
3
+ flex-direction: column;
4
+ justify-content: center;
5
+ align-items: center;
6
+ height: 100%;
7
+ }
8
+
9
+ .trc-parallel-selection-list .div-lists {
10
+ display: flex;
11
+ align-items: center;
12
+ justify-content: center;
13
+ width: 100%;
14
+ flex-grow: 1;
15
+ min-height: calc(100% - 80px);
16
+ max-height: 100%;
17
+ }
18
+
19
+ .trc-parallel-selection-list .div-lists .div-left-list {
20
+ grid-area: lef;
21
+ display: flex;
22
+ flex-flow: column;
23
+ align-items: center;
24
+ box-sizing: border-box;
25
+ padding: 10px;
26
+ width: 50%;
27
+ height: 100%;
28
+ }
29
+
30
+ .trc-parallel-selection-list .div-lists .div-right-list {
31
+ grid-area: rig;
32
+ display: flex;
33
+ flex-flow: column;
34
+ align-items: center;
35
+ box-sizing: border-box;
36
+ padding: 10px;
37
+ width: 50%;
38
+ height: 100%;
39
+ }
40
+
41
+ .trc-parallel-selection-list .div-action-buttons {
42
+ grid-area: but;
43
+ display: flex;
44
+ align-items: center;
45
+ justify-content: space-between;
46
+ box-sizing: border-box;
47
+ padding: 10px 20px;
48
+ width: 100%;
49
+ height: 80px;
50
+ }
51
+
52
+ .trc-parallel-selection-list .list-title {
53
+ font-size: 20px;
54
+ font-weight: 600;
55
+ color: dimgray;
56
+ height: 30px;
57
+ display: flex;
58
+ align-items: center;
59
+ justify-content: center;
60
+ }
61
+
62
+ .trc-parallel-selection-list .div-search-bar {
63
+ width: 100%;
64
+ border: 1px solid rgb(185, 185, 185);
65
+ border-top-left-radius: 6px;
66
+ border-top-right-radius: 6px;
67
+ padding: 6px;
68
+ height: 30px;
69
+ box-sizing: border-box;
70
+ color: dimgray;
71
+ display: flex;
72
+ align-items: center;
73
+ justify-content: center;
74
+ }
75
+
76
+ .trc-parallel-selection-list .div-search-bar input {
77
+ border: none;
78
+ padding-left: 10px;
79
+ width: 100%;
80
+ }
81
+
82
+ .trc-parallel-selection-list .div-search-bar input:focus {
83
+ outline: none;
84
+ }
85
+
86
+ .trc-parallel-selection-list .list-container {
87
+ width: 100%;
88
+ display: flex;
89
+ flex-flow: column;
90
+ box-sizing: border-box;
91
+ border: 1px solid rgb(169, 169, 169);
92
+ border-bottom-left-radius: 6px;
93
+ border-bottom-right-radius: 6px;
94
+ border-top: none;
95
+ height: calc(100% - 60px);
96
+ }
97
+
98
+ .trc-parallel-selection-list .list-container .apply-all-button {
99
+ display: flex;
100
+ align-items: center;
101
+ justify-content: center;
102
+ width: 100%;
103
+ height: 30px;
104
+ border: none;
105
+ background-color: transparent;
106
+ color: dimgray;
107
+ font-weight: 700;
108
+ border-bottom: 1px solid rgb(169, 169, 169);
109
+ box-sizing: border-box;
110
+ padding: 5px 0;
111
+ transition: all 0.3s;
112
+ cursor: pointer;
113
+ }
114
+
115
+ .trc-parallel-selection-list .list-container .apply-all-button svg {
116
+ width: 20px;
117
+ height: 20px;
118
+ }
119
+
120
+ .trc-parallel-selection-list .list-container .apply-all-button:hover {
121
+ background-color: rgb(238, 238, 238);
122
+ }
123
+
124
+ .trc-parallel-selection-list .list-container .scrollable-section {
125
+ overflow-y: auto;
126
+ height: calc(100% - 30px);
127
+ }
128
+
129
+ .trc-parallel-selection-list
130
+ .list-container
131
+ .scrollable-section
132
+ .resizable-div-for-scroll {
133
+ width: 100%;
134
+ box-sizing: border-box;
135
+ }
136
+
137
+ .trc-parallel-selection-list
138
+ .list-container
139
+ .scrollable-section
140
+ .resizable-div-for-scroll
141
+ .div-datum-wrapper {
142
+ width: 100%;
143
+ display: flex;
144
+ justify-content: space-between;
145
+ align-items: center;
146
+ border-bottom: 1px solid rgb(169, 169, 169);
147
+ }
148
+
149
+ .trc-parallel-selection-list
150
+ .list-container
151
+ .scrollable-section
152
+ .resizable-div-for-scroll
153
+ .div-datum-wrapper
154
+ .div-custom-component-wrapper {
155
+ position: relative;
156
+ height: 100%;
157
+ width: calc(100% - 50px);
158
+ display: flex;
159
+ align-items: center;
160
+ justify-content: center;
161
+ overflow: hidden;
162
+ }
163
+
164
+ .trc-parallel-selection-list
165
+ .list-container
166
+ .scrollable-section
167
+ .resizable-div-for-scroll
168
+ .div-datum-wrapper
169
+ .visible-default-name {
170
+ box-sizing: border-box;
171
+ padding: 17px 10px;
172
+ font-size: 16px;
173
+ font-weight: 600;
174
+ color: dimgray;
175
+ height: 50px;
176
+ white-space: nowrap;
177
+ text-overflow: ellipsis;
178
+ overflow: hidden;
179
+ width: calc(100% - 50px);
180
+ text-align: start;
181
+ }
182
+
183
+ .trc-parallel-selection-list
184
+ .list-container
185
+ .scrollable-section
186
+ .resizable-div-for-scroll
187
+ .div-datum-wrapper
188
+ .apply-to-one-button {
189
+ height: 30px;
190
+ width: 30px;
191
+ display: flex;
192
+ align-items: center;
193
+ justify-content: center;
194
+ margin: 10px;
195
+ background-color: transparent;
196
+ border: none;
197
+ border-radius: 15px;
198
+ transition: all 0.3s;
199
+ cursor: pointer;
200
+ }
201
+
202
+ .trc-parallel-selection-list
203
+ .list-container
204
+ .scrollable-section
205
+ .resizable-div-for-scroll
206
+ .div-datum-wrapper
207
+ .apply-to-one-button:hover {
208
+ background-color: rgb(238, 238, 238);
209
+ }
210
+
211
+ .trc-parallel-selection-list .div-action-buttons button {
212
+ box-sizing: border-box;
213
+ padding: 10px 15px;
214
+ display: flex;
215
+ align-items: center;
216
+ justify-content: center;
217
+ background-color: transparent;
218
+ border: solid 2px;
219
+ border-radius: 6px;
220
+ font-size: 16px;
221
+ font-weight: 600;
222
+ transition: all 0.3s;
223
+ cursor: pointer;
224
+ }
225
+
226
+ .trc-parallel-selection-list .div-action-buttons .cancel-button {
227
+ border-color: dimgray;
228
+ color: dimgray;
229
+ }
230
+
231
+ .trc-parallel-selection-list .div-action-buttons .cancel-button:hover {
232
+ background-color: dimgray;
233
+ color: white;
234
+ }
235
+
236
+ .trc-parallel-selection-list .div-action-buttons .apply-button {
237
+ border-color: var(--primary-color);
238
+ color: var(--primary-color);
239
+ }
240
+
241
+ .trc-parallel-selection-list .div-action-buttons .apply-button:hover {
242
+ background-color: var(--primary-color);
243
+ color: white;
244
+ }
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import "./ParallelSelectionList.css";
3
+ import { ParallelSelectionListPropsTypes } from "./types";
4
+ declare const ParallelSelectionList: ({ dataList, applyAction, cancelAction, onSelectionChange, leftListTitle, rightListTitle, leftListApplyAllButtonText, rightListApplyAllButtonText, searchBarsVisible, applyButtonText, cancelButtonText, preSelectedDatumsIds, listElementsHeight, }: ParallelSelectionListPropsTypes) => React.JSX.Element;
5
+ export default ParallelSelectionList;
@@ -0,0 +1,147 @@
1
+ "use strict";
2
+ var __importDefault = (this && this.__importDefault) || function (mod) {
3
+ return (mod && mod.__esModule) ? mod : { "default": mod };
4
+ };
5
+ Object.defineProperty(exports, "__esModule", { value: true });
6
+ const react_1 = __importDefault(require("react"));
7
+ const react_2 = require("react");
8
+ require("./ParallelSelectionList.css");
9
+ //Icons
10
+ const bs_1 = require("react-icons/bs");
11
+ //Hooks
12
+ const useResizeObserver_1 = __importDefault(require("../../hooks/useResizeObserver"));
13
+ const ParallelSelectionList = ({ dataList, applyAction, cancelAction, onSelectionChange, leftListTitle, rightListTitle, leftListApplyAllButtonText, rightListApplyAllButtonText, searchBarsVisible, applyButtonText, cancelButtonText, preSelectedDatumsIds = [], listElementsHeight = 50, }) => {
14
+ //Refs
15
+ const leftListRef = (0, react_2.useRef)(null);
16
+ const rightListRef = (0, react_2.useRef)(null);
17
+ //useState
18
+ const [selectedDatumsIds, setSelectedDatumsIds] = (0, react_2.useState)(preSelectedDatumsIds);
19
+ const [filteredLeftList, setFilteredLeftList] = (0, react_2.useState)([]);
20
+ const [filteredRightList, setFilteredRightList] = (0, react_2.useState)([]);
21
+ const [leftListFirstVisibleElementIndex, setLeftListFirstVisibleElementIndex] = (0, react_2.useState)(0);
22
+ const [leftListLastVisibleElementIndex, setLeftListLastVisibleElementIndex] = (0, react_2.useState)(0);
23
+ const [rightListFirstVisibleElementIndex, setRightListFirstVisibleElementIndex] = (0, react_2.useState)(0);
24
+ const [rightListLastVisibleElementIndex, setRightListLastVisibleElementIndex] = (0, react_2.useState)(0);
25
+ const [leftListSearchValue, setLeftListSearchValue] = (0, react_2.useState)("");
26
+ const [rightListSearchValue, setRightListSearchValue] = (0, react_2.useState)("");
27
+ //hooks
28
+ const [leftListWidth, leftListHeight] = (0, useResizeObserver_1.default)(leftListRef);
29
+ const [rightListWidth, rightListHeight] = (0, useResizeObserver_1.default)(rightListRef);
30
+ //Functions
31
+ const addToSelectedDatumsIds = (datumIdsArray) => {
32
+ const selectedDatumsIdsClone = [...selectedDatumsIds];
33
+ datumIdsArray.forEach((datumId) => {
34
+ if (!selectedDatumsIds.includes(datumId)) {
35
+ selectedDatumsIdsClone.push(datumId);
36
+ }
37
+ });
38
+ setSelectedDatumsIds(selectedDatumsIdsClone);
39
+ };
40
+ const removeFromSelectedDatumsIds = (datumIdsArray) => {
41
+ const selectedDatumsIdsClone = [...selectedDatumsIds];
42
+ datumIdsArray.forEach((datumId) => {
43
+ if (selectedDatumsIds.includes(datumId)) {
44
+ selectedDatumsIdsClone.splice(selectedDatumsIdsClone.indexOf(datumId), 1);
45
+ }
46
+ });
47
+ setSelectedDatumsIds(selectedDatumsIdsClone);
48
+ };
49
+ //useEffects
50
+ (0, react_2.useEffect)(() => {
51
+ let dataListClone = [...dataList];
52
+ dataListClone = dataListClone.filter((datum) => !selectedDatumsIds.includes(datum._id));
53
+ dataListClone = dataListClone.filter((datum) => datum.searchValue.toLowerCase().includes(leftListSearchValue.toLowerCase()));
54
+ setFilteredLeftList(dataListClone);
55
+ }, [leftListSearchValue, dataList, selectedDatumsIds]);
56
+ (0, react_2.useEffect)(() => {
57
+ let dataListClone = [...dataList];
58
+ dataListClone = dataListClone.filter((datum) => selectedDatumsIds.includes(datum._id));
59
+ dataListClone = dataListClone.filter((datum) => datum.searchValue.toLowerCase().includes(rightListSearchValue.toLowerCase()));
60
+ setFilteredRightList(dataListClone);
61
+ }, [rightListSearchValue, dataList, selectedDatumsIds]);
62
+ (0, react_2.useEffect)(() => {
63
+ if (leftListRef.current && leftListRef.current.clientHeight !== 0) {
64
+ setLeftListLastVisibleElementIndex(leftListFirstVisibleElementIndex +
65
+ Math.floor(leftListRef.current.clientHeight / listElementsHeight) +
66
+ 2);
67
+ }
68
+ else {
69
+ setLeftListLastVisibleElementIndex(filteredLeftList.length);
70
+ }
71
+ }, [
72
+ leftListHeight,
73
+ leftListWidth,
74
+ leftListFirstVisibleElementIndex,
75
+ listElementsHeight,
76
+ filteredLeftList.length,
77
+ ]);
78
+ (0, react_2.useEffect)(() => {
79
+ if (rightListRef.current && rightListRef.current.clientHeight !== 0) {
80
+ setRightListLastVisibleElementIndex(rightListFirstVisibleElementIndex +
81
+ Math.floor(rightListRef.current.clientHeight / listElementsHeight) +
82
+ 2);
83
+ }
84
+ else {
85
+ setRightListLastVisibleElementIndex(filteredRightList.length);
86
+ }
87
+ }, [
88
+ rightListHeight,
89
+ rightListWidth,
90
+ rightListFirstVisibleElementIndex,
91
+ listElementsHeight,
92
+ filteredRightList.length,
93
+ ]);
94
+ (0, react_2.useEffect)(() => {
95
+ //I know what I am doing... maybe
96
+ if (onSelectionChange) {
97
+ onSelectionChange(selectedDatumsIds);
98
+ }
99
+ // eslint-disable-next-line
100
+ }, [selectedDatumsIds]);
101
+ return (react_1.default.createElement("div", { className: "trc-parallel-selection-list" },
102
+ react_1.default.createElement("div", { className: "div-lists" },
103
+ react_1.default.createElement("div", { className: "div-left-list" },
104
+ react_1.default.createElement("p", { className: "list-title" }, leftListTitle),
105
+ searchBarsVisible && (react_1.default.createElement("div", { className: "div-search-bar" },
106
+ react_1.default.createElement(bs_1.BsSearch, null),
107
+ react_1.default.createElement("input", { type: "text", value: leftListSearchValue, onChange: (event) => setLeftListSearchValue(event.target.value) }))),
108
+ react_1.default.createElement("div", { className: "list-container" },
109
+ react_1.default.createElement("button", { className: "apply-all-button", onClick: () => addToSelectedDatumsIds(filteredLeftList.map((datum) => datum._id)) },
110
+ leftListApplyAllButtonText,
111
+ " ",
112
+ react_1.default.createElement(bs_1.BsChevronDoubleRight, null)),
113
+ react_1.default.createElement("div", { ref: leftListRef, className: "scrollable-section", onScroll: (event) => setLeftListFirstVisibleElementIndex(Math.floor(event.target.scrollTop / listElementsHeight)) },
114
+ react_1.default.createElement("div", { className: "resizable-div-for-scroll", style: {
115
+ paddingTop: leftListFirstVisibleElementIndex * listElementsHeight,
116
+ height: filteredLeftList.length * listElementsHeight,
117
+ } }, filteredLeftList
118
+ .slice(leftListFirstVisibleElementIndex, leftListLastVisibleElementIndex)
119
+ .map((datum) => (react_1.default.createElement("div", { key: datum._id, className: "div-datum-wrapper", style: { height: listElementsHeight } },
120
+ datum.customComponent ? (react_1.default.createElement("div", { className: "div-custom-component-wrapper" }, datum.customComponent)) : (react_1.default.createElement("p", { className: "visible-default-name", title: datum.visibleDefaultName }, datum.visibleDefaultName)),
121
+ react_1.default.createElement("button", { className: "apply-to-one-button", onClick: () => addToSelectedDatumsIds([datum._id]) },
122
+ react_1.default.createElement(bs_1.BsChevronRight, null))))))))),
123
+ react_1.default.createElement("div", { className: "div-right-list" },
124
+ react_1.default.createElement("p", { className: "list-title" }, rightListTitle),
125
+ searchBarsVisible && (react_1.default.createElement("div", { className: "div-search-bar" },
126
+ react_1.default.createElement(bs_1.BsSearch, null),
127
+ react_1.default.createElement("input", { type: "text", value: rightListSearchValue, onChange: (event) => setRightListSearchValue(event.target.value) }))),
128
+ react_1.default.createElement("div", { className: "list-container" },
129
+ react_1.default.createElement("button", { className: "apply-all-button", onClick: () => removeFromSelectedDatumsIds(filteredRightList.map((datum) => datum._id)) },
130
+ react_1.default.createElement(bs_1.BsChevronDoubleLeft, null),
131
+ " ",
132
+ rightListApplyAllButtonText),
133
+ react_1.default.createElement("div", { ref: rightListRef, className: "scrollable-section", onScroll: (event) => setRightListFirstVisibleElementIndex(Math.floor(event.target.scrollTop / listElementsHeight)) },
134
+ react_1.default.createElement("div", { className: "resizable-div-for-scroll", style: {
135
+ paddingTop: rightListFirstVisibleElementIndex * listElementsHeight,
136
+ height: filteredRightList.length * listElementsHeight,
137
+ } }, filteredRightList
138
+ .slice(rightListFirstVisibleElementIndex, rightListLastVisibleElementIndex)
139
+ .map((datum) => (react_1.default.createElement("div", { key: datum._id, className: "div-datum-wrapper", style: { height: listElementsHeight } },
140
+ react_1.default.createElement("button", { className: "apply-to-one-button", onClick: () => removeFromSelectedDatumsIds([datum._id]) },
141
+ react_1.default.createElement(bs_1.BsChevronLeft, null)),
142
+ datum.customComponent ? (react_1.default.createElement("div", { className: "div-custom-component-wrapper" }, datum.customComponent)) : (react_1.default.createElement("p", { className: "visible-default-name", title: datum.visibleDefaultName }, datum.visibleDefaultName)))))))))),
143
+ (cancelAction || applyAction) && (react_1.default.createElement("div", { className: "div-action-buttons" },
144
+ cancelAction && (react_1.default.createElement("button", { className: "cancel-button", onClick: () => cancelAction() }, cancelButtonText ? cancelButtonText : "Cancel")),
145
+ applyAction && (react_1.default.createElement("button", { className: "apply-button", onClick: () => applyAction(selectedDatumsIds) }, applyButtonText ? applyButtonText : "Apply"))))));
146
+ };
147
+ exports.default = ParallelSelectionList;
@@ -0,0 +1,22 @@
1
+ export interface ParallelSelectionListPropsTypes {
2
+ dataList: ListDatumType[];
3
+ applyAction?: (dataListId: ListDatumType["_id"][]) => void;
4
+ cancelAction?: Function;
5
+ onSelectionChange?: (dataListId: ListDatumType["_id"][]) => void;
6
+ leftListTitle?: string;
7
+ rightListTitle?: string;
8
+ leftListApplyAllButtonText?: string;
9
+ rightListApplyAllButtonText?: string;
10
+ searchBarsVisible?: boolean;
11
+ applyButtonText?: string;
12
+ cancelButtonText?: string;
13
+ preSelectedDatumsIds?: ListDatumType["_id"][];
14
+ listElementsHeight?: number;
15
+ }
16
+
17
+ export type ListDatumType = {
18
+ _id: string;
19
+ searchValue: string;
20
+ visibleDefaultName: string;
21
+ customComponent?: JSX.Element;
22
+ };
@@ -0,0 +1,15 @@
1
+ .trc-pop-up {
2
+ background-color: rgb(255, 255, 255);
3
+ border-color: rgb(235, 235, 235);
4
+ border-style: solid;
5
+ border-width: 0px 1px 1px;
6
+ box-shadow: rgb(0 0 0 / 15%) 0px 14px 36px 2px;
7
+ padding: 0px;
8
+ position: absolute;
9
+ overflow: auto;
10
+ box-sizing: border-box;
11
+ }
12
+
13
+ .trc-pop-up.pop-up-hidden {
14
+ display: none;
15
+ }
@@ -0,0 +1,5 @@
1
+ import React from "react";
2
+ import "./PopUp.css";
3
+ import { PopUpPropsType } from "./types";
4
+ declare const PopUp: ({ open, children, closeAction, outBoundClickClosesPopUp, aditionalInlineStyle, aditionalClass, activationButtonRef, }: PopUpPropsType) => React.JSX.Element;
5
+ export default PopUp;
@@ -0,0 +1,50 @@
1
+ "use strict";
2
+ var __createBinding = (this && this.__createBinding) || (Object.create ? (function(o, m, k, k2) {
3
+ if (k2 === undefined) k2 = k;
4
+ var desc = Object.getOwnPropertyDescriptor(m, k);
5
+ if (!desc || ("get" in desc ? !m.__esModule : desc.writable || desc.configurable)) {
6
+ desc = { enumerable: true, get: function() { return m[k]; } };
7
+ }
8
+ Object.defineProperty(o, k2, desc);
9
+ }) : (function(o, m, k, k2) {
10
+ if (k2 === undefined) k2 = k;
11
+ o[k2] = m[k];
12
+ }));
13
+ var __setModuleDefault = (this && this.__setModuleDefault) || (Object.create ? (function(o, v) {
14
+ Object.defineProperty(o, "default", { enumerable: true, value: v });
15
+ }) : function(o, v) {
16
+ o["default"] = v;
17
+ });
18
+ var __importStar = (this && this.__importStar) || function (mod) {
19
+ if (mod && mod.__esModule) return mod;
20
+ var result = {};
21
+ if (mod != null) for (var k in mod) if (k !== "default" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);
22
+ __setModuleDefault(result, mod);
23
+ return result;
24
+ };
25
+ var __importDefault = (this && this.__importDefault) || function (mod) {
26
+ return (mod && mod.__esModule) ? mod : { "default": mod };
27
+ };
28
+ Object.defineProperty(exports, "__esModule", { value: true });
29
+ const react_1 = __importStar(require("react"));
30
+ require("./PopUp.css");
31
+ //hooks
32
+ const useOutsideClick_1 = __importDefault(require("../../hooks/useOutsideClick"));
33
+ const PopUp = ({ open = false, children, closeAction, outBoundClickClosesPopUp, aditionalInlineStyle = {}, aditionalClass, activationButtonRef, }) => {
34
+ //Refs
35
+ const popUpRef = (0, react_1.useRef)(null);
36
+ //Hooks
37
+ (0, useOutsideClick_1.default)(popUpRef, () => {
38
+ if (outBoundClickClosesPopUp) {
39
+ setOpenState(false);
40
+ if (closeAction)
41
+ closeAction();
42
+ }
43
+ }, activationButtonRef ? [activationButtonRef] : []);
44
+ //useState
45
+ const [openState, setOpenState] = (0, react_1.useState)(open);
46
+ return (react_1.default.createElement("div", { ref: popUpRef, className: "trc-pop-up" +
47
+ ((closeAction && open) || (!closeAction && openState) ? "" : " pop-up-hidden") +
48
+ (aditionalClass ? " " + aditionalClass : ""), style: open ? aditionalInlineStyle : {} }, children));
49
+ };
50
+ exports.default = PopUp;