shared-ritm 1.3.14 → 1.3.15

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 (136) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +4291 -4257
  4. package/dist/shared-ritm.umd.js +154 -154
  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/settings/ApiService.d.ts +1 -1
  8. package/package.json +65 -65
  9. package/src/App.vue +2461 -2461
  10. package/src/api/services/AuthService.ts +53 -53
  11. package/src/api/services/BrigadesService.ts +32 -32
  12. package/src/api/services/CommentsService.ts +24 -24
  13. package/src/api/services/ControlsService.ts +96 -96
  14. package/src/api/services/EquipmentService.ts +29 -29
  15. package/src/api/services/FileService.ts +17 -17
  16. package/src/api/services/GanttService.ts +17 -17
  17. package/src/api/services/InstrumentsService.ts +68 -68
  18. package/src/api/services/MetricsService.ts +110 -110
  19. package/src/api/services/ModulesService.ts +27 -27
  20. package/src/api/services/ProjectsService.ts +83 -83
  21. package/src/api/services/RepairsService.ts +124 -124
  22. package/src/api/services/ScheduleService.ts +69 -69
  23. package/src/api/services/SearchService.ts +22 -22
  24. package/src/api/services/TasksService.ts +150 -150
  25. package/src/api/services/UserService.ts +119 -119
  26. package/src/api/services/VideoService.ts +108 -108
  27. package/src/api/settings/ApiService.ts +124 -124
  28. package/src/api/types/Api_Auth.ts +105 -105
  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 +111 -111
  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 +156 -156
  35. package/src/api/types/Api_Modules.ts +21 -21
  36. package/src/api/types/Api_Projects.ts +62 -62
  37. package/src/api/types/Api_Repairs.ts +140 -140
  38. package/src/api/types/Api_Schedule.ts +64 -64
  39. package/src/api/types/Api_Search.ts +80 -80
  40. package/src/api/types/Api_Service.ts +9 -9
  41. package/src/api/types/Api_Tasks.ts +371 -371
  42. package/src/api/types/Api_User.ts +146 -146
  43. package/src/api/types/Api_Video.ts +198 -198
  44. package/src/common/app-button/AppButton.vue +173 -173
  45. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  46. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  47. package/src/common/app-datepicker/AppDatepicker.vue +218 -218
  48. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  49. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  50. package/src/common/app-file/AppFile.vue +80 -80
  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 +179 -179
  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-modal/index.vue +96 -96
  60. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  61. package/src/common/app-select/AppSelect.vue +157 -157
  62. package/src/common/app-sheet/AppSheet.vue +120 -120
  63. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  64. package/src/common/app-sidebar/AppSidebar.vue +174 -168
  65. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  66. package/src/common/app-sidebar/components/SidebarMenuItem.vue +149 -149
  67. package/src/common/app-table/AppTable.vue +308 -308
  68. package/src/common/app-table/AppTableLayout.vue +137 -137
  69. package/src/common/app-table/components/ModalSelect.vue +294 -294
  70. package/src/common/app-table/components/TableModal.vue +356 -356
  71. package/src/common/app-table/components/TablePagination.vue +152 -152
  72. package/src/common/app-table/components/TableSearch.vue +76 -76
  73. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  74. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  75. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  76. package/src/common/app-toggle/AppToggle.vue +24 -24
  77. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  78. package/src/global.d.ts +1 -1
  79. package/src/icons/components/arrow-down-icon.vue +25 -25
  80. package/src/icons/components/arrow-frame-icon.vue +19 -19
  81. package/src/icons/components/arrow-square.vue +22 -22
  82. package/src/icons/components/table-filter-icon.vue +30 -30
  83. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  84. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  85. package/src/icons/header/NotificationIcon.vue +18 -18
  86. package/src/icons/header/PersonIcon.vue +11 -11
  87. package/src/icons/header/SettingIcon.vue +14 -14
  88. package/src/icons/header/flashIcon.vue +24 -24
  89. package/src/icons/header/searchStatusIcon.vue +24 -24
  90. package/src/icons/header/smallCapsIcon.vue +34 -34
  91. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  92. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  93. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  94. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  95. package/src/icons/sidebar/instruments-icon.vue +45 -45
  96. package/src/icons/sidebar/logo-icon.vue +15 -15
  97. package/src/icons/sidebar/logout-icon.vue +13 -13
  98. package/src/icons/sidebar/modules-icon.vue +16 -16
  99. package/src/icons/sidebar/notifications-icon.vue +24 -24
  100. package/src/icons/sidebar/order-icon.vue +44 -44
  101. package/src/icons/sidebar/pass-icon.vue +38 -38
  102. package/src/icons/sidebar/positions-icon.vue +42 -42
  103. package/src/icons/sidebar/preorder-icon.vue +19 -19
  104. package/src/icons/sidebar/projects-icon.vue +31 -31
  105. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  106. package/src/icons/sidebar/repairs-icon.vue +20 -20
  107. package/src/icons/sidebar/roles-icon.vue +26 -26
  108. package/src/icons/sidebar/status-history-icon.vue +24 -24
  109. package/src/icons/sidebar/tasks-icon.vue +28 -28
  110. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  111. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  112. package/src/icons/sidebar/teams-icon.vue +32 -32
  113. package/src/icons/sidebar/user-icon.vue +18 -18
  114. package/src/icons/sidebar/users-icon.vue +46 -46
  115. package/src/icons/sidebar/videosources-icon.vue +19 -19
  116. package/src/icons/sidebar/videowall-icon.vue +13 -13
  117. package/src/icons/sidebar/videozones-icon.vue +21 -21
  118. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  119. package/src/icons/sidebar/workshop-icon.vue +100 -100
  120. package/src/icons/sidebar/workzones-icon.vue +22 -22
  121. package/src/icons/task/attention-icon.vue +13 -13
  122. package/src/icons/task/clock-icon.vue +10 -10
  123. package/src/icons/task/delete-icon.vue +10 -10
  124. package/src/icons/task/fire-icon.vue +16 -16
  125. package/src/index.ts +131 -131
  126. package/src/main.ts +28 -28
  127. package/src/quasar-user-options.ts +17 -17
  128. package/src/router/index.ts +10 -10
  129. package/src/shared/styles/general.css +124 -124
  130. package/src/shims-vue.d.ts +5 -5
  131. package/src/styles/variables.sass +12 -12
  132. package/src/utils/confirm.ts +12 -12
  133. package/src/utils/faceApiHelper.ts +132 -132
  134. package/src/utils/files.ts +19 -19
  135. package/src/utils/helpers.ts +59 -59
  136. package/src/utils/notification.ts +9 -9
