@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
@@ -20,3 +20,5 @@ export const UPDATE_CURRENT_SECTION_ID = "UPDATE_CURRENT_SECTION_ID";
20
20
  export const UPDATE_AVAILABLE_SECTIONS = "UPDATE_AVAILABLE_SECTIONS";
21
21
  export const INIT_CUSTOMIZATION_META = "INIT_CUSTOMIZATION_META";
22
22
  export const INIT_CUSTOMIZATION_AUTO_DEFAULT = "INIT_CUSTOMIZATION_AUTO_DEFAULT";
23
+ export const DANGEROUS_DESTORY_STORE = "DANGEROUS_DESTORY_STORE";
24
+ export const INIT_PLUGINS = "@@INIT_PLUGINS";
@@ -0,0 +1,8 @@
1
+ export * from "./app";
2
+ export * from "./conditions";
3
+ export * from "./inputs";
4
+ export * from "./sagas";
5
+ export * from "./mandatories";
6
+ export * from "./references";
7
+ export * from "./smartscript";
8
+ export * from "./user";
@@ -0,0 +1,8 @@
1
+ export * from "./app";
2
+ export * from "./conditions";
3
+ export * from "./inputs";
4
+ export * from "./sagas";
5
+ export * from "./mandatories";
6
+ export * from "./references";
7
+ export * from "./smartscript";
8
+ export * from "./user";
@@ -0,0 +1,3 @@
1
+ export * from "./data";
2
+ export * from "./model";
3
+ export * from "./user";
@@ -0,0 +1,3 @@
1
+ export * from "./data";
2
+ export * from "./model";
3
+ export * from "./user";
@@ -0,0 +1,5 @@
1
+ export * from "./store";
2
+ export * from "./routerHistory";
3
+ export * from "./actions";
4
+ export * from "./constants";
5
+ export * from "./selectors";
@@ -0,0 +1,5 @@
1
+ export * from "./store";
2
+ export * from "./routerHistory";
3
+ export * from "./actions";
4
+ export * from "./constants";
5
+ export * from "./selectors";
@@ -5,12 +5,14 @@ import { INIT_CONDITIONS, UPDATE_SECTION_CONDITION, UPDATE_OPTION_CONDITION, UPD
5
5
  import { selectOptionRelations, selectOptionConditionsObject, selectVariableConditionsObject, } from "../selectors/references";
6
6
  import { setDataStatus } from "../actions/app";
7
7
  import { selectSectionConditionValue, selectOptionConditionValue, selectVariableConditionValue, } from "../selectors/conditions";
8
+ import { selectDataStatus } from "../selectors/app";
8
9
  const watchUpdateOptionInput = (mpi, next, action) => {
9
10
  const { id, index, value } = action;
10
11
  const oldValue = selectOptionInputByIndex(id, index);
11
12
  const nextResult = next(action);
12
13
  if (value !== oldValue) {
13
- mpi.dispatch(setDataStatus("unsaved"));
14
+ if (selectDataStatus() !== "unsaved")
15
+ mpi.dispatch(setDataStatus("unsaved"));
14
16
  const Conditions = new ConditionsRunner(mpi.dispatch);
15
17
  Conditions.executeHooks("options", id, index);
16
18
  }
@@ -21,7 +23,8 @@ const watchUpdateOptionCondition = (mpi, next, action) => {
21
23
  const oldValue = selectOptionConditionValue(id, index);
22
24
  const nextResult = next(action);
23
25
  if (value !== oldValue) {
24
- mpi.dispatch(setDataStatus("unsaved"));
26
+ if (selectDataStatus() !== "unsaved")
27
+ mpi.dispatch(setDataStatus("unsaved"));
25
28
  const Conditions = new ConditionsRunner(mpi.dispatch);
26
29
  Conditions.executeHooks("options", id, index);
27
30
  }
@@ -32,7 +35,8 @@ const watchUpdateVariableInput = (mpi, next, action) => {
32
35
  const oldValue = selectVariableInputByIndex(id, index);
33
36
  const nextResult = next(action);
34
37
  if (value !== oldValue) {
35
- mpi.dispatch(setDataStatus("unsaved"));
38
+ if (selectDataStatus() !== "unsaved")
39
+ mpi.dispatch(setDataStatus("unsaved"));
36
40
  const Conditions = new ConditionsRunner(mpi.dispatch);
37
41
  Conditions.executeHooks("variables", id, index);
38
42
  }
@@ -43,7 +47,8 @@ const watchUpdateVariableCondition = (mpi, next, action) => {
43
47
  const oldValue = selectVariableConditionValue(id, index);
44
48
  const nextResult = next(action);
45
49
  if (value !== oldValue) {
46
- mpi.dispatch(setDataStatus("unsaved"));
50
+ if (selectDataStatus() !== "unsaved")
51
+ mpi.dispatch(setDataStatus("unsaved"));
47
52
  const Conditions = new ConditionsRunner(mpi.dispatch);
48
53
  Conditions.executeHooks("variables", id, index);
49
54
  }
@@ -65,7 +70,8 @@ const watchUpdateSectionCondition = (mpi, next, action) => {
65
70
  const watchMultipleOccurenciesChange = (mpi, next, action) => {
66
71
  const nextResult = next(action);
67
72
  const Conditions = new ConditionsRunner(mpi.dispatch);
68
- mpi.dispatch(setDataStatus("unsaved"));
73
+ if (selectDataStatus() !== "unsaved")
74
+ mpi.dispatch(setDataStatus("unsaved"));
69
75
  const { id } = action;
70
76
  const optionRelations = selectOptionRelations(id);
71
77
  if (optionRelations === undefined)
@@ -1,9 +1,10 @@
1
- import conditionsWatcherMiddleware from './conditionsWatcherMiddleware';
2
- import { addMultipleOccurencyAction, deleteMultipleOccurencyAction, updateOptionAction, updateVariableAction, } from '../actions/inputs';
3
- import { initConditionsAction } from '../actions/conditions';
1
+ import conditionsWatcherMiddleware from "./conditionsWatcherMiddleware";
2
+ import { addMultipleOccurencyAction, deleteMultipleOccurencyAction, updateOptionAction, updateVariableAction, } from "../actions/inputs";
3
+ import { initConditionsAction } from "../actions/conditions";
4
+ import { selectorsMiddleware } from "../selectors/selectors";
4
5
  const mockInputs = {
5
6
  variables: {
6
- 1: ['Hello'],
7
+ 1: ["Hello"],
7
8
  2: [],
8
9
  3: [],
9
10
  },
@@ -19,6 +20,11 @@ const mockInputs = {
19
20
  const mpi = {
20
21
  dispatch: jest.fn(),
21
22
  getState: () => ({
23
+ app: {
24
+ instance: {
25
+ dataStatus: "saved",
26
+ },
27
+ },
22
28
  inputs: mockInputs,
23
29
  }),
24
30
  };
@@ -53,21 +59,21 @@ const mockOptionsRelations = {
53
59
  dependants: [7, 8],
54
60
  },
55
61
  };
56
- jest.mock('../selectors/inputs', () => ({
62
+ jest.mock("../selectors/inputs", () => ({
57
63
  __esModule: true,
58
64
  selectOptionInput: (id) => mockInputs.options[id],
59
65
  selectOptionInputByIndex: (id, index) => mockInputs.options[id][index],
60
66
  selectVariableInput: (id) => mockInputs.variables[id],
61
67
  selectVariableInputByIndex: (id, index) => mockInputs.variables[id][index],
62
68
  }));
63
- jest.mock('../../libs/ConditionsRunner', () => {
69
+ jest.mock("../../libs/ConditionsRunner", () => {
64
70
  class ConditionsRunnerMock {
65
71
  constructor(dispatch) {
66
72
  this.dispatch = dispatch;
67
73
  }
68
74
  executeHooks(...args) {
69
75
  this.dispatch({
70
- type: 'EXEC_HOOKS_MOCK',
76
+ type: "EXEC_HOOKS_MOCK",
71
77
  arguments: args,
72
78
  });
73
79
  }
@@ -79,245 +85,246 @@ jest.mock('../../libs/ConditionsRunner', () => {
79
85
  });
80
86
  const mockOptionsConditions = {};
81
87
  const mockVariablesConditions = {};
82
- jest.mock('../selectors/references', () => ({
88
+ jest.mock("../selectors/references", () => ({
83
89
  __esModule: true,
84
90
  selectOptionRelations: (id) => mockOptionsRelations[id],
85
91
  selectOptionConditionsObject: (id) => mockOptionsConditions[id],
86
92
  selectVariableConditionsObject: (id) => mockVariablesConditions[id],
87
93
  }));
88
- describe('Conditions Watcher Middleware Test suit', () => {
94
+ describe("Conditions Watcher Middleware Test suit", () => {
89
95
  beforeEach(() => {
96
+ selectorsMiddleware(mpi)(next)({ type: "@INIT" });
90
97
  jest.clearAllMocks();
91
98
  });
92
- it('Completes INIT_CONDITIONS action correctly', () => {
99
+ it("Completes INIT_CONDITIONS action correctly", () => {
93
100
  conditionsWatcherMiddleware(mpi)(next)(initConditionsAction(initialConditions));
94
101
  expect(next.mock.calls.length).toBe(1);
95
- expect(next.mock.calls[0][0]).toStrictEqual(Object.assign({ type: 'INIT_CONDITIONS' }, initialConditions));
102
+ expect(next.mock.calls[0][0]).toStrictEqual(Object.assign({ type: "INIT_CONDITIONS" }, initialConditions));
96
103
  expect(mpi.dispatch.mock.calls.length).toBe(12);
97
104
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
98
- type: 'EXEC_HOOKS_MOCK',
99
- arguments: ['options', 1, 0],
105
+ type: "EXEC_HOOKS_MOCK",
106
+ arguments: ["options", 1, 0],
100
107
  });
101
108
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
102
- type: 'EXEC_HOOKS_MOCK',
103
- arguments: ['options', 2, 0],
109
+ type: "EXEC_HOOKS_MOCK",
110
+ arguments: ["options", 2, 0],
104
111
  });
105
112
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
106
- type: 'EXEC_HOOKS_MOCK',
107
- arguments: ['options', 2, 1],
113
+ type: "EXEC_HOOKS_MOCK",
114
+ arguments: ["options", 2, 1],
108
115
  });
109
116
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
110
- type: 'EXEC_HOOKS_MOCK',
111
- arguments: ['options', 3, 0],
117
+ type: "EXEC_HOOKS_MOCK",
118
+ arguments: ["options", 3, 0],
112
119
  });
113
120
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
114
- type: 'EXEC_HOOKS_MOCK',
115
- arguments: ['options', 3, 1],
121
+ type: "EXEC_HOOKS_MOCK",
122
+ arguments: ["options", 3, 1],
116
123
  });
117
124
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
118
- type: 'EXEC_HOOKS_MOCK',
119
- arguments: ['options', 4, 0],
125
+ type: "EXEC_HOOKS_MOCK",
126
+ arguments: ["options", 4, 0],
120
127
  });
121
128
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
122
- type: 'EXEC_HOOKS_MOCK',
123
- arguments: ['options', 4, 1],
129
+ type: "EXEC_HOOKS_MOCK",
130
+ arguments: ["options", 4, 1],
124
131
  });
125
132
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
126
- type: 'EXEC_HOOKS_MOCK',
127
- arguments: ['options', 7, 0],
133
+ type: "EXEC_HOOKS_MOCK",
134
+ arguments: ["options", 7, 0],
128
135
  });
129
136
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
130
- type: 'EXEC_HOOKS_MOCK',
131
- arguments: ['options', 7, 1],
137
+ type: "EXEC_HOOKS_MOCK",
138
+ arguments: ["options", 7, 1],
132
139
  });
133
140
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
134
- type: 'EXEC_HOOKS_MOCK',
135
- arguments: ['options', 8, 0],
141
+ type: "EXEC_HOOKS_MOCK",
142
+ arguments: ["options", 8, 0],
136
143
  });
137
144
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
138
- type: 'EXEC_HOOKS_MOCK',
139
- arguments: ['options', 8, 1],
145
+ type: "EXEC_HOOKS_MOCK",
146
+ arguments: ["options", 8, 1],
140
147
  });
141
148
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
142
- type: 'EXEC_HOOKS_MOCK',
143
- arguments: ['variables', 1, 0],
149
+ type: "EXEC_HOOKS_MOCK",
150
+ arguments: ["variables", 1, 0],
144
151
  });
145
152
  });
146
- it('Completes UPDATE_OPTION_INPUT action correctly', () => {
153
+ it("Completes UPDATE_OPTION_INPUT action correctly", () => {
147
154
  conditionsWatcherMiddleware(mpi)(next)(updateOptionAction(3, false, 0));
148
155
  expect(next.mock.calls.length).toBe(1);
149
156
  expect(next.mock.calls[0][0]).toStrictEqual({
150
- type: 'UPDATE_OPTION_INPUT',
157
+ type: "UPDATE_OPTION_INPUT",
151
158
  id: 3,
152
159
  index: 0,
153
160
  value: false,
154
161
  });
155
162
  expect(mpi.dispatch.mock.calls.length).toBe(2);
156
163
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
157
- type: 'SET_DATA_STATUS',
158
- dataStatus: 'unsaved',
164
+ type: "SET_DATA_STATUS",
165
+ dataStatus: "unsaved",
159
166
  });
160
167
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
161
- type: 'EXEC_HOOKS_MOCK',
162
- arguments: ['options', 3, 0],
168
+ type: "EXEC_HOOKS_MOCK",
169
+ arguments: ["options", 3, 0],
163
170
  });
164
171
  });
