dashboard-shell-shell 3.0.5-test.6 → 3.0.5-test.60

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 (348) hide show
  1. package/assets/brand/csp/favicon.png +0 -0
  2. package/assets/brand/harvester/favicon.png +0 -0
  3. package/assets/brand/suse/favicon.png +0 -0
  4. package/assets/icons/demo.css +539 -0
  5. package/assets/icons/demo.css:Zone.Identifier +0 -0
  6. package/assets/icons/demo_index.html +1131 -0
  7. package/assets/icons/demo_index.html:Zone.Identifier +0 -0
  8. package/assets/icons/iconfont.css +219 -0
  9. package/assets/icons/iconfont.css:Zone.Identifier +0 -0
  10. package/assets/icons/iconfont.js +1 -0
  11. package/assets/icons/iconfont.js:Zone.Identifier +0 -0
  12. package/assets/icons/iconfont.json +324 -0
  13. package/assets/icons/iconfont.json:Zone.Identifier +0 -0
  14. package/assets/icons/iconfont.ttf +0 -0
  15. package/assets/icons/iconfont.ttf:Zone.Identifier +0 -0
  16. package/assets/icons/iconfont.woff +0 -0
  17. package/assets/icons/iconfont.woff2 +0 -0
  18. package/assets/icons/iconfont.woff2:Zone.Identifier +0 -0
  19. package/assets/icons/iconfont.woff:Zone.Identifier +0 -0
  20. package/assets/iconsNew/demo.css +539 -0
  21. package/assets/iconsNew/demo.css:Zone.Identifier +0 -0
  22. package/assets/iconsNew/demo_index.html +303 -0
  23. package/assets/iconsNew/demo_index.html:Zone.Identifier +0 -0
  24. package/assets/iconsNew/iconfont.css +43 -0
  25. package/assets/iconsNew/iconfont.css:Zone.Identifier +0 -0
  26. package/assets/iconsNew/iconfont.js +1 -0
  27. package/assets/iconsNew/iconfont.js:Zone.Identifier +0 -0
  28. package/assets/iconsNew/iconfont.json +44 -0
  29. package/assets/iconsNew/iconfont.json:Zone.Identifier +0 -0
  30. package/assets/iconsNew/iconfont.ttf +0 -0
  31. package/assets/iconsNew/iconfont.ttf:Zone.Identifier +0 -0
  32. package/assets/iconsNew/iconfont.woff +0 -0
  33. package/assets/iconsNew/iconfont.woff2 +0 -0
  34. package/assets/iconsNew/iconfont.woff2:Zone.Identifier +0 -0
  35. package/assets/iconsNew/iconfont.woff:Zone.Identifier +0 -0
  36. package/assets/images/API.svg +3 -0
  37. package/assets/images/action.svg +6 -0
  38. package/assets/images/login/password.svg +20 -0
  39. package/assets/images/login/user.svg +6 -0
  40. package/assets/images/login-bg.png +0 -0
  41. package/assets/images/login-left.png +0 -0
  42. package/assets/images/login-logo.svg +19 -0
  43. package/assets/images/logo.png +0 -0
  44. package/assets/images/pl/dark/logo.png +0 -0
  45. package/assets/images/pl/half-logo.svg +2 -23
  46. package/assets/images/pl/harvester.png +0 -0
  47. package/assets/images/pl/logo.png +0 -0
  48. package/assets/images/promp-yellow.svg +5 -0
  49. package/assets/images/user.png +0 -0
  50. package/assets/styles/all.scss +83 -0
  51. package/assets/styles/app.scss +5 -0
  52. package/assets/styles/base/_basic.scss +2 -2
  53. package/assets/styles/base/_helpers.scss +1 -1
  54. package/assets/styles/base/_mixins.scss +1 -1
  55. package/assets/styles/base/_typography.scss +2 -1
  56. package/assets/styles/base/_variables.scss +14 -7
  57. package/assets/styles/fonts/_icons.scss +3 -2
  58. package/assets/styles/global/_button.scss +44 -26
  59. package/assets/styles/global/_columns.scss +3 -1
  60. package/assets/styles/global/_form.scss +46 -13
  61. package/assets/styles/global/_labeled-input.scss +54 -26
  62. package/assets/styles/global/_layout.scss +8 -3
  63. package/assets/styles/global/_select.scss +25 -17
  64. package/assets/styles/global/_table.scss +7 -1
  65. package/assets/styles/global/_tooltip.scss +60 -8
  66. package/assets/styles/themes/_dark.scss +3 -0
  67. package/assets/styles/themes/_light.scss +69 -46
  68. package/assets/styles/vendor/vue-select.scss +24 -10
  69. package/assets/translations/en-us.yaml +92 -4
  70. package/assets/translations/zh-hans.yaml +656 -206
  71. package/components/ActionDropdown.vue +2 -1
  72. package/components/ActionMenu.vue +2 -2
  73. package/components/ActionMenuShell.vue +2 -0
  74. package/components/AppModal.vue +46 -5
  75. package/components/BrandImage.vue +1 -0
  76. package/components/ButtonDropdown.vue +28 -4
  77. package/components/ButtonMultiAction.vue +1 -0
  78. package/components/ClusterIconMenu.vue +2 -2
  79. package/components/CodeMirror.vue +26 -10
  80. package/components/ConsumptionGauge.vue +24 -5
  81. package/components/ContainerResourceLimit.vue +2 -2
  82. package/components/CopyToClipboard.vue +15 -0
  83. package/components/CruResource.vue +12 -10
  84. package/components/CruResourceFooter.vue +2 -2
  85. package/components/DashboardOptions.vue +29 -17
  86. package/components/DotState.vue +84 -0
  87. package/components/Drawer/Chrome.vue +2 -2
  88. package/components/Drawer/ResourceDetailDrawer/ConfigTab.vue +30 -27
  89. package/components/Drawer/ResourceDetailDrawer/YamlTab.vue +1 -1
  90. package/components/Drawer/ResourceDetailDrawer/index.vue +5 -4
  91. package/components/ExplorerMembers.vue +28 -4
  92. package/components/ExplorerProjectsNamespaces.vue +19 -5
  93. package/components/GlobalRoleBindings.vue +23 -4
  94. package/components/GrafanaDashboard.vue +4 -4
  95. package/components/GrowlManager.vue +3 -1
  96. package/components/HardwareResourceGauge.vue +39 -3
  97. package/components/IndentedPanel.vue +4 -10
  98. package/components/InfoBox.vue +3 -3
  99. package/components/InputOrDisplay.vue +28 -2
  100. package/components/LabelValue.vue +20 -1
  101. package/components/ModalWithCard.vue +12 -3
  102. package/components/PodSecurityAdmission.vue +2 -2
  103. package/components/PromptModal.vue +1 -1
  104. package/components/PromptRemove.vue +53 -12
  105. package/components/RelatedResources.vue +3 -0
  106. package/components/Resource/Detail/Metadata/IdentifyingInformation/index.vue +1 -3
  107. package/components/Resource/Detail/Metadata/KeyValue.vue +8 -4
  108. package/components/Resource/Detail/Metadata/index.vue +3 -1
  109. package/components/Resource/Detail/TitleBar/Title.vue +4 -3
  110. package/components/Resource/Detail/TitleBar/Top.vue +2 -0
  111. package/components/Resource/Detail/TitleBar/composables.ts +16 -1
  112. package/components/Resource/Detail/TitleBar/index.vue +125 -27
  113. package/components/ResourceDetail/Masthead/index.vue +1 -1
  114. package/components/ResourceDetail/Masthead/latest.vue +1 -1
  115. package/components/ResourceDetail/Masthead/legacy.vue +183 -39
  116. package/components/ResourceDetail/legacy.vue +47 -29
  117. package/components/ResourceList/Masthead.vue +222 -54
  118. package/components/ResourceList/ResourceLoadingIndicator.vue +5 -2
  119. package/components/ResourceTable.vue +40 -2
  120. package/components/SideNav.vue +74 -20
  121. package/components/SingleClusterInfo.vue +2 -1
  122. package/components/SortableTable/THead.vue +79 -4
  123. package/components/SortableTable/index.vue +1053 -464
  124. package/components/SortableTable/paging.js +26 -16
  125. package/components/SortableTable/selection.js +2 -2
  126. package/components/Tabbed/Tab.vue +3 -3
  127. package/components/Tabbed/index.vue +53 -30
  128. package/components/YamlEditor.vue +0 -1
  129. package/components/auth/Principal.vue +51 -19
  130. package/components/auth/RoleDetailEdit.vue +69 -14
  131. package/components/auth/SelectPrincipal.vue +1 -0
  132. package/components/breadcrumb/index.vue +119 -0
  133. package/components/form/ArrayList.vue +177 -152
  134. package/components/form/ArrayListGrouped.vue +13 -3
  135. package/components/form/ArrayListSelect.vue +1 -1
  136. package/components/form/BannerSettings.vue +64 -59
  137. package/components/form/ChangePassword.vue +5 -5
  138. package/components/form/ClusterAppearance.vue +4 -3
  139. package/components/form/ColorInput.vue +32 -8
  140. package/components/form/Command.vue +4 -5
  141. package/components/form/Conditions.vue +15 -1
  142. package/components/form/Footer.vue +12 -8
  143. package/components/form/HealthCheck.vue +0 -2
  144. package/components/form/HookOption.vue +87 -58
  145. package/components/form/InputWithSelect.vue +8 -4
  146. package/components/form/KeyValue.vue +66 -8
  147. package/components/form/LabeledSelect.vue +216 -242
  148. package/components/form/Labels.vue +4 -4
  149. package/components/form/MatchExpressions.vue +28 -11
  150. package/components/form/Members/ClusterMembershipEditor.vue +1 -1
  151. package/components/form/Members/ClusterPermissionsEditor.vue +61 -43
  152. package/components/form/Members/MembershipEditor.vue +4 -4
  153. package/components/form/Members/ProjectMembershipEditor.vue +1 -1
  154. package/components/form/NameNsDescription.vue +76 -21
  155. package/components/form/Networking.vue +6 -9
  156. package/components/form/NodeAffinity.vue +29 -28
  157. package/components/form/Password.vue +16 -7
  158. package/components/form/PodAffinity.vue +24 -25
  159. package/components/form/Probe.vue +15 -11
  160. package/components/form/ProjectMemberEditor.vue +66 -48
  161. package/components/form/ResourceQuota/Namespace.vue +4 -4
  162. package/components/form/ResourceQuota/NamespaceRow.vue +26 -23
  163. package/components/form/ResourceQuota/Project.vue +4 -4
  164. package/components/form/ResourceQuota/ProjectRow.vue +38 -35
  165. package/components/form/ResourceSelector.vue +1 -1
  166. package/components/form/SecretSelector.vue +24 -23
  167. package/components/form/Security.vue +1 -3
  168. package/components/form/Select.vue +12 -3
  169. package/components/form/ServiceNameSelect.vue +2 -5
  170. package/components/form/ServicePorts.vue +149 -75
  171. package/components/form/SimpleSecretSelector.vue +29 -9
  172. package/components/form/Taints.vue +2 -1
  173. package/components/form/Tolerations.vue +13 -9
  174. package/components/form/UnitInput.vue +8 -3
  175. package/components/form/ValueFromResource.vue +110 -96
  176. package/components/form/WorkloadPorts.vue +143 -123
  177. package/components/formatter/BadgeStateFormatter.vue +8 -5
  178. package/components/formatter/LiveDate.vue +3 -3
  179. package/components/formatter/WorkloadHealthScale.vue +4 -3
  180. package/components/nav/Favorite.vue +5 -1
  181. package/components/nav/Group.vue +139 -99
  182. package/components/nav/Header.vue +127 -150
  183. package/components/nav/HeaderPageActionMenu.vue +1 -0
  184. package/components/nav/NamespaceFilter.vue +34 -36
  185. package/components/nav/TopLevelMenu.vue +62 -25
  186. package/components/nav/Type.vue +73 -43
  187. package/composables/useClickOutside.ts +1 -1
  188. package/config/menuRouteMap.js +10 -0
  189. package/config/private-label.js +15 -11
  190. package/config/product/auth.js +17 -7
  191. package/config/product/explorer.js +32 -10
  192. package/config/product/manager.js +28 -17
  193. package/config/product/settings.js +19 -9
  194. package/config/product/uiplugins.js +13 -10
  195. package/config/router/navigation-guards/index.js +61 -3
  196. package/config/settings.ts +28 -0
  197. package/config/table-headers.js +3 -2
  198. package/detail/node.vue +28 -23
  199. package/dialog/AddCustomBadgeDialog.vue +17 -9
  200. package/dialog/ForceMachineRemoveDialog.vue +2 -2
  201. package/dialog/RollbackWorkloadDialog.vue +1 -1
  202. package/dialog/ScalePoolDownDialog.vue +2 -2
  203. package/edit/autoscaling.horizontalpodautoscaler/external-metric.vue +1 -1
  204. package/edit/autoscaling.horizontalpodautoscaler/hpa-scaling-rule.vue +9 -6
  205. package/edit/autoscaling.horizontalpodautoscaler/index.vue +3 -1
  206. package/edit/autoscaling.horizontalpodautoscaler/metric-identifier.vue +2 -2
  207. package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +7 -5
  208. package/edit/autoscaling.horizontalpodautoscaler/metric-target.vue +5 -3
  209. package/edit/autoscaling.horizontalpodautoscaler/metrics-row.vue +2 -2
  210. package/edit/autoscaling.horizontalpodautoscaler/object-metric.vue +2 -2
  211. package/edit/autoscaling.horizontalpodautoscaler/pod-metric.vue +1 -1
  212. package/edit/autoscaling.horizontalpodautoscaler/resource-metric.vue +2 -2
  213. package/edit/configmap.vue +4 -0
  214. package/edit/logging-flow/index.vue +1 -2
  215. package/edit/logging.banzaicloud.io.output/providers/awsElasticsearch.vue +3 -3
  216. package/edit/logging.banzaicloud.io.output/providers/azurestorage.vue +19 -19
  217. package/edit/logging.banzaicloud.io.output/providers/cloudwatch.vue +23 -23
  218. package/edit/logging.banzaicloud.io.output/providers/datadog.vue +19 -19
  219. package/edit/logging.banzaicloud.io.output/providers/elasticsearch.vue +14 -14
  220. package/edit/logging.banzaicloud.io.output/providers/forward.vue +12 -12
  221. package/edit/logging.banzaicloud.io.output/providers/gcs.vue +23 -23
  222. package/edit/logging.banzaicloud.io.output/providers/gelf.vue +6 -6
  223. package/edit/logging.banzaicloud.io.output/providers/kafka.vue +10 -10
  224. package/edit/logging.banzaicloud.io.output/providers/kinesisStream.vue +8 -8
  225. package/edit/logging.banzaicloud.io.output/providers/logdna.vue +17 -17
  226. package/edit/logging.banzaicloud.io.output/providers/logz.vue +7 -7
  227. package/edit/logging.banzaicloud.io.output/providers/loki.vue +12 -12
  228. package/edit/logging.banzaicloud.io.output/providers/newrelic.vue +3 -3
  229. package/edit/logging.banzaicloud.io.output/providers/opensearch.vue +14 -14
  230. package/edit/logging.banzaicloud.io.output/providers/redis.vue +6 -6
  231. package/edit/logging.banzaicloud.io.output/providers/s3.vue +23 -23
  232. package/edit/logging.banzaicloud.io.output/providers/splunkHec.vue +13 -13
  233. package/edit/logging.banzaicloud.io.output/providers/sumologic.vue +2 -2
  234. package/edit/logging.banzaicloud.io.output/providers/syslog.vue +54 -54
  235. package/edit/management.cattle.io.user.vue +17 -4
  236. package/edit/monitoring.coreos.com.alertmanagerconfig/auth.vue +19 -19
  237. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +31 -31
  238. package/edit/monitoring.coreos.com.alertmanagerconfig/routeConfig.vue +36 -12
  239. package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +6 -6
  240. package/edit/monitoring.coreos.com.alertmanagerconfig/types/opsgenie.vue +10 -10
  241. package/edit/monitoring.coreos.com.alertmanagerconfig/types/pagerduty.vue +4 -4
  242. package/edit/monitoring.coreos.com.alertmanagerconfig/types/slack.vue +4 -4
  243. package/edit/monitoring.coreos.com.alertmanagerconfig/types/webhook.vue +1 -1
  244. package/edit/monitoring.coreos.com.receiver/types/email.vue +6 -6
  245. package/edit/monitoring.coreos.com.receiver/types/opsgenie.vue +10 -10
  246. package/edit/monitoring.coreos.com.receiver/types/pagerduty.vue +5 -5
  247. package/edit/monitoring.coreos.com.receiver/types/slack.vue +4 -4
  248. package/edit/namespace.vue +1 -2
  249. package/edit/networking.k8s.io.ingress/Certificate.vue +14 -5
  250. package/edit/networking.k8s.io.ingress/DefaultBackend.vue +2 -2
  251. package/edit/networking.k8s.io.ingress/Rule.vue +5 -11
  252. package/edit/networking.k8s.io.ingress/RulePath.vue +105 -96
  253. package/edit/networking.k8s.io.networkpolicy/PolicyRule.vue +3 -3
  254. package/edit/networking.k8s.io.networkpolicy/PolicyRulePort.vue +4 -2
  255. package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +12 -11
  256. package/edit/networking.k8s.io.networkpolicy/index.vue +1 -1
  257. package/edit/persistentvolume/index.vue +3 -1
  258. package/edit/persistentvolumeclaim.vue +2 -0
  259. package/edit/provisioning.cattle.io.cluster/tabs/Basics.vue +1 -1
  260. package/edit/secret/index.vue +2 -2
  261. package/edit/service.vue +4 -1
  262. package/edit/storage.k8s.io.storageclass/index.vue +10 -8
  263. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/aws-ebs.vue +34 -27
  264. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/gce-pd.vue +15 -13
  265. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/vsphere-volume.vue +41 -39
  266. package/edit/token.vue +31 -12
  267. package/edit/workload/Job.vue +31 -34
  268. package/edit/workload/Upgrading.vue +5 -5
  269. package/edit/workload/index.vue +22 -18
  270. package/edit/workload/storage/Mount.vue +1 -0
  271. package/edit/workload/storage/awsElasticBlockStore.vue +9 -7
  272. package/edit/workload/storage/azureDisk.vue +14 -10
  273. package/edit/workload/storage/azureFile.vue +9 -7
  274. package/edit/workload/storage/csi/index.vue +6 -9
  275. package/edit/workload/storage/emptyDir.vue +7 -5
  276. package/edit/workload/storage/gcePersistentDisk.vue +9 -7
  277. package/edit/workload/storage/hostPath.vue +7 -5
  278. package/edit/workload/storage/nfs.vue +8 -6
  279. package/edit/workload/storage/persistentVolumeClaim/index.vue +12 -10
  280. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +20 -15
  281. package/edit/workload/storage/secret.vue +9 -6
  282. package/edit/workload/storage/vsphereVolume.vue +11 -7
  283. package/initialize/app-extended.js +7 -1
  284. package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +8 -6
  285. package/list/management.cattle.io.setting.vue +22 -13
  286. package/list/management.cattle.io.user.vue +7 -3
  287. package/list/namespace.vue +3 -0
  288. package/list/provisioning.cattle.io.cluster.vue +6 -7
  289. package/mixins/brand.js +17 -0
  290. package/mixins/create-edit-view/impl.js +10 -0
  291. package/models/provisioning.cattle.io.cluster.js +19 -18
  292. package/models/workload.js +2 -2
  293. package/package.json +1 -1
  294. package/pages/account/index.vue +93 -58
  295. package/pages/account/pri.vue +229 -0
  296. package/pages/auth/login.vue +220 -52
  297. package/pages/auth/setup.vue +175 -33
  298. package/pages/c/_cluster/_product/namespaces.vue +5 -5
  299. package/pages/c/_cluster/auth/roles/index.vue +83 -8
  300. package/pages/c/_cluster/explorer/ConfigBadge.vue +1 -1
  301. package/pages/c/_cluster/explorer/index.vue +2 -1
  302. package/pages/c/_cluster/explorer/tools/index.vue +6 -6
  303. package/pages/c/_cluster/monitoring/monitor/index.vue +2 -2
  304. package/pages/c/_cluster/settings/banners.vue +174 -102
  305. package/pages/c/_cluster/settings/brand.vue +350 -302
  306. package/pages/c/_cluster/settings/performance.vue +61 -38
  307. package/pages/home.vue +119 -37
  308. package/pages/prefs.vue +27 -25
  309. package/pkg/tsconfig.json +9 -9
  310. package/pkg/vue.config.js +1 -1
  311. package/plugins/dashboard-store/actions.js +1 -1
  312. package/plugins/dashboard-store/resource-class.js +28 -27
  313. package/promptRemove/mixin/roleDeletionCheck.js +2 -2
  314. package/public/index.html +4 -4
  315. package/rancher-components/BadgeState/BadgeState.vue +38 -55
  316. package/rancher-components/Banner/Banner.vue +25 -9
  317. package/rancher-components/Card/Card.vue +7 -8
  318. package/rancher-components/Form/Checkbox/Checkbox.vue +4 -0
  319. package/rancher-components/Form/LabeledInput/LabeledInput.vue +42 -3
  320. package/rancher-components/Form/Radio/RadioButton.vue +35 -11
  321. package/rancher-components/Form/Radio/RadioGroup.vue +22 -6
  322. package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +3 -3
  323. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.vue +1 -0
  324. package/rancher-components/LabeledTooltip/LabeledTooltip.vue +41 -4
  325. package/rancher-components/RcDropdown/RcDropdown.vue +35 -7
  326. package/rancher-components/RcDropdown/RcDropdownItem.vue +2 -2
  327. package/rancher-components/RcDropdown/RcDropdownMenu.vue +12 -6
  328. package/rancher-components/RcDropdown/types.ts +1 -0
  329. package/rancher-components/StringList/StringList.vue +1 -1
  330. package/scripts/build-pkg.sh +18 -23
  331. package/scripts/publish-shell.sh +1 -1
  332. package/static/favicon.ico +0 -0
  333. package/static/favicon.png +0 -0
  334. package/static/loading-indicator.html +3 -3
  335. package/store/i18n.js +6 -2
  336. package/store/modal.ts +3 -3
  337. package/store/prefs.js +11 -4
  338. package/store/type-map.js +30 -2
  339. package/types/shell/index.d.ts +86 -97
  340. package/utils/error.js +109 -8
  341. package/utils/errorTranslate.json +1740 -0
  342. package/utils/errorTranslateNew.json +39 -0
  343. package/utils/roleFiltering.js +33 -0
  344. package/utils/router.js +21 -0
  345. package/utils/select.js +26 -3
  346. package/utils/string.js +8 -5
  347. package/utils/title.ts +1 -1
  348. package/vue.config.js +1 -1
