@mysetup/hooks 1.5.0 → 1.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.
@@ -1,7 +1,7 @@
1
1
  import type { FormEvent } from "react";
2
2
  import type { AlertState } from "@mysetup/types";
3
3
  import type { FormValue, Validations } from "./types";
4
- export declare const useForm: <T extends Record<keyof T, unknown> = object>(options?: {
4
+ export declare const useForm: <T extends Record<keyof T, unknown> = Record<string, unknown>>(options?: {
5
5
  validations: Validations<T>;
6
6
  initialValues?: Partial<T>;
7
7
  onReset?: () => void;
@@ -1 +1 @@
1
- {"version":3,"file":"useForm.d.ts","sourceRoot":"","sources":["../../../src/useForm/useForm.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,KAAK,EAAE,SAAS,EAAY,WAAW,EAAE,MAAM,SAAS,CAAC;AAKhE,eAAO,MAAM,OAAO,GAAI,CAAC,SAAS,MAAM,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,qBAAqB;IAC3E,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;IAC5B,aAAa,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;CACzB;6BAmRmC,MAAM,CAAC;;0BAKb,SAAS;;;;;;;;wBA9Q1B,MAAM,CAAC,SACL,SAAS;uBAmIY,SAAS,CAAC,eAAe,CAAC;4BApH3B,MAAM,CAAC;;;;4BA0QP,OAAO,CAAC,CAAC,CAAC;CAsB5C,CAAC"}
1
+ {"version":3,"file":"useForm.d.ts","sourceRoot":"","sources":["../../../src/useForm/useForm.tsx"],"names":[],"mappings":"AACA,OAAO,KAAK,EAAE,SAAS,EAAE,MAAM,OAAO,CAAC;AACvC,OAAO,KAAK,EAAE,UAAU,EAAE,MAAM,gBAAgB,CAAC;AAGjD,OAAO,KAAK,EAAE,SAAS,EAAY,WAAW,EAAE,MAAM,SAAS,CAAC;AAKhE,eAAO,MAAM,OAAO,GAChB,CAAC,SAAS,MAAM,CAAC,MAAM,CAAC,EAAE,OAAO,CAAC,sCAC1B;IACR,WAAW,EAAE,WAAW,CAAC,CAAC,CAAC,CAAC;IAC5B,aAAa,CAAC,EAAE,OAAO,CAAC,CAAC,CAAC,CAAC;IAC3B,OAAO,CAAC,EAAE,MAAM,IAAI,CAAC;IACrB,QAAQ,CAAC,EAAE,MAAM,IAAI,CAAC;CACzB;6BAqRmC,MAAM,CAAC;;0BAKb,SAAS;;;;;;wBArPR,MAAM,CAAC;;wBA9BzB,MAAM,CAAC,SACL,SAAS;uBAmIY,SAAS,CAAC,eAAe,CAAC;4BApH3B,MAAM,CAAC;;;;4BA+QP,OAAO,CAAC,CAAC,CAAC;CAsB5C,CAAC"}
@@ -56,8 +56,6 @@ var useForm = function (options) {
56
56
  var _b = (0, react_1.useState)({}), errors = _b[0], setErrors = _b[1];
57
57
  var _c = (0, react_1.useState)({}), passed = _c[0], setPassed = _c[1];
58
58
  var _d = (0, react_1.useState)(false), isSubmitted = _d[0], setIsSubmitted = _d[1];
59
- var newErrors = {};
60
- var newPassed = {};
61
59
  var handleChange = function (key, value, showError) {
62
60
  if (showError === void 0) { showError = false; }
63
61
  setData(function (prev) {
@@ -76,7 +74,7 @@ var useForm = function (options) {
76
74
  handleChange(key, value.trim(), showError);
77
75
  return;
78
76
  }
79
- var isValid = checkFieldValidation(key, data[key], showError).isValid;
77
+ var isValid = checkFieldValidation(key, value, showError).isValid;
80
78
  if (isValid) {
81
79
  clearError(key);
82
80
  }
@@ -164,49 +162,59 @@ var useForm = function (options) {
164
162
  };
165
163
  };
166
164
  var handleSubmit = function (e) { return __awaiter(void 0, void 0, void 0, function () {
167
- var isValid, validations, key, inputValue, validationRules, _i, _a, rule, _b, value, ruleName, params, normalizeValue, normalizeRuleName, normalizeParams, ruleValue, msg;
168
- var _c;
169
- return __generator(this, function (_d) {
165
+ var isValid, validations, _loop_2, key;
166
+ var _a;
167
+ return __generator(this, function (_b) {
170
168
  e === null || e === void 0 ? void 0 : e.preventDefault();
171
169
  setIsSubmitted(true);
172
170
  isValid = true;
173
171
  validations = options === null || options === void 0 ? void 0 : options.validations;
174
172
  if (validations) {
175
- for (key in validations) {
176
- inputValue = data[key];
177
- validationRules = (_c = validations[key]) === null || _c === void 0 ? void 0 : _c.rules;
178
- for (_i = 0, _a = validationRules || []; _i < _a.length; _i++) {
179
- rule = _a[_i];
180
- _b = normalizeValues(inputValue, rule), value = _b[0], ruleName = _b[1], params = _b[2];
181
- normalizeValue = value;
182
- normalizeRuleName = ruleName;
183
- normalizeParams = params;
184
- ruleValue = rulesList_1.rulesList[normalizeRuleName];
173
+ _loop_2 = function (key) {
174
+ var inputValue = data[key];
175
+ var validationRules = (_a = validations[key]) === null || _a === void 0 ? void 0 : _a.rules;
176
+ var _loop_3 = function (rule) {
177
+ var _d = normalizeValues(inputValue, rule), value = _d[0], ruleName = _d[1], params = _d[2];
178
+ var normalizeValue = value;
179
+ var normalizeRuleName = ruleName;
180
+ var normalizeParams = params;
181
+ var ruleValue = rulesList_1.rulesList[normalizeRuleName];
185
182
  if (!passes(normalizeRuleName, normalizeValue, normalizeParams)) {
186
183
  isValid = false;
187
- msg = (0, helpers_1.message)(normalizeRuleName, key, rulesList_1.rulesList, validations);
184
+ var msg_2 = (0, helpers_1.message)(normalizeRuleName, key, rulesList_1.rulesList, validations);
188
185
  if (normalizeParams.length > 0 &&
189
186
  Object.prototype.hasOwnProperty.call(rulesList_1.rulesList[normalizeRuleName], "messageReplace")) {
190
- msg = ruleValue.messageReplace
191
- ? ruleValue.messageReplace(msg, normalizeParams)
187
+ msg_2 = ruleValue.messageReplace
188
+ ? ruleValue.messageReplace(msg_2, normalizeParams)
192
189
  : "";
193
190
  }
194
- newErrors[key] = {
195
- type: "error",
196
- message: msg,
197
- };
191
+ setErrors(function (prev) {
192
+ var _a;
193
+ return (__assign(__assign({}, prev), (_a = {}, _a[key] = {
194
+ type: "error",
195
+ message: msg_2,
196
+ }, _a)));
197
+ });
198
198
  }
199
199
  else {
200
- newPassed[key] = {
201
- type: "success",
202
- message: "",
203
- };
204
- setPassed(newPassed);
200
+ setPassed(function (prev) {
201
+ var _a;
202
+ return (__assign(__assign({}, prev), (_a = {}, _a[key] = {
203
+ type: "success",
204
+ message: "",
205
+ }, _a)));
206
+ });
205
207
  }
208
+ };
209
+ for (var _i = 0, _c = validationRules || []; _i < _c.length; _i++) {
210
+ var rule = _c[_i];
211
+ _loop_3(rule);
206
212
  }
213
+ };
214
+ for (key in validations) {
215
+ _loop_2(key);
207
216
  }
208
217
  if (!isValid) {
209
- setErrors(newErrors);
210
218
  return [2 /*return*/];
211
219
  }
212
220
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@mysetup/hooks",
3
- "version": "1.5.0",
3
+ "version": "1.7.0",
4
4
  "license": "MIT",
5
5
  "main": "dist/index.js",
6
6
  "files": [
@@ -35,16 +35,16 @@
35
35
  "@mysetup/prettier-config": "latest",
36
36
  "@mysetup/test-helpers": "latest",
37
37
  "@mysetup/tsconfig": "latest",
38
- "@testing-library/react": "^16.0.1",
38
+ "@testing-library/react": "^16.2.0",
39
39
  "@types/jest": "^29.5.14",
40
- "@types/node": "^22.8.6",
41
- "@types/react": "^18.3.12",
40
+ "@types/node": "^22.13.1",
41
+ "@types/react": "^18.3.1",
42
42
  "@types/react-dom": "^18.3.1",
43
43
  "eslint": "8.57.0",
44
44
  "jest": "^29.7.0",
45
45
  "react": "^18.3.1",
46
46
  "react-dom": "^18.3.1",
47
- "typescript": "^5.6.3"
47
+ "typescript": "^5.7.3"
48
48
  },
49
49
  "prettier": "@mysetup/prettier-config",
50
50
  "engines": {