@legalplace/wizardx-core 2.6.4 → 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 (346) hide show
  1. package/CHANGELOG.md +35 -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/helpers/apiEndpoint.d.ts +1 -0
  31. package/dist/helpers/apiEndpoint.js +4 -0
  32. package/dist/helpers/index.d.ts +4 -0
  33. package/dist/helpers/index.js +4 -0
  34. package/dist/helpers/propsEqualityCheck.d.ts +1 -0
  35. package/dist/helpers/propsEqualityCheck.js +9 -0
  36. package/dist/hooks/index.d.ts +4 -0
  37. package/dist/hooks/index.js +4 -0
  38. package/dist/hooks/useActions.d.ts +2 -0
  39. package/dist/hooks/useActions.js +4 -0
  40. package/dist/hooks/useDispatch.d.ts +1 -0
  41. package/dist/hooks/useDispatch.js +4 -0
  42. package/dist/hooks/useSelectors.d.ts +2 -0
  43. package/dist/hooks/useSelectors.js +4 -0
  44. package/dist/index.d.ts +13 -0
  45. package/dist/index.js +13 -0
  46. package/dist/libs/PathReader.d.ts +10 -6
  47. package/dist/libs/PathReader.js +47 -28
  48. package/dist/libs/index.d.ts +5 -0
  49. package/dist/libs/index.js +5 -0
  50. package/dist/redux/actions/index.d.ts +9 -0
  51. package/dist/redux/actions/index.js +9 -0
  52. package/dist/redux/actions/library.d.ts +59 -63
  53. package/dist/redux/actions/sagas/index.d.ts +3 -0
  54. package/dist/redux/actions/sagas/index.js +3 -0
  55. package/dist/redux/actions/sagas/model.d.ts +1 -5
  56. package/dist/redux/constants/app.d.ts +2 -0
  57. package/dist/redux/constants/app.js +2 -0
  58. package/dist/redux/constants/index.d.ts +8 -0
  59. package/dist/redux/constants/index.js +8 -0
  60. package/dist/redux/constants/sagas/index.d.ts +3 -0
  61. package/dist/redux/constants/sagas/index.js +3 -0
  62. package/dist/redux/index.d.ts +5 -0
  63. package/dist/redux/index.js +5 -0
  64. package/dist/redux/middlewares/conditionsWatcherMiddleware.js +11 -5
  65. package/dist/redux/middlewares/conditionsWatcherMiddleware.test.js +120 -113
  66. package/dist/redux/middlewares/paginationWatcherMiddleware.js +2 -2
  67. package/dist/redux/middlewares/smartscriptMiddleware.js +8 -0
  68. package/dist/redux/reducers/pluginsStore.d.ts +3 -0
  69. package/dist/redux/reducers/pluginsStore.js +12 -0
  70. package/dist/redux/routerHistory.js +2 -2
  71. package/dist/redux/sagas/fetchModel.js +22 -6
  72. package/dist/redux/sagas/initInputs.js +6 -7
  73. package/dist/redux/sagas/saveData.js +2 -0
  74. package/dist/redux/selectors/app.js +13 -18
  75. package/dist/redux/selectors/cache.d.ts +17 -0
  76. package/dist/redux/selectors/cache.js +35 -0
  77. package/dist/redux/selectors/conditions.js +7 -7
  78. package/dist/redux/selectors/index.d.ts +8 -0
  79. package/dist/redux/selectors/index.js +8 -0
  80. package/dist/redux/selectors/inputs.js +3 -3
  81. package/dist/redux/selectors/library.d.ts +2 -2
  82. package/dist/redux/selectors/references.js +26 -26
  83. package/dist/redux/selectors/selectors.d.ts +2 -2
  84. package/dist/redux/selectors/selectors.js +19 -8
  85. package/dist/redux/selectors/selectors.test.js +6 -6
  86. package/dist/redux/selectors/user.js +5 -5
  87. package/dist/redux/store.d.ts +1 -1
  88. package/dist/redux/store.js +12 -4
  89. package/dist/service/api.manager.d.ts +1 -6
  90. package/dist/service/index.d.ts +3 -0
  91. package/dist/service/index.js +3 -0
  92. package/dist/types/PluginConfig.type.d.ts +57 -0
  93. package/dist/types/PluginConfig.type.js +1 -0
  94. package/dist/types/State.type.d.ts +6 -0
  95. package/dist/types/config.type.d.ts +3 -1
  96. package/dist/types/index.d.ts +11 -0
  97. package/dist/types/index.js +11 -0
  98. package/package.json +11 -11
  99. package/.depcheckrc +0 -1
  100. package/.eslintignore +0 -2
  101. package/.eslintrc +0 -5
  102. package/__mocks__/fileMock.js +0 -1
  103. package/babel.config.json +0 -3
  104. package/jest.config.ts +0 -193
  105. package/setupJest.ts +0 -8
  106. package/src/App.test.tsx +0 -41
  107. package/src/App.tsx +0 -152
  108. package/src/Globals.ts +0 -69
  109. package/src/Loader.tsx +0 -8
  110. package/src/PluginLoader.test.tsx +0 -70
  111. package/src/PluginLoader.tsx +0 -407
  112. package/src/Shimmer.tsx +0 -108
  113. package/src/ThemeLoader.test.tsx +0 -82
  114. package/src/ThemeLoader.tsx +0 -95
  115. package/src/components/PluginRoute.tsx +0 -48
  116. package/src/components/SmartScript.tsx +0 -166
  117. package/src/components/UserLocked/UserLockedComponent.tsx +0 -33
  118. package/src/components/View.test.tsx +0 -110
  119. package/src/components/View.tsx +0 -114
  120. package/src/componentsConnectors/connectBox.test.tsx +0 -226
  121. package/src/componentsConnectors/connectBox.tsx +0 -70
  122. package/src/componentsConnectors/connectDocument.test.tsx +0 -108
  123. package/src/componentsConnectors/connectDocument.tsx +0 -64
  124. package/src/componentsConnectors/connectHeader.tsx +0 -21
  125. package/src/componentsConnectors/connectMetaTitle.test.tsx +0 -40
  126. package/src/componentsConnectors/connectMetaTitle.tsx +0 -8
  127. package/src/componentsConnectors/connectOption.tsx +0 -222
  128. package/src/componentsConnectors/connectPagination.tsx +0 -102
  129. package/src/componentsConnectors/connectPreview.tsx +0 -5
  130. package/src/componentsConnectors/connectProgress.tsx +0 -59
  131. package/src/componentsConnectors/connectRootOption.tsx +0 -95
  132. package/src/componentsConnectors/connectSection.tsx +0 -79
  133. package/src/componentsConnectors/connectSummary.tsx +0 -21
  134. package/src/componentsConnectors/connectSummaryItem.tsx +0 -102
  135. package/src/componentsConnectors/connectTermsheet.tsx +0 -359
  136. package/src/componentsConnectors/connectVariable.tsx +0 -191
  137. package/src/componentsConnectors/connectWizardWrapper.tsx +0 -30
  138. package/src/componentsConnectors/connector/componentConnector.tsx +0 -219
  139. package/src/componentsConnectors/library.ts +0 -35
  140. package/src/config.test.ts +0 -63
  141. package/src/config.ts +0 -11
  142. package/src/constants/emailValidation.ts +0 -2
  143. package/src/constants/phoneValidation.ts +0 -4
  144. package/src/definitions/path.join.d.ts +0 -4
  145. package/src/helpers/outputsParsing.ts +0 -412
  146. package/src/helpers/preloadTheme.ts +0 -17
  147. package/src/helpers/scriptsLoader.ts +0 -20
  148. package/src/hooks/usePrevious.ts +0 -9
  149. package/src/libs/ConditionsInitiator.ts +0 -164
  150. package/src/libs/ConditionsRunner/DataPopulator.ts +0 -266
  151. package/src/libs/ConditionsRunner.ts +0 -454
  152. package/src/libs/DocumentsOutputs.ts +0 -171
  153. package/src/libs/Eval/EvalBase.ts +0 -116
  154. package/src/libs/Eval/EvalFunctions.ts +0 -724
  155. package/src/libs/Eval/NumbersToLetters.ts +0 -185
  156. package/src/libs/EvalVariable.ts +0 -265
  157. package/src/libs/EventsTracking.ts +0 -250
  158. package/src/libs/InputsInitiator.ts +0 -136
  159. package/src/libs/NumAuto.test.ts +0 -55
  160. package/src/libs/NumAuto.ts +0 -56
  161. package/src/libs/OvcConverter.ts +0 -285
  162. package/src/libs/PathReader.ts +0 -272
  163. package/src/libs/SectionValidity.test.ts +0 -146
  164. package/src/libs/SectionValidity.ts +0 -110
  165. package/src/libs/SmartScriptStore.ts +0 -492
  166. package/src/misc/test_model.ts +0 -14603
  167. package/src/misc/test_models/connectDocumen.testmodel.json +0 -178
  168. package/src/misc/test_models/setDefaults.testmodel.json +0 -279
  169. package/src/misc/test_models/testmodel.json +0 -1
  170. package/src/polyfills/index.ts +0 -5
  171. package/src/polyfills/objectValues.ts +0 -4
  172. package/src/polyfills/prepend.ts +0 -31
  173. package/src/polyfills/stringRepeat.ts +0 -44
  174. package/src/redux/actions/app.test.ts +0 -123
  175. package/src/redux/actions/app.ts +0 -249
  176. package/src/redux/actions/conditions.test.ts +0 -84
  177. package/src/redux/actions/conditions.ts +0 -135
  178. package/src/redux/actions/inputs.test.ts +0 -85
  179. package/src/redux/actions/inputs.ts +0 -111
  180. package/src/redux/actions/library.ts +0 -23
  181. package/src/redux/actions/mandatories.ts +0 -98
  182. package/src/redux/actions/references.test.ts +0 -48
  183. package/src/redux/actions/references.ts +0 -37
  184. package/src/redux/actions/sagas/data.test.ts +0 -11
  185. package/src/redux/actions/sagas/data.ts +0 -18
  186. package/src/redux/actions/sagas/model.test.ts +0 -14
  187. package/src/redux/actions/sagas/model.ts +0 -48
  188. package/src/redux/actions/sagas/user.ts +0 -25
  189. package/src/redux/actions/smartscript.ts +0 -55
  190. package/src/redux/actions/user.test.ts +0 -18
  191. package/src/redux/actions/user.ts +0 -41
  192. package/src/redux/constants/app.ts +0 -36
  193. package/src/redux/constants/conditions.ts +0 -25
  194. package/src/redux/constants/inputs.ts +0 -15
  195. package/src/redux/constants/mandatories.ts +0 -11
  196. package/src/redux/constants/references.ts +0 -7
  197. package/src/redux/constants/sagas/data.ts +0 -1
  198. package/src/redux/constants/sagas/model.ts +0 -2
  199. package/src/redux/constants/sagas/user.ts +0 -2
  200. package/src/redux/constants/smartscript.ts +0 -9
  201. package/src/redux/constants/user.ts +0 -6
  202. package/src/redux/listeners/subscriber.test.ts +0 -45
  203. package/src/redux/listeners/subscriber.ts +0 -29
  204. package/src/redux/middlewares/conditionsWatcherMiddleware.test.ts +0 -370
  205. package/src/redux/middlewares/conditionsWatcherMiddleware.ts +0 -321
  206. package/src/redux/middlewares/evaluationsWatcherMiddleware.test.ts +0 -323
  207. package/src/redux/middlewares/evaluationsWatcherMiddleware.ts +0 -250
  208. package/src/redux/middlewares/mandatoriesWatcherMiddleware.ts +0 -473
  209. package/src/redux/middlewares/multiplesActionsMiddleware.test.ts +0 -230
  210. package/src/redux/middlewares/multiplesActionsMiddleware.ts +0 -121
  211. package/src/redux/middlewares/paginationWatcherMiddleware.ts +0 -251
  212. package/src/redux/middlewares/pluginsHookMiddleware.ts +0 -24
  213. package/src/redux/middlewares/prefillerWatcherMiddleware.test.ts +0 -118
  214. package/src/redux/middlewares/prefillerWatcherMiddleware.ts +0 -462
  215. package/src/redux/middlewares/smartscriptMiddleware.ts +0 -228
  216. package/src/redux/middlewares/thirdpartyScriptsMiddleware.ts +0 -41
  217. package/src/redux/reducers/app/customizations/initCustomizationAutoDefault.ts +0 -16
  218. package/src/redux/reducers/app/customizations/initCustomizationMeta.ts +0 -16
  219. package/src/redux/reducers/app/instance/initInstance.ts +0 -29
  220. package/src/redux/reducers/app/instance/setDataStatus.ts +0 -16
  221. package/src/redux/reducers/app/instance/updateInstance.ts +0 -30
  222. package/src/redux/reducers/app/instance/updateInstancePaid.ts +0 -20
  223. package/src/redux/reducers/app/instance.test.ts +0 -106
  224. package/src/redux/reducers/app/meta/fetchModelFailed.ts +0 -11
  225. package/src/redux/reducers/app/meta/fetchModelNonBlocking.ts +0 -11
  226. package/src/redux/reducers/app/meta/fetchModelSucceeded.ts +0 -11
  227. package/src/redux/reducers/app/meta/fetchModelUnhealthy.ts +0 -18
  228. package/src/redux/reducers/app/meta/fetchModelUserLocked.ts +0 -11
  229. package/src/redux/reducers/app/meta/initMeta.ts +0 -22
  230. package/src/redux/reducers/app/meta/setModelUuid.ts +0 -17
  231. package/src/redux/reducers/app/meta.test.ts +0 -90
  232. package/src/redux/reducers/app/pagination/goNextPage.ts +0 -69
  233. package/src/redux/reducers/app/pagination/goPage.ts +0 -81
  234. package/src/redux/reducers/app/pagination/goPreviousPage.ts +0 -60
  235. package/src/redux/reducers/app/pagination/initPagination.ts +0 -46
  236. package/src/redux/reducers/app/pagination/updateAvailableAppStates.ts +0 -77
  237. package/src/redux/reducers/app/pagination.test.ts +0 -363
  238. package/src/redux/reducers/app/wizard/updateAvailableSections.ts +0 -40
  239. package/src/redux/reducers/app/wizard.test.ts +0 -84
  240. package/src/redux/reducers/app.test.ts +0 -336
  241. package/src/redux/reducers/app.ts +0 -150
  242. package/src/redux/reducers/conditions/addMultipleOccurency.test.ts +0 -131
  243. package/src/redux/reducers/conditions/addMultipleOccurency.ts +0 -155
  244. package/src/redux/reducers/conditions/deleteMultipleOccurency.test.ts +0 -95
  245. package/src/redux/reducers/conditions/deleteMultipleOccurency.ts +0 -141
  246. package/src/redux/reducers/conditions/initConditions.ts +0 -18
  247. package/src/redux/reducers/conditions/updateDocumentConditions.test.ts +0 -47
  248. package/src/redux/reducers/conditions/updateDocumentConditions.ts +0 -21
  249. package/src/redux/reducers/conditions/updateOptionConditions.ts +0 -24
  250. package/src/redux/reducers/conditions/updateOptionValidatorCondition.test.ts +0 -50
  251. package/src/redux/reducers/conditions/updateOptionValidatorCondition.ts +0 -28
  252. package/src/redux/reducers/conditions/updatePrefillerConditions.ts +0 -29
  253. package/src/redux/reducers/conditions/updateSectionConditions.ts +0 -28
  254. package/src/redux/reducers/conditions/updateVariableConditions.ts +0 -25
  255. package/src/redux/reducers/conditions/updateVariableValidatorCondition.test.ts +0 -50
  256. package/src/redux/reducers/conditions/updateVariableValidatorCondition.ts +0 -28
  257. package/src/redux/reducers/conditions.test.ts +0 -241
  258. package/src/redux/reducers/conditions.ts +0 -68
  259. package/src/redux/reducers/inputs/addMultipleOccurency.test.ts +0 -117
  260. package/src/redux/reducers/inputs/addMultipleOccurency.ts +0 -50
  261. package/src/redux/reducers/inputs/deleteMultipleOccurency.test.ts +0 -70
  262. package/src/redux/reducers/inputs/deleteMultipleOccurency.ts +0 -50
  263. package/src/redux/reducers/inputs/initOption.ts +0 -16
  264. package/src/redux/reducers/inputs/initVariable.ts +0 -16
  265. package/src/redux/reducers/inputs/updateOptionInput.ts +0 -24
  266. package/src/redux/reducers/inputs/updateVariableInput.ts +0 -24
  267. package/src/redux/reducers/inputs.test.ts +0 -221
  268. package/src/redux/reducers/inputs.ts +0 -51
  269. package/src/redux/reducers/mandatories/addMultipleOccurency.ts +0 -52
  270. package/src/redux/reducers/mandatories/deleteMultipleOccurency.ts +0 -55
  271. package/src/redux/reducers/mandatories/initMandatoryOption.ts +0 -17
  272. package/src/redux/reducers/mandatories/initMandatoryVariable.ts +0 -17
  273. package/src/redux/reducers/mandatories/setMandatoryIgnore.ts +0 -17
  274. package/src/redux/reducers/mandatories/setMandatoryOption.ts +0 -25
  275. package/src/redux/reducers/mandatories/setMandatorySection.ts +0 -20
  276. package/src/redux/reducers/mandatories/setMandatoryVariable.ts +0 -24
  277. package/src/redux/reducers/mandatories.ts +0 -56
  278. package/src/redux/reducers/references/initReferences.ts +0 -37
  279. package/src/redux/reducers/references/updateOptionMeta.ts +0 -73
  280. package/src/redux/reducers/references/updateVariableMeta.ts +0 -72
  281. package/src/redux/reducers/references.ts +0 -59
  282. package/src/redux/reducers/smartscript/enableSmartScript.ts +0 -13
  283. package/src/redux/reducers/smartscript/initSmartScriptTriggers.ts +0 -14
  284. package/src/redux/reducers/smartscript/updateSmartscriptOptionHidden.ts +0 -30
  285. package/src/redux/reducers/smartscript/updateSmartscriptVariableHidden.ts +0 -30
  286. package/src/redux/reducers/smartscript.ts +0 -47
  287. package/src/redux/reducers/user/initUser.ts +0 -15
  288. package/src/redux/reducers/user/setUserStatus.ts +0 -13
  289. package/src/redux/reducers/user/setUserValidToken.ts +0 -13
  290. package/src/redux/reducers/user.test.ts +0 -51
  291. package/src/redux/reducers/user.ts +0 -40
  292. package/src/redux/routerHistore.test.ts +0 -19
  293. package/src/redux/routerHistory.ts +0 -26
  294. package/src/redux/sagas/fetchModel.test.ts +0 -76
  295. package/src/redux/sagas/fetchModel.ts +0 -683
  296. package/src/redux/sagas/homogeneousRadioInputsSaga.ts +0 -42
  297. package/src/redux/sagas/initInputs.ts +0 -110
  298. package/src/redux/sagas/runner.test.ts +0 -12
  299. package/src/redux/sagas/runner.ts +0 -26
  300. package/src/redux/sagas/saveData.test.ts +0 -125
  301. package/src/redux/sagas/saveData.ts +0 -55
  302. package/src/redux/sagas/setDefaults.test.ts +0 -100
  303. package/src/redux/sagas/setDefaults.ts +0 -167
  304. package/src/redux/sagas/setUserEmail.ts +0 -175
  305. package/src/redux/selectors/app.test.ts +0 -162
  306. package/src/redux/selectors/app.ts +0 -331
  307. package/src/redux/selectors/conditions.test.ts +0 -92
  308. package/src/redux/selectors/conditions.ts +0 -293
  309. package/src/redux/selectors/inputs.test.ts +0 -72
  310. package/src/redux/selectors/inputs.ts +0 -76
  311. package/src/redux/selectors/library.ts +0 -17
  312. package/src/redux/selectors/mandatories.ts +0 -83
  313. package/src/redux/selectors/references.test.ts +0 -660
  314. package/src/redux/selectors/references.ts +0 -413
  315. package/src/redux/selectors/selectors.test.ts +0 -21
  316. package/src/redux/selectors/selectors.ts +0 -87
  317. package/src/redux/selectors/smartscript.ts +0 -30
  318. package/src/redux/selectors/user.test.ts +0 -39
  319. package/src/redux/selectors/user.ts +0 -45
  320. package/src/redux/store.test.ts +0 -22
  321. package/src/redux/store.ts +0 -100
  322. package/src/service/api.manager.ts +0 -261
  323. package/src/service/auth.service.ts +0 -5
  324. package/src/service/pardot.service.ts +0 -10
  325. package/src/tests-misc/plugins/jestTestPlugin/after.tsx +0 -5
  326. package/src/tests-misc/plugins/jestTestPlugin/before.tsx +0 -11
  327. package/src/tests-misc/plugins/jestTestPlugin/index.ts +0 -11
  328. package/src/tests-misc/plugins/jestTestPlugin/title.tsx +0 -8
  329. package/src/tests-misc/themes/jestTestTheme/components/EmailComponent.tsx +0 -5
  330. package/src/tests-misc/themes/jestTestTheme/components/TermsheetComponent.tsx +0 -5
  331. package/src/tests-misc/themes/jestTestTheme/components/WizardComponent.tsx +0 -5
  332. package/src/tests-misc/themes/jestTestTheme/faltyIndex.ts +0 -3
  333. package/src/tests-misc/themes/jestTestTheme/faltyIndexLoader.ts +0 -1
  334. package/src/tests-misc/themes/jestTestTheme/index.ts +0 -13
  335. package/src/types/Actions.type.ts +0 -612
  336. package/src/types/Components.type.ts +0 -181
  337. package/src/types/State.type.ts +0 -323
  338. package/src/types/Termsheet.type.ts +0 -28
  339. package/src/types/api.type.ts +0 -37
  340. package/src/types/config.type.ts +0 -55
  341. package/src/types/env.type.ts +0 -5
  342. package/src/types/getActions.type.ts +0 -3
  343. package/src/types/getConnectors.type.ts +0 -5
  344. package/src/types/getSelectors.type.ts +0 -3
  345. package/src/wizard-params.ts +0 -56
  346. package/tsconfig.json +0 -43
package/CHANGELOG.md CHANGED
@@ -3,6 +3,41 @@
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
+
6
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)
7
42
 
8
43
  **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";