165
- it('Completes UPDATE_VARIABLE_INPUT action correctly', () => {
166
- conditionsWatcherMiddleware(mpi)(next)(updateVariableAction(1, 'Hey', 0));
172
+ it("Completes UPDATE_VARIABLE_INPUT action correctly", () => {
173
+ conditionsWatcherMiddleware(mpi)(next)(updateVariableAction(1, "Hey", 0));
167
174
  expect(next.mock.calls.length).toBe(1);
168
175
  expect(next.mock.calls[0][0]).toStrictEqual({
169
- type: 'UPDATE_VARIABLE_INPUT',
176
+ type: "UPDATE_VARIABLE_INPUT",
170
177
  id: 1,
171
178
  index: 0,
172
- value: 'Hey',
179
+ value: "Hey",
173
180
  });
174
181
  expect(mpi.dispatch.mock.calls.length).toBe(2);
175
182
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
176
- type: 'SET_DATA_STATUS',
177
- dataStatus: 'unsaved',
183
+ type: "SET_DATA_STATUS",
184
+ dataStatus: "unsaved",
178
185
  });
179
186
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
180
- type: 'EXEC_HOOKS_MOCK',
181
- arguments: ['variables', 1, 0],
187
+ type: "EXEC_HOOKS_MOCK",
188
+ arguments: ["variables", 1, 0],
182
189
  });
