@rancher/shell 0.1.0 → 0.1.1

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 (595) hide show
  1. package/assets/styles/base/_basic.scss +0 -1
  2. package/assets/styles/base/_variables.scss +2 -0
  3. package/assets/styles/global/_labeled-input.scss +6 -1
  4. package/assets/styles/global/_select.scss +9 -0
  5. package/assets/styles/vendor/vue-js-modal.scss +4 -0
  6. package/assets/translations/en-us.yaml +240 -16
  7. package/assets/translations/zh-hans.yaml +335 -111
  8. package/chart/example.vue +1 -1
  9. package/chart/istio.vue +2 -2
  10. package/chart/logging/index.vue +2 -2
  11. package/chart/monitoring/alerting/index.vue +2 -2
  12. package/chart/monitoring/grafana/index.vue +2 -2
  13. package/chart/monitoring/index.vue +2 -2
  14. package/chart/monitoring/prometheus/index.vue +4 -4
  15. package/chart/rancher-alerting-drivers.vue +17 -3
  16. package/chart/rancher-backup/S3.vue +37 -4
  17. package/chart/rancher-backup/index.vue +3 -3
  18. package/cloud-credential/aws.vue +1 -1
  19. package/cloud-credential/azure.vue +1 -1
  20. package/cloud-credential/digitalocean.vue +1 -1
  21. package/cloud-credential/gcp.vue +1 -1
  22. package/cloud-credential/generic.vue +1 -1
  23. package/cloud-credential/harvester.vue +2 -2
  24. package/cloud-credential/linode.vue +1 -1
  25. package/cloud-credential/s3.vue +2 -2
  26. package/cloud-credential/vmwarevsphere.vue +1 -1
  27. package/components/ActionMenu.vue +11 -1
  28. package/components/Alert.vue +1 -1
  29. package/components/AssignTo.vue +2 -2
  30. package/components/AsyncButton.vue +25 -12
  31. package/components/AwsComplianceBanner.vue +44 -0
  32. package/components/BannerGraphic.vue +11 -2
  33. package/components/ChartReadme.vue +10 -2
  34. package/components/CompoundStatusBadge.vue +50 -0
  35. package/components/CopyToClipboardText.vue +25 -4
  36. package/components/CruResource.vue +185 -16
  37. package/components/CruResourceFooter.vue +17 -1
  38. package/components/EtcdInfoBanner.vue +1 -1
  39. package/components/FilterLabel.vue +254 -0
  40. package/components/GlobalRoleBindings.vue +2 -2
  41. package/components/GrafanaDashboard.vue +1 -1
  42. package/components/GrowlManager.vue +20 -9
  43. package/components/HarvesterServiceAddOnConfig.vue +2 -2
  44. package/components/Import.vue +2 -2
  45. package/components/LandingPagePreference.vue +2 -2
  46. package/components/Markdown.vue +44 -12
  47. package/components/ModalWithCard.vue +2 -2
  48. package/components/MoveModal.vue +1 -1
  49. package/components/PercentageBar.vue +1 -1
  50. package/components/PromptChangePassword.vue +1 -1
  51. package/components/PromptModal.vue +13 -2
  52. package/components/PromptRemove.vue +64 -33
  53. package/components/PromptRestore.vue +3 -3
  54. package/components/Questions/Boolean.vue +1 -1
  55. package/components/Questions/Float.vue +1 -1
  56. package/components/Questions/Int.vue +1 -1
  57. package/components/Questions/Reference.vue +1 -1
  58. package/components/Questions/String.vue +1 -1
  59. package/components/RelatedResources.vue +1 -1
  60. package/components/RelatedWorkloadsTable.vue +3 -1
  61. package/components/ResourceDetail/Masthead.vue +27 -9
  62. package/components/ResourceDetail/index.vue +72 -7
  63. package/components/ResourceList/Masthead.vue +22 -0
  64. package/components/ResourceList/ResourceLoadingIndicator.vue +137 -0
  65. package/components/ResourceList/index.vue +42 -7
  66. package/components/ResourceTable.vue +11 -2
  67. package/components/ResourceYaml.vue +7 -1
  68. package/components/SelectIconGrid.vue +14 -1
  69. package/components/SortableTable/THead.vue +1 -1
  70. package/components/SortableTable/debug.js +117 -0
  71. package/components/SortableTable/index.vue +200 -43
  72. package/components/SortableTable/paging.js +2 -12
  73. package/components/SortableTable/selection.js +3 -0
  74. package/components/SortableTable/sorting.js +3 -1
  75. package/components/Tabbed/Tab.vue +25 -4
  76. package/components/Tabbed/index.vue +133 -119
  77. package/components/TypeDescription.vue +1 -1
  78. package/components/VMConsoleBar.vue +1 -1
  79. package/components/Wizard.vue +53 -14
  80. package/components/YamlEditor.vue +10 -0
  81. package/components/__tests__/CopyCode.test.ts +1 -7
  82. package/components/__tests__/CruResource.test.ts +1 -8
  83. package/components/auth/AllowedPrincipals.vue +1 -1
  84. package/components/auth/AuthBanner.vue +2 -1
  85. package/components/auth/AzureWarning.vue +69 -0
  86. package/components/auth/RoleDetailEdit.vue +4 -4
  87. package/components/auth/login/ldap.vue +1 -1
  88. package/components/cards/ApplicationCard.vue +140 -0
  89. package/components/dialog/AddClusterMemberDialog.vue +1 -1
  90. package/components/dialog/AddCustomBadgeDialog.vue +4 -4
  91. package/components/dialog/AddProjectMemberDialog.vue +2 -2
  92. package/components/dialog/AddonConfigConfirmationDialog.vue +1 -1
  93. package/components/dialog/DrainNode.vue +3 -3
  94. package/components/dialog/ForceMachineRemoveDialog.vue +2 -2
  95. package/components/dialog/GenericPrompt.vue +2 -2
  96. package/components/dialog/RollbackWorkloadDialog.vue +2 -2
  97. package/components/dialog/RotateCertificatesDialog.vue +3 -3
  98. package/components/dialog/RotateEncryptionKeyDialog.vue +11 -6
  99. package/components/dialog/SaveAsRKETemplateDialog.vue +3 -3
  100. package/components/dialog/harvester/AddHotplugModal.vue +3 -3
  101. package/components/dialog/harvester/BackupModal.vue +3 -3
  102. package/components/dialog/harvester/CloneTemplate.vue +3 -3
  103. package/components/dialog/harvester/EjectCDROMDialog.vue +3 -3
  104. package/components/dialog/harvester/ExportImageDialog.vue +3 -3
  105. package/components/dialog/harvester/MaintenanceDialog.vue +2 -2
  106. package/components/dialog/harvester/MigrationDialog.vue +2 -2
  107. package/components/dialog/harvester/RestoreDialog.vue +2 -2
  108. package/components/dialog/harvester/SupportBundle.vue +2 -2
  109. package/components/dialog/harvester/UnplugVolume.vue +2 -2
  110. package/components/fleet/FleetBundleResources.vue +1 -1
  111. package/components/fleet/FleetBundles.vue +1 -1
  112. package/components/fleet/FleetResources.vue +5 -3
  113. package/components/fleet/ForceDirectedTreeChart/chartIcons.js +17 -0
  114. package/components/fleet/ForceDirectedTreeChart/index.vue +553 -0
  115. package/components/form/ArrayList.vue +22 -3
  116. package/components/form/BannerSettings.vue +3 -3
  117. package/components/form/ChangePassword.vue +2 -2
  118. package/components/form/Command.vue +28 -9
  119. package/components/form/Error.vue +50 -0
  120. package/components/form/Footer.vue +2 -5
  121. package/components/form/HealthCheck.vue +2 -2
  122. package/components/form/HookOption.vue +2 -2
  123. package/components/form/InputWithSelect.vue +12 -2
  124. package/components/form/KeyValue.vue +5 -2
  125. package/components/form/LabeledSelect.vue +27 -14
  126. package/components/form/Labels.vue +12 -0
  127. package/components/form/MatchExpressions.vue +44 -10
  128. package/components/form/Members/ClusterPermissionsEditor.vue +3 -3
  129. package/components/form/Members/MembershipEditor.vue +10 -1
  130. package/components/form/Members/ProjectMembershipEditor.vue +1 -0
  131. package/components/form/NameNsDescription.vue +202 -79
  132. package/components/form/Networking.vue +1 -1
  133. package/components/form/NodeAffinity.vue +41 -26
  134. package/components/form/NodeScheduling.vue +29 -3
  135. package/components/form/NotificationSettings.vue +2 -2
  136. package/components/form/Password.vue +1 -1
  137. package/components/form/PodAffinity.vue +64 -6
  138. package/components/form/PodSecurity.vue +2 -2
  139. package/components/form/Ports.vue +1 -1
  140. package/components/form/Probe.vue +60 -17
  141. package/components/form/ProjectMemberEditor.vue +3 -3
  142. package/components/form/ResourceQuota/NamespaceRow.vue +46 -2
  143. package/components/form/ResourceQuota/Project.vue +4 -0
  144. package/components/form/ResourceTabs/index.vue +19 -7
  145. package/components/form/RuleSelector.vue +1 -1
  146. package/components/form/Security.vue +56 -14
  147. package/components/form/Select.vue +52 -10
  148. package/components/form/SelectOrCreateAuthSecret.vue +70 -31
  149. package/components/form/ServiceNameSelect.vue +1 -1
  150. package/components/form/ServicePorts.vue +10 -2
  151. package/components/form/ShellInput.vue +1 -1
  152. package/components/form/SimpleSecretSelector.vue +2 -2
  153. package/components/form/Tolerations.vue +1 -1
  154. package/components/form/UnitInput.vue +12 -3
  155. package/components/form/ValueFromResource.vue +1 -1
  156. package/components/form/WorkloadPorts.vue +1 -1
  157. package/components/form/__tests__/Command.test.ts +63 -0
  158. package/components/form/__tests__/Error.test.ts +56 -0
  159. package/components/form/__tests__/MatchExpressions.test.ts +79 -0
  160. package/components/form/__tests__/Probe.test.ts +62 -0
  161. package/components/form/__tests__/Security.test.ts +55 -0
  162. package/components/form/__tests__/UnitInput.test.ts +31 -23
  163. package/components/formatter/BadgeStateFormatter.vue +1 -1
  164. package/components/formatter/Capitalize.vue +7 -0
  165. package/components/formatter/ClusterLink.vue +6 -2
  166. package/components/formatter/ClusterProvider.vue +36 -0
  167. package/components/formatter/DelayedValue.vue +43 -0
  168. package/components/formatter/Endpoints.vue +2 -2
  169. package/components/formatter/HarvesterDiskState.vue +1 -1
  170. package/components/formatter/HarvesterIpAddress.vue +37 -18
  171. package/components/formatter/HarvesterMigrationState.vue +1 -1
  172. package/components/formatter/HarvesterVmState.vue +1 -1
  173. package/components/formatter/LinkDetail.vue +11 -2
  174. package/components/formatter/LinkName.vue +2 -2
  175. package/components/formatter/LiveExpiryBadgeState.vue +1 -1
  176. package/components/formatter/LivePodRestarts.vue +47 -0
  177. package/components/formatter/MachineSummaryGraph.vue +51 -5
  178. package/components/formatter/PodsUsage.vue +5 -3
  179. package/components/formatter/Weight.vue +1 -1
  180. package/components/formatter/WorkloadHealthScale.vue +17 -6
  181. package/components/nav/HarvesterUpgrade.vue +15 -5
  182. package/components/nav/Header.vue +15 -6
  183. package/components/nav/Jump.vue +1 -1
  184. package/components/nav/NamespaceFilter.vue +30 -10
  185. package/components/nav/TopLevelMenu.vue +52 -14
  186. package/components/nav/WindowManager/ContainerLogs.vue +14 -2
  187. package/components/nav/WorkspaceSwitcher.vue +1 -1
  188. package/components/{NovncConsole.vue → novnc/NovncConsole.vue} +0 -0
  189. package/components/novnc/NovncConsoleItem.vue +89 -0
  190. package/components/novnc/NovncConsoleWrapper.vue +243 -0
  191. package/config/labels-annotations.js +6 -2
  192. package/config/product/explorer.js +7 -3
  193. package/config/product/fleet.js +4 -1
  194. package/config/product/manager.js +5 -6
  195. package/config/product/settings.js +12 -1
  196. package/config/query-params.js +2 -0
  197. package/config/roles.ts +5 -0
  198. package/config/settings.js +60 -63
  199. package/config/table-headers.js +47 -18
  200. package/config/types.js +24 -8
  201. package/content/docs/en-us/whats-new.md +25 -0
  202. package/core/plugin.ts +12 -2
  203. package/creators/app/init +7 -1
  204. package/creators/pkg/tsconfig.json +2 -3
  205. package/detail/catalog.cattle.io.app.vue +1 -1
  206. package/detail/cis.cattle.io.clusterscan.vue +1 -1
  207. package/detail/fleet.cattle.io.bundle.vue +73 -21
  208. package/detail/fleet.cattle.io.gitrepo.vue +5 -4
  209. package/detail/harvesterhci.io.host/HarvesterHostBasic.vue +25 -4
  210. package/detail/harvesterhci.io.host/HarvesterHostDisk.vue +2 -2
  211. package/detail/harvesterhci.io.virtualmachinebackup/index.vue +1 -1
  212. package/detail/helm.cattle.io.projecthelmchart.vue +1 -1
  213. package/detail/networking.k8s.io.ingress.vue +10 -2
  214. package/detail/pod.vue +37 -1
  215. package/detail/provisioning.cattle.io.cluster.vue +102 -15
  216. package/detail/workload/index.vue +163 -15
  217. package/edit/auth/azuread.vue +146 -34
  218. package/edit/auth/github.vue +3 -3
  219. package/edit/auth/googleoauth.vue +3 -3
  220. package/edit/auth/ldap/config.vue +15 -7
  221. package/edit/auth/ldap/index.vue +2 -2
  222. package/edit/auth/oidc.vue +3 -3
  223. package/edit/auth/saml.vue +3 -3
  224. package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -1
  225. package/edit/autoscaling.horizontalpodautoscaler/metric-identifier.vue +1 -1
  226. package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +1 -1
  227. package/edit/autoscaling.horizontalpodautoscaler/metric-target.vue +1 -1
  228. package/edit/autoscaling.horizontalpodautoscaler/metrics-row.vue +1 -1
  229. package/edit/catalog.cattle.io.clusterrepo.vue +2 -2
  230. package/edit/cis.cattle.io.clusterscan.vue +4 -4
  231. package/edit/cis.cattle.io.clusterscanbenchmark.vue +1 -1
  232. package/edit/constraints.gatekeeper.sh.constraint/index.vue +1 -1
  233. package/edit/fleet.cattle.io.cluster.vue +1 -0
  234. package/edit/fleet.cattle.io.clustergroup.vue +1 -1
  235. package/edit/fleet.cattle.io.gitrepo.vue +290 -157
  236. package/edit/harvesterhci.io.host/HarvesterDisk.vue +4 -5
  237. package/edit/harvesterhci.io.host/index.vue +28 -19
  238. package/edit/harvesterhci.io.keypair.vue +1 -1
  239. package/edit/harvesterhci.io.managedchart/rancher-monitoring.vue +1 -1
  240. package/edit/harvesterhci.io.management.cluster.vue +1 -1
  241. package/edit/harvesterhci.io.networkattachmentdefinition.vue +2 -2
  242. package/edit/harvesterhci.io.setting/additional-ca.vue +1 -1
  243. package/edit/harvesterhci.io.setting/backup-target.vue +1 -1
  244. package/edit/harvesterhci.io.setting/http-proxy.vue +1 -1
  245. package/edit/harvesterhci.io.setting/index.vue +3 -3
  246. package/edit/harvesterhci.io.setting/overcommit-config.vue +4 -1
  247. package/edit/harvesterhci.io.setting/ssl-parameters.vue +1 -1
  248. package/edit/harvesterhci.io.setting/support-bundle-image.vue +1 -1
  249. package/edit/harvesterhci.io.setting/vip-pools.vue +1 -1
  250. package/edit/harvesterhci.io.setting/vm-force-reset-policy.vue +2 -2
  251. package/edit/harvesterhci.io.virtualmachinebackup.vue +2 -2
  252. package/edit/harvesterhci.io.virtualmachineimage.vue +2 -2
  253. package/edit/harvesterhci.io.virtualmachinetemplateversion.vue +26 -18
  254. package/edit/helm.cattle.io.projecthelmchart.vue +3 -3
  255. package/edit/k8s.cni.cncf.io.networkattachmentdefinition.vue +2 -2
  256. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/AccessCredentialsUsers.vue +1 -1
  257. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/index.vue +1 -1
  258. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/DataTemplate.vue +1 -0
  259. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/index.vue +2 -1
  260. package/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory.vue +3 -1
  261. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/__tests__/HarvesterEditNetwork.test.ts +41 -0
  262. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/base.vue +79 -36
  263. package/edit/kubevirt.io.virtualmachine/VirtualMachineReserved.vue +54 -0
  264. package/edit/kubevirt.io.virtualmachine/VirtualMachineSSHKey.vue +1 -1
  265. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/index.vue +2 -3
  266. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditContainer.test.ts +40 -0
  267. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditExisting.test.ts +102 -0
  268. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVMImage.test.ts +117 -0
  269. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVolume.test.ts +74 -0
  270. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/container.vue +59 -13
  271. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/existing.vue +72 -16
  272. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/vmImage.vue +74 -14
  273. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/volume.vue +35 -9
  274. package/edit/kubevirt.io.virtualmachine/index.vue +33 -24
  275. package/edit/logging-flow/index.vue +1 -1
  276. package/edit/logging.banzaicloud.io.output/index.vue +1 -1
  277. package/edit/logging.banzaicloud.io.output/providers/awsElasticsearch.vue +1 -1
  278. package/edit/logging.banzaicloud.io.output/providers/azurestorage.vue +1 -1
  279. package/edit/logging.banzaicloud.io.output/providers/cloudwatch.vue +1 -1
  280. package/edit/logging.banzaicloud.io.output/providers/datadog.vue +2 -2
  281. package/edit/logging.banzaicloud.io.output/providers/elasticsearch.vue +2 -2
  282. package/edit/logging.banzaicloud.io.output/providers/file.vue +1 -1
  283. package/edit/logging.banzaicloud.io.output/providers/forward.vue +1 -1
  284. package/edit/logging.banzaicloud.io.output/providers/gcs.vue +2 -2
  285. package/edit/logging.banzaicloud.io.output/providers/gelf.vue +2 -2
  286. package/edit/logging.banzaicloud.io.output/providers/kafka.vue +2 -2
  287. package/edit/logging.banzaicloud.io.output/providers/kinesisStream.vue +1 -1
  288. package/edit/logging.banzaicloud.io.output/providers/logdna.vue +1 -1
  289. package/edit/logging.banzaicloud.io.output/providers/logz.vue +2 -2
  290. package/edit/logging.banzaicloud.io.output/providers/loki.vue +2 -2
  291. package/edit/logging.banzaicloud.io.output/providers/newrelic.vue +1 -1
  292. package/edit/logging.banzaicloud.io.output/providers/s3.vue +2 -2
  293. package/edit/logging.banzaicloud.io.output/providers/splunkHec.vue +2 -2
  294. package/edit/logging.banzaicloud.io.output/providers/sumologic.vue +1 -1
  295. package/edit/logging.banzaicloud.io.output/providers/syslog.vue +2 -2
  296. package/edit/management.cattle.io.clusterroletemplatebinding.vue +2 -0
  297. package/edit/management.cattle.io.node.vue +71 -0
  298. package/edit/management.cattle.io.project.vue +28 -23
  299. package/edit/management.cattle.io.setting.vue +14 -3
  300. package/edit/management.cattle.io.user.vue +1 -1
  301. package/edit/monitoring.coreos.com.alertmanagerconfig/index.vue +4 -4
  302. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +13 -13
  303. package/edit/monitoring.coreos.com.alertmanagerconfig/routeConfig.vue +18 -10
  304. package/edit/monitoring.coreos.com.alertmanagerconfig/tls.vue +2 -2
  305. package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +12 -7
  306. package/edit/monitoring.coreos.com.alertmanagerconfig/types/opsgenie.vue +12 -7
  307. package/edit/monitoring.coreos.com.alertmanagerconfig/types/pagerduty.vue +20 -11
  308. package/edit/monitoring.coreos.com.alertmanagerconfig/types/slack.vue +13 -8
  309. package/edit/monitoring.coreos.com.alertmanagerconfig/types/webhook.vue +25 -7
  310. package/edit/monitoring.coreos.com.prometheusrule/AlertingRule.vue +2 -2
  311. package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +20 -7
  312. package/edit/monitoring.coreos.com.prometheusrule/RecordingRule.vue +1 -1
  313. package/edit/monitoring.coreos.com.prometheusrule/index.vue +19 -8
  314. package/edit/monitoring.coreos.com.receiver/auth.vue +1 -1
  315. package/edit/monitoring.coreos.com.receiver/index.vue +2 -2
  316. package/edit/monitoring.coreos.com.receiver/tls.vue +2 -2
  317. package/edit/monitoring.coreos.com.receiver/types/email.vue +2 -2
  318. package/edit/monitoring.coreos.com.receiver/types/opsgenie.vue +2 -2
  319. package/edit/monitoring.coreos.com.receiver/types/pagerduty.vue +2 -2
  320. package/edit/monitoring.coreos.com.receiver/types/slack.vue +2 -2
  321. package/edit/monitoring.coreos.com.receiver/types/webhook.banner.vue +1 -1
  322. package/edit/monitoring.coreos.com.receiver/types/webhook.vue +3 -3
  323. package/edit/monitoring.coreos.com.route.vue +2 -2
  324. package/edit/namespace.vue +0 -8
  325. package/edit/network.harvesterhci.io.clusternetwork/vlan.vue +1 -1
  326. package/edit/networking.istio.io.destinationrule/LoadBalancer.vue +2 -2
  327. package/edit/networking.istio.io.destinationrule/index.vue +1 -1
  328. package/edit/networking.k8s.io.ingress/Certificate.vue +5 -1
  329. package/edit/networking.k8s.io.ingress/Certificates.vue +5 -0
  330. package/edit/networking.k8s.io.ingress/DefaultBackend.vue +17 -2
  331. package/edit/networking.k8s.io.ingress/IngressClass.vue +63 -0
  332. package/edit/networking.k8s.io.ingress/Rule.vue +42 -6
  333. package/edit/networking.k8s.io.ingress/RulePath.vue +29 -5
  334. package/edit/networking.k8s.io.ingress/Rules.vue +11 -0
  335. package/edit/networking.k8s.io.ingress/index.vue +104 -15
  336. package/edit/networking.k8s.io.networkpolicy/PolicyRulePort.vue +1 -1
  337. package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +2 -2
  338. package/edit/networking.k8s.io.networkpolicy/index.vue +2 -2
  339. package/edit/persistentvolume/index.vue +1 -1
  340. package/edit/persistentvolume/plugins/awsElasticBlockStore.vue +2 -2
  341. package/edit/persistentvolume/plugins/azureDisk.vue +2 -2
  342. package/edit/persistentvolume/plugins/azureFile.vue +2 -2
  343. package/edit/persistentvolume/plugins/cephfs.vue +4 -4
  344. package/edit/persistentvolume/plugins/cinder.vue +2 -2
  345. package/edit/persistentvolume/plugins/csi.vue +2 -2
  346. package/edit/persistentvolume/plugins/fc.vue +4 -4
  347. package/edit/persistentvolume/plugins/flexVolume.vue +2 -2
  348. package/edit/persistentvolume/plugins/flocker.vue +1 -1
  349. package/edit/persistentvolume/plugins/gcePersistentDisk.vue +2 -2
  350. package/edit/persistentvolume/plugins/glusterfs.vue +2 -2
  351. package/edit/persistentvolume/plugins/hostPath.vue +1 -1
  352. package/edit/persistentvolume/plugins/iscsi.vue +4 -4
  353. package/edit/persistentvolume/plugins/local.vue +1 -1
  354. package/edit/persistentvolume/plugins/longhorn.vue +2 -2
  355. package/edit/persistentvolume/plugins/nfs.vue +2 -2
  356. package/edit/persistentvolume/plugins/photonPersistentDisk.vue +1 -1
  357. package/edit/persistentvolume/plugins/portworxVolume.vue +2 -2
  358. package/edit/persistentvolume/plugins/quobyte.vue +2 -2
  359. package/edit/persistentvolume/plugins/rbd.vue +4 -4
  360. package/edit/persistentvolume/plugins/scaleIO.vue +2 -2
  361. package/edit/persistentvolume/plugins/storageos.vue +2 -2
  362. package/edit/persistentvolume/plugins/vsphereVolume.vue +1 -1
  363. package/edit/persistentvolumeclaim.vue +24 -8
  364. package/edit/provisioning.cattle.io.cluster/ACE.vue +2 -2
  365. package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +8 -3
  366. package/edit/provisioning.cattle.io.cluster/DrainOptions.vue +2 -2
  367. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +15 -3
  368. package/edit/provisioning.cattle.io.cluster/RegistryConfigs.vue +16 -3
  369. package/edit/provisioning.cattle.io.cluster/S3Config.vue +2 -2
  370. package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +1 -1
  371. package/edit/provisioning.cattle.io.cluster/__tests__/CustomCommand.tests.ts +1 -7
  372. package/edit/provisioning.cattle.io.cluster/import.vue +2 -1
  373. package/edit/provisioning.cattle.io.cluster/index.vue +26 -7
  374. package/edit/provisioning.cattle.io.cluster/rke2.vue +136 -48
  375. package/edit/resources.cattle.io.backup.vue +26 -8
  376. package/edit/resources.cattle.io.restore.vue +3 -3
  377. package/edit/secret/basic.vue +1 -1
  378. package/edit/secret/index.vue +80 -2
  379. package/edit/secret/registry.vue +2 -2
  380. package/edit/secret/ssh.vue +1 -1
  381. package/edit/secret/tls.vue +1 -1
  382. package/edit/service.vue +47 -11
  383. package/edit/serviceaccount.vue +1 -1
  384. package/edit/storage.k8s.io.storageclass/index.vue +1 -1
  385. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/aws-ebs.vue +7 -3
  386. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/azure-disk.vue +1 -1
  387. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/azure-file.vue +1 -1
  388. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/cinder.vue +2 -2
  389. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/gce-pd.vue +2 -2
  390. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/glusterfs.vue +1 -1
  391. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/portworx-volume.vue +1 -1
  392. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/quobyte.vue +1 -1
  393. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/rbd.vue +1 -1
  394. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/scaleio.vue +1 -1
  395. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/storageos.vue +1 -1
  396. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/vsphere-volume.vue +1 -1
  397. package/edit/token.vue +3 -3
  398. package/edit/ui.cattle.io.navlink.vue +2 -2
  399. package/edit/workload/Job.vue +111 -23
  400. package/edit/workload/Upgrading.vue +77 -22
  401. package/edit/workload/__tests__/Job.test.ts +72 -0
  402. package/edit/workload/__tests__/Upgrading.test.ts +60 -0
  403. package/edit/workload/index.vue +13 -1085
  404. package/edit/workload/mixins/workload.js +900 -0
  405. package/edit/workload/storage/Mount.vue +2 -2
  406. package/edit/workload/storage/awsElasticBlockStore.vue +1 -1
  407. package/edit/workload/storage/azureDisk.vue +2 -2
  408. package/edit/workload/storage/azureFile.vue +1 -1
  409. package/edit/workload/storage/ephemeralVolume/index.vue +2 -2
  410. package/edit/workload/storage/gcePersistentDisk.vue +1 -1
  411. package/edit/workload/storage/hostPath.vue +1 -1
  412. package/edit/workload/storage/nfs.vue +2 -2
  413. package/edit/workload/storage/persistentVolumeClaim/index.vue +2 -2
  414. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +3 -3
  415. package/edit/workload/storage/secret.vue +2 -2
  416. package/edit/workload/storage/vsphereVolume.vue +1 -1
  417. package/edit/workload/types/Deployment.vue +377 -0
  418. package/edit/workload/types/Generic.vue +295 -0
  419. package/layouts/default.vue +26 -7
  420. package/layouts/error.vue +3 -2
  421. package/layouts/home.vue +12 -2
  422. package/layouts/plain.vue +18 -2
  423. package/layouts/unauthenticated.vue +2 -1
  424. package/list/catalog.cattle.io.clusterrepo.vue +1 -1
  425. package/list/fleet.cattle.io.bundle.vue +1 -1
  426. package/list/fleet.cattle.io.cluster.vue +1 -1
  427. package/list/fleet.cattle.io.clusterregistrationtoken.vue +1 -1
  428. package/list/harvesterhci.io.dashboard/HarvesterUpgrade.vue +9 -8
  429. package/list/harvesterhci.io.dashboard/UpgradeInfo.vue +40 -0
  430. package/list/harvesterhci.io.dashboard/index.vue +14 -36
  431. package/list/harvesterhci.io.host/index.vue +24 -12
  432. package/list/harvesterhci.io.networkattachmentdefinition.vue +1 -1
  433. package/list/harvesterhci.io.setting.vue +1 -1
  434. package/list/harvesterhci.io.virtualmachinebackup.vue +1 -1
  435. package/list/harvesterhci.io.virtualmachineimage.vue +36 -3
  436. package/list/harvesterhci.io.virtualmachinetemplateversion.vue +1 -5
  437. package/list/helm.cattle.io.projecthelmchart.vue +1 -1
  438. package/list/kubevirt.io.virtualmachine.vue +4 -2
  439. package/list/management.cattle.io.feature.vue +3 -3
  440. package/list/management.cattle.io.setting.vue +2 -2
  441. package/list/monitoring.coreos.com.alertmanagerconfig.vue +1 -1
  442. package/list/namespace.vue +3 -1
  443. package/list/node.vue +10 -3
  444. package/list/persistentvolumeclaim.vue +42 -0
  445. package/list/provisioning.cattle.io.cluster.vue +22 -20
  446. package/list/workload.vue +31 -6
  447. package/machine-config/amazonec2.vue +37 -12
  448. package/machine-config/azure.vue +3 -3
  449. package/machine-config/digitalocean.vue +2 -2
  450. package/machine-config/generic.vue +1 -1
  451. package/machine-config/harvester.vue +124 -25
  452. package/machine-config/linode.vue +2 -2
  453. package/machine-config/vmwarevsphere.vue +5 -5
  454. package/middleware/authenticated.js +36 -6
  455. package/middleware/unauthenticated.js +22 -0
  456. package/mixins/brand.js +50 -3
  457. package/mixins/browser-tab-visibility.js +37 -0
  458. package/mixins/chart.js +36 -4
  459. package/mixins/{compact-input.js → compact-input.ts} +5 -3
  460. package/mixins/form-validation.js +122 -0
  461. package/mixins/harvester-vm/index.js +134 -90
  462. package/mixins/labeled-form-element.ts +193 -0
  463. package/mixins/resource-fetch.js +173 -0
  464. package/models/cluster.x-k8s.io.machine.js +6 -2
  465. package/models/etcdbackup.js +4 -0
  466. package/models/event.js +4 -0
  467. package/models/fleet.cattle.io.bundle.js +1 -1
  468. package/models/fleet.cattle.io.gitrepo.js +10 -0
  469. package/models/harvester/harvesterhci.io.virtualmachinebackup.js +5 -2
  470. package/models/harvester/harvesterhci.io.virtualmachineimage.js +11 -8
  471. package/models/harvester/harvesterhci.io.virtualmachinetemplateversion.js +11 -2
  472. package/models/harvester/kubevirt.io.virtualmachine.js +2 -2
  473. package/models/harvester/kubevirt.io.virtualmachineinstance.js +1 -1
  474. package/models/harvester/node.js +27 -32
  475. package/models/harvester/persistentvolumeclaim.js +1 -1
  476. package/models/management.cattle.io.cluster.js +17 -11
  477. package/models/management.cattle.io.clusterroletemplatebinding.js +2 -2
  478. package/models/management.cattle.io.globalrole.js +19 -0
  479. package/models/management.cattle.io.node.js +10 -11
  480. package/models/management.cattle.io.project.js +60 -26
  481. package/models/management.cattle.io.roletemplate.js +19 -0
  482. package/models/monitoring.coreos.com.alertmanagerconfig.js +3 -2
  483. package/models/monitoring.coreos.com.prometheusrule.js +9 -0
  484. package/models/namespace.js +9 -1
  485. package/models/networking.k8s.io.ingress.js +17 -5
  486. package/models/persistentvolumeclaim.js +47 -1
  487. package/models/projectroletemplatebinding.js +2 -2
  488. package/models/provisioning.cattle.io.cluster.js +92 -13
  489. package/models/rke.cattle.io.etcdsnapshot.js +4 -0
  490. package/models/service.js +11 -5
  491. package/models/storage.k8s.io.storageclass.js +14 -1
  492. package/models/workload.js +7 -2
  493. package/nuxt.config.js +27 -7
  494. package/package.json +10 -14
  495. package/pages/about.vue +15 -1
  496. package/pages/account/index.vue +1 -1
  497. package/pages/auth/login.vue +17 -5
  498. package/pages/auth/setup.vue +47 -9
  499. package/pages/c/_cluster/_product/_resource/create.vue +1 -1
  500. package/pages/c/_cluster/_product/members/index.vue +6 -1
  501. package/pages/c/_cluster/_product/projectsnamespaces.vue +113 -11
  502. package/pages/c/_cluster/apps/charts/chart.vue +1 -1
  503. package/pages/c/_cluster/apps/charts/index.vue +2 -2
  504. package/pages/c/_cluster/apps/charts/install.vue +197 -19
  505. package/pages/c/_cluster/auth/config/index.vue +1 -1
  506. package/pages/c/_cluster/explorer/EventsTable.vue +1 -15
  507. package/pages/c/_cluster/explorer/index.vue +64 -35
  508. package/pages/c/_cluster/explorer/tools/index.vue +1 -1
  509. package/pages/c/_cluster/fleet/GitRepoGraphConfig.js +249 -0
  510. package/pages/c/_cluster/fleet/index.vue +47 -65
  511. package/pages/c/_cluster/harvester/airgapupgrade/index.vue +7 -4
  512. package/pages/c/_cluster/harvester/console/_uid/vnc.vue +7 -1
  513. package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +8 -14
  514. package/pages/c/_cluster/monitoring/index.vue +1 -1
  515. package/pages/c/_cluster/monitoring/route-receiver/index.vue +1 -1
  516. package/pages/c/_cluster/settings/banners.vue +2 -2
  517. package/pages/c/_cluster/settings/brand.vue +62 -7
  518. package/pages/c/_cluster/settings/performance.vue +167 -0
  519. package/pages/diagnostic.vue +468 -0
  520. package/pages/fail-whale.vue +17 -5
  521. package/pages/home.vue +36 -22
  522. package/pages/plugins.vue +1 -1
  523. package/pages/prefs.vue +20 -7
  524. package/pages/support/index.vue +51 -9
  525. package/pkg/auto-import.js +1 -1
  526. package/pkg/dynamic-importer.lib.js +8 -0
  527. package/pkg/tsconfig.json +26 -9
  528. package/pkg/vue.config.js +8 -0
  529. package/plugins/console.js +29 -0
  530. package/plugins/dashboard-store/actions.js +171 -28
  531. package/plugins/dashboard-store/getters.js +13 -1
  532. package/plugins/dashboard-store/index.js +5 -1
  533. package/plugins/dashboard-store/mutations.js +72 -22
  534. package/plugins/dashboard-store/resource-class.js +259 -184
  535. package/plugins/i18n.js +9 -3
  536. package/plugins/steve/actions.js +16 -1
  537. package/plugins/steve/getters.js +9 -1
  538. package/plugins/steve/index.js +6 -2
  539. package/plugins/steve/mutations.js +100 -5
  540. package/plugins/steve/norman-class.js +8 -0
  541. package/plugins/steve/performanceTesting.js +5 -0
  542. package/plugins/steve/subscribe.js +144 -12
  543. package/plugins/steve/web-worker.steve-sub-worker.js +129 -0
  544. package/promptRemove/kubevirt.io.virtualmachine.vue +3 -17
  545. package/promptRemove/management.cattle.io.project.vue +128 -0
  546. package/promptRemove/pod.vue +131 -0
  547. package/rancher-components/BadgeState/BadgeState.spec.ts +12 -0
  548. package/{components → rancher-components/BadgeState}/BadgeState.vue +18 -10
  549. package/rancher-components/BadgeState/index.ts +1 -0
  550. package/{components/__tests__ → rancher-components/Banner}/Banner.test.ts +1 -1
  551. package/{components → rancher-components/Banner}/Banner.vue +22 -7
  552. package/rancher-components/Banner/index.ts +1 -0
  553. package/{components → rancher-components/Card}/Card.vue +58 -12
  554. package/rancher-components/Card/index.ts +1 -0
  555. package/{components/form → rancher-components/Form/Checkbox}/Checkbox.vue +118 -25
  556. package/rancher-components/Form/Checkbox/index.ts +1 -0
  557. package/{components/form/__tests__ → rancher-components/Form/LabeledInput}/LabeledInput.test.ts +13 -2
  558. package/rancher-components/Form/LabeledInput/LabeledInput.vue +341 -0
  559. package/rancher-components/Form/LabeledInput/index.ts +1 -0
  560. package/{components/form → rancher-components/Form/Radio}/RadioButton.vue +50 -22
  561. package/{components/form → rancher-components/Form/Radio}/RadioGroup.vue +76 -28
  562. package/rancher-components/Form/Radio/index.ts +2 -0
  563. package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +169 -0
  564. package/rancher-components/Form/TextArea/index.ts +1 -0
  565. package/rancher-components/Form/index.ts +4 -0
  566. package/{components/form → rancher-components/LabeledTooltip}/LabeledTooltip.vue +32 -11
  567. package/rancher-components/LabeledTooltip/index.ts +1 -0
  568. package/scripts/build-pkg.sh +4 -0
  569. package/scripts/publish-shell.sh +37 -18
  570. package/scripts/test-plugins-build.sh +115 -0
  571. package/store/catalog.js +4 -0
  572. package/store/growl.js +6 -0
  573. package/store/i18n.js +18 -9
  574. package/store/index.js +190 -107
  575. package/store/prefs.js +8 -2
  576. package/store/resource-fetch.js +44 -0
  577. package/store/type-map.js +43 -7
  578. package/store/uiplugins.ts +1 -1
  579. package/utils/favicon.js +40 -0
  580. package/utils/object.js +26 -9
  581. package/utils/promise.js +20 -0
  582. package/utils/socket.js +10 -1
  583. package/utils/string.js +16 -0
  584. package/utils/validators/formRules/__tests__/index.test.ts +928 -0
  585. package/utils/validators/formRules/index.ts +447 -0
  586. package/utils/validators/prometheusrule.js +1 -1
  587. package/utils/validators/vm.js +12 -5
  588. package/utils/width.js +39 -0
  589. package/yarn-error.log +196 -0
  590. package/components/NovncConsoleWrapper.vue +0 -150
  591. package/components/form/Container.vue +0 -143
  592. package/components/form/LabeledInput.vue +0 -245
  593. package/components/form/Scheduling.vue +0 -115
  594. package/components/form/TextAreaAutoGrow.vue +0 -127
  595. package/mixins/labeled-form-element.js +0 -137
