@rancher/shell 0.3.0 → 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 (322) 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 +4 -4
  6. package/assets/styles/themes/_light.scss +4 -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 +669 -73
  10. package/assets/translations/zh-hans.yaml +547 -165
  11. package/chart/monitoring/steps/uninstall-v1.vue +2 -2
  12. package/cloud-credential/azure.vue +23 -0
  13. package/cloud-credential/harvester.vue +25 -62
  14. package/cloud-credential/pnap.vue +80 -0
  15. package/components/.DS_Store +0 -0
  16. package/components/AdvancedSection.vue +9 -2
  17. package/components/Alert.vue +2 -2
  18. package/components/ButtonDropdown.vue +0 -2
  19. package/components/ButtonGroup.vue +1 -0
  20. package/components/CollapsibleCard.vue +0 -1
  21. package/components/CruResource.vue +41 -4
  22. package/components/DetailTop.vue +58 -3
  23. package/components/DisableAuthProviderModal.vue +106 -0
  24. package/{rancher-components/components/Utils/DraggableZone → components}/DraggableZone.vue +0 -0
  25. package/components/ExplorerMembers.vue +253 -30
  26. package/components/ExplorerProjectsNamespaces.vue +77 -33
  27. package/components/GrowlManager.vue +3 -3
  28. package/components/IconOrSvg.vue +149 -0
  29. package/components/LogItem.vue +69 -0
  30. package/components/PodSecurityAdmission.vue +302 -0
  31. package/components/PromptModal.vue +1 -0
  32. package/components/ResourceDetail/Masthead.vue +54 -2
  33. package/components/ResourceDetail/index.vue +12 -5
  34. package/components/ResourceList/Masthead.vue +11 -1
  35. package/components/ResourceList/ResourceLoadingIndicator.vue +12 -2
  36. package/components/ResourceList/index.vue +53 -12
  37. package/components/ResourceList/resource-list.config.js +7 -0
  38. package/components/ResourceTable.vue +31 -6
  39. package/components/SimpleBox.vue +1 -1
  40. package/components/SortableTable/THead.vue +15 -5
  41. package/components/SortableTable/index.vue +21 -10
  42. package/components/Tabbed/index.vue +20 -15
  43. package/components/__tests__/.DS_Store +0 -0
  44. package/components/__tests__/AsyncButton.test.ts +140 -0
  45. package/components/__tests__/BackLink.test.ts +33 -0
  46. package/components/__tests__/ButtonGroup.test.ts +124 -0
  47. package/components/__tests__/ClusterBadge.test.ts +32 -0
  48. package/components/__tests__/CollapsibleCard.test.ts +64 -0
  49. package/components/__tests__/ConsumptionGauge.test.ts +88 -0
  50. package/components/__tests__/CruResource.test.ts +3 -2
  51. package/components/__tests__/FixedBanner.test.ts +129 -0
  52. package/components/__tests__/GrowlManager.test.ts +147 -0
  53. package/components/__tests__/NamespaceFilter.test.ts +33 -25
  54. package/components/__tests__/PercentageBar.test.ts +32 -0
  55. package/components/__tests__/PodSecurityAdmission.test.ts +398 -0
  56. package/components/auth/AuthBanner.vue +20 -10
  57. package/components/auth/RoleDetailEdit.vue +26 -17
  58. package/components/auth/SelectPrincipal.vue +36 -5
  59. package/components/form/ArrayList.vue +3 -35
  60. package/components/form/ArrayListGrouped.vue +13 -4
  61. package/components/form/ArrayListSelect.vue +5 -5
  62. package/components/form/Error.vue +8 -0
  63. package/components/form/KeyValue.vue +39 -7
  64. package/components/form/LabeledSelect.vue +5 -2
  65. package/components/form/Labels.vue +46 -16
  66. package/components/form/Members/ClusterPermissionsEditor.vue +17 -17
  67. package/components/form/Members/MembershipEditor.vue +12 -12
  68. package/components/form/NameNsDescription.vue +1 -1
  69. package/components/form/NodeScheduling.vue +1 -1
  70. package/components/form/Probe.vue +3 -3
  71. package/components/form/ResourceQuota/Project.vue +6 -6
  72. package/components/form/ResourceTabs/index.vue +1 -6
  73. package/components/form/Security.vue +7 -6
  74. package/components/form/Select.vue +3 -2
  75. package/components/form/SelectOrCreateAuthSecret.vue +22 -29
  76. package/components/form/ServicePorts.vue +8 -0
  77. package/components/form/WorkloadPorts.vue +7 -1
  78. package/components/form/__tests__/ArrayList.test.ts +74 -0
  79. package/components/form/__tests__/ArrayListGrouped.test.ts +6 -4
  80. package/components/formatter/Checked.vue +1 -1
  81. package/components/formatter/ClusterLink.vue +5 -0
  82. package/components/formatter/IconIsDefault.vue +2 -2
  83. package/components/formatter/InternalExternalIP.vue +11 -8
  84. package/components/formatter/LiveDuration.vue +78 -0
  85. package/components/formatter/WorkloadHealthScale.vue +5 -3
  86. package/components/nav/Header.vue +6 -3
  87. package/components/nav/NamespaceFilter.vue +146 -63
  88. package/components/nav/TopLevelMenu.vue +22 -19
  89. package/components/nav/WindowManager/ContainerLogs.vue +83 -126
  90. package/components/nav/WindowManager/ContainerShell.vue +9 -7
  91. package/components/nav/WindowManager/Window.vue +2 -0
  92. package/components/nav/WindowManager/index.vue +10 -0
  93. package/config/elemental-types.js +9 -0
  94. package/config/features.js +2 -0
  95. package/config/home-links.js +4 -1
  96. package/config/pod-security-admission.ts +82 -0
  97. package/config/product/apps.js +1 -1
  98. package/config/product/auth.js +6 -5
  99. package/config/product/explorer.js +6 -6
  100. package/config/product/fleet.js +1 -1
  101. package/config/product/manager.js +6 -2
  102. package/config/secret.js +0 -1
  103. package/config/settings.ts +26 -9
  104. package/config/table-headers.js +22 -11
  105. package/config/types.js +4 -1
  106. package/content/docs/zh-hans/getting-started.md +113 -137
  107. package/content/docs/zh-hans/whats-new.md +8 -46
  108. package/creators/pkg/package-lock.json +37 -0
  109. package/creators/pkg/package.json +1 -1
  110. package/detail/catalog.cattle.io.app.vue +1 -1
  111. package/detail/pod.vue +1 -1
  112. package/detail/provisioning.cattle.io.cluster.vue +35 -9
  113. package/detail/service.vue +2 -9
  114. package/detail/workload/index.vue +0 -1
  115. package/dialog/AddClusterMemberDialog.vue +22 -28
  116. package/dialog/AddProjectMemberDialog.vue +53 -9
  117. package/dialog/DiagnosticTimingsDialog.vue +8 -7
  118. package/dialog/DrainNode.vue +44 -48
  119. package/dialog/ForceMachineRemoveDialog.vue +5 -7
  120. package/dialog/GenericPrompt.vue +15 -20
  121. package/dialog/RollbackWorkloadDialog.vue +15 -46
  122. package/dialog/RotateCertificatesDialog.vue +5 -7
  123. package/dialog/RotateEncryptionKeyDialog.vue +5 -9
  124. package/dialog/SaveAsRKETemplateDialog.vue +5 -13
  125. package/dialog/ScaleMachineDownDialog.vue +1 -1
  126. package/dialog/ScalePoolDownDialog.vue +121 -0
  127. package/edit/__tests__/management.cattle.io.setting.test.ts +3 -3
  128. package/edit/auth/azuread.vue +16 -16
  129. package/edit/auth/github.vue +8 -0
  130. package/edit/auth/googleoauth.vue +10 -1
  131. package/edit/auth/ldap/index.vue +10 -0
  132. package/edit/auth/oidc.vue +10 -0
  133. package/edit/auth/saml.vue +10 -0
  134. package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -1
  135. package/edit/cloudcredential.vue +3 -7
  136. package/edit/logging-flow/Match.vue +39 -8
  137. package/edit/logging-flow/index.vue +27 -4
  138. package/edit/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +107 -0
  139. package/edit/management.cattle.io.project.vue +8 -1
  140. package/edit/management.cattle.io.setting.vue +5 -2
  141. package/edit/management.cattle.io.user.vue +7 -1
  142. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +23 -7
  143. package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +2 -2
  144. package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +14 -6
  145. package/edit/namespace.vue +18 -4
  146. package/edit/networking.k8s.io.ingress/Certificate.vue +1 -0
  147. package/edit/networking.k8s.io.ingress/IngressClass.vue +8 -6
  148. package/edit/networking.k8s.io.ingress/RulePath.vue +12 -6
  149. package/edit/networking.k8s.io.ingress/index.vue +8 -6
  150. package/edit/persistentvolume/index.vue +30 -27
  151. package/edit/persistentvolume/plugins/cephfs.vue +29 -29
  152. package/edit/persistentvolume/plugins/csi.vue +102 -62
  153. package/edit/persistentvolume/plugins/fc.vue +19 -19
  154. package/edit/persistentvolume/plugins/iscsi.vue +45 -45
  155. package/edit/persistentvolume/plugins/rbd.vue +39 -39
  156. package/edit/persistentvolumeclaim.vue +78 -75
  157. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +11 -7
  158. package/edit/provisioning.cattle.io.cluster/RegistryConfigs.vue +10 -1
  159. package/edit/provisioning.cattle.io.cluster/RegistryMirrors.vue +87 -27
  160. package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +3 -6
  161. package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +93 -0
  162. package/edit/provisioning.cattle.io.cluster/import.vue +1 -1
  163. package/edit/provisioning.cattle.io.cluster/index.vue +29 -6
  164. package/edit/provisioning.cattle.io.cluster/rke2.vue +440 -152
  165. package/edit/secret/index.vue +3 -7
  166. package/edit/service.vue +3 -1
  167. package/edit/storage.k8s.io.storageclass/index.vue +100 -16
  168. package/edit/storage.k8s.io.storageclass/provisioners/driver.harvesterhci.io.vue +114 -0
  169. package/edit/workload/__tests__/index.test.ts +98 -0
  170. package/edit/workload/index.vue +58 -8
  171. package/edit/workload/mixins/workload.js +107 -70
  172. package/edit/workload/storage/ContainerMountPaths.vue +0 -10
  173. package/edit/workload/storage/emptyDir.vue +88 -0
  174. package/edit/workload/storage/ephemeralVolume/index.vue +1 -1
  175. package/edit/workload/storage/index.vue +8 -0
  176. package/edit/workload/storage/persistentVolumeClaim/index.vue +1 -1
  177. package/layouts/default.vue +57 -44
  178. package/list/__tests__/workload.test.ts +5 -2
  179. package/list/catalog.cattle.io.app.vue +1 -0
  180. package/list/cis.cattle.io.clusterscan.vue +1 -0
  181. package/list/fleet.cattle.io.bundle.vue +5 -6
  182. package/list/fleet.cattle.io.cluster.vue +6 -3
  183. package/list/fleet.cattle.io.clusterregistrationtoken.vue +5 -6
  184. package/list/fleet.cattle.io.gitrepo.vue +4 -9
  185. package/list/helm.cattle.io.projecthelmchart.vue +1 -5
  186. package/list/logging.banzaicloud.io.clusterflow.vue +4 -1
  187. package/list/logging.banzaicloud.io.flow.vue +6 -5
  188. package/list/management.cattle.io.cluster.vue +1 -0
  189. package/list/management.cattle.io.feature.vue +3 -4
  190. package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +47 -0
  191. package/list/management.cattle.io.setting.vue +2 -2
  192. package/list/management.cattle.io.user.vue +4 -10
  193. package/list/monitoring.coreos.com.alertmanagerconfig.vue +2 -7
  194. package/list/node.vue +8 -5
  195. package/list/persistentvolume.vue +3 -3
  196. package/list/persistentvolumeclaim.vue +3 -4
  197. package/list/provisioning.cattle.io.cluster.vue +18 -19
  198. package/list/service.vue +6 -14
  199. package/list/workload.vue +43 -38
  200. package/machine-config/azure.vue +429 -60
  201. package/machine-config/pnap.vue +288 -0
  202. package/mixins/auth-config.js +1 -3
  203. package/mixins/browser-tab-visibility.js +8 -14
  204. package/mixins/chart.js +1 -1
  205. package/mixins/create-edit-view/impl.js +4 -0
  206. package/mixins/create-edit-view/index.js +4 -2
  207. package/mixins/resource-fetch-namespaced.js +98 -0
  208. package/mixins/resource-fetch.js +79 -45
  209. package/mixins/resource-manager.js +1 -23
  210. package/models/apps.controllerrevision.js +7 -0
  211. package/models/apps.daemonset.js +18 -0
  212. package/models/apps.deployment.js +44 -0
  213. package/models/apps.replicaset.js +7 -0
  214. package/models/apps.statefulset.js +18 -0
  215. package/models/batch.job.js +7 -14
  216. package/models/cluster/node.js +10 -2
  217. package/models/cluster.x-k8s.io.machine.js +26 -4
  218. package/models/cluster.x-k8s.io.machinedeployment.js +12 -2
  219. package/models/event.js +7 -0
  220. package/models/logging.banzaicloud.io.flow.js +4 -0
  221. package/models/management.cattle.io.cluster.js +1 -1
  222. package/models/management.cattle.io.clusterroletemplatebinding.js +1 -1
  223. package/models/management.cattle.io.globalrole.js +2 -2
  224. package/models/management.cattle.io.node.js +37 -2
  225. package/models/management.cattle.io.podsecurityadmissionconfigurationtemplate.ts +4 -0
  226. package/models/management.cattle.io.project.js +30 -11
  227. package/models/management.cattle.io.setting.js +1 -1
  228. package/models/management.cattle.io.user.js +37 -1
  229. package/models/namespace.js +42 -5
  230. package/models/persistentvolume.js +14 -2
  231. package/models/pod.js +15 -0
  232. package/models/projectroletemplatebinding.js +7 -0
  233. package/models/provisioning.cattle.io.cluster.js +61 -10
  234. package/models/rke-machine.cattle.io.pnapmachinetemplate.js +15 -0
  235. package/models/service.js +14 -13
  236. package/models/storage.k8s.io.storageclass.js +33 -18
  237. package/models/workload.js +38 -7
  238. package/nuxt.config.js +27 -17
  239. package/package.json +7 -7
  240. package/pages/about.vue +14 -2
  241. package/pages/c/_cluster/apps/charts/index.vue +4 -3
  242. package/pages/c/_cluster/apps/charts/install.vue +59 -22
  243. package/pages/c/_cluster/auth/config/_id.vue +6 -0
  244. package/pages/c/_cluster/auth/config/index.vue +8 -6
  245. package/pages/c/_cluster/auth/group.principal/assign-edit.vue +1 -1
  246. package/pages/c/_cluster/auth/roles/index.vue +1 -1
  247. package/pages/c/_cluster/explorer/index.vue +12 -6
  248. package/pages/c/_cluster/longhorn/index.vue +1 -1
  249. package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +15 -4
  250. package/pages/c/_cluster/monitoring/index.vue +1 -1
  251. package/pages/c/_cluster/neuvector/index.vue +1 -1
  252. package/pages/c/_cluster/settings/performance.vue +48 -2
  253. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +34 -1
  254. package/pages/c/_cluster/uiplugins/index.vue +28 -2
  255. package/pages/diagnostic.vue +5 -4
  256. package/pages/home.vue +105 -30
  257. package/pages/prefs.vue +23 -12
  258. package/pages/rio/mesh.vue +1 -1
  259. package/pkg/dynamic-importer.lib.js +8 -0
  260. package/pkg/vue.config.js +4 -0
  261. package/plugins/dashboard-store/__tests__/mutations.spec.js +406 -0
  262. package/plugins/dashboard-store/actions.js +32 -25
  263. package/plugins/dashboard-store/getters.js +50 -33
  264. package/plugins/dashboard-store/mutations.js +134 -28
  265. package/plugins/dashboard-store/resource-class.js +21 -41
  266. package/plugins/steve/actions.js +30 -0
  267. package/plugins/steve/caches/resourceCache.js +60 -0
  268. package/plugins/steve/getters.js +44 -1
  269. package/plugins/steve/mutations.js +97 -36
  270. package/plugins/steve/resourceWatcher.js +277 -0
  271. package/plugins/steve/schema.utils.js +25 -0
  272. package/plugins/steve/subscribe.js +288 -115
  273. package/plugins/steve/worker/index.js +17 -0
  274. package/plugins/steve/worker/web-worker.advanced.js +302 -0
  275. package/plugins/steve/{web-worker.steve-sub-worker.js → worker/web-worker.basic.js} +3 -44
  276. package/rancher-components/Card/Card.vue +3 -3
  277. package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +1 -0
  278. package/rancher-components/StringList/StringList.test.ts +45 -420
  279. package/rancher-components/StringList/StringList.vue +1 -10
  280. package/rancher-components/components/Banner/Banner.test.ts +44 -0
  281. package/rancher-components/components/Banner/Banner.vue +129 -61
  282. package/rancher-components/components/Form/Checkbox/Checkbox.test.ts +13 -22
  283. package/rancher-components/components/Form/Checkbox/Checkbox.vue +8 -6
  284. package/rancher-components/components/Form/ToggleSwitch/ToggleSwitch.test.ts +9 -9
  285. package/rancher-components/components/LabeledTooltip/LabeledTooltip.vue +0 -1
  286. package/rancher-components/components/StringList/StringList.test.ts +7 -7
  287. package/rancher-components/components/StringList/StringList.vue +21 -15
  288. package/scripts/test-plugins-build.sh +8 -0
  289. package/static/loading-indicator.html +1 -1
  290. package/store/index.js +54 -3
  291. package/store/plugins.js +0 -17
  292. package/store/pnap.js +128 -0
  293. package/store/prefs.js +4 -2
  294. package/store/type-map.js +55 -13
  295. package/types/pod-security-admission.ts +36 -0
  296. package/types/shell/index.d.ts +496 -396
  297. package/utils/__tests__/object.test.ts +17 -1
  298. package/utils/__tests__/pod-security-admission.test.ts +61 -0
  299. package/utils/async.ts +36 -0
  300. package/utils/color.js +45 -0
  301. package/utils/crypto/browserHashUtils.js +18 -0
  302. package/utils/dynamic-importer.js +8 -0
  303. package/utils/install-redirect.js +1 -1
  304. package/utils/object.js +24 -0
  305. package/utils/pod-security-admission.ts +39 -0
  306. package/utils/socket.js +61 -24
  307. package/utils/string.js +2 -0
  308. package/utils/svg-filter.js +301 -0
  309. package/utils/time.js +49 -0
  310. package/utils/validators/cidr.js +4 -0
  311. package/utils/validators/formRules/__tests__/index.test.ts +23 -3
  312. package/utils/validators/formRules/index.ts +14 -0
  313. package/config/product/harvester-manager.js +0 -162
  314. package/edit/harvesterhci.io.management.cluster.vue +0 -153
  315. package/list/harvesterhci.io.management.cluster.vue +0 -241
  316. package/machine-config/harvester.vue +0 -693
  317. package/models/harvesterhci.io.management.cluster.js +0 -228
  318. package/pages/c/_cluster/harvesterManager/index.vue +0 -24
  319. package/rancher-components/Card/Card.test.ts +0 -39
  320. package/rancher-components/Utils/DraggableZone/DraggableZone.vue +0 -181
  321. package/rancher-components/Utils/DraggableZone/index.ts +0 -1
  322. package/rancher-components/components/Utils/DraggableZone/index.ts +0 -1