183
190
  });
184
- it('Completes ADD_MULTIPLE_OCCURENCY action correctly', () => {
191
+ it("Completes ADD_MULTIPLE_OCCURENCY action correctly", () => {
185
192
  conditionsWatcherMiddleware(mpi)(next)(addMultipleOccurencyAction(2));
186
193
  expect(next.mock.calls.length).toBe(1);
187
194
  expect(next.mock.calls[0][0]).toStrictEqual({
188
- type: 'ADD_MULTIPLE_OCCURENCY',
195
+ type: "ADD_MULTIPLE_OCCURENCY",
189
196
  id: 2,
190
197
  });
191
198
  expect(mpi.dispatch.mock.calls.length).toBe(15);
192
199
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
193
- type: 'SET_DATA_STATUS',
194
- dataStatus: 'unsaved',
200
+ type: "SET_DATA_STATUS",
201
+ dataStatus: "unsaved",
195
202
  });
196
203
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
197
- type: 'EXEC_HOOKS_MOCK',
198
- arguments: ['options', 2, 0],
204
+ type: "EXEC_HOOKS_MOCK",
205
+ arguments: ["options", 2, 0],
199
206
  });
200
207
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
201
- type: 'EXEC_HOOKS_MOCK',
202
- arguments: ['options', 2, 1],
208
+ type: "EXEC_HOOKS_MOCK",
209
+ arguments: ["options", 2, 1],
203
210
  });
