@rancher/shell 0.1.1 → 0.1.3

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 (294) hide show
  1. package/assets/translations/en-us.yaml +33 -769
  2. package/assets/translations/zh-hans.yaml +153 -781
  3. package/components/ActionMenu.vue +3 -3
  4. package/components/CodeMirror.vue +6 -8
  5. package/components/CommunityLinks.vue +1 -1
  6. package/components/ContainerResourceLimit.vue +14 -0
  7. package/components/ExplorerMembers.vue +123 -0
  8. package/components/ExplorerProjectsNamespaces.vue +405 -0
  9. package/components/GrafanaDashboard.vue +17 -2
  10. package/components/LocaleSelector.vue +81 -0
  11. package/components/PromptModal.vue +2 -3
  12. package/components/ResourceList/index.vue +1 -1
  13. package/components/ResourceTable.vue +3 -6
  14. package/components/SingleClusterInfo.vue +1 -1
  15. package/components/SortableTable/index.vue +23 -20
  16. package/components/SortableTable/selection.js +1 -0
  17. package/components/auth/AzureWarning.vue +5 -1
  18. package/components/auth/Principal.vue +1 -1
  19. package/components/auth/RoleDetailEdit.vue +32 -12
  20. package/components/fleet/FleetRepos.vue +0 -2
  21. package/components/form/NameNsDescription.vue +4 -6
  22. package/components/form/NodeScheduling.vue +1 -1
  23. package/components/form/ResourceTabs/index.vue +27 -18
  24. package/components/form/WorkloadPorts.vue +1 -1
  25. package/components/formatter/ClusterLink.vue +13 -0
  26. package/components/formatter/PodImages.vue +11 -1
  27. package/components/formatter/RKETemplateName.vue +37 -0
  28. package/components/formatter/WorkloadHealthScale.vue +1 -1
  29. package/components/nav/Header.vue +9 -9
  30. package/components/nav/NamespaceFilter.vue +7 -4
  31. package/components/nav/TopLevelMenu.vue +6 -43
  32. package/components/nav/WindowManager/ContainerLogs.vue +1 -1
  33. package/config/product/harvester-manager.js +64 -2
  34. package/config/product/manager.js +9 -0
  35. package/config/settings.js +17 -71
  36. package/config/table-headers.js +0 -1
  37. package/config/types.js +8 -26
  38. package/core/plugin-routes.ts +34 -22
  39. package/core/plugin.ts +15 -3
  40. package/core/plugins-loader.js +2 -0
  41. package/core/plugins.js +79 -36
  42. package/core/types.ts +7 -1
  43. package/creators/app/tsconfig.json +6 -1
  44. package/creators/pkg/init +3 -0
  45. package/creators/pkg/tsconfig.json +7 -2
  46. package/detail/provisioning.cattle.io.cluster.vue +23 -0
  47. package/detail/workload/index.vue +11 -5
  48. package/{components/dialog → dialog}/AddClusterMemberDialog.vue +0 -0
  49. package/{components/dialog → dialog}/AddCustomBadgeDialog.vue +0 -0
  50. package/{components/dialog → dialog}/AddProjectMemberDialog.vue +0 -0
  51. package/{components/dialog → dialog}/AddonConfigConfirmationDialog.vue +0 -0
  52. package/{components/dialog → dialog}/DrainNode.vue +0 -0
  53. package/{components/dialog → dialog}/ForceMachineRemoveDialog.vue +0 -0
  54. package/{components/dialog → dialog}/GenericPrompt.vue +0 -0
  55. package/{components/dialog → dialog}/RollbackWorkloadDialog.vue +0 -0
  56. package/{components/dialog → dialog}/RotateCertificatesDialog.vue +0 -0
  57. package/{components/dialog → dialog}/RotateEncryptionKeyDialog.vue +0 -0
  58. package/{components/dialog → dialog}/SaveAsRKETemplateDialog.vue +0 -0
  59. package/{components/dialog → dialog}/ScaleMachineDownDialog.vue +0 -0
  60. package/edit/auth/azuread.vue +20 -1
  61. package/edit/cloudcredential.vue +7 -1
  62. package/edit/management.cattle.io.project.vue +2 -2
  63. package/edit/namespace.vue +17 -10
  64. package/edit/networking.k8s.io.ingress/index.vue +2 -1
  65. package/edit/persistentvolumeclaim.vue +33 -2
  66. package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +1 -1
  67. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +34 -6
  68. package/edit/provisioning.cattle.io.cluster/index.vue +1 -1
  69. package/edit/provisioning.cattle.io.cluster/rke2.vue +21 -6
  70. package/edit/service.vue +1 -1
  71. package/edit/workload/index.vue +363 -15
  72. package/edit/workload/mixins/workload.js +62 -7
  73. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +1 -0
  74. package/layouts/default.vue +52 -27
  75. package/layouts/error.vue +5 -1
  76. package/layouts/home.vue +6 -2
  77. package/list/harvesterhci.io.management.cluster.vue +74 -33
  78. package/list/namespace.vue +3 -5
  79. package/list/provisioning.cattle.io.cluster.vue +6 -0
  80. package/machine-config/amazonec2.vue +2 -0
  81. package/machine-config/harvester.vue +96 -49
  82. package/middleware/authenticated.js +56 -52
  83. package/mixins/brand.js +3 -4
  84. package/mixins/create-edit-view/impl.js +0 -8
  85. package/mixins/form-validation.js +1 -1
  86. package/mixins/resource-fetch.js +3 -1
  87. package/models/chart.js +1 -1
  88. package/models/cluster/node.js +12 -1
  89. package/models/fleet.cattle.io.bundle.js +26 -19
  90. package/models/harvesterhci.io.management.cluster.js +194 -5
  91. package/models/management.cattle.io.cluster.js +1 -1
  92. package/models/management.cattle.io.clusterroletemplatebinding.js +9 -0
  93. package/models/management.cattle.io.globalrole.js +0 -19
  94. package/models/management.cattle.io.project.js +23 -2
  95. package/models/management.cattle.io.roletemplate.js +2 -21
  96. package/models/namespace.js +19 -3
  97. package/models/pod.js +19 -2
  98. package/models/provisioning.cattle.io.cluster.js +71 -0
  99. package/models/service.js +5 -1
  100. package/models/workload.js +4 -243
  101. package/models/workload.service.js +314 -0
  102. package/nuxt.config.js +14 -12
  103. package/package.json +3 -3
  104. package/pages/auth/login.vue +11 -2
  105. package/pages/auth/setup.vue +1 -1
  106. package/pages/c/_cluster/_product/members/index.vue +3 -93
  107. package/pages/c/_cluster/_product/projectsnamespaces.vue +6 -403
  108. package/pages/c/_cluster/apps/charts/install.vue +0 -6
  109. package/pages/c/_cluster/settings/performance.vue +19 -16
  110. package/pages/fail-whale.vue +1 -10
  111. package/pages/index.vue +18 -4
  112. package/pages/plugins.vue +2 -2
  113. package/pages/prefs.vue +8 -6
  114. package/pkg/auto-import.js +44 -7
  115. package/pkg/dynamic-plugin-loader.js +28 -0
  116. package/pkg/import.js +2 -2
  117. package/pkg/model-loader-require.lib.js +3 -0
  118. package/pkg/vue.config.js +9 -6
  119. package/plugins/console.js +10 -5
  120. package/plugins/dashboard-store/actions.js +8 -3
  121. package/plugins/dashboard-store/getters.js +7 -2
  122. package/plugins/dashboard-store/model-loader-require.js +12 -0
  123. package/plugins/dashboard-store/model-loader.js +4 -1
  124. package/plugins/dashboard-store/resource-class.js +10 -3
  125. package/plugins/steve/actions.js +1 -1
  126. package/plugins/steve/index.js +6 -4
  127. package/plugins/steve/steve-description-class.js +32 -0
  128. package/plugins/steve/subscribe.js +34 -23
  129. package/rancher-components/Banner/Banner.vue +2 -2
  130. package/rancher-components/Form/Checkbox/Checkbox.test.ts +77 -0
  131. package/rancher-components/Form/Checkbox/Checkbox.vue +12 -2
  132. package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +0 -2
  133. package/rancher-components/Form/LabeledInput/LabeledInput.vue +2 -0
  134. package/rancher-components/Form/Radio/RadioButton.vue +14 -1
  135. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.test.ts +107 -0
  136. package/{components/form → rancher-components/Form/ToggleSwitch}/ToggleSwitch.vue +18 -8
  137. package/rancher-components/Form/ToggleSwitch/index.ts +1 -0
  138. package/rancher-components/Form/index.ts +1 -0
  139. package/scripts/build-pkg.sh +48 -2
  140. package/scripts/drone-build-pkg.sh +31 -0
  141. package/scripts/publish-shell.sh +10 -11
  142. package/scripts/serve-pkgs +17 -10
  143. package/scripts/test-plugins-build.sh +18 -1
  144. package/store/catalog.js +3 -1
  145. package/store/i18n.js +16 -11
  146. package/store/index.js +4 -181
  147. package/store/prefs.js +30 -2
  148. package/store/type-map.js +16 -29
  149. package/types/{index.d.ts → rancher/index.d.ts} +0 -0
  150. package/utils/cluster.js +1 -1
  151. package/utils/custom-validators.js +1 -12
  152. package/utils/dynamic-importer.js +1 -1
  153. package/utils/validators/setting.js +0 -35
  154. package/components/FilterLabel.vue +0 -254
  155. package/components/HarvesterUpgradeProgressBarList.vue +0 -109
  156. package/components/VMConsoleBar.vue +0 -87
  157. package/components/dialog/harvester/AddHotplugModal.vue +0 -159
  158. package/components/dialog/harvester/BackupModal.vue +0 -117
  159. package/components/dialog/harvester/CloneTemplate.vue +0 -125
  160. package/components/dialog/harvester/EjectCDROMDialog.vue +0 -157
  161. package/components/dialog/harvester/ExportImageDialog.vue +0 -152
  162. package/components/dialog/harvester/MaintenanceDialog.vue +0 -94
  163. package/components/dialog/harvester/MigrationDialog.vue +0 -154
  164. package/components/dialog/harvester/RestoreDialog.vue +0 -153
  165. package/components/dialog/harvester/SupportBundle.vue +0 -217
  166. package/components/dialog/harvester/UnplugVolume.vue +0 -108
  167. package/components/form/SerialConsole/index.vue +0 -267
  168. package/components/formatter/AttachVMWithName.vue +0 -46
  169. package/components/formatter/CloudInitType.vue +0 -27
  170. package/components/formatter/HarvesterBackupTargetValidation.vue +0 -43
  171. package/components/formatter/HarvesterCPUUsed.vue +0 -122
  172. package/components/formatter/HarvesterDiskState.vue +0 -66
  173. package/components/formatter/HarvesterHostName.vue +0 -66
  174. package/components/formatter/HarvesterIpAddress.vue +0 -90
  175. package/components/formatter/HarvesterMemoryUsed.vue +0 -140
  176. package/components/formatter/HarvesterMigrationState.vue +0 -85
  177. package/components/formatter/HarvesterNodeName.vue +0 -49
  178. package/components/formatter/HarvesterStorageUsed.vue +0 -194
  179. package/components/formatter/HarvesterVmState.vue +0 -123
  180. package/components/nav/HarvesterUpgrade.vue +0 -232
  181. package/components/novnc/NovncConsole.vue +0 -93
  182. package/components/novnc/NovncConsoleItem.vue +0 -89
  183. package/components/novnc/NovncConsoleWrapper.vue +0 -243
  184. package/config/harvester-map.js +0 -44
  185. package/config/harvester-table-headers.js +0 -27
  186. package/config/product/harvester.js +0 -305
  187. package/detail/harvesterhci.io.host/HarvesterHostBasic.vue +0 -364
  188. package/detail/harvesterhci.io.host/HarvesterHostDisk.vue +0 -200
  189. package/detail/harvesterhci.io.host/HarvesterHostNetwork.vue +0 -89
  190. package/detail/harvesterhci.io.host/VirtualMachineInstance.vue +0 -134
  191. package/detail/harvesterhci.io.host/index.vue +0 -243
  192. package/detail/harvesterhci.io.virtualmachinebackup/index.vue +0 -221
  193. package/detail/harvesterhci.io.virtualmachineimage.vue +0 -118
  194. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineBasics.vue +0 -279
  195. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineEvents.vue +0 -75
  196. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineKeypairs.vue +0 -114
  197. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineMigration.vue +0 -79
  198. package/detail/kubevirt.io.virtualmachine/index.vue +0 -213
  199. package/edit/harvesterhci.io.cloudtemplate.vue +0 -123
  200. package/edit/harvesterhci.io.host/HarvesterDisk.vue +0 -262
  201. package/edit/harvesterhci.io.host/index.vue +0 -533
  202. package/edit/harvesterhci.io.keypair.vue +0 -112
  203. package/edit/harvesterhci.io.managedchart/index.vue +0 -25
  204. package/edit/harvesterhci.io.managedchart/rancher-monitoring.vue +0 -172
  205. package/edit/harvesterhci.io.networkattachmentdefinition.vue +0 -210
  206. package/edit/harvesterhci.io.setting/additional-ca.vue +0 -36
  207. package/edit/harvesterhci.io.setting/backup-target.vue +0 -182
  208. package/edit/harvesterhci.io.setting/http-proxy.vue +0 -79
  209. package/edit/harvesterhci.io.setting/index.vue +0 -201
  210. package/edit/harvesterhci.io.setting/overcommit-config.vue +0 -94
  211. package/edit/harvesterhci.io.setting/ssl-certificates.vue +0 -117
  212. package/edit/harvesterhci.io.setting/ssl-parameters.vue +0 -161
  213. package/edit/harvesterhci.io.setting/support-bundle-image.vue +0 -134
  214. package/edit/harvesterhci.io.setting/support-bundle-namespaces.vue +0 -73
  215. package/edit/harvesterhci.io.setting/vip-pools.vue +0 -244
  216. package/edit/harvesterhci.io.setting/vm-force-reset-policy.vue +0 -81
  217. package/edit/harvesterhci.io.virtualmachinebackup.vue +0 -256
  218. package/edit/harvesterhci.io.virtualmachineimage.vue +0 -364
  219. package/edit/harvesterhci.io.virtualmachinetemplateversion.vue +0 -340
  220. package/edit/harvesterhci.io.volume.vue +0 -195
  221. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/AccessCredentialsUsers.vue +0 -190
  222. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/index.vue +0 -212
  223. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/basicAuth.vue +0 -94
  224. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/sshkey.vue +0 -85
  225. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/DataTemplate.vue +0 -153
  226. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/index.vue +0 -279
  227. package/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory.vue +0 -113
  228. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/__tests__/HarvesterEditNetwork.test.ts +0 -41
  229. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/base.vue +0 -281
  230. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/index.vue +0 -142
  231. package/edit/kubevirt.io.virtualmachine/VirtualMachineReserved.vue +0 -54
  232. package/edit/kubevirt.io.virtualmachine/VirtualMachineSSHKey.vue +0 -256
  233. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/index.vue +0 -391
  234. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditContainer.test.ts +0 -40
  235. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditExisting.test.ts +0 -102
  236. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVMImage.test.ts +0 -117
  237. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVolume.test.ts +0 -74
  238. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/container.vue +0 -132
  239. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/existing.vue +0 -303
  240. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/vmImage.vue +0 -285
  241. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/volume.vue +0 -188
  242. package/edit/kubevirt.io.virtualmachine/index.vue +0 -642
  243. package/edit/network.harvesterhci.io.clusternetwork/index.vue +0 -19
  244. package/edit/network.harvesterhci.io.clusternetwork/vlan.vue +0 -134
  245. package/edit/workload/types/Deployment.vue +0 -377
  246. package/edit/workload/types/Generic.vue +0 -295
  247. package/list/harvesterhci.io.cloudtemplate.vue +0 -78
  248. package/list/harvesterhci.io.dashboard/HarvesterUpgrade.vue +0 -211
  249. package/list/harvesterhci.io.dashboard/UpgradeInfo.vue +0 -40
  250. package/list/harvesterhci.io.dashboard/index.vue +0 -752
  251. package/list/harvesterhci.io.host/index.vue +0 -186
  252. package/list/harvesterhci.io.networkattachmentdefinition.vue +0 -167
  253. package/list/harvesterhci.io.setting.vue +0 -241
  254. package/list/harvesterhci.io.virtualmachinebackup.vue +0 -172
  255. package/list/harvesterhci.io.virtualmachineimage.vue +0 -80
  256. package/list/harvesterhci.io.virtualmachinetemplateversion.vue +0 -173
  257. package/list/harvesterhci.io.volume.vue +0 -122
  258. package/list/kubevirt.io.virtualmachine.vue +0 -193
  259. package/mixins/harvester-vm/impl.js +0 -267
  260. package/mixins/harvester-vm/index.js +0 -1357
  261. package/models/harvester/configmap.js +0 -32
  262. package/models/harvester/harvesterhci.io.blockdevice.js +0 -55
  263. package/models/harvester/harvesterhci.io.keypair.js +0 -12
  264. package/models/harvester/harvesterhci.io.setting.js +0 -127
  265. package/models/harvester/harvesterhci.io.supportbundle.js +0 -35
  266. package/models/harvester/harvesterhci.io.upgrade.js +0 -226
  267. package/models/harvester/harvesterhci.io.virtualmachinebackup.js +0 -116
  268. package/models/harvester/harvesterhci.io.virtualmachineimage.js +0 -255
  269. package/models/harvester/harvesterhci.io.virtualmachinerestore.js +0 -43
  270. package/models/harvester/harvesterhci.io.virtualmachinetemplate.js +0 -69
  271. package/models/harvester/harvesterhci.io.virtualmachinetemplateversion.js +0 -227
  272. package/models/harvester/k8s.cni.cncf.io.networkattachmentdefinition.js +0 -32
  273. package/models/harvester/kubevirt.io.virtualmachine.js +0 -850
  274. package/models/harvester/kubevirt.io.virtualmachineinstance.js +0 -142
  275. package/models/harvester/management.cattle.io.managedchart.js +0 -191
  276. package/models/harvester/management.cattle.io.setting.js +0 -40
  277. package/models/harvester/network.harvesterhci.io.clusternetwork.js +0 -100
  278. package/models/harvester/network.harvesterhci.io.nodenetwork.js +0 -34
  279. package/models/harvester/node.js +0 -255
  280. package/models/harvester/persistentvolumeclaim.js +0 -166
  281. package/models/harvester/pod.js +0 -185
  282. package/pages/c/_cluster/harvester/airgapupgrade/index.vue +0 -309
  283. package/pages/c/_cluster/harvester/console/_uid/serial.vue +0 -51
  284. package/pages/c/_cluster/harvester/console/_uid/vnc.vue +0 -52
  285. package/pages/c/_cluster/harvester/index.vue +0 -24
  286. package/pages/c/_cluster/harvester/support/index.vue +0 -154
  287. package/pkg/model-loader.lib.js +0 -3
  288. package/plugins/lookup.js +0 -50
  289. package/promptRemove/kubevirt.io.virtualmachine.vue +0 -164
  290. package/store/harvester-common.js +0 -126
  291. package/utils/validators/vm-datavolumes.js +0 -38
  292. package/utils/validators/vm-image.js +0 -32
  293. package/utils/validators/vm.js +0 -221
  294. package/yarn-error.log +0 -196