package/pages/home.vue CHANGED
@@ -40,6 +40,14 @@ export default {
40
40
  fetch() {
41
41
  this.$store.dispatch('management/findAll', { type: CAPI.RANCHER_CLUSTER });
42
42
  this.$store.dispatch('management/findAll', { type: MANAGEMENT.CLUSTER });
43
+
44
+ if ( this.$store.getters['management/canList'](CAPI.MACHINE) ) {
45
+ this.$store.dispatch('management/findAll', { type: CAPI.MACHINE });
46
+ }
47
+
48
+ if ( this.$store.getters['management/canList'](MANAGEMENT.NODE) ) {
49
+ this.$store.dispatch('management/findAll', { type: MANAGEMENT.NODE });
50
+ }
43
51
  },
44
52
 
45
53
  data() {
@@ -71,12 +79,30 @@ export default {
71
79
  return this.$store.getters['management/all'](CAPI.RANCHER_CLUSTER);
72
80
  },
73
81
 
82
+ // User can go to Cluster Management if they can see the cluster schema
83
+ canManageClusters() {
84
+ const schema = this.$store.getters['management/schemaFor'](CAPI.RANCHER_CLUSTER);
85
+
86
+ return !!schema;
87
+ },
88
+
74
89
  canCreateCluster() {
75
90
  const schema = this.$store.getters['management/schemaFor'](CAPI.RANCHER_CLUSTER);
76
91
 
77
92
  return !!schema?.collectionMethods.find(x => x.toLowerCase() === 'post');
78
93
  },
79
94
 
95
+ manageLocation() {
96
+ return {
97
+ name: 'c-cluster-product-resource',
98
+ params: {
99
+ product: MANAGER,
100
+ cluster: BLANK_CLUSTER,
101
+ resource: CAPI.RANCHER_CLUSTER
102
+ },
103
+ };
104
+ },
105
+
80
106
  createLocation() {
81
107
  return {
82
108
  name: 'c-cluster-product-resource-create',
@@ -176,6 +202,12 @@ export default {
176
202
  markSeenReleaseNotes(this.$store);
177
203
  },
178
204
 
205
+ // Forget the types when we leave the page
206
+ beforeDestroy() {
207
+ this.$store.dispatch('management/forgetType', CAPI.MACHINE);
208
+ this.$store.dispatch('management/forgetType', MANAGEMENT.NODE);
209
+ },
210
+
179
211
  methods: {
180
212
  /**
181
213
  * Define actions for each navigation link
@@ -269,7 +301,9 @@ export default {
269
301
  data-testid="changelog-banner"
270
302
  color="info whats-new"
271
303
  >
272
- <div>{{ t('landing.seeWhatsNew') }}</div>
304
+ <div>
305
+ {{ t('landing.seeWhatsNew') }}
306
+ </div>
273
307
  <a
274
308
  class="hand"
275
309
  @click.prevent.stop="showWhatsNew"
@@ -286,11 +320,13 @@ export default {
286
320
  >
287
321
  <div class="col span-12">
288
322
  <Banner
289
- color="set-login-page"
323
+ color="set-login-page mt-0"
290
324
  :closable="true"
291
325
  @close="closeSetLoginBanner()"
292
326
  >
293
- <div>{{ t('landing.landingPrefs.title') }}</div>
327
+ <div>
328
+ {{ t('landing.landingPrefs.title') }}
329
+ </div>
294
330
  <a
295
331
  class="hand mr-20"
296
332
  @click.prevent.stop="showUserPrefs"
@@ -324,19 +360,28 @@ export default {
324
360
  </div>
325
361
  </template>
326
362
  <template
327
- v-if="canCreateCluster"
363
+ v-if="canCreateCluster || canManageClusters"
328
364
  #header-middle
329
365
  >
330
366
  <div class="table-heading">
331
367
  <n-link
368
+ v-if="canManageClusters"
369
+ :to="manageLocation"
370
+ class="btn btn-sm role-secondary"
371
+ >
372
+ {{ t('cluster.manageAction') }}
373
+ </n-link>
374
+ <n-link
375
+ v-if="canCreateCluster"
332
376
  :to="importLocation"
333
- class="btn role-primary"
377
+ class="btn btn-sm role-primary"
334
378
  >
335
379
  {{ t('cluster.importAction') }}
336
380
  </n-link>
337
381
  <n-link
382
+ v-if="canCreateCluster"
338
383
  :to="createLocation"
339
- class="btn role-primary"
384
+ class="btn btn-sm role-primary"
340
385
  >
341
386
  {{ t('generic.create') }}
342
387
  </n-link>
@@ -344,15 +389,22 @@ export default {
344
389
  </template>
345
390
  <template #col:name="{row}">
346
391
  <td>
347
- <span v-if="row.mgmt">
348
- <n-link
349
- v-if="row.mgmt.isReady && !row.hasError"
350
- :to="{ name: 'c-cluster-explorer', params: { cluster: row.mgmt.id }}"
351
- >
352
- {{ row.nameDisplay }}
353
- </n-link>
354
- <span v-else>{{ row.nameDisplay }}</span>
355
- </span>
392
+ <div class="list-cluster-name">
393
+ <span v-if="row.mgmt">
394
+ <n-link
395
+ v-if="row.mgmt.isReady && !row.hasError"
396
+ :to="{ name: 'c-cluster-explorer', params: { cluster: row.mgmt.id }}"
397
+ >
398
+ {{ row.nameDisplay }}
399
+ </n-link>
400
+ <span v-else>{{ row.nameDisplay }}</span>
401
+ </span>
402
+ <i
403
+ v-if="row.unavailableMachines"
404
+ v-tooltip="row.unavailableMachines"
405
+ class="conditions-alert-icon icon-alert icon"
406
+ />
407
+ </div>
356
408
  </td>
357
409
  </template>
358
410
  <template #col:cpu="{row}">
@@ -410,19 +462,19 @@ export default {
410
462
  }
411
463
  }
412
464
 
413
- .banner.info.whats-new, .banner.set-login-page {
414
- border: 0;
415
- margin-top: 0;
416
- display: flex;
417
- align-items: center;
418
- flex-direction: row;
419
- > div {
420
- flex: 1;
421
- }
422
- > a {
423
- align-self: flex-end;
465
+ .set-login-page, .whats-new {
466
+ > ::v-deep .banner__content {
467
+ display: flex;
468
+
469
+ > div {
470
+ flex: 1;
471
+ }
472
+ > a {
473
+ align-self: flex-end;
474
+ }
424
475
  }
425
476
  }
477
+
426
478
  .banner.set-login-page {
427
479
  border: 1px solid var(--border);
428
480
  }
@@ -432,7 +484,7 @@ export default {
432
484
  height: 39px;
433
485
 
434
486
  & > a {
435
- margin-left: 5px;
487
+ margin-left: 10px;
436
488
  }
437
489
  }
438
490
  .panel:not(:first-child) {
@@ -451,12 +503,35 @@ export default {
451
503
  display: contents;
452
504
  white-space: nowrap;
453
505
  }
506
+
507
+ .list-cluster-name {
508
+ align-items: center;
509
+ display: flex;
510
+
511
+ .conditions-alert-icon {
512
+ color: var(--error);
513
+ margin-left: 4px;
514
+ }
515
+ }
516
+
517
+ // Hide the side-panel showing links when the screen is small
518
+ @media screen and (max-width: 996px) {
519
+ .side-panel {
520
+ display: none;
521
+ }
522
+ }
454
523
  </style>
455
524
  <style lang="scss">
456
525
  .home-page {
457
- .search > INPUT {
458
- background-color: transparent;
459
- padding: 8px;
526
+ .search {
527
+ align-items: center;
528
+ display: flex;
529
+
530
+ > INPUT {
531
+ background-color: transparent;
532
+ height: 30px;
533
+ padding: 8px;
534
+ }
460
535
  }
461
536
 
462
537
  h2 {
package/pages/prefs.vue CHANGED
@@ -9,7 +9,7 @@ import { Checkbox } from '@components/Form/Checkbox';
9
9
  import LandingPagePreference from '@shell/components/LandingPagePreference';
10
10
  import {
11
11
  mapPref, THEME, KEYMAP, DATE_FORMAT, TIME_FORMAT, ROWS_PER_PAGE, HIDE_DESC, SHOW_PRE_RELEASE, MENU_MAX_CLUSTERS,
12
- VIEW_IN_API, ALL_NAMESPACES, THEME_SHORTCUT, PLUGIN_DEVELOPER
12
+ VIEW_IN_API, ALL_NAMESPACES, THEME_SHORTCUT, PLUGIN_DEVELOPER, SCALE_POOL_PROMPT
13
13
  } from '@shell/store/prefs';
14
14
  import LabeledSelect from '@shell/components/form/LabeledSelect';
15
15
  import { addObject } from '@shell/utils/array';
@@ -25,17 +25,18 @@ export default {
25
25
  return { admin: isAdminUser(this.$store.getters) };
26
26
  },
27
27
  computed: {
28
- keymap: mapPref(KEYMAP),
29
- viewInApi: mapPref(VIEW_IN_API),
30
- allNamespaces: mapPref(ALL_NAMESPACES),
31
- themeShortcut: mapPref(THEME_SHORTCUT),
32
- dateFormat: mapPref(DATE_FORMAT),
33
- timeFormat: mapPref(TIME_FORMAT),
34
- perPage: mapPref(ROWS_PER_PAGE),
35
- hideDesc: mapPref(HIDE_DESC),
36
- showPreRelease: mapPref(SHOW_PRE_RELEASE),
37
- menuMaxClusters: mapPref(MENU_MAX_CLUSTERS),
38
- pluginDeveloper: mapPref(PLUGIN_DEVELOPER),
28
+ keymap: mapPref(KEYMAP),
29
+ viewInApi: mapPref(VIEW_IN_API),
30
+ allNamespaces: mapPref(ALL_NAMESPACES),
31
+ themeShortcut: mapPref(THEME_SHORTCUT),
32
+ dateFormat: mapPref(DATE_FORMAT),
33
+ timeFormat: mapPref(TIME_FORMAT),
34
+ perPage: mapPref(ROWS_PER_PAGE),
35
+ hideDesc: mapPref(HIDE_DESC),
36
+ showPreRelease: mapPref(SHOW_PRE_RELEASE),
37
+ menuMaxClusters: mapPref(MENU_MAX_CLUSTERS),
38
+ pluginDeveloper: mapPref(PLUGIN_DEVELOPER),
39
+ scalingDownPrompt: mapPref(SCALE_POOL_PROMPT),
39
40
 
40
41
  ...mapGetters(['isSingleProduct']),
41
42
 
@@ -238,6 +239,16 @@ export default {
238
239
  </div>
239
240
  </div>
240
241
  </div>
242
+ <!-- Confirmation setting -->
243
+ <div class="col adv-features mt-10 mb-10">
244
+ <hr>
245
+ <h4 v-t="'prefs.confirmationSetting.title'" />
246
+ <Checkbox
247
+ v-model="scalingDownPrompt"
248
+ :label="t('prefs.confirmationSetting.scalingDownPrompt')"
249
+ class="mt-10"
250
+ />
251
+ </div>
241
252
  <!-- Advanced Features -->
242
253
  <div class="col adv-features mt-10 mb-10">
243
254
  <hr>
@@ -408,7 +408,7 @@ export default {
408
408
  </script>
409
409
  <template>
410
410
  <div class="mesh">
411
- <header class="header-layout">
411
+ <header>
412
412
  <h1>App Mesh</h1>
413
413
  </header>
414
414
 
@@ -72,3 +72,11 @@ export function importWindowComponent(name) {
72
72
  export function resolveWindowComponent(key) {
73
73
  return undefined;
74
74
  }
75
+
76
+ export function resolveMachineConfigComponent(key) {
77
+ return undefined;
78
+ }
79
+
80
+ export function resolveCloudCredentialComponent(key) {
81
+ return undefined;
82
+ }
package/pkg/vue.config.js CHANGED
@@ -45,14 +45,18 @@ module.exports = function(dir) {
45
45
  },
46
46
 
47
47
  configureWebpack: (config) => {
48
+ const pkgName = dir.replace(`${ path.dirname(dir) }/`, '');
49
+
48
50
  // Alias updates
49
51
  config.resolve.alias['@shell'] = path.join(dir, '.shell');
50
52
  config.resolve.alias['~shell'] = path.join(dir, '.shell');
51
53
  // This should be udpated once we move to rancher-components as a dependency
52
54
  config.resolve.alias['@components'] = COMPONENTS_DIR;
53
55
  config.resolve.alias['./node_modules'] = path.join(maindir, 'node_modules');
56
+ config.resolve.alias[`@pkg/${ pkgName }`] = dir;
54
57
  config.resolve.alias['@pkg'] = dir;
55
58
  config.resolve.alias['~pkg'] = dir;
59
+ config.resolve.alias['~'] = maindir;
56
60
  delete config.resolve.alias['@'];
57
61
 
58
62
  // Prevent the dynamic importer and the model-loader-require from importing anything dynamically - we don't want all of the