204
211
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
205
- type: 'EXEC_HOOKS_MOCK',
206
- arguments: ['options', 3, 0],
212
+ type: "EXEC_HOOKS_MOCK",
213
+ arguments: ["options", 3, 0],
207
214
  });
208
215
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
209
- type: 'EXEC_HOOKS_MOCK',
210
- arguments: ['options', 3, 1],
216
+ type: "EXEC_HOOKS_MOCK",
217
+ arguments: ["options", 3, 1],
211
218
  });
212
219
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
213
- type: 'EXEC_HOOKS_MOCK',
214
- arguments: ['options', 4, 0],
220
+ type: "EXEC_HOOKS_MOCK",
221
+ arguments: ["options", 4, 0],
215
222
  });
216
223
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
217
- type: 'EXEC_HOOKS_MOCK',
218
- arguments: ['options', 4, 1],
224
+ type: "EXEC_HOOKS_MOCK",
225
+ arguments: ["options", 4, 1],
219
226
  });
220
227
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
221
- type: 'EXEC_HOOKS_MOCK',
222
- arguments: ['options', 7, 0],
228
+ type: "EXEC_HOOKS_MOCK",
229
+ arguments: ["options", 7, 0],
223
230
  });
224
231
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
225
- type: 'EXEC_HOOKS_MOCK',
226
- arguments: ['options', 7, 1],
232
+ type: "EXEC_HOOKS_MOCK",
233
+ arguments: ["options", 7, 1],
227
234
  });
