@digigov/form 2.0.0-85c27c19 → 2.0.0-aefd0709
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.
- package/Field/FieldBase/index.js +1 -0
- package/Field/FieldBase.js.map +2 -2
- package/Field/FieldBaseContainer/index.js +2 -2
- package/Field/FieldBaseContainer.js.map +2 -2
- package/Field/FieldConditional/index.js +7 -3
- package/Field/FieldConditional.js.map +2 -2
- package/Field/index.js +5 -2
- package/Field/index.js.map +2 -2
- package/Field/types.d.ts +10 -8
- package/Field/utils/index.d.ts +1 -0
- package/Field/utils/index.js +18 -1
- package/Field/utils/index.js.map +2 -2
- package/FieldArray/index.d.ts +1 -0
- package/FieldArray/index.js +7 -6
- package/FieldArray/index.js.map +2 -2
- package/FieldObject/index.d.ts +2 -0
- package/FieldObject/index.js +9 -5
- package/FieldObject/index.js.map +2 -2
- package/Fieldset/index.d.ts +1 -1
- package/Fieldset/index.js +5 -5
- package/Fieldset/index.js.map +2 -2
- package/Fieldset/types.d.ts +2 -3
- package/FormBuilder/index.d.ts +8 -2
- package/FormBuilder/index.js +150 -6
- package/FormBuilder/index.js.map +3 -3
- package/FormContext.js.map +2 -2
- package/MultiplicityField/add-objects/index.js +11 -7
- package/MultiplicityField/add-objects.js.map +2 -2
- package/MultiplicityField/index.js +16 -12
- package/MultiplicityField/index.js.map +2 -2
- package/MultiplicityField/types.d.ts +1 -2
- package/Questions/Questions/index.js +5 -4
- package/Questions/Questions.js.map +2 -2
- package/Questions/QuestionsContext.d.ts +0 -1
- package/Questions/Step/StepArrayReview.js.map +2 -2
- package/Questions/Step/StepContext.d.ts +0 -1
- package/Questions/Step/StepTitle/index.js +4 -3
- package/Questions/Step/StepTitle.d.ts +1 -1
- package/Questions/Step/StepTitle.js.map +2 -2
- package/Questions/Step/types.d.ts +0 -1
- package/Questions/types.d.ts +0 -1
- package/cjs/Field/FieldBase/index.js +1 -0
- package/cjs/Field/FieldBase.js.map +2 -2
- package/cjs/Field/FieldBaseContainer/index.js +4 -4
- package/cjs/Field/FieldBaseContainer.js.map +3 -3
- package/cjs/Field/FieldConditional/index.js +7 -3
- package/cjs/Field/FieldConditional.js.map +2 -2
- package/cjs/Field/index.js +5 -2
- package/cjs/Field/index.js.map +2 -2
- package/cjs/Field/types.js.map +1 -1
- package/cjs/Field/utils/index.js +18 -0
- package/cjs/Field/utils/index.js.map +2 -2
- package/cjs/FieldArray/index.js +8 -7
- package/cjs/FieldArray/index.js.map +3 -3
- package/cjs/FieldObject/index.js +10 -6
- package/cjs/FieldObject/index.js.map +3 -3
- package/cjs/Fieldset/index.js +10 -10
- package/cjs/Fieldset/index.js.map +3 -3
- package/cjs/Fieldset/types.js.map +1 -1
- package/cjs/FormBuilder/index.js +165 -5
- package/cjs/FormBuilder/index.js.map +3 -3
- package/cjs/FormContext/index.js +2 -2
- package/cjs/FormContext.js.map +3 -3
- package/cjs/MultiplicityField/add-objects/index.js +15 -11
- package/cjs/MultiplicityField/add-objects.js.map +3 -3
- package/cjs/MultiplicityField/index.js +15 -16
- package/cjs/MultiplicityField/index.js.map +3 -3
- package/cjs/MultiplicityField/types.js.map +1 -1
- package/cjs/Questions/Questions/index.js +5 -4
- package/cjs/Questions/Questions.js.map +2 -2
- package/cjs/Questions/Step/StepArrayReview.js.map +2 -2
- package/cjs/Questions/Step/StepTitle/index.js +5 -5
- package/cjs/Questions/Step/StepTitle.js.map +3 -3
- package/cjs/index.js +11 -155
- package/cjs/index.js.map +4 -4
- package/cjs/inputs/AutoCompleteInput/__stories__/Default/index.js +1 -7
- package/cjs/inputs/AutoCompleteInput/__stories__/Default.js.map +2 -2
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +1 -8
- package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
- package/cjs/inputs/AutoCompleteInput/index.js +10 -8
- package/cjs/inputs/AutoCompleteInput/index.js.map +3 -3
- package/cjs/inputs/Checkboxes/index.js +7 -9
- package/cjs/inputs/Checkboxes/index.js.map +3 -3
- package/cjs/inputs/DateInput/__stories__/Default/index.js +3 -8
- package/cjs/inputs/DateInput/__stories__/Default.js.map +2 -2
- package/cjs/inputs/DateInput/index.js +4 -5
- package/cjs/inputs/DateInput/index.js.map +3 -3
- package/cjs/inputs/FileInput/index.js +8 -9
- package/cjs/inputs/FileInput/index.js.map +3 -3
- package/cjs/inputs/ImageInput/ImageInput.stories/index.js +4 -4
- package/cjs/inputs/ImageInput/ImageInput.stories.js.map +2 -2
- package/cjs/inputs/ImageInput/__stories__/MaxSize/index.js +69 -0
- package/cjs/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +2 -1
- package/cjs/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +2 -2
- package/cjs/inputs/ImageInput/index.js +9 -9
- package/cjs/inputs/ImageInput/index.js.map +3 -3
- package/cjs/inputs/Input/__stories__/LandlineNumber/index.js +1 -0
- package/cjs/inputs/Input/__stories__/LandlineNumber.js.map +2 -2
- package/cjs/inputs/Input/__stories__/MobilePhone/index.js +1 -0
- package/cjs/inputs/Input/__stories__/MobilePhone.js.map +2 -2
- package/cjs/inputs/Input/__stories__/PhoneNumber/index.js +1 -0
- package/cjs/inputs/Input/__stories__/PhoneNumber.js.map +2 -2
- package/cjs/inputs/Input/__stories__/PostalCode/index.js +1 -0
- package/cjs/inputs/Input/__stories__/PostalCode.js.map +2 -2
- package/cjs/inputs/Input/index.js +19 -6
- package/cjs/inputs/Input/index.js.map +3 -3
- package/cjs/inputs/Input/inputsInputScenarios.js.map +2 -2
- package/cjs/inputs/Label/index.js +3 -3
- package/cjs/inputs/Label/index.js.map +3 -3
- package/cjs/inputs/OtpInput/index.js.map +2 -2
- package/cjs/inputs/Radio/__stories__/Conditional.js.map +2 -2
- package/cjs/inputs/Radio/index.js +56 -10
- package/cjs/inputs/Radio/index.js.map +3 -3
- package/cjs/inputs/Select/index.js +3 -4
- package/cjs/inputs/Select/index.js.map +3 -3
- package/cjs/inputs/inputsScenarios/index.js +4 -11
- package/cjs/inputs/inputsScenarios.js.map +2 -2
- package/cjs/lazy/index.js +320 -59
- package/cjs/lazy.js.map +2 -2
- package/cjs/locales/el.js.map +1 -1
- package/cjs/registry/index.js +118 -38
- package/cjs/registry.js.map +2 -2
- package/cjs/types.js.map +1 -1
- package/cjs/utils/index.js +2 -1
- package/cjs/utils.js.map +2 -2
- package/cjs/validators/index.js +16 -66
- package/cjs/validators/index.js.map +3 -3
- package/cjs/validators/utils/date/index.js +138 -0
- package/cjs/validators/utils/date.js.map +7 -0
- package/cjs/validators/utils/file/index.js +1 -1
- package/cjs/validators/utils/file.js.map +2 -2
- package/cjs/validators/utils/index.js +3 -1
- package/cjs/validators/utils/index.js.map +2 -2
- package/cjs/validators/utils/phone.js.map +2 -2
- package/cjs/validators/utils/postal_code.js.map +1 -1
- package/cjs/validators/utils/uuid4.js.map +2 -2
- package/index.d.ts +5 -8
- package/index.js +9 -152
- package/index.js.map +4 -4
- package/inputs/AutoCompleteInput/__stories__/Default/index.js +1 -7
- package/inputs/AutoCompleteInput/__stories__/Default.js.map +2 -2
- package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +1 -8
- package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
- package/inputs/AutoCompleteInput/index.d.ts +1 -1
- package/inputs/AutoCompleteInput/index.js +12 -8
- package/inputs/AutoCompleteInput/index.js.map +2 -2
- package/inputs/Checkboxes/index.d.ts +1 -1
- package/inputs/Checkboxes/index.js +8 -6
- package/inputs/Checkboxes/index.js.map +2 -2
- package/inputs/DateInput/__stories__/Default/index.js +3 -8
- package/inputs/DateInput/__stories__/Default.js.map +2 -2
- package/inputs/DateInput/index.d.ts +1 -2
- package/inputs/DateInput/index.js +6 -4
- package/inputs/DateInput/index.js.map +2 -2
- package/inputs/FileInput/index.js +6 -7
- package/inputs/FileInput/index.js.map +2 -2
- package/inputs/ImageInput/ImageInput.stories/index.js +2 -2
- package/inputs/ImageInput/ImageInput.stories.d.ts +1 -1
- package/inputs/ImageInput/ImageInput.stories.js.map +2 -2
- package/inputs/ImageInput/__stories__/MaxSize/index.js +36 -0
- package/inputs/ImageInput/__stories__/MaxSize/package.json +6 -0
- package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
- package/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension/index.js +2 -1
- package/inputs/ImageInput/__stories__/WithInvalidImageDimension.js.map +2 -2
- package/inputs/ImageInput/index.js +8 -8
- package/inputs/ImageInput/index.js.map +2 -2
- package/inputs/Input/__stories__/LandlineNumber/index.js +1 -0
- package/inputs/Input/__stories__/LandlineNumber.js.map +2 -2
- package/inputs/Input/__stories__/MobilePhone/index.js +1 -0
- package/inputs/Input/__stories__/MobilePhone.js.map +2 -2
- package/inputs/Input/__stories__/PhoneNumber/index.js +1 -0
- package/inputs/Input/__stories__/PhoneNumber.js.map +2 -2
- package/inputs/Input/__stories__/PostalCode/index.js +1 -0
- package/inputs/Input/__stories__/PostalCode.js.map +2 -2
- package/inputs/Input/index.js +17 -4
- package/inputs/Input/index.js.map +3 -3
- package/inputs/Input/inputsInputScenarios.js.map +2 -2
- package/inputs/Label/index.d.ts +0 -2
- package/inputs/Label/index.js +2 -2
- package/inputs/Label/index.js.map +2 -2
- package/inputs/OtpInput/index.js.map +2 -2
- package/inputs/Radio/__stories__/Conditional.js.map +2 -2
- package/inputs/Radio/index.d.ts +5 -1
- package/inputs/Radio/index.js +57 -8
- package/inputs/Radio/index.js.map +2 -2
- package/inputs/Select/index.d.ts +1 -1
- package/inputs/Select/index.js +4 -2
- package/inputs/Select/index.js.map +2 -2
- package/inputs/inputsScenarios/index.js +4 -11
- package/inputs/inputsScenarios.d.ts +0 -42
- package/inputs/inputsScenarios.js.map +2 -2
- package/lazy/index.js +320 -59
- package/lazy.d.ts +17 -10
- package/lazy.js.map +2 -2
- package/locales/el.js.map +1 -1
- package/package.json +4 -4
- package/registry/index.js +118 -38
- package/registry.d.ts +1 -0
- package/registry.js.map +2 -2
- package/src/Field/FieldBase.tsx +1 -0
- package/src/Field/FieldBaseContainer.tsx +2 -2
- package/src/Field/FieldConditional.tsx +4 -0
- package/src/Field/index.tsx +4 -1
- package/src/Field/types.tsx +10 -8
- package/src/Field/utils/index.ts +18 -1
- package/src/FieldArray/index.test.tsx +14 -13
- package/src/FieldArray/index.tsx +9 -6
- package/src/FieldObject/index.tsx +8 -2
- package/src/Fieldset/index.tsx +5 -5
- package/src/Fieldset/types.tsx +2 -2
- package/src/FormBuilder/{FormBuilder.mdx → doc.mdx} +20 -33
- package/src/FormBuilder/index.test.tsx +11 -10
- package/src/FormBuilder/index.tsx +178 -7
- package/src/FormBuilder/scenarios.test.tsx +2 -2
- package/src/FormContext.tsx +1 -2
- package/src/MultiplicityField/add-objects.tsx +10 -8
- package/src/MultiplicityField/{MultiplicityField.mdx → doc.mdx} +12 -16
- package/src/MultiplicityField/index.test.tsx +26 -25
- package/src/MultiplicityField/index.tsx +15 -12
- package/src/MultiplicityField/types.ts +1 -2
- package/src/Questions/Questions.tsx +4 -4
- package/src/Questions/Step/StepArrayReview.tsx +1 -1
- package/src/Questions/Step/StepTitle.tsx +4 -3
- package/src/Questions/__snapshots__/index.spec.tsx.snap +8 -4
- package/src/Questions/{index.mdx → doc.mdx} +9 -12
- package/src/Questions/index.spec.tsx +6 -2
- package/src/Questions/index.test.tsx +11 -10
- package/src/create-simple-form.mdx +2 -6
- package/src/{index.mdx → doc.mdx} +4 -8
- package/src/index.ts +6 -0
- package/src/inputs/AutoCompleteInput/__stories__/Default.tsx +2 -10
- package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +1 -8
- package/src/inputs/AutoCompleteInput/{index.mdx → doc.mdx} +2 -13
- package/src/inputs/AutoCompleteInput/index.test.tsx +14 -13
- package/src/inputs/AutoCompleteInput/index.tsx +36 -31
- package/src/inputs/Checkboxes/{index.mdx → doc.mdx} +5 -15
- package/src/inputs/Checkboxes/index.test.tsx +17 -16
- package/src/inputs/Checkboxes/index.tsx +10 -8
- package/src/inputs/DateInput/__stories__/Default.tsx +7 -12
- package/src/inputs/DateInput/{index.mdx → doc.mdx} +1 -8
- package/src/inputs/DateInput/index.test.tsx +11 -10
- package/src/inputs/DateInput/index.tsx +6 -4
- package/src/inputs/FileInput/{index.mdx → doc.mdx} +1 -5
- package/src/inputs/FileInput/index.test.tsx +11 -10
- package/src/inputs/FileInput/index.tsx +7 -8
- package/src/inputs/ImageInput/ImageInput.stories.js +1 -1
- package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
- package/src/inputs/ImageInput/__stories__/WithInvalidImageDimension.tsx +2 -0
- package/src/inputs/ImageInput/doc.mdx +23 -0
- package/src/inputs/ImageInput/index.test.tsx +21 -16
- package/src/inputs/ImageInput/index.tsx +10 -15
- package/src/inputs/Input/__stories__/LandlineNumber.tsx +2 -1
- package/src/inputs/Input/__stories__/MobilePhone.tsx +1 -0
- package/src/inputs/Input/__stories__/PhoneNumber.tsx +1 -0
- package/src/inputs/Input/__stories__/PostalCode.tsx +1 -0
- package/src/inputs/Input/doc.mdx +56 -0
- package/src/inputs/Input/index.test.tsx +38 -37
- package/src/inputs/Input/index.tsx +32 -29
- package/src/inputs/Input/inputsInputScenarios.ts +244 -245
- package/src/inputs/Label/doc.mdx +14 -0
- package/src/inputs/Label/index.test.tsx +11 -10
- package/src/inputs/Label/index.tsx +2 -6
- package/src/inputs/OtpInput/{index.mdx → doc.mdx} +1 -8
- package/src/inputs/OtpInput/index.test.tsx +11 -10
- package/src/inputs/OtpInput/index.tsx +2 -1
- package/src/inputs/Radio/__stories__/Conditional.tsx +2 -1
- package/src/inputs/Radio/{index.mdx → doc.mdx} +5 -15
- package/src/inputs/Radio/index.test.tsx +17 -16
- package/src/inputs/Radio/index.tsx +76 -10
- package/src/inputs/Select/{index.mdx → doc.mdx} +1 -5
- package/src/inputs/Select/index.test.tsx +11 -10
- package/src/inputs/Select/index.tsx +5 -3
- package/src/inputs/inputsScenarios.ts +174 -181
- package/src/installation.mdx +2 -5
- package/src/lazy.js +322 -62
- package/src/locales/el.ts +1 -1
- package/src/registry.js +121 -45
- package/src/types.tsx +3 -2
- package/src/utils.ts +2 -2
- package/src/validators/index.ts +33 -71
- package/src/validators/utils/date.ts +107 -0
- package/src/validators/utils/file.ts +5 -3
- package/src/validators/utils/index.ts +1 -0
- package/src/validators/utils/phone.ts +1 -1
- package/src/validators/utils/postal_code.ts +1 -1
- package/src/validators/utils/uuid4.ts +2 -1
- package/src/validators/validators.spec.ts +3 -3
- package/types.d.ts +3 -3
- package/types.js.map +1 -1
- package/utils/index.js +2 -1
- package/utils.js.map +2 -2
- package/validators/index.js +20 -67
- package/validators/index.js.map +2 -2
- package/validators/utils/date/index.js +103 -0
- package/validators/utils/date/package.json +6 -0
- package/validators/utils/date.d.ts +9 -0
- package/validators/utils/date.js.map +7 -0
- package/validators/utils/file/index.js +1 -1
- package/validators/utils/file.js.map +2 -2
- package/validators/utils/index.d.ts +1 -0
- package/validators/utils/index.js +1 -0
- package/validators/utils/index.js.map +2 -2
- package/validators/utils/phone.d.ts +1 -1
- package/validators/utils/phone.js.map +2 -2
- package/validators/utils/postal_code.d.ts +1 -1
- package/validators/utils/postal_code.js.map +1 -1
- package/validators/utils/uuid4.js.map +2 -2
- package/src/index.tsx +0 -178
- package/src/inputs/ImageInput/index.mdx +0 -19
- package/src/inputs/Input/index.mdx +0 -95
- package/src/inputs/Label/index.mdx +0 -0
- /package/src/Field/{index.mdx → doc.mdx} +0 -0
|
@@ -12,12 +12,13 @@ export const LandlineNumber = () => (
|
|
|
12
12
|
key="phone-number"
|
|
13
13
|
name="phone-number"
|
|
14
14
|
type="phone_number"
|
|
15
|
+
autoComplete="tel"
|
|
15
16
|
label={{
|
|
16
17
|
primary: 'Σταθερό τηλέφωνο',
|
|
17
18
|
}}
|
|
18
19
|
extra={{
|
|
19
20
|
countries: ['gr'],
|
|
20
|
-
phoneType:'landline',
|
|
21
|
+
phoneType: 'landline',
|
|
21
22
|
}}
|
|
22
23
|
required
|
|
23
24
|
/>
|
|
@@ -0,0 +1,56 @@
|
|
|
1
|
+
---
|
|
2
|
+
title: Input
|
|
3
|
+
---
|
|
4
|
+
|
|
5
|
+
# Input
|
|
6
|
+
|
|
7
|
+
The input element of type `string` is used to create interactive controls for web-based forms in order to accept data from the user;
|
|
8
|
+
a wide variety of types of input data and control widgets are available, depending on the device and user agent. The input element is one of the most powerful and complex in all of HTML due to the sheer number of combinations of input types and attributes.
|
|
9
|
+
|
|
10
|
+
## How to use
|
|
11
|
+
|
|
12
|
+
### String
|
|
13
|
+
|
|
14
|
+
<code src="@digigov/form/inputs/Input/__stories__/String.tsx" />
|
|
15
|
+
|
|
16
|
+
### Boolean
|
|
17
|
+
|
|
18
|
+
<code src="@digigov/form/inputs/Input/__stories__/Boolean.tsx" />
|
|
19
|
+
|
|
20
|
+
### AFM
|
|
21
|
+
|
|
22
|
+
<code src="@digigov/form/inputs/Input/__stories__/AFM.tsx" />
|
|
23
|
+
|
|
24
|
+
|
|
25
|
+
### IBAN
|
|
26
|
+
|
|
27
|
+
<code src="@digigov/form/inputs/Input/__stories__/IBAN.tsx" />
|
|
28
|
+
|
|
29
|
+
|
|
30
|
+
### Integer
|
|
31
|
+
|
|
32
|
+
<code src="@digigov/form/inputs/Input/__stories__/Integer.tsx" />
|
|
33
|
+
|
|
34
|
+
|
|
35
|
+
### Landline number
|
|
36
|
+
|
|
37
|
+
<code src="@digigov/form/inputs/Input/__stories__/LandlineNumber.tsx" />
|
|
38
|
+
|
|
39
|
+
|
|
40
|
+
### Mobile phone
|
|
41
|
+
|
|
42
|
+
<code src="@digigov/form/inputs/Input/__stories__/MobilePhone.tsx" />
|
|
43
|
+
|
|
44
|
+
|
|
45
|
+
### Phone number
|
|
46
|
+
|
|
47
|
+
<code src="@digigov/form/inputs/Input/__stories__/PhoneNumber.tsx" />
|
|
48
|
+
|
|
49
|
+
|
|
50
|
+
### Postal code
|
|
51
|
+
|
|
52
|
+
<code src="@digigov/form/inputs/Input/__stories__/PostalCode.tsx" />
|
|
53
|
+
|
|
54
|
+
### Text with character limit
|
|
55
|
+
|
|
56
|
+
<code src="@digigov/form/inputs/Input/__stories__/TextWithLimit.tsx" />
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { test, expect } from '@playwright/experimental-ct-react';
|
|
3
|
-
import TestVariant from '@digigov/ui/utils/TestVariant'
|
|
4
3
|
import { AFM } from '@digigov/form/inputs/Input/__stories__/AFM';
|
|
5
4
|
import { Boolean } from '@digigov/form/inputs/Input/__stories__/Boolean';
|
|
6
5
|
import { IBAN } from '@digigov/form/inputs/Input/__stories__/IBAN';
|
|
@@ -11,46 +10,48 @@ import { PhoneNumber } from '@digigov/form/inputs/Input/__stories__/PhoneNumber'
|
|
|
11
10
|
import { PostalCode } from '@digigov/form/inputs/Input/__stories__/PostalCode';
|
|
12
11
|
import { String } from '@digigov/form/inputs/Input/__stories__/String';
|
|
13
12
|
import { TextWithLimit } from '@digigov/form/inputs/Input/__stories__/TextWithLimit';
|
|
13
|
+
import TestVariant from '@digigov/ui/utils/TestVariant';
|
|
14
14
|
|
|
15
15
|
test('renders the All Input variants', async ({ mount, page }) => {
|
|
16
16
|
await mount(
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
</
|
|
49
|
-
|
|
50
|
-
)
|
|
17
|
+
<div>
|
|
18
|
+
<TestVariant title="AFM">
|
|
19
|
+
<AFM />
|
|
20
|
+
</TestVariant>
|
|
21
|
+
<TestVariant title="Boolean">
|
|
22
|
+
<Boolean />
|
|
23
|
+
</TestVariant>
|
|
24
|
+
<TestVariant title="IBAN">
|
|
25
|
+
<IBAN />
|
|
26
|
+
</TestVariant>
|
|
27
|
+
<TestVariant title="Integer">
|
|
28
|
+
<Integer />
|
|
29
|
+
</TestVariant>
|
|
30
|
+
<TestVariant title="LandlineNumber">
|
|
31
|
+
<LandlineNumber />
|
|
32
|
+
</TestVariant>
|
|
33
|
+
<TestVariant title="MobilePhone">
|
|
34
|
+
<MobilePhone />
|
|
35
|
+
</TestVariant>
|
|
36
|
+
<TestVariant title="PhoneNumber">
|
|
37
|
+
<PhoneNumber />
|
|
38
|
+
</TestVariant>
|
|
39
|
+
<TestVariant title="PostalCode">
|
|
40
|
+
<PostalCode />
|
|
41
|
+
</TestVariant>
|
|
42
|
+
<TestVariant title="String">
|
|
43
|
+
<String />
|
|
44
|
+
</TestVariant>
|
|
45
|
+
<TestVariant title="TextWithLimit">
|
|
46
|
+
<TextWithLimit />
|
|
47
|
+
</TestVariant>
|
|
48
|
+
</div>
|
|
49
|
+
);
|
|
51
50
|
await page.evaluate(() => document.fonts.ready);
|
|
52
51
|
|
|
53
|
-
const screenshot = await page.screenshot({
|
|
52
|
+
const screenshot = await page.screenshot({
|
|
53
|
+
fullPage: true,
|
|
54
|
+
animations: 'disabled',
|
|
55
|
+
});
|
|
54
56
|
expect(screenshot).toMatchSnapshot();
|
|
55
57
|
});
|
|
56
|
-
|
|
@@ -1,10 +1,10 @@
|
|
|
1
1
|
import React from 'react';
|
|
2
2
|
import { useWatch } from 'react-hook-form';
|
|
3
3
|
import { UncontrolledFieldProps } from '@digigov/form/Field/types';
|
|
4
|
-
import {
|
|
5
|
-
import
|
|
6
|
-
import TextInput from '@digigov/react-core/TextInput';
|
|
4
|
+
import { TextArea } from '@digigov/ui/form/TextArea';
|
|
5
|
+
import { TextInput } from '@digigov/ui/form/TextInput';
|
|
7
6
|
import { useTranslation } from '@digigov/ui/i18n';
|
|
7
|
+
import { Hint } from '@digigov/ui/typography/Hint';
|
|
8
8
|
|
|
9
9
|
const TYPES_MAP = {
|
|
10
10
|
string: 'text',
|
|
@@ -40,6 +40,27 @@ export const Input: React.ExoticComponent<InputProps> = React.forwardRef(
|
|
|
40
40
|
const fieldType = TYPES_MAP[type || 'text'] || 'text';
|
|
41
41
|
const { t } = useTranslation();
|
|
42
42
|
const currentValue: string | '' = useWatch({ control, name });
|
|
43
|
+
|
|
44
|
+
const getRemainingChars = (currentValue, limit) => {
|
|
45
|
+
if (currentValue) {
|
|
46
|
+
return limit?.max - currentValue.length;
|
|
47
|
+
}
|
|
48
|
+
return limit?.max;
|
|
49
|
+
};
|
|
50
|
+
|
|
51
|
+
const constructRemainingText = (currentValue, limit) => {
|
|
52
|
+
const remainingChars = getRemainingChars(currentValue, limit);
|
|
53
|
+
let remainingText =
|
|
54
|
+
Math.abs(remainingChars) === 1
|
|
55
|
+
? t('form.info.text.character')
|
|
56
|
+
: t('form.info.text.characters');
|
|
57
|
+
remainingText +=
|
|
58
|
+
remainingChars > 0
|
|
59
|
+
? ` ${t('form.info.text.remaining')}.`
|
|
60
|
+
: ` ${t('form.info.text.too_many')}.`;
|
|
61
|
+
return remainingText;
|
|
62
|
+
};
|
|
63
|
+
|
|
43
64
|
if (multiline === true) {
|
|
44
65
|
return (
|
|
45
66
|
<>
|
|
@@ -56,32 +77,13 @@ export const Input: React.ExoticComponent<InputProps> = React.forwardRef(
|
|
|
56
77
|
}}
|
|
57
78
|
/>
|
|
58
79
|
{limit?.max && (
|
|
59
|
-
<Hint>
|
|
60
|
-
{
|
|
61
|
-
|
|
62
|
-
currentValue
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
{!currentValue
|
|
67
|
-
? limit.max
|
|
68
|
-
: limit?.max - currentValue?.length}
|
|
69
|
-
</b>{' '}
|
|
70
|
-
{currentValue && limit?.max - currentValue?.length === 1
|
|
71
|
-
? `${t('form.info.text.character')}`
|
|
72
|
-
: `${t('form.info.text.characters')}`}{' '}
|
|
73
|
-
{t('form.info.text.remaining')}.
|
|
74
|
-
</span>
|
|
75
|
-
) : (
|
|
76
|
-
<span style={{ color: '#b60202' }}>
|
|
77
|
-
{t('form.info.text.you_have')}{' '}
|
|
78
|
-
<b>{currentValue && currentValue?.length - limit?.max}</b>{' '}
|
|
79
|
-
{currentValue?.length - limit?.max === 1
|
|
80
|
-
? `${t('form.info.text.character')}`
|
|
81
|
-
: `${t('form.info.text.characters')}`}{' '}
|
|
82
|
-
{t('form.info.text.too_many')}.
|
|
83
|
-
</span>
|
|
84
|
-
)}
|
|
80
|
+
<Hint display={'flex'}>
|
|
81
|
+
{t('form.info.text.you_have')}
|
|
82
|
+
<Hint fontWeight="bold">
|
|
83
|
+
{`${Math.abs(getRemainingChars(currentValue, limit))}`}
|
|
84
|
+
|
|
85
|
+
</Hint>
|
|
86
|
+
{constructRemainingText(currentValue, limit)}
|
|
85
87
|
</Hint>
|
|
86
88
|
)}
|
|
87
89
|
</>
|
|
@@ -91,6 +93,7 @@ export const Input: React.ExoticComponent<InputProps> = React.forwardRef(
|
|
|
91
93
|
<TextInput
|
|
92
94
|
name={name}
|
|
93
95
|
type={fieldType}
|
|
96
|
+
data-type={type}
|
|
94
97
|
className={className}
|
|
95
98
|
ref={ref}
|
|
96
99
|
{...{ ...props, reset: undefined, required: undefined }}
|