shared-ritm 1.2.137 → 1.2.139

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 (133) hide show
  1. package/README.md +103 -103
  2. package/dist/index.css +1 -1
  3. package/dist/shared-ritm.es.js +174 -166
  4. package/dist/shared-ritm.umd.js +38 -38
  5. package/dist/types/api/services/PhotoService.d.ts +40 -0
  6. package/dist/types/api/services/RepairsService.d.ts +1 -1
  7. package/dist/types/api/types/Api_Repairs.d.ts +8 -11
  8. package/dist/types/api/types/Api_Tasks.d.ts +1 -1
  9. package/package.json +64 -64
  10. package/src/App.vue +2461 -2461
  11. package/src/api/services/AuthService.ts +53 -53
  12. package/src/api/services/BrigadesService.ts +32 -32
  13. package/src/api/services/CommentsService.ts +24 -24
  14. package/src/api/services/ControlsService.ts +92 -92
  15. package/src/api/services/EquipmentService.ts +29 -29
  16. package/src/api/services/FileService.ts +17 -17
  17. package/src/api/services/GanttService.ts +17 -17
  18. package/src/api/services/InstrumentsService.ts +63 -63
  19. package/src/api/services/MetricsService.ts +110 -110
  20. package/src/api/services/ModulesService.ts +27 -27
  21. package/src/api/services/ProjectsService.ts +83 -83
  22. package/src/api/services/RepairsService.ts +124 -124
  23. package/src/api/services/ScheduleService.ts +69 -69
  24. package/src/api/services/SearchService.ts +22 -22
  25. package/src/api/services/TasksService.ts +145 -145
  26. package/src/api/services/UserService.ts +113 -113
  27. package/src/api/services/VideoService.ts +103 -103
  28. package/src/api/settings/ApiService.ts +124 -124
  29. package/src/api/types/Api_Auth.ts +86 -86
  30. package/src/api/types/Api_Brigades.ts +36 -36
  31. package/src/api/types/Api_Comment.ts +40 -40
  32. package/src/api/types/Api_Controls.ts +111 -111
  33. package/src/api/types/Api_Equipment.ts +3 -3
  34. package/src/api/types/Api_Files.ts +7 -7
  35. package/src/api/types/Api_Instruments.ts +136 -136
  36. package/src/api/types/Api_Modules.ts +21 -21
  37. package/src/api/types/Api_Projects.ts +61 -61
  38. package/src/api/types/Api_Repairs.ts +140 -138
  39. package/src/api/types/Api_Schedule.ts +64 -64
  40. package/src/api/types/Api_Search.ts +79 -79
  41. package/src/api/types/Api_Service.ts +9 -9
  42. package/src/api/types/Api_Tasks.ts +319 -319
  43. package/src/api/types/Api_User.ts +140 -140
  44. package/src/api/types/Api_Video.ts +145 -145
  45. package/src/common/app-button/AppButton.vue +173 -173
  46. package/src/common/app-checkbox/AppCheckbox.vue +26 -26
  47. package/src/common/app-date-picker/AppDatePicker.vue +81 -81
  48. package/src/common/app-datepicker/AppDatepicker.vue +176 -166
  49. package/src/common/app-dialogs/AppConfirmDialog.vue +99 -99
  50. package/src/common/app-dropdown/AppDropdown.vue +37 -37
  51. package/src/common/app-icon/AppIcon.vue +108 -108
  52. package/src/common/app-input/AppInput.vue +148 -148
  53. package/src/common/app-input-new/AppInputNew.vue +175 -175
  54. package/src/common/app-input-search/AppInputSearch.vue +174 -174
  55. package/src/common/app-layout/AppLayout.vue +84 -84
  56. package/src/common/app-layout/components/AppLayoutHeader.vue +273 -273
  57. package/src/common/app-layout/components/AppLayoutPage.vue +16 -16
  58. package/src/common/app-loader/index.vue +43 -43
  59. package/src/common/app-page-layout/AppPageLayout.vue +122 -122
  60. package/src/common/app-select/AppSelect.vue +157 -157
  61. package/src/common/app-sheet/AppSheet.vue +120 -120
  62. package/src/common/app-sheet-new/AppSheetNew.vue +244 -244
  63. package/src/common/app-sidebar/AppSidebar.vue +168 -168
  64. package/src/common/app-sidebar/components/SidebarMenu.vue +37 -37
  65. package/src/common/app-sidebar/components/SidebarMenuItem.vue +148 -148
  66. package/src/common/app-table/AppTable.vue +308 -308
  67. package/src/common/app-table/AppTableLayout.vue +137 -137
  68. package/src/common/app-table/components/ModalSelect.vue +285 -285
  69. package/src/common/app-table/components/TableModal.vue +356 -356
  70. package/src/common/app-table/components/TablePagination.vue +152 -152
  71. package/src/common/app-table/controllers/useBaseTable.ts +45 -45
  72. package/src/common/app-table/controllers/useColumnSelector.ts +38 -38
  73. package/src/common/app-table/controllers/useTableModel.ts +102 -102
  74. package/src/common/app-toggle/AppToggle.vue +24 -24
  75. package/src/common/app-wrapper/AppWrapper.vue +28 -28
  76. package/src/global.d.ts +1 -1
  77. package/src/icons/components/arrow-down-icon.vue +25 -25
  78. package/src/icons/components/arrow-frame-icon.vue +19 -19
  79. package/src/icons/components/arrow-square.vue +22 -22
  80. package/src/icons/components/table-filter-icon.vue +30 -30
  81. package/src/icons/dialogs/RemoveIcon.vue +12 -12
  82. package/src/icons/dialogs/SafetyIcon.vue +12 -12
  83. package/src/icons/header/NotificationIcon.vue +18 -18
  84. package/src/icons/header/PersonIcon.vue +11 -11
  85. package/src/icons/header/SettingIcon.vue +14 -14
  86. package/src/icons/header/flashIcon.vue +24 -24
  87. package/src/icons/header/searchStatusIcon.vue +24 -24
  88. package/src/icons/header/smallCapsIcon.vue +34 -34
  89. package/src/icons/sidebar/assign-module-icon.vue +36 -36
  90. package/src/icons/sidebar/instrument-history-icon.vue +32 -32
  91. package/src/icons/sidebar/instrument-order-icon.vue +38 -38
  92. package/src/icons/sidebar/instrument-work-zone-icon.vue +18 -18
  93. package/src/icons/sidebar/instruments-icon.vue +45 -45
  94. package/src/icons/sidebar/logo-icon.vue +15 -15
  95. package/src/icons/sidebar/logout-icon.vue +13 -13
  96. package/src/icons/sidebar/modules-icon.vue +16 -16
  97. package/src/icons/sidebar/notifications-icon.vue +24 -24
  98. package/src/icons/sidebar/order-icon.vue +44 -44
  99. package/src/icons/sidebar/pass-icon.vue +38 -38
  100. package/src/icons/sidebar/positions-icon.vue +42 -42
  101. package/src/icons/sidebar/preorder-icon.vue +19 -19
  102. package/src/icons/sidebar/projects-icon.vue +31 -31
  103. package/src/icons/sidebar/repair-object-icon.vue +18 -18
  104. package/src/icons/sidebar/repairs-icon.vue +20 -20
  105. package/src/icons/sidebar/roles-icon.vue +26 -26
  106. package/src/icons/sidebar/status-history-icon.vue +24 -24
  107. package/src/icons/sidebar/tasks-icon.vue +28 -28
  108. package/src/icons/sidebar/tasks_tasks-icon.vue +39 -39
  109. package/src/icons/sidebar/tasks_today-icon.vue +27 -27
  110. package/src/icons/sidebar/teams-icon.vue +32 -32
  111. package/src/icons/sidebar/user-icon.vue +18 -18
  112. package/src/icons/sidebar/users-icon.vue +46 -46
  113. package/src/icons/sidebar/videosources-icon.vue +19 -19
  114. package/src/icons/sidebar/videowall-icon.vue +13 -13
  115. package/src/icons/sidebar/videozones-icon.vue +21 -21
  116. package/src/icons/sidebar/warehouses-icon.vue +43 -43
  117. package/src/icons/sidebar/workshop-icon.vue +100 -100
  118. package/src/icons/sidebar/workzones-icon.vue +22 -22
  119. package/src/icons/task/attention-icon.vue +13 -13
  120. package/src/icons/task/clock-icon.vue +10 -10
  121. package/src/icons/task/delete-icon.vue +10 -10
  122. package/src/icons/task/fire-icon.vue +16 -16
  123. package/src/index.ts +126 -126
  124. package/src/main.ts +28 -28
  125. package/src/quasar-user-options.ts +17 -17
  126. package/src/router/index.ts +10 -10
  127. package/src/shared/styles/general.css +124 -124
  128. package/src/shims-vue.d.ts +5 -5
  129. package/src/styles/variables.sass +12 -12
  130. package/src/utils/confirm.ts +12 -12
  131. package/src/utils/faceApiHelper.ts +132 -132
  132. package/src/utils/helpers.ts +59 -59
  133. package/src/utils/notification.ts +9 -9