228
235
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
229
- type: 'EXEC_HOOKS_MOCK',
230
- arguments: ['options', 8, 0],
236
+ type: "EXEC_HOOKS_MOCK",
237
+ arguments: ["options", 8, 0],
231
238
  });
232
239
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
233
- type: 'EXEC_HOOKS_MOCK',
234
- arguments: ['options', 8, 1],
240
+ type: "EXEC_HOOKS_MOCK",
241
+ arguments: ["options", 8, 1],
235
242
  });
236
243
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
237
- type: 'EXEC_HOOKS_MOCK',
238
- arguments: ['variables', 2, 0],
244
+ type: "EXEC_HOOKS_MOCK",
245
+ arguments: ["variables", 2, 0],
239
246
  });
240
247
  expect(mpi.dispatch.mock.calls[12][0]).toStrictEqual({
241
- type: 'EXEC_HOOKS_MOCK',
242
- arguments: ['variables', 2, 1],
248
+ type: "EXEC_HOOKS_MOCK",
249
+ arguments: ["variables", 2, 1],
243
250
  });
244
251
  expect(mpi.dispatch.mock.calls[13][0]).toStrictEqual({
245
- type: 'EXEC_HOOKS_MOCK',
246
- arguments: ['variables', 3, 0],
252
+ type: "EXEC_HOOKS_MOCK",
253
+ arguments: ["variables", 3, 0],
247
254
  });
248
255
  expect(mpi.dispatch.mock.calls[14][0]).toStrictEqual({
249
- type: 'EXEC_HOOKS_MOCK',
250
- arguments: ['variables', 3, 1],
256
+ type: "EXEC_HOOKS_MOCK",
257
+ arguments: ["variables", 3, 1],
251
258
  });
252
259
  });