@@ -1,221 +0,0 @@
1
- <script>
2
- import Tabbed from '@shell/components/Tabbed';
3
- import Tab from '@shell/components/Tabbed/Tab';
4
- import Loading from '@shell/components/Loading';
5
- import CruResource from '@shell/components/CruResource';
6
- import { Checkbox } from '@components/Form/Checkbox';
7
- import LabelValue from '@shell/components/LabelValue';
8
- import VM_MIXIN from '@shell/mixins/harvester-vm';
9
- import { allHash } from '@shell/utils/promise';
10
- import CreateEditView from '@shell/mixins/create-edit-view';
11
- import { HCI } from '@shell/config/types';
12
- import CpuMemory from '@shell/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory';
13
-
14
- import OverviewKeypairs from '@shell/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineKeypairs';
15
- import Volume from '@shell/edit/kubevirt.io.virtualmachine/VirtualMachineVolume';
16
- import Network from '@shell/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork';
17
- import CloudConfig from '@shell/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig';
18
- const UNDEFINED = 'n/a';
19
-
20
- export default {
21
- name: 'BackupDetail',
22
-
23
- components: {
24
- Volume,
25
- Network,
26
- CruResource,
27
- Tabbed,
28
- Loading,
29
- LabelValue,
30
- Tab,
31
- CloudConfig,
32
- Checkbox,
33
- CpuMemory,
34
- OverviewKeypairs,
35
- },
36
-
37
- mixins: [CreateEditView, VM_MIXIN],
38
-
39
- props: {
40
- value: {
41
- type: Object,
42
- required: true,
43
- },
44
- mode: {
45
- type: String,
46
- required: true,
47
- },
48
- },
49
-
50
- async fetch() {
51
- await allHash({ allImages: this.$store.dispatch('harvester/findAll', { type: HCI.IMAGE }) });
52
- },
53
-
54
- data() {
55
- return { vm: null };
56
- },
57
-
58
- computed: {
59
- name() {
60
- return this.value?.metadata?.name || UNDEFINED;
61
- },
62
-
63
- hostname() {
64
- return this?.spec?.template?.spec?.hostname;
65
- },
66
-
67
- imageName() {
68
- const imageList = this.$store.getters['harvester/all'](HCI.IMAGE) || [];
69
-
70
- const image = imageList.find( I => this.imageId === I.id);
71
-
72
- return image?.spec?.displayName || '-';
73
- },
74
-
75
- disks() {
76
- const disks = this?.spec?.template?.spec?.domain?.devices?.disks || [];
77
-
78
- return disks.filter((disk) => {
79
- return !!disk.bootOrder;
80
- }).sort((a, b) => {
81
- if (a.bootOrder < b.bootOrder) {
82
- return -1;
83
- }
84
-
85
- return 1;
86
- });
87
- },
88
-
89
- cdroms() {
90
- const disks = this?.spec?.template?.spec?.domain?.devices?.disks || [];
91
-
92
- return disks.filter((disk) => {
93
- return !!disk.cdrom;
94
- });
95
- },
96
- },
97
-
98
- methods: {
99
- getDeviceType(o) {
100
- if (o.disk) {
101
- return 'Disk';
102
- } else {
103
- return 'CD-ROM';
104
- }
105
- },
106
- isEmpty(o) {
107
- return o !== undefined && Object.keys(o).length === 0;
108
- },
109
- onTabChanged({ tab }) {
110
- if (tab.name === 'advanced') {
111
- this.$refs.yamlEditor?.refresh();
112
- }
113
- }
114
- },
115
- };
116
- </script>
117
-
118
- <template>
119
- <Loading v-if="$fetchState.pending" />
120
- <CruResource
121
- v-else
122
- :done-route="doneRoute"
123
- :resource="value"
124
- :mode="mode"
125
- :apply-hooks="applyHooks"
126
- >
127
- <Tabbed v-if="spec" :side-tabs="true" @changed="onTabChanged">
128
- <Tab name="Basics" :label="t('harvester.virtualMachine.detail.tabs.basics')">
129
- <div class="row">
130
- <div class="col span-6">
131
- <LabelValue :name="t('harvester.virtualMachine.detail.details.name')" :value="name" />
132
- </div>
133
-
134
- <div class="col span-6">
135
- <LabelValue :name="t('harvester.fields.image')" :value="imageName" />
136
- </div>
137
- </div>
138
-
139
- <div class="row">
140
- <div class="col span-6">
141
- <LabelValue :name="t('harvester.virtualMachine.detail.details.hostname')" :value="hostname" />
142
- </div>
143
-
144
- <div class="col span-6">
145
- <LabelValue :name="t('harvester.virtualMachine.input.MachineType')" :value="machineType" />
146
- </div>
147
- </div>
148
-
149
- <CpuMemory :cpu="cpu" :mode="mode" :memory="memory" />
150
-
151
- <div class="row">
152
- <div class="col span-6">
153
- <LabelValue :name="t('harvester.virtualMachine.detail.details.bootOrder')">
154
- <template #value>
155
- <div>
156
- <ul>
157
- <li v-for="(disk) in disks" :key="disk.bootOrder">
158
- {{ disk.bootOrder }}. {{ disk.name }} ({{ getDeviceType(disk) }})
159
- </li>
160
- </ul>
161
- </div>
162
- </template>
163
- </LabelValue>
164
- </div>
165
- <div class="col span-6">
166
- <LabelValue :name="t('harvester.virtualMachine.detail.details.CDROMs')">
167
- <template #value>
168
- <div>
169
- <ul v-if="cdroms.length > 0">
170
- <li v-for="(rom) in cdroms" :key="rom.name">
171
- {{ rom.name }}
172
- </li>
173
- </ul>
174
- <span v-else>
175
- {{ t("harvester.virtualMachine.detail.notAvailable") }}
176
- </span>
177
- </div>
178
- </template>
179
- </LabelValue>
180
- </div>
181
- </div>
182
- </Tab>
183
-
184
- <Tab
185
- name="volume"
186
- :label="t('harvester.tab.volume')"
187
- :weight="-1"
188
- >
189
- <Volume v-model="diskRows" :mode="mode" />
190
- </Tab>
191
-
192
- <Tab
193
- name="network"
194
- :label="t('harvester.tab.network')"
195
- :weight="-2"
196
- >
197
- <Network v-model="networkRows" :mode="mode" />
198
- </Tab>
199
-
200
- <Tab name="keypairs" :label="t('harvester.virtualMachine.detail.tabs.keypairs')" class="bordered-table" :weight="-3">
201
- <OverviewKeypairs v-if="vm" v-model="vm" />
202
- </Tab>
203
-
204
- <Tab
205
- name="advanced"
206
- :label="t('harvester.tab.advanced')"
207
- :weight="-4"
208
- >
209
- <CloudConfig
210
- ref="yamlEditor"
211
- :user-script="userScript"
212
- :mode="mode"
213
- :network-script="networkScript"
214
- />
215
-
216
- <div class="spacer"></div>
217
- <Checkbox v-model="installUSBTablet" :mode="mode" class="check" type="checkbox" :label="t('harvester.virtualMachine.enableUsb')" />
218
- </Tab>
219
- </Tabbed>
220
- </CruResource>
221
- </template>
@@ -1,118 +0,0 @@
1
- <script>
2
- import CopyToClipboardText from '@shell/components/CopyToClipboardText';
3
- import LabelValue from '@shell/components/LabelValue';
4
- import { DESCRIPTION, HCI } from '@shell/config/labels-annotations';
5
- import Tabbed from '@shell/components/Tabbed';
6
- import Tab from '@shell/components/Tabbed/Tab';
7
- import { findBy } from '@shell/utils/array';
8
- import { get } from '@shell/utils/object';
9
-
10
- export default {
11
- components: {
12
- CopyToClipboardText,
13
- Tab,
14
- Tabbed,
15
- LabelValue
16
- },
17
-
18
- props: {
19
- value: {
20
- type: Object,
21
- required: true,
22
- },
23
- },
24
-
25
- data() {
26
- return {};
27
- },
28
-
29
- computed: {
30
- formattedValue() {
31
- return this.value?.downSize;
32
- },
33
-
34
- url() {
35
- return this.value?.spec?.url || '-';
36
- },
37
-
38
- description() {
39
- return this.value?.metadata?.annotations?.[DESCRIPTION] || '-';
40
- },
41
-
42
- errorMessage() {
43
- const conditions = get(this.value, 'status.conditions');
44
-
45
- return findBy(conditions, 'type', 'Imported')?.message || '-';
46
- },
47
-
48
- isUpload() {
49
- return this.value?.spec?.sourceType === 'upload';
50
- },
51
-
52
- imageName() {
53
- return this.value?.metadata?.annotations?.[HCI.IMAGE_NAME] || '-';
54
- },
55
- }
56
- };
57
- </script>
58
-
59
- <template>
60
- <Tabbed v-bind="$attrs" class="mt-15" :side-tabs="true">
61
- <Tab name="detail" :label="t('harvester.virtualMachine.detail.tabs.basics')" class="bordered-table">
62
- <div class="row">
63
- <div class="col span-12">
64
- <LabelValue
65
- v-if="isUpload"
66
- :name="t('harvester.image.fileName')"
67
- :value="imageName"
68
- class="mb-20"
69
- />
70
- <LabelValue
71
- v-else
72
- :name="t('harvester.image.url')"
73
- :value="url"
74
- class="mb-20"
75
- >
76
- <template #value>
77
- <div v-if="url !== '-'">
78
- <CopyToClipboardText :text="url" />
79
- </div>
80
- <div v-else>
81
- {{ url }}
82
- </div>
83
- </template>
84
- </LabelValue>
85
- </div>
86
- </div>
87
-
88
- <div class="row">
89
- <div class="col span-12">
90
- <LabelValue :name="t('harvester.image.size')" :value="formattedValue" class="mb-20" />
91
- </div>
92
- </div>
93
-
94
- <div class="row">
95
- <div class="col span-12">
96
- <LabelValue :name="t('nameNsDescription.description.label')" :value="description" class="mb-20" />
97
- </div>
98
- </div>
99
-
100
- <div v-if="errorMessage !== '-'" class="row">
101
- <div class="col span-12">
102
- <div>
103
- {{ t('tableHeaders.message') }}
104
- </div>
105
- <div :class="{ 'error': errorMessage !== '-' }">
106
- {{ errorMessage }}
107
- </div>
108
- </div>
109
- </div>
110
- </Tab>
111
- </Tabbed>
112
- </template>
113
-
114
- <style lang="scss" scoped>
115
- .error {
116
- color: var(--error);
117
- }
118
- </style>
@@ -1,279 +0,0 @@
1
- <script>
2
- import HarvesterIpAddress from '@shell/components/formatter/HarvesterIpAddress';
3
- import VMConsoleBar from '@shell/components/VMConsoleBar';
4
- import LabelValue from '@shell/components/LabelValue';
5
- import InputOrDisplay from '@shell/components/InputOrDisplay';
6
- import { HCI } from '@shell/config/types';
7
- import CreateEditView from '@shell/mixins/create-edit-view';
8
-
9
- const UNDEFINED = 'n/a';
10
-
11
- export default {
12
- name: 'Details',
13
-
14
- components: {
15
- VMConsoleBar,
16
- HarvesterIpAddress,
17
- LabelValue,
18
- InputOrDisplay
19
- },
20
-
21
- mixins: [CreateEditView],
22
-
23
- props: {
24
- value: {
25
- type: Object,
26
- required: true
27
- },
28
- resource: {
29
- type: Object,
30
- required: true,
31
- default: () => {
32
- return {};
33
- }
34
- },
35
- mode: {
36
- type: String,
37
- required: true,
38
- },
39
- },
40
-
41
- computed: {
42
- creationTimestamp() {
43
- const date = new Date(this.value?.metadata?.creationTimestamp);
44
-
45
- if (!date.getMonth) {
46
- return UNDEFINED;
47
- }
48
-
49
- return `${ date.getMonth() + 1 }/${ date.getDate() }/${ date.getUTCFullYear() }`;
50
- },
51
-
52
- node() {
53
- return this.resource?.status?.nodeName || UNDEFINED;
54
- },
55
-
56
- hostname() {
57
- return this.resource?.spec?.hostname || this.resource?.status?.guestOSInfo?.hostname;
58
- },
59
-
60
- imageName() {
61
- const imageList = this.$store.getters['harvester/all'](HCI.IMAGE) || [];
62
-
63
- const image = imageList.find( (I) => {
64
- return this.value.rootImageId === I.id;
65
- });
66
-
67
- return image?.spec?.displayName || 'N/A';
68
- },
69
-
70
- disks() {
71
- const disks = this.value?.spec?.template?.spec?.domain?.devices?.disks || [];
72
-
73
- return disks.filter((disk) => {
74
- return !!disk.bootOrder;
75
- }).sort((a, b) => {
76
- if (a.bootOrder < b.bootOrder) {
77
- return -1;
78
- }
79
-
80
- return 1;
81
- });
82
- },
83
-
84
- cdroms() {
85
- const disks = this.value?.spec?.template?.spec?.domain?.devices?.disks || [];
86
-
87
- return disks.filter((disk) => {
88
- return !!disk.cdrom;
89
- });
90
- },
91
-
92
- flavor() {
93
- const domain = this.value?.spec?.template?.spec?.domain;
94
-
95
- return `${ domain.cpu?.cores } vCPU , ${ domain.resources?.limits?.memory } ${ this.t('harvester.virtualMachine.input.memory') }`;
96
- },
97
-
98
- kernelRelease() {
99
- return this.resource?.status?.guestOSInfo?.kernelRelease;
100
- },
101
-
102
- operatingSystem() {
103
- return this.resource?.status?.guestOSInfo?.prettyName;
104
- },
105
-
106
- isDown() {
107
- return this.isEmpty(this.resource);
108
- },
109
-
110
- machineType() {
111
- return this.value?.spec?.template?.spec?.domain?.machine?.type || undefined;
112
- }
113
- },
114
-
115
- methods: {
116
- getDeviceType(o) {
117
- if (o.disk) {
118
- return 'Disk';
119
- } else {
120
- return 'CD-ROM';
121
- }
122
- },
123
- isEmpty(o) {
124
- return o !== undefined && Object.keys(o).length === 0;
125
- }
126
- }
127
- };
128
- </script>
129
-
130
- <template>
131
- <div class="overview-basics">
132
- <div class="row">
133
- <div class="col span-6">
134
- <LabelValue :name="t('harvester.virtualMachine.detail.details.name')" :value="value.nameDisplay">
135
- <template #value>
136
- <div class="smart-row">
137
- <div class="console">
138
- {{ value.nameDisplay }} <VMConsoleBar :resource="value" class="consoleBut" />
139
- </div>
140
- </div>
141
- </template>
142
- </LabelValue>
143
- </div>
144
-
145
- <div class="col span-6">
146
- <LabelValue :name="t('harvester.fields.image')" :value="imageName" />
147
- </div>
148
- </div>
149
-
150
- <div class="row">
151
- <div class="col span-6">
152
- <LabelValue :name="t('harvester.virtualMachine.detail.details.hostname')" :value="hostname">
153
- <template #value>
154
- <div v-if="!isDown">
155
- {{ hostname || t("harvester.virtualMachine.detail.GuestAgentNotInstalled") }}
156
- </div>
157
- <div v-else>
158
- {{ t("harvester.virtualMachine.detail.details.down") }}
159
- </div>
160
- </template>
161
- </LabelValue>
162
- </div>
163
-
164
- <div class="col span-6">
165
- <LabelValue :name="t('harvester.virtualMachine.detail.details.node')" :value="node">
166
- <template #value>
167
- <div v-if="!isDown">
168
- {{ node }}
169
- </div>
170
- <div v-else>
171
- {{ t("harvester.virtualMachine.detail.details.down") }}
172
- </div>
173
- </template>
174
- </LabelValue>
175
- </div>
176
- </div>
177
-
178
- <div class="row">
179
- <div class="col span-6">
180
- <LabelValue :name="t('harvester.virtualMachine.detail.details.ipAddress')">
181
- <template #value>
182
- <HarvesterIpAddress v-model="value.id" :row="value" />
183
- </template>
184
- </LabelValue>
185
- </div>
186
-
187
- <div class="col span-6">
188
- <LabelValue :name="t('harvester.virtualMachine.detail.details.created')" :value="creationTimestamp" />
189
- </div>
190
- </div>
191
-
192
- <hr class="section-divider" />
193
-
194
- <h2>{{ t('harvester.virtualMachine.detail.tabs.configurations') }}</h2>
195
-
196
- <div class="row">
197
- <div class="col span-6">
198
- <InputOrDisplay :name="t('harvester.virtualMachine.detail.details.bootOrder')" :value="disks" :mode="mode">
199
- <template #value>
200
- <ul>
201
- <li v-for="(disk) in disks" :key="disk.bootOrder">
202
- {{ disk.bootOrder }}. {{ disk.name }} ({{ getDeviceType(disk) }})
203
- </li>
204
- </ul>
205
- </template>
206
- </InputOrDisplay>
207
- </div>
208
- <div class="col span-6">
209
- <InputOrDisplay :name="t('harvester.virtualMachine.detail.details.CDROMs')" :value="cdroms" :mode="mode">
210
- <template #value>
211
- <div>
212
- <ul v-if="cdroms.length > 0">
213
- <li v-for="(rom) in cdroms" :key="rom.name">
214
- {{ rom.name }}
215
- </li>
216
- </ul>
217
- <span v-else>
218
- {{ t("harvester.virtualMachine.detail.notAvailable") }}
219
- </span>
220
- </div>
221
- </template>
222
- </InputOrDisplay>
223
- </div>
224
- </div>
225
- <div class="row">
226
- <div class="col span-6">
227
- <LabelValue :name="t('harvester.virtualMachine.detail.details.operatingSystem')" :value="operatingSystem || t('harvester.virtualMachine.detail.GuestAgentNotInstalled')" />
228
- </div>
229
- <LabelValue :name="t('harvester.virtualMachine.detail.details.flavor')" :value="flavor" />
230
- </div>
231
- <div class="row">
232
- <div class="col span-6">
233
- <LabelValue :name="t('harvester.virtualMachine.detail.details.kernelRelease')" :value="kernelRelease || t('harvester.virtualMachine.detail.GuestAgentNotInstalled')" />
234
- </div>
235
-
236
- <div class="col span-6">
237
- <LabelValue :name="t('harvester.virtualMachine.input.MachineType')" :value="machineType" />
238
- </div>
239
- </div>
240
- </div>
241
- </template>
242
-
243
- <style lang="scss" scoped>
244
- .consoleBut {
245
- position: relative;
246
- top: -20px;
247
- left: 38px;
248
- }
249
-
250
- .overview-basics {
251
- display: grid;
252
- grid-template-columns: 100%;
253
- grid-template-rows: auto;
254
- grid-row-gap: 15px;
255
-
256
- .badge-state {
257
- padding: 2px 5px;
258
- font-size: 12px;
259
- margin-right: 3px;
260
- }
261
-
262
- .smart-row {
263
- display: flex;
264
- flex-direction: row;
265
-
266
- .console {
267
- display: flex;
268
- }
269
- }
270
-
271
- &__name {
272
- flex: 1;
273
- }
274
-
275
- &__ssh-key {
276
- min-width: 150px;
277
- }
278
- }
279
- </style>
@@ -1,75 +0,0 @@
1
- <script>
2
- import { REASON } from '@shell/config/table-headers';
3
- import SortableTable from '@shell/components/SortableTable';
4
-
5
- export default {
6
- name: 'VirtualMachineEvents',
7
-
8
- components: { SortableTable },
9
-
10
- props: {
11
- events: {
12
- type: Array,
13
- required: true,
14
- },
15
- },
16
-
17
- data() {
18
- const reason = {
19
- ...REASON,
20
- canBeVariable: true,
21
- width: 180
22
- };
23
-
24
- const eventHeaders = [
25
- reason,
26
- {
27
- name: 'resource',
28
- label: 'Resource',
29
- labelKey: 'clusterIndexPage.sections.events.resource.label',
30
- value: 'displayInvolvedObject',
31
- sort: ['involvedObject.kind', 'involvedObject.name'],
32
- canBeVariable: true,
33
- },
34
- {
35
- align: 'right',
36
- name: 'date',
37
- label: 'Date',
38
- labelKey: 'clusterIndexPage.sections.events.date.label',
39
- value: 'lastTimestamp',
40
- sort: 'lastTimestamp:desc',
41
- formatter: 'LiveDate',
42
- formatterOpts: { addSuffix: true },
43
- width: 125,
44
- defaultSort: true,
45
- },
46
- ];
47
-
48
- return { eventHeaders };
49
- },
50
-
51
- };
52
- </script>
53
-
54
- <template>
55
- <SortableTable
56
- :rows="events"
57
- :headers="eventHeaders"
58
- key-field="id"
59
- :search="false"
60
- :table-actions="false"
61
- :row-actions="false"
62
- :paging="true"
63
- :rows-per-page="10"
64
- default-sort-by="date"
65
- >
66
- <template #cell:resource="{row, value}">
67
- <div class="text-info">
68
- {{ value }}
69
- </div>
70
- <div v-if="row.message">
71
- {{ row.displayMessage }}
72
- </div>
73
- </template>
74
- </SortableTable>
75
- </template>