@@ -1,285 +1,285 @@
1
- <template>
2
- <label v-if="label" class="field-label">
3
- {{ label }}
4
- <span v-if="rules?.length && isShowRequired" class="required">*</span>
5
- </label>
6
-
7
- <q-select
8
- ref="select"
9
- v-model="selected"
10
- :options="filteredOptions"
11
- :disable="isDisabled"
12
- :multiple="multiple"
13
- :popup-content-class="'custom-select-menu'"
14
- :hide-selected="!showChip && !simple"
15
- :placeholder="isEmpty ? placeholder : null"
16
- :loading="loading"
17
- :option-value="optionValue || 'value'"
18
- :option-label="optionLabel || 'label'"
19
- emit-value
20
- filled
21
- map-options
22
- stack-label
23
- use-input
24
- :use-chips="!simple"
25
- :hide-bottom-space="hideBottomSpace"
26
- input-debounce="100"
27
- autocomplete=""
28
- :rules="rules"
29
- @virtual-scroll="onScroll"
30
- @filter="filterFn"
31
- >
32
- <template v-if="multiple || showChip || 'selected' in slots" #selected-item="scope">
33
- <slot v-if="'selected' in slots && scope.opt" name="selected" :opt="scope.opt" />
34
- <q-chip
35
- v-else-if="scope.opt"
36
- removable
37
- :tabindex="scope.tabindex"
38
- :style="{ backgroundColor: chipColor }"
39
- icon-remove="close"
40
- text-color="secondary"
41
- @remove="scope.removeAtIndex(scope.index)"
42
- >
43
- {{ scope.opt[optionLabel || 'label'] }}
44
- </q-chip>
45
- </template>
46
-
47
- <template #append>
48
- <q-icon
49
- v-if="!isDisabled && !isEmpty"
50
- name="close"
51
- class="cursor-pointer clear-input"
52
- @click.stop="handleClear"
53
- />
54
- </template>
55
-
56
- <template #no-option>
57
- <div class="q-pa-sm">
58
- <q-item>
59
- <q-item-section class="wrapper-empty-text">
60
- {{ emptyText || 'Ничего не найдено' }}
61
- <button
62
- v-if="allowCreate && internalSearch && internalSearch.trim()"
63
- class="add-new-items"
64
- @click="handleCreateFromSearch"
65
- >
66
- Добавить
67
- </button>
68
- </q-item-section>
69
- </q-item>
70
- </div>
71
- </template>
72
-
73
- <template #option="scope">
74
- <q-item v-if="scope.opt.__loading" class="q-py-md q-ml-md">
75
- <q-spinner-dots size="24px" color="primary" />
76
- </q-item>
77
- <q-item v-else-if="'option' in slots" v-bind="scope.itemProps">
78
- <slot name="option" :opt="scope.opt" />
79
- </q-item>
80
- <q-item v-else v-bind="scope.itemProps">
81
- <q-item-section>{{ scope.opt[optionLabel || 'label'] }}</q-item-section>
82
- </q-item>
83
- </template>
84
- </q-select>
85
- </template>
86
-
87
- <script setup lang="ts">
88
- import { computed, defineEmits, defineProps, ref, Ref, useSlots } from 'vue'
89
- type Option = Record<string, any>
90
-
91
- interface AppQSelectProps {
92
- modelValue: any
93
- options: Option[]
94
- placeholder?: string | undefined
95
- emptyText?: string
96
- optionLabel?: string
97
- optionValue?: string
98
- label?: string
99
- multiple?: boolean
100
- loading?: boolean
101
- isShowRequired?: boolean
102
- isDisabled?: boolean
103
- allowCreate?: boolean
104
- isSearch?: boolean
105
- showChip?: boolean
106
- simple?: boolean
107
- hideBottomSpace?: boolean
108
- chipColor?: string
109
- height?: string
110
- borderColor?: string
111
- borderRadius?: string
112
- menuWidth?: string
113
- rules?: ((val: any) => boolean | string)[]
114
- }
115
-
116
- const props = defineProps<AppQSelectProps>()
117
- const emit = defineEmits(['update:modelValue', 'update:scroll', 'update:search', 'clear', 'create'])
118
-
119
- const slots = useSlots()
120
-
121
- const select = ref({})
122
- const lcText: Ref<string> = ref('')
123
- const internalSearch = ref('')
124
-
125
- const selected = computed({
126
- get() {
127
- return props.modelValue
128
- },
129
- set(value) {
130
- emit('update:modelValue', value)
131
- },
132
- })
133
-
134
- const isEmpty = computed(() => {
135
- if (!props.modelValue && props.modelValue !== 0) return true
136
-
137
- return Array.isArray(props.modelValue) && !props.modelValue.length
138
- })
139
-
140
- function handleClear() {
141
- const emptyValue = props.multiple ? [] : null
142
- selected.value = emptyValue
143
- lcText.value = ''
144
- emit('update:modelValue', emptyValue)
145
- emit('clear')
146
- }
147
-
148
- const filteredOptions = computed(() => {
149
- const labelKey = props.optionLabel || 'label'
150
-
151
- const baseOptions =
152
- 'option' in slots
153
- ? props.options
154
- : props.options.filter(x => {
155
- const label = x[labelKey]
156
- return typeof label === 'string' && label.toLowerCase().includes(lcText.value)
157
- })
158
-
159
- if (props.loading) {
160
- return [
161
- ...baseOptions,
162
- {
163
- __loading: true,
164
- label: '__loading__',
165
- value: '__loading__',
166
- },
167
- ]
168
- }
169
-
170
- return baseOptions
171
- })
172
-
173
- function handleCreateFromSearch() {
174
- const labelKey = props.optionLabel || 'label'
175
- const valueKey = props.optionValue || 'value'
176
-
177
- const trimmed = internalSearch.value?.trim()
178
- if (!trimmed) return
179
-
180
- const newOption = {
181
- [labelKey]: trimmed,
182
- [valueKey]: trimmed,
183
- }
184
- emit('create', newOption)
185
- handleClear()
186
- }
187
-
188
- function filterFn(val: string, update: (cb: () => void) => void) {
189
- debouncedFilter(val, update)
190
- }
191
-
192
- const debouncedFilter = debounce((val: string, update: (cb: () => void) => void) => {
193
- internalSearch.value = val
194
- emit('update:search', val)
195
- update(() => {
196
- lcText.value = val.toLowerCase()
197
- })
198
- }, 500)
199
-
200
- function onScroll({ to, ref: qSelectRef }) {
201
- const totalOptions = qSelectRef.options.length
202
- if (to >= totalOptions - 1 && !lcText.value) {
203
- emit('update:scroll')
204
- }
205
- }
206
-
207
- function debounce<T>(fn: T, ms) {
208
- let timeoutId
209
- return function (...args) {
210
- clearTimeout(timeoutId)
211
- return new Promise(resolve => {
212
- timeoutId = setTimeout(() => {
213
- resolve(fn(...args))
214
- }, ms)
215
- })
216
- }
217
- }
218
- </script>
219
-
220
- <style lang="scss" scoped>
221
- .wrapper-empty-text {
222
- display: flex;
223
- align-items: center;
224
- justify-content: space-between;
225
- flex-direction: row;
226
- .add-new-items {
227
- background: #3f8cff;
228
- color: #fff;
229
- outline: none;
230
- border: none;
231
- border-radius: 4px;
232
- padding: 5px 10px;
233
- cursor: pointer;
234
- }
235
- }
236
- .field-label {
237
- font-size: 14px;
238
- font-weight: 700;
239
- color: #7d8592;
240
- }
241
- .required {
242
- color: #f65160;
243
- font-weight: bold;
244
- }
245
-
246
- ::v-deep(.q-placeholder) {
247
- color: #7d8592;
248
- }
249
- ::v-deep(.q-field__control) {
250
- border-radius: 8px;
251
- border: 1px solid #d8e0f0;
252
- background: #fff;
253
- box-shadow: 0 1px 2px 0 rgba(184, 200, 224, 0.22);
254
- }
255
- :deep(.q-field__control:before) {
256
- display: none;
257
- }
258
- :global(.q-field--filled.q-field--highlighted .q-field__control:before) {
259
- background: #fff !important;
260
- border: none;
261
- }
262
- ::v-deep(.q-field--with-bottom) {
263
- padding-bottom: 0;
264
- }
265
- ::v-deep(.q-field__bottom) {
266
- padding: 0;
267
- }
268
- .clear-input {
269
- color: #d8e0f0;
270
- }
271
- ::v-deep(.q-chip) {
272
- border-radius: 4px;
273
- background: #e9eff9;
274
- color: #1d425d;
275
- font-family: NunitoSansFont, sans-serif;
276
- font-size: 14px;
277
- height: 30px;
278
- line-height: 30px;
279
- padding: 0 15px;
280
- .q-chip__icon {
281
- color: #3f8cff;
282
- margin-left: 5px;
283
- }
284
- }
285
- </style>
1
+ <template>
2
+ <label v-if="label" class="field-label">
3
+ {{ label }}
4
+ <span v-if="rules?.length && isShowRequired" class="required">*</span>
5
+ </label>
6
+
7
+ <q-select
8
+ ref="select"
9
+ v-model="selected"
10
+ :options="filteredOptions"
11
+ :disable="isDisabled"
12
+ :multiple="multiple"
13
+ :popup-content-class="'custom-select-menu'"
14
+ :hide-selected="!showChip && !simple"
15
+ :placeholder="isEmpty ? placeholder : null"
16
+ :loading="loading"
17
+ :option-value="optionValue || 'value'"
18
+ :option-label="optionLabel || 'label'"
19
+ emit-value
20
+ filled
21
+ map-options
22
+ stack-label
23
+ use-input
24
+ :use-chips="!simple"
25
+ :hide-bottom-space="hideBottomSpace"
26
+ input-debounce="100"
27
+ autocomplete=""
28
+ :rules="rules"
29
+ @virtual-scroll="onScroll"
30
+ @filter="filterFn"
31
+ >
32
+ <template v-if="multiple || showChip || 'selected' in slots" #selected-item="scope">
33
+ <slot v-if="'selected' in slots && scope.opt" name="selected" :opt="scope.opt" />
34
+ <q-chip
35
+ v-else-if="scope.opt"
36
+ removable
37
+ :tabindex="scope.tabindex"
38
+ :style="{ backgroundColor: chipColor }"
39
+ icon-remove="close"
40
+ text-color="secondary"
41
+ @remove="scope.removeAtIndex(scope.index)"
42
+ >
43
+ {{ scope.opt[optionLabel || 'label'] }}
44
+ </q-chip>
45
+ </template>
46
+
47
+ <template #append>
48
+ <q-icon
49
+ v-if="!isDisabled && !isEmpty"
50
+ name="close"
51
+ class="cursor-pointer clear-input"
52
+ @click.stop="handleClear"
53
+ />
54
+ </template>
55
+
56
+ <template #no-option>
57
+ <div class="q-pa-sm">
58
+ <q-item>
59
+ <q-item-section class="wrapper-empty-text">
60
+ {{ emptyText || 'Ничего не найдено' }}
61
+ <button
62
+ v-if="allowCreate && internalSearch && internalSearch.trim()"
63
+ class="add-new-items"
64
+ @click="handleCreateFromSearch"
65
+ >
66
+ Добавить
67
+ </button>
68
+ </q-item-section>
69
+ </q-item>
70
+ </div>
71
+ </template>
72
+
73
+ <template #option="scope">
74
+ <q-item v-if="scope.opt.__loading" class="q-py-md q-ml-md">
75
+ <q-spinner-dots size="24px" color="primary" />
76
+ </q-item>
77
+ <q-item v-else-if="'option' in slots" v-bind="scope.itemProps">
78
+ <slot name="option" :opt="scope.opt" />
79
+ </q-item>
80
+ <q-item v-else v-bind="scope.itemProps">
81
+ <q-item-section>{{ scope.opt[optionLabel || 'label'] }}</q-item-section>
82
+ </q-item>
83
+ </template>
84
+ </q-select>
85
+ </template>
86
+
87
+ <script setup lang="ts">
88
+ import { computed, defineEmits, defineProps, ref, Ref, useSlots } from 'vue'
89
+ type Option = Record<string, any>
90
+
91
+ interface AppQSelectProps {
92
+ modelValue: any
93
+ options: Option[]
94
+ placeholder?: string | undefined
95
+ emptyText?: string
96
+ optionLabel?: string
97
+ optionValue?: string
98
+ label?: string
99
+ multiple?: boolean
100
+ loading?: boolean
101
+ isShowRequired?: boolean
102
+ isDisabled?: boolean
103
+ allowCreate?: boolean
104
+ isSearch?: boolean
105
+ showChip?: boolean
106
+ simple?: boolean
107
+ hideBottomSpace?: boolean
108
+ chipColor?: string
109
+ height?: string
110
+ borderColor?: string
111
+ borderRadius?: string
112
+ menuWidth?: string
113
+ rules?: ((val: any) => boolean | string)[]
114
+ }
115
+
116
+ const props = defineProps<AppQSelectProps>()
117
+ const emit = defineEmits(['update:modelValue', 'update:scroll', 'update:search', 'clear', 'create'])
118
+
119
+ const slots = useSlots()
120
+
121
+ const select = ref({})
122
+ const lcText: Ref<string> = ref('')
123
+ const internalSearch = ref('')
124
+
125
+ const selected = computed({
126
+ get() {
127
+ return props.modelValue
128
+ },
129
+ set(value) {
130
+ emit('update:modelValue', value)
131
+ },
132
+ })
133
+
134
+ const isEmpty = computed(() => {
135
+ if (!props.modelValue && props.modelValue !== 0) return true
136
+
137
+ return Array.isArray(props.modelValue) && !props.modelValue.length
138
+ })
139
+
140
+ function handleClear() {
141
+ const emptyValue = props.multiple ? [] : null
142
+ selected.value = emptyValue
143
+ lcText.value = ''
144
+ emit('update:modelValue', emptyValue)
145
+ emit('clear')
146
+ }
147
+
148
+ const filteredOptions = computed(() => {
149
+ const labelKey = props.optionLabel || 'label'
150
+
151
+ const baseOptions =
152
+ 'option' in slots
153
+ ? props.options
154
+ : props.options.filter(x => {
155
+ const label = x[labelKey]
156
+ return typeof label === 'string' && label.toLowerCase().includes(lcText.value)
157
+ })
158
+
159
+ if (props.loading) {
160
+ return [
161
+ ...baseOptions,
162
+ {
163
+ __loading: true,
164
+ label: '__loading__',
165
+ value: '__loading__',
166
+ },
167
+ ]
168
+ }
169
+
170
+ return baseOptions
171
+ })
172
+
173
+ function handleCreateFromSearch() {
174
+ const labelKey = props.optionLabel || 'label'
175
+ const valueKey = props.optionValue || 'value'
176
+
177
+ const trimmed = internalSearch.value?.trim()
178
+ if (!trimmed) return
179
+
180
+ const newOption = {
181
+ [labelKey]: trimmed,
182
+ [valueKey]: trimmed,
183
+ }
184
+ emit('create', newOption)
185
+ handleClear()
186
+ }
187
+
188
+ function filterFn(val: string, update: (cb: () => void) => void) {
189
+ debouncedFilter(val, update)
190
+ }
191
+
192
+ const debouncedFilter = debounce((val: string, update: (cb: () => void) => void) => {
193
+ internalSearch.value = val
194
+ emit('update:search', val)
195
+ update(() => {
196
+ lcText.value = val.toLowerCase()
197
+ })
198
+ }, 500)
199
+
200
+ function onScroll({ to, ref: qSelectRef }) {
201
+ const totalOptions = qSelectRef.options.length
202
+ if (to >= totalOptions - 1 && !lcText.value) {
203
+ emit('update:scroll')
204
+ }
205
+ }
206
+
207
+ function debounce<T>(fn: T, ms) {
208
+ let timeoutId
209
+ return function (...args) {
210
+ clearTimeout(timeoutId)
211
+ return new Promise(resolve => {
212
+ timeoutId = setTimeout(() => {
213
+ resolve(fn(...args))
214
+ }, ms)
215
+ })
216
+ }
217
+ }
218
+ </script>
219
+
220
+ <style lang="scss" scoped>
221
+ .wrapper-empty-text {
222
+ display: flex;
223
+ align-items: center;
224
+ justify-content: space-between;
225
+ flex-direction: row;
226
+ .add-new-items {
227
+ background: #3f8cff;
228
+ color: #fff;
229
+ outline: none;
230
+ border: none;
231
+ border-radius: 4px;
232
+ padding: 5px 10px;
233
+ cursor: pointer;
234
+ }
235
+ }
236
+ .field-label {
237
+ font-size: 14px;
238
+ font-weight: 700;
239
+ color: #7d8592;
240
+ }
241
+ .required {
242
+ color: #f65160;
243
+ font-weight: bold;
244
+ }
245
+
246
+ ::v-deep(.q-placeholder) {
247
+ color: #7d8592;
248
+ }
249
+ ::v-deep(.q-field__control) {
250
+ border-radius: 8px;
251
+ border: 1px solid #d8e0f0;
252
+ background: #fff;
253
+ box-shadow: 0 1px 2px 0 rgba(184, 200, 224, 0.22);
254
+ }
255
+ :deep(.q-field__control:before) {
256
+ display: none;
257
+ }
258
+ :global(.q-field--filled.q-field--highlighted .q-field__control:before) {
259
+ background: #fff !important;
260
+ border: none;
261
+ }
262
+ ::v-deep(.q-field--with-bottom) {
263
+ padding-bottom: 0;
264
+ }
265
+ ::v-deep(.q-field__bottom) {
266
+ padding: 0;
267
+ }
268
+ .clear-input {
269
+ color: #d8e0f0;
270
+ }
271
+ ::v-deep(.q-chip) {
272
+ border-radius: 4px;
273
+ background: #e9eff9;
274
+ color: #1d425d;
275
+ font-family: NunitoSansFont, sans-serif;
276
+ font-size: 14px;
277
+ height: 30px;
278
+ line-height: 30px;
279
+ padding: 0 15px;
280
+ .q-chip__icon {
281
+ color: #3f8cff;
282
+ margin-left: 5px;
283
+ }
284
+ }
285
+ </style>