codevdesign 0.0.43 → 0.0.45

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.
@@ -25,26 +25,33 @@
25
25
  @click="retournerMenu"
26
26
  /></slot>
27
27
 
28
- <!-- Titre -->
29
- <slot name="titre"
30
- ><span class="pl-3"> {{ props.titre }}</span></slot
31
- >
32
-
33
- <!-- État -->
34
- <slot name="etat">
35
- <span
36
- v-if="monEtat?.afficher"
37
- class="pl-10"
28
+ <div class="titre-bloc">
29
+ <!-- Titre -->
30
+ <slot name="titre"
31
+ ><span class="pl-3"> {{ props.titre }}</span></slot
38
32
  >
39
- <v-btn
40
- size="small"
41
- :color="monEtat.couleur"
42
- variant="tonal"
33
+
34
+ <!-- État -->
35
+ <slot name="etat">
36
+ <span
37
+ v-if="monEtat?.afficher"
38
+ class="pl-10"
43
39
  >
44
- {{ monEtat.texte }}
45
- </v-btn>
46
- </span></slot
47
- >
40
+ <v-btn
41
+ size="small"
42
+ :color="monEtat.couleur"
43
+ variant="tonal"
44
+ >
45
+ {{ monEtat.texte }}
46
+ </v-btn>
47
+ </span></slot
48
+ >
49
+
50
+ <!-- Sous-titre -->
51
+ <slot name="soustitre"
52
+ ><span class="pl-3 soustitre"> {{ props.soustitre }}</span></slot
53
+ >
54
+ </div>
48
55
  </v-toolbar-title>
49
56
  </v-col>
50
57
  </v-row>
@@ -68,6 +75,7 @@
68
75
 
69
76
  const props = defineProps<{
70
77
  titre: string
78
+ soustitre?: string
71
79
  retour?: string
72
80
  etat?: EnteteEtat
73
81
  }>()
@@ -102,6 +110,17 @@
102
110
  font-weight: bold;
103
111
  margin-bottom: 15px;
104
112
  }
113
+ .soustitre {
114
+ display: block;
115
+ font-size: 1rem;
116
+ color: #223654;
117
+ font-weight: normal;
118
+ }
119
+ .titre-bloc {
120
+ display: inline-block;
121
+ vertical-align: middle;
122
+ padding-left: 12px;
123
+ }
105
124
  .v-icon:hover {
106
125
  color: #095797 !important;
107
126
  }
@@ -67,6 +67,8 @@
67
67
  import { estRequis as estRequisRegle, estUniqueBilingue, estMinimumLongueur, estMaximumLongueur } from './validateurs'
68
68
  import { ChoixLangue } from '@/enums/choixLangue'
69
69
  import { computed, type PropType, toRefs } from 'vue'
70
+ import { useI18n } from 'vue-i18n'
71
+ const { t } = useI18n({ useScope: 'global' })
70
72
 
71
73
  const props = defineProps<{
72
74
  textarea?: boolean
@@ -106,21 +108,26 @@
106
108
  )
107
109
  }
108
110
 
109
- if (estRequis.value) _regles.push(v => estRequisRegle(v))
111
+ if (estRequis.value) _regles.push(v => estRequisRegle(v, t))
110
112
 
111
113
  if (estUniqueValeurs.value) {
112
114
  _regles.push(v =>
113
- estUniqueBilingue(v, model.value, {
114
- champs: { Anglais: champs.value.Anglais, Francais: champs.value.Francais },
115
- valeurs: estUniqueValeurs.value!,
116
- langueCss: langue.value,
117
- }),
115
+ estUniqueBilingue(
116
+ v,
117
+ model.value,
118
+ {
119
+ champs: { Anglais: champs.value.Anglais, Francais: champs.value.Francais },
120
+ valeurs: estUniqueValeurs.value!,
121
+ langueCss: langue.value,
122
+ },
123
+ t,
124
+ ),
118
125
  )
119
126
  }
120
127
 
121
- if (minimumLongueur.value !== undefined) _regles.push(v => estMinimumLongueur(v, minimumLongueur.value!))
128
+ if (minimumLongueur.value !== undefined) _regles.push(v => estMinimumLongueur(v, minimumLongueur.value!, t))
122
129
 
123
- if (maximumLongueur.value !== undefined) _regles.push(v => estMaximumLongueur(v, maximumLongueur.value!))
130
+ if (maximumLongueur.value !== undefined) _regles.push(v => estMaximumLongueur(v, maximumLongueur.value!, t))
124
131
 
125
132
  return _regles
126
133
  })
@@ -1,5 +1,4 @@
1
1
  import { ChoixLangue } from '@/enums/choixLangue'
2
- import i18n from '@/plugins/i18n'
3
2
 
