@eturnity/eturnity_reusable_components 6.50.1-EPDM-8599.0 → 6.50.1-EPDM-9466.0

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 (279) hide show
  1. package/.prettierrc +6 -6
  2. package/.storybook/main.js +8 -8
  3. package/.storybook/preview.js +46 -46
  4. package/README.md +29 -29
  5. package/babel.config.js +4 -4
  6. package/package.json +66 -66
  7. package/postcss.config.js +6 -6
  8. package/public/index.html +17 -17
  9. package/src/App.vue +248 -250
  10. package/src/assets/icons/arrow_down.svg +3 -3
  11. package/src/assets/icons/arrow_up_red.svg +3 -3
  12. package/src/assets/icons/black_spinner.svg +35 -35
  13. package/src/assets/icons/delete_icon.svg +11 -11
  14. package/src/assets/icons/delete_icon_gray.svg +11 -11
  15. package/src/assets/icons/drag_icon.svg +8 -8
  16. package/src/assets/icons/external_icon.svg +6 -6
  17. package/src/assets/icons/language_icon.svg +6 -6
  18. package/src/assets/icons/pdf_icon.svg +6 -6
  19. package/src/assets/icons/plus_button.svg +4 -4
  20. package/src/assets/icons/search_icon_black.svg +3 -3
  21. package/src/assets/icons/subposition_icon.svg +3 -3
  22. package/src/assets/icons/subposition_marker.svg +3 -3
  23. package/src/assets/icons/warning_icon.svg +3 -3
  24. package/src/assets/svgIcons/2d_active.svg +7 -7
  25. package/src/assets/svgIcons/2d_inactive.svg +8 -8
  26. package/src/assets/svgIcons/3d_active.svg +7 -7
  27. package/src/assets/svgIcons/3d_inactive.svg +8 -8
  28. package/src/assets/svgIcons/_readme.md +7 -7
  29. package/src/assets/svgIcons/accept.svg +5 -5
  30. package/src/assets/svgIcons/activate_panels_active.svg +22 -22
  31. package/src/assets/svgIcons/activate_panels_inactive.svg +20 -20
  32. package/src/assets/svgIcons/add_icon-1.svg +3 -3
  33. package/src/assets/svgIcons/add_icon.svg +4 -4
  34. package/src/assets/svgIcons/address_book.svg +3 -3
  35. package/src/assets/svgIcons/after_sale_as_a_service.svg +6 -6
  36. package/src/assets/svgIcons/all_good.svg +3 -3
  37. package/src/assets/svgIcons/angle_active.svg +5 -5
  38. package/src/assets/svgIcons/angle_inactive.svg +4 -4
  39. package/src/assets/svgIcons/area_active.svg +11 -11
  40. package/src/assets/svgIcons/area_inactive.svg +26 -26
  41. package/src/assets/svgIcons/areas_tool.svg +14 -14
  42. package/src/assets/svgIcons/arrow_down.svg +3 -3
  43. package/src/assets/svgIcons/arrow_left.svg +4 -4
  44. package/src/assets/svgIcons/arrow_right.svg +4 -4
  45. package/src/assets/svgIcons/arrow_up.svg +3 -3
  46. package/src/assets/svgIcons/attachment.svg +3 -3
  47. package/src/assets/svgIcons/base_layer.svg +3 -3
  48. package/src/assets/svgIcons/battery.svg +3 -3
  49. package/src/assets/svgIcons/bell.svg +3 -3
  50. package/src/assets/svgIcons/bold.svg +3 -3
  51. package/src/assets/svgIcons/bom.svg +3 -3
  52. package/src/assets/svgIcons/bom_generation.svg +10 -10
  53. package/src/assets/svgIcons/bookmaker.svg +3 -3
  54. package/src/assets/svgIcons/bubble.svg +3 -3
  55. package/src/assets/svgIcons/bug.svg +5 -5
  56. package/src/assets/svgIcons/bullet_list.svg +8 -8
  57. package/src/assets/svgIcons/calendar.svg +7 -7
  58. package/src/assets/svgIcons/calendar_icon.svg +7 -7
  59. package/src/assets/svgIcons/call.svg +3 -3
  60. package/src/assets/svgIcons/camera.svg +3 -3
  61. package/src/assets/svgIcons/car.svg +3 -3
  62. package/src/assets/svgIcons/cart.svg +3 -3
  63. package/src/assets/svgIcons/checkbox.svg +3 -3
  64. package/src/assets/svgIcons/clear_formatting.svg +7 -7
  65. package/src/assets/svgIcons/clickable_info.svg +4 -4
  66. package/src/assets/svgIcons/clip.svg +3 -3
  67. package/src/assets/svgIcons/clock.svg +17 -17
  68. package/src/assets/svgIcons/close_for_modals,_tool_tips.svg +4 -4
  69. package/src/assets/svgIcons/co_branding.svg +5 -5
  70. package/src/assets/svgIcons/collapse.svg +4 -4
  71. package/src/assets/svgIcons/collections.svg +3 -3
  72. package/src/assets/svgIcons/component_library.svg +7 -7
  73. package/src/assets/svgIcons/context_menu-1.svg +6 -6
  74. package/src/assets/svgIcons/context_menu-2.svg +5 -5
  75. package/src/assets/svgIcons/context_menu.svg +5 -5
  76. package/src/assets/svgIcons/context_menu_tabs.svg +5 -5
  77. package/src/assets/svgIcons/cross.svg +4 -4
  78. package/src/assets/svgIcons/current_variant.svg +4 -4
  79. package/src/assets/svgIcons/dashboard.svg +3 -3
  80. package/src/assets/svgIcons/deadline.svg +4 -4
  81. package/src/assets/svgIcons/deal_flow.svg +5 -5
  82. package/src/assets/svgIcons/delete.svg +4 -4
  83. package/src/assets/svgIcons/delete_area_active.svg +16 -16
  84. package/src/assets/svgIcons/delete_area_inactive.svg +15 -15
  85. package/src/assets/svgIcons/direction_active-1.svg +12 -12
  86. package/src/assets/svgIcons/direction_active.svg +5 -5
  87. package/src/assets/svgIcons/direction_arrow.svg +4 -4
  88. package/src/assets/svgIcons/direction_inactive.svg +4 -4
  89. package/src/assets/svgIcons/dislike.svg +3 -3
  90. package/src/assets/svgIcons/distance_tool.svg +8 -8
  91. package/src/assets/svgIcons/distances_active.svg +9 -9
  92. package/src/assets/svgIcons/distances_inactive.svg +8 -8
  93. package/src/assets/svgIcons/distort_tool.svg +10 -10
  94. package/src/assets/svgIcons/distort_tool2.svg +16 -16
  95. package/src/assets/svgIcons/document.svg +3 -3
  96. package/src/assets/svgIcons/documents.svg +4 -4
  97. package/src/assets/svgIcons/downarrow.svg +3 -3
  98. package/src/assets/svgIcons/download.svg +4 -4
  99. package/src/assets/svgIcons/draggable_corner.svg +5 -5
  100. package/src/assets/svgIcons/draw_tool.svg +3 -3
  101. package/src/assets/svgIcons/duplicate-1.svg +8 -8
  102. package/src/assets/svgIcons/duplicate-2.svg +5 -5
  103. package/src/assets/svgIcons/duplicate.svg +4 -4
  104. package/src/assets/svgIcons/e-mobility_configurator.svg +6 -6
  105. package/src/assets/svgIcons/e_signature.svg +5 -5
  106. package/src/assets/svgIcons/edit_button.svg +3 -3
  107. package/src/assets/svgIcons/email.svg +3 -3
  108. package/src/assets/svgIcons/ems-1.svg +3 -3
  109. package/src/assets/svgIcons/ems.svg +3 -3
  110. package/src/assets/svgIcons/end_of_the_list.svg +5 -5
  111. package/src/assets/svgIcons/erase.svg +4 -4
  112. package/src/assets/svgIcons/external_icon.svg +5 -5
  113. package/src/assets/svgIcons/fav_icon.svg +4 -4
  114. package/src/assets/svgIcons/finance.svg +3 -3
  115. package/src/assets/svgIcons/financing_for_pv-1.svg +5 -5
  116. package/src/assets/svgIcons/financing_for_pv-2.svg +3 -3
  117. package/src/assets/svgIcons/financing_for_pv.svg +6 -6
  118. package/src/assets/svgIcons/finish-1.svg +4 -4
  119. package/src/assets/svgIcons/finish.svg +3 -3
  120. package/src/assets/svgIcons/flatten.svg +11 -11
  121. package/src/assets/svgIcons/folder.svg +3 -3
  122. package/src/assets/svgIcons/free_technology.svg +5 -5
  123. package/src/assets/svgIcons/heat_calc.svg +7 -7
  124. package/src/assets/svgIcons/house.svg +3 -3
  125. package/src/assets/svgIcons/info.svg +3 -3
  126. package/src/assets/svgIcons/initial_situation.svg +3 -3
  127. package/src/assets/svgIcons/integrations.svg +3 -3
  128. package/src/assets/svgIcons/intro-tour-1.svg +3 -3
  129. package/src/assets/svgIcons/intro-tour.svg +3 -3
  130. package/src/assets/svgIcons/inverter-1.svg +5 -5
  131. package/src/assets/svgIcons/inverter.svg +3 -3
  132. package/src/assets/svgIcons/italic.svg +3 -3
  133. package/src/assets/svgIcons/key.svg +3 -3
  134. package/src/assets/svgIcons/layers_close.svg +4 -4
  135. package/src/assets/svgIcons/layers_open.svg +4 -4
  136. package/src/assets/svgIcons/lead_marketplace.svg +6 -6
  137. package/src/assets/svgIcons/lead_provider.svg +4 -4
  138. package/src/assets/svgIcons/length_in_2d_active.svg +12 -12
  139. package/src/assets/svgIcons/length_in_2d_inctive.svg +13 -13
  140. package/src/assets/svgIcons/light_bulb.svg +3 -3
  141. package/src/assets/svgIcons/like.svg +3 -3
  142. package/src/assets/svgIcons/line_graph.svg +3 -3
  143. package/src/assets/svgIcons/local_subsidies.svg +18 -18
  144. package/src/assets/svgIcons/location.svg +3 -3
  145. package/src/assets/svgIcons/lock.svg +3 -3
  146. package/src/assets/svgIcons/loop.svg +3 -3
  147. package/src/assets/svgIcons/lunch.svg +4 -4
  148. package/src/assets/svgIcons/magic_tool.svg +6 -6
  149. package/src/assets/svgIcons/map_icon.svg +5 -5
  150. package/src/assets/svgIcons/map_settings.svg +3 -3
  151. package/src/assets/svgIcons/margin_tool.svg +4 -4
  152. package/src/assets/svgIcons/meeting.svg +6 -6
  153. package/src/assets/svgIcons/move_copy.svg +4 -4
  154. package/src/assets/svgIcons/new_area_inactive.svg +11 -11
  155. package/src/assets/svgIcons/next.svg +4 -4
  156. package/src/assets/svgIcons/not_equal_to.svg +3 -3
  157. package/src/assets/svgIcons/numbered_list.svg +6 -6
  158. package/src/assets/svgIcons/obstacle_tool.svg +9 -9
  159. package/src/assets/svgIcons/obstacle_tool_origin.svg +3 -3
  160. package/src/assets/svgIcons/offset_tool.svg +8 -8
  161. package/src/assets/svgIcons/outline_tool.svg +11 -11
  162. package/src/assets/svgIcons/pan_tool.svg +12 -12
  163. package/src/assets/svgIcons/panels_tool.svg +8 -8
  164. package/src/assets/svgIcons/pen_tool.svg +4 -4
  165. package/src/assets/svgIcons/picker_tool.svg +4 -4
  166. package/src/assets/svgIcons/picture.svg +3 -3
  167. package/src/assets/svgIcons/pin.svg +5 -5
  168. package/src/assets/svgIcons/presentation.svg +3 -3
  169. package/src/assets/svgIcons/previous.svg +4 -4
  170. package/src/assets/svgIcons/profile-1.svg +4 -4
  171. package/src/assets/svgIcons/profile.svg +4 -4
  172. package/src/assets/svgIcons/profitability.svg +3 -3
  173. package/src/assets/svgIcons/project_analysis.svg +4 -4
  174. package/src/assets/svgIcons/project_settings.svg +4 -4
  175. package/src/assets/svgIcons/pv.svg +3 -3
  176. package/src/assets/svgIcons/quotations.svg +6 -6
  177. package/src/assets/svgIcons/redo.svg +6 -6
  178. package/src/assets/svgIcons/resizer.svg +5 -5
  179. package/src/assets/svgIcons/roof_layer.svg +3 -3
  180. package/src/assets/svgIcons/rotate_tool.svg +3 -3
  181. package/src/assets/svgIcons/rotate_view.svg +5 -5
  182. package/src/assets/svgIcons/ruler_tool.svg +3 -3
  183. package/src/assets/svgIcons/run_simulation.svg +3 -3
  184. package/src/assets/svgIcons/scaling_tool.svg +8 -8
  185. package/src/assets/svgIcons/search.svg +3 -3
  186. package/src/assets/svgIcons/security.svg +3 -3
  187. package/src/assets/svgIcons/settings.svg +3 -3
  188. package/src/assets/svgIcons/show_in_a_new_tab.svg +12 -12
  189. package/src/assets/svgIcons/smartphone.svg +4 -4
  190. package/src/assets/svgIcons/solar_calc.svg +13 -13
  191. package/src/assets/svgIcons/sorting.svg +4 -4
  192. package/src/assets/svgIcons/start_of_the_list.svg +5 -5
  193. package/src/assets/svgIcons/strikethrough.svg +4 -4
  194. package/src/assets/svgIcons/subscriptions.svg +3 -3
  195. package/src/assets/svgIcons/subsidies-1.svg +5 -5
  196. package/src/assets/svgIcons/subsidies-2.svg +3 -3
  197. package/src/assets/svgIcons/subsidies.svg +3 -3
  198. package/src/assets/svgIcons/subtract_icon.svg +3 -3
  199. package/src/assets/svgIcons/suitcase.svg +3 -3
  200. package/src/assets/svgIcons/template_icon_not_clickable.svg +6 -6
  201. package/src/assets/svgIcons/transfer.svg +4 -4
  202. package/src/assets/svgIcons/trim_tool.svg +4 -4
  203. package/src/assets/svgIcons/truck.svg +3 -3
  204. package/src/assets/svgIcons/underlined.svg +3 -3
  205. package/src/assets/svgIcons/undo.svg +6 -6
  206. package/src/assets/svgIcons/uparrow.svg +3 -3
  207. package/src/assets/svgIcons/update.svg +3 -3
  208. package/src/assets/svgIcons/upload_avatar-1.svg +12 -12
  209. package/src/assets/svgIcons/upload_avatar.svg +5 -5
  210. package/src/assets/svgIcons/upload_image.svg +8 -8
  211. package/src/assets/svgIcons/upload_image_tool.svg +7 -7
  212. package/src/assets/svgIcons/variants.svg +6 -6
  213. package/src/assets/svgIcons/vertical_tool.svg +3 -3
  214. package/src/assets/svgIcons/virtual_storage.svg +4 -4
  215. package/src/assets/svgIcons/warning.svg +4 -4
  216. package/src/assets/svgIcons/way.svg +5 -5
  217. package/src/assets/svgIcons/wifi.svg +3 -3
  218. package/src/assets/svgIcons/winter.svg +3 -3
  219. package/src/assets/svgIcons/workflow_template.svg +11 -11
  220. package/src/assets/theme.js +38 -38
  221. package/src/components/addNewButton/AddNewButton.stories.js +24 -24
  222. package/src/components/addNewButton/index.vue +58 -58
  223. package/src/components/buttons/buttonIcon/index.vue +142 -142
  224. package/src/components/buttons/closeButton/CloseButton.stories.js +29 -29
  225. package/src/components/buttons/closeButton/index.vue +61 -61
  226. package/src/components/buttons/mainButton/index.vue +107 -107
  227. package/src/components/deleteIcon/DeleteIcon.stories.js +29 -29
  228. package/src/components/deleteIcon/index.vue +61 -61
  229. package/src/components/dropdown/Dropdown.stories.js +54 -54
  230. package/src/components/dropdown/index.vue +118 -118
  231. package/src/components/errorMessage/index.vue +61 -61
  232. package/src/components/filter/filterSettings.vue +650 -650
  233. package/src/components/filter/index.vue +132 -132
  234. package/src/components/filter/parentDropdown.vue +91 -91
  235. package/src/components/icon/Icons.stories.js +41 -41
  236. package/src/components/icon/iconCollection.vue +68 -68
  237. package/src/components/icon/index.vue +116 -116
  238. package/src/components/iconWrapper/index.vue +152 -152
  239. package/src/components/infoText/index.vue +170 -170
  240. package/src/components/inputs/checkbox/Checkbox.stories.js +57 -57
  241. package/src/components/inputs/checkbox/index.vue +187 -187
  242. package/src/components/inputs/inputNumber/InputNumber.stories.js +150 -150
  243. package/src/components/inputs/inputNumber/index.vue +710 -710
  244. package/src/components/inputs/inputNumberQuestion/index.vue +215 -215
  245. package/src/components/inputs/inputText/InputText.stories.js +75 -75
  246. package/src/components/inputs/inputText/index.vue +355 -355
  247. package/src/components/inputs/radioButton/RadioButton.stories.js +58 -58
  248. package/src/components/inputs/radioButton/index.vue +267 -267
  249. package/src/components/inputs/searchInput/SearchInput.stories.js +40 -40
  250. package/src/components/inputs/searchInput/index.vue +133 -133
  251. package/src/components/inputs/select/index.vue +582 -578
  252. package/src/components/inputs/select/option/index.vue +107 -107
  253. package/src/components/inputs/select/select.stories.js +59 -59
  254. package/src/components/inputs/slider/index.vue +126 -126
  255. package/src/components/inputs/switchField/index.vue +260 -264
  256. package/src/components/inputs/textAreaInput/TextAreaInput.stories.js +135 -135
  257. package/src/components/inputs/textAreaInput/index.vue +206 -206
  258. package/src/components/inputs/toggle/Toggle.stories.js +77 -77
  259. package/src/components/inputs/toggle/index.vue +298 -298
  260. package/src/components/modals/modal/index.vue +159 -159
  261. package/src/components/modals/modal/modal.stories.js +31 -31
  262. package/src/components/pageSubtitle/index.vue +68 -68
  263. package/src/components/pageTitle/index.vue +45 -45
  264. package/src/components/pagination/index.vue +129 -129
  265. package/src/components/progressBar/index.vue +125 -125
  266. package/src/components/projectMarker/index.vue +299 -299
  267. package/src/components/sideMenu/index.vue +266 -266
  268. package/src/components/spinner/index.vue +71 -71
  269. package/src/components/tableDropdown/index.vue +637 -637
  270. package/src/components/tables/mainTable/exampleNested.vue +328 -328
  271. package/src/components/tables/mainTable/index.vue +446 -446
  272. package/src/components/tables/viewTable/index.vue +195 -195
  273. package/src/components/threeDots/index.vue +384 -384
  274. package/src/components/videoThumbnail/index.vue +107 -107
  275. package/src/components/videoThumbnail/videoThumbnail.stories.js +35 -35
  276. package/src/helpers/numberConverter.js +102 -102
  277. package/src/helpers/translateLang.js +119 -119
  278. package/src/main.js +13 -13
  279. package/src/components/infoCard/index.vue +0 -38