@@ -1,96 +1,96 @@
1
- <template>
2
- <q-dialog v-model="model">
3
- <q-card class="modal" :style="{ width, 'max-width': width || 'unset', maxHeight: maxHeight || '600px' }">
4
- <q-card-section class="section">
5
- <div v-if="title" class="title">{{ title }}</div>
6
-
7
- <slot />
8
-
9
- <div v-if="loading" class="loader-overlay">
10
- <q-spinner-audio class="loader-spinner" size="md" :thickness="3" color="primary" />
11
- </div>
12
- </q-card-section>
13
-
14
- <q-card-actions align="center" class="btn__wrapper">
15
- <slot name="actions" />
16
- </q-card-actions>
17
- </q-card>
18
- </q-dialog>
19
- </template>
20
-
21
- <script setup lang="ts">
22
- import { defineProps, defineEmits, defineModel } from 'vue'
23
-
24
- type Props = {
25
- modelValue?: boolean
26
- title?: string
27
- width?: string
28
- loading?: boolean
29
- maxHeight?: string
30
- }
31
-
32
- defineProps<Props>()
33
-
34
- const emit = defineEmits(['update:modelValue'])
35
-
36
- const model = defineModel<boolean>()
37
- </script>
38
-
39
- <style scoped lang="scss">
40
- .modal {
41
- display: grid;
42
- border-radius: 0.5rem;
43
- grid-template-rows: 1fr auto;
44
- font-family: NunitoSansFont, sans-serif;
45
- color: #1d425d;
46
- overflow: hidden;
47
-
48
- .section {
49
- position: relative;
50
- display: grid;
51
- grid-template-rows: auto 1fr;
52
- justify-items: center;
53
- gap: 0.5rem;
54
- background-color: white;
55
- overflow: auto;
56
-
57
- .loader-overlay {
58
- width: 100%;
59
- height: 100%;
60
- position: absolute;
61
- inset: 0;
62
- z-index: 10;
63
- background: rgba(255, 255, 255, 0.8);
64
- display: flex;
65
- align-items: center;
66
- justify-content: center;
67
- }
68
- .loader-spinner {
69
- z-index: 11;
70
- }
71
- }
72
-
73
- .title {
74
- font-size: 32px;
75
- font-weight: 700;
76
- }
77
-
78
- .btn__wrapper {
79
- width: 100%;
80
- background-color: var(--light-blue);
81
- padding: 1rem;
82
- }
83
- }
84
- </style>
85
-
86
- <style lang="scss">
87
- .modal {
88
- .btn__wrapper {
89
- button {
90
- padding: 13px 37px;
91
- border-radius: 4px;
92
- color: var(--action-text-color);
93
- }
94
- }
95
- }
96
- </style>
1
+ <template>
2
+ <q-dialog v-model="model">
3
+ <q-card class="modal" :style="{ width, 'max-width': width || 'unset', maxHeight: maxHeight || '600px' }">
4
+ <q-card-section class="section">
5
+ <div v-if="title" class="title">{{ title }}</div>
6
+
7
+ <slot />
8
+
9
+ <div v-if="loading" class="loader-overlay">
10
+ <q-spinner-audio class="loader-spinner" size="md" :thickness="3" color="primary" />
11
+ </div>
12
+ </q-card-section>
13
+
14
+ <q-card-actions align="center" class="btn__wrapper">
15
+ <slot name="actions" />
16
+ </q-card-actions>
17
+ </q-card>
18
+ </q-dialog>
19
+ </template>
20
+
21
+ <script setup lang="ts">
22
+ import { defineProps, defineEmits, defineModel } from 'vue'
23
+
24
+ type Props = {
25
+ modelValue?: boolean
26
+ title?: string
27
+ width?: string
28
+ loading?: boolean
29
+ maxHeight?: string
30
+ }
31
+
32
+ defineProps<Props>()
33
+
34
+ const emit = defineEmits(['update:modelValue'])
35
+
36
+ const model = defineModel<boolean>()
37
+ </script>
38
+
39
+ <style scoped lang="scss">
40
+ .modal {
41
+ display: grid;
42
+ border-radius: 0.5rem;
43
+ grid-template-rows: 1fr auto;
44
+ font-family: NunitoSansFont, sans-serif;
45
+ color: #1d425d;
46
+ overflow: hidden;
47
+
48
+ .section {
49
+ position: relative;
50
+ display: grid;
51
+ grid-template-rows: auto 1fr;
52
+ justify-items: center;
53
+ gap: 0.5rem;
54
+ background-color: white;
55
+ overflow: auto;
56
+
57
+ .loader-overlay {
58
+ width: 100%;
59
+ height: 100%;
60
+ position: absolute;
61
+ inset: 0;
62
+ z-index: 10;
63
+ background: rgba(255, 255, 255, 0.8);
64
+ display: flex;
65
+ align-items: center;
66
+ justify-content: center;
67
+ }
68
+ .loader-spinner {
69
+ z-index: 11;
70
+ }
71
+ }
72
+
73
+ .title {
74
+ font-size: 32px;
75
+ font-weight: 700;
76
+ }
77
+
78
+ .btn__wrapper {
79
+ width: 100%;
80
+ background-color: var(--light-blue);
81
+ padding: 1rem;
82
+ }
83
+ }
84
+ </style>
85
+
86
+ <style lang="scss">
87
+ .modal {
88
+ .btn__wrapper {
89
+ button {
90
+ padding: 13px 37px;
91
+ border-radius: 4px;
92
+ color: var(--action-text-color);
93
+ }
94
+ }
95
+ }
96
+ </style>
@@ -1,122 +1,122 @@
1
- <template lang="pug">
2
- q-page#content(:class="$style['page-container']")
3
- q-toolbar(:class="$style['toolbar']")
4
- q-toolbar-title(:class="$style.title") {{ title }}
5
- div(:class="$style['action-buttons']")
6
- app-button(
7
- rounded
8
- :class="$style['button-new']"
9
- :label="'Новый ремонт'"
10
- @click="emits('create-repair')"
11
- color="#fff"
12
- icon="add"
13
- )
14
- app-button(rounded :class="$style['button-video-wall']" @click="emits('routing-to-video-wall')")
15
- video-wall-icon
16
- span Видеостена
17
- app-button(rounded :class="$style.button" @click="openFullScreenWidgets")
18
- q-tooltip на весь экран
19
- q-icon(name="open_in_full")
20
- //app-button(rounded :class="$style.button")
21
- // graph-icon
22
- //app-button(rounded :class="$style.button")
23
- // time-line-icon
24
- slot
25
- </template>
26
-
27
- <script setup lang="ts">
28
- import { defineProps, defineEmits, defineAsyncComponent } from 'vue'
29
- import AppButton from '@/common/app-button/AppButton.vue'
30
- import { useQuasar } from 'quasar'
31
- import VideoWallIcon from '@/icons/page-header/videoWallIcon.vue'
32
-
33
- const $q = useQuasar()
34
-
35
- const FullScreenDialog = defineAsyncComponent(() => import('@/components/dialogs/full-screen-widgets/index.vue'))
36
- // import GraphIcon from '@/icons/page-header/graphIcon.vue'
37
- // import TimeLineIcon from '@/icons/page-header/timeLineIcon.vue'
38
- interface Props {
39
- title: string
40
- }
41
- const props = defineProps<Props>()
42
- const emits = defineEmits(['create-repair', ''])
43
-
44
- const openFullScreenWidgets = () => {
45
- $q.dialog({
46
- component: FullScreenDialog,
47
- })
48
- }
49
- </script>
50
- <style module lang="scss">
51
- .toolbar {
52
- padding: 0;
53
- margin-top: 16px;
54
- }
55
- .page-container {
56
- padding: 0 4px 0 0;
57
- max-width: 1300px;
58
- margin: 0 auto;
59
- max-height: 600px;
60
- overflow: auto;
61
- &::-webkit-scrollbar-thumb {
62
- height: 88px;
63
- background-color: #d3dbeb;
64
- border-radius: 6px;
65
- }
66
- }
67
- .button {
68
- padding: 12px;
69
- background: white;
70
- }
71
-
72
- .button-new {
73
- padding: 12px 18px;
74
- background: #3f8cff;
75
- }
76
- .button-video-wall {
77
- padding: 10px 18px;
78
- background: white;
79
- span {
80
- color: #3f8cff;
81
- margin-left: 8px;
82
- font-size: 16px;
83
- font-weight: 700;
84
- }
85
- }
86
- .title {
87
- color: #fff;
88
- font-family: Montserrat, sans-serif;
89
- font-size: 32px;
90
- font-style: normal;
91
- font-weight: 700;
92
- line-height: normal;
93
- }
94
-
95
- .action-buttons {
96
- position: relative;
97
- display: flex;
98
- align-items: center;
99
- column-gap: 16px;
100
- }
101
-
102
- @media (max-width: 1440px) {
103
- .page-container {
104
- max-width: 874px;
105
- }
106
- .action-buttons {
107
- column-gap: 8px;
108
- }
109
- .title {
110
- font-size: 24px;
111
- line-height: normal;
112
- }
113
- .button {
114
- padding: 10px;
115
- background: white;
116
- }
117
- .button-new {
118
- padding: 10px 12px;
119
- background: #3f8cff;
120
- }
121
- }
122
- </style>
1
+ <template lang="pug">
2
+ q-page#content(:class="$style['page-container']")
3
+ q-toolbar(:class="$style['toolbar']")
4
+ q-toolbar-title(:class="$style.title") {{ title }}
5
+ div(:class="$style['action-buttons']")
6
+ app-button(
7
+ rounded
8
+ :class="$style['button-new']"
9
+ :label="'Новый ремонт'"
10
+ @click="emits('create-repair')"
11
+ color="#fff"
12
+ icon="add"
13
+ )
14
+ app-button(rounded :class="$style['button-video-wall']" @click="emits('routing-to-video-wall')")
15
+ video-wall-icon
16
+ span Видеостена
17
+ app-button(rounded :class="$style.button" @click="openFullScreenWidgets")
18
+ q-tooltip на весь экран
19
+ q-icon(name="open_in_full")
20
+ //app-button(rounded :class="$style.button")
21
+ // graph-icon
22
+ //app-button(rounded :class="$style.button")
23
+ // time-line-icon
24
+ slot
25
+ </template>
26
+
27
+ <script setup lang="ts">
28
+ import { defineProps, defineEmits, defineAsyncComponent } from 'vue'
29
+ import AppButton from '@/common/app-button/AppButton.vue'
30
+ import { useQuasar } from 'quasar'
31
+ import VideoWallIcon from '@/icons/page-header/videoWallIcon.vue'
32
+
33
+ const $q = useQuasar()
34
+
35
+ const FullScreenDialog = defineAsyncComponent(() => import('@/components/dialogs/full-screen-widgets/index.vue'))
36
+ // import GraphIcon from '@/icons/page-header/graphIcon.vue'
37
+ // import TimeLineIcon from '@/icons/page-header/timeLineIcon.vue'
38
+ interface Props {
39
+ title: string
40
+ }
41
+ const props = defineProps<Props>()
42
+ const emits = defineEmits(['create-repair', ''])
43
+
44
+ const openFullScreenWidgets = () => {
45
+ $q.dialog({
46
+ component: FullScreenDialog,
47
+ })
48
+ }
49
+ </script>
50
+ <style module lang="scss">
51
+ .toolbar {
52
+ padding: 0;
53
+ margin-top: 16px;
54
+ }
55
+ .page-container {
56
+ padding: 0 4px 0 0;
57
+ max-width: 1300px;
58
+ margin: 0 auto;
59
+ max-height: 600px;
60
+ overflow: auto;
61
+ &::-webkit-scrollbar-thumb {
62
+ height: 88px;
63
+ background-color: #d3dbeb;
64
+ border-radius: 6px;
65
+ }
66
+ }
67
+ .button {
68
+ padding: 12px;
69
+ background: white;
70
+ }
71
+
72
+ .button-new {
73
+ padding: 12px 18px;
74
+ background: #3f8cff;
75
+ }
76
+ .button-video-wall {
77
+ padding: 10px 18px;
78
+ background: white;
79
+ span {
80
+ color: #3f8cff;
81
+ margin-left: 8px;
82
+ font-size: 16px;
83
+ font-weight: 700;
84
+ }
85
+ }
86
+ .title {
87
+ color: #fff;
88
+ font-family: Montserrat, sans-serif;
89
+ font-size: 32px;
90
+ font-style: normal;
91
+ font-weight: 700;
92
+ line-height: normal;
93
+ }
94
+
95
+ .action-buttons {
96
+ position: relative;
97
+ display: flex;
98
+ align-items: center;
99
+ column-gap: 16px;
100
+ }
101
+
102
+ @media (max-width: 1440px) {
103
+ .page-container {
104
+ max-width: 874px;
105
+ }
106
+ .action-buttons {
107
+ column-gap: 8px;
108
+ }
109
+ .title {
110
+ font-size: 24px;
111
+ line-height: normal;
112
+ }
113
+ .button {
114
+ padding: 10px;
115
+ background: white;
116
+ }
117
+ .button-new {
118
+ padding: 10px 12px;
119
+ background: #3f8cff;
120
+ }
121
+ }
122
+ </style>