@legalplace/wizardx-core 2.6.4 → 2.7.1

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (348) hide show
  1. package/CHANGELOG.md +49 -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/components/SmartScript.d.ts +2 -2
  7. package/dist/components/SmartScript.js +2 -0
  8. package/dist/componentsConnectors/connectBox.d.ts +3 -1
  9. package/dist/componentsConnectors/connectDocument.d.ts +3 -1
  10. package/dist/componentsConnectors/connectHeader.d.ts +3 -1
  11. package/dist/componentsConnectors/connectMetaTitle.d.ts +3 -1
  12. package/dist/componentsConnectors/connectOption.d.ts +6 -2
  13. package/dist/componentsConnectors/connectOption.js +1 -1
  14. package/dist/componentsConnectors/connectPagination.d.ts +3 -1
  15. package/dist/componentsConnectors/connectPreview.d.ts +3 -1
  16. package/dist/componentsConnectors/connectProgress.d.ts +3 -1
  17. package/dist/componentsConnectors/connectRootOption.d.ts +3 -1
  18. package/dist/componentsConnectors/connectSection.d.ts +3 -1
  19. package/dist/componentsConnectors/connectSection.js +7 -10
  20. package/dist/componentsConnectors/connectSummary.d.ts +3 -1
  21. package/dist/componentsConnectors/connectSummaryItem.d.ts +3 -1
  22. package/dist/componentsConnectors/connectVariable.d.ts +6 -2
  23. package/dist/componentsConnectors/connectVariable.js +1 -1
  24. package/dist/componentsConnectors/connectWizardWrapper.d.ts +3 -1
  25. package/dist/componentsConnectors/connector/componentConnector.d.ts +5 -1
  26. package/dist/componentsConnectors/connector/componentConnector.js +43 -4
  27. package/dist/componentsConnectors/connector/index.d.ts +1 -0
  28. package/dist/componentsConnectors/connector/index.js +1 -0
  29. package/dist/componentsConnectors/index.d.ts +17 -0
  30. package/dist/componentsConnectors/index.js +17 -0
  31. package/dist/componentsConnectors/library.d.ts +43 -15
  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 +10 -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/PathReader.d.ts +10 -6
  49. package/dist/libs/PathReader.js +47 -28
  50. package/dist/libs/index.d.ts +5 -0
  51. package/dist/libs/index.js +5 -0
  52. package/dist/redux/actions/index.d.ts +9 -0
  53. package/dist/redux/actions/index.js +9 -0
  54. package/dist/redux/actions/library.d.ts +59 -63
  55. package/dist/redux/actions/sagas/index.d.ts +3 -0
  56. package/dist/redux/actions/sagas/index.js +3 -0
  57. package/dist/redux/actions/sagas/model.d.ts +1 -5
  58. package/dist/redux/constants/app.d.ts +2 -0
  59. package/dist/redux/constants/app.js +2 -0
  60. package/dist/redux/constants/index.d.ts +8 -0
  61. package/dist/redux/constants/index.js +8 -0
  62. package/dist/redux/constants/sagas/index.d.ts +3 -0
  63. package/dist/redux/constants/sagas/index.js +3 -0
  64. package/dist/redux/index.d.ts +5 -0
  65. package/dist/redux/index.js +5 -0
  66. package/dist/redux/middlewares/conditionsWatcherMiddleware.js +11 -5
  67. package/dist/redux/middlewares/conditionsWatcherMiddleware.test.js +120 -113
  68. package/dist/redux/middlewares/paginationWatcherMiddleware.js +2 -2
  69. package/dist/redux/middlewares/smartscriptMiddleware.js +8 -0
  70. package/dist/redux/reducers/pluginsStore.d.ts +3 -0
  71. package/dist/redux/reducers/pluginsStore.js +12 -0
  72. package/dist/redux/routerHistory.js +2 -2
  73. package/dist/redux/sagas/fetchModel.js +22 -6
  74. package/dist/redux/sagas/initInputs.js +6 -7
  75. package/dist/redux/sagas/saveData.js +2 -0
  76. package/dist/redux/selectors/app.js +13 -18
  77. package/dist/redux/selectors/cache.d.ts +17 -0
  78. package/dist/redux/selectors/cache.js +35 -0
  79. package/dist/redux/selectors/conditions.js +7 -7
  80. package/dist/redux/selectors/index.d.ts +8 -0
  81. package/dist/redux/selectors/index.js +8 -0
  82. package/dist/redux/selectors/inputs.js +3 -3
  83. package/dist/redux/selectors/library.d.ts +2 -2
  84. package/dist/redux/selectors/references.js +26 -26
  85. package/dist/redux/selectors/selectors.d.ts +2 -2
  86. package/dist/redux/selectors/selectors.js +19 -8
  87. package/dist/redux/selectors/selectors.test.js +6 -6
  88. package/dist/redux/selectors/user.js +5 -5
  89. package/dist/redux/store.d.ts +1 -1
  90. package/dist/redux/store.js +12 -4
  91. package/dist/service/api.manager.d.ts +1 -6
  92. package/dist/service/index.d.ts +3 -0
  93. package/dist/service/index.js +3 -0
  94. package/dist/types/PluginConfig.type.d.ts +57 -0
  95. package/dist/types/PluginConfig.type.js +1 -0
  96. package/dist/types/State.type.d.ts +6 -0
  97. package/dist/types/config.type.d.ts +3 -1
  98. package/dist/types/index.d.ts +11 -0
  99. package/dist/types/index.js +11 -0
  100. package/package.json +13 -13
  101. package/.depcheckrc +0 -1
  102. package/.eslintignore +0 -2
  103. package/.eslintrc +0 -5
  104. package/__mocks__/fileMock.js +0 -1
  105. package/babel.config.json +0 -3
  106. package/jest.config.ts +0 -193
  107. package/setupJest.ts +0 -8
  108. package/src/App.test.tsx +0 -41
  109. package/src/App.tsx +0 -152
  110. package/src/Globals.ts +0 -69
  111. package/src/Loader.tsx +0 -8
  112. package/src/PluginLoader.test.tsx +0 -70
  113. package/src/PluginLoader.tsx +0 -407
  114. package/src/Shimmer.tsx +0 -108
  115. package/src/ThemeLoader.test.tsx +0 -82
  116. package/src/ThemeLoader.tsx +0 -95
  117. package/src/components/PluginRoute.tsx +0 -48
  118. package/src/components/SmartScript.tsx +0 -166
  119. package/src/components/UserLocked/UserLockedComponent.tsx +0 -33
  120. package/src/components/View.test.tsx +0 -110
  121. package/src/components/View.tsx +0 -114
  122. package/src/componentsConnectors/connectBox.test.tsx +0 -226
  123. package/src/componentsConnectors/connectBox.tsx +0 -70
  124. package/src/componentsConnectors/connectDocument.test.tsx +0 -108
  125. package/src/componentsConnectors/connectDocument.tsx +0 -64
  126. package/src/componentsConnectors/connectHeader.tsx +0 -21
  127. package/src/componentsConnectors/connectMetaTitle.test.tsx +0 -40
  128. package/src/componentsConnectors/connectMetaTitle.tsx +0 -8
  129. package/src/componentsConnectors/connectOption.tsx +0 -222
  130. package/src/componentsConnectors/connectPagination.tsx +0 -102
  131. package/src/componentsConnectors/connectPreview.tsx +0 -5
  132. package/src/componentsConnectors/connectProgress.tsx +0 -59
  133. package/src/componentsConnectors/connectRootOption.tsx +0 -95
  134. package/src/componentsConnectors/connectSection.tsx +0 -79
  135. package/src/componentsConnectors/connectSummary.tsx +0 -21
  136. package/src/componentsConnectors/connectSummaryItem.tsx +0 -102
  137. package/src/componentsConnectors/connectTermsheet.tsx +0 -359
  138. package/src/componentsConnectors/connectVariable.tsx +0 -191
  139. package/src/componentsConnectors/connectWizardWrapper.tsx +0 -30
  140. package/src/componentsConnectors/connector/componentConnector.tsx +0 -219
  141. package/src/componentsConnectors/library.ts +0 -35
  142. package/src/config.test.ts +0 -63
  143. package/src/config.ts +0 -11
  144. package/src/constants/emailValidation.ts +0 -2
  145. package/src/constants/phoneValidation.ts +0 -4
  146. package/src/definitions/path.join.d.ts +0 -4
  147. package/src/helpers/outputsParsing.ts +0 -412
  148. package/src/helpers/preloadTheme.ts +0 -17
  149. package/src/helpers/scriptsLoader.ts +0 -20
  150. package/src/hooks/usePrevious.ts +0 -9
  151. package/src/libs/ConditionsInitiator.ts +0 -164
  152. package/src/libs/ConditionsRunner/DataPopulator.ts +0 -266
  153. package/src/libs/ConditionsRunner.ts +0 -454
  154. package/src/libs/DocumentsOutputs.ts +0 -171
  155. package/src/libs/Eval/EvalBase.ts +0 -116
  156. package/src/libs/Eval/EvalFunctions.ts +0 -724
  157. package/src/libs/Eval/NumbersToLetters.ts +0 -185
  158. package/src/libs/EvalVariable.ts +0 -265
  159. package/src/libs/EventsTracking.ts +0 -250
  160. package/src/libs/InputsInitiator.ts +0 -136
  161. package/src/libs/NumAuto.test.ts +0 -55
  162. package/src/libs/NumAuto.ts +0 -56
  163. package/src/libs/OvcConverter.ts +0 -285
  164. package/src/libs/PathReader.ts +0 -272
  165. package/src/libs/SectionValidity.test.ts +0 -146
  166. package/src/libs/SectionValidity.ts +0 -110
  167. package/src/libs/SmartScriptStore.ts +0 -492
  168. package/src/misc/test_model.ts +0 -14603
  169. package/src/misc/test_models/connectDocumen.testmodel.json +0 -178
  170. package/src/misc/test_models/setDefaults.testmodel.json +0 -279
  171. package/src/misc/test_models/testmodel.json +0 -1
  172. package/src/polyfills/index.ts +0 -5
  173. package/src/polyfills/objectValues.ts +0 -4
  174. package/src/polyfills/prepend.ts +0 -31
  175. package/src/polyfills/stringRepeat.ts +0 -44
  176. package/src/redux/actions/app.test.ts +0 -123
  177. package/src/redux/actions/app.ts +0 -249
  178. package/src/redux/actions/conditions.test.ts +0 -84
  179. package/src/redux/actions/conditions.ts +0 -135
  180. package/src/redux/actions/inputs.test.ts +0 -85
  181. package/src/redux/actions/inputs.ts +0 -111
  182. package/src/redux/actions/library.ts +0 -23
  183. package/src/redux/actions/mandatories.ts +0 -98
  184. package/src/redux/actions/references.test.ts +0 -48
  185. package/src/redux/actions/references.ts +0 -37
  186. package/src/redux/actions/sagas/data.test.ts +0 -11
  187. package/src/redux/actions/sagas/data.ts +0 -18
  188. package/src/redux/actions/sagas/model.test.ts +0 -14
  189. package/src/redux/actions/sagas/model.ts +0 -48
  190. package/src/redux/actions/sagas/user.ts +0 -25
  191. package/src/redux/actions/smartscript.ts +0 -55
  192. package/src/redux/actions/user.test.ts +0 -18
  193. package/src/redux/actions/user.ts +0 -41
  194. package/src/redux/constants/app.ts +0 -36
  195. package/src/redux/constants/conditions.ts +0 -25
  196. package/src/redux/constants/inputs.ts +0 -15
  197. package/src/redux/constants/mandatories.ts +0 -11
  198. package/src/redux/constants/references.ts +0 -7
  199. package/src/redux/constants/sagas/data.ts +0 -1
  200. package/src/redux/constants/sagas/model.ts +0 -2
  201. package/src/redux/constants/sagas/user.ts +0 -2
  202. package/src/redux/constants/smartscript.ts +0 -9
  203. package/src/redux/constants/user.ts +0 -6
  204. package/src/redux/listeners/subscriber.test.ts +0 -45
  205. package/src/redux/listeners/subscriber.ts +0 -29
  206. package/src/redux/middlewares/conditionsWatcherMiddleware.test.ts +0 -370
  207. package/src/redux/middlewares/conditionsWatcherMiddleware.ts +0 -321
  208. package/src/redux/middlewares/evaluationsWatcherMiddleware.test.ts +0 -323
  209. package/src/redux/middlewares/evaluationsWatcherMiddleware.ts +0 -250
  210. package/src/redux/middlewares/mandatoriesWatcherMiddleware.ts +0 -473
  211. package/src/redux/middlewares/multiplesActionsMiddleware.test.ts +0 -230
  212. package/src/redux/middlewares/multiplesActionsMiddleware.ts +0 -121
  213. package/src/redux/middlewares/paginationWatcherMiddleware.ts +0 -251
  214. package/src/redux/middlewares/pluginsHookMiddleware.ts +0 -24
  215. package/src/redux/middlewares/prefillerWatcherMiddleware.test.ts +0 -118
  216. package/src/redux/middlewares/prefillerWatcherMiddleware.ts +0 -462
  217. package/src/redux/middlewares/smartscriptMiddleware.ts +0 -228
  218. package/src/redux/middlewares/thirdpartyScriptsMiddleware.ts +0 -41
  219. package/src/redux/reducers/app/customizations/initCustomizationAutoDefault.ts +0 -16
  220. package/src/redux/reducers/app/customizations/initCustomizationMeta.ts +0 -16
  221. package/src/redux/reducers/app/instance/initInstance.ts +0 -29
  222. package/src/redux/reducers/app/instance/setDataStatus.ts +0 -16
  223. package/src/redux/reducers/app/instance/updateInstance.ts +0 -30
  224. package/src/redux/reducers/app/instance/updateInstancePaid.ts +0 -20
  225. package/src/redux/reducers/app/instance.test.ts +0 -106
  226. package/src/redux/reducers/app/meta/fetchModelFailed.ts +0 -11
  227. package/src/redux/reducers/app/meta/fetchModelNonBlocking.ts +0 -11
  228. package/src/redux/reducers/app/meta/fetchModelSucceeded.ts +0 -11
  229. package/src/redux/reducers/app/meta/fetchModelUnhealthy.ts +0 -18
  230. package/src/redux/reducers/app/meta/fetchModelUserLocked.ts +0 -11
  231. package/src/redux/reducers/app/meta/initMeta.ts +0 -22
  232. package/src/redux/reducers/app/meta/setModelUuid.ts +0 -17
  233. package/src/redux/reducers/app/meta.test.ts +0 -90
  234. package/src/redux/reducers/app/pagination/goNextPage.ts +0 -69
  235. package/src/redux/reducers/app/pagination/goPage.ts +0 -81
  236. package/src/redux/reducers/app/pagination/goPreviousPage.ts +0 -60
  237. package/src/redux/reducers/app/pagination/initPagination.ts +0 -46
  238. package/src/redux/reducers/app/pagination/updateAvailableAppStates.ts +0 -77
  239. package/src/redux/reducers/app/pagination.test.ts +0 -363
  240. package/src/redux/reducers/app/wizard/updateAvailableSections.ts +0 -40
  241. package/src/redux/reducers/app/wizard.test.ts +0 -84
  242. package/src/redux/reducers/app.test.ts +0 -336
  243. package/src/redux/reducers/app.ts +0 -150
  244. package/src/redux/reducers/conditions/addMultipleOccurency.test.ts +0 -131
  245. package/src/redux/reducers/conditions/addMultipleOccurency.ts +0 -155
  246. package/src/redux/reducers/conditions/deleteMultipleOccurency.test.ts +0 -95
  247. package/src/redux/reducers/conditions/deleteMultipleOccurency.ts +0 -141
  248. package/src/redux/reducers/conditions/initConditions.ts +0 -18
  249. package/src/redux/reducers/conditions/updateDocumentConditions.test.ts +0 -47
  250. package/src/redux/reducers/conditions/updateDocumentConditions.ts +0 -21
  251. package/src/redux/reducers/conditions/updateOptionConditions.ts +0 -24
  252. package/src/redux/reducers/conditions/updateOptionValidatorCondition.test.ts +0 -50
  253. package/src/redux/reducers/conditions/updateOptionValidatorCondition.ts +0 -28
  254. package/src/redux/reducers/conditions/updatePrefillerConditions.ts +0 -29
  255. package/src/redux/reducers/conditions/updateSectionConditions.ts +0 -28
  256. package/src/redux/reducers/conditions/updateVariableConditions.ts +0 -25
  257. package/src/redux/reducers/conditions/updateVariableValidatorCondition.test.ts +0 -50
  258. package/src/redux/reducers/conditions/updateVariableValidatorCondition.ts +0 -28
  259. package/src/redux/reducers/conditions.test.ts +0 -241
  260. package/src/redux/reducers/conditions.ts +0 -68
  261. package/src/redux/reducers/inputs/addMultipleOccurency.test.ts +0 -117
  262. package/src/redux/reducers/inputs/addMultipleOccurency.ts +0 -50
  263. package/src/redux/reducers/inputs/deleteMultipleOccurency.test.ts +0 -70
  264. package/src/redux/reducers/inputs/deleteMultipleOccurency.ts +0 -50
  265. package/src/redux/reducers/inputs/initOption.ts +0 -16
  266. package/src/redux/reducers/inputs/initVariable.ts +0 -16
  267. package/src/redux/reducers/inputs/updateOptionInput.ts +0 -24
  268. package/src/redux/reducers/inputs/updateVariableInput.ts +0 -24
  269. package/src/redux/reducers/inputs.test.ts +0 -221
  270. package/src/redux/reducers/inputs.ts +0 -51
  271. package/src/redux/reducers/mandatories/addMultipleOccurency.ts +0 -52
  272. package/src/redux/reducers/mandatories/deleteMultipleOccurency.ts +0 -55
  273. package/src/redux/reducers/mandatories/initMandatoryOption.ts +0 -17
  274. package/src/redux/reducers/mandatories/initMandatoryVariable.ts +0 -17
  275. package/src/redux/reducers/mandatories/setMandatoryIgnore.ts +0 -17
  276. package/src/redux/reducers/mandatories/setMandatoryOption.ts +0 -25
  277. package/src/redux/reducers/mandatories/setMandatorySection.ts +0 -20
  278. package/src/redux/reducers/mandatories/setMandatoryVariable.ts +0 -24
  279. package/src/redux/reducers/mandatories.ts +0 -56
  280. package/src/redux/reducers/references/initReferences.ts +0 -37
  281. package/src/redux/reducers/references/updateOptionMeta.ts +0 -73
  282. package/src/redux/reducers/references/updateVariableMeta.ts +0 -72
  283. package/src/redux/reducers/references.ts +0 -59
  284. package/src/redux/reducers/smartscript/enableSmartScript.ts +0 -13
  285. package/src/redux/reducers/smartscript/initSmartScriptTriggers.ts +0 -14
  286. package/src/redux/reducers/smartscript/updateSmartscriptOptionHidden.ts +0 -30
  287. package/src/redux/reducers/smartscript/updateSmartscriptVariableHidden.ts +0 -30
  288. package/src/redux/reducers/smartscript.ts +0 -47
  289. package/src/redux/reducers/user/initUser.ts +0 -15
  290. package/src/redux/reducers/user/setUserStatus.ts +0 -13
  291. package/src/redux/reducers/user/setUserValidToken.ts +0 -13
  292. package/src/redux/reducers/user.test.ts +0 -51
  293. package/src/redux/reducers/user.ts +0 -40
  294. package/src/redux/routerHistore.test.ts +0 -19
  295. package/src/redux/routerHistory.ts +0 -26
  296. package/src/redux/sagas/fetchModel.test.ts +0 -76
  297. package/src/redux/sagas/fetchModel.ts +0 -683
  298. package/src/redux/sagas/homogeneousRadioInputsSaga.ts +0 -42
  299. package/src/redux/sagas/initInputs.ts +0 -110
  300. package/src/redux/sagas/runner.test.ts +0 -12
  301. package/src/redux/sagas/runner.ts +0 -26
  302. package/src/redux/sagas/saveData.test.ts +0 -125
  303. package/src/redux/sagas/saveData.ts +0 -55
  304. package/src/redux/sagas/setDefaults.test.ts +0 -100
  305. package/src/redux/sagas/setDefaults.ts +0 -167
  306. package/src/redux/sagas/setUserEmail.ts +0 -175
  307. package/src/redux/selectors/app.test.ts +0 -162
  308. package/src/redux/selectors/app.ts +0 -331
  309. package/src/redux/selectors/conditions.test.ts +0 -92
  310. package/src/redux/selectors/conditions.ts +0 -293
  311. package/src/redux/selectors/inputs.test.ts +0 -72
  312. package/src/redux/selectors/inputs.ts +0 -76
  313. package/src/redux/selectors/library.ts +0 -17
  314. package/src/redux/selectors/mandatories.ts +0 -83
  315. package/src/redux/selectors/references.test.ts +0 -660
  316. package/src/redux/selectors/references.ts +0 -413
  317. package/src/redux/selectors/selectors.test.ts +0 -21
  318. package/src/redux/selectors/selectors.ts +0 -87
  319. package/src/redux/selectors/smartscript.ts +0 -30
  320. package/src/redux/selectors/user.test.ts +0 -39
  321. package/src/redux/selectors/user.ts +0 -45
  322. package/src/redux/store.test.ts +0 -22
  323. package/src/redux/store.ts +0 -100
  324. package/src/service/api.manager.ts +0 -261
  325. package/src/service/auth.service.ts +0 -5
  326. package/src/service/pardot.service.ts +0 -10
  327. package/src/tests-misc/plugins/jestTestPlugin/after.tsx +0 -5
  328. package/src/tests-misc/plugins/jestTestPlugin/before.tsx +0 -11
  329. package/src/tests-misc/plugins/jestTestPlugin/index.ts +0 -11
  330. package/src/tests-misc/plugins/jestTestPlugin/title.tsx +0 -8
  331. package/src/tests-misc/themes/jestTestTheme/components/EmailComponent.tsx +0 -5
  332. package/src/tests-misc/themes/jestTestTheme/components/TermsheetComponent.tsx +0 -5
  333. package/src/tests-misc/themes/jestTestTheme/components/WizardComponent.tsx +0 -5
  334. package/src/tests-misc/themes/jestTestTheme/faltyIndex.ts +0 -3
  335. package/src/tests-misc/themes/jestTestTheme/faltyIndexLoader.ts +0 -1
  336. package/src/tests-misc/themes/jestTestTheme/index.ts +0 -13
  337. package/src/types/Actions.type.ts +0 -612
  338. package/src/types/Components.type.ts +0 -181
  339. package/src/types/State.type.ts +0 -323
  340. package/src/types/Termsheet.type.ts +0 -28
  341. package/src/types/api.type.ts +0 -37
  342. package/src/types/config.type.ts +0 -55
  343. package/src/types/env.type.ts +0 -5
  344. package/src/types/getActions.type.ts +0 -3
  345. package/src/types/getConnectors.type.ts +0 -5
  346. package/src/types/getSelectors.type.ts +0 -3
  347. package/src/wizard-params.ts +0 -56
  348. package/tsconfig.json +0 -43
