shared-ritm 1.3.28 → 1.3.29

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 (58) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +8736 -8788
  3. package/dist/shared-ritm.umd.js +324 -324
  4. package/dist/types/api/services/ComentsServise.d.ts +10 -0
  5. package/dist/types/api/services/GanttService.d.ts +1 -0
  6. package/dist/types/api/services/PhotoService.d.ts +51 -38
  7. package/dist/types/api/services/RepairsService.d.ts +1 -1
  8. package/dist/types/api/settings/ApiService.d.ts +1 -1
  9. package/dist/types/api/types/Api_Users.d.ts +43 -0
  10. package/package.json +64 -64
  11. package/src/App.vue +2461 -2461
  12. package/src/api/services/BrigadesService.ts +32 -32
  13. package/src/api/services/ControlsService.ts +96 -96
  14. package/src/api/services/EquipmentService.ts +29 -29
  15. package/src/api/services/GanttService.ts +6 -0
  16. package/src/api/services/InstrumentsService.ts +68 -68
  17. package/src/api/services/MetricsService.ts +123 -123
  18. package/src/api/services/ModulesService.ts +27 -27
  19. package/src/api/services/ProjectsService.ts +83 -83
  20. package/src/api/services/RepairsService.ts +111 -111
  21. package/src/api/services/ScheduleService.ts +69 -69
  22. package/src/api/services/SearchService.ts +22 -22
  23. package/src/api/services/UserService.ts +119 -119
  24. package/src/api/services/VideoService.ts +108 -108
  25. package/src/api/settings/ApiService.ts +124 -124
  26. package/src/api/types/Api_Auth.ts +105 -105
  27. package/src/api/types/Api_Brigades.ts +36 -36
  28. package/src/api/types/Api_Controls.ts +111 -111
  29. package/src/api/types/Api_Equipment.ts +3 -3
  30. package/src/api/types/Api_Instruments.ts +156 -156
  31. package/src/api/types/Api_Metrics.ts +5 -5
  32. package/src/api/types/Api_Modules.ts +21 -21
  33. package/src/api/types/Api_Projects.ts +62 -62
  34. package/src/api/types/Api_Repairs.ts +186 -186
  35. package/src/api/types/Api_Schedule.ts +64 -64
  36. package/src/api/types/Api_Search.ts +80 -80
  37. package/src/api/types/Api_Tasks.ts +372 -372
  38. package/src/api/types/Api_User.ts +146 -146
  39. package/src/api/types/Api_Video.ts +198 -198
  40. package/src/common/app-datepicker/AppDatepicker.vue +218 -218
  41. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  42. package/src/common/app-input-new/AppInputNew.vue +179 -179
  43. package/src/common/app-layout/AppLayout.vue +84 -84
  44. package/src/common/app-modal/index.vue +96 -96
  45. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  46. package/src/common/app-sidebar/AppSidebar.vue +174 -174
  47. package/src/common/app-sidebar/components/SidebarMenuItem.vue +149 -149
  48. package/src/common/app-table/AppTable.vue +313 -313
  49. package/src/common/app-table/AppTableLayout.vue +137 -137
  50. package/src/common/app-table/components/ModalSelect.vue +298 -298
  51. package/src/common/app-table/components/TableModal.vue +23 -4
  52. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  53. package/src/common/app-table/controllers/useColumnSelector.ts +12 -1
  54. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  55. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  56. package/src/index.ts +131 -131
  57. package/src/styles/variables.sass +12 -12
  58. package/src/utils/files.ts +19 -19