@@ -26,8 +26,8 @@ export default {
26
26
 
27
27
  <template>
28
28
  <div>
29
- <div class="row mb-10">
30
- <div class="col span-6">
29
+ <div class="row">
30
+ <div class="col mr-10">
31
31
  <LabeledInput
32
32
  v-model:value="value.name"
33
33
  :required="true"
@@ -35,7 +35,7 @@ export default {
35
35
  :label="t('workload.storage.volumeName')"
36
36
  />
37
37
  </div>
38
- <div class="col span-6">
38
+ <div class="col" style="display: flex;align-items: center;">
39
39
  <Checkbox
40
40
  v-model:value="value.azureFile.readOnly"
41
41
  :mode="mode"
@@ -43,8 +43,8 @@ export default {
43
43
  />
44
44
  </div>
45
45
  </div>
46
- <div class="row mb-10">
47
- <div class="col span-6">
46
+ <div class="row">
47
+ <div class="col">
48
48
  <LabeledInput
49
49
  v-model:value="value.azureFile.shareName"
50
50
  :mode="mode"
@@ -52,7 +52,9 @@ export default {
52
52
  :label="t('workload.storage.csi.shareName')"
53
53
  />
54
54
  </div>
55
- <div class="col span-6">
55
+ </div>
56
+ <div class="row">
57
+ <div class="col">
56
58
  <LabeledInput
57
59
  v-model:value="value.azureFile.secretName"
58
60
  :mode="mode"
@@ -62,7 +64,7 @@ export default {
62
64
  </div>
63
65
  </div>
64
66
  <div class="row">
65
- <div class="col span-6">
67
+ <div class="col">
66
68
  <LabeledInput
67
69
  v-model:value="value.azureFile.fsType"
68
70
  :mode="mode"
@@ -77,8 +77,8 @@ export default {
77
77
  <template>
78
78
  <div>
79
79
  <div>
80
- <div class="row mb-10">
81
- <div class="col span-6">
80
+ <div class="row">
81
+ <div class="col mr-10">
82
82
  <LabeledInput
83
83
  v-model:value="value.name"
84
84
  :required="true"
@@ -86,7 +86,7 @@ export default {
86
86
  :label="t('workload.storage.volumeName')"
87
87
  />
88
88
  </div>
89
- <div class="col span-6">
89
+ <div class="col" style="display: flex;align-items: center;">
90
90
  <Checkbox
91
91
  v-model:value="value.csi.readOnly"
92
92
  :mode="mode"
@@ -94,8 +94,8 @@ export default {
94
94
  />
95
95
  </div>
96
96
  </div>
97
- <div class="row mb-10">
98
- <div class="col span-6">
97
+ <div class="row">
98
+ <div class="col">
99
99
  <LabeledSelect
100
100
  v-model:value="value.csi.driver"
101
101
  data-testid="workload-storage-driver"
@@ -107,10 +107,7 @@ export default {
107
107
  />
108
108
  </div>
109
109
  </div>
110
- <div
111
- v-if="driverComponent"
112
- class="mb-10"
113
- >
110
+ <div v-if="driverComponent">
114
111
  <component
115
112
  :is="driverComponent"
116
113
  v-model:value="value.csi.volumeAttributes"
@@ -52,8 +52,8 @@ export default {
52
52
  </script>
53
53
  <template>
54
54
  <div>
55
- <div class="row mb-10">
56
- <div class="col span-6">
55
+ <div class="row">
56
+ <div class="col">
57
57
  <LabeledInput
58
58
  v-model:value="value.name"
59
59
  :required="true"
@@ -61,7 +61,9 @@ export default {
61
61
  :label="t('workload.storage.volumeName')"
62
62
  />
63
63
  </div>
64
- <div class="col span-6">
64
+ </div>
65
+ <div class="row">
66
+ <div class="col">
65
67
  <LabeledSelect
66
68
  v-model:value="medium"
67
69
  :mode="mode"
@@ -71,8 +73,8 @@ export default {
71
73
  />
72
74
  </div>
73
75
  </div>
74
- <div class="row mb-10">
75
- <div class="col span-6">
76
+ <div class="row">
77
+ <div class="col">
76
78
  <UnitInput
77
79
  v-model:value="value.emptyDir.sizeLimit"
78
80
  :mode="mode"
@@ -26,8 +26,8 @@ export default {
26
26
 
27
27
  <template>
28
28
  <div>
29
- <div class="row mb-10">
30
- <div class="col span-6">
29
+ <div class="row">
30
+ <div class="col mr-10">
31
31
  <LabeledInput
32
32
  v-model:value="value.name"
33
33
  :required="true"
@@ -35,7 +35,7 @@ export default {
35
35
  :label="t('workload.storage.volumeName')"
36
36
  />
37
37
  </div>
38
- <div class="col span-6">
38
+ <div class="col" style="display: flex;align-items: center;">
39
39
  <Checkbox
40
40
  v-model:value="value.gcePersistentDisk.readOnly"
41
41
  :mode="mode"
@@ -43,8 +43,8 @@ export default {
43
43
  />
44
44
  </div>
45
45
  </div>
46
- <div class="row mb-10">
47
- <div class="col span-6">
46
+ <div class="row">
47
+ <div class="col">
48
48
  <LabeledInput
49
49
  v-model:value="value.gcePersistentDisk.pdName"
50
50
  :mode="mode"
@@ -52,7 +52,9 @@ export default {
52
52
  :required="true"
53
53
  />
54
54
  </div>
55
- <div class="col span-6">
55
+ </div>
56
+ <div class="row">
57
+ <div class="col">
56
58
  <LabeledInput
57
59
  v-model:value.number="value.gcePersistentDisk.partition"
58
60
  :mode="mode"
@@ -61,7 +63,7 @@ export default {
61
63
  </div>
62
64
  </div>
63
65
  <div class="row">
64
- <div class="col span-6">
66
+ <div class="col">
65
67
  <LabeledInput
66
68
  v-model:value="value.gcePersistentDisk.fsType"
67
69
  :mode="mode"
@@ -82,8 +82,8 @@ export default {
82
82
  <template>
83
83
  <div>
84
84
  <div>
85
- <div class="row mb-10">
86
- <div class="col span-6">
85
+ <div class="row">
86
+ <div class="col">
87
87
  <LabeledInput
88
88
  v-model:value="value.name"
89
89
  :required="true"
@@ -92,8 +92,8 @@ export default {
92
92
  />
93
93
  </div>
94
94
  </div>
95
- <div class="row mb-10">
96
- <div class="col span-6">
95
+ <div class="row">
96
+ <div class="col">
97
97
  <LabeledInput
98
98
  v-model:value="value.hostPath.path"
99
99
  :required="true"
@@ -101,7 +101,9 @@ export default {
101
101
  :label="t('workload.storage.nodePath')"
102
102
  />
103
103
  </div>
104
- <div class="col span-6">
104
+ </div>
105
+ <div class="row">
106
+ <div class="col">
105
107
  <LabeledSelect
106
108
  v-model:value="value.hostPath.type"
107
109
  :mode="mode"
@@ -38,8 +38,8 @@ export default {
38
38
  <template>
39
39
  <div>
40
40
  <div>
41
- <div class="row mb-10">
42
- <div class="col span-6">
41
+ <div class="row">
42
+ <div class="col mr-10">
43
43
  <LabeledInput
44
44
  v-model:value="value.name"
45
45
  :required="true"
@@ -47,7 +47,7 @@ export default {
47
47
  :label="t('workload.storage.volumeName')"
48
48
  />
49
49
  </div>
50
- <div class="col span-6">
50
+ <div class="col" style="display: flex;align-items: center;">
51
51
  <Checkbox
52
52
  v-model:value="value.nfs.readOnly"
53
53
  :mode="mode"
@@ -55,8 +55,8 @@ export default {
55
55
  />
56
56
  </div>
57
57
  </div>
58
- <div class="row mb-10">
59
- <div class="col span-6">
58
+ <div class="row">
59
+ <div class="col">
60
60
  <LabeledInput
61
61
  v-model:value="value.nfs.path"
62
62
  :required="true"
@@ -64,7 +64,9 @@ export default {
64
64
  :label="t('workload.storage.path')"
65
65
  />
66
66
  </div>
67
- <div class="col span-6">
67
+ </div>
68
+ <div class="row">
69
+ <div class="col">
68
70
  <LabeledInput
69
71
  v-model:value="value.nfs.server"
70
72
  :required="true"
@@ -121,8 +121,8 @@ export default {
121
121
  @removePvcForm="removePvcForm"
122
122
  />
123
123
  </div>
124
- <div class="row mb-10">
125
- <div class="col span-6">
124
+ <div class="row">
125
+ <div class="col mr-10">
126
126
  <LabeledInput
127
127
  v-model:value="value.name"
128
128
  :required="true"
@@ -130,7 +130,16 @@ export default {
130
130
  :label="t('workload.storage.volumeName')"
131
131
  />
132
132
  </div>
133
- <div class="col span-6">
133
+ <div class="col" style="display: flex;align-items: center;">
134
+ <Checkbox
135
+ v-model:value="value.persistentVolumeClaim.readOnly"
136
+ :mode="mode"
137
+ :label="t('workload.storage.readOnly')"
138
+ />
139
+ </div>
140
+ </div>
141
+ <div class="row">
142
+ <div class="col">
134
143
  <LabeledSelect
135
144
  v-if="!createNew"
136
145
  v-model:value="value.persistentVolumeClaim.claimName"
@@ -142,13 +151,6 @@ export default {
142
151
  />
143
152
  </div>
144
153
  </div>
145
- <div class="row">
146
- <Checkbox
147
- v-model:value="value.persistentVolumeClaim.readOnly"
148
- :mode="mode"
149
- :label="t('workload.storage.readOnly')"
150
- />
151
- </div>
152
154
  </div>
153
155
  </div>
154
156
  </template>
@@ -156,8 +156,8 @@ export default {
156
156
 
157
157
  <template>
158
158
  <div>
159
- <div class="row mb-10">
160
- <div class="col span-6">
159
+ <div class="row">
160
+ <div class="col">
161
161
  <LabeledInput
162
162
  v-model:value="value.metadata.name"
163
163
  :mode="mode"
@@ -167,8 +167,9 @@ export default {
167
167
  />
168
168
  </div>
169
169
  </div>
170
- <div class="row mb-10">
171
- <div class="col span-6">
170
+ <div class="row">
171
+ <div style="width: 160px;"></div>
172
+ <div class="col">
172
173
  <RadioGroup
173
174
  v-model:value="isCreatePV"
174
175
  name="isCreatePV"
@@ -177,7 +178,9 @@ export default {
177
178
  :mode="mode"
178
179
  />
179
180
  </div>
180
- <div class="col span-6">
181
+ </div>
182
+ <div class="row">
183
+ <div class="col">
181
184
  <LabeledSelect
182
185
  v-if="isCreatePV"
183
186
  v-model:value="spec.storageClassName"
@@ -200,16 +203,16 @@ export default {
200
203
  </div>
201
204
  </div>
202
205
 
203
- <div class="row mb-10">
204
- <div class="col span-6">
205
- <div class="access-modes">
206
- <t
207
- class="text-label"
208
- k="persistentVolumeClaim.accessModes"
209
- />
210
- <span class="text-error">*</span>
211
- </div>
206
+ <div class="row">
207
+ <div class="col">
212
208
  <div class="access-modes">
209
+ <div style="width: 160px;">
210
+ <t
211
+ class="text-label"
212
+ k="persistentVolumeClaim.accessModes"
213
+ />
214
+ <span class="text-error">*</span>
215
+ </div>
213
216
  <Checkbox
214
217
  :mode="mode"
215
218
  :value="value.spec.accessModes.includes('ReadWriteOnce')"
@@ -230,9 +233,11 @@ export default {
230
233
  />
231
234
  </div>
232
235
  </div>
236
+ </div>
237
+ <div class="row">
233
238
  <div
234
239
  v-if="isCreatePV"
235
- class="col span-6"
240
+ class="col"
236
241
  >
237
242
  <UnitInput
238
243
  v-model:value="spec.resources.requests.storage"
@@ -130,8 +130,8 @@ export default {
130
130
  <template>
131
131
  <div>
132
132
  <div>
133
- <div class="row mb-10">
134
- <div class="col span-6">
133
+ <div class="row">
134
+ <div class="col">
135
135
  <LabeledInput
136
136
  v-model:value="value.name"
137
137
  :required="true"
@@ -139,8 +139,9 @@ export default {
139
139
  :label="t('workload.storage.volumeName')"
140
140
  />
141
141
  </div>
142
-
143
- <div class="col span-6">
142
+ </div>
143
+ <div class="row">
144
+ <div class="col">
144
145
  <LabeledInput
145
146
  v-model:value="defaultMode"
146
147
  :mode="mode"
@@ -149,7 +150,7 @@ export default {
149
150
  </div>
150
151
  </div>
151
152
  <div class="row">
152
- <div class="col span-6">
153
+ <div class="col">
153
154
  <LabeledSelect
154
155
  v-if="type==='secret'"
155
156
  v-model:value="value[type].secretName"
@@ -169,7 +170,9 @@ export default {
169
170
  :loading="loading"
170
171
  />
171
172
  </div>
172
- <div class="col span-6">
173
+ </div>
174
+ <div class="row">
175
+ <div class="col">
173
176
  <RadioGroup
174
177
  v-model:value="optional"
175
178
  :mode="mode"
@@ -25,8 +25,8 @@ export default {
25
25
 
26
26
  <template>
27
27
  <div>
28
- <div class="row mb-10">
29
- <div class="col span-6">
28
+ <div class="row">
29
+ <div class="col">
30
30
  <LabeledInput
31
31
  v-model:value="value.name"
32
32
  :required="true"
@@ -35,8 +35,8 @@ export default {
35
35
  />
36
36
  </div>
37
37
  </div>
38
- <div class="row mb-10">
39
- <div class="col span-6">
38
+ <div class="row">
39
+ <div class="col">
40
40
  <LabeledInput
41
41
  v-model:value="value.vsphereVolume.storagePolicyID"
42
42
  :mode="mode"
@@ -44,7 +44,9 @@ export default {
44
44
  :required="true"
45
45
  />
46
46
  </div>
47
- <div class="col span-6">
47
+ </div>
48
+ <div class="row">
49
+ <div class="col">
48
50
  <LabeledInput
49
51
  v-model:value.number="value.vsphereVolume.storagePolicyName"
50
52
  :mode="mode"
@@ -53,7 +55,7 @@ export default {
53
55
  </div>
54
56
  </div>
55
57
  <div class="row">
56
- <div class="col span-6">
58
+ <div class="col">
57
59
  <LabeledInput
58
60
  v-model:value="value.vsphereVolume.volumePath"
59
61
  :mode="mode"
@@ -61,7 +63,9 @@ export default {
61
63
  :required="true"
62
64
  />
63
65
  </div>
64
- <div class="col span-6">
66
+ </div>
67
+ <div class="row">
68
+ <div class="col">
65
69
  <LabeledInput
66
70
  v-model:value="value.vsphereVolume.fsType"
67
71
  :mode="mode"
@@ -55,7 +55,13 @@ async function extendApp(vueApp) {
55
55
  const next = (location) => appPartials.router.push(location);
56
56
  // Resolve route
57
57
 
58
- const path = getLocation(router.options.base, router.options.mode);
58
+ let path = getLocation(router.options.base, router.options.mode);
59
+
60
+ // 🔹 增加 rewrite,不改变原逻辑
61
+ if (path.includes('/cloud/')) {
62
+ path = path.replace(/cloud/g, 'harvester');
63
+ }
64
+
59
65
  const route = router.resolve(path);
60
66
 
61
67
  // Set context to app.context
@@ -37,15 +37,17 @@ export default {
37
37
 
38
38
  <template>
39
39
  <div>
40
- <Banner
41
- color="info"
42
- :label="t('podSecurityAdmission.banner.modifications')"
43
- />
44
-
45
40
  <ResourceTable
46
41
  :loading="loading"
47
42
  :schema="schema"
48
43
  :rows="rows"
49
- />
44
+ >
45
+ <template #banner>
46
+ <Banner
47
+ color="info"
48
+ :label="t('podSecurityAdmission.banner.modifications')"
49
+ />
50
+ </template>
51
+ </ResourceTable>
50
52
  </div>
51
53
  </template>
@@ -1,6 +1,6 @@
1
1
  <script>
2
2
  import { MANAGEMENT } from '@shell/config/types';
3
- import { ALLOWED_SETTINGS, PROVISIONING_SETTINGS } from '@shell/config/settings';
3
+ import { ALLOWED_SETTINGS_NEW, ALLOWED_SETTINGS, PROVISIONING_SETTINGS } from '@shell/config/settings';
4
4
  import { Banner } from '@components/Banner';
5
5
  import Loading from '@shell/components/Loading';
6
6
  import { VIEW_IN_API } from '@shell/store/prefs';
@@ -26,8 +26,12 @@ export default {
26
26
  const settings = [];
27
27
  const provisioningSettings = [];
28
28
 
29
+ const topLevelPermissions = sessionStorage.getItem('TOPLEVELPERMISSIONS') || ''
30
+
31
+ const allowedSettings = topLevelPermissions && topLevelPermissions === 'superadmin' ? ALLOWED_SETTINGS : ALLOWED_SETTINGS_NEW
32
+
29
33
  // Combine the allowed settings with the data from the API
30
- for ( const id in ALLOWED_SETTINGS ) {
34
+ for ( const id in allowedSettings ) {
31
35
  const setting = settingsMap[id];
32
36
 
33
37
  if ( !setting ) {
@@ -69,7 +73,10 @@ export default {
69
73
  },
70
74
 
71
75
  data() {
72
- return { settings: null, provisioningSettings: null };
76
+
77
+ const topLevelPermissions = sessionStorage.getItem('TOPLEVELPERMISSIONS') || ''
78
+
79
+ return { topLevelPermissions, settings: null, provisioningSettings: null };
73
80
  },
74
81
  computed: { ...mapGetters({ t: 'i18n/t' }) }
75
82
  };
@@ -96,16 +103,18 @@ export default {
96
103
  />
97
104
  </div>
98
105
 
99
- <h2>
100
- {{ t('advancedSettings.provisioning.header') }}
101
- </h2>
102
- <div
103
- v-for="(setting) in provisioningSettings"
104
- :key="setting.id"
105
- >
106
- <Setting
107
- :value="setting"
108
- />
106
+ <div v-if="topLevelPermissions && topLevelPermissions === 'superadmin'">
107
+ <h2>
108
+ {{ t('advancedSettings.provisioning.header') }}
109
+ </h2>
110
+ <div
111
+ v-for="(setting) in provisioningSettings"
112
+ :key="setting.id"
113
+ >
114
+ <Setting
115
+ :value="setting"
116
+ />
117
+ </div>
109
118
  </div>
110
119
  </div>
111
120
  </template>
@@ -142,9 +142,10 @@ export default {
142
142
  :to="{ name: 'c-cluster-auth-user.retention'}"
143
143
  class="btn role-link btn-sm btn-user-retention"
144
144
  data-testid="router-link-user-retention"
145
+ style="text-align: left;min-width: auto !important;width: auto;"
145
146
  >
146
- <i class="icon icon-gear" />
147
- {{ t('user.retention.button.label') }}
147
+ <!-- <i class="icon icon-gear" />
148
+ {{ t('user.retention.button.label') }} -->
148
149
  </router-link>
149
150
  </template>
150
151
  </Masthead>
@@ -171,8 +172,11 @@ export default {
171
172
 
172
173
  <style lang="scss">
173
174
  .btn-user-retention {
174
- display: flex;
175
+ display: block;
175
176
  gap: 0.25rem;
176
177
  padding: 0;
177
178
  }
179
+ .btn-user-retention:hover {
180
+ color: #333 !important;
181
+ }
178
182
  </style>
@@ -42,6 +42,9 @@ export default {
42
42
  headers() {
43
43
  const headersFromSchema = this.$store.getters['type-map/headersFor'](this.schema);
44
44
 
45
+ [headersFromSchema[0], headersFromSchema[1]] = [headersFromSchema[1], headersFromSchema[0]];
46
+ headersFromSchema[0].width = '200px';
47
+ headersFromSchema[1].width = '100px';
45
48
  // harvester is reusing this namespace.js to render ns page, we need to make sure harvester backend support quota schema to show this column.
46
49
  if (this.hasHarvesterResourceQuotaSchema && Array.isArray(headersFromSchema) && headersFromSchema.length > 1) {
47
50
  const columnIdx = headersFromSchema.length - 1;
@@ -307,19 +307,18 @@ export default {
307
307
  <router-link
308
308
  v-if="row.mgmt && row.mgmt.isReady && !row.hasError"
309
309
  data-testid="cluster-manager-list-explore-management"
310
- class="btn btn-sm role-secondary"
311
310
  :to="{name: 'c-cluster', params: {cluster: row.mgmt.id}}"
312
311
  >
313
- {{ t('cluster.explore') }}
312
+ <a href="javascript:;">
313
+ {{ t('cluster.explore') }}
314
+ </a>
314
315
  </router-link>
315
- <button
316
- v-else
316
+ <span
317
317
  data-testid="cluster-manager-list-explore"
318
- :disabled="true"
319
- class="btn btn-sm role-secondary"
318
+ v-else
320
319
  >
321
320
  {{ t('cluster.explore') }}
322
- </button>
321
+ </span>
323
322
  </template>
324
323
  </ResourceTable>
325
324
  </div>
package/mixins/brand.js CHANGED
@@ -175,7 +175,24 @@ export default {
175
175
  const vars = createCssVars(color, this.theme, name);
176
176
 
177
177
  for (const prop in vars) {
178
+
178
179
  document.body.style.setProperty(prop, vars[prop]);
180
+
181
+ // 主色调hover值动态
182
+ if (prop === '--primary-hover-bg') {
183
+ // 如果是你要设置透明度的变量,比如 hover
184
+ let value = '#E8F4FF';
185
+ if (vars[prop]) {
186
+ const match = vars[prop].match(/rgb\((\d+),\s*(\d+),\s*(\d+)\)/);
187
+ if (match) {
188
+ const [_, r, g, b] = match;
189
+ value = `rgba(${r}, ${g}, ${b}, 0.15)`;
190
+ }
191
+ }
192
+
193
+ document.body.style.setProperty('--nav-hover-color', vars[prop]);
194
+ document.body.style.setProperty('--nav-active', value);
195
+ }
179
196
  }
180
197
  },
181
198
 
@@ -170,6 +170,16 @@ export default {
170
170
  } catch (err) {
171
171
  // This exception handles errors from the `request` action when it receives a failed http request. The `err` object could be from the action's error handler (raw http response object containing `status`) or thrown later on given the response of the action (a massaged object containing `_status`). TBD why one 409 triggers the error handler and another does not.
172
172
  const IS_ERR_409 = err.status === 409 || err._status === 409;
173
+
174
+ const IS_ERR_403 = err.status === 403 || err._status === 403;
175
+
176
+ if (err.message === '' && err.fieldName && err.code) {
177
+ err.message = err.code + ' ' + err.fieldName
178
+ }
179
+
180
+ if (IS_ERR_403) {
181
+ err.message = '权限不足'
182
+ }
173
183
 
174
184
  // Conflict, the resource being edited has changed since starting editing
175
185
  if (IS_ERR_409 && depth === 0 && this.isEdit) {