shared-ritm 1.2.97 → 1.2.99

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 (119) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +2051 -2054
  4. package/dist/shared-ritm.umd.js +25 -25
  5. package/dist/types/api/services/UserService.d.ts +7 -0
  6. package/dist/types/api/services/VideoService.d.ts +0 -14
  7. package/dist/types/api/types/Api_Tasks.d.ts +1 -1
  8. package/dist/types/index.d.ts +0 -1
  9. package/package.json +1 -1
  10. package/src/App.vue +2461 -2461
  11. package/src/api/services/AuthService.ts +64 -64
  12. package/src/api/services/CommentsService.ts +24 -24
  13. package/src/api/services/ControlsService.ts +65 -65
  14. package/src/api/services/FileService.ts +17 -17
  15. package/src/api/services/GanttService.ts +17 -17
  16. package/src/api/services/MetricsService.ts +110 -110
  17. package/src/api/services/ProjectsService.ts +68 -68
  18. package/src/api/services/RepairsService.ts +119 -119
  19. package/src/api/services/SearchService.ts +16 -16
  20. package/src/api/services/TasksService.ts +145 -145
  21. package/src/api/services/UserService.ts +101 -87
  22. package/src/api/services/VideoService.ts +0 -19
  23. package/src/api/types/Api_Comment.ts +40 -40
  24. package/src/api/types/Api_Controls.ts +72 -72
  25. package/src/api/types/Api_Files.ts +7 -7
  26. package/src/api/types/Api_Projects.ts +55 -55
  27. package/src/api/types/Api_Repairs.ts +115 -115
  28. package/src/api/types/Api_Search.ts +48 -48
  29. package/src/api/types/Api_Service.ts +9 -9
  30. package/src/api/types/Api_Tasks.ts +315 -315
  31. package/src/common/app-button/AppButton.vue +173 -173
  32. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  33. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  34. package/src/common/app-datepicker/AppDatepicker.vue +165 -165
  35. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  36. package/src/common/app-dropdown/AppDropdown.vue +31 -31
  37. package/src/common/app-icon/AppIcon.vue +108 -108
  38. package/src/common/app-input/AppInput.vue +148 -148
  39. package/src/common/app-input-new/AppInputNew.vue +152 -152
  40. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  41. package/src/common/app-layout/AppLayout.vue +84 -84
  42. package/src/common/app-layout/components/AppLayoutHeader.vue +1 -0
  43. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  44. package/src/common/app-loader/index.vue +43 -43
  45. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  46. package/src/common/app-select/AppSelect.vue +157 -157
  47. package/src/common/app-sheet/AppSheet.vue +120 -120
  48. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  49. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  50. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  51. package/src/common/app-table/AppTable.vue +1 -8
  52. package/src/common/app-table/AppTableLayout.vue +4 -5
  53. package/src/common/app-table/components/TablePagination.vue +152 -152
  54. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  55. package/src/common/app-table/controllers/useTableModel.ts +93 -93
  56. package/src/common/app-toggle/AppToggle.vue +24 -24
  57. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  58. package/src/global.d.ts +1 -1
  59. package/src/icons/components/arrow-down-icon.vue +25 -25
  60. package/src/icons/components/arrow-frame-icon.vue +19 -19
  61. package/src/icons/components/arrow-square.vue +22 -22
  62. package/src/icons/components/table-filter-icon.vue +30 -30
  63. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  64. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  65. package/src/icons/header/NotificationIcon.vue +18 -18
  66. package/src/icons/header/PersonIcon.vue +11 -11
  67. package/src/icons/header/SettingIcon.vue +14 -14
  68. package/src/icons/header/flashIcon.vue +24 -24
  69. package/src/icons/header/searchStatusIcon.vue +24 -24
  70. package/src/icons/header/smallCapsIcon.vue +34 -34
  71. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  72. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  73. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  74. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  75. package/src/icons/sidebar/instruments-icon.vue +45 -45
  76. package/src/icons/sidebar/logo-icon.vue +15 -15
  77. package/src/icons/sidebar/logout-icon.vue +13 -13
  78. package/src/icons/sidebar/modules-icon.vue +16 -16
  79. package/src/icons/sidebar/notifications-icon.vue +24 -24
  80. package/src/icons/sidebar/order-icon.vue +44 -44
  81. package/src/icons/sidebar/pass-icon.vue +38 -38
  82. package/src/icons/sidebar/positions-icon.vue +42 -42
  83. package/src/icons/sidebar/preorder-icon.vue +19 -19
  84. package/src/icons/sidebar/projects-icon.vue +31 -31
  85. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  86. package/src/icons/sidebar/repairs-icon.vue +20 -20
  87. package/src/icons/sidebar/roles-icon.vue +26 -26
  88. package/src/icons/sidebar/status-history-icon.vue +24 -24
  89. package/src/icons/sidebar/tasks-icon.vue +28 -28
  90. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  91. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  92. package/src/icons/sidebar/teams-icon.vue +32 -32
  93. package/src/icons/sidebar/user-icon.vue +18 -18
  94. package/src/icons/sidebar/users-icon.vue +46 -46
  95. package/src/icons/sidebar/videosources-icon.vue +19 -19
  96. package/src/icons/sidebar/videowall-icon.vue +13 -13
  97. package/src/icons/sidebar/videozones-icon.vue +21 -21
  98. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  99. package/src/icons/sidebar/workshop-icon.vue +100 -100
  100. package/src/icons/sidebar/workzones-icon.vue +22 -22
  101. package/src/icons/task/attention-icon.vue +13 -13
  102. package/src/icons/task/clock-icon.vue +10 -10
  103. package/src/icons/task/delete-icon.vue +10 -10
  104. package/src/icons/task/fire-icon.vue +16 -16
  105. package/src/index.ts +0 -1
  106. package/src/main.ts +28 -28
  107. package/src/quasar-user-options.ts +17 -17
  108. package/src/router/index.ts +10 -10
  109. package/src/shared/styles/general.css +124 -124
  110. package/src/shims-vue.d.ts +5 -5
  111. package/src/utils/confirm.ts +12 -12
  112. package/src/utils/faceApiHelper.ts +137 -137
  113. package/src/utils/helpers.ts +59 -59
  114. package/src/utils/notification.ts +9 -9
  115. package/dist/types/api/services/ComentsServise.d.ts +0 -10
  116. package/dist/types/api/services/PhotoService.d.ts +0 -53
  117. package/dist/types/api/types/Api_Users.d.ts +0 -43
  118. package/dist/types/api/types/Api_Video.d.ts +0 -87
  119. package/src/api/types/Api_Video.ts +0 -90
