@eturnity/eturnity_reusable_components 1.2.19-EPDM-5295.0 → 1.2.19-EPDM-3412.8

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 (217) 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 +5 -5
  6. package/package.json +62 -62
  7. package/public/index.html +17 -17
  8. package/src/App.vue +215 -218
  9. package/src/assets/icons/arrow_down.svg +3 -3
  10. package/src/assets/icons/arrow_up_red.svg +3 -3
  11. package/src/assets/icons/black_spinner.svg +35 -35
  12. package/src/assets/icons/delete_icon.svg +11 -11
  13. package/src/assets/icons/delete_icon_gray.svg +11 -11
  14. package/src/assets/icons/drag_icon.svg +8 -8
  15. package/src/assets/icons/error_icon copy.png +0 -0
  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/accept.svg +5 -5
  29. package/src/assets/svgIcons/activate_panels_active.svg +22 -22
  30. package/src/assets/svgIcons/activate_panels_inactive.svg +20 -20
  31. package/src/assets/svgIcons/add_icon-1.svg +3 -3
  32. package/src/assets/svgIcons/add_icon.svg +4 -4
  33. package/src/assets/svgIcons/address_book.svg +3 -3
  34. package/src/assets/svgIcons/after_sale_as_a_service.svg +6 -6
  35. package/src/assets/svgIcons/all_good.svg +3 -3
  36. package/src/assets/svgIcons/angle_active.svg +5 -5
  37. package/src/assets/svgIcons/angle_inactive.svg +4 -4
  38. package/src/assets/svgIcons/area_active.svg +11 -11
  39. package/src/assets/svgIcons/area_inactive.svg +26 -26
  40. package/src/assets/svgIcons/arrow_down.svg +3 -3
  41. package/src/assets/svgIcons/arrow_left.svg +4 -4
  42. package/src/assets/svgIcons/arrow_right.svg +4 -4
  43. package/src/assets/svgIcons/arrow_up.svg +3 -3
  44. package/src/assets/svgIcons/attachment.svg +3 -3
  45. package/src/assets/svgIcons/battery.svg +3 -3
  46. package/src/assets/svgIcons/bell.svg +3 -3
  47. package/src/assets/svgIcons/bold.svg +3 -3
  48. package/src/assets/svgIcons/bom.svg +3 -3
  49. package/src/assets/svgIcons/bom_generation.svg +10 -10
  50. package/src/assets/svgIcons/bubble.svg +3 -3
  51. package/src/assets/svgIcons/bullet_list.svg +8 -8
  52. package/src/assets/svgIcons/calendar.svg +7 -7
  53. package/src/assets/svgIcons/calendar_icon.svg +7 -7
  54. package/src/assets/svgIcons/call.svg +3 -3
  55. package/src/assets/svgIcons/camera.svg +3 -3
  56. package/src/assets/svgIcons/car.svg +3 -3
  57. package/src/assets/svgIcons/cart.svg +3 -3
  58. package/src/assets/svgIcons/checkbox.svg +3 -3
  59. package/src/assets/svgIcons/clear_formatting.svg +7 -7
  60. package/src/assets/svgIcons/clickable_info.svg +4 -4
  61. package/src/assets/svgIcons/clip.svg +3 -3
  62. package/src/assets/svgIcons/clock.svg +4 -4
  63. package/src/assets/svgIcons/close_for_modals,_tool_tips.svg +4 -4
  64. package/src/assets/svgIcons/collapse.svg +4 -4
  65. package/src/assets/svgIcons/component_library.svg +7 -7
  66. package/src/assets/svgIcons/context_menu-1.svg +6 -6
  67. package/src/assets/svgIcons/context_menu-2.svg +5 -5
  68. package/src/assets/svgIcons/context_menu.svg +5 -5
  69. package/src/assets/svgIcons/context_menu_tabs.svg +5 -5
  70. package/src/assets/svgIcons/current_variant.svg +4 -4
  71. package/src/assets/svgIcons/deadline.svg +4 -4
  72. package/src/assets/svgIcons/delete.svg +4 -4
  73. package/src/assets/svgIcons/delete_area_active.svg +16 -16
  74. package/src/assets/svgIcons/delete_area_inactive.svg +15 -15
  75. package/src/assets/svgIcons/direction_active-1.svg +12 -12
  76. package/src/assets/svgIcons/direction_active.svg +5 -5
  77. package/src/assets/svgIcons/direction_inactive.svg +4 -4
  78. package/src/assets/svgIcons/distances_active.svg +9 -9
  79. package/src/assets/svgIcons/distances_inactive.svg +8 -8
  80. package/src/assets/svgIcons/document.svg +3 -3
  81. package/src/assets/svgIcons/downarrow.svg +3 -3
  82. package/src/assets/svgIcons/download.svg +4 -4
  83. package/src/assets/svgIcons/duplicate-1.svg +8 -8
  84. package/src/assets/svgIcons/duplicate-2.svg +5 -5
  85. package/src/assets/svgIcons/duplicate-3.svg +3 -3
  86. package/src/assets/svgIcons/duplicate.svg +4 -4
  87. package/src/assets/svgIcons/e-mobility_configurator.svg +6 -6
  88. package/src/assets/svgIcons/edit_button.svg +3 -3
  89. package/src/assets/svgIcons/email.svg +3 -3
  90. package/src/assets/svgIcons/ems-1.svg +3 -3
  91. package/src/assets/svgIcons/ems.svg +3 -3
  92. package/src/assets/svgIcons/end_of_the_list.svg +5 -5
  93. package/src/assets/svgIcons/erase.svg +4 -4
  94. package/src/assets/svgIcons/fav_icon.svg +4 -4
  95. package/src/assets/svgIcons/financing_for_pv-1.svg +5 -5
  96. package/src/assets/svgIcons/financing_for_pv-2.svg +3 -3
  97. package/src/assets/svgIcons/financing_for_pv.svg +6 -6
  98. package/src/assets/svgIcons/finish-1.svg +4 -4
  99. package/src/assets/svgIcons/finish.svg +3 -3
  100. package/src/assets/svgIcons/folder.svg +3 -3
  101. package/src/assets/svgIcons/heat_calc.svg +7 -7
  102. package/src/assets/svgIcons/house.svg +3 -3
  103. package/src/assets/svgIcons/info.svg +3 -3
  104. package/src/assets/svgIcons/initial_situation.svg +3 -3
  105. package/src/assets/svgIcons/intro-tour-1.svg +3 -3
  106. package/src/assets/svgIcons/intro-tour.svg +3 -3
  107. package/src/assets/svgIcons/inverter-1.svg +5 -5
  108. package/src/assets/svgIcons/inverter.svg +3 -3
  109. package/src/assets/svgIcons/italic.svg +3 -3
  110. package/src/assets/svgIcons/key.svg +3 -3
  111. package/src/assets/svgIcons/lead_marketplace.svg +6 -6
  112. package/src/assets/svgIcons/lead_provider.svg +4 -4
  113. package/src/assets/svgIcons/length_in_2d_active.svg +12 -12
  114. package/src/assets/svgIcons/length_in_2d_inctive.svg +13 -13
  115. package/src/assets/svgIcons/light_bulb.svg +3 -3
  116. package/src/assets/svgIcons/line_graph.svg +3 -3
  117. package/src/assets/svgIcons/local_subsidies.svg +18 -18
  118. package/src/assets/svgIcons/location.svg +3 -3
  119. package/src/assets/svgIcons/lock.svg +3 -3
  120. package/src/assets/svgIcons/loop.svg +3 -3
  121. package/src/assets/svgIcons/lunch.svg +4 -4
  122. package/src/assets/svgIcons/map_icon.svg +3 -3
  123. package/src/assets/svgIcons/meeting.svg +6 -6
  124. package/src/assets/svgIcons/move_copy.svg +4 -4
  125. package/src/assets/svgIcons/new_area_inactive.svg +11 -11
  126. package/src/assets/svgIcons/next.svg +4 -4
  127. package/src/assets/svgIcons/not_equal_to.svg +3 -3
  128. package/src/assets/svgIcons/numbered_list.svg +6 -6
  129. package/src/assets/svgIcons/obstacle_tool.svg +13 -13
  130. package/src/assets/svgIcons/pan_tool.svg +12 -12
  131. package/src/assets/svgIcons/panels_tool.svg +8 -8
  132. package/src/assets/svgIcons/pen_tool.svg +4 -4
  133. package/src/assets/svgIcons/picker_tool.svg +4 -4
  134. package/src/assets/svgIcons/picture.svg +3 -3
  135. package/src/assets/svgIcons/pin.svg +5 -5
  136. package/src/assets/svgIcons/presentation.svg +3 -3
  137. package/src/assets/svgIcons/previous.svg +4 -4
  138. package/src/assets/svgIcons/profile-1.svg +4 -4
  139. package/src/assets/svgIcons/profile.svg +4 -4
  140. package/src/assets/svgIcons/profitability.svg +3 -3
  141. package/src/assets/svgIcons/project_analysis.svg +4 -4
  142. package/src/assets/svgIcons/project_settings.svg +4 -4
  143. package/src/assets/svgIcons/pv.svg +3 -3
  144. package/src/assets/svgIcons/quotations.svg +6 -6
  145. package/src/assets/svgIcons/rotate_view.svg +5 -5
  146. package/src/assets/svgIcons/run_simulation.svg +3 -3
  147. package/src/assets/svgIcons/scaling_tool.svg +8 -8
  148. package/src/assets/svgIcons/search.svg +3 -3
  149. package/src/assets/svgIcons/security.svg +3 -3
  150. package/src/assets/svgIcons/settings.svg +3 -3
  151. package/src/assets/svgIcons/show_in_a_new_tab.svg +12 -12
  152. package/src/assets/svgIcons/smartphone.svg +4 -4
  153. package/src/assets/svgIcons/solar_calc.svg +13 -13
  154. package/src/assets/svgIcons/sorting.svg +4 -4
  155. package/src/assets/svgIcons/start_of_the_list.svg +5 -5
  156. package/src/assets/svgIcons/strikethrough.svg +4 -4
  157. package/src/assets/svgIcons/subsidies-1.svg +5 -5
  158. package/src/assets/svgIcons/subsidies-2.svg +3 -3
  159. package/src/assets/svgIcons/subsidies.svg +3 -3
  160. package/src/assets/svgIcons/subtract_icon.svg +3 -3
  161. package/src/assets/svgIcons/suitcase.svg +3 -3
  162. package/src/assets/svgIcons/template_icon_not_clickable.svg +6 -6
  163. package/src/assets/svgIcons/truck.svg +3 -3
  164. package/src/assets/svgIcons/underlined.svg +3 -3
  165. package/src/assets/svgIcons/uparrow.svg +3 -3
  166. package/src/assets/svgIcons/upload_avatar-1.svg +12 -12
  167. package/src/assets/svgIcons/upload_avatar.svg +5 -5
  168. package/src/assets/svgIcons/upload_image.svg +8 -8
  169. package/src/assets/svgIcons/virtual_storage.svg +4 -4
  170. package/src/assets/svgIcons/warning.svg +4 -4
  171. package/src/assets/svgIcons/way.svg +5 -5
  172. package/src/assets/svgIcons/wifi.svg +3 -3
  173. package/src/assets/svgIcons/winter.svg +3 -3
  174. package/src/assets/theme.js +34 -34
  175. package/src/components/addNewButton/AddNewButton.stories.js +24 -24
  176. package/src/components/addNewButton/index.vue +58 -58
  177. package/src/components/buttons/closeButton/CloseButton.stories.js +29 -29
  178. package/src/components/buttons/closeButton/index.vue +61 -61
  179. package/src/components/buttons/externalButton/index.vue +101 -101
  180. package/src/components/buttons/mainButton/index.vue +82 -82
  181. package/src/components/deleteIcon/DeleteIcon.stories.js +29 -29
  182. package/src/components/deleteIcon/index.vue +55 -55
  183. package/src/components/errorMessage/index.vue +62 -0
  184. package/src/components/icon/Icons.stories.js +41 -41
  185. package/src/components/icon/iconCollection.vue +68 -68
  186. package/src/components/icon/index.vue +76 -76
  187. package/src/components/infoText/index.vue +166 -151
  188. package/src/components/inputs/checkbox/Checkbox.stories.js +57 -57
  189. package/src/components/inputs/checkbox/index.vue +182 -182
  190. package/src/components/inputs/inputNumber/InputNumber.stories.js +150 -150
  191. package/src/components/inputs/inputNumber/index.vue +483 -390
  192. package/src/components/inputs/inputNumberQuestion/index.vue +215 -215
  193. package/src/components/inputs/inputText/InputText.stories.js +75 -75
  194. package/src/components/inputs/inputText/index.vue +200 -198
  195. package/src/components/inputs/radioButton/RadioButton.stories.js +58 -58
  196. package/src/components/inputs/radioButton/index.vue +253 -253
  197. package/src/components/inputs/searchInput/SearchInput.stories.js +40 -40
  198. package/src/components/inputs/searchInput/index.vue +96 -96
  199. package/src/components/inputs/slider/index.vue +126 -126
  200. package/src/components/inputs/textAreaInput/TextAreaInput.stories.js +135 -135
  201. package/src/components/inputs/textAreaInput/index.vue +194 -189
  202. package/src/components/inputs/toggle/Toggle.stories.js +77 -77
  203. package/src/components/inputs/toggle/index.vue +288 -288
  204. package/src/components/modals/modal/index.vue +153 -153
  205. package/src/components/modals/modal/modal.stories.js +31 -31
  206. package/src/components/pageSubtitle/index.vue +64 -64
  207. package/src/components/pageTitle/index.vue +37 -37
  208. package/src/components/progressBar/index.vue +125 -125
  209. package/src/components/spinner/index.vue +71 -71
  210. package/src/components/tableDropdown/index.vue +644 -644
  211. package/src/components/tables/mainTable/exampleNested.vue +328 -328
  212. package/src/components/tables/mainTable/index.vue +365 -365
  213. package/src/components/tables/viewTable/index.vue +195 -195
  214. package/src/components/threeDots/index.vue +324 -324
  215. package/src/helpers/numberConverter.js +101 -98
  216. package/src/helpers/translateLang.js +80 -80
  217. package/src/main.js +11 -11
