shared-ritm 1.2.153 → 1.2.154

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 (50) hide show
  1. package/dist/index.css +1 -1
  2. package/dist/shared-ritm.es.js +12 -14
  3. package/dist/shared-ritm.umd.js +6 -6
  4. package/dist/types/api/services/ComentsServise.d.ts +10 -0
  5. package/dist/types/api/services/PhotoService.d.ts +51 -38
  6. package/dist/types/api/types/Api_Tasks.d.ts +1 -0
  7. package/dist/types/api/types/Api_Users.d.ts +43 -0
  8. package/package.json +64 -64
  9. package/src/api/services/BrigadesService.ts +32 -32
  10. package/src/api/services/ControlsService.ts +92 -92
  11. package/src/api/services/EquipmentService.ts +29 -29
  12. package/src/api/services/InstrumentsService.ts +63 -63
  13. package/src/api/services/MetricsService.ts +110 -110
  14. package/src/api/services/ModulesService.ts +27 -27
  15. package/src/api/services/ProjectsService.ts +83 -83
  16. package/src/api/services/RepairsService.ts +124 -124
  17. package/src/api/services/ScheduleService.ts +69 -69
  18. package/src/api/services/SearchService.ts +22 -22
  19. package/src/api/services/UserService.ts +113 -113
  20. package/src/api/services/VideoService.ts +108 -108
  21. package/src/api/settings/ApiService.ts +124 -124
  22. package/src/api/types/Api_Auth.ts +105 -105
  23. package/src/api/types/Api_Brigades.ts +36 -36
  24. package/src/api/types/Api_Controls.ts +111 -111
  25. package/src/api/types/Api_Equipment.ts +3 -3
  26. package/src/api/types/Api_Instruments.ts +136 -136
  27. package/src/api/types/Api_Modules.ts +21 -21
  28. package/src/api/types/Api_Projects.ts +62 -62
  29. package/src/api/types/Api_Repairs.ts +140 -140
  30. package/src/api/types/Api_Schedule.ts +64 -64
  31. package/src/api/types/Api_Search.ts +80 -80
  32. package/src/api/types/Api_Tasks.ts +1 -0
  33. package/src/api/types/Api_User.ts +145 -145
  34. package/src/api/types/Api_Video.ts +198 -198
  35. package/src/common/app-datepicker/AppDatepicker.vue +176 -176
  36. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  37. package/src/common/app-input-new/AppInputNew.vue +175 -175
  38. package/src/common/app-layout/AppLayout.vue +84 -84
  39. package/src/common/app-modal/index.vue +96 -96
  40. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  41. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  42. package/src/common/app-sidebar/components/SidebarMenuItem.vue +149 -149
  43. package/src/common/app-table/AppTable.vue +308 -308
  44. package/src/common/app-table/AppTableLayout.vue +137 -137
  45. package/src/common/app-table/components/ModalSelect.vue +286 -286
  46. package/src/common/app-table/components/TableModal.vue +356 -356
  47. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  48. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  49. package/src/index.ts +128 -128
  50. package/src/styles/variables.sass +12 -12
