@eturnity/eturnity_reusable_components 7.8.1-EPDM-8441.1 → 7.8.2

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 (281) 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 +247 -247
  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/logout.svg +3 -3
  147. package/src/assets/svgIcons/loop.svg +3 -3
  148. package/src/assets/svgIcons/lunch.svg +4 -4
  149. package/src/assets/svgIcons/magic_tool.svg +6 -6
  150. package/src/assets/svgIcons/map_icon.svg +5 -5
  151. package/src/assets/svgIcons/map_settings.svg +3 -3
  152. package/src/assets/svgIcons/margin_tool.svg +4 -4
  153. package/src/assets/svgIcons/meeting.svg +6 -6
  154. package/src/assets/svgIcons/move_copy.svg +4 -4
  155. package/src/assets/svgIcons/new_area_inactive.svg +11 -11
  156. package/src/assets/svgIcons/next.svg +4 -4
  157. package/src/assets/svgIcons/not_equal_to.svg +3 -3
  158. package/src/assets/svgIcons/numbered_list.svg +6 -6
  159. package/src/assets/svgIcons/obstacle_tool.svg +9 -9
  160. package/src/assets/svgIcons/obstacle_tool_origin.svg +3 -3
  161. package/src/assets/svgIcons/offset_tool.svg +8 -8
  162. package/src/assets/svgIcons/outline_tool.svg +11 -11
  163. package/src/assets/svgIcons/pan_tool.svg +12 -12
  164. package/src/assets/svgIcons/panels_tool.svg +8 -8
  165. package/src/assets/svgIcons/pen_tool.svg +4 -4
  166. package/src/assets/svgIcons/picker_tool.svg +4 -4
  167. package/src/assets/svgIcons/picture.svg +3 -3
  168. package/src/assets/svgIcons/pin.svg +5 -5
  169. package/src/assets/svgIcons/presentation.svg +3 -3
  170. package/src/assets/svgIcons/previous.svg +4 -4
  171. package/src/assets/svgIcons/profile-1.svg +4 -4
  172. package/src/assets/svgIcons/profile.svg +4 -4
  173. package/src/assets/svgIcons/profitability.svg +3 -3
  174. package/src/assets/svgIcons/project_analysis.svg +4 -4
  175. package/src/assets/svgIcons/project_settings.svg +4 -4
  176. package/src/assets/svgIcons/pv.svg +3 -3
  177. package/src/assets/svgIcons/quotations.svg +6 -6
  178. package/src/assets/svgIcons/redo.svg +6 -6
  179. package/src/assets/svgIcons/resizer.svg +5 -5
  180. package/src/assets/svgIcons/roof_layer.svg +3 -3
  181. package/src/assets/svgIcons/rotate_tool.svg +3 -3
  182. package/src/assets/svgIcons/rotate_view.svg +5 -5
  183. package/src/assets/svgIcons/ruler_tool.svg +3 -3
  184. package/src/assets/svgIcons/run_simulation.svg +3 -3
  185. package/src/assets/svgIcons/scaling_tool.svg +8 -8
  186. package/src/assets/svgIcons/search.svg +3 -3
  187. package/src/assets/svgIcons/security.svg +3 -3
  188. package/src/assets/svgIcons/settings.svg +3 -3
  189. package/src/assets/svgIcons/show_in_a_new_tab.svg +12 -12
  190. package/src/assets/svgIcons/smartphone.svg +4 -4
  191. package/src/assets/svgIcons/solar_calc.svg +13 -13
  192. package/src/assets/svgIcons/sorting.svg +4 -4
  193. package/src/assets/svgIcons/start_of_the_list.svg +5 -5
  194. package/src/assets/svgIcons/strikethrough.svg +4 -4
  195. package/src/assets/svgIcons/subscriptions.svg +3 -3
  196. package/src/assets/svgIcons/subsidies-1.svg +5 -5
  197. package/src/assets/svgIcons/subsidies-2.svg +3 -3
  198. package/src/assets/svgIcons/subsidies.svg +3 -3
  199. package/src/assets/svgIcons/subtract_icon.svg +3 -3
  200. package/src/assets/svgIcons/suitcase.svg +3 -3
  201. package/src/assets/svgIcons/template_icon_not_clickable.svg +6 -6
  202. package/src/assets/svgIcons/transfer.svg +4 -4
  203. package/src/assets/svgIcons/trim_tool.svg +4 -4
  204. package/src/assets/svgIcons/truck.svg +3 -3
  205. package/src/assets/svgIcons/underlined.svg +3 -3
  206. package/src/assets/svgIcons/undo.svg +6 -6
  207. package/src/assets/svgIcons/uparrow.svg +3 -3
  208. package/src/assets/svgIcons/update.svg +3 -3
  209. package/src/assets/svgIcons/upload_avatar-1.svg +12 -12
  210. package/src/assets/svgIcons/upload_avatar.svg +5 -5
  211. package/src/assets/svgIcons/upload_image.svg +8 -8
  212. package/src/assets/svgIcons/upload_image_tool.svg +7 -7
  213. package/src/assets/svgIcons/variants.svg +6 -6
  214. package/src/assets/svgIcons/vertical_tool.svg +3 -3
  215. package/src/assets/svgIcons/virtual_storage.svg +4 -4
  216. package/src/assets/svgIcons/warning.svg +4 -4
  217. package/src/assets/svgIcons/way.svg +5 -5
  218. package/src/assets/svgIcons/wifi.svg +3 -3
  219. package/src/assets/svgIcons/winter.svg +3 -3
  220. package/src/assets/svgIcons/workflow_template.svg +11 -11
  221. package/src/assets/theme.js +39 -39
  222. package/src/components/addNewButton/AddNewButton.stories.js +24 -24
  223. package/src/components/addNewButton/index.vue +62 -62
  224. package/src/components/buttons/buttonIcon/index.vue +142 -142
  225. package/src/components/buttons/closeButton/CloseButton.stories.js +29 -29
  226. package/src/components/buttons/closeButton/index.vue +61 -61
  227. package/src/components/buttons/mainButton/index.vue +107 -107
  228. package/src/components/deleteIcon/DeleteIcon.stories.js +29 -29
  229. package/src/components/deleteIcon/index.vue +61 -61
  230. package/src/components/dropdown/Dropdown.stories.js +54 -54
  231. package/src/components/dropdown/index.vue +118 -118
  232. package/src/components/errorMessage/index.vue +61 -61
  233. package/src/components/filter/filterSettings.vue +650 -650
  234. package/src/components/filter/index.vue +143 -143
  235. package/src/components/filter/parentDropdown.vue +91 -91
  236. package/src/components/icon/Icons.stories.js +41 -41
  237. package/src/components/icon/iconCollection.vue +68 -68
  238. package/src/components/icon/index.vue +116 -116
  239. package/src/components/iconWrapper/index.vue +156 -156
  240. package/src/components/infoCard/index.vue +35 -35
  241. package/src/components/infoText/index.vue +171 -171
  242. package/src/components/inputs/checkbox/Checkbox.stories.js +57 -57
  243. package/src/components/inputs/checkbox/index.vue +187 -187
  244. package/src/components/inputs/inputNumber/InputNumber.stories.js +150 -150
  245. package/src/components/inputs/inputNumber/index.vue +710 -710
  246. package/src/components/inputs/inputNumberQuestion/index.vue +215 -215
  247. package/src/components/inputs/inputText/InputText.stories.js +75 -75
  248. package/src/components/inputs/inputText/index.vue +355 -360
  249. package/src/components/inputs/radioButton/RadioButton.stories.js +58 -58
  250. package/src/components/inputs/radioButton/index.vue +267 -267
  251. package/src/components/inputs/searchInput/SearchInput.stories.js +40 -40
  252. package/src/components/inputs/searchInput/index.vue +133 -133
  253. package/src/components/inputs/select/index.vue +596 -622
  254. package/src/components/inputs/select/option/index.vue +111 -111
  255. package/src/components/inputs/select/select.stories.js +59 -59
  256. package/src/components/inputs/slider/index.vue +126 -126
  257. package/src/components/inputs/switchField/index.vue +265 -265
  258. package/src/components/inputs/textAreaInput/TextAreaInput.stories.js +135 -135
  259. package/src/components/inputs/textAreaInput/index.vue +206 -206
  260. package/src/components/inputs/toggle/Toggle.stories.js +77 -77
  261. package/src/components/inputs/toggle/index.vue +298 -298
  262. package/src/components/modals/modal/index.vue +178 -178
  263. package/src/components/modals/modal/modal.stories.js +31 -31
  264. package/src/components/navigationTabs/index.vue +107 -107
  265. package/src/components/pageSubtitle/index.vue +68 -68
  266. package/src/components/pageTitle/index.vue +68 -68
  267. package/src/components/pagination/index.vue +144 -144
  268. package/src/components/progressBar/index.vue +125 -125
  269. package/src/components/projectMarker/index.vue +291 -291
  270. package/src/components/sideMenu/index.vue +270 -270
  271. package/src/components/spinner/index.vue +71 -71
  272. package/src/components/tableDropdown/index.vue +637 -637
  273. package/src/components/tables/mainTable/exampleNested.vue +328 -328
  274. package/src/components/tables/mainTable/index.vue +446 -446
  275. package/src/components/tables/viewTable/index.vue +195 -195
  276. package/src/components/threeDots/index.vue +393 -389
  277. package/src/components/videoThumbnail/index.vue +107 -107
  278. package/src/components/videoThumbnail/videoThumbnail.stories.js +35 -35
  279. package/src/helpers/numberConverter.js +102 -102
  280. package/src/helpers/translateLang.js +119 -119
  281. package/src/main.js +13 -13
@@ -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>