codevdesign 1.0.78 → 2.0.0

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 (94) hide show
  1. package/assets/csqc.css +28 -30
  2. package/composants/csqcAide.vue +1 -1
  3. package/composants/csqcAlerteErreur.vue +1 -1
  4. package/composants/csqcChaise/chaiseConteneur.vue +4 -4
  5. package/composants/csqcChaise/chaiseItem.vue +54 -54
  6. package/composants/csqcCodeBudgetaireGenerique.vue +260 -256
  7. package/composants/csqcConfirmation.vue +76 -75
  8. package/composants/csqcDate.vue +88 -86
  9. package/composants/csqcDialogue.vue +120 -118
  10. package/composants/csqcEditeurTexteRiche.vue +378 -378
  11. package/composants/csqcEntete.vue +17 -17
  12. package/composants/csqcImportCSV.vue +2 -2
  13. package/composants/csqcModaleSaisie.vue +97 -97
  14. package/composants/csqcRecherche.vue +9 -9
  15. package/composants/csqcRechercheUtilisateur.vue +198 -198
  16. package/composants/csqcSnackbar.vue +207 -207
  17. package/composants/csqcSwitch.vue +6 -6
  18. package/composants/csqcTable/csqcTable.vue +19 -14
  19. package/composants/csqcTable/csqcTableModaleChoixColonnes.vue +5 -5
  20. package/composants/csqcTable/sortableDataTable.ts +1 -1
  21. package/composants/csqcTexteBilingue.vue +1 -1
  22. package/composants/csqcTiroir.vue +197 -197
  23. package/composants/gabarit/csqcMenu.vue +4 -4
  24. package/composants/gabarit/pivEntete.vue +6 -5
  25. package/composants/gabarit/pivPiedPage.vue +44 -29
  26. package/composants/validateurs.ts +8 -2
  27. package/editeur.ts +1 -1
  28. package/importCSV.ts +1 -1
  29. package/index.ts +80 -80
  30. package/locales/en.json +1 -1
  31. package/locales/fr.json +3 -3
  32. package/modeles/assurancesAssuranceGeneraleGrics.ts +3 -3
  33. package/modeles/assurancesAssurancePersonnelleGrics.ts +6 -6
  34. package/modeles/assurancesContratGrics.ts +6 -6
  35. package/modeles/assurancesDetailsPrimeReguliereGrics.ts +4 -4
  36. package/modeles/assurancesDonneesAssureurGrics.ts +5 -5
  37. package/modeles/assurancesEmployeGrics.ts +4 -4
  38. package/modeles/assurancesGrics.ts +6 -6
  39. package/modeles/assurancesRegimeAssuranceGrics.ts +2 -2
  40. package/modeles/assurancesRegimeBaseEmployeurGrics.ts +2 -2
  41. package/modeles/assurancesRegimeBaseGrics.ts +2 -2
  42. package/modeles/composants/csqcMenuModele.ts +18 -18
  43. package/modeles/composants/datatableColonne.ts +19 -19
  44. package/modeles/employeAdresseGrics.ts +6 -6
  45. package/modeles/employeAdressesPersonnellesGrics.ts +4 -4
  46. package/modeles/employeAffectationCorpsEmploiGrics.ts +2 -2
  47. package/modeles/employeBanquesCongeBanqueGrics.ts +2 -2
  48. package/modeles/employeBanquesCongeGrics.ts +6 -6
  49. package/modeles/employeBanquesCongeRegimeAbsenceGrics.ts +2 -2
  50. package/modeles/employeCourrielsPersonnels.ts +2 -2
  51. package/modeles/employeCourrielsProfessionnels.ts +2 -2
  52. package/modeles/employeEmploisCategorieGrics.ts +2 -2
  53. package/modeles/employeEmploisClasseGrics.ts +2 -2
  54. package/modeles/employeEmploisCorpsEmploiGrics.ts +2 -2
  55. package/modeles/employeEmploisEtatEmploiGrics.ts +2 -2
  56. package/modeles/employeEmploisGrics.ts +29 -29
  57. package/modeles/employeEmploisGroupePaieGrics.ts +2 -2
  58. package/modeles/employeEmploisLieuTravailPrincipalGrics.ts +3 -3
  59. package/modeles/employeEmploisLieuxTravailSecondairesGrics.ts +3 -3
  60. package/modeles/employeEmploisRegimeAbsenceGrics.ts +2 -2
  61. package/modeles/employeEmploisSecteurGrics.ts +2 -2
  62. package/modeles/employeEmploisStatutEngagementGrics.ts +2 -2
  63. package/modeles/employeExperienceEmploiGrics.ts +2 -2
  64. package/modeles/employeExperienceEmployeGrics.ts +5 -5
  65. package/modeles/employeExperienceExperiencesGrics.ts +4 -4
  66. package/modeles/employeExperienceExperiencesTotalesGrics.ts +7 -7
  67. package/modeles/employeExperienceGrics.ts +9 -9
  68. package/modeles/employeGrics.ts +23 -23
  69. package/modeles/employeTelephoneGrics.ts +4 -4
  70. package/modeles/employeTelephonesPersonnelsGrics.ts +3 -3
  71. package/modeles/employeTelephonesProfessionnelsGrics.ts +3 -3
  72. package/modeles/groupeCE.ts +6 -6
  73. package/modeles/groupeCEIntervalle.ts +6 -6
  74. package/modeles/historiquesAbsenceBanqueGrics.ts +2 -2
  75. package/modeles/historiquesAbsenceGrics.ts +13 -13
  76. package/modeles/historiquesAbsenceLieuTravailGrics.ts +2 -2
  77. package/modeles/historiquesAbsenceSousBanqueGrics.ts +2 -2
  78. package/modeles/motifsAbsenceBanque.ts +2 -2
  79. package/modeles/motifsAbsenceGrics.ts +9 -9
  80. package/modeles/motifsAbsenceRegimeAbsence.ts +2 -2
  81. package/modeles/motifsAbsenceSousMotifs.ts +2 -2
  82. package/modeles/motifsAbsenceTraitementBanques.ts +3 -3
  83. package/modeles/syndicat.ts +18 -18
  84. package/modeles/syndicatGroupeCe.ts +3 -3
  85. package/modeles/syndicatResponsable.ts +8 -8
  86. package/modeles/syndicatUnite.ts +3 -3
  87. package/modeles/unite.ts +15 -15
  88. package/modeles/uniteTypeEnseignement.ts +4 -4
  89. package/modeles/utilisateur.ts +8 -8
  90. package/outils/appAxios.ts +16 -16
  91. package/outils/csqcOutils.ts +6 -5
  92. package/outils/csqcRafraichisseurTokenParent.ts +20 -4
  93. package/outils/rafraichisseurToken.ts +1 -1
  94. package/package.json +13 -13
