@legalplace/wizardx-core 2.6.3 → 2.7.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (357) hide show
  1. package/CHANGELOG.md +43 -0
  2. package/dist/App.js +13 -4
  3. package/dist/PluginLoader.d.ts +3 -1
  4. package/dist/PluginLoader.js +12 -0
  5. package/dist/ThemeLoader.d.ts +2 -2
  6. package/dist/componentsConnectors/connectBox.d.ts +3 -1
  7. package/dist/componentsConnectors/connectDocument.d.ts +3 -1
  8. package/dist/componentsConnectors/connectHeader.d.ts +3 -1
  9. package/dist/componentsConnectors/connectMetaTitle.d.ts +3 -1
  10. package/dist/componentsConnectors/connectOption.d.ts +6 -2
  11. package/dist/componentsConnectors/connectOption.js +1 -1
  12. package/dist/componentsConnectors/connectPagination.d.ts +3 -1
  13. package/dist/componentsConnectors/connectPreview.d.ts +3 -1
  14. package/dist/componentsConnectors/connectProgress.d.ts +3 -1
  15. package/dist/componentsConnectors/connectRootOption.d.ts +3 -1
  16. package/dist/componentsConnectors/connectSection.d.ts +3 -1
  17. package/dist/componentsConnectors/connectSection.js +7 -10
  18. package/dist/componentsConnectors/connectSummary.d.ts +3 -1
  19. package/dist/componentsConnectors/connectSummaryItem.d.ts +3 -1
  20. package/dist/componentsConnectors/connectVariable.d.ts +6 -2
  21. package/dist/componentsConnectors/connectVariable.js +1 -1
  22. package/dist/componentsConnectors/connectWizardWrapper.d.ts +3 -1
  23. package/dist/componentsConnectors/connector/componentConnector.d.ts +5 -1
  24. package/dist/componentsConnectors/connector/componentConnector.js +44 -4
  25. package/dist/componentsConnectors/connector/index.d.ts +1 -0
  26. package/dist/componentsConnectors/connector/index.js +1 -0
  27. package/dist/componentsConnectors/index.d.ts +17 -0
  28. package/dist/componentsConnectors/index.js +17 -0
  29. package/dist/componentsConnectors/library.d.ts +43 -15
  30. package/dist/constants/phoneValidation.d.ts +0 -1
  31. package/dist/constants/phoneValidation.js +0 -1
  32. package/dist/helpers/apiEndpoint.d.ts +1 -0
  33. package/dist/helpers/apiEndpoint.js +4 -0
  34. package/dist/helpers/index.d.ts +4 -0
  35. package/dist/helpers/index.js +4 -0
  36. package/dist/helpers/propsEqualityCheck.d.ts +1 -0
  37. package/dist/helpers/propsEqualityCheck.js +9 -0
  38. package/dist/hooks/index.d.ts +4 -0
  39. package/dist/hooks/index.js +4 -0
  40. package/dist/hooks/useActions.d.ts +2 -0
  41. package/dist/hooks/useActions.js +4 -0
  42. package/dist/hooks/useDispatch.d.ts +1 -0
  43. package/dist/hooks/useDispatch.js +4 -0
  44. package/dist/hooks/useSelectors.d.ts +2 -0
  45. package/dist/hooks/useSelectors.js +4 -0
  46. package/dist/index.d.ts +13 -0
  47. package/dist/index.js +13 -0
  48. package/dist/libs/EventsTracking.d.ts +0 -1
  49. package/dist/libs/EventsTracking.js +0 -18
  50. package/dist/libs/PathReader.d.ts +10 -6
  51. package/dist/libs/PathReader.js +47 -28
  52. package/dist/libs/index.d.ts +5 -0
  53. package/dist/libs/index.js +5 -0
  54. package/dist/redux/actions/index.d.ts +9 -0
  55. package/dist/redux/actions/index.js +9 -0
  56. package/dist/redux/actions/library.d.ts +59 -63
  57. package/dist/redux/actions/sagas/index.d.ts +3 -0
  58. package/dist/redux/actions/sagas/index.js +3 -0
  59. package/dist/redux/actions/sagas/model.d.ts +1 -5
  60. package/dist/redux/constants/app.d.ts +2 -0
  61. package/dist/redux/constants/app.js +2 -0
  62. package/dist/redux/constants/index.d.ts +8 -0
  63. package/dist/redux/constants/index.js +8 -0
  64. package/dist/redux/constants/sagas/index.d.ts +3 -0
  65. package/dist/redux/constants/sagas/index.js +3 -0
  66. package/dist/redux/index.d.ts +5 -0
  67. package/dist/redux/index.js +5 -0
  68. package/dist/redux/middlewares/conditionsWatcherMiddleware.js +11 -5
  69. package/dist/redux/middlewares/conditionsWatcherMiddleware.test.js +120 -113
  70. package/dist/redux/middlewares/paginationWatcherMiddleware.js +2 -2
  71. package/dist/redux/middlewares/smartscriptMiddleware.js +8 -0
  72. package/dist/redux/reducers/pluginsStore.d.ts +3 -0
  73. package/dist/redux/reducers/pluginsStore.js +12 -0
  74. package/dist/redux/routerHistory.js +2 -2
  75. package/dist/redux/sagas/fetchModel.js +22 -6
  76. package/dist/redux/sagas/initInputs.js +6 -7
  77. package/dist/redux/sagas/saveData.js +3 -46
  78. package/dist/redux/sagas/setUserEmail.js +1 -28
  79. package/dist/redux/selectors/app.js +13 -18
  80. package/dist/redux/selectors/cache.d.ts +17 -0
  81. package/dist/redux/selectors/cache.js +35 -0
  82. package/dist/redux/selectors/conditions.js +7 -7
  83. package/dist/redux/selectors/index.d.ts +8 -0
  84. package/dist/redux/selectors/index.js +8 -0
  85. package/dist/redux/selectors/inputs.js +3 -3
  86. package/dist/redux/selectors/library.d.ts +2 -2
  87. package/dist/redux/selectors/references.js +26 -26
  88. package/dist/redux/selectors/selectors.d.ts +2 -2
  89. package/dist/redux/selectors/selectors.js +19 -8
  90. package/dist/redux/selectors/selectors.test.js +6 -6
  91. package/dist/redux/selectors/user.js +5 -5
  92. package/dist/redux/store.d.ts +1 -1
  93. package/dist/redux/store.js +12 -4
  94. package/dist/service/api.manager.d.ts +1 -6
  95. package/dist/service/index.d.ts +3 -0
  96. package/dist/service/index.js +3 -0
  97. package/dist/types/PluginConfig.type.d.ts +57 -0
  98. package/dist/types/PluginConfig.type.js +1 -0
  99. package/dist/types/State.type.d.ts +6 -0
  100. package/dist/types/config.type.d.ts +3 -1
  101. package/dist/types/index.d.ts +11 -0
  102. package/dist/types/index.js +11 -0
  103. package/package.json +11 -12
  104. package/.depcheckrc +0 -1
  105. package/.eslintignore +0 -2
  106. package/.eslintrc +0 -5
  107. package/__mocks__/fileMock.js +0 -1
  108. package/babel.config.json +0 -3
  109. package/dist/helpers/sendinblueHelper.d.ts +0 -4
  110. package/dist/helpers/sendinblueHelper.js +0 -46
  111. package/dist/libs/Extracts.d.ts +0 -20
  112. package/dist/libs/Extracts.js +0 -110
  113. package/jest.config.ts +0 -193
  114. package/setupJest.ts +0 -8
  115. package/src/App.test.tsx +0 -41
  116. package/src/App.tsx +0 -152
  117. package/src/Globals.ts +0 -69
  118. package/src/Loader.tsx +0 -8
  119. package/src/PluginLoader.test.tsx +0 -70
  120. package/src/PluginLoader.tsx +0 -407
  121. package/src/Shimmer.tsx +0 -108
  122. package/src/ThemeLoader.test.tsx +0 -82
  123. package/src/ThemeLoader.tsx +0 -95
  124. package/src/components/PluginRoute.tsx +0 -48
  125. package/src/components/SmartScript.tsx +0 -166
  126. package/src/components/UserLocked/UserLockedComponent.tsx +0 -33
  127. package/src/components/View.test.tsx +0 -110
  128. package/src/components/View.tsx +0 -114
  129. package/src/componentsConnectors/connectBox.test.tsx +0 -226
  130. package/src/componentsConnectors/connectBox.tsx +0 -70
  131. package/src/componentsConnectors/connectDocument.test.tsx +0 -108
  132. package/src/componentsConnectors/connectDocument.tsx +0 -64
  133. package/src/componentsConnectors/connectHeader.tsx +0 -21
  134. package/src/componentsConnectors/connectMetaTitle.test.tsx +0 -40
  135. package/src/componentsConnectors/connectMetaTitle.tsx +0 -8
  136. package/src/componentsConnectors/connectOption.tsx +0 -222
  137. package/src/componentsConnectors/connectPagination.tsx +0 -102
  138. package/src/componentsConnectors/connectPreview.tsx +0 -5
  139. package/src/componentsConnectors/connectProgress.tsx +0 -59
  140. package/src/componentsConnectors/connectRootOption.tsx +0 -95
  141. package/src/componentsConnectors/connectSection.tsx +0 -79
  142. package/src/componentsConnectors/connectSummary.tsx +0 -21
  143. package/src/componentsConnectors/connectSummaryItem.tsx +0 -102
  144. package/src/componentsConnectors/connectTermsheet.tsx +0 -359
  145. package/src/componentsConnectors/connectVariable.tsx +0 -191
  146. package/src/componentsConnectors/connectWizardWrapper.tsx +0 -30
  147. package/src/componentsConnectors/connector/componentConnector.tsx +0 -219
  148. package/src/componentsConnectors/library.ts +0 -35
  149. package/src/config.test.ts +0 -63
  150. package/src/config.ts +0 -11
  151. package/src/constants/emailValidation.ts +0 -2
  152. package/src/constants/phoneValidation.ts +0 -6
  153. package/src/definitions/path.join.d.ts +0 -4
  154. package/src/helpers/outputsParsing.ts +0 -412
  155. package/src/helpers/preloadTheme.ts +0 -17
  156. package/src/helpers/scriptsLoader.ts +0 -20
  157. package/src/helpers/sendinblueHelper.ts +0 -65
  158. package/src/hooks/usePrevious.ts +0 -9
  159. package/src/libs/ConditionsInitiator.ts +0 -164
  160. package/src/libs/ConditionsRunner/DataPopulator.ts +0 -266
  161. package/src/libs/ConditionsRunner.ts +0 -454
  162. package/src/libs/DocumentsOutputs.ts +0 -171
  163. package/src/libs/Eval/EvalBase.ts +0 -116
  164. package/src/libs/Eval/EvalFunctions.ts +0 -724
  165. package/src/libs/Eval/NumbersToLetters.ts +0 -185
  166. package/src/libs/EvalVariable.ts +0 -265
  167. package/src/libs/EventsTracking.ts +0 -276
  168. package/src/libs/Extracts.ts +0 -159
  169. package/src/libs/InputsInitiator.ts +0 -136
  170. package/src/libs/NumAuto.test.ts +0 -55
  171. package/src/libs/NumAuto.ts +0 -56
  172. package/src/libs/OvcConverter.ts +0 -285
  173. package/src/libs/PathReader.ts +0 -272
  174. package/src/libs/SectionValidity.test.ts +0 -146
  175. package/src/libs/SectionValidity.ts +0 -110
  176. package/src/libs/SmartScriptStore.ts +0 -492
  177. package/src/misc/test_model.ts +0 -14603
  178. package/src/misc/test_models/connectDocumen.testmodel.json +0 -178
  179. package/src/misc/test_models/setDefaults.testmodel.json +0 -279
  180. package/src/misc/test_models/testmodel.json +0 -1
  181. package/src/polyfills/index.ts +0 -5
  182. package/src/polyfills/objectValues.ts +0 -4
  183. package/src/polyfills/prepend.ts +0 -31
  184. package/src/polyfills/stringRepeat.ts +0 -44
  185. package/src/redux/actions/app.test.ts +0 -123
  186. package/src/redux/actions/app.ts +0 -249
  187. package/src/redux/actions/conditions.test.ts +0 -84
  188. package/src/redux/actions/conditions.ts +0 -135
  189. package/src/redux/actions/inputs.test.ts +0 -85
  190. package/src/redux/actions/inputs.ts +0 -111
  191. package/src/redux/actions/library.ts +0 -23
  192. package/src/redux/actions/mandatories.ts +0 -98
  193. package/src/redux/actions/references.test.ts +0 -48
  194. package/src/redux/actions/references.ts +0 -37
  195. package/src/redux/actions/sagas/data.test.ts +0 -11
  196. package/src/redux/actions/sagas/data.ts +0 -18
  197. package/src/redux/actions/sagas/model.test.ts +0 -14
  198. package/src/redux/actions/sagas/model.ts +0 -48
  199. package/src/redux/actions/sagas/user.ts +0 -25
  200. package/src/redux/actions/smartscript.ts +0 -55
  201. package/src/redux/actions/user.test.ts +0 -18
  202. package/src/redux/actions/user.ts +0 -41
  203. package/src/redux/constants/app.ts +0 -36
  204. package/src/redux/constants/conditions.ts +0 -25
  205. package/src/redux/constants/inputs.ts +0 -15
  206. package/src/redux/constants/mandatories.ts +0 -11
  207. package/src/redux/constants/references.ts +0 -7
  208. package/src/redux/constants/sagas/data.ts +0 -1
  209. package/src/redux/constants/sagas/model.ts +0 -2
  210. package/src/redux/constants/sagas/user.ts +0 -2
  211. package/src/redux/constants/smartscript.ts +0 -9
  212. package/src/redux/constants/user.ts +0 -6
  213. package/src/redux/listeners/subscriber.test.ts +0 -45
  214. package/src/redux/listeners/subscriber.ts +0 -29
  215. package/src/redux/middlewares/conditionsWatcherMiddleware.test.ts +0 -370
  216. package/src/redux/middlewares/conditionsWatcherMiddleware.ts +0 -321
  217. package/src/redux/middlewares/evaluationsWatcherMiddleware.test.ts +0 -323
  218. package/src/redux/middlewares/evaluationsWatcherMiddleware.ts +0 -250
  219. package/src/redux/middlewares/mandatoriesWatcherMiddleware.ts +0 -473
  220. package/src/redux/middlewares/multiplesActionsMiddleware.test.ts +0 -230
  221. package/src/redux/middlewares/multiplesActionsMiddleware.ts +0 -121
  222. package/src/redux/middlewares/paginationWatcherMiddleware.ts +0 -251
  223. package/src/redux/middlewares/pluginsHookMiddleware.ts +0 -24
  224. package/src/redux/middlewares/prefillerWatcherMiddleware.test.ts +0 -118
  225. package/src/redux/middlewares/prefillerWatcherMiddleware.ts +0 -462
  226. package/src/redux/middlewares/smartscriptMiddleware.ts +0 -228
  227. package/src/redux/middlewares/thirdpartyScriptsMiddleware.ts +0 -41
  228. package/src/redux/reducers/app/customizations/initCustomizationAutoDefault.ts +0 -16
  229. package/src/redux/reducers/app/customizations/initCustomizationMeta.ts +0 -16
  230. package/src/redux/reducers/app/instance/initInstance.ts +0 -29
  231. package/src/redux/reducers/app/instance/setDataStatus.ts +0 -16
  232. package/src/redux/reducers/app/instance/updateInstance.ts +0 -30
  233. package/src/redux/reducers/app/instance/updateInstancePaid.ts +0 -20
  234. package/src/redux/reducers/app/instance.test.ts +0 -106
  235. package/src/redux/reducers/app/meta/fetchModelFailed.ts +0 -11
  236. package/src/redux/reducers/app/meta/fetchModelNonBlocking.ts +0 -11
  237. package/src/redux/reducers/app/meta/fetchModelSucceeded.ts +0 -11
  238. package/src/redux/reducers/app/meta/fetchModelUnhealthy.ts +0 -18
  239. package/src/redux/reducers/app/meta/fetchModelUserLocked.ts +0 -11
  240. package/src/redux/reducers/app/meta/initMeta.ts +0 -22
  241. package/src/redux/reducers/app/meta/setModelUuid.ts +0 -17
  242. package/src/redux/reducers/app/meta.test.ts +0 -90
  243. package/src/redux/reducers/app/pagination/goNextPage.ts +0 -69
  244. package/src/redux/reducers/app/pagination/goPage.ts +0 -81
  245. package/src/redux/reducers/app/pagination/goPreviousPage.ts +0 -60
  246. package/src/redux/reducers/app/pagination/initPagination.ts +0 -46
  247. package/src/redux/reducers/app/pagination/updateAvailableAppStates.ts +0 -77
  248. package/src/redux/reducers/app/pagination.test.ts +0 -363
  249. package/src/redux/reducers/app/wizard/updateAvailableSections.ts +0 -40
  250. package/src/redux/reducers/app/wizard.test.ts +0 -84
  251. package/src/redux/reducers/app.test.ts +0 -336
  252. package/src/redux/reducers/app.ts +0 -150
  253. package/src/redux/reducers/conditions/addMultipleOccurency.test.ts +0 -131
  254. package/src/redux/reducers/conditions/addMultipleOccurency.ts +0 -155
  255. package/src/redux/reducers/conditions/deleteMultipleOccurency.test.ts +0 -95
  256. package/src/redux/reducers/conditions/deleteMultipleOccurency.ts +0 -141
  257. package/src/redux/reducers/conditions/initConditions.ts +0 -18
  258. package/src/redux/reducers/conditions/updateDocumentConditions.test.ts +0 -47
  259. package/src/redux/reducers/conditions/updateDocumentConditions.ts +0 -21
  260. package/src/redux/reducers/conditions/updateOptionConditions.ts +0 -24
  261. package/src/redux/reducers/conditions/updateOptionValidatorCondition.test.ts +0 -50
  262. package/src/redux/reducers/conditions/updateOptionValidatorCondition.ts +0 -28
  263. package/src/redux/reducers/conditions/updatePrefillerConditions.ts +0 -29
  264. package/src/redux/reducers/conditions/updateSectionConditions.ts +0 -28
  265. package/src/redux/reducers/conditions/updateVariableConditions.ts +0 -25
  266. package/src/redux/reducers/conditions/updateVariableValidatorCondition.test.ts +0 -50
  267. package/src/redux/reducers/conditions/updateVariableValidatorCondition.ts +0 -28
  268. package/src/redux/reducers/conditions.test.ts +0 -241
  269. package/src/redux/reducers/conditions.ts +0 -68
  270. package/src/redux/reducers/inputs/addMultipleOccurency.test.ts +0 -117
  271. package/src/redux/reducers/inputs/addMultipleOccurency.ts +0 -50
  272. package/src/redux/reducers/inputs/deleteMultipleOccurency.test.ts +0 -70
  273. package/src/redux/reducers/inputs/deleteMultipleOccurency.ts +0 -50
  274. package/src/redux/reducers/inputs/initOption.ts +0 -16
  275. package/src/redux/reducers/inputs/initVariable.ts +0 -16
  276. package/src/redux/reducers/inputs/updateOptionInput.ts +0 -24
  277. package/src/redux/reducers/inputs/updateVariableInput.ts +0 -24
  278. package/src/redux/reducers/inputs.test.ts +0 -221
  279. package/src/redux/reducers/inputs.ts +0 -51
  280. package/src/redux/reducers/mandatories/addMultipleOccurency.ts +0 -52
  281. package/src/redux/reducers/mandatories/deleteMultipleOccurency.ts +0 -55
  282. package/src/redux/reducers/mandatories/initMandatoryOption.ts +0 -17
  283. package/src/redux/reducers/mandatories/initMandatoryVariable.ts +0 -17
  284. package/src/redux/reducers/mandatories/setMandatoryIgnore.ts +0 -17
  285. package/src/redux/reducers/mandatories/setMandatoryOption.ts +0 -25
  286. package/src/redux/reducers/mandatories/setMandatorySection.ts +0 -20
  287. package/src/redux/reducers/mandatories/setMandatoryVariable.ts +0 -24
  288. package/src/redux/reducers/mandatories.ts +0 -56
  289. package/src/redux/reducers/references/initReferences.ts +0 -37
  290. package/src/redux/reducers/references/updateOptionMeta.ts +0 -73
  291. package/src/redux/reducers/references/updateVariableMeta.ts +0 -72
  292. package/src/redux/reducers/references.ts +0 -59
  293. package/src/redux/reducers/smartscript/enableSmartScript.ts +0 -13
  294. package/src/redux/reducers/smartscript/initSmartScriptTriggers.ts +0 -14
  295. package/src/redux/reducers/smartscript/updateSmartscriptOptionHidden.ts +0 -30
  296. package/src/redux/reducers/smartscript/updateSmartscriptVariableHidden.ts +0 -30
  297. package/src/redux/reducers/smartscript.ts +0 -47
  298. package/src/redux/reducers/user/initUser.ts +0 -15
  299. package/src/redux/reducers/user/setUserStatus.ts +0 -13
  300. package/src/redux/reducers/user/setUserValidToken.ts +0 -13
  301. package/src/redux/reducers/user.test.ts +0 -51
  302. package/src/redux/reducers/user.ts +0 -40
  303. package/src/redux/routerHistore.test.ts +0 -19
  304. package/src/redux/routerHistory.ts +0 -26
  305. package/src/redux/sagas/fetchModel.test.ts +0 -76
  306. package/src/redux/sagas/fetchModel.ts +0 -683
  307. package/src/redux/sagas/homogeneousRadioInputsSaga.ts +0 -42
  308. package/src/redux/sagas/initInputs.ts +0 -110
  309. package/src/redux/sagas/runner.test.ts +0 -12
  310. package/src/redux/sagas/runner.ts +0 -26
  311. package/src/redux/sagas/saveData.test.ts +0 -125
  312. package/src/redux/sagas/saveData.ts +0 -116
  313. package/src/redux/sagas/setDefaults.test.ts +0 -100
  314. package/src/redux/sagas/setDefaults.ts +0 -167
  315. package/src/redux/sagas/setUserEmail.ts +0 -221
  316. package/src/redux/selectors/app.test.ts +0 -162
  317. package/src/redux/selectors/app.ts +0 -331
  318. package/src/redux/selectors/conditions.test.ts +0 -92
  319. package/src/redux/selectors/conditions.ts +0 -293
  320. package/src/redux/selectors/inputs.test.ts +0 -72
  321. package/src/redux/selectors/inputs.ts +0 -76
  322. package/src/redux/selectors/library.ts +0 -17
  323. package/src/redux/selectors/mandatories.ts +0 -83
  324. package/src/redux/selectors/references.test.ts +0 -660
  325. package/src/redux/selectors/references.ts +0 -413
  326. package/src/redux/selectors/selectors.test.ts +0 -21
  327. package/src/redux/selectors/selectors.ts +0 -87
  328. package/src/redux/selectors/smartscript.ts +0 -30
  329. package/src/redux/selectors/user.test.ts +0 -39
  330. package/src/redux/selectors/user.ts +0 -45
  331. package/src/redux/store.test.ts +0 -22
  332. package/src/redux/store.ts +0 -100
  333. package/src/service/api.manager.ts +0 -261
  334. package/src/service/auth.service.ts +0 -5
  335. package/src/service/pardot.service.ts +0 -10
  336. package/src/tests-misc/plugins/jestTestPlugin/after.tsx +0 -5
  337. package/src/tests-misc/plugins/jestTestPlugin/before.tsx +0 -11
  338. package/src/tests-misc/plugins/jestTestPlugin/index.ts +0 -11
  339. package/src/tests-misc/plugins/jestTestPlugin/title.tsx +0 -8
  340. package/src/tests-misc/themes/jestTestTheme/components/EmailComponent.tsx +0 -5
  341. package/src/tests-misc/themes/jestTestTheme/components/TermsheetComponent.tsx +0 -5
  342. package/src/tests-misc/themes/jestTestTheme/components/WizardComponent.tsx +0 -5
  343. package/src/tests-misc/themes/jestTestTheme/faltyIndex.ts +0 -3
  344. package/src/tests-misc/themes/jestTestTheme/faltyIndexLoader.ts +0 -1
  345. package/src/tests-misc/themes/jestTestTheme/index.ts +0 -13
  346. package/src/types/Actions.type.ts +0 -612
  347. package/src/types/Components.type.ts +0 -181
  348. package/src/types/State.type.ts +0 -323
  349. package/src/types/Termsheet.type.ts +0 -28
  350. package/src/types/api.type.ts +0 -37
  351. package/src/types/config.type.ts +0 -55
  352. package/src/types/env.type.ts +0 -5
  353. package/src/types/getActions.type.ts +0 -3
  354. package/src/types/getConnectors.type.ts +0 -5
  355. package/src/types/getSelectors.type.ts +0 -3
  356. package/src/wizard-params.ts +0 -56
  357. package/tsconfig.json +0 -43
