@eturnity/eturnity_reusable_components 8.26.11-EPDM-15023.0 → 8.26.11-EPDM-11600.15

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/dist/main.es15.js CHANGED
@@ -10,13 +10,11 @@ const ButtonAttrs = {
10
10
  type: String,
11
11
  isDisabled: Boolean,
12
12
  minWidth: String,
13
- width: String,
14
13
  noWrap: Boolean,
15
14
  height: String,
16
15
  variant: String,
17
16
  buttonSize: String,
18
- appTheme: String,
19
- isActive: Boolean
17
+ appTheme: String
20
18
  };
21
19
  const ButtonContainer = styled("div", ButtonAttrs)`
22
20
  display: flex;
@@ -30,7 +28,7 @@ const ButtonContainer = styled("div", ButtonAttrs)`
30
28
  return (_d = (_c = (_b = (_a = props.theme) == null ? void 0 : _a.mainButton) == null ? void 0 : _b.size) == null ? void 0 : _c[props.buttonSize]) == null ? void 0 : _d.fontSize;
31
29
  }};
32
30
  color: ${(props) => props.isDisabled ? props.theme.mainButton[props.appTheme][props.type][props.variant].disabled.textColor : props.theme.mainButton[props.appTheme][props.type][props.variant].default.textColor};
