shared-ritm 1.2.151 → 1.2.152

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 (50) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +4619 -4550
  3. package/dist/shared-ritm.umd.js +156 -156
  4. package/dist/types/api/services/PhotoService.d.ts +38 -51
  5. package/dist/types/api/services/VideoService.d.ts +1 -0
  6. package/dist/types/index.d.ts +2 -1
  7. package/package.json +64 -64
  8. package/src/api/services/BrigadesService.ts +32 -32
  9. package/src/api/services/ControlsService.ts +92 -92
  10. package/src/api/services/EquipmentService.ts +29 -29
  11. package/src/api/services/InstrumentsService.ts +63 -63
  12. package/src/api/services/MetricsService.ts +110 -110
  13. package/src/api/services/ModulesService.ts +27 -27
  14. package/src/api/services/ProjectsService.ts +83 -83
  15. package/src/api/services/RepairsService.ts +124 -124
  16. package/src/api/services/ScheduleService.ts +69 -69
  17. package/src/api/services/SearchService.ts +22 -22
  18. package/src/api/services/UserService.ts +113 -113
  19. package/src/api/services/VideoService.ts +107 -103
  20. package/src/api/settings/ApiService.ts +124 -124
  21. package/src/api/types/Api_Auth.ts +105 -105
  22. package/src/api/types/Api_Brigades.ts +36 -36
  23. package/src/api/types/Api_Controls.ts +111 -111
  24. package/src/api/types/Api_Equipment.ts +3 -3
  25. package/src/api/types/Api_Instruments.ts +136 -136
  26. package/src/api/types/Api_Modules.ts +21 -21
  27. package/src/api/types/Api_Projects.ts +62 -62
  28. package/src/api/types/Api_Repairs.ts +140 -140
  29. package/src/api/types/Api_Schedule.ts +64 -64
  30. package/src/api/types/Api_Search.ts +80 -80
  31. package/src/api/types/Api_User.ts +145 -145
  32. package/src/api/types/Api_Video.ts +145 -145
  33. package/src/common/app-datepicker/AppDatepicker.vue +176 -176
  34. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  35. package/src/common/app-input-new/AppInputNew.vue +175 -175
  36. package/src/common/app-layout/AppLayout.vue +84 -84
  37. package/src/common/app-modal/index.vue +96 -0
  38. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  39. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  40. package/src/common/app-sidebar/components/SidebarMenuItem.vue +149 -149
  41. package/src/common/app-table/AppTable.vue +308 -308
  42. package/src/common/app-table/AppTableLayout.vue +137 -137
  43. package/src/common/app-table/components/ModalSelect.vue +286 -285
  44. package/src/common/app-table/components/TableModal.vue +356 -356
  45. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  46. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  47. package/src/index.ts +128 -126
  48. package/src/styles/variables.sass +12 -12
  49. package/dist/types/api/services/ComentsServise.d.ts +0 -10
  50. package/dist/types/api/types/Api_Users.d.ts +0 -43
