bfg-common 1.4.734 → 1.4.799

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 (84) hide show
  1. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  2. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  3. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  5. package/assets/localization/local_be.json +2 -16
  6. package/assets/localization/local_en.json +2 -16
  7. package/assets/localization/local_hy.json +2 -16
  8. package/assets/localization/local_kk.json +2 -16
  9. package/assets/localization/local_ru.json +2 -16
  10. package/assets/localization/local_zh.json +2 -16
  11. package/components/atoms/select/TheSelect.vue +1 -10
  12. package/components/common/browse/blocks/lib/models/types.ts +1 -1
  13. package/components/common/browse/lib/models/interfaces.ts +5 -5
  14. package/components/common/{monitor/advanced/tools/chartOptionsModal → chartOptionsModal}/counters/timespan/form/Form.vue +544 -539
  15. package/components/common/{pages/hardwareHealth/historyTestimony/tools/chartOptionsModal → chartOptionsModal}/counters/timespan/form/lib/config/dateForm.ts +116 -115
  16. package/components/common/diagramMain/Header.vue +211 -211
  17. package/components/common/diagramMain/adapter/AdapterItems.vue +61 -61
  18. package/components/common/diagramMain/lib/config/initial.ts +50 -50
  19. package/components/common/diagramMain/lib/models/types.ts +21 -21
  20. package/components/common/diagramMain/lib/utils/utils.ts +331 -331
  21. package/components/common/diagramMain/modals/ManagePhysicalAdaptersModal.vue +330 -330
  22. package/components/common/diagramMain/modals/editSettings/ConfirmTeamingSettingsModal.vue +40 -40
  23. package/components/common/diagramMain/modals/editSettings/EditSettings.vue +497 -497
  24. package/components/common/diagramMain/modals/editSettings/EditSettingsModal.vue +812 -812
  25. package/components/common/diagramMain/modals/editSettings/tabs/NetworkProperties.vue +214 -214
  26. package/components/common/diagramMain/modals/editSettings/tabs/Security.vue +189 -189
  27. package/components/common/diagramMain/modals/editSettings/tabs/SwitchProperties.vue +163 -163
  28. package/components/common/diagramMain/modals/editSettings/tabs/TeamingFailover.vue +175 -175
  29. package/components/common/diagramMain/modals/editSettings/tabs/TrafficShaping.vue +398 -398
  30. package/components/common/diagramMain/modals/editSettings/tabs/port/IpvFourSettings.vue +346 -346
  31. package/components/common/diagramMain/modals/editSettings/tabs/port/PortProperties.vue +205 -205
  32. package/components/common/diagramMain/modals/lib/config/diagramConfig.ts +23 -23
  33. package/components/common/diagramMain/modals/lib/config/initial.ts +180 -180
  34. package/components/common/diagramMain/modals/lib/config/vmKernelAdapter.ts +90 -90
  35. package/components/common/diagramMain/modals/lib/mappers/mappers.ts +87 -87
  36. package/components/common/diagramMain/modals/lib/utils/index.ts +24 -24
  37. package/components/common/diagramMain/modals/migrateVmkernelAdapter/lib/config/steps.ts +114 -114
  38. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/ConnectionSettings.vue +169 -169
  39. package/components/common/diagramMain/modals/migrateVmkernelAdapter/steps/SelectVmkernelAdapter.vue +159 -159
  40. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/common.ts +14 -14
  41. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/connectionSettings.ts +137 -137
  42. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/selectVmkernelAdapter.ts +52 -52
  43. package/components/common/diagramMain/modals/migrateVmkernelAdapter/validations/validations.ts +19 -19
  44. package/components/common/diagramMain/port/Ports.vue +47 -47
  45. package/components/common/monitor/advanced/Advanced.vue +5 -0
  46. package/components/common/monitor/advanced/tools/Tools.vue +9 -2
  47. package/components/common/monitor/advanced/tools/chartOptionsModal/ChartOptionsModal.vue +9 -2
  48. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/Counters.vue +2 -0
  49. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/Timespan.vue +95 -93
  50. package/components/common/monitor/overview/filters/Filters.vue +3 -0
  51. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +15 -5
  52. package/components/common/monitor/overview/filters/customIntervalModal/lib/config/dateChecker.ts +24 -14
  53. package/components/common/pages/hardwareHealth/HardwareHealth.vue +12 -5
  54. package/components/common/pages/hardwareHealth/historyTestimony/Graph.vue +456 -451
  55. package/components/common/pages/hardwareHealth/historyTestimony/tools/Tools.vue +387 -380
  56. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/ChartOptionsModal.vue +13 -6
  57. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/Counters.vue +94 -94
  58. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/timespan/Timespan.vue +66 -66
  59. package/components/common/pages/tasks/Tasks.vue +0 -9
  60. package/components/common/pages/tasks/table/Table.vue +1 -0
  61. package/components/common/pages/tasks/table/errorInfo/ErrorInfo.vue +6 -10
  62. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +8 -8
  63. package/components/common/vm/actions/add/Add.vue +0 -2
  64. package/components/common/vm/actions/clone/Clone.vue +0 -2
  65. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +0 -3
  66. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +0 -2
  67. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +0 -2
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +1 -9
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareNew.vue +2 -5
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardwareOld.vue +1 -3
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/config/dropdownItems.ts +4 -6
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +10 -52
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceNew.vue +5 -31
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDeviceOld.vue +5 -31
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +2 -9
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/lib/config/options.ts +4 -11
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionNew.vue +1 -1
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/typeSelection/TypeSelectionOld.vue +1 -1
  79. package/components/common/vm/actions/editSettings/EditSettings.vue +0 -3
  80. package/components/common/vm/actions/editSettings/EditSettingsOld.vue +0 -2
  81. package/components/common/vm/actions/editSettings/new/New.vue +0 -2
  82. package/package.json +3 -3
  83. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/form/lib/config/dateForm.ts +0 -114
  84. package/components/common/pages/hardwareHealth/historyTestimony/tools/chartOptionsModal/counters/timespan/form/Form.vue +0 -539
