@rancher/shell 3.0.5-rc.3 → 3.0.5-rc.6

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 (424) hide show
  1. package/assets/data/aws-regions.json +1 -0
  2. package/assets/images/icons/document.svg +3 -0
  3. package/assets/images/key.svg +17 -0
  4. package/assets/images/vendor/cognito.svg +1 -0
  5. package/assets/styles/app.scss +1 -0
  6. package/assets/styles/base/_basic.scss +10 -0
  7. package/assets/styles/base/_spacing.scss +29 -0
  8. package/assets/styles/global/_form.scss +1 -1
  9. package/assets/styles/global/_labeled-input.scss +1 -1
  10. package/assets/styles/global/_layout.scss +1 -1
  11. package/assets/styles/themes/_dark.scss +28 -0
  12. package/assets/styles/themes/_light.scss +68 -0
  13. package/assets/styles/vendor/vue-select.scss +1 -1
  14. package/assets/translations/en-us.yaml +721 -83
  15. package/assets/translations/zh-hans.yaml +11 -9
  16. package/cloud-credential/gcp.vue +9 -1
  17. package/components/AppModal.vue +2 -0
  18. package/components/Certificates.vue +5 -0
  19. package/components/CodeMirror.vue +1 -1
  20. package/components/ConfigMapSettings/Settings.vue +377 -0
  21. package/components/ConfigMapSettings/index.vue +354 -0
  22. package/components/CruResource.vue +1 -2
  23. package/components/DetailText.vue +61 -11
  24. package/components/Drawer/Chrome.vue +116 -0
  25. package/components/Drawer/ResourceDetailDrawer/ConfigTab.vue +61 -0
  26. package/components/Drawer/ResourceDetailDrawer/YamlTab.vue +48 -0
  27. package/components/Drawer/ResourceDetailDrawer/__tests__/ConfigTab.test.ts +54 -0
  28. package/components/Drawer/ResourceDetailDrawer/__tests__/YamlTab.test.ts +80 -0
  29. package/components/Drawer/ResourceDetailDrawer/__tests__/composables.test.ts +82 -0
  30. package/components/Drawer/ResourceDetailDrawer/__tests__/helpers.test.ts +42 -0
  31. package/components/Drawer/ResourceDetailDrawer/composables.ts +50 -0
  32. package/components/Drawer/ResourceDetailDrawer/helpers.ts +10 -0
  33. package/components/Drawer/ResourceDetailDrawer/index.vue +110 -0
  34. package/components/FilterPanel.vue +156 -0
  35. package/components/{fleet/ForceDirectedTreeChart/index.vue → ForceDirectedTreeChart.vue} +47 -41
  36. package/components/GrowlManager.vue +16 -15
  37. package/components/IconOrSvg.vue +19 -35
  38. package/components/KeyValueView.vue +1 -1
  39. package/components/LocaleSelector.vue +9 -1
  40. package/components/ProgressBarMulti.vue +1 -0
  41. package/components/PromptModal.vue +6 -1
  42. package/components/PromptRemove.vue +5 -1
  43. package/components/RelatedResources.vue +4 -12
  44. package/components/Resource/Detail/Additional.vue +46 -0
  45. package/components/Resource/Detail/Card/PodsCard/Bubble.vue +13 -0
  46. package/components/Resource/Detail/Card/PodsCard/composable.ts +30 -0
  47. package/components/Resource/Detail/Card/PodsCard/index.vue +118 -0
  48. package/components/Resource/Detail/Card/ResourceUsageCard/composable.ts +51 -0
  49. package/components/Resource/Detail/Card/ResourceUsageCard/index.vue +79 -0
  50. package/components/Resource/Detail/Card/Scaler.vue +89 -0
  51. package/components/Resource/Detail/Card/StateCard/composables.ts +112 -0
  52. package/components/Resource/Detail/Card/StateCard/index.vue +39 -0
  53. package/components/Resource/Detail/Card/VerticalGap.vue +11 -0
  54. package/components/Resource/Detail/Card/__tests__/Card.test.ts +36 -0
  55. package/components/Resource/Detail/Card/__tests__/PodsCard.test.ts +84 -0
  56. package/components/Resource/Detail/Card/__tests__/ResourceUsageCard.test.ts +72 -0
  57. package/components/Resource/Detail/Card/__tests__/Scaler.test.ts +87 -0
  58. package/components/Resource/Detail/Card/__tests__/StateCard.test.ts +53 -0
  59. package/components/Resource/Detail/Card/__tests__/VerticalGap.test.ts +14 -0
  60. package/components/Resource/Detail/Card/__tests__/index.test.ts +36 -0
  61. package/components/Resource/Detail/Card/index.vue +56 -0
  62. package/components/Resource/Detail/Metadata/Annotations/__tests__/index.test.ts +19 -0
  63. package/components/Resource/Detail/Metadata/Annotations/composable.ts +12 -0
  64. package/components/Resource/Detail/Metadata/Annotations/index.vue +31 -0
  65. package/components/Resource/Detail/Metadata/IdentifyingInformation/__tests__/identifying-fields.test.ts +223 -0
  66. package/components/Resource/Detail/Metadata/IdentifyingInformation/__tests__/index.test.ts +103 -0
  67. package/components/Resource/Detail/Metadata/IdentifyingInformation/composable.ts +64 -0
  68. package/components/Resource/Detail/Metadata/IdentifyingInformation/identifying-fields.ts +298 -0
  69. package/components/Resource/Detail/Metadata/IdentifyingInformation/index.vue +133 -0
  70. package/components/Resource/Detail/Metadata/KeyValue.vue +138 -0
  71. package/components/Resource/Detail/Metadata/Labels/__tests__/index.test.ts +18 -0
  72. package/components/Resource/Detail/Metadata/Labels/composable.ts +12 -0
  73. package/components/Resource/Detail/Metadata/Labels/index.vue +31 -0
  74. package/components/Resource/Detail/Metadata/Rectangle.vue +32 -0
  75. package/components/Resource/Detail/Metadata/__tests__/KeyValue.test.ts +107 -0
  76. package/components/Resource/Detail/Metadata/__tests__/Rectangle.test.ts +24 -0
  77. package/components/Resource/Detail/Metadata/__tests__/composables.test.ts +75 -0
  78. package/components/Resource/Detail/Metadata/__tests__/index.test.ts +91 -0
  79. package/components/Resource/Detail/Metadata/composables.ts +78 -0
  80. package/components/Resource/Detail/Metadata/index.vue +73 -0
  81. package/components/Resource/Detail/Page.vue +37 -0
  82. package/components/Resource/Detail/PercentageBar.vue +40 -0
  83. package/components/Resource/Detail/ResourceRow.vue +138 -0
  84. package/components/Resource/Detail/ResourceTabs/ConfigMapDataTab/__tests__/composables.test.ts +29 -0
  85. package/components/Resource/Detail/ResourceTabs/ConfigMapDataTab/__tests__/index.test.ts +48 -0
  86. package/components/Resource/Detail/ResourceTabs/ConfigMapDataTab/composables.ts +31 -0
  87. package/components/Resource/Detail/ResourceTabs/ConfigMapDataTab/index.vue +50 -0
  88. package/components/Resource/Detail/ResourceTabs/KnownHostsTab/__tests__/composables.test.ts +66 -0
  89. package/components/Resource/Detail/ResourceTabs/KnownHostsTab/composables.ts +21 -0
  90. package/components/Resource/Detail/ResourceTabs/KnownHostsTab/index.vue +31 -0
  91. package/components/Resource/Detail/ResourceTabs/SecretDataTab/Basic.vue +45 -0
  92. package/components/Resource/Detail/ResourceTabs/SecretDataTab/BasicAuth.vue +31 -0
  93. package/components/Resource/Detail/ResourceTabs/SecretDataTab/Certificate.vue +31 -0
  94. package/components/Resource/Detail/ResourceTabs/SecretDataTab/Registry.vue +22 -0
  95. package/components/Resource/Detail/ResourceTabs/SecretDataTab/ServiceAccountToken.vue +31 -0
  96. package/components/Resource/Detail/ResourceTabs/SecretDataTab/Ssh.vue +32 -0
  97. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/Basic.test.ts +40 -0
  98. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/BasicAuth.test.ts +33 -0
  99. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/Certificate.test.ts +33 -0
  100. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/Registry.test.ts +27 -0
  101. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/ServiceAccountToken.test.ts +33 -0
  102. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/Ssh.test.ts +33 -0
  103. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/auth-types.test.ts +186 -0
  104. package/components/Resource/Detail/ResourceTabs/SecretDataTab/__tests__/composables.test.ts +102 -0
  105. package/components/Resource/Detail/ResourceTabs/SecretDataTab/auth-types.ts +109 -0
  106. package/components/Resource/Detail/ResourceTabs/SecretDataTab/composeables.ts +52 -0
  107. package/components/Resource/Detail/ResourceTabs/SecretDataTab/index.vue +71 -0
  108. package/components/Resource/Detail/SpacedRow.vue +14 -0
  109. package/components/Resource/Detail/StatusBar.vue +59 -0
  110. package/components/Resource/Detail/StatusRow.vue +61 -0
  111. package/components/Resource/Detail/TitleBar/Title.vue +14 -0
  112. package/components/Resource/Detail/TitleBar/Top.vue +14 -0
  113. package/components/Resource/Detail/TitleBar/__tests__/Title.test.ts +17 -0
  114. package/components/Resource/Detail/TitleBar/__tests__/Top.test.ts +17 -0
  115. package/components/Resource/Detail/TitleBar/__tests__/composables.test.ts +63 -0
  116. package/components/Resource/Detail/TitleBar/__tests__/index.test.ts +142 -0
  117. package/components/Resource/Detail/TitleBar/composables.ts +44 -0
  118. package/components/Resource/Detail/TitleBar/index.vue +196 -0
  119. package/components/Resource/Detail/Top/index.vue +34 -0
  120. package/components/Resource/Detail/__tests__/Page.test.ts +32 -0
  121. package/components/Resource/Detail/composables.ts +45 -0
  122. package/components/ResourceDetail/Masthead/__tests__/index.test.ts +70 -0
  123. package/components/ResourceDetail/{__tests__/Masthead.test.ts → Masthead/__tests__/legacy.test.ts} +3 -3
  124. package/components/ResourceDetail/Masthead/index.vue +65 -0
  125. package/components/ResourceDetail/Masthead/latest.vue +44 -0
  126. package/components/ResourceDetail/__tests__/index.test.ts +135 -0
  127. package/components/ResourceDetail/index.vue +73 -557
  128. package/components/ResourceDetail/legacy.vue +562 -0
  129. package/components/ResourceList/Masthead.vue +6 -0
  130. package/components/ResourceTable.vue +41 -7
  131. package/components/ResourceYaml.vue +14 -1
  132. package/components/SlideInPanelManager.vue +117 -10
  133. package/components/SortableTable/index.vue +13 -2
  134. package/components/SortableTable/selection.js +21 -8
  135. package/components/StateDot/index.vue +28 -0
  136. package/components/StatusBadge.vue +6 -4
  137. package/components/SubtleLink.vue +25 -0
  138. package/components/Tabbed/index.vue +11 -15
  139. package/components/Wizard.vue +16 -3
  140. package/components/YamlEditor.vue +1 -1
  141. package/components/__tests__/ConfigMapSettings.test.ts +376 -0
  142. package/components/__tests__/FilterPanel.test.ts +81 -0
  143. package/components/__tests__/GrowlManager.test.ts +0 -25
  144. package/components/auth/AuthBanner.vue +2 -3
  145. package/components/auth/RoleDetailEdit.vue +45 -3
  146. package/components/auth/login/ldap.vue +1 -1
  147. package/components/auth/login/oidc.vue +6 -1
  148. package/components/fleet/FleetApplications.vue +174 -0
  149. package/components/fleet/FleetClusterTargets/TargetsList.vue +66 -0
  150. package/components/fleet/FleetClusterTargets/index.vue +455 -0
  151. package/components/fleet/FleetClusters.vue +25 -6
  152. package/components/fleet/FleetGitRepoPaths.vue +476 -0
  153. package/components/fleet/FleetHelmOps.vue +123 -0
  154. package/components/fleet/FleetIntro.vue +58 -28
  155. package/components/fleet/FleetNoWorkspaces.vue +5 -1
  156. package/components/fleet/FleetOCIStorageSecret.vue +171 -0
  157. package/components/fleet/FleetRepos.vue +37 -80
  158. package/components/fleet/FleetResources.vue +53 -26
  159. package/components/fleet/FleetSummary.vue +26 -51
  160. package/components/fleet/FleetValuesFrom.vue +295 -0
  161. package/components/fleet/__tests__/FleetClusterTargets.test.ts +1224 -0
  162. package/components/fleet/__tests__/FleetGitRepoPaths.test.ts +265 -0
  163. package/components/fleet/__tests__/FleetOCIStorageSecret.test.ts +213 -0
  164. package/components/fleet/__tests__/FleetSummary.test.ts +39 -39
  165. package/components/fleet/__tests__/FleetValuesFrom.test.ts +300 -0
  166. package/components/fleet/dashboard/Empty.vue +73 -0
  167. package/components/fleet/dashboard/ResourceCard.vue +184 -0
  168. package/components/fleet/dashboard/ResourceCardSummary.vue +195 -0
  169. package/components/fleet/dashboard/ResourceDetails.vue +194 -0
  170. package/components/fleet/dashboard/ResourcePanel.vue +383 -0
  171. package/components/form/ArrayList.vue +19 -2
  172. package/components/form/ChangePassword.vue +3 -1
  173. package/components/form/Footer.vue +10 -4
  174. package/components/form/KeyValue.vue +81 -43
  175. package/components/form/LabeledSelect.vue +56 -16
  176. package/components/form/Labels.vue +90 -17
  177. package/components/form/MatchExpressions.vue +46 -5
  178. package/components/form/NameNsDescription.vue +1 -1
  179. package/components/form/ResourceSelector.vue +1 -0
  180. package/components/form/ResourceTabs/index.vue +5 -0
  181. package/components/form/SecretSelector.vue +9 -2
  182. package/components/form/Select.vue +57 -19
  183. package/components/form/SimpleSecretSelector.vue +17 -4
  184. package/components/form/Taints.vue +21 -2
  185. package/components/form/UnitInput.vue +8 -0
  186. package/components/form/ValueFromResource.vue +31 -19
  187. package/components/form/__tests__/LabeledSelect.test.ts +8 -4
  188. package/components/form/__tests__/Labels.test.ts +360 -0
  189. package/components/form/__tests__/MatchExpressions.test.ts +16 -13
  190. package/components/form/__tests__/Select.test.ts +5 -2
  191. package/components/formatter/FleetApplicationClustersReady.vue +77 -0
  192. package/components/formatter/FleetApplicationSource.vue +71 -0
  193. package/components/formatter/FleetSummaryGraph.vue +7 -0
  194. package/components/formatter/WorkloadHealthScale.vue +1 -1
  195. package/components/google/AccountAccess.vue +211 -0
  196. package/components/google/types/gcp.d.ts +136 -0
  197. package/components/google/types/index.d.ts +101 -0
  198. package/components/google/util/__mocks__/gcp.ts +465 -0
  199. package/components/google/util/formatter.ts +82 -0
  200. package/components/google/util/gcp.ts +134 -0
  201. package/components/google/util/index.d.ts +11 -0
  202. package/components/nav/Favorite.vue +1 -1
  203. package/components/nav/Group.vue +70 -47
  204. package/components/nav/Header.vue +13 -8
  205. package/components/nav/NamespaceFilter.vue +13 -1
  206. package/components/nav/NotificationCenter/Notification.vue +510 -0
  207. package/components/nav/NotificationCenter/NotificationHeader.vue +112 -0
  208. package/components/nav/NotificationCenter/index.vue +148 -0
  209. package/components/nav/TopLevelMenu.helper.ts +55 -34
  210. package/components/nav/TopLevelMenu.vue +11 -0
  211. package/components/nav/Type.vue +4 -1
  212. package/composables/drawer.ts +26 -0
  213. package/composables/resources.test.ts +63 -0
  214. package/composables/resources.ts +38 -0
  215. package/composables/useI18n.ts +12 -11
  216. package/composables/useIsNewDetailPageEnabled.ts +17 -0
  217. package/config/labels-annotations.js +20 -11
  218. package/config/product/auth.js +17 -1
  219. package/config/product/{cis.js → compliance.js} +23 -26
  220. package/config/product/explorer.js +5 -1
  221. package/config/product/fleet.js +77 -17
  222. package/config/product/settings.js +22 -11
  223. package/config/query-params.js +6 -1
  224. package/config/roles.ts +2 -1
  225. package/config/router/navigation-guards/authentication.js +51 -2
  226. package/config/router/routes.js +45 -31
  227. package/config/secret.ts +15 -0
  228. package/config/settings.ts +24 -5
  229. package/config/store.js +2 -0
  230. package/config/system-namespaces.js +1 -1
  231. package/config/table-headers.js +53 -23
  232. package/config/types.js +17 -6
  233. package/core/plugin-helpers.ts +3 -2
  234. package/core/plugin.ts +32 -7
  235. package/core/types.ts +18 -1
  236. package/detail/{cis.cattle.io.clusterscan.vue → compliance.cattle.io.clusterscan.vue} +22 -18
  237. package/detail/fleet.cattle.io.cluster.vue +28 -15
  238. package/detail/fleet.cattle.io.gitrepo.vue +10 -1
  239. package/detail/fleet.cattle.io.helmop.vue +157 -0
  240. package/detail/management.cattle.io.fleetworkspace.vue +18 -27
  241. package/detail/management.cattle.io.oidcclient.vue +369 -0
  242. package/detail/node.vue +2 -2
  243. package/detail/pod.vue +2 -2
  244. package/detail/service.vue +10 -1
  245. package/detail/workload/index.vue +8 -2
  246. package/dialog/ExtensionCatalogUninstallDialog.vue +7 -4
  247. package/dialog/GenericPrompt.vue +1 -1
  248. package/dialog/HelmOpForceUpdateDialog.vue +132 -0
  249. package/dialog/ImportDialog.vue +8 -8
  250. package/dialog/OidcClientSecretDialog.vue +117 -0
  251. package/dialog/RedeployWorkloadDialog.vue +164 -0
  252. package/edit/__tests__/cis.cattle.io.clusterscan.test.ts +3 -3
  253. package/edit/__tests__/fleet.cattle.io.gitrepo.test.ts +60 -68
  254. package/edit/auth/oidc.vue +159 -93
  255. package/edit/autoscaling.horizontalpodautoscaler/index.vue +4 -1
  256. package/edit/{cis.cattle.io.clusterscan.vue → compliance.cattle.io.clusterscan.vue} +30 -31
  257. package/edit/{cis.cattle.io.clusterscanbenchmark.vue → compliance.cattle.io.clusterscanbenchmark.vue} +4 -4
  258. package/edit/{cis.cattle.io.clusterscanprofile.vue → compliance.cattle.io.clusterscanprofile.vue} +5 -5
  259. package/edit/configmap.vue +4 -1
  260. package/edit/constraints.gatekeeper.sh.constraint/index.vue +1 -0
  261. package/edit/fleet.cattle.io.gitrepo.vue +70 -255
  262. package/edit/fleet.cattle.io.helmop.vue +772 -0
  263. package/edit/helm.cattle.io.projecthelmchart.vue +1 -0
  264. package/edit/k8s.cni.cncf.io.networkattachmentdefinition.vue +1 -0
  265. package/edit/logging-flow/index.vue +1 -0
  266. package/edit/logging.banzaicloud.io.output/index.vue +1 -0
  267. package/edit/management.cattle.io.fleetworkspace.vue +44 -10
  268. package/edit/management.cattle.io.oidcclient.vue +162 -0
  269. package/edit/management.cattle.io.project.vue +4 -1
  270. package/edit/monitoring.coreos.com.alertmanagerconfig/index.vue +1 -1
  271. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +5 -0
  272. package/edit/monitoring.coreos.com.prometheusrule/index.vue +1 -0
  273. package/edit/monitoring.coreos.com.receiver/auth.vue +30 -30
  274. package/edit/monitoring.coreos.com.receiver/index.vue +1 -0
  275. package/edit/monitoring.coreos.com.receiver/types/email.vue +1 -1
  276. package/edit/monitoring.coreos.com.route.vue +1 -0
  277. package/edit/namespace.vue +1 -0
  278. package/edit/networking.istio.io.destinationrule/index.vue +4 -1
  279. package/edit/networking.k8s.io.ingress/index.vue +4 -1
  280. package/edit/networking.k8s.io.networkpolicy/PolicyRules.vue +7 -2
  281. package/edit/networking.k8s.io.networkpolicy/index.vue +6 -2
  282. package/edit/node.vue +1 -0
  283. package/edit/persistentvolume/index.vue +4 -1
  284. package/edit/provisioning.cattle.io.cluster/rke2.vue +418 -382
  285. package/edit/provisioning.cattle.io.cluster/tabs/Basics.vue +27 -27
  286. package/edit/provisioning.cattle.io.cluster/tabs/MachinePool.vue +5 -0
  287. package/edit/resources.cattle.io.restore.vue +1 -1
  288. package/edit/secret/index.vue +1 -0
  289. package/edit/service.vue +4 -1
  290. package/edit/serviceaccount.vue +4 -1
  291. package/edit/storage.k8s.io.storageclass/index.vue +4 -1
  292. package/edit/workload/index.vue +5 -0
  293. package/list/{cis.cattle.io.clusterscan.vue → compliance.cattle.io.clusterscan.vue} +2 -2
  294. package/list/fleet.cattle.io.gitrepo.vue +1 -1
  295. package/list/fleet.cattle.io.helmop.vue +108 -0
  296. package/list/management.cattle.io.oidcclient.vue +108 -0
  297. package/list/namespace.vue +5 -2
  298. package/list/node.vue +2 -0
  299. package/machine-config/amazonec2.vue +3 -24
  300. package/machine-config/components/GCEImage.vue +374 -0
  301. package/machine-config/google.vue +617 -0
  302. package/mixins/__tests__/brand.spec.ts +170 -0
  303. package/mixins/auth-config.js +8 -1
  304. package/mixins/brand.js +16 -17
  305. package/mixins/create-edit-view/index.js +5 -0
  306. package/mixins/preset.js +100 -0
  307. package/mixins/resource-fetch-api-pagination.js +18 -0
  308. package/mixins/resource-fetch.js +1 -1
  309. package/mixins/resource-table-watch.js +45 -0
  310. package/mixins/vue-select-overrides.js +1 -0
  311. package/models/__tests__/chart.test.ts +273 -0
  312. package/models/__tests__/fleet.cattle.io.gitrepo.test.ts +1 -1
  313. package/models/chart.js +144 -2
  314. package/models/{cis.cattle.io.clusterscan.js → compliance.cattle.io.clusterscan.js} +8 -8
  315. package/models/{cis.cattle.io.clusterscanbenchmark.js → compliance.cattle.io.clusterscanbenchmark.js} +1 -1
  316. package/models/{cis.cattle.io.clusterscanprofile.js → compliance.cattle.io.clusterscanprofile.js} +5 -5
  317. package/models/{cis.cattle.io.clusterscanreport.js → compliance.cattle.io.clusterscanreport.js} +1 -1
  318. package/models/fleet-application.js +314 -0
  319. package/models/fleet.cattle.io.bundle.js +9 -8
  320. package/models/fleet.cattle.io.cluster.js +11 -0
  321. package/models/fleet.cattle.io.gitrepo.js +41 -365
  322. package/models/fleet.cattle.io.helmop.js +198 -0
  323. package/models/management.cattle.io.authconfig.js +1 -0
  324. package/models/management.cattle.io.fleetworkspace.js +14 -1
  325. package/models/management.cattle.io.oidcclient.js +18 -0
  326. package/models/management.cattle.io.registration.js +3 -0
  327. package/models/provisioning.cattle.io.cluster.js +5 -5
  328. package/models/service.js +4 -0
  329. package/models/workload.js +19 -18
  330. package/package.json +2 -1
  331. package/pages/about.vue +4 -58
  332. package/pages/auth/login.vue +1 -1
  333. package/pages/auth/verify.vue +13 -1
  334. package/pages/c/_cluster/apps/charts/AddRepoLink.vue +36 -0
  335. package/pages/c/_cluster/apps/charts/AppChartCardFooter.vue +80 -0
  336. package/pages/c/_cluster/apps/charts/AppChartCardSubHeader.vue +54 -0
  337. package/pages/c/_cluster/apps/charts/StatusLabel.vue +33 -0
  338. package/pages/c/_cluster/apps/charts/index.vue +487 -465
  339. package/pages/c/_cluster/auth/user.retention/index.vue +87 -78
  340. package/pages/c/_cluster/explorer/EventsTable.vue +1 -1
  341. package/pages/c/_cluster/explorer/index.vue +3 -3
  342. package/pages/c/_cluster/explorer/tools/pages/_page.vue +0 -1
  343. package/pages/c/_cluster/fleet/__tests__/index.test.ts +426 -0
  344. package/pages/c/_cluster/fleet/application/_resource/_id.vue +14 -0
  345. package/pages/c/_cluster/fleet/application/_resource/create.vue +14 -0
  346. package/pages/c/_cluster/fleet/application/create.vue +341 -0
  347. package/pages/c/_cluster/fleet/application/index.vue +139 -0
  348. package/pages/c/_cluster/fleet/graph/config.js +277 -0
  349. package/pages/c/_cluster/fleet/index.vue +809 -329
  350. package/pages/c/_cluster/fleet/settings/index.vue +229 -0
  351. package/pages/c/_cluster/longhorn/index.vue +5 -2
  352. package/pages/c/_cluster/uiplugins/CatalogList/index.vue +16 -1
  353. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +2 -2
  354. package/pages/explorer/resource/detail/configmap.vue +42 -0
  355. package/pages/explorer/resource/detail/secret.vue +50 -0
  356. package/pages/home.vue +9 -55
  357. package/pages/support/index.vue +4 -6
  358. package/plugins/dashboard-store/actions.js +50 -14
  359. package/plugins/dashboard-store/getters.js +38 -21
  360. package/plugins/dashboard-store/mutations.js +51 -7
  361. package/plugins/dashboard-store/resource-class.js +30 -4
  362. package/plugins/steve/__tests__/subscribe.spec.ts +66 -1
  363. package/plugins/steve/actions.js +3 -0
  364. package/plugins/steve/steve-pagination-utils.ts +17 -8
  365. package/plugins/steve/subscribe.js +235 -43
  366. package/rancher-components/BadgeState/BadgeState.vue +3 -1
  367. package/rancher-components/Banner/Banner.vue +13 -0
  368. package/rancher-components/Form/Checkbox/Checkbox.vue +11 -6
  369. package/rancher-components/Form/LabeledInput/LabeledInput.vue +1 -1
  370. package/rancher-components/LabeledTooltip/LabeledTooltip.vue +1 -0
  371. package/rancher-components/RcItemCard/RcItemCard.test.ts +189 -0
  372. package/rancher-components/RcItemCard/RcItemCard.vue +430 -0
  373. package/rancher-components/RcItemCard/RcItemCardAction.vue +24 -0
  374. package/rancher-components/RcItemCard/index.ts +2 -0
  375. package/store/auth.js +3 -0
  376. package/store/catalog.js +85 -25
  377. package/store/growl.js +97 -8
  378. package/store/index.js +39 -14
  379. package/store/notifications.ts +426 -0
  380. package/store/prefs.js +0 -1
  381. package/store/slideInPanel.ts +6 -0
  382. package/store/type-map.js +19 -15
  383. package/store/uiplugins.ts +15 -1
  384. package/types/fleet.d.ts +59 -0
  385. package/types/notifications/index.ts +74 -0
  386. package/types/resources/settings.d.ts +19 -1
  387. package/types/shell/index.d.ts +388 -307
  388. package/types/store/dashboard-store.types.ts +33 -3
  389. package/types/store/pagination.types.ts +6 -1
  390. package/types/store/subscribe.types.ts +50 -0
  391. package/utils/__tests__/fleet.test.ts +148 -0
  392. package/utils/__tests__/object.test.ts +54 -1
  393. package/utils/__tests__/string.test.ts +273 -1
  394. package/utils/__tests__/time.test.ts +31 -0
  395. package/utils/auth.js +41 -5
  396. package/utils/crypto/encryption.ts +103 -0
  397. package/utils/cspAdaptor.ts +51 -0
  398. package/utils/fleet-types.ts +0 -0
  399. package/utils/fleet.ts +190 -2
  400. package/utils/object.js +36 -0
  401. package/utils/pagination-utils.ts +27 -2
  402. package/utils/pagination-wrapper.ts +132 -50
  403. package/utils/release-notes.ts +48 -0
  404. package/utils/selector-typed.ts +7 -2
  405. package/utils/settings.ts +4 -1
  406. package/utils/string.js +24 -0
  407. package/utils/style.ts +39 -0
  408. package/utils/{time.js → time.ts} +25 -6
  409. package/utils/uiplugins.ts +22 -0
  410. package/utils/validators/formRules/__tests__/index.test.ts +36 -3
  411. package/utils/validators/formRules/index.ts +13 -3
  412. package/utils/window.js +11 -7
  413. package/components/__tests__/ApplicationCard.test.ts +0 -27
  414. package/components/cards/ApplicationCard.vue +0 -145
  415. package/components/fleet/ForceDirectedTreeChart/chartIcons.js +0 -17
  416. package/config/product/legacy.js +0 -62
  417. package/config/secret.js +0 -14
  418. package/pages/c/_cluster/fleet/GitRepoGraphConfig.js +0 -249
  419. package/pages/c/_cluster/legacy/pages/_page.vue +0 -29
  420. package/pages/c/_cluster/legacy/project/_page.vue +0 -57
  421. package/pages/c/_cluster/legacy/project/index.vue +0 -32
  422. package/pages/c/_cluster/legacy/project/pipelines.vue +0 -96
  423. /package/components/ResourceDetail/{Masthead.vue → Masthead/legacy.vue} +0 -0
  424. /package/{components/form/SSHKnownHosts → dialog}/__tests__/KnownHostsEditDialog.test.ts +0 -0
