shared-ritm 1.2.124 → 1.2.125

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 (131) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +4776 -4766
  4. package/dist/shared-ritm.umd.js +110 -110
  5. package/dist/types/api/services/ControlsService.d.ts +3 -2
  6. package/dist/types/api/services/PhotoService.d.ts +40 -0
  7. package/dist/types/api/services/RepairsService.d.ts +1 -0
  8. package/dist/types/api/types/Api_Controls.d.ts +10 -0
  9. package/package.json +64 -64
  10. package/src/App.vue +2461 -2461
  11. package/src/api/services/AuthService.ts +53 -53
  12. package/src/api/services/BrigadesService.ts +32 -32
  13. package/src/api/services/CommentsService.ts +24 -24
  14. package/src/api/services/ControlsService.ts +73 -69
  15. package/src/api/services/EquipmentService.ts +29 -29
  16. package/src/api/services/FileService.ts +17 -17
  17. package/src/api/services/GanttService.ts +17 -17
  18. package/src/api/services/InstrumentsService.ts +63 -63
  19. package/src/api/services/MetricsService.ts +110 -110
  20. package/src/api/services/ModulesService.ts +27 -27
  21. package/src/api/services/ProjectsService.ts +79 -79
  22. package/src/api/services/RepairsService.ts +123 -119
  23. package/src/api/services/SearchService.ts +22 -22
  24. package/src/api/services/TasksService.ts +145 -145
  25. package/src/api/services/UserService.ts +101 -101
  26. package/src/api/services/VideoService.ts +71 -71
  27. package/src/api/settings/ApiService.ts +124 -124
  28. package/src/api/types/Api_Auth.ts +86 -86
  29. package/src/api/types/Api_Brigades.ts +36 -36
  30. package/src/api/types/Api_Comment.ts +40 -40
  31. package/src/api/types/Api_Controls.ts +93 -82
  32. package/src/api/types/Api_Equipment.ts +3 -3
  33. package/src/api/types/Api_Files.ts +7 -7
  34. package/src/api/types/Api_Instruments.ts +136 -136
  35. package/src/api/types/Api_Modules.ts +21 -21
  36. package/src/api/types/Api_Projects.ts +60 -60
  37. package/src/api/types/Api_Repairs.ts +117 -117
  38. package/src/api/types/Api_Search.ts +77 -77
  39. package/src/api/types/Api_Service.ts +9 -9
  40. package/src/api/types/Api_Tasks.ts +319 -319
  41. package/src/api/types/Api_User.ts +117 -117
  42. package/src/api/types/Api_Video.ts +140 -140
  43. package/src/common/app-button/AppButton.vue +173 -173
  44. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  45. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  46. package/src/common/app-datepicker/AppDatepicker.vue +165 -165
  47. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  48. package/src/common/app-dropdown/AppDropdown.vue +37 -31
  49. package/src/common/app-icon/AppIcon.vue +108 -108
  50. package/src/common/app-input/AppInput.vue +148 -148
  51. package/src/common/app-input-new/AppInputNew.vue +175 -175
  52. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  53. package/src/common/app-layout/AppLayout.vue +84 -84
  54. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  55. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  56. package/src/common/app-loader/index.vue +43 -43
  57. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  58. package/src/common/app-select/AppSelect.vue +157 -157
  59. package/src/common/app-sheet/AppSheet.vue +120 -120
  60. package/src/common/app-sheet-new/AppSheetNew.vue +246 -246
  61. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  62. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  63. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  64. package/src/common/app-table/AppTable.vue +308 -314
  65. package/src/common/app-table/AppTableLayout.vue +137 -137
  66. package/src/common/app-table/components/ModalSelect.vue +281 -270
  67. package/src/common/app-table/components/TableModal.vue +356 -356
  68. package/src/common/app-table/components/TablePagination.vue +152 -152
  69. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  70. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  71. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  72. package/src/common/app-toggle/AppToggle.vue +24 -24
  73. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  74. package/src/global.d.ts +1 -1
  75. package/src/icons/components/arrow-down-icon.vue +25 -25
  76. package/src/icons/components/arrow-frame-icon.vue +19 -19
  77. package/src/icons/components/arrow-square.vue +22 -22
  78. package/src/icons/components/table-filter-icon.vue +30 -30
  79. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  80. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  81. package/src/icons/header/NotificationIcon.vue +18 -18
  82. package/src/icons/header/PersonIcon.vue +11 -11
  83. package/src/icons/header/SettingIcon.vue +14 -14
  84. package/src/icons/header/flashIcon.vue +24 -24
  85. package/src/icons/header/searchStatusIcon.vue +24 -24
  86. package/src/icons/header/smallCapsIcon.vue +34 -34
  87. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  88. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  89. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  90. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  91. package/src/icons/sidebar/instruments-icon.vue +45 -45
  92. package/src/icons/sidebar/logo-icon.vue +15 -15
  93. package/src/icons/sidebar/logout-icon.vue +13 -13
  94. package/src/icons/sidebar/modules-icon.vue +16 -16
  95. package/src/icons/sidebar/notifications-icon.vue +24 -24
  96. package/src/icons/sidebar/order-icon.vue +44 -44
  97. package/src/icons/sidebar/pass-icon.vue +38 -38
  98. package/src/icons/sidebar/positions-icon.vue +42 -42
  99. package/src/icons/sidebar/preorder-icon.vue +19 -19
  100. package/src/icons/sidebar/projects-icon.vue +31 -31
  101. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  102. package/src/icons/sidebar/repairs-icon.vue +20 -20
  103. package/src/icons/sidebar/roles-icon.vue +26 -26
  104. package/src/icons/sidebar/status-history-icon.vue +24 -24
  105. package/src/icons/sidebar/tasks-icon.vue +28 -28
  106. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  107. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  108. package/src/icons/sidebar/teams-icon.vue +32 -32
  109. package/src/icons/sidebar/user-icon.vue +18 -18
  110. package/src/icons/sidebar/users-icon.vue +46 -46
  111. package/src/icons/sidebar/videosources-icon.vue +19 -19
  112. package/src/icons/sidebar/videowall-icon.vue +13 -13
  113. package/src/icons/sidebar/videozones-icon.vue +21 -21
  114. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  115. package/src/icons/sidebar/workshop-icon.vue +100 -100
  116. package/src/icons/sidebar/workzones-icon.vue +22 -22
  117. package/src/icons/task/attention-icon.vue +13 -13
  118. package/src/icons/task/clock-icon.vue +10 -10
  119. package/src/icons/task/delete-icon.vue +10 -10
  120. package/src/icons/task/fire-icon.vue +16 -16
  121. package/src/index.ts +123 -123
  122. package/src/main.ts +28 -28
  123. package/src/quasar-user-options.ts +17 -17
  124. package/src/router/index.ts +10 -10
  125. package/src/shared/styles/general.css +124 -124
  126. package/src/shims-vue.d.ts +5 -5
  127. package/src/styles/variables.sass +12 -12
  128. package/src/utils/confirm.ts +12 -12
  129. package/src/utils/faceApiHelper.ts +132 -132
  130. package/src/utils/helpers.ts +59 -59
  131. package/src/utils/notification.ts +9 -9
