@inseefr/lunatic 3.4.17 → 3.4.19
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/components/Input/Input.js +6 -3
- package/components/Input/Input.js.map +1 -1
- package/components/Input/Input.spec.js +13 -0
- package/components/Input/Input.spec.js.map +1 -1
- package/components/Textarea/Textarea.js +4 -1
- package/components/Textarea/Textarea.js.map +1 -1
- package/components/Textarea/Textarea.spec.js +13 -0
- package/components/Textarea/Textarea.spec.js.map +1 -1
- package/components/shared/CharactersCount/CharactersCount.d.ts +7 -0
- package/components/shared/CharactersCount/CharactersCount.js +20 -0
- package/components/shared/CharactersCount/CharactersCount.js.map +1 -0
- package/components/shared/CharactersCount/CharactersCount.spec.d.ts +1 -0
- package/components/shared/CharactersCount/CharactersCount.spec.js +28 -0
- package/components/shared/CharactersCount/CharactersCount.spec.js.map +1 -0
- package/components/shared/utils/getCharactersCountId.d.ts +4 -0
- package/components/shared/utils/getCharactersCountId.js +10 -0
- package/components/shared/utils/getCharactersCountId.js.map +1 -0
- package/esm/components/Input/Input.js +6 -3
- package/esm/components/Input/Input.js.map +1 -1
- package/esm/components/Input/Input.spec.js +13 -0
- package/esm/components/Input/Input.spec.js.map +1 -1
- package/esm/components/Textarea/Textarea.js +4 -1
- package/esm/components/Textarea/Textarea.js.map +1 -1
- package/esm/components/Textarea/Textarea.spec.js +13 -0
- package/esm/components/Textarea/Textarea.spec.js.map +1 -1
- package/esm/components/shared/CharactersCount/CharactersCount.d.ts +7 -0
- package/esm/components/shared/CharactersCount/CharactersCount.js +15 -0
- package/esm/components/shared/CharactersCount/CharactersCount.js.map +1 -0
- package/esm/components/shared/CharactersCount/CharactersCount.spec.d.ts +1 -0
- package/esm/components/shared/CharactersCount/CharactersCount.spec.js +26 -0
- package/esm/components/shared/CharactersCount/CharactersCount.spec.js.map +1 -0
- package/esm/components/shared/utils/getCharactersCountId.d.ts +4 -0
- package/esm/components/shared/utils/getCharactersCountId.js +7 -0
- package/esm/components/shared/utils/getCharactersCountId.js.map +1 -0
- package/esm/main.css +10 -0
- package/esm/main.css.map +1 -1
- package/esm/use-lunatic/hooks/use-page-has-response.js +1 -1
- package/esm/use-lunatic/hooks/use-page-has-response.js.map +1 -1
- package/esm/use-lunatic/props/propValue.js +15 -4
- package/esm/use-lunatic/props/propValue.js.map +1 -1
- package/esm/use-lunatic/props/propValue.spec.js +49 -2
- package/esm/use-lunatic/props/propValue.spec.js.map +1 -1
- package/main.css +10 -0
- package/main.css.map +1 -1
- package/package.json +23 -1
- package/src/components/Input/Input.spec.tsx +19 -0
- package/src/components/Input/Input.tsx +26 -18
- package/src/components/Input/__snapshots__/Input.spec.tsx.snap +27 -19
- package/src/components/RosterForLoop/__snapshots__/RosterForLoop.spec.tsx.snap +42 -20
- package/src/components/Textarea/Textarea.spec.tsx +18 -0
- package/src/components/Textarea/Textarea.tsx +21 -13
- package/src/components/Textarea/__snapshots__/Textarea.spec.tsx.snap +21 -11
- package/src/components/shared/CharactersCount/CharactersCount.spec.tsx +31 -0
- package/src/components/shared/CharactersCount/CharactersCount.tsx +27 -0
- package/src/components/shared/utils/getCharactersCountId.test.ts +14 -0
- package/src/components/shared/utils/getCharactersCountId.ts +6 -0
- package/src/css/components/Input.scss +10 -0
- package/src/use-lunatic/hooks/use-page-has-response.test.ts +42 -0
- package/src/use-lunatic/hooks/use-page-has-response.ts +1 -1
- package/src/use-lunatic/props/propValue.spec.ts +53 -2
- package/src/use-lunatic/props/propValue.ts +21 -6
- package/tsconfig.build.tsbuildinfo +1 -1
- package/use-lunatic/hooks/use-page-has-response.js +1 -1
- package/use-lunatic/hooks/use-page-has-response.js.map +1 -1
- package/use-lunatic/props/propValue.js +15 -4
- package/use-lunatic/props/propValue.js.map +1 -1
- package/use-lunatic/props/propValue.spec.js +49 -2
- package/use-lunatic/props/propValue.spec.js.map +1 -1
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propValue.js","sourceRoot":"","sources":["../../../src/use-lunatic/props/propValue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAIjE,MAAM,UAAU,YAAY,CAC3B,SAAqC,EACrC,IAGC;;IAED,IAAI,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAC7C,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QACxB,CAAC,CAAC,SAAS,CAAC;IACb,IAAI,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;QAChC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;IACxC,CAAC;IACD,IAAI,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7B,OAAO,MAAM,CAAC,WAAW,CACxB,MAAA,MAAA,SAAS,CAAC,SAAS,0CAAE,GAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;YAC1C,QAAQ,CAAC,IAAI;YACb,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;SAC5C,CAAC,mCAAI,EAAE,CACR,CAAC;IACH,CAAC;IACD,IAAI,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QAC5B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;IACD,0DAA0D;IAC1D,IAAI,YAAY,IAAI,SAAS,EAAE,CAAC;QAC/B,OAAO,
|
|
1
|
+
{"version":3,"file":"propValue.js","sourceRoot":"","sources":["../../../src/use-lunatic/props/propValue.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,oBAAoB,CAAC;AAC9C,OAAO,EAAE,WAAW,EAAE,YAAY,EAAE,MAAM,sBAAsB,CAAC;AAIjE,MAAM,UAAU,YAAY,CAC3B,SAAqC,EACrC,IAGC;;IAED,IAAI,SAAS,GAAG,QAAQ,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QAC7C,CAAC,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,CAAC;QACxB,CAAC,CAAC,SAAS,CAAC;IACb,IAAI,IAAI,CAAC,KAAK,CAAC,eAAe,EAAE,CAAC;QAChC,SAAS,GAAG,IAAI,CAAC,KAAK,CAAC,eAAe,CAAC;IACxC,CAAC;IACD,IAAI,YAAY,CAAC,SAAS,CAAC,EAAE,CAAC;QAC7B,OAAO,MAAM,CAAC,WAAW,CACxB,MAAA,MAAA,SAAS,CAAC,SAAS,0CAAE,GAAG,CAAC,CAAC,EAAE,QAAQ,EAAE,EAAE,EAAE,CAAC;YAC1C,QAAQ,CAAC,IAAI;YACb,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC;SAC5C,CAAC,mCAAI,EAAE,CACR,CAAC;IACH,CAAC;IACD,IAAI,WAAW,CAAC,SAAS,CAAC,EAAE,CAAC;QAC5B,OAAO,IAAI,CAAC,SAAS,CAAC,GAAG,CAAC,SAAS,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,CAAC;IAC/D,CAAC;IACD,0DAA0D;IAC1D,IAAI,YAAY,IAAI,SAAS,EAAE,CAAC;QAC/B,OAAO,sBAAsB,CAAC,SAAS,CAAC,UAAU,EAAE,IAAI,CAAC,SAAS,CAAC,CAAC;IACrE,CAAC;IACD,OAAO,IAAI,CAAC;AACb,CAAC;AAED;;GAEG;AACH,SAAS,sBAAsB,CAC9B,UAAwC,EACxC,SAAgC;IAEhC,OAAO,MAAM,CAAC,WAAW,CACxB,UAAU,CAAC,OAAO,CAAC,CAAC,CAAC,EAAE,EAAE;QACxB,IAAI,UAAU,IAAI,CAAC,EAAE,CAAC;YACrB,OAAO,CAAC,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,EAAE,SAAS,CAAC,GAAG,CAAC,CAAC,CAAC,QAAQ,CAAC,IAAI,CAAC,CAAC,CAAC,CAAC;QAC5D,CAAC;QACD,IAAI,YAAY,IAAI,CAAC,EAAE,CAAC;YACvB,OAAO,MAAM,CAAC,OAAO,CAAC,sBAAsB,CAAC,CAAC,CAAC,UAAU,EAAE,SAAS,CAAC,CAAC,CAAC;QACxE,CAAC;QACD,OAAO,EAAE,CAAC;IACX,CAAC,CAAC,CACF,CAAC;AACH,CAAC"}
|
|
@@ -18,7 +18,7 @@ describe('fillComponentValue', () => {
|
|
|
18
18
|
},
|
|
19
19
|
}));
|
|
20
20
|
};
|
|
21
|
-
describe('response', () => {
|
|
21
|
+
describe('single response', () => {
|
|
22
22
|
const component = {
|
|
23
23
|
response: { name: 'PRENOM' },
|
|
24
24
|
};
|
|
@@ -31,7 +31,7 @@ describe('fillComponentValue', () => {
|
|
|
31
31
|
expectFilledComponent(component, { PRENOM: ['John', 'Renaud'] }, 3).toBe(undefined);
|
|
32
32
|
});
|
|
33
33
|
});
|
|
34
|
-
describe('responses', () => {
|
|
34
|
+
describe('multiple responses', () => {
|
|
35
35
|
const component = {
|
|
36
36
|
responses: times(3, (k) => ({
|
|
37
37
|
response: { name: `NAME${k}` },
|
|
@@ -50,5 +50,52 @@ describe('fillComponentValue', () => {
|
|
|
50
50
|
});
|
|
51
51
|
});
|
|
52
52
|
});
|
|
53
|
+
describe('Loop component with nested components', () => {
|
|
54
|
+
const loopComponent = {
|
|
55
|
+
id: 'm7j9kwro',
|
|
56
|
+
componentType: 'Loop',
|
|
57
|
+
components: [
|
|
58
|
+
{
|
|
59
|
+
id: 'm7j9iem8',
|
|
60
|
+
componentType: 'Sequence',
|
|
61
|
+
},
|
|
62
|
+
{
|
|
63
|
+
id: 'question-m7j9q1ep',
|
|
64
|
+
componentType: 'Question',
|
|
65
|
+
components: [
|
|
66
|
+
{
|
|
67
|
+
id: 'm7j9q1ep',
|
|
68
|
+
componentType: 'Input',
|
|
69
|
+
response: { name: 'VOTREPRENO' },
|
|
70
|
+
},
|
|
71
|
+
],
|
|
72
|
+
},
|
|
73
|
+
{
|
|
74
|
+
id: 'question-m7jb81xh',
|
|
75
|
+
componentType: 'Question',
|
|
76
|
+
components: [
|
|
77
|
+
{
|
|
78
|
+
id: 'm7jb81xh',
|
|
79
|
+
componentType: 'InputNumber',
|
|
80
|
+
response: { name: 'VOTREAGE' },
|
|
81
|
+
},
|
|
82
|
+
],
|
|
83
|
+
},
|
|
84
|
+
],
|
|
85
|
+
};
|
|
86
|
+
it('should correctly extract values from nested responses as arrays', () => {
|
|
87
|
+
const values = {
|
|
88
|
+
VOTREPRENO: ['Alice', 'Bob', 'Charlie'],
|
|
89
|
+
VOTREAGE: [22, 30, 40],
|
|
90
|
+
};
|
|
91
|
+
expectFilledComponent(loopComponent, values).toEqual(values);
|
|
92
|
+
});
|
|
93
|
+
it('should return null for missing responses', () => {
|
|
94
|
+
expectFilledComponent(loopComponent).toEqual({
|
|
95
|
+
VOTREPRENO: null,
|
|
96
|
+
VOTREAGE: null,
|
|
97
|
+
});
|
|
98
|
+
});
|
|
99
|
+
});
|
|
53
100
|
});
|
|
54
101
|
//# sourceMappingURL=propValue.spec.js.map
|
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"propValue.spec.js","sourceRoot":"","sources":["../../../src/use-lunatic/props/propValue.spec.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,QAAQ,EAAE,MAAM,EAAE,EAAE,EAAE,MAAM,QAAQ,CAAC;AAC9C,OAAO,EAAE,YAAY,EAAE,MAAM,aAAa,CAAC;AAE3C,OAAO,EAAE,qBAAqB,EAAE,MAAM,8CAA8C,CAAC;AACrF,OAAO,EAAE,KAAK,EAAE,MAAM,mBAAmB,CAAC;AAE1C,QAAQ,CAAC,oBAAoB,EAAE,GAAG,EAAE;IACnC,6BAA6B;IAC7B,MAAM,qBAAqB,GAAG,CAC7B,SAAqC;IACrC,6BAA6B;IAC7B,SAAkC,EAAE;IACpC,kBAAkB;IAClB,SAAkB,EACjB,EAAE;QACH,OAAO,MAAM,CACZ,YAAY,CAAC,SAAS,EAAE;YACvB,SAAS,EAAE,qBAAqB,CAAC,cAAc,CAAC,MAAM,CAAC;YACvD,KAAK,EAAE;gBACN,OAAO,EAAE,CAAC;gBACV,IAAI,EAAE,CAAC;gBACP,SAAS;aACT;SACD,CAAC,CACF,CAAC;IACH,CAAC,CAAC;IAEF,QAAQ,CAAC,
|
|
1
|
+
{"version":3,"file":"propValue.spec.js","sourceRoot":"","sources":["../../../src/use-lunatic/props/propValue.spec.ts"],"names":[],"mappings":"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"}
|
package/main.css
CHANGED
|
@@ -611,6 +611,16 @@ fieldset {
|
|
|
611
611
|
background-color: var(--color-error);
|
|
612
612
|
}
|
|
613
613
|
|
|
614
|
+
.characters-count {
|
|
615
|
+
display: block;
|
|
616
|
+
font-size: 12px;
|
|
617
|
+
padding-top: 0.3rem;
|
|
618
|
+
}
|
|
619
|
+
|
|
620
|
+
.max-length-reached {
|
|
621
|
+
color: red;
|
|
622
|
+
}
|
|
623
|
+
|
|
614
624
|
.lunatic-component .lunatic-input-number {
|
|
615
625
|
display: inline-block;
|
|
616
626
|
}
|
package/main.css.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"sourceRoot":"","sources":["../src/css/main.scss","../src/css/components/Button.scss","../src/css/components/CheckboxGroup.scss","../src/css/components/CheckboxOne.scss","../src/css/components/CheckboxOption.scss","../src/css/components/Combobox.scss","../src/css/components/ComponentErrors.scss","../src/css/components/Datepicker.scss","../src/css/components/Declarations.scss","../src/css/components/Dropdown.scss","../src/css/components/Duration.scss","../src/css/components/Fieldset.scss","../src/css/components/IconButton.scss","../src/css/components/Input.scss","../src/css/components/InputNumber.scss","../src/css/components/Label.scss","../src/css/components/Missing.scss","../src/css/components/ModalControls.scss","../src/css/components/RosterForLoop.scss","../src/css/components/Roundabout.scss","../src/css/components/Sequence.scss","../src/css/components/Suggester.scss","../src/css/components/Table.scss","../src/css/components/Textarea.scss","../src/css/components/VariableStatus.scss","../src/css/components/Dragger.scss","../src/css/components/SuggesterWidget.scss"],"names":[],"mappings":";AAAA;EACC;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EAEA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EAEA;;;AAkBD;AAyBC;AA+BA;;AAvDA;EACC;EACA;;AAED;EACC;EACA;;AAID;AAAA;AAAA;AAAA;AAAA;EAKC;EACA;EACA;EACA;EACA;EACA;EACA;;AASD;EACC;;AAEA;EACC;EACA;;AACA;EACC;;AAGF;EACC;EACA;;AACA;EACC;;AAGF;EACC;;AAED;EACC;;AAMF;EAxEA;EACA;;AA0EA;EA3EA;EACA;;AA6EA;EACC;EA1ED;EACA;EACA;;AAEA;EACC;;AAwED;EA7EA;EACA;EACA;;AAEA;EACC;;AA4ED;EACC;;AAGD;EACC;;AAGD;EACC;EACA;;AAGD;EACC;;AACA;EACC;EACA;EACA;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AAEC;EACC;;AAED;EACC;;;AAMJ;EACC;;;AC1JD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EAEC;EACA;EACA;;AAED;EACC;EACA;EACA;;AAED;EACC;EACA;;;ACnBA;EACC;EACA;;AAGF;EACC;EACA;EACA;;;ACRA;EACC;;AAGF;EACC;;AAEA;EACC;EACA;EACA;;AACA;EACC;;;ACdJ;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;;;AAIF;EACC;;;AAGD;AAAA;EAEC;;AAEA;AAAA;EACC;EACA;;;AAMD;AAAA;EACC;;;AAMF;EACC;;AAEA;EACC;;;AAIF;EACC;;;AAGD;EACC;EACA;EACA;EACA;EACA;;;AC1DD;EACC;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EAEA;;AACA;EACC;EACA;EACA;;AAEC;EACC;EACA;EACA;;AACA;EACC;;AAED;EACC;EACA;EACA;EACA;EApCL;;AAuCK;EAhDL;EASA;EAPA;EACA;EACA;EACA;;AAgDI;EACC;EACA;EACA;EACA;EAhDL;EAkDK;EACA;EACA;EA7DL;EASA;EAPA;EACA;EACA;EACA;;AA2DK;EACC;EACA;EACA;;AAGD;EACC;;AAKH;EAnEH;EAqEI;EACA;EACA;EACA,YACC;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAED;EACC;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAED;EACC;EACA;;AAQN;EACC;EACA;EACA;EACA;;AACA;EACC;;AAIA;EACC;EACA;EACA;EACA;;AAKH;EACC;EACA;;AAEA;EACC;;AAGD;EACC;;AAGD;EACC;;AAEA;EACC;;AACA;EACC;EACA;EACA;EACA;EAKA;;AAJA;EACC;;AAMF;EAEC;EACA;EACA;EACA;;AACA;EACC;;AAKH;AAAA;AAAA;AAAA;EAIC;EACA;EACA;EACA;;AAIA;EACC;;AAED;EApMH;EACA;EACA;;;ACFA;EACC;;;ACFF;EACC;EACA;EACA;;;AAGD;EACC;;;AAGD;EACC;;;AAGD;EACC;EACA;EACA;;;AChBA;EACC;;AAGD;EACC;EACA;;AAGD;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;;AACA;EACC;;AAIF;EACC;EACA;;AACA;EACC;;;ACxBD;EACC;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAGD;EACC;EACA;;AAGD;EACC;;;ACjCJ;AAAA;EAEC;EACA;EACA;;;AAED;EACC;;;ACPD;EACC;EACA;EACA;;;ACHD;EACC;EACA;;;AAID;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,YACC;;AAID;EACC;EACA;EACA;;AAGD;EACC;EACA;;AAGD;EACC;;AAGD;EACC;EACA;;;AChCA;AAAA;AAAA;AAAA;EACC;;AACA;AAAA;AAAA;AAAA;EACC;EACA;EACA;;AAGF;AAAA;AAAA;AAAA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;AAAA;AAAA;AAAA;EACC;EACA;;AAED;AAAA;AAAA;AAAA;EACC;;AAED;AAAA;AAAA;AAAA;EACC;;AAIF;AAAA;AAAA;AAAA;EACC;EACA;EACA;;;
|
|
1
|
+
{"version":3,"sourceRoot":"","sources":["../src/css/main.scss","../src/css/components/Button.scss","../src/css/components/CheckboxGroup.scss","../src/css/components/CheckboxOne.scss","../src/css/components/CheckboxOption.scss","../src/css/components/Combobox.scss","../src/css/components/ComponentErrors.scss","../src/css/components/Datepicker.scss","../src/css/components/Declarations.scss","../src/css/components/Dropdown.scss","../src/css/components/Duration.scss","../src/css/components/Fieldset.scss","../src/css/components/IconButton.scss","../src/css/components/Input.scss","../src/css/components/InputNumber.scss","../src/css/components/Label.scss","../src/css/components/Missing.scss","../src/css/components/ModalControls.scss","../src/css/components/RosterForLoop.scss","../src/css/components/Roundabout.scss","../src/css/components/Sequence.scss","../src/css/components/Suggester.scss","../src/css/components/Table.scss","../src/css/components/Textarea.scss","../src/css/components/VariableStatus.scss","../src/css/components/Dragger.scss","../src/css/components/SuggesterWidget.scss"],"names":[],"mappings":";AAAA;EACC;EACA;EACA;EACA;EACA;EAEA;EACA;EACA;EACA;EAEA;EACA;EACA;EAEA;EACA;EACA;EACA;EACA;EAEA;;;AAkBD;AAyBC;AA+BA;;AAvDA;EACC;EACA;;AAED;EACC;EACA;;AAID;AAAA;AAAA;AAAA;AAAA;EAKC;EACA;EACA;EACA;EACA;EACA;EACA;;AASD;EACC;;AAEA;EACC;EACA;;AACA;EACC;;AAGF;EACC;EACA;;AACA;EACC;;AAGF;EACC;;AAED;EACC;;AAMF;EAxEA;EACA;;AA0EA;EA3EA;EACA;;AA6EA;EACC;EA1ED;EACA;EACA;;AAEA;EACC;;AAwED;EA7EA;EACA;EACA;;AAEA;EACC;;AA4ED;EACC;;AAGD;EACC;;AAGD;EACC;EACA;;AAGD;EACC;;AACA;EACC;EACA;EACA;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AAEC;EACC;;AAED;EACC;;;AAMJ;EACC;;;AC1JD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EAEC;EACA;EACA;;AAED;EACC;EACA;EACA;;AAED;EACC;EACA;;;ACnBA;EACC;EACA;;AAGF;EACC;EACA;EACA;;;ACRA;EACC;;AAGF;EACC;;AAEA;EACC;EACA;EACA;;AACA;EACC;;;ACdJ;EACC;EACA;;;AAGD;EACC;EACA;;;AAGD;EACC;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;;;AAIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;;;AAIF;EACC;;;AAGD;AAAA;EAEC;;AAEA;AAAA;EACC;EACA;;;AAMD;AAAA;EACC;;;AAMF;EACC;;AAEA;EACC;;;AAIF;EACC;;;AAGD;EACC;EACA;EACA;EACA;EACA;;;AC1DD;EACC;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EAEA;;AACA;EACC;EACA;EACA;;AAEC;EACC;EACA;EACA;;AACA;EACC;;AAED;EACC;EACA;EACA;EACA;EApCL;;AAuCK;EAhDL;EASA;EAPA;EACA;EACA;EACA;;AAgDI;EACC;EACA;EACA;EACA;EAhDL;EAkDK;EACA;EACA;EA7DL;EASA;EAPA;EACA;EACA;EACA;;AA2DK;EACC;EACA;EACA;;AAGD;EACC;;AAKH;EAnEH;EAqEI;EACA;EACA;EACA,YACC;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAED;EACC;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAED;EACC;EACA;;AAQN;EACC;EACA;EACA;EACA;;AACA;EACC;;AAIA;EACC;EACA;EACA;EACA;;AAKH;EACC;EACA;;AAEA;EACC;;AAGD;EACC;;AAGD;EACC;;AAEA;EACC;;AACA;EACC;EACA;EACA;EACA;EAKA;;AAJA;EACC;;AAMF;EAEC;EACA;EACA;EACA;;AACA;EACC;;AAKH;AAAA;AAAA;AAAA;EAIC;EACA;EACA;EACA;;AAIA;EACC;;AAED;EApMH;EACA;EACA;;;ACFA;EACC;;;ACFF;EACC;EACA;EACA;;;AAGD;EACC;;;AAGD;EACC;;;AAGD;EACC;EACA;EACA;;;AChBA;EACC;;AAGD;EACC;EACA;;AAGD;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;;AAGD;EACC;EACA;EACA;EACA;EACA;EACA;;AACA;EACC;;AAIF;EACC;EACA;;AACA;EACC;;;ACxBD;EACC;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAGD;EACC;EACA;;AAGD;EACC;;;ACjCJ;AAAA;EAEC;EACA;EACA;;;AAED;EACC;;;ACPD;EACC;EACA;EACA;;;ACHD;EACC;EACA;;;AAID;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA,YACC;;AAID;EACC;EACA;EACA;;AAGD;EACC;EACA;;AAGD;EACC;;AAGD;EACC;EACA;;;AChCA;AAAA;AAAA;AAAA;EACC;;AACA;AAAA;AAAA;AAAA;EACC;EACA;EACA;;AAGF;AAAA;AAAA;AAAA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;AAAA;AAAA;AAAA;EACC;EACA;;AAED;AAAA;AAAA;AAAA;EACC;;AAED;AAAA;AAAA;AAAA;EACC;;AAIF;AAAA;AAAA;AAAA;EACC;EACA;EACA;;;AAKH;EACC;EACA;EACA;;;AAGD;EACC;;;AClDA;EACC;;AAEA;EACC;;;ACNF;EACC;EACA;;;ACHF;EACC;;;AAED;EACC;EACA;EACA;;;AAED;EACC;EACA;;;AAED;EACC;EACA;;;AAED;EACC;;;AAED;EACC;EACA;;;AAED;EACC;EACA;;;ACzBD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AACA;EACC;EACA;EACA;;AAGD;EACC;EACA;;AACA;EACC;;AAMF;AAAA;AAAA;AAAA;EAIC;EACA;;AAGF;EACC;EACA;;;AClBF;EACC;EACA;EACA;EACA;;AAEC;EACC;EACA;;;ACnCH;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;;AAGD;EACC;EACA;EACA;;;AAGD;EACC;EACA;EACA;EACA;;;AAGD;EACC;;;AAGD;EACC;EACA;EACA;;;AAGD;AAAA;EAEC;;;AAED;AAAA;EAEC;;;ACtCA;EACC;EACA;EACA;EACA;EACA;EACA;;;AC8BD;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AAIA;EACC;;AACA;EACC;EACA;EACA;;AAOC;EACC;EACA;EACA;;AACA;EACC;;AAED;EACC;EACA;EACA;EACA;EAtEN;;AAyEM;EAjEN;EARA;EAUA;EACA;EACA;EACA;;AAiEK;EACC;EACA;EACA;EACA;EACA;EAnFN;;AAsFM;EACC;EA/EP;EARA;EAUA;EACA;EACA;EACA;;AA6EM;EACC;EACA;EACA;;AAGD;EACC;;AAKH;EAtGJ;EAwGK;EACA;EACA;EACA,YACC;;AAED;EACC;EACA;EACA;EACA;EACA;EACA;;AAED;EACC;EACA;EACA;EACA;EACA;EACA;;AACA;EACC;EACA;;AAED;EACC;EACA;;AASP;EACC;EACA;EACA;;AAEA;EACC;;AAjIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AAsHA;EACC;;AArIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AA0HA;EACC;;AAzIF;EACC;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;EACA;;AA+HA;EACC;EACA;;AACA;EACC;EACA;EACA;;;ACrKJ;EACC;EACA;EACA;EACA;;AAEA;EACC;EACA;;AAGD;AAAA;EAEC;EACA;EACA;;AAGD;EACC;EACA;EACA;EACA;EACA;EAEA;EACA,YACC;;AAKD;AAAA;EAEC;EACA;EACA;;;AAKH;EACC;EACA;;;ACxCA;EACC;EACA;;;ACLF;EACC;AAMA;AAUA;;AAdA;EACC;;AAID;EACC;EACA;EACA;EACA;EACA;EACA;;AAID;EACC;EACA;EACA;EACA;EACA;EACA;EACA;;AAEC;EACC;;AAED;EACC;;;AC/BJ;EACC;EACA;EACA;EACA;EACA;EACA;;;ACaA;EACC;EACA;;AAED;EACC;EACA;EACA,kBA1BO;EA2BP;EACA;EACA;EACA;;AAlBD;EACC;EACA;;AAoBA;EACC;EACA;EACA;EACA;;AACA;EACC;EACA,OAxCK;EAyCL;EACA;EACA;;AAED;EACC,OA9CK;EA+CL;EACA;EACA;EACA;;AAED;EACC;EACA;EACA;EACA;EACA;EACA,kBA1DK;;AA4DL;EACC;EACA;;AAGD;EACC,kBAjEI;EAkEJ;EACA;;AAIA;EACC;EACA;EACA,MA5EG;;AAiFN;EACC;EACA;EACA;EACA;;AAGC;EACC,cAvFG;EAwFH;EAMA;;AALA;EACC,kBA1FE;EA2FF;;AAOH;EACC;EACA;EACA;;AACA;EACC,kBAxGG;EAyGH;;AAMJ;EACC;EACA;EACA;EACA,kBApHM;EAqHN;EACA;EACA;EACA;EACA;;AAGC;EACC;;AAIF;EACC;EACA;EACA,MAnIK;;AAWR;EACC;EACA;;AA4HA;EACC;EACA;EACA;EACA;;AAEA;EACC;EACA;EACA;EACA,kBAnJK;EAoJL;EACA;;AAEA;EACC;;AAGD;EACC,kBA1JI;EA2JJ;;AAGD;EACC;;AACA;EACC;;AAED;EACC;EACA;EACA,MAzKG","file":"main.css"}
|
package/package.json
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@inseefr/lunatic",
|
|
3
|
-
"version": "3.4.
|
|
3
|
+
"version": "3.4.19",
|
|
4
4
|
"description": "Library of questionnaire components",
|
|
5
5
|
"repository": {
|
|
6
6
|
"type": "git",
|
|
@@ -98,6 +98,8 @@
|
|
|
98
98
|
"src/components/shared/Button/IconButton.spec.tsx",
|
|
99
99
|
"src/components/shared/Button/IconButton.tsx",
|
|
100
100
|
"src/components/shared/Button/__snapshots__/Button.spec.tsx.snap",
|
|
101
|
+
"src/components/shared/CharactersCount/CharactersCount.spec.tsx",
|
|
102
|
+
"src/components/shared/CharactersCount/CharactersCount.tsx",
|
|
101
103
|
"src/components/shared/Checkbox/CheckboxOption.spec.tsx",
|
|
102
104
|
"src/components/shared/Checkbox/CheckboxOption.tsx",
|
|
103
105
|
"src/components/shared/Checkbox/getShortcutKey.ts",
|
|
@@ -177,6 +179,8 @@
|
|
|
177
179
|
"src/components/shared/Table/Tr.spec.tsx",
|
|
178
180
|
"src/components/shared/Table/Tr.tsx",
|
|
179
181
|
"src/components/shared/Table/index.ts",
|
|
182
|
+
"src/components/shared/utils/getCharactersCountId.test.ts",
|
|
183
|
+
"src/components/shared/utils/getCharactersCountId.ts",
|
|
180
184
|
"src/components/type.ts",
|
|
181
185
|
"src/css/components/Button.scss",
|
|
182
186
|
"src/css/components/CheckboxGroup.scss",
|
|
@@ -640,6 +644,12 @@
|
|
|
640
644
|
"components/shared/Button/IconButton.spec.d.ts",
|
|
641
645
|
"components/shared/Button/IconButton.spec.js",
|
|
642
646
|
"components/shared/Button/IconButton.spec.js.map",
|
|
647
|
+
"components/shared/CharactersCount/CharactersCount.d.ts",
|
|
648
|
+
"components/shared/CharactersCount/CharactersCount.js",
|
|
649
|
+
"components/shared/CharactersCount/CharactersCount.js.map",
|
|
650
|
+
"components/shared/CharactersCount/CharactersCount.spec.d.ts",
|
|
651
|
+
"components/shared/CharactersCount/CharactersCount.spec.js",
|
|
652
|
+
"components/shared/CharactersCount/CharactersCount.spec.js.map",
|
|
643
653
|
"components/shared/Checkbox/CheckboxOption.d.ts",
|
|
644
654
|
"components/shared/Checkbox/CheckboxOption.js",
|
|
645
655
|
"components/shared/Checkbox/CheckboxOption.js.map",
|
|
@@ -874,6 +884,9 @@
|
|
|
874
884
|
"components/shared/Table/index.d.ts",
|
|
875
885
|
"components/shared/Table/index.js",
|
|
876
886
|
"components/shared/Table/index.js.map",
|
|
887
|
+
"components/shared/utils/getCharactersCountId.d.ts",
|
|
888
|
+
"components/shared/utils/getCharactersCountId.js",
|
|
889
|
+
"components/shared/utils/getCharactersCountId.js.map",
|
|
877
890
|
"components/type.d.ts",
|
|
878
891
|
"components/type.js",
|
|
879
892
|
"components/type.js.map",
|
|
@@ -1048,6 +1061,12 @@
|
|
|
1048
1061
|
"esm/components/shared/Button/IconButton.spec.d.ts",
|
|
1049
1062
|
"esm/components/shared/Button/IconButton.spec.js",
|
|
1050
1063
|
"esm/components/shared/Button/IconButton.spec.js.map",
|
|
1064
|
+
"esm/components/shared/CharactersCount/CharactersCount.d.ts",
|
|
1065
|
+
"esm/components/shared/CharactersCount/CharactersCount.js",
|
|
1066
|
+
"esm/components/shared/CharactersCount/CharactersCount.js.map",
|
|
1067
|
+
"esm/components/shared/CharactersCount/CharactersCount.spec.d.ts",
|
|
1068
|
+
"esm/components/shared/CharactersCount/CharactersCount.spec.js",
|
|
1069
|
+
"esm/components/shared/CharactersCount/CharactersCount.spec.js.map",
|
|
1051
1070
|
"esm/components/shared/Checkbox/CheckboxOption.d.ts",
|
|
1052
1071
|
"esm/components/shared/Checkbox/CheckboxOption.js",
|
|
1053
1072
|
"esm/components/shared/Checkbox/CheckboxOption.js.map",
|
|
@@ -1282,6 +1301,9 @@
|
|
|
1282
1301
|
"esm/components/shared/Table/index.d.ts",
|
|
1283
1302
|
"esm/components/shared/Table/index.js",
|
|
1284
1303
|
"esm/components/shared/Table/index.js.map",
|
|
1304
|
+
"esm/components/shared/utils/getCharactersCountId.d.ts",
|
|
1305
|
+
"esm/components/shared/utils/getCharactersCountId.js",
|
|
1306
|
+
"esm/components/shared/utils/getCharactersCountId.js.map",
|
|
1285
1307
|
"esm/components/type.d.ts",
|
|
1286
1308
|
"esm/components/type.js",
|
|
1287
1309
|
"esm/components/type.js.map",
|
|
@@ -1,6 +1,12 @@
|
|
|
1
1
|
import { fireEvent, render, screen } from '@testing-library/react';
|
|
2
2
|
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
3
3
|
import { Input } from './Input';
|
|
4
|
+
import { CharactersCount } from '../shared/CharactersCount/CharactersCount';
|
|
5
|
+
|
|
6
|
+
vi.mock('../shared/CharactersCount/CharactersCount', () => ({
|
|
7
|
+
CharactersCount: vi.fn(),
|
|
8
|
+
}));
|
|
9
|
+
|
|
4
10
|
describe('Input', () => {
|
|
5
11
|
const mockOnChange = vi.fn();
|
|
6
12
|
const baseProps = {
|
|
@@ -34,6 +40,19 @@ describe('Input', () => {
|
|
|
34
40
|
expect(input).toBeInTheDocument();
|
|
35
41
|
});
|
|
36
42
|
|
|
43
|
+
it('calls CharactersCount component with correct props', () => {
|
|
44
|
+
const props = { ...baseProps, maxLength: 30 };
|
|
45
|
+
render(<Input {...props} />);
|
|
46
|
+
expect(CharactersCount).toHaveBeenCalledWith(
|
|
47
|
+
{
|
|
48
|
+
id: props.id,
|
|
49
|
+
maxLength: props.maxLength,
|
|
50
|
+
value: props.value,
|
|
51
|
+
},
|
|
52
|
+
{}
|
|
53
|
+
);
|
|
54
|
+
});
|
|
55
|
+
|
|
37
56
|
it('calls onChange with parsed value', () => {
|
|
38
57
|
const { container } = render(<Input {...baseProps} errors={undefined} />);
|
|
39
58
|
|
|
@@ -8,6 +8,8 @@ import {
|
|
|
8
8
|
} from '../shared/ComponentErrors/ComponentErrors';
|
|
9
9
|
import { Declarations } from '../shared/Declarations/Declarations';
|
|
10
10
|
import type { LunaticError } from '../../use-lunatic/type';
|
|
11
|
+
import { CharactersCount } from '../shared/CharactersCount/CharactersCount';
|
|
12
|
+
import { getCharactersCountId } from '../shared/utils/getCharactersCountId';
|
|
11
13
|
|
|
12
14
|
export function Input({
|
|
13
15
|
handleChanges,
|
|
@@ -47,6 +49,8 @@ export const CustomInput = slottableComponent<CustomProps>('Input', (props) => {
|
|
|
47
49
|
declarations,
|
|
48
50
|
} = props;
|
|
49
51
|
const labelId = `label-${id}`;
|
|
52
|
+
const charactersCountId = getCharactersCountId(id, maxLength);
|
|
53
|
+
|
|
50
54
|
return (
|
|
51
55
|
<div className={classnames('lunatic-input')}>
|
|
52
56
|
<Label htmlFor={id} id={labelId} description={description}>
|
|
@@ -57,24 +61,28 @@ export const CustomInput = slottableComponent<CustomProps>('Input', (props) => {
|
|
|
57
61
|
declarations={declarations}
|
|
58
62
|
id={id}
|
|
59
63
|
/>
|
|
60
|
-
<
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
64
|
+
<div className="field-with-count">
|
|
65
|
+
<input
|
|
66
|
+
id={id}
|
|
67
|
+
aria-labelledby={labelId}
|
|
68
|
+
aria-describedby={maxLength ? charactersCountId : undefined}
|
|
69
|
+
autoComplete="off"
|
|
70
|
+
type="text"
|
|
71
|
+
disabled={disabled}
|
|
72
|
+
readOnly={readOnly}
|
|
73
|
+
value={(value ?? '').toString()}
|
|
74
|
+
title={value ?? ''}
|
|
75
|
+
onChange={(e) => onChange(e.target.value)}
|
|
76
|
+
aria-required={required}
|
|
77
|
+
required={required}
|
|
78
|
+
maxLength={maxLength}
|
|
79
|
+
aria-invalid={!!errors}
|
|
80
|
+
onBlur={(e) => {
|
|
81
|
+
e.target.setSelectionRange(0, 0);
|
|
82
|
+
}}
|
|
83
|
+
/>
|
|
84
|
+
<CharactersCount id={id} maxLength={maxLength} value={value} />
|
|
85
|
+
</div>
|
|
78
86
|
<ComponentErrors errors={errors} />
|
|
79
87
|
</div>
|
|
80
88
|
);
|
|
@@ -16,15 +16,19 @@ exports[`Input > renders without crashing 1`] = `
|
|
|
16
16
|
description
|
|
17
17
|
</span>
|
|
18
18
|
</label>
|
|
19
|
-
<
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
19
|
+
<div
|
|
20
|
+
class="field-with-count"
|
|
21
|
+
>
|
|
22
|
+
<input
|
|
23
|
+
aria-invalid="false"
|
|
24
|
+
aria-labelledby="label-input"
|
|
25
|
+
autocomplete="off"
|
|
26
|
+
id="input"
|
|
27
|
+
title="input"
|
|
28
|
+
type="text"
|
|
29
|
+
value="input"
|
|
30
|
+
/>
|
|
31
|
+
</div>
|
|
28
32
|
</div>
|
|
29
33
|
</div>
|
|
30
34
|
`;
|
|
@@ -34,16 +38,20 @@ exports[`Input > should handle readOnly 1`] = `
|
|
|
34
38
|
<div
|
|
35
39
|
class="lunatic-input"
|
|
36
40
|
>
|
|
37
|
-
<
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
41
|
+
<div
|
|
42
|
+
class="field-with-count"
|
|
43
|
+
>
|
|
44
|
+
<input
|
|
45
|
+
aria-invalid="false"
|
|
46
|
+
aria-labelledby="label-number"
|
|
47
|
+
autocomplete="off"
|
|
48
|
+
id="number"
|
|
49
|
+
readonly=""
|
|
50
|
+
title="toto"
|
|
51
|
+
type="text"
|
|
52
|
+
value="toto"
|
|
53
|
+
/>
|
|
54
|
+
</div>
|
|
47
55
|
</div>
|
|
48
56
|
</div>
|
|
49
57
|
`;
|
|
@@ -31,16 +31,27 @@ exports[`RosterForLoop > renders the right number of columns 1`] = `
|
|
|
31
31
|
<div
|
|
32
32
|
class="lunatic-input"
|
|
33
33
|
>
|
|
34
|
-
<
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
34
|
+
<div
|
|
35
|
+
class="field-with-count"
|
|
36
|
+
>
|
|
37
|
+
<input
|
|
38
|
+
aria-describedby="characters-count-jrc3ye5q-QOP-lo6tcvvx-0"
|
|
39
|
+
aria-invalid="false"
|
|
40
|
+
aria-labelledby="label-jrc3ye5q-QOP-lo6tcvvx-0"
|
|
41
|
+
autocomplete="off"
|
|
42
|
+
id="jrc3ye5q-QOP-lo6tcvvx-0"
|
|
43
|
+
maxlength="249"
|
|
44
|
+
title="azeaze"
|
|
45
|
+
type="text"
|
|
46
|
+
value="azeaze"
|
|
47
|
+
/>
|
|
48
|
+
<span
|
|
49
|
+
class="characters-count"
|
|
50
|
+
id="characters-count-jrc3ye5q-QOP-lo6tcvvx-0"
|
|
51
|
+
>
|
|
52
|
+
6/249
|
|
53
|
+
</span>
|
|
54
|
+
</div>
|
|
44
55
|
</div>
|
|
45
56
|
</div>
|
|
46
57
|
</div>
|
|
@@ -61,16 +72,27 @@ exports[`RosterForLoop > renders the right number of columns 1`] = `
|
|
|
61
72
|
<div
|
|
62
73
|
class="lunatic-input"
|
|
63
74
|
>
|
|
64
|
-
<
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
75
|
+
<div
|
|
76
|
+
class="field-with-count"
|
|
77
|
+
>
|
|
78
|
+
<input
|
|
79
|
+
aria-describedby="characters-count-jrc3ye5q-QOP-lo6tcvvx-1"
|
|
80
|
+
aria-invalid="false"
|
|
81
|
+
aria-labelledby="label-jrc3ye5q-QOP-lo6tcvvx-1"
|
|
82
|
+
autocomplete="off"
|
|
83
|
+
id="jrc3ye5q-QOP-lo6tcvvx-1"
|
|
84
|
+
maxlength="249"
|
|
85
|
+
title="azeaze"
|
|
86
|
+
type="text"
|
|
87
|
+
value="azeaze"
|
|
88
|
+
/>
|
|
89
|
+
<span
|
|
90
|
+
class="characters-count"
|
|
91
|
+
id="characters-count-jrc3ye5q-QOP-lo6tcvvx-1"
|
|
92
|
+
>
|
|
93
|
+
6/249
|
|
94
|
+
</span>
|
|
95
|
+
</div>
|
|
74
96
|
</div>
|
|
75
97
|
</div>
|
|
76
98
|
</div>
|
|
@@ -1,6 +1,11 @@
|
|
|
1
1
|
import { render } from '@testing-library/react';
|
|
2
2
|
import { beforeEach, describe, expect, it, vi } from 'vitest';
|
|
3
3
|
import { Textarea } from './Textarea';
|
|
4
|
+
import { CharactersCount } from '../shared/CharactersCount/CharactersCount';
|
|
5
|
+
|
|
6
|
+
vi.mock('../shared/CharactersCount/CharactersCount', () => ({
|
|
7
|
+
CharactersCount: vi.fn(),
|
|
8
|
+
}));
|
|
4
9
|
|
|
5
10
|
describe('Textarea', () => {
|
|
6
11
|
const mockOnChange = vi.fn();
|
|
@@ -22,6 +27,19 @@ describe('Textarea', () => {
|
|
|
22
27
|
expect(container).toMatchSnapshot();
|
|
23
28
|
});
|
|
24
29
|
|
|
30
|
+
it('calls CharactersCount component with correct props', () => {
|
|
31
|
+
const props = { ...baseProps, maxLength: 30 };
|
|
32
|
+
render(<Textarea {...props} />);
|
|
33
|
+
expect(CharactersCount).toHaveBeenCalledWith(
|
|
34
|
+
{
|
|
35
|
+
id: props.id,
|
|
36
|
+
maxLength: props.maxLength,
|
|
37
|
+
value: props.value,
|
|
38
|
+
},
|
|
39
|
+
{}
|
|
40
|
+
);
|
|
41
|
+
});
|
|
42
|
+
|
|
25
43
|
it('should handle readOnly', () => {
|
|
26
44
|
const { container } = render(
|
|
27
45
|
<Textarea
|
|
@@ -7,6 +7,8 @@ import {
|
|
|
7
7
|
import { slottableComponent } from '../shared/HOC/slottableComponent';
|
|
8
8
|
import { Declarations } from '../shared/Declarations/Declarations';
|
|
9
9
|
import type { LunaticError } from '../../use-lunatic/type';
|
|
10
|
+
import { CharactersCount } from '../shared/CharactersCount/CharactersCount';
|
|
11
|
+
import { getCharactersCountId } from '../shared/utils/getCharactersCountId';
|
|
10
12
|
|
|
11
13
|
export function Textarea({
|
|
12
14
|
handleChanges,
|
|
@@ -51,6 +53,7 @@ export const CustomTextarea = slottableComponent<CustomProps>(
|
|
|
51
53
|
placeHolder,
|
|
52
54
|
} = props;
|
|
53
55
|
const labelId = `label-${id}`;
|
|
56
|
+
const charactersCountId = getCharactersCountId(id, maxLength);
|
|
54
57
|
|
|
55
58
|
return (
|
|
56
59
|
<div className="lunatic-textarea">
|
|
@@ -62,19 +65,24 @@ export const CustomTextarea = slottableComponent<CustomProps>(
|
|
|
62
65
|
declarations={declarations}
|
|
63
66
|
id={id}
|
|
64
67
|
/>
|
|
65
|
-
<
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
68
|
+
<div className="field-with-count">
|
|
69
|
+
<textarea
|
|
70
|
+
required={required}
|
|
71
|
+
disabled={disabled}
|
|
72
|
+
id={id}
|
|
73
|
+
aria-labelledby={labelId}
|
|
74
|
+
aria-describedby={maxLength ? charactersCountId : undefined}
|
|
75
|
+
rows={rows}
|
|
76
|
+
maxLength={maxLength}
|
|
77
|
+
cols={cols}
|
|
78
|
+
onChange={(e) => onChange(e.target.value)}
|
|
79
|
+
value={value ?? ''}
|
|
80
|
+
placeholder={placeHolder}
|
|
81
|
+
readOnly={readOnly}
|
|
82
|
+
aria-invalid={!!errors}
|
|
83
|
+
/>
|
|
84
|
+
<CharactersCount id={id} maxLength={maxLength} value={value} />
|
|
85
|
+
</div>
|
|
78
86
|
<ComponentErrors errors={errors} />
|
|
79
87
|
</div>
|
|
80
88
|
);
|
|
@@ -5,12 +5,17 @@ exports[`Textarea > renders without crashing 1`] = `
|
|
|
5
5
|
<div
|
|
6
6
|
class="lunatic-textarea"
|
|
7
7
|
>
|
|
8
|
-
<
|
|
9
|
-
|
|
10
|
-
id="input"
|
|
8
|
+
<div
|
|
9
|
+
class="field-with-count"
|
|
11
10
|
>
|
|
12
|
-
|
|
13
|
-
|
|
11
|
+
<textarea
|
|
12
|
+
aria-invalid="false"
|
|
13
|
+
aria-labelledby="label-input"
|
|
14
|
+
id="input"
|
|
15
|
+
>
|
|
16
|
+
input
|
|
17
|
+
</textarea>
|
|
18
|
+
</div>
|
|
14
19
|
</div>
|
|
15
20
|
</div>
|
|
16
21
|
`;
|
|
@@ -20,13 +25,18 @@ exports[`Textarea > should handle readOnly 1`] = `
|
|
|
20
25
|
<div
|
|
21
26
|
class="lunatic-textarea"
|
|
22
27
|
>
|
|
23
|
-
<
|
|
24
|
-
|
|
25
|
-
id="textarea"
|
|
26
|
-
readonly=""
|
|
28
|
+
<div
|
|
29
|
+
class="field-with-count"
|
|
27
30
|
>
|
|
28
|
-
|
|
29
|
-
|
|
31
|
+
<textarea
|
|
32
|
+
aria-invalid="false"
|
|
33
|
+
aria-labelledby="label-textarea"
|
|
34
|
+
id="textarea"
|
|
35
|
+
readonly=""
|
|
36
|
+
>
|
|
37
|
+
Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.
|
|
38
|
+
</textarea>
|
|
39
|
+
</div>
|
|
30
40
|
</div>
|
|
31
41
|
</div>
|
|
32
42
|
`;
|
|
@@ -0,0 +1,31 @@
|
|
|
1
|
+
import { describe, expect, it } from 'vitest';
|
|
2
|
+
import { CharactersCount } from './CharactersCount';
|
|
3
|
+
import { render } from '@testing-library/react';
|
|
4
|
+
|
|
5
|
+
describe('CharactersCount', () => {
|
|
6
|
+
const defaultProps = {
|
|
7
|
+
id: 'test-id',
|
|
8
|
+
maxLength: 20,
|
|
9
|
+
value: 'Hello',
|
|
10
|
+
};
|
|
11
|
+
|
|
12
|
+
it('renders correctly characters count if there is a maximum length', () => {
|
|
13
|
+
const { getByText } = render(<CharactersCount {...defaultProps} />);
|
|
14
|
+
|
|
15
|
+
expect(getByText('5/20')).toBeInTheDocument();
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
it('should apply the max-length-reached class when limit is reached', () => {
|
|
19
|
+
const props = { ...defaultProps, maxLength: 5 };
|
|
20
|
+
const { getByText } = render(<CharactersCount {...props} />);
|
|
21
|
+
|
|
22
|
+
expect(getByText('5/5')).toHaveClass('max-length-reached');
|
|
23
|
+
});
|
|
24
|
+
|
|
25
|
+
it('should not render anything when maxLength is not provided', () => {
|
|
26
|
+
const props = { ...defaultProps, maxLength: undefined };
|
|
27
|
+
const { container } = render(<CharactersCount {...props} />);
|
|
28
|
+
|
|
29
|
+
expect(container.firstChild).toBeNull();
|
|
30
|
+
});
|
|
31
|
+
});
|
|
@@ -0,0 +1,27 @@
|
|
|
1
|
+
import classNames from 'classnames';
|
|
2
|
+
import { getCharactersCountId } from '../utils/getCharactersCountId';
|
|
3
|
+
|
|
4
|
+
type Props = {
|
|
5
|
+
id: string;
|
|
6
|
+
maxLength?: number;
|
|
7
|
+
value?: string | null;
|
|
8
|
+
};
|
|
9
|
+
|
|
10
|
+
export function CharactersCount({ id, maxLength, value }: Readonly<Props>) {
|
|
11
|
+
if (!maxLength) return null;
|
|
12
|
+
|
|
13
|
+
const currentLength = value?.length ?? 0;
|
|
14
|
+
const charactersCountId = getCharactersCountId(id, maxLength);
|
|
15
|
+
const hasReachedMaxLength = currentLength === maxLength;
|
|
16
|
+
|
|
17
|
+
return (
|
|
18
|
+
<span
|
|
19
|
+
id={charactersCountId}
|
|
20
|
+
className={classNames('characters-count', {
|
|
21
|
+
'max-length-reached': hasReachedMaxLength,
|
|
22
|
+
})}
|
|
23
|
+
>
|
|
24
|
+
{`${currentLength}/${maxLength}`}
|
|
25
|
+
</span>
|
|
26
|
+
);
|
|
27
|
+
}
|