@legalplace/wizardx-core 2.6.3 → 2.7.0

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 (357) hide show
  1. package/CHANGELOG.md +43 -0
  2. package/dist/App.js +13 -4
  3. package/dist/PluginLoader.d.ts +3 -1
  4. package/dist/PluginLoader.js +12 -0
  5. package/dist/ThemeLoader.d.ts +2 -2
  6. package/dist/componentsConnectors/connectBox.d.ts +3 -1
  7. package/dist/componentsConnectors/connectDocument.d.ts +3 -1
  8. package/dist/componentsConnectors/connectHeader.d.ts +3 -1
  9. package/dist/componentsConnectors/connectMetaTitle.d.ts +3 -1
  10. package/dist/componentsConnectors/connectOption.d.ts +6 -2
  11. package/dist/componentsConnectors/connectOption.js +1 -1
  12. package/dist/componentsConnectors/connectPagination.d.ts +3 -1
  13. package/dist/componentsConnectors/connectPreview.d.ts +3 -1
  14. package/dist/componentsConnectors/connectProgress.d.ts +3 -1
  15. package/dist/componentsConnectors/connectRootOption.d.ts +3 -1
  16. package/dist/componentsConnectors/connectSection.d.ts +3 -1
  17. package/dist/componentsConnectors/connectSection.js +7 -10
  18. package/dist/componentsConnectors/connectSummary.d.ts +3 -1
  19. package/dist/componentsConnectors/connectSummaryItem.d.ts +3 -1
  20. package/dist/componentsConnectors/connectVariable.d.ts +6 -2
  21. package/dist/componentsConnectors/connectVariable.js +1 -1
  22. package/dist/componentsConnectors/connectWizardWrapper.d.ts +3 -1
  23. package/dist/componentsConnectors/connector/componentConnector.d.ts +5 -1
  24. package/dist/componentsConnectors/connector/componentConnector.js +44 -4
  25. package/dist/componentsConnectors/connector/index.d.ts +1 -0
  26. package/dist/componentsConnectors/connector/index.js +1 -0
  27. package/dist/componentsConnectors/index.d.ts +17 -0
  28. package/dist/componentsConnectors/index.js +17 -0
  29. package/dist/componentsConnectors/library.d.ts +43 -15
  30. package/dist/constants/phoneValidation.d.ts +0 -1
  31. package/dist/constants/phoneValidation.js +0 -1
  32. package/dist/helpers/apiEndpoint.d.ts +1 -0
  33. package/dist/helpers/apiEndpoint.js +4 -0
  34. package/dist/helpers/index.d.ts +4 -0
  35. package/dist/helpers/index.js +4 -0
  36. package/dist/helpers/propsEqualityCheck.d.ts +1 -0
  37. package/dist/helpers/propsEqualityCheck.js +9 -0
  38. package/dist/hooks/index.d.ts +4 -0
  39. package/dist/hooks/index.js +4 -0
  40. package/dist/hooks/useActions.d.ts +2 -0
  41. package/dist/hooks/useActions.js +4 -0
  42. package/dist/hooks/useDispatch.d.ts +1 -0
  43. package/dist/hooks/useDispatch.js +4 -0
  44. package/dist/hooks/useSelectors.d.ts +2 -0
  45. package/dist/hooks/useSelectors.js +4 -0
  46. package/dist/index.d.ts +13 -0
  47. package/dist/index.js +13 -0
  48. package/dist/libs/EventsTracking.d.ts +0 -1
  49. package/dist/libs/EventsTracking.js +0 -18
  50. package/dist/libs/PathReader.d.ts +10 -6
  51. package/dist/libs/PathReader.js +47 -28
  52. package/dist/libs/index.d.ts +5 -0
  53. package/dist/libs/index.js +5 -0
  54. package/dist/redux/actions/index.d.ts +9 -0
  55. package/dist/redux/actions/index.js +9 -0
  56. package/dist/redux/actions/library.d.ts +59 -63
  57. package/dist/redux/actions/sagas/index.d.ts +3 -0
  58. package/dist/redux/actions/sagas/index.js +3 -0
  59. package/dist/redux/actions/sagas/model.d.ts +1 -5
  60. package/dist/redux/constants/app.d.ts +2 -0
  61. package/dist/redux/constants/app.js +2 -0
  62. package/dist/redux/constants/index.d.ts +8 -0
  63. package/dist/redux/constants/index.js +8 -0
  64. package/dist/redux/constants/sagas/index.d.ts +3 -0
  65. package/dist/redux/constants/sagas/index.js +3 -0
  66. package/dist/redux/index.d.ts +5 -0
  67. package/dist/redux/index.js +5 -0
  68. package/dist/redux/middlewares/conditionsWatcherMiddleware.js +11 -5
  69. package/dist/redux/middlewares/conditionsWatcherMiddleware.test.js +120 -113
  70. package/dist/redux/middlewares/paginationWatcherMiddleware.js +2 -2
  71. package/dist/redux/middlewares/smartscriptMiddleware.js +8 -0
  72. package/dist/redux/reducers/pluginsStore.d.ts +3 -0
  73. package/dist/redux/reducers/pluginsStore.js +12 -0
  74. package/dist/redux/routerHistory.js +2 -2
  75. package/dist/redux/sagas/fetchModel.js +22 -6
  76. package/dist/redux/sagas/initInputs.js +6 -7
  77. package/dist/redux/sagas/saveData.js +3 -46
  78. package/dist/redux/sagas/setUserEmail.js +1 -28
  79. package/dist/redux/selectors/app.js +13 -18
  80. package/dist/redux/selectors/cache.d.ts +17 -0
  81. package/dist/redux/selectors/cache.js +35 -0
  82. package/dist/redux/selectors/conditions.js +7 -7
  83. package/dist/redux/selectors/index.d.ts +8 -0
  84. package/dist/redux/selectors/index.js +8 -0
  85. package/dist/redux/selectors/inputs.js +3 -3
  86. package/dist/redux/selectors/library.d.ts +2 -2
  87. package/dist/redux/selectors/references.js +26 -26
  88. package/dist/redux/selectors/selectors.d.ts +2 -2
  89. package/dist/redux/selectors/selectors.js +19 -8
  90. package/dist/redux/selectors/selectors.test.js +6 -6
  91. package/dist/redux/selectors/user.js +5 -5
  92. package/dist/redux/store.d.ts +1 -1
  93. package/dist/redux/store.js +12 -4
  94. package/dist/service/api.manager.d.ts +1 -6
  95. package/dist/service/index.d.ts +3 -0
  96. package/dist/service/index.js +3 -0
  97. package/dist/types/PluginConfig.type.d.ts +57 -0
  98. package/dist/types/PluginConfig.type.js +1 -0
  99. package/dist/types/State.type.d.ts +6 -0
  100. package/dist/types/config.type.d.ts +3 -1
  101. package/dist/types/index.d.ts +11 -0
  102. package/dist/types/index.js +11 -0
  103. package/package.json +11 -12
  104. package/.depcheckrc +0 -1
  105. package/.eslintignore +0 -2
  106. package/.eslintrc +0 -5
  107. package/__mocks__/fileMock.js +0 -1
  108. package/babel.config.json +0 -3
  109. package/dist/helpers/sendinblueHelper.d.ts +0 -4
  110. package/dist/helpers/sendinblueHelper.js +0 -46
  111. package/dist/libs/Extracts.d.ts +0 -20
  112. package/dist/libs/Extracts.js +0 -110
  113. package/jest.config.ts +0 -193
  114. package/setupJest.ts +0 -8
  115. package/src/App.test.tsx +0 -41
  116. package/src/App.tsx +0 -152
  117. package/src/Globals.ts +0 -69
  118. package/src/Loader.tsx +0 -8
  119. package/src/PluginLoader.test.tsx +0 -70
  120. package/src/PluginLoader.tsx +0 -407
  121. package/src/Shimmer.tsx +0 -108
  122. package/src/ThemeLoader.test.tsx +0 -82
  123. package/src/ThemeLoader.tsx +0 -95
  124. package/src/components/PluginRoute.tsx +0 -48
  125. package/src/components/SmartScript.tsx +0 -166
  126. package/src/components/UserLocked/UserLockedComponent.tsx +0 -33
  127. package/src/components/View.test.tsx +0 -110
  128. package/src/components/View.tsx +0 -114
  129. package/src/componentsConnectors/connectBox.test.tsx +0 -226
  130. package/src/componentsConnectors/connectBox.tsx +0 -70
  131. package/src/componentsConnectors/connectDocument.test.tsx +0 -108
  132. package/src/componentsConnectors/connectDocument.tsx +0 -64
  133. package/src/componentsConnectors/connectHeader.tsx +0 -21
  134. package/src/componentsConnectors/connectMetaTitle.test.tsx +0 -40
  135. package/src/componentsConnectors/connectMetaTitle.tsx +0 -8
  136. package/src/componentsConnectors/connectOption.tsx +0 -222
  137. package/src/componentsConnectors/connectPagination.tsx +0 -102
  138. package/src/componentsConnectors/connectPreview.tsx +0 -5
  139. package/src/componentsConnectors/connectProgress.tsx +0 -59
  140. package/src/componentsConnectors/connectRootOption.tsx +0 -95
  141. package/src/componentsConnectors/connectSection.tsx +0 -79
  142. package/src/componentsConnectors/connectSummary.tsx +0 -21
  143. package/src/componentsConnectors/connectSummaryItem.tsx +0 -102
  144. package/src/componentsConnectors/connectTermsheet.tsx +0 -359
  145. package/src/componentsConnectors/connectVariable.tsx +0 -191
  146. package/src/componentsConnectors/connectWizardWrapper.tsx +0 -30
  147. package/src/componentsConnectors/connector/componentConnector.tsx +0 -219
  148. package/src/componentsConnectors/library.ts +0 -35
  149. package/src/config.test.ts +0 -63
  150. package/src/config.ts +0 -11
  151. package/src/constants/emailValidation.ts +0 -2
  152. package/src/constants/phoneValidation.ts +0 -6
  153. package/src/definitions/path.join.d.ts +0 -4
  154. package/src/helpers/outputsParsing.ts +0 -412
  155. package/src/helpers/preloadTheme.ts +0 -17
  156. package/src/helpers/scriptsLoader.ts +0 -20
  157. package/src/helpers/sendinblueHelper.ts +0 -65
  158. package/src/hooks/usePrevious.ts +0 -9
  159. package/src/libs/ConditionsInitiator.ts +0 -164
  160. package/src/libs/ConditionsRunner/DataPopulator.ts +0 -266
  161. package/src/libs/ConditionsRunner.ts +0 -454
  162. package/src/libs/DocumentsOutputs.ts +0 -171
  163. package/src/libs/Eval/EvalBase.ts +0 -116
  164. package/src/libs/Eval/EvalFunctions.ts +0 -724
  165. package/src/libs/Eval/NumbersToLetters.ts +0 -185
  166. package/src/libs/EvalVariable.ts +0 -265
  167. package/src/libs/EventsTracking.ts +0 -276
  168. package/src/libs/Extracts.ts +0 -159
  169. package/src/libs/InputsInitiator.ts +0 -136
  170. package/src/libs/NumAuto.test.ts +0 -55
  171. package/src/libs/NumAuto.ts +0 -56
  172. package/src/libs/OvcConverter.ts +0 -285
  173. package/src/libs/PathReader.ts +0 -272
  174. package/src/libs/SectionValidity.test.ts +0 -146
  175. package/src/libs/SectionValidity.ts +0 -110
  176. package/src/libs/SmartScriptStore.ts +0 -492
  177. package/src/misc/test_model.ts +0 -14603
  178. package/src/misc/test_models/connectDocumen.testmodel.json +0 -178
  179. package/src/misc/test_models/setDefaults.testmodel.json +0 -279
  180. package/src/misc/test_models/testmodel.json +0 -1
  181. package/src/polyfills/index.ts +0 -5
  182. package/src/polyfills/objectValues.ts +0 -4
  183. package/src/polyfills/prepend.ts +0 -31
  184. package/src/polyfills/stringRepeat.ts +0 -44
  185. package/src/redux/actions/app.test.ts +0 -123
  186. package/src/redux/actions/app.ts +0 -249
  187. package/src/redux/actions/conditions.test.ts +0 -84
  188. package/src/redux/actions/conditions.ts +0 -135
  189. package/src/redux/actions/inputs.test.ts +0 -85
  190. package/src/redux/actions/inputs.ts +0 -111
  191. package/src/redux/actions/library.ts +0 -23
  192. package/src/redux/actions/mandatories.ts +0 -98
  193. package/src/redux/actions/references.test.ts +0 -48
  194. package/src/redux/actions/references.ts +0 -37
  195. package/src/redux/actions/sagas/data.test.ts +0 -11
  196. package/src/redux/actions/sagas/data.ts +0 -18
  197. package/src/redux/actions/sagas/model.test.ts +0 -14
  198. package/src/redux/actions/sagas/model.ts +0 -48
  199. package/src/redux/actions/sagas/user.ts +0 -25
  200. package/src/redux/actions/smartscript.ts +0 -55
  201. package/src/redux/actions/user.test.ts +0 -18
  202. package/src/redux/actions/user.ts +0 -41
  203. package/src/redux/constants/app.ts +0 -36
  204. package/src/redux/constants/conditions.ts +0 -25
  205. package/src/redux/constants/inputs.ts +0 -15
  206. package/src/redux/constants/mandatories.ts +0 -11
  207. package/src/redux/constants/references.ts +0 -7
  208. package/src/redux/constants/sagas/data.ts +0 -1
  209. package/src/redux/constants/sagas/model.ts +0 -2
  210. package/src/redux/constants/sagas/user.ts +0 -2
  211. package/src/redux/constants/smartscript.ts +0 -9
  212. package/src/redux/constants/user.ts +0 -6
  213. package/src/redux/listeners/subscriber.test.ts +0 -45
  214. package/src/redux/listeners/subscriber.ts +0 -29
  215. package/src/redux/middlewares/conditionsWatcherMiddleware.test.ts +0 -370
  216. package/src/redux/middlewares/conditionsWatcherMiddleware.ts +0 -321
  217. package/src/redux/middlewares/evaluationsWatcherMiddleware.test.ts +0 -323
  218. package/src/redux/middlewares/evaluationsWatcherMiddleware.ts +0 -250
  219. package/src/redux/middlewares/mandatoriesWatcherMiddleware.ts +0 -473
  220. package/src/redux/middlewares/multiplesActionsMiddleware.test.ts +0 -230
  221. package/src/redux/middlewares/multiplesActionsMiddleware.ts +0 -121
  222. package/src/redux/middlewares/paginationWatcherMiddleware.ts +0 -251
  223. package/src/redux/middlewares/pluginsHookMiddleware.ts +0 -24
  224. package/src/redux/middlewares/prefillerWatcherMiddleware.test.ts +0 -118
  225. package/src/redux/middlewares/prefillerWatcherMiddleware.ts +0 -462
  226. package/src/redux/middlewares/smartscriptMiddleware.ts +0 -228
  227. package/src/redux/middlewares/thirdpartyScriptsMiddleware.ts +0 -41
  228. package/src/redux/reducers/app/customizations/initCustomizationAutoDefault.ts +0 -16
  229. package/src/redux/reducers/app/customizations/initCustomizationMeta.ts +0 -16
  230. package/src/redux/reducers/app/instance/initInstance.ts +0 -29
  231. package/src/redux/reducers/app/instance/setDataStatus.ts +0 -16
  232. package/src/redux/reducers/app/instance/updateInstance.ts +0 -30
  233. package/src/redux/reducers/app/instance/updateInstancePaid.ts +0 -20
  234. package/src/redux/reducers/app/instance.test.ts +0 -106
  235. package/src/redux/reducers/app/meta/fetchModelFailed.ts +0 -11
  236. package/src/redux/reducers/app/meta/fetchModelNonBlocking.ts +0 -11
  237. package/src/redux/reducers/app/meta/fetchModelSucceeded.ts +0 -11
  238. package/src/redux/reducers/app/meta/fetchModelUnhealthy.ts +0 -18
  239. package/src/redux/reducers/app/meta/fetchModelUserLocked.ts +0 -11
  240. package/src/redux/reducers/app/meta/initMeta.ts +0 -22
  241. package/src/redux/reducers/app/meta/setModelUuid.ts +0 -17
  242. package/src/redux/reducers/app/meta.test.ts +0 -90
  243. package/src/redux/reducers/app/pagination/goNextPage.ts +0 -69
  244. package/src/redux/reducers/app/pagination/goPage.ts +0 -81
  245. package/src/redux/reducers/app/pagination/goPreviousPage.ts +0 -60
  246. package/src/redux/reducers/app/pagination/initPagination.ts +0 -46
  247. package/src/redux/reducers/app/pagination/updateAvailableAppStates.ts +0 -77
  248. package/src/redux/reducers/app/pagination.test.ts +0 -363
  249. package/src/redux/reducers/app/wizard/updateAvailableSections.ts +0 -40
  250. package/src/redux/reducers/app/wizard.test.ts +0 -84
  251. package/src/redux/reducers/app.test.ts +0 -336
  252. package/src/redux/reducers/app.ts +0 -150
  253. package/src/redux/reducers/conditions/addMultipleOccurency.test.ts +0 -131
  254. package/src/redux/reducers/conditions/addMultipleOccurency.ts +0 -155
  255. package/src/redux/reducers/conditions/deleteMultipleOccurency.test.ts +0 -95
  256. package/src/redux/reducers/conditions/deleteMultipleOccurency.ts +0 -141
  257. package/src/redux/reducers/conditions/initConditions.ts +0 -18
  258. package/src/redux/reducers/conditions/updateDocumentConditions.test.ts +0 -47
  259. package/src/redux/reducers/conditions/updateDocumentConditions.ts +0 -21
  260. package/src/redux/reducers/conditions/updateOptionConditions.ts +0 -24
  261. package/src/redux/reducers/conditions/updateOptionValidatorCondition.test.ts +0 -50
  262. package/src/redux/reducers/conditions/updateOptionValidatorCondition.ts +0 -28
  263. package/src/redux/reducers/conditions/updatePrefillerConditions.ts +0 -29
  264. package/src/redux/reducers/conditions/updateSectionConditions.ts +0 -28
  265. package/src/redux/reducers/conditions/updateVariableConditions.ts +0 -25
  266. package/src/redux/reducers/conditions/updateVariableValidatorCondition.test.ts +0 -50
  267. package/src/redux/reducers/conditions/updateVariableValidatorCondition.ts +0 -28
  268. package/src/redux/reducers/conditions.test.ts +0 -241
  269. package/src/redux/reducers/conditions.ts +0 -68
  270. package/src/redux/reducers/inputs/addMultipleOccurency.test.ts +0 -117
  271. package/src/redux/reducers/inputs/addMultipleOccurency.ts +0 -50
  272. package/src/redux/reducers/inputs/deleteMultipleOccurency.test.ts +0 -70
  273. package/src/redux/reducers/inputs/deleteMultipleOccurency.ts +0 -50
  274. package/src/redux/reducers/inputs/initOption.ts +0 -16
  275. package/src/redux/reducers/inputs/initVariable.ts +0 -16
  276. package/src/redux/reducers/inputs/updateOptionInput.ts +0 -24
  277. package/src/redux/reducers/inputs/updateVariableInput.ts +0 -24
  278. package/src/redux/reducers/inputs.test.ts +0 -221
  279. package/src/redux/reducers/inputs.ts +0 -51
  280. package/src/redux/reducers/mandatories/addMultipleOccurency.ts +0 -52
  281. package/src/redux/reducers/mandatories/deleteMultipleOccurency.ts +0 -55
  282. package/src/redux/reducers/mandatories/initMandatoryOption.ts +0 -17
  283. package/src/redux/reducers/mandatories/initMandatoryVariable.ts +0 -17
  284. package/src/redux/reducers/mandatories/setMandatoryIgnore.ts +0 -17
  285. package/src/redux/reducers/mandatories/setMandatoryOption.ts +0 -25
  286. package/src/redux/reducers/mandatories/setMandatorySection.ts +0 -20
  287. package/src/redux/reducers/mandatories/setMandatoryVariable.ts +0 -24
  288. package/src/redux/reducers/mandatories.ts +0 -56
  289. package/src/redux/reducers/references/initReferences.ts +0 -37
  290. package/src/redux/reducers/references/updateOptionMeta.ts +0 -73
  291. package/src/redux/reducers/references/updateVariableMeta.ts +0 -72
  292. package/src/redux/reducers/references.ts +0 -59
  293. package/src/redux/reducers/smartscript/enableSmartScript.ts +0 -13
  294. package/src/redux/reducers/smartscript/initSmartScriptTriggers.ts +0 -14
  295. package/src/redux/reducers/smartscript/updateSmartscriptOptionHidden.ts +0 -30
  296. package/src/redux/reducers/smartscript/updateSmartscriptVariableHidden.ts +0 -30
  297. package/src/redux/reducers/smartscript.ts +0 -47
  298. package/src/redux/reducers/user/initUser.ts +0 -15
  299. package/src/redux/reducers/user/setUserStatus.ts +0 -13
  300. package/src/redux/reducers/user/setUserValidToken.ts +0 -13
  301. package/src/redux/reducers/user.test.ts +0 -51
  302. package/src/redux/reducers/user.ts +0 -40
  303. package/src/redux/routerHistore.test.ts +0 -19
  304. package/src/redux/routerHistory.ts +0 -26
  305. package/src/redux/sagas/fetchModel.test.ts +0 -76
  306. package/src/redux/sagas/fetchModel.ts +0 -683
  307. package/src/redux/sagas/homogeneousRadioInputsSaga.ts +0 -42
  308. package/src/redux/sagas/initInputs.ts +0 -110
  309. package/src/redux/sagas/runner.test.ts +0 -12
  310. package/src/redux/sagas/runner.ts +0 -26
  311. package/src/redux/sagas/saveData.test.ts +0 -125
  312. package/src/redux/sagas/saveData.ts +0 -116
  313. package/src/redux/sagas/setDefaults.test.ts +0 -100
  314. package/src/redux/sagas/setDefaults.ts +0 -167
  315. package/src/redux/sagas/setUserEmail.ts +0 -221
  316. package/src/redux/selectors/app.test.ts +0 -162
  317. package/src/redux/selectors/app.ts +0 -331
  318. package/src/redux/selectors/conditions.test.ts +0 -92
  319. package/src/redux/selectors/conditions.ts +0 -293
  320. package/src/redux/selectors/inputs.test.ts +0 -72
  321. package/src/redux/selectors/inputs.ts +0 -76
  322. package/src/redux/selectors/library.ts +0 -17
  323. package/src/redux/selectors/mandatories.ts +0 -83
  324. package/src/redux/selectors/references.test.ts +0 -660
  325. package/src/redux/selectors/references.ts +0 -413
  326. package/src/redux/selectors/selectors.test.ts +0 -21
  327. package/src/redux/selectors/selectors.ts +0 -87
  328. package/src/redux/selectors/smartscript.ts +0 -30
  329. package/src/redux/selectors/user.test.ts +0 -39
  330. package/src/redux/selectors/user.ts +0 -45
  331. package/src/redux/store.test.ts +0 -22
  332. package/src/redux/store.ts +0 -100
  333. package/src/service/api.manager.ts +0 -261
  334. package/src/service/auth.service.ts +0 -5
  335. package/src/service/pardot.service.ts +0 -10
  336. package/src/tests-misc/plugins/jestTestPlugin/after.tsx +0 -5
  337. package/src/tests-misc/plugins/jestTestPlugin/before.tsx +0 -11
  338. package/src/tests-misc/plugins/jestTestPlugin/index.ts +0 -11
  339. package/src/tests-misc/plugins/jestTestPlugin/title.tsx +0 -8
  340. package/src/tests-misc/themes/jestTestTheme/components/EmailComponent.tsx +0 -5
  341. package/src/tests-misc/themes/jestTestTheme/components/TermsheetComponent.tsx +0 -5
  342. package/src/tests-misc/themes/jestTestTheme/components/WizardComponent.tsx +0 -5
  343. package/src/tests-misc/themes/jestTestTheme/faltyIndex.ts +0 -3
  344. package/src/tests-misc/themes/jestTestTheme/faltyIndexLoader.ts +0 -1
  345. package/src/tests-misc/themes/jestTestTheme/index.ts +0 -13
  346. package/src/types/Actions.type.ts +0 -612
  347. package/src/types/Components.type.ts +0 -181
  348. package/src/types/State.type.ts +0 -323
  349. package/src/types/Termsheet.type.ts +0 -28
  350. package/src/types/api.type.ts +0 -37
  351. package/src/types/config.type.ts +0 -55
  352. package/src/types/env.type.ts +0 -5
  353. package/src/types/getActions.type.ts +0 -3
  354. package/src/types/getConnectors.type.ts +0 -5
  355. package/src/types/getSelectors.type.ts +0 -3
  356. package/src/wizard-params.ts +0 -56
  357. package/tsconfig.json +0 -43