@@ -1,246 +1,246 @@
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
- min-width: 976px;
110
-
111
- &-spinner {
112
- position: absolute;
113
- top: 50%;
114
- left: 50%;
115
- z-index: 4;
116
- }
117
- }
118
-
119
- .wrapper {
120
- display: flex;
121
- overflow: hidden;
122
- font-family: 'NunitoSansFont', sans-serif;
123
- color: #3f414d;
124
- max-width: unset;
125
- }
126
-
127
- .sidebar {
128
- max-width: 25vw;
129
- flex: none;
130
- padding: 2rem 0 2rem 2rem;
131
- background-color: #f4f9fd;
132
-
133
- &.noTitle {
134
- padding: 0 0 2rem 2rem;
135
- }
136
-
137
- h5 {
138
- font-size: 24px;
139
- font-weight: 700;
140
- padding-right: 2rem;
141
- }
142
-
143
- .tabs {
144
- color: #b9c0c7;
145
- transition-duration: 0.1s;
146
- margin: 16px 0;
147
- }
148
-
149
- .active-tab {
150
- color: #3f8cff;
151
- }
152
- }
153
-
154
- .content {
155
- background-color: #fff;
156
- height: 100vh;
157
- width: 100%;
158
- display: grid;
159
- grid-template-rows: auto 1fr auto;
160
-
161
- &-header {
162
- display: flex;
163
- justify-content: space-between;
164
- align-items: center;
165
- padding: 4px 1rem;
166
- border-bottom: 1px solid var(--g-grey-100);
167
- overflow: hidden;
168
-
169
- h2 {
170
- font-size: 32px;
171
- font-weight: 700;
172
- }
173
- }
174
- }
175
-
176
- .app-sheet-actions {
177
- display: flex;
178
- gap: 1rem;
179
- padding: 1rem;
180
- border-top: 1px solid var(--g-grey-100);
181
- }
182
- </style>
183
-
184
- <style lang="scss" module>
185
- .sheet-dialog {
186
- :global(.q-dialog__inner) {
187
- max-width: 95vw;
188
- }
189
-
190
- :global(.q-dialog__inner--minimized) {
191
- padding: 0;
192
- }
193
- }
194
-
195
- .tab {
196
- padding: 0 !important;
197
-
198
- :global(.q-focus-helper) {
199
- display: none !important;
200
- }
201
- :global(.q-ripple) {
202
- display: none !important;
203
- }
204
- :global(.q-tab__content) {
205
- width: 100%;
206
- justify-content: left;
207
- margin: 10px 0;
208
- padding-right: 2rem;
209
-
210
- :global(.q-tab__label) {
211
- font-size: 18px;
212
- font-family: NunitoSansFont, sans-serif;
213
- }
214
- :global(.q-tab__icon) {
215
- font-size: 33px;
216
- width: 33px;
217
- height: 33px;
218
- }
219
-
220
- &::after {
221
- content: '';
222
- position: absolute;
223
- bottom: -23px;
224
- left: 15px;
225
- height: 26px;
226
- border: 1px solid #b9c0c7;
227
- }
228
- }
229
- }
230
-
231
- .tab:last-child {
232
- :global(.q-tab__content) {
233
- &::after {
234
- display: none;
235
- }
236
- }
237
- }
238
- </style>
239
-
240
- <style lang="scss">
241
- .app-sheet-actions {
242
- button {
243
- border-radius: 8px;
244
- }
245
- }
246
- </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
+ min-width: 976px;
110
+
111
+ &-spinner {
112
+ position: absolute;
113
+ top: 50%;
114
+ left: 50%;
115
+ z-index: 4;
116
+ }
117
+ }
118
+
119
+ .wrapper {
120
+ display: flex;
121
+ overflow: hidden;
122
+ font-family: 'NunitoSansFont', sans-serif;
123
+ color: #3f414d;
124
+ max-width: unset;
125
+ }
126
+
127
+ .sidebar {
128
+ max-width: 25vw;
129
+ flex: none;
130
+ padding: 2rem 0 2rem 2rem;
131
+ background-color: #f4f9fd;
132
+
133
+ &.noTitle {
134
+ padding: 0 0 2rem 2rem;
135
+ }
136
+
137
+ h5 {
138
+ font-size: 24px;
139
+ font-weight: 700;
140
+ padding-right: 2rem;
141
+ }
142
+
143
+ .tabs {
144
+ color: #b9c0c7;
145
+ transition-duration: 0.1s;
146
+ margin: 16px 0;
147
+ }
148
+
149
+ .active-tab {
150
+ color: #3f8cff;
151
+ }
152
+ }
153
+
154
+ .content {
155
+ background-color: #fff;
156
+ height: 100vh;
157
+ width: 100%;
158
+ display: grid;
159
+ grid-template-rows: auto 1fr auto;
160
+
161
+ &-header {
162
+ display: flex;
163
+ justify-content: space-between;
164
+ align-items: center;
165
+ padding: 4px 1rem;
166
+ border-bottom: 1px solid var(--g-grey-100);
167
+ overflow: hidden;
168
+
169
+ h2 {
170
+ font-size: 32px;
171
+ font-weight: 700;
172
+ }
173
+ }
174
+ }
175
+
176
+ .app-sheet-actions {
177
+ display: flex;
178
+ gap: 1rem;
179
+ padding: 1rem;
180
+ border-top: 1px solid var(--g-grey-100);
181
+ }
182
+ </style>
183
+
184
+ <style lang="scss" module>
185
+ .sheet-dialog {
186
+ :global(.q-dialog__inner) {
187
+ max-width: 95vw;
188
+ }
189
+
190
+ :global(.q-dialog__inner--minimized) {
191
+ padding: 0;
192
+ }
193
+ }
194
+
195
+ .tab {
196
+ padding: 0 !important;
197
+
198
+ :global(.q-focus-helper) {
199
+ display: none !important;
200
+ }
201
+ :global(.q-ripple) {
202
+ display: none !important;
203
+ }
204
+ :global(.q-tab__content) {
205
+ width: 100%;
206
+ justify-content: left;
207
+ margin: 10px 0;
208
+ padding-right: 2rem;
209
+
210
+ :global(.q-tab__label) {
211
+ font-size: 18px;
212
+ font-family: NunitoSansFont, sans-serif;
213
+ }
214
+ :global(.q-tab__icon) {
215
+ font-size: 33px;
216
+ width: 33px;
217
+ height: 33px;
218
+ }
219
+
220
+ &::after {
221
+ content: '';
222
+ position: absolute;
223
+ bottom: -23px;
224
+ left: 15px;
225
+ height: 26px;
226
+ border: 1px solid #b9c0c7;
227
+ }
228
+ }
229
+ }
230
+
231
+ .tab:last-child {
232
+ :global(.q-tab__content) {
233
+ &::after {
234
+ display: none;
235
+ }
236
+ }
237
+ }
238
+ </style>
239
+
240
+ <style lang="scss">
241
+ .app-sheet-actions {
242
+ button {
243
+ border-radius: 8px;
244
+ }
245
+ }
246
+ </style>