@saasmakers/ui 1.0.4 → 1.0.6
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.
|
@@ -56,7 +56,7 @@ function onClick(event: MouseEvent) {
|
|
|
56
56
|
<template>
|
|
57
57
|
<component
|
|
58
58
|
:is="to ? NuxtLinkLocale : 'button'"
|
|
59
|
-
class="relative inline-block select-none appearance-none border focus:outline-none"
|
|
59
|
+
class="relative inline-block select-none appearance-none border focus-visible:outline-none"
|
|
60
60
|
:class="{
|
|
61
61
|
'inline-block': !circular,
|
|
62
62
|
'flex items-center justify-center': circular,
|
|
@@ -141,43 +141,43 @@ function onClick(event: MouseEvent) {
|
|
|
141
141
|
<i18n lang="json">
|
|
142
142
|
{
|
|
143
143
|
"de": {
|
|
144
|
-
"confirm": "Bestätigen"
|
|
144
|
+
"confirm": "Bestätigen?"
|
|
145
145
|
},
|
|
146
146
|
"en": {
|
|
147
|
-
"confirm": "Confirm"
|
|
147
|
+
"confirm": "Confirm?"
|
|
148
148
|
},
|
|
149
149
|
"es": {
|
|
150
|
-
"confirm": "Confirmar"
|
|
150
|
+
"confirm": "¿Confirmar?"
|
|
151
151
|
},
|
|
152
152
|
"fr": {
|
|
153
|
-
"confirm": "Confirmer"
|
|
153
|
+
"confirm": "Confirmer ?"
|
|
154
154
|
},
|
|
155
155
|
"it": {
|
|
156
|
-
"confirm": "
|
|
156
|
+
"confirm": "Confermare?"
|
|
157
157
|
},
|
|
158
158
|
"ja": {
|
|
159
|
-
"confirm": "
|
|
159
|
+
"confirm": "確認しますか?"
|
|
160
160
|
},
|
|
161
161
|
"ko": {
|
|
162
|
-
"confirm": "
|
|
162
|
+
"confirm": "확인할까요?"
|
|
163
163
|
},
|
|
164
164
|
"nl": {
|
|
165
|
-
"confirm": "Bevestigen"
|
|
165
|
+
"confirm": "Bevestigen?"
|
|
166
166
|
},
|
|
167
167
|
"pl": {
|
|
168
|
-
"confirm": "
|
|
168
|
+
"confirm": "Potwierdzić?"
|
|
169
169
|
},
|
|
170
170
|
"pt": {
|
|
171
|
-
"confirm": "Confirmar"
|
|
171
|
+
"confirm": "Confirmar?"
|
|
172
172
|
},
|
|
173
173
|
"pt-BR": {
|
|
174
|
-
"confirm": "Confirmar"
|
|
174
|
+
"confirm": "Confirmar?"
|
|
175
175
|
},
|
|
176
176
|
"id": {
|
|
177
|
-
"confirm": "Konfirmasi"
|
|
177
|
+
"confirm": "Konfirmasi?"
|
|
178
178
|
},
|
|
179
179
|
"vi": {
|
|
180
|
-
"confirm": "Xác nhận"
|
|
180
|
+
"confirm": "Xác nhận?"
|
|
181
181
|
}
|
|
182
182
|
}
|
|
183
183
|
</i18n>
|
|
@@ -163,43 +163,43 @@ function onKeyDown(event: KeyboardEvent) {
|
|
|
163
163
|
<i18n lang="json">
|
|
164
164
|
{
|
|
165
165
|
"de": {
|
|
166
|
-
"confirm": "Bestätigen"
|
|
166
|
+
"confirm": "Bestätigen?"
|
|
167
167
|
},
|
|
168
168
|
"en": {
|
|
169
|
-
"confirm": "Confirm"
|
|
169
|
+
"confirm": "Confirm?"
|
|
170
170
|
},
|
|
171
171
|
"es": {
|
|
172
|
-
"confirm": "Confirmar"
|
|
172
|
+
"confirm": "¿Confirmar?"
|
|
173
173
|
},
|
|
174
174
|
"fr": {
|
|
175
|
-
"confirm": "Confirmer"
|
|
175
|
+
"confirm": "Confirmer ?"
|
|
176
176
|
},
|
|
177
177
|
"it": {
|
|
178
|
-
"confirm": "
|
|
178
|
+
"confirm": "Confermare?"
|
|
179
179
|
},
|
|
180
180
|
"ja": {
|
|
181
|
-
"confirm": "
|
|
181
|
+
"confirm": "確認しますか?"
|
|
182
182
|
},
|
|
183
183
|
"ko": {
|
|
184
|
-
"confirm": "
|
|
184
|
+
"confirm": "확인할까요?"
|
|
185
185
|
},
|
|
186
186
|
"nl": {
|
|
187
|
-
"confirm": "Bevestigen"
|
|
187
|
+
"confirm": "Bevestigen?"
|
|
188
188
|
},
|
|
189
189
|
"pl": {
|
|
190
|
-
"confirm": "
|
|
190
|
+
"confirm": "Potwierdzić?"
|
|
191
191
|
},
|
|
192
192
|
"pt": {
|
|
193
|
-
"confirm": "Confirmar"
|
|
193
|
+
"confirm": "Confirmar?"
|
|
194
194
|
},
|
|
195
195
|
"pt-BR": {
|
|
196
|
-
"confirm": "Confirmar"
|
|
196
|
+
"confirm": "Confirmar?"
|
|
197
197
|
},
|
|
198
198
|
"id": {
|
|
199
|
-
"confirm": "Konfirmasi"
|
|
199
|
+
"confirm": "Konfirmasi?"
|
|
200
200
|
},
|
|
201
201
|
"vi": {
|
|
202
|
-
"confirm": "Xác nhận"
|
|
202
|
+
"confirm": "Xác nhận?"
|
|
203
203
|
}
|
|
204
204
|
}
|
|
205
205
|
</i18n>
|
|
@@ -35,7 +35,7 @@ const modelValue = defineModel<FieldCheckbox['modelValue']>({ default: false })
|
|
|
35
35
|
v-model="modelValue"
|
|
36
36
|
class="border border-gray-300 rounded-lg accent-indigo-700 transition-shadow flex-initial dark:border-gray-700"
|
|
37
37
|
:class="{
|
|
38
|
-
'cursor-pointer hover:border-gray-400 dark:hover:border-gray-600 focus:border-gray-500 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:ring-indigo-500/40 dark:focus:border-gray-500': !disabled,
|
|
38
|
+
'cursor-pointer hover:border-gray-400 dark:hover:border-gray-600 focus-visible:border-gray-500 focus-visible:outline-none focus-visible:ring-2 focus-visible:ring-offset-2 focus-visible:ring-indigo-500/40 dark:focus-visible:border-gray-500': !disabled,
|
|
39
39
|
'field-disabled': disabled,
|
|
40
40
|
'h-3.5 w-3.5': size === 'xs',
|
|
41
41
|
'h-4 w-4': size === 'sm',
|
|
@@ -9,72 +9,80 @@ const props = withDefaults(defineProps<FieldMessage>(), {
|
|
|
9
9
|
validation: undefined,
|
|
10
10
|
})
|
|
11
11
|
|
|
12
|
-
// Composable
|
|
13
12
|
const { t } = useI18n()
|
|
14
13
|
|
|
15
14
|
const validationMessage = computed(() => {
|
|
16
|
-
// Available rules
|
|
17
|
-
|
|
18
|
-
|
|
19
|
-
|
|
20
|
-
|
|
21
|
-
|
|
22
|
-
|
|
23
|
-
|
|
24
|
-
|
|
25
|
-
|
|
26
|
-
|
|
27
|
-
|
|
28
|
-
|
|
29
|
-
|
|
30
|
-
|
|
31
|
-
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
39
|
-
|
|
40
|
-
|
|
41
|
-
|
|
42
|
-
|
|
43
|
-
|
|
44
|
-
|
|
45
|
-
|
|
46
|
-
|
|
47
|
-
|
|
48
|
-
|
|
49
|
-
|
|
50
|
-
|
|
51
|
-
|
|
52
|
-
|
|
53
|
-
|
|
54
|
-
|
|
55
|
-
|
|
56
|
-
|
|
57
|
-
|
|
58
|
-
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
69
|
-
|
|
70
|
-
|
|
71
|
-
|
|
72
|
-
|
|
73
|
-
|
|
74
|
-
|
|
75
|
-
|
|
76
|
-
|
|
77
|
-
|
|
15
|
+
// Available rules: https://vuelidate.js.org/#sub-builtin-validators
|
|
16
|
+
if (!props.validation?.$dirty) {
|
|
17
|
+
return ''
|
|
18
|
+
}
|
|
19
|
+
|
|
20
|
+
const firstError = props.validation.$errors[0]
|
|
21
|
+
if (firstError) {
|
|
22
|
+
return unref(firstError.$message)
|
|
23
|
+
}
|
|
24
|
+
|
|
25
|
+
switch (false) {
|
|
26
|
+
case ruleIsInvalid(props.validation.alpha): {
|
|
27
|
+
return t('alpha')
|
|
28
|
+
}
|
|
29
|
+
case ruleIsInvalid(props.validation.alphaNum): {
|
|
30
|
+
return t('alphaNum')
|
|
31
|
+
}
|
|
32
|
+
case ruleIsInvalid(props.validation.between): {
|
|
33
|
+
return t('between', {
|
|
34
|
+
max: props.validation.between.$params.max,
|
|
35
|
+
min: props.validation.between.$params.min,
|
|
36
|
+
})
|
|
37
|
+
}
|
|
38
|
+
case ruleIsInvalid(props.validation.decimal): {
|
|
39
|
+
return t('decimal')
|
|
40
|
+
}
|
|
41
|
+
case ruleIsInvalid(props.validation.email): {
|
|
42
|
+
return t('email')
|
|
43
|
+
}
|
|
44
|
+
case ruleIsInvalid(props.validation.integer): {
|
|
45
|
+
return t('integer')
|
|
46
|
+
}
|
|
47
|
+
case ruleIsInvalid(props.validation.ipAddress): {
|
|
48
|
+
return t('ipAddress')
|
|
49
|
+
}
|
|
50
|
+
case ruleIsInvalid(props.validation.macAddress): {
|
|
51
|
+
return t('macAddress')
|
|
52
|
+
}
|
|
53
|
+
case ruleIsInvalid(props.validation.maxLength): {
|
|
54
|
+
return t('maxLength', { max: props.validation.maxLength.$params.max })
|
|
55
|
+
}
|
|
56
|
+
case ruleIsInvalid(props.validation.maxValue): {
|
|
57
|
+
return t('maxValue', { max: props.validation.maxValue.$params.max })
|
|
58
|
+
}
|
|
59
|
+
case ruleIsInvalid(props.validation.minLength): {
|
|
60
|
+
return t('minLength', { min: props.validation.minLength.$params.min })
|
|
61
|
+
}
|
|
62
|
+
case ruleIsInvalid(props.validation.minValue): {
|
|
63
|
+
return t('minValue', { min: props.validation.minValue.$params.min })
|
|
64
|
+
}
|
|
65
|
+
case ruleIsInvalid(props.validation.numeric): {
|
|
66
|
+
return t('numeric')
|
|
67
|
+
}
|
|
68
|
+
case ruleIsInvalid(props.validation.required):
|
|
69
|
+
case ruleIsInvalid(props.validation.requiredIf):
|
|
70
|
+
case ruleIsInvalid(props.validation.requiredUnless): {
|
|
71
|
+
return t('required')
|
|
72
|
+
}
|
|
73
|
+
case ruleIsInvalid(props.validation.sameAs): {
|
|
74
|
+
return t('sameAs', {
|
|
75
|
+
field: props.validation.sameAs?.$params?.otherName
|
|
76
|
+
?? props.validation.$params?.sameAs?.eq
|
|
77
|
+
?? '',
|
|
78
|
+
})
|
|
79
|
+
}
|
|
80
|
+
case ruleIsInvalid(props.validation.url): {
|
|
81
|
+
return t('url')
|
|
82
|
+
}
|
|
83
|
+
default: {
|
|
84
|
+
if (props.validation.$invalid === true) {
|
|
85
|
+
return t('invalid')
|
|
78
86
|
}
|
|
79
87
|
}
|
|
80
88
|
}
|
|
@@ -97,13 +105,28 @@ const text = computed<BaseTextText>(() => {
|
|
|
97
105
|
return ''
|
|
98
106
|
}
|
|
99
107
|
})
|
|
108
|
+
|
|
109
|
+
function ruleIsInvalid(rule: unknown) {
|
|
110
|
+
if (rule === false) {
|
|
111
|
+
return true
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
if (rule && typeof rule === 'object' && '$invalid' in rule) {
|
|
115
|
+
return (rule as {
|
|
116
|
+
$invalid: boolean
|
|
117
|
+
}).$invalid
|
|
118
|
+
}
|
|
119
|
+
|
|
120
|
+
return false
|
|
121
|
+
}
|
|
100
122
|
</script>
|
|
101
123
|
|
|
102
124
|
<template>
|
|
103
125
|
<BaseIcon
|
|
104
126
|
v-if="text"
|
|
105
|
-
class="
|
|
127
|
+
class="text-left tracking-tighter"
|
|
106
128
|
:class="{
|
|
129
|
+
'field-disabled': disabled,
|
|
107
130
|
'mt-2': size === 'xs',
|
|
108
131
|
'mt-2.5': size === 'sm',
|
|
109
132
|
'mt-3': size === 'base',
|
|
@@ -189,7 +212,7 @@ const text = computed<BaseTextText>(() => {
|
|
|
189
212
|
"minLength": "La valeur est trop petite (min: {min})",
|
|
190
213
|
"minValue": "La valeur minimum acceptée: {min}",
|
|
191
214
|
"numeric": "La valeur n'accepte que des chiffres",
|
|
192
|
-
"required": "
|
|
215
|
+
"required": "Ce champ est requis",
|
|
193
216
|
"sameAs": "La valeur ne correspond pas à: {field}",
|
|
194
217
|
"url": "La valeur n'est pas une URL valide"
|
|
195
218
|
},
|
|
@@ -174,7 +174,7 @@ function selectOption(event: MouseEvent, value: string) {
|
|
|
174
174
|
'border-0': border === 'none',
|
|
175
175
|
'border-gray-400 dark:border-gray-600': opened,
|
|
176
176
|
'hover:border-gray-300 dark:hover:border-gray-700': !opened && !disabled,
|
|
177
|
-
'focus:border-gray-400 dark:focus:border-gray-600': !disabled,
|
|
177
|
+
'focus-visible:border-gray-400 dark:focus-visible:border-gray-600': !disabled,
|
|
178
178
|
'px-3': padding,
|
|
179
179
|
'text-2xs h-8': size === 'xs',
|
|
180
180
|
'text-xs h-10': size === 'sm',
|