@@ -1,218 +1,218 @@
1
- <template>
2
- <div class="datepicker">
3
- <app-input-new
4
- v-model="model"
5
- readonly
6
- input-class="cursor-pointer"
7
- :label="label"
8
- :required="required"
9
- :rules="rules"
10
- :error="error"
11
- :disable="disabled"
12
- placeholder="Выберите дату"
13
- >
14
- <q-popup-proxy v-if="!disabled" class="datepicker__wrapper" @update:model-value="updateError">
15
- <q-date
16
- :model-value="model"
17
- :mask="time ? `DD.MM.YYYY ${timeFormat}` : 'DD.MM.YYYY'"
18
- :options="disablePastDates"
19
- @update:model-value="updateDate"
20
- />
21
- <q-time
22
- v-if="time"
23
- v-model="model"
24
- :mask="`DD.MM.YYYY ${timeFormat}`"
25
- format24h
26
- :hour-options="hourOptions()"
27
- :minute-options="minuteOptions()"
28
- />
29
- </q-popup-proxy>
30
- <template #append>
31
- <q-icon name="event" class="cursor-pointer"></q-icon>
32
- </template>
33
- </app-input-new>
34
- </div>
35
- </template>
36
-
37
- <script setup lang="ts">
38
- import AppInputNew from '@/common/app-input-new/AppInputNew.vue'
39
- import { ref, withDefaults, defineEmits, defineProps, defineModel } from 'vue'
40
- import { date } from 'quasar'
41
-
42
- interface Props {
43
- label?: string
44
- modelValue?: string
45
- rules?: ((val?: string | number | null) => boolean | string)[]
46
- disableRuleDates?: string | string[]
47
- time?: boolean
48
- noPastDates?: boolean
49
- disabled?: boolean
50
- required?: boolean
51
- timeFormat?: string
52
- }
53
- const props = withDefaults(defineProps<Props>(), {
54
- label: '',
55
- timeFormat: 'HH:mm',
56
- rules: () => [],
57
- disableRuleDates: undefined,
58
- modelValue: undefined,
59
- })
60
-
61
- defineEmits(['update:modelValue'])
62
-
63
- const model = defineModel<string | null | undefined>()
64
-
65
- const error = ref(false)
66
-
67
- const updateError = (state: boolean) => {
68
- if (props.required && !error.value && !model.value && !state) {
69
- error.value = true
70
- }
71
- }
72
-
73
- const updateDate = (value: string) => {
74
- error.value = false
75
-
76
- if (!props.noPastDates) {
77
- model.value = value
78
- return
79
- }
80
-
81
- const today = new Date()
82
- const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
83
- const selectedDate = getSelectedDate(value)
84
-
85
- if (selectedDate !== todayStr) {
86
- model.value = value
87
- return
88
- }
89
-
90
- const selectedHour = getSelectedHour(value)
91
- const selectedMinutes = getSelectedMinutes(value)
92
- const currentHour = today.getHours()
93
- const currentMinutes = today.getMinutes()
94
-
95
- if (
96
- (selectedHour || selectedHour === 0) &&
97
- (selectedMinutes || selectedMinutes === 0) &&
98
- (selectedHour < currentHour || (selectedHour === currentHour && selectedMinutes < currentMinutes))
99
- ) {
100
- today.setHours(currentHour, currentMinutes, 0)
101
- model.value = date.formatDate(today, `DD.MM.YYYY ${props.timeFormat}`)
102
- } else {
103
- model.value = value
104
- }
105
- }
106
-
107
- const disablePastDates = (date: string) => {
108
- if (!props.noPastDates && !props.disableRuleDates) return true
109
-
110
- const [year, month, day] = date.split('/')
111
- const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
112
- currentDate.setHours(0, 0, 0, 0)
113
-
114
- if (props.disableRuleDates) {
115
- if (Array.isArray(props.disableRuleDates)) {
116
- const firstDate = props.disableRuleDates[0] ? new Date(props.disableRuleDates[0]) : null
117
- firstDate?.setHours(0, 0, 0, 0)
118
- const lastDate = props.disableRuleDates[1] ? new Date(props.disableRuleDates[1]) : null
119
- lastDate?.setHours(0, 0, 0, 0)
120
-
121
- return (!firstDate || currentDate >= firstDate) && (!lastDate || currentDate <= lastDate)
122
- } else {
123
- const firstDate = new Date(props.disableRuleDates)
124
- return currentDate >= firstDate
125
- }
126
- }
127
-
128
- const today = new Date()
129
- const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
130
-
131
- return currentDate >= todayDate
132
- }
133
-
134
- function getSelectedDate(value = model.value) {
135
- if (!value) return null
136
-
137
- return value.toString().substring(0, 10)
138
- }
139
-
140
- function getSelectedHour(value = model.value) {
141
- if (!value) return null
142
-
143
- const timePart = value.toString().split(' ')[1]
144
- return timePart ? Number(timePart.split(':')[0]) : null
145
- }
146
-
147
- function getSelectedMinutes(value = model.value) {
148
- if (!value) return null
149
-
150
- const timePart = value.toString().split(' ')[1]
151
- return timePart ? Number(timePart.split(':')[1]) : null
152
- }
153
-
154
- function hourOptions(): number[] {
155
- const today = new Date()
156
- const selectedDate = getSelectedDate()
157
- const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
158
-
159
- if (selectedDate !== todayStr) {
160
- return Array.from({ length: 24 }, (_, i) => i)
161
- }
162
-
163
- const currentHour = today.getHours()
164
- return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
165
- }
166
-
167
- function minuteOptions(): number[] {
168
- const today = new Date()
169
- const selectedDate = getSelectedDate()
170
- const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
171
- const selectedHour = getSelectedHour()
172
-
173
- if (selectedDate !== todayStr) {
174
- return Array.from({ length: 60 }, (_, i) => i)
175
- }
176
-
177
- if (selectedHour === today.getHours()) {
178
- const currentMinutes = today.getMinutes()
179
- return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
180
- }
181
-
182
- return Array.from({ length: 60 }, (_, i) => i)
183
- }
184
- </script>
185
-
186
- <style scoped lang="scss">
187
- .datepicker {
188
- :deep(input),
189
- :deep(.q-field--readonly.q-field--float .q-field__native) {
190
- cursor: pointer;
191
- }
192
-
193
- &__label {
194
- font-size: 14px;
195
- font-weight: 700;
196
- color: #7d8592;
197
-
198
- .required {
199
- color: #f65160;
200
- font-weight: bold;
201
- }
202
- }
203
- }
204
- </style>
205
-
206
- <style lang="scss">
207
- .datepicker {
208
- &__wrapper {
209
- display: flex;
210
-
211
- .q-time,
212
- .q-date {
213
- box-shadow: none;
214
- border-radius: 0;
215
- }
216
- }
217
- }
218
- </style>
1
+ <template>
2
+ <div class="datepicker">
3
+ <app-input-new
4
+ v-model="model"
5
+ readonly
6
+ input-class="cursor-pointer"
7
+ :label="label"
8
+ :required="required"
9
+ :rules="rules"
10
+ :error="error"
11
+ :disable="disabled"
12
+ placeholder="Выберите дату"
13
+ >
14
+ <q-popup-proxy v-if="!disabled" class="datepicker__wrapper" @update:model-value="updateError">
15
+ <q-date
16
+ :model-value="model"
17
+ :mask="time ? `DD.MM.YYYY ${timeFormat}` : 'DD.MM.YYYY'"
18
+ :options="disablePastDates"
19
+ @update:model-value="updateDate"
20
+ />
21
+ <q-time
22
+ v-if="time"
23
+ v-model="model"
24
+ :mask="`DD.MM.YYYY ${timeFormat}`"
25
+ format24h
26
+ :hour-options="hourOptions()"
27
+ :minute-options="minuteOptions()"
28
+ />
29
+ </q-popup-proxy>
30
+ <template #append>
31
+ <q-icon name="event" class="cursor-pointer"></q-icon>
32
+ </template>
33
+ </app-input-new>
34
+ </div>
35
+ </template>
36
+
37
+ <script setup lang="ts">
38
+ import AppInputNew from '@/common/app-input-new/AppInputNew.vue'
39
+ import { ref, withDefaults, defineEmits, defineProps, defineModel } from 'vue'
40
+ import { date } from 'quasar'
41
+
42
+ interface Props {
43
+ label?: string
44
+ modelValue?: string
45
+ rules?: ((val?: string | number | null) => boolean | string)[]
46
+ disableRuleDates?: string | string[]
47
+ time?: boolean
48
+ noPastDates?: boolean
49
+ disabled?: boolean
50
+ required?: boolean
51
+ timeFormat?: string
52
+ }
53
+ const props = withDefaults(defineProps<Props>(), {
54
+ label: '',
55
+ timeFormat: 'HH:mm',
56
+ rules: () => [],
57
+ disableRuleDates: undefined,
58
+ modelValue: undefined,
59
+ })
60
+
61
+ defineEmits(['update:modelValue'])
62
+
63
+ const model = defineModel<string | null | undefined>()
64
+
65
+ const error = ref(false)
66
+
67
+ const updateError = (state: boolean) => {
68
+ if (props.required && !error.value && !model.value && !state) {
69
+ error.value = true
70
+ }
71
+ }
72
+
73
+ const updateDate = (value: string) => {
74
+ error.value = false
75
+
76
+ if (!props.noPastDates) {
77
+ model.value = value
78
+ return
79
+ }
80
+
81
+ const today = new Date()
82
+ const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
83
+ const selectedDate = getSelectedDate(value)
84
+
85
+ if (selectedDate !== todayStr) {
86
+ model.value = value
87
+ return
88
+ }
89
+
90
+ const selectedHour = getSelectedHour(value)
91
+ const selectedMinutes = getSelectedMinutes(value)
92
+ const currentHour = today.getHours()
93
+ const currentMinutes = today.getMinutes()
94
+
95
+ if (
96
+ (selectedHour || selectedHour === 0) &&
97
+ (selectedMinutes || selectedMinutes === 0) &&
98
+ (selectedHour < currentHour || (selectedHour === currentHour && selectedMinutes < currentMinutes))
99
+ ) {
100
+ today.setHours(currentHour, currentMinutes, 0)
101
+ model.value = date.formatDate(today, `DD.MM.YYYY ${props.timeFormat}`)
102
+ } else {
103
+ model.value = value
104
+ }
105
+ }
106
+
107
+ const disablePastDates = (date: string) => {
108
+ if (!props.noPastDates && !props.disableRuleDates) return true
109
+
110
+ const [year, month, day] = date.split('/')
111
+ const currentDate = new Date(Number(year), Number(month) - 1, Number(day))
112
+ currentDate.setHours(0, 0, 0, 0)
113
+
114
+ if (props.disableRuleDates) {
115
+ if (Array.isArray(props.disableRuleDates)) {
116
+ const firstDate = props.disableRuleDates[0] ? new Date(props.disableRuleDates[0]) : null
117
+ firstDate?.setHours(0, 0, 0, 0)
118
+ const lastDate = props.disableRuleDates[1] ? new Date(props.disableRuleDates[1]) : null
119
+ lastDate?.setHours(0, 0, 0, 0)
120
+
121
+ return (!firstDate || currentDate >= firstDate) && (!lastDate || currentDate <= lastDate)
122
+ } else {
123
+ const firstDate = new Date(props.disableRuleDates)
124
+ return currentDate >= firstDate
125
+ }
126
+ }
127
+
128
+ const today = new Date()
129
+ const todayDate = new Date(today.getFullYear(), today.getMonth(), today.getDate())
130
+
131
+ return currentDate >= todayDate
132
+ }
133
+
134
+ function getSelectedDate(value = model.value) {
135
+ if (!value) return null
136
+
137
+ return value.toString().substring(0, 10)
138
+ }
139
+
140
+ function getSelectedHour(value = model.value) {
141
+ if (!value) return null
142
+
143
+ const timePart = value.toString().split(' ')[1]
144
+ return timePart ? Number(timePart.split(':')[0]) : null
145
+ }
146
+
147
+ function getSelectedMinutes(value = model.value) {
148
+ if (!value) return null
149
+
150
+ const timePart = value.toString().split(' ')[1]
151
+ return timePart ? Number(timePart.split(':')[1]) : null
152
+ }
153
+
154
+ function hourOptions(): number[] {
155
+ const today = new Date()
156
+ const selectedDate = getSelectedDate()
157
+ const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
158
+
159
+ if (selectedDate !== todayStr) {
160
+ return Array.from({ length: 24 }, (_, i) => i)
161
+ }
162
+
163
+ const currentHour = today.getHours()
164
+ return Array.from({ length: 24 - currentHour }, (_, i) => currentHour + i)
165
+ }
166
+
167
+ function minuteOptions(): number[] {
168
+ const today = new Date()
169
+ const selectedDate = getSelectedDate()
170
+ const todayStr = today.toLocaleDateString('ru-RU').slice(0, 10)
171
+ const selectedHour = getSelectedHour()
172
+
173
+ if (selectedDate !== todayStr) {
174
+ return Array.from({ length: 60 }, (_, i) => i)
175
+ }
176
+
177
+ if (selectedHour === today.getHours()) {
178
+ const currentMinutes = today.getMinutes()
179
+ return Array.from({ length: 60 - currentMinutes }, (_, i) => currentMinutes + i)
180
+ }
181
+
182
+ return Array.from({ length: 60 }, (_, i) => i)
183
+ }
184
+ </script>
185
+
186
+ <style scoped lang="scss">
187
+ .datepicker {
188
+ :deep(input),
189
+ :deep(.q-field--readonly.q-field--float .q-field__native) {
190
+ cursor: pointer;
191
+ }
192
+
193
+ &__label {
194
+ font-size: 14px;
195
+ font-weight: 700;
196
+ color: #7d8592;
197
+
198
+ .required {
199
+ color: #f65160;
200
+ font-weight: bold;
201
+ }
202
+ }
203
+ }
204
+ </style>
205
+
206
+ <style lang="scss">
207
+ .datepicker {
208
+ &__wrapper {
209
+ display: flex;
210
+
211
+ .q-time,
212
+ .q-date {
213
+ box-shadow: none;
214
+ border-radius: 0;
215
+ }
216
+ }
217
+ }
218
+ </style>
@@ -1,37 +1,37 @@
1
- <template>
2
- <q-btn-dropdown
3
- v-model="model"
4
- :color="color"
5
- :content-style="{ width: width || '200px', minWidth: height || '200px' }"
6
- >
7
- <template #label>
8
- <slot name="label">
9
- {{ label }}
10
- </slot>
11
- </template>
12
- <template #default>
13
- <slot name="content" />
14
- </template>
15
- </q-btn-dropdown>
16
- </template>
17
-
18
- <script setup lang="ts">
19
- interface Props {
20
- label?: string
21
- color?: string
22
- width?: number
23
- height?: number
24
- }
25
-
26
- const props = defineProps<Props>()
27
-
28
- const model = defineModel<boolean>()
29
- </script>
30
-
31
- <style scoped lang="scss">
32
- .q-btn {
33
- &:before {
34
- box-shadow: none;
35
- }
36
- }
37
- </style>
1
+ <template>
2
+ <q-btn-dropdown
3
+ v-model="model"
4
+ :color="color"
5
+ :content-style="{ width: width || '200px', minWidth: height || '200px' }"
6
+ >
7
+ <template #label>
8
+ <slot name="label">
9
+ {{ label }}
10
+ </slot>
11
+ </template>
12
+ <template #default>
13
+ <slot name="content" />
14
+ </template>
15
+ </q-btn-dropdown>
16
+ </template>
17
+
18
+ <script setup lang="ts">
19
+ interface Props {
20
+ label?: string
21
+ color?: string
22
+ width?: number
23
+ height?: number
24
+ }
25
+
26
+ const props = defineProps<Props>()
27
+
28
+ const model = defineModel<boolean>()
29
+ </script>
30
+
31
+ <style scoped lang="scss">
32
+ .q-btn {
33
+ &:before {
34
+ box-shadow: none;
35
+ }
36
+ }
37
+ </style>