package/CHANGELOG.md CHANGED
@@ -3,6 +3,55 @@
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.1](https://git.legalplace.eu/legalplace/monorepo/compare/@legalplace/wizardx-core@2.7.0...@legalplace/wizardx-core@2.7.1) (2022-01-18)
7
+
8
+
9
+ ### Bug Fixes
10
+
11
+ * fix cacheKey for memoized states api[#4719](https://git.legalplace.eu/legalplace/monorepo/issues/4719) ([b76f9a0](https://git.legalplace.eu/legalplace/monorepo/commits/b76f9a0cbee082ff607da40682a40253c9991eec))
12
+ * fix input type number and enabling bundle analyzer with variable only api[#4719](https://git.legalplace.eu/legalplace/monorepo/issues/4719) ([3948d0b](https://git.legalplace.eu/legalplace/monorepo/commits/3948d0b520ebc2aac5f1ad735d0beb12814486f2))
13
+ * fix issue with props equalityCheck on state memoization api[#4719](https://git.legalplace.eu/legalplace/monorepo/issues/4719) ([e059091](https://git.legalplace.eu/legalplace/monorepo/commits/e059091be42aa358598f4bc2173fd940c7da968f))
14
+ * fix moment import api[#4719](https://git.legalplace.eu/legalplace/monorepo/issues/4719) ([bb4fd18](https://git.legalplace.eu/legalplace/monorepo/commits/bb4fd188666fb412e8c96cd22bc7149c5566aa55))
15
+
16
+
17
+
18
+
19
+
20
+ # [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)
21
+
22
+
23
+ ### Bug Fixes
24
+
25
+ * 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))
26
+ * code review fixes api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([86ab582](https://git.legalplace.eu/legalplace/monorepo/commits/86ab582aa1a460b9c2ee2adcfd25e8f93237a0c1))
27
+ * fix checkout init api[#4664](https://git.legalplace.eu/legalplace/monorepo/issues/4664) ([416afea](https://git.legalplace.eu/legalplace/monorepo/commits/416afea28f527f1fdcd9a23381a948b25f482f3f))
28
+ * 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))
29
+ * fix import api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([f7eaafe](https://git.legalplace.eu/legalplace/monorepo/commits/f7eaafe34a1314e82eeff1fc7ac38c7624a2395c))
30
+ * fix linting api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([40c3b1a](https://git.legalplace.eu/legalplace/monorepo/commits/40c3b1aeedf35b7bebd279a3f841ee00d5ff8720))
31
+ * fix merges api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([0ad9d26](https://git.legalplace.eu/legalplace/monorepo/commits/0ad9d2634d7a0f09e44422aec121b8f46c8143d0))
32
+ * fix mr api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([6111eda](https://git.legalplace.eu/legalplace/monorepo/commits/6111eda4cef95c7edbf32927b5c3e77ff6ad5bce))
33
+ * 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))
34
+ * fix permalink init. api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([273b4c1](https://git.legalplace.eu/legalplace/monorepo/commits/273b4c190a76f9750498060bec77e7288712308e))
35
+ * fixing paginationWatcherMiddleware api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([4d44ec7](https://git.legalplace.eu/legalplace/monorepo/commits/4d44ec78f6b4cae9ef3226778029555d8e2b8af9))
36
+ * fixing prefix name api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([37dbba0](https://git.legalplace.eu/legalplace/monorepo/commits/37dbba07993c0ccafdaf1b0703bf7b9bdfbc7069))
37
+ * 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))
38
+ * 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))
39
+ * 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))
40
+ * upgrading @legalplace/storybook api[#4604](https://git.legalplace.eu/legalplace/monorepo/issues/4604) ([351b97a](https://git.legalplace.eu/legalplace/monorepo/commits/351b97a4832b118986a56dcfe47c9bf194e15fdd))
41
+ * upgrading alpha storybook version api[#4664](https://git.legalplace.eu/legalplace/monorepo/issues/4664) ([ab440d8](https://git.legalplace.eu/legalplace/monorepo/commits/ab440d8e8f3b01de289e45bc50bf72ce4122a4e2))
42
+
43
+
44
+ ### Features
45
+
46
+ * 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))
47
+ * adding support for document titles api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([dbe69cb](https://git.legalplace.eu/legalplace/monorepo/commits/dbe69cb815efe5bd23f0b097bf7ae07c51c06f5b))
48
+ * 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))
49
+ * using wizardx for company sheet api[#4471](https://git.legalplace.eu/legalplace/monorepo/issues/4471) ([551dbc3](https://git.legalplace.eu/legalplace/monorepo/commits/551dbc373dc3c8502fd119eccd731986f305d8e3))
50
+
51
+
52
+
53
+
54
+
6
55
  ## [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)
7
56
 
8
57
  **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
  };
@@ -1,5 +1,5 @@
1
1
  import { Action } from "redux";
2
- import type { Moment } from "moment-business-days";
2
+ import moment from "moment-business-days";
3
3
  import { SmartScriptStore } from "../libs/SmartScriptStore";
4
4
  import { StateType } from "../types/State.type";
5
5
  export declare type TInitTriggersCallback = (triggers: StateType.SmartScript["triggers"], actions: Action[]) => void;
@@ -21,7 +21,7 @@ declare global {
21
21
  displayOption: typeof SmartScriptStore.displayOption;
22
22
  hideVariable: typeof SmartScriptStore.hideVariable;
23
23
  displayVariable: typeof SmartScriptStore.displayVariable;
24
- moment: Moment;
24
+ moment: typeof moment;
25
25
  triggerListeners: (type: "option" | "variable", id: number, inputs: StateType.Inputs) => Action[];
26
26
  initTriggers: (callback: TInitTriggersCallback, inputs: StateType.Inputs, newInstance: boolean) => void;
27
27
  }
@@ -2,6 +2,7 @@ import { Fragment as _Fragment, jsx as _jsx } from "react/jsx-runtime";
2
2
  import { useEffect, useState } from "react";
3
3
  import { useParams } from "react-router-dom";
4
4
  import queryString from "query-string";
5
+ import moment from "moment-business-days";
5
6
  import { getConfig } from "../config";
6
7
  import { SmartScriptStore } from "../libs/SmartScriptStore";
7
8
  const SmartScriptComponent = () => {
@@ -24,6 +25,7 @@ const SmartScriptComponent = () => {
24
25
  window.displayVariable = SmartScriptStore.displayVariable;
25
26
  window.hideOption = SmartScriptStore.hideOption;
26
27
  window.displayOption = SmartScriptStore.displayOption;
28
+ window.moment = moment;
27
29
  const apiEndpoint = getConfig().apiEndpoint + (/\/$/.test(getConfig().apiEndpoint) ? "" : "/");
28
30
  const { permalink, uniqid } = useParams();
29
31
  const modelVersion = queryString.parse(window.location.search).version;
@@ -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,32 @@ const ConnectorHooc = (Component, componentName, additionnalHooks) => {
37
40
  ConnectedComponent.displayName = `connectedComponent(${componentName})`;
38
41
  return ConnectedComponent;
39
42
  };
43
+ const generateCacheKey = (object, hashKey = true) => {
44
+ const key = Object.entries(object).reduce((p, [prop, value]) => {
45
+ if (["function", "undefined"].includes(typeof value))
46
+ return `${p}.${prop}.${typeof value}`;
47
+ if (value === null)
48
+ return `${p}.${prop}.null`;
49
+ if (value && typeof value === "object")
50
+ return `${prop}.${generateCacheKey(value, false)}`;
51
+ return `${p}.${prop}.${value.toString()}`;
52
+ }, "");
53
+ return hashKey && key.length > 40 ? sha1(key, "hex") : key;
54
+ };
55
+ function MemoizeStateToProps(componentName, stateToProps) {
56
+ if (!stateToProps)
57
+ return undefined;
58
+ const cache = {};
59
+ return (selectors) => (state, ownProps) => {
60
+ const nextProps = stateToProps(selectors)(state, ownProps);
61
+ const cacheKey = generateCacheKey(ownProps);
62
+ const prevProps = cache[cacheKey];
63
+ const equalityCheck = prevProps && propsEqualityCheck(cache[cacheKey], nextProps);
64
+ if (!equalityCheck)
65
+ cache[cacheKey] = nextProps;
66
+ return cache[cacheKey];
67
+ };
68
+ }
40
69
  function ConnectorConnect(options) {
41
70
  const { stateToProps, dispatchToProps } = options;
42
71
  const mapStateToProps = stateToProps
@@ -47,12 +76,22 @@ function ConnectorConnect(options) {
47
76
  : undefined;
48
77
  return connect(mapStateToProps, mapDispatchToProps);
49
78
  }
79
+ function ConnectorConnectWithStore(options) {
80
+ const { stateToProps, dispatchToProps } = options;
81
+ return (Component) => {
82
+ const ConnectedWrappedComponent = ConnectorConnect({ stateToProps, dispatchToProps })(Component);
83
+ return (props) => (_jsx(ConnectedWrappedComponent, Object.assign({}, props, { store: getStore() }), void 0));
84
+ };
85
+ }
50
86
  export function componentConnector(options) {
51
- return function Connector(Component) {
52
- const { componentName, stateToProps, dispatchToProps, additionnalHooks } = options;
87
+ const { componentName, connectStore, stateToProps, dispatchToProps, additionnalHooks, } = options;
88
+ return function Connector(Component, connectorOptions) {
89
+ const memoizeStateToProps = options.memoizeStateToProps || (connectorOptions === null || connectorOptions === void 0 ? void 0 : connectorOptions.memoizeStateToProps);
53
90
  const hooc = ConnectorHooc(Component, componentName, additionnalHooks);
54
- return ConnectorConnect({
55
- stateToProps,
91
+ return (connectStore ? ConnectorConnectWithStore : ConnectorConnect)({
92
+ stateToProps: memoizeStateToProps
93
+ ? MemoizeStateToProps(componentName, stateToProps)
94
+ : stateToProps,
56
95
  dispatchToProps,
57
96
  })(hooc);
58
97
  };
@@ -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";