@@ -1,390 +1,483 @@
1
- <template>
2
- <container>
3
- <label-wrapper v-if="labelText">
4
- <label-text>
5
- {{ labelText }}
6
- </label-text>
7
- <info-text
8
- v-if="labelInfoText"
9
- :text="labelInfoText"
10
- borderColor="#ccc"
11
- size="13"
12
- :alignText="labelInfoAlign"
13
- />
14
- </label-wrapper>
15
- <input-wrapper>
16
- <input-container
17
- ref="inputField1"
18
- :hasUnit="unitName && !!unitName.length"
19
- :placeholder="placeholder"
20
- :isError="isError"
21
- :inputWidth="inputWidth"
22
- :minWidth="minWidth"
23
- :value="formatWithCurrency(value)"
24
- @blur="onInputBlur($event)"
25
- @focus="focusInput()"
26
- @keyup.enter="$emit('on-enter-click')"
27
- :disabled="disabled"
28
- :isDisabled="disabled"
29
- :noBorder="noBorder"
30
- :textAlign="textAlign"
31
- :fontSize="fontSize"
32
- :fontColor="fontColor"
33
- />
34
- <unit-container
35
- v-if="unitName && showLinearUnitName"
36
- :hasLength="!!textInput.length"
37
- :isError="isError"
38
- >{{ unitName }}</unit-container
39
- >
40
- </input-wrapper>
41
- <error-message v-if="isError">{{ errorMessage }}</error-message>
42
- </container>
43
- </template>
44
-
45
- <script>
46
- // import InputNumber from "@eturnity/eturnity_reusable_components/src/components/inputs/inputNumber"
47
- //This component should be used for questions with input fields only
48
- //How to use:
49
- // <input-number
50
- // placeholder="Enter distance"
51
- // :isError="false" //default is false
52
- // inputWidth="150px" //by default, this is 100%
53
- // minWidth="100px"
54
- // :numberPrecision="3"
55
- // unitName="pc"
56
- // :value="inputValue" //required -- String
57
- // @input-change="onInputChange($event)" //required
58
- // @on-enter-click="onInputSubmit()"
59
- // :errorMessage="Enter a number between 1 and 10"
60
- // :disabled="false"
61
- // :noBorder="true"
62
- // textAlign="left" // "left, right, center"
63
- // :showLinearUnitName="true"
64
- // fontSize="13px"
65
- // labelText="Number of Modules"
66
- // labelInfoText="Here is some information for you..."
67
- // labelInfoAlign="left"
68
- // :minNumber="0"
69
- // fontColor="blue"
70
- // />
71
- import styled from 'vue-styled-components'
72
- import {
73
- stringToNumber,
74
- numberToString
75
- } from '../../../helpers/numberConverter'
76
- import InfoText from '../../infoText'
77
-
78
- const Container = styled.div`
79
- width: 100%;
80
- position: relative;
81
- `
82
-
83
- const inputProps = {
84
- isError: Boolean,
85
- hasUnit: Boolean,
86
- inputWidth: String,
87
- minWidth: String,
88
- isDisabled: Boolean,
89
- noBorder: Boolean,
90
- textAlign: String,
91
- fontSize: String,
92
- fontColor: String
93
- }
94
- const InputContainer = styled('input', inputProps)`
95
- border: ${(props) =>
96
- props.isError
97
- ? '1px solid ' + props.theme.colors.red
98
- : props.noBorder
99
- ? 'none'
100
- : '1px solid ' + props.theme.colors.mediumGray};
101
- padding: ${(props) =>
102
- props.hasUnit ? '11px 40px 11px 10px' : '11px 5px 11px 10px'};
103
- border-radius: 4px;
104
- text-align: ${(props) => props.textAlign};
105
- cursor: ${(props) => (props.isDisabled ? 'not-allowed' : 'auto')};
106
- font-size: ${(props) => (props.fontSize ? props.fontSize : '13px')};
107
- color: ${(props) =>
108
- props.isError
109
- ? props.theme.colors.red
110
- : props.fontColor
111
- ? props.fontColor + ' !important'
112
- : props.theme.colors.black};
113
- width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
114
- min-width: ${(props) => (props.minWidth ? props.minWidth : 'unset')};
115
- background-color: ${(props) =>
116
- props.isDisabled ? props.theme.colors.grey5 : '#fff'};
117
- box-sizing: border-box;
118
-
119
- &::placeholder {
120
- color: ${(props) =>
121
- props.isError ? props.theme.colors.red : props.theme.colors.darkGray};
122
- }
123
-
124
- &:focus {
125
- outline: none;
126
- }
127
- `
128
-
129
- const InputWrapper = styled.span`
130
- position: relative;
131
- `
132
-
133
- const UnitContainer = styled('span', inputProps)`
134
- border-left: 1px solid
135
- ${(props) =>
136
- props.isError
137
- ? props.theme.colors.red
138
- : props.hasLength
139
- ? props.theme.colors.black
140
- : props.theme.colors.mediumGray};
141
- position: absolute;
142
- right: 10px;
143
- top: 0;
144
- padding-left: 10px;
145
- color: ${(props) =>
146
- props.isError
147
- ? props.theme.colors.red
148
- : props.hasLength
149
- ? props.theme.colors.black
150
- : props.theme.colors.mediumGray};
151
- `
152
-
153
- const ErrorMessage = styled.div`
154
- font-size: 14px;
155
- color: ${(props) => props.theme.colors.red};
156
- position: absolute;
157
- top: calc(100% + 1px);
158
- `
159
-
160
- const LabelWrapper = styled.div`
161
- display: flex;
162
- gap: 10px;
163
- margin-bottom: 8px;
164
- `
165
-
166
- const LabelText = styled.div`
167
- font-weight: bold;
168
- font-size: 13px;
169
- `
170
-
171
- export default {
172
- name: 'input-number',
173
- components: {
174
- Container,
175
- InputContainer,
176
- InputWrapper,
177
- UnitContainer,
178
- ErrorMessage,
179
- LabelWrapper,
180
- LabelText,
181
- InfoText
182
- },
183
- data() {
184
- return {
185
- textInput: '',
186
- isFocused: false
187
- }
188
- },
189
- props: {
190
- placeholder: {
191
- required: false,
192
- default: ''
193
- },
194
- isError: {
195
- required: false,
196
- default: false
197
- },
198
- inputWidth: {
199
- required: false,
200
- default: null
201
- },
202
- minWidth: {
203
- required: false,
204
- default: null
205
- },
206
- value: {
207
- required: true,
208
- default: null
209
- },
210
- clearInput: {
211
- required: false,
212
- default: false
213
- },
214
- errorMessage: {
215
- required: false,
216
- default: 'Please insert a correct number'
217
- },
218
- numberPrecision: {
219
- required: false,
220
- default: 0
221
- },
222
- unitName: {
223
- required: false,
224
- default: ''
225
- },
226
- showLinearUnitName: {
227
- required: false,
228
- default: false
229
- },
230
- disabled: {
231
- required: false,
232
- default: false
233
- },
234
- noBorder: {
235
- required: false,
236
- default: false
237
- },
238
- textAlign: {
239
- required: false,
240
- default: 'left'
241
- },
242
- fontSize: {
243
- required: false,
244
- default: '13px'
245
- },
246
- labelText: {
247
- required: false,
248
- default: null
249
- },
250
- labelInfoText: {
251
- required: false,
252
- default: null
253
- },
254
- labelInfoAlign: {
255
- required: false,
256
- default: 'right'
257
- },
258
- minNumber: {
259
- required: false,
260
- default: null
261
- },
262
- fontColor: {
263
- required: false,
264
- default: null
265
- },
266
- numberToStringEnabled: {
267
- required: false,
268
- default: true
269
- }
270
- },
271
- methods: {
272
- onChangeHandler(event) {
273
- if (isNaN(event)) {
274
- event = this.minNumber || this.minNumber === 0 ? this.minNumber : event
275
- }
276
- this.$emit('input-change', event)
277
- },
278
- onEvaluateCode(val) {
279
- // function to perform math on the code
280
- // filter the string in case of any malicious content
281
- let filtered = val.replace(/[^-()\d/*+.,]/g, '')
282
- filtered = filtered.split(/([-+*/()])/)
283
- let formatted = filtered.map((item) => {
284
- if (
285
- item === '+' ||
286
- item === '-' ||
287
- item === '*' ||
288
- item === '/' ||
289
- item === '(' ||
290
- item === ')' ||
291
- item === ''
292
- ) {
293
- return item
294
- } else {
295
- let num = stringToNumber({
296
- value: item,
297
- numberPrecision: false
298
- })
299
- return num
300
- }
301
- })
302
- let evaluated = eval(formatted.join(''))
303
- if (typeof evaluated === 'string') {
304
- evaluated = stringToNumber({
305
- value: evaluated,
306
- numberPrecision: this.numberPrecision
307
- })
308
- }
309
- return evaluated
310
- },
311
- onInputBlur(e) {
312
- this.isFocused = false
313
- let value = e.target.value
314
- let evaluatedInput = this.onEvaluateCode(value)
315
- this.onChangeHandler(evaluatedInput ? evaluatedInput : value)
316
- if ((evaluatedInput && value.length) || this.minNumber !== null) {
317
- this.textInput = numberToString({
318
- value:
319
- evaluatedInput && value.length ? evaluatedInput : this.minNumber,
320
- numberPrecision: this.numberPrecision
321
- })
322
- }
323
- let adjustedMinValue =
324
- value && value.length
325
- ? value
326
- : this.minNumber || this.minNumber === 0
327
- ? this.minNumber
328
- : ''
329
- this.$emit('input-blur', adjustedMinValue)
330
- },
331
- focusInput() {
332
- if (this.disabled) {
333
- return
334
- }
335
- this.isFocused = true
336
- this.$nextTick(() => {
337
- this.$refs.inputField1.$el.select()
338
- })
339
- },
340
- formatWithCurrency(value) {
341
- let adjustedMinValue =
342
- value || value === 0
343
- ? value
344
- : this.minNumber || this.minNumber === 0
345
- ? this.minNumber
346
- : ''
347
- if ((adjustedMinValue || adjustedMinValue === 0) && !this.isFocused) {
348
- let input = this.numberToStringEnabled
349
- ? numberToString({
350
- value: adjustedMinValue,
351
- numberPrecision: this.numberPrecision
352
- })
353
- : adjustedMinValue
354
- let unit = this.showLinearUnitName ? '' : this.unitName
355
- return input + ' ' + unit
356
- } else if (!adjustedMinValue && adjustedMinValue !== 0) {
357
- return ''
358
- } else {
359
- return this.numberToStringEnabled
360
- ? numberToString({
361
- value: adjustedMinValue,
362
- numberPrecision: this.numberPrecision
363
- })
364
- : adjustedMinValue
365
- }
366
- }
367
- },
368
- created() {
369
- if (this.value) {
370
- this.textInput = numberToString({
371
- value: this.value,
372
- numberPrecision: this.numberPrecision
373
- })
374
- } else if (this.minNumber !== null) {
375
- this.textInput = numberToString({
376
- value: this.minNumber,
377
- numberPrecision: this.numberPrecision
378
- })
379
- }
380
- },
381
- watch: {
382
- clearInput: function (value) {
383
- if (value) {
384
- // If the value is typed, then we should clear the textInput on Continue
385
- this.textInput = ''
386
- }
387
- }
388
- }
389
- }
390
- </script>
1
+ <template>
2
+ <container :inputWidth="inputWidth">
3
+ <label-wrapper v-if="labelText">
4
+ <label-text>
5
+ {{ labelText }}
6
+ </label-text>
7
+ <info-text
8
+ v-if="labelInfoText"
9
+ :text="labelInfoText"
10
+ borderColor="#ccc"
11
+ size="14px"
12
+ :alignText="labelInfoAlign"
13
+ />
14
+ </label-wrapper>
15
+ <input-wrapper>
16
+ <input-container
17
+ v-bind="$attrs"
18
+ ref="inputField1"
19
+ :hasUnit="unitName && !!unitName.length"
20
+ :placeholder="displayedPlaceholder"
21
+ :isError="isError"
22
+ :inputWidth="inputWidth"
23
+ :inputHeight="inputHeight"
24
+ :minWidth="minWidth"
25
+ :value="formatWithCurrency(value)"
26
+ @input.native="onChangeHandler($event.target.value)"
27
+ @blur="onInputBlur($event)"
28
+ @focus="focusInput()"
29
+ @keyup.enter="$emit('on-enter-click')"
30
+ :disabled="disabled"
31
+ :isDisabled="disabled"
32
+ :noBorder="noBorder"
33
+ :textAlign="textAlign"
34
+ :fontSize="fontSize"
35
+ :fontColor="fontColor"
36
+ v-on="$listeners"
37
+ :hasSlot="hasSlot"
38
+ :slotSize="slotSize"
39
+ />
40
+ <slot-container v-if="hasSlot" :slotSize="slotSize" :isError="isError">
41
+ <slot></slot>
42
+ </slot-container>
43
+
44
+ <unit-container
45
+ v-if="unitName && showLinearUnitName && !hasSlot"
46
+ :hasLength="!!textInput.length"
47
+ :isError="isError"
48
+ >{{ unitName }}</unit-container
49
+ >
50
+ <icon
51
+ v-if="(isError || inputIcon) && !showLinearUnitName"
52
+ :class="inputIconImageClass"
53
+ :src="isError ? warningIcon : inputIconImage"
54
+ />
55
+ </input-wrapper>
56
+ <error-message v-if="isError">{{ errorMessage }}</error-message>
57
+ </container>
58
+ </template>
59
+
60
+ <script>
61
+ // import InputNumber from "@eturnity/eturnity_reusable_components/src/components/inputs/inputNumber"
62
+ //This component should be used for questions with input fields only
63
+ //How to use:
64
+ // <input-number
65
+ // placeholder="Enter distance"
66
+ // :isError="false" //default is false
67
+ // inputWidth="150px" //by default, this is 100%
68
+ // minWidth="100px"
69
+ // :numberPrecision="3"
70
+ // unitName="pc"
71
+ // :value="inputValue" //required -- String
72
+ // @input-change="onInputChange($event)" //required
73
+ // @on-enter-click="onInputSubmit()"
74
+ // :errorMessage="Enter a number between 1 and 10"
75
+ // :disabled="false"
76
+ // :noBorder="true"
77
+ // textAlign="left" // "left, right, center"
78
+ // :showLinearUnitName="true"
79
+ // fontSize="13px"
80
+ // labelText="Number of Modules"
81
+ // labelInfoText="Here is some information for you..."
82
+ // labelInfoAlign="left"
83
+ // :minNumber="0"
84
+ // fontColor="blue"
85
+ // />
86
+ import styled from 'vue-styled-components'
87
+ import {
88
+ stringToNumber,
89
+ numberToString
90
+ } from '../../../helpers/numberConverter'
91
+ import InfoText from '../../infoText'
92
+ import ErrorMessage from '../../errorMessage'
93
+ import warningIcon from '../../../assets/icons/error_icon.png'
94
+
95
+ const inputProps = {
96
+ isError: Boolean,
97
+ hasUnit: Boolean,
98
+ inputWidth: String,
99
+ minWidth: String,
100
+ isDisabled: Boolean,
101
+ noBorder: Boolean,
102
+ textAlign: String,
103
+ fontSize: String,
104
+ fontColor: String,
105
+ hasSlot: Boolean,
106
+ slotSize: String,
107
+ inputHeight:String
108
+ }
109
+
110
+ const Container = styled('div', inputProps)`
111
+ width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
112
+ position: relative;
113
+ `
114
+
115
+ const InputContainer = styled('input', inputProps)`
116
+ border: ${(props) =>
117
+ props.isError
118
+ ? '1px solid ' + props.theme.colors.red
119
+ : props.noBorder
120
+ ? 'none'
121
+ : '1px solid ' + props.theme.colors.mediumGray};
122
+ padding-top: 11px;
123
+ padding-bottom: 11px;
124
+ padding-left: 10px;
125
+ padding-right: ${(props) =>
126
+ props.slotSize
127
+ ? 'calc(' + props.slotSize + ' + 10px)'
128
+ : props.hasUnit
129
+ ? '40px'
130
+ : '5px'};
131
+ border-radius: 4px;
132
+ text-align: ${(props) => props.textAlign};
133
+ cursor: ${(props) => (props.isDisabled ? 'not-allowed' : 'auto')};
134
+ font-size: ${(props) => (props.fontSize ? props.fontSize : '13px')};
135
+ color: ${(props) =>
136
+ props.isError
137
+ ? props.theme.colors.red
138
+ : props.fontColor
139
+ ? props.fontColor + ' !important'
140
+ : props.theme.colors.black};
141
+ width: ${(props) => (props.inputWidth ? props.inputWidth : '100%')};
142
+ min-width: ${(props) => (props.minWidth ? props.minWidth : 'unset')};
143
+ background-color: ${(props) =>
144
+ props.isDisabled ? props.theme.colors.grey5 : '#fff'};
145
+ box-sizing: border-box;
146
+ max-height: ${(props) => (props.inputHeight)};
147
+ &::placeholder {
148
+ color: ${(props) =>
149
+ props.isError ? props.theme.colors.red : props.theme.colors.darkGray};
150
+ }
151
+
152
+ &:focus {
153
+ outline: none;
154
+ }
155
+ `
156
+ const IconProps = {
157
+ inputIconHeight: String
158
+ }
159
+
160
+ const Icon = styled('img', IconProps)`
161
+ position: absolute;
162
+ right: 10px;
163
+ top: 2px;
164
+ `
165
+
166
+ const InputWrapper = styled.span`
167
+ position: relative;
168
+ `
169
+
170
+ const UnitContainer = styled('span', inputProps)`
171
+ border-left: 1px solid
172
+ ${(props) =>
173
+ props.isError
174
+ ? props.theme.colors.red
175
+ : props.hasLength
176
+ ? props.theme.colors.black
177
+ : props.theme.colors.mediumGray};
178
+ position: absolute;
179
+ right: 10px;
180
+ top: 0;
181
+ padding-left: 10px;
182
+ text-align: right;
183
+ color: ${(props) =>
184
+ props.isError
185
+ ? props.theme.colors.red
186
+ : props.hasLength
187
+ ? props.theme.colors.black
188
+ : props.theme.colors.mediumGray};
189
+ `
190
+
191
+ const SlotContainer = styled('span', inputProps)`
192
+ text-align: right;
193
+ border-left: 1px solid
194
+ ${(props) =>
195
+ props.isError
196
+ ? props.theme.colors.red
197
+ : props.hasLength
198
+ ? props.theme.colors.black
199
+ : props.theme.colors.mediumGray};
200
+ position: absolute;
201
+ width: ${(props) =>
202
+ props.slotSize ? 'calc(' + props.slotSize + ' - 10px)' : 'fit-content'};
203
+ right: 10px;
204
+ top: 0;
205
+ padding-left: 10px;
206
+ color: ${(props) =>
207
+ props.isError
208
+ ? props.theme.colors.red
209
+ : props.hasLength
210
+ ? props.theme.colors.black
211
+ : props.theme.colors.mediumGray};
212
+ `
213
+
214
+ const LabelWrapper = styled.div`
215
+ display: flex;
216
+ gap: 10px;
217
+ margin-bottom: 8px;
218
+ `
219
+
220
+ const LabelText = styled.div`
221
+ font-weight: bold;
222
+ font-size: 13px;
223
+ `
224
+
225
+ export default {
226
+ name: 'input-number',
227
+ components: {
228
+ Container,
229
+ InputContainer,
230
+ InputWrapper,
231
+ UnitContainer,
232
+ ErrorMessage,
233
+ LabelWrapper,
234
+ LabelText,
235
+ InfoText,
236
+ Icon,
237
+ SlotContainer
238
+ },
239
+ inheritAttrs: false,
240
+ data() {
241
+ return {
242
+ textInput: '',
243
+ isFocused: false,
244
+ warningIcon: warningIcon,
245
+ }
246
+ },
247
+ props: {
248
+ placeholder: {
249
+ required: false,
250
+ default: ''
251
+ },
252
+ isError: {
253
+ required: false,
254
+ default: false
255
+ },
256
+ inputWidth: {
257
+ required: false,
258
+ default: null
259
+ },
260
+ minWidth: {
261
+ required: false,
262
+ default: null
263
+ },
264
+ inputHeight:{
265
+ required:false,
266
+ default:null
267
+ },
268
+ value: {
269
+ required: true,
270
+ default: null
271
+ },
272
+ clearInput: {
273
+ required: false,
274
+ default: false
275
+ },
276
+ errorMessage: {
277
+ required: false,
278
+ default: 'Please insert a correct number'
279
+ },
280
+ numberPrecision: {
281
+ required: false,
282
+ default: 0
283
+ },
284
+ unitName: {
285
+ required: false,
286
+ default: ''
287
+ },
288
+ showLinearUnitName: {
289
+ required: false,
290
+ default: false
291
+ },
292
+ disabled: {
293
+ required: false,
294
+ default: false
295
+ },
296
+ noBorder: {
297
+ required: false,
298
+ default: false
299
+ },
300
+ textAlign: {
301
+ required: false,
302
+ default: 'left'
303
+ },
304
+ fontSize: {
305
+ required: false,
306
+ default: '13px'
307
+ },
308
+ labelText: {
309
+ required: false,
310
+ default: null
311
+ },
312
+ labelInfoText: {
313
+ required: false,
314
+ default: null
315
+ },
316
+ labelInfoAlign: {
317
+ required: false,
318
+ default: 'left'
319
+ },
320
+ minNumber: {
321
+ required: false,
322
+ default: null
323
+ },
324
+ fontColor: {
325
+ required: false,
326
+ default: null
327
+ },
328
+ numberToStringEnabled: {
329
+ required: false,
330
+ default: true
331
+ },
332
+ inputIcon: {
333
+ require: false,
334
+ type: Boolean,
335
+ default: false
336
+ },
337
+ inputIconImage: {
338
+ require: false,
339
+ type: String,
340
+ default: ''
341
+ },
342
+ inputIconImageClass: {
343
+ require: false,
344
+ type: Array,
345
+ default: () => []
346
+ },
347
+ slotSize: {
348
+ required: false
349
+ }
350
+ },
351
+ computed: {
352
+ displayedPlaceholder() {
353
+ if (this.placeholder) return this.placeholder
354
+ return `${this.minNumber || 0} ${this.unitName ? this.unitName : ''}`
355
+ },
356
+ hasSlot() {
357
+ return !!this.$slots.default
358
+ },
359
+ computedSlotSize() {
360
+ return this.slotSize || this.$slots['default'][0].elm.clientWidth
361
+ }
362
+ },
363
+ methods: {
364
+ onChangeHandler(event) {
365
+ if (isNaN(event) || event=="") {
366
+ event = this.minNumber || this.minNumber === 0 ? this.minNumber : event
367
+ }
368
+ this.$emit('input-change', event)
369
+ },
370
+ onEvaluateCode(val) {
371
+ // function to perform math on the code
372
+ // filter the string in case of any malicious content
373
+ let filtered = val.replace(/[^-()\d/*+.,]/g, '')
374
+ filtered = filtered.split(/([-+*/()])/)
375
+ let formatted = filtered.map((item) => {
376
+ if (
377
+ item === '+' ||
378
+ item === '-' ||
379
+ item === '*' ||
380
+ item === '/' ||
381
+ item === '(' ||
382
+ item === ')' ||
383
+ item === ''
384
+ ) {
385
+ return item
386
+ } else {
387
+ let num = stringToNumber({
388
+ value: item,
389
+ numberPrecision: false
390
+ })
391
+ return num
392
+ }
393
+ })
394
+ let evaluated = eval(formatted.join(''))
395
+ if (typeof evaluated === 'string') {
396
+ evaluated = stringToNumber({
397
+ value: evaluated,
398
+ numberPrecision: this.numberPrecision
399
+ })
400
+ }
401
+ return evaluated
402
+ },
403
+ onInputBlur(e) {
404
+ this.isFocused = false
405
+ let value = e.target.value
406
+ let evaluatedInput = this.onEvaluateCode(value)
407
+ this.onChangeHandler(evaluatedInput ? evaluatedInput : value)
408
+ if ((evaluatedInput && value.length) || this.minNumber !== null) {
409
+ this.textInput = numberToString({
410
+ value:
411
+ evaluatedInput && value.length ? evaluatedInput : this.minNumber,
412
+ numberPrecision: this.numberPrecision
413
+ })
414
+ }
415
+ let adjustedMinValue =
416
+ value && value.length
417
+ ? value
418
+ : this.minNumber || this.minNumber === 0
419
+ ? this.minNumber
420
+ : ''
421
+ this.$emit('input-blur', adjustedMinValue)
422
+ },
423
+ focusInput() {
424
+ if (this.disabled) {
425
+ return
426
+ }
427
+ this.isFocused = true
428
+ this.$nextTick(() => {
429
+ this.$refs.inputField1.$el.select()
430
+ })
431
+ this.$emit('input-focus')
432
+ },
433
+ formatWithCurrency(value) {
434
+ let adjustedMinValue =
435
+ value || value === 0
436
+ ? value
437
+ : this.minNumber || this.minNumber === 0
438
+ ? this.minNumber
439
+ : ''
440
+ if ((adjustedMinValue || adjustedMinValue === 0) && !this.isFocused) {
441
+ let input = this.numberToStringEnabled
442
+ ? numberToString({
443
+ value: adjustedMinValue,
444
+ numberPrecision: this.numberPrecision
445
+ })
446
+ : adjustedMinValue
447
+ let unit = this.showLinearUnitName ? '' : this.unitName
448
+ return input + ' ' + unit
449
+ } else if (!adjustedMinValue && adjustedMinValue !== 0) {
450
+ return ''
451
+ } else {
452
+ return this.numberToStringEnabled
453
+ ? numberToString({
454
+ value: adjustedMinValue,
455
+ numberPrecision: this.numberPrecision
456
+ })
457
+ : adjustedMinValue
458
+ }
459
+ }
460
+ },
461
+ created() {
462
+ if (this.value) {
463
+ this.textInput = numberToString({
464
+ value: this.value,
465
+ numberPrecision: this.numberPrecision
466
+ })
467
+ } else if (this.minNumber !== null) {
468
+ this.textInput = numberToString({
469
+ value: this.minNumber,
470
+ numberPrecision: this.numberPrecision
471
+ })
472
+ }
473
+ },
474
+ watch: {
475
+ clearInput: function (value) {
476
+ if (value) {
477
+ // If the value is typed, then we should clear the textInput on Continue
478
+ this.textInput = ''
479
+ }
480
+ }
481
+ }
482
+ }
483
+ </script>