33
- background-color: ${(props) => props.isDisabled ? props.theme.mainButton[props.appTheme][props.type][props.variant].disabled.backgroundColor : props.isActive ? props.theme.mainButton[props.appTheme][props.type][props.variant].active.backgroundColor : props.theme.mainButton[props.appTheme][props.type][props.variant].default.backgroundColor};
31
+ background-color: ${(props) => props.isDisabled ? props.theme.mainButton[props.appTheme][props.type][props.variant].disabled.backgroundColor : props.theme.mainButton[props.appTheme][props.type][props.variant].default.backgroundColor};
34
32
  border: ${(props) => {
35
33
  const borderValue = props.isDisabled ? props.theme.mainButton[props.appTheme][props.type][props.variant].disabled.borderColor : props.theme.mainButton[props.appTheme][props.type][props.variant].default.borderColor;
36
34
  return borderValue ? "1px solid " + borderValue : "none";
@@ -43,7 +41,7 @@ const ButtonContainer = styled("div", ButtonAttrs)`
43
41
  ${(props) => props.noWrap ? `white-space: nowrap;` : ""};
44
42
  height: ${(props) => props.height};
45
43
  line-height: 1;
46
- width: ${(props) => props.width};
44
+
47
45
  &:hover {
48
46
  background-color: ${(props) => props.isDisabled ? props.theme.mainButton[props.appTheme][props.type][props.variant].disabled.backgroundColor : props.theme.mainButton[props.appTheme][props.type][props.variant].hover.backgroundColor};
49
47
  }
@@ -107,11 +105,6 @@ const _sfc_main = {
107
105
  default: false,
108
106
  type: Boolean
109
107
  },
110
- isActive: {
111
- required: false,
112
- default: false,
113
- type: Boolean
114
- },
115
108
  icon: {
116
109
  required: false,
117
110
  default: null,
@@ -146,11 +139,6 @@ const _sfc_main = {
146
139
  default: null,
147
140
  type: String
148
141
  },
149
- width: {
150
- required: false,
151
- default: "auto",
152
- type: String
153
- },
154
142
  height: {
155
143
  required: false,
156
144
  default: "auto",
@@ -201,13 +189,11 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
201
189
  "data-id": $props.dataId,
202
190
  "data-qa-id": $props.dataQaId,
203
191
  height: $props.height,
204
- "is-active": $props.isActive,
205
192
  "is-disabled": $props.isDisabled,
206
193
  "min-width": $props.minWidth,
207
194
  "no-wrap": $props.noWrap,
208
195
  type: $props.type,
209
- variant: $props.variant,
210
- width: $props.width
196
+ variant: $props.variant
211
197
  }, {
212
198
  default: withCtx(() => [createVNode(_component_LabelComponent, {
213
199
  "has-icon": Boolean($props.icon)
@@ -222,7 +208,7 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
222
208
  _: 1
223
209
  }, 8, ["has-icon"])]),
224
210
  _: 1
225
- }, 8, ["id", "app-theme", "button-size", "data-id", "data-qa-id", "height", "is-active", "is-disabled", "min-width", "no-wrap", "type", "variant", "width"])]),
211
+ }, 8, ["id", "app-theme", "button-size", "data-id", "data-qa-id", "height", "is-disabled", "min-width", "no-wrap", "type", "variant"])]),
226
212
  _: 1
227
213
  });
228
214
  }
@@ -2,25 +2,19 @@ import "./main.es3.js";
2
2
  import { openBlock, createElementBlock, createElementVNode as createBaseVNode } from "./main.es6.js";
3
3
  const _hoisted_1 = {
4
4
  xmlns: "http://www.w3.org/2000/svg",
5
- width: "16",
6
- height: "16",
5
+ width: "22",
6
+ height: "21",
7
7
  fill: "none"
8
8
  };
9
- const _hoisted_2 = /* @__PURE__ */ createBaseVNode("circle", {
10
- cx: "20",
11
- cy: "20",
12
- r: "7"
13
- }, null, -1);
14
- const _hoisted_3 = /* @__PURE__ */ createBaseVNode("path", {
9
+ const _hoisted_2 = /* @__PURE__ */ createBaseVNode("path", {
15
10
  fill: "#FF5656",
16
- d: "M24.96 15.04c-2.722-2.72-7.198-2.72-9.92 0-2.72 2.722-2.72 7.198 0 9.92 2.722 2.72 7.198 2.72 9.92 0 2.72-2.722 2.72-7.11 0-9.92m-1.317 7.462-1.23 1.228-2.457-2.457-2.458 2.457-1.228-1.228 2.457-2.458-2.457-2.458 1.228-1.229 2.458 2.458 2.458-2.458 1.229 1.23-2.458 2.457z"
11
+ d: "M18.439 3.061C14.357-1.02 7.643-1.02 3.56 3.061-.52 7.143-.52 13.857 3.561 17.94c4.082 4.081 10.796 4.081 14.878 0 4.081-4.082 4.081-10.665 0-14.878m-1.975 11.191-1.843 1.844-3.687-3.687-3.686 3.687-1.844-1.844 3.687-3.686-3.687-3.687 1.844-1.843 3.686 3.687 3.687-3.687 1.843 1.843-3.687 3.687z"
17
12
  }, null, -1);
18
- const _hoisted_4 = [
19
- _hoisted_2,
20
- _hoisted_3
13
+ const _hoisted_3 = [
14
+ _hoisted_2
21
15
  ];
22
16
  function render(_ctx, _cache) {
23
- return openBlock(), createElementBlock("svg", _hoisted_1, _hoisted_4);
17
+ return openBlock(), createElementBlock("svg", _hoisted_1, _hoisted_3);
24
18
  }
25
19
  const erase = { render };
26
20
  export {
package/dist/main.es21.js CHANGED
@@ -503,7 +503,7 @@ function _sfc_render(_ctx, _cache, $props, $setup, $data, $options) {
503
503
  _: 1
504
504
  }, 8, ["color", "size"])) : createCommentVNode("", true)], 64)) : createCommentVNode("", true), createTextVNode(), renderSlot(_ctx.$slots, "trigger")]),
505
505
  _: 3
506
- }, 8, ["background-color", "border-radius", "hovered-icon", "is-active", "is-disabled", "padding"])], 512), createTextVNode(), !$props.hideInfoText && $setup.isVisible && (!!$props.text || _ctx.$slots.default) ? (openBlock(), createBlock(Teleport, {
506
+ }, 8, ["background-color", "border-radius", "hovered-icon", "is-active", "is-disabled", "padding"])], 512), createTextVNode(), $setup.isVisible && (!!$props.text || _ctx.$slots.default) ? (openBlock(), createBlock(Teleport, {
507
507
  key: 0,
508
508
  to: "body"
509
509
  }, [createVNode(_component_TextWrapper, {
@@ -1,4 +1,4 @@
1
- const __vite_glob_0_174 = "";
1
+ const __vite_glob_0_174 = "";
2
2
  export {
3
3
  __vite_glob_0_174 as default
4
4
  };
package/dist/main.es8.js CHANGED
@@ -342,7 +342,7 @@ const theme = (() => {
342
342
  borderColor: semanticColors.grey[300]
343
343
  },
344
344
  active: {
345
- backgroundColor: semanticColors.purple[100],
345
+ backgroundColor: semanticColors.purple[50],
346
346
  textColor: semanticColors.purple[600],
347
347
  borderColor: semanticColors.grey[600]
348
348
  },
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@eturnity/eturnity_reusable_components",
3
- "version": "8.26.11-EPDM-15023.0",
3
+ "version": "8.26.11-EPDM-11600.15",
4
4
  "files": [
5
5
  "dist",
6
6
  "src"
@@ -1,4 +1,3 @@
1
- <svg fill="none" height="16" viewbox="12 12 16 16" width="16" xmlns="http://www.w3.org/2000/svg">
2
- <circle cx="20" cy="20" r="7"></circle>
3
- <path d="M24.9592 15.0408C22.2382 12.3197 17.7618 12.3197 15.0408 15.0408C12.3197 17.7618 12.3197 22.2382 15.0408 24.9592C17.7618 27.6803 22.2382 27.6803 24.9592 24.9592C27.6803 22.2382 27.6803 17.8495 24.9592 15.0408ZM23.6426 22.5016L22.4138 23.7304L19.9561 21.2727L17.4984 23.7304L16.2696 22.5016L18.7273 20.0439L16.2696 17.5862L17.4984 16.3574L19.9561 18.815L22.4138 16.3574L23.6426 17.5862L21.185 20.0439L23.6426 22.5016Z" fill="#FF5656"></path>
1
+ <svg width="22" height="21" viewBox="0 0 22 21" fill="none" xmlns="http://www.w3.org/2000/svg">
2
+ <path d="M18.4389 3.06113C14.3574 -1.02038 7.64263 -1.02038 3.56113 3.06113C-0.520376 7.14263 -0.520376 13.8574 3.56113 17.9389C7.64263 22.0204 14.3574 22.0204 18.4389 17.9389C22.5204 13.8574 22.5204 7.2743 18.4389 3.06113ZM16.464 14.2524L14.6207 16.0956L10.9342 12.4091L7.24765 16.0956L5.40439 14.2524L9.09091 10.5658L5.40439 6.87931L7.24765 5.03605L10.9342 8.72257L14.6207 5.03605L16.464 6.87931L12.7774 10.5658L16.464 14.2524Z" fill="#FF5656"/>
4
3
  </svg>
@@ -333,7 +333,7 @@ const theme = (() => {
333
333
  borderColor: semanticColors.grey[300],
334
334
  },
335
335
  active: {
336
- backgroundColor: semanticColors.purple[100],
336
+ backgroundColor: semanticColors.purple[50],
337
337
  textColor: semanticColors.purple[600],
338
338
  borderColor: semanticColors.grey[600],
339
339
  },
@@ -22,7 +22,7 @@
22
22
  <!-- For stacked bar chart -->
23
23
  <template v-if="seriesData.length">
24
24
  <InputRow
25
- v-for="(series, seriesIndex) in seriesData"
25
+ v-for="series in seriesData"
26
26
  :key="series.name"
27
27
  :data-series-name="series.name"
28
28
  >
@@ -36,10 +36,8 @@
36
36
  :allow-negative="false"
37
37
  :default-number="0"
38
38
  :disabled="isInputsDisabled"
39
- :error-message="getInputErrorMessage(series.data, item.label)"
40
39
  input-height="36px"
41
40
  :is-disabled-styled-only="true"
42
- :is-error="getIsError(series.data, item.label)"
43
41
  :is-info-border="
44
42
  fieldMode === 'percentage'
45
43
  ? calculatePercentageTotal(item.label) !== 100
@@ -119,10 +117,8 @@
119
117
  <InputNumber
120
118
  :allow-negative="false"
121
119
  :disabled="isInputsDisabled"
122
- :error-message="item.errorMessage"
123
120
  input-height="36px"
124
121
  :is-disabled-styled-only="true"
125
- :is-error="item.isError"
126
122
  :min-decimals="0"
127
123
  :number-precision="0"
128
124
  text-align="center"
@@ -146,11 +142,6 @@
146
142
  </InfoCardBody>
147
143
  </InfoCard>
148
144
  </InfoCardContainer>
149
- <InfoCardContainer v-if="hasInputErrors" :y-axis-width="yAxisWidth">
150
- <InfoCard align-items="center" type="error_minor">
151
- <InfoCardBody> {{ inputErrorMessage }} </InfoCardBody>
152
- </InfoCard>
153
- </InfoCardContainer>
154
145
  </template>
155
146
 
156
147
  <script setup>
@@ -213,10 +204,6 @@
213
204
  type: String,
214
205
  default: '',
215
206
  },
216
- inputErrorMessage: {
217
- type: String,
218
- default: '',
219
- },
220
207
  })
221
208
 
222
209
  const seriesData = ref([])
@@ -242,8 +229,6 @@
242
229
  label: d.label,
243
230
  value: d.value,
244
231
  percentage: d.percentage,
245
- isError: d.isError,
246
- errorMessage: d.errorMessage,
247
232
  originalValue: currentSeriesData.length
248
233
  ? currentSeriesData[itemIndex].data[dIndex].originalValue
249
234
  : d.value,
@@ -290,7 +275,7 @@
290
275
  }
291
276
  }
292
277
 
293
- const getDisplayValue = (data, label) => {
278
+ const getDisplayValue = (data, label, shouldRound = true) => {
294
279
  if (props.fieldMode === 'absolute') {
295
280
  return data.find((d) => d.label === label)?.value
296
281
  }
@@ -298,13 +283,6 @@
298
283
  return data.find((d) => d.label === label)?.percentage
299
284
  }
300
285
 
301
- const getIsError = (data, label) => {
302
- return data.find((d) => d.label === label)?.isError
303
- }
304
- const getInputErrorMessage = (data, label) => {
305
- return data.find((d) => d.label === label)?.errorMessage
306
- }
307
-
308
286
  const calculatePercentageTotal = (label) => {
309
287
  const percentageTotal = seriesData.value.reduce((sum, series) => {
310
288
  const percentage =
@@ -358,14 +336,6 @@
358
336
  return calculatePercentageTotal(d.label) !== 100
359
337
  })
360
338
  })
361
- const hasInputErrors = computed(() => {
362
- if (seriesData.value.length) {
363
- return seriesData.value.some((serie) =>
364
- serie.data.some((item) => item.isError)
365
- )
366
- }
367
- return props.data.some((item) => item.isError)
368
- })
369
339
 
370
340
  const handleFieldsScroll = (event) => {
371
341
  emit('sync-scroll', event.target.scrollLeft)
@@ -68,7 +68,10 @@ export function useAxisCalculations(props, maxValue) {
68
68
  // Generate labels including 0 up to numSteps
69
69
  const numSteps = Math.floor(max / stepSize)
70
70
  for (let i = 0; i <= numSteps; i++) {
71
- labels.push(i * stepSize)
71
+ const stepValue = i * stepSize
72
+ const roundedStepValueString = stepValue.toFixed(2)
73
+ const roundedStepValueNumber = parseFloat(roundedStepValueString)
74
+ labels.push(roundedStepValueNumber)
72
75
  }
73
76
 
74
77
  // Ensure we always have at least 2 labels (0 and max)
@@ -17,8 +17,8 @@
17
17
  />
18
18
  </ChartControlsWrapper>
19
19
  <GraphSection :height="height" :width="width">
20
- <YAxis :height="height" :width="yAxisWidth">
21
- <YAxisTitleWrapper v-if="yAxisTitle" :height="yAxisHeight">
20
+ <YAxis :width="yAxisWidth">
21
+ <YAxisTitleWrapper v-if="yAxisTitle">
22
22
  {{ yAxisTitle }}
23
23
  </YAxisTitleWrapper>
24
24
  <YAxisRow
@@ -51,6 +51,11 @@
51
51
  <LoadingOverlay v-if="isLoading">
52
52
  <Spinner size="medium" />
53
53
  </LoadingOverlay>
54
+ <InfoCardContainer v-else-if="isDataIssueMessageDisplayed">
55
+ <RCInfoCard align-items="center">
56
+ {{ dataIssueMessage }}
57
+ </RCInfoCard>
58
+ </InfoCardContainer>
54
59
  <SelectionBox
55
60
  v-if="selectionSize && isSelectionEnabled"
56
61
  :bar-width="barWidth"
@@ -166,7 +171,6 @@
166
171
  :is-inputs-disabled="isLoading"
167
172
  :is-scrollable="isScrollable"
168
173
  :percentage-error-message="percentageErrorMessage"
169
- :input-error-message="inputErrorMessage"
170
174
  :series="series"
171
175
  :y-axis-width="yAxisWidth"
172
176
  @input-blur="handleInputBlur"
@@ -183,6 +187,7 @@
183
187
  import ChartControls from './ChartControls'
184
188
  import BottomFields from './BottomFields'
185
189
  import SelectionBox from './SelectionBox'
190
+ import RCInfoCard from '../infoCard'
186
191
  import Spinner from '../spinner'
187
192
  import { numberToString } from '../../helpers/numberConverter'
188
193
 
@@ -218,6 +223,7 @@
218
223
  TooltipGradientBox,
219
224
  ChartControlsWrapper,
220
225
  LoadingOverlay,
226
+ InfoCardContainer,
221
227
  } from './styles/chart'
222
228
 
223
229
  const props = defineProps({
@@ -300,6 +306,14 @@
300
306
  type: Boolean,
301
307
  default: false,
302
308
  },
309
+ dataIssueMessage: {
310
+ type: String,
311
+ default: '',
312
+ },
313
+ isDataIssueMessageDisplayed: {
314
+ type: Boolean,
315
+ default: false,
316
+ },
303
317
  showPercentageOnTooltip: {
304
318
  type: Boolean,
305
319
  default: false,
@@ -308,10 +322,6 @@
308
322
  type: String,
309
323
  default: '',
310
324
  },
311
- inputErrorMessage: {
312
- type: String,
313
- default: '',
314
- },
315
325
  })
316
326
 
317
327
  const generateChartId = () =>
@@ -16,12 +16,9 @@ export const GraphSection = styled('div', { width: String, height: String })`
16
16
  display: flex;
17
17
  `
18
18
 
19
- export const YAxis = styled('div', { width: String, height: String })`
19
+ export const YAxis = styled('div', { width: String })`
20
20
  width: ${(props) => props.width};
21
- display: flex;
22
- flex-direction: column;
23
21
  position: relative;
24
- height: ${(props) => props.height};
25
22
  `
26
23
 
27
24
  export const YAxisRow = styled('div', { percentage: Number })`
@@ -29,10 +26,13 @@ export const YAxisRow = styled('div', { percentage: Number })`
29
26
  align-items: center;
30
27
  width: 100%;
31
28
  position: absolute;
32
- height: 0;
29
+ height: 1px;
33
30
  bottom: ${(props) =>
34
31
  Number.isFinite(props.percentage) ? `${props.percentage}%` : '0'};
35
- transform: translateY(50%);
32
+ ${(props) =>
33
+ Number.isFinite(props.percentage) && props.percentage === 100
34
+ ? 'transform: translateY(1px)'
35
+ : ''};
36
36
  `
37
37
 
38
38
  export const YAxisLabel = styled.div`
@@ -50,25 +50,24 @@ export const YAxisLine = styled('div', { yAxisWidth: String })`
50
50
  right: -10px;
51
51
  left: calc(${(props) => props.yAxisWidth} - 10px);
52
52
  height: 1px;
53
- background-color: rgba(0, 0, 0, 0.1);
53
+ background-color: ${(props) => props.theme.semanticColors.grey[400]};
54
54
  width: 12px;
55
55
  z-index: 0;
56
- top: 50%;
57
- transform: translateY(-50%);
58
56
  `
59
57
 
60
- export const YAxisTitleWrapper = styled('div', { height: String })`
61
- position: absolute;
62
- left: -66px;
63
- top: ${(props) => props.height};
64
- transform: rotate(-90deg) translateX(50%);
65
- transform-origin: right;
58
+ export const YAxisTitleWrapper = styled('div')`
66
59
  font-size: 12px;
67
- color: ${(props) => props.theme.semanticColors.teal[600]};
68
- display: flex;
69
- align-items: center;
60
+ font-weight: 500;
61
+ color: ${(props) => props.theme.semanticColors.grey[700]};
70
62
  white-space: nowrap;
71
- font-family: ${(props) => props.theme.fonts.mainFont};
63
+ height: 0;
64
+ width: 0;
65
+ display: flex;
66
+ align-items: flex-start;
67
+ justify-content: center;
68
+ position: absolute;
69
+ top: 50%;
70
+ transform: rotate(-90deg);
72
71
  `
73
72
 
74
73
  export const ScrollContainer = styled('div', {
@@ -90,6 +89,8 @@ export const ChartContent = styled('div', {
90
89
  height: ${(props) => props.height};
91
90
  position: relative;
92
91
  background: ${(props) => props.theme.semanticColors.grey[100]};
92
+ border-bottom: ${(props) =>
93
+ `1px solid ${props.theme.semanticColors.grey[400]}`};
93
94
  ${(props) =>
94
95
  props.isScrollable
95
96
  ? ` min-width: ${props.totalBars * (props.barWidth + 8) + 24}px;`
@@ -179,7 +180,7 @@ export const XAxisLabelHighlight = styled.div`
179
180
  export const XAxisLine = styled.div`
180
181
  width: 1px;
181
182
  height: 6px;
182
- background-color: rgba(0, 0, 0, 0.1);
183
+ background-color: ${(props) => props.theme.semanticColors.grey[400]};
183
184
  position: absolute;
184
185
  bottom: -6px;
185
186
  left: 50%;
@@ -271,3 +272,13 @@ export const LoadingOverlay = styled('div')`
271
272
  align-items: center;
272
273
  z-index: 2;
273
274
  `
275
+
276
+ export const InfoCardContainer = styled('div')`
277
+ position: absolute;
278
+ top: 50%;
279
+ left: 50%;
280
+ transform: translate(-50%, -50%);
281
+ width: 500px;
282
+ max-width: 500px;
283
+ z-index: 2;
284
+ `
@@ -7,13 +7,11 @@
7
7
  :data-id="dataId"
8
8
  :data-qa-id="dataQaId"
9
9
  :height="height"
10
- :is-active="isActive"
11
10
  :is-disabled="isDisabled"
12
11
  :min-width="minWidth"
13
12
  :no-wrap="noWrap"
14
13
  :type="type"
15
14
  :variant="variant"
16
- :width="width"
17
15
  >
18
16
  <LabelComponent :has-icon="Boolean(icon)">
19
17
  <Icon
@@ -52,13 +50,11 @@
52
50
  type: String,
53
51
  isDisabled: Boolean,
54
52
  minWidth: String,
55
- width: String,
56
53
  noWrap: Boolean,
57
54
  height: String,
58
55
  variant: String,
59
56
  buttonSize: String,
60
57
  appTheme: String,
61
- isActive: Boolean,
62
58
  }
63
59
  const ButtonContainer = styled('div', ButtonAttrs)`
64
60
  display: flex;
@@ -77,9 +73,6 @@
77
73
  props.isDisabled
78
74
  ? props.theme.mainButton[props.appTheme][props.type][props.variant]
79
75
  .disabled.backgroundColor
80
- : props.isActive
81
- ? props.theme.mainButton[props.appTheme][props.type][props.variant]
82
- .active.backgroundColor
83
76
  : props.theme.mainButton[props.appTheme][props.type][props.variant]
84
77
  .default.backgroundColor};
85
78
  border: ${(props) => {
@@ -98,7 +91,7 @@
98
91
  ${(props) => (props.noWrap ? `white-space: nowrap;` : '')};
99
92
  height: ${(props) => props.height};
100
93
  line-height: 1;
101
- width: ${(props) => props.width};
94
+
102
95
  &:hover {
103
96
  background-color: ${(props) =>
104
97
  props.isDisabled
@@ -177,11 +170,6 @@
177
170
  default: false,
178
171
  type: Boolean,
179
172
  },
180
- isActive: {
181
- required: false,
182
- default: false,
183
- type: Boolean,
184
- },
185
173
  icon: {
186
174
  required: false,
187
175
  default: null,
@@ -216,11 +204,6 @@
216
204
  default: null,
217
205
  type: String,
218
206
  },
219
- width: {
220
- required: false,
221
- default: 'auto',
222
- type: String,
223
- },
224
207
  height: {
225
208
  required: false,
226
209
  default: 'auto',
@@ -49,10 +49,7 @@
49
49
  <slot name="trigger"></slot>
50
50
  </IconWrapper>
51
51
  </div>
52
- <Teleport
53
- v-if="!hideInfoText && isVisible && (!!text || $slots.default)"
54
- to="body"
55
- >
52
+ <Teleport v-if="isVisible && (!!text || $slots.default)" to="body">
56
53
  <TextWrapper data-test-id="info_text_wrapper" :style="wrapperStyle">
57
54
  <TextOverlay
58
55
  ref="infoBox"
@@ -3,15 +3,15 @@ import InputNumber from './index.vue'
3
3
  export default {
4
4
  title: 'InputNumber',
5
5
  component: InputNumber,
6
- // argTypes: {},
7
6
  }
8
7
 
9
- const Template = (args, { argTypes }) => ({
8
+ const Template = (args) => ({
10
9
  // Components used in your story `template` are defined in the `components` object
11
10
  components: { InputNumber },
12
- // The story's `args` need to be mapped into the template through the `setup()` method
13
- props: Object.keys(argTypes),
14
- template: '<input-number v-bind="$props" />',
11
+ setup() {
12
+ return { args: args }
13
+ },
14
+ template: `<InputNumber v-bind="args" />`,
15
15
 
16
16
  // import InputNumber from "@eturnity/eturnity_reusable_components/src/components/inputs/inputNumber"
17
17
  // How to use:
@@ -50,7 +50,6 @@
50
50
  :color-mode="colorMode"
51
51
  :data-id="inputDataId"
52
52
  :data-qa-id="dataQaId"
53
- :disabled="disabled && !isDisabledStyledOnly"
54
53
  :font-color="colorMode === 'transparent' ? 'white' : fontColor"
55
54
  :font-size="fontSize"
56
55
  :has-label-slot="hasLabelSlot"
@@ -58,7 +57,7 @@
58
57
  :has-unit="unitName && !!unitName.length"
59
58
  :input-height="inputHeight"
60
59
  :is-border-error-only="isBorderErrorOnly"
61
- :is-disabled="disabled"
60
+ :is-disabled="disabled && !isDisabledStyledOnly"
62
61
  :is-error="isError"
63
62
  :is-info-border="isInfoBorder"
64
63
  :is-interactive="isInteractive"
@@ -96,7 +95,6 @@
96
95
  :color-mode="colorMode"
97
96
  :data-id="inputDataId"
98
97
  :data-qa-id="dataQaId"
99
- :disabled="disabled && !isDisabledStyledOnly"
100
98
  :font-color="colorMode === 'transparent' ? 'white' : fontColor"
101
99
  :font-size="fontSize"
102
100
  :has-label-slot="hasLabelSlot"
@@ -104,7 +102,7 @@
104
102
  :has-unit="unitName && !!unitName.length"
105
103
  :input-height="inputHeight"
106
104
  :is-border-error-only="isBorderErrorOnly"
107
- :is-disabled="disabled"
105
+ :is-disabled="disabled && !isDisabledStyledOnly"
108
106
  :is-error="isError"
109
107
  :is-info-border="isInfoBorder"
110
108
  :is-interactive="isInteractive"
@@ -748,6 +746,7 @@
748
746
  default: '',
749
747
  },
750
748
  dataQaId: {
749
+ type: String,
751
750
  required: false,
752
751
  default: '',
753
752
  },
@@ -799,10 +798,6 @@
799
798
  type: Boolean,
800
799
  default: false,
801
800
  },
802
- hasSpaceBetweenUnit: {
803
- type: Boolean,
804
- default: true,
805
- },
806
801
  },
807
802
  data() {
808
803
  return {
@@ -816,12 +811,8 @@
816
811
  displayedPlaceholder() {
817
812
  if (this.placeholder) return this.placeholder
818
813
  if (this.defaultNumber)
819
- return `${this.defaultNumber}${this.hasSpaceBetweenUnit ? ' ' : ''}${
820
- this.unitName ? this.unitName : ''
821
- }`
822
- return `${this.minNumber || 0}${this.hasSpaceBetweenUnit ? ' ' : ''}${
823
- this.unitName ? this.unitName : ''
824
- }`
814
+ return `${this.defaultNumber} ${this.unitName ? this.unitName : ''}`
815
+ return `${this.minNumber || 0} ${this.unitName ? this.unitName : ''}`
825
816
  },
826
817
  hasSlot() {
827
818
  return !!this.$slots.default
@@ -1035,9 +1026,8 @@
1035
1026
  return
1036
1027
  }
1037
1028
  this.textInput = this.formatWithCurrency(this.value)
1038
- const textInputWithoutUnit = this.formatWithoutUnit(this.value)
1039
1029
  this.enteredValue = stringToNumber({
1040
- value: textInputWithoutUnit,
1030
+ value: this.textInput,
1041
1031
  numberPrecision: this.numberPrecision,
1042
1032
  minDecimals: this.minDecimals,
1043
1033
  })
@@ -1058,38 +1048,6 @@
1058
1048
  this.$refs.inputField1.$el.blur()
1059
1049
  })
1060
1050
  },
1061
- formatWithoutUnit(value) {
1062
- let adjustedMinValue =
1063
- value || value === 0
1064
- ? value
1065
- : this.defaultNumber
1066
- ? this.defaultNumber
1067
- : this.minNumber || this.minNumber === 0
1068
- ? this.minNumber
1069
- : ''
1070
- if (adjustedMinValue || adjustedMinValue === 0) {
1071
- let input = this.numberToStringEnabled
1072
- ? numberToString({
1073
- value: adjustedMinValue,
1074
- numberPrecision: this.numberPrecision,
1075
- minDecimals: this.minDecimals,
1076
- })
1077
- : adjustedMinValue
1078
- return input
1079
- } else if (!adjustedMinValue && adjustedMinValue !== 0) {
1080
- return ''
1081
- } else if (this.isFocused) {
1082
- return value
1083
- } else {
1084
- return this.numberToStringEnabled
1085
- ? numberToString({
1086
- value: adjustedMinValue,
1087
- numberPrecision: this.numberPrecision,
1088
- minDecimals: this.minDecimals,
1089
- })
1090
- : adjustedMinValue
1091
- }
1092
- },
1093
1051
  formatWithCurrency(value) {
1094
1052
  let adjustedMinValue =
1095
1053
  value || value === 0
@@ -1110,7 +1068,7 @@
1110
1068
  let unit = this.showLinearUnitName ? '' : this.unitName
1111
1069
  //return input + ' ' + unit
1112
1070
  if (unit) {
1113
- return `${input}${this.hasSpaceBetweenUnit ? ' ' : ''}${unit}`
1071
+ return input + ' ' + unit
1114
1072
  }
1115
1073
  return input
1116
1074
  } else if (!adjustedMinValue && adjustedMinValue !== 0) {
@@ -5,7 +5,8 @@
5
5
  :has-info-text="!!infoText"
6
6
  :margin-bottom="marginBottom"
7
7
  >
8
- <span data-test-id="page_subtitle_text">
8
+ <span v-if="containsHtml" data-test-id="page_subtitle_text" v-html="text"></span>
9
+ <span v-else data-test-id="page_subtitle_text">
9
10
  {{ text }}
10
11
  </span>
11
12
  <InfoText
@@ -58,6 +59,11 @@
58
59
  required: true,
59
60
  type: String,
60
61
  },
62
+ containsHtml: {
63
+ required: false,
64
+ type: Boolean,
65
+ default: false,
66
+ },
61
67
  color: {
62
68
  required: false,
63
69
  type: String,