@@ -1,539 +1,544 @@
1
- <template>
2
- <div class="chart-option-timespan-split">
3
- <div class="vertical-flex-container">
4
- <div class="timespan-objects-section-direction">
5
- <label for="chart-timespan-type-select"
6
- >{{ localization.inventoryMonitor.timespan }}:</label
7
- >
8
- <div class="vertical-flex-container chart-option-timespan-settings">
9
- <div class="timespan-select chart-option-setting-row">
10
- <div class="view-select-label horizontal-flex-container">
11
- <div class="select">
12
- <select
13
- id="chart-timespan-type-select"
14
- v-model="localSelectedTimespan"
15
- data-id="chart-timespan-type-select"
16
- >
17
- <option
18
- v-for="(item, index) in timespanOptions"
19
- :key="index"
20
- :value="item.value"
21
- >
22
- {{ item.text }}
23
- </option>
24
- </select>
25
- </div>
26
- </div>
27
- </div>
28
- <div
29
- :class="[
30
- 'custom-timespan-settings-container',
31
- { active: localSelectedTimespan === 'custom_interval' },
32
- ]"
33
- >
34
- <table>
35
- <tbody>
36
- <tr>
37
- <td class="relative">
38
- <input
39
- id="custom-time-lastInput"
40
- v-model="localPeriodType"
41
- data-id="custom-time-lastInput"
42
- type="radio"
43
- value="last"
44
- class="custom-radio-button"
45
- name="lastFrom"
46
- />
47
- <label
48
- for="custom-time-lastInput"
49
- class="custom-radio-label"
50
- >
51
- {{ periodTypeText }}:
52
- </label>
53
- </td>
54
- <td>
55
- <div
56
- :class="[
57
- 'custom-timespan-type-last-container',
58
- { active: localPeriodType === 'last' },
59
- ]"
60
- >
61
- <input
62
- id="chart-option-setting-row"
63
- v-model="localLast"
64
- data-id="chart-option-setting-row"
65
- type="number"
66
- class="chart-option-setting-row custom-time-input"
67
- />
68
- <div
69
- class="chart-option-setting-row custom-time-input inline-block"
70
- >
71
- <div
72
- class="view-select-label horizontal-flex-container"
73
- >
74
- <div class="select">
75
- <select
76
- id="chart-timespan-type-select"
77
- v-model="localSelectedCustomTime"
78
- data-id="chart-timespan-type-select"
79
- >
80
- <option
81
- v-for="(item, index) in customTimeOptions"
82
- :key="index"
83
- :value="item.value"
84
- >
85
- {{ item.text }}
86
- </option>
87
- </select>
88
- </div>
89
- </div>
90
- </div>
91
- </div>
92
- </td>
93
- </tr>
94
- <tr>
95
- <td class="relative">
96
- <input
97
- id="custom-time-fromInput"
98
- v-model="localPeriodType"
99
- data-id="custom-time-from-input"
100
- type="radio"
101
- value="period"
102
- class="custom-radio-button"
103
- name="lastFrom"
104
- />
105
- <label
106
- for="custom-time-fromInput"
107
- class="custom-radio-label text-capitalize text-right"
108
- >{{ localization.common.from2 }}:
109
- </label>
110
- </td>
111
- <td>
112
- <div
113
- :class="[
114
- 'date-container-row disabled-container calendar-date-row',
115
- { active: localPeriodType === 'period' },
116
- ]"
117
- >
118
- <input
119
- id="current-date-from"
120
- v-model.lazy="localCurrentDateFrom"
121
- data-id="current-date-from-input"
122
- type="text"
123
- class="chart-option-setting-row custom-time-input first-from"
124
- />
125
- <div class="section-datepicker">
126
- <atoms-datepicker
127
- v-model="dateFrom"
128
- :lang="props.language"
129
- class="calendar-from calendar-popup btn-show-hide-calendar"
130
- @update="onUpdateDateFrom"
131
- />
132
- </div>
133
- <input
134
- id="current-time-from"
135
- v-model="currentTimeFrom"
136
- data-id="current-time-from-input"
137
- type="text"
138
- class="chart-option-setting-row custom-time-input"
139
- />
140
- </div>
141
- </td>
142
- </tr>
143
- <tr>
144
- <td class="custom-time-label-text text-right">
145
- {{ localization.common.to2 }}:
146
- </td>
147
- <td>
148
- <div
149
- :class="[
150
- 'date-container-row disabled-container calendar-date-row',
151
- { active: localPeriodType === 'period' },
152
- ]"
153
- >
154
- <input
155
- id="current-date-to"
156
- v-model.lazy="currentDateTo"
157
- data-id="current-date-to-input"
158
- type="text"
159
- class="chart-option-setting-row custom-time-input first-to"
160
- />
161
- <div class="section-datepicker">
162
- <atoms-datepicker
163
- v-model="dateTo"
164
- :lang="props.language"
165
- class="calendar-from calendar-popup btn-show-hide-calendar"
166
- @update="onUpdateDateTo"
167
- />
168
- </div>
169
- <input
170
- id="current-time-to"
171
- v-model="currentTimeTo"
172
- data-id="current-time-to-input"
173
- type="text"
174
- class="chart-option-setting-row custom-time-input"
175
- />
176
- </div>
177
- </td>
178
- </tr>
179
- <tr>
180
- <td></td>
181
- <td
182
- :class="[
183
- 'disabled-container',
184
- { active: localPeriodType === 'period' },
185
- ]"
186
- >
187
- <span> ({{ localization.inventoryMonitor.isoTimeFormat }}) </span>
188
- </td>
189
- </tr>
190
- </tbody>
191
- </table>
192
- </div>
193
- </div>
194
- </div>
195
- <div class="horizontal-flex-container chart-type-container">
196
- <div class="view-select-label horizontal-flex-container">
197
- <label for="chart-type-select" class="label-select"
198
- >{{ localization.inventoryMonitor.chartType }}:</label
199
- >
200
- <div class="select">
201
- <select
202
- id="chart-type-select"
203
- v-model="chartType"
204
- data-id="chart-type-select"
205
- >
206
- <option
207
- v-for="(item, index) in chartTypeOptions"
208
- :key="index"
209
- :value="item.value"
210
- >
211
- {{ item.text }}
212
- </option>
213
- </select>
214
- </div>
215
- </div>
216
- </div>
217
- </div>
218
- </div>
219
- </template>
220
-
221
- <script setup lang="ts">
222
- import { format } from 'date-fns'
223
- import type { UI_I_Localization } from '~/lib/models/interfaces'
224
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
225
- import {
226
- timespanFunc,
227
- customTimeFunc,
228
- chartTypeFunc,
229
- } from '~/components/common/monitor/advanced/tools/chartOptionsModal/counters/timespan/form/lib/config/dateForm'
230
-
231
- const props = defineProps<{
232
- language: string
233
- selectedChartType: string
234
- selectedTimespanType: string
235
- unitsCount: number
236
- periodType: string
237
- selectedCustomTime: string
238
- customDateFrom: string
239
- customDateTo: string
240
- customTimeFrom: string
241
- customTimeTo: string
242
- }>()
243
-
244
- const emits = defineEmits<{
245
- (event: 'update-chart-type', value: string): void
246
- (event: 'update-custom-time', value: string): void
247
- (event: 'update-timespan-type', value: string): void
248
- (event: 'update-unit-count', value: number): void
249
- (event: 'update-period-type', value: string): void
250
- (event: 'update-custom-date-from', value: string): void
251
- (event: 'update-custom-date-to', value: string): void
252
- (event: 'update-custom-time-from', value: string): void
253
- (event: 'update-custom-time-to', value: string): void
254
- }>()
255
-
256
- const { $formattedDate, $isDate, $getTimeFormat, $getUnixByDate } = useNuxtApp()
257
-
258
- const localization = computed<UI_I_Localization>(() => useLocal())
259
-
260
- const timespanOptions = computed<UI_I_OptionItem[]>(() =>
261
- timespanFunc(localization.value)
262
- )
263
- const localSelectedTimespan = ref<string>(
264
- props.selectedTimespanType || timespanOptions.value[0].value
265
- )
266
- watch(
267
- () => props.selectedTimespanType,
268
- (newValue) => {
269
- localSelectedTimespan.value = newValue || timespanOptions.value[0].value
270
- }
271
- )
272
- const localPeriodType = ref<string>('last')
273
- watch(
274
- () => props.periodType,
275
- (newValue) => {
276
- localPeriodType.value = newValue || 'last'
277
- },
278
- { immediate: true }
279
- )
280
-
281
- watch(
282
- localSelectedTimespan,
283
- (newValue) => {
284
- emits('update-timespan-type', newValue)
285
- },
286
- { immediate: true }
287
- )
288
-
289
- watch(
290
- localPeriodType,
291
- (newValue) => {
292
- const currentValue = newValue || 'period'
293
- emits('update-period-type', currentValue)
294
- },
295
- { immediate: true }
296
- )
297
-
298
- const localLast = ref<number>(1)
299
- watch(
300
- localLast,
301
- (newValue) => {
302
- emits('update-unit-count', newValue)
303
- },
304
- { immediate: true }
305
- )
306
- watch(
307
- () => props.unitsCount,
308
- (newValue) => {
309
- localLast.value = newValue > 0 ? newValue : 1
310
- },
311
- { immediate: true }
312
- )
313
-
314
- const localSelectedCustomTime = ref<string>('hours')
315
- const customTimeOptions = computed<UI_I_OptionItem[]>(() => {
316
- const lang = useLocalStorage('lang')
317
-
318
- return customTimeFunc(localization.value, localLast.value, lang)
319
- })
320
- watch(
321
- () => props.selectedCustomTime,
322
- (newValue) => {
323
- localSelectedCustomTime.value = newValue || 'hours'
324
- },
325
- { immediate: true }
326
- )
327
- watch(
328
- localSelectedCustomTime,
329
- (newValue) => {
330
- emits('update-custom-time', newValue)
331
- },
332
- { immediate: true }
333
- )
334
-
335
- const chartType = ref<string>('line_graph')
336
- const chartTypeOptions = computed<UI_I_OptionItem[]>(() =>
337
- chartTypeFunc(localization.value)
338
- )
339
-
340
- const periodTypeText = computed<string>(() => {
341
- let text = ''
342
- const lang = useLocalStorage('lang')
343
-
344
- if (lang !== 'ru_RU') text = localization.value.common.last
345
- else text = getCorrectRuPeriodTypeText(localLast.value)
346
-
347
- return text
348
- })
349
-
350
- const getCorrectRuPeriodTypeText = (hours: number): string => {
351
- let prefix: string
352
-
353
- if (!hours) return getCorrectRuPeriodTypeText.prefix
354
-
355
- if (hours % 10 === 1 && hours % 100 !== 11) prefix = 'Последний'
356
- else prefix = 'Последние'
357
-
358
- getCorrectRuPeriodTypeText.prefix = prefix
359
- return prefix
360
- }
361
-
362
- const setCurrentChartType = (): void => {
363
- const selected = props.selectedChartType
364
- let result = 'line_graph'
365
-
366
- if (selected === 'spline') result = 'line_graph'
367
- else if (selected === 'area') result = 'stacked_graph'
368
-
369
- chartType.value = result
370
- }
371
-
372
- watch(
373
- () => props.selectedChartType,
374
- () => {
375
- setCurrentChartType()
376
- },
377
- { immediate: true }
378
- )
379
-
380
- watch(
381
- chartType,
382
- (newValue) => {
383
- let currentValue = 'spline'
384
-
385
- if (newValue === 'line_graph') currentValue = 'spline'
386
- else if (newValue === 'stacked_graph') currentValue = 'area'
387
-
388
- emits('update-chart-type', currentValue)
389
- },
390
- { immediate: true }
391
- )
392
-
393
- const yesterday = new Date().setDate(new Date().getDate() - 1)
394
- const dateFrom = ref<number>(yesterday)
395
- const dateTo = ref<number>(new Date().getTime())
396
-
397
- const localCurrentDateFrom = ref<string>('')
398
- const currentDateTo = ref<string>('')
399
- const currentTimeFrom = ref<string>('')
400
- const currentTimeTo = ref<string>('')
401
-
402
- const getCurrentTime = (): void => {
403
- localCurrentDateFrom.value =
404
- props.customDateFrom || $formattedDate(yesterday, '')
405
- currentDateTo.value = props.customDateTo || $formattedDate(new Date(), '')
406
-
407
- const currentTime = format(new Date(), $getTimeFormat(true))
408
- currentTimeFrom.value = props.customTimeFrom || currentTime
409
- currentTimeTo.value = props.customTimeTo || currentTime
410
- }
411
-
412
- const onUpdateDateFrom = (val: number): void => {
413
- if (!val) return
414
-
415
- localCurrentDateFrom.value = $formattedDate(new Date(val), '')
416
- }
417
- watch(localCurrentDateFrom, (newValue) => {
418
- emits('update-custom-date-from', newValue)
419
- if (!newValue) return
420
-
421
- if ($isDate(newValue)) dateFrom.value = $getUnixByDate(newValue)
422
- })
423
-
424
- const onUpdateDateTo = (val: number): void => {
425
- if (!val) return
426
-
427
- currentDateTo.value = $formattedDate(new Date(val), '')
428
- }
429
- watch(currentDateTo, (newValue) => {
430
- emits('update-custom-date-to', newValue)
431
- if (!newValue) return
432
-
433
- if ($isDate(newValue)) dateTo.value = $getUnixByDate(newValue)
434
- })
435
- watch(currentTimeFrom, (newValue) => {
436
- emits('update-custom-time-from', newValue)
437
- })
438
- watch(currentTimeTo, (newValue) => {
439
- emits('update-custom-time-to', newValue)
440
- })
441
-
442
- onMounted(() => {
443
- getCurrentTime()
444
- })
445
- </script>
446
-
447
- <style scoped lang="scss">
448
- .chart-option-timespan-split {
449
- overflow-x: auto;
450
- //flex-basis: 56%;
451
- padding: 5px;
452
-
453
- .timespan-objects-section-direction {
454
- display: flex;
455
- flex-direction: row;
456
- align-items: flex-start;
457
-
458
- .chart-option-timespan-settings {
459
- margin-left: 15px;
460
-
461
- .chart-option-setting-row {
462
- width: 150px;
463
- margin-bottom: 5px;
464
- }
465
-
466
- .custom-radio-button {
467
- position: absolute;
468
- opacity: 0;
469
-
470
- &:checked + .custom-radio-label:before {
471
- box-shadow: inset 0 0 0 6px #0079b8;
472
- border: none;
473
- }
474
- }
475
- .custom-radio-label {
476
- display: block;
477
- position: relative;
478
- min-height: 19.2px;
479
- padding-left: 23px;
480
- cursor: pointer;
481
- line-height: 19.2px;
482
- color: #454545;
483
-
484
- &:before {
485
- position: absolute;
486
- top: 3px;
487
- left: 0;
488
- content: '';
489
- display: inline-block;
490
- height: 16px;
491
- width: 16px;
492
- border: 0.8px solid #565656;
493
- border-radius: 50%;
494
- }
495
- }
496
-
497
- .calendar-date-row {
498
- display: flex;
499
- align-items: center;
500
-
501
- .custom-time-input.first-from,
502
- .custom-time-input.first-to {
503
- max-width: 114px;
504
- }
505
- .btn-show-hide-calendar {
506
- margin: 0 9px;
507
- cursor: pointer;
508
- }
509
- }
510
-
511
- .custom-time-input {
512
- margin-left: 8px;
513
- margin-right: 8px;
514
- max-width: 140px;
515
- }
516
- }
517
-
518
- .custom-timespan-settings-container:not(.active),
519
- .custom-timespan-type-last-container:not(.active),
520
- .disabled-container:not(.active) {
521
- opacity: 0.6;
522
- pointer-events: none;
523
- }
524
- }
525
-
526
- .chart-type-container {
527
- margin-top: 15px;
528
-
529
- .horizontal-flex-container {
530
- display: flex;
531
- flex-direction: row;
532
-
533
- .select {
534
- margin-left: 15px;
535
- }
536
- }
537
- }
538
- }
539
- </style>
1
+ <template>
2
+ <div class="chart-option-timespan-split">
3
+ <div class="vertical-flex-container">
4
+ <div class="timespan-objects-section-direction">
5
+ <label for="chart-timespan-type-select"
6
+ >{{ localization.inventoryMonitor.timespan }}:</label
7
+ >
8
+ <div class="vertical-flex-container chart-option-timespan-settings">
9
+ <div class="timespan-select chart-option-setting-row">
10
+ <div class="view-select-label horizontal-flex-container">
11
+ <div class="select">
12
+ <select
13
+ id="chart-timespan-type-select"
14
+ v-model="localSelectedTimespan"
15
+ data-id="chart-timespan-type-select"
16
+ >
17
+ <option
18
+ v-for="(item, index) in timespanOptions"
19
+ :key="index"
20
+ :value="item.value"
21
+ >
22
+ {{ item.text }}
23
+ </option>
24
+ </select>
25
+ </div>
26
+ </div>
27
+ </div>
28
+ <div
29
+ :class="[
30
+ 'custom-timespan-settings-container',
31
+ { active: localSelectedTimespan === 'custom_interval' },
32
+ ]"
33
+ >
34
+ <table>
35
+ <tbody>
36
+ <tr>
37
+ <td class="relative">
38
+ <input
39
+ id="custom-time-lastInput"
40
+ v-model="localPeriodType"
41
+ data-id="custom-time-lastInput"
42
+ type="radio"
43
+ value="last"
44
+ class="custom-radio-button"
45
+ name="lastFrom"
46
+ />
47
+ <label
48
+ for="custom-time-lastInput"
49
+ class="custom-radio-label"
50
+ >
51
+ {{ periodTypeText }}:
52
+ </label>
53
+ </td>
54
+ <td>
55
+ <div
56
+ :class="[
57
+ 'custom-timespan-type-last-container',
58
+ { active: localPeriodType === 'last' },
59
+ ]"
60
+ >
61
+ <input
62
+ id="chart-option-setting-row"
63
+ v-model="localLast"
64
+ data-id="chart-option-setting-row"
65
+ type="number"
66
+ class="chart-option-setting-row custom-time-input"
67
+ />
68
+ <div
69
+ class="chart-option-setting-row custom-time-input inline-block"
70
+ >
71
+ <div
72
+ class="view-select-label horizontal-flex-container"
73
+ >
74
+ <div class="select">
75
+ <select
76
+ id="chart-timespan-type-select"
77
+ v-model="localSelectedCustomTime"
78
+ data-id="chart-timespan-type-select"
79
+ >
80
+ <option
81
+ v-for="(item, index) in customTimeOptions"
82
+ :key="index"
83
+ :value="item.value"
84
+ >
85
+ {{ item.text }}
86
+ </option>
87
+ </select>
88
+ </div>
89
+ </div>
90
+ </div>
91
+ </div>
92
+ </td>
93
+ </tr>
94
+ <tr>
95
+ <td class="relative">
96
+ <input
97
+ id="custom-time-fromInput"
98
+ v-model="localPeriodType"
99
+ data-id="custom-time-from-input"
100
+ type="radio"
101
+ value="period"
102
+ class="custom-radio-button"
103
+ name="lastFrom"
104
+ />
105
+ <label
106
+ for="custom-time-fromInput"
107
+ class="custom-radio-label text-capitalize text-right"
108
+ >{{ localization.common.from2 }}:
109
+ </label>
110
+ </td>
111
+ <td>
112
+ <div
113
+ :class="[
114
+ 'date-container-row disabled-container calendar-date-row',
115
+ { active: localPeriodType === 'period' },
116
+ ]"
117
+ >
118
+ <input
119
+ id="current-date-from"
120
+ v-model.lazy="localCurrentDateFrom"
121
+ data-id="current-date-from-input"
122
+ type="text"
123
+ class="chart-option-setting-row custom-time-input first-from"
124
+ />
125
+ <div class="section-datepicker">
126
+ <atoms-datepicker
127
+ v-model="dateFrom"
128
+ :lang="props.language"
129
+ class="calendar-from calendar-popup btn-show-hide-calendar"
130
+ @update="onUpdateDateFrom"
131
+ />
132
+ </div>
133
+ <input
134
+ id="current-time-from"
135
+ v-model="currentTimeFrom"
136
+ data-id="current-time-from-input"
137
+ type="text"
138
+ class="chart-option-setting-row custom-time-input"
139
+ />
140
+ </div>
141
+ </td>
142
+ </tr>
143
+ <tr>
144
+ <td class="custom-time-label-text text-right">
145
+ {{ localization.common.to2 }}:
146
+ </td>
147
+ <td>
148
+ <div
149
+ :class="[
150
+ 'date-container-row disabled-container calendar-date-row',
151
+ { active: localPeriodType === 'period' },
152
+ ]"
153
+ >
154
+ <input
155
+ id="current-date-to"
156
+ v-model.lazy="currentDateTo"
157
+ data-id="current-date-to-input"
158
+ type="text"
159
+ class="chart-option-setting-row custom-time-input first-to"
160
+ />
161
+ <div class="section-datepicker">
162
+ <atoms-datepicker
163
+ v-model="dateTo"
164
+ :lang="props.language"
165
+ class="calendar-from calendar-popup btn-show-hide-calendar"
166
+ @update="onUpdateDateTo"
167
+ />
168
+ </div>
169
+ <input
170
+ id="current-time-to"
171
+ v-model="currentTimeTo"
172
+ data-id="current-time-to-input"
173
+ type="text"
174
+ class="chart-option-setting-row custom-time-input"
175
+ />
176
+ </div>
177
+ </td>
178
+ </tr>
179
+ <tr>
180
+ <td></td>
181
+ <td
182
+ :class="[
183
+ 'disabled-container',
184
+ { active: localPeriodType === 'period' },
185
+ ]"
186
+ >
187
+ <span>
188
+ ({{ localization.inventoryMonitor.isoTimeFormat }})
189
+ </span>
190
+ </td>
191
+ </tr>
192
+ </tbody>
193
+ </table>
194
+ </div>
195
+ </div>
196
+ </div>
197
+ <div class="horizontal-flex-container chart-type-container">
198
+ <div class="view-select-label horizontal-flex-container">
199
+ <label for="chart-type-select" class="label-select"
200
+ >{{ localization.inventoryMonitor.chartType }}:</label
201
+ >
202
+ <div class="select">
203
+ <select
204
+ id="chart-type-select"
205
+ v-model="chartType"
206
+ data-id="chart-type-select"
207
+ >
208
+ <option
209
+ v-for="(item, index) in chartTypeOptions"
210
+ :key="index"
211
+ :value="item.value"
212
+ >
213
+ {{ item.text }}
214
+ </option>
215
+ </select>
216
+ </div>
217
+ </div>
218
+ </div>
219
+ </div>
220
+ </div>
221
+ </template>
222
+
223
+ <script setup lang="ts">
224
+ import { format } from 'date-fns'
225
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
226
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
227
+ import {
228
+ timespanFunc,
229
+ customTimeFunc,
230
+ chartTypeFunc,
231
+ } from '~/components/common/chartOptionsModal/counters/timespan/form/lib/config/dateForm'
232
+
233
+ const props = defineProps<{
234
+ language: string
235
+ selectedChartType: string
236
+ selectedTimespanType: string
237
+ unitsCount: number
238
+ periodType: string
239
+ selectedCustomTime: string
240
+ customDateFrom: string
241
+ customDateTo: string
242
+ customTimeFrom: string
243
+ customTimeTo: string
244
+ validDateEnd: number
245
+ }>()
246
+
247
+ const emits = defineEmits<{
248
+ (event: 'update-chart-type', value: string): void
249
+ (event: 'update-custom-time', value: string): void
250
+ (event: 'update-timespan-type', value: string): void
251
+ (event: 'update-unit-count', value: number): void
252
+ (event: 'update-period-type', value: string): void
253
+ (event: 'update-custom-date-from', value: string): void
254
+ (event: 'update-custom-date-to', value: string): void
255
+ (event: 'update-custom-time-from', value: string): void
256
+ (event: 'update-custom-time-to', value: string): void
257
+ }>()
258
+
259
+ const { $formattedDate, $isDate, $getTimeFormat, $getUnixByDate } = useNuxtApp()
260
+
261
+ const localization = computed<UI_I_Localization>(() => useLocal())
262
+
263
+ const timespanOptions = computed<UI_I_OptionItem[]>(() =>
264
+ timespanFunc(localization.value)
265
+ )
266
+ const localSelectedTimespan = ref<string>(
267
+ props.selectedTimespanType || timespanOptions.value[0].value
268
+ )
269
+ watch(
270
+ () => props.selectedTimespanType,
271
+ (newValue) => {
272
+ localSelectedTimespan.value = newValue || timespanOptions.value[0].value
273
+ }
274
+ )
275
+ const localPeriodType = ref<string>('last')
276
+ watch(
277
+ () => props.periodType,
278
+ (newValue) => {
279
+ localPeriodType.value = newValue || 'last'
280
+ },
281
+ { immediate: true }
282
+ )
283
+
284
+ watch(
285
+ localSelectedTimespan,
286
+ (newValue) => {
287
+ emits('update-timespan-type', newValue)
288
+ },
289
+ { immediate: true }
290
+ )
291
+
292
+ watch(
293
+ localPeriodType,
294
+ (newValue) => {
295
+ const currentValue = newValue || 'period'
296
+ emits('update-period-type', currentValue)
297
+ },
298
+ { immediate: true }
299
+ )
300
+
301
+ const localLast = ref<number>(1)
302
+ watch(
303
+ localLast,
304
+ (newValue) => {
305
+ emits('update-unit-count', newValue)
306
+ },
307
+ { immediate: true }
308
+ )
309
+ watch(
310
+ () => props.unitsCount,
311
+ (newValue) => {
312
+ localLast.value = newValue > 0 ? newValue : 1
313
+ },
314
+ { immediate: true }
315
+ )
316
+
317
+ const localSelectedCustomTime = ref<string>('hours')
318
+ const customTimeOptions = computed<UI_I_OptionItem[]>(() => {
319
+ const lang = useLocalStorage('lang')
320
+
321
+ return customTimeFunc(localization.value, localLast.value, lang)
322
+ })
323
+ watch(
324
+ () => props.selectedCustomTime,
325
+ (newValue) => {
326
+ localSelectedCustomTime.value = newValue || 'hours'
327
+ },
328
+ { immediate: true }
329
+ )
330
+ watch(
331
+ localSelectedCustomTime,
332
+ (newValue) => {
333
+ emits('update-custom-time', newValue)
334
+ },
335
+ { immediate: true }
336
+ )
337
+
338
+ const chartType = ref<string>('line_graph')
339
+ const chartTypeOptions = computed<UI_I_OptionItem[]>(() =>
340
+ chartTypeFunc(localization.value)
341
+ )
342
+
343
+ const periodTypeText = computed<string>(() => {
344
+ let text = ''
345
+ const lang = useLocalStorage('lang')
346
+
347
+ if (lang !== 'ru_RU') text = localization.value.common.last
348
+ else text = getCorrectRuPeriodTypeText(localLast.value)
349
+
350
+ return text
351
+ })
352
+
353
+ const getCorrectRuPeriodTypeText = (hours: number): string => {
354
+ let prefix: string
355
+
356
+ if (!hours) return getCorrectRuPeriodTypeText.prefix
357
+
358
+ if (hours % 10 === 1 && hours % 100 !== 11) prefix = 'Последний'
359
+ else prefix = 'Последние'
360
+
361
+ getCorrectRuPeriodTypeText.prefix = prefix
362
+ return prefix
363
+ }
364
+
365
+ const setCurrentChartType = (): void => {
366
+ const selected = props.selectedChartType
367
+ let result = 'line_graph'
368
+
369
+ if (selected === 'spline') result = 'line_graph'
370
+ else if (selected === 'area') result = 'stacked_graph'
371
+
372
+ chartType.value = result
373
+ }
374
+
375
+ watch(
376
+ () => props.selectedChartType,
377
+ () => {
378
+ setCurrentChartType()
379
+ },
380
+ { immediate: true }
381
+ )
382
+
383
+ watch(
384
+ chartType,
385
+ (newValue) => {
386
+ let currentValue = 'spline'
387
+
388
+ if (newValue === 'line_graph') currentValue = 'spline'
389
+ else if (newValue === 'stacked_graph') currentValue = 'area'
390
+
391
+ emits('update-chart-type', currentValue)
392
+ },
393
+ { immediate: true }
394
+ )
395
+
396
+ const yesterday = new Date().setDate(new Date().getDate() - 1)
397
+ const dateFrom = ref<number>(yesterday)
398
+ const dateTo = ref<number>(new Date().getTime())
399
+
400
+ const localCurrentDateFrom = ref<string>('')
401
+ const currentDateTo = ref<string>('')
402
+ const currentTimeFrom = ref<string>('')
403
+ const currentTimeTo = ref<string>('')
404
+
405
+ const getCurrentTime = (): void => {
406
+ localCurrentDateFrom.value =
407
+ props.customDateFrom || $formattedDate(yesterday, '')
408
+ currentDateTo.value =
409
+ props.customDateTo || $formattedDate(props.validDateEnd, '')
410
+
411
+ currentTimeFrom.value =
412
+ props.customTimeFrom || format(new Date(), $getTimeFormat(true))
413
+ currentTimeTo.value =
414
+ props.customTimeTo || format(props.validDateEnd, $getTimeFormat(true))
415
+ }
416
+
417
+ const onUpdateDateFrom = (value: number): void => {
418
+ if (!value) return
419
+
420
+ localCurrentDateFrom.value = $formattedDate(new Date(value), '')
421
+ }
422
+ watch(localCurrentDateFrom, (newValue) => {
423
+ emits('update-custom-date-from', newValue)
424
+ if (!newValue) return
425
+
426
+ if ($isDate(newValue)) dateFrom.value = $getUnixByDate(newValue)
427
+ })
428
+
429
+ const onUpdateDateTo = (value: number): void => {
430
+ if (!value) return
431
+
432
+ currentDateTo.value = $formattedDate(new Date(value), '')
433
+ }
434
+ watch(currentDateTo, (newValue) => {
435
+ emits('update-custom-date-to', newValue)
436
+ if (!newValue) return
437
+
438
+ if ($isDate(newValue)) dateTo.value = $getUnixByDate(newValue)
439
+ })
440
+ watch(currentTimeFrom, (newValue) => {
441
+ emits('update-custom-time-from', newValue)
442
+ })
443
+ watch(currentTimeTo, (newValue) => {
444
+ emits('update-custom-time-to', newValue)
445
+ })
446
+
447
+ onMounted(() => {
448
+ getCurrentTime()
449
+ })
450
+ </script>
451
+
452
+ <style scoped lang="scss">
453
+ .chart-option-timespan-split {
454
+ overflow-x: auto;
455
+ //flex-basis: 56%;
456
+ padding: 5px;
457
+
458
+ .timespan-objects-section-direction {
459
+ display: flex;
460
+ flex-direction: row;
461
+ align-items: flex-start;
462
+
463
+ .chart-option-timespan-settings {
464
+ margin-left: 15px;
465
+
466
+ .chart-option-setting-row {
467
+ width: 150px;
468
+ margin-bottom: 5px;
469
+ }
470
+
471
+ .custom-radio-button {
472
+ position: absolute;
473
+ opacity: 0;
474
+
475
+ &:checked + .custom-radio-label:before {
476
+ box-shadow: inset 0 0 0 6px #0079b8;
477
+ border: none;
478
+ }
479
+ }
480
+ .custom-radio-label {
481
+ display: block;
482
+ position: relative;
483
+ min-height: 19.2px;
484
+ padding-left: 23px;
485
+ cursor: pointer;
486
+ line-height: 19.2px;
487
+ color: #454545;
488
+
489
+ &:before {
490
+ position: absolute;
491
+ top: 3px;
492
+ left: 0;
493
+ content: '';
494
+ display: inline-block;
495
+ height: 16px;
496
+ width: 16px;
497
+ border: 0.8px solid #565656;
498
+ border-radius: 50%;
499
+ }
500
+ }
501
+
502
+ .calendar-date-row {
503
+ display: flex;
504
+ align-items: center;
505
+
506
+ .custom-time-input.first-from,
507
+ .custom-time-input.first-to {
508
+ max-width: 114px;
509
+ }
510
+ .btn-show-hide-calendar {
511
+ margin: 0 9px;
512
+ cursor: pointer;
513
+ }
514
+ }
515
+
516
+ .custom-time-input {
517
+ margin-left: 8px;
518
+ margin-right: 8px;
519
+ max-width: 140px;
520
+ }
521
+ }
522
+
523
+ .custom-timespan-settings-container:not(.active),
524
+ .custom-timespan-type-last-container:not(.active),
525
+ .disabled-container:not(.active) {
526
+ opacity: 0.6;
527
+ pointer-events: none;
528
+ }
529
+ }
530
+
531
+ .chart-type-container {
532
+ margin-top: 15px;
533
+
534
+ .horizontal-flex-container {
535
+ display: flex;
536
+ flex-direction: row;
537
+
538
+ .select {
539
+ margin-left: 15px;
540
+ }
541
+ }
542
+ }
543
+ }
544
+ </style>