@digigov/form 2.0.0-113e6661 → 2.0.0-36b707c1

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.
Files changed (38) hide show
  1. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -1
  2. package/cjs/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
  3. package/cjs/inputs/AutoCompleteInput/index.js +3 -2
  4. package/cjs/inputs/AutoCompleteInput/index.js.map +2 -2
  5. package/cjs/inputs/ImageInput/ImageInput.stories/index.js +4 -4
  6. package/cjs/inputs/ImageInput/ImageInput.stories.js.map +2 -2
  7. package/cjs/inputs/ImageInput/__stories__/MaxSize/index.js +69 -0
  8. package/cjs/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
  9. package/cjs/inputs/inputsScenarios/index.js +0 -1
  10. package/cjs/inputs/inputsScenarios.js.map +2 -2
  11. package/cjs/validators/utils/file/index.js +1 -1
  12. package/cjs/validators/utils/file.js.map +2 -2
  13. package/index.js +1 -1
  14. package/inputs/AutoCompleteInput/__stories__/Multiple/index.js +0 -1
  15. package/inputs/AutoCompleteInput/__stories__/Multiple.js.map +2 -2
  16. package/inputs/AutoCompleteInput/index.js +3 -2
  17. package/inputs/AutoCompleteInput/index.js.map +2 -2
  18. package/inputs/ImageInput/ImageInput.stories/index.js +2 -2
  19. package/inputs/ImageInput/ImageInput.stories.d.ts +1 -1
  20. package/inputs/ImageInput/ImageInput.stories.js.map +2 -2
  21. package/inputs/ImageInput/__stories__/MaxSize/index.js +36 -0
  22. package/inputs/ImageInput/__stories__/MaxSize/package.json +6 -0
  23. package/inputs/ImageInput/__stories__/MaxSize.d.ts +3 -0
  24. package/inputs/ImageInput/__stories__/MaxSize.js.map +7 -0
  25. package/inputs/inputsScenarios/index.js +0 -1
  26. package/inputs/inputsScenarios.d.ts +0 -42
  27. package/inputs/inputsScenarios.js.map +2 -2
  28. package/package.json +4 -4
  29. package/src/FormBuilder/scenarios.test.tsx +2 -2
  30. package/src/inputs/AutoCompleteInput/__stories__/Multiple.tsx +0 -1
  31. package/src/inputs/AutoCompleteInput/index.tsx +3 -2
  32. package/src/inputs/ImageInput/ImageInput.stories.js +2 -1
  33. package/src/inputs/ImageInput/__stories__/MaxSize.tsx +37 -0
  34. package/src/inputs/ImageInput/index.test.tsx +4 -0
  35. package/src/inputs/inputsScenarios.ts +147 -148
  36. package/src/validators/utils/file.ts +1 -1
  37. package/validators/utils/file/index.js +1 -1
  38. package/validators/utils/file.js.map +2 -2
@@ -34,7 +34,6 @@ export declare const INPUTS_FIELDS: ({
34
34
  value: string;
35
35
  }[];
36
36
  component?: undefined;
37
- multiple?: undefined;
38
37
  };
39
38
  maxLength?: undefined;