@@ -1,244 +1,244 @@
1
- <template>
2
- <q-dialog
3
- :model-value="modelValue"
4
- :position="'right'"
5
- :class="$style['sheet-dialog']"
6
- :persistent="persistent"
7
- no-shake
8
- no-esc-dismiss
9
- full-height
10
- @update:model-value="emit('update:modelValue', $event)"
11
- >
12
- <div v-if="loading" class="custom-wrapper" :style="{ width }">
13
- <div class="loader">
14
- <q-spinner-audio v-if="loading" class="loader-spinner" size="md" :thickness="3" color="primary" />
15
- </div>
16
- </div>
17
- <div v-else class="wrapper" :style="{ width }">
18
- <div v-if="tabs?.length" class="sidebar" :class="{ noTitle: !tabsTitle }" :style="{ width: sidebarWidth }">
19
- <h5 v-if="tabsTitle">{{ tabsTitle }}</h5>
20
- <q-tabs
21
- v-model="currTabId"
22
- vertical
23
- align="justify"
24
- inline-label
25
- class="tabs"
26
- dense
27
- active-class="active-tab"
28
- no-caps
29
- >
30
- <q-tab
31
- v-for="tab in tabs"
32
- :key="tab.id"
33
- :class="$style['tab']"
34
- :name="tab.title"
35
- icon="radio_button_unchecked"
36
- :label="tab.title"
37
- />
38
- </q-tabs>
39
- </div>
40
-
41
- <div class="content">
42
- <div v-if="title" class="content-header">
43
- <h2 class="ellipsis" :title="title">{{ title }}</h2>
44
- <q-btn v-close-popup="!persistent" dense flat icon="close" @click="emit('close')" />
45
- </div>
46
-
47
- <slot />
48
-
49
- <div v-if="'actions' in slots" class="app-sheet-actions">
50
- <slot name="actions" />
51
- </div>
52
- </div>
53
- </div>
54
- </q-dialog>
55
- </template>
56
-
57
- <script setup lang="ts">
58
- import { computed, defineEmits, defineProps, useSlots, withDefaults } from 'vue'
59
- import { QDialog } from 'quasar'
60
-
61
- interface DialogProps {
62
- modelValue: boolean
63
- loading?: boolean
64
- title?: string
65
- tabsTitle?: string
66
- width?: string
67
- type?: 'details' | 'custom'
68
- tabs?: { id: string | number; title?: string }[]
69
- tabId?: string
70
- sidebarWidth?: string
71
- persistent?: boolean
72
- }
73
-
74
- const props = withDefaults(defineProps<DialogProps>(), {
75
- modelValue: false,
76
- title: '',
77
- tabsTitle: '',
78
- width: '1200px',
79
- type: 'details',
80
- loading: false,
81
- tabs: () => [],
82
- tabId: '',
83
- sidebarWidth: '',
84
- persistent: false,
85
- })
86
-
87
- const emit = defineEmits(['update:modelValue', 'update:tabId', 'close', 'before-hide'])
88
-
89
- const slots = useSlots()
90
-
91
- const currTabId = computed({
92
- get() {
93
- return props.tabs?.find(t => t.id === props.tabId)?.title
94
- },
95
- set(value) {
96
- const id = props.tabs?.find(t => t.title === value)?.id
97
- emit('update:tabId', id)
98
- },
99
- })
100
- </script>
101
-
102
- <style lang="scss" scoped>
103
- .custom-wrapper {
104
- max-width: unset;
105
- background-color: white;
106
- }
107
-
108
- .loader {
109
- &-spinner {
110
- position: absolute;
111
- top: 50%;
112
- left: 50%;
113
- z-index: 4;
114
- }
115
- }
116
-
117
- .wrapper {
118
- display: flex;
119
- overflow: hidden;
120
- font-family: 'NunitoSansFont', sans-serif;
121
- color: #3f414d;
122
- max-width: unset;
123
- }
124
-
125
- .sidebar {
126
- max-width: 25vw;
127
- flex: none;
128
- padding: 2rem 0 2rem 2rem;
129
- background-color: #f4f9fd;
130
-
131
- &.noTitle {
132
- padding: 0 0 2rem 2rem;
133
- }
134
-
135
- h5 {
136
- font-size: 24px;
137
- font-weight: 700;
138
- padding-right: 2rem;
139
- }
140
-
141
- .tabs {
142
- color: #b9c0c7;
143
- transition-duration: 0.1s;
144
- margin: 16px 0;
145
- }
146
-
147
- .active-tab {
148
- color: #3f8cff;
149
- }
150
- }
151
-
152
- .content {
153
- background-color: #fff;
154
- height: 100vh;
155
- width: 100%;
156
- display: grid;
157
- grid-template-rows: auto 1fr auto;
158
-
159
- &-header {
160
- display: flex;
161
- justify-content: space-between;
162
- align-items: center;
163
- padding: 4px 1rem;
164
- border-bottom: 1px solid var(--g-grey-100);
165
- overflow: hidden;
166
-
167
- h2 {
168
- font-size: 32px;
169
- font-weight: 700;
170
- }
171
- }
172
- }
173
-
174
- .app-sheet-actions {
175
- display: flex;
176
- gap: 1rem;
177
- padding: 1rem;
178
- border-top: 1px solid var(--g-grey-100);
179
- }
180
- </style>
181
-
182
- <style lang="scss" module>
183
- .sheet-dialog {
184
- :global(.q-dialog__inner) {
185
- max-width: 95vw;
186
- }
187
-
188
- :global(.q-dialog__inner--minimized) {
189
- padding: 0;
190
- }
191
- }
192
-
193
- .tab {
194
- padding: 0 !important;
195
-
196
- :global(.q-focus-helper) {
197
- display: none !important;
198
- }
199
- :global(.q-ripple) {
200
- display: none !important;
201
- }
202
- :global(.q-tab__content) {
203
- width: 100%;
204
- justify-content: left;
205
- margin: 10px 0;
206
- padding-right: 2rem;
207
-
208
- :global(.q-tab__label) {
209
- font-size: 18px;
210
- font-family: NunitoSansFont, sans-serif;
211
- }
212
- :global(.q-tab__icon) {
213
- font-size: 33px;
214
- width: 33px;
215
- height: 33px;
216
- }
217
-
218
- &::after {
219
- content: '';
220
- position: absolute;
221
- bottom: -23px;
222
- left: 15px;
223
- height: 26px;
224
- border: 1px solid #b9c0c7;
225
- }
226
- }
227
- }
228
-
229
- .tab:last-child {
230
- :global(.q-tab__content) {
231
- &::after {
232
- display: none;
233
- }
234
- }
235
- }
236
- </style>
237
-
238
- <style lang="scss">
239
- .app-sheet-actions {
240
- button {
241
- border-radius: 8px;
242
- }
243
- }
244
- </style>
1
+ <template>
2
+ <q-dialog
3
+ :model-value="modelValue"
4
+ :position="'right'"
5
+ :class="$style['sheet-dialog']"
6
+ :persistent="persistent"
7
+ no-shake
8
+ no-esc-dismiss
9
+ full-height
10
+ @update:model-value="emit('update:modelValue', $event)"
11
+ >
12
+ <div v-if="loading" class="custom-wrapper" :style="{ width }">
13
+ <div class="loader">
14
+ <q-spinner-audio v-if="loading" class="loader-spinner" size="md" :thickness="3" color="primary" />
15
+ </div>
16
+ </div>
17
+ <div v-else class="wrapper" :style="{ width }">
18
+ <div v-if="tabs?.length" class="sidebar" :class="{ noTitle: !tabsTitle }" :style="{ width: sidebarWidth }">
19
+ <h5 v-if="tabsTitle">{{ tabsTitle }}</h5>
20
+ <q-tabs
21
+ v-model="currTabId"
22
+ vertical
23
+ align="justify"
24
+ inline-label
25
+ class="tabs"
26
+ dense
27
+ active-class="active-tab"
28
+ no-caps
29
+ >
30
+ <q-tab
31
+ v-for="tab in tabs"
32
+ :key="tab.id"
33
+ :class="$style['tab']"
34
+ :name="tab.title"
35
+ icon="radio_button_unchecked"
36
+ :label="tab.title"
37
+ />
38
+ </q-tabs>
39
+ </div>
40
+
41
+ <div class="content">
42
+ <div v-if="title" class="content-header">
43
+ <h2 class="ellipsis" :title="title">{{ title }}</h2>
44
+ <q-btn v-close-popup="!persistent" dense flat icon="close" @click="emit('close')" />
45
+ </div>
46
+
47
+ <slot />
48
+
49
+ <div v-if="'actions' in slots" class="app-sheet-actions">
50
+ <slot name="actions" />
51
+ </div>
52
+ </div>
53
+ </div>
54
+ </q-dialog>
55
+ </template>
56
+
57
+ <script setup lang="ts">
58
+ import { computed, defineEmits, defineProps, useSlots, withDefaults } from 'vue'
59
+ import { QDialog } from 'quasar'
60
+
61
+ interface DialogProps {
62
+ modelValue: boolean
63
+ loading?: boolean
64
+ title?: string
65
+ tabsTitle?: string
66
+ width?: string
67
+ type?: 'details' | 'custom'
68
+ tabs?: { id: string | number; title?: string }[]
69
+ tabId?: string
70
+ sidebarWidth?: string
71
+ persistent?: boolean
72
+ }
73
+
74
+ const props = withDefaults(defineProps<DialogProps>(), {
75
+ modelValue: false,
76
+ title: '',
77
+ tabsTitle: '',
78
+ width: '1200px',
79
+ type: 'details',
80
+ loading: false,
81
+ tabs: () => [],
82
+ tabId: '',
83
+ sidebarWidth: '',
84
+ persistent: false,
85
+ })
86
+
87
+ const emit = defineEmits(['update:modelValue', 'update:tabId', 'close', 'before-hide'])
88
+
89
+ const slots = useSlots()
90
+
91
+ const currTabId = computed({
92
+ get() {
93
+ return props.tabs?.find(t => t.id === props.tabId)?.title
94
+ },
95
+ set(value) {
96
+ const id = props.tabs?.find(t => t.title === value)?.id
97
+ emit('update:tabId', id)
98
+ },
99
+ })
100
+ </script>
101
+
102
+ <style lang="scss" scoped>
103
+ .custom-wrapper {
104
+ max-width: unset;
105
+ background-color: white;
106
+ }
107
+
108
+ .loader {
109
+ &-spinner {
110
+ position: absolute;
111
+ top: 50%;
112
+ left: 50%;
113
+ z-index: 4;
114
+ }
115
+ }
116
+
117
+ .wrapper {
118
+ display: flex;
119
+ overflow: hidden;
120
+ font-family: 'NunitoSansFont', sans-serif;
121
+ color: #3f414d;
122
+ max-width: unset;
123
+ }
124
+
125
+ .sidebar {
126
+ max-width: 25vw;
127
+ flex: none;
128
+ padding: 2rem 0 2rem 2rem;
129
+ background-color: #f4f9fd;
130
+
131
+ &.noTitle {
132
+ padding: 0 0 2rem 2rem;
133
+ }
134
+
135
+ h5 {
136
+ font-size: 24px;
137
+ font-weight: 700;
138
+ padding-right: 2rem;
139
+ }
140
+
141
+ .tabs {
142
+ color: #b9c0c7;
143
+ transition-duration: 0.1s;
144
+ margin: 16px 0;
145
+ }
146
+
147
+ .active-tab {
148
+ color: #3f8cff;
149
+ }
150
+ }
151
+
152
+ .content {
153
+ background-color: #fff;
154
+ height: 100vh;
155
+ width: 100%;
156
+ display: grid;
157
+ grid-template-rows: auto 1fr auto;
158
+
159
+ &-header {
160
+ display: flex;
161
+ justify-content: space-between;
162
+ align-items: center;
163
+ padding: 4px 1rem;
164
+ border-bottom: 1px solid var(--g-grey-100);
165
+ overflow: hidden;
166
+
167
+ h2 {
168
+ font-size: 32px;
169
+ font-weight: 700;
170
+ }
171
+ }
172
+ }
173
+
174
+ .app-sheet-actions {
175
+ display: flex;
176
+ gap: 1rem;
177
+ padding: 1rem;
178
+ border-top: 1px solid var(--g-grey-100);
179
+ }
180
+ </style>
181
+
182
+ <style lang="scss" module>
183
+ .sheet-dialog {
184
+ :global(.q-dialog__inner) {
185
+ max-width: 95vw;
186
+ }
187
+
188
+ :global(.q-dialog__inner--minimized) {
189
+ padding: 0;
190
+ }
191
+ }
192
+
193
+ .tab {
194
+ padding: 0 !important;
195
+
196
+ :global(.q-focus-helper) {
197
+ display: none !important;
198
+ }
199
+ :global(.q-ripple) {
200
+ display: none !important;
201
+ }
202
+ :global(.q-tab__content) {
203
+ width: 100%;
204
+ justify-content: left;
205
+ margin: 10px 0;
206
+ padding-right: 2rem;
207
+
208
+ :global(.q-tab__label) {
209
+ font-size: 18px;
210
+ font-family: NunitoSansFont, sans-serif;
211
+ }
212
+ :global(.q-tab__icon) {
213
+ font-size: 33px;
214
+ width: 33px;
215
+ height: 33px;
216
+ }
217
+
218
+ &::after {
219
+ content: '';
220
+ position: absolute;
221
+ bottom: -23px;
222
+ left: 15px;
223
+ height: 26px;
224
+ border: 1px solid #b9c0c7;
225
+ }
226
+ }
227
+ }
228
+
229
+ .tab:last-child {
230
+ :global(.q-tab__content) {
231
+ &::after {
232
+ display: none;
233
+ }
234
+ }
235
+ }
236
+ </style>
237
+
238
+ <style lang="scss">
239
+ .app-sheet-actions {
240
+ button {
241
+ border-radius: 8px;
242
+ }
243
+ }
244
+ </style>