@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,90 +0,0 @@
1
- <script>
2
- import { OFF } from '@shell/models/harvester/kubevirt.io.virtualmachine';
3
- import { get } from '@shell/utils/object';
4
- import { isIpv4 } from '@shell/utils/string';
5
- import { HCI as HCI_ANNOTATIONS } from '@shell/config/labels-annotations';
6
- import { HCI } from '@shell/config/types';
7
- import { MANAGEMENT_NETWORK } from '@shell/mixins/harvester-vm';
8
- import CopyToClipboard from '@shell/components/CopyToClipboard';
9
-
10
- export default {
11
- components: { CopyToClipboard },
12
- props: {
13
- value: {
14
- type: String,
15
- default: ''
16
- },
17
- row: {
18
- type: Object,
19
- required: true
20
- }
21
- },
22
-
23
- computed: {
24
- // Return VM instance IP and VM annotation IP
25
- ips() {
26
- return [...this.vmiIp, ...this.networkAnnotationIP]
27
- .filter(Boolean)
28
- .sort((a, b) => a.ip < b.ip ? -1 : 1);
29
- },
30
-
31
- networkAnnotationIP() {
32
- if (this.row.actualState !== 'Running') { // TODO: Running
33
- return [];
34
- }
35
-
36
- const annotationIp = get(this.row, `metadata.annotations."${ HCI_ANNOTATIONS.NETWORK_IPS }"`) || '[]';
37
-
38
- // Obtain IP from VM annotation, remove the CIDR suffix number if CIDR Exist
39
- try {
40
- const out = JSON.parse(annotationIp);
41
-
42
- return out.map( ip => ({
43
- ip: ip.replace(/\/[\d\D]*/, ''),
44
- name: ''
45
- }));
46
- } catch (e) {
47
- return [];
48
- }
49
- },
50
-
51
- vmiIp() {
52
- const vmiResources = this.$store.getters['harvester/all'](HCI.VMI);
53
- const resource = vmiResources.find(VMI => VMI.id === this.value) || null;
54
- const networksName = this.row.networksName || [];
55
- const vmiNetworks = resource?.spec?.networks || [];
56
-
57
- return (resource?.status?.interfaces || []).filter((intf) => {
58
- return isIpv4(intf.ipAddress) && networksName.includes(intf.name);
59
- }).map((intf) => {
60
- let name;
61
- const network = vmiNetworks.find(network => network.name === intf.name);
62
-
63
- if (network && network.multus) {
64
- name = network.multus.networkName;
65
- } else if (network && network.pod) {
66
- name = MANAGEMENT_NETWORK;
67
- }
68
-
69
- return {
70
- ip: intf.ipAddress,
71
- name
72
- };
73
- });
74
- },
75
-
76
- showIP() {
77
- return this.row.stateDisplay !== OFF;
78
- },
79
- },
80
- };
81
- </script>
82
-
83
- <template>
84
- <div v-if="showIP">
85
- <span v-for="{ip, name} in ips" :key="ip">
86
- <span v-tooltip="name">{{ ip }}</span>
87
- <CopyToClipboard :text="ip" label-as="tooltip" class="icon-btn" action-color="bg-transparent" />
88
- </span>
89
- </div>
90
- </template>
@@ -1,140 +0,0 @@
1
- <script>
2
- import ConsumptionGauge from '@shell/components/ConsumptionGauge';
3
- import { METRIC, NODE } from '@shell/config/types';
4
- import { formatSi, exponentNeeded, UNITS, parseSi } from '@shell/utils/units';
5
-
6
- export default {
7
- name: 'HarvesterMemoryUsed',
8
- components: { ConsumptionGauge },
9
-
10
- props: {
11
- value: {
12
- type: String,
13
- default: ''
14
- },
15
-
16
- row: {
17
- type: Object,
18
- required: true
19
- },
20
-
21
- resourceName: {
22
- type: String,
23
- default: ''
24
- },
25
-
26
- showUsed: {
27
- type: Boolean,
28
- default: false,
29
- },
30
- },
31
-
32
- data() {
33
- return {};
34
- },
35
-
36
- computed: {
37
- metrics() {
38
- return this.$store.getters['harvester/byId'](METRIC.NODE, this.row.id);
39
- },
40
-
41
- memoryTotal() {
42
- let out = 0;
43
-
44
- if (this.metrics) {
45
- out = this.metrics.memoryCapacity;
46
- }
47
-
48
- return out;
49
- },
50
-
51
- memoryUnits() {
52
- const exponent = exponentNeeded(this.memoryTotal, 1024);
53
-
54
- return `${ UNITS[exponent] }iB`;
55
- },
56
-
57
- node() {
58
- const inStore = this.$store.getters['currentProduct'].inStore;
59
- const node = this.$store.getters[`${ inStore }/byId`](NODE, this.row.id);
60
-
61
- return node;
62
- },
63
-
64
- reserved() {
65
- if (this.metrics) {
66
- return this.node.memoryReserved;
67
- } else {
68
- return 0;
69
- }
70
- },
71
-
72
- used() {
73
- if (this.metrics) {
74
- return parseSi(this.metrics?.usage?.memory || '0m', { increment: 1024 });
75
- } else {
76
- return 0;
77
- }
78
- },
79
- },
80
-
81
- methods: {
82
- memoryFormatter(value) {
83
- const exponent = exponentNeeded(this.memoryTotal, 1024);
84
-
85
- const formatOptions = {
86
- addSuffix: false,
87
- increment: 1024,
88
- minExponent: exponent
89
- };
90
-
91
- return formatSi(value, formatOptions);
92
- },
93
- }
94
- };
95
- </script>
96
-
97
- <template>
98
- <div>
99
- <ConsumptionGauge
100
- :capacity="memoryTotal"
101
- :used="reserved"
102
- :units="memoryUnits"
103
- :number-formatter="memoryFormatter"
104
- :resource-name="resourceName"
105
- >
106
- <template #title="{amountTemplateValues, formattedPercentage}">
107
- <span>
108
- {{ t('clusterIndexPage.hardwareResourceGauge.reserved') }}
109
- </span>
110
- <span>
111
- {{ t('node.detail.glance.consumptionGauge.amount', amountTemplateValues) }}
112
- <span class="ml-10 percentage">/&nbsp;{{ formattedPercentage }}
113
- </span>
114
- </span>
115
- </template>
116
- </ConsumptionGauge>
117
- <div
118
- v-if="showUsed"
119
- class="mt-10"
120
- >
121
- <ConsumptionGauge
122
- :capacity="memoryTotal"
123
- :used="used"
124
- :units="memoryUnits"
125
- :number-formatter="memoryFormatter"
126
- >
127
- <template #title="{amountTemplateValues, formattedPercentage}">
128
- <span>
129
- {{ t('clusterIndexPage.hardwareResourceGauge.used') }}
130
- </span>
131
- <span>
132
- {{ t('node.detail.glance.consumptionGauge.amount', amountTemplateValues) }}
133
- <span class="ml-10 percentage">/&nbsp;{{ formattedPercentage }}
134
- </span>
135
- </span>
136
- </template>
137
- </ConsumptionGauge>
138
- </div>
139
- </div>
140
- </template>
@@ -1,85 +0,0 @@
1
- <script>
2
- import { HCI } from '@shell/config/types';
3
- import { BadgeState } from '@components/BadgeState';
4
-
5
- export default {
6
- components: { BadgeState },
7
-
8
- props: {
9
- vmResource: {
10
- type: Object,
11
- required: true
12
- },
13
- showSuccess: {
14
- type: Boolean,
15
- default: true
16
- }
17
- },
18
-
19
- computed: {
20
- vmiResource() {
21
- const vmiList = this.$store.getters['harvester/all'](HCI.VMI) || [];
22
- const vmi = vmiList.find( (VMI) => {
23
- return VMI?.metadata?.ownerReferences?.[0]?.uid === this.vmResource?.metadata?.uid;
24
- });
25
-
26
- return vmi;
27
- },
28
- state() {
29
- return this.vmiResource?.migrationState?.status || '';
30
- }
31
- },
32
-
33
- watch: {
34
- state(neu) {
35
- this.$emit('state-changed', neu);
36
- }
37
- },
38
- };
39
- </script>
40
-
41
- <template>
42
- <div v-if="state">
43
- <span v-if="!showSuccess">/</span>
44
- <BadgeState :label="vmiResource.migrationState.status" :color="vmiResource.migrationStateBackground" />
45
- </div>
46
- </template>
47
-
48
- <style lang="scss" scoped>
49
- .badge-state {
50
- padding: 5px 10px;
51
- border: 1px solid transparent;
52
- border-radius: 20px;
53
-
54
- &.bg-info {
55
- border-color: var(--primary);
56
- }
57
-
58
- &.bg-error {
59
- border-color: var(--error);
60
- }
61
-
62
- &.bg-warning {
63
- border-color: var(--warning);
64
- }
65
-
66
- // Successful states are de-emphasized by using [text-]color instead of background-color
67
- &.bg-success {
68
- color: var(--success);
69
- border-color: var(--success);
70
- background: transparent;
71
- }
72
- }
73
-
74
- .sortable-table TD .badge-state {
75
- @include clip;
76
- display: inline-block;
77
- max-width: 100%;
78
- position: relative;
79
- padding: 2px 10px 1px 10px;
80
- font-size: 1em;
81
- max-width: 200px;
82
- font-size: .85em;
83
- vertical-align: middle;
84
- }
85
- </style>
@@ -1,49 +0,0 @@
1
- <script>
2
- import { HCI, NODE } from '@shell/config/types';
3
- import CopyToClipboard from '@shell/components/CopyToClipboard';
4
-
5
- export default {
6
- components: { CopyToClipboard },
7
- props: {
8
- value: {
9
- type: String,
10
- default: ''
11
- },
12
- row: {
13
- type: Object,
14
- required: true
15
- }
16
- },
17
-
18
- computed: {
19
- nodeName() {
20
- return this.node?.nameDisplay || '';
21
- },
22
-
23
- vmi() {
24
- const vmiResources = this.$store.getters['harvester/all'](HCI.VMI);
25
- const resource = vmiResources.find(VMI => VMI.id === this.row.id) || null;
26
-
27
- return resource;
28
- },
29
-
30
- node() {
31
- const nodeName = this.vmi?.status?.nodeName;
32
-
33
- return this.$store.getters['harvester/byId'](NODE, nodeName);
34
- },
35
- },
36
- };
37
- </script>
38
-
39
- <template>
40
- <div>
41
- {{ nodeName }}
42
- <CopyToClipboard
43
- :text="nodeName"
44
- label-as="tooltip"
45
- class="icon-btn"
46
- action-color="bg-transparent"
47
- />
48
- </div>
49
- </template>
@@ -1,194 +0,0 @@
1
- <script>
2
- import ConsumptionGauge from '@shell/components/ConsumptionGauge';
3
- import { LONGHORN } from '@shell/config/types';
4
- import { formatSi, exponentNeeded, UNITS } from '@shell/utils/units';
5
-
6
- export default {
7
- name: 'HarvesterStorageUsed',
8
- components: { ConsumptionGauge },
9
-
10
- props: {
11
- value: {
12
- type: String,
13
- default: ''
14
- },
15
-
16
- row: {
17
- type: Object,
18
- required: true
19
- },
20
-
21
- resourceName: {
22
- type: String,
23
- default: ''
24
- },
25
-
26
- showReserved: {
27
- type: Boolean,
28
- default: false,
29
- },
30
- },
31
-
32
- data() {
33
- return {};
34
- },
35
-
36
- computed: {
37
- usage() {
38
- const inStore = this.$store.getters['currentProduct'].inStore;
39
- const longhornNode = this.$store.getters[`${ inStore }/byId`](LONGHORN.NODES, `longhorn-system/${ this.row.id }`);
40
- let out = 0;
41
-
42
- const diskStatus = longhornNode?.status?.diskStatus || {};
43
-
44
- Object.values(diskStatus).map((disk) => {
45
- if (disk?.storageAvailable && disk?.storageMaximum) {
46
- out += disk.storageMaximum - disk.storageAvailable;
47
- }
48
- });
49
-
50
- return Number(out);
51
- },
52
-
53
- reserved() {
54
- const inStore = this.$store.getters['currentProduct'].inStore;
55
- const longhornNode = this.$store.getters[`${ inStore }/byId`](LONGHORN.NODES, `longhorn-system/${ this.row.id }`);
56
- let reserved = 0;
57
-
58
- const disks = longhornNode?.spec?.disks || {};
59
-
60
- Object.values(disks).map((disk) => {
61
- if (disk.allowScheduling) {
62
- reserved += disk.storageReserved;
63
- }
64
- });
65
-
66
- return reserved;
67
- },
68
-
69
- total() {
70
- const inStore = this.$store.getters['currentProduct'].inStore;
71
- const longhornNode = this.$store.getters[`${ inStore }/byId`](LONGHORN.NODES, `longhorn-system/${ this.row.id }`);
72
- let out = 0;
73
-
74
- const diskStatus = longhornNode?.status?.diskStatus || {};
75
-
76
- Object.values(diskStatus).map((disk) => {
77
- if (disk?.storageMaximum) {
78
- out += disk.storageMaximum;
79
- }
80
- });
81
-
82
- return out;
83
- },
84
-
85
- units() {
86
- const exponent = exponentNeeded(this.total, 1024);
87
-
88
- return `${ UNITS[exponent] }iB`;
89
- },
90
-
91
- used() {
92
- let out = this.formatter(this.usage || 0);
93
-
94
- if (!Number.parseFloat(out) > 0) {
95
- out = this.formatter(this.usage || 0, { canRoundToZero: false });
96
- }
97
-
98
- return out;
99
- },
100
-
101
- formatReserved() {
102
- let out = this.formatter(this.reserved || 0);
103
-
104
- if (!Number.parseFloat(out) > 0) {
105
- out = this.formatter(this.reserved || 0, { canRoundToZero: false });
106
- }
107
-
108
- return out;
109
- },
110
-
111
- usedAmountTemplateValues() {
112
- return {
113
- used: this.used,
114
- total: this.formatter(this.total || 0),
115
- unit: this.units,
116
- };
117
- },
118
-
119
- reservedAmountTemplateValues() {
120
- return {
121
- used: this.formatReserved,
122
- total: this.formatter(this.total || 0),
123
- unit: this.units,
124
- };
125
- },
126
- },
127
-
128
- methods: {
129
- formatter(value, format) {
130
- const minExponent = exponentNeeded(this.total, 1024);
131
- const formatOptions = {
132
- addSuffix: false,
133
- increment: 1024,
134
- minExponent,
135
- };
136
-
137
- return formatSi(value, {
138
- ...formatOptions,
139
- ...format,
140
- });
141
- },
142
- }
143
- };
144
- </script>
145
-
146
- <template>
147
- <div>
148
- <div
149
- v-if="showReserved"
150
- >
151
- <ConsumptionGauge
152
- :capacity="total"
153
- :used="reserved"
154
- :units="units"
155
- :number-formatter="formatter"
156
- :resource-name="resourceName"
157
- >
158
- <template #title="{formattedPercentage}">
159
- <span>
160
- {{ t('clusterIndexPage.hardwareResourceGauge.reserved') }}
161
- </span>
162
- <span>
163
- {{ t('node.detail.glance.consumptionGauge.amount', reservedAmountTemplateValues) }}
164
- <span class="ml-10 percentage">
165
- /&nbsp;{{ formattedPercentage }}
166
- </span>
167
- </span>
168
- </template>
169
- </ConsumptionGauge>
170
- </div>
171
- <ConsumptionGauge
172
- :capacity="total"
173
- :used="usage"
174
- :units="units"
175
- :number-formatter="formatter"
176
- :resource-name="showReserved ? '' : resourceName"
177
- :class="{
178
- 'mt-10': showReserved,
179
- }"
180
- >
181
- <template #title="{formattedPercentage}">
182
- <span>
183
- {{ t('node.detail.glance.consumptionGauge.used') }}
184
- </span>
185
- <span>
186
- {{ t('node.detail.glance.consumptionGauge.amount', usedAmountTemplateValues) }}
187
- <span class="ml-10 percentage">
188
- /&nbsp;{{ formattedPercentage }}
189
- </span>
190
- </span>
191
- </template>
192
- </ConsumptionGauge>
193
- </div>
194
- </template>
@@ -1,123 +0,0 @@
1
- <script>
2
- import VMState from '@shell/components/formatter/BadgeStateFormatter';
3
- import HarvesterMigrationState from '@shell/components/formatter/HarvesterMigrationState';
4
-
5
- export default {
6
- components: { VMState, HarvesterMigrationState },
7
- props: {
8
- value: {
9
- type: String,
10
- default: ''
11
- },
12
-
13
- row: {
14
- type: Object,
15
- required: true
16
- },
17
-
18
- allNodeNetwork: {
19
- type: Array,
20
- default: () => {
21
- return [];
22
- }
23
- },
24
-
25
- allClusterNetwork: {
26
- type: Array,
27
- default: () => {
28
- return [];
29
- }
30
- }
31
- },
32
-
33
- data() {
34
- return { isMigrating: false };
35
- },
36
-
37
- computed: {
38
- networkImpassability() {
39
- const nodeName = this.row?.nodeName;
40
- const nn = this.allNodeNetwork.find( N => N.attachNodeName === nodeName);
41
-
42
- return (!!nn?.message || !this.enableClusterNetwork) && this.row?.attachNetwork && this?.row?.actualState === 'Running';
43
- },
44
-
45
- enableClusterNetwork() {
46
- const clusterNetwork = this.allClusterNetwork?.[0] || {};
47
-
48
- return clusterNetwork?.enable;
49
- },
50
-
51
- warningMessage() {
52
- const out = [];
53
-
54
- if (this.networkImpassability && this.allClusterNetwork.length) {
55
- out.push(this.t('harvester.network.message.vlanInactive', { name: this.row.realAttachNodeName }));
56
- }
57
-
58
- if (this.row.warningMessage?.pod) {
59
- const pod = this.row.warningMessage.pod;
60
-
61
- if (pod.metadata?.state?.error && !/pod has unbound immediate PersistentVolumeClaims/.test(pod.metadata?.state?.message)) {
62
- out.push(pod.metadata?.state?.message);
63
- }
64
- }
65
-
66
- if (this.row?.actualState === 'VM error' && this.row.warningMessage?.message) {
67
- out.push(this.row.warningMessage?.message);
68
- }
69
-
70
- if (this.row?.migrationMessage) {
71
- out.push(this.row?.migrationMessage.message);
72
- }
73
-
74
- return out;
75
- }
76
- },
77
-
78
- methods: {
79
- migrationStateChanged(neu) {
80
- if (neu === 'Failed') {
81
- this.isMigrating = false;
82
- } else {
83
- this.isMigrating = !!neu;
84
- }
85
- }
86
- },
87
- };
88
- </script>
89
-
90
- <template>
91
- <span>
92
- <HarvesterMigrationState v-show="isMigrating" :vm-resource="row" @state-changed="migrationStateChanged" />
93
- <div v-show="!isMigrating" class="state">
94
- <VMState :row="row" />
95
- <v-popover
96
- v-if="warningMessage.length"
97
- trigger="hover"
98
- offset="16"
99
- >
100
- <span class="tooltip-target">
101
- <i class="icon icon-warning icon-lg text-warning" />
102
- </span>
103
-
104
- <template slot="popover">
105
- <p v-for="(message, index) in warningMessage" :key="message">
106
- {{ index + 1 }}. {{ message }}
107
- </p>
108
- </template>
109
- </v-popover>
110
- </div>
111
- </span>
112
- </template>
113
-
114
- <style lang="scss" scoped>
115
- .state {
116
- display: flex;
117
- justify-content: space-between;
118
-
119
- .icon-warning {
120
- margin-top: 2px;
121
- }
122
- }
123
- </style>