@colisweb/rescript-toolkit 4.8.1 → 4.8.2

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 (2) hide show
  1. package/package.json +1 -1
  2. package/src/form/Reform.res +21 -10
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@colisweb/rescript-toolkit",
3
- "version": "4.8.1",
3
+ "version": "4.8.2",
4
4
  "type": "module",
5
5
  "scripts": {
6
6
  "clean": "rescript clean",
@@ -180,7 +180,7 @@ module Make = (Config: Config) => {
180
180
  ~onSubmit,
181
181
  ~onSubmitFail=ignore,
182
182
  ~i18n=?,
183
- ~validationStrategy=OnDemand,
183
+ ~validationStrategy=OnChange,
184
184
  (),
185
185
  ) => {
186
186
  let intl = useIntl()
@@ -257,6 +257,8 @@ module Make = (Config: Config) => {
257
257
  field,
258
258
  (Valid: fieldState),
259
259
  ))
260
+
261
+ self.send(SetFormState(Valid))
260
262
  self.send(SetFieldsState(newFieldsState))
261
263
  submit ? self.send(Submit) : ()
262
264
  }
@@ -332,16 +334,25 @@ module Make = (Config: Config) => {
332
334
  ),
333
335
  })
334
336
  | FieldArrayUpdateByIndex(field, value, index) =>
335
- Update({
336
- ...state,
337
- values: Config.set(
338
- state.values,
339
- field,
340
- Config.get(state.values, field)->Belt.Array.mapWithIndex((i, currentValue) =>
341
- i == index ? value : currentValue
337
+ UpdateWithSideEffects(
338
+ {
339
+ ...state,
340
+ values: Config.set(
341
+ state.values,
342
+ field,
343
+ Config.get(state.values, field)->Belt.Array.mapWithIndex((i, currentValue) =>
344
+ i == index ? value : currentValue
345
+ ),
342
346
  ),
343
- ),
344
- })
347
+ },
348
+ self => {
349
+ switch validationStrategy {
350
+ | OnChange => self.send(ValidateField(Field(field)))
351
+ | OnDemand => ()
352
+ }
353
+ None
354
+ },
355
+ )
345
356
  | SetFormState(newState) => Update({...state, formState: newState})
346
357
  | ResetForm =>
347
358
  Update({