40
39
  } | {
@@ -47,7 +46,6 @@ export declare const INPUTS_FIELDS: ({
47
46
  };
48
47
  extra: {
49
48
  component: string;
50
- multiple: boolean;
51
49
  options: {
52
50
  label: {
53
51
  primary: string;
@@ -56,25 +54,6 @@ export declare const INPUTS_FIELDS: ({
56
54
  }[];
57
55
  };
58
56
  maxLength?: undefined;
59
- } | {
60
- key: string;
61
- type: string;
62
- required: boolean;
63
- label: {
64
- primary: string;
65
- secondary?: undefined;
66
- };
67
- extra: {
68
- component: string;
69
- options: {
70
- label: {
71
- primary: string;
72
- };
73
- value: string;
74
- }[];
75
- multiple?: undefined;
76
- };
77
- maxLength?: undefined;
78
57
  } | {
79
58
  key: string;
80
59
  type: string;
@@ -125,7 +104,6 @@ export declare const scenarios: ({
125
104
  value: string;
126
105
  }[];
127
106
  component?: undefined;
128
- multiple?: undefined;
129
107
  };
130
108
  maxLength?: undefined;
131
109
  } | {
@@ -136,25 +114,6 @@ export declare const scenarios: ({
136
114
  primary: string;
137
115
  secondary?: undefined;
138
116
  };
139
- extra: {
140
- component: string;
141
- multiple: boolean;
142
- options: {
143
- label: {
144
- primary: string;
145
- };
146
- value: string;
147
- }[];
148
- };
149
- maxLength?: undefined;
150
- } | {
151
- key: string;
152
- type: string;
153
- required: boolean;
154
- label: {
155
- primary: string;
156
- secondary?: undefined;
157
- };
158
117
  extra: {
159
118
  component: string;
160
119
  options: {
@@ -163,7 +122,6 @@ export declare const scenarios: ({
163
122
  };
164
123
  value: string;
165
124
  }[];
166
- multiple?: undefined;
167
125
  };
168
126
  maxLength?: undefined;
169
127
  } | {
@@ -1,7 +1,7 @@
1
1
  {
2
2
  "version": 3,
3
3
  "sources": ["../../src/inputs/inputsScenarios.ts"],
4
- "sourcesContent": ["import el from '@digigov/form/locales/el';\n\nexport const INPUTS_FIELDS = [\n {\n key: 'date-example',\n type: 'date',\n required: true,\n label: {\n primary: '\u03A0\u03BF\u03B9\u03AC \u03B5\u03AF\u03BD\u03B1\u03B9 \u03B7 \u03B7\u03BC\u03B5\u03C1\u03BF\u03BC\u03B7\u03BD\u03AF\u03B1 \u03B3\u03AD\u03BD\u03BD\u03B7\u03C3\u03AE\u03C2 \u03C3\u03B1\u03C2;',\n secondary:\n '\u0393\u03B9\u03B1 \u03C0\u03B1\u03C1\u03AC\u03B4\u03B5\u03B9\u03B3\u03BC\u03B1, 05 11 2020',\n },\n },\n {\n key: 'otp',\n type: 'otp',\n maxLength: 6,\n label: {\n primary: '\u03A3\u03C5\u03BC\u03C0\u03BB\u03B7\u03C1\u03CE\u03C3\u03C4\u03B5 \u03C4\u03BF\u03BD \u03BA\u03C9\u03B4\u03B9\u03BA\u03CC \u03B5\u03C0\u03B9\u03B2\u03B5\u03B2\u03B1\u03AF\u03C9\u03C3\u03B7\u03C2',\n },\n required: true,\n },\n {\n key: 'checkbox',\n type: 'choice:multiple',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'autocomplete_multiple',\n required: true,\n type: 'choice:multiple',\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'AutoComplete',\n multiple: true,\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n },\n },\n {\n key: 'radio',\n type: 'choice:single',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'select',\n type: 'choice:single',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'Select',\n options: [\n {\n label: { primary: '' },\n value: '',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'autocomplete_single',\n required: true,\n type: 'choice:single',\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'AutoComplete',\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n },\n },\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n },\n {\n key: 'file',\n type: 'file',\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03BF \u03B1\u03C1\u03C7\u03B5\u03AF\u03BF \u03C4\u03B7\u03C2 \u03B1\u03C0\u03CC\u03B4\u03B5\u03B9\u03BE\u03B7\u03C2',\n },\n required: true,\n },\n ]\n\nexport const scenarios = [\n {\n title: 'success fill for inputs',\n describe: 'inputs scenario',\n fields: INPUTS_FIELDS,\n fill: [\n {\n fieldKey: 'date-example',\n value: {\n day: '22',\n month: '11',\n year: '2020'\n },\n },\n {\n fieldKey: 'otp',\n value: {\n '0': '4',\n '1': '4',\n '2': '4',\n '3': '4',\n '4': '4',\n '5': '4',\n }\n },\n {\n fieldKey: 'checkbox',\n value: [\n 'fever', 'fatigue'\n ]\n },\n {\n fieldKey: 'autocomplete_multiple',\n value: [\n 'fever', 'fatigue'\n ]\n },\n {\n fieldKey: 'radio',\n value: 'fever'\n },\n {\n fieldKey: 'select',\n value: 'fatigue'\n },\n {\n fieldKey: 'autocomplete_single',\n value: 'fatigue'\n },\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n width: 500,\n height: 500,\n size: 3\n }\n },\n {\n fieldKey: 'file',\n value: {\n fileName: 'file.txt',\n size: 200\n }\n },\n ],\n expect: [\n {\n type: 'success',\n fieldKey: 'date-example',\n text: el.form.error.date.invalid,\n },\n {\n type: 'success',\n fieldKey: 'otp',\n args: {\n 'maxLength': 6\n },\n text: el.form.error.otp.less_than,\n },\n {\n type: 'success',\n fieldKey: 'checkbox',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'autocomplete_multiple',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'radio',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'select',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'autocomplete_single',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'image',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'file',\n text: el.form.error.required,\n },\n ]\n },\n {\n title: 'empty fill for inputs',\n describe: 'inputs scenario',\n fields: INPUTS_FIELDS,\n fill: [],\n expect: [\n {\n type: 'error',\n fieldKey: 'date-example',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'otp',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'checkbox',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'autocomplete_multiple',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'radio',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'select',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'autocomplete_single',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'image',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'file',\n text: el.form.error.required,\n },\n ]\n },\n {\n title: 'incorrect types for DateInput and OtpInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'date-example',\n type: 'date',\n required: true,\n label: {\n primary: '\u03A0\u03BF\u03B9\u03AC \u03B5\u03AF\u03BD\u03B1\u03B9 \u03B7 \u03B7\u03BC\u03B5\u03C1\u03BF\u03BC\u03B7\u03BD\u03AF\u03B1 \u03B3\u03AD\u03BD\u03BD\u03B7\u03C3\u03AE\u03C2 \u03C3\u03B1\u03C2;',\n secondary:\n '\u0393\u03B9\u03B1 \u03C0\u03B1\u03C1\u03AC\u03B4\u03B5\u03B9\u03B3\u03BC\u03B1, 05 11 2020',\n },\n },\n {\n key: 'otp',\n type: 'otp',\n maxLength: 6,\n label: {\n primary: '\u03A3\u03C5\u03BC\u03C0\u03BB\u03B7\u03C1\u03CE\u03C3\u03C4\u03B5 \u03C4\u03BF\u03BD \u03BA\u03C9\u03B4\u03B9\u03BA\u03CC \u03B5\u03C0\u03B9\u03B2\u03B5\u03B2\u03B1\u03AF\u03C9\u03C3\u03B7\u03C2',\n },\n required: true,\n },\n ],\n fill: [\n {\n fieldKey: 'date-example',\n value: {\n day: 'a2',\n month: '11',\n year: '2020'\n },\n },\n {\n fieldKey: 'otp',\n value: {\n '0': 'a',\n '1': '4',\n '2': '4',\n '3': '4',\n '4': '4',\n '5': '4',\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'date-example',\n text: el.form.error.date.invalid,\n },\n {\n type: 'error',\n fieldKey: 'otp',\n args: {\n 'maxLength': 6\n },\n text: el.form.error.otp.less_than,\n },\n ]\n },\n {\n title: 'wrong sizes for ImageInput and FileInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n extra: {\n limit: {\n maxSize: 300,\n },\n },\n },\n {\n key: 'file',\n type: 'file',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03BF \u03B1\u03C1\u03C7\u03B5\u03AF\u03BF \u03C4\u03B7\u03C2 \u03B1\u03C0\u03CC\u03B4\u03B5\u03B9\u03BE\u03B7\u03C2',\n },\n extra: {\n limit: {\n maxSize: 300,\n },\n },\n },\n ],\n fill: [\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n size: 300\n }\n },\n {\n fieldKey: 'file',\n value: {\n fileName: 'file.txt',\n size: 200\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'image',\n args: {\n maxSizeToMb: 0.0003\n },\n text: el.form.error.file_size,\n },\n {\n type: 'error',\n fieldKey: 'file',\n args: {\n maxSizeToMb: 0.0003\n },\n text: el.form.error.file_size,\n },\n ]\n },\n {\n title: 'wrong dimensions for ImageInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n extra: {\n limit: {\n maxHeight: 400,\n maxWidth: 400,\n minHeight: 100,\n minWidth: 100,\n },\n },\n },\n ],\n fill: [\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n width: 500,\n height: 500\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'image',\n args: {\n minWidth: 100,\n minHeight: 100,\n maxWidth: 400,\n maxHeight: 400,\n },\n text: el.form.error.image.image_dimension_size,\n },\n ]\n },\n]\n\nexport default scenarios;"],
5
- "mappings": "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",
4
+ "sourcesContent": ["import el from '@digigov/form/locales/el';\n\nexport const INPUTS_FIELDS = [\n {\n key: 'date-example',\n type: 'date',\n required: true,\n label: {\n primary: '\u03A0\u03BF\u03B9\u03AC \u03B5\u03AF\u03BD\u03B1\u03B9 \u03B7 \u03B7\u03BC\u03B5\u03C1\u03BF\u03BC\u03B7\u03BD\u03AF\u03B1 \u03B3\u03AD\u03BD\u03BD\u03B7\u03C3\u03AE\u03C2 \u03C3\u03B1\u03C2;',\n secondary:\n '\u0393\u03B9\u03B1 \u03C0\u03B1\u03C1\u03AC\u03B4\u03B5\u03B9\u03B3\u03BC\u03B1, 05 11 2020',\n },\n },\n {\n key: 'otp',\n type: 'otp',\n maxLength: 6,\n label: {\n primary: '\u03A3\u03C5\u03BC\u03C0\u03BB\u03B7\u03C1\u03CE\u03C3\u03C4\u03B5 \u03C4\u03BF\u03BD \u03BA\u03C9\u03B4\u03B9\u03BA\u03CC \u03B5\u03C0\u03B9\u03B2\u03B5\u03B2\u03B1\u03AF\u03C9\u03C3\u03B7\u03C2',\n },\n required: true,\n },\n {\n key: 'checkbox',\n type: 'choice:multiple',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'autocomplete_multiple',\n required: true,\n type: 'choice:multiple',\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'AutoComplete',\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n },\n },\n {\n key: 'radio',\n type: 'choice:single',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'select',\n type: 'choice:single',\n required: true,\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'Select',\n options: [\n {\n label: { primary: '' },\n value: '',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n }\n },\n {\n key: 'autocomplete_single',\n required: true,\n type: 'choice:single',\n label: { primary: '\u03A0\u03CE\u03C2 \u03B1\u03B9\u03C3\u03B8\u03AC\u03BD\u03B5\u03C3\u03C4\u03B5 \u03B1\u03C5\u03C4\u03AE \u03C4\u03B7 \u03C3\u03C4\u03B9\u03B3\u03BC\u03AE;' },\n extra: {\n component: 'AutoComplete',\n options: [\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C3\u03C5\u03BD\u03AC\u03C7\u03B9' },\n value: 'runny-nose',\n },\n {\n label: { primary: '\u0388\u03C7\u03C9 \u03C0\u03C5\u03C1\u03B5\u03C4\u03CC' },\n value: 'fever',\n },\n {\n label: { primary: '\u0391\u03B9\u03C3\u03B8\u03AC\u03BD\u03BF\u03BC\u03B1\u03B9 \u03BA\u03BF\u03CD\u03C1\u03B1\u03C3\u03B7' },\n value: 'fatigue',\n },\n ],\n },\n },\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n },\n {\n key: 'file',\n type: 'file',\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03BF \u03B1\u03C1\u03C7\u03B5\u03AF\u03BF \u03C4\u03B7\u03C2 \u03B1\u03C0\u03CC\u03B4\u03B5\u03B9\u03BE\u03B7\u03C2',\n },\n required: true,\n },\n]\n\nexport const scenarios = [\n {\n title: 'success fill for inputs',\n describe: 'inputs scenario',\n fields: INPUTS_FIELDS,\n fill: [\n {\n fieldKey: 'date-example',\n value: {\n day: '22',\n month: '11',\n year: '2020'\n },\n },\n {\n fieldKey: 'otp',\n value: {\n '0': '4',\n '1': '4',\n '2': '4',\n '3': '4',\n '4': '4',\n '5': '4',\n }\n },\n {\n fieldKey: 'checkbox',\n value: [\n 'fever', 'fatigue'\n ]\n },\n {\n fieldKey: 'autocomplete_multiple',\n value: [\n 'fever', 'fatigue'\n ]\n },\n {\n fieldKey: 'radio',\n value: 'fever'\n },\n {\n fieldKey: 'select',\n value: 'fatigue'\n },\n {\n fieldKey: 'autocomplete_single',\n value: 'fatigue'\n },\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n width: 500,\n height: 500,\n size: 3\n }\n },\n {\n fieldKey: 'file',\n value: {\n fileName: 'file.txt',\n size: 200\n }\n },\n ],\n expect: [\n {\n type: 'success',\n fieldKey: 'date-example',\n text: el.form.error.date.invalid,\n },\n {\n type: 'success',\n fieldKey: 'otp',\n args: {\n 'maxLength': 6\n },\n text: el.form.error.otp.less_than,\n },\n {\n type: 'success',\n fieldKey: 'checkbox',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'autocomplete_multiple',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'radio',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'select',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'autocomplete_single',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'image',\n text: el.form.error.required,\n },\n {\n type: 'success',\n fieldKey: 'file',\n text: el.form.error.required,\n },\n ]\n },\n {\n title: 'empty fill for inputs',\n describe: 'inputs scenario',\n fields: INPUTS_FIELDS,\n fill: [],\n expect: [\n {\n type: 'error',\n fieldKey: 'date-example',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'otp',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'checkbox',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'autocomplete_multiple',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'radio',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'select',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'autocomplete_single',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'image',\n text: el.form.error.required,\n },\n {\n type: 'error',\n fieldKey: 'file',\n text: el.form.error.required,\n },\n ]\n },\n {\n title: 'incorrect types for DateInput and OtpInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'date-example',\n type: 'date',\n required: true,\n label: {\n primary: '\u03A0\u03BF\u03B9\u03AC \u03B5\u03AF\u03BD\u03B1\u03B9 \u03B7 \u03B7\u03BC\u03B5\u03C1\u03BF\u03BC\u03B7\u03BD\u03AF\u03B1 \u03B3\u03AD\u03BD\u03BD\u03B7\u03C3\u03AE\u03C2 \u03C3\u03B1\u03C2;',\n secondary:\n '\u0393\u03B9\u03B1 \u03C0\u03B1\u03C1\u03AC\u03B4\u03B5\u03B9\u03B3\u03BC\u03B1, 05 11 2020',\n },\n },\n {\n key: 'otp',\n type: 'otp',\n maxLength: 6,\n label: {\n primary: '\u03A3\u03C5\u03BC\u03C0\u03BB\u03B7\u03C1\u03CE\u03C3\u03C4\u03B5 \u03C4\u03BF\u03BD \u03BA\u03C9\u03B4\u03B9\u03BA\u03CC \u03B5\u03C0\u03B9\u03B2\u03B5\u03B2\u03B1\u03AF\u03C9\u03C3\u03B7\u03C2',\n },\n required: true,\n },\n ],\n fill: [\n {\n fieldKey: 'date-example',\n value: {\n day: 'a2',\n month: '11',\n year: '2020'\n },\n },\n {\n fieldKey: 'otp',\n value: {\n '0': 'a',\n '1': '4',\n '2': '4',\n '3': '4',\n '4': '4',\n '5': '4',\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'date-example',\n text: el.form.error.date.invalid,\n },\n {\n type: 'error',\n fieldKey: 'otp',\n args: {\n 'maxLength': 6\n },\n text: el.form.error.otp.less_than,\n },\n ]\n },\n {\n title: 'wrong sizes for ImageInput and FileInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n extra: {\n limit: {\n maxSize: 300,\n },\n },\n },\n {\n key: 'file',\n type: 'file',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03BF \u03B1\u03C1\u03C7\u03B5\u03AF\u03BF \u03C4\u03B7\u03C2 \u03B1\u03C0\u03CC\u03B4\u03B5\u03B9\u03BE\u03B7\u03C2',\n },\n extra: {\n limit: {\n maxSize: 300,\n },\n },\n },\n ],\n fill: [\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n size: 300\n }\n },\n {\n fieldKey: 'file',\n value: {\n fileName: 'file.txt',\n size: 200\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'image',\n args: {\n maxSizeToMb: 0.0003\n },\n text: el.form.error.file_size,\n },\n {\n type: 'error',\n fieldKey: 'file',\n args: {\n maxSizeToMb: 0.0003\n },\n text: el.form.error.file_size,\n },\n ]\n },\n {\n title: 'wrong dimensions for ImageInput',\n describe: 'inputs scenario',\n fields: [\n {\n key: 'image',\n type: 'image',\n required: true,\n label: {\n primary: '\u0391\u03BD\u03B5\u03B2\u03AC\u03C3\u03C4\u03B5 \u03C4\u03B7 \u03C6\u03C9\u03C4\u03BF\u03B3\u03C1\u03B1\u03C6\u03AF\u03B1 \u03C4\u03BF\u03C5 \u03C0\u03C1\u03BF\u03C3\u03C4\u03AF\u03BC\u03BF\u03C5',\n },\n extra: {\n limit: {\n maxHeight: 400,\n maxWidth: 400,\n minHeight: 100,\n minWidth: 100,\n },\n },\n },\n ],\n fill: [\n {\n fieldKey: 'image',\n value: {\n fileName: 'green_image.png',\n width: 500,\n height: 500\n }\n },\n ],\n expect: [\n {\n type: 'error',\n fieldKey: 'image',\n args: {\n minWidth: 100,\n minHeight: 100,\n maxWidth: 400,\n maxHeight: 400,\n },\n text: el.form.error.image.image_dimension_size,\n },\n ]\n },\n]\n\nexport default scenarios;"],
5
+ "mappings": "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",
6
6
  "names": []
7
7
  }
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@digigov/form",
3
- "version": "2.0.0-113e6661",
3
+ "version": "2.0.0-36b707c1",
4
4
  "description": "@digigov form builder",
5
5
  "author": "GRNET Developers <devs@lists.grnet.gr>",
6
6
  "license": "BSD-2-Clause",
@@ -14,11 +14,11 @@
14
14
  "yup": "0.32.11",
15
15
  "dayjs": "1.10.4",
16
16
  "@hookform/resolvers": "3.9.0",
17
- "@digigov/react-icons": "2.0.0-113e6661"
17
+ "@digigov/react-icons": "2.0.0-36b707c1"
18
18
  },
19
19
  "peerDependencies": {
20
- "@digigov/ui": "2.0.0-113e6661",
21
- "@digigov/react-core": "2.0.0-113e6661",
20
+ "@digigov/ui": "2.0.0-36b707c1",
21
+ "@digigov/react-core": "2.0.0-36b707c1",
22
22
  "clsx": "1.1.1",
23
23
  "react": ">=16.8.0 <19.0.0",
24
24
  "react-dom": ">=16.8.0 <19.0.0"
@@ -1120,7 +1120,7 @@ const inputsScenarios = [
1120
1120
  args: {
1121
1121
  maxSizeToMb: 0.0003,
1122
1122
  },
1123
- text: el.form.error.file_size,
1123
+ text: el.form.error.image_size,
1124
1124
  },
1125
1125
  {
1126
1126
  type: 'error',
@@ -1847,7 +1847,7 @@ for (const scenario of scenarios) {
1847
1847
  test(scenario.title, async ({ mount, page }) => {
1848
1848
  const formBuilder = await mount(
1849
1849
  // @ts-ignore
1850
- <FormBuilder auto={true} fields={scenario.fields} onSubmit={() => {}} />
1850
+ <FormBuilder auto={true} fields={scenario.fields} onSubmit={() => { }} />
1851
1851
  );
1852
1852
  await fillFields(page, formBuilder, scenario);
1853
1853
  await submitForm(formBuilder);
@@ -20,7 +20,6 @@ const fields: FieldSpec[] = [
20
20
  type: 'choice:multiple',
21
21
  extra: {
22
22
  component: 'AutoComplete',
23
- multiple: true,
24
23
  options: results.map((r) => {
25
24
  return {
26
25
  label: {
@@ -29,7 +29,8 @@ export interface AutoCompleteInputProps
29
29
 
30
30
  export const AutoCompleteInput: React.FC<AutoCompleteInputProps> = ({
31
31
  name,
32
- extra: { options, multiple },
32
+ type,
33
+ extra: { options },
33
34
  onChange,
34
35
  value,
35
36
  error,
@@ -56,7 +57,7 @@ export const AutoCompleteInput: React.FC<AutoCompleteInputProps> = ({
56
57
 
57
58
  return (
58
59
  <UIAutoComplete
59
- multiple={multiple}
60
+ multiple={type === 'choice:multiple' ? true : false}
60
61
  source={suggest}
61
62
  onConfirm={(value) => {
62
63
  if (Array.isArray(value)) {
@@ -5,5 +5,6 @@ export default {
5
5
  displayName: 'ImageInput',
6
6
  };
7
7
  export { Default } from '@digigov/form/inputs/ImageInput/__stories__/Default';
8
- export { WithInvalidImageSize } from '@digigov/form/inputs/ImageInput/__stories__/WithInvalidImageSize';
9
8
  export { WithInvalidImageDimension } from '@digigov/form/inputs/ImageInput/__stories__/WithInvalidImageDimension';
9
+ export { MaxSize } from '@digigov/form/inputs/ImageInput/__stories__/MaxSize';
10
+
@@ -0,0 +1,37 @@
1
+ import React from 'react';
2
+ import FormBuilder, { Field, Fieldset } from '@digigov/form';
3
+ import { FieldSpec } from '@digigov/form/types';
4
+ import { Button } from '@digigov/ui/form/Button';
5
+ const FIELDS: FieldSpec[] = [
6
+ {
7
+ key: 'image',
8
+ type: 'image',
9
+ required: true,
10
+ label: {
11
+ primary: 'Ανέβασμα φωτογραφίας',
12
+ secondary: 'Μέγιστο μέγεθος φωτογραφίας: 10KB.',
13
+ },
14
+ extra: {
15
+ limit: {
16
+ maxSize: 1000,
17
+ },
18
+ }
19
+ },
20
+ ];
21
+
22
+ export const MaxSize = () => (
23
+ <FormBuilder
24
+ fields={FIELDS}
25
+ onSubmit={(data) => {
26
+ console.log(data);
27
+ }}
28
+ >
29
+ <Fieldset>
30
+ {FIELDS.map((field) => (
31
+ <Field key={field.key} name={field.key} />
32
+ ))}
33
+ </Fieldset>
34
+ <Button type="submit">Συνέχεια</Button>
35
+ </FormBuilder>
36
+ );
37
+ export default MaxSize;
@@ -2,6 +2,7 @@ import React from 'react';
2
2
  import { test, expect } from '@playwright/experimental-ct-react';
3
3
  import TestVariant from '@digigov/ui/utils/TestVariant'
4
4
  import { Default } from '@digigov/form/inputs/ImageInput/__stories__/Default';
5
+ import { MaxSize } from '@digigov/form/inputs/ImageInput/__stories__/MaxSize';
5
6
  import { WithInvalidImageDimension } from '@digigov/form/inputs/ImageInput/__stories__/WithInvalidImageDimension';
6
7
  import { WithInvalidImageSize } from '@digigov/form/inputs/ImageInput/__stories__/WithInvalidImageSize';
7
8
 
@@ -12,6 +13,9 @@ test('renders the All ImageInput variants', async ({ mount, page }) => {
12
13
  <TestVariant title="Default">
13
14
  <Default />
14
15
  </TestVariant>
16
+ <TestVariant title="MaxSize">
17
+ <MaxSize />
18
+ </TestVariant>
15
19
  <TestVariant title="WithInvalidImageDimension">
16
20
  <WithInvalidImageDimension />
17
21
  </TestVariant>
@@ -1,160 +1,159 @@
1
1
  import el from '@digigov/form/locales/el';
2
2
 
3
3
  export const INPUTS_FIELDS = [
4
- {
5
- key: 'date-example',
6
- type: 'date',
7
- required: true,
8
- label: {
9
- primary: 'Ποιά είναι η ημερομηνία γέννησής σας;',
10
- secondary:
11
- 'Για παράδειγμα, 05 11 2020',
12
- },
13
- },
14
- {
15
- key: 'otp',
16
- type: 'otp',
17
- maxLength: 6,
18
- label: {
19
- primary: 'Συμπληρώστε τον κωδικό επιβεβαίωσης',
20
- },
21
- required: true,
22
- },
23
- {
24
- key: 'checkbox',
25
- type: 'choice:multiple',
26
- required: true,
27
- label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
28
- extra: {
29
- options: [
30
- {
31
- label: { primary: 'Έχω συνάχι' },
32
- value: 'runny-nose',
33
- },
34
- {
35
- label: { primary: 'Έχω πυρετό' },
36
- value: 'fever',
37
- },
38
- {
39
- label: { primary: 'Αισθάνομαι κούραση' },
40
- value: 'fatigue',
41
- },
42
- ],
43
- }
44
- },
45
- {
46
- key: 'autocomplete_multiple',
47
- required: true,
48
- type: 'choice:multiple',
49
- label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
50
- extra: {
51
- component: 'AutoComplete',
52
- multiple: true,
53
- options: [
54
- {
55
- label: { primary: 'Έχω συνάχι' },
56
- value: 'runny-nose',
57
- },
58
- {
59
- label: { primary: 'Έχω πυρετό' },
60
- value: 'fever',
61
- },
62
- {
63
- label: { primary: 'Αισθάνομαι κούραση' },
64
- value: 'fatigue',
65
- },
66
- ],
67
- },
4
+ {
5
+ key: 'date-example',
6
+ type: 'date',
7
+ required: true,
8
+ label: {
9
+ primary: 'Ποιά είναι η ημερομηνία γέννησής σας;',
10
+ secondary:
11
+ 'Για παράδειγμα, 05 11 2020',
68
12
  },
69
- {
70
- key: 'radio',
71
- type: 'choice:single',
72
- required: true,
73
- label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
74
- extra: {
75
- options: [
76
- {
77
- label: { primary: 'Έχω συνάχι' },
78
- value: 'runny-nose',
79
- },
80
- {
81
- label: { primary: 'Έχω πυρετό' },
82
- value: 'fever',
83
- },
84
- {
85
- label: { primary: 'Αισθάνομαι κούραση' },
86
- value: 'fatigue',
87
- },
88
- ],
89
- }
13
+ },
14
+ {
15
+ key: 'otp',
16
+ type: 'otp',
17
+ maxLength: 6,
18
+ label: {
19
+ primary: 'Συμπληρώστε τον κωδικό επιβεβαίωσης',
90
20
  },
91
- {
92
- key: 'select',
93
- type: 'choice:single',
94
- required: true,
95
- label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
96
- extra: {
97
- component: 'Select',
98
- options: [
99
- {
100
- label: { primary: '' },
101
- value: '',
102
- },
103
- {
104
- label: { primary: 'Έχω συνάχι' },
105
- value: 'runny-nose',
106
- },
107
- {
108
- label: { primary: 'Έχω πυρετό' },
109
- value: 'fever',
110
- },
111
- {
112
- label: { primary: 'Αισθάνομαι κούραση' },
113
- value: 'fatigue',
114
- },
115
- ],
116
- }
21
+ required: true,
22
+ },
23
+ {
24
+ key: 'checkbox',
25
+ type: 'choice:multiple',
26
+ required: true,
27
+ label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
28
+ extra: {
29
+ options: [
30
+ {
31
+ label: { primary: 'Έχω συνάχι' },
32
+ value: 'runny-nose',
33
+ },
34
+ {
35
+ label: { primary: 'Έχω πυρετό' },
36
+ value: 'fever',
37
+ },
38
+ {
39
+ label: { primary: 'Αισθάνομαι κούραση' },
40
+ value: 'fatigue',
41
+ },
42
+ ],
43
+ }
44
+ },
45
+ {
46
+ key: 'autocomplete_multiple',
47
+ required: true,
48
+ type: 'choice:multiple',
49
+ label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
50
+ extra: {
51
+ component: 'AutoComplete',
52
+ options: [
53
+ {
54
+ label: { primary: 'Έχω συνάχι' },
55
+ value: 'runny-nose',
56
+ },
57
+ {
58
+ label: { primary: 'Έχω πυρετό' },
59
+ value: 'fever',
60
+ },
61
+ {
62
+ label: { primary: 'Αισθάνομαι κούραση' },
63
+ value: 'fatigue',
64
+ },
65
+ ],
117
66
  },
118
- {
119
- key: 'autocomplete_single',
120
- required: true,
121
- type: 'choice:single',
122
- label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
123
- extra: {
124
- component: 'AutoComplete',
125
- options: [
126
- {
127
- label: { primary: 'Έχω συνάχι' },
128
- value: 'runny-nose',
129
- },
130
- {
131
- label: { primary: 'Έχω πυρετό' },
132
- value: 'fever',
133
- },
134
- {
135
- label: { primary: 'Αισθάνομαι κούραση' },
136
- value: 'fatigue',
137
- },
138
- ],
139
- },
67
+ },
68
+ {
69
+ key: 'radio',
70
+ type: 'choice:single',
71
+ required: true,
72
+ label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
73
+ extra: {
74
+ options: [
75
+ {
76
+ label: { primary: 'Έχω συνάχι' },
77
+ value: 'runny-nose',
78
+ },
79
+ {
80
+ label: { primary: 'Έχω πυρετό' },
81
+ value: 'fever',
82
+ },
83
+ {
84
+ label: { primary: 'Αισθάνομαι κούραση' },
85
+ value: 'fatigue',
86
+ },
87
+ ],
88
+ }
89
+ },
90
+ {
91
+ key: 'select',
92
+ type: 'choice:single',
93
+ required: true,
94
+ label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
95
+ extra: {
96
+ component: 'Select',
97
+ options: [
98
+ {
99
+ label: { primary: '' },
100
+ value: '',
101
+ },
102
+ {
103
+ label: { primary: 'Έχω συνάχι' },
104
+ value: 'runny-nose',
105
+ },
106
+ {
107
+ label: { primary: 'Έχω πυρετό' },
108
+ value: 'fever',
109
+ },
110
+ {
111
+ label: { primary: 'Αισθάνομαι κούραση' },
112
+ value: 'fatigue',
113
+ },
114
+ ],
115
+ }
116
+ },
117
+ {
118
+ key: 'autocomplete_single',
119
+ required: true,
120
+ type: 'choice:single',
121
+ label: { primary: 'Πώς αισθάνεστε αυτή τη στιγμή;' },
122
+ extra: {
123
+ component: 'AutoComplete',
124
+ options: [
125
+ {
126
+ label: { primary: 'Έχω συνάχι' },
127
+ value: 'runny-nose',
128
+ },
129
+ {
130
+ label: { primary: 'Έχω πυρετό' },
131
+ value: 'fever',
132
+ },
133
+ {
134
+ label: { primary: 'Αισθάνομαι κούραση' },
135
+ value: 'fatigue',
136
+ },
137
+ ],
140
138
  },
141
- {
142
- key: 'image',
143
- type: 'image',
144
- required: true,
145
- label: {
146
- primary: 'Ανεβάστε τη φωτογραφία του προστίμου',
147
- },
139
+ },
140
+ {
141
+ key: 'image',
142
+ type: 'image',
143
+ required: true,
144
+ label: {
145
+ primary: 'Ανεβάστε τη φωτογραφία του προστίμου',
148
146
  },
149
- {
150
- key: 'file',
151
- type: 'file',
152
- label: {
153
- primary: 'Ανεβάστε το αρχείο της απόδειξης',
154
- },
155
- required: true,
147
+ },
148
+ {
149
+ key: 'file',
150
+ type: 'file',
151
+ label: {
152
+ primary: 'Ανεβάστε το αρχείο της απόδειξης',
156
153
  },
157
- ]
154
+ required: true,
155
+ },
156
+ ]
158
157
 
159
158
  export const scenarios = [
160
159
  {
@@ -6,7 +6,7 @@ const DEFAULT_FILE_MAX_SIZE = 10000000;
6
6
  export const FILE_MAX_SIZE_VALIDATOR = (field: FieldSpec): ValidatorSchema => ({
7
7
  name: 'file-max-size-validator',
8
8
  message: {
9
- key: 'form.error.file_size',
9
+ key: field.type === 'file' ? 'form.error.file_size' : 'form.error.image_size',
10
10
  context: {
11
11
  maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1000000,
12
12
  },
@@ -2,7 +2,7 @@ const DEFAULT_FILE_MAX_SIZE = 1e7;
2
2
  const FILE_MAX_SIZE_VALIDATOR = (field) => ({
3
3
  name: "file-max-size-validator",
4
4
  message: {
5
- key: "form.error.file_size",
5
+ key: field.type === "file" ? "form.error.file_size" : "form.error.image_size",
6
6
  context: {
7
7
  maxSizeToMb: (field?.extra?.limit.maxSize || DEFAULT_FILE_MAX_SIZE) / 1e6
8
8
  }