bfg-common 1.4.860 → 1.4.862

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 (143) hide show
  1. package/assets/scss/common/normalize.scss +361 -361
  2. package/components/atoms/TheIcon3.vue +50 -50
  3. package/components/atoms/autocomplete/Autocomplete.vue +301 -301
  4. package/components/atoms/collapse/CollapseNav.vue +164 -164
  5. package/components/atoms/dropdown/dropdown/Dropdown.vue +168 -168
  6. package/components/atoms/modal/bySteps/BySteps.vue +253 -253
  7. package/components/atoms/stack/StackBlock.vue +185 -185
  8. package/components/atoms/table/dataGrid/DataGrid.vue +1704 -1704
  9. package/components/atoms/table/dataGrid/DataGridColumnSwitch.vue +222 -222
  10. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  11. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  12. package/components/common/browse/BrowseNew.vue +237 -237
  13. package/components/common/browse/BrowseOld.vue +217 -217
  14. package/components/common/browse/blocks/contents/Files.vue +37 -37
  15. package/components/common/browse/blocks/contents/FilesOld.vue +72 -72
  16. package/components/common/browse/blocks/contents/filesNew/FilesNew.vue +96 -96
  17. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  18. package/components/common/context/Context.vue +111 -111
  19. package/components/common/context/lib/models/interfaces.ts +30 -30
  20. package/components/common/context/recursion/Recursion.vue +87 -87
  21. package/components/common/context/recursion/RecursionOld.vue +227 -227
  22. package/components/common/details/DetailsItem.vue +109 -109
  23. package/components/common/graph/Graph.vue +104 -104
  24. package/components/common/layout/theHeader/helpMenu/About.vue +82 -82
  25. package/components/common/layout/theHeader/helpMenu/aboutNew/AboutNew.vue +103 -103
  26. package/components/common/modals/unsavedChanges/UnsavedChanges.vue +56 -56
  27. package/components/common/monitor/advanced/tools/chartOptionsModal/counters/table/lib/config/utils.ts +1040 -1040
  28. package/components/common/monitor/overview/OverviewNew.vue +142 -142
  29. package/components/common/monitor/overview/OverviewOld.vue +139 -139
  30. package/components/common/monitor/overview/filters/Filters.vue +166 -166
  31. package/components/common/monitor/overview/filters/FiltersNew.vue +172 -172
  32. package/components/common/monitor/overview/filters/FiltersOld.vue +151 -151
  33. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModal.vue +175 -175
  34. package/components/common/monitor/overview/filters/customIntervalModal/CustomIntervalModalOld.vue +161 -161
  35. package/components/common/pages/home/StatusContent.vue +49 -49
  36. package/components/common/pages/home/headline/Headline.vue +45 -45
  37. package/components/common/pages/home/headline/HeadlineOld.vue +42 -42
  38. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  39. package/components/common/pages/home/widgets/Widgets.vue +49 -49
  40. package/components/common/pages/home/widgets/WidgetsNew.vue +86 -86
  41. package/components/common/pages/home/widgets/WidgetsOld.vue +34 -34
  42. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  43. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  44. package/components/common/pages/home/widgets/vms/Vms.vue +26 -26
  45. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  46. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  47. package/components/common/pages/packages/Packages.vue +208 -208
  48. package/components/common/recursionTree/RecursionTree.vue +223 -223
  49. package/components/common/select/button/ButtonDropdown.vue +108 -108
  50. package/components/common/spiceConsole/Drawer.vue +370 -370
  51. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  52. package/components/common/split/horizontal/HorizontalNew.vue +376 -376
  53. package/components/common/split/horizontal/HorizontalOld.vue +337 -337
  54. package/components/common/split/vertical/Vertical.vue +160 -160
  55. package/components/common/vm/actions/add/Add.vue +621 -621
  56. package/components/common/vm/actions/clone/Clone.vue +639 -639
  57. package/components/common/vm/actions/clone/lib/config/steps.ts +129 -129
  58. package/components/common/vm/actions/common/customizeHardware/CustomizeHardware.vue +271 -271
  59. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareNew.vue +271 -271
  60. package/components/common/vm/actions/common/customizeHardware/CustomizeHardwareOld.vue +174 -174
  61. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +694 -694
  62. package/components/common/vm/actions/common/customizeHardware/virtualHardware/browseView/BrowseView.vue +219 -219
  63. package/components/common/vm/actions/common/customizeHardware/virtualHardware/bus/BusNew.vue +117 -117
  64. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveNew.vue +161 -161
  65. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/CdDvdDriveOld.vue +165 -165
  66. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/Media.vue +25 -25
  67. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaNew.vue +70 -70
  68. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cdDvdDrive/media/MediaOld.vue +50 -50
  69. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/Cpu.vue +338 -338
  70. package/components/common/vm/actions/common/customizeHardware/virtualHardware/limit/Limit.vue +220 -220
  71. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +364 -364
  72. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskNew.vue +229 -229
  73. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDiskOld.vue +247 -247
  74. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/mode/ModeOld.vue +56 -56
  75. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/sharing/SharingNew.vue +44 -44
  76. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetwork.vue +283 -283
  77. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/NewNetworkNew.vue +124 -124
  78. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/LocationOld.vue +134 -134
  79. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/New.vue +63 -63
  80. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/location/new/table/lib/config/config.ts +95 -95
  81. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddress.vue +119 -119
  82. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressNew.vue +69 -69
  83. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newNetwork/macAddress/MacAddressOld.vue +83 -83
  84. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +205 -205
  85. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoNew.vue +66 -66
  86. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIoOld.vue +62 -62
  87. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +31 -31
  88. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoNew.vue +84 -84
  89. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIoOld.vue +76 -76
  90. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/Note.vue +15 -15
  91. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteNew.vue +42 -42
  92. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/note/NoteOld.vue +30 -30
  93. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +41 -41
  94. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridNew.vue +81 -81
  95. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGridOld.vue +84 -84
  96. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newUsbController/NewUsbControllerNew.vue +56 -56
  97. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/Other.vue +16 -16
  98. package/components/common/vm/actions/common/customizeHardware/virtualHardware/other/OtherNew.vue +30 -30
  99. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardNew.vue +104 -104
  100. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/VideoCardOld.vue +112 -112
  101. package/components/common/vm/actions/common/customizeHardware/virtualHardware/videoCard/totalVideoMemory/TotalVideoMemoryNew.vue +54 -54
  102. package/components/common/vm/actions/common/customizeHardware/vmoptions/Vmoptions.vue +145 -145
  103. package/components/common/vm/actions/common/customizeHardware/vmoptions/VmoptionsNew.vue +102 -102
  104. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/BootOptionsNew.vue +75 -75
  105. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/delay/Delay.vue +26 -26
  106. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/Firmware.vue +57 -57
  107. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/firmware/FirmwareNew.vue +42 -42
  108. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/menu/MenuNew.vue +25 -25
  109. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +171 -171
  110. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/OrderNew.vue +50 -50
  111. package/components/common/vm/actions/common/customizeHardware/vmoptions/generalOptions/GeneralOptionsNew.vue +141 -141
  112. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/New.vue +140 -140
  113. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/copyPaste/CopyPasteNew.vue +30 -30
  114. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/fileTransfer/FileTransferNew.vue +30 -30
  115. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/folderSharing/FolderSharingNew.vue +30 -30
  116. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/Keymap.vue +32 -32
  117. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/keymap/KeymapNew.vue +39 -39
  118. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/Password.vue +103 -103
  119. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordNew.vue +102 -102
  120. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/password/PasswordOld.vue +94 -94
  121. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirection.vue +28 -28
  122. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionNew.vue +38 -38
  123. package/components/common/vm/actions/common/customizeHardware/vmoptions/remoteConsoleOptions/usbRedirection/UsbRedirectionOld.vue +44 -44
  124. package/components/common/vm/actions/common/select/storage/Storage.vue +130 -130
  125. package/components/common/vm/actions/common/select/storage/StorageOld.vue +129 -129
  126. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  127. package/components/common/wizards/datastore/add/lib/config/steps.ts +138 -138
  128. package/components/common/wizards/vm/migrate/Migrate.vue +302 -302
  129. package/components/common/wizards/vm/migrate/lib/config/constructDataReady.ts +220 -220
  130. package/components/common/wizards/vm/migrate/select/network/Network.vue +103 -103
  131. package/components/common/wizards/vm/migrate/select/network/table/network/Network.vue +150 -150
  132. package/components/common/wizards/vm/migrate/select/network/table/network/lib/config/advancedTable.ts +91 -91
  133. package/components/common/wizards/vm/migrate/select/priority/Priority.vue +43 -43
  134. package/composables/productNameLocal.ts +30 -30
  135. package/composables/useAppVersion.ts +21 -21
  136. package/package.json +1 -1
  137. package/plugins/date.ts +233 -233
  138. package/plugins/recursion.ts +311 -311
  139. package/public/spice-console/lib/images/bitmap.js +203 -203
  140. package/public/spice-console/network/spicechannel.js +383 -383
  141. package/store/main/mutations.ts +7 -7
  142. package/store/main/state.ts +7 -7
  143. package/store/tasks/mappers/recentTasks.ts +64 -64
