shared-ritm 1.3.89 → 1.3.90

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 (76) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +380 -373
  3. package/dist/shared-ritm.umd.js +3 -3
  4. package/dist/types/api/services/ControlsService.d.ts +3 -0
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/settings/ApiService.d.ts +1 -1
  7. package/dist/types/stories/Button.stories.d.ts +13 -0
  8. package/dist/types/stories/Checkbox.stories.d.ts +7 -0
  9. package/dist/types/stories/Confirm.stories.d.ts +8 -0
  10. package/dist/types/stories/DatePicker.stories.d.ts +8 -0
  11. package/dist/types/stories/Dropdown.stories.d.ts +8 -0
  12. package/dist/types/stories/File.stories.d.ts +8 -0
  13. package/dist/types/stories/Icon.stories.d.ts +7 -0
  14. package/dist/types/stories/Input.stories.d.ts +11 -0
  15. package/dist/types/stories/InputNew.stories.d.ts +12 -0
  16. package/dist/types/stories/InputSearch.stories.d.ts +10 -0
  17. package/dist/types/stories/Loader.stories.d.ts +8 -0
  18. package/dist/types/stories/Select.stories.d.ts +7 -0
  19. package/dist/types/stories/Toggle.stories.d.ts +8 -0
  20. package/package.json +70 -70
  21. package/src/App.vue +2461 -2461
  22. package/src/api/services/AuthService.ts +67 -67
  23. package/src/api/services/ControlsService.ts +100 -96
  24. package/src/api/services/EquipmentService.ts +52 -52
  25. package/src/api/services/MetricsService.ts +143 -143
  26. package/src/api/services/RepairsService.ts +111 -111
  27. package/src/api/services/UserIssueService.ts +32 -32
  28. package/src/api/services/UserService.ts +129 -129
  29. package/src/api/services/VideoService.ts +118 -118
  30. package/src/api/settings/ApiService.ts +184 -184
  31. package/src/api/types/Api_Auth.ts +121 -121
  32. package/src/api/types/Api_Equipment.ts +13 -13
  33. package/src/api/types/Api_Metrics.ts +51 -51
  34. package/src/api/types/Api_Repairs.ts +187 -187
  35. package/src/api/types/Api_Search.ts +81 -81
  36. package/src/api/types/Api_Tasks.ts +376 -376
  37. package/src/api/types/Api_User.ts +160 -160
  38. package/src/api/types/Api_User_Issue.ts +36 -36
  39. package/src/api/types/Api_Video.ts +244 -244
  40. package/src/common/app-button/Button.stories.ts +369 -369
  41. package/src/common/app-checkbox/AppCheckbox.vue +31 -31
  42. package/src/common/app-checkbox/Checkbox.stories.ts +252 -252
  43. package/src/common/app-date-picker/DatePicker.stories.ts +66 -66
  44. package/src/common/app-datepicker/Datepicker.stories.ts +145 -145
  45. package/src/common/app-dialogs/AppConfirmDialog.vue +109 -109
  46. package/src/common/app-dialogs/Confirm.stories.ts +93 -93
  47. package/src/common/app-dropdown/Dropdown.stories.ts +94 -94
  48. package/src/common/app-file/File.stories.ts +104 -104
  49. package/src/common/app-icon/AppIcon.vue +110 -110
  50. package/src/common/app-icon/Icon.stories.ts +91 -91
  51. package/src/common/app-input/Input.stories.ts +160 -160
  52. package/src/common/app-input-new/AppInputNew.vue +181 -181
  53. package/src/common/app-input-new/InputNew.stories.ts +240 -240
  54. package/src/common/app-input-search/InputSearch.stories.ts +149 -149
  55. package/src/common/app-layout/components/AppLayoutHeader.vue +289 -289
  56. package/src/common/app-loader/Loader.stories.ts +114 -114
  57. package/src/common/app-modal/index.vue +6 -1
  58. package/src/common/app-select/AppSelect.vue +159 -159
  59. package/src/common/app-select/Select.stories.ts +155 -155
  60. package/src/common/app-sidebar/AppSidebar.vue +174 -174
  61. package/src/common/app-table/AppTable.vue +313 -313
  62. package/src/common/app-table/components/ModalSelect.stories.ts +323 -323
  63. package/src/common/app-table/components/ModalSelect.vue +302 -302
  64. package/src/common/app-table/components/TableModal.vue +369 -369
  65. package/src/common/app-table/controllers/useColumnSelector.ts +45 -45
  66. package/src/common/app-table/controllers/useTableModel.ts +97 -97
  67. package/src/common/app-toggle/AppToggle.vue +12 -12
  68. package/src/common/app-toggle/Toggle.stories.ts +245 -245
  69. package/src/common/app-wrapper/AppWrapper.vue +31 -31
  70. package/src/configs/storybook.ts +14 -14
  71. package/src/icons/sidebar/user-requests-icon.vue +23 -23
  72. package/src/index.ts +134 -134
  73. package/src/shared/styles/general.css +140 -140
  74. package/src/styles/variables.sass +12 -12
  75. package/src/utils/files.ts +38 -38
  76. package/src/utils/helpers.ts +59 -59