4
3
  /**
5
4
  * Valide que le champ contient une valeur définie et non vide.
@@ -7,10 +6,9 @@ import i18n from '@/plugins/i18n'
7
6
  * et toute autre valeur définie (ex. objets sélectionnés dans un v-select).
8
7
  *
9
8
  * @param valeur La valeur saisie ou sélectionnée dans le champ.
10
- * @returns `true` si la valeur est considérée comme valide, sinon retourne un message d'erreur.
9
+ * @returns true si la valeur est considérée comme valide, sinon retourne un message d'erreur.
11
10
  */
12
- export function estRequis(valeur: unknown): true | string {
13
- const { t } = i18n.global
11
+ export function estRequis(valeur: unknown, t: (key: string, params?: any) => string): true | string {
14
12
  if (valeur == null) return t('validateurs.estRequis')
15
13
 
16
14
  if (typeof valeur === 'number' && isNaN(valeur)) return t('validateurs.estRequis')
@@ -26,27 +24,25 @@ export function estRequis(valeur: unknown): true | string {
26
24
  * Valide que le champ contient une valeur qui est d'une longeur minimale.
27
25
  * @param valeur La valeur saisie du champ texte.
28
26
  * @param min La longeur minimale de la valeur.
29
- * @returns `true` si la longeur de la valeur est égale ou supérieure au minimum, sinon retourne un message d'erreur.
27
+ * @returns true si la longeur de la valeur est égale ou supérieure au minimum, sinon retourne un message d'erreur.
30
28
  */
31
- export function estMinimumLongueur(valeur: string, min: number) {
32
- const { t } = i18n.global
29
+ export function estMinimumLongueur(valeur: string, min: number, t: (key: string, params?: any) => string) {
33
30
  if (min <= 0) {
34
31
  min = 1
35
32
  console.warn(
36
33
  'CsqcValidateurs (estMinimumLongeur) - Une valeur négative ou égale à 0 a été reçue. Assurez-vous de passer une valeur supérieur à 0 dans la fonction estMinimumLongeur. La valeur a été mise à 1.',
37
34
  )
38
35
  }
39
- return (valeur && valeur.trim().length >= min) || t('validateurs.estMinimumLongueur', { nbCaracteres: min }, min)
36
+ return (valeur && valeur.trim().length >= min) || t('validateurs.estMinimumLongueur', { nbCaracteres: min })
40
37
  }
41
38
 
42
39
  /**
43
40
  * Valide que le champ contient une valeur qui ne dépasse pas une longeur maximale.
44
41
  * @param valeur La valeur saisie du champ texte.
45
42
  * @param max La longeur maximale (inclusive) de la valeur.
46
- * @returns `true` si la longeur de la valeur est inférieure ou égale au maximum, sinon retourne un message d'erreur.
43
+ * @returns true si la longeur de la valeur est inférieure ou égale au maximum, sinon retourne un message d'erreur.
47
44
  */
48
- export function estMaximumLongueur(valeur: string, max: number) {
49
- const { t } = i18n.global
45
+ export function estMaximumLongueur(valeur: string, max: number, t: (key: string, params?: any) => string) {
50
46
  if (max < 1) {
51
47
  max = 1
52
48
  console.warn(
@@ -54,7 +50,7 @@ export function estMaximumLongueur(valeur: string, max: number) {
54
50
  )
55
51
  }
56
52
 
57
- return (valeur && valeur.trim().length <= max) || t('validateurs.estMaximumLongueur', { nbCaracteres: max }, max)
53
+ return (valeur && valeur.trim().length <= max) || t('validateurs.estMaximumLongueur', { nbCaracteres: max })
58
54
  }
59
55
 
60
56
  /**
@@ -69,8 +65,8 @@ export function estUniqueBilingue<T extends ModeleAvecId>(
69
65
  valeur: string,
70
66
  modele: T,
71
67
  options: EstUniqueOptionsBilingue<T>,
68
+ t: (key: string, params?: any) => string,
72
69
  ) {
73
- const { t } = i18n.global
74
70
  // Affectations valeurs par défaut
75
71
  const { champs, langueCss, valeurs } = options
76
72
  if (!langueCss) options.langueCss = ChoixLangue.Francais
@@ -142,8 +138,12 @@ export function estUniqueBilingue<T extends ModeleAvecId>(
142
138
  * @param options Les configurations de la fonction
143
139
  * @returns Vrai si la valeur est unique, ou une string d'erreur si un doublon est trouvé.
144
140
  */
145
- export function estUnique<T extends ModeleAvecId>(valeur: string, modele: T, options: EstUniqueOptions<T>) {
146
- const { t } = i18n.global
141
+ export function estUnique<T extends ModeleAvecId>(
142
+ valeur: string,
143
+ modele: T,
144
+ options: EstUniqueOptions<T>,
145
+ t: (key: string, params?: any) => string,
146
+ ) {
147
147
  const { champ, valeurs } = options
148
148
  return (
149
149
  !valeurs.some(
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "codevdesign",
3
- "version": "0.0.43",
3
+ "version": "0.0.45",
4
4
  "description": "Composants Vuetify 3 pour les projets Codev",
5
5
  "files": [
6
6
  "./**/*.vue",