package/CHANGELOG.md CHANGED
@@ -3,6 +3,49 @@
3
3
  All notable changes to this project will be documented in this file.
4
4
  See [Conventional Commits](https://conventionalcommits.org) for commit guidelines.
5
5
 
6
+ # [2.7.0](https://git.legalplace.eu/legalplace/monorepo/compare/@legalplace/wizardx-core@2.6.4...@legalplace/wizardx-core@2.7.0) (2022-01-06)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * allow storing undefined values to cache. api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([0c42995](https://git.legalplace.eu/legalplace/monorepo/commits/0c4299523a575e3e43aea9c4054b5136c69b44a5))
12
+ * code review fixes api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([86ab582](https://git.legalplace.eu/legalplace/monorepo/commits/86ab582aa1a460b9c2ee2adcfd25e8f93237a0c1))
13
+ * fix checkout init api[#4664](https://git.legalplace.eu/legalplace/monorepo/issues/4664) ([416afea](https://git.legalplace.eu/legalplace/monorepo/commits/416afea28f527f1fdcd9a23381a948b25f482f3f))
14
+ * fix empty strings errors on path generation api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([18a168b](https://git.legalplace.eu/legalplace/monorepo/commits/18a168b94608d151379a66b9d63c473a78fbd702))
15
+ * fix import api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([f7eaafe](https://git.legalplace.eu/legalplace/monorepo/commits/f7eaafe34a1314e82eeff1fc7ac38c7624a2395c))
16
+ * fix linting api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([40c3b1a](https://git.legalplace.eu/legalplace/monorepo/commits/40c3b1aeedf35b7bebd279a3f841ee00d5ff8720))
17
+ * fix merges api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([0ad9d26](https://git.legalplace.eu/legalplace/monorepo/commits/0ad9d2634d7a0f09e44422aec121b8f46c8143d0))
18
+ * fix mr api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([6111eda](https://git.legalplace.eu/legalplace/monorepo/commits/6111eda4cef95c7edbf32927b5c3e77ff6ad5bce))
19
+ * fix path parsing issue when instance has a uniqid api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([954b39f](https://git.legalplace.eu/legalplace/monorepo/commits/954b39fd0d69729914141830b31793a77b8f8217))
20
+ * fix permalink init. api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([273b4c1](https://git.legalplace.eu/legalplace/monorepo/commits/273b4c190a76f9750498060bec77e7288712308e))
21
+ * fixing paginationWatcherMiddleware api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([4d44ec7](https://git.legalplace.eu/legalplace/monorepo/commits/4d44ec78f6b4cae9ef3226778029555d8e2b8af9))
22
+ * fixing prefix name api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([37dbba0](https://git.legalplace.eu/legalplace/monorepo/commits/37dbba07993c0ccafdaf1b0703bf7b9bdfbc7069))
23
+ * fixing selectors cache and supporting cache clear on store reset. api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([ca62c85](https://git.legalplace.eu/legalplace/monorepo/commits/ca62c852c4725c8eeae6f4769a49da98663613e2))
24
+ * initiating availableSections to avoid having currentSectionId as undefined api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([8c112f6](https://git.legalplace.eu/legalplace/monorepo/commits/8c112f669bbf51bac57c937a298e2a40314d4cd8))
25
+ * optimizing inputs update and fixing issue with modal not closing api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([d6091f2](https://git.legalplace.eu/legalplace/monorepo/commits/d6091f2f1fd98babda0c52f8cfdf8d904d8b1fde))
26
+ * upgrading @legalplace/storybook api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([351b97a](https://git.legalplace.eu/legalplace/monorepo/commits/351b97a4832b118986a56dcfe47c9bf194e15fdd))
27
+ * upgrading alpha storybook version api[#4664](https://git.legalplace.eu/legalplace/monorepo/issues/4664) ([ab440d8](https://git.legalplace.eu/legalplace/monorepo/commits/ab440d8e8f3b01de289e45bc50bf72ce4122a4e2))
28
+
29
+
30
+ ### Features
31
+
32
+ * adding export indexes to wizardx-core api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([394fabc](https://git.legalplace.eu/legalplace/monorepo/commits/394fabc998e41523b732ef83f58237382932c0a3))
33
+ * adding support for document titles api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([dbe69cb](https://git.legalplace.eu/legalplace/monorepo/commits/dbe69cb815efe5bd23f0b097bf7ae07c51c06f5b))
34
+ * upgrading storybook to test perfs on staging api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([465d741](https://git.legalplace.eu/legalplace/monorepo/commits/465d7411800a45d0dbf52cbf482b46c25227ee46))
35
+ * using wizardx for company sheet api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([551dbc3](https://git.legalplace.eu/legalplace/monorepo/commits/551dbc373dc3c8502fd119eccd731986f305d8e3))
36
+
37
+
38
+
39
+
40
+
41
+ ## [2.6.4](https://git.legalplace.eu/legalplace/monorepo/compare/@legalplace/wizardx-core@2.6.3...@legalplace/wizardx-core@2.6.4) (2022-01-05)
42
+
43
+ **Note:** Version bump only for package @legalplace/wizardx-core
44
+
45
+
46
+
47
+
48
+
6
49
  ## [2.6.3](https://git.legalplace.eu/legalplace/monorepo/compare/@legalplace/wizardx-core@2.6.2...@legalplace/wizardx-core@2.6.3) (2021-12-13)
7
50
 
8
51
  **Note:** Version bump only for package @legalplace/wizardx-core
package/dist/App.js CHANGED
@@ -13,6 +13,8 @@ import ViewComponent from "./components/View";
13
13
  import PluginRoute from "./components/PluginRoute";
14
14
  import SmartScriptComponent from "./components/SmartScript";
15
15
  import { clearPlugins } from "./PluginLoader";
16
+ import { PathReader } from "./libs/PathReader";
17
+ import { DANGEROUS_DESTORY_STORE } from "./redux/constants/app";
16
18
  class WizardXCore extends React.Component {
17
19
  constructor(props) {
18
20
  var _a;
@@ -37,7 +39,12 @@ class WizardXCore extends React.Component {
37
39
  updateConfig(props.wizardParams);
38
40
  if (props.preloadTheme && ((_a = props.wizardParams) === null || _a === void 0 ? void 0 : _a.theme.name))
39
41
  preloadTheme(props.wizardParams.theme.name);
40
- createAppStore(historyType);
42
+ if (!getStore(false)) {
43
+ createAppStore(historyType);
44
+ }
45
+ else {
46
+ getStore().dispatch({ type: DANGEROUS_DESTORY_STORE });
47
+ }
41
48
  }
42
49
  componentDidMount() {
43
50
  if (getConfig().permalink) {
@@ -56,15 +63,17 @@ class WizardXCore extends React.Component {
56
63
  }));
57
64
  }
58
65
  }
66
+ else if (PathReader.isSmartScriptPath()) {
67
+ getHistory().push(window.location.pathname);
68
+ }
59
69
  const { dispatch, getState } = getStore();
60
70
  const state = getState();
61
71
  dispatch(fetchModelPrerequisitesAction(getConfig().permalink || state.app.meta.permalink, getConfig().prefix || state.app.meta.prefix || ""));
62
72
  }
63
73
  render() {
64
- return (_jsx(Provider, Object.assign({ store: getStore() }, { children: _jsx(ConnectedRouter, Object.assign({ history: getHistory() }, { children: _jsxs(Switch, { children: [_jsx(Route, { path: "/p/:path", component: PluginRoute }, void 0), _jsx(Route, { path: getConfig().router.wizardInstancePath, component: ViewComponent }, void 0), _jsx(Route, { path: getConfig().router.wizardPath, component: ViewComponent }, void 0), _jsx(Route, { path: getConfig().router.smartscriptPath ||
65
- "/contrats/:permalink/smartscript/:uniqid?", component: SmartScriptComponent }, void 0), _jsx(Redirect, { to: {
74
+ return (_jsx(Provider, Object.assign({ store: getStore() }, { children: _jsx(ConnectedRouter, Object.assign({ history: getHistory() }, { children: _jsxs(Switch, { children: [_jsx(Route, { path: "/p/:path", component: PluginRoute }, void 0), _jsx(Route, { path: getConfig().router.wizardInstancePath, component: ViewComponent }, void 0), _jsx(Route, { path: getConfig().router.wizardPath, component: ViewComponent }, void 0), _jsx(Route, { path: getConfig().router.smartscriptPath, exact: true, strict: true, component: SmartScriptComponent }, void 0), !window.location.href.includes("smartscript") && (_jsx(Redirect, { to: {
66
75
  pathname: getConfig().router.notFoundPath,
67
- } }, void 0)] }, void 0) }), void 0) }), void 0));
76
+ } }, void 0))] }, void 0) }), void 0) }), void 0));
68
77
  }
69
78
  }
70
79
  export default WizardXCore;
@@ -1,6 +1,8 @@
1
1
  import React, { Props } from "react";
2
- import { Action } from "redux";
3
2
  import { LoadableComponent } from "@loadable/component";
3
+ import type { Action, AnyAction, CombinedState, Reducer } from "redux";
4
+ declare let pluginsStoreReducers: Record<string, Reducer<CombinedState<Record<string, any>>, AnyAction>>;
5
+ export declare const getPluginsStoreReducers: () => Readonly<typeof pluginsStoreReducers>;
4
6
  export declare type PluginAppStatesRegisterFunction = (currentAppStates: string[]) => string[];
5
7
  export declare type PluginsPageAppStatesType = Record<string, string>;
6
8
  export declare type actionOverrideFunction = (action: Action) => Action;
@@ -15,10 +15,13 @@ import { getStore } from "./redux/store";
15
15
  import { getHistory } from "./redux/routerHistory";
16
16
  import { EventsTracking } from "./libs/EventsTracking";
17
17
  import Globals from "./Globals";
18
+ import { INIT_PLUGINS } from "./redux/constants/app";
18
19
  let globalAnchors = {};
19
20
  let reduxAnchors = {};
20
21
  let actionOverrideAnchor = {};
21
22
  let replacers = {};
23
+ let pluginsStoreReducers = {};
24
+ export const getPluginsStoreReducers = () => pluginsStoreReducers;
22
25
  let PluginsAppStatesRegistrers = [];
23
26
  let PluginsPageAppStates = {};
24
27
  let PluginsAppStatesComponents = {};
@@ -110,11 +113,19 @@ const loadPluginFiles = (pluginsList) => __awaiter(void 0, void 0, void 0, funct
110
113
  });
111
114
  return;
112
115
  }
116
+ if (anchor === "reduxStore" && anchors[anchor].reducer) {
117
+ pluginsStoreReducers[plugin] = anchors[anchor].reducer;
118
+ }
113
119
  if (!Object.prototype.hasOwnProperty.call(globalAnchors, anchor))
114
120
  globalAnchors[anchor] = [];
115
121
  globalAnchors[anchor].push(anchors[anchor]);
116
122
  });
123
+ if (typeof anchors.onLoad === "function")
124
+ anchors.onLoad();
117
125
  });
126
+ if (Object.keys(pluginsStoreReducers).length > 0) {
127
+ getStore().dispatch({ type: INIT_PLUGINS });
128
+ }
118
129
  });
119
130
  let pluginsLoadingDone = false;
120
131
  export const loadPlugins = (plugins) => __awaiter(void 0, void 0, void 0, function* () {
@@ -222,4 +233,5 @@ export const clearPlugins = () => {
222
233
  PluginAdditionRoutes = {};
223
234
  cache = {};
224
235
  pluginsLoadingDone = false;
236
+ pluginsStoreReducers = {};
225
237
  };
@@ -12,7 +12,7 @@ export declare const getThemeParams: () => {
12
12
  previewBtn: boolean;
13
13
  };
14
14
  } | undefined;
15
- sidebar: {
15
+ sidebar?: {
16
16
  [key: string]: any;
17
17
  default: import("./types/config.type").SideBarType;
18
18
  states: {
@@ -20,7 +20,7 @@ export declare const getThemeParams: () => {
20
20
  wizard?: import("./types/config.type").SideBarType;
21
21
  email?: import("./types/config.type").SideBarType;
22
22
  };
23
- };
23
+ } | undefined;
24
24
  fonts?: any;
25
25
  style?: Record<string, any> | undefined;
26
26
  };
@@ -11,6 +11,8 @@ export declare type ConnectBoxMapProps = {
11
11
  options: number[];
12
12
  tags?: string[];
13
13
  };
14
- export declare const connectBox: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectBoxOwnProps & ConnectBoxMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectBoxOwnProps & AdditionnalProps & {
14
+ export declare const connectBox: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectBoxOwnProps & ConnectBoxMapProps & AdditionnalProps>, connectorOptions?: {
15
+ memoizeStateToProps?: boolean | undefined;
16
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectBoxOwnProps & AdditionnalProps & {
15
17
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
16
18
  }>;
@@ -5,6 +5,8 @@ export declare type ConnectDocumentMapProps = {
5
5
  document: string;
6
6
  outputs: Record<string, string>;
7
7
  };
8
- export declare const connectDocument: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectDocumentOwnProps & ConnectDocumentMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectDocumentOwnProps & AdditionnalProps & {
8
+ export declare const connectDocument: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectDocumentOwnProps & ConnectDocumentMapProps & AdditionnalProps>, connectorOptions?: {
9
+ memoizeStateToProps?: boolean | undefined;
10
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectDocumentOwnProps & AdditionnalProps & {
9
11
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
10
12
  }>;
@@ -4,6 +4,8 @@ export declare type ConnectHeaderOwnProps = {
4
4
  export declare type ConnectHeaderMapProps = {
5
5
  hasValidAuthToken: boolean;
6
6
  };
7
- export declare const connectHeader: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectHeaderOwnProps & ConnectHeaderMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectHeaderOwnProps & AdditionnalProps & {
7
+ export declare const connectHeader: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectHeaderOwnProps & ConnectHeaderMapProps & AdditionnalProps>, connectorOptions?: {
8
+ memoizeStateToProps?: boolean | undefined;
9
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectHeaderOwnProps & AdditionnalProps & {
8
10
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
9
11
  }>;
@@ -2,7 +2,9 @@ export declare const connectMetaTitle: <AdditionnalProps = {}>(Component: import
2
2
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
3
3
  } & {
4
4
  title: string;
5
- } & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & {
5
+ } & AdditionnalProps>, connectorOptions?: {
6
+ memoizeStateToProps?: boolean | undefined;
7
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & {
6
8
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
7
9
  } & AdditionnalProps & {
8
10
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
@@ -1,4 +1,5 @@
1
1
  import type { OptionV3 } from "@legalplace/models-v3-types";
2
+ import { ConnectorMapSelectors } from "./connector/componentConnector";
2
3
  export declare type ConnectOptionOwnProps = {
3
4
  id: number;
4
5
  index: number;
@@ -8,7 +9,7 @@ export declare type ConnectOptionOwnProps = {
8
9
  };
9
10
  export declare type ConnectOptionMapProps = {
10
11
  label: string;
11
- type: string;
12
+ type: OptionV3["meta"]["type"];
12
13
  value: boolean;
13
14
  condition?: boolean;
14
15
  validator?: boolean;
@@ -25,6 +26,9 @@ export declare type ConnectOptionDispatchProps = {
25
26
  addMultipleOccurency: () => void;
26
27
  deleteMultipleOccurency: () => void;
27
28
  };
28
- export declare const connectOption: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectOptionOwnProps & ConnectOptionMapProps & ConnectOptionDispatchProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectOptionOwnProps & AdditionnalProps & {
29
+ export declare const canOptionDisplay: (id: number, index: number, selectors: ConnectorMapSelectors) => Readonly<boolean>;
30
+ export declare const connectOption: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectOptionOwnProps & ConnectOptionMapProps & ConnectOptionDispatchProps & AdditionnalProps>, connectorOptions?: {
31
+ memoizeStateToProps?: boolean | undefined;
32
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectOptionOwnProps & AdditionnalProps & {
29
33
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
30
34
  }>;
@@ -1,7 +1,7 @@
1
1
  import { parseOptionLabel, parseRawWithVariables, } from "../helpers/outputsParsing";
2
2
  import { componentConnector, } from "./connector/componentConnector";
3
3
  import { isStepAvailable } from "../redux/selectors/app";
4
- const canOptionDisplay = (id, index, selectors) => {
4
+ export const canOptionDisplay = (id, index, selectors) => {
5
5
  const option = selectors.selectOptionReference(id);
6
6
  let display = isStepAvailable(option.meta.step);
7
7
  display = display && !(option.meta.hidden === true);
@@ -15,6 +15,8 @@ export declare type ConnectPaginationDispatchProps = {
15
15
  goNextPage: () => void;
16
16
  goPreviousPage: () => void;
17
17
  };
18
- export declare const connectPagination: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectPaginationMapProps & ConnectPaginationDispatchProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & AdditionnalProps & {
18
+ export declare const connectPagination: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectPaginationMapProps & ConnectPaginationDispatchProps & AdditionnalProps>, connectorOptions?: {
19
+ memoizeStateToProps?: boolean | undefined;
20
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & AdditionnalProps & {
19
21
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
20
22
  }>;
@@ -1,6 +1,8 @@
1
1
  export declare const connectPreview: <AdditionnalProps = {}>(Component: import("react").ComponentType<{
2
2
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
3
- } & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & {
3
+ } & AdditionnalProps>, connectorOptions?: {
4
+ memoizeStateToProps?: boolean | undefined;
5
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & {
4
6
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
5
7
  } & AdditionnalProps & {
6
8
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
@@ -9,6 +9,8 @@ export declare type ConnectPreviewMapProps = {
9
9
  greatestPage: number;
10
10
  totalPages: number;
11
11
  };
12
- export declare const connectProgress: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectPreviewOwnProps & ConnectPreviewMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectPreviewOwnProps & AdditionnalProps & {
12
+ export declare const connectProgress: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectPreviewOwnProps & ConnectPreviewMapProps & AdditionnalProps>, connectorOptions?: {
13
+ memoizeStateToProps?: boolean | undefined;
14
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectPreviewOwnProps & AdditionnalProps & {
13
15
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
14
16
  }>;
@@ -15,6 +15,8 @@ export declare type ConnectRootOptionDispatchProps = {
15
15
  addMultipleOccurency: () => void;
16
16
  deleteMultipleOccurency: (index: number) => void;
17
17
  };
18
- export declare const connectRootOption: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectRootOptionOwnProps & ConnectRootOptionMapProps & ConnectRootOptionDispatchProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectRootOptionOwnProps & AdditionnalProps & {
18
+ export declare const connectRootOption: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectRootOptionOwnProps & ConnectRootOptionMapProps & ConnectRootOptionDispatchProps & AdditionnalProps>, connectorOptions?: {
19
+ memoizeStateToProps?: boolean | undefined;
20
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectRootOptionOwnProps & AdditionnalProps & {
19
21
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
20
22
  }>;
@@ -8,6 +8,8 @@ export declare type ConnectSectionMapProps = {
8
8
  childOptions: number[];
9
9
  tags?: string[];
10
10
  };
11
- export declare const connectSection: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectSectionOwnProps & ConnectSectionMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectSectionOwnProps & AdditionnalProps & {
11
+ export declare const connectSection: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectSectionOwnProps & ConnectSectionMapProps & AdditionnalProps>, connectorOptions?: {
12
+ memoizeStateToProps?: boolean | undefined;
13
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectSectionOwnProps & AdditionnalProps & {
12
14
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
13
15
  }>;
@@ -1,24 +1,21 @@
1
1
  import { componentConnector, } from "./connector/componentConnector";
2
- const childOptionsCache = {};
3
2
  const stateToProps = (selectors) => (state, ownProps) => {
4
3
  const { selectCurrentSectionId, selectSectionReference, selectOptionReference, } = selectors;
5
4
  const id = typeof ownProps.id !== "undefined" ? ownProps.id : selectCurrentSectionId();
6
5
  const section = selectSectionReference(id);
7
6
  if (section === undefined)
8
7
  throw new Error(`Section ${id} does not exist`);
9
- if (!(id in childOptionsCache)) {
10
- childOptionsCache[id] = section.options.filter((optionId) => {
11
- const optionReference = selectOptionReference(optionId);
12
- if (optionReference === undefined)
13
- throw new Error(`Option ${optionId} does not exist`);
14
- return !["hidden", "repeated"].includes(optionReference.meta.type);
15
- });
16
- }
8
+ const childOptions = section.options.filter((optionId) => {
9
+ const optionReference = selectOptionReference(optionId);
10
+ if (optionReference === undefined)
11
+ throw new Error(`Option ${optionId} does not exist`);
12
+ return !["hidden", "repeated"].includes(optionReference.meta.type);
13
+ });
17
14
  const mandatoryValidated = selectors.selectMandatorySection(id);
18
15
  return {
19
16
  id,
20
17
  mandatoryValidated,
21
- childOptions: childOptionsCache[id],
18
+ childOptions,
22
19
  title: section.label,
23
20
  tags: section.tags,
24
21
  };
@@ -4,7 +4,9 @@ export declare type ConnectSummaryMapProps = {
4
4
  };
5
5
  export declare const connectSummary: <AdditionnalProps = {}>(Component: import("react").ComponentType<{
6
6
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
7
- } & ConnectSummaryMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & {
7
+ } & ConnectSummaryMapProps & AdditionnalProps>, connectorOptions?: {
8
+ memoizeStateToProps?: boolean | undefined;
9
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & {
8
10
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
9
11
  } & AdditionnalProps & {
10
12
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
@@ -10,6 +10,8 @@ export declare type ConnectSummaryItemMapProps = {
10
10
  pageNumber: number;
11
11
  disableClick?: boolean;
12
12
  };
13
- export declare const connectSummaryItem: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectSummaryItemOwnProps & ConnectSummaryItemMapProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectSummaryItemOwnProps & AdditionnalProps & {
13
+ export declare const connectSummaryItem: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectSummaryItemOwnProps & ConnectSummaryItemMapProps & AdditionnalProps>, connectorOptions?: {
14
+ memoizeStateToProps?: boolean | undefined;
15
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectSummaryItemOwnProps & AdditionnalProps & {
14
16
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
15
17
  }>;
@@ -1,4 +1,5 @@
1
1
  import type { VariableV3 } from "@legalplace/models-v3-types";
2
+ import { ConnectorMapSelectors } from "./connector/componentConnector";
2
3
  export declare type ConnectVariableOwnProps = {
3
4
  id: number;
4
5
  index: number;
@@ -7,7 +8,7 @@ export declare type ConnectVariableMapProps = {
7
8
  id: number;
8
9
  index: number;
9
10
  label: string;
10
- type: string;
11
+ type: VariableV3["type"] | "advancedmask";
11
12
  value: string | number;
12
13
  condition?: boolean;
13
14
  validator?: boolean;
@@ -20,6 +21,9 @@ export declare type ConnectVariableMapProps = {
20
21
  export declare type ConnectVariableDispatchProps = {
21
22
  updateVariable: (value: string | number) => void;
22
23
  };
23
- export declare const connectVariable: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectVariableOwnProps & ConnectVariableMapProps & ConnectVariableDispatchProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & ConnectVariableOwnProps & AdditionnalProps & {
24
+ export declare const canVariableDisplay: (id: number, index: number, selectors: ConnectorMapSelectors) => Readonly<boolean>;
25
+ export declare const connectVariable: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectVariableOwnProps & ConnectVariableMapProps & ConnectVariableDispatchProps & AdditionnalProps>, connectorOptions?: {
26
+ memoizeStateToProps?: boolean | undefined;
27
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & ConnectVariableOwnProps & AdditionnalProps & {
24
28
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
25
29
  }>;
@@ -1,7 +1,7 @@
1
1
  import { componentConnector, } from "./connector/componentConnector";
2
2
  import { isStepAvailable } from "../redux/selectors/app";
3
3
  import { parseRawWithVariables, parseVariableLabel, } from "../helpers/outputsParsing";
4
- const canVariableDisplay = (id, index, selectors) => {
4
+ export const canVariableDisplay = (id, index, selectors) => {
5
5
  const { selectVariableReference, isLevelAccessibleForUser } = selectors;
6
6
  const variable = selectVariableReference(id);
7
7
  let display = isStepAvailable(variable.step);
@@ -3,6 +3,8 @@ export declare type ConnectWizardWrapperDispatchProps = {
3
3
  closePreview: () => void;
4
4
  };
5
5
  export declare type ConnectWizardWrapperOwnProps = {};
6
- export declare const connectWizardWrapper: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectWizardWrapperDispatchProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & AdditionnalProps & {
6
+ export declare const connectWizardWrapper: <AdditionnalProps = {}>(Component: import("react").ComponentType<ConnectWizardWrapperDispatchProps & AdditionnalProps>, connectorOptions?: {
7
+ memoizeStateToProps?: boolean | undefined;
8
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<import("react").ComponentClass<any, any> | import("react").FunctionComponent<any>, import("react-redux").Omit<any, never> & AdditionnalProps & {
7
9
  store?: import("redux").Store<any, import("redux").AnyAction> | undefined;
8
10
  }>;
@@ -16,9 +16,13 @@ export declare function componentConnector<OwnProps = {}, MapProps = {}, Dispatc
16
16
  store?: Store;
17
17
  }, InjectedProps = OwnPropsWithStore & MapProps & DispatchProps>(options: {
18
18
  componentName: string;
19
+ connectStore?: boolean;
20
+ memoizeStateToProps?: true;
19
21
  stateToProps?: ConnectorStateToProps<OwnPropsWithStore, MapProps> | undefined;
20
22
  dispatchToProps?: ConnectorDispatchProps<OwnPropsWithStore, DispatchProps> | undefined;
21
23
  additionnalHooks?: AdditionnalHooksFunction<InjectedProps>;
22
- }): <AdditionnalProps = {}>(Component: React.ComponentType<InjectedProps & AdditionnalProps>) => import("react-redux").ConnectedComponent<any, import("react-redux").Omit<unknown, never> & OwnPropsWithStore & AdditionnalProps & {
24
+ }): <AdditionnalProps = {}>(Component: React.ComponentType<InjectedProps & AdditionnalProps>, connectorOptions?: {
25
+ memoizeStateToProps?: boolean | undefined;
26
+ } | undefined) => ((props: any) => JSX.Element) | import("react-redux").ConnectedComponent<React.ComponentClass<any, any> | React.FunctionComponent<any>, import("react-redux").Omit<any, never> & OwnPropsWithStore & AdditionnalProps & {
23
27
  store?: Store<any, import("redux").AnyAction> | undefined;
24
28
  }>;
@@ -1,8 +1,11 @@
1
1
  import { jsx as _jsx, Fragment as _Fragment, jsxs as _jsxs } from "react/jsx-runtime";
2
2
  import { connect } from "react-redux";
3
+ import sha1 from "@cryptography/sha1";
3
4
  import { PluginLoader, ReplaceComponent } from "../../PluginLoader";
4
5
  import { selectorsLibrary } from "../../redux/selectors/library";
5
6
  import { actionsLibrary } from "../../redux/actions/library";
7
+ import { getStore } from "../../redux/store";
8
+ import { propsEqualityCheck } from "../../helpers/propsEqualityCheck";
6
9
  const AnchorsHooks = (props, componentName, additionnalHooks) => {
7
10
  let beforeAnchors = [`before(${componentName})`];
8
11
  let afterAnchors = [`after(${componentName})`];
@@ -37,6 +40,33 @@ const ConnectorHooc = (Component, componentName, additionnalHooks) => {
37
40
  ConnectedComponent.displayName = `connectedComponent(${componentName})`;
38
41
  return ConnectedComponent;
39
42
  };
43
+ const generateCacheKey = (object) => sha1(Object.keys(object)
44
+ .map((prop) => {
45
+ if (typeof object[prop] === "function")
46
+ return `${prop}.function`;
47
+ if (typeof object[prop] === "undefined")
48
+ return `${prop}.undefined`;
49
+ if (object[prop] === null)
50
+ return `${prop}.null`;
51
+ if (object[prop] && typeof object[prop] === "object")
52
+ return `${prop}.${generateCacheKey(object[prop])}`;
53
+ return `${prop}.${object[prop].toString()}`;
54
+ })
55
+ .join("."), "hex");
56
+ function MemoizeStateToProps(stateToProps) {
57
+ if (!stateToProps)
58
+ return undefined;
59
+ const cache = {};
60
+ return (selectors) => (state, ownProps) => {
61
+ const nextProps = stateToProps(selectorsLibrary)(state, ownProps);
62
+ const cacheKey = generateCacheKey(ownProps);
63
+ const prevProps = cache[cacheKey];
64
+ const equalityCheck = prevProps && propsEqualityCheck(cache[cacheKey], nextProps);
65
+ if (!equalityCheck)
66
+ cache[cacheKey] = nextProps;
67
+ return cache[cacheKey];
68
+ };
69
+ }
40
70
  function ConnectorConnect(options) {
41
71
  const { stateToProps, dispatchToProps } = options;
42
72
  const mapStateToProps = stateToProps
@@ -47,12 +77,22 @@ function ConnectorConnect(options) {
47
77
  : undefined;
48
78
  return connect(mapStateToProps, mapDispatchToProps);
49
79
  }
80
+ function ConnectorConnectWithStore(options) {
81
+ const { stateToProps, dispatchToProps } = options;
82
+ return (Component) => {
83
+ const ConnectedWrappedComponent = ConnectorConnect({ stateToProps, dispatchToProps })(Component);
84
+ return (props) => (_jsx(ConnectedWrappedComponent, Object.assign({}, props, { store: getStore() }), void 0));
85
+ };
86
+ }
50
87
  export function componentConnector(options) {
51
- return function Connector(Component) {
52
- const { componentName, stateToProps, dispatchToProps, additionnalHooks } = options;
88
+ const { componentName, connectStore, stateToProps, dispatchToProps, additionnalHooks, } = options;
89
+ return function Connector(Component, connectorOptions) {
90
+ const memoizeStateToProps = options.memoizeStateToProps || (connectorOptions === null || connectorOptions === void 0 ? void 0 : connectorOptions.memoizeStateToProps);
53
91
  const hooc = ConnectorHooc(Component, componentName, additionnalHooks);
54
- return ConnectorConnect({
55
- stateToProps,
92
+ return (connectStore ? ConnectorConnectWithStore : ConnectorConnect)({
93
+ stateToProps: memoizeStateToProps
94
+ ? MemoizeStateToProps(stateToProps)
95
+ : stateToProps,
56
96
  dispatchToProps,
57
97
  })(hooc);
58
98
  };
@@ -0,0 +1 @@
1
+ export * from "./componentConnector";
@@ -0,0 +1 @@
1
+ export * from "./componentConnector";
@@ -0,0 +1,17 @@
1
+ export * from "./connectBox";
2
+ export * from "./connectDocument";
3
+ export * from "./connectHeader";
4
+ export * from "./connectMetaTitle";
5
+ export * from "./connectOption";
6
+ export * from "./connectPagination";
7
+ export * from "./connectPreview";
8
+ export * from "./connectProgress";
9
+ export * from "./connectRootOption";
10
+ export * from "./connectSection";
11
+ export * from "./connectSummary";
12
+ export * from "./connectSummaryItem";
13
+ export * from "./connectTermsheet";
14
+ export * from "./connectVariable";
15
+ export * from "./connectWizardWrapper";
16
+ export * from "./connector";
17
+ export * from "./library";
@@ -0,0 +1,17 @@
1
+ export * from "./connectBox";
2
+ export * from "./connectDocument";
3
+ export * from "./connectHeader";
4
+ export * from "./connectMetaTitle";
5
+ export * from "./connectOption";
6
+ export * from "./connectPagination";
7
+ export * from "./connectPreview";
8
+ export * from "./connectProgress";
9
+ export * from "./connectRootOption";
10
+ export * from "./connectSection";
11
+ export * from "./connectSummary";
12
+ export * from "./connectSummaryItem";
13
+ export * from "./connectTermsheet";
14
+ export * from "./connectVariable";
15
+ export * from "./connectWizardWrapper";
16
+ export * from "./connector";
17
+ export * from "./library";