shared-ritm 1.2.125 → 1.2.127

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 (128) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +283 -285
  4. package/dist/shared-ritm.umd.js +8 -8
  5. package/package.json +64 -64
  6. package/src/App.vue +2461 -2461
  7. package/src/api/services/AuthService.ts +53 -53
  8. package/src/api/services/BrigadesService.ts +32 -32
  9. package/src/api/services/CommentsService.ts +24 -24
  10. package/src/api/services/ControlsService.ts +73 -73
  11. package/src/api/services/EquipmentService.ts +29 -29
  12. package/src/api/services/FileService.ts +17 -17
  13. package/src/api/services/GanttService.ts +17 -17
  14. package/src/api/services/InstrumentsService.ts +63 -63
  15. package/src/api/services/MetricsService.ts +110 -110
  16. package/src/api/services/ModulesService.ts +27 -27
  17. package/src/api/services/ProjectsService.ts +79 -79
  18. package/src/api/services/RepairsService.ts +123 -123
  19. package/src/api/services/SearchService.ts +22 -22
  20. package/src/api/services/TasksService.ts +145 -145
  21. package/src/api/services/UserService.ts +101 -101
  22. package/src/api/services/VideoService.ts +71 -71
  23. package/src/api/settings/ApiService.ts +124 -124
  24. package/src/api/types/Api_Auth.ts +86 -86
  25. package/src/api/types/Api_Brigades.ts +36 -36
  26. package/src/api/types/Api_Comment.ts +40 -40
  27. package/src/api/types/Api_Controls.ts +93 -93
  28. package/src/api/types/Api_Equipment.ts +3 -3
  29. package/src/api/types/Api_Files.ts +7 -7
  30. package/src/api/types/Api_Instruments.ts +136 -136
  31. package/src/api/types/Api_Modules.ts +21 -21
  32. package/src/api/types/Api_Projects.ts +60 -60
  33. package/src/api/types/Api_Repairs.ts +117 -117
  34. package/src/api/types/Api_Search.ts +77 -77
  35. package/src/api/types/Api_Service.ts +9 -9
  36. package/src/api/types/Api_Tasks.ts +319 -319
  37. package/src/api/types/Api_User.ts +117 -117
  38. package/src/api/types/Api_Video.ts +140 -140
  39. package/src/common/app-button/AppButton.vue +173 -173
  40. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  41. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  42. package/src/common/app-datepicker/AppDatepicker.vue +165 -165
  43. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  44. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  45. package/src/common/app-icon/AppIcon.vue +108 -108
  46. package/src/common/app-input/AppInput.vue +148 -148
  47. package/src/common/app-input-new/AppInputNew.vue +175 -175
  48. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  49. package/src/common/app-layout/AppLayout.vue +84 -84
  50. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  51. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  52. package/src/common/app-loader/index.vue +43 -43
  53. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  54. package/src/common/app-select/AppSelect.vue +157 -157
  55. package/src/common/app-sheet/AppSheet.vue +120 -120
  56. package/src/common/app-sheet-new/AppSheetNew.vue +246 -246
  57. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  58. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  59. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  60. package/src/common/app-table/AppTable.vue +308 -308
  61. package/src/common/app-table/AppTableLayout.vue +137 -137
  62. package/src/common/app-table/components/ModalSelect.vue +281 -281
  63. package/src/common/app-table/components/TableModal.vue +356 -356
  64. package/src/common/app-table/components/TablePagination.vue +152 -152
  65. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  66. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  67. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  68. package/src/common/app-toggle/AppToggle.vue +24 -24
  69. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  70. package/src/global.d.ts +1 -1
  71. package/src/icons/components/arrow-down-icon.vue +25 -25
  72. package/src/icons/components/arrow-frame-icon.vue +19 -19
  73. package/src/icons/components/arrow-square.vue +22 -22
  74. package/src/icons/components/table-filter-icon.vue +30 -30
  75. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  76. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  77. package/src/icons/header/NotificationIcon.vue +18 -18
  78. package/src/icons/header/PersonIcon.vue +11 -11
  79. package/src/icons/header/SettingIcon.vue +14 -14
  80. package/src/icons/header/flashIcon.vue +24 -24
  81. package/src/icons/header/searchStatusIcon.vue +24 -24
  82. package/src/icons/header/smallCapsIcon.vue +34 -34
  83. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  84. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  85. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  86. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  87. package/src/icons/sidebar/instruments-icon.vue +45 -45
  88. package/src/icons/sidebar/logo-icon.vue +15 -15
  89. package/src/icons/sidebar/logout-icon.vue +13 -13
  90. package/src/icons/sidebar/modules-icon.vue +16 -16
  91. package/src/icons/sidebar/notifications-icon.vue +24 -24
  92. package/src/icons/sidebar/order-icon.vue +44 -44
  93. package/src/icons/sidebar/pass-icon.vue +38 -38
  94. package/src/icons/sidebar/positions-icon.vue +42 -42
  95. package/src/icons/sidebar/preorder-icon.vue +19 -19
  96. package/src/icons/sidebar/projects-icon.vue +31 -31
  97. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  98. package/src/icons/sidebar/repairs-icon.vue +20 -20
  99. package/src/icons/sidebar/roles-icon.vue +26 -26
  100. package/src/icons/sidebar/status-history-icon.vue +24 -24
  101. package/src/icons/sidebar/tasks-icon.vue +28 -28
  102. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  103. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  104. package/src/icons/sidebar/teams-icon.vue +32 -32
  105. package/src/icons/sidebar/user-icon.vue +18 -18
  106. package/src/icons/sidebar/users-icon.vue +46 -46
  107. package/src/icons/sidebar/videosources-icon.vue +19 -19
  108. package/src/icons/sidebar/videowall-icon.vue +13 -13
  109. package/src/icons/sidebar/videozones-icon.vue +21 -21
  110. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  111. package/src/icons/sidebar/workshop-icon.vue +100 -100
  112. package/src/icons/sidebar/workzones-icon.vue +22 -22
  113. package/src/icons/task/attention-icon.vue +13 -13
  114. package/src/icons/task/clock-icon.vue +10 -10
  115. package/src/icons/task/delete-icon.vue +10 -10
  116. package/src/icons/task/fire-icon.vue +16 -16
  117. package/src/index.ts +123 -123
  118. package/src/main.ts +28 -28
  119. package/src/quasar-user-options.ts +17 -17
  120. package/src/router/index.ts +10 -10
  121. package/src/shared/styles/general.css +124 -124
  122. package/src/shims-vue.d.ts +5 -5
  123. package/src/styles/variables.sass +12 -12
  124. package/src/utils/confirm.ts +12 -12
  125. package/src/utils/faceApiHelper.ts +132 -132
  126. package/src/utils/helpers.ts +59 -59
  127. package/src/utils/notification.ts +9 -9
  128. package/dist/types/api/services/PhotoService.d.ts +0 -40
@@ -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>