@rancher/shell 0.2.5 → 0.3.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 (635) hide show
  1. package/assets/styles/global/_button.scss +5 -1
  2. package/assets/styles/global/_columns.scss +4 -0
  3. package/assets/styles/global/_layout.scss +1 -2
  4. package/assets/styles/global/_select.scss +1 -4
  5. package/assets/styles/themes/_dark.scss +8 -4
  6. package/assets/styles/themes/_light.scss +9 -3
  7. package/assets/styles/themes/_suse.scss +1 -1
  8. package/assets/styles/vendor/vue-select.scss +4 -3
  9. package/assets/translations/en-us.yaml +682 -74
  10. package/assets/translations/zh-hans.yaml +554 -170
  11. package/chart/istio.vue +1 -1
  12. package/chart/monitoring/grafana/index.vue +1 -1
  13. package/chart/monitoring/index.vue +1 -1
  14. package/chart/monitoring/prometheus/index.vue +4 -4
  15. package/chart/monitoring/steps/uninstall-v1.vue +2 -2
  16. package/cloud-credential/azure.vue +23 -0
  17. package/cloud-credential/harvester.vue +25 -62
  18. package/cloud-credential/pnap.vue +80 -0
  19. package/components/AdvancedSection.vue +9 -2
  20. package/components/Alert.vue +2 -2
  21. package/components/AlertTable.vue +1 -1
  22. package/components/AssignTo.vue +1 -1
  23. package/components/AsyncButton.vue +2 -2
  24. package/components/BrandImage.vue +1 -1
  25. package/components/ButtonDropdown.vue +0 -2
  26. package/components/ButtonGroup.vue +2 -1
  27. package/components/ClusterProviderIcon.vue +2 -2
  28. package/components/Collapse.vue +6 -2
  29. package/components/CollapsibleCard.vue +2 -3
  30. package/components/ConsumptionGauge.vue +4 -4
  31. package/components/ContainerResourceLimit.vue +1 -1
  32. package/components/CountBox.vue +1 -1
  33. package/components/CountGauge.vue +1 -1
  34. package/components/CruResource.vue +43 -5
  35. package/components/DashboardMetrics.vue +2 -2
  36. package/components/DetailTop.vue +58 -3
  37. package/components/DisableAuthProviderModal.vue +106 -0
  38. package/components/DraggableZone.vue +181 -0
  39. package/components/ExplorerMembers.vue +253 -30
  40. package/components/ExplorerProjectsNamespaces.vue +82 -38
  41. package/components/FixedBanner.vue +6 -6
  42. package/components/GlobalRoleBindings.vue +6 -6
  43. package/components/GradientBox.vue +2 -2
  44. package/components/GrowlManager.vue +3 -3
  45. package/components/IconMessage.vue +4 -4
  46. package/components/IconOrSvg.vue +149 -0
  47. package/components/Import.vue +5 -5
  48. package/components/InputOrDisplay.vue +1 -1
  49. package/components/KeyValueView.vue +1 -1
  50. package/components/LabelValue.vue +1 -1
  51. package/components/LogItem.vue +69 -0
  52. package/components/ModalWithCard.vue +1 -1
  53. package/components/MoveModal.vue +1 -1
  54. package/components/PercentageBar.vue +2 -2
  55. package/components/PodSecurityAdmission.vue +302 -0
  56. package/components/PromptChangePassword.vue +1 -1
  57. package/components/PromptModal.vue +2 -1
  58. package/components/PromptRemove.vue +2 -2
  59. package/components/PromptRestore.vue +13 -13
  60. package/components/Questions/Question.js +1 -1
  61. package/components/ResourceCancelModal.vue +3 -3
  62. package/components/ResourceDetail/Masthead.vue +55 -3
  63. package/components/ResourceDetail/index.vue +12 -5
  64. package/components/ResourceList/Masthead.vue +12 -2
  65. package/components/ResourceList/ResourceLoadingIndicator.vue +12 -2
  66. package/components/ResourceList/index.vue +53 -12
  67. package/components/ResourceList/resource-list.config.js +7 -0
  68. package/components/ResourceSummary.vue +4 -4
  69. package/components/ResourceTable.vue +31 -6
  70. package/components/RoleBindings.vue +19 -19
  71. package/components/SimpleBox.vue +6 -2
  72. package/components/SingleClusterInfo.vue +5 -5
  73. package/components/SortableTable/THead.vue +20 -6
  74. package/components/SortableTable/actions.js +4 -2
  75. package/components/SortableTable/index.vue +30 -19
  76. package/components/SortableTable/selection.js +2 -2
  77. package/components/Tabbed/index.vue +20 -15
  78. package/components/TableSparkLine.vue +1 -1
  79. package/components/TypeDescription.vue +1 -1
  80. package/components/Wizard.vue +1 -1
  81. package/components/YamlEditor.vue +6 -6
  82. package/components/__tests__/ApplicationCard.test.ts +27 -0
  83. package/components/__tests__/AsyncButton.test.ts +140 -0
  84. package/components/__tests__/BackLink.test.ts +33 -0
  85. package/components/__tests__/ButtonGroup.test.ts +124 -0
  86. package/components/__tests__/ClusterBadge.test.ts +32 -0
  87. package/components/__tests__/Collapse.spec.ts +44 -0
  88. package/components/__tests__/CollapsibleCard.test.ts +64 -0
  89. package/components/__tests__/ConsumptionGauge.test.ts +88 -0
  90. package/components/__tests__/CruResource.test.ts +6 -5
  91. package/components/__tests__/FixedBanner.test.ts +129 -0
  92. package/components/__tests__/GrowlManager.test.ts +147 -0
  93. package/components/__tests__/NamespaceFilter.test.ts +221 -0
  94. package/components/__tests__/PercentageBar.test.ts +32 -0
  95. package/components/__tests__/PodSecurityAdmission.test.ts +398 -0
  96. package/components/__tests__/SimpleBox.spec.ts +28 -0
  97. package/components/auth/AuthBanner.vue +20 -10
  98. package/components/auth/RoleDetailEdit.vue +41 -30
  99. package/components/auth/SelectPrincipal.vue +45 -5
  100. package/components/auth/login/ldap.vue +3 -0
  101. package/components/cards/ApplicationCard.vue +10 -5
  102. package/components/fleet/FleetBundleResources.vue +8 -8
  103. package/components/fleet/FleetClusters.vue +10 -10
  104. package/components/fleet/FleetRepos.vue +5 -5
  105. package/components/fleet/FleetResources.vue +6 -6
  106. package/components/fleet/FleetSummary.vue +5 -5
  107. package/components/fleet/ResourcesSummary.vue +1 -1
  108. package/components/form/ArrayList.vue +3 -35
  109. package/components/form/ArrayListGrouped.vue +14 -5
  110. package/components/form/ArrayListSelect.vue +8 -8
  111. package/components/form/BannerSettings.vue +6 -6
  112. package/components/form/ChangePassword.vue +3 -3
  113. package/components/form/Error.vue +10 -2
  114. package/components/form/FileSelector.vue +3 -3
  115. package/components/form/Footer.vue +1 -1
  116. package/components/form/GithubPicker.vue +4 -4
  117. package/components/form/KeyValue.vue +41 -9
  118. package/components/form/LabeledSelect.vue +5 -2
  119. package/components/form/Labels.vue +46 -16
  120. package/components/form/MatchExpressions.vue +1 -1
  121. package/components/form/Members/ClusterPermissionsEditor.vue +28 -28
  122. package/components/form/Members/MembershipEditor.vue +14 -14
  123. package/components/form/NameNsDescription.vue +1 -1
  124. package/components/form/NodeAffinity.vue +1 -1
  125. package/components/form/NodeScheduling.vue +1 -1
  126. package/components/form/Password.vue +3 -3
  127. package/components/form/PodAffinity.vue +1 -1
  128. package/components/form/Probe.vue +3 -3
  129. package/components/form/ProjectMemberEditor.vue +1 -1
  130. package/components/form/ResourceQuota/Project.vue +6 -6
  131. package/components/form/ResourceQuota/shared.js +12 -12
  132. package/components/form/ResourceTabs/index.vue +1 -6
  133. package/components/form/SecretSelector.vue +1 -1
  134. package/components/form/Security.vue +8 -7
  135. package/components/form/Select.vue +7 -2
  136. package/components/form/SelectOrCreateAuthSecret.vue +22 -29
  137. package/components/form/ServicePorts.vue +8 -0
  138. package/components/form/SimpleSecretSelector.vue +1 -1
  139. package/components/form/Taints.vue +1 -1
  140. package/components/form/UnitInput.vue +7 -7
  141. package/components/form/ValueFromResource.vue +1 -1
  142. package/components/form/WorkloadPorts.vue +8 -2
  143. package/components/form/__tests__/ArrayList.test.ts +74 -0
  144. package/components/form/__tests__/ArrayListGrouped.test.ts +6 -4
  145. package/components/formatter/AppSummaryGraph.vue +4 -4
  146. package/components/formatter/BadgeStateFormatter.vue +2 -2
  147. package/components/formatter/Checked.vue +2 -2
  148. package/components/formatter/ClusterLink.vue +8 -3
  149. package/components/formatter/Date.vue +1 -1
  150. package/components/formatter/DelayedValue.vue +1 -1
  151. package/components/formatter/Endpoints.vue +1 -1
  152. package/components/formatter/FleetSummaryGraph.vue +4 -4
  153. package/components/formatter/IconIsDefault.vue +3 -3
  154. package/components/formatter/IconText.vue +4 -4
  155. package/components/formatter/ImagePercentageBar.vue +4 -4
  156. package/components/formatter/IngressFullPath.vue +1 -1
  157. package/components/formatter/InternalExternalIP.vue +11 -8
  158. package/components/formatter/LinkDetail.vue +3 -3
  159. package/components/formatter/List.vue +1 -1
  160. package/components/formatter/ListLink.vue +1 -1
  161. package/components/formatter/ListLinkDetail.vue +1 -1
  162. package/components/formatter/LiveDate.vue +3 -3
  163. package/components/formatter/LiveDuration.vue +78 -0
  164. package/components/formatter/LivePodRestarts.vue +1 -1
  165. package/components/formatter/Number.vue +1 -1
  166. package/components/formatter/Percentage.vue +2 -2
  167. package/components/formatter/PercentageBar.vue +3 -3
  168. package/components/formatter/PodImages.vue +1 -1
  169. package/components/formatter/Principal.vue +1 -1
  170. package/components/formatter/PrincipalGroupBindings.vue +2 -2
  171. package/components/formatter/QualityText.vue +1 -1
  172. package/components/formatter/ReceiverIcons.vue +2 -2
  173. package/components/formatter/Scale.vue +1 -1
  174. package/components/formatter/ScanResult.vue +1 -1
  175. package/components/formatter/SecretData.vue +1 -1
  176. package/components/formatter/ServiceType.vue +1 -1
  177. package/components/formatter/Shortened.vue +1 -1
  178. package/components/formatter/VerticalScroll.vue +2 -2
  179. package/components/formatter/VirtualServiceGateways.vue +3 -3
  180. package/components/formatter/Weight.vue +2 -2
  181. package/components/formatter/WorkloadDetailEndpoints.vue +1 -1
  182. package/components/formatter/WorkloadHealthScale.vue +7 -5
  183. package/components/formatter/__tests__/Date.test.ts +60 -0
  184. package/components/formatter/__tests__/LinkDetail.test.ts +72 -0
  185. package/components/formatter/__tests__/LiveDate.test.ts +84 -0
  186. package/components/formatter/__tests__/Si.test.ts +35 -0
  187. package/components/graph/LinePlot.vue +1 -1
  188. package/components/graph/ProgressArc.vue +5 -5
  189. package/components/nav/GlobalLoading.vue +1 -1
  190. package/components/nav/Header.vue +6 -4
  191. package/components/nav/Jump.vue +3 -3
  192. package/components/nav/NamespaceFilter.vue +200 -68
  193. package/components/nav/TopLevelMenu.vue +24 -21
  194. package/components/nav/Type.vue +1 -1
  195. package/components/nav/WindowManager/ChartReadme.vue +1 -1
  196. package/components/nav/WindowManager/ContainerLogs.vue +84 -127
  197. package/components/nav/WindowManager/ContainerShell.vue +28 -7
  198. package/components/nav/WindowManager/KubectlShell.vue +6 -6
  199. package/components/nav/WindowManager/MachineSsh.vue +1 -1
  200. package/components/nav/WindowManager/Window.vue +2 -0
  201. package/components/nav/WindowManager/index.vue +206 -25
  202. package/config/elemental-types.js +9 -0
  203. package/config/features.js +2 -0
  204. package/config/home-links.js +4 -1
  205. package/config/labels-annotations.js +19 -19
  206. package/config/pod-security-admission.ts +82 -0
  207. package/config/product/apps.js +5 -5
  208. package/config/product/auth.js +22 -21
  209. package/config/product/cis.js +24 -24
  210. package/config/product/explorer.js +25 -24
  211. package/config/product/fleet.js +7 -7
  212. package/config/product/gatekeeper.js +7 -7
  213. package/config/product/istio.js +7 -7
  214. package/config/product/legacy.js +21 -21
  215. package/config/product/logging.js +90 -90
  216. package/config/product/manager.js +19 -15
  217. package/config/product/monitoring.js +36 -36
  218. package/config/product/multi-cluster-apps.js +24 -24
  219. package/config/product/settings.js +42 -42
  220. package/config/secret.js +0 -1
  221. package/config/settings.ts +39 -22
  222. package/config/table-headers.js +70 -52
  223. package/config/types.js +11 -8
  224. package/config/uiplugins.js +4 -4
  225. package/content/docs/zh-hans/getting-started.md +113 -137
  226. package/content/docs/zh-hans/whats-new.md +8 -46
  227. package/creators/app/app.package.json +4 -1
  228. package/creators/app/{.eslintignore → files/.eslintignore} +0 -0
  229. package/creators/app/{.eslintrc.js → files/.eslintrc.js} +0 -0
  230. package/creators/app/{.vscode → files/.vscode}/settings.json +0 -0
  231. package/creators/app/{babel.config.js → files/babel.config.js} +0 -0
  232. package/creators/app/{nuxt.config.js → files/nuxt.config.js} +0 -0
  233. package/creators/app/{tsconfig.json → files/tsconfig.json} +2 -1
  234. package/creators/app/init +16 -17
  235. package/creators/app/package.json +7 -1
  236. package/creators/pkg/{babel.config.js → files/babel.config.js} +0 -0
  237. package/creators/pkg/{index.ts → files/index.ts} +0 -0
  238. package/creators/pkg/{tsconfig.json → files/tsconfig.json} +13 -12
  239. package/creators/pkg/{vue.config.js → files/vue.config.js} +0 -0
  240. package/creators/pkg/init +1 -1
  241. package/creators/pkg/package.json +2 -2
  242. package/creators/update/init +56 -0
  243. package/creators/update/package.json +20 -0
  244. package/creators/update/upgrade +56 -0
  245. package/detail/catalog.cattle.io.app.vue +1 -1
  246. package/detail/cis.cattle.io.clusterscan.vue +6 -6
  247. package/detail/configmap.vue +1 -1
  248. package/detail/constraints.gatekeeper.sh.constraint.vue +1 -1
  249. package/detail/fleet.cattle.io.bundle.vue +5 -5
  250. package/detail/fleet.cattle.io.gitrepo.vue +5 -5
  251. package/detail/helm.cattle.io.projecthelmchart.vue +1 -1
  252. package/detail/management.cattle.io.user.vue +3 -3
  253. package/detail/namespace.vue +13 -13
  254. package/detail/node.vue +2 -2
  255. package/detail/pod.vue +2 -2
  256. package/detail/provisioning.cattle.io.cluster.vue +47 -10
  257. package/detail/secret.vue +2 -2
  258. package/detail/service.vue +2 -9
  259. package/detail/workload/index.vue +1 -2
  260. package/dialog/AddClusterMemberDialog.vue +23 -29
  261. package/dialog/AddCustomBadgeDialog.vue +4 -4
  262. package/dialog/AddProjectMemberDialog.vue +81 -30
  263. package/dialog/AddonConfigConfirmationDialog.vue +1 -1
  264. package/dialog/DiagnosticTimingsDialog.vue +9 -8
  265. package/dialog/DrainNode.vue +56 -60
  266. package/dialog/ForceMachineRemoveDialog.vue +6 -8
  267. package/dialog/GenericPrompt.vue +16 -21
  268. package/dialog/RollbackWorkloadDialog.vue +22 -53
  269. package/dialog/RotateCertificatesDialog.vue +9 -11
  270. package/dialog/RotateEncryptionKeyDialog.vue +6 -10
  271. package/dialog/SaveAsRKETemplateDialog.vue +6 -14
  272. package/dialog/ScaleMachineDownDialog.vue +2 -2
  273. package/dialog/ScalePoolDownDialog.vue +121 -0
  274. package/edit/__tests__/management.cattle.io.setting.test.ts +4 -4
  275. package/edit/auth/azuread.vue +18 -18
  276. package/edit/auth/github.vue +10 -2
  277. package/edit/auth/googleoauth.vue +10 -1
  278. package/edit/auth/ldap/index.vue +14 -4
  279. package/edit/auth/oidc.vue +13 -3
  280. package/edit/auth/saml.vue +14 -4
  281. package/edit/autoscaling.horizontalpodautoscaler/external-metric.vue +2 -2
  282. package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -1
  283. package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +1 -1
  284. package/edit/autoscaling.horizontalpodautoscaler/object-metric.vue +2 -2
  285. package/edit/autoscaling.horizontalpodautoscaler/pod-metric.vue +2 -2
  286. package/edit/cis.cattle.io.clusterscan.vue +2 -2
  287. package/edit/cloudcredential.vue +3 -7
  288. package/edit/constraints.gatekeeper.sh.constraint/index.vue +1 -1
  289. package/edit/fleet.cattle.io.clustergroup.vue +3 -3
  290. package/edit/fleet.cattle.io.gitrepo.vue +9 -9
  291. package/edit/group.principal.vue +2 -2
  292. package/edit/helm.cattle.io.projecthelmchart.vue +3 -3
  293. package/edit/logging-flow/Match.vue +39 -8
  294. package/edit/logging-flow/index.vue +28 -5
  295. package/edit/logging.banzaicloud.io.output/providers/datadog.vue +1 -1
  296. package/edit/logging.banzaicloud.io.output/providers/elasticsearch.vue +1 -1
  297. package/edit/logging.banzaicloud.io.output/providers/gcs.vue +1 -1
  298. package/edit/logging.banzaicloud.io.output/providers/gelf.vue +1 -1
  299. package/edit/logging.banzaicloud.io.output/providers/kafka.vue +1 -1
  300. package/edit/logging.banzaicloud.io.output/providers/logz.vue +1 -1
  301. package/edit/logging.banzaicloud.io.output/providers/loki.vue +1 -1
  302. package/edit/logging.banzaicloud.io.output/providers/opensearch.vue +213 -0
  303. package/edit/logging.banzaicloud.io.output/providers/redis.vue +142 -0
  304. package/edit/logging.banzaicloud.io.output/providers/s3.vue +1 -1
  305. package/edit/logging.banzaicloud.io.output/providers/splunkHec.vue +1 -1
  306. package/edit/logging.banzaicloud.io.output/providers/syslog.vue +1 -1
  307. package/edit/management.cattle.io.fleetworkspace.vue +1 -1
  308. package/edit/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +107 -0
  309. package/edit/management.cattle.io.project.vue +11 -4
  310. package/edit/management.cattle.io.projectroletemplatebinding.vue +5 -5
  311. package/edit/management.cattle.io.setting.vue +6 -3
  312. package/edit/management.cattle.io.user.vue +11 -5
  313. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +33 -17
  314. package/edit/monitoring.coreos.com.alertmanagerconfig/tls.vue +1 -1
  315. package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +6 -6
  316. package/edit/monitoring.coreos.com.alertmanagerconfig/types/opsgenie.vue +5 -5
  317. package/edit/monitoring.coreos.com.alertmanagerconfig/types/pagerduty.vue +3 -3
  318. package/edit/monitoring.coreos.com.alertmanagerconfig/types/slack.vue +3 -3
  319. package/edit/monitoring.coreos.com.alertmanagerconfig/types/webhook.vue +4 -4
  320. package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +14 -6
  321. package/edit/monitoring.coreos.com.receiver/auth.vue +2 -2
  322. package/edit/monitoring.coreos.com.receiver/index.vue +1 -1
  323. package/edit/monitoring.coreos.com.receiver/types/email.vue +1 -1
  324. package/edit/monitoring.coreos.com.receiver/types/opsgenie.vue +1 -1
  325. package/edit/monitoring.coreos.com.receiver/types/pagerduty.vue +1 -1
  326. package/edit/monitoring.coreos.com.receiver/types/webhook.vue +1 -1
  327. package/edit/monitoring.coreos.com.route.vue +1 -1
  328. package/edit/namespace.vue +18 -4
  329. package/edit/networking.istio.io.destinationrule/LoadBalancer.vue +1 -1
  330. package/edit/networking.k8s.io.ingress/Certificate.vue +1 -0
  331. package/edit/networking.k8s.io.ingress/Certificates.vue +3 -3
  332. package/edit/networking.k8s.io.ingress/DefaultBackend.vue +2 -2
  333. package/edit/networking.k8s.io.ingress/IngressClass.vue +9 -7
  334. package/edit/networking.k8s.io.ingress/Rule.vue +1 -1
  335. package/edit/networking.k8s.io.ingress/RulePath.vue +17 -11
  336. package/edit/networking.k8s.io.ingress/Rules.vue +7 -7
  337. package/edit/networking.k8s.io.ingress/index.vue +8 -6
  338. package/edit/networking.k8s.io.networkpolicy/PolicyRule.vue +1 -1
  339. package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +3 -3
  340. package/edit/networking.k8s.io.networkpolicy/PolicyRules.vue +1 -1
  341. package/edit/networking.k8s.io.networkpolicy/index.vue +5 -5
  342. package/edit/persistentvolume/index.vue +30 -27
  343. package/edit/persistentvolume/plugins/awsElasticBlockStore.vue +1 -1
  344. package/edit/persistentvolume/plugins/azureDisk.vue +1 -1
  345. package/edit/persistentvolume/plugins/azureFile.vue +1 -1
  346. package/edit/persistentvolume/plugins/cephfs.vue +31 -31
  347. package/edit/persistentvolume/plugins/cinder.vue +1 -1
  348. package/edit/persistentvolume/plugins/csi.vue +104 -64
  349. package/edit/persistentvolume/plugins/fc.vue +21 -21
  350. package/edit/persistentvolume/plugins/flexVolume.vue +2 -2
  351. package/edit/persistentvolume/plugins/flocker.vue +1 -1
  352. package/edit/persistentvolume/plugins/gcePersistentDisk.vue +1 -1
  353. package/edit/persistentvolume/plugins/glusterfs.vue +1 -1
  354. package/edit/persistentvolume/plugins/hostPath.vue +1 -1
  355. package/edit/persistentvolume/plugins/iscsi.vue +47 -47
  356. package/edit/persistentvolume/plugins/local.vue +1 -1
  357. package/edit/persistentvolume/plugins/longhorn.vue +2 -2
  358. package/edit/persistentvolume/plugins/nfs.vue +1 -1
  359. package/edit/persistentvolume/plugins/photonPersistentDisk.vue +1 -1
  360. package/edit/persistentvolume/plugins/portworxVolume.vue +1 -1
  361. package/edit/persistentvolume/plugins/quobyte.vue +1 -1
  362. package/edit/persistentvolume/plugins/rbd.vue +41 -41
  363. package/edit/persistentvolume/plugins/scaleIO.vue +1 -1
  364. package/edit/persistentvolume/plugins/storageos.vue +1 -1
  365. package/edit/persistentvolume/plugins/vsphereVolume.vue +1 -1
  366. package/edit/persistentvolumeclaim.vue +78 -75
  367. package/edit/provisioning.cattle.io.cluster/DrainOptions.vue +1 -1
  368. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +12 -8
  369. package/edit/provisioning.cattle.io.cluster/RegistryConfigs.vue +10 -1
  370. package/edit/provisioning.cattle.io.cluster/RegistryMirrors.vue +87 -27
  371. package/edit/provisioning.cattle.io.cluster/S3Config.vue +1 -1
  372. package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +3 -6
  373. package/edit/provisioning.cattle.io.cluster/__tests__/CustomCommand.tests.ts +1 -1
  374. package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +93 -0
  375. package/edit/provisioning.cattle.io.cluster/import.vue +3 -3
  376. package/edit/provisioning.cattle.io.cluster/index.vue +31 -8
  377. package/edit/provisioning.cattle.io.cluster/rke2.vue +458 -164
  378. package/edit/resources.cattle.io.backup.vue +2 -2
  379. package/edit/secret/generic.vue +1 -0
  380. package/edit/secret/index.vue +3 -7
  381. package/edit/service.vue +3 -1
  382. package/edit/storage.k8s.io.storageclass/index.vue +101 -17
  383. package/edit/storage.k8s.io.storageclass/provisioners/driver.harvesterhci.io.vue +114 -0
  384. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/no-provisioner.vue +1 -1
  385. package/edit/token.vue +1 -1
  386. package/edit/ui.cattle.io.navlink.vue +8 -8
  387. package/edit/workload/Job.vue +3 -3
  388. package/edit/workload/Upgrading.vue +1 -1
  389. package/edit/workload/VolumeClaimTemplate.vue +1 -1
  390. package/edit/workload/__tests__/index.test.ts +98 -0
  391. package/edit/workload/index.vue +61 -11
  392. package/edit/workload/mixins/workload.js +128 -91
  393. package/edit/workload/storage/ContainerMountPaths.vue +1 -11
  394. package/edit/workload/storage/Mount.vue +1 -1
  395. package/edit/workload/storage/azureDisk.vue +1 -1
  396. package/edit/workload/storage/azureFile.vue +1 -1
  397. package/edit/workload/storage/csi/index.vue +1 -1
  398. package/edit/workload/storage/emptyDir.vue +88 -0
  399. package/edit/workload/storage/ephemeralVolume/index.vue +2 -2
  400. package/edit/workload/storage/gcePersistentDisk.vue +1 -1
  401. package/edit/workload/storage/hostPath.vue +1 -1
  402. package/edit/workload/storage/index.vue +8 -0
  403. package/edit/workload/storage/nfs.vue +1 -1
  404. package/edit/workload/storage/persistentVolumeClaim/index.vue +2 -2
  405. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +1 -1
  406. package/edit/workload/storage/secret.vue +1 -1
  407. package/edit/workload/storage/vsphereVolume.vue +1 -1
  408. package/layouts/default.vue +132 -58
  409. package/list/__tests__/workload.test.ts +53 -0
  410. package/list/catalog.cattle.io.app.vue +1 -0
  411. package/list/cis.cattle.io.clusterscan.vue +1 -0
  412. package/list/fleet.cattle.io.bundle.vue +5 -6
  413. package/list/fleet.cattle.io.cluster.vue +6 -3
  414. package/list/fleet.cattle.io.clusterregistrationtoken.vue +5 -6
  415. package/list/fleet.cattle.io.gitrepo.vue +5 -10
  416. package/list/group.principal.vue +8 -8
  417. package/list/helm.cattle.io.projecthelmchart.vue +2 -6
  418. package/list/logging.banzaicloud.io.clusterflow.vue +4 -1
  419. package/list/logging.banzaicloud.io.flow.vue +6 -5
  420. package/list/management.cattle.io.cluster.vue +1 -0
  421. package/list/management.cattle.io.feature.vue +4 -5
  422. package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +47 -0
  423. package/list/management.cattle.io.setting.vue +2 -2
  424. package/list/management.cattle.io.user.vue +4 -10
  425. package/list/monitoring.coreos.com.alertmanagerconfig.vue +2 -7
  426. package/list/node.vue +9 -6
  427. package/list/persistentvolume.vue +3 -3
  428. package/list/persistentvolumeclaim.vue +3 -4
  429. package/list/provisioning.cattle.io.cluster.vue +21 -22
  430. package/list/service.vue +6 -14
  431. package/list/workload.vue +43 -38
  432. package/machine-config/amazonec2.vue +1 -1
  433. package/machine-config/azure.vue +429 -60
  434. package/machine-config/pnap.vue +288 -0
  435. package/mixins/__tests__/create-edit-view.test.ts +1 -1
  436. package/mixins/auth-config.js +1 -3
  437. package/mixins/browser-tab-visibility.js +8 -14
  438. package/mixins/chart.js +15 -15
  439. package/mixins/create-edit-view/impl.js +4 -0
  440. package/mixins/create-edit-view/index.js +9 -7
  441. package/mixins/form-validation.js +1 -1
  442. package/mixins/labeled-form-element.ts +6 -6
  443. package/mixins/resource-fetch-namespaced.js +98 -0
  444. package/mixins/resource-fetch.js +82 -48
  445. package/mixins/resource-manager.js +2 -24
  446. package/models/apps.controllerrevision.js +7 -0
  447. package/models/apps.daemonset.js +18 -0
  448. package/models/apps.deployment.js +44 -0
  449. package/models/apps.replicaset.js +7 -0
  450. package/models/apps.statefulset.js +18 -0
  451. package/models/autoscaling.horizontalpodautoscaler.js +5 -5
  452. package/models/batch.cronjob.js +15 -15
  453. package/models/batch.job.js +15 -0
  454. package/models/catalog.cattle.io.app.js +6 -6
  455. package/models/catalog.cattle.io.clusterrepo.js +7 -7
  456. package/models/catalog.cattle.io.operation.js +5 -5
  457. package/models/chart.js +4 -4
  458. package/models/cis.cattle.io.clusterscan.js +10 -10
  459. package/models/cluster/node.js +46 -38
  460. package/models/cluster.x-k8s.io.machine.js +39 -17
  461. package/models/cluster.x-k8s.io.machinedeployment.js +12 -2
  462. package/models/constraints.gatekeeper.sh.constraint.js +1 -1
  463. package/models/etcdbackup.js +4 -4
  464. package/models/event.js +7 -0
  465. package/models/fleet.cattle.io.cluster.js +15 -15
  466. package/models/fleet.cattle.io.clustergroup.js +1 -1
  467. package/models/fleet.cattle.io.gitrepo.js +15 -15
  468. package/models/group.principal.js +1 -1
  469. package/models/logging.banzaicloud.io.clusterflow.js +2 -2
  470. package/models/logging.banzaicloud.io.flow.js +6 -2
  471. package/models/logging.banzaicloud.io.output.js +15 -3
  472. package/models/management.cattle.io.authconfig.js +4 -4
  473. package/models/management.cattle.io.cluster.js +10 -10
  474. package/models/management.cattle.io.clusterroletemplatebinding.js +9 -9
  475. package/models/management.cattle.io.globalrole.js +26 -5
  476. package/models/management.cattle.io.node.js +46 -11
  477. package/models/management.cattle.io.nodepool.js +3 -3
  478. package/models/management.cattle.io.nodetemplate.js +21 -21
  479. package/models/management.cattle.io.podsecurityadmissionconfigurationtemplate.ts +4 -0
  480. package/models/management.cattle.io.project.js +32 -13
  481. package/models/management.cattle.io.projectroletemplatebinding.js +6 -6
  482. package/models/management.cattle.io.roletemplate.js +54 -31
  483. package/models/management.cattle.io.setting.js +1 -1
  484. package/models/management.cattle.io.user.js +41 -5
  485. package/models/monitoring.coreos.com.alertmanagerconfig.js +4 -4
  486. package/models/monitoring.coreos.com.receiver.js +7 -7
  487. package/models/monitoring.coreos.com.route.js +2 -2
  488. package/models/namespace.js +55 -5
  489. package/models/persistentvolume.js +14 -2
  490. package/models/persistentvolumeclaim.js +4 -4
  491. package/models/pod.js +25 -10
  492. package/models/projectroletemplatebinding.js +7 -0
  493. package/models/provisioning.cattle.io.cluster.js +89 -38
  494. package/models/rbac.authorization.k8s.io.role.js +4 -4
  495. package/models/rke-machine.cattle.io.pnapmachinetemplate.js +15 -0
  496. package/models/rke.cattle.io.etcdsnapshot.js +4 -4
  497. package/models/service.js +29 -28
  498. package/models/storage.k8s.io.storageclass.js +41 -26
  499. package/models/workload.js +66 -35
  500. package/nuxt.config.js +59 -34
  501. package/package.json +7 -7
  502. package/pages/about.vue +15 -3
  503. package/pages/account/index.vue +1 -1
  504. package/pages/auth/login.vue +37 -7
  505. package/pages/auth/setup.vue +11 -11
  506. package/pages/c/_cluster/_product/_resource/_id.vue +2 -2
  507. package/pages/c/_cluster/apps/charts/chart.vue +4 -4
  508. package/pages/c/_cluster/apps/charts/index.vue +21 -20
  509. package/pages/c/_cluster/apps/charts/install.vue +73 -36
  510. package/pages/c/_cluster/auth/config/_id.vue +8 -2
  511. package/pages/c/_cluster/auth/config/index.vue +8 -6
  512. package/pages/c/_cluster/auth/group.principal/assign-edit.vue +1 -1
  513. package/pages/c/_cluster/auth/roles/_resource/_id.vue +2 -2
  514. package/pages/c/_cluster/auth/roles/index.vue +5 -7
  515. package/pages/c/_cluster/explorer/EventsTable.vue +8 -8
  516. package/pages/c/_cluster/explorer/index.vue +26 -20
  517. package/pages/c/_cluster/explorer/tools/index.vue +4 -4
  518. package/pages/c/_cluster/fleet/GitRepoGraphConfig.js +2 -2
  519. package/pages/c/_cluster/fleet/index.vue +10 -10
  520. package/pages/c/_cluster/gatekeeper/index.vue +1 -1
  521. package/pages/c/_cluster/legacy/index.vue +1 -1
  522. package/pages/c/_cluster/longhorn/index.vue +2 -2
  523. package/pages/c/_cluster/mcapps/index.vue +1 -1
  524. package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +15 -4
  525. package/pages/c/_cluster/monitoring/index.vue +1 -1
  526. package/pages/c/_cluster/navlinks/_group.vue +1 -1
  527. package/pages/c/_cluster/neuvector/index.vue +2 -2
  528. package/pages/c/_cluster/settings/banners.vue +30 -30
  529. package/pages/c/_cluster/settings/brand.vue +9 -9
  530. package/pages/c/_cluster/settings/links.vue +6 -6
  531. package/pages/c/_cluster/settings/performance.vue +48 -2
  532. package/pages/c/_cluster/uiplugins/DeveloperInstallDialog.vue +1 -1
  533. package/pages/c/_cluster/uiplugins/InstallDialog.vue +1 -1
  534. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +59 -9
  535. package/pages/c/_cluster/uiplugins/index.vue +30 -4
  536. package/pages/diagnostic.vue +5 -4
  537. package/pages/home.vue +105 -30
  538. package/pages/prefs.vue +23 -12
  539. package/pages/rio/mesh.vue +5 -5
  540. package/pages/support/index.vue +7 -7
  541. package/pkg/dynamic-importer.lib.js +8 -0
  542. package/pkg/vue.config.js +14 -1
  543. package/plugins/dashboard-store/__tests__/mutations.spec.js +406 -0
  544. package/plugins/dashboard-store/actions.js +32 -25
  545. package/plugins/dashboard-store/getters.js +50 -33
  546. package/plugins/dashboard-store/mutations.js +134 -28
  547. package/plugins/dashboard-store/normalize.js +1 -1
  548. package/plugins/dashboard-store/resource-class.js +121 -141
  549. package/plugins/steve/actions.js +30 -0
  550. package/plugins/steve/caches/resourceCache.js +60 -0
  551. package/plugins/steve/getters.js +44 -1
  552. package/plugins/steve/mutations.js +97 -36
  553. package/plugins/steve/resourceWatcher.js +277 -0
  554. package/plugins/steve/schema.utils.js +25 -0
  555. package/plugins/steve/subscribe.js +292 -119
  556. package/plugins/steve/worker/index.js +17 -0
  557. package/plugins/steve/worker/web-worker.advanced.js +302 -0
  558. package/plugins/steve/{web-worker.steve-sub-worker.js → worker/web-worker.basic.js} +6 -47
  559. package/promptRemove/management.cattle.io.project.vue +1 -1
  560. package/promptRemove/mixin/roleDeletionCheck.js +7 -7
  561. package/promptRemove/pod.vue +2 -2
  562. package/rancher-components/components/BadgeState/BadgeState.spec.ts +12 -0
  563. package/rancher-components/components/BadgeState/BadgeState.vue +111 -0
  564. package/rancher-components/components/BadgeState/index.ts +1 -0
  565. package/rancher-components/components/Banner/Banner.test.ts +57 -0
  566. package/rancher-components/components/Banner/Banner.vue +242 -0
  567. package/rancher-components/components/Banner/index.ts +1 -0
  568. package/rancher-components/components/Card/Card.test.ts +37 -0
  569. package/rancher-components/components/Card/Card.vue +166 -0
  570. package/rancher-components/components/Card/index.ts +1 -0
  571. package/rancher-components/components/Form/Checkbox/Checkbox.test.ts +68 -0
  572. package/rancher-components/components/Form/Checkbox/Checkbox.vue +418 -0
  573. package/rancher-components/components/Form/Checkbox/index.ts +1 -0
  574. package/rancher-components/components/Form/LabeledInput/LabeledInput.test.ts +23 -0
  575. package/rancher-components/components/Form/LabeledInput/LabeledInput.vue +355 -0
  576. package/rancher-components/components/Form/LabeledInput/index.ts +1 -0
  577. package/rancher-components/components/Form/Radio/RadioButton.vue +276 -0
  578. package/rancher-components/components/Form/Radio/RadioGroup.vue +253 -0
  579. package/rancher-components/components/Form/Radio/index.ts +2 -0
  580. package/rancher-components/components/Form/TextArea/TextAreaAutoGrow.vue +169 -0
  581. package/rancher-components/components/Form/TextArea/index.ts +1 -0
  582. package/rancher-components/components/Form/ToggleSwitch/ToggleSwitch.test.ts +94 -0
  583. package/rancher-components/components/Form/ToggleSwitch/ToggleSwitch.vue +149 -0
  584. package/rancher-components/components/Form/ToggleSwitch/index.ts +1 -0
  585. package/rancher-components/components/Form/index.ts +5 -0
  586. package/rancher-components/components/LabeledTooltip/LabeledTooltip.vue +151 -0
  587. package/rancher-components/components/LabeledTooltip/index.ts +1 -0
  588. package/rancher-components/components/StringList/StringList.test.ts +483 -0
  589. package/rancher-components/components/StringList/StringList.vue +611 -0
  590. package/rancher-components/components/StringList/index.ts +1 -0
  591. package/scripts/publish-shell.sh +38 -5
  592. package/scripts/record-deps.js +37 -0
  593. package/scripts/test-plugins-build.sh +19 -7
  594. package/scripts/typegen.sh +84 -0
  595. package/static/loading-indicator.html +1 -1
  596. package/store/action-menu.js +3 -3
  597. package/store/auth.js +4 -4
  598. package/store/aws.js +4 -4
  599. package/store/catalog.js +22 -22
  600. package/store/index.js +58 -7
  601. package/store/plugins.js +2 -19
  602. package/store/pnap.js +128 -0
  603. package/store/prefs.js +13 -3
  604. package/store/type-map.js +101 -44
  605. package/store/uiplugins.ts +2 -2
  606. package/store/wm.js +10 -0
  607. package/types/pod-security-admission.ts +36 -0
  608. package/types/shell/index.d.ts +3159 -0
  609. package/types/vue-shim.d +20 -0
  610. package/utils/__tests__/object.test.ts +17 -1
  611. package/utils/__tests__/pod-security-admission.test.ts +61 -0
  612. package/utils/alertmanagerconfig.js +6 -6
  613. package/utils/async.ts +36 -0
  614. package/utils/color.js +45 -0
  615. package/utils/crypto/browserHashUtils.js +18 -0
  616. package/utils/dynamic-importer.js +8 -0
  617. package/utils/gc/gc-types.ts +1 -1
  618. package/utils/install-redirect.js +1 -1
  619. package/utils/object.js +26 -2
  620. package/utils/parse-externalid.js +5 -5
  621. package/utils/pod-security-admission.ts +39 -0
  622. package/utils/socket.js +61 -24
  623. package/utils/string.js +2 -0
  624. package/utils/svg-filter.js +301 -0
  625. package/utils/time.js +55 -0
  626. package/utils/validators/cidr.js +4 -0
  627. package/utils/validators/formRules/__tests__/index.test.ts +26 -6
  628. package/utils/validators/formRules/index.ts +14 -0
  629. package/config/product/harvester-manager.js +0 -162
  630. package/creators/pkg/nuxt.config.js +0 -6
  631. package/edit/harvesterhci.io.management.cluster.vue +0 -153
  632. package/list/harvesterhci.io.management.cluster.vue +0 -241
  633. package/machine-config/harvester.vue +0 -693
  634. package/models/harvesterhci.io.management.cluster.js +0 -228
  635. package/pages/c/_cluster/harvesterManager/index.vue +0 -24
