shared-ritm 1.2.137 → 1.2.139

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 (133) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +174 -166
  4. package/dist/shared-ritm.umd.js +38 -38
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/services/RepairsService.d.ts +1 -1
  7. package/dist/types/api/types/Api_Repairs.d.ts +8 -11
  8. package/dist/types/api/types/Api_Tasks.d.ts +1 -1
  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 +92 -92
  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 +83 -83
  22. package/src/api/services/RepairsService.ts +124 -124
  23. package/src/api/services/ScheduleService.ts +69 -69
  24. package/src/api/services/SearchService.ts +22 -22
  25. package/src/api/services/TasksService.ts +145 -145
  26. package/src/api/services/UserService.ts +113 -113
  27. package/src/api/services/VideoService.ts +103 -103
  28. package/src/api/settings/ApiService.ts +124 -124
  29. package/src/api/types/Api_Auth.ts +86 -86
  30. package/src/api/types/Api_Brigades.ts +36 -36
  31. package/src/api/types/Api_Comment.ts +40 -40
  32. package/src/api/types/Api_Controls.ts +111 -111
  33. package/src/api/types/Api_Equipment.ts +3 -3
  34. package/src/api/types/Api_Files.ts +7 -7
  35. package/src/api/types/Api_Instruments.ts +136 -136
  36. package/src/api/types/Api_Modules.ts +21 -21
  37. package/src/api/types/Api_Projects.ts +61 -61
  38. package/src/api/types/Api_Repairs.ts +140 -138
  39. package/src/api/types/Api_Schedule.ts +64 -64
  40. package/src/api/types/Api_Search.ts +79 -79
  41. package/src/api/types/Api_Service.ts +9 -9
  42. package/src/api/types/Api_Tasks.ts +319 -319
  43. package/src/api/types/Api_User.ts +140 -140
  44. package/src/api/types/Api_Video.ts +145 -145
  45. package/src/common/app-button/AppButton.vue +173 -173
  46. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  47. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  48. package/src/common/app-datepicker/AppDatepicker.vue +176 -166
  49. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  50. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  51. package/src/common/app-icon/AppIcon.vue +108 -108
  52. package/src/common/app-input/AppInput.vue +148 -148
  53. package/src/common/app-input-new/AppInputNew.vue +175 -175
  54. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  55. package/src/common/app-layout/AppLayout.vue +84 -84
  56. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  57. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  58. package/src/common/app-loader/index.vue +43 -43
  59. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  60. package/src/common/app-select/AppSelect.vue +157 -157
  61. package/src/common/app-sheet/AppSheet.vue +120 -120
  62. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  63. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  64. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  65. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  66. package/src/common/app-table/AppTable.vue +308 -308
  67. package/src/common/app-table/AppTableLayout.vue +137 -137
  68. package/src/common/app-table/components/ModalSelect.vue +285 -285
  69. package/src/common/app-table/components/TableModal.vue +356 -356
  70. package/src/common/app-table/components/TablePagination.vue +152 -152
  71. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  72. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  73. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  74. package/src/common/app-toggle/AppToggle.vue +24 -24
  75. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  76. package/src/global.d.ts +1 -1
  77. package/src/icons/components/arrow-down-icon.vue +25 -25
  78. package/src/icons/components/arrow-frame-icon.vue +19 -19
  79. package/src/icons/components/arrow-square.vue +22 -22
  80. package/src/icons/components/table-filter-icon.vue +30 -30
  81. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  82. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  83. package/src/icons/header/NotificationIcon.vue +18 -18
  84. package/src/icons/header/PersonIcon.vue +11 -11
  85. package/src/icons/header/SettingIcon.vue +14 -14
  86. package/src/icons/header/flashIcon.vue +24 -24
  87. package/src/icons/header/searchStatusIcon.vue +24 -24
  88. package/src/icons/header/smallCapsIcon.vue +34 -34
  89. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  90. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  91. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  92. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  93. package/src/icons/sidebar/instruments-icon.vue +45 -45
  94. package/src/icons/sidebar/logo-icon.vue +15 -15
  95. package/src/icons/sidebar/logout-icon.vue +13 -13
  96. package/src/icons/sidebar/modules-icon.vue +16 -16
  97. package/src/icons/sidebar/notifications-icon.vue +24 -24
  98. package/src/icons/sidebar/order-icon.vue +44 -44
  99. package/src/icons/sidebar/pass-icon.vue +38 -38
  100. package/src/icons/sidebar/positions-icon.vue +42 -42
  101. package/src/icons/sidebar/preorder-icon.vue +19 -19
  102. package/src/icons/sidebar/projects-icon.vue +31 -31
  103. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  104. package/src/icons/sidebar/repairs-icon.vue +20 -20
  105. package/src/icons/sidebar/roles-icon.vue +26 -26
  106. package/src/icons/sidebar/status-history-icon.vue +24 -24
  107. package/src/icons/sidebar/tasks-icon.vue +28 -28
  108. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  109. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  110. package/src/icons/sidebar/teams-icon.vue +32 -32
  111. package/src/icons/sidebar/user-icon.vue +18 -18
  112. package/src/icons/sidebar/users-icon.vue +46 -46
  113. package/src/icons/sidebar/videosources-icon.vue +19 -19
  114. package/src/icons/sidebar/videowall-icon.vue +13 -13
  115. package/src/icons/sidebar/videozones-icon.vue +21 -21
  116. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  117. package/src/icons/sidebar/workshop-icon.vue +100 -100
  118. package/src/icons/sidebar/workzones-icon.vue +22 -22
  119. package/src/icons/task/attention-icon.vue +13 -13
  120. package/src/icons/task/clock-icon.vue +10 -10
  121. package/src/icons/task/delete-icon.vue +10 -10
  122. package/src/icons/task/fire-icon.vue +16 -16
  123. package/src/index.ts +126 -126
  124. package/src/main.ts +28 -28
  125. package/src/quasar-user-options.ts +17 -17
  126. package/src/router/index.ts +10 -10
  127. package/src/shared/styles/general.css +124 -124
  128. package/src/shims-vue.d.ts +5 -5
  129. package/src/styles/variables.sass +12 -12
  130. package/src/utils/confirm.ts +12 -12
  131. package/src/utils/faceApiHelper.ts +132 -132
  132. package/src/utils/helpers.ts +59 -59
  133. package/src/utils/notification.ts +9 -9
