@eturnity/eturnity_reusable_components 8.7.5-EPIC-8593.1 → 8.7.5-EPIC-8593.3
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/package.json
CHANGED
@@ -68,7 +68,17 @@
|
|
68
68
|
<Icon name="current_variant" size="20px" />
|
69
69
|
</IconWrapper>
|
70
70
|
<IconWrapper v-if="hasError" data-test-id="error_wrapper" size="16px">
|
71
|
-
<
|
71
|
+
<InfoText
|
72
|
+
v-if="infoErrorMessage != ''"
|
73
|
+
:align-arrow="infoTextAlign"
|
74
|
+
:app-theme="appTheme"
|
75
|
+
button-type="error"
|
76
|
+
data-test-id="info_text_message"
|
77
|
+
icon-name="warning"
|
78
|
+
:size="fontSize ? fontSize : '16px'"
|
79
|
+
:text="infoErrorMessage"
|
80
|
+
/>
|
81
|
+
<Icon v-else cursor="default" name="warning" size="16px" />
|
72
82
|
</IconWrapper>
|
73
83
|
<IconWrapper
|
74
84
|
v-if="iconName && !hasError && inputType !== 'password'"
|
@@ -148,10 +158,10 @@
|
|
148
158
|
}
|
149
159
|
const InputContainer = styled('input', inputProps)`
|
150
160
|
border: ${(props) =>
|
151
|
-
props.
|
152
|
-
? '1px solid ' + props.theme.colors.red
|
153
|
-
: props.noBorder
|
161
|
+
props.noBorder
|
154
162
|
? 'none'
|
163
|
+
: props.isError
|
164
|
+
? '1px solid ' + props.theme.colors.red
|
155
165
|
: props.borderColor
|
156
166
|
? props.theme.colors[props.borderColor]
|
157
167
|
? '1px solid ' + props.theme.colors[props.borderColor]
|
@@ -410,6 +420,11 @@
|
|
410
420
|
default: '',
|
411
421
|
type: String,
|
412
422
|
},
|
423
|
+
infoErrorMessage: {
|
424
|
+
required: false,
|
425
|
+
default: '',
|
426
|
+
type: String,
|
427
|
+
},
|
413
428
|
},
|
414
429
|
data() {
|
415
430
|
return {
|
@@ -45,7 +45,9 @@
|
|
45
45
|
<SelectButton
|
46
46
|
ref="select"
|
47
47
|
:bg-color="
|
48
|
-
buttonBgColor
|
48
|
+
buttonBgColor
|
49
|
+
? buttonBgColor
|
50
|
+
: colorMode == 'dark'
|
49
51
|
? 'transparentBlack1'
|
50
52
|
: colorMode == 'transparent'
|
51
53
|
? 'transparent'
|
@@ -370,7 +372,7 @@
|
|
370
372
|
? props.theme.colors.grey5
|
371
373
|
: props.theme.colors[props.bgColor]
|
372
374
|
? props.theme.colors[props.bgColor]
|
373
|
-
: props.bgColor};
|
375
|
+
: props.bgColor} !important;
|
374
376
|
color: ${(props) =>
|
375
377
|
props.colorMode === 'transparent'
|
376
378
|
? props.theme.colors.white
|
@@ -8,7 +8,11 @@
|
|
8
8
|
:is-active="activeTab === item.id"
|
9
9
|
@click="onTabClick({ id: item.id })"
|
10
10
|
>
|
11
|
-
<
|
11
|
+
<NameContainer>
|
12
|
+
<div>{{ item.text }}</div>
|
13
|
+
<DotIcon v-if="item.subText" :is-active="activeTab === item.id" />
|
14
|
+
<SubText v-if="item.subText">{{ item.subText }}</SubText>
|
15
|
+
</NameContainer>
|
12
16
|
<RCIcon v-if="item.hasError" name="warning" size="14px" />
|
13
17
|
</TabItem>
|
14
18
|
</TabsContainer>
|
@@ -36,6 +40,27 @@
|
|
36
40
|
import styled from 'vue3-styled-components'
|
37
41
|
import RCIcon from '../icon'
|
38
42
|
|
43
|
+
const NameContainer = styled.div`
|
44
|
+
display: flex;
|
45
|
+
align-items: center;
|
46
|
+
justify-content: center;
|
47
|
+
gap: 8px;
|
48
|
+
`
|
49
|
+
|
50
|
+
const DotIconAttrs = { isActive: Boolean }
|
51
|
+
const DotIcon = styled('div', DotIconAttrs)`
|
52
|
+
width: 4px;
|
53
|
+
height: 4px;
|
54
|
+
border-radius: 100%;
|
55
|
+
background-color: ${(props) =>
|
56
|
+
props.isActive ? props.theme.colors.purple6 : props.theme.colors.black};
|
57
|
+
`
|
58
|
+
|
59
|
+
const SubText = styled.div`
|
60
|
+
font-size: 12px;
|
61
|
+
color: ${(props) => props.theme.colors.black};
|
62
|
+
`
|
63
|
+
|
39
64
|
const PageContainer = styled.div``
|
40
65
|
|
41
66
|
const TabsContainer = styled.div`
|
@@ -67,7 +92,10 @@
|
|
67
92
|
components: {
|
68
93
|
PageContainer,
|
69
94
|
TabsContainer,
|
95
|
+
NameContainer,
|
70
96
|
TabItem,
|
97
|
+
SubText,
|
98
|
+
DotIcon,
|
71
99
|
RCIcon,
|
72
100
|
},
|
73
101
|
props: {
|
@@ -0,0 +1,11 @@
|
|
1
|
+
import { langForLocaleString } from './translateLang'
|
2
|
+
|
3
|
+
export const toLocaleNumber = (value, digit = 0) => {
|
4
|
+
if (isNaN(value)) {
|
5
|
+
return '-'
|
6
|
+
}
|
7
|
+
return new Intl.NumberFormat(langForLocaleString(), {
|
8
|
+
minimumFractionDigits: digit,
|
9
|
+
maximumFractionDigits: digit,
|
10
|
+
}).format(value)
|
11
|
+
}
|