@zengenti/contensis-react-base 3.1.1-beta.9 → 3.2.1-beta.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 (148) hide show
  1. package/README.md +36 -0
  2. package/cjs/{App-4c9e6d1b.js → App-8a2f85d5.js} +90 -74
  3. package/cjs/App-8a2f85d5.js.map +1 -0
  4. package/cjs/{ChangePassword.container-15acbce2.js → ChangePassword.container-efcb1fcd.js} +27 -28
  5. package/cjs/ChangePassword.container-efcb1fcd.js.map +1 -0
  6. package/{esm/ToJs-48b1f586.js → cjs/CookieHelper.class-34994aa1.js} +11 -97
  7. package/cjs/CookieHelper.class-34994aa1.js.map +1 -0
  8. package/cjs/{RouteLoader-190ac009.js → RouteLoader-4fb33db9.js} +10 -6
  9. package/cjs/RouteLoader-4fb33db9.js.map +1 -0
  10. package/cjs/{ContensisDeliveryApi-d63b3d39.js → SSRContext-433c53e4.js} +103 -42
  11. package/cjs/SSRContext-433c53e4.js.map +1 -0
  12. package/cjs/ToJs-7f965106.js +128 -0
  13. package/cjs/ToJs-7f965106.js.map +1 -0
  14. package/cjs/client.js +20 -20
  15. package/cjs/client.js.map +1 -1
  16. package/cjs/contensis-react-base.js +44 -34
  17. package/cjs/contensis-react-base.js.map +1 -1
  18. package/cjs/forms.js +54 -14
  19. package/cjs/forms.js.map +1 -1
  20. package/cjs/redux.js +16 -16
  21. package/cjs/redux.js.map +1 -1
  22. package/cjs/routing.js +13 -4
  23. package/cjs/routing.js.map +1 -1
  24. package/cjs/{sagas-e04b94c1.js → sagas-50a16d58.js} +9 -7
  25. package/cjs/sagas-50a16d58.js.map +1 -0
  26. package/cjs/search.js +1 -1
  27. package/cjs/{selectors-8e56cc34.js → selectors-e3f1fd85.js} +240 -3
  28. package/cjs/selectors-e3f1fd85.js.map +1 -0
  29. package/cjs/{version-bb4a3418.js → store-665c229b.js} +7 -23
  30. package/cjs/store-665c229b.js.map +1 -0
  31. package/cjs/user.js +9 -10
  32. package/cjs/user.js.map +1 -1
  33. package/cjs/util.js +14 -10
  34. package/cjs/util.js.map +1 -1
  35. package/cjs/{version-c2a37225.js → version-3b05d6c8.js} +17 -17
  36. package/cjs/{version-c2a37225.js.map → version-3b05d6c8.js.map} +1 -1
  37. package/cjs/version-7b43af3e.js +20 -0
  38. package/cjs/version-7b43af3e.js.map +1 -0
  39. package/esm/{App-b8c75933.js → App-91d81f0c.js} +59 -43
  40. package/esm/App-91d81f0c.js.map +1 -0
  41. package/esm/{ChangePassword.container-6a1c60f3.js → ChangePassword.container-96dab474.js} +4 -5
  42. package/esm/ChangePassword.container-96dab474.js.map +1 -0
  43. package/{cjs/ToJs-374a7fbd.js → esm/CookieHelper.class-6d649751.js} +5 -129
  44. package/esm/CookieHelper.class-6d649751.js.map +1 -0
  45. package/esm/{RouteLoader-487b5a9b.js → RouteLoader-94ca1c51.js} +10 -6
  46. package/esm/RouteLoader-94ca1c51.js.map +1 -0
  47. package/esm/{ContensisDeliveryApi-7b71bb3e.js → SSRContext-88841734.js} +95 -41
  48. package/esm/SSRContext-88841734.js.map +1 -0
  49. package/esm/ToJs-67b34be1.js +98 -0
  50. package/esm/ToJs-67b34be1.js.map +1 -0
  51. package/esm/client.js +18 -18
  52. package/esm/client.js.map +1 -1
  53. package/esm/contensis-react-base.js +31 -21
  54. package/esm/contensis-react-base.js.map +1 -1
  55. package/esm/forms.js +54 -14
  56. package/esm/forms.js.map +1 -1
  57. package/esm/redux.js +7 -7
  58. package/esm/routing.js +13 -4
  59. package/esm/routing.js.map +1 -1
  60. package/esm/{sagas-933a8fc8.js → sagas-cf693497.js} +9 -7
  61. package/esm/sagas-cf693497.js.map +1 -0
  62. package/esm/search.js +2 -2
  63. package/esm/selectors-d2bdfe22.js +396 -0
  64. package/esm/selectors-d2bdfe22.js.map +1 -0
  65. package/esm/{version-f6660b69.js → store-f524c50d.js} +4 -16
  66. package/esm/store-f524c50d.js.map +1 -0
  67. package/esm/user.js +7 -8
  68. package/esm/user.js.map +1 -1
  69. package/esm/util.js +6 -5
  70. package/esm/util.js.map +1 -1
  71. package/esm/version-7f50b694.js +15 -0
  72. package/esm/version-7f50b694.js.map +1 -0
  73. package/esm/{version-5a0b9406.js → version-dcc28b32.js} +3 -3
  74. package/esm/{version-5a0b9406.js.map → version-dcc28b32.js.map} +1 -1
  75. package/models/app/App.d.ts +1 -1
  76. package/models/app/pages/VersionInfo/components/VersionInfo.d.ts +1 -1
  77. package/models/client/client.d.ts +1 -1
  78. package/models/index.d.ts +1 -2
  79. package/models/models/AppRouteProps.d.ts +11 -0
  80. package/models/{redux/appstate.d.ts → models/AppState.d.ts} +1 -1
  81. package/models/models/ContentTypeMapping.d.ts +29 -0
  82. package/models/models/EntryMapper.d.ts +3 -0
  83. package/models/models/GetRouteActionArgs.d.ts +15 -0
  84. package/models/models/ReduxInjector.d.ts +5 -0
  85. package/models/models/RequireLogin.d.ts +6 -0
  86. package/models/models/RouteComponent.d.ts +2 -0
  87. package/models/models/RouteComponentProps.d.ts +9 -0
  88. package/models/models/RouteLoaderProps.d.ts +6 -0
  89. package/models/models/RouteNode.d.ts +5 -0
  90. package/models/models/SSRContext.d.ts +11 -0
  91. package/models/models/StaticRoute.d.ts +28 -0
  92. package/models/models/WithEvents.d.ts +29 -0
  93. package/models/models/config/AppConfig.d.ts +12 -0
  94. package/models/{config.d.ts → models/config/ServerConfig.d.ts} +2 -12
  95. package/models/models/config/StateType.d.ts +1 -0
  96. package/models/models/config/index.d.ts +3 -0
  97. package/models/models/index.d.ts +15 -0
  98. package/models/redux/sagas/navigation.d.ts +1 -3
  99. package/models/redux/store/injectors.d.ts +4 -4
  100. package/models/redux/store/store.d.ts +1 -2
  101. package/models/routing/components/RouteLoader.d.ts +1 -1
  102. package/models/routing/redux/actions.d.ts +2 -3
  103. package/models/routing/redux/selectors.d.ts +2 -2
  104. package/models/routing/util/find-contenttype-mapping.d.ts +1 -1
  105. package/models/routing/util/queries.d.ts +2 -2
  106. package/models/search/models/Queries.d.ts +2 -1
  107. package/models/search/models/Search.d.ts +3 -0
  108. package/models/search/search/ContensisDeliveryApi.d.ts +2 -2
  109. package/models/server/features/caching/cacheDuration.schema.d.ts +1 -0
  110. package/models/server/features/linkdepth-api/search.d.ts +1 -1
  111. package/models/server/internalServer.d.ts +1 -1
  112. package/models/server/util/bundles.d.ts +1 -1
  113. package/models/server/util/headers.d.ts +1 -1
  114. package/models/server/webApp.d.ts +1 -1
  115. package/models/user/redux/selectors.d.ts +1 -2
  116. package/models/user/util/matchGroups.d.ts +1 -1
  117. package/models/util/CachedDeliveryApi.d.ts +11 -10
  118. package/models/util/ContensisDeliveryApi.d.ts +9 -6
  119. package/models/util/SSRContext.d.ts +30 -0
  120. package/models/util/index.d.ts +1 -0
  121. package/models/util/json-mapper.d.ts +1 -2
  122. package/package.json +3 -3
  123. package/cjs/App-4c9e6d1b.js.map +0 -1
  124. package/cjs/ChangePassword.container-15acbce2.js.map +0 -1
  125. package/cjs/ContensisDeliveryApi-d63b3d39.js.map +0 -1
  126. package/cjs/CookieConstants-000427db.js +0 -10
  127. package/cjs/CookieConstants-000427db.js.map +0 -1
  128. package/cjs/RouteLoader-190ac009.js.map +0 -1
  129. package/cjs/ToJs-374a7fbd.js.map +0 -1
  130. package/cjs/reducers-ea1b2dc0.js +0 -236
  131. package/cjs/reducers-ea1b2dc0.js.map +0 -1
  132. package/cjs/sagas-e04b94c1.js.map +0 -1
  133. package/cjs/selectors-8e56cc34.js.map +0 -1
  134. package/cjs/version-bb4a3418.js.map +0 -1
  135. package/esm/App-b8c75933.js.map +0 -1
  136. package/esm/ChangePassword.container-6a1c60f3.js.map +0 -1
  137. package/esm/ContensisDeliveryApi-7b71bb3e.js.map +0 -1
  138. package/esm/CookieConstants-3d3b6531.js +0 -6
  139. package/esm/CookieConstants-3d3b6531.js.map +0 -1
  140. package/esm/RouteLoader-487b5a9b.js.map +0 -1
  141. package/esm/ToJs-48b1f586.js.map +0 -1
  142. package/esm/reducers-919da5e0.js +0 -213
  143. package/esm/reducers-919da5e0.js.map +0 -1
  144. package/esm/sagas-933a8fc8.js.map +0 -1
  145. package/esm/selectors-1f0cc787.js +0 -182
  146. package/esm/selectors-1f0cc787.js.map +0 -1
  147. package/esm/version-f6660b69.js.map +0 -1
  148. package/models/routing/routes.d.ts +0 -127