@@ -1,135 +1,135 @@
1
- import TextAreaInput from "./index.vue"
2
-
3
- export default {
4
- title: "TextAreaInput",
5
- component: TextAreaInput,
6
- // argTypes: {},
7
- }
8
-
9
- const Template = (args, { argTypes }) => ({
10
- // Components used in your story `template` are defined in the `components` object
11
- components: { TextAreaInput },
12
- // The story's `args` need to be mapped into the template through the `setup()` method
13
- props: Object.keys(argTypes),
14
- template: '<text-area-input v-bind="$props" />',
15
-
16
- // import TextAreaInput from "@eturnity/eturnity_reusable_components/src/components/inputs/textAreaInput"
17
- // To use:
18
- // <text-area-input
19
- // placeholder="Comments"
20
- // @input-change="onInputChange({ value: $event, type: 'note' })"
21
- // :value="form.note"
22
- // rowHeight="4" //optional
23
- // :isError="false"
24
- // :errorText="$gettext('field_required')"
25
- // infoTextAlign="right" // left by default
26
- // infoTextMessage="My info message"
27
- // label="Question 5"
28
- // alignItems="horizontal" // horizontal, vertical
29
- // :isDisabled="true"
30
- // />
31
- })
32
-
33
- export const Default = Template.bind({})
34
- Default.args = {
35
- placeholder: "Enter a comment",
36
- isDisabled: false,
37
- rowHeight: "2",
38
- isError: false,
39
- errorText: "This field is required",
40
- infoTextAlign: "right",
41
- infoTextMessage: "",
42
- label: "",
43
- value: "",
44
- alignItems: "vertical",
45
- inputWidth: "350px",
46
- }
47
-
48
- export const Disabled = Template.bind({})
49
- Disabled.args = {
50
- placeholder: "Enter a comment",
51
- isDisabled: true,
52
- rowHeight: "2",
53
- isError: false,
54
- errorText: "This field is required",
55
- infoTextAlign: "right",
56
- infoTextMessage: "",
57
- label: "",
58
- value: "",
59
- alignItems: "vertical",
60
- inputWidth: "350px",
61
- }
62
-
63
- export const Error = Template.bind({})
64
- Error.args = {
65
- placeholder: "Enter a comment",
66
- isDisabled: false,
67
- rowHeight: "2",
68
- isError: true,
69
- errorText: "This field is required",
70
- infoTextAlign: "right",
71
- infoTextMessage: "",
72
- label: "",
73
- value: "",
74
- alignItems: "vertical",
75
- inputWidth: "350px",
76
- }
77
-
78
- export const WithLabel = Template.bind({})
79
- WithLabel.args = {
80
- placeholder: "Enter a comment",
81
- isDisabled: false,
82
- rowHeight: "2",
83
- isError: false,
84
- errorText: "This field is required",
85
- infoTextAlign: "right",
86
- infoTextMessage: "Here is some information",
87
- label: "Description",
88
- value: "Here is my description!",
89
- alignItems: "vertical",
90
- inputWidth: "350px",
91
- }
92
-
93
- export const HorizontalLabel = Template.bind({})
94
- HorizontalLabel.args = {
95
- placeholder: "Enter a comment",
96
- isDisabled: false,
97
- rowHeight: "2",
98
- isError: false,
99
- errorText: "This field is required",
100
- infoTextAlign: "right",
101
- infoTextMessage: "Here is some information",
102
- label: "Description",
103
- value: "Here is my description!",
104
- alignItems: "horizontal",
105
- inputWidth: "350px",
106
- }
107
-
108
- export const LargerTextArea = Template.bind({})
109
- LargerTextArea.args = {
110
- placeholder: "Enter a comment",
111
- isDisabled: false,
112
- rowHeight: "5",
113
- isError: false,
114
- errorText: "This field is required",
115
- infoTextAlign: "right",
116
- infoTextMessage: "Here is some information",
117
- label: "Description",
118
- value: "Here is my description!",
119
- alignItems: "vertical",
120
- }
121
-
122
- export const LargerFontSize = Template.bind({})
123
- LargerFontSize.args = {
124
- placeholder: "Enter a comment",
125
- isDisabled: false,
126
- rowHeight: "5",
127
- fontSize: "24px",
128
- isError: false,
129
- errorText: "This field is required",
130
- infoTextAlign: "right",
131
- infoTextMessage: "Here is some information",
132
- label: "Description",
133
- value: "Here is my description!",
134
- alignItems: "vertical",
135
- }
1
+ import TextAreaInput from "./index.vue"
2
+
3
+ export default {
4
+ title: "TextAreaInput",
5
+ component: TextAreaInput,
6
+ // argTypes: {},
7
+ }
8
+
9
+ const Template = (args, { argTypes }) => ({
10
+ // Components used in your story `template` are defined in the `components` object
11
+ components: { TextAreaInput },
12
+ // The story's `args` need to be mapped into the template through the `setup()` method
13
+ props: Object.keys(argTypes),
14
+ template: '<text-area-input v-bind="$props" />',
15
+
16
+ // import TextAreaInput from "@eturnity/eturnity_reusable_components/src/components/inputs/textAreaInput"
17
+ // To use:
18
+ // <text-area-input
19
+ // placeholder="Comments"
20
+ // @input-change="onInputChange({ value: $event, type: 'note' })"
21
+ // :value="form.note"
22
+ // rowHeight="4" //optional
23
+ // :isError="false"
24
+ // :errorText="$gettext('field_required')"
25
+ // infoTextAlign="right" // left by default
26
+ // infoTextMessage="My info message"
27
+ // label="Question 5"
28
+ // alignItems="horizontal" // horizontal, vertical
29
+ // :isDisabled="true"
30
+ // />
31
+ })
32
+
33
+ export const Default = Template.bind({})
34
+ Default.args = {
35
+ placeholder: "Enter a comment",
36
+ isDisabled: false,
37
+ rowHeight: "2",
38
+ isError: false,
39
+ errorText: "This field is required",
40
+ infoTextAlign: "right",
41
+ infoTextMessage: "",
42
+ label: "",
43
+ value: "",
44
+ alignItems: "vertical",
45
+ inputWidth: "350px",
46
+ }
47
+
48
+ export const Disabled = Template.bind({})
49
+ Disabled.args = {
50
+ placeholder: "Enter a comment",
51
+ isDisabled: true,
52
+ rowHeight: "2",
53
+ isError: false,
54
+ errorText: "This field is required",
55
+ infoTextAlign: "right",
56
+ infoTextMessage: "",
57
+ label: "",
58
+ value: "",
59
+ alignItems: "vertical",
60
+ inputWidth: "350px",
61
+ }
62
+
63
+ export const Error = Template.bind({})
64
+ Error.args = {
65
+ placeholder: "Enter a comment",
66
+ isDisabled: false,
67
+ rowHeight: "2",
68
+ isError: true,
69
+ errorText: "This field is required",
70
+ infoTextAlign: "right",
71
+ infoTextMessage: "",
72
+ label: "",
73
+ value: "",
74
+ alignItems: "vertical",
75
+ inputWidth: "350px",
76
+ }
77
+
78
+ export const WithLabel = Template.bind({})
79
+ WithLabel.args = {
80
+ placeholder: "Enter a comment",
81
+ isDisabled: false,
82
+ rowHeight: "2",
83
+ isError: false,
84
+ errorText: "This field is required",
85
+ infoTextAlign: "right",
86
+ infoTextMessage: "Here is some information",
87
+ label: "Description",
88
+ value: "Here is my description!",
89
+ alignItems: "vertical",
90
+ inputWidth: "350px",
91
+ }
92
+
93
+ export const HorizontalLabel = Template.bind({})
94
+ HorizontalLabel.args = {
95
+ placeholder: "Enter a comment",
96
+ isDisabled: false,
97
+ rowHeight: "2",
98
+ isError: false,
99
+ errorText: "This field is required",
100
+ infoTextAlign: "right",
101
+ infoTextMessage: "Here is some information",
102
+ label: "Description",
103
+ value: "Here is my description!",
104
+ alignItems: "horizontal",
105
+ inputWidth: "350px",
106
+ }
107
+
108
+ export const LargerTextArea = Template.bind({})
109
+ LargerTextArea.args = {
110
+ placeholder: "Enter a comment",
111
+ isDisabled: false,
112
+ rowHeight: "5",
113
+ isError: false,
114
+ errorText: "This field is required",
115
+ infoTextAlign: "right",
116
+ infoTextMessage: "Here is some information",
117
+ label: "Description",
118
+ value: "Here is my description!",
119
+ alignItems: "vertical",
120
+ }
121
+
122
+ export const LargerFontSize = Template.bind({})
123
+ LargerFontSize.args = {
124
+ placeholder: "Enter a comment",
125
+ isDisabled: false,
126
+ rowHeight: "5",
127
+ fontSize: "24px",
128
+ isError: false,
129
+ errorText: "This field is required",
130
+ infoTextAlign: "right",
131
+ infoTextMessage: "Here is some information",
132
+ label: "Description",
133
+ value: "Here is my description!",
134
+ alignItems: "vertical",
135
+ }
@@ -1,206 +1,206 @@
1
- <template>
2
- <container :inputWidth="inputWidth">
3
- <input-wrapper
4
- :alignItems="alignItems"
5
- :hasLabel="label && label.length > 0"
6
- >
7
- <label-wrapper v-if="label">
8
- <input-label :fontSize="fontSize" :data-id="labelDataId">{{
9
- label
10
- }}</input-label>
11
- <info-text
12
- v-if="infoTextMessage"
13
- :text="infoTextMessage"
14
- borderColor="#ccc"
15
- size="16px"
16
- :alignText="infoTextAlign"
17
- />
18
- </label-wrapper>
19
- <input-container
20
- :inputWidth="inputWidth"
21
- :isError="isError"
22
- :fontSize="fontSize"
23
- :disabled="isDisabled"
24
- >
25
- <textarea
26
- :placeholder="placeholder"
27
- :rows="rowHeight"
28
- :value="value"
29
- :disabled="isDisabled"
30
- @input="onChangeHandler"
31
- :resize="resize"
32
- :data-id="inputDataId"
33
- />
34
- </input-container>
35
- </input-wrapper>
36
- <error-message v-if="isError && errorText">{{ errorText }}</error-message>
37
- </container>
38
- </template>
39
-
40
- <script>
41
- // import TextAreaInput from "@eturnity/eturnity_reusable_components/src/components/inputs/textAreaInput"
42
- // To use:
43
- // <text-area-input
44
- // placeholder="Comments"
45
- // @input-change="onInputChange({ value: $event, type: 'note' })"
46
- // :value="form.note"
47
- // rowHeight="4" //optional
48
- // :isError="false"
49
- // :errorText="$gettext('field_required')"
50
- // infoTextAlign="right" // left by default
51
- // infoTextMessage="My info message"
52
- // label="Question 5"
53
- // alignItems="horizontal" // horizontal, vertical
54
- // :isDisabled="true"
55
- // . fontSize="13px"
56
- // />
57
- import styled from 'vue-styled-components'
58
- import InfoText from '../../infoText'
59
- import ErrorMessage from '../../errorMessage'
60
-
61
- const containerProps = { inputWidth: String }
62
- const Container = styled('div', containerProps)`
63
- width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
64
- position: relative;
65
- margin-bottom: 20px;
66
- `
67
-
68
- const LabelWrapper = styled.div`
69
- display: inline-grid;
70
- grid-template-columns: auto 1fr;
71
- grid-gap: 12px;
72
- align-items: center;
73
- `
74
-
75
- const inputProps = {
76
- isError: Boolean,
77
- disabled: Boolean,
78
- fontSize: String,
79
- inputWidth: String
80
- }
81
-
82
- const InputContainer = styled('div', inputProps)`
83
- textarea {
84
- border: ${(props) =>
85
- props.isError
86
- ? `1px solid ${props.theme.colors.red} !important`
87
- : `1px solid ${props.theme.colors.grey4} !important`};
88
- padding: ${(props) =>
89
- props.hasUnit ? '11px 40px 11px 10px !important' : '15px !important'};
90
- border-radius: 4px !important;
91
- font-size: ${(props) => `${props.fontSize} !important`};
92
- color: ${(props) => `${props.theme.colors.grey1} !important`};
93
- width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
94
- max-width: 100%;
95
- box-sizing: border-box; // to allow width of 100% with padding
96
- cursor: ${(props) => (props.disabled ? 'not-allowed' : 'inherit')};
97
-
98
- &::placeholder {
99
- color: ${(props) => `${props.theme.colors.grey2} !important`};
100
- }
101
-
102
- &:focus {
103
- outline: none;
104
- }
105
- }
106
- `
107
-
108
- const inputAttrs = { alignItems: String, hasLabel: Boolean }
109
- const InputWrapper = styled('div', inputAttrs)`
110
- position: relative;
111
- display: grid;
112
- align-items: center;
113
- gap: 8px;
114
- grid-template-columns: ${(props) =>
115
- !props.hasLabel
116
- ? '1fr'
117
- : props.alignItems === 'vertical'
118
- ? '1fr'
119
- : 'auto 1fr'};
120
- `
121
-
122
- const labelAttrs = { fontSize: String }
123
- const InputLabel = styled('div', labelAttrs)`
124
- font-weight: bold;
125
- font-size: ${(props) => (props.fontSize ? props.fontSize : '16px')};
126
- `
127
-
128
- export default {
129
- name: 'text-area-input',
130
- components: {
131
- Container,
132
- InputContainer,
133
- InputWrapper,
134
- ErrorMessage,
135
- InfoText,
136
- LabelWrapper,
137
- InputLabel
138
- },
139
- props: {
140
- placeholder: {
141
- required: false,
142
- default: ''
143
- },
144
- isError: {
145
- required: false,
146
- default: false
147
- },
148
- rowHeight: {
149
- required: false,
150
- default: '2'
151
- },
152
- value: {
153
- required: true,
154
- default: null
155
- },
156
- errorText: {
157
- required: false
158
- },
159
- isDisabled: {
160
- required: false,
161
- default: false
162
- },
163
- alignItems: {
164
- required: false,
165
- default: 'horizontal'
166
- },
167
- infoTextMessage: {
168
- required: false
169
- },
170
- infoTextAlign: {
171
- required: false
172
- },
173
- label: {
174
- required: false
175
- },
176
- fontSize: {
177
- required: false,
178
- default: '13px'
179
- },
180
- inputWidth: {
181
- required: false,
182
- default: null
183
- },
184
- resize: {
185
- required: false,
186
- default: 'none'
187
- },
188
- labelDataId: {
189
- required: false,
190
- default: ''
191
- },
192
- inputDataId: {
193
- required: false,
194
- default: ''
195
- }
196
- },
197
- methods: {
198
- onChangeHandler($event) {
199
- if (this.isDisabled) {
200
- return
201
- }
202
- this.$emit('input-change', $event.target.value)
203
- }
204
- }
205
- }
206
- </script>
1
+ <template>
2
+ <container :inputWidth="inputWidth">
3
+ <input-wrapper
4
+ :alignItems="alignItems"
5
+ :hasLabel="label && label.length > 0"
6
+ >
7
+ <label-wrapper v-if="label">
8
+ <input-label :fontSize="fontSize" :data-id="labelDataId">{{
9
+ label
10
+ }}</input-label>
11
+ <info-text
12
+ v-if="infoTextMessage"
13
+ :text="infoTextMessage"
14
+ borderColor="#ccc"
15
+ size="16px"
16
+ :alignText="infoTextAlign"
17
+ />
18
+ </label-wrapper>
19
+ <input-container
20
+ :inputWidth="inputWidth"
21
+ :isError="isError"
22
+ :fontSize="fontSize"
23
+ :disabled="isDisabled"
24
+ >
25
+ <textarea
26
+ :placeholder="placeholder"
27
+ :rows="rowHeight"
28
+ :value="value"
29
+ :disabled="isDisabled"
30
+ @input="onChangeHandler"
31
+ :resize="resize"
32
+ :data-id="inputDataId"
33
+ />
34
+ </input-container>
35
+ </input-wrapper>
36
+ <error-message v-if="isError && errorText">{{ errorText }}</error-message>
37
+ </container>
38
+ </template>
39
+
40
+ <script>
41
+ // import TextAreaInput from "@eturnity/eturnity_reusable_components/src/components/inputs/textAreaInput"
42
+ // To use:
43
+ // <text-area-input
44
+ // placeholder="Comments"
45
+ // @input-change="onInputChange({ value: $event, type: 'note' })"
46
+ // :value="form.note"
47
+ // rowHeight="4" //optional
48
+ // :isError="false"
49
+ // :errorText="$gettext('field_required')"
50
+ // infoTextAlign="right" // left by default
51
+ // infoTextMessage="My info message"
52
+ // label="Question 5"
53
+ // alignItems="horizontal" // horizontal, vertical
54
+ // :isDisabled="true"
55
+ // . fontSize="13px"
56
+ // />
57
+ import styled from 'vue-styled-components'
58
+ import InfoText from '../../infoText'
59
+ import ErrorMessage from '../../errorMessage'
60
+
61
+ const containerProps = { inputWidth: String }
62
+ const Container = styled('div', containerProps)`
63
+ width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
64
+ position: relative;
65
+ margin-bottom: 20px;
66
+ `
67
+
68
+ const LabelWrapper = styled.div`
69
+ display: inline-grid;
70
+ grid-template-columns: auto 1fr;
71
+ grid-gap: 12px;
72
+ align-items: center;
73
+ `
74
+
75
+ const inputProps = {
76
+ isError: Boolean,
77
+ disabled: Boolean,
78
+ fontSize: String,
79
+ inputWidth: String
80
+ }
81
+
82
+ const InputContainer = styled('div', inputProps)`
83
+ textarea {
84
+ border: ${(props) =>
85
+ props.isError
86
+ ? `1px solid ${props.theme.colors.red} !important`
87
+ : `1px solid ${props.theme.colors.grey4} !important`};
88
+ padding: ${(props) =>
89
+ props.hasUnit ? '11px 40px 11px 10px !important' : '15px !important'};
90
+ border-radius: 4px !important;
91
+ font-size: ${(props) => `${props.fontSize} !important`};
92
+ color: ${(props) => `${props.theme.colors.grey1} !important`};
93
+ width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
94
+ max-width: 100%;
95
+ box-sizing: border-box; // to allow width of 100% with padding
96
+ cursor: ${(props) => (props.disabled ? 'not-allowed' : 'inherit')};
97
+
98
+ &::placeholder {
99
+ color: ${(props) => `${props.theme.colors.grey2} !important`};
100
+ }
101
+
102
+ &:focus {
103
+ outline: none;
104
+ }
105
+ }
106
+ `
107
+
108
+ const inputAttrs = { alignItems: String, hasLabel: Boolean }
109
+ const InputWrapper = styled('div', inputAttrs)`
110
+ position: relative;
111
+ display: grid;
112
+ align-items: center;
113
+ gap: 8px;
114
+ grid-template-columns: ${(props) =>
115
+ !props.hasLabel
116
+ ? '1fr'
117
+ : props.alignItems === 'vertical'
118
+ ? '1fr'
119
+ : 'auto 1fr'};
120
+ `
121
+
122
+ const labelAttrs = { fontSize: String }
123
+ const InputLabel = styled('div', labelAttrs)`
124
+ font-weight: bold;
125
+ font-size: ${(props) => (props.fontSize ? props.fontSize : '16px')};
126
+ `
127
+
128
+ export default {
129
+ name: 'text-area-input',
130
+ components: {
131
+ Container,
132
+ InputContainer,
133
+ InputWrapper,
134
+ ErrorMessage,
135
+ InfoText,
136
+ LabelWrapper,
137
+ InputLabel
138
+ },
139
+ props: {
140
+ placeholder: {
141
+ required: false,
142
+ default: ''
143
+ },
144
+ isError: {
145
+ required: false,
146
+ default: false
147
+ },
148
+ rowHeight: {
149
+ required: false,
150
+ default: '2'
151
+ },
152
+ value: {
153
+ required: true,
154
+ default: null
155
+ },
156
+ errorText: {
157
+ required: false
158
+ },
159
+ isDisabled: {
160
+ required: false,
161
+ default: false
162
+ },
163
+ alignItems: {
164
+ required: false,
165
+ default: 'horizontal'
166
+ },
167
+ infoTextMessage: {
168
+ required: false
169
+ },
170
+ infoTextAlign: {
171
+ required: false
172
+ },
173
+ label: {
174
+ required: false
175
+ },
176
+ fontSize: {
177
+ required: false,
178
+ default: '13px'
179
+ },
180
+ inputWidth: {
181
+ required: false,
182
+ default: null
183
+ },
184
+ resize: {
185
+ required: false,
186
+ default: 'none'
187
+ },
188
+ labelDataId: {
189
+ required: false,
190
+ default: ''
191
+ },
192
+ inputDataId: {
193
+ required: false,
194
+ default: ''
195
+ }
196
+ },
197
+ methods: {
198
+ onChangeHandler($event) {
199
+ if (this.isDisabled) {
200
+ return
201
+ }
202
+ this.$emit('input-change', $event.target.value)
203
+ }
204
+ }
205
+ }
206
+ </script>