@rancher/shell 3.0.12-rc.1 → 3.0.12-rc.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (376) hide show
  1. package/apis/impl/apis.ts +6 -0
  2. package/apis/index.ts +26 -0
  3. package/apis/intf/resources-api/cluster-api.ts +18 -0
  4. package/apis/intf/resources-api/mgmt-api.ts +15 -0
  5. package/apis/intf/resources-api/resource-base.ts +107 -0
  6. package/apis/intf/resources-api/resource-constants.ts +147 -0
  7. package/apis/intf/resources-api/resources-api.ts +143 -0
  8. package/apis/intf/resources.ts +49 -0
  9. package/apis/intf/{modal.ts → shell-api/modal.ts} +21 -26
  10. package/apis/intf/shell-api/proxy.ts +216 -0
  11. package/apis/intf/{slide-in.ts → shell-api/slide-in.ts} +4 -3
  12. package/apis/intf/{system.ts → shell-api/system.ts} +4 -1
  13. package/apis/intf/shell.ts +12 -6
  14. package/apis/resources/__tests__/resources-api-class.test.ts +550 -0
  15. package/apis/resources/index.ts +22 -0
  16. package/apis/resources/resources-api-class.ts +187 -0
  17. package/apis/shell/__tests__/proxy.test.ts +369 -0
  18. package/apis/shell/index.ts +8 -1
  19. package/apis/shell/modal.ts +4 -1
  20. package/apis/shell/notifications.ts +9 -6
  21. package/apis/shell/proxy.ts +256 -0
  22. package/apis/shell/slide-in.ts +4 -1
  23. package/apis/vue-shim.d.ts +2 -1
  24. package/assets/data/aws-regions.json +4 -0
  25. package/assets/fonts/lato/LatoLatin-Black.woff +0 -0
  26. package/assets/fonts/lato/LatoLatin-Black.woff2 +0 -0
  27. package/assets/fonts/lato/LatoLatin-BlackItalic.woff +0 -0
  28. package/assets/fonts/lato/LatoLatin-BlackItalic.woff2 +0 -0
  29. package/assets/fonts/lato/LatoLatin-Bold.woff +0 -0
  30. package/assets/fonts/lato/LatoLatin-Bold.woff2 +0 -0
  31. package/assets/fonts/lato/LatoLatin-BoldItalic.woff +0 -0
  32. package/assets/fonts/lato/LatoLatin-BoldItalic.woff2 +0 -0
  33. package/assets/fonts/lato/LatoLatin-Heavy.woff +0 -0
  34. package/assets/fonts/lato/LatoLatin-Heavy.woff2 +0 -0
  35. package/assets/fonts/lato/LatoLatin-HeavyItalic.woff +0 -0
  36. package/assets/fonts/lato/LatoLatin-HeavyItalic.woff2 +0 -0
  37. package/assets/fonts/lato/LatoLatin-Italic.woff +0 -0
  38. package/assets/fonts/lato/LatoLatin-Italic.woff2 +0 -0
  39. package/assets/fonts/lato/LatoLatin-Light.woff +0 -0
  40. package/assets/fonts/lato/LatoLatin-Light.woff2 +0 -0
  41. package/assets/fonts/lato/LatoLatin-LightItalic.woff +0 -0
  42. package/assets/fonts/lato/LatoLatin-LightItalic.woff2 +0 -0
  43. package/assets/fonts/lato/LatoLatin-Medium.woff +0 -0
  44. package/assets/fonts/lato/LatoLatin-Medium.woff2 +0 -0
  45. package/assets/fonts/lato/LatoLatin-MediumItalic.woff +0 -0
  46. package/assets/fonts/lato/LatoLatin-MediumItalic.woff2 +0 -0
  47. package/assets/fonts/lato/LatoLatin-Regular.woff +0 -0
  48. package/assets/fonts/lato/LatoLatin-Regular.woff2 +0 -0
  49. package/assets/fonts/lato/LatoLatin-Semibold.woff +0 -0
  50. package/assets/fonts/lato/LatoLatin-Semibold.woff2 +0 -0
  51. package/assets/fonts/lato/LatoLatin-SemiboldItalic.woff +0 -0
  52. package/assets/fonts/lato/LatoLatin-SemiboldItalic.woff2 +0 -0
  53. package/assets/images/providers/entraid-black.svg +4 -0
  54. package/assets/images/providers/entraid.svg +9 -0
  55. package/assets/images/vendor/entraid.svg +9 -0
  56. package/assets/styles/app.scss +0 -1
  57. package/assets/styles/base/_variables.scss +2 -0
  58. package/assets/styles/fonts/_fontstack.scss +132 -8
  59. package/assets/translations/en-us.yaml +41 -22
  60. package/assets/translations/zh-hans.yaml +4 -8
  61. package/chart/__tests__/S3.test.ts +10 -3
  62. package/chart/monitoring/index.vue +10 -1
  63. package/components/ActionDropdownShell.vue +2 -1
  64. package/components/CountBox.vue +20 -0
  65. package/components/CreateDriver.vue +0 -12
  66. package/components/CruResourceFooter.vue +9 -5
  67. package/components/DetailText.vue +12 -3
  68. package/components/ExplorerProjectsNamespaces.vue +1 -1
  69. package/components/InstallHelmCharts.vue +2 -2
  70. package/components/LandingPagePreference.vue +14 -5
  71. package/components/Resource/Detail/Metadata/IdentifyingInformation/index.vue +15 -1
  72. package/components/Resource/Detail/Metadata/index.vue +6 -0
  73. package/components/Resource/Detail/ResourcePopover/index.vue +12 -1
  74. package/components/Resource/Detail/SpacedRow.vue +3 -1
  75. package/components/Resource/Detail/TitleBar/index.vue +10 -11
  76. package/components/ResourceList/Masthead.vue +12 -8
  77. package/components/SelectIconGrid.vue +5 -10
  78. package/components/SingleClusterInfo.vue +1 -0
  79. package/components/SortableTable/__tests__/sorting.test.ts +126 -0
  80. package/components/SortableTable/index.vue +6 -9
  81. package/components/SortableTable/selection.js +23 -5
  82. package/components/SortableTable/sorting.js +6 -3
  83. package/components/Wizard.vue +14 -13
  84. package/components/__tests__/CountBox.test.ts +72 -0
  85. package/components/__tests__/DetailText.test.ts +113 -0
  86. package/components/fleet/FleetBundles.vue +100 -12
  87. package/components/fleet/FleetClusterTargets/index.vue +54 -15
  88. package/components/fleet/__tests__/FleetClusterTargets.test.ts +149 -115
  89. package/components/fleet/__tests__/FleetClusters.test.ts +12 -12
  90. package/components/form/InputWithSelect.vue +18 -10
  91. package/components/form/KeyValue.vue +17 -1
  92. package/components/form/LabeledSelect.vue +101 -26
  93. package/components/form/NameNsDescription.vue +11 -0
  94. package/components/form/Security.vue +6 -2
  95. package/components/form/Select.vue +73 -56
  96. package/components/form/ServiceNameSelect.vue +13 -11
  97. package/components/form/WorkloadPorts.vue +2 -7
  98. package/components/form/__tests__/KeyValue.test.ts +66 -0
  99. package/components/form/__tests__/NodeScheduling.test.ts +9 -0
  100. package/components/form/__tests__/Security.test.ts +76 -0
  101. package/components/form/labeled-select-utils/useLabeledSelectPagination.ts +138 -0
  102. package/components/formatter/Autoscaler.vue +4 -4
  103. package/components/formatter/ClusterKubeVersion.vue +27 -0
  104. package/components/formatter/ClusterLink.vue +1 -7
  105. package/components/formatter/ClusterProvider.vue +6 -10
  106. package/components/formatter/FleetSummaryGraph.vue +0 -3
  107. package/components/formatter/MachineSummaryGraph.vue +1 -1
  108. package/components/formatter/PodsUsage.vue +2 -2
  109. package/components/formatter/__tests__/Autoscaler.test.ts +19 -22
  110. package/components/formatter/__tests__/FleetSummaryGraph.test.ts +216 -0
  111. package/components/formatter/__tests__/PodsUsage.test.ts +6 -10
  112. package/components/nav/Group.vue +7 -6
  113. package/components/nav/Header.vue +24 -3
  114. package/components/nav/NamespaceFilter.vue +2 -2
  115. package/components/nav/NotificationCenter/Notification.vue +4 -1
  116. package/components/nav/NotificationCenter/NotificationHeader.vue +20 -8
  117. package/components/nav/NotificationCenter/__tests__/NotificationHeader.test.ts +80 -0
  118. package/components/nav/TopLevelMenu.helper.ts +15 -3
  119. package/components/nav/TopLevelMenu.vue +16 -5
  120. package/components/nav/Type.vue +8 -7
  121. package/components/nav/WindowManager/index.vue +2 -1
  122. package/components/nav/WorkspaceSwitcher.vue +13 -0
  123. package/components/nav/__tests__/Group.test.ts +67 -0
  124. package/components/nav/__tests__/Header.test.ts +235 -0
  125. package/components/nav/__tests__/TopLevelMenu.test.ts +145 -21
  126. package/components/nav/__tests__/Type.test.ts +20 -3
  127. package/components/templates/default.vue +34 -4
  128. package/components/templates/home.vue +30 -25
  129. package/components/templates/plain.vue +31 -26
  130. package/components/templates/standalone.vue +17 -0
  131. package/composables/useFormValidation.ts +93 -0
  132. package/composables/useLabeledFormElement.ts +10 -2
  133. package/composables/useLabeledSelect.ts +60 -0
  134. package/composables/useUserRetentionValidation.ts +1 -49
  135. package/composables/useVeeValidateField.test.ts +159 -0
  136. package/composables/useVeeValidateField.ts +67 -0
  137. package/config/cookies.js +0 -1
  138. package/config/labels-annotations.js +1 -0
  139. package/config/pagination-table-headers.js +18 -1
  140. package/config/product/manager.js +82 -21
  141. package/config/query-params.js +1 -0
  142. package/config/router/routes.js +6 -8
  143. package/config/table-headers.js +20 -1
  144. package/config/types.js +2 -1
  145. package/core/__tests__/plugin-products.test.ts +1505 -30
  146. package/core/plugin-products-base.ts +137 -20
  147. package/core/plugin-products-helpers.ts +5 -4
  148. package/core/plugin-products.ts +4 -0
  149. package/core/plugin-types.ts +129 -4
  150. package/core/plugin.ts +15 -7
  151. package/core/productDebugger.js +9 -4
  152. package/core/types-provisioning.ts +43 -30
  153. package/core/types.ts +58 -19
  154. package/detail/__tests__/management.cattle.io.fleetworkspace.test.ts +128 -0
  155. package/detail/__tests__/pod.test.ts +41 -0
  156. package/detail/harvesterhci.io.management.cluster.vue +6 -2
  157. package/detail/management.cattle.io.fleetworkspace.vue +49 -0
  158. package/detail/pod.vue +1 -1
  159. package/detail/provisioning.cattle.io.cluster.vue +4 -10
  160. package/edit/__tests__/fleet.cattle.io.helmop.test.ts +9 -0
  161. package/edit/__tests__/kontainerDriver.test.ts +0 -13
  162. package/edit/__tests__/nodeDriver.test.ts +5 -11
  163. package/edit/__tests__/resources.cattle.io.restore.test.ts +9 -0
  164. package/edit/auditlog.cattle.io.auditpolicy/__tests__/__snapshots__/General.test.ts.snap +6 -0
  165. package/edit/auth/__tests__/azuread.test.ts +217 -34
  166. package/edit/auth/__tests__/oidc.test.ts +54 -0
  167. package/edit/auth/azuread.vue +123 -15
  168. package/edit/auth/oidc.vue +10 -2
  169. package/edit/kontainerDriver.vue +1 -2
  170. package/edit/networking.k8s.io.ingress/DefaultBackend.vue +13 -4
  171. package/edit/networking.k8s.io.ingress/RulePath.vue +8 -4
  172. package/edit/networking.k8s.io.ingress/index.vue +75 -20
  173. package/edit/nodeDriver.vue +0 -2
  174. package/edit/provisioning.cattle.io.cluster/AgentEnv.vue +1 -0
  175. package/edit/provisioning.cattle.io.cluster/__tests__/AgentEnv.test.ts +25 -0
  176. package/edit/provisioning.cattle.io.cluster/__tests__/MachinePool.test.ts +104 -0
  177. package/edit/provisioning.cattle.io.cluster/index.vue +81 -106
  178. package/edit/provisioning.cattle.io.cluster/rke2.vue +8 -4
  179. package/edit/provisioning.cattle.io.cluster/tabs/MachinePool.vue +11 -0
  180. package/edit/provisioning.cattle.io.cluster/tabs/registries/RegistryConfigs.vue +37 -4
  181. package/edit/provisioning.cattle.io.cluster/tabs/registries/__tests__/RegistryConfigs.test.ts +132 -7
  182. package/edit/provisioning.cattle.io.cluster/tabs/registries/index.vue +2 -1
  183. package/edit/secret/__tests__/ssh.test.ts +5 -6
  184. package/edit/secret/basic.vue +31 -0
  185. package/edit/secret/index.vue +68 -17
  186. package/edit/secret/registry.vue +38 -0
  187. package/edit/secret/ssh.vue +29 -0
  188. package/edit/secret/tls.vue +30 -0
  189. package/edit/service.vue +4 -4
  190. package/edit/workload/Upgrading.vue +3 -3
  191. package/edit/workload/__tests__/Upgrading.test.ts +6 -9
  192. package/edit/workload/mixins/workload.js +2 -1
  193. package/initialize/App.vue +29 -2
  194. package/initialize/install-plugins.js +0 -2
  195. package/list/__tests__/management.cattle.io.feature.test.ts +105 -0
  196. package/list/catalog.cattle.io.app.vue +25 -5
  197. package/list/fleet.cattle.io.bundle.vue +7 -104
  198. package/list/fleet.cattle.io.clusterregistrationtoken.vue +20 -0
  199. package/list/management.cattle.io.feature.vue +1 -1
  200. package/list/management.cattle.io.fleetworkspace.vue +8 -0
  201. package/list/provisioning.cattle.io.cluster.vue +262 -180
  202. package/list/utils/management.cattle.io.cluster.utils.ts +128 -0
  203. package/machine-config/amazonec2.vue +1 -0
  204. package/mixins/__tests__/chart.test.ts +112 -0
  205. package/mixins/brand.js +2 -1
  206. package/mixins/chart.js +50 -15
  207. package/mixins/resource-fetch-api-pagination.js +41 -5
  208. package/models/__tests__/catalog.cattle.io.app.test.ts +15 -1
  209. package/models/__tests__/catalog.cattle.io.clusterrepo.test.ts +84 -0
  210. package/models/__tests__/chart.test.ts +99 -6
  211. package/models/__tests__/ext.cattle.io.kubeconfig.test.ts +67 -67
  212. package/models/__tests__/management.cattle.io.cluster.test.ts +1 -1
  213. package/models/__tests__/management.cattle.io.feature.test.ts +131 -0
  214. package/models/__tests__/management.cattle.io.node.ts +6 -5
  215. package/models/__tests__/management.cattle.io.nodepool.ts +5 -4
  216. package/models/__tests__/monitoring.coreos.com.alertmanagerconfig.test.ts +98 -0
  217. package/models/__tests__/provisioning.cattle.io.cluster.test.ts +32 -11
  218. package/models/base-cluster.x-k8s.io.js +26 -0
  219. package/models/catalog.cattle.io.app.js +21 -17
  220. package/models/catalog.cattle.io.clusterrepo.js +39 -11
  221. package/models/chart.js +33 -19
  222. package/models/cluster.js +1 -1
  223. package/models/cluster.x-k8s.io.machine.js +4 -22
  224. package/models/cluster.x-k8s.io.machinedeployment.js +2 -20
  225. package/models/cluster.x-k8s.io.machineset.js +2 -20
  226. package/models/compliance.cattle.io.clusterscan.js +130 -2
  227. package/models/ext.cattle.io.kubeconfig.ts +4 -7
  228. package/models/fleet-application.js +4 -2
  229. package/models/fleet.cattle.io.bundle.js +1 -1
  230. package/models/kontainerdriver.js +11 -0
  231. package/models/management.cattle.io.authconfig.js +5 -1
  232. package/models/management.cattle.io.cluster.js +402 -78
  233. package/models/management.cattle.io.feature.js +3 -3
  234. package/models/management.cattle.io.kontainerdriver.js +1 -26
  235. package/models/management.cattle.io.node.js +6 -4
  236. package/models/management.cattle.io.nodepool.js +1 -1
  237. package/models/monitoring.coreos.com.alertmanagerconfig.js +31 -17
  238. package/models/networking.k8s.io.ingress.js +12 -4
  239. package/models/nodedriver.js +7 -0
  240. package/models/provisioning.cattle.io.cluster.js +47 -330
  241. package/models/rke.cattle.io.etcdsnapshot.js +1 -2
  242. package/package.json +20 -37
  243. package/pages/__tests__/readme.test.ts +49 -0
  244. package/pages/auth/setup.vue +2 -3
  245. package/pages/c/_cluster/apps/charts/__tests__/chart.test.ts +265 -0
  246. package/pages/c/_cluster/apps/charts/__tests__/index.test.ts +55 -0
  247. package/pages/c/_cluster/apps/charts/__tests__/install.test.ts +53 -0
  248. package/pages/c/_cluster/apps/charts/chart.vue +275 -39
  249. package/pages/c/_cluster/apps/charts/index.vue +2 -2
  250. package/pages/c/_cluster/apps/charts/install.vue +18 -10
  251. package/pages/c/_cluster/auth/user.retention/index.vue +55 -22
  252. package/pages/c/_cluster/explorer/__tests__/index.test.ts +23 -25
  253. package/pages/c/_cluster/explorer/index.vue +5 -49
  254. package/pages/c/_cluster/istio/__tests__/istio.index.test.ts +194 -0
  255. package/pages/c/_cluster/istio/index.vue +21 -6
  256. package/pages/c/_cluster/manager/drivers/kontainerDriver/index.vue +5 -7
  257. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +40 -2
  258. package/pages/c/_cluster/uiplugins/__tests__/PluginInfoPanel.test.ts +61 -0
  259. package/pages/c/_cluster/uiplugins/__tests__/index.test.ts +735 -13
  260. package/pages/c/_cluster/uiplugins/index.vue +226 -222
  261. package/pages/diagnostic.vue +13 -17
  262. package/pages/fail-whale.vue +18 -0
  263. package/pages/home.vue +77 -260
  264. package/pages/readme.vue +88 -0
  265. package/plugins/dashboard-store/__tests__/resource-class.test.ts +88 -0
  266. package/plugins/dashboard-store/actions.js +40 -18
  267. package/plugins/dashboard-store/resource-class.js +5 -2
  268. package/plugins/steve/__tests__/subscribe.spec.ts +6 -3
  269. package/plugins/steve/steve-pagination-utils.ts +11 -3
  270. package/plugins/steve/subscribe.js +35 -5
  271. package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +211 -1
  272. package/rancher-components/Form/LabeledInput/LabeledInput.vue +37 -4
  273. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +1 -1
  274. package/rancher-components/RcButton/RcButton.test.ts +37 -1
  275. package/rancher-components/RcButton/RcButton.vue +38 -8
  276. package/rancher-components/RcDropdown/RcDropdownTrigger.vue +10 -8
  277. package/scripts/test-plugins-build.sh +5 -2
  278. package/server/server-middleware.js +2 -2
  279. package/static/humans.txt +1 -0
  280. package/static/robots.txt +34 -0
  281. package/static/welcome-cow.svg +18 -0
  282. package/store/__tests__/catalog.test.ts +276 -12
  283. package/store/__tests__/type-map.test.ts +556 -1
  284. package/store/action-menu.js +8 -3
  285. package/store/auth.js +1 -4
  286. package/store/aws.js +27 -16
  287. package/store/catalog.js +87 -11
  288. package/store/digitalocean.js +20 -38
  289. package/store/index.js +2 -0
  290. package/store/linode.js +25 -40
  291. package/store/pnap.js +1 -0
  292. package/store/type-map.js +111 -29
  293. package/tsconfig.paths.json +8 -8
  294. package/types/kube/kube-api.ts +14 -1
  295. package/types/rancher/steve.api.ts +12 -12
  296. package/types/resources/settings.d.ts +2 -1
  297. package/types/shell/index.d.ts +128 -24
  298. package/types/store/dashboard-store.types.ts +108 -11
  299. package/types/store/pagination.types.ts +6 -3
  300. package/utils/__tests__/alertmanagerconfig.test.ts +117 -0
  301. package/utils/__tests__/async.test.ts +87 -0
  302. package/utils/__tests__/aws.test.ts +140 -0
  303. package/utils/__tests__/banners.test.ts +176 -0
  304. package/utils/__tests__/chart.test.ts +64 -1
  305. package/utils/__tests__/color.test.ts +226 -0
  306. package/utils/__tests__/duration.test.ts +140 -0
  307. package/utils/__tests__/fleet.test.ts +340 -0
  308. package/utils/__tests__/git.test.ts +270 -0
  309. package/utils/__tests__/inactivity.test.ts +316 -0
  310. package/utils/__tests__/ingress.test.ts +553 -0
  311. package/utils/__tests__/kube.test.ts +68 -0
  312. package/utils/__tests__/namespace-filter.test.ts +109 -0
  313. package/utils/__tests__/object.test.ts +77 -0
  314. package/utils/__tests__/pagination-utils.test.ts +361 -0
  315. package/utils/__tests__/parse-externalid.test.ts +137 -0
  316. package/utils/__tests__/perf-setting.utils.test.ts +98 -0
  317. package/utils/__tests__/poller-sequential.test.ts +177 -0
  318. package/utils/__tests__/poller.test.ts +170 -0
  319. package/utils/__tests__/promise.test.ts +346 -0
  320. package/utils/__tests__/settings.test.ts +140 -0
  321. package/utils/__tests__/sort-utils.test.ts +301 -0
  322. package/utils/__tests__/string-utils.test.ts +798 -0
  323. package/utils/__tests__/string.test.ts +23 -1
  324. package/utils/__tests__/style.test.ts +154 -0
  325. package/utils/__tests__/svg-filter.test.ts +184 -0
  326. package/utils/__tests__/time.test.ts +14 -1
  327. package/utils/__tests__/units.test.ts +417 -0
  328. package/utils/__tests__/url.test.ts +246 -0
  329. package/utils/__tests__/versions.test.ts +128 -0
  330. package/utils/__tests__/xccdf.test.ts +391 -0
  331. package/utils/chart.js +36 -0
  332. package/utils/fleet.ts +13 -3
  333. package/utils/gatekeeper/__tests__/util.test.ts +174 -0
  334. package/utils/gc/__tests__/gc-interval.test.ts +119 -0
  335. package/utils/gc/__tests__/gc-root-store.test.ts +225 -0
  336. package/utils/gc/__tests__/gc-route-changed.test.ts +96 -0
  337. package/utils/gc/__tests__/gc.test.ts +487 -0
  338. package/utils/ingress.ts +9 -1
  339. package/utils/object.js +33 -2
  340. package/utils/pagination-utils.ts +2 -1
  341. package/utils/string.js +25 -2
  342. package/utils/time.ts +5 -0
  343. package/utils/uiplugins.ts +5 -5
  344. package/utils/validators/__tests__/cluster-name.test.ts +110 -0
  345. package/utils/validators/__tests__/cron-schedule.test.ts +79 -0
  346. package/utils/validators/__tests__/index.test.ts +481 -0
  347. package/utils/validators/__tests__/kubernetes-name.test.ts +163 -0
  348. package/utils/validators/__tests__/misc-validators.test.ts +246 -0
  349. package/utils/validators/__tests__/pod-affinity.test.ts +382 -0
  350. package/utils/validators/__tests__/prometheusrule.test.ts +211 -0
  351. package/utils/validators/__tests__/role-template.test.ts +149 -0
  352. package/utils/validators/__tests__/service.test.ts +283 -0
  353. package/utils/validators/__tests__/setting.test.js +32 -0
  354. package/utils/validators/formRules/__tests__/index.test.ts +50 -0
  355. package/utils/validators/formRules/index.ts +5 -5
  356. package/utils/validators/machine-pool.ts +1 -1
  357. package/utils/validators/setting.js +18 -3
  358. package/utils/xccdf.ts +418 -0
  359. package/vue.config.js +0 -9
  360. package/assets/fonts/lato/lato-v17-latin-700.woff +0 -0
  361. package/assets/fonts/lato/lato-v17-latin-700.woff2 +0 -0
  362. package/assets/fonts/lato/lato-v17-latin-regular.woff +0 -0
  363. package/assets/fonts/lato/lato-v17-latin-regular.woff2 +0 -0
  364. package/assets/images/providers/azuread-black.svg +0 -22
  365. package/assets/images/providers/azuread.svg +0 -25
  366. package/assets/images/vendor/azuread.svg +0 -18
  367. package/assets/styles/fonts/_dots.scss +0 -18
  368. package/components/EmberPage.vue +0 -622
  369. package/components/EmberPageView.vue +0 -39
  370. package/components/form/labeled-select-utils/labeled-select-pagination.ts +0 -116
  371. package/mixins/labeled-form-element.ts +0 -225
  372. package/pages/c/_cluster/explorer/tools/pages/_page.vue +0 -28
  373. package/pages/c/_cluster/manager/pages/_page.vue +0 -22
  374. package/pages/c/_cluster/mcapps/pages/_page.vue +0 -22
  375. package/plugins/ember-cookie.js +0 -17
  376. package/utils/ember-page.js +0 -30