package/esm/forms.js CHANGED
@@ -569,9 +569,8 @@ const getFieldType = field => {
569
569
  return 'dateRange';
570
570
  } else if (field.dataFormat === 'entry') {
571
571
  return 'entryPicker';
572
- } else {
573
- return 'textfield';
574
572
  }
573
+ if (field.dataFormat === 'quote') return 'title';else return 'textfield';
575
574
  };
576
575
 
577
576
  const sagas = [takeEvery(SUBMIT_FORM_SUCCESS, onFormSuccess), takeEvery(SUBMIT_FORM_FOR_VALIDATION, doValidateForm), takeEvery(SUBMIT_FORM, onSubmitForm), takeEvery(SET_FORM_ID, doFetchForm),
@@ -594,12 +593,15 @@ function* doValidateForm(action) {
594
593
 
595
594
  function* onValidateGroupFields(formId, groupId) {
596
595
  const state = yield select();
596
+ const selectFormFieldErrors = makeSelectFormFieldErrors(formId);
597
+ const existingErrors = selectFormFieldErrors(state) || [];
598
+ const existingErrorsFiltered = (existingErrors === null || existingErrors === void 0 ? void 0 : existingErrors.filter(ee => (ee === null || ee === void 0 ? void 0 : ee.groupId) !== groupId)) || [];
597
599
  const selectPostData = makeSelectFormPostData(formId);
598
600
  const postData = selectPostData(state);
599
601
  const selectFormFields = makeSelectFormFields(formId);
600
602
  const fields = selectFormFields(state);
601
603
  const groupFields = fields.filter(f => f.groupId == groupId);
602
- let errors = [];
604
+ let errors = [...existingErrorsFiltered];
603
605
  groupFields.forEach(field => {
604
606
  let value = '';
605
607
  if (postData[field.id]) value = postData[field.id];
@@ -632,6 +634,28 @@ function* onValidateAllFields(formId) {
632
634
  value: errors
633
635
  });
634
636
  }
637
+
638
+ // function* onValidateSingleField(formId, fieldId, value) {
639
+ // const state = yield select();
640
+ // const selectFormFields = makeSelectFormFields(formId);
641
+ // const fields = selectFormFields(state);
642
+
643
+ // const selectFormFieldErrors = makeSelectFormFieldErrors(formId)
644
+ // const errors = selectFormFieldErrors(state);
645
+
646
+ // const fieldData = fields.find(f => f.id == fieldId);
647
+
648
+ // const newErrors = [];
649
+ // // loop through current errors to remove any of the item we currently edit
650
+ // errors.forEach(error => {
651
+ // // push any existing errors to new array
652
+ // if (error.fieldId !== fieldId) newErrors.push(error);
653
+ // });
654
+ // const err = doValidateField(fieldData, value);
655
+ // if (err) newErrors.push(err);
656
+ // yield put({ type: SET_FIELD_ERROR, formId: formId, value: newErrors });
657
+ // }
658
+
635
659
  function* doTogglePage(action) {
636
660
  const {
637
661
  formId,
@@ -641,8 +665,10 @@ function* doTogglePage(action) {
641
665
  const selectFormGroups = makeSelectFormGroup(formId);
642
666
  const formGroups = selectFormGroups(state);
643
667
  if (action.type === PAGE_FORWARD) {
644
- const errors = yield onValidateGroupFields(formId, formGroups[pageIndex - 1].id);
645
- if (errors && errors.length <= 0) {
668
+ const groupdId = formGroups[pageIndex - 1].id;
669
+ const errors = yield onValidateGroupFields(formId, groupdId);
670
+ const hasErrorsWithinGroup = errors === null || errors === void 0 ? void 0 : errors.filter(e => e.groupId === groupdId).length;
671
+ if (!hasErrorsWithinGroup) {
646
672
  yield put({
647
673
  type: SET_CURRENT_PAGE,
648
674
  formId: formId,
@@ -4942,11 +4968,11 @@ const CountrySelect = ({
4942
4968
  label,
4943
4969
  field,
4944
4970
  validations,
4945
- defaultValue,
4971
+ defaultValue = '',
4946
4972
  placeholder
4947
4973
  }) => {
4948
4974
  const elInputRef = useRef(null);
4949
- const [country, setCountry] = useState('');
4975
+ const [country, setCountry] = useState(defaultValue);
4950
4976
  const selectFormValidationSent = makeSelectFormValidationSent(formId);
4951
4977
  const formValidationSent = useSelector(selectFormValidationSent);
4952
4978
  const [a11yInvalid, setA11yInvalid] = useState('');
@@ -5223,10 +5249,20 @@ const FormComposer = ({
5223
5249
  id: field.id,
5224
5250
  label: field.name && field.name[defaultLanguage],
5225
5251
  validations: field.validations,
5226
- defaultValue: field === null || field === void 0 ? void 0 : (_field$default = field.default) === null || _field$default === void 0 ? void 0 : _field$default[defaultLanguage],
5252
+ defaultValue: formData && formData[field.id] || (field === null || field === void 0 ? void 0 : (_field$default = field.default) === null || _field$default === void 0 ? void 0 : _field$default[defaultLanguage]),
5227
5253
  placeholder: field === null || field === void 0 ? void 0 : (_field$editor = field.editor) === null || _field$editor === void 0 ? void 0 : (_field$editor$propert = _field$editor.properties) === null || _field$editor$propert === void 0 ? void 0 : (_field$editor$propert2 = _field$editor$propert.placeholderText) === null || _field$editor$propert2 === void 0 ? void 0 : _field$editor$propert2[defaultLanguage]
5228
5254
  });
5229
5255
  }
5256
+ case 'title':
5257
+ {
5258
+ return /*#__PURE__*/React.createElement("span", {
5259
+ className: "form__title",
5260
+ "data-form": "title",
5261
+ style: {
5262
+ display: 'block'
5263
+ }
5264
+ }, field.name && field.name[defaultLanguage]);
5265
+ }
5230
5266
  }
5231
5267
  });
5232
5268
  };
@@ -5375,6 +5411,7 @@ const Form = ({
5375
5411
  const errors = useSelector(selectFormFieldErrors);
5376
5412
  const entries = useSelector(selectFormEntries);
5377
5413
  const formData = useSelector(selectFormPostData);
5414
+ const currentGroup = pagingInfo === null || pagingInfo === void 0 ? void 0 : pagingInfo.currentPageId;
5378
5415
  if (pagingInfo && pagingInfo.pageCount > 1) {
5379
5416
  const isLastPage = pagingInfo.pageCount == pagingInfo.pageIndex + 1;
5380
5417
  return /*#__PURE__*/React.createElement(ThemeProvider, {
@@ -5428,13 +5465,16 @@ const Form = ({
5428
5465
  className: "form__errors",
5429
5466
  role: "alert"
5430
5467
  }, errors === null || errors === void 0 ? void 0 : errors.map(({
5431
- message
5468
+ message,
5469
+ groupId
5432
5470
  }, i) => {
5433
- return /*#__PURE__*/React.createElement(Callout, {
5434
- className: "form__error",
5435
- text: message,
5436
- key: i
5437
- });
5471
+ if (currentGroup === groupId) {
5472
+ return /*#__PURE__*/React.createElement(Callout, {
5473
+ className: "form__error",
5474
+ text: message,
5475
+ key: i
5476
+ });
5477
+ }
5438
5478
  }))));
5439
5479
  } else {
5440
5480
  return /*#__PURE__*/React.createElement(ThemeProvider, {