253
- it('Completes DELETE_MULTIPLE_OCCURENCY action correctly', () => {
260
+ it("Completes DELETE_MULTIPLE_OCCURENCY action correctly", () => {
254
261
  conditionsWatcherMiddleware(mpi)(next)(deleteMultipleOccurencyAction(2, 1));
255
262
  expect(next.mock.calls.length).toBe(1);
256
263
  expect(next.mock.calls[0][0]).toStrictEqual({
257
- type: 'DELETE_MULTIPLE_OCCURENCY',
264
+ type: "DELETE_MULTIPLE_OCCURENCY",
258
265
  id: 2,
259
266
  index: 1,
260
267
  });
261
268
  expect(mpi.dispatch.mock.calls.length).toBe(15);
262
269
  expect(mpi.dispatch.mock.calls[0][0]).toStrictEqual({
263
- type: 'SET_DATA_STATUS',
264
- dataStatus: 'unsaved',
270
+ type: "SET_DATA_STATUS",
271
+ dataStatus: "unsaved",
265
272
  });
266
273
  expect(mpi.dispatch.mock.calls[1][0]).toStrictEqual({
267
- type: 'EXEC_HOOKS_MOCK',
268
- arguments: ['options', 2, 0],
274
+ type: "EXEC_HOOKS_MOCK",
275
+ arguments: ["options", 2, 0],
269
276
  });
270
277
  expect(mpi.dispatch.mock.calls[2][0]).toStrictEqual({
271
- type: 'EXEC_HOOKS_MOCK',
272
- arguments: ['options', 2, 1],
278
+ type: "EXEC_HOOKS_MOCK",
279
+ arguments: ["options", 2, 1],
273
280
  });
274
281
  expect(mpi.dispatch.mock.calls[3][0]).toStrictEqual({
275
- type: 'EXEC_HOOKS_MOCK',
276
- arguments: ['options', 3, 0],
282
+ type: "EXEC_HOOKS_MOCK",
283
+ arguments: ["options", 3, 0],
277
284
  });
278
285
  expect(mpi.dispatch.mock.calls[4][0]).toStrictEqual({
279
- type: 'EXEC_HOOKS_MOCK',
280
- arguments: ['options', 3, 1],
286
+ type: "EXEC_HOOKS_MOCK",
287
+ arguments: ["options", 3, 1],
281
288
  });
282
289
  expect(mpi.dispatch.mock.calls[5][0]).toStrictEqual({
283
- type: 'EXEC_HOOKS_MOCK',
284
- arguments: ['options', 4, 0],
290
+ type: "EXEC_HOOKS_MOCK",
291
+ arguments: ["options", 4, 0],
285
292
  });
286
293
  expect(mpi.dispatch.mock.calls[6][0]).toStrictEqual({
287
- type: 'EXEC_HOOKS_MOCK',
288
- arguments: ['options', 4, 1],
294
+ type: "EXEC_HOOKS_MOCK",
295
+ arguments: ["options", 4, 1],
289
296
  });
290
297
  expect(mpi.dispatch.mock.calls[7][0]).toStrictEqual({
291
- type: 'EXEC_HOOKS_MOCK',
292
- arguments: ['options', 7, 0],
298
+ type: "EXEC_HOOKS_MOCK",
299
+ arguments: ["options", 7, 0],
293
300
  });
294
301
  expect(mpi.dispatch.mock.calls[8][0]).toStrictEqual({
295
- type: 'EXEC_HOOKS_MOCK',
296
- arguments: ['options', 7, 1],
302
+ type: "EXEC_HOOKS_MOCK",
303
+ arguments: ["options", 7, 1],
297
304
  });
298
305
  expect(mpi.dispatch.mock.calls[9][0]).toStrictEqual({
299
- type: 'EXEC_HOOKS_MOCK',
300
- arguments: ['options', 8, 0],
306
+ type: "EXEC_HOOKS_MOCK",
307
+ arguments: ["options", 8, 0],
301
308
  });
302
309
  expect(mpi.dispatch.mock.calls[10][0]).toStrictEqual({
303
- type: 'EXEC_HOOKS_MOCK',
304
- arguments: ['options', 8, 1],
310
+ type: "EXEC_HOOKS_MOCK",
311
+ arguments: ["options", 8, 1],
305
312
  });
306
313
  expect(mpi.dispatch.mock.calls[11][0]).toStrictEqual({
307
- type: 'EXEC_HOOKS_MOCK',
308
- arguments: ['variables', 2, 0],
314
+ type: "EXEC_HOOKS_MOCK",
315
+ arguments: ["variables", 2, 0],
309
316
  });
310
317
  expect(mpi.dispatch.mock.calls[12][0]).toStrictEqual({
311
- type: 'EXEC_HOOKS_MOCK',
312
- arguments: ['variables', 2, 1],
318
+ type: "EXEC_HOOKS_MOCK",
319
+ arguments: ["variables", 2, 1],
313
320
  });
314
321
  expect(mpi.dispatch.mock.calls[13][0]).toStrictEqual({
315
- type: 'EXEC_HOOKS_MOCK',
316
- arguments: ['variables', 3, 0],
322
+ type: "EXEC_HOOKS_MOCK",
323
+ arguments: ["variables", 3, 0],
317
324
  });
318
325
  expect(mpi.dispatch.mock.calls[14][0]).toStrictEqual({
319
- type: 'EXEC_HOOKS_MOCK',
320
- arguments: ['variables', 3, 1],
326
+ type: "EXEC_HOOKS_MOCK",
327
+ arguments: ["variables", 3, 1],
321
328
  });
322
329
  });
323
330
  });