@@ -1,413 +0,0 @@
1
- import { StateType } from "../../types/State.type";
2
- import { createSelector } from "./selectors";
3
-
4
- /**
5
- * Warning:
6
- * All hashKeys for selectors here return static id (they never change)
7
- * this is because references never change, so it is useless to purge
8
- * memoization for them
9
- */
10
-
11
- export const selectReferences = createSelector(
12
- (state: StateType) => state.references
13
- );
14
-
15
- /**
16
- * Returns output's reference
17
- * @param id Option's id
18
- */
19
- // eslint-disable-next-line max-len
20
- export const selectOutputReference = createSelector(
21
- (state: StateType, id: number) => {
22
- if (typeof state.references === "undefined") return undefined;
23
- return state.references.outputs[id];
24
- },
25
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
26
- );
27
-
28
- /**
29
- * Returns output's reference
30
- * @param id Option's id
31
- */
32
- // eslint-disable-next-line max-len
33
- export const selectBoxReference = createSelector(
34
- (state: StateType, id: number) => {
35
- if (state.references.boxes[id] === undefined)
36
- throw new Error(`Box ${id} does not exist`);
37
- return state.references.boxes[id];
38
- },
39
- () => Math.random()
40
- );
41
-
42
- /*
43
- * |---------------------------------|
44
- * | Options Selectors |
45
- * |---------------------------------|
46
- */
47
-
48
- /**
49
- * Returns whether the option is multiple or not
50
- * @param id Option's id
51
- */
52
- export const isOptionMultiple = createSelector(
53
- (state: StateType, id: number) => {
54
- if (typeof state.references === "undefined") return undefined;
55
- return state.references.options[id].meta.multiple?.enabled === true;
56
- },
57
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
58
- );
59
-
60
- /**
61
- * Returns option's reference
62
- * @param id Option's id
63
- */
64
- // eslint-disable-next-line max-len
65
- export const selectOptionReference = createSelector(
66
- (state: StateType, id: number) => {
67
- if (state.references.options[id] === undefined)
68
- throw new Error(`Option ${id} does not exist`);
69
-
70
- return state.references.options[id];
71
- },
72
- () => Math.random()
73
- );
74
-
75
- /**
76
- * Returns Option's relations
77
- * @param id Option's id
78
- */
79
- // eslint-disable-next-line max-len
80
- export const selectOptionRelations = createSelector(
81
- (state: StateType, id: number) => {
82
- if (state.references.relations.options[id] === undefined)
83
- throw new Error(`Option ${id} relations do not exist`);
84
- return state.references.relations.options[id];
85
- },
86
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
87
- );
88
-
89
- /**
90
- * Returns Section's relations
91
- * @param id Section's id
92
- */
93
- // eslint-disable-next-line max-len
94
- export const selectSectionRelations = createSelector(
95
- (state: StateType, id: number) => {
96
- if (state.references.relations.sections[id] === undefined)
97
- throw new Error(`Section ${id} relations do not exist`);
98
- return state.references.relations.sections[id];
99
- },
100
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
101
- );
102
-
103
- /**
104
- * Returns Option's parents
105
- * @param id Option's id
106
- */
107
- export const selectOptionParents = createSelector(
108
- (state: StateType, id: number) => {
109
- if (state.references.relations.options[id].parents === undefined)
110
- throw new Error(`Option ${id} parent relations are undefined`);
111
-
112
- return state.references.relations.options[id].parents;
113
- },
114
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
115
- );
116
-
117
- /**
118
- * Returns Option's siblings for radio options
119
- * @param id Option's id
120
- */
121
- export const selectRadioSiblings = createSelector(
122
- (state: StateType, id: number) => {
123
- if (state.references.relations.options[id] === undefined)
124
- throw new Error(`Option ${id} relations do not exist`);
125
- const { radioSiblings } = state.references.relations.options[id];
126
- return radioSiblings;
127
- },
128
- (state, id) => (!state.references ? Math.random() : id)
129
- );
130
-
131
- /*
132
- * |---------------------------------|
133
- * | Variables Selectors |
134
- * |---------------------------------|
135
- */
136
- // eslint-disable-next-line max-len
137
- export const selectVariableReference = createSelector(
138
- (state: StateType, id: number, noThrow = false) => {
139
- if (state.references.variables[id] === undefined && noThrow === false)
140
- throw new Error(`Variable ${id} does not exist`);
141
- return state.references.variables[id];
142
- },
143
- () => Math.random()
144
- );
145
-
146
- export const selectVariableRelations = createSelector(
147
- (state: StateType, id: number) => {
148
- if (state.references.relations.variables[id] === undefined)
149
- throw new Error(`Variable ${id} relations do not exist`);
150
- return state.references.relations.variables[id];
151
- },
152
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
153
- );
154
-
155
- export const selectVariableParents = createSelector(
156
- (state: StateType, id: number) => {
157
- if (state.references.relations.variables[id] === undefined)
158
- throw new Error(`Variable ${id} parents relations is undefined`);
159
- return state.references.relations.variables[id].parents;
160
- },
161
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
162
- );
163
-
164
- /*
165
- * |---------------------------------|
166
- * | Documents Selectors |
167
- * |---------------------------------|
168
- */
169
- export const selectAllDocumentsReferences = createSelector(
170
- (state: StateType) => {
171
- if (state.references.documents === undefined)
172
- throw new Error(`Documents references do not exist`);
173
- return state.references.documents;
174
- },
175
- (state: StateType) => (!state.references ? Math.random() : 1)
176
- );
177
-
178
- export const selectDocumentReference = createSelector(
179
- (state: StateType, document: string) => {
180
- if (state.references.documents === undefined)
181
- throw new Error(`Documents references do not exist`);
182
- return state.references.documents[document];
183
- },
184
- (state: StateType) => (!state.references ? Math.random() : 1)
185
- );
186
-
187
- /*
188
- * |---------------------------------|
189
- * | Sections Selectors |
190
- * |---------------------------------|
191
- */
192
- export const selectAllSectionsReferences = createSelector(
193
- (state: StateType, document = "main") => {
194
- if (typeof state.references === "undefined") return undefined;
195
- return state.references.sections[document];
196
- },
197
- (state: StateType, document = "main") =>
198
- !state.references ? Math.random() : document
199
- );
200
-
201
- /**
202
- * Return section's reference
203
- * @param id Section's id
204
- */
205
- // eslint-disable-next-line max-len
206
- export const selectSectionReference = createSelector(
207
- (state: StateType, id: number, document = "main") => {
208
- if (state.references.sections[document] === undefined)
209
- throw new Error(`Document ${document} does not exist`);
210
- if (state.references.sections[document][id] === undefined) {
211
- throw new Error(`Section ${id} does not exist in document ${document}`);
212
- }
213
- return state.references.sections[document][id];
214
- },
215
- (state: StateType, id: number, document = "main") =>
216
- !state.references ? Math.random() : `${id}-${document}`
217
- );
218
-
219
- /**
220
- * Sections defaults Selectors
221
- */
222
- export const selectSectionDefaults = createSelector(
223
- (state: StateType, id: number) => {
224
- if (typeof state.references === "undefined") return undefined;
225
- return state.references.defaults[id];
226
- },
227
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
228
- );
229
-
230
- /*
231
- * |---------------------------------|
232
- * | Conditions Selectors |
233
- * |---------------------------------|
234
- */
235
- export const selectOptionConditionsObject = createSelector(
236
- (state: StateType, id: number) => {
237
- if (typeof state.references === "undefined") return undefined;
238
- return state.references.conditions.options[id];
239
- },
240
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
241
- );
242
-
243
- export const selectVariableConditionsObject = createSelector(
244
- (state: StateType, id: number) => {
245
- if (typeof state.references === "undefined") return undefined;
246
- return state.references.conditions.variables[id];
247
- },
248
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
249
- );
250
-
251
- export const selectDocumentConditionsObject = createSelector(
252
- (state: StateType, name: string) => {
253
- if (typeof state.references === "undefined") return undefined;
254
- return state.references.conditions.documents[name];
255
- },
256
- (state: StateType, name: string) => (!state.references ? Math.random() : name)
257
- );
258
-
259
- export const selectSectionConditionsObject = createSelector(
260
- (state: StateType, id: number, document = "main") =>
261
- state.references.conditions.sections[document][id],
262
- (state: StateType, id: number, document = "main") =>
263
- !state.references ? Math.random() : `${id}-${document}`
264
- );
265
-
266
- export const selectPrefillerConditionsObject = createSelector(
267
- (state: StateType, id: number) => {
268
- if (typeof state.references === "undefined") return undefined;
269
- return state.references.conditions.prefillers[id];
270
- },
271
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
272
- );
273
-
274
- export const selectOptionValidatorConditionsObject = createSelector(
275
- (state: StateType, id: number) => {
276
- if (typeof state.references === "undefined") return undefined;
277
- return state.references.conditions.validators.options[id];
278
- },
279
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
280
- );
281
-
282
- export const selectVariableValidatorConditionsObject = createSelector(
283
- (state: StateType, id: number) => {
284
- if (typeof state.references === "undefined") return undefined;
285
- return state.references.conditions.validators.variables[id];
286
- },
287
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
288
- );
289
-
290
- /*
291
- * |---------------------------------|
292
- * | Helpers Selectors |
293
- * |---------------------------------|
294
- */
295
- export const areVariablesSiblings = createSelector(
296
- (state: StateType, ...args: number[]) => {
297
- if (typeof state.references === "undefined") return undefined;
298
-
299
- // Getting variables first parent
300
- const rootParents = args
301
- .map((variableId) => {
302
- const parents = selectVariableParents(variableId);
303
- if (parents === undefined) return null;
304
- return parents[parents.length - 1];
305
- })
306
- .filter((a) => a !== null);
307
-
308
- const comparator = rootParents.length > 0 ? rootParents[0] : -1;
309
-
310
- return rootParents.every((c) => c === comparator);
311
- },
312
- (state: StateType, ...args: number[]) =>
313
- args.reduce((p, c) => p + c.toString(), "")
314
- );
315
-
316
- /**
317
- * Tags selector
318
- */
319
- export const selectVariablesByTag = createSelector(
320
- (state: StateType, tag: string) => {
321
- const ids: number[] = [];
322
- Object.keys(state.references.variables).forEach((id) => {
323
- const variable = state.references.variables[id];
324
- if (Array.isArray(variable.tags) && variable.tags.includes(tag))
325
- ids.push(parseInt(id, 10));
326
- });
327
- return ids;
328
- }
329
- );
330
-
331
- export const selectOptionsByTag = createSelector(
332
- (state: StateType, tag: string) => {
333
- const ids: number[] = [];
334
- Object.keys(state.references.options).forEach((id) => {
335
- const option = state.references.options[id];
336
- if (Array.isArray(option.meta.tags) && option.meta.tags.includes(tag))
337
- ids.push(parseInt(id, 10));
338
- });
339
- return ids;
340
- }
341
- );
342
-
343
- /**
344
- * Returns Option's parent section
345
- * @param id Option's id
346
- */
347
- export const selectOptionParentSection = createSelector(
348
- (state: StateType, id: number) => {
349
- const { parents } = state.references.relations.options[id];
350
- if (parents === undefined)
351
- throw new Error(`Option ${id} parent relations are undefined`);
352
-
353
- // Getting root option id
354
- const rootId = parents.length > 0 ? parents[parents.length - 1] : id;
355
-
356
- // Looking for section
357
- const sections = Object.values(state.references.sections.main);
358
-
359
- for (let i = 0; i < sections.length; i += 1) {
360
- if (sections[i].options.includes(rootId)) return sections[i].id;
361
- }
362
-
363
- throw new Error(
364
- `Cannot find parent section for option ${id} (Root option id: ${rootId})`
365
- );
366
- },
367
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
368
- );
369
-
370
- /**
371
- * Returns Variable's parent section
372
- * @param id Variable's id
373
- */
374
- export const selectVariableParentSection = createSelector(
375
- (state: StateType, id: number) => {
376
- const { parents } = state.references.relations.variables[id];
377
- if (parents === undefined)
378
- throw new Error(`Variable ${id} parent relations are undefined`);
379
-
380
- // Getting root option id
381
- const rootId = parents[parents.length - 1];
382
-
383
- // Looking for section
384
- const sections = Object.values(state.references.sections.main);
385
-
386
- for (let i = 0; i < sections.length; i += 1) {
387
- if (sections[i].options.includes(rootId)) return sections[i].id;
388
- }
389
-
390
- throw new Error(
391
- `Cannot find parent section for variable ${id} (Root option id: ${rootId})`
392
- );
393
- },
394
- (state: StateType, id: number) => (!state.references ? Math.random() : id)
395
- );
396
-
397
- export const selectUserEmailSectionVariableIds = createSelector(
398
- (state: StateType, sectionId: number) => {
399
- const { variables } = state.references;
400
-
401
- // Extract all user_email variables
402
- const userEmailVariables = Object.keys(variables).filter(
403
- (variableId) => variables[variableId].type === "user_email"
404
- );
405
-
406
- return userEmailVariables.filter(
407
- (variableId) =>
408
- selectVariableParentSection(parseInt(variableId, 10)) === sectionId
409
- );
410
- },
411
- (state: StateType, sectionId: number) =>
412
- !state.references ? Math.random() : sectionId
413
- );
@@ -1,21 +0,0 @@
1
- import configureMockStore from 'redux-mock-store';
2
- import { createSelector, selectorsMiddleware } from './selectors';
3
-
4
- describe('Selectors Test', () => {
5
- it('Middleware', () => {
6
- const mockStore = configureMockStore([selectorsMiddleware]);
7
- const store = mockStore({});
8
-
9
- const myFakeFunction = jest.fn();
10
-
11
- const selector = createSelector(myFakeFunction);
12
-
13
- store.dispatch({ type: 'FAKE_ACTION' });
14
- selector();
15
- selector();
16
- selector();
17
- selector();
18
-
19
- expect(myFakeFunction).toHaveBeenCalledTimes(1);
20
- });
21
- });
@@ -1,87 +0,0 @@
1
- import { Action, MiddlewareAPI, Dispatch } from "redux";
2
- import { StateType } from "../../types/State.type";
3
-
4
- let SelectorsStateTrack = -1;
5
- let globalMPI: MiddlewareAPI;
6
-
7
- /**
8
- * Create a Memoized version of the selector function based on
9
- * the state version and the arguments passed to it
10
- *
11
- * @category Selectors
12
- *
13
- * @param selector {function} A selector function
14
- * @param [equalityFn] {function} returns the cache key
15
- *
16
- * @return A memoized selector function
17
- */
18
- export type SelectorFunction = (state: StateType, ...args: any[]) => any;
19
- export type SelectorArguments<F extends SelectorFunction> = F extends (
20
- state: StateType,
21
- ...a: infer A
22
- ) => any
23
- ? A
24
- : never;
25
- export type SelectorReturn<F extends SelectorFunction> = F extends (
26
- state: StateType,
27
- ...a: any[]
28
- ) => infer R
29
- ? R
30
- : never;
31
- export type SelectorEqualityFn<T extends SelectorFunction> = (
32
- state: StateType,
33
- ...a: SelectorArguments<T>
34
- ) => string | number;
35
-
36
- export function createSelector<
37
- T extends SelectorFunction,
38
- R = SelectorReturn<T>
39
- >(
40
- selector: T,
41
- equalityFn?: SelectorEqualityFn<T>
42
- ): (...args: SelectorArguments<T>) => Readonly<R> {
43
- const cache: Record<string, any> = {};
44
- return (...args) => {
45
- let state;
46
-
47
- if (SelectorsStateTrack === -1)
48
- throw new Error(`State hasn't beed initiated yet`);
49
-
50
- // Getting state from MPI, wrapping it inside a try/catch since it throws
51
- // an error if selectors are used inside reducers
52
- try {
53
- state = globalMPI.getState();
54
- } catch (e) {
55
- throw new Error(
56
- "You may not use selectors while the reducer is executing. (Try sagas or middlewares)"
57
- );
58
- }
59
-
60
- // Calculating current cache key
61
- const currentKey: string | number =
62
- typeof equalityFn === "function"
63
- ? equalityFn(state, ...args)
64
- : [SelectorsStateTrack, ...args].reduce((v, c) => v + c);
65
-
66
- if (!Object.prototype.hasOwnProperty.call(cache, currentKey)) {
67
- cache[currentKey] = selector(state, ...args);
68
- }
69
-
70
- return cache[currentKey];
71
- };
72
- }
73
-
74
- /**
75
- * Selector Redux Middleware
76
- * @param mpi Redux's Middleware API
77
- */
78
- export const selectorsMiddleware =
79
- (mpi: MiddlewareAPI) => (next: Dispatch) => (action: Action) => {
80
- const result = next(action);
81
-
82
- // Adding Middleware API
83
- globalMPI = mpi;
84
- SelectorsStateTrack += 1;
85
-
86
- return result;
87
- };
@@ -1,30 +0,0 @@
1
- import { createSelector } from "./selectors";
2
- import { StateType } from "../../types/State.type";
3
-
4
- /**
5
- * Returns if option's index is hidden by Smartscript or not
6
- */
7
- export const selectIsSmartscriptOptionIndexHidden = createSelector(
8
- (state: StateType, id: number, index: number) =>
9
- Array.isArray(state.smartscript.hidden.options[id]) &&
10
- state.smartscript.hidden.options[id].includes(index),
11
- (state, id, index) =>
12
- Array.isArray(state.smartscript.hidden.options[id]) &&
13
- state.smartscript.hidden.options[id].includes(index)
14
- ? "1"
15
- : "0"
16
- );
17
-
18
- /**
19
- * Returns if variable's index is hidden by Smartscript or not
20
- */
21
- export const selectIsSmartscriptVariableIndexHidden = createSelector(
22
- (state: StateType, id: number, index: number) =>
23
- Array.isArray(state.smartscript.hidden.variables[id]) &&
24
- state.smartscript.hidden.variables[id].includes(index),
25
- (state, id, index) =>
26
- Array.isArray(state.smartscript.hidden.variables[id]) &&
27
- state.smartscript.hidden.variables[id].includes(index)
28
- ? "1"
29
- : "0"
30
- );
@@ -1,39 +0,0 @@
1
- import { createAppStore, getStore } from '../store';
2
- import { selectCurrentUserLevel, isLevelAccessibleForUser } from './user';
3
- import { initUserAction } from '../actions/user';
4
-
5
- // Initiating state
6
- createAppStore('memory');
7
- const store = getStore();
8
-
9
- describe('User selectors test suit', () => {
10
- it('selectCurrentUserLevel', () => {
11
- store.dispatch(
12
- initUserAction({
13
- displayName: 'John Doe',
14
- level: 'MANAGER',
15
- email: 'john@doe.com',
16
- })
17
- );
18
-
19
- const selector = selectCurrentUserLevel();
20
-
21
- expect(selector).toEqual('MANAGER');
22
- });
23
-
24
- it('selectCurrentUserLevel', () => {
25
- store.dispatch(
26
- initUserAction({
27
- displayName: 'John Doe',
28
- level: 'MANAGER',
29
- email: 'john@doe.com',
30
- })
31
- );
32
-
33
- expect(isLevelAccessibleForUser('GUEST')).toBeTruthy();
34
- expect(isLevelAccessibleForUser('USER')).toBeTruthy();
35
- expect(isLevelAccessibleForUser('MANAGER')).toBeTruthy();
36
- expect(isLevelAccessibleForUser('ADMIN')).toBeFalsy();
37
- expect(isLevelAccessibleForUser('SUPER')).toBeFalsy();
38
- });
39
- });
@@ -1,45 +0,0 @@
1
- import { StateType } from "../../types/State.type";
2
- import { createSelector } from "./selectors";
3
-
4
- /**
5
- * Returns current user level
6
- */
7
- export const selectCurrentUserLevel = createSelector(
8
- (state: StateType) => (state.user ? state.user.level : undefined),
9
- (state: StateType) => (state.user ? state.user.level : Math.random())
10
- );
11
-
12
- export const selectUserStatus = createSelector(
13
- (state: StateType) => (state.user ? state.user.status : "unauthenticated"),
14
- (state: StateType) => (state.user ? state.user.status : Math.random())
15
- );
16
-
17
- export const selectUserValidToken = createSelector(
18
- (state: StateType) => state.user?.validToken || false,
19
- (state: StateType) =>
20
- state.user ? (state.user.validToken || false).toString() : Math.random()
21
- );
22
-
23
- export const selectUserEmail = createSelector(
24
- (state: StateType) =>
25
- state.user && state.user.email && state.user.email.length > 0
26
- ? state.user.email
27
- : "",
28
- (state: StateType) =>
29
- state.user && state.user.email && state.user.email.length > 0
30
- ? state.user.email
31
- : Math.random()
32
- );
33
-
34
- export const isLevelAccessibleForUser = createSelector(
35
- (
36
- state: StateType,
37
- level: "ADMIN" | "MANAGER" | "USER" | "GUEST" | "SUPER"
38
- ) => {
39
- const currentUserLevel = state.user ? state.user.level : "GUEST";
40
- const levelEnum = ["GUEST", "USER", "MANAGER", "ADMIN", "SUPER"];
41
- return levelEnum.indexOf(level) <= levelEnum.indexOf(currentUserLevel);
42
- },
43
- (state: StateType, level: "ADMIN" | "MANAGER" | "USER" | "GUEST" | "SUPER") =>
44
- state.user ? `${state.user.level}-${level}` : Math.random()
45
- );
@@ -1,22 +0,0 @@
1
- import { createAppStore, getStore } from './store';
2
-
3
- /**
4
- * Testing store creation
5
- */
6
- describe('Store Creation', () => {
7
- it('Throws error when trying to get store before creation', () => {
8
- expect(() => getStore()).toThrowError('Store not yet created');
9
- });
10
-
11
- it('It creates store', () => {
12
- createAppStore();
13
- const store = getStore();
14
- return expect(store).toHaveProperty('getState');
15
- });
16
-
17
- it('It properly connects redux', () => {
18
- createAppStore();
19
- const state = getStore().getState();
20
- return expect(state).toHaveProperty('router');
21
- });
22
- });