@@ -1,145 +1,145 @@
1
- import ApiService from '../settings/ApiService'
2
- import { ResponseApi } from '../types/Api_Service'
3
- import {
4
- Api_Task_Close_Reason,
5
- Api_Task_Instrument_Dto,
6
- Api_Task_Instrument_From_Warehouse,
7
- Api_Task_Module_Instrument_Condition,
8
- Api_Task_Dto,
9
- Api_Tasks_Task_Dto,
10
- Api_Task_ChangeStatusVerification_Dto,
11
- Api_QualityMetric_Request_Dto,
12
- Api_Tasks_Task_Edit_Request_Dto,
13
- Api_Tasks_ReplaceInstrument_Request_Dto,
14
- Api_Tasks_AllPersonalUser_Dto,
15
- Api_Tasks_InstrumentHistory_Item_Dto,
16
- } from '../types/Api_Tasks'
17
- import { Api_Equipment_Full_Dto, Api_Task_Video_Source, Api_Task_Video_Source_Stream } from '../types/Api_Repairs'
18
-
19
- export type EquipmentData = {
20
- id: string
21
- model: unknown
22
- name: string
23
- registration_number: string
24
- repair_frequency: unknown
25
- repair_range: number
26
- }
27
-
28
- class TasksService extends ApiService {
29
- public fetchTaskById(id: string): Promise<Api_Tasks_Task_Dto> {
30
- return this.get<Api_Tasks_Task_Dto>(`/tasks/${id}`)
31
- }
32
-
33
- public fetchTasksList(params: any): Promise<ResponseApi<Api_Task_Dto[]>> {
34
- return this.get<ResponseApi<Api_Task_Dto[]>>('/list/tasks/search', { params })
35
- }
36
-
37
- public fetchSubtasksList(id: string): Promise<Api_Task_Dto[]> {
38
- return this.get<Api_Task_Dto[]>(`/task/${id}/subtasks/list`)
39
- }
40
-
41
- public fetchTaskBranch(id: string): Promise<ResponseApi<any>> {
42
- return this.get(`/get_list_task_branch?task_id=${id}`)
43
- }
44
-
45
- public fetchInstrumentsList(params: any): Promise<ResponseApi<any[]>> {
46
- return this.get('admin/instruments', { params })
47
- }
48
-
49
- public fetchInstrumentTypeListWithPreparedWarehouse(params: {
50
- page: number
51
- per_page: number
52
- 'filterList[taskId]'?: string | undefined
53
- search?: string
54
- }): Promise<ResponseApi<Api_Task_Instrument_From_Warehouse[]>> {
55
- return this.get('/instrument_type/get_instrument_type_list_with_prepared_warehouse', { params })
56
- }
57
-
58
- public fetchInstrumentsEquivalentList(params: any): Promise<ResponseApi<Api_Task_Instrument_Dto[]>> {
59
- return this.get<ResponseApi<Api_Task_Instrument_Dto[]>>('tasks/instrument/list', { params })
60
- }
61
-
62
- public fetchDiffInstruments(params: any): Promise<ResponseApi<Api_Task_Module_Instrument_Condition>> {
63
- return this.get<ResponseApi<Api_Task_Module_Instrument_Condition>>(`tasks/${params.taskId}/fill/module`, {
64
- params,
65
- })
66
- }
67
-
68
- public replaceInstruments(payload: Api_Tasks_ReplaceInstrument_Request_Dto[]): Promise<ResponseApi<any[]>> {
69
- return this.post<Api_Tasks_ReplaceInstrument_Request_Dto[], ResponseApi<any[]>>(
70
- `/instruments/equivalent/attach`,
71
- payload,
72
- )
73
- }
74
-
75
- public fetchTaskUsagePersonal(task_id: string): Promise<Api_Tasks_AllPersonalUser_Dto> {
76
- return this.get<Api_Tasks_AllPersonalUser_Dto>(`tasks/${task_id}/usage/users`)
77
- }
78
-
79
- public fetchTaskUsageInstrument(task_id: string): Promise<Api_Tasks_InstrumentHistory_Item_Dto[]> {
80
- return this.get<Api_Tasks_InstrumentHistory_Item_Dto[]>(`tasks/${task_id}/usage/instruments`)
81
- }
82
-
83
- public fetchEquipment(params: any): Promise<ResponseApi<Api_Equipment_Full_Dto[]>> {
84
- return this.get<ResponseApi<Api_Equipment_Full_Dto[]>>('repairs/equipment/list', { params })
85
- }
86
-
87
- public fetchTaskVideoSources(params: any): Promise<ResponseApi<Api_Task_Video_Source[]>> {
88
- return this.get<ResponseApi<Api_Task_Video_Source[]>>('work_zone/get_list_video_source', { params })
89
- }
90
-
91
- public fetchTaskVideoSourcesStream(params: any): Promise<ResponseApi<Api_Task_Video_Source_Stream[]>> {
92
- return this.get<ResponseApi<Api_Task_Video_Source_Stream[]>>('horizon/video-source', { params })
93
- }
94
-
95
- public createWorkZone(payload: any): Promise<unknown> {
96
- return this.post('admin/work-zones', payload)
97
- }
98
-
99
- public createTask(payload: any): Promise<ResponseApi<any>> {
100
- return this.post(`tasks`, payload)
101
- }
102
-
103
- public editTask(task_id: string, payload: Api_Tasks_Task_Edit_Request_Dto): Promise<Api_Tasks_Task_Dto> {
104
- return this.put<Api_Tasks_Task_Edit_Request_Dto, Api_Tasks_Task_Dto>(`tasks/${task_id}`, payload)
105
- }
106
-
107
- public mergeTask(payload: { name: string; tasks_id: string[]; defect?: string }): Promise<ResponseApi<any>> {
108
- return this.post(`tasks/merge`, payload)
109
- }
110
-
111
- public deleteTask(id: string): Promise<any> {
112
- return this.delete(`tasks/${id}`)
113
- }
114
-
115
- public changeStatus(taskId: string, statusId: string): Promise<any> {
116
- return this.put<{ status_id: string }, any>(`task/${taskId}/change-status`, {
117
- status_id: statusId,
118
- })
119
- }
120
-
121
- public saveMetrics(payload: Api_QualityMetric_Request_Dto[]): Promise<EquipmentData[]> {
122
- return this.put<Api_QualityMetric_Request_Dto[], EquipmentData[]>('/update_quality_metrics', payload)
123
- }
124
-
125
- public checkReasonForStatus(task_id: string): Promise<Api_Task_Close_Reason> {
126
- return this.post<{ task_id: string }, Api_Task_Close_Reason>('/tasks/check_reason_for_task', { task_id })
127
- }
128
-
129
- public verifyTaskStatus(task_id: string, status_id: string): Promise<Api_Task_ChangeStatusVerification_Dto[]> {
130
- return this.get<Api_Task_ChangeStatusVerification_Dto[]>(`/task/${task_id}/change-status/verification`, {
131
- params: { status_id },
132
- })
133
- }
134
-
135
- public checkBranchBeforeCloseTask(task_id: string): Promise<ResponseApi<boolean>> {
136
- return this.post<{ task_id: string }, ResponseApi<boolean>>(`/check_branch_before_close_task`, { task_id })
137
- }
138
- }
139
-
140
- let api: TasksService
141
-
142
- export default function useTasksService() {
143
- if (!api) api = new TasksService()
144
- return api
145
- }
1
+ import ApiService from '../settings/ApiService'
2
+ import { ResponseApi } from '../types/Api_Service'
3
+ import {
4
+ Api_Task_Close_Reason,
5
+ Api_Task_Instrument_Dto,
6
+ Api_Task_Instrument_From_Warehouse,
7
+ Api_Task_Module_Instrument_Condition,
8
+ Api_Task_Dto,
9
+ Api_Tasks_Task_Dto,
10
+ Api_Task_ChangeStatusVerification_Dto,
11
+ Api_QualityMetric_Request_Dto,
12
+ Api_Tasks_Task_Edit_Request_Dto,
13
+ Api_Tasks_ReplaceInstrument_Request_Dto,
14
+ Api_Tasks_AllPersonalUser_Dto,
15
+ Api_Tasks_InstrumentHistory_Item_Dto,
16
+ } from '../types/Api_Tasks'
17
+ import { Api_Equipment_Full_Dto, Api_Task_Video_Source, Api_Task_Video_Source_Stream } from '../types/Api_Repairs'
18
+
19
+ export type EquipmentData = {
20
+ id: string
21
+ model: unknown
22
+ name: string
23
+ registration_number: string
24
+ repair_frequency: unknown
25
+ repair_range: number
26
+ }
27
+
28
+ class TasksService extends ApiService {
29
+ public fetchTaskById(id: string): Promise<Api_Tasks_Task_Dto> {
30
+ return this.get<Api_Tasks_Task_Dto>(`/tasks/${id}`)
31
+ }
32
+
33
+ public fetchTasksList(params: any): Promise<ResponseApi<Api_Task_Dto[]>> {
34
+ return this.get<ResponseApi<Api_Task_Dto[]>>('/list/tasks/search', { params })
35
+ }
36
+
37
+ public fetchSubtasksList(id: string): Promise<Api_Task_Dto[]> {
38
+ return this.get<Api_Task_Dto[]>(`/task/${id}/subtasks/list`)
39
+ }
40
+
41
+ public fetchTaskBranch(id: string): Promise<ResponseApi<any>> {
42
+ return this.get(`/get_list_task_branch?task_id=${id}`)
43
+ }
44
+
45
+ public fetchInstrumentsList(params: any): Promise<ResponseApi<any[]>> {
46
+ return this.get('admin/instruments', { params })
47
+ }
48
+
49
+ public fetchInstrumentTypeListWithPreparedWarehouse(params: {
50
+ page: number
51
+ per_page: number
52
+ 'filterList[taskId]'?: string | undefined
53
+ search?: string
54
+ }): Promise<ResponseApi<Api_Task_Instrument_From_Warehouse[]>> {
55
+ return this.get('/instrument_type/get_instrument_type_list_with_prepared_warehouse', { params })
56
+ }
57
+
58
+ public fetchInstrumentsEquivalentList(params: any): Promise<ResponseApi<Api_Task_Instrument_Dto[]>> {
59
+ return this.get<ResponseApi<Api_Task_Instrument_Dto[]>>('tasks/instrument/list', { params })
60
+ }
61
+
62
+ public fetchDiffInstruments(params: any): Promise<ResponseApi<Api_Task_Module_Instrument_Condition>> {
63
+ return this.get<ResponseApi<Api_Task_Module_Instrument_Condition>>(`tasks/${params.taskId}/fill/module`, {
64
+ params,
65
+ })
66
+ }
67
+
68
+ public replaceInstruments(payload: Api_Tasks_ReplaceInstrument_Request_Dto[]): Promise<ResponseApi<any[]>> {
69
+ return this.post<Api_Tasks_ReplaceInstrument_Request_Dto[], ResponseApi<any[]>>(
70
+ `/instruments/equivalent/attach`,
71
+ payload,
72
+ )
73
+ }
74
+
75
+ public fetchTaskUsagePersonal(task_id: string): Promise<Api_Tasks_AllPersonalUser_Dto> {
76
+ return this.get<Api_Tasks_AllPersonalUser_Dto>(`tasks/${task_id}/usage/users`)
77
+ }
78
+
79
+ public fetchTaskUsageInstrument(task_id: string): Promise<Api_Tasks_InstrumentHistory_Item_Dto[]> {
80
+ return this.get<Api_Tasks_InstrumentHistory_Item_Dto[]>(`tasks/${task_id}/usage/instruments`)
81
+ }
82
+
83
+ public fetchEquipment(params: any): Promise<ResponseApi<Api_Equipment_Full_Dto[]>> {
84
+ return this.get<ResponseApi<Api_Equipment_Full_Dto[]>>('repairs/equipment/list', { params })
85
+ }
86
+
87
+ public fetchTaskVideoSources(params: any): Promise<ResponseApi<Api_Task_Video_Source[]>> {
88
+ return this.get<ResponseApi<Api_Task_Video_Source[]>>('work_zone/get_list_video_source', { params })
89
+ }
90
+
91
+ public fetchTaskVideoSourcesStream(params: any): Promise<ResponseApi<Api_Task_Video_Source_Stream[]>> {
92
+ return this.get<ResponseApi<Api_Task_Video_Source_Stream[]>>('horizon/video-source', { params })
93
+ }
94
+
95
+ public createWorkZone(payload: any): Promise<unknown> {
96
+ return this.post('admin/work-zones', payload)
97
+ }
98
+
99
+ public createTask(payload: any): Promise<ResponseApi<any>> {
100
+ return this.post(`tasks`, payload)
101
+ }
102
+
103
+ public editTask(task_id: string, payload: Api_Tasks_Task_Edit_Request_Dto): Promise<Api_Tasks_Task_Dto> {
104
+ return this.put<Api_Tasks_Task_Edit_Request_Dto, Api_Tasks_Task_Dto>(`tasks/${task_id}`, payload)
105
+ }
106
+
107
+ public mergeTask(payload: { name: string; tasks_id: string[]; defect?: string }): Promise<ResponseApi<any>> {
108
+ return this.post(`tasks/merge`, payload)
109
+ }
110
+
111
+ public deleteTask(id: string): Promise<any> {
112
+ return this.delete(`tasks/${id}`)
113
+ }
114
+
115
+ public changeStatus(taskId: string, statusId: string): Promise<any> {
116
+ return this.put<{ status_id: string }, any>(`task/${taskId}/change-status`, {
117
+ status_id: statusId,
118
+ })
119
+ }
120
+
121
+ public saveMetrics(payload: Api_QualityMetric_Request_Dto[]): Promise<EquipmentData[]> {
122
+ return this.put<Api_QualityMetric_Request_Dto[], EquipmentData[]>('/update_quality_metrics', payload)
123
+ }
124
+
125
+ public checkReasonForStatus(task_id: string): Promise<Api_Task_Close_Reason> {
126
+ return this.post<{ task_id: string }, Api_Task_Close_Reason>('/tasks/check_reason_for_task', { task_id })
127
+ }
128
+
129
+ public verifyTaskStatus(task_id: string, status_id: string): Promise<Api_Task_ChangeStatusVerification_Dto[]> {
130
+ return this.get<Api_Task_ChangeStatusVerification_Dto[]>(`/task/${task_id}/change-status/verification`, {
131
+ params: { status_id },
132
+ })
133
+ }
134
+
135
+ public checkBranchBeforeCloseTask(task_id: string): Promise<ResponseApi<boolean>> {
136
+ return this.post<{ task_id: string }, ResponseApi<boolean>>(`/check_branch_before_close_task`, { task_id })
137
+ }
138
+ }
139
+
140
+ let api: TasksService
141
+
142
+ export default function useTasksService() {
143
+ if (!api) api = new TasksService()
144
+ return api
145
+ }
@@ -1,87 +1,101 @@
1
- import ApiService from '../settings/ApiService'
2
- import {
3
- Api_User,
4
- Api_User_Create,
5
- Api_User_Delete_Body,
6
- Api_User_Delete_Photos_Body,
7
- Api_User_Position,
8
- Api_User_Role,
9
- Api_User_Team,
10
- Api_User_Team_Search,
11
- } from '../types/Api_User'
12
- import { ResponseApi } from '../types/Api_Service'
13
-
14
- class UserService extends ApiService {
15
- public async editUser({ id, model }: { id: string; model: any }): Promise<Api_User> {
16
- return await this.put<Partial<Api_User>, Api_User>(`/admin/users/${id}`, model)
17
- }
18
-
19
- public async getUser(id: string): Promise<Api_User> {
20
- return await this.get<Api_User>(`/admin/users/${id}`)
21
- }
22
-
23
- public async createUser(model: Api_User_Create): Promise<Api_User> {
24
- return await this.post<Api_User_Create, Api_User>('/admin/users', model)
25
- }
26
-
27
- public async deleteUser({
28
- user_id,
29
- archive_reason,
30
- }: Api_User_Delete_Body): Promise<{ data: boolean; status: number }> {
31
- return await this.post(`/users/archive_user`, { user_id, archive_reason })
32
- }
33
-
34
- public async deleteUserPhotos({
35
- user_id,
36
- photos,
37
- }: Api_User_Delete_Photos_Body): Promise<{ data: boolean; status: number }> {
38
- return await this.post(`/users/photos/delete`, { user_id, photos })
39
- }
40
-
41
- public async restoreUser(user_id: string): Promise<{ data: boolean; status: number }> {
42
- return await this.post(`/users/restore_user`, { user_id })
43
- }
44
-
45
- public async getRoles(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Role[]>> {
46
- return await this.get<ResponseApi<Api_User_Role[]>>('/search/roles', { params })
47
- }
48
-
49
- public async getPositions(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Position[]>> {
50
- return await this.get<ResponseApi<Api_User_Position[]>>('/search/positions', { params })
51
- }
52
-
53
- public async createPosition(body: Partial<Api_User_Position>): Promise<ResponseApi<Api_User_Position>> {
54
- return await this.post<Partial<Api_User_Position>, ResponseApi<Api_User_Position>>('/admin/positions', body)
55
- }
56
-
57
- public async editPosition(id: string, body: Partial<Api_User_Position>): Promise<ResponseApi<Api_User_Position>> {
58
- return await this.put<Partial<Api_User_Position>, ResponseApi<Api_User_Position>>(`/admin/positions/${id}`, body)
59
- }
60
-
61
- public async deletePosition(id: string): Promise<{ data: boolean; status: number }> {
62
- return await this.delete(`/admin/positions/${id}`)
63
- }
64
-
65
- public async getTeams(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Team_Search[]>> {
66
- return await this.get<ResponseApi<Api_User_Team_Search[]>>('/search/teams', { params })
67
- }
68
-
69
- public async createTeam(body: Partial<Api_User_Team_Search>): Promise<ResponseApi<Api_User_Team>> {
70
- return await this.post<Partial<Api_User_Team_Search>, ResponseApi<Api_User_Team>>('/teams', body)
71
- }
72
-
73
- public async editTeam(id: string, body: Partial<Api_User_Team_Search>): Promise<{ data: boolean; status: number }> {
74
- return await this.patch<Partial<Api_User_Team_Search>, { data: boolean; status: number }>(`/teams/${id}`, body)
75
- }
76
-
77
- public async deleteTeam(id: string): Promise<{ data: boolean; status: number }> {
78
- return await this.delete(`/teams/${id}`)
79
- }
80
- }
81
-
82
- let api: UserService
83
-
84
- export default function useUserService() {
85
- if (!api) api = new UserService()
86
- return api
87
- }
1
+ import ApiService from '../settings/ApiService'
2
+ import {
3
+ Api_User,
4
+ Api_User_Create,
5
+ Api_User_Delete_Body,
6
+ Api_User_Delete_Photos_Body,
7
+ Api_User_Position,
8
+ Api_User_Role,
9
+ Api_User_Team,
10
+ Api_User_Team_Search,
11
+ } from '../types/Api_User'
12
+ import { ResponseApi } from '../types/Api_Service'
13
+
14
+ class UserService extends ApiService {
15
+ public async editUser({ id, model }: { id: string; model: any }): Promise<Api_User> {
16
+ return await this.put<Partial<Api_User>, Api_User>(`/admin/users/${id}`, model)
17
+ }
18
+
19
+ public async getUser(id: string): Promise<Api_User> {
20
+ return await this.get<Api_User>(`/admin/users/${id}`)
21
+ }
22
+
23
+ public async createUser(model: Api_User_Create): Promise<Api_User> {
24
+ return await this.post<Api_User_Create, Api_User>('/admin/users', model)
25
+ }
26
+
27
+ public async deleteUser({
28
+ user_id,
29
+ archive_reason,
30
+ }: Api_User_Delete_Body): Promise<{ data: boolean; status: number }> {
31
+ return await this.post(`/users/archive_user`, { user_id, archive_reason })
32
+ }
33
+
34
+ public async deleteUserPhotos({
35
+ user_id,
36
+ photos,
37
+ }: Api_User_Delete_Photos_Body): Promise<{ data: boolean; status: number }> {
38
+ return await this.post(`/users/photos/delete`, { user_id, photos })
39
+ }
40
+
41
+ public async restoreUser(user_id: string): Promise<{ data: boolean; status: number }> {
42
+ return await this.post(`/users/restore_user`, { user_id })
43
+ }
44
+
45
+ public async getRoles(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Role[]>> {
46
+ return await this.get<ResponseApi<Api_User_Role[]>>('/search/roles', { params })
47
+ }
48
+
49
+ public async getPositions(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Position[]>> {
50
+ return await this.get<ResponseApi<Api_User_Position[]>>('/search/positions', { params })
51
+ }
52
+
53
+ public async createPosition(body: Partial<Api_User_Position>): Promise<ResponseApi<Api_User_Position>> {
54
+ return await this.post<Partial<Api_User_Position>, ResponseApi<Api_User_Position>>('/admin/positions', body)
55
+ }
56
+
57
+ public async editPosition(id: string, body: Partial<Api_User_Position>): Promise<ResponseApi<Api_User_Position>> {
58
+ return await this.put<Partial<Api_User_Position>, ResponseApi<Api_User_Position>>(`/admin/positions/${id}`, body)
59
+ }
60
+
61
+ public async deletePosition(id: string): Promise<{ data: boolean; status: number }> {
62
+ return await this.delete(`/admin/positions/${id}`)
63
+ }
64
+
65
+ public async getTeams(params?: { per_page?: number }): Promise<ResponseApi<Api_User_Team_Search[]>> {
66
+ return await this.get<ResponseApi<Api_User_Team_Search[]>>('/search/teams', { params })
67
+ }
68
+
69
+ public async createTeam(body: Partial<Api_User_Team_Search>): Promise<ResponseApi<Api_User_Team>> {
70
+ return await this.post<Partial<Api_User_Team_Search>, ResponseApi<Api_User_Team>>('/teams', body)
71
+ }
72
+
73
+ public async editTeam(id: string, body: Partial<Api_User_Team_Search>): Promise<{ data: boolean; status: number }> {
74
+ return await this.patch<Partial<Api_User_Team_Search>, { data: boolean; status: number }>(`/teams/${id}`, body)
75
+ }
76
+
77
+ public async deleteTeam(id: string): Promise<{ data: boolean; status: number }> {
78
+ return await this.delete(`/teams/${id}`)
79
+ }
80
+
81
+ public async checkUserVectors(id: string): Promise<{ count: number }> {
82
+ return await this.get(`/user/get-vectors/${id}`)
83
+ }
84
+
85
+ public async addUserVectors(formData: FormData): Promise<{ response: string }> {
86
+ return await this.post(`/user/add-vector`, formData, {
87
+ headers: { 'Content-Type': 'multipart/form-data' },
88
+ })
89
+ }
90
+
91
+ public async removeUserVectors(id: string): Promise<unknown> {
92
+ return await this.delete(`/user/delete-vectors/${id}`)
93
+ }
94
+ }
95
+
96
+ let api: UserService
97
+
98
+ export default function useUserService() {
99
+ if (!api) api = new UserService()
100
+ return api
101
+ }
@@ -1,31 +1,12 @@
1
1
  import ApiService from '../settings/ApiService'
2
- import { ResponseApi } from '@/api/types/Api_Service'
3
- import { Api_Work_Zone, Api_Work_Zone_Search } from '@/api/types/Api_Video'
4
2
 
5
3
  class VideoService extends ApiService {
6
4
  public async startVideoAnalytics(): Promise<boolean> {
7
5
  return await this.post('/statanly/start', null)
8
6
  }
9
-
10
7
  public reloadVideoAnalytics(ids: string[]): Promise<any> {
11
8
  return this.post('/horizon/video-source/reload', { video_source_ids: ids })
12
9
  }
13
-
14
- public async fetchWorkZones(params?: any): Promise<ResponseApi<Api_Work_Zone_Search[]>> {
15
- return await this.get('/search/work_zones', { params })
16
- }
17
-
18
- public async fetchWorkZone(id: string): Promise<ResponseApi<Api_Work_Zone>> {
19
- return await this.get(`/work_zone/get_work_zone/${id}`)
20
- }
21
-
22
- public async editWorkZone(id: string, body: { title: string }): Promise<{ data: Api_Work_Zone; status: number }> {
23
- return await this.put(`/admin/work-zones/${id}`, body)
24
- }
25
-
26
- public async deleteWorkZone(id: string): Promise<{ data: boolean; status: number }> {
27
- return await this.delete(`/admin/work-zones/${id}`)
28
- }
29
10
  }
30
11
 
31
12
  let api: VideoService
@@ -1,40 +1,40 @@
1
- export type FileRequest = {
2
- name: string
3
- type: string
4
- path: string
5
- extension: string
6
- id: string
7
- }
8
-
9
- export type Api_Comment_Dto = {
10
- created_at: string
11
- files: FileRequest[]
12
- first_name: string
13
- for_status: boolean
14
- full_name: string
15
- id: string
16
- last_name: string
17
- text: string
18
- user_id: string
19
- user_name: string
20
- }
21
-
22
- export type Api_Comment_Request_Dto = {
23
- for_status?: boolean
24
- task_id?: string
25
- text?: string
26
- type_id?: string
27
- files?: string[]
28
- }
29
-
30
- export type Api_Comment_Update_Dto = {
31
- created_at: string
32
- files: FileRequest[]
33
- for_status: false
34
- id: string
35
- text: string
36
- type: string | null
37
- type_id: string | null
38
- updated_at: string
39
- user_id: string
40
- }
1
+ export type FileRequest = {
2
+ name: string
3
+ type: string
4
+ path: string
5
+ extension: string
6
+ id: string
7
+ }
8
+
9
+ export type Api_Comment_Dto = {
10
+ created_at: string
11
+ files: FileRequest[]
12
+ first_name: string
13
+ for_status: boolean
14
+ full_name: string
15
+ id: string
16
+ last_name: string
17
+ text: string
18
+ user_id: string
19
+ user_name: string
20
+ }
21
+
22
+ export type Api_Comment_Request_Dto = {
23
+ for_status?: boolean
24
+ task_id?: string
25
+ text?: string
26
+ type_id?: string
27
+ files?: string[]
28
+ }
29
+
30
+ export type Api_Comment_Update_Dto = {
31
+ created_at: string
32
+ files: FileRequest[]
33
+ for_status: false
34
+ id: string
35
+ text: string
36
+ type: string | null
37
+ type_id: string | null
38
+ updated_at: string
39
+ user_id: string
40
+ }