Skip to main content

ArrayControlState

Defined in: hooks/types.ts:255

БостояниС массива Ρ„ΠΎΡ€ΠΌΡ‹, Π²ΠΎΠ·Π²Ρ€Π°Ρ‰Π°Π΅ΠΌΠΎΠ΅ Ρ…ΡƒΠΊΠΎΠΌ useFormControl для ArrayNode.

Π‘ΠΎΠ΄Π΅Ρ€ΠΆΠΈΡ‚ Ρ€Π΅Π°ΠΊΡ‚ΠΈΠ²Π½Ρ‹Π΅ Π΄Π°Π½Π½Ρ‹Π΅ массива: значСния элСмСнтов, Π΄Π»ΠΈΠ½Ρƒ, состояниС Π²Π°Π»ΠΈΠ΄Π°Ρ†ΠΈΠΈ ΠΈ Ρ„Π»Π°Π³ΠΈ взаимодСйствия.

Example​

interface Phone {
type: string;
number: string;
}

interface Props {
control: ArrayNode<Phone>;
}

function PhoneList({ control }: Props) {
const { length, valid } = useFormControl(control);

return (
<div>
{control.map((item, index) => (
<PhoneItem
key={item.id}
control={item}
onRemove={() => control.remove(index)}
/>
))}

{length === 0 && <p>No phones added</p>}

<button onClick={() => control.push({ type: 'mobile', number: '' })}>
Add Phone
</button>

{!valid && <p className="error">Please fix phone errors</p>}
</div>
);
}

See​

  • useFormControl - Ρ…ΡƒΠΊ для получСния состояния
  • FieldControlState - состояниС для ΠΏΠΎΠ»Π΅ΠΉ

Type Parameters​

T​

T

Π’ΠΈΠΏ элСмСнта массива (ΠΎΠ±Ρ‹Ρ‡Π½ΠΎ ΠΎΠ±ΡŠΠ΅ΠΊΡ‚ с полями Ρ„ΠΎΡ€ΠΌΡ‹)

Properties​

dirty​

dirty: boolean;

Defined in: hooks/types.ts:345

Π€Π»Π°Π³ измСнСния. true ΠΊΠΎΠ³Π΄Π° Π·Π½Π°Ρ‡Π΅Π½ΠΈΠ΅ массива отличаСтся ΠΎΡ‚ Π½Π°Ρ‡Π°Π»ΡŒΠ½ΠΎΠ³ΠΎ.

Example​

const { dirty } = useFormControl(itemsArray);

return (
<div>
{dirty && <span>* Unsaved changes</span>}
<button disabled={!dirty}>Save</button>
</div>
);

errors​

errors: ValidationError[];

Defined in: hooks/types.ts:309

Массив ошибок Π²Π°Π»ΠΈΠ΄Π°Ρ†ΠΈΠΈ уровня массива. НС Π²ΠΊΠ»ΡŽΡ‡Π°Π΅Ρ‚ ошибки ΠΎΡ‚Π΄Π΅Π»ΡŒΠ½Ρ‹Ρ… элСмСнтов.

Example​

// Π’Π°Π»ΠΈΠ΄Π°Ρ‚ΠΎΡ€ массива
validators.apply(phonesArray, {
validator: (phones) => phones.length >= 1,
message: 'At least one phone required'
});

// Π’ ΠΊΠΎΠΌΠΏΠΎΠ½Π΅Π½Ρ‚Π΅
const { errors } = useFormControl(phonesArray);
// errors содСрТит ΠΎΡˆΠΈΠ±ΠΊΡƒ "At least one phone required" Ссли массив пуст

invalid​

invalid: boolean;

Defined in: hooks/types.ts:321

Π€Π»Π°Π³ нСвалидности. true ΠΊΠΎΠ³Π΄Π° Π΅ΡΡ‚ΡŒ ошибки Π² массивС ΠΈΠ»ΠΈ любом элСмСнтС.


length​

length: number;

Defined in: hooks/types.ts:284

ΠšΠΎΠ»ΠΈΡ‡Π΅ΡΡ‚Π²ΠΎ элСмСнтов Π² массивС. Π­ΠΊΠ²ΠΈΠ²Π°Π»Π΅Π½Ρ‚Π½ΠΎ value.length, Π½ΠΎ ΠΎΠΏΡ‚ΠΈΠΌΠΈΠ·ΠΈΡ€ΠΎΠ²Π°Π½ΠΎ для рСактивности.

Example​

const { length } = useFormControl(itemsArray);

return (
<div>
<span>Items: {length}</span>
{length >= 10 && <span>Maximum reached</span>}
</div>
);

pending​

pending: boolean;

Defined in: hooks/types.ts:290

Π€Π»Π°Π³ асинхронной Π²Π°Π»ΠΈΠ΄Π°Ρ†ΠΈΠΈ. true ΠΊΠΎΠ³Π΄Π° выполняСтся асинхронный Π²Π°Π»ΠΈΠ΄Π°Ρ‚ΠΎΡ€ массива ΠΈΠ»ΠΈ любого элСмСнта.


touched​

touched: boolean;

Defined in: hooks/types.ts:327

Π€Π»Π°Π³ взаимодСйствия. true послС взаимодСйствия с Π»ΡŽΠ±Ρ‹ΠΌ элСмСнтом массива.


valid​

valid: boolean;

Defined in: hooks/types.ts:315

Π€Π»Π°Π³ валидности массива ΠΈ всСх Π΅Π³ΠΎ элСмСнтов. true Ρ‚ΠΎΠ»ΡŒΠΊΠΎ ΠΊΠΎΠ³Π΄Π° массив ΠΈ всС Π²Π»ΠΎΠΆΠ΅Π½Π½Ρ‹Π΅ элСмСнты Π²Π°Π»ΠΈΠ΄Π½Ρ‹.


value​

value: T[];

Defined in: hooks/types.ts:266

Массив Ρ‚Π΅ΠΊΡƒΡ‰ΠΈΡ… Π·Π½Π°Ρ‡Π΅Π½ΠΈΠΉ всСх элСмСнтов.

Example​

const { value } = useFormControl(phonesArray);
console.log(value);
// [{ type: 'mobile', number: '+1234567890' }, { type: 'home', number: '+0987654321' }]