@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
@@ -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
- });