bfg-common 1.5.708 → 1.5.709

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 (197) hide show
  1. package/CODE_STYLE.md +109 -109
  2. package/assets/img/icons/icons-sprite-dark-1.svg +2 -3
  3. package/assets/img/icons/icons-sprite-dark-3.svg +227 -227
  4. package/assets/img/icons/icons-sprite-dark-5.svg +488 -488
  5. package/assets/img/icons/icons-sprite-light-1.svg +3 -4
  6. package/assets/img/icons/icons-sprite-light-3.svg +227 -227
  7. package/assets/img/icons/icons-sprite-light-5.svg +488 -488
  8. package/assets/localization/local_be.json +46 -3
  9. package/assets/localization/local_en.json +46 -3
  10. package/assets/localization/local_hy.json +46 -3
  11. package/assets/localization/local_kk.json +46 -3
  12. package/assets/localization/local_ru.json +48 -5
  13. package/assets/localization/local_zh.json +46 -3
  14. package/assets/scss/common/icons/icons-1.scss +1 -1
  15. package/assets/scss/common/icons/icons-2.scss +18 -0
  16. package/assets/scss/common/theme.scss +2 -0
  17. package/assets/scss/components/auth.scss +32 -5
  18. package/components/atoms/TheIcon3.vue +50 -50
  19. package/components/atoms/collapse/CollapseNav.vue +170 -170
  20. package/components/atoms/dropdown/tree/Tree.vue +2 -0
  21. package/components/atoms/perPage/PerPage.vue +58 -58
  22. package/components/atoms/switch/Switch.vue +7 -1
  23. package/components/atoms/table/dataGrid/DataGrid.vue +1718 -1718
  24. package/components/atoms/table/dataGrid/DataGridPagination.vue +97 -97
  25. package/components/atoms/table/dataGrid/lib/config/settingsTable.ts +94 -94
  26. package/components/atoms/table/dataGrid/lib/utils/export.ts +16 -16
  27. package/components/atoms/wizard/Wizard.vue +1 -1
  28. package/components/common/backup/storage/actions/add/lib/utils.ts +51 -51
  29. package/components/common/browse/blocks/contents/filesNew/Skeleton.vue +18 -18
  30. package/components/common/certificate/Certificate.vue +27 -0
  31. package/components/common/certificate/CertificateInfo.vue +139 -0
  32. package/components/common/certificate/Tools.vue +59 -0
  33. package/components/common/certificate/lib/config/tabsPannel.ts +22 -0
  34. package/components/common/certificate/lib/models/interfaces.ts +9 -0
  35. package/components/common/certificate/lib/models/types.ts +1 -0
  36. package/components/common/certificate/modals/renew/New.vue +64 -0
  37. package/components/common/certificate/modals/renew/Old.vue +122 -0
  38. package/components/common/certificate/modals/renew/Renew.vue +67 -0
  39. package/components/common/diagramMain/modals/lib/config/vCenterModal.ts +48 -48
  40. package/components/common/diagramMain/port/Port.vue +580 -580
  41. package/components/common/help/navbar/left/lib/utils/constructAccordion.ts +2 -1
  42. package/components/common/help/navbar/right/Right.vue +86 -23
  43. package/components/common/layout/theHeader/TheHeader.vue +186 -191
  44. package/components/common/layout/theHeader/TheHeaderNew.vue +3 -7
  45. package/components/common/layout/theHeader/TheHeaderOld.vue +3 -7
  46. package/components/common/layout/theHeader/helpMenu/About.vue +79 -79
  47. package/components/common/layout/theHeader/helpMenu/aboutOld/AboutOld.vue +79 -79
  48. package/components/common/layout/theHeader/modals/reconnect/ReconnectOld.vue +2 -0
  49. package/components/common/layout/theHeader/userMenu/UserMenu.vue +109 -113
  50. package/components/common/layout/theHeader/userMenu/modals/changePassword/ChangePassword.vue +12 -21
  51. package/components/common/layout/theHeader/userMenu/modals/changePassword/New.vue +36 -43
  52. package/components/common/layout/theHeader/userMenu/modals/changePassword/Old.vue +0 -2
  53. package/components/common/layout/theHeader/userMenu/modals/changePassword/lib/utils.ts +1 -1
  54. package/components/common/layout/theHeader/userMenu/modals/preferences/Preferences.vue +81 -86
  55. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesNew.vue +113 -102
  56. package/components/common/layout/theHeader/userMenu/modals/preferences/PreferencesOld.vue +2 -4
  57. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/ChangeLanguage.vue +114 -115
  58. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{ChangeLanguageNew.vue → New.vue} +65 -89
  59. package/components/common/layout/theHeader/userMenu/modals/preferences/changeLanguage/{ChangeLanguageOld.vue → Old.vue} +66 -91
  60. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/DefaultConsole.vue +8 -7
  61. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{DefaultConsoleNew.vue → New.vue} +3 -3
  62. package/components/common/layout/theHeader/userMenu/modals/preferences/defaultConsole/{DefaultConsoleOld.vue → Old.vue} +2 -2
  63. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/Inventory.vue +7 -8
  64. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{InventoryNew.vue → New.vue} +3 -2
  65. package/components/common/layout/theHeader/userMenu/modals/preferences/inventory/{InventoryOld.vue → Old.vue} +2 -2
  66. package/components/common/layout/theHeader/userMenu/modals/preferences/lib/models/types.ts +7 -7
  67. package/components/common/layout/theHeader/userMenu/modals/preferences/security/New.vue +277 -12
  68. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Old.vue +30 -56
  69. package/components/common/layout/theHeader/userMenu/modals/preferences/security/Security.vue +65 -6
  70. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{TimeFormatNew.vue → New.vue} +3 -3
  71. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/{TimeFormatOld.vue → Old.vue} +2 -2
  72. package/components/common/layout/theHeader/userMenu/modals/preferences/timeFormat/TimeFormat.vue +8 -8
  73. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{ViewNew.vue → New.vue} +12 -3
  74. package/components/common/layout/theHeader/userMenu/modals/preferences/view/{ViewOld.vue → Old.vue} +2 -2
  75. package/components/common/layout/theHeader/userMenu/modals/preferences/view/View.vue +33 -45
  76. package/components/common/monitor/advanced/graphView/GraphView.vue +8 -0
  77. package/components/common/monitor/advanced/tools/Tools.vue +5 -1
  78. package/components/common/pages/auth/TheFooter.vue +104 -0
  79. package/components/common/pages/backups/DetailView.vue +52 -52
  80. package/components/common/pages/backups/lib/models/interfaces.ts +36 -36
  81. package/components/common/pages/backups/modals/Modals.vue +243 -243
  82. package/components/common/pages/backups/modals/createBackup/configuration/maxBandwidth/lib/config/options.ts +6 -6
  83. package/components/common/pages/backups/modals/createBackup/lib/config/readyToCompleteOptions.ts +69 -69
  84. package/components/common/pages/backups/modals/lib/config/restore.ts +115 -115
  85. package/components/common/pages/backups/modals/lib/models/interfaces.ts +186 -186
  86. package/components/common/pages/backups/modals/restore/name/lib/models/interfaces.ts +6 -6
  87. package/components/common/pages/files/lib/models/enums.ts +10 -0
  88. package/components/common/pages/hardwareHealth/historyTestimony/tools/Tools.vue +7 -2
  89. package/components/common/pages/hardwareHealth/tableView/TableView.vue +8 -0
  90. package/components/common/pages/hardwareHealth/tableView/lib/config/sensorTable.ts +13 -1
  91. package/components/common/pages/hardwareHealth/toolsPanel/lib/config/actionsPanel.ts +4 -4
  92. package/components/common/pages/home/lib/models/interfaces.ts +48 -48
  93. package/components/common/pages/home/widgets/hosts/Hosts.vue +27 -27
  94. package/components/common/pages/home/widgets/hosts/lib/config/items.ts +23 -23
  95. package/components/common/pages/home/widgets/vms/VmsOld.vue +35 -35
  96. package/components/common/pages/home/widgets/vms/lib/config/items.ts +19 -19
  97. package/components/common/pages/scheduledTasks/lib/utils/utils.ts +84 -84
  98. package/components/common/pages/tasks/table/expandDetails/ExpandDetails.vue +1 -1
  99. package/components/common/qr/Qr.vue +69 -0
  100. package/components/common/readyToComplete/ReadyToComplete.vue +17 -17
  101. package/components/common/select/radio/RadioGroup.vue +137 -137
  102. package/components/common/selectLanguage/SelectLanguage.vue +200 -200
  103. package/components/common/spiceConsole/Drawer.vue +420 -420
  104. package/components/common/spiceConsole/SpiceConsole.vue +184 -184
  105. package/components/common/spiceConsole/lib/models/interfaces.ts +5 -5
  106. package/components/common/split/horizontal/New.vue +0 -2
  107. package/components/common/split/vertical/New.vue +2 -1
  108. package/components/common/tools/Actions.vue +207 -207
  109. package/components/common/treeView/TreeView.vue +52 -52
  110. package/components/common/vm/actions/add/New.vue +1 -1
  111. package/components/common/vm/actions/add/Old.vue +1 -1
  112. package/components/common/vm/actions/clone/lib/config/steps.ts +295 -295
  113. package/components/common/vm/actions/clone/new/New.vue +438 -438
  114. package/components/common/vm/actions/clone/old/Old.vue +1 -0
  115. package/components/common/vm/actions/common/customizeHardware/virtualHardware/New.vue +10 -34
  116. package/components/common/vm/actions/common/customizeHardware/virtualHardware/Old.vue +15 -37
  117. package/components/common/vm/actions/common/customizeHardware/virtualHardware/VirtualHardware.vue +49 -50
  118. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/coresPerSocket/CoresPerSocket.vue +1 -1
  119. package/components/common/vm/actions/common/customizeHardware/virtualHardware/cpu/shares/lib/config/options.ts +28 -28
  120. package/components/common/vm/actions/common/customizeHardware/virtualHardware/lib/models/interfaces.ts +3 -1
  121. package/components/common/vm/actions/common/customizeHardware/virtualHardware/memory/Memory.vue +283 -283
  122. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newHardDisk/NewHardDisk.vue +13 -7
  123. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/New.vue +7 -4
  124. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/NewPciDevice.vue +52 -45
  125. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/Old.vue +5 -8
  126. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/DirectPathIo.vue +1 -3
  127. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/New.vue +2 -2
  128. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/directPathIo/Old.vue +2 -2
  129. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/DynamicDirectPathIo.vue +1 -1
  130. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/New.vue +1 -2
  131. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/dynamicDirectPathIo/Old.vue +1 -2
  132. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/New.vue +1 -1
  133. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/NvidiaGrid.vue +1 -1
  134. package/components/common/vm/actions/common/customizeHardware/virtualHardware/newPciDevice/nvidiaGrid/Old.vue +1 -1
  135. package/components/common/vm/actions/common/customizeHardware/vmoptions/bootOptions/order/Order.vue +156 -156
  136. package/components/common/vm/actions/common/select/compatibility/Old.vue +107 -107
  137. package/components/common/vm/actions/common/select/createType/lib/models/interfaces.ts +5 -5
  138. package/components/common/vm/actions/common/select/options/New.vue +264 -264
  139. package/components/common/vm/actions/common/select/options/Old.vue +1 -2
  140. package/components/common/vm/actions/common/select/options/Options.vue +58 -58
  141. package/components/common/vm/actions/common/select/storage/Old.vue +125 -125
  142. package/components/common/vm/actions/common/select/storage/new/New.vue +311 -311
  143. package/components/common/vm/actions/common/select/storage/new/lib/models/interfaces.ts +5 -5
  144. package/components/common/vm/actions/common/select/storage/new/lib/utils/utils.ts +21 -21
  145. package/components/common/vm/actions/common/select/template/old/Old.vue +50 -50
  146. package/components/common/vm/actions/editSettings/new/Skeleton.vue +88 -88
  147. package/components/common/wizards/common/compatibility/Compatibility.vue +35 -35
  148. package/components/common/wizards/common/compatibility/New.vue +1 -1
  149. package/components/common/wizards/common/compatibility/Old.vue +1 -1
  150. package/components/common/wizards/common/steps/computeResource/New.vue +93 -93
  151. package/components/common/wizards/common/steps/name/Name.vue +178 -178
  152. package/components/common/wizards/common/steps/name/New.vue +221 -221
  153. package/components/common/wizards/common/steps/name/Old.vue +121 -121
  154. package/components/common/wizards/common/steps/name/lib/models/interfaces.ts +4 -4
  155. package/components/common/wizards/common/steps/name/location/New.vue +40 -40
  156. package/components/common/wizards/datastore/add/Add.vue +228 -228
  157. package/components/common/wizards/datastore/add/lib/config/createDatastore.ts +1 -0
  158. package/components/common/wizards/datastore/add/lib/models/interfaces.ts +1 -0
  159. package/components/common/wizards/datastore/add/lib/utils.ts +85 -85
  160. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceNew.vue +5 -0
  161. package/components/common/wizards/datastore/add/steps/nameAndDevice/NameAndDeviceOld.vue +5 -0
  162. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/AdvancedOptions.vue +43 -0
  163. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/New.vue +114 -0
  164. package/components/common/wizards/datastore/add/steps/nameAndDevice/advancedOptions/Old.vue +114 -0
  165. package/components/common/wizards/datastore/add/steps/nameAndDevice/table/old/Old.vue +2 -3
  166. package/components/common/wizards/datastore/add/steps/readyComplete/lib/config/propertiesDetails.ts +8 -1
  167. package/components/common/wizards/datastore/add/steps/typeMode/lib/config/typeOptions.ts +43 -43
  168. package/components/common/wizards/vm/migrate/lib/models/enums.ts +2 -2
  169. package/components/common/wizards/vm/migrate/steps/selectStorage/SelectStorage.vue +4 -4
  170. package/components/common/wizards/vm/migrate/steps/selectStorage/configure/disk/table/new/lib/config/diskTable.ts +6 -2
  171. package/components/common/wizards/vm/migrate/steps/selectStorage/configure/disk/table/old/lib/config/diskTable.ts +18 -12
  172. package/composables/useAppVersion.ts +21 -21
  173. package/composables/useEnvLanguage.ts +7 -8
  174. package/composables/useLocal.ts +6 -6
  175. package/composables/useLocalCommon.ts +39 -39
  176. package/lib/models/interfaces.ts +1 -0
  177. package/package.json +3 -4
  178. package/plugins/console.ts +21 -21
  179. package/plugins/date.ts +14 -37
  180. package/plugins/mouse.ts +21 -21
  181. package/plugins/panelStates.ts +70 -70
  182. package/plugins/text.ts +59 -59
  183. package/public/spice-console/application/clientgui.js +854 -854
  184. package/public/spice-console/application/packetfactory.js +211 -211
  185. package/public/spice-console/application/virtualmouse.js +147 -147
  186. package/public/spice-console/lib/images/bitmap.js +203 -203
  187. package/public/spice-console/network/spicechannel.js +440 -440
  188. package/public/spice-console/process/cursorprocess.js +128 -128
  189. package/public/spice-console/process/inputprocess.js +227 -227
  190. package/public/spice-console/process/mainprocess.js +212 -212
  191. package/public/spice-console/run.js +210 -210
  192. package/store/main/getters.ts +2 -2
  193. package/store/main/mutations.ts +7 -7
  194. package/store/main/state.ts +7 -7
  195. package/store/tasks/mappers/recentTasks.ts +123 -123
  196. package/store/tasks/mutations.ts +82 -82
  197. package/components/common/qrcode/Qrcode.vue +0 -56