@@ -1,168 +1,168 @@
1
- <template>
2
- <q-drawer
3
- :key="`${drawer}`"
4
- v-model="drawer"
5
- :class="$style.drawer"
6
- :mini="isSidebarMini"
7
- :overlay="!isFixSidebar"
8
- :width="drawerWidth"
9
- :mini-width="drawerMiniWidth"
10
- :breakpoint="960"
11
- show-if-above
12
- @mouseover="toggleSidebarMini(false)"
13
- @mouseout="toggleSidebarMini(true)"
14
- >
15
- <template v-if="isTablet">
16
- <q-item :class="$style['tablet-logo']">
17
- <q-item-section avatar>
18
- <q-btn
19
- round
20
- unelevated
21
- :class="$style['tablet-logo__btn']"
22
- :icon="tabletLogoBtn"
23
- @click="openDrawerIsTablet()"
24
- />
25
- </q-item-section>
26
- <q-item-section :class="$style['logo__text']">РИТМ</q-item-section>
27
- </q-item>
28
- </template>
29
- <template v-else>
30
- <q-item :class="$style.logo">
31
- <q-item-section avatar>
32
- <app-icon name="logo-icon" />
33
- </q-item-section>
34
- <q-item-section :class="$style['logo__text']">РИТМ</q-item-section>
35
- </q-item>
36
- <q-btn
37
- dense
38
- round
39
- unelevated
40
- class="q-mini-drawer-hide"
41
- :class="$style['minify-btn']"
42
- icon="chevron_left"
43
- @click="isFixSidebar = !isFixSidebar"
44
- >
45
- <q-tooltip>Закрепить сайдбар</q-tooltip>
46
- </q-btn>
47
- </template>
48
- <sidebar-menu :main="main" :menu-items="menuItems" :minify="isSidebarMini" :is-route-active="isRouteActive" />
49
- <q-item v-ripple :class="$style['menu-exit']" clickable @click="logout()">
50
- <q-item-section avatar>
51
- <app-icon :name="'logout-icon'" color="white" size="24px" />
52
- </q-item-section>
53
- <q-item-section :class="$style['menu-exit__label']">Выход</q-item-section>
54
- </q-item>
55
- </q-drawer>
56
- </template>
57
-
58
- <script setup lang="ts">
59
- import { computed, defineProps, defineEmits, ref, watch, withDefaults } from 'vue'
60
- import SidebarMenu from './components/SidebarMenu.vue'
61
-
62
- import { useQuasar } from 'quasar'
63
- import AppIcon from '@/common/app-icon/AppIcon.vue'
64
-
65
- interface Props {
66
- isDrawer: boolean
67
- minify?: boolean
68
- menuItems?: any[]
69
- main?: boolean
70
- isRouteActive: (item: any) => boolean
71
- }
72
- const emits = defineEmits(['logout'])
73
- const props = withDefaults(defineProps<Props>(), {
74
- main: false,
75
- menuItems: () => [],
76
- })
77
- const $q = useQuasar()
78
-
79
- const drawer = ref(true)
80
- const isSidebarMini = ref(true)
81
- const isFixSidebar = ref(false)
82
-
83
- const isTablet = computed(() => $q.screen.lt.lg)
84
- const tabletLogoBtn = computed(() => (isSidebarMini.value ? 'menu' : 'close'))
85
- const drawerWidth = computed(() => (isTablet.value ? 250 : 275))
86
- const drawerMiniWidth = computed(() => (isTablet.value ? 47 : 72))
87
-
88
- function toggleSidebarMini(value: boolean): void {
89
- if (!isFixSidebar.value && !isTablet.value) isSidebarMini.value = value
90
- }
91
-
92
- function openDrawerIsTablet() {
93
- isFixSidebar.value = !isFixSidebar.value
94
- isSidebarMini.value = !isSidebarMini.value
95
- }
96
-
97
- function logout(): void {
98
- emits('logout')
99
- }
100
-
101
- watch(
102
- () => isTablet.value,
103
- (value: boolean) => {
104
- isFixSidebar.value = value
105
- },
106
- )
107
- </script>
108
-
109
- <style lang="scss" module>
110
- .drawer {
111
- display: flex;
112
- flex-direction: column;
113
- height: 100vh;
114
- background: linear-gradient(184deg, #0b3f8e 9.62%, #5386d3 59.23%, #5386d3 91.63%);
115
- border-right: 1px solid #e4e6e8;
116
- &::-webkit-scrollbar {
117
- height: 4px;
118
- width: 4px;
119
- }
120
- &::-webkit-scrollbar-thumb {
121
- width: 4px;
122
- height: 4px;
123
- }
124
- }
125
- .logo {
126
- display: flex;
127
- justify-content: center;
128
- margin: 24px 0;
129
- &__text {
130
- color: white;
131
- font-size: 20px;
132
- font-weight: 700;
133
- }
134
- }
135
- .tablet-logo {
136
- border-bottom: 1px solid white;
137
- &__btn {
138
- color: white;
139
- }
140
- }
141
-
142
- .minify-btn {
143
- background: #0b3f8e;
144
- color: white;
145
- position: absolute;
146
- top: 25px;
147
- right: -17px;
148
-
149
- &:global(.--mini) {
150
- :global(.q-icon) {
151
- transform: rotate(180deg);
152
- }
153
- }
154
- }
155
-
156
- .menu-exit {
157
- border-top: 1px solid white;
158
- :global(.q-item__section--avatar) {
159
- min-width: 24px;
160
- }
161
- &__label {
162
- color: #fff;
163
- font-family: 'Nunito Sans', sans-serif;
164
- font-size: 16px;
165
- font-weight: 300;
166
- }
167
- }
168
- </style>
1
+ <template>
2
+ <q-drawer
3
+ :key="`${drawer}`"
4
+ v-model="drawer"
5
+ :class="$style.drawer"
6
+ :mini="isSidebarMini"
7
+ :overlay="!isFixSidebar"
8
+ :width="drawerWidth"
9
+ :mini-width="drawerMiniWidth"
10
+ :breakpoint="960"
11
+ show-if-above
12
+ @mouseover="toggleSidebarMini(false)"
13
+ @mouseout="toggleSidebarMini(true)"
14
+ >
15
+ <template v-if="isTablet">
16
+ <q-item :class="$style['tablet-logo']">
17
+ <q-item-section avatar>
18
+ <q-btn
19
+ round
20
+ unelevated
21
+ :class="$style['tablet-logo__btn']"
22
+ :icon="tabletLogoBtn"
23
+ @click="openDrawerIsTablet()"
24
+ />
25
+ </q-item-section>
26
+ <q-item-section :class="$style['logo__text']">РИТМ</q-item-section>
27
+ </q-item>
28
+ </template>
29
+ <template v-else>
30
+ <q-item :class="$style.logo">
31
+ <q-item-section avatar>
32
+ <app-icon name="logo-icon" />
33
+ </q-item-section>
34
+ <q-item-section :class="$style['logo__text']">РИТМ</q-item-section>
35
+ </q-item>
36
+ <q-btn
37
+ dense
38
+ round
39
+ unelevated
40
+ class="q-mini-drawer-hide"
41
+ :class="$style['minify-btn']"
42
+ icon="chevron_left"
43
+ @click="isFixSidebar = !isFixSidebar"
44
+ >
45
+ <q-tooltip>Закрепить сайдбар</q-tooltip>
46
+ </q-btn>
47
+ </template>
48
+ <sidebar-menu :main="main" :menu-items="menuItems" :minify="isSidebarMini" :is-route-active="isRouteActive" />
49
+ <q-item v-ripple :class="$style['menu-exit']" clickable @click="logout()">
50
+ <q-item-section avatar>
51
+ <app-icon :name="'logout-icon'" color="white" size="24px" />
52
+ </q-item-section>
53
+ <q-item-section :class="$style['menu-exit__label']">Выход</q-item-section>
54
+ </q-item>
55
+ </q-drawer>
56
+ </template>
57
+
58
+ <script setup lang="ts">
59
+ import { computed, defineProps, defineEmits, ref, watch, withDefaults } from 'vue'
60
+ import SidebarMenu from './components/SidebarMenu.vue'
61
+
62
+ import { useQuasar } from 'quasar'
63
+ import AppIcon from '@/common/app-icon/AppIcon.vue'
64
+
65
+ interface Props {
66
+ isDrawer: boolean
67
+ minify?: boolean
68
+ menuItems?: any[]
69
+ main?: boolean
70
+ isRouteActive: (item: any) => boolean
71
+ }
72
+ const emits = defineEmits(['logout'])
73
+ const props = withDefaults(defineProps<Props>(), {
74
+ main: false,
75
+ menuItems: () => [],
76
+ })
77
+ const $q = useQuasar()
78
+
79
+ const drawer = ref(true)
80
+ const isSidebarMini = ref(true)
81
+ const isFixSidebar = ref(false)
82
+
83
+ const isTablet = computed(() => $q.screen.lt.lg)
84
+ const tabletLogoBtn = computed(() => (isSidebarMini.value ? 'menu' : 'close'))
85
+ const drawerWidth = computed(() => (isTablet.value ? 250 : 275))
86
+ const drawerMiniWidth = computed(() => (isTablet.value ? 47 : 72))
87
+
88
+ function toggleSidebarMini(value: boolean): void {
89
+ if (!isFixSidebar.value && !isTablet.value) isSidebarMini.value = value
90
+ }
91
+
92
+ function openDrawerIsTablet() {
93
+ isFixSidebar.value = !isFixSidebar.value
94
+ isSidebarMini.value = !isSidebarMini.value
95
+ }
96
+
97
+ function logout(): void {
98
+ emits('logout')
99
+ }
100
+
101
+ watch(
102
+ () => isTablet.value,
103
+ (value: boolean) => {
104
+ isFixSidebar.value = value
105
+ },
106
+ )
107
+ </script>
108
+
109
+ <style lang="scss" module>
110
+ .drawer {
111
+ display: flex;
112
+ flex-direction: column;
113
+ height: 100vh;
114
+ background: linear-gradient(184deg, #0b3f8e 9.62%, #5386d3 59.23%, #5386d3 91.63%);
115
+ border-right: 1px solid #e4e6e8;
116
+ &::-webkit-scrollbar {
117
+ height: 4px;
118
+ width: 4px;
119
+ }
120
+ &::-webkit-scrollbar-thumb {
121
+ width: 4px;
122
+ height: 4px;
123
+ }
124
+ }
125
+ .logo {
126
+ display: flex;
127
+ justify-content: center;
128
+ margin: 24px 0;
129
+ &__text {
130
+ color: white;
131
+ font-size: 20px;
132
+ font-weight: 700;
133
+ }
134
+ }
135
+ .tablet-logo {
136
+ border-bottom: 1px solid white;
137
+ &__btn {
138
+ color: white;
139
+ }
140
+ }
141
+
142
+ .minify-btn {
143
+ background: #0b3f8e;
144
+ color: white;
145
+ position: absolute;
146
+ top: 25px;
147
+ right: -17px;
148
+
149
+ &:global(.--mini) {
150
+ :global(.q-icon) {
151
+ transform: rotate(180deg);
152
+ }
153
+ }
154
+ }
155
+
156
+ .menu-exit {
157
+ border-top: 1px solid white;
158
+ :global(.q-item__section--avatar) {
159
+ min-width: 24px;
160
+ }
161
+ &__label {
162
+ color: #fff;
163
+ font-family: 'Nunito Sans', sans-serif;
164
+ font-size: 16px;
165
+ font-weight: 300;
166
+ }
167
+ }
168
+ </style>
@@ -1,37 +1,37 @@
1
- <template>
2
- <div :class="$style.wrapper">
3
- <sidebar-menu-item
4
- v-for="(item, index) in menuItems"
5
- :key="index"
6
- :item="item"
7
- :main="main"
8
- :minify="minify"
9
- :is-route-active="isRouteActive"
10
- />
11
- </div>
12
- </template>
13
-
14
- <script lang="ts" setup>
15
- import { defineProps } from 'vue'
16
- import SidebarMenuItem from './SidebarMenuItem.vue'
17
-
18
- interface Props {
19
- menuItems?: any[]
20
- minify?: boolean
21
- main: boolean
22
- isRouteActive: (item: any) => boolean
23
- }
24
-
25
- const props = defineProps<Props>()
26
- </script>
27
-
28
- <style lang="scss" module>
29
- .wrapper {
30
- overflow-y: auto;
31
- overflow-x: hidden;
32
- flex-grow: 1;
33
- :global(.q-item) {
34
- min-height: 54px;
35
- }
36
- }
37
- </style>
1
+ <template>
2
+ <div :class="$style.wrapper">
3
+ <sidebar-menu-item
4
+ v-for="(item, index) in menuItems"
5
+ :key="index"
6
+ :item="item"
7
+ :main="main"
8
+ :minify="minify"
9
+ :is-route-active="isRouteActive"
10
+ />
11
+ </div>
12
+ </template>
13
+
14
+ <script lang="ts" setup>
15
+ import { defineProps } from 'vue'
16
+ import SidebarMenuItem from './SidebarMenuItem.vue'
17
+
18
+ interface Props {
19
+ menuItems?: any[]
20
+ minify?: boolean
21
+ main: boolean
22
+ isRouteActive: (item: any) => boolean
23
+ }
24
+
25
+ const props = defineProps<Props>()
26
+ </script>
27
+
28
+ <style lang="scss" module>
29
+ .wrapper {
30
+ overflow-y: auto;
31
+ overflow-x: hidden;
32
+ flex-grow: 1;
33
+ :global(.q-item) {
34
+ min-height: 54px;
35
+ }
36
+ }
37
+ </style>