@@ -21,8 +21,8 @@ const watchLocationChange = (mpi, next, action) => {
21
21
  const pathReader = new PathReader(mpi.getState());
22
22
  if (selectPermalink() === "") {
23
23
  mpi.dispatch(initMetaAction({
24
- permalink: pathReader.currentPermalink,
25
- prefix: pathReader.prefix,
24
+ permalink: pathReader.currentPermalink || "",
25
+ prefix: pathReader.currentPrefix || "",
26
26
  id: 0,
27
27
  title: "",
28
28
  modelVersion: 0,
@@ -9,6 +9,14 @@ import { updateOptionAction, updateVariableAction } from "../actions/inputs";
9
9
  let iframe = null;
10
10
  const watchEnableSmartScript = (mpi, next, action) => {
11
11
  next(action);
12
+ if (PathReader.isSmartScriptPath()) {
13
+ return;
14
+ }
15
+ const iframeElement = document.querySelector("#lp-smartscript");
16
+ if (iframeElement) {
17
+ iframe = iframeElement;
18
+ return;
19
+ }
12
20
  iframe = document.createElement("iframe");
13
21
  iframe.id = "lp-smartscript";
14
22
  iframe.setAttribute("style", "position: absolute; width:0; height:0; border:0;");
@@ -0,0 +1,3 @@
1
+ import { AnyAction } from "redux";
2
+ import { StateType } from "../../types/State.type";
3
+ export declare const pluginsStoreReducer: (state: StateType.PluginsStore | undefined, action: AnyAction) => StateType.PluginsStore;
@@ -0,0 +1,12 @@
1
+ import { getPluginsStoreReducers } from "../../PluginLoader";
2
+ export const pluginsStoreReducer = (state = {}, action) => {
3
+ const pluginsStoreReducers = getPluginsStoreReducers();
4
+ const plugins = Object.keys(pluginsStoreReducers);
5
+ const newState = Object.assign({}, state);
6
+ for (let i = 0; i < plugins.length; i += 1) {
7
+ const currentPlugin = plugins[i];
8
+ const reducer = pluginsStoreReducers[currentPlugin];
9
+ newState[currentPlugin] = reducer(newState[currentPlugin], action);
10
+ }
11
+ return newState;
12
+ };
@@ -4,8 +4,8 @@ export const createHistory = (historyType) => {
4
4
  history =
5
5
  historyType === "memory"
6
6
  ? createMemoryHistory({
7
- initialEntries: ["/one", "/two"],
8
- initialIndex: 1,
7
+ initialEntries: ["/"],
8
+ initialIndex: 0,
9
9
  })
10
10
  : createBrowserHistory();
11
11
  return history;
@@ -26,7 +26,7 @@ function* setFetchModelToNonBlocking(firstCurrentAppState) {
26
26
  currentPage: 1,
27
27
  greatestPage: 1,
28
28
  currentSectionId: 0,
29
- availableSections: [],
29
+ availableSections: [0],
30
30
  currentAppState: firstCurrentAppState || "wizard",
31
31
  availableAppStates: ["wizard"],
32
32
  }));
@@ -42,10 +42,12 @@ function* getClientConfig(permalink, uniqid) {
42
42
  throw new Error(`Unable to fetch client config, we did not receive any response`);
43
43
  }
44
44
  clientConfigResponse = yield call([clientConfigResponse, "json"]);
45
- if ((_a = clientConfigResponse.clientConfig.metadata) === null || _a === void 0 ? void 0 : _a.apiEndpoint) {
45
+ if (!getConfig().disableRemoteConfig &&
46
+ ((_a = clientConfigResponse.clientConfig.metadata) === null || _a === void 0 ? void 0 : _a.apiEndpoint)) {
46
47
  updateConfig(Object.assign(Object.assign({}, getConfig()), { apiEndpoint: (_b = clientConfigResponse.clientConfig.metadata) === null || _b === void 0 ? void 0 : _b.apiEndpoint }));
47
48
  }
48
- if ((_c = clientConfigResponse.clientConfig.metadata) === null || _c === void 0 ? void 0 : _c.plugins) {
49
+ if (!getConfig().disableRemoteConfig &&
50
+ ((_c = clientConfigResponse.clientConfig.metadata) === null || _c === void 0 ? void 0 : _c.plugins)) {
49
51
  yield call(loadPlugins, (_d = clientConfigResponse.clientConfig.metadata) === null || _d === void 0 ? void 0 : _d.plugins);
50
52
  }
51
53
  else
@@ -55,7 +57,8 @@ function* getClientConfig(permalink, uniqid) {
55
57
  if (/compactTheme/.test(window.location.href)) {
56
58
  yield call(setWizardTheme, { name: "compact" });
57
59
  }
58
- else if ((_g = (_f = clientConfigResponse.clientConfig.metadata) === null || _f === void 0 ? void 0 : _f.theme) === null || _g === void 0 ? void 0 : _g.name) {
60
+ else if (!getConfig().disableRemoteConfig &&
61
+ ((_g = (_f = clientConfigResponse.clientConfig.metadata) === null || _f === void 0 ? void 0 : _f.theme) === null || _g === void 0 ? void 0 : _g.name)) {
59
62
  yield call(setWizardTheme, clientConfigResponse.clientConfig.metadata.theme);
60
63
  }
61
64
  else {
@@ -87,7 +90,6 @@ function* getWizardConfig(permalink, uniqidParam, prefix, queryParams) {
87
90
  return { modelUuid: response.modelUuid };
88
91
  }
89
92
  function* fetchModelInformation(modelUuid, permalink, prefix, queryParams) {
90
- var _a;
91
93
  let response = yield call(fetch, ...getModelInformationArguments(modelUuid, queryParams));
92
94
  if (response === undefined) {
93
95
  throw new Error(`Unable to fetch wizard config, we did not receive any response`);
@@ -104,7 +106,14 @@ function* fetchModelInformation(modelUuid, permalink, prefix, queryParams) {
104
106
  const meta = Object.assign(Object.assign({}, response.meta), { permalink,
105
107
  prefix });
106
108
  yield put(initMetaAction(meta));
107
- document.title = `${meta.title} - ${((_a = getConfig().brand) === null || _a === void 0 ? void 0 : _a.name) || "LegalPlace"}`;
109
+ const { brand } = getConfig();
110
+ const { name, documentTitle } = brand || {};
111
+ if (documentTitle !== false) {
112
+ document.title =
113
+ typeof documentTitle === "string"
114
+ ? documentTitle
115
+ : `${meta.title} - ${name || "LegalPlace"}`;
116
+ }
108
117
  const { references, customization, smartScript } = response;
109
118
  yield put(initReferencesAction(references));
110
119
  if (customization.disableAutoDefault !== undefined)
@@ -230,6 +239,13 @@ function* fetchModelPrerequisites(action) {
230
239
  const queryParams = new URLSearchParams(window.location.search);
231
240
  if (pathReader.modelVersion)
232
241
  queryParams.set("version", pathReader.modelVersion);
242
+ const { apiQueryParams } = getConfig().metadata || {};
243
+ if (apiQueryParams) {
244
+ Object.keys(apiQueryParams).forEach((currentParam) => {
245
+ if (apiQueryParams[currentParam] !== undefined)
246
+ queryParams.set(currentParam, apiQueryParams[currentParam]);
247
+ });
248
+ }
233
249
  const clientConfigReturnValue = yield call(getClientConfig, permalink, uniqid || "");
234
250
  const wizardConfig = yield call(getWizardConfig, permalink, uniqidParam, prefix, queryParams);
235
251
  yield put(fetchModelAction(permalink, prefix, uniqid, uniqidParam, queryParams, pathReader, urlParams, clientConfigReturnValue, wizardConfig));