@@ -1,123 +1,123 @@
1
- import {
2
- UI_E_RecentTaskStatus,
3
- UI_E_IconNameByRecentTaskStatus,
4
- } from '~/lib/models/store/tasks/enums'
5
- import type {
6
- API_UI_I_RecentTask,
7
- UI_I_RecentTask,
8
- UI_T_TaskStatusDetails,
9
- } from '~/lib/models/store/tasks/interfaces'
10
- import { base64 } from '~/lib/utils/base64'
11
- import {
12
- UI_E_RecentTaskStatusIcon,
13
- UI_E_RecentTaskStatusIconNewView,
14
- } from '~/store/tasks/lib/models/enums'
15
-
16
- export const recentTasks = (
17
- data: API_UI_I_RecentTask<string>
18
- ): UI_I_RecentTask<string> => {
19
- const { $store }: any = useNuxtApp()
20
-
21
- const isNewView = $store.getters['main/getIsNewView']
22
-
23
- const items =
24
- data.items
25
- ?.sort((a, b) => {
26
- return b.start_time - a.start_time
27
- })
28
- .map((task) => {
29
- let args: any = {}
30
- try {
31
- args = base64.decode(task.args)
32
- } catch (error) {
33
- args = {}
34
- }
35
-
36
- let completion: string = task.completion + '' || '--'
37
- let execution: string | number = Math.abs(
38
- task.start_time - task.completion
39
- )
40
- let queuedFor: number = task.start_time - task.creation_time
41
- let startTime: string = task.start_time + '' || '--'
42
- // Обрабатываем данные когда задачка в ожидании
43
- if (task.status === 0) {
44
- completion = '--'
45
- execution = '--'
46
- queuedFor = 0
47
- startTime = Date.now() / 1000 + ''
48
- // Обрабатываем данные когда задачка в работе или когда в статусе retry
49
- } else if (task.status === 1 || task.status === 5) {
50
- completion = '--'
51
- execution = '--'
52
- }
53
-
54
- const { upd_operations } = task.extra
55
- const operations: UI_T_TaskStatusDetails[] =
56
- upd_operations?.operations?.map(
57
- (operation: UI_T_TaskStatusDetails) => {
58
- return {
59
- ...operation,
60
- iconClassName: isNewView
61
- ? UI_E_RecentTaskStatusIconNewView[operation.status]
62
- : UI_E_RecentTaskStatusIcon[operation.status],
63
- testId: operation.operation_type.replaceAll(' ', '-'),
64
- }
65
- }
66
- ) || []
67
-
68
- // TODO
69
- let statusIcon = 'help-icon'
70
- switch (task.status) {
71
- case 0:
72
- statusIcon = 'help-icon'
73
- break
74
- case 1:
75
- statusIcon = 'green-play'
76
- break
77
- case 2:
78
- statusIcon = 'success-circle'
79
- break
80
- case 3:
81
- case 4:
82
- statusIcon = 'error-outline'
83
- break
84
- case 5:
85
- statusIcon = 'warning-outline'
86
- break
87
- }
88
-
89
- const targetName = task.extra.target_name || '--'
90
- const targetType = task.extra.target_type || task.target_type
91
-
92
- return {
93
- args,
94
- completion,
95
- execution,
96
- queuedFor,
97
- startTime,
98
- statusIcon,
99
- progress: task.progress,
100
- details: task.details,
101
- error: task.error,
102
- initiator: task.initiator,
103
- server: task.server,
104
- // statusIcon: UI_E_IconNameByRecentTaskStatus[task.status],
105
- statusText: task.error || UI_E_RecentTaskStatus[task.status],
106
- status: task.status,
107
- statusDetails: operations,
108
- target: task.target,
109
- targetName,
110
- targetType,
111
- // targetType: task.target_type,
112
- taskName: task.task_name,
113
- id: task.id,
114
- zone: task.zone,
115
- extra: task.extra,
116
- isCanceled: task.status === 4
117
- }
118
- }) || []
119
- return {
120
- items,
121
- last: data.last,
122
- }
123
- }
1
+ import {
2
+ UI_E_RecentTaskStatus,
3
+ UI_E_IconNameByRecentTaskStatus,
4
+ } from '~/lib/models/store/tasks/enums'
5
+ import type {
6
+ API_UI_I_RecentTask,
7
+ UI_I_RecentTask,
8
+ UI_T_TaskStatusDetails,
9
+ } from '~/lib/models/store/tasks/interfaces'
10
+ import { base64 } from '~/lib/utils/base64'
11
+ import {
12
+ UI_E_RecentTaskStatusIcon,
13
+ UI_E_RecentTaskStatusIconNewView,
14
+ } from '~/store/tasks/lib/models/enums'
15
+
16
+ export const recentTasks = (
17
+ data: API_UI_I_RecentTask<string>
18
+ ): UI_I_RecentTask<string> => {
19
+ const { $store }: any = useNuxtApp()
20
+
21
+ const isNewView = $store.getters['main/getIsNewView']
22
+
23
+ const items =
24
+ data.items
25
+ ?.sort((a, b) => {
26
+ return b.start_time - a.start_time
27
+ })
28
+ .map((task) => {
29
+ let args: any = {}
30
+ try {
31
+ args = base64.decode(task.args)
32
+ } catch (error) {
33
+ args = {}
34
+ }
35
+
36
+ let completion: string = task.completion + '' || '--'
37
+ let execution: string | number = Math.abs(
38
+ task.start_time - task.completion
39
+ )
40
+ let queuedFor: number = task.start_time - task.creation_time
41
+ let startTime: string = task.start_time + '' || '--'
42
+ // Обрабатываем данные когда задачка в ожидании
43
+ if (task.status === 0) {
44
+ completion = '--'
45
+ execution = '--'
46
+ queuedFor = 0
47
+ startTime = Date.now() / 1000 + ''
48
+ // Обрабатываем данные когда задачка в работе или когда в статусе retry
49
+ } else if (task.status === 1 || task.status === 5) {
50
+ completion = '--'
51
+ execution = '--'
52
+ }
53
+
54
+ const { upd_operations } = task.extra
55
+ const operations: UI_T_TaskStatusDetails[] =
56
+ upd_operations?.operations?.map(
57
+ (operation: UI_T_TaskStatusDetails) => {
58
+ return {
59
+ ...operation,
60
+ iconClassName: isNewView
61
+ ? UI_E_RecentTaskStatusIconNewView[operation.status]
62
+ : UI_E_RecentTaskStatusIcon[operation.status],
63
+ testId: operation.operation_type.replaceAll(' ', '-'),
64
+ }
65
+ }
66
+ ) || []
67
+
68
+ // TODO
69
+ let statusIcon = 'help-icon'
70
+ switch (task.status) {
71
+ case 0:
72
+ statusIcon = 'help-icon'
73
+ break
74
+ case 1:
75
+ statusIcon = 'green-play'
76
+ break
77
+ case 2:
78
+ statusIcon = 'success-circle'
79
+ break
80
+ case 3:
81
+ case 4:
82
+ statusIcon = 'error-outline'
83
+ break
84
+ case 5:
85
+ statusIcon = 'warning-outline'
86
+ break
87
+ }
88
+
89
+ const targetName = task.extra.target_name || '--'
90
+ const targetType = task.extra.target_type || task.target_type
91
+
92
+ return {
93
+ args,
94
+ completion,
95
+ execution,
96
+ queuedFor,
97
+ startTime,
98
+ statusIcon,
99
+ progress: task.progress,
100
+ details: task.details,
101
+ error: task.error,
102
+ initiator: task.initiator,
103
+ server: task.server,
104
+ // statusIcon: UI_E_IconNameByRecentTaskStatus[task.status],
105
+ statusText: task.error || UI_E_RecentTaskStatus[task.status],
106
+ status: task.status,
107
+ statusDetails: operations,
108
+ target: task.target,
109
+ targetName,
110
+ targetType,
111
+ // targetType: task.target_type,
112
+ taskName: task.task_name,
113
+ id: task.id,
114
+ zone: task.zone,
115
+ extra: task.extra,
116
+ isCanceled: task.status === 4
117
+ }
118
+ }) || []
119
+ return {
120
+ items,
121
+ last: data.last,
122
+ }
123
+ }
@@ -1,82 +1,82 @@
1
- import type {
2
- UI_I_RawRecentTask,
3
- UI_I_TasksLoadingPayload,
4
- UI_I_RecentTask,
5
- UI_I_Task,
6
- } from '~/lib/models/store/tasks/interfaces'
7
- import type { UI_I_TasksState } from '~/store/tasks/lib/models/interfaces'
8
-
9
- export default {
10
- M_SET_RECENT_TASKS_LIST(
11
- state: UI_I_TasksState,
12
- payload: UI_I_RecentTask<string>
13
- ): void {
14
- if (state.recentTaskList) {
15
- state.recentTaskList.last = payload.last
16
-
17
- // Заменяем которые уже имеются и удаляем их из payload.items
18
- state.recentTaskList.items = state.recentTaskList.items.map((task) => {
19
- let changedTask = null
20
- payload.items = payload.items.filter((task2) => {
21
- if (task2.id === task.id) changedTask = task2
22
- return task2.id !== task.id
23
- })
24
-
25
- return changedTask || task
26
- })
27
-
28
- // Делаем слияние новых и старых tasks
29
- state.recentTaskList.items = [
30
- ...payload.items,
31
- ...state.recentTaskList.items,
32
- ]
33
- return
34
- }
35
-
36
- state.recentTaskList = payload
37
- },
38
- M_SET_ABORT_CONTROLLER(
39
- state: UI_I_TasksState,
40
- payload: AbortController
41
- ): void {
42
- state.abortController = payload
43
- },
44
- M_CANCEL_RECENT_TASKS(state: UI_I_TasksState): void {
45
- state.abortController && state.abortController.abort()
46
- },
47
- M_HIDE_CANCEL_RECENT_TASK_BY_ID(
48
- state: UI_I_TasksState,
49
- payload: string
50
- ): void {
51
- if (!state.recentTaskList) return
52
- state.recentTaskList.items = state.recentTaskList.items.map((task) => {
53
- if (task.id === payload) {
54
- task.isCanceled = true
55
- }
56
- return task
57
- })
58
- },
59
- M_SET_TASKS_LAST_QUERY(state: UI_I_TasksState, payload: string): void {
60
- state.taskLastRequestType = payload
61
- },
62
- M_SET_TASKS_LIST(state: UI_I_TasksState, payload: UI_I_Task<string>): void {
63
- state.taskList = payload
64
- },
65
- M_SET_UPDATED_RECENT_TASKS_LIST(
66
- state: UI_I_TasksState,
67
- payload: UI_I_RawRecentTask<string>
68
- ): void {
69
- state.updatedTaskList = payload.items
70
- },
71
- M_SET_FIRST_TASK(state: UI_I_TasksState): void {
72
- state.hasFirstTask = true
73
- },
74
-
75
- M_SET_LOADING(
76
- state: UI_I_TasksState,
77
- payload: UI_I_TasksLoadingPayload
78
- ): void {
79
- const { prop, value } = payload
80
- state.loading[prop] = value
81
- },
82
- }
1
+ import type {
2
+ UI_I_RawRecentTask,
3
+ UI_I_TasksLoadingPayload,
4
+ UI_I_RecentTask,
5
+ UI_I_Task,
6
+ } from '~/lib/models/store/tasks/interfaces'
7
+ import type { UI_I_TasksState } from '~/store/tasks/lib/models/interfaces'
8
+
9
+ export default {
10
+ M_SET_RECENT_TASKS_LIST(
11
+ state: UI_I_TasksState,
12
+ payload: UI_I_RecentTask<string>
13
+ ): void {
14
+ if (state.recentTaskList) {
15
+ state.recentTaskList.last = payload.last
16
+
17
+ // Заменяем которые уже имеются и удаляем их из payload.items
18
+ state.recentTaskList.items = state.recentTaskList.items.map((task) => {
19
+ let changedTask = null
20
+ payload.items = payload.items.filter((task2) => {
21
+ if (task2.id === task.id) changedTask = task2
22
+ return task2.id !== task.id
23
+ })
24
+
25
+ return changedTask || task
26
+ })
27
+
28
+ // Делаем слияние новых и старых tasks
29
+ state.recentTaskList.items = [
30
+ ...payload.items,
31
+ ...state.recentTaskList.items,
32
+ ]
33
+ return
34
+ }
35
+
36
+ state.recentTaskList = payload
37
+ },
38
+ M_SET_ABORT_CONTROLLER(
39
+ state: UI_I_TasksState,
40
+ payload: AbortController
41
+ ): void {
42
+ state.abortController = payload
43
+ },
44
+ M_CANCEL_RECENT_TASKS(state: UI_I_TasksState): void {
45
+ state.abortController && state.abortController.abort()
46
+ },
47
+ M_HIDE_CANCEL_RECENT_TASK_BY_ID(
48
+ state: UI_I_TasksState,
49
+ payload: string
50
+ ): void {
51
+ if (!state.recentTaskList) return
52
+ state.recentTaskList.items = state.recentTaskList.items.map((task) => {
53
+ if (task.id === payload) {
54
+ task.isCanceled = true
55
+ }
56
+ return task
57
+ })
58
+ },
59
+ M_SET_TASKS_LAST_QUERY(state: UI_I_TasksState, payload: string): void {
60
+ state.taskLastRequestType = payload
61
+ },
62
+ M_SET_TASKS_LIST(state: UI_I_TasksState, payload: UI_I_Task<string>): void {
63
+ state.taskList = payload
64
+ },
65
+ M_SET_UPDATED_RECENT_TASKS_LIST(
66
+ state: UI_I_TasksState,
67
+ payload: UI_I_RawRecentTask<string>
68
+ ): void {
69
+ state.updatedTaskList = payload.items
70
+ },
71
+ M_SET_FIRST_TASK(state: UI_I_TasksState): void {
72
+ state.hasFirstTask = true
73
+ },
74
+
75
+ M_SET_LOADING(
76
+ state: UI_I_TasksState,
77
+ payload: UI_I_TasksLoadingPayload
78
+ ): void {
79
+ const { prop, value } = payload
80
+ state.loading[prop] = value
81
+ },
82
+ }
@@ -1,56 +0,0 @@
1
- <template>
2
- <div class="qrcode">
3
- <img v-if="qrDataUrl" :src="qrDataUrl" alt="QR Code" class="qr-image" />
4
- </div>
5
- </template>
6
-
7
- <script setup lang="ts">
8
- import QRCode from 'qrcode'
9
-
10
- const props = defineProps<{
11
- qrCodeUrl: string
12
- }>()
13
-
14
- const qrDataUrl = ref<string>('')
15
- const generateQRCode = async (): Promise<void> => {
16
- try {
17
- qrDataUrl.value = await QRCode.toDataURL(props.qrCodeUrl, {
18
- width: 150,
19
- margin: 2,
20
- })
21
- } catch (error) {
22
- console.error('Error generating QR code:', error)
23
- }
24
- }
25
-
26
- watch(
27
- () => props.qrCodeUrl,
28
- (newValue) => {
29
- newValue && generateQRCode()
30
- },
31
- { immediate: true }
32
- )
33
- </script>
34
-
35
- <style scoped lang="scss">
36
- .qr-code-display {
37
- text-align: center;
38
- max-width: 400px;
39
- margin: 0 auto;
40
- }
41
-
42
- .qr-wrapper {
43
- margin: 20px 0;
44
- padding: 20px;
45
- background: white;
46
- border-radius: 12px;
47
- border: 1px solid #e0e0e0;
48
- display: inline-block;
49
- }
50
-
51
- .qr-canvas,
52
- .qr-image {
53
- width: 150px;
54
- height: 150px;
55
- }
56
- </style>