@@ -1,166 +1,166 @@
1
- <template>
2
- <common-monitor-overview-filters-new
3
- v-if="isNewView"
4
- v-model:selected-period="selectedPeriod"
5
- v-model:selected-view="selectedView"
6
- :disabled-period-options="disabledPeriodOptions"
7
- :period-options="periodOptions"
8
- :is-show-custom-interval-button="isShowCustomIntervalButton"
9
- :chart-title-date="chartTitleDate"
10
- :view-options="viewOptions"
11
- :valid-date-end="props.validDateEnd"
12
- :is-show-interval-modal="isShowIntervalModal"
13
- :selected-periods="props.selectedPeriods"
14
- :format-date="props.formatDate"
15
- :current-lang="props.currentLang"
16
- @submit-interval-modal="onSubmitIntervalModal"
17
- @show-interval-modal="onShowIntervalModal"
18
- @hide-interval-modal="onHideIntervalModal"
19
- />
20
- <common-monitor-overview-filters-old
21
- v-else
22
- v-model:selected-period="selectedPeriod"
23
- v-model:selected-view="selectedView"
24
- :disabled-period-options="disabledPeriodOptions"
25
- :period-options="periodOptions"
26
- :is-show-custom-interval-button="isShowCustomIntervalButton"
27
- :chart-title-date="chartTitleDate"
28
- :view-options="viewOptions"
29
- :valid-date-end="props.validDateEnd"
30
- :is-show-interval-modal="isShowIntervalModal"
31
- :selected-periods="props.selectedPeriods"
32
- :format-date="props.formatDate"
33
- :current-lang="props.currentLang"
34
- @submit-interval-modal="onSubmitIntervalModal"
35
- @show-interval-modal="onShowIntervalModal"
36
- @hide-interval-modal="onHideIntervalModal"
37
- />
38
- </template>
39
-
40
- <script setup lang="ts">
41
- import type { UI_I_Localization } from '~/lib/models/interfaces'
42
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
43
- import type { UI_I_MonitorGraphPayload } from '~/components/common/monitor/lib/models/interfaces'
44
- import type { UI_T_OverviewViewType } from '~/components/common/monitor/overview/filters/lib/models/types'
45
- import {
46
- periodFunc,
47
- viewFunc,
48
- } from '~/components/common/monitor/overview/filters/lib/config/filterOptions'
49
- import { getValidDateByOptionFunc } from '~/components/common/monitor/lib/config/getValidDateByOption'
50
-
51
- const { $formattedDatetime, $store }: any = useNuxtApp()
52
- const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
53
-
54
- const props = defineProps<{
55
- startDate: number
56
- endDate: number
57
- chartType: 'spline' | 'pie'
58
- view: UI_T_OverviewViewType
59
- selectedPeriods: number[]
60
- formatDate: string
61
- currentLang: string
62
- validDateEnd: number
63
- formatTime?: string
64
- }>()
65
-
66
- const emits = defineEmits<{
67
- (event: 'update-filters', value: UI_I_MonitorGraphPayload): void
68
- (event: 'update-custom-date', value: number[]): void
69
- }>()
70
-
71
- const localization = computed<UI_I_Localization>(() => useLocal())
72
-
73
- const selectedPeriod = ref<string>('')
74
- const periodOptions = computed<UI_I_OptionItem[]>(() =>
75
- periodFunc(localization.value)
76
- )
77
- watch(
78
- () => periodOptions.value,
79
- (newValue: UI_I_OptionItem[]) => {
80
- if (newValue) selectedPeriod.value = newValue[0].value
81
- },
82
- { immediate: true }
83
- )
84
-
85
- const isShowCustomIntervalButton = computed<boolean>(
86
- () => selectedPeriod.value === 'custom_interval'
87
- )
88
-
89
- const isShowIntervalModal = ref<boolean>(false)
90
- const onShowIntervalModal = (): void => {
91
- isShowIntervalModal.value = true
92
- }
93
- const onHideIntervalModal = (): void => {
94
- isShowIntervalModal.value = false
95
- }
96
- const onSubmitIntervalModal = (customDates: number[]): void => {
97
- customDatesData.value = customDates
98
- sendUpdatedFilters()
99
- onHideIntervalModal()
100
- emits('update-custom-date', customDates)
101
- }
102
-
103
- const chartTitleDate = computed<string>(() => {
104
- const startValue = props.startDate
105
- const endValue = props.endDate
106
- if (!startValue && !endValue) return ''
107
-
108
- const start = $formattedDatetime(
109
- startValue,
110
- props.formatDate,
111
- true,
112
- '',
113
- props.formatTime
114
- )
115
- const end = $formattedDatetime(
116
- endValue,
117
- props.formatDate,
118
- true,
119
- '',
120
- props.formatTime
121
- )
122
- return `${start} - ${end}`
123
- })
124
-
125
- // const disabledPeriodOptions = computed<boolean>(
126
- // () => props.chartType === 'pie' || !chartTitleDate.value
127
- // )
128
-
129
- const disabledPeriodOptions = computed<boolean>(() => props.chartType === 'pie')
130
-
131
- const selectedView = ref<string>('')
132
- const viewOptions = computed<UI_I_OptionItem[]>(() =>
133
- viewFunc(localization.value, props.view)
134
- )
135
- watch(
136
- () => viewOptions.value,
137
- (newValue: UI_I_OptionItem[]) => {
138
- if (newValue) selectedView.value = newValue[0].value
139
- },
140
- { immediate: true }
141
- )
142
-
143
- const customDatesData = ref<number[]>([])
144
- const sendUpdatedFilters = (): void => {
145
- const currentPeriod =
146
- selectedPeriod.value === 'custom_interval'
147
- ? customDatesData.value
148
- : getValidDateByOptionFunc(selectedPeriod.value)
149
- const filters: UI_I_MonitorGraphPayload = {
150
- period: currentPeriod,
151
- view: selectedView.value,
152
- periodName: selectedPeriod.value,
153
- }
154
-
155
- emits('update-filters', filters)
156
- }
157
- watch(
158
- () => [selectedPeriod.value, selectedView.value],
159
- () => {
160
- sendUpdatedFilters()
161
- },
162
- { immediate: true }
163
- )
164
- </script>
165
-
166
- <style scoped lang="scss"></style>
1
+ <template>
2
+ <common-monitor-overview-filters-new
3
+ v-if="isNewView"
4
+ v-model:selected-period="selectedPeriod"
5
+ v-model:selected-view="selectedView"
6
+ :disabled-period-options="disabledPeriodOptions"
7
+ :period-options="periodOptions"
8
+ :is-show-custom-interval-button="isShowCustomIntervalButton"
9
+ :chart-title-date="chartTitleDate"
10
+ :view-options="viewOptions"
11
+ :valid-date-end="props.validDateEnd"
12
+ :is-show-interval-modal="isShowIntervalModal"
13
+ :selected-periods="props.selectedPeriods"
14
+ :format-date="props.formatDate"
15
+ :current-lang="props.currentLang"
16
+ @submit-interval-modal="onSubmitIntervalModal"
17
+ @show-interval-modal="onShowIntervalModal"
18
+ @hide-interval-modal="onHideIntervalModal"
19
+ />
20
+ <common-monitor-overview-filters-old
21
+ v-else
22
+ v-model:selected-period="selectedPeriod"
23
+ v-model:selected-view="selectedView"
24
+ :disabled-period-options="disabledPeriodOptions"
25
+ :period-options="periodOptions"
26
+ :is-show-custom-interval-button="isShowCustomIntervalButton"
27
+ :chart-title-date="chartTitleDate"
28
+ :view-options="viewOptions"
29
+ :valid-date-end="props.validDateEnd"
30
+ :is-show-interval-modal="isShowIntervalModal"
31
+ :selected-periods="props.selectedPeriods"
32
+ :format-date="props.formatDate"
33
+ :current-lang="props.currentLang"
34
+ @submit-interval-modal="onSubmitIntervalModal"
35
+ @show-interval-modal="onShowIntervalModal"
36
+ @hide-interval-modal="onHideIntervalModal"
37
+ />
38
+ </template>
39
+
40
+ <script setup lang="ts">
41
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
42
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
43
+ import type { UI_I_MonitorGraphPayload } from '~/components/common/monitor/lib/models/interfaces'
44
+ import type { UI_T_OverviewViewType } from '~/components/common/monitor/overview/filters/lib/models/types'
45
+ import {
46
+ periodFunc,
47
+ viewFunc,
48
+ } from '~/components/common/monitor/overview/filters/lib/config/filterOptions'
49
+ import { getValidDateByOptionFunc } from '~/components/common/monitor/lib/config/getValidDateByOption'
50
+
51
+ const { $formattedDatetime, $store }: any = useNuxtApp()
52
+ const isNewView = computed<boolean>(() => $store.getters['main/getIsNewView'])
53
+
54
+ const props = defineProps<{
55
+ startDate: number
56
+ endDate: number
57
+ chartType: 'spline' | 'pie'
58
+ view: UI_T_OverviewViewType
59
+ selectedPeriods: number[]
60
+ formatDate: string
61
+ currentLang: string
62
+ validDateEnd: number
63
+ formatTime?: string
64
+ }>()
65
+
66
+ const emits = defineEmits<{
67
+ (event: 'update-filters', value: UI_I_MonitorGraphPayload): void
68
+ (event: 'update-custom-date', value: number[]): void
69
+ }>()
70
+
71
+ const localization = computed<UI_I_Localization>(() => useLocal())
72
+
73
+ const selectedPeriod = ref<string>('')
74
+ const periodOptions = computed<UI_I_OptionItem[]>(() =>
75
+ periodFunc(localization.value)
76
+ )
77
+ watch(
78
+ () => periodOptions.value,
79
+ (newValue: UI_I_OptionItem[]) => {
80
+ if (newValue) selectedPeriod.value = newValue[0].value
81
+ },
82
+ { immediate: true }
83
+ )
84
+
85
+ const isShowCustomIntervalButton = computed<boolean>(
86
+ () => selectedPeriod.value === 'custom_interval'
87
+ )
88
+
89
+ const isShowIntervalModal = ref<boolean>(false)
90
+ const onShowIntervalModal = (): void => {
91
+ isShowIntervalModal.value = true
92
+ }
93
+ const onHideIntervalModal = (): void => {
94
+ isShowIntervalModal.value = false
95
+ }
96
+ const onSubmitIntervalModal = (customDates: number[]): void => {
97
+ customDatesData.value = customDates
98
+ sendUpdatedFilters()
99
+ onHideIntervalModal()
100
+ emits('update-custom-date', customDates)
101
+ }
102
+
103
+ const chartTitleDate = computed<string>(() => {
104
+ const startValue = props.startDate
105
+ const endValue = props.endDate
106
+ if (!startValue && !endValue) return ''
107
+
108
+ const start = $formattedDatetime(
109
+ startValue,
110
+ props.formatDate,
111
+ true,
112
+ '',
113
+ props.formatTime
114
+ )
115
+ const end = $formattedDatetime(
116
+ endValue,
117
+ props.formatDate,
118
+ true,
119
+ '',
120
+ props.formatTime
121
+ )
122
+ return `${start} - ${end}`
123
+ })
124
+
125
+ // const disabledPeriodOptions = computed<boolean>(
126
+ // () => props.chartType === 'pie' || !chartTitleDate.value
127
+ // )
128
+
129
+ const disabledPeriodOptions = computed<boolean>(() => props.chartType === 'pie')
130
+
131
+ const selectedView = ref<string>('')
132
+ const viewOptions = computed<UI_I_OptionItem[]>(() =>
133
+ viewFunc(localization.value, props.view)
134
+ )
135
+ watch(
136
+ () => viewOptions.value,
137
+ (newValue: UI_I_OptionItem[]) => {
138
+ if (newValue) selectedView.value = newValue[0].value
139
+ },
140
+ { immediate: true }
141
+ )
142
+
143
+ const customDatesData = ref<number[]>([])
144
+ const sendUpdatedFilters = (): void => {
145
+ const currentPeriod =
146
+ selectedPeriod.value === 'custom_interval'
147
+ ? customDatesData.value
148
+ : getValidDateByOptionFunc(selectedPeriod.value)
149
+ const filters: UI_I_MonitorGraphPayload = {
150
+ period: currentPeriod,
151
+ view: selectedView.value,
152
+ periodName: selectedPeriod.value,
153
+ }
154
+
155
+ emits('update-filters', filters)
156
+ }
157
+ watch(
158
+ () => [selectedPeriod.value, selectedView.value],
159
+ () => {
160
+ sendUpdatedFilters()
161
+ },
162
+ { immediate: true }
163
+ )
164
+ </script>
165
+
166
+ <style scoped lang="scss"></style>
@@ -1,172 +1,172 @@
1
- <template>
2
- <div class="overview-filters">
3
- <div class="period-select-wrap">
4
- <label for="period-select" class="label-select"
5
- >{{ localization.inventoryMonitor.period }}:</label
6
- >
7
-
8
- <ui-select
9
- v-if="!props.disabledPeriodOptions"
10
- v-model="selectedPeriod"
11
- :items="props.periodOptions"
12
- test-id="period-select"
13
- width="auto"
14
- />
15
- <span v-else class="single-option">{{
16
- props.periodOptions[0].text
17
- }}</span>
18
- <span v-if="!props.disabledPeriodOptions" class="chart-text">
19
- {{ props.chartTitleDate }}
20
- </span>
21
- <ui-skeleton-item
22
- v-if="!props.disabledPeriodOptions && !props.chartTitleDate"
23
- width="320"
24
- height="16"
25
- />
26
-
27
- <ui-tooltip
28
- v-show="props.isShowCustomIntervalButton"
29
- id="tooltip-interval-modal-button"
30
- test-id="tooltip-interval-modal-button"
31
- size="sm"
32
- position="bottom"
33
- position-by-tooltip="center"
34
- >
35
- <template #target>
36
- <div
37
- id="tooltip-interval-modal-button"
38
- class="popped tooltip inline-block"
39
- >
40
- <ui-icon
41
- name="edit"
42
- width="16"
43
- height="16"
44
- test-id="show-interval-modal-button"
45
- class="interval-modal-button"
46
- @click="onShowIntervalModal"
47
- />
48
- </div>
49
- </template>
50
- <template #content>
51
- <span class="header-tooltip-text">
52
- {{ localization.inventoryMonitor.changeCustomInterval }}
53
- </span>
54
- </template>
55
- </ui-tooltip>
56
- </div>
57
-
58
- <div class="view-select-wrap">
59
- <label for="view-select" class="label-select"
60
- >{{ localization.common.view }}:</label
61
- >
62
- <ui-select
63
- v-model="selectedView"
64
- :items="props.viewOptions"
65
- test-id="view-select"
66
- width="auto"
67
- left
68
- />
69
- </div>
70
- </div>
71
-
72
- <common-monitor-overview-filters-custom-interval-modal
73
- v-if="props.validDateEnd"
74
- v-show="props.isShowIntervalModal"
75
- :selected-periods="props.selectedPeriods"
76
- :format-date="props.formatDate"
77
- :current-lang="props.currentLang"
78
- :valid-date-end="props.validDateEnd"
79
- @hide="onHideIntervalModal"
80
- @submit="onSubmitIntervalModal"
81
- />
82
- </template>
83
-
84
- <script setup lang="ts">
85
- import type { UI_I_Localization } from '~/lib/models/interfaces'
86
- import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
87
-
88
- const selectedPeriod = defineModel<string>('selected-period')
89
- const selectedView = defineModel<string>('selected-view')
90
-
91
- const props = defineProps<{
92
- disabledPeriodOptions: boolean
93
- periodOptions: UI_I_OptionItem[]
94
- isShowCustomIntervalButton: boolean
95
- chartTitleDate: string
96
- viewOptions: UI_I_OptionItem[]
97
- validDateEnd: number
98
- isShowIntervalModal: boolean
99
- selectedPeriods: number[]
100
- formatDate: string
101
- currentLang: string
102
- }>()
103
- const emits = defineEmits<{
104
- (event: 'submit-interval-modal', value: number[]): void
105
- (event: 'show-interval-modal'): void
106
- (event: 'hide-interval-modal'): void
107
- }>()
108
-
109
- const localization = computed<UI_I_Localization>(() => useLocal())
110
-
111
- const onShowIntervalModal = (): void => {
112
- emits('show-interval-modal')
113
- }
114
- const onHideIntervalModal = (): void => {
115
- emits('hide-interval-modal')
116
- }
117
- const onSubmitIntervalModal = (data: number[]): void => {
118
- emits('submit-interval-modal', data)
119
- }
120
- </script>
121
-
122
- <style>
123
- :root {
124
- --overview-filter-text-color: #4d5d69;
125
- --overview-filter-edit-hover-color: #008fd6;
126
- }
127
- :root.dark-theme {
128
- --overview-filter-text-color: #e9eaec;
129
- --overview-filter-edit-hover-color: #2ba2de;
130
- }
131
- </style>
132
- <style scoped lang="scss">
133
- .overview-filters {
134
- display: flex;
135
- justify-content: space-between;
136
- align-items: center;
137
- padding: 12px 16px 16px 16px;
138
-
139
- .period-select-wrap {
140
- display: flex;
141
- align-items: center;
142
-
143
- .chart-text {
144
- font-size: 13px;
145
- color: var(--overview-filter-text-color);
146
- margin-left: 12px;
147
- }
148
-
149
- .interval-modal-button {
150
- color: var(--overview-filter-text-color);
151
- margin-left: 8px;
152
- cursor: pointer;
153
-
154
- &:hover {
155
- color: var(--overview-filter-edit-hover-color);
156
- }
157
- }
158
- }
159
-
160
- .view-select-wrap {
161
- display: flex;
162
- align-items: center;
163
- }
164
-
165
- .label-select {
166
- font-size: 13px;
167
- font-weight: 500;
168
- color: var(--overview-filter-text-color);
169
- margin-right: 12px;
170
- }
171
- }
172
- </style>
1
+ <template>
2
+ <div class="overview-filters">
3
+ <div class="period-select-wrap">
4
+ <label for="period-select" class="label-select"
5
+ >{{ localization.inventoryMonitor.period }}:</label
6
+ >
7
+
8
+ <ui-select
9
+ v-if="!props.disabledPeriodOptions"
10
+ v-model="selectedPeriod"
11
+ :items="props.periodOptions"
12
+ test-id="period-select"
13
+ width="auto"
14
+ />
15
+ <span v-else class="single-option">{{
16
+ props.periodOptions[0].text
17
+ }}</span>
18
+ <span v-if="!props.disabledPeriodOptions" class="chart-text">
19
+ {{ props.chartTitleDate }}
20
+ </span>
21
+ <ui-skeleton-item
22
+ v-if="!props.disabledPeriodOptions && !props.chartTitleDate"
23
+ width="320"
24
+ height="16"
25
+ />
26
+
27
+ <ui-tooltip
28
+ v-show="props.isShowCustomIntervalButton"
29
+ id="tooltip-interval-modal-button"
30
+ test-id="tooltip-interval-modal-button"
31
+ size="sm"
32
+ position="bottom"
33
+ position-by-tooltip="center"
34
+ >
35
+ <template #target>
36
+ <div
37
+ id="tooltip-interval-modal-button"
38
+ class="popped tooltip inline-block"
39
+ >
40
+ <ui-icon
41
+ name="edit"
42
+ width="16"
43
+ height="16"
44
+ test-id="show-interval-modal-button"
45
+ class="interval-modal-button"
46
+ @click="onShowIntervalModal"
47
+ />
48
+ </div>
49
+ </template>
50
+ <template #content>
51
+ <span class="header-tooltip-text">
52
+ {{ localization.inventoryMonitor.changeCustomInterval }}
53
+ </span>
54
+ </template>
55
+ </ui-tooltip>
56
+ </div>
57
+
58
+ <div class="view-select-wrap">
59
+ <label for="view-select" class="label-select"
60
+ >{{ localization.common.view }}:</label
61
+ >
62
+ <ui-select
63
+ v-model="selectedView"
64
+ :items="props.viewOptions"
65
+ test-id="view-select"
66
+ width="auto"
67
+ left
68
+ />
69
+ </div>
70
+ </div>
71
+
72
+ <common-monitor-overview-filters-custom-interval-modal
73
+ v-if="props.validDateEnd"
74
+ v-show="props.isShowIntervalModal"
75
+ :selected-periods="props.selectedPeriods"
76
+ :format-date="props.formatDate"
77
+ :current-lang="props.currentLang"
78
+ :valid-date-end="props.validDateEnd"
79
+ @hide="onHideIntervalModal"
80
+ @submit="onSubmitIntervalModal"
81
+ />
82
+ </template>
83
+
84
+ <script setup lang="ts">
85
+ import type { UI_I_Localization } from '~/lib/models/interfaces'
86
+ import type { UI_I_OptionItem } from '~/components/atoms/lib/models/interfaces'
87
+
88
+ const selectedPeriod = defineModel<string>('selected-period')
89
+ const selectedView = defineModel<string>('selected-view')
90
+
91
+ const props = defineProps<{
92
+ disabledPeriodOptions: boolean
93
+ periodOptions: UI_I_OptionItem[]
94
+ isShowCustomIntervalButton: boolean
95
+ chartTitleDate: string
96
+ viewOptions: UI_I_OptionItem[]
97
+ validDateEnd: number
98
+ isShowIntervalModal: boolean
99
+ selectedPeriods: number[]
100
+ formatDate: string
101
+ currentLang: string
102
+ }>()
103
+ const emits = defineEmits<{
104
+ (event: 'submit-interval-modal', value: number[]): void
105
+ (event: 'show-interval-modal'): void
106
+ (event: 'hide-interval-modal'): void
107
+ }>()
108
+
109
+ const localization = computed<UI_I_Localization>(() => useLocal())
110
+
111
+ const onShowIntervalModal = (): void => {
112
+ emits('show-interval-modal')
113
+ }
114
+ const onHideIntervalModal = (): void => {
115
+ emits('hide-interval-modal')
116
+ }
117
+ const onSubmitIntervalModal = (data: number[]): void => {
118
+ emits('submit-interval-modal', data)
119
+ }
120
+ </script>
121
+
122
+ <style>
123
+ :root {
124
+ --overview-filter-text-color: #4d5d69;
125
+ --overview-filter-edit-hover-color: #008fd6;
126
+ }
127
+ :root.dark-theme {
128
+ --overview-filter-text-color: #e9eaec;
129
+ --overview-filter-edit-hover-color: #2ba2de;
130
+ }
131
+ </style>
132
+ <style scoped lang="scss">
133
+ .overview-filters {
134
+ display: flex;
135
+ justify-content: space-between;
136
+ align-items: center;
137
+ padding: 12px 16px 16px 16px;
138
+
139
+ .period-select-wrap {
140
+ display: flex;
141
+ align-items: center;
142
+
143
+ .chart-text {
144
+ font-size: 13px;
145
+ color: var(--overview-filter-text-color);
146
+ margin-left: 12px;
147
+ }
148
+
149
+ .interval-modal-button {
150
+ color: var(--overview-filter-text-color);
151
+ margin-left: 8px;
152
+ cursor: pointer;
153
+
154
+ &:hover {
155
+ color: var(--overview-filter-edit-hover-color);
156
+ }
157
+ }
158
+ }
159
+
160
+ .view-select-wrap {
161
+ display: flex;
162
+ align-items: center;
163
+ }
164
+
165
+ .label-select {
166
+ font-size: 13px;
167
+ font-weight: 500;
168
+ color: var(--overview-filter-text-color);
169
+ margin-right: 12px;
170
+ }
171
+ }
172
+ </style>