mirror of
https://github.com/pezkuwichain/pezkuwi-sdk-ui.git
synced 2026-06-18 04:51:06 +00:00
Initial commit: Pezkuwi SDK UI
Comprehensive web interface for interacting with Pezkuwi blockchain. Features: - Blockchain explorer - Wallet management - Staking interface - Governance participation - Developer tools Co-Authored-By: Claude Opus 4.5 <noreply@anthropic.com>
This commit is contained in:
@@ -0,0 +1,31 @@
|
||||
// Copyright 2017-2026 @pezkuwi/react-hooks authors & contributors
|
||||
// SPDX-License-Identifier: Apache-2.0
|
||||
|
||||
import { useCallback, useMemo, useState } from 'react';
|
||||
|
||||
import { isUndefined } from '@pezkuwi/util';
|
||||
|
||||
export type FormField<T> = [
|
||||
T | null,
|
||||
boolean,
|
||||
(_?: T | null) => void
|
||||
];
|
||||
|
||||
type ValidateFn<T> = (_: T) => boolean;
|
||||
|
||||
const defaultValidate = (): boolean => true;
|
||||
|
||||
// FIXME Since we use generics, this cannot be a createNamedHook as of yet
|
||||
export function useFormField<T> (defaultValue: T | null, validate: ValidateFn<T> = defaultValidate): FormField<T> {
|
||||
const [value, setValue] = useState<T | null>(defaultValue);
|
||||
const isValid = useMemo(
|
||||
() => !!value && validate(value),
|
||||
[validate, value]
|
||||
);
|
||||
const setter = useCallback(
|
||||
(value?: T | null) => !isUndefined(value) && setValue(value),
|
||||
[]
|
||||
);
|
||||
|
||||
return [value, isValid, setter];
|
||||
}
|
||||
Reference in New Issue
Block a user