react-hook-form-rules 1.7.2 → 1.7.4

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 (74) hide show
  1. package/CHANGELOG.md +14 -0
  2. package/dist/index.d.ts +3 -1
  3. package/dist/index.js +5 -1
  4. package/package.json +12 -1
  5. package/.github/workflows/release.yml +0 -53
  6. package/.github/workflows/test.yml +0 -17
  7. package/dist/rules/array/get-max-array-length.d.ts +0 -9
  8. package/dist/rules/array/get-max-array-length.js +0 -17
  9. package/dist/rules/array/get-min-array-length.d.ts +0 -9
  10. package/dist/rules/array/get-min-array-length.js +0 -17
  11. package/dist/rules/get-email-rule.d.ts +0 -17
  12. package/dist/rules/get-email-rule.js +0 -20
  13. package/dist/rules/get-max-array-length.d.ts +0 -8
  14. package/dist/rules/get-max-array-length.js +0 -16
  15. package/dist/rules/get-max-length-rule.d.ts +0 -11
  16. package/dist/rules/get-max-length-rule.js +0 -22
  17. package/dist/rules/get-max-rule.d.ts +0 -11
  18. package/dist/rules/get-max-rule.js +0 -15
  19. package/dist/rules/get-min-array-length.d.ts +0 -8
  20. package/dist/rules/get-min-array-length.js +0 -16
  21. package/dist/rules/get-min-length-rule.d.ts +0 -11
  22. package/dist/rules/get-min-length-rule.js +0 -22
  23. package/dist/rules/get-min-rule.d.ts +0 -16
  24. package/dist/rules/get-min-rule.js +0 -16
  25. package/dist/rules/get-require-rule.d.ts +0 -11
  26. package/dist/rules/get-require-rule.js +0 -16
  27. package/dist/rules/get-required-array-role.d.ts +0 -8
  28. package/dist/rules/get-required-array-role.js +0 -15
  29. package/dist/rules/get-required-array-rule.d.ts +0 -8
  30. package/dist/rules/get-required-array-rule.js +0 -15
  31. package/dist/rules/get-required-object-rule.d.ts +0 -8
  32. package/dist/rules/get-required-object-rule.js +0 -20
  33. package/dist/rules/get-url-rule.d.ts +0 -17
  34. package/dist/rules/get-url-rule.js +0 -20
  35. package/dist/rules/helpers/get-min-error.d.ts +0 -6
  36. package/dist/rules/helpers/get-min-error.js +0 -9
  37. package/dist/rules/helpers/get-min-length-error.d.ts +0 -6
  38. package/dist/rules/helpers/get-min-length-error.js +0 -9
  39. package/dist/rules/link/get-email-rule.d.ts +0 -17
  40. package/dist/rules/link/get-email-rule.js +0 -40
  41. package/dist/rules/link/get-url-rule.d.ts +0 -17
  42. package/dist/rules/link/get-url-rule.js +0 -20
  43. package/i18n.ts +0 -28
  44. package/index.ts +0 -30
  45. package/jest.config.js +0 -8
  46. package/locales/en.json +0 -12
  47. package/locales/ru.json +0 -11
  48. package/release.config.cjs +0 -81
  49. package/rules/array/get-max-array-length-rule.ts +0 -19
  50. package/rules/array/get-min-array-length-rule.ts +0 -19
  51. package/rules/array/get-required-array-rule.ts +0 -12
  52. package/rules/array/tests/get-max-array-length-rule.test.ts +0 -17
  53. package/rules/array/tests/get-min-array-length-rule.test.ts +0 -17
  54. package/rules/array/tests/get-required-array-rule.test.ts +0 -16
  55. package/rules/constants.ts +0 -1
  56. package/rules/default/get-max-length-rule.ts +0 -15
  57. package/rules/default/get-max-rule.ts +0 -13
  58. package/rules/default/get-min-length-rule.ts +0 -16
  59. package/rules/default/get-min-rule.ts +0 -15
  60. package/rules/default/get-require-rule.ts +0 -16
  61. package/rules/default/tests/get-max-length-rule.test.ts +0 -24
  62. package/rules/default/tests/get-max-rule.test.ts +0 -24
  63. package/rules/default/tests/get-min-length-rule.test.ts +0 -24
  64. package/rules/default/tests/get-min-rule.test.ts +0 -24
  65. package/rules/default/tests/get-required-rule.test.ts +0 -10
  66. package/rules/object/get-required-object-rule.ts +0 -20
  67. package/rules/object/tests/get-require-object-rule.test.ts +0 -18
  68. package/rules/patterns/get-email-rule.ts +0 -22
  69. package/rules/patterns/get-pattern-rule.ts +0 -12
  70. package/rules/patterns/get-url-rule.ts +0 -23
  71. package/rules/patterns/tests/get-email-rule.test.ts +0 -27
  72. package/rules/patterns/tests/get-pattern-rule.test.ts +0 -10
  73. package/rules/patterns/tests/get-url-rule.test.ts +0 -28
  74. package/tsconfig.json +0 -12
