shared-ritm 1.3.125 → 1.3.126

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