@@ -1,175 +1,175 @@
1
- <template>
2
- <div class="app-input-new">
3
- <label v-if="label" class="app-input-new__label">
4
- {{ label }}
5
- <span v-if="required" class="required">*</span>
6
- </label>
7
-
8
- <q-input
9
- v-model="model"
10
- filled
11
- :type="inputType"
12
- :rules="rules"
13
- :placeholder="placeholder"
14
- :disable="disable"
15
- :readonly="readonly"
16
- :class="inputClass"
17
- :error="error"
18
- :autocomplete="autocomplete"
19
- @blur="emit('blur')"
20
- >
21
- <slot />
22
- <template #append>
23
- <slot name="append" />
24
- <q-icon
25
- v-if="type === 'password'"
26
- :name="isVisiblePass ? 'visibility' : 'visibility_off'"
27
- color="primary"
28
- class="cursor-pointer"
29
- @click="isVisiblePass = !isVisiblePass"
30
- />
31
- <q-icon
32
- v-if="clearable && String(model)?.length"
33
- name="close"
34
- class="cursor-pointer clear-input"
35
- @click="model = null"
36
- />
37
- <q-btn
38
- v-if="uuid && !disable && !readonly"
39
- flat
40
- no-caps
41
- label="UUID"
42
- size="sm"
43
- class="q-ml-sm uuid-btn"
44
- @click="model = uuidv4()"
45
- />
46
- <q-icon
47
- v-if="copyable"
48
- name="content_copy"
49
- class="cursor-pointer q-ml-sm copy-icon"
50
- color="primary"
51
- :disable="!model"
52
- @click="copyToClipboard"
53
- />
54
- </template>
55
- </q-input>
56
- </div>
57
- </template>
58
-
59
- <script setup lang="ts">
60
- import { defineEmits, defineProps, computed, ref } from 'vue'
61
- import { uuidv4 } from '@/utils/helpers'
62
- import { notificationSettings } from '@/utils/notification'
63
- import { QInputProps, useQuasar } from 'quasar'
64
-
65
- const props = defineProps<
66
- QInputProps & {
67
- modelValue?: string | number | null
68
- label?: string
69
- placeholder?: string
70
- rules?: ((val: string | number | null | undefined) => boolean | string)[]
71
- inputClass?: string
72
- required?: boolean
73
- readonly?: boolean
74
- disable?: boolean
75
- uuid?: boolean
76
- clearable?: boolean
77
- copyable?: boolean
78
- error?: boolean
79
- autocomplete?: string
80
- }
81
- >()
82
-
83
- const emit = defineEmits<{
84
- (e: 'update:modelValue', val?: string | number | null): void
85
- (e: 'blur', val?: string | number | null): void
86
- }>()
87
-
88
- const $q = useQuasar()
89
-
90
- const isVisiblePass = ref(false)
91
-
92
- const model = computed({
93
- get: () => getValue(props.modelValue),
94
- set: (newValue?: string | number | null) => emit('update:modelValue', getValue(newValue)),
95
- })
96
-
97
- const inputType = computed(() => (props.type === 'password' && isVisiblePass.value ? 'text' : props.type))
98
-
99
- const getValue = (value?: string | number | null) => {
100
- if (props.type === 'number') return value ? +value : value
101
-
102
- return value
103
- }
104
-
105
- const copyToClipboard = () => {
106
- if (!model.value && model.value !== 0) return
107
-
108
- navigator.clipboard.writeText(model.value.toString()).then(() => {
109
- $q.notify(notificationSettings('success', 'Данные скопированы'))
110
- })
111
- }
112
- </script>
113
-
114
- <style scoped lang="scss">
115
- .app-input-new {
116
- display: flex;
117
- flex-direction: column;
118
- margin-bottom: 15px;
119
-
120
- &__label {
121
- font-size: 14px;
122
- font-weight: 700;
123
- color: #7d8592;
124
- }
125
-
126
- .required {
127
- color: #f65160;
128
- font-weight: bold;
129
- }
130
-
131
- .clear-input {
132
- color: #d8e0f0;
133
- }
134
-
135
- .uuid-btn {
136
- height: 32px;
137
- padding: 0 10px;
138
- border: 1px solid #3f8cff;
139
- color: #3f8cff;
140
- font-weight: 700;
141
- font-size: 14px;
142
- background: white;
143
- border-radius: 6px;
144
-
145
- :deep(.block) {
146
- line-height: normal;
147
- }
148
- }
149
-
150
- :deep(.q-placeholder) {
151
- color: #7d8592;
152
- }
153
-
154
- :deep(.q-field__control) {
155
- min-height: 58px;
156
- border-radius: 8px;
157
- border: 1px solid #d8e0f0;
158
- background: #fff;
159
- box-shadow: 0 1px 2px 0 rgba(184, 200, 224, 0.22);
160
- }
161
-
162
- :deep(.q-field--filled .q-field__control:before) {
163
- background: #fff !important;
164
- border: none;
165
- }
166
-
167
- :deep(.q-field--with-bottom) {
168
- padding-bottom: 0;
169
- }
170
-
171
- :deep(.q-field__bottom) {
172
- padding: 0;
173
- }
174
- }
175
- </style>
1
+ <template>
2
+ <div class="app-input-new">
3
+ <label v-if="label" class="app-input-new__label">
4
+ {{ label }}
5
+ <span v-if="required" class="required">*</span>
6
+ </label>
7
+
8
+ <q-input
9
+ v-model="model"
10
+ filled
11
+ :type="inputType"
12
+ :rules="rules"
13
+ :placeholder="placeholder"
14
+ :disable="disable"
15
+ :readonly="readonly"
16
+ :class="inputClass"
17
+ :error="error"
18
+ :autocomplete="autocomplete"
19
+ @blur="emit('blur')"
20
+ >
21
+ <slot />
22
+ <template #append>
23
+ <slot name="append" />
24
+ <q-icon
25
+ v-if="type === 'password'"
26
+ :name="isVisiblePass ? 'visibility' : 'visibility_off'"
27
+ color="primary"
28
+ class="cursor-pointer"
29
+ @click="isVisiblePass = !isVisiblePass"
30
+ />
31
+ <q-icon
32
+ v-if="clearable && String(model)?.length"
33
+ name="close"
34
+ class="cursor-pointer clear-input"
35
+ @click="model = null"
36
+ />
37
+ <q-btn
38
+ v-if="uuid && !disable && !readonly"
39
+ flat
40
+ no-caps
41
+ label="UUID"
42
+ size="sm"
43
+ class="q-ml-sm uuid-btn"
44
+ @click="model = uuidv4()"
45
+ />
46
+ <q-icon
47
+ v-if="copyable"
48
+ name="content_copy"
49
+ class="cursor-pointer q-ml-sm copy-icon"
50
+ color="primary"
51
+ :disable="!model"
52
+ @click="copyToClipboard"
53
+ />
54
+ </template>
55
+ </q-input>
56
+ </div>
57
+ </template>
58
+
59
+ <script setup lang="ts">
60
+ import { defineEmits, defineProps, computed, ref } from 'vue'
61
+ import { uuidv4 } from '@/utils/helpers'
62
+ import { notificationSettings } from '@/utils/notification'
63
+ import { QInputProps, useQuasar } from 'quasar'
64
+
65
+ const props = defineProps<
66
+ QInputProps & {
67
+ modelValue?: string | number | null
68
+ label?: string
69
+ placeholder?: string
70
+ rules?: ((val: string | number | null | undefined) => boolean | string)[]
71
+ inputClass?: string
72
+ required?: boolean
73
+ readonly?: boolean
74
+ disable?: boolean
75
+ uuid?: boolean
76
+ clearable?: boolean
77
+ copyable?: boolean
78
+ error?: boolean
79
+ autocomplete?: string
80
+ }
81
+ >()
82
+
83
+ const emit = defineEmits<{
84
+ (e: 'update:modelValue', val?: string | number | null): void
85
+ (e: 'blur', val?: string | number | null): void
86
+ }>()
87
+
88
+ const $q = useQuasar()
89
+
90
+ const isVisiblePass = ref(false)
91
+
92
+ const model = computed({
93
+ get: () => getValue(props.modelValue),
94
+ set: (newValue?: string | number | null) => emit('update:modelValue', getValue(newValue)),
95
+ })
96
+
97
+ const inputType = computed(() => (props.type === 'password' && isVisiblePass.value ? 'text' : props.type))
98
+
99
+ const getValue = (value?: string | number | null) => {
100
+ if (props.type === 'number') return value ? +value : value
101
+
102
+ return value
103
+ }
104
+
105
+ const copyToClipboard = () => {
106
+ if (!model.value && model.value !== 0) return
107
+
108
+ navigator.clipboard.writeText(model.value.toString()).then(() => {
109
+ $q.notify(notificationSettings('success', 'Данные скопированы'))
110
+ })
111
+ }
112
+ </script>
113
+
114
+ <style scoped lang="scss">
115
+ .app-input-new {
116
+ display: flex;
117
+ flex-direction: column;
118
+ margin-bottom: 15px;
119
+
120
+ &__label {
121
+ font-size: 14px;
122
+ font-weight: 700;
123
+ color: #7d8592;
124
+ }
125
+
126
+ .required {
127
+ color: #f65160;
128
+ font-weight: bold;
129
+ }
130
+
131
+ .clear-input {
132
+ color: #d8e0f0;
133
+ }
134
+
135
+ .uuid-btn {
136
+ height: 32px;
137
+ padding: 0 10px;
138
+ border: 1px solid #3f8cff;
139
+ color: #3f8cff;
140
+ font-weight: 700;
141
+ font-size: 14px;
142
+ background: white;
143
+ border-radius: 6px;
144
+
145
+ :deep(.block) {
146
+ line-height: normal;
147
+ }
148
+ }
149
+
150
+ :deep(.q-placeholder) {
151
+ color: #7d8592;
152
+ }
153
+
154
+ :deep(.q-field__control) {
155
+ min-height: 58px;
156
+ border-radius: 8px;
157
+ border: 1px solid #d8e0f0;
158
+ background: #fff;
159
+ box-shadow: 0 1px 2px 0 rgba(184, 200, 224, 0.22);
160
+ }
161
+
162
+ :deep(.q-field--filled .q-field__control:before) {
163
+ background: #fff !important;
164
+ border: none;
165
+ }
166
+
167
+ :deep(.q-field--with-bottom) {
168
+ padding-bottom: 0;
169
+ }
170
+
171
+ :deep(.q-field__bottom) {
172
+ padding: 0;
173
+ }
174
+ }
175
+ </style>
@@ -1,84 +1,84 @@
1
- <template>
2
- <q-layout :class="$style.layout" view="lHh LpR fFf">
3
- <div v-if="logged" :class="$style['loader-backdrop']">
4
- <app-loader :loading="logged" size="md" :thickness="3" :backdrop="true" />
5
- </div>
6
-
7
- <slot name="drawer" />
8
- <slot name="header" :style="marginLeft" />
9
-
10
- <q-page-container :class="{ container: container }" @wheel="mouseMove">
11
- <slot name="content" :style="marginLeft" />
12
- </q-page-container>
13
-
14
- <slot name="footer" />
15
- </q-layout>
16
- </template>
17
-
18
- <script lang="ts" setup>
19
- import { computed, defineProps, nextTick, onBeforeUnmount, onMounted, ref } from 'vue'
20
- import AppLoader from '@/common/app-loader/index.vue'
21
- interface LayoutProps {
22
- logged: boolean
23
- console?: boolean
24
- container?: boolean
25
- padding?: string
26
- }
27
-
28
- const props = defineProps<LayoutProps>()
29
-
30
- const hasPaddingLeft = ref(false)
31
-
32
- function mouseMove(e: any) {
33
- const content = document.getElementById('content')
34
- const scrollable = e.target
35
- if (content && !scrollable.closest('#content')) {
36
- content.scrollBy({ top: e.deltaY })
37
- }
38
- }
39
-
40
- const marginLeft = computed(() => {
41
- return hasPaddingLeft.value ? { 'margin-left': '0px' } : { 'margin-left': '72px' }
42
- })
43
-
44
- function checkPaddingLeft() {
45
- const el = document.querySelector('.q-page-container') as HTMLElement | null
46
-
47
- if (el) {
48
- nextTick(() => {
49
- const observer = new ResizeObserver(() => {
50
- hasPaddingLeft.value = window.getComputedStyle(el).paddingLeft !== '0px'
51
- })
52
- observer.observe(el)
53
- onBeforeUnmount(() => observer.disconnect())
54
- })
55
- }
56
- }
57
-
58
- onMounted(() => {
59
- checkPaddingLeft()
60
- })
61
- </script>
62
-
63
- <style lang="scss" module>
64
- .layout {
65
- position: relative;
66
- background: linear-gradient(235deg, #87caff 9.16%, #5386d3 45.8%, #0b3f8e 92.27%);
67
- }
68
- .loader {
69
- &-backdrop {
70
- width: 100%;
71
- height: 100%;
72
- background-color: rgba(255, 255, 255, 0.1);
73
- position: absolute;
74
- right: 0;
75
- z-index: 2999;
76
- }
77
- &-spinner {
78
- position: absolute;
79
- top: 50%;
80
- left: 50%;
81
- z-index: 2;
82
- }
83
- }
84
- </style>
1
+ <template>
2
+ <q-layout :class="$style.layout" view="lHh LpR fFf">
3
+ <div v-if="logged" :class="$style['loader-backdrop']">
4
+ <app-loader :loading="logged" size="md" :thickness="3" :backdrop="true" />
5
+ </div>
6
+
7
+ <slot name="drawer" />
8
+ <slot name="header" :style="marginLeft" />
9
+
10
+ <q-page-container :class="{ container: container }" @wheel="mouseMove">
11
+ <slot name="content" :style="marginLeft" />
12
+ </q-page-container>
13
+
14
+ <slot name="footer" />
15
+ </q-layout>
16
+ </template>
17
+
18
+ <script lang="ts" setup>
19
+ import { computed, defineProps, nextTick, onBeforeUnmount, onMounted, ref } from 'vue'
20
+ import AppLoader from '@/common/app-loader/index.vue'
21
+ interface LayoutProps {
22
+ logged: boolean
23
+ console?: boolean
24
+ container?: boolean
25
+ padding?: string
26
+ }
27
+
28
+ const props = defineProps<LayoutProps>()
29
+
30
+ const hasPaddingLeft = ref(false)
31
+
32
+ function mouseMove(e: any) {
33
+ const content = document.getElementById('content')
34
+ const scrollable = e.target
35
+ if (content && !scrollable.closest('#content')) {
36
+ content.scrollBy({ top: e.deltaY })
37
+ }
38
+ }
39
+
40
+ const marginLeft = computed(() => {
41
+ return hasPaddingLeft.value ? { 'margin-left': '0px' } : { 'margin-left': '72px' }
42
+ })
43
+
44
+ function checkPaddingLeft() {
45
+ const el = document.querySelector('.q-page-container') as HTMLElement | null
46
+
47
+ if (el) {
48
+ nextTick(() => {
49
+ const observer = new ResizeObserver(() => {
50
+ hasPaddingLeft.value = window.getComputedStyle(el).paddingLeft !== '0px'
51
+ })
52
+ observer.observe(el)
53
+ onBeforeUnmount(() => observer.disconnect())
54
+ })
55
+ }
56
+ }
57
+
58
+ onMounted(() => {
59
+ checkPaddingLeft()
60
+ })
61
+ </script>
62
+
63
+ <style lang="scss" module>
64
+ .layout {
65
+ position: relative;
66
+ background: linear-gradient(235deg, #87caff 9.16%, #5386d3 45.8%, #0b3f8e 92.27%);
67
+ }
68
+ .loader {
69
+ &-backdrop {
70
+ width: 100%;
71
+ height: 100%;
72
+ background-color: rgba(255, 255, 255, 0.1);
73
+ position: absolute;
74
+ right: 0;
75
+ z-index: 2999;
76
+ }
77
+ &-spinner {
78
+ position: absolute;
79
+ top: 50%;
80
+ left: 50%;
81
+ z-index: 2;
82
+ }
83
+ }
84
+ </style>