@@ -1,184 +1,184 @@
1
- import axios, { AxiosError, AxiosInstance, AxiosRequestConfig, AxiosResponse, InternalAxiosRequestConfig } from 'axios'
2
- import { Api_Auth_Login } from '@/api/types/Api_Auth'
3
-
4
- // eslint-disable-next-line
5
- var isRefreshing = false
6
- // eslint-disable-next-line
7
- var refreshSubscribers: any[] = []
8
-
9
- interface Api_Auth_Refresh {
10
- accessToken: string
11
- }
12
-
13
- export enum ApiServiceType {
14
- SERVICE_AUTH = 'SERVICE_AUTH',
15
- }
16
-
17
- export default class ApiService {
18
- private axiosInstance: AxiosInstance
19
-
20
- constructor() {
21
- this.axiosInstance = axios.create({
22
- baseURL: process.env.VUE_APP_BACKEND,
23
- headers: {
24
- 'Content-Type': 'application/json',
25
- Accept: 'application/json',
26
- },
27
- withCredentials: true,
28
- })
29
-
30
- this.axiosInstance.interceptors.request.use(
31
- (config: InternalAxiosRequestConfig) => {
32
- config.headers.Authorization = `Bearer ${this.getAccessToken()}`
33
- return config
34
- },
35
- (error: AxiosError) => {
36
- return Promise.reject(error)
37
- },
38
- )
39
-
40
- this.axiosInstance.interceptors.response.use(
41
- (response: AxiosResponse) => {
42
- return response.data
43
- },
44
- async error => {
45
- const originalRequest = error.config
46
-
47
- if (
48
- error.response?.status !== 401 ||
49
- originalRequest.url === '/v2/auth/refresh' ||
50
- originalRequest.url === '/v2/login' ||
51
- originalRequest._retry
52
- ) {
53
- return Promise.reject(error)
54
- }
55
-
56
- originalRequest._retry = true
57
-
58
- if (isRefreshing) {
59
- return new Promise(resolve => {
60
- this.subscribeTokenRefresh(() => resolve(this.axiosInstance(originalRequest)))
61
- })
62
- }
63
-
64
- isRefreshing = true
65
-
66
- try {
67
- const response = await this.refresh()
68
-
69
- const newToken = response.accessToken
70
- if (!newToken) {
71
- await this.logoutUser()
72
- return Promise.reject(error)
73
- }
74
-
75
- this.setAccessToken(newToken)
76
- this.onRefreshed()
77
- isRefreshing = false
78
- return this.axiosInstance(originalRequest)
79
- } catch (e) {
80
- await this.logoutUser()
81
- return Promise.reject(e)
82
- }
83
- },
84
- )
85
- }
86
-
87
- private setAccessToken(token: string) {
88
- localStorage.setItem('token', token)
89
- }
90
- private getAccessToken() {
91
- return localStorage.getItem('token')
92
- }
93
-
94
- private removeToken() {
95
- localStorage.removeItem('token')
96
- }
97
-
98
- private subscribeTokenRefresh(cb: any) {
99
- refreshSubscribers.push(cb)
100
- }
101
-
102
- private refresh(): Promise<Api_Auth_Refresh> {
103
- return this.post<null, Api_Auth_Login>(`/v2/auth/refresh`, null)
104
- }
105
-
106
- private onRefreshed() {
107
- refreshSubscribers.forEach(cb => cb())
108
- refreshSubscribers = []
109
- }
110
-
111
- public async logoutUser(): Promise<any> {
112
- isRefreshing = false
113
- await this.post<any, any>(`/v2/logout`, null)
114
- this.removeToken()
115
- window.location.href = '/sign-in'
116
- }
117
-
118
- private handleError(error: AxiosError): void {
119
- if (error.response) {
120
- console.error('API Error:', error.response.status, error.response.data)
121
- } else if (error.request) {
122
- console.error('No response received:', error.request)
123
- } else {
124
- console.error('Error during request setup:', error.message)
125
- }
126
- }
127
-
128
- protected async get<T>(url: string, options?: AxiosRequestConfig) {
129
- try {
130
- const response: AxiosResponse<T> = await this.axiosInstance.get<T>(url, options)
131
- if (response?.data === false) return false as unknown as T
132
-
133
- return response?.data ?? (response as unknown as T)
134
- } catch (error) {
135
- const axiosError = error as AxiosError
136
- this.handleError(axiosError)
137
- throw error
138
- }
139
- }
140
-
141
- protected async delete<T>(url: string, options?: AxiosRequestConfig) {
142
- try {
143
- return await this.axiosInstance.delete<T>(url, options)
144
- } catch (error) {
145
- const axiosError = error as AxiosError
146
- this.handleError(axiosError)
147
- throw error
148
- }
149
- }
150
-
151
- protected async post<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig) {
152
- try {
153
- const response: AxiosResponse<T2> = await this.axiosInstance.post<T1, AxiosResponse<T2>>(url, payload, options)
154
- if (response?.data === false) return false
155
- return response?.data || (response as any)
156
- } catch (error) {
157
- const axiosError = error as AxiosError
158
- this.handleError(axiosError)
159
- throw error
160
- }
161
- }
162
-
163
- protected async patch<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig): Promise<T2> {
164
- try {
165
- const response: AxiosResponse<T2> = await this.axiosInstance.patch<T1, AxiosResponse<T2>>(url, payload, options)
166
- return response.data
167
- } catch (error) {
168
- const axiosError = error as AxiosError
169
- this.handleError(axiosError)
170
- throw error
171
- }
172
- }
173
-
174
- protected async put<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig) {
175
- try {
176
- const response: AxiosResponse<T2> = await this.axiosInstance.put<T1, AxiosResponse<T2>>(url, payload, options)
177
- return response.data
178
- } catch (error) {
179
- const axiosError = error as AxiosError
180
- this.handleError(axiosError)
181
- throw error
182
- }
183
- }
184
- }
1
+ import axios, { AxiosError, AxiosInstance, AxiosRequestConfig, AxiosResponse, InternalAxiosRequestConfig } from 'axios'
2
+ import { Api_Auth_Login } from '@/api/types/Api_Auth'
3
+
4
+ // eslint-disable-next-line
5
+ var isRefreshing = false
6
+ // eslint-disable-next-line
7
+ var refreshSubscribers: any[] = []
8
+
9
+ interface Api_Auth_Refresh {
10
+ accessToken: string
11
+ }
12
+
13
+ export enum ApiServiceType {
14
+ SERVICE_AUTH = 'SERVICE_AUTH',
15
+ }
16
+
17
+ export default class ApiService {
18
+ private axiosInstance: AxiosInstance
19
+
20
+ constructor() {
21
+ this.axiosInstance = axios.create({
22
+ baseURL: process.env.VUE_APP_BACKEND,
23
+ headers: {
24
+ 'Content-Type': 'application/json',
25
+ Accept: 'application/json',
26
+ },
27
+ withCredentials: true,
28
+ })
29
+
30
+ this.axiosInstance.interceptors.request.use(
31
+ (config: InternalAxiosRequestConfig) => {
32
+ config.headers.Authorization = `Bearer ${this.getAccessToken()}`
33
+ return config
34
+ },
35
+ (error: AxiosError) => {
36
+ return Promise.reject(error)
37
+ },
38
+ )
39
+
40
+ this.axiosInstance.interceptors.response.use(
41
+ (response: AxiosResponse) => {
42
+ return response.data
43
+ },
44
+ async error => {
45
+ const originalRequest = error.config
46
+
47
+ if (
48
+ error.response?.status !== 401 ||
49
+ originalRequest.url === '/v2/auth/refresh' ||
50
+ originalRequest.url === '/v2/login' ||
51
+ originalRequest._retry
52
+ ) {
53
+ return Promise.reject(error)
54
+ }
55
+
56
+ originalRequest._retry = true
57
+
58
+ if (isRefreshing) {
59
+ return new Promise(resolve => {
60
+ this.subscribeTokenRefresh(() => resolve(this.axiosInstance(originalRequest)))
61
+ })
62
+ }
63
+
64
+ isRefreshing = true
65
+
66
+ try {
67
+ const response = await this.refresh()
68
+
69
+ const newToken = response.accessToken
70
+ if (!newToken) {
71
+ this.logoutUser()
72
+ return Promise.reject(error)
73
+ }
74
+
75
+ this.setAccessToken(newToken)
76
+ this.onRefreshed()
77
+ isRefreshing = false
78
+ return this.axiosInstance(originalRequest)
79
+ } catch (e) {
80
+ this.logoutUser()
81
+ return Promise.reject(e)
82
+ }
83
+ },
84
+ )
85
+ }
86
+
87
+ private setAccessToken(token: string) {
88
+ localStorage.setItem('token', token)
89
+ }
90
+ private getAccessToken() {
91
+ return localStorage.getItem('token')
92
+ }
93
+
94
+ private removeToken() {
95
+ localStorage.removeItem('token')
96
+ }
97
+
98
+ private subscribeTokenRefresh(cb: any) {
99
+ refreshSubscribers.push(cb)
100
+ }
101
+
102
+ private refresh(): Promise<Api_Auth_Refresh> {
103
+ return this.post<null, Api_Auth_Login>(`/v2/auth/refresh`, null)
104
+ }
105
+
106
+ private onRefreshed() {
107
+ refreshSubscribers.forEach(cb => cb())
108
+ refreshSubscribers = []
109
+ }
110
+
111
+ public logoutUser(): any {
112
+ isRefreshing = false
113
+ this.post<any, any>(`/v2/logout`, {})
114
+ this.removeToken()
115
+ window.location.href = '/sign-in'
116
+ }
117
+
118
+ private handleError(error: AxiosError): void {
119
+ if (error.response) {
120
+ console.error('API Error:', error.response.status, error.response.data)
121
+ } else if (error.request) {
122
+ console.error('No response received:', error.request)
123
+ } else {
124
+ console.error('Error during request setup:', error.message)
125
+ }
126
+ }
127
+
128
+ protected async get<T>(url: string, options?: AxiosRequestConfig) {
129
+ try {
130
+ const response: AxiosResponse<T> = await this.axiosInstance.get<T>(url, options)
131
+ if (response?.data === false) return false as unknown as T
132
+
133
+ return response?.data ?? (response as unknown as T)
134
+ } catch (error) {
135
+ const axiosError = error as AxiosError
136
+ this.handleError(axiosError)
137
+ throw error
138
+ }
139
+ }
140
+
141
+ protected async delete<T>(url: string, options?: AxiosRequestConfig) {
142
+ try {
143
+ return await this.axiosInstance.delete<T>(url, options)
144
+ } catch (error) {
145
+ const axiosError = error as AxiosError
146
+ this.handleError(axiosError)
147
+ throw error
148
+ }
149
+ }
150
+
151
+ protected async post<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig) {
152
+ try {
153
+ const response: AxiosResponse<T2> = await this.axiosInstance.post<T1, AxiosResponse<T2>>(url, payload, options)
154
+ if (response?.data === false) return false
155
+ return response?.data || (response as any)
156
+ } catch (error) {
157
+ const axiosError = error as AxiosError
158
+ this.handleError(axiosError)
159
+ throw error
160
+ }
161
+ }
162
+
163
+ protected async patch<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig): Promise<T2> {
164
+ try {
165
+ const response: AxiosResponse<T2> = await this.axiosInstance.patch<T1, AxiosResponse<T2>>(url, payload, options)
166
+ return response.data
167
+ } catch (error) {
168
+ const axiosError = error as AxiosError
169
+ this.handleError(axiosError)
170
+ throw error
171
+ }
172
+ }
173
+
174
+ protected async put<T1, T2>(url: string, payload: T1, options?: AxiosRequestConfig) {
175
+ try {
176
+ const response: AxiosResponse<T2> = await this.axiosInstance.put<T1, AxiosResponse<T2>>(url, payload, options)
177
+ return response.data
178
+ } catch (error) {
179
+ const axiosError = error as AxiosError
180
+ this.handleError(axiosError)
181
+ throw error
182
+ }
183
+ }
184
+ }
@@ -1,121 +1,121 @@
1
- import { Api_User } from '@/api/types/Api_User'
2
-
3
- export type LoginPayload = {
4
- email: string
5
- password: string
6
- }
7
-
8
- export type Api_Auth_User_Education = {
9
- created_at: string
10
- display_name: string
11
- id: string
12
- name: string
13
- }
14
-
15
- export type Api_Auth_User_Photo = {
16
- id: string
17
- name: string
18
- path: string
19
- type: string
20
- }
21
-
22
- export type Api_Auth_User_Position = {
23
- description: string
24
- display_name: string
25
- id: string
26
- name: string
27
- }
28
-
29
- export type Api_User_Roles_Permissions = {
30
- created_at: string
31
- description: string
32
- display_name: string
33
- id: string
34
- name: string
35
- updated_at: string
36
- }
37
-
38
- export type Api_Auth_User_Role = {
39
- display_name: string
40
- id: string
41
- name: string
42
- permissions: Api_User_Roles_Permissions[]
43
- }
44
-
45
- export type Api_Auth_User_Team = {
46
- display_name: string
47
- id: string
48
- name: string
49
- roles: Api_Auth_User_Role[]
50
- }
51
-
52
- export type Api_Auth_User = {
53
- RFID: string
54
- avatar_id: null | string
55
- avatar_path: null | string
56
- dismissal_at: null | string
57
- divisions: string
58
- educations: Api_Auth_User_Education[]
59
- email: string
60
- email_verified_at: string
61
- first_name: string
62
- full_name: string
63
- id: string
64
- last_name: string
65
- passes: any[]
66
- patronymic: string
67
- personnel_number: number
68
- phone: string
69
- photos: Api_Auth_User_Photo[]
70
- positions: Api_Auth_User_Position[]
71
- profession: string
72
- roles: Api_Auth_User_Role[]
73
- security_warnings: any[]
74
- teams: Api_Auth_User_Team[]
75
- avatar: null
76
- change_password: null
77
- created_at: string
78
- deleted_at: null
79
- face_recognition_id: null
80
- password_change_available_at: string
81
- password_change_due_at: string
82
- password_last_changed_at: string
83
- updated_at: string
84
- }
85
-
86
- export type Api_Auth_Login = {
87
- token: string
88
- user: Api_Auth_User
89
- }
90
-
91
- export type ChangePasswordPayload = {
92
- password: string
93
- password_confirmation: string
94
- }
95
-
96
- export type ChangePasswordAndActivatePayload = {
97
- email: string
98
- currentPassword: string
99
- password: string
100
- passwordConfirmation: string
101
- }
102
-
103
- export type ChangePasswordResponse = Pick<
104
- Api_User,
105
- | 'id'
106
- | 'archiveHistory'
107
- | 'assigned_tasks'
108
- | 'divisions'
109
- | 'email'
110
- | 'full_name'
111
- | 'passes'
112
- | 'personnel_number'
113
- | 'phone'
114
- | 'photos'
115
- | 'positions'
116
- | 'responsible_tasks'
117
- | 'teams'
118
- | 'warehouses'
119
- >
120
-
121
- export type ConfigResponse = any
1
+ import { Api_User } from '@/api/types/Api_User'
2
+
3
+ export type LoginPayload = {
4
+ email: string
5
+ password: string
6
+ }
7
+
8
+ export type Api_Auth_User_Education = {
9
+ created_at: string
10
+ display_name: string
11
+ id: string
12
+ name: string
13
+ }
14
+
15
+ export type Api_Auth_User_Photo = {
16
+ id: string
17
+ name: string
18
+ path: string
19
+ type: string
20
+ }
21
+
22
+ export type Api_Auth_User_Position = {
23
+ description: string
24
+ display_name: string
25
+ id: string
26
+ name: string
27
+ }
28
+
29
+ export type Api_User_Roles_Permissions = {
30
+ created_at: string
31
+ description: string
32
+ display_name: string
33
+ id: string
34
+ name: string
35
+ updated_at: string
36
+ }
37
+
38
+ export type Api_Auth_User_Role = {
39
+ display_name: string
40
+ id: string
41
+ name: string
42
+ permissions: Api_User_Roles_Permissions[]
43
+ }
44
+
45
+ export type Api_Auth_User_Team = {
46
+ display_name: string
47
+ id: string
48
+ name: string
49
+ roles: Api_Auth_User_Role[]
50
+ }
51
+
52
+ export type Api_Auth_User = {
53
+ RFID: string
54
+ avatar_id: null | string
55
+ avatar_path: null | string
56
+ dismissal_at: null | string
57
+ divisions: string
58
+ educations: Api_Auth_User_Education[]
59
+ email: string
60
+ email_verified_at: string
61
+ first_name: string
62
+ full_name: string
63
+ id: string
64
+ last_name: string
65
+ passes: any[]
66
+ patronymic: string
67
+ personnel_number: number
68
+ phone: string
69
+ photos: Api_Auth_User_Photo[]
70
+ positions: Api_Auth_User_Position[]
71
+ profession: string
72
+ roles: Api_Auth_User_Role[]
73
+ security_warnings: any[]
74
+ teams: Api_Auth_User_Team[]
75
+ avatar: null
76
+ change_password: null
77
+ created_at: string
78
+ deleted_at: null
79
+ face_recognition_id: null
80
+ password_change_available_at: string
81
+ password_change_due_at: string
82
+ password_last_changed_at: string
83
+ updated_at: string
84
+ }
85
+
86
+ export type Api_Auth_Login = {
87
+ token: string
88
+ user: Api_Auth_User
89
+ }
90
+
91
+ export type ChangePasswordPayload = {
92
+ password: string
93
+ password_confirmation: string
94
+ }
95
+
96
+ export type ChangePasswordAndActivatePayload = {
97
+ email: string
98
+ currentPassword: string
99
+ password: string
100
+ passwordConfirmation: string
101
+ }
102
+
103
+ export type ChangePasswordResponse = Pick<
104
+ Api_User,
105
+ | 'id'
106
+ | 'archiveHistory'
107
+ | 'assigned_tasks'
108
+ | 'divisions'
109
+ | 'email'
110
+ | 'full_name'
111
+ | 'passes'
112
+ | 'personnel_number'
113
+ | 'phone'
114
+ | 'photos'
115
+ | 'positions'
116
+ | 'responsible_tasks'
117
+ | 'teams'
118
+ | 'warehouses'
119
+ >
120
+
121
+ export type ConfigResponse = any
@@ -1,13 +1,13 @@
1
- import { Api_Equipment_Full_Dto } from '@/api/types/Api_Repairs'
2
-
3
- export type Api_Equipment_Create = Omit<Api_Equipment_Full_Dto, 'id'>
4
-
5
- export type Api_Equipment_Type = {
6
- id: string
7
- name: string
8
- model?: string | null
9
- description?: string | null
10
- updated_at: string
11
- }
12
-
13
- export type Api_Equipment_Type_Body = Omit<Api_Equipment_Type, 'id' | 'updated_at'>
1
+ import { Api_Equipment_Full_Dto } from '@/api/types/Api_Repairs'
2
+
3
+ export type Api_Equipment_Create = Omit<Api_Equipment_Full_Dto, 'id'>
4
+
5
+ export type Api_Equipment_Type = {
6
+ id: string
7
+ name: string
8
+ model?: string | null
9
+ description?: string | null
10
+ updated_at: string
11
+ }
12
+
13
+ export type Api_Equipment_Type_Body = Omit<Api_Equipment_Type, 'id' | 'updated_at'>