@@ -1,569 +1,85 @@
1
- <script>
2
- import CreateEditView from '@shell/mixins/create-edit-view/impl';
3
- import Loading from '@shell/components/Loading';
4
- import ResourceYaml from '@shell/components/ResourceYaml';
5
- import {
6
- _VIEW, _EDIT, _CLONE, _IMPORT, _STAGE, _CREATE,
7
- AS, _YAML, _DETAIL, _CONFIG, _GRAPH, PREVIEW, MODE,
8
- } from '@shell/config/query-params';
9
- import { FLEET, SCHEMA } from '@shell/config/types';
10
- import { createYaml } from '@shell/utils/create-yaml';
11
- import Masthead from '@shell/components/ResourceDetail/Masthead';
12
- import DetailTop from '@shell/components/DetailTop';
13
- import { clone, diff } from '@shell/utils/object';
14
- import IconMessage from '@shell/components/IconMessage';
15
- import ForceDirectedTreeChart from '@shell/components/fleet/ForceDirectedTreeChart';
16
- import { checkSchemasForFindAllHash } from '@shell/utils/auth';
17
- import { stringify } from '@shell/utils/error';
18
- import { Banner } from '@components/Banner';
19
-
20
- function modeFor(route) {
21
- if ( route.query?.mode === _IMPORT ) {
22
- return _IMPORT;
23
- }
24
-
25
- if ( route.params?.id ) {
26
- return route.query.mode || _VIEW;
27
- } else {
28
- return _CREATE;
29
- }
30
- }
31
-
32
- async function getYaml(store, model) {
33
- let yaml;
34
- const opt = { headers: { accept: 'application/yaml' } };
35
-
36
- if ( model.hasLink('view') ) {
37
- yaml = (await model.followLink('view', opt)).data;
38
- }
39
-
40
- return model.cleanForDownload(yaml);
1
+ <script lang="ts" setup>
2
+ import { useRoute } from 'vue-router';
3
+ import { computed, defineAsyncComponent } from 'vue';
4
+
5
+ import { MODE, _VIEW } from '@shell/config/query-params';
6
+ import Legacy from '@shell/components/ResourceDetail/legacy.vue';
7
+ import Loading from '@shell/components/Loading.vue';
8
+ import { useIsNewDetailPageEnabled } from '@shell/composables/useIsNewDetailPageEnabled';
9
+
10
+ export interface Props {
11
+ flexContent?: boolean;
12
+ componentTestId?: string;
13
+ storeOverride?: string;
14
+ resourceOverride?: string;
15
+ parentRouteOverride?: string;
16
+ errorsMap?: any;
41
17
  }
42
18
 
43
- export default {
44
- emits: ['input'],
45
-
46
- components: {
47
- Loading,
48
- DetailTop,
49
- ForceDirectedTreeChart,
50
- ResourceYaml,
51
- Masthead,
52
- IconMessage,
53
- Banner
54
- },
55
-
56
- mixins: [CreateEditView],
57
-
58
- props: {
59
- storeOverride: {
60
- type: String,
61
- default: null,
62
- },
63
-
64
- resourceOverride: {
65
- type: String,
66
- default: null,
67
- },
68
-
69
- parentRouteOverride: {
70
- type: String,
71
- default: null,
72
- },
73
-
74
- flexContent: {
75
- type: Boolean,
76
- default: false,
77
- },
78
-
79
- /**
80
- * Inherited global identifier prefix for tests
81
- * Define a term based on the parent component to avoid conflicts on multiple components
82
- */
83
- componentTestid: {
84
- type: String,
85
- default: 'resource-details'
86
- },
87
- errorsMap: {
88
- type: Object,
89
- default: null
90
- },
91
- },
92
-
93
- async fetch() {
94
- const store = this.$store;
95
- const route = this.$route;
96
- const params = route.params;
97
- let resourceType = this.resourceOverride || params.resource;
98
-
99
- const inStore = this.storeOverride || store.getters['currentStore'](resourceType);
100
- const realMode = this.realMode;
101
-
102
- // eslint-disable-next-line prefer-const
103
- let { namespace, id } = params;
104
-
105
- // There are 6 "real" modes that can be put into the query string
106
- // These are mapped down to the 3 regular page "mode"s that create-edit-view components
107
- // know about: view, edit, create (stage, import and clone become "create")
108
- const mode = ([_CLONE, _IMPORT, _STAGE].includes(realMode) ? _CREATE : realMode);
109
-
110
- const getGraphConfig = store.getters['type-map/hasGraph'](resourceType);
111
- const hasGraph = !!getGraphConfig;
112
- const hasCustomDetail = store.getters['type-map/hasCustomDetail'](resourceType, id);
113
- const hasCustomEdit = store.getters['type-map/hasCustomEdit'](resourceType, id);
114
-
115
- const schemas = store.getters[`${ inStore }/all`](SCHEMA);
116
-
117
- // As determines what component will be rendered
118
- const requested = route.query[AS];
119
- let as;
120
- let notFound = false;
121
-
122
- if ( mode === _VIEW && hasCustomDetail && (!requested || requested === _DETAIL) ) {
123
- as = _DETAIL;
124
- } else if ( mode === _VIEW && hasGraph && requested === _GRAPH) {
125
- as = _GRAPH;
126
- } else if ( hasCustomEdit && (!requested || requested === _CONFIG) ) {
127
- as = _CONFIG;
128
- } else {
129
- as = _YAML;
130
- }
131
-
132
- this.as = as;
133
-
134
- const options = store.getters[`type-map/optionsFor`](resourceType);
135
-
136
- this.showMasthead = [_CREATE, _EDIT].includes(mode) ? options.resourceEditMasthead : true;
137
- const canViewYaml = options.canYaml;
138
-
139
- if ( options.resource ) {
140
- resourceType = options.resource;
141
- }
142
-
143
- const schema = store.getters[`${ inStore }/schemaFor`](resourceType);
144
- let model, initialModel, liveModel, yaml;
145
-
146
- if ( realMode === _CREATE || realMode === _IMPORT ) {
147
- if ( !namespace ) {
148
- namespace = store.getters['defaultNamespace'];
149
- }
150
-
151
- const data = { type: resourceType };
152
-
153
- if ( schema?.attributes?.namespaced ) {
154
- data.metadata = { namespace };
155
- }
156
-
157
- liveModel = await store.dispatch(`${ inStore }/create`, data);
158
- initialModel = await store.dispatch(`${ inStore }/clone`, { resource: liveModel });
159
- model = await store.dispatch(`${ inStore }/clone`, { resource: liveModel });
160
-
161
- if (model.forceYaml === true) {
162
- as = _YAML;
163
- this.as = as;
164
- }
165
-
166
- if ( as === _YAML ) {
167
- if (schema?.fetchResourceFields) {
168
- // fetch resourceFields for createYaml
169
- await schema.fetchResourceFields();
170
- }
171
-
172
- yaml = createYaml(schemas, resourceType, data);
173
- }
174
- } else {
175
- if ( as === _GRAPH ) {
176
- const graphSchema = await checkSchemasForFindAllHash({
177
- cluster: {
178
- inStoreType: 'management',
179
- type: FLEET.CLUSTER
180
- },
181
- bundle: {
182
- inStoreType: 'management',
183
- type: FLEET.BUNDLE,
184
- opt: { excludeFields: ['metadata.managedFields', 'spec.resources'] },
185
- },
186
-
187
- bundleDeployment: {
188
- inStoreType: 'management',
189
- type: FLEET.BUNDLE_DEPLOYMENT
190
- }
191
-
192
- }, this.$store);
193
-
194
- this.canViewChart = graphSchema.cluster && graphSchema.bundle && graphSchema.bundleDeployment;
195
- }
196
-
197
- let fqid = id;
198
-
199
- if ( schema.attributes?.namespaced && namespace ) {
200
- fqid = `${ namespace }/${ fqid }`;
201
- }
202
-
203
- try {
204
- liveModel = await store.dispatch(`${ inStore }/find`, {
205
- type: resourceType,
206
- id: fqid,
207
- opt: { watch: true }
208
- });
209
- } catch (e) {
210
- if (e.status === 404 || e.status === 403) {
211
- store.dispatch('loadingError', new Error(this.t('nav.failWhale.resourceIdNotFound', { resource: resourceType, fqid }, true)));
212
- }
213
- liveModel = {};
214
- notFound = fqid;
215
- }
216
-
217
- try {
218
- if (realMode === _VIEW) {
219
- model = liveModel;
220
- } else {
221
- model = await store.dispatch(`${ inStore }/clone`, { resource: liveModel });
222
- }
223
- initialModel = await store.dispatch(`${ inStore }/clone`, { resource: liveModel });
224
-
225
- if ( as === _YAML ) {
226
- yaml = await getYaml(this.$store, liveModel);
227
- }
228
- } catch (e) {
229
- this.errors.push(e);
230
- }
231
- if ( as === _YAML ) {
232
- try {
233
- yaml = await getYaml(this.$store, liveModel);
234
- } catch (e) {
235
- this.errors.push(e);
236
- }
237
- }
238
-
239
- if ( as === _GRAPH ) {
240
- this.chartData = liveModel;
241
- }
242
-
243
- if ( [_CLONE, _IMPORT, _STAGE].includes(realMode) ) {
244
- model.cleanForNew();
245
- yaml = model.cleanYaml(yaml, realMode);
246
- }
247
- }
248
-
249
- // Ensure common properties exists
250
- try {
251
- model = await store.dispatch(`${ inStore }/cleanForDetail`, model);
252
- } catch (e) {
253
- this.errors.push(e);
254
- }
255
-
256
- const out = {
257
- hasGraph,
258
- getGraphConfig,
259
- hasCustomDetail,
260
- hasCustomEdit,
261
- canViewYaml,
262
- resourceType,
263
- as,
264
- yaml,
265
- initialModel,
266
- liveModel,
267
- mode,
268
- value: model,
269
- notFound,
270
- };
271
-
272
- for ( const key in out ) {
273
- this[key] = out[key];
274
- }
275
-
276
- if ( this.mode === _CREATE ) {
277
- this.value.applyDefaults(this, realMode);
278
- }
279
- },
280
- data() {
281
- return {
282
- chartData: null,
283
- resourceSubtype: null,
284
-
285
- // Set by fetch
286
- hasGraph: null,
287
- hasCustomDetail: null,
288
- hasCustomEdit: null,
289
- resourceType: null,
290
- asYaml: null,
291
- yaml: null,
292
- liveModel: null,
293
- initialModel: null,
294
- mode: null,
295
- as: null,
296
- value: null,
297
- model: null,
298
- notFound: null,
299
- canViewChart: true,
300
- canViewYaml: null,
301
- errors: []
302
- };
303
- },
304
-
305
- computed: {
306
- realMode() {
307
- // There are 5 "real" modes that you can start in: view, edit, create, stage, clone
308
- const realMode = modeFor(this.$route);
309
-
310
- return realMode;
311
- },
312
-
313
- isView() {
314
- return this.mode === _VIEW;
315
- },
316
-
317
- isYaml() {
318
- return this.as === _YAML;
319
- },
320
-
321
- isDetail() {
322
- return this.as === _DETAIL;
323
- },
324
-
325
- isGraph() {
326
- return this.as === _GRAPH;
327
- },
328
-
329
- offerPreview() {
330
- return this.as === _YAML && [_EDIT, _CLONE, _IMPORT, _STAGE].includes(this.mode);
331
- },
332
-
333
- showComponent() {
334
- switch ( this.as ) {
335
- case _DETAIL: return this.detailComponent;
336
- case _CONFIG: return this.editComponent;
337
- }
338
-
339
- return null;
340
- },
341
- hasErrors() {
342
- return this.errors?.length && Array.isArray(this.errors);
343
- },
344
- mappedErrors() {
345
- return !this.errors ? {} : this.errorsMap || this.errors.reduce((acc, error) => ({
346
- ...acc,
347
- [error]: {
348
- message: error?.data?.message || error,
349
- icon: null
350
- }
351
- }), {});
352
- },
353
- },
354
-
355
- watch: {
356
- '$route'(current, prev) {
357
- if (current.name !== prev.name) {
358
- return;
359
- }
360
- const neu = clone(current.query);
361
- const old = clone(prev.query);
362
-
363
- delete neu[PREVIEW];
364
- delete old[PREVIEW];
365
-
366
- if ( !this.isView ) {
367
- delete neu[AS];
368
- delete old[AS];
369
- }
370
-
371
- const queryDiff = Object.keys(diff(neu, old));
372
-
373
- if (queryDiff.includes(MODE) || queryDiff.includes(AS)) {
374
- this.$fetch();
375
- }
376
- },
377
-
378
- // Auto refresh YAML when the model changes
379
- async 'value.metadata.resourceVersion'(a, b) {
380
- if ( this.mode === _VIEW && this.as === _YAML && a && b && a !== b) {
381
- this.yaml = await getYaml(this.$store, this.liveModel);
382
- }
383
- }
384
- },
385
-
386
- created() {
387
- this.configureResource();
388
- },
19
+ // Ideally I'd prefer to have separate routes/pages for each of these but our app makes a
20
+ // fair amount of assumptions around having one detail page for each resource and that the
21
+ // detail, config, edit, yaml, create pages are all derived from the same page.
22
+ //
23
+ // I could also dynamically check for and import these pages but I wanted this to be easier
24
+ // to be explicit and easier to search for.
25
+ const resourceToPage: any = {
26
+ // 'apps.daemonset': defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/apps.daemonset.vue')),
27
+ // 'apps.deployment': defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/apps.deployment.vue')),
28
+ // 'apps.statefulset': defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/apps.statefulset.vue')),
29
+ // 'batch.cronjob': defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/batch.cronjob.vue')),
30
+ // 'batch.job': defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/batch.job.vue')),
31
+ configmap: defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/configmap.vue')),
32
+ // namespace: defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/namespace.vue')),
33
+ // node: defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/node.vue')),
34
+ // pod: defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/pod.vue')),
35
+ secret: defineAsyncComponent(() => import('@shell/pages/explorer/resource/detail/secret.vue')),
36
+ };
389
37
 
390
- methods: {
391
- stringify,
392
- setSubtype(subtype) {
393
- this.resourceSubtype = subtype;
394
- },
38
+ defineOptions({ inheritAttrs: false });
395
39
 
396
- keyAction(act) {
397
- const m = this.liveModel;
40
+ const route = useRoute();
41
+ const props = withDefaults(defineProps<Props>(), {
42
+ flexContent: false,
43
+ componentTestId: 'resource-details',
44
+ storeOverride: undefined,
45
+ resourceOverride: undefined,
46
+ parentRouteOverride: undefined,
47
+ errorsMap: undefined
48
+ });
398
49
 
399
- if ( m?.[act] ) {
400
- m[act]();
401
- }
402
- },
403
- closeError(index) {
404
- this.errors = this.errors.filter((_, i) => i !== index);
405
- },
406
- /**
407
- * Initializes the resource components based on the provided user and
408
- * resource override.
409
- *
410
- * Configures the detail and edit components for a resource based on the
411
- * user's ID and the specified resource.
412
- *
413
- * @param {Object} user - The user object containing user-specific
414
- * information.
415
- * @param {string|null} resourceOverride - An optional resource override
416
- * string. If not provided, the method will use the default resource from
417
- * the route parameters or the instance's resourceOverride property.
418
- */
419
- configureResource(userId = '', resourceOverride = null) {
420
- const id = userId || this.$route.params.id;
421
- const resource = resourceOverride || this.resourceOverride || this.$route.params.resource;
422
- const options = this.$store.getters[`type-map/optionsFor`](resource);
50
+ const currentResourceName = computed(() => {
51
+ const resource = route?.params?.resource;
423
52
 
424
- const detailResource = options.resourceDetail || options.resource || resource;
425
- const editResource = options.resourceEdit || options.resource || resource;
53
+ if (!resource) {
54
+ return;
55
+ }
426
56
 
427
- // FIXME: These aren't right... signature is (rawType, subType).. not (rawType, resourceId)
428
- // Remove id? How does subtype get in (cluster/node)
429
- this.detailComponent = this.$store.getters['type-map/importDetail'](detailResource, id);
430
- this.editComponent = this.$store.getters['type-map/importEdit'](editResource, id);
431
- },
432
- /**
433
- * Sets the mode and initializes the resource components.
434
- *
435
- * This method sets the mode of the component and configures the resource
436
- * components based on the provided user and resource.
437
- *
438
- * @param {Object} payload - An object containing the mode, user, and
439
- * resource properties.
440
- * @param {string} payload.mode - The mode to set.
441
- * @param {Object} payload.user - The user object containing user-specific
442
- * information.
443
- * @param {string} payload.resource - The resource string to use for
444
- * initialization.
445
- */
446
- setMode({ mode, userId, resource }) {
447
- this.mode = mode;
448
- this.value.id = userId;
449
- this.configureResource(userId, resource);
450
- }
57
+ if (typeof resource === 'string') {
58
+ return resource;
451
59
  }
452
- };
60
+
61
+ // This should never occur, just satisfying the types
62
+ return resource[0];
63
+ });
64
+ const mode = computed(() => route?.query?.[MODE]);
65
+ const isView = computed(() => route?.params?.id && (!mode.value || mode.value === _VIEW));
66
+ // We're defaulting to legacy being on, we'll switch this once we want to enable the new detail page by default
67
+ const iseNewDetailPageEnabled = useIsNewDetailPageEnabled();
68
+ const page = computed(() => currentResourceName.value ? resourceToPage[currentResourceName.value] : undefined);
69
+ const useLatest = computed(() => !!(iseNewDetailPageEnabled.value && isView.value && page.value));
453
70
  </script>
454
71
 
455
72
  <template>
456
- <Loading v-if="$fetchState.pending || notFound" />
457
- <div v-else>
458
- <Masthead
459
- v-if="showMasthead"
460
- :resource="resourceType"
461
- :value="liveModel"
462
- :mode="mode"
463
- :real-mode="realMode"
464
- :as="as"
465
- :has-graph="hasGraph"
466
- :has-detail="hasCustomDetail"
467
- :has-edit="hasCustomEdit"
468
- :can-view-yaml="canViewYaml"
469
- :resource-subtype="resourceSubtype"
470
- :parent-route-override="parentRouteOverride"
471
- :store-override="storeOverride"
472
- >
473
- <DetailTop
474
- v-if="isView && isDetail"
475
- :value="liveModel"
476
- />
477
- </Masthead>
478
- <div
479
- v-if="hasErrors"
480
- id="cru-errors"
481
- class="cru__errors"
482
- >
483
- <Banner
484
- v-for="(err, i) in errors"
485
- :key="i"
486
- color="error"
487
- :data-testid="`error-banner${i}`"
488
- :label="stringify(mappedErrors[err].message)"
489
- :icon="mappedErrors[err].icon"
490
- :closable="true"
491
- @close="closeError(i)"
492
- />
493
- </div>
494
-
495
- <ForceDirectedTreeChart
496
- v-if="isGraph && canViewChart"
497
- :data="chartData"
498
- :fdc-config="getGraphConfig"
499
- />
500
-
501
- <ResourceYaml
502
- v-else-if="isYaml"
503
- ref="resourceyaml"
504
- :value="value"
505
- :mode="mode"
506
- :yaml="yaml"
507
- :offer-preview="offerPreview"
508
- :done-route="doneRoute"
509
- :done-override="value ? value.doneOverride : null"
510
- @update:value="$emit('input', $event)"
511
- @error="e=>errors.push(e)"
512
- />
513
-
514
- <component
515
- :is="showComponent"
516
- v-else
517
- ref="comp"
518
- v-model:value="value"
519
- v-bind="$data"
520
- :done-params="doneParams"
521
- :done-route="doneRoute"
522
- :mode="mode"
523
- :initial-value="initialModel"
524
- :live-value="liveModel"
525
- :real-mode="realMode"
526
- :class="{'flex-content': flexContent}"
527
- @update:value="$emit('input', $event)"
528
- @update:mode="setMode"
529
- @set-subtype="setSubtype"
530
- />
531
-
532
- <button
533
- v-if="isView"
534
- v-shortkey.once="['shift','d']"
535
- :data-testid="componentTestid + '-detail'"
536
- class="hide"
537
- @shortkey="keyAction('goToDetail')"
538
- />
539
- <button
540
- v-if="isView"
541
- v-shortkey.once="['shift','c']"
542
- :data-testid="componentTestid + '-config'"
543
- class="hide"
544
- @shortkey="keyAction('goToViewConfig')"
545
- />
546
- <button
547
- v-if="isView"
548
- v-shortkey.once="['shift','y']"
549
- :data-testid="componentTestid + '-yaml'"
550
- class="hide"
551
- @shortkey="keyAction('goToViewYaml')"
552
- />
553
- <button
554
- v-if="isView"
555
- v-shortkey.once="['shift','e']"
556
- :data-testid="componentTestid + '-edit'"
557
- class="hide"
558
- @shortkey="keyAction('goToEdit')"
559
- />
560
- </div>
73
+ <Suspense v-if="useLatest">
74
+ <template #default>
75
+ <component :is="page" />
76
+ </template>
77
+ <template #fallback>
78
+ <Loading />
79
+ </template>
80
+ </Suspense>
81
+ <Legacy
82
+ v-else
83
+ v-bind="{...$attrs, ...props}"
84
+ />
561
85
  </template>
562
-
563
- <style lang='scss' scoped>
564
- .flex-content {
565
- display: flex;
566
- flex-direction: column;
567
- flex-grow: 1;
568
- }
569
- </style>