@@ -1,17 +0,0 @@
1
- interface EmailRule {
2
- pattern?: RegExp;
3
- message?: string;
4
- }
5
- /**
6
- * Validates an email address.
7
- * @param options - Parameters.
8
- * @param options.pattern - Regular expression.
9
- * @param options.message - Custom message.
10
- *
11
- * @example rules: { pattern: getEmailRule() }
12
- */
13
- export declare const getEmailRule: ({ pattern, message, }: EmailRule) => {
14
- value: RegExp;
15
- message: string;
16
- };
17
- export {};
@@ -1,40 +0,0 @@
1
- <<<<<<<< HEAD:dist/rules/link/get-email-rule.js
2
- "use strict";
3
- Object.defineProperty(exports, "__esModule", { value: true });
4
- exports.getEmailRule = void 0;
5
- const DEFAULT_PATTERN = /^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/;
6
- const DEFAULT_MESSAGE = "Please check the correctness of the entered email address.";
7
- ========
8
- import { getPatternRule } from "./get-pattern-rule";
9
- import { translate } from "../../i18n";
10
-
11
- const DEFAULT_PATTERN = /^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/;
12
-
13
- interface EmailRule {
14
- pattern?: RegExp;
15
- message?: string;
16
- }
17
-
18
- >>>>>>>> release:rules/patterns/get-email-rule.ts
19
- /**
20
- * Validates an email address.
21
- * @param options - Parameters.
22
- * @param {string} options.pattern - Regular expression.
23
- * @param {string} options.message - Custom message.
24
- *
25
- * @example rules: { pattern: getEmailRule() }
26
- */
27
- <<<<<<<< HEAD:dist/rules/link/get-email-rule.js
28
- const getEmailRule = ({ pattern = DEFAULT_PATTERN, message = DEFAULT_MESSAGE, }) => {
29
- return {
30
- value: pattern,
31
- message,
32
- };
33
- };
34
- exports.getEmailRule = getEmailRule;
35
- ========
36
- export const getEmailRule = ({
37
- pattern = DEFAULT_PATTERN,
38
- message = translate('email'),
39
- }: EmailRule) => getPatternRule(pattern, message)
40
- >>>>>>>> release:rules/patterns/get-email-rule.ts
@@ -1,17 +0,0 @@
1
- interface UrlRule {
2
- message?: string;
3
- pattern?: RegExp;
4
- }
5
- /**
6
- * Returns a rule that validates the input URL.
7
- * @param options - Parameters.
8
- * @param options.pattern - Regular expression.
9
- * @param options.message - Custom message.
10
- *
11
- * @example rules: { pattern: getUrlValidationRule() }
12
- */
13
- export declare const getUrlRule: ({ pattern, message, }: UrlRule) => {
14
- message: string;
15
- value: RegExp;
16
- };
17
- export {};
@@ -1,20 +0,0 @@
1
- "use strict";
2
- Object.defineProperty(exports, "__esModule", { value: true });
3
- exports.getUrlRule = void 0;
4
- const DEFAULT_MESSAGE = "The URL does not match the format.";
5
- const DEFAULT_PATTERN = /(http(s)?):\/\/(www\.)?[-a-zA-Z0-9@:%._\+~#=]{1,256}\.[a-zA-Z0-9()]{1,6}\b([-a-zA-Z0-9()@:%_\+.~#?&//=]*)/;
6
- /**
7
- * Returns a rule that validates the input URL.
8
- * @param options - Parameters.
9
- * @param options.pattern - Regular expression.
10
- * @param options.message - Custom message.
11
- *
12
- * @example rules: { pattern: getUrlValidationRule() }
13
- */
14
- const getUrlRule = ({ pattern = DEFAULT_PATTERN, message = DEFAULT_MESSAGE, }) => {
15
- return {
16
- message,
17
- value: pattern,
18
- };
19
- };
20
- exports.getUrlRule = getUrlRule;
package/i18n.ts DELETED
@@ -1,28 +0,0 @@
1
- import en from './locales/en.json'
2
- import ru from './locales/ru.json'
3
-
4
- const translataions = {
5
- en,
6
- ru,
7
- };
8
-
9
- let currentLang = 'en'
10
-
11
- export const setLanguage = (lang: string) => {
12
- if ((translataions as any)[lang]) {
13
- currentLang = lang;
14
- } else {
15
- console.warn(`⚠️ Language "${lang}" is not supported. Defaulting to English.`);
16
- }
17
- }
18
-
19
- export const translate = (key: string, params = {}) => {
20
- let text = (translataions as any)[currentLang][key] || key;
21
-
22
- // Подставляем параметры (например, {{min}})
23
- Object.keys(params).forEach((param) => {
24
- text = text.replace(`{{${param}}}`, (params as any)[param]);
25
- });
26
-
27
- return text;
28
- }
package/index.ts DELETED
@@ -1,30 +0,0 @@
1
- import { getEmailRule } from "./rules/patterns/get-email-rule";
2
- import { getUrlRule } from "./rules/patterns/get-url-rule";
3
- import { getPatternRule } from "./rules/patterns/get-pattern-rule";
4
-
5
- import { getMaxArrayLengthRule } from "./rules/array/get-max-array-length-rule";
6
- import { getMinArrayLengthRule } from "./rules/array/get-min-array-length-rule";
7
- import { getRequiredArrayRule } from "./rules/array/get-required-array-rule";
8
-
9
- import { getMaxLengthRule } from "./rules/default/get-max-length-rule";
10
- import { getMaxRule } from "./rules/default/get-max-rule";
11
- import { getMinLengthRule } from "./rules/default/get-min-length-rule";
12
- import { getMinRule } from "./rules/default/get-min-rule";
13
- import { getRequiredRule } from "./rules/default/get-require-rule";
14
-
15
- import { getRequiredObjectRule } from "./rules/object/get-required-object-rule";
16
-
17
- export {
18
- getPatternRule,
19
- getMaxRule,
20
- getRequiredObjectRule,
21
- getRequiredArrayRule,
22
- getEmailRule,
23
- getMaxLengthRule,
24
- getMaxArrayLengthRule,
25
- getMinArrayLengthRule,
26
- getMinLengthRule,
27
- getMinRule,
28
- getRequiredRule,
29
- getUrlRule,
30
- };
package/jest.config.js DELETED
@@ -1,8 +0,0 @@
1
- /** @type {import('ts-jest').JestConfigWithTsJest} **/
2
- module.exports = {
3
- testEnvironment: "node",
4
- transform: {
5
- "^.+\.tsx?$": ["ts-jest", {}],
6
- },
7
- testPathIgnorePatterns: ['./dist']
8
- };
package/locales/en.json DELETED
@@ -1,12 +0,0 @@
1
- {
2
- "required": "This field is required.",
3
- "maxArrayLength": "Maximum number of values - {{max}}.",
4
- "minArrayLength": "Minimum number of values - {{min}}.",
5
- "min": "Minimum value - {{min}}.",
6
- "max": "Maximum value - {{max}}.",
7
- "minLength": "Minimum length - {{min}}.",
8
- "maxLength": "Maximum length - {{max}}.",
9
- "email": "Please check the correctness of the entered email address.",
10
- "url": "The URL does not match the format."
11
- }
12
-
package/locales/ru.json DELETED
@@ -1,11 +0,0 @@
1
- {
2
- "required": "Поле объязательное.",
3
- "maxArrayLength": "Максимальное количество значений - {{max}}.",
4
- "minArrayLength": "Минимальное количество значений - {{min}}.",
5
- "min": "Минимальное значение - {{min}}.",
6
- "max": "Максимальное значение - {{max}}.",
7
- "minLength": "Минимальная длина - {{min}}.",
8
- "maxLength": "Максимальная длина - {{max}}.",
9
- "email": "Проверьте правильность введенного адреса электронной почты.",
10
- "url": "URL не соответствует формату."
11
- }
@@ -1,81 +0,0 @@
1
- /**
2
- * @type {import('semantic-release').GlobalConfig}
3
- */
4
- module.exports = {
5
- branches: ["release"],
6
- plugins: [
7
- [
8
- '@semantic-release/commit-analyzer',
9
- {
10
- releaseRules: [
11
- { breaking: true, release: 'major' },
12
- { revert: true, release: 'patch' },
13
- { type: 'feat', release: 'minor' },
14
- { type: 'fix', release: 'patch' },
15
- { type: 'docs', release: 'patch' },
16
- { type: 'style', release: 'patch' },
17
- { type: 'refactor', release: 'patch' },
18
- { type: 'perf', release: 'patch' },
19
- { type: 'test', release: 'patch' },
20
- { type: 'chore', release: 'patch' },
21
- ],
22
- },
23
- ],
24
- [
25
- '@semantic-release/release-notes-generator',
26
- {
27
- parserOpts: {
28
- noteKeywords: ['BREAKING CHANGE', 'BREAKING CHANGES', 'BREAKING'],
29
- },
30
- preset: 'conventionalcommits',
31
- presetConfig: {
32
- types: [
33
- { type: 'build', section: '📦 Build System', hidden: false },
34
- { type: 'chore', section: '📦 Build System', hidden: true },
35
- { type: 'ci', section: '💿 Continuous Integration', hidden: false },
36
- { type: 'docs', section: '📄 Documentation', hidden: false },
37
- { type: 'feat', section: '🆕 Features', hidden: false },
38
- { type: 'fix', section: '🐞 Bug Fixes', hidden: false },
39
- { type: 'perf', section: '⚡️ Performance Improvements', hidden: false },
40
- { type: 'refactor', section: '🔥 Code Refactoring', hidden: false },
41
- { type: 'style', section: '🛠 Styles', hidden: false },
42
- { type: 'test', section: '🧪 Tests', hidden: false },
43
- ],
44
- },
45
- writerOpts: {
46
- commitsSort: ['subject', 'scope'],
47
- },
48
- },
49
- ],
50
- "@semantic-release/changelog",
51
- [
52
- "@semantic-release/npm",
53
- {
54
- "npmPublish": true,
55
- "pkgRoot": ".",
56
- "publishConfig": {
57
- "registry": "https://registry.npmjs.org/",
58
- }
59
- }
60
- ],
61
- [
62
- "@semantic-release/npm",
63
- {
64
- "npmPublish": false,
65
- "pkgRoot": ".",
66
- "publishConfig": {
67
- "registry": "https://npm.pkg.github.com/",
68
- }
69
- }
70
- ],
71
- [
72
- "@semantic-release/github",
73
- {
74
- assets: [
75
- { path: "dist/*.tgz", label: "Package Distribution" },
76
- ],
77
- },
78
- ],
79
- "@semantic-release/git",
80
- ]
81
- };
@@ -1,19 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates an array for the maximum number of values.
5
- * @param arr - Array of values.
6
- * @param maxLength - Maximum number of values.
7
- * @param message - Custom message.
8
- *
9
- * @example getMaxArrayLengthRule(2, "Maximum number of values is 2").
10
- */
11
- export const getMaxArrayLengthRule = (
12
- arr: unknown[],
13
- maxLength: number,
14
- message?: string,
15
- ) => {
16
- const formattedMessage = message || translate('maxArrayLength', { max: maxLength });
17
-
18
- return arr.length < maxLength || formattedMessage;
19
- };
@@ -1,19 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates an array for the maximum number of values.
5
- * @param arr - Array of values.
6
- * @param maxLength - Maximum number of values.
7
- * @param message - Custom message.
8
- *
9
- * @example getMaxArrayLengthRule(3, "Maximum number of values is 2").
10
- */
11
- export const getMinArrayLengthRule = (
12
- arr: unknown[],
13
- minLength: number,
14
- message?: string,
15
- ) => {
16
- const formattedMessage = message || translate('minArrayLength', { min: minLength });
17
-
18
- return arr.length >= minLength || formattedMessage;
19
- };
@@ -1,12 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates an array, checking if it contains values.
5
- * @param arr - Array of values.
6
- * @param {string} message - Custom message.
7
- *
8
- * @example rules: { validate: (arr) => getRequiredArrayRule(arr) }
9
- */
10
- export const getRequiredArrayRule = (arr: unknown[], message?: string) => {
11
- return arr.length > 0 || (message || translate('required'));
12
- };
@@ -1,17 +0,0 @@
1
- import { getMaxArrayLengthRule } from '../get-max-array-length-rule'
2
-
3
- const MAX_LENGTH = 2;
4
-
5
- describe('Тестирование функции getMaxArrayLengthRule', () => {
6
- test('Проверка, что функция возвращает текстовое сообщение с ошибкой если длинна массива превышает максимальную.', () => {
7
- expect(getMaxArrayLengthRule([1, 2, 3], MAX_LENGTH)).toBe(`Maximum number of values - ${MAX_LENGTH}.`)
8
- })
9
-
10
- test('Проверка, что функция возвращает true, если длинна массива меньше, либо равна максимальной.', () => {
11
- expect(getMaxArrayLengthRule([1], MAX_LENGTH)).toBe(true)
12
- })
13
-
14
- test('Проверка, что функция возвращает кастомное сообщение, если кол-во заначений превышает максимальное.', () => {
15
- expect(getMaxArrayLengthRule([1, 2, 3, 4], MAX_LENGTH, 'test message')).toBe('test message')
16
- })
17
- })
@@ -1,17 +0,0 @@
1
- import { getMinArrayLengthRule } from "../get-min-array-length-rule";
2
-
3
- const MIN_LENGTH = 2;
4
-
5
- describe('Тестирование функции getMinArrayLengthRule', () => {
6
- test('Проверка, что функция возвращает текстовое сообщение с ошибкой если длинна массива меньше минимальной.', () => {
7
- expect(getMinArrayLengthRule([1], MIN_LENGTH)).toBe(`Minimum number of values - ${MIN_LENGTH}.`)
8
- })
9
-
10
- test('Проверка, что функция возвращает true, если длинна массива большe, либо равна минимальной.', () => {
11
- expect(getMinArrayLengthRule([1, 3, 4], MIN_LENGTH)).toBe(true)
12
- })
13
-
14
- test('Проверка, что функция возвращает кастомное сообщение, если кол-во заначений меньше минимальной.', () => {
15
- expect(getMinArrayLengthRule([1], MIN_LENGTH, 'test message')).toBe('test message')
16
- })
17
- })
@@ -1,16 +0,0 @@
1
- import { REQUIRED_MESSAGE_TEXT } from '../../constants'
2
- import { getRequiredArrayRule } from '../get-required-array-rule'
3
-
4
- describe('Тестирование функции getRequiredArrayRule', () => {
5
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой, когда массив не содержит значения.', () => {
6
- expect(getRequiredArrayRule([], 'test message')).toBe('test message')
7
- })
8
-
9
- test('Проверка, что функция возвращает true, когда массив не пустой.', () => {
10
- expect(getRequiredArrayRule([1, 2, 3])).toBe(true)
11
- })
12
-
13
- test('Проверка, что функция возвращает базовое сообщение, когда массив пустой.', () => {
14
- expect(getRequiredArrayRule([])).toBe(REQUIRED_MESSAGE_TEXT)
15
- })
16
- })
@@ -1 +0,0 @@
1
- export const REQUIRED_MESSAGE_TEXT = 'This field is required.';
@@ -1,15 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates the maximum length of a string.
5
- * @param maxLength - Maximum number of characters allowed.
6
- * @param message - Custom message.
7
- *
8
- * @example rules: { maxLength: getMaxLengthRule(1000) }
9
- */
10
- export const getMaxLengthRule = (maxLength: number, message?: string) => ({
11
- value: maxLength,
12
- message: message || translate('maxLength', {
13
- max: maxLength,
14
- }),
15
- })
@@ -1,13 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Returns an error if the number exceeds the specified value.
5
- * @param max - Maximum number.
6
- * @param message - Custom message.
7
- *
8
- * @example rules: { max: getMaxRule(20) }
9
- */
10
- export const getMaxRule = (max: number, message?: string) => ({
11
- value: max,
12
- message: message || translate('max', { max }),
13
- });
@@ -1,16 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Returns a rule that validates the minimum length of a string.
5
- * @param minLength - Minimum number of characters allowed.
6
- * @param message - Custom message.
7
- *
8
- * @example rules: { minLength: getMinLengthRule(20) }
9
- */
10
- export const getMinLengthRule = (minLength: number, message?: string) => {
11
-
12
- return {
13
- value: minLength,
14
- message: message || translate('minLength', { min: minLength }),
15
- };
16
- };
@@ -1,15 +0,0 @@
1
- import { translate } from "../../i18n"
2
-
3
- /**
4
- * Returns an error if the number is less than the specified value.
5
- * @param min - Minimum number.
6
- * @param message - Custom message.
7
- *
8
- * @example rules: { min: getMinRule(20) }
9
- */
10
- export const getMinRule = (min: number, message?: string) => ({
11
- value: min,
12
- message: message || translate('min', {
13
- min,
14
- }),
15
- })
@@ -1,16 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates a required field.
5
- * @param isRequired - Dynamic parameter that indicates whether the field is required.
6
- * @param message - Custom message.
7
- *
8
- * @example rules: { required: getRequiredRule() }
9
- */
10
- export const getRequiredRule = (
11
- isRequired = true,
12
- message = translate('required')
13
- ) => ({
14
- value: isRequired,
15
- message,
16
- })
@@ -1,24 +0,0 @@
1
- import { getMaxLengthRule } from "../get-max-length-rule"
2
-
3
- describe('Тестирование функции getMinLengthRule', () => {
4
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой.', () => {
5
- expect(getMaxLengthRule(1, 'test message')).toEqual({
6
- value: 1,
7
- message: 'test message',
8
- })
9
- })
10
-
11
- test('Проверка, что функция возвращает базовую ошибку.', () => {
12
- expect(getMaxLengthRule(1)).toEqual({
13
- value: 1,
14
- message: `Maximum length - ${1}.`
15
- })
16
- })
17
-
18
- test('Проверка, что функция возвращает базовую ошибку и переданное минимальное значение.', () => {
19
- expect(getMaxLengthRule(111)).toEqual({
20
- value: 111,
21
- message: `Maximum length - 111.`
22
- })
23
- })
24
- })
@@ -1,24 +0,0 @@
1
- import { getMaxRule } from "../get-max-rule"
2
-
3
- describe('Тестирование функции getMaxRule', () => {
4
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой.', () => {
5
- expect(getMaxRule(1, 'test message')).toEqual({
6
- value: 1,
7
- message: 'test message',
8
- })
9
- })
10
-
11
- test('Проверка, что функция возвращает базовую ошибку.', () => {
12
- expect(getMaxRule(1)).toEqual({
13
- value: 1,
14
- message: `Maximum value - 1.`
15
- })
16
- })
17
-
18
- test('Проверка, что функция возвращает базовую ошибку и переданное минимальное значение.', () => {
19
- expect(getMaxRule(111)).toEqual({
20
- value: 111,
21
- message: `Maximum value - 111.`
22
- })
23
- })
24
- })
@@ -1,24 +0,0 @@
1
- import { getMinLengthRule } from "../get-min-length-rule"
2
-
3
- describe('Тестирование функции getMinLengthRule', () => {
4
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой.', () => {
5
- expect(getMinLengthRule(1, 'test message')).toEqual({
6
- value: 1,
7
- message: 'test message',
8
- })
9
- })
10
-
11
- test('Проверка, что функция возвращает базовую ошибку.', () => {
12
- expect(getMinLengthRule(1)).toEqual({
13
- value: 1,
14
- message: `Minimum length - ${1}.`
15
- })
16
- })
17
-
18
- test('Проверка, что функция возвращает базовую ошибку и переданное минимальное значение.', () => {
19
- expect(getMinLengthRule(111)).toEqual({
20
- value: 111,
21
- message: `Minimum length - 111.`
22
- })
23
- })
24
- })
@@ -1,24 +0,0 @@
1
- import { getMinRule } from "../get-min-rule";
2
-
3
- describe('Тестирование функции getMinRule', () => {
4
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой.', () => {
5
- expect(getMinRule(1, 'test message')).toEqual({
6
- value: 1,
7
- message: 'test message',
8
- })
9
- })
10
-
11
- test('Проверка, что функция возвращает базовую ошибку.', () => {
12
- expect(getMinRule(1)).toEqual({
13
- value: 1,
14
- message: `Minimum value - 1.`
15
- })
16
- })
17
-
18
- test('Проверка, что функция возвращает базовую ошибку и переданное минимальное значение.', () => {
19
- expect(getMinRule(111)).toEqual({
20
- value: 111,
21
- message: `Minimum value - 111.`
22
- })
23
- })
24
- })
@@ -1,10 +0,0 @@
1
- import { getRequiredRule } from '../get-require-rule'
2
-
3
- describe('Тестирование функции getRequiredRule', () => {
4
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой.', () => {
5
- expect(getRequiredRule(true, 'test message')).toEqual({
6
- value: true,
7
- message: 'test message',
8
- })
9
- })
10
- })
@@ -1,20 +0,0 @@
1
- import { translate } from "../../i18n";
2
-
3
- /**
4
- * Validates an object, checking if it contains values.
5
- * @param {Object} obj - Object with values.
6
- * @param {string} message - Custom message.
7
- *
8
- * @example rules: { validate: (obj) => getRequiredObjectRule(obj) }
9
- */
10
- export const getRequiredObjectRule = (obj: Record<string, unknown>, message?: string) => {
11
- const formattedMessage = message || translate("required");
12
-
13
- if (!obj) {
14
- return false || formattedMessage;
15
- }
16
-
17
- const isEmpty = Object?.keys(obj)?.length > 0;
18
-
19
- return isEmpty || formattedMessage;
20
- };
@@ -1,18 +0,0 @@
1
- import { REQUIRED_MESSAGE_TEXT } from '../../constants'
2
- import { getRequiredObjectRule } from '../get-required-object-rule'
3
-
4
- describe('Тестирование функции getRequireObjectRule', () => {
5
- test('Проверка, что функция возвращает кастомное сообщение с ошибкой, когда объект не содержит значения.', () => {
6
- expect(getRequiredObjectRule({}, 'test message')).toBe('test message')
7
- })
8
-
9
- test('Проверка, что функция возвращает true, когда объект не пустой.', () => {
10
- expect(getRequiredObjectRule({ test: '123' })).toBe(true)
11
- })
12
-
13
- test('Проверка, что функция возвращает базовое сообщение, когда объект пустой.', () => {
14
- expect(getRequiredObjectRule({})).toBe(REQUIRED_MESSAGE_TEXT)
15
- })
16
- })
17
-
18
-
@@ -1,22 +0,0 @@
1
- import { getPatternRule } from "./get-pattern-rule";
2
- import { translate } from "../../i18n";
3
-
4
- const DEFAULT_PATTERN = /^[\w-\.]+@([\w-]+\.)+[\w-]{2,4}$/;
5
-
6
- interface EmailRule {
7
- pattern?: RegExp;
8
- message?: string;
9
- }
10
-
11
- /**
12
- * Validates an email address.
13
- * @param options - Parameters.
14
- * @param {string} options.pattern - Regular expression.
15
- * @param {string} options.message - Custom message.
16
- *
17
- * @example rules: { pattern: getEmailRule({}) }
18
- */
19
- export const getEmailRule = ({
20
- pattern = DEFAULT_PATTERN,
21
- message = translate('email'),
22
- }: EmailRule) => getPatternRule(pattern, message)
@@ -1,12 +0,0 @@
1
- /**
2
- * Returns a rule that validates the pattern.
3
- * @param options - Parameters.
4
- * @param options.pattern - Regular expression.
5
- * @param options.message - Custom message.
6
- *
7
- * @example rules: { pattern: getPatternRule(pattern) }
8
- */
9
- export const getPatternRule = (pattern: RegExp, message: string) => ({
10
- value: pattern,
11
- message,
12
- })