@@ -375,50 +375,22 @@ export default {
375
375
  },
376
376
 
377
377
  cpuReserved() {
378
- const useful = this.pods.filter((pod) => {
379
- const nodeName = pod?.spec?.nodeName;
380
-
381
- return this.availableNodes.includes(nodeName);
382
- }).reduce((sum, pod) => {
383
- const containers = pod?.spec?.containers || [];
384
-
385
- const containerCpuReserved = containers.reduce((sum, c) => {
386
- sum += parseSi(c?.resources?.requests?.cpu || '0m');
387
-
388
- return sum;
389
- }, 0);
390
-
391
- sum += containerCpuReserved;
392
-
393
- return sum;
378
+ const useful = this.nodes.reduce((total, node) => {
379
+ return total + node.cpuReserved;
394
380
  }, 0);
395
381
 
396
382
  return {
397
- total: this.cpusTotal,
398
- useful: Number(formatSi(useful)),
383
+ total: this.cpusTotal,
384
+ useful,
399
385
  };
400
386
  },
401
387
 
402
388
  ramReserved() {
403
- const useful = this.pods.filter((pod) => {
404
- const nodeName = pod?.spec?.nodeName;
405
-
406
- return this.availableNodes.includes(nodeName);
407
- }).reduce((sum, pod) => {
408
- const containers = pod?.spec?.containers || [];
409
-
410
- const containerMemoryReserved = containers.reduce((sum, c) => {
411
- sum += parseSi(c?.resources?.requests?.memory || '0m', { increment: 1024 });
412
-
413
- return sum;
414
- }, 0);
415
-
416
- sum += containerMemoryReserved;
417
-
418
- return sum;
389
+ const useful = this.nodes.reduce((total, node) => {
390
+ return total + node.memoryReserved;
419
391
  }, 0);
420
392
 
421
- return this.createMemoryValues(this.memoryTotal, useful);
393
+ return createMemoryValues(this.memoryTotal, useful);
422
394
  },
423
395
 
424
396
  availableNodes() {
@@ -583,7 +555,12 @@ export default {
583
555
  <h3 class="mt-40">
584
556
  {{ t('clusterIndexPage.sections.capacity.label') }}
585
557
  </h3>
586
- <div class="hardware-resource-gauges">
558
+ <div
559
+ class="hardware-resource-gauges"
560
+ :class="{
561
+ live: !storageTotal,
562
+ }"
563
+ >
587
564
  <HardwareResourceGauge
588
565
  :name="t('harvester.dashboard.hardwareResourceGauge.cpu')"
589
566
  :reserved="cpuReserved"
@@ -595,6 +572,7 @@ export default {
595
572
  :used="ramUsed"
596
573
  />
597
574
  <HardwareResourceGauge
575
+ v-if="storageTotal"
598
576
  :name="t('harvester.dashboard.hardwareResourceGauge.storage')"
599
577
  :used="storageUsed"
600
578
  :reserved="storageReserved"
@@ -44,6 +44,8 @@ export default {
44
44
 
45
45
  if (this.$store.getters['harvester/schemaFor'](LONGHORN.NODES)) {
46
46
  _hash.longhornNodes = this.$store.dispatch('harvester/findAll', { type: LONGHORN.NODES });
47
+ } else {
48
+ this.hasLonghornSchema = false;
47
49
  }
48
50
 
49
51
  if (this.$store.getters['harvester/schemaFor'](HCI.BLOCK_DEVICE)) {
@@ -57,8 +59,9 @@ export default {
57
59
 
58
60
  data() {
59
61
  return {
60
- rows: [],
61
- hasMetricSchema: true
62
+ rows: [],
63
+ hasMetricSchema: true,
64
+ hasLonghornSchema: true,
62
65
  };
63
66
  },
64
67
 
@@ -86,33 +89,42 @@ export default {
86
89
  ];
87
90
 
88
91
  if (this.hasMetricSchema) {
92
+ const width = this.hasLonghornSchema ? '230' : '345';
89
93
  const metricCol = [
90
94
  {
91
95
  name: 'cpu',
92
96
  labelKey: 'node.detail.glance.consumptionGauge.cpu',
93
97
  value: 'id',
94
- width: '230',
98
+ width,
95
99
  formatter: 'HarvesterCPUUsed',
100
+ formatterOpts: { showUsed: true },
96
101
  },
97
102
  {
98
103
  name: 'memory',
99
104
  labelKey: 'node.detail.glance.consumptionGauge.memory',
100
105
  value: 'id',
101
- width: '230',
102
- formatter: 'HarvesterMemoryUsed'
106
+ width,
107
+ formatter: 'HarvesterMemoryUsed',
108
+ formatterOpts: { showUsed: true },
103
109
  },
104
- {
105
- name: 'storage',
106
- labelKey: 'tableHeaders.storage',
107
- value: 'id',
108
- width: '230',
109
- formatter: 'HarvesterStorageUsed',
110
- }
111
110
  ];
112
111
 
113
112
  out.splice(-1, 0, ...metricCol);
114
113
  }
115
114
 
115
+ if (this.hasLonghornSchema) {
116
+ const storageHeader = {
117
+ name: 'storage',
118
+ labelKey: 'tableHeaders.storage',
119
+ value: 'id',
120
+ width: '230',
121
+ formatter: 'HarvesterStorageUsed',
122
+ formatterOpts: { showReserved: true },
123
+ };
124
+
125
+ out.splice(-1, 0, storageHeader);
126
+ }
127
+
116
128
  out.push(AGE);
117
129
 
118
130
  return out;
@@ -1,5 +1,5 @@
1
1
  <script>
2
- import Banner from '@shell/components/Banner';
2
+ import { Banner } from '@components/Banner';
3
3
  import Loading from '@shell/components/Loading';
4
4
  import MessageLink from '@shell/components/MessageLink';
5
5
  import ResourceTable from '@shell/components/ResourceTable';
@@ -1,6 +1,6 @@
1
1
  <script>
2
2
  import { mapGetters } from 'vuex';
3
- import Banner from '@shell/components/Banner';
3
+ import { Banner } from '@components/Banner';
4
4
  import Loading from '@shell/components/Loading';
5
5
  import { DEV } from '@shell/store/prefs';
6
6
  import { HCI, MANAGEMENT } from '@shell/config/types';
@@ -1,5 +1,5 @@
1
1
  <script>
2
- import Banner from '@shell/components/Banner';
2
+ import { Banner } from '@components/Banner';
3
3
  import Loading from '@shell/components/Loading';
4
4
  import MessageLink from '@shell/components/MessageLink';
5
5
  import Masthead from '@shell/components/ResourceList/Masthead';
@@ -1,6 +1,8 @@
1
1
  <script>
2
2
  import ResourceTable from '@shell/components/ResourceTable';
3
- import Banner from '@shell/components/Banner';
3
+ import { Banner } from '@components/Banner';
4
+ import FilterLabel from '@shell/components/FilterLabel';
5
+ import { defaultTableSortGenerationFn } from '@shell/components/ResourceTable.vue';
4
6
 
5
7
  export default {
6
8
  name: 'ListHarvesterImage',
@@ -8,6 +10,7 @@ export default {
8
10
  components: {
9
11
  ResourceTable,
10
12
  Banner,
13
+ FilterLabel
11
14
  },
12
15
 
13
16
  props: {
@@ -21,11 +24,36 @@ export default {
21
24
  },
22
25
  },
23
26
 
27
+ data() {
28
+ return {
29
+ searchLabels: [],
30
+ filterRows: []
31
+ };
32
+ },
33
+
24
34
  computed: {
25
35
  uploadingImages() {
26
36
  return this.$store.getters['harvester-common/uploadingImages'] || [];
27
37
  },
28
38
  },
39
+
40
+ methods: {
41
+ changeRows(filterRows, searchLabels) {
42
+ this.$set(this, 'filterRows', filterRows);
43
+ this.$set(this, 'searchLabels', searchLabels);
44
+ },
45
+
46
+ sortGenerationFn() {
47
+ let base = defaultTableSortGenerationFn(this.schema, this.$store);
48
+
49
+ this.searchLabels.map((label) => {
50
+ base += label.key;
51
+ base += label.value;
52
+ });
53
+
54
+ return base;
55
+ },
56
+ }
29
57
  };
30
58
  </script>
31
59
 
@@ -38,10 +66,15 @@ export default {
38
66
  />
39
67
  <ResourceTable
40
68
  v-bind="$attrs"
41
- :rows="rows"
69
+ :rows="filterRows"
42
70
  :schema="schema"
71
+ :sort-generation-fn="sortGenerationFn"
43
72
  key-field="_key"
44
73
  v-on="$listeners"
45
- />
74
+ >
75
+ <template #more-header-middle>
76
+ <FilterLabel ref="filterLabel" :rows="rows" @changeRows="changeRows" />
77
+ </template>
78
+ </ResourceTable>
46
79
  </div>
47
80
  </template>
@@ -87,10 +87,6 @@ export default {
87
87
 
88
88
  templateResource(group) {
89
89
  return group?.rows?.[0].template;
90
- },
91
-
92
- isDefaultVersion(row) {
93
- return row.defaultVersion === row?.status?.version;
94
90
  }
95
91
  },
96
92
  };
@@ -131,7 +127,7 @@ export default {
131
127
  </template>
132
128
 
133
129
  <template #col:defaultVersion="{row}">
134
- <td v-if="isDefaultVersion(row)">
130
+ <td v-if="row.isDefaultVersion">
135
131
  <i class="icon icon-lg icon-checkmark" />
136
132
  </td>
137
133
  <td v-else></td>
@@ -2,7 +2,7 @@
2
2
  import Loading from '@shell/components/Loading';
3
3
  import ResourceTable from '@shell/components/ResourceTable';
4
4
  import Masthead from '@shell/components/ResourceList/Masthead';
5
- import Banner from '@shell/components/Banner';
5
+ import { Banner } from '@components/Banner';
6
6
  import { HELM } from '@shell/config/types';
7
7
 
8
8
  export default {
@@ -176,6 +176,10 @@ export default {
176
176
  }
177
177
 
178
178
  .name-console {
179
+ display: flex;
180
+ align-items: center;
181
+ justify-content: space-around;
182
+
179
183
  span {
180
184
  line-height: 26px;
181
185
  width:160px;
@@ -185,7 +189,5 @@ export default {
185
189
  -o-text-overflow:ellipsis;
186
190
  }
187
191
 
188
- display: flex;
189
- justify-content: space-around
190
192
  }
191
193
  </style>
@@ -1,11 +1,11 @@
1
1
  <script>
2
2
  import { mapState, mapGetters } from 'vuex';
3
3
  import AsyncButton from '@shell/components/AsyncButton';
4
- import Card from '@shell/components/Card';
4
+ import { Card } from '@components/Card';
5
5
  import ResourceTable from '@shell/components/ResourceTable';
6
6
  import Loading from '@shell/components/Loading';
7
- import Banner from '@shell/components/Banner';
8
- import LabeledInput from '@shell/components/form/LabeledInput';
7
+ import { Banner } from '@components/Banner';
8
+ import { LabeledInput } from '@components/Form/LabeledInput';
9
9
  import { MANAGEMENT } from '@shell/config/types';
10
10
  import { SETTING } from '@shell/config/settings';
11
11
 
@@ -2,7 +2,7 @@
2
2
  import { mapGetters } from 'vuex';
3
3
  import { MANAGEMENT } from '@shell/config/types';
4
4
  import { ALLOWED_SETTINGS } from '@shell/config/settings';
5
- import Banner from '@shell/components/Banner';
5
+ import { Banner } from '@components/Banner';
6
6
  import Loading from '@shell/components/Loading';
7
7
  import { DEV } from '@shell/store/prefs';
8
8
 
@@ -27,7 +27,7 @@ export default {
27
27
  const setting = settingsMap[id];
28
28
 
29
29
  if ( !setting ) {
30
- return;
30
+ continue;
31
31
  }
32
32
 
33
33
  const readonly = !!ALLOWED_SETTINGS[id].readOnly;
@@ -1,7 +1,7 @@
1
1
  <script>
2
2
  import ResourceTable from '@shell/components/ResourceTable';
3
3
  import Loading from '@shell/components/Loading';
4
- import Banner from '@shell/components/Banner';
4
+ import { Banner } from '@components/Banner';
5
5
  import { MONITORING } from '@shell/config/types';
6
6
 
7
7
  export default {
@@ -22,7 +22,9 @@ export default {
22
22
  filterRow() {
23
23
  if (this.isVirtualCluster) {
24
24
  return this.rows.filter( (N) => {
25
- return !N.isSystem && !N.isFleetManaged;
25
+ const isSettingSystemNamespace = this.$store.getters['systemNamespaces'].includes(N.metadata.name);
26
+
27
+ return !N.isSystem && !N.isFleetManaged && !isSettingSystemNamespace;
26
28
  });
27
29
  } else {
28
30
  return this.rows;
package/list/node.vue CHANGED
@@ -2,7 +2,7 @@
2
2
  import ResourceTable from '@shell/components/ResourceTable';
3
3
  import Loading from '@shell/components/Loading';
4
4
  import Tag from '@shell/components/Tag';
5
- import Banner from '@shell/components/Banner';
5
+ import { Banner } from '@components/Banner';
6
6
  import {
7
7
  STATE, NAME, ROLES, VERSION, INTERNAL_EXTERNAL_IP, CPU, RAM, PODS, AGE, KUBE_NODE_OS
8
8
  } from '@shell/config/table-headers';
@@ -54,8 +54,8 @@ export default {
54
54
  }
55
55
 
56
56
  if (this.canViewPods) {
57
- // Used for running pods metrics
58
- hash.pods = this.$store.dispatch('cluster/findAll', { type: POD });
57
+ // Used for running pods metrics - we don't need to block on this to show the list of nodes
58
+ this.$store.dispatch('cluster/findAll', { type: POD });
59
59
  }
60
60
 
61
61
  const res = await allHash(hash);
@@ -70,6 +70,13 @@ export default {
70
70
  };
71
71
  },
72
72
 
73
+ beforeDestroy() {
74
+ // Stop watching pods, nodes and node metrics
75
+ this.$store.dispatch('cluster/forgetType', POD);
76
+ this.$store.dispatch('cluster/forgetType', NODE);
77
+ this.$store.dispatch('cluster/forgetType', METRIC.NODE);
78
+ },
79
+
73
80
  computed: {
74
81
  hasWindowsNodes() {
75
82
  return (this.kubeNodes || []).some(node => node.status.nodeInfo.operatingSystem === 'windows');
@@ -0,0 +1,42 @@
1
+ <script>
2
+ import ResourceTable from '@shell/components/ResourceTable';
3
+ import { STORAGE_CLASS } from '@shell/config/types';
4
+
5
+ export default {
6
+ name: 'ListPersistentVolumeClaim',
7
+ components: { ResourceTable },
8
+
9
+ props: {
10
+ resource: {
11
+ type: String,
12
+ required: true,
13
+ },
14
+
15
+ schema: {
16
+ type: Object,
17
+ required: true,
18
+ },
19
+ },
20
+
21
+ async fetch() {
22
+ const inStore = this.$store.getters['currentStore']();
23
+
24
+ // Fetch storage classes so we can determine if a PVC can be expanded
25
+ this.$store.dispatch(`${ inStore }/findAll`, { type: STORAGE_CLASS });
26
+
27
+ this.rows = await this.$store.dispatch(`${ inStore }/findAll`, { type: this.resource });
28
+ },
29
+
30
+ data() {
31
+ return { rows: [] };
32
+ }
33
+ };
34
+ </script>
35
+
36
+ <template>
37
+ <ResourceTable
38
+ :loading="$fetchState.pending"
39
+ :schema="schema"
40
+ :rows="rows"
41
+ />
42
+ </template>
@@ -1,9 +1,9 @@
1
1
  <script>
2
- import Banner from '@shell/components/Banner';
2
+ import { Banner } from '@components/Banner';
3
3
  import ResourceTable from '@shell/components/ResourceTable';
4
4
  import Masthead from '@shell/components/ResourceList/Masthead';
5
5
  import { allHash } from '@shell/utils/promise';
6
- import { CAPI, MANAGEMENT, SNAPSHOT } from '@shell/config/types';
6
+ import { CAPI, MANAGEMENT, SNAPSHOT, NORMAN } from '@shell/config/types';
7
7
  import { MODE, _IMPORT } from '@shell/config/query-params';
8
8
  import { filterOnlyKubernetesClusters, filterHiddenLocalCluster } from '@shell/utils/cluster';
9
9
  import { mapFeature, HARVESTER as HARVESTER_FEATURE } from '@shell/store/features';
@@ -16,8 +16,9 @@ export default {
16
16
 
17
17
  async fetch() {
18
18
  const hash = {
19
- mgmtClusters: this.$store.dispatch('management/findAll', { type: MANAGEMENT.CLUSTER }),
20
- rancherClusters: this.$store.dispatch('management/findAll', { type: CAPI.RANCHER_CLUSTER }),
19
+ normanClusters: this.$store.dispatch('rancher/findAll', { type: NORMAN.CLUSTER }),
20
+ mgmtClusters: this.$store.dispatch('management/findAll', { type: MANAGEMENT.CLUSTER }),
21
+ rancherClusters: this.$store.dispatch('management/findAll', { type: CAPI.RANCHER_CLUSTER }),
21
22
  };
22
23
 
23
24
  if ( this.$store.getters['management/canList'](SNAPSHOT) ) {
@@ -122,39 +123,40 @@ export default {
122
123
  :schema="schema"
123
124
  :resource="resource"
124
125
  :create-location="createLocation"
126
+ component-testid="cluster-manager-list"
125
127
  >
126
128
  <template v-if="canImport" slot="extraActions">
127
129
  <n-link
128
130
  :to="importLocation"
129
131
  class="btn role-primary"
132
+ data-testid="cluster-manager-list-import"
130
133
  >
131
134
  {{ t('cluster.importAction') }}
132
135
  </n-link>
133
136
  </template>
134
137
  </Masthead>
135
138
 
136
- <ResourceTable :schema="schema" :rows="rows" :namespaced="false">
137
- <template #cell:provider="{row}">
138
- <template v-if="row.machineProvider">
139
- {{ row.machineProviderDisplay }}
140
- <div class="text-muted">
141
- {{ row.provisionerDisplay }}
142
- </div>
143
- </template>
144
- <template v-else>
145
- {{ row.provisionerDisplay }}
146
- </template>
147
- </template>
139
+ <ResourceTable :schema="schema" :rows="rows" :namespaced="false" :loading="$fetchState.pending">
148
140
  <template #cell:summary="{row}">
149
141
  <span v-if="!row.stateParts.length">{{ row.nodes.length }}</span>
150
142
  </template>
151
143
  <template #cell:explorer="{row}">
152
144
  <span v-if="row.mgmt && row.mgmt.isHarvester"></span>
153
- <n-link v-else-if="row.mgmt && row.mgmt.isReady" class="btn btn-sm role-primary" :to="{name: 'c-cluster', params: {cluster: row.mgmt.id}}">
154
- Explore
145
+ <n-link
146
+ v-else-if="row.mgmt && row.mgmt.isReady"
147
+ data-testid="cluster-manager-list-explore-management"
148
+ class="btn btn-sm role-secondary"
149
+ :to="{name: 'c-cluster', params: {cluster: row.mgmt.id}}"
150
+ >
151
+ {{ t('cluster.exploreHarvester') }}
155
152
  </n-link>
156
- <button v-else :disabled="true" class="btn btn-sm role-primary">
157
- Explore
153
+ <button
154
+ v-else
155
+ data-testid="cluster-manager-list-explore"
156
+ :disabled="true"
157
+ class="btn btn-sm role-secondary"
158
+ >
159
+ {{ t('cluster.explore') }}
158
160
  </button>
159
161
  </template>
160
162
  </ResourceTable>
package/list/workload.vue CHANGED
@@ -1,6 +1,7 @@
1
1
  <script>
2
2
  import ResourceTable from '@shell/components/ResourceTable';
3
3
  import { WORKLOAD_TYPES, SCHEMA, NODE, POD } from '@shell/config/types';
4
+ import ResourceFetch from '@shell/mixins/resource-fetch';
4
5
 
5
6
  const schema = {
6
7
  id: 'workload',
@@ -15,6 +16,7 @@ const schema = {
15
16
  export default {
16
17
  name: 'ListWorkload',
17
18
  components: { ResourceTable },
19
+ mixins: [ResourceFetch],
18
20
 
19
21
  async fetch() {
20
22
  try {
@@ -30,19 +32,23 @@ export default {
30
32
  this.loadHeathResources();
31
33
 
32
34
  if ( this.allTypes ) {
33
- resources = await Promise.all(Object.values(WORKLOAD_TYPES).map((type) => {
34
- // You may not have RBAC to see some of the types
35
- if ( !this.$store.getters['cluster/schemaFor'](type) ) {
36
- return null;
35
+ const allowedResources = [];
36
+
37
+ Object.values(WORKLOAD_TYPES).forEach((type) => {
38
+ // You may not have RBAC to see some of the types
39
+ if (this.$store.getters['cluster/schemaFor'](type) ) {
40
+ allowedResources.push(type);
37
41
  }
42
+ });
38
43
 
39
- return this.$store.dispatch('cluster/findAll', { type });
44
+ resources = await Promise.all(allowedResources.map((allowed) => {
45
+ return this.$fetchType(allowed, allowedResources);
40
46
  }));
41
47
  } else {
42
48
  const type = this.$route.params.resource;
43
49
 
44
50
  if ( this.$store.getters['cluster/schemaFor'](type) ) {
45
- const resource = await this.$store.dispatch('cluster/findAll', { type });
51
+ const resource = await this.$fetchType(type);
46
52
 
47
53
  resources = [resource];
48
54
  }
@@ -89,6 +95,25 @@ export default {
89
95
  },
90
96
  },
91
97
 
98
+ // All of the resources that we will load that we need for the loading indicator
99
+ $loadingResources(route, store) {
100
+ const allTypes = route.params.resource === schema.id;
101
+
102
+ const allowedResources = [];
103
+
104
+ Object.values(WORKLOAD_TYPES).forEach((type) => {
105
+ // You may not have RBAC to see some of the types
106
+ if (store.getters['cluster/schemaFor'](type) ) {
107
+ allowedResources.push(type);
108
+ }
109
+ });
110
+
111
+ return {
112
+ loadResources: allTypes ? allowedResources : [route.params.resource],
113
+ loadIndeterminate: allTypes,
114
+ };
115
+ },
116
+
92
117
  methods: {
93
118
  loadHeathResources() {
94
119
  // Fetch these in the background to populate workload health
@@ -1,13 +1,13 @@
1
1
  <script>
2
2
  import Loading from '@shell/components/Loading';
3
- import Banner from '@shell/components/Banner';
3
+ import { Banner } from '@components/Banner';
4
4
  import CreateEditView from '@shell/mixins/create-edit-view';
5
5
  import LabeledSelect from '@shell/components/form/LabeledSelect';
6
- import LabeledInput from '@shell/components/form/LabeledInput';
6
+ import { LabeledInput } from '@components/Form/LabeledInput';
7
7
  import KeyValue from '@shell/components/form/KeyValue';
8
8
  import UnitInput from '@shell/components/form/UnitInput';
9
- import RadioGroup from '@shell/components/form/RadioGroup';
10
- import Checkbox from '@shell/components/form/Checkbox';
9
+ import { RadioGroup } from '@components/Form/Radio';
10
+ import { Checkbox } from '@components/Form/Checkbox';
11
11
  import { NORMAN } from '@shell/config/types';
12
12
  import { allHash } from '@shell/utils/promise';
13
13
  import { addObject, addObjects, findBy } from '@shell/utils/array';
@@ -212,8 +212,11 @@ export default {
212
212
  const subnetsByVpc = {};
213
213
 
214
214
  for ( const obj of this.vpcInfo.Vpcs ) {
215
+ const name = obj.Tags && obj.Tags?.length ? obj.Tags.find(t => t.Key === 'Name')?.Value : null;
216
+
215
217
  vpcs.push({
216
- label: `${ obj.VpcId } (${ obj.CidrBlock })`,
218
+ label: name || obj.VpcId,
219
+ subLabel: name ? obj.VpcId : obj.CidrBlock,
217
220
  isDefault: obj.IsDefault || false,
218
221
  kind: 'vpc',
219
222
  value: obj.VpcId,
@@ -234,8 +237,11 @@ export default {
234
237
  subnetsByVpc[obj.VpcId] = entry;
235
238
  }
236
239
 
240
+ const name = obj.Tags && obj.Tags?.length ? obj.Tags.find(t => t.Key === 'Name')?.Value : null;
241
+
237
242
  entry.push({
238
- label: `${ obj.SubnetId } (${ obj.CidrBlock } - ${ obj.AvailableIpAddressCount } available)`,
243
+ label: name || obj.SubnetId,
244
+ subLabel: name ? obj.SubnetId : obj.CidrBlock,
239
245
  kind: 'subnet',
240
246
  isDefault: obj.DefaultForAz || false,
241
247
  value: obj.SubnetId,
@@ -468,15 +474,13 @@ export default {
468
474
  :disabled="disabled"
469
475
  :placeholder="t('cluster.machineConfig.amazonEc2.selectedNetwork.placeholder')"
470
476
  :label="t('cluster.machineConfig.amazonEc2.selectedNetwork.label')"
477
+ option-key="value"
471
478
  @input="updateNetwork($event)"
472
479
  >
473
480
  <template v-slot:option="opt">
474
- <template v-if="opt.kind === 'vpc'">
475
- <b>{{ opt.label }}</b>
476
- </template>
477
- <template v-else>
478
- <span class="pl-10">{{ opt.label }}</span>
479
- </template>
481
+ <div :class="{'vpc': opt.kind === 'vpc', 'vpc-subnet': opt.kind !== 'vpc'}">
482
+ <span class="vpc-name">{{ opt.label }}</span><span class="vpc-info">{{ opt.subLabel }}</span>
483
+ </div>
480
484
  </template>
481
485
  </LabeledSelect>
482
486
  </div>
@@ -662,3 +666,24 @@ export default {
662
666
  </template>
663
667
  </div>
664
668
  </template>
669
+ <style scoped lang="scss">
670
+ .vpc, .vpc-subnet {
671
+ display: flex;
672
+ line-height: 30px;
673
+
674
+ .vpc-name {
675
+ font-weight: bold;
676
+ flex: 1;
677
+ }
678
+
679
+ .vpc-info {
680
+ font-size: 12px;
681
+ opacity: 0.7;
682
+ }
683
+ }
684
+
685
+ .vpc-subnet .vpc-name {
686
+ font-weight: normal;
687
+ padding-left: 15px;
688
+ }
689
+ </style>