@@ -1,7 +1,10 @@
1
1
  <script>
2
2
  import { _EDIT } from '@shell/config/query-params';
3
+ import { useStore } from 'vuex';
3
4
  import { LabeledInput } from '@components/Form/LabeledInput';
4
5
  import FileSelector, { createOnSelected } from '@shell/components/form/FileSelector';
6
+ import { useFormRules } from '@shell/composables/useFormValidation';
7
+ import { useI18n } from '@shell/composables/useI18n';
5
8
 
6
9
  export default {
7
10
  components: { LabeledInput, FileSelector },
@@ -18,6 +21,28 @@ export default {
18
21
  }
19
22
  },
20
23
 
24
+ setup() {
25
+ const store = useStore();
26
+ const { t } = useI18n(store);
27
+ const { getRules } = useFormRules(
28
+ t,
29
+ [
30
+ {
31
+ path: 'tls.key',
32
+ rules: ['required'],
33
+ translationKey: 'secret.certificate.privateKey',
34
+ },
35
+ {
36
+ path: 'tls.crt',
37
+ rules: ['required'],
38
+ translationKey: 'secret.certificate.certificate',
39
+ },
40
+ ]
41
+ );
42
+
43
+ return { getRules };
44
+ },
45
+
21
46
  data() {
22
47
  // do not show existing key when editing
23
48
  const originalKey = this.value.decodedData['tls.key'] || '';
@@ -63,9 +88,12 @@ export default {
63
88
  <div class="col span-6">
64
89
  <LabeledInput
65
90
  v-model:value="key"
91
+ name="tls.key"
92
+ required
66
93
  type="multiline"
67
94
  :label="t('secret.certificate.privateKey')"
68
95
  :mode="mode"
96
+ :rules="getRules('tls.key')"
69
97
  :placeholder="t('secret.certificate.privateKeyPlaceholder')"
70
98
  />
71
99
  <FileSelector
@@ -77,10 +105,12 @@ export default {
77
105
  <div class="col span-6">
78
106
  <LabeledInput
79
107
  v-model:value="crt"
108
+ name="tls.crt"
80
109
  required
81
110
  type="multiline"
82
111
  :label="t('secret.certificate.certificate')"
83
112
  :mode="mode"
113
+ :rules="getRules('tls.crt')"
84
114
  :placeholder="t('secret.certificate.certificatePlaceholder')"
85
115
  />
86
116
  <FileSelector
package/edit/service.vue CHANGED
@@ -203,10 +203,9 @@ export default {
203
203
  },
204
204
 
205
205
  provisioningCluster() {
206
- const out = this.$store.getters['management/all'](CAPI.RANCHER_CLUSTER).find((c) => c?.status?.clusterName === this.currentCluster.metadata.name);
207
-
208
- return out;
206
+ return this.currentCluster.provCluster;
209
207
  },
208
+
210
209
  errorMessages() {
211
210
  if (!this.serviceType) {
212
211
  return [];
@@ -273,8 +272,9 @@ export default {
273
272
  const hash = {};
274
273
 
275
274
  if (this.$store.getters[`management/canList`](CAPI.RANCHER_CLUSTER)) {
276
- hash.provClusters = this.$store.dispatch('management/findAll', { type: CAPI.RANCHER_CLUSTER });
275
+ hash.provClusters = this.$store.dispatch('management/find', { type: CAPI.RANCHER_CLUSTER, id: this.currentCluster.provClusterId });
277
276
  }
277
+
278
278
  if (this.$store.getters[`management/canList`](HCI.HARVESTER_CONFIG)) {
279
279
  hash.harvesterConfigs = this.$store.dispatch(`management/findAll`, { type: HCI.HARVESTER_CONFIG });
280
280
  }
@@ -133,10 +133,10 @@ export default {
133
133
  } = this;
134
134
  let { maxSurge, maxUnavailable } = this;
135
135
 
136
- if (this.surgeUnits === '%' && !maxSurge.includes('%')) {
136
+ if (this.surgeUnits === '%' && !`${ maxSurge }`.includes('%')) {
137
137
  maxSurge = `${ maxSurge }%`;
138
138
  }
139
- if (this.unavailableUnits === '%' && !maxUnavailable.includes('%')) {
139
+ if (this.unavailableUnits === '%' && !`${ maxUnavailable }`.includes('%')) {
140
140
  maxUnavailable = `${ maxUnavailable }%`;
141
141
  }
142
142
 
@@ -204,7 +204,7 @@ export default {
204
204
  if (units === 'Pods') {
205
205
  this[target] = parseInt(value);
206
206
  } else {
207
- this[target] = `${ value }%`;
207
+ this[target] = value;
208
208
  }
209
209
  if (target === 'maxSurge') {
210
210
  this.surgeUnits = units;
@@ -25,20 +25,17 @@ describe('component: Upgrading', () => {
25
25
  expect(wrapper.props('value')?.[key]).toBe(newValue);
26
26
  });
27
27
 
28
- // TODO: #6179: Integrate test with component fix, as the scope is not to check the value of the input
29
- // eslint-disable-next-line jest/no-disabled-tests
30
- it.skip.each([
31
- ['surge', 'maxSurge', '%'],
32
- ['unavailable', 'maxUnavailable', '%'],
33
- ])('should set typed value in %p into %p and unit', (field, key, unit) => {
28
+ it.each([
29
+ ['maxSurge', '%'],
30
+ ['maxUnavailable', '%'],
31
+ ])('should set typed value in %p with %p unit', (key, unit) => {
34
32
  const wrapper = mount(Upgrading);
35
- const input = wrapper.find(`[data-testid="input-policy-${ field }"]`).find('input');
36
33
  const newValue = 123;
37
34
  const expectation = `${ newValue }${ unit }`;
38
35
 
39
- input.setValue(newValue);
40
- input.trigger('blur');
36
+ wrapper.vm.updateWithUnits({ selected: unit, text: newValue }, key);
41
37
 
38
+ expect(wrapper.vm[key]).toBe(newValue);
42
39
  expect(wrapper.props('value')?.strategy.rollingUpdate[key]).toBe(expectation);
43
40
  });
44
41
 
@@ -151,7 +151,8 @@ export default {
151
151
  const fetches = {};
152
152
 
153
153
  if (this.$store.getters[`management/canList`](CAPI.RANCHER_CLUSTER)) {
154
- fetches.rancherClusters = this.$store.dispatch('management/findAll', { type: CAPI.RANCHER_CLUSTER });
154
+ // I could only find one place where a prov cluster might be used by this and parent components - shell/components/form/WorkloadPorts.vue provisioningCluster
155
+ fetches.rancherCluster = this.$store.dispatch('management/find', { type: CAPI.RANCHER_CLUSTER, id: this.currentCluster.provClusterId });
155
156
  }
156
157
 
157
158
  if (this.$store.getters[`management/canList`](HCI.HARVESTER_CONFIG)) {
@@ -1,10 +1,16 @@
1
1
  <script>
2
2
  import GlobalLoading from '@shell/components/nav/GlobalLoading.vue';
3
+ import WindowManager from '@shell/components/nav/WindowManager';
3
4
 
4
5
  import '@shell/assets/styles/app.scss';
5
6
 
6
7
  export default {
7
- data: () => ({ isOnline: true }),
8
+ data() {
9
+ return {
10
+ isOnline: true,
11
+ currentLayout: null,
12
+ };
13
+ },
8
14
 
9
15
  created() {
10
16
  // add to window so we can listen when ready
@@ -36,6 +42,14 @@ export default {
36
42
  this.$loading = this.$refs.loading;
37
43
  },
38
44
 
45
+ provide() {
46
+ return {
47
+ notifyWmContainerReady: (layout) => {
48
+ this.currentLayout = layout;
49
+ }
50
+ };
51
+ },
52
+
39
53
  computed: {
40
54
  isOffline() {
41
55
  return !this.isOnline;
@@ -55,7 +69,10 @@ export default {
55
69
  },
56
70
  },
57
71
 
58
- components: { GlobalLoading }
72
+ components: {
73
+ GlobalLoading,
74
+ WindowManager,
75
+ }
59
76
  };
60
77
  </script>
61
78
  <template>
@@ -65,6 +82,16 @@ export default {
65
82
  id="__layout"
66
83
  >
67
84
  <router-view />
85
+ <!--
86
+ WindowManager is teleported into each template's wm-container
87
+ This keeps a single instance that never re-mounts while appearing in each template
88
+ -->
89
+ <Teleport
90
+ v-if="currentLayout"
91
+ :to="`#wm-container-${currentLayout}`"
92
+ >
93
+ <WindowManager :layout="currentLayout" />
94
+ </Teleport>
68
95
  </div>
69
96
  </div>
70
97
  </template>
@@ -21,7 +21,6 @@ import plugin from '@shell/plugins/plugin';
21
21
  import pluginsLoader from '@shell/core/plugins-loader.js';
22
22
  import replaceAll from '@shell/plugins/replaceall';
23
23
  import steveCreateWorker from '@shell/plugins/steve-create-worker';
24
- import emberCookie from '@shell/plugins/ember-cookie';
25
24
  import ShortKey from '@shell/plugins/shortkey';
26
25
  import { initUiApis } from '@shell/apis/impl/apis';
27
26
 
@@ -57,7 +56,6 @@ export async function installInjectedPlugins(app, vueApp) {
57
56
  replaceAll,
58
57
  plugin,
59
58
  steveCreateWorker,
60
- emberCookie,
61
59
  dynamicContent,
62
60
  ];
63
61
 
@@ -0,0 +1,105 @@
1
+ import { shallowMount } from '@vue/test-utils';
2
+
3
+ jest.mock('@shell/mixins/resource-fetch', () => ({
4
+ __esModule: true,
5
+ default: {
6
+ data() {
7
+ return {
8
+ forceUpdateLiveAndDelayed: 0, loading: false, rows: []
9
+ };
10
+ },
11
+ async $fetchType() {}
12
+ }
13
+ }));
14
+
15
+ // eslint-disable-next-line import/first
16
+ import ManagementFeature from '@shell/list/management.cattle.io.feature.vue';
17
+
18
+ const createMockStore = () => ({
19
+ getters: {
20
+ 'i18n/t': (key: string) => key,
21
+ 'management/schemaFor': () => ({ resourceMethods: ['PUT'] }),
22
+ },
23
+ dispatch: jest.fn(),
24
+ });
25
+
26
+ const createWrapper = (rows: any[]) => {
27
+ return shallowMount(ManagementFeature, {
28
+ props: {
29
+ resource: 'management.cattle.io.feature',
30
+ schema: { id: 'management.cattle.io.feature' } as any,
31
+ },
32
+ data: () => ({ rows }),
33
+ global: {
34
+ mocks: {
35
+ $store: createMockStore(),
36
+ $fetchState: { pending: false },
37
+ $fetchType: jest.fn(),
38
+ },
39
+ stubs: {
40
+ // Render the cell:name slot directly so we can assert on the lock icon
41
+ ResourceTable: {
42
+ props: ['rows'],
43
+ template: '<div><slot name="cell:name" :row="rows[0]" /></div>',
44
+ },
45
+ },
46
+ }
47
+ });
48
+ };
49
+
50
+ describe('list/management.cattle.io.feature', () => {
51
+ describe('locked icon rendering in cell:name slot', () => {
52
+ it('should render the lock icon when status.lockedValue is not null', () => {
53
+ const row = {
54
+ metadata: { name: 'feature-a' },
55
+ nameDisplay: 'feature-a',
56
+ status: { lockedValue: true },
57
+ };
58
+
59
+ const wrapper = createWrapper([row]);
60
+
61
+ expect(wrapper.find('i.icon-lock').exists()).toBe(true);
62
+ });
63
+
64
+ it('should not render the lock icon when status.lockedValue is null', () => {
65
+ const row = {
66
+ metadata: { name: 'feature-a' },
67
+ nameDisplay: 'feature-a',
68
+ status: { lockedValue: null },
69
+ };
70
+
71
+ const wrapper = createWrapper([row]);
72
+
73
+ expect(wrapper.find('i.icon-lock').exists()).toBe(false);
74
+ });
75
+
76
+ it('should not throw and should not render the lock icon when status is missing (malformed feature flag)', () => {
77
+ const row = {
78
+ metadata: { name: 'feature-a' },
79
+ nameDisplay: 'feature-a',
80
+ };
81
+
82
+ expect(() => createWrapper([row])).not.toThrow();
83
+
84
+ const wrapper = createWrapper([row]);
85
+
86
+ expect(wrapper.find('i.icon-lock').exists()).toBe(false);
87
+ });
88
+ });
89
+
90
+ describe('filteredRows', () => {
91
+ it('should filter out hidden feature flags', () => {
92
+ const rows = [
93
+ { metadata: { name: 'fleet' } },
94
+ { metadata: { name: 'some-feature' } },
95
+ ];
96
+
97
+ const wrapper = createWrapper(rows);
98
+
99
+ const filtered = (wrapper.vm as any).filteredRows;
100
+
101
+ expect(filtered).toHaveLength(1);
102
+ expect(filtered[0].metadata.name).toBe('some-feature');
103
+ });
104
+ });
105
+ });
@@ -40,14 +40,15 @@ export default {
40
40
  data-testid="installed-app-catalog-list"
41
41
  >
42
42
  <template #cell:upgrade="{row}">
43
- <span
43
+ <div
44
44
  v-if="row.upgradeAvailable === APP_UPGRADE_STATUS.SINGLE_UPGRADE"
45
- class="badge-state bg-warning hand"
45
+ v-clean-tooltip="row.upgradeAvailableVersion"
46
+ class="badge-state bg-warning hand app-upgrade-badge"
46
47
  @click="row.goToUpgrade(row.upgradeAvailableVersion)"
47
48
  >
48
- {{ row.upgradeAvailableVersion }}
49
+ <div>{{ row.upgradeAvailableVersion }}</div>
49
50
  <i class="icon icon-upload" />
50
- </span>
51
+ </div>
51
52
  <span
52
53
  v-else-if="row.upgradeAvailable === APP_UPGRADE_STATUS.NOT_APPLICABLE"
53
54
  v-t="'catalog.app.managed'"
@@ -69,8 +70,27 @@ export default {
69
70
  </PaginatedResourceTable>
70
71
  </template>
71
72
 
72
- <style scoped>
73
+ <style scoped lang="scss">
73
74
  .apps :deep() .state-description{
74
75
  color: var(--error)
75
76
  }
77
+
78
+ .badge-state.app-upgrade-badge {
79
+ display: inline-flex;
80
+ align-items: center;
81
+ border-radius: var(--border-radius);
82
+ padding: 2px 4px;
83
+
84
+ > div {
85
+ overflow: hidden;
86
+ text-overflow: ellipsis;
87
+ white-space: nowrap;
88
+ min-width: 0;
89
+ }
90
+
91
+ > .icon {
92
+ flex-shrink: 0;
93
+ }
94
+ }
95
+
76
96
  </style>
@@ -1,19 +1,9 @@
1
1
  <script>
2
- import { FLEET } from '@shell/config/types';
3
- import { Banner } from '@components/Banner';
4
- import ResourceTable from '@shell/components/ResourceTable';
5
- import ResourceFetch from '@shell/mixins/resource-fetch';
6
- import {
7
- AGE,
8
- STATE,
9
- NAME,
10
- } from '@shell/config/table-headers';
11
- import { isHarvesterCluster } from '@shell/utils/cluster';
2
+ import FleetBundles from '@shell/components/fleet/FleetBundles';
12
3
 
13
4
  export default {
14
5
  name: 'ListBundle',
15
- components: { Banner, ResourceTable },
16
- mixins: [ResourceFetch],
6
+ components: { FleetBundles },
17
7
  props: {
18
8
  resource: {
19
9
  type: String,
@@ -28,100 +18,13 @@ export default {
28
18
  default: false
29
19
  }
30
20
  },
31
-
32
- async fetch() {
33
- await this.$fetchType(this.resource);
34
- if (this.$store.getters['management/schemaFor']( FLEET.CLUSTER )) {
35
- this.allFleet = await this.$store.getters['management/all'](FLEET.CLUSTER);
36
- }
37
- },
38
-
39
- data() {
40
- return { allFleet: [] };
41
- },
42
-
43
- computed: {
44
- harvesterClusters() {
45
- const harvester = {};
46
-
47
- this.allFleet.forEach((c) => {
48
- if (isHarvesterCluster(c)) {
49
- harvester[c.metadata.name] = c;
50
- }
51
- });
52
-
53
- return harvester;
54
- },
55
-
56
- bundles() {
57
- const harvester = this.harvesterClusters;
58
-
59
- return this.rows.filter((bundle) => {
60
- const targets = bundle.spec?.targets || [];
61
-
62
- // Filter out any bundle that has one target whose cluster is a harvester cluster
63
- if (targets.length === 1) {
64
- return !harvester[targets[0].clusterName];
65
- }
66
-
67
- return true;
68
- });
69
- },
70
-
71
- hidden() {
72
- return this.rows.length - this.bundles.length;
73
- },
74
-
75
- headers() {
76
- const out = [
77
- STATE,
78
- NAME,
79
- {
80
- name: 'deploymentsReady',
81
- labelKey: 'tableHeaders.bundleDeploymentsReady',
82
- value: 'status.display.readyClusters',
83
- sort: 'status.display.readyClusters',
84
- search: ['status.summary.ready', 'status.summary.desiredReady'],
85
- },
86
- AGE
87
- ];
88
-
89
- return out;
90
- },
91
- },
92
-
93
- // override with relevant info for the loading indicator since this doesn't use it's own masthead
94
- $loadingResources() {
95
- // results are filtered so we wouldn't get the correct count on indicator...
96
- return { loadIndeterminate: true };
97
- },
98
21
  };
99
22
  </script>
100
23
 
101
24
  <template>
102
- <div>
103
- <Banner
104
- v-if="hidden"
105
- color="info"
106
- :label="t('fleet.bundles.harvester', {count: hidden} )"
107
- />
108
- <ResourceTable
109
- :schema="schema"
110
- :headers="headers"
111
- :rows="bundles"
112
- :loading="loading"
113
- :use-query-params-for-simple-filtering="useQueryParamsForSimpleFiltering"
114
- :force-update-live-and-delayed="forceUpdateLiveAndDelayed"
115
- >
116
- <template #cell:deploymentsReady="{row}">
117
- <span
118
- v-if="row.status && row.status.summary && (row.status.summary.desiredReady !== row.status.summary.ready)"
119
- class="text-warning"
120
- >
121
- {{ row.status.summary.ready || 0 }}/{{ row.status.summary.desiredReady }}</span>
122
- <span v-else-if="row.status && row.status.summary">{{ row.status.summary.desiredReady }}</span>
123
- <span v-else>-</span>
124
- </template>
125
- </ResourceTable>
126
- </div>
25
+ <FleetBundles
26
+ :resource="resource"
27
+ :schema="schema"
28
+ :use-query-params-for-simple-filtering="useQueryParamsForSimpleFiltering"
29
+ />
127
30
  </template>
@@ -4,6 +4,8 @@ import { Banner } from '@components/Banner';
4
4
  import ResourceTable from '@shell/components/ResourceTable';
5
5
  import { isHarvesterCluster } from '@shell/utils/cluster';
6
6
  import ResourceFetch from '@shell/mixins/resource-fetch';
7
+ import { HARVESTER_CONTAINER } from '@shell/store/features';
8
+ import { checkSchemasForFindAllHash } from '@shell/utils/auth';
7
9
 
8
10
  export default {
9
11
  name: 'ListClusterGroup',
@@ -25,6 +27,16 @@ export default {
25
27
  },
26
28
 
27
29
  async fetch() {
30
+ try {
31
+ await checkSchemasForFindAllHash({
32
+ cluster: {
33
+ inStoreType: 'management',
34
+ type: FLEET.CLUSTER
35
+ },
36
+ }, this.$store);
37
+ } catch (e) {
38
+ }
39
+
28
40
  await this.$fetchType(this.resource);
29
41
  if (this.$store.getters['management/schemaFor']( FLEET.CLUSTER )) {
30
42
  this.allFleet = await this.$store.getters['management/all'](FLEET.CLUSTER);
@@ -35,6 +47,10 @@ export default {
35
47
  return { allFleet: [] };
36
48
  },
37
49
 
50
+ mounted() {
51
+ this.areHarvesterHostsVisible = this.$store.getters['features/get'](HARVESTER_CONTAINER);
52
+ },
53
+
38
54
  computed: {
39
55
  harvesterClusters() {
40
56
  const harvester = {};
@@ -50,6 +66,10 @@ export default {
50
66
  tokens() {
51
67
  const harvester = this.harvesterClusters;
52
68
 
69
+ if (this.areHarvesterHostsVisible) {
70
+ return this.rows;
71
+ }
72
+
53
73
  return this.rows.filter((token) => {
54
74
  const refs = token.metadata?.ownerReferences || [];
55
75
 
@@ -69,7 +69,7 @@ export default {
69
69
  <div class="feature-name">
70
70
  <div>{{ scope.row.nameDisplay }}</div>
71
71
  <i
72
- v-if="scope.row.status.lockedValue !== null"
72
+ v-if="scope.row.status && scope.row.status.lockedValue !== null"
73
73
  class="icon icon-lock"
74
74
  />
75
75
  </div>
@@ -21,6 +21,14 @@ export default {
21
21
  }
22
22
  },
23
23
 
24
+ created() {
25
+ this.$store.dispatch('showWorkspaceSwitcher', false);
26
+ },
27
+
28
+ beforeUnmount() {
29
+ this.$store.dispatch('showWorkspaceSwitcher', true);
30
+ },
31
+
24
32
  async fetch() {
25
33
  try {
26
34
  await this.$fetchType(this.resource);