@@ -85,7 +85,7 @@
85
85
  </v-row>
86
86
 
87
87
  <!-- Barre en bas -->
88
- <div style="position: absolute; bottom: 0; left: 0; right: 0; height: 2px; background-color: #808a9d" />
88
+ <div style="background-color: #808a9d; bottom: 0; height: 2px; left: 0; position: absolute; right: 0" />
89
89
  </v-app-bar>
90
90
  </template>
91
91
 
@@ -146,21 +146,21 @@
146
146
  }
147
147
  .titre-texte {
148
148
  color: var(--entete-texte, #223654);
149
+ max-width: 100%;
149
150
  overflow: hidden;
150
151
  text-overflow: ellipsis;
151
152
  white-space: nowrap;
152
- max-width: 100%;
153
153
  }
154
154
  .soustitre-texte {
155
+ color: var(--entete-texte, #223654);
155
156
  display: block;
156
157
  font-size: 1rem;
157
158
  font-weight: normal;
158
- color: var(--entete-texte, #223654);
159
159
  }
160
160
  .titre-bloc {
161
161
  display: inline-block;
162
- vertical-align: middle;
163
162
  padding-left: 12px;
163
+ vertical-align: middle;
164
164
  }
165
165
  /* Couleur de l’icône (retour) + hover */
166
166
  .v-icon {
@@ -170,26 +170,26 @@
170
170
  filter: brightness(0.85);
171
171
  }
172
172
  .entete-ligne {
173
- display: flex;
174
173
  align-items: center;
174
+ display: flex;
175
175
  flex-wrap: wrap;
176
- width: 100%;
177
176
  gap: 8px;
177
+ width: 100%;
178
178
  }
179
179
 
180
180
  .entete-gauche {
181
- display: flex;
182
181
  align-items: center;
183
- min-width: 0; /* important pour éviter overflow */
182
+ display: flex;
184
183
  flex: 1;
184
+ min-width: 0; /* important pour éviter overflow */
185
185
  }
186
186
 
187
187
  .entete-droite {
188
- display: flex;
189
188
  align-items: center;
189
+ display: flex;
190
+ flex-shrink: 0;
190
191
  gap: 12px;
191
192
  padding-right: 16px;
192
- flex-shrink: 0;
193
193
  }
194
194
 
195
195
  @media (max-width: 600px) {
@@ -197,27 +197,27 @@
197
197
  width: 100%;
198
198
  }
199
199
  .entete-droite {
200
- width: 100%;
201
- padding-right: 8px;
202
- padding-left: 0;
203
200
  justify-content: flex-end;
201
+ padding-left: 0;
202
+ padding-right: 8px;
203
+ width: 100%;
204
204
  }
205
205
  .titre {
206
206
  font-size: 1.2rem;
207
207
  }
208
208
  .titre-bloc {
209
+ align-items: flex-start;
209
210
  display: flex;
210
211
  flex-direction: column;
211
- align-items: flex-start;
212
- min-width: 0;
213
212
  max-width: 100%;
213
+ min-width: 0;
214
214
  padding-left: 4px;
215
215
  }
216
216
  .titre-texte {
217
- white-space: nowrap;
217
+ max-width: 100%;
218
218
  overflow: hidden;
219
219
  text-overflow: ellipsis;
220
- max-width: 100%;
220
+ white-space: nowrap;
221
221
  }
222
222
  :deep(.v-col) {
223
223
  padding-left: 8px !important;
@@ -90,7 +90,7 @@
90
90
 
91
91
  emit('import', data)
92
92
  } catch (error) {
93
- emit('import-erreur', erreurTexte || t('csqc.csqcImportCSV.erreur.lectureFichier'))
93
+ emit('import-erreur', erreurTexte.value || t('csqc.csqcImportCSV.erreur.lectureFichier'))
94
94
  }
95
95
  }
96
96
 
@@ -100,7 +100,7 @@
100
100
 
101
101
  reader.readAsText(file)
102
102
  } else {
103
- const message = erreurTexte || t('csqc.csqcImportCSV.erreur.erreur')
103
+ const message = erreurTexte.value || t('csqc.csqcImportCSV.erreur.erreur')
104
104
  emit('import-erreur', message)
105
105
  csvFile.value = null
106
106
  }
@@ -1,97 +1,97 @@
1
- <template>
2
- <csqcDialogue
3
- ref="modale"
4
- :titre="titre"
5
- activator="supprimer"
6
- :largeur="largeur"
7
- v-bind="$attrs"
8
- @ok="confirmer"
9
- @annuler="annuler"
10
- >
11
- <v-form
12
- ref="form"
13
- @submit.prevent
14
- >
15
- <v-row>
16
- <v-col
17
- cols="12"
18
- class="pa-0 ma-0"
19
- >
20
- <span v-html="texte"></span>
21
- </v-col>
22
- </v-row>
23
-
24
- <v-row>
25
- <v-col
26
- cols="12"
27
- class="pa-0 ma-0"
28
- >
29
- <v-text-field
30
- v-if="!multiligne"
31
- v-model="reponse"
32
- autofocus
33
- @keyup.enter="confirmer"
34
- />
35
- <v-textarea
36
- v-if="multiligne"
37
- v-model="reponse"
38
- :rows="3"
39
- autofocus
40
- />
41
- </v-col>
42
- </v-row>
43
- </v-form>
44
- </csqcDialogue>
45
- </template>
46
-
47
- <script lang="ts" setup>
48
- import { ref } from 'vue'
49
- import csqcDialogue from './csqcDialogue.vue'
50
-
51
- const modale = ref<InstanceType<typeof csqcDialogue> | null>(null)
52
- const utilisateurATermine = ref(false)
53
- const reponse = ref<string | null>(null)
54
- const texte = ref('')
55
- const titre = ref('')
56
- const largeur = ref('525px')
57
- const multiligne = ref(false)
58
-
59
- const ouvrir = async (
60
- titreParam: string,
61
- message: string,
62
- valeurDefaut: string | null = null,
63
- multiligneParam: boolean = false,
64
- largeurParam = '525px',
65
- ) => {
66
- texte.value = message
67
- titre.value = titreParam
68
- reponse.value = valeurDefaut
69
- multiligne.value = multiligneParam
70
- largeur.value = largeurParam
71
- utilisateurATermine.value = false
72
- modale.value?.ouvrir()
73
-
74
- while (!utilisateurATermine.value) {
75
- await new Promise(resolve => setTimeout(resolve, 100)) // Attendre 100ms
76
- }
77
-
78
- return reponse.value
79
- }
80
-
81
- const confirmer = (): void => {
82
- utilisateurATermine.value = true
83
- fermer()
84
- }
85
-
86
- const annuler = (): void => {
87
- reponse.value = null
88
- utilisateurATermine.value = true
89
- fermer()
90
- }
91
-
92
- const fermer = (): void => {
93
- modale.value?.fermer()
94
- }
95
-
96
- defineExpose({ ouvrir, fermer })
97
- </script>
1
+ <template>
2
+ <csqcDialogue
3
+ ref="modale"
4
+ :titre="titre"
5
+ activator="supprimer"
6
+ :largeur="largeur"
7
+ v-bind="$attrs"
8
+ @ok="confirmer"
9
+ @annuler="annuler"
10
+ >
11
+ <v-form
12
+ ref="form"
13
+ @submit.prevent
14
+ >
15
+ <v-row>
16
+ <v-col
17
+ cols="12"
18
+ class="pa-0 ma-0"
19
+ >
20
+ <span v-html="texte"></span>
21
+ </v-col>
22
+ </v-row>
23
+
24
+ <v-row>
25
+ <v-col
26
+ cols="12"
27
+ class="pa-0 ma-0"
28
+ >
29
+ <v-text-field
30
+ v-if="!multiligne"
31
+ v-model="reponse"
32
+ autofocus
33
+ @keyup.enter="confirmer"
34
+ />
35
+ <v-textarea
36
+ v-if="multiligne"
37
+ v-model="reponse"
38
+ :rows="3"
39
+ autofocus
40
+ />
41
+ </v-col>
42
+ </v-row>
43
+ </v-form>
44
+ </csqcDialogue>
45
+ </template>
46
+
47
+ <script lang="ts" setup>
48
+ import { ref } from 'vue'
49
+ import csqcDialogue from './csqcDialogue.vue'
50
+
51
+ const modale = ref<InstanceType<typeof csqcDialogue> | null>(null)
52
+ const utilisateurATermine = ref(false)
53
+ const reponse = ref<string | null>(null)
54
+ const texte = ref('')
55
+ const titre = ref('')
56
+ const largeur = ref('525px')
57
+ const multiligne = ref(false)
58
+
59
+ const ouvrir = async (
60
+ titreParam: string,
61
+ message: string,
62
+ valeurDefaut: string | null = null,
63
+ multiligneParam: boolean = false,
64
+ largeurParam = '525px',
65
+ ) => {
66
+ texte.value = message
67
+ titre.value = titreParam
68
+ reponse.value = valeurDefaut
69
+ multiligne.value = multiligneParam
70
+ largeur.value = largeurParam
71
+ utilisateurATermine.value = false
72
+ modale.value?.ouvrir()
73
+
74
+ while (!utilisateurATermine.value) {
75
+ await new Promise(resolve => setTimeout(resolve, 100)) // Attendre 100ms
76
+ }
77
+
78
+ return reponse.value
79
+ }
80
+
81
+ const confirmer = (): void => {
82
+ utilisateurATermine.value = true
83
+ fermer()
84
+ }
85
+
86
+ const annuler = (): void => {
87
+ reponse.value = null
88
+ utilisateurATermine.value = true
89
+ fermer()
90
+ }
91
+
92
+ const fermer = (): void => {
93
+ modale.value?.fermer()
94
+ }
95
+
96
+ defineExpose({ ouvrir, fermer })
97
+ </script>
@@ -1,7 +1,7 @@
1
1
  <template>
2
2
  <div>
3
3
  <v-row
4
- dense
4
+ density="compact"
5
5
  class="pt-0 mt-0"
6
6
  >
7
7
  <v-col
@@ -59,7 +59,7 @@
59
59
  </v-col>
60
60
  </v-row>
61
61
  <v-row
62
- dense
62
+ density="compact"
63
63
  class="pt-0 mt-0"
64
64
  >
65
65
  <v-col
@@ -190,25 +190,25 @@
190
190
  }
191
191
 
192
192
  .BarreRechercheBackIcone {
193
+ background-color: #095797 !important;
194
+ border-bottom: 1px solid #808a9d;
195
+ border-radius: 0 4px 4px 0 !important;
193
196
  border-right: 1px solid #808a9d;
194
197
  border-top: 1px solid #808a9d;
195
- border-bottom: 1px solid #808a9d;
196
- background-color: #095797 !important;
197
198
  height: 40px !important;
198
- width: 40px !important;
199
+ margin-left: -16px;
199
200
  max-width: 40px !important;
200
201
  min-width: 40px !important;
201
- padding-right: 0 !important;
202
202
  padding-left: 0 !important;
203
- border-radius: 0 4px 4px 0 !important;
204
- margin-left: -16px;
203
+ padding-right: 0 !important;
204
+ width: 40px !important;
205
205
  }
206
206
 
207
207
  /* icone loupe */
208
208
  .BarreRechercheIcone {
209
+ color: white !important;
209
210
  font-size: 34px !important;
210
211
  margin-left: 1px !important;
211
212
  margin-top: 2px !important;
212
- color: white !important;
213
213
  }
214
214
  </style>