@@ -5,7 +5,12 @@ import Masthead from '@shell/components/ResourceList/Masthead';
5
5
  import { AGE, ROLE, STATE, PRINCIPAL } from '@shell/config/table-headers';
6
6
  import { canViewClusterPermissionsEditor } from '@shell/components/form/Members/ClusterPermissionsEditor.vue';
7
7
  import Banner from '@components/Banner/Banner.vue';
8
+ import Tabbed from '@shell/components/Tabbed/index.vue';
9
+ import Tab from '@shell/components/Tabbed/Tab.vue';
10
+ import SortableTable from '@shell/components/SortableTable';
8
11
  import { mapGetters } from 'vuex';
12
+ import { canViewProjectMembershipEditor } from '@shell/components/form/Members/ProjectMembershipEditor.vue';
13
+ import { allHash } from '@shell/utils/promise';
9
14
 
10
15
  /**
11
16
  * Explorer members page.
@@ -17,7 +22,10 @@ export default {
17
22
  components: {
18
23
  Banner,
19
24
  Masthead,
20
- ResourceTable
25
+ ResourceTable,
26
+ Tabbed,
27
+ Tab,
28
+ SortableTable
21
29
  },
22
30
 
23
31
  props: {
@@ -38,19 +46,39 @@ export default {
38
46
  `rancher/schemaFor`
39
47
  ](NORMAN.CLUSTER_ROLE_TEMPLATE_BINDING);
40
48
 
41
- const hydration = [
42
- clusterRoleTemplateBindingSchema ? this.$store.dispatch(
43
- `rancher/findAll`,
44
- { type: NORMAN.CLUSTER_ROLE_TEMPLATE_BINDING },
45
- { root: true }
46
- ) : [],
47
- clusterRoleTemplateBindingSchema ? this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.CLUSTER_ROLE_TEMPLATE_BINDING }) : [],
48
- this.$store.dispatch('rancher/findAll', { type: NORMAN.PRINCIPAL }),
49
- this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.USER }),
50
- this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.ROLE_TEMPLATE })
51
- ];
52
-
53
- await Promise.all(hydration);
49
+ const projectRoleTemplateBindingSchema = this.$store.getters['rancher/schemaFor'](NORMAN.PROJECT_ROLE_TEMPLATE_BINDING);
50
+
51
+ this.$set(this, 'normanClusterRTBSchema', clusterRoleTemplateBindingSchema);
52
+ this.$set(this, 'normanProjectRTBSchema', projectRoleTemplateBindingSchema);
53
+
54
+ if (clusterRoleTemplateBindingSchema) {
55
+ Promise.all([
56
+ this.$store.dispatch(`rancher/findAll`, { type: NORMAN.CLUSTER_ROLE_TEMPLATE_BINDING }, { root: true }),
57
+ this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.CLUSTER_ROLE_TEMPLATE_BINDING })
58
+ ]).then(([normanBindings]) => {
59
+ this.$set(this, 'normanClusterRoleTemplateBindings', normanBindings);
60
+ this.loadingClusterBindings = false;
61
+ });
62
+ }
63
+
64
+ if (projectRoleTemplateBindingSchema) {
65
+ this.$store.dispatch('rancher/findAll', { type: NORMAN.PROJECT_ROLE_TEMPLATE_BINDING }, { root: true })
66
+ .then((bindings) => {
67
+ this.$set(this, 'projectRoleTemplateBindings', bindings);
68
+ this.loadingProjectBindings = false;
69
+ });
70
+ }
71
+
72
+ this.$store.dispatch('management/findAll', { type: MANAGEMENT.PROJECT })
73
+ .then(projects => this.$set(this, 'projects', projects));
74
+
75
+ const hydration = {
76
+ normanPrincipals: this.$store.dispatch('rancher/findAll', { type: NORMAN.PRINCIPAL }),
77
+ mgmt: this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.USER }),
78
+ mgmtRoleTemplates: this.$store.dispatch(`management/findAll`, { type: MANAGEMENT.ROLE_TEMPLATE }),
79
+ };
80
+
81
+ await allHash(hydration);
54
82
  },
55
83
 
56
84
  data() {
@@ -66,54 +94,249 @@ export default {
66
94
  cluster: this.$store.getters['currentCluster'].id
67
95
  }
68
96
  },
69
- resource: MANAGEMENT.CLUSTER_ROLE_TEMPLATE_BINDING,
70
- VIRTUAL_TYPES
97
+ resource: MANAGEMENT.CLUSTER_ROLE_TEMPLATE_BINDING,
98
+ normanClusterRTBSchema: null,
99
+ normanProjectRTBSchema: null,
100
+ normanClusterRoleTemplateBindings: [],
101
+ projectRoleTemplateBindings: [],
102
+ projects: [],
103
+ VIRTUAL_TYPES,
104
+ projectRoleTemplateColumns: [
105
+ STATE,
106
+ {
107
+ name: 'member',
108
+ labeKey: 'generic.name',
109
+ value: 'principalId',
110
+ formatter: 'Principal'
111
+ },
112
+ {
113
+ name: 'role',
114
+ labelKey: 'tableHeaders.role',
115
+ value: 'roleTemplate.nameDisplay'
116
+ },
117
+ { ...AGE, value: 'createdTS' }
118
+ ],
119
+ loadingProjectBindings: true,
120
+ loadingClusterBindings: true
71
121
  };
72
122
  },
73
123
 
74
124
  computed: {
125
+ ...mapGetters(['currentCluster']),
75
126
  clusterRoleTemplateBindings() {
76
- return this.$store.getters[`rancher/all`](NORMAN.CLUSTER_ROLE_TEMPLATE_BINDING).map(b => b.clusterroletemplatebinding) ;
127
+ return this.normanClusterRoleTemplateBindings.map(b => b.clusterroletemplatebinding) ;
77
128
  },
78
- ...mapGetters(['currentCluster']),
79
129
  filteredClusterRoleTemplateBindings() {
80
130
  return this.clusterRoleTemplateBindings.filter(
81
131
  b => b?.clusterName === this.$store.getters['currentCluster'].id
82
132
  );
83
133
  },
134
+ filteredProjects() {
135
+ return this.projects.reduce((all, p) => {
136
+ if (p?.spec?.clusterName === this.currentCluster.id) {
137
+ all[p.id] = p;
138
+ }
139
+
140
+ return all;
141
+ }, {});
142
+ },
143
+ filteredProjectRoleTemplateBindings() {
144
+ const out = this.projectRoleTemplateBindings.filter((rb) => {
145
+ const projectId = rb.projectId.replace(':', '/');
146
+
147
+ return !!this.filteredProjects[projectId];
148
+ });
149
+
150
+ return out;
151
+ },
152
+ projectsWithoutRoles() {
153
+ const inUse = this.filteredProjectRoleTemplateBindings.reduce((projects, binding) => {
154
+ const thisProjectId = (binding.projectId || '').replace(':', '/');
155
+
156
+ if (!projects.includes(thisProjectId)) {
157
+ projects.push(thisProjectId);
158
+ }
159
+
160
+ return projects;
161
+ }, []);
162
+
163
+ return Object.keys(this.filteredProjects).reduce((all, projectId) => {
164
+ const project = this.filteredProjects[projectId];
165
+
166
+ if ( !inUse.includes(projectId)) {
167
+ all.push(project);
168
+ }
169
+
170
+ return all;
171
+ }, []);
172
+ },
173
+
174
+ // We're using this because we need to show projects as groups even if the project doesn't have any role bindings
175
+ rowsWithFakeProjects() {
176
+ const fakeRows = this.projectsWithoutRoles.map((project) => {
177
+ return {
178
+ groupByLabel: `${ ('resourceTable.groupLabel.notInAProject') }-${ project.id }`,
179
+ isFake: true,
180
+ mainRowKey: project.id,
181
+ nameDisplay: project.spec?.displayName, // Enable filtering by the project name
182
+ project,
183
+ availableActions: [],
184
+ projectId: project.id
185
+ };
186
+ });
187
+
188
+ return [...fakeRows, ...this.filteredProjectRoleTemplateBindings];
189
+ },
84
190
  canManageMembers() {
85
191
  return canViewClusterPermissionsEditor(this.$store);
86
192
  },
193
+ canManageProjectMembers() {
194
+ return canViewProjectMembershipEditor(this.$store);
195
+ },
87
196
  isLocal() {
88
197
  return this.$store.getters['currentCluster'].isLocal;
89
- }
198
+ },
199
+ canEditProjectMembers() {
200
+ return this.normanProjectRTBSchema?.collectionMethods.find(x => x.toLowerCase() === 'post');
201
+ },
202
+ canEditClusterMembers() {
203
+ return this.normanClusterRTBSchema?.collectionMethods.find(x => x.toLowerCase() === 'post');
204
+ },
205
+ },
206
+ methods: {
207
+ getMgmtProjectId(group) {
208
+ return group.group.key.replace(':', '/');
209
+ },
210
+ getMgmtProject(group) {
211
+ return this.$store.getters['management/byId'](MANAGEMENT.PROJECT, this.getMgmtProjectId(group));
212
+ },
213
+ getProjectLabel(group) {
214
+ return this.getMgmtProject(group)?.spec?.displayName;
215
+ },
216
+ addProjectMember(group) {
217
+ this.$store.dispatch('cluster/promptModal', {
218
+ component: 'AddProjectMemberDialog',
219
+ componentProps: {
220
+ projectId: group.group.key.replace('/', ':'),
221
+ saveInModal: true
222
+ },
223
+ modalSticky: true
224
+ });
225
+ },
226
+ slotName(project) {
227
+ return `main-row:${ project.id }`;
228
+ },
90
229
  }
91
230
  };
92
231
  </script>
93
232
 
94
233
  <template>
95
- <div>
234
+ <div class="project-members">
96
235
  <Masthead
97
236
  :schema="schema"
98
237
  :resource="resource"
99
238
  :favorite-resource="VIRTUAL_TYPES.CLUSTER_MEMBERS"
100
239
  :create-location="createLocation"
101
240
  :create-button-label="t('members.createActionLabel')"
241
+ :is-creatable="false"
242
+ :type-display="t('members.clusterAndProject')"
102
243
  />
103
244
  <Banner
104
245
  v-if="isLocal"
105
246
  color="error"
106
247
  :label="t('members.localClusterWarning')"
107
248
  />
108
- <ResourceTable
109
- :schema="schema"
110
- :headers="headers"
111
- :rows="$fetchState.pending ? [] : filteredClusterRoleTemplateBindings"
112
- :groupable="false"
113
- :namespaced="false"
114
- :loading="$fetchState.pending || !currentCluster"
115
- sub-search="subSearch"
116
- :sub-fields="['nameDisplay']"
117
- />
249
+ <Tabbed>
250
+ <Tab
251
+ name="cluster-membership"
252
+ label="Cluster Membership"
253
+ >
254
+ <div
255
+ v-if="canEditClusterMembers"
256
+ class="row mb-10 cluster-add"
257
+ >
258
+ <n-link
259
+ :to="createLocation"
260
+ class="btn role-primary pull-right"
261
+ >
262
+ {{ t('members.createActionLabel') }}
263
+ </n-link>
264
+ </div>
265
+ <ResourceTable
266
+ :schema="schema"
267
+ :headers="headers"
268
+ :rows="filteredClusterRoleTemplateBindings"
269
+ :groupable="false"
270
+ :namespaced="false"
271
+ :loading="$fetchState.pending || !currentCluster || loadingClusterBindings"
272
+ sub-search="subSearch"
273
+ :sub-fields="['nameDisplay']"
274
+ />
275
+ </Tab>
276
+ <Tab
277
+ v-if="canManageProjectMembers"
278
+ name="project-membership"
279
+ label="Project Membership"
280
+ >
281
+ <SortableTable
282
+ group-by="projectId"
283
+ :loading="$fetchState.pending || !currentCluster || loadingProjectBindings"
284
+ :rows="rowsWithFakeProjects"
285
+ :headers="projectRoleTemplateColumns"
286
+ >
287
+ <template #group-by="group">
288
+ <div class="group-bar">
289
+ <div
290
+ v-trim-whitespace
291
+ class="group-tab"
292
+ >
293
+ <div
294
+ class="project-name"
295
+ v-html="getProjectLabel(group)"
296
+ />
297
+ </div>
298
+ <div class="right">
299
+ <button
300
+ v-if="canEditProjectMembers"
301
+ type="button"
302
+ class="create-namespace btn btn-sm role-secondary mr-5 right"
303
+ @click="addProjectMember(group)"
304
+ >
305
+ {{ t('members.createActionLabel') }}
306
+ </button>
307
+ </div>
308
+ </div>
309
+ </template>
310
+ <template
311
+ v-for="project in projectsWithoutRoles"
312
+ v-slot:[slotName(project)]
313
+ >
314
+ <tr
315
+ :key="project.id"
316
+ class="main-row"
317
+ >
318
+ <td
319
+ class="empty text-center"
320
+ colspan="100%"
321
+ >
322
+ {{ t('members.noRolesAssigned') }}
323
+ </td>
324
+ </tr>
325
+ </template>
326
+ </SortableTable>
327
+ </Tab>
328
+ </Tabbed>
118
329
  </div>
119
330
  </template>
331
+
332
+ <style lang='scss' scoped>
333
+ .project-members {
334
+ & ::v-deep .group-bar{
335
+ display: flex;
336
+ justify-content: space-between;
337
+ }
338
+ }
339
+ .cluster-add {
340
+ justify-content: flex-end;
341
+ }
342
+ </style>
@@ -85,10 +85,10 @@ export default {
85
85
  },
86
86
  headers() {
87
87
  const project = {
88
- name: 'project',
89
- label: 'Project',
90
- value: 'project.nameDisplay',
91
- sort: ['projectNameSort', 'nameSort'],
88
+ name: 'project',
89
+ label: this.t('tableHeaders.project'),
90
+ value: 'project.nameDisplay',
91
+ sort: ['projectNameSort', 'nameSort'],
92
92
  };
93
93
 
94
94
  return [
@@ -136,8 +136,8 @@ export default {
136
136
 
137
137
  if (this.showMockNotInProjectGroup) {
138
138
  fakeRows.push( {
139
- groupByLabel: this.t('resourceTable.groupLabel.notInAProject'), // Same as the groupByLabel for the namespace model
140
- mainRowKey: 'fake-empty',
139
+ groupByLabel: this.t('resourceTable.groupLabel.notInAProject'), // Same as the groupByLabel for the namespace model
140
+ mainRowKey: 'fake-empty',
141
141
  });
142
142
  }
143
143
 
@@ -235,6 +235,19 @@ export default {
235
235
  }
236
236
  },
237
237
  methods: {
238
+ /**
239
+ * Get PSA HTML to be displayed in the tooltips
240
+ */
241
+ getPsaTooltip(row) {
242
+ const dictionary = row.psaTooltipsDescription;
243
+ const list = Object.values(dictionary)
244
+ .sort()
245
+ .map(text => `<li>${ text }</li>`).join('');
246
+ const title = `<p>${ this.t('podSecurityAdmission.name') }: </p>`;
247
+
248
+ return `${ title }<ul class="psa-tooltip">${ list }</ul>`;
249
+ },
250
+
238
251
  userIsFilteringForSpecificNamespaceOrProject() {
239
252
  const activeFilters = this.$store.getters['namespaceFilters'];
240
253
 
@@ -342,21 +355,21 @@ export default {
342
355
  v-on="$listeners"
343
356
  >
344
357
  <template #group-by="group">
345
- <div
346
- class="project-bar"
347
- :class="{'has-description': projectDescription(group.group)}"
358
+ <div
359
+ class="project-bar"
360
+ :class="{'has-description': projectDescription(group.group)}"
348
361
  >
349
- <div
350
- v-trim-whitespace
351
- class="group-tab"
362
+ <div
363
+ v-trim-whitespace
364
+ class="group-tab"
352
365
  >
353
- <div
354
- class="project-name"
355
- v-html="projectLabel(group.group)"
366
+ <div
367
+ class="project-name"
368
+ v-html="projectLabel(group.group)"
356
369
  />
357
- <div
358
- v-if="projectDescription(group.group)"
359
- class="description text-muted text-small"
370
+ <div
371
+ v-if="projectDescription(group.group)"
372
+ class="description text-muted text-small"
360
373
  >
361
374
  {{ projectDescription(group.group) }}
362
375
  </div>
@@ -369,11 +382,11 @@ export default {
369
382
  >
370
383
  {{ t('projectNamespaces.createNamespace') }}
371
384
  </n-link>
372
- <button
373
- type="button"
374
- class="project-action btn btn-sm role-multi-action actions mr-10"
375
- :class="{invisible: !showProjectActionButton(group.group)}"
376
- @click="showProjectAction($event, group.group)"
385
+ <button
386
+ type="button"
387
+ class="project-action btn btn-sm role-multi-action actions mr-10"
388
+ :class="{invisible: !showProjectActionButton(group.group)}"
389
+ @click="showProjectAction($event, group.group)"
377
390
  >
378
391
  <i class="icon icon-actions" />
379
392
  </button>
@@ -382,22 +395,40 @@ export default {
382
395
  </template>
383
396
  <template #cell:project="{row}">
384
397
  <span v-if="row.project">{{ row.project.nameDisplay }}</span>
385
- <span
386
- v-else
387
- class="text-muted"
398
+ <span
399
+ v-else
400
+ class="text-muted"
388
401
  >&ndash;</span>
389
402
  </template>
390
- <template
391
- v-for="project in projectsWithoutNamespaces"
392
- v-slot:[slotName(project)]
403
+ <template #cell:name="{row}">
404
+ <div class="namespace-name">
405
+ <n-link
406
+ v-if="row.detailLocation"
407
+ :to="row.detailLocation"
408
+ >
409
+ {{ row.name }}
410
+ </n-link>
411
+ <span v-else>
412
+ {{ row.name }}
413
+ </span>
414
+ <i
415
+ v-if="row.hasSystemLabels"
416
+ v-tooltip="getPsaTooltip(row)"
417
+ class="icon icon-lock ml-5"
418
+ />
419
+ </div>
420
+ </template>
421
+ <template
422
+ v-for="project in projectsWithoutNamespaces"
423
+ v-slot:[slotName(project)]
393
424
  >
394
- <tr
395
- :key="project.id"
396
- class="main-row"
425
+ <tr
426
+ :key="project.id"
427
+ class="main-row"
397
428
  >
398
- <td
399
- class="empty text-center"
400
- colspan="5"
429
+ <td
430
+ class="empty text-center"
431
+ colspan="5"
401
432
  >
402
433
  {{ t('projectNamespaces.noNamespaces') }}
403
434
  </td>
@@ -405,9 +436,9 @@ export default {
405
436
  </template>
406
437
  <template #main-row:fake-empty>
407
438
  <tr class="main-row">
408
- <td
409
- class="empty text-center"
410
- colspan="5"
439
+ <td
440
+ class="empty text-center"
441
+ colspan="5"
411
442
  >
412
443
  {{ t('projectNamespaces.noProjectNoNamespaces') }}
413
444
  </td>
@@ -448,6 +479,19 @@ export default {
448
479
  }
449
480
  }
450
481
  }
482
+
483
+ .namespace-name {
484
+ display: flex;
485
+ align-items: center;
486
+ }
451
487
  }
452
488
  }
453
489
  </style>
490
+ <style lang="scss">
491
+ .psa-tooltip {
492
+ // These could pop up a lot as the mouse moves around, keep them as small and unintrusive as possible
493
+ // (easier to test with v-tooltip="{ content: getPSA(row), autoHide: false, show: true }")
494
+ margin: 3px 0;
495
+ padding: 0 8px 0 22px;
496
+ }
497
+ </style>
@@ -25,12 +25,12 @@ export default {
25
25
 
26
26
  data() {
27
27
  return {
28
- showDialog: true,
29
- showHeader: false,
30
- showFooter: false,
31
- showConsent: false,
32
- banner: {},
33
- bannerSetting: null
28
+ showDialog: true,
29
+ showHeader: false,
30
+ showFooter: false,
31
+ showConsent: false,
32
+ banner: {},
33
+ bannerSetting: null
34
34
  };
35
35
  },
36
36
 
@@ -17,7 +17,7 @@ export default {
17
17
  Loading,
18
18
  Card
19
19
  },
20
- props: {
20
+ props: {
21
21
  mode: {
22
22
  type: String,
23
23
  default: _VIEW,
@@ -38,11 +38,11 @@ export default {
38
38
  }
39
39
  },
40
40
  groupPrincipalId: {
41
- type: String,
41
+ type: String,
42
42
  default: ''
43
43
  },
44
44
  userId: {
45
- type: String,
45
+ type: String,
46
46
  default: ''
47
47
  }
48
48
  },
@@ -104,7 +104,7 @@ export default {
104
104
  return this.type === 'user';
105
105
  }
106
106
  },
107
- watch: {
107
+ watch: {
108
108
  groupPrincipalId(groupPrincipalId, oldGroupPrincipalId) {
109
109
  if (groupPrincipalId === oldGroupPrincipalId) {
110
110
  return;
@@ -201,8 +201,8 @@ export default {
201
201
  },
202
202
  async saveAddedRoles(userId) {
203
203
  const requestOptions = {
204
- type: MANAGEMENT.GLOBAL_ROLE_BINDING,
205
- metadata: { generateName: `grb-` },
204
+ type: MANAGEMENT.GLOBAL_ROLE_BINDING,
205
+ metadata: { generateName: `grb-` },
206
206
  };
207
207
 
208
208
  if (this.groupPrincipalId) {
@@ -3,13 +3,13 @@ export default {
3
3
  props: {
4
4
  // a "r, g, b" tuple
5
5
  primaryColorVar: {
6
- type: String,
6
+ type: String,
7
7
  default: null,
8
8
  },
9
9
 
10
10
  // Show the left side
11
11
  showTab: {
12
- type: Boolean,
12
+ type: Boolean,
13
13
  default: true,
14
14
  },
15
15
  showSolid: {
@@ -86,8 +86,9 @@ export default {
86
86
  >
87
87
  <div class="growl-list">
88
88
  <div
89
- v-for="growl in stack"
89
+ v-for="(growl, idx) in stack"
90
90
  :key="growl.id"
91
+ :data-testid="`growl-list-item-${idx}`"
91
92
  :class="{'growl': true, ['bg-'+growl.color]: true}"
92
93
  >
93
94
  <div
@@ -117,7 +118,7 @@ export default {
117
118
  <button
118
119
  type="button"
119
120
  class="btn btn-sm role-primary"
120
- @click="closeAll"
121
+ @click="closeAll()"
121
122
  >
122
123
  {{ t('growl.clearAll') }}
123
124
  </button>
@@ -151,7 +152,6 @@ export default {
151
152
 
152
153
  .close {
153
154
  padding: 5px;
154
- font-size: 24px;
155
155
  }
156
156
 
157
157
  .icon-container {
@@ -1,8 +1,8 @@
1
1
  <script>
2
2
  export default {
3
- props: {
3
+ props: {
4
4
  vertical: {
5
- type: Boolean,
5
+ type: Boolean,
6
6
  default: false,
7
7
  },
8
8
  icon: {
@@ -10,7 +10,7 @@ export default {
10
10
  required: true,
11
11
  },
12
12
  iconState: {
13
- type: String,
13
+ type: String,
14
14
  default: null
15
15
  },
16
16
  message: {
@@ -22,7 +22,7 @@ export default {
22
22
  default: null
23
23
  },
24
24
  subtle: {
25
- type: Boolean,
25
+ type: Boolean,
26
26
  default: false,
27
27
  }
28
28
  },