169 похожих чатов

Import {useState} from "react"; import {Validator} from "./validators"; export type UseStateWithValidationOptions<T> =

{
defaultValue?: T,
validators?: Validator<T>[],
errorMessages?: any[],
errorTypes?: any[]
}

/**
* Хук для установки значений объекта и его валидации,
* возвращает объект содержащий :
* value - значение,
* setValue - колбэк для установки значения,
* errorType - код первой ошибки,
* errorMessage - сообщение первой ошибки,
* isError - флаг есть ли ошибка
*
* @param defaultValue - дефолтное значение объекта
* @param validators - массив валидаторов, функций принимающих в качестве параметра объект
* @param errorMessages - массив сообщений об ошибке
* @param errorTypes - массив кодов ошибки
*
* @return Объект содержащий :
* value - значение,
* setValue - колбэк для установки значения,
* errorType - код первой ошибки,
* errorMessage - сообщение первой ошибки,
* isError - флаг есть ли ошибка

export function useStateObjectWithValidation<T>(
options: UseStateWithValidationOptions<T>
);
*/
export function useStateObjectWithValidation<T>(
defaultValue: T = null,
validators: Validator<T>[] = null,
errorMessages: any[] = null,
errorTypes: any[] = null
) {
const [value, setValue] = useState(defaultValue);

let errorType = null;
let errorMessage = null;
let isError = false;

for (let i = 0; i < validators?.length ?? 0; i++) {
const validator = validators[i];
if (!validator(value)) {
errorType = errorTypes?.[i] ?? null;
errorMessage = errorMessages?.[i] ?? null;
isError = true;
// всегда возвращаем первую ошибку валидации
break;
}
}
return {value, setValue, errorType, errorMessage, isError};
}

/**
* Хук для установки значений объекта и его валидации,
* API сделан по аналогии с useState, но дополнительно возвращает третий элемент кортежа - ошибку валидации
*
* @param defaultValue - дефолтное значение объекта
* @param validators - массив валидаторов, функций принимающих в качестве параметра объект
* @param errorMessages - массив сообщений об ошибке
* @param errorTypes - массив кодов ошибки
*
* @return Кортеж из трех элементов содержащий :
* первый элемент - значение,
* второй элемент - колбэк для установки значения,
* третий элемент - объект содержащий: { isError - флаг наличия ошибки, errorType - код первой ошибки,
* errorMessage - сообщение первой ошибки }
*/
export function useStateWithValidation<T>(
defaultValue: T = null,
validators: Validator<any>[] = null,
errorMessages = null,
errorTypes = null
) {
const o = useStateObjectWithValidation(validators, errorMessages, errorTypes);
return [
o.value,
o.setValue,
{
isError: o.isError,
errorType: o.errorType,
errorMessage: o.errorMessage
}];
}

/**
* Хук для установки значений объекта и его валидации,
* API сделан по аналогии с useState, но дополнительно возвращает третий элемент кортежа - ошибку валидации
*
* @param options - опции типа UseStateWithValidationOptions
*
* @return Кортеж из трех элементов содержащий :
* первый элемент - значение,
* второй элемент - колбэк для установки значения,
* третий элемент - объект содержащий: { isError - флаг наличия ошибки, errorType - код первой ошибки,
* errorMessage - сообщение первой ошибки }
*/
export function useStateWithValidationOptional<T>(options: UseStateWithValidationOptions<T>) {
return useStateWithValidation(
options.defaultValue,
options.validators,
options.errorMessages,
options.errorTypes
);
}

1 ответов

9 просмотров

А теперь все поля заблокируй (:

Похожие вопросы

Обсуждают сегодня

function LoadMemoryFromInet2( f:TMemoryStream; const url:string; var e:string ):Boolean; var http:TIdHttp; LHandler: TIdSSLIOHandlerSocketOpenSSL;begin Result := fals...
Александр Смоляков
1
Мужики и девушки, привет) в Вelphi xe7 в настройках во вкладке "Editor Options" далее " Color" есть список: "Elements", открыв который мы можем настраивать отображение разных...
Kraszx
14
Добрый вечер. Есть вопрос, а может и предложение. Был у меня диалог в другой группе о делфи и я задался вопросом: "А нельзя ли в делфи цвет //коментария и {комментария} сде...
Kraszx
24
Я вот подумал. SSE выполняет операции максимум с 64-битной точностью. А FPU - всегда с 80-битной. Разве не должно быть FPU точнее тогда?
The Bird of Hermes
13
Мдя, прикол, боевая сборка запускается (именно под отладчиком) после F9 примерно полторы минуты (97 секунд если быть точным). Начал копать - проблема детектится сразу - зависа...
Александр (Rouse_) Багель
38
Здравствуйте, вопрос по структурам данных. Были у вас случаи, когда пришлось писать деревья или двунаправленные списки?
/ /
50
как быть с принтером? такой подход прокатит?
zamtmn
12
Всем привет! Подскажи, пожалуйста, как передать в TComboBox сразу значение и id записи. На Delphi я делал так: ComboBox1.Items.AddObject('Какое-то значение', Pointer(id запис...
Евгений
13
This is a big issue. Just by being a citizen of a country, you are denied to contribute to Open Source software: https://youtu.be/L5Ec5jrpLVk?si=1iIuHnMPbCB4anV-
Sharuzzaman Ahmat Raslan
72
Товарищи, кто работа с iphelper? Или может я в самой логике ошибки фигачу, не пойму.... var ifTable : PMIB_IFTABLE; size, corSize: DWORD; Buffer ...
Warfarellen
4
Карта сайта