@rancher/shell 0.1.2 → 0.1.4

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 (347) hide show
  1. package/assets/brand/suse/dark/rancher-logo.svg +1 -148
  2. package/assets/brand/suse/rancher-logo.svg +1 -130
  3. package/assets/images/featured/img1.jpg +0 -0
  4. package/assets/images/featured.jpg +0 -0
  5. package/assets/images/generic-plugin.svg +7 -0
  6. package/assets/styles/themes/_dark.scss +3 -0
  7. package/assets/styles/themes/_light.scss +3 -0
  8. package/assets/styles/themes/_suse.scss +1 -1
  9. package/assets/translations/en-us.yaml +209 -813
  10. package/assets/translations/zh-hans.yaml +28 -792
  11. package/components/ActionMenu.vue +3 -3
  12. package/components/AsyncButton.vue +17 -2
  13. package/components/ButtonDropdown.vue +4 -0
  14. package/components/Carousel.vue +291 -0
  15. package/components/CodeMirror.vue +6 -8
  16. package/components/CommunityLinks.vue +70 -19
  17. package/components/ContainerResourceLimit.vue +14 -0
  18. package/components/CruResource.vue +11 -3
  19. package/components/Dialog.vue +102 -0
  20. package/components/ExplorerMembers.vue +121 -0
  21. package/components/ExplorerProjectsNamespaces.vue +404 -0
  22. package/components/GrafanaDashboard.vue +17 -2
  23. package/components/IconMessage.vue +9 -1
  24. package/components/LocaleSelector.vue +114 -0
  25. package/components/PromptModal.vue +2 -3
  26. package/components/ResourceList/index.vue +1 -1
  27. package/components/ResourceTable.vue +9 -7
  28. package/components/SimpleBox.vue +6 -4
  29. package/components/SingleClusterInfo.vue +1 -1
  30. package/components/SortableTable/index.vue +18 -25
  31. package/components/SortableTable/selection.js +1 -0
  32. package/components/Tabbed/Tab.vue +5 -0
  33. package/components/Tabbed/index.vue +29 -2
  34. package/components/auth/AzureWarning.vue +5 -1
  35. package/components/auth/Principal.vue +2 -1
  36. package/components/auth/RoleDetailEdit.vue +18 -11
  37. package/components/fleet/FleetBundles.vue +8 -3
  38. package/components/fleet/FleetRepos.vue +0 -2
  39. package/components/fleet/FleetSummary.vue +6 -0
  40. package/components/form/KeyValue.vue +80 -58
  41. package/components/form/NameNsDescription.vue +12 -8
  42. package/components/form/NodeScheduling.vue +1 -1
  43. package/components/form/ResourceTabs/index.vue +5 -1
  44. package/components/form/WorkloadPorts.vue +1 -1
  45. package/components/formatter/ClusterLink.vue +3 -7
  46. package/components/formatter/WorkloadHealthScale.vue +1 -1
  47. package/components/nav/Header.vue +9 -9
  48. package/components/nav/NamespaceFilter.vue +10 -7
  49. package/components/nav/TopLevelMenu.vue +10 -65
  50. package/components/nav/WindowManager/ContainerLogs.vue +1 -1
  51. package/config/footer.js +13 -14
  52. package/config/labels-annotations.js +2 -1
  53. package/config/product/explorer.js +5 -4
  54. package/config/product/harvester-manager.js +64 -2
  55. package/config/product/legacy.js +0 -47
  56. package/config/product/manager.js +9 -0
  57. package/config/product/multi-cluster-apps.js +0 -12
  58. package/config/product/settings.js +12 -1
  59. package/config/product/uiplugins.js +17 -0
  60. package/config/settings.js +37 -72
  61. package/config/table-headers.js +0 -1
  62. package/config/types.js +9 -25
  63. package/config/uiplugins.js +60 -0
  64. package/content/docs/en-us/getting-started.md +1 -26
  65. package/core/plugin-routes.ts +34 -22
  66. package/core/plugin.ts +15 -3
  67. package/core/plugins-loader.js +2 -0
  68. package/core/plugins.js +91 -36
  69. package/core/types.ts +7 -1
  70. package/detail/provisioning.cattle.io.cluster.vue +15 -2
  71. package/detail/workload/index.vue +11 -5
  72. package/{components/dialog → dialog}/AddClusterMemberDialog.vue +0 -0
  73. package/{components/dialog → dialog}/AddCustomBadgeDialog.vue +0 -0
  74. package/{components/dialog → dialog}/AddProjectMemberDialog.vue +0 -0
  75. package/{components/dialog → dialog}/AddonConfigConfirmationDialog.vue +0 -0
  76. package/dialog/DiagnosticTimingsDialog.vue +116 -0
  77. package/{components/dialog → dialog}/DrainNode.vue +0 -0
  78. package/{components/dialog → dialog}/ForceMachineRemoveDialog.vue +0 -0
  79. package/{components/dialog → dialog}/GenericPrompt.vue +0 -0
  80. package/{components/dialog → dialog}/RollbackWorkloadDialog.vue +0 -0
  81. package/{components/dialog → dialog}/RotateCertificatesDialog.vue +9 -3
  82. package/{components/dialog → dialog}/RotateEncryptionKeyDialog.vue +0 -0
  83. package/{components/dialog → dialog}/SaveAsRKETemplateDialog.vue +0 -0
  84. package/{components/dialog → dialog}/ScaleMachineDownDialog.vue +0 -0
  85. package/edit/auth/azuread.vue +44 -6
  86. package/edit/management.cattle.io.project.vue +2 -2
  87. package/edit/namespace.vue +17 -10
  88. package/edit/networking.k8s.io.ingress/index.vue +2 -2
  89. package/edit/persistentvolume/index.vue +3 -0
  90. package/edit/persistentvolumeclaim.vue +1 -0
  91. package/edit/pod.vue +27 -0
  92. package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +1 -1
  93. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +33 -5
  94. package/edit/provisioning.cattle.io.cluster/rke2.vue +76 -5
  95. package/edit/service.vue +8 -6
  96. package/edit/workload/__tests__/Upgrading.test.ts +1 -0
  97. package/edit/workload/index.vue +375 -15
  98. package/edit/workload/mixins/workload.js +62 -7
  99. package/edit/workload/storage/ContainerMountPaths.vue +240 -0
  100. package/edit/workload/storage/Mount.vue +1 -0
  101. package/edit/workload/storage/awsElasticBlockStore.vue +20 -1
  102. package/edit/workload/storage/azureDisk.vue +22 -2
  103. package/edit/workload/storage/azureFile.vue +20 -2
  104. package/edit/workload/storage/csi/index.vue +23 -1
  105. package/edit/workload/storage/gcePersistentDisk.vue +20 -2
  106. package/edit/workload/storage/index.vue +23 -49
  107. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +1 -0
  108. package/edit/workload/storage/vsphereVolume.vue +11 -1
  109. package/layouts/default.vue +63 -32
  110. package/layouts/error.vue +5 -1
  111. package/layouts/home.vue +14 -5
  112. package/layouts/plain.vue +10 -5
  113. package/list/harvesterhci.io.management.cluster.vue +74 -33
  114. package/list/management.cattle.io.setting.vue +3 -3
  115. package/list/namespace.vue +3 -5
  116. package/list/provisioning.cattle.io.cluster.vue +1 -1
  117. package/machine-config/amazonec2.vue +2 -0
  118. package/machine-config/harvester.vue +100 -51
  119. package/middleware/authenticated.js +56 -52
  120. package/mixins/form-validation.js +1 -1
  121. package/mixins/resource-fetch.js +3 -1
  122. package/models/catalog.cattle.io.uiplugin.js +34 -0
  123. package/models/cluster/node.js +25 -2
  124. package/models/fleet.cattle.io.bundle.js +27 -20
  125. package/models/harvesterhci.io.management.cluster.js +200 -5
  126. package/models/management.cattle.io.cluster.js +1 -1
  127. package/models/management.cattle.io.clusterroletemplatebinding.js +9 -0
  128. package/models/management.cattle.io.project.js +23 -2
  129. package/models/namespace.js +19 -3
  130. package/models/pod.js +19 -2
  131. package/models/provisioning.cattle.io.cluster.js +16 -6
  132. package/models/workload.js +9 -246
  133. package/models/workload.service.js +314 -0
  134. package/nuxt.config.js +80 -34
  135. package/package.json +107 -108
  136. package/pages/auth/login.vue +11 -2
  137. package/pages/auth/setup.vue +1 -1
  138. package/pages/c/_cluster/_product/members/index.vue +3 -93
  139. package/pages/c/_cluster/_product/projectsnamespaces.vue +6 -403
  140. package/pages/c/_cluster/apps/charts/index.vue +46 -1
  141. package/pages/c/_cluster/apps/charts/install.vue +10 -9
  142. package/pages/c/_cluster/explorer/index.vue +72 -9
  143. package/pages/c/_cluster/explorer/tools/index.vue +12 -5
  144. package/pages/c/_cluster/mcapps/index.vue +1 -1
  145. package/pages/c/_cluster/settings/brand.vue +0 -40
  146. package/pages/c/_cluster/settings/links.vue +200 -0
  147. package/pages/c/_cluster/settings/performance.vue +19 -16
  148. package/pages/c/_cluster/uiplugins/DeveloperInstallDialog.vue +232 -0
  149. package/pages/c/_cluster/uiplugins/InstallDialog.vue +242 -0
  150. package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +284 -0
  151. package/pages/c/_cluster/uiplugins/RemoveUIPlugins.vue +130 -0
  152. package/pages/c/_cluster/uiplugins/SetupUIPlugins.vue +253 -0
  153. package/pages/c/_cluster/uiplugins/UninstallDialog.vue +115 -0
  154. package/pages/c/_cluster/uiplugins/index.vue +694 -0
  155. package/pages/diagnostic.vue +185 -101
  156. package/pages/docs/_doc.vue +3 -1
  157. package/pages/fail-whale.vue +1 -10
  158. package/pages/home.vue +21 -56
  159. package/pages/index.vue +18 -4
  160. package/pages/prefs.vue +108 -86
  161. package/pages/safeMode.vue +17 -0
  162. package/pages/support/index.vue +23 -15
  163. package/pkg/auto-import.js +44 -7
  164. package/pkg/dynamic-importer.lib.js +4 -0
  165. package/pkg/dynamic-plugin-loader.js +28 -0
  166. package/pkg/import.js +2 -2
  167. package/pkg/model-loader-require.lib.js +3 -0
  168. package/pkg/vue.config.js +9 -6
  169. package/plugins/dashboard-store/model-loader-require.js +12 -0
  170. package/plugins/dashboard-store/model-loader.js +4 -1
  171. package/plugins/dashboard-store/resource-class.js +12 -5
  172. package/plugins/formatters.js +15 -0
  173. package/plugins/plugin.js +56 -4
  174. package/plugins/steve/actions.js +1 -1
  175. package/plugins/steve/index.js +6 -4
  176. package/plugins/steve/mutations.js +1 -1
  177. package/plugins/steve/subscribe.js +89 -56
  178. package/plugins/steve/web-worker.steve-sub-worker.js +24 -15
  179. package/promptRemove/management.cattle.io.globalrole.vue +47 -0
  180. package/promptRemove/management.cattle.io.roletemplate.vue +47 -0
  181. package/promptRemove/mixin/roleDeletionCheck.js +97 -0
  182. package/rancher-components/Form/Checkbox/Checkbox.test.ts +77 -0
  183. package/rancher-components/Form/Checkbox/Checkbox.vue +12 -2
  184. package/scripts/build-pkg.sh +48 -2
  185. package/scripts/drone-build-pkg.sh +31 -0
  186. package/scripts/publish-shell.sh +11 -12
  187. package/scripts/serve-pkgs +17 -10
  188. package/scripts/sync-shell-deps +37 -0
  189. package/store/catalog.js +12 -9
  190. package/store/i18n.js +26 -12
  191. package/store/index.js +4 -181
  192. package/store/prefs.js +46 -2
  193. package/store/type-map.js +47 -33
  194. package/store/uiplugins.ts +15 -61
  195. package/utils/__tests__/object.test.ts +0 -24
  196. package/utils/__tests__/selector.test.ts +1 -1
  197. package/utils/cluster.js +1 -1
  198. package/utils/custom-validators.js +1 -12
  199. package/utils/dynamic-importer.js +5 -1
  200. package/utils/grafana.js +2 -6
  201. package/utils/socket.js +41 -20
  202. package/utils/string.js +1 -7
  203. package/utils/validators/formRules/__tests__/index.test.ts +108 -0
  204. package/utils/validators/formRules/index.ts +9 -1
  205. package/utils/validators/setting.js +0 -35
  206. package/yarn-error.log +195 -0
  207. package/components/FilterLabel.vue +0 -254
  208. package/components/HarvesterUpgradeProgressBarList.vue +0 -109
  209. package/components/VMConsoleBar.vue +0 -87
  210. package/components/dialog/harvester/AddHotplugModal.vue +0 -159
  211. package/components/dialog/harvester/BackupModal.vue +0 -117
  212. package/components/dialog/harvester/CloneTemplate.vue +0 -125
  213. package/components/dialog/harvester/EjectCDROMDialog.vue +0 -157
  214. package/components/dialog/harvester/ExportImageDialog.vue +0 -152
  215. package/components/dialog/harvester/MaintenanceDialog.vue +0 -94
  216. package/components/dialog/harvester/MigrationDialog.vue +0 -154
  217. package/components/dialog/harvester/RestoreDialog.vue +0 -153
  218. package/components/dialog/harvester/SupportBundle.vue +0 -217
  219. package/components/dialog/harvester/UnplugVolume.vue +0 -108
  220. package/components/form/SerialConsole/index.vue +0 -267
  221. package/components/formatter/AttachVMWithName.vue +0 -46
  222. package/components/formatter/CloudInitType.vue +0 -27
  223. package/components/formatter/HarvesterBackupTargetValidation.vue +0 -43
  224. package/components/formatter/HarvesterCPUUsed.vue +0 -122
  225. package/components/formatter/HarvesterDiskState.vue +0 -66
  226. package/components/formatter/HarvesterHostName.vue +0 -66
  227. package/components/formatter/HarvesterIpAddress.vue +0 -90
  228. package/components/formatter/HarvesterMemoryUsed.vue +0 -140
  229. package/components/formatter/HarvesterMigrationState.vue +0 -85
  230. package/components/formatter/HarvesterNodeName.vue +0 -49
  231. package/components/formatter/HarvesterStorageUsed.vue +0 -194
  232. package/components/formatter/HarvesterVmState.vue +0 -123
  233. package/components/nav/HarvesterUpgrade.vue +0 -232
  234. package/components/novnc/NovncConsole.vue +0 -93
  235. package/components/novnc/NovncConsoleItem.vue +0 -89
  236. package/components/novnc/NovncConsoleWrapper.vue +0 -243
  237. package/config/harvester-map.js +0 -44
  238. package/config/harvester-table-headers.js +0 -27
  239. package/config/product/harvester.js +0 -305
  240. package/detail/harvesterhci.io.host/HarvesterHostBasic.vue +0 -364
  241. package/detail/harvesterhci.io.host/HarvesterHostDisk.vue +0 -200
  242. package/detail/harvesterhci.io.host/HarvesterHostNetwork.vue +0 -89
  243. package/detail/harvesterhci.io.host/VirtualMachineInstance.vue +0 -134
  244. package/detail/harvesterhci.io.host/index.vue +0 -243
  245. package/detail/harvesterhci.io.virtualmachinebackup/index.vue +0 -221
  246. package/detail/harvesterhci.io.virtualmachineimage.vue +0 -118
  247. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineBasics.vue +0 -279
  248. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineEvents.vue +0 -75
  249. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineKeypairs.vue +0 -114
  250. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineMigration.vue +0 -79
  251. package/detail/kubevirt.io.virtualmachine/index.vue +0 -213
  252. package/edit/harvesterhci.io.cloudtemplate.vue +0 -123
  253. package/edit/harvesterhci.io.host/HarvesterDisk.vue +0 -262
  254. package/edit/harvesterhci.io.host/index.vue +0 -533
  255. package/edit/harvesterhci.io.keypair.vue +0 -112
  256. package/edit/harvesterhci.io.managedchart/index.vue +0 -25
  257. package/edit/harvesterhci.io.managedchart/rancher-monitoring.vue +0 -172
  258. package/edit/harvesterhci.io.networkattachmentdefinition.vue +0 -210
  259. package/edit/harvesterhci.io.setting/additional-ca.vue +0 -36
  260. package/edit/harvesterhci.io.setting/backup-target.vue +0 -182
  261. package/edit/harvesterhci.io.setting/http-proxy.vue +0 -79
  262. package/edit/harvesterhci.io.setting/index.vue +0 -201
  263. package/edit/harvesterhci.io.setting/overcommit-config.vue +0 -94
  264. package/edit/harvesterhci.io.setting/ssl-certificates.vue +0 -117
  265. package/edit/harvesterhci.io.setting/ssl-parameters.vue +0 -161
  266. package/edit/harvesterhci.io.setting/support-bundle-image.vue +0 -134
  267. package/edit/harvesterhci.io.setting/support-bundle-namespaces.vue +0 -73
  268. package/edit/harvesterhci.io.setting/vip-pools.vue +0 -244
  269. package/edit/harvesterhci.io.setting/vm-force-reset-policy.vue +0 -81
  270. package/edit/harvesterhci.io.virtualmachinebackup.vue +0 -256
  271. package/edit/harvesterhci.io.virtualmachineimage.vue +0 -364
  272. package/edit/harvesterhci.io.virtualmachinetemplateversion.vue +0 -340
  273. package/edit/harvesterhci.io.volume.vue +0 -195
  274. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/AccessCredentialsUsers.vue +0 -190
  275. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/index.vue +0 -212
  276. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/basicAuth.vue +0 -94
  277. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/sshkey.vue +0 -85
  278. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/DataTemplate.vue +0 -153
  279. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/index.vue +0 -279
  280. package/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory.vue +0 -113
  281. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/__tests__/HarvesterEditNetwork.test.ts +0 -41
  282. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/base.vue +0 -281
  283. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/index.vue +0 -142
  284. package/edit/kubevirt.io.virtualmachine/VirtualMachineReserved.vue +0 -54
  285. package/edit/kubevirt.io.virtualmachine/VirtualMachineSSHKey.vue +0 -256
  286. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/index.vue +0 -391
  287. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditContainer.test.ts +0 -40
  288. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditExisting.test.ts +0 -102
  289. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVMImage.test.ts +0 -117
  290. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVolume.test.ts +0 -74
  291. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/container.vue +0 -132
  292. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/existing.vue +0 -303
  293. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/vmImage.vue +0 -285
  294. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/volume.vue +0 -188
  295. package/edit/kubevirt.io.virtualmachine/index.vue +0 -642
  296. package/edit/network.harvesterhci.io.clusternetwork/index.vue +0 -19
  297. package/edit/network.harvesterhci.io.clusternetwork/vlan.vue +0 -134
  298. package/edit/workload/types/Deployment.vue +0 -377
  299. package/edit/workload/types/Generic.vue +0 -295
  300. package/list/harvesterhci.io.cloudtemplate.vue +0 -78
  301. package/list/harvesterhci.io.dashboard/HarvesterUpgrade.vue +0 -211
  302. package/list/harvesterhci.io.dashboard/UpgradeInfo.vue +0 -40
  303. package/list/harvesterhci.io.dashboard/index.vue +0 -752
  304. package/list/harvesterhci.io.host/index.vue +0 -186
  305. package/list/harvesterhci.io.networkattachmentdefinition.vue +0 -167
  306. package/list/harvesterhci.io.setting.vue +0 -241
  307. package/list/harvesterhci.io.virtualmachinebackup.vue +0 -172
  308. package/list/harvesterhci.io.virtualmachineimage.vue +0 -80
  309. package/list/harvesterhci.io.virtualmachinetemplateversion.vue +0 -173
  310. package/list/harvesterhci.io.volume.vue +0 -122
  311. package/list/kubevirt.io.virtualmachine.vue +0 -193
  312. package/mixins/harvester-vm/impl.js +0 -267
  313. package/mixins/harvester-vm/index.js +0 -1357
  314. package/models/harvester/configmap.js +0 -32
  315. package/models/harvester/harvesterhci.io.blockdevice.js +0 -55
  316. package/models/harvester/harvesterhci.io.keypair.js +0 -12
  317. package/models/harvester/harvesterhci.io.setting.js +0 -127
  318. package/models/harvester/harvesterhci.io.supportbundle.js +0 -35
  319. package/models/harvester/harvesterhci.io.upgrade.js +0 -226
  320. package/models/harvester/harvesterhci.io.virtualmachinebackup.js +0 -116
  321. package/models/harvester/harvesterhci.io.virtualmachineimage.js +0 -255
  322. package/models/harvester/harvesterhci.io.virtualmachinerestore.js +0 -43
  323. package/models/harvester/harvesterhci.io.virtualmachinetemplate.js +0 -69
  324. package/models/harvester/harvesterhci.io.virtualmachinetemplateversion.js +0 -227
  325. package/models/harvester/k8s.cni.cncf.io.networkattachmentdefinition.js +0 -32
  326. package/models/harvester/kubevirt.io.virtualmachine.js +0 -850
  327. package/models/harvester/kubevirt.io.virtualmachineinstance.js +0 -142
  328. package/models/harvester/management.cattle.io.managedchart.js +0 -191
  329. package/models/harvester/management.cattle.io.setting.js +0 -40
  330. package/models/harvester/network.harvesterhci.io.clusternetwork.js +0 -100
  331. package/models/harvester/network.harvesterhci.io.nodenetwork.js +0 -34
  332. package/models/harvester/node.js +0 -255
  333. package/models/harvester/persistentvolumeclaim.js +0 -166
  334. package/models/harvester/pod.js +0 -185
  335. package/pages/c/_cluster/harvester/airgapupgrade/index.vue +0 -309
  336. package/pages/c/_cluster/harvester/console/_uid/serial.vue +0 -51
  337. package/pages/c/_cluster/harvester/console/_uid/vnc.vue +0 -52
  338. package/pages/c/_cluster/harvester/index.vue +0 -24
  339. package/pages/c/_cluster/harvester/support/index.vue +0 -154
  340. package/pages/plugins.vue +0 -387
  341. package/pkg/model-loader.lib.js +0 -3
  342. package/promptRemove/kubevirt.io.virtualmachine.vue +0 -164
  343. package/server/verdaccio-middleware.js +0 -56
  344. package/store/harvester-common.js +0 -126
  345. package/utils/validators/vm-datavolumes.js +0 -38
  346. package/utils/validators/vm-image.js +0 -32
  347. package/utils/validators/vm.js +0 -221
@@ -155,10 +155,10 @@ export default {
155
155
  // If the action menu state is controlled with Vuex,
156
156
  // use the target element and the target event
157
157
  // to position the menu.
158
- this.style = fitOnScreen(menu, event || elem, {
158
+ this.style = fitOnScreen(menu, elem || event, {
159
159
  overlapX: true,
160
- fudgeX: elem ? 4 : 0,
161
- fudgeY: elem ? 4 : 0,
160
+ fudgeX: elem ? -2 : 0,
161
+ fudgeY: elem ? 20 : 0,
162
162
  positionX: (elem ? AUTO : CENTER),
163
163
  positionY: AUTO,
164
164
  });
@@ -95,7 +95,13 @@ export default Vue.extend({
95
95
  currentPhase: {
96
96
  type: String,
97
97
  default: ASYNC_BUTTON_STATES.ACTION,
98
- }
98
+ },
99
+
100
+ manual: {
101
+ type: Boolean,
102
+ default: false,
103
+ },
104
+
99
105
  },
100
106
 
101
107
  data(): { phase: string, timer?: NodeJS.Timeout} {
@@ -190,6 +196,12 @@ export default Vue.extend({
190
196
  }
191
197
  },
192
198
 
199
+ beforeDestroy() {
200
+ if (this.timer) {
201
+ clearTimeout(this.timer);
202
+ }
203
+ },
204
+
193
205
  methods: {
194
206
  clicked($event: MouseEvent) {
195
207
  if ($event) {
@@ -205,7 +217,10 @@ export default Vue.extend({
205
217
  clearTimeout(this.timer);
206
218
  }
207
219
 
208
- this.phase = ASYNC_BUTTON_STATES.WAITING;
220
+ // If manual property is set, don't automatically change the button on click
221
+ if (!this.manual) {
222
+ this.phase = ASYNC_BUTTON_STATES.WAITING;
223
+ }
209
224
 
210
225
  const cb: AsyncButtonCallback = (success) => {
211
226
  this.done(success);
@@ -194,6 +194,10 @@ export default {
194
194
  @search:focus="onFocus"
195
195
  @input="$emit('click-action', $event)"
196
196
  >
197
+ <template slot="no-options">
198
+ <slot name="no-options"></slot>
199
+ </template>
200
+
197
201
  <template #selected-option="option">
198
202
  <button
199
203
  tabindex="-1"
@@ -0,0 +1,291 @@
1
+ <script>
2
+ import { get } from '@shell/utils/object';
3
+ import { BadgeState } from '@components/BadgeState';
4
+
5
+ export default {
6
+ components: { BadgeState },
7
+ name: 'Carousel',
8
+ props: {
9
+ sliders: {
10
+ type: Array,
11
+ required: true,
12
+ },
13
+ keyField: {
14
+ type: String,
15
+ default: 'key',
16
+ },
17
+ asLink: {
18
+ type: Boolean,
19
+ default: false,
20
+ },
21
+ linkField: {
22
+ type: String,
23
+ default: 'link'
24
+ },
25
+ targetField: {
26
+ type: String,
27
+ default: 'target',
28
+ },
29
+ rel: {
30
+ type: String,
31
+ default: 'noopener noreferrer nofollow'
32
+ },
33
+ },
34
+ data() {
35
+ return {
36
+ slider: this.sliders,
37
+ activeItemId: 0,
38
+ autoScroll: true
39
+ };
40
+ },
41
+
42
+ computed: {
43
+
44
+ trackStyle() {
45
+ const sliderItem = this.activeItemId * 100 / this.slider.length;
46
+ const width = 60 * this.slider.length;
47
+
48
+ return `transform: translateX(-${ sliderItem }%); width: ${ width }%`;
49
+ },
50
+ },
51
+
52
+ methods: {
53
+ get,
54
+
55
+ select(slide, i) {
56
+ this.$emit('clicked', slide, i);
57
+ },
58
+
59
+ scrollSlide(i) {
60
+ this.autoScroll = false;
61
+ this.activeItemId = i;
62
+ setTimeout(() => {
63
+ this.slidePosition();
64
+ }, 400);
65
+ },
66
+
67
+ nextPrev(item) {
68
+ this.autoScroll = false;
69
+ if (item === 'next' && this.activeItemId < this.slider.length - 1) {
70
+ this.activeItemId++;
71
+ }
72
+
73
+ if (item === 'prev' && this.activeItemId > 0) {
74
+ this.activeItemId--;
75
+ }
76
+
77
+ this.slidePosition();
78
+ },
79
+
80
+ timer() {
81
+ setInterval(this.autoScrollSlide, 2000);
82
+ },
83
+ autoScrollSlide() {
84
+ if (this.activeItemId < this.slider.length && this.autoScroll ) {
85
+ this.activeItemId++;
86
+ }
87
+
88
+ if (this.activeItemId > this.slider.length - 1) {
89
+ this.autoScroll = false;
90
+ this.activeItemId = 0;
91
+ }
92
+ this.slidePosition();
93
+ },
94
+
95
+ slidePosition() {
96
+ if (this.activeItemId <= 1) {
97
+ this.$refs.slide[this.slider.length - 1].style.left = '-93%';
98
+ this.$refs.slide[0].style.left = '7%';
99
+ } else {
100
+ this.$refs.slide[this.slider.length - 1].style.left = '7%';
101
+ this.$refs.slide[0].style.left = '107%';
102
+ }
103
+ }
104
+ },
105
+
106
+ mounted() {
107
+ this.timer();
108
+ }
109
+ };
110
+
111
+ </script>
112
+
113
+ <template>
114
+ <div class="slider">
115
+ <div id="slide-track" ref="slider" :style="trackStyle" class="slide-track">
116
+ <div
117
+ :is="asLink ? 'a' : 'div'"
118
+ v-for="(slide, i) in sliders"
119
+ :id="`slide` + i"
120
+ ref="slide"
121
+ :key="get(slide, keyField)"
122
+ class="slide"
123
+ :href="asLink ? get(slide, linkField) : null"
124
+ :target="get(slide, targetField)"
125
+ :rel="rel"
126
+ @click="select(slide, i)"
127
+ >
128
+ <div class="slide-content">
129
+ <div class="slide-img">
130
+ <img :src="slide.icon ? slide.icon : `/_nuxt/shell/assets/images/generic-catalog.svg`" />
131
+ </div>
132
+ <div class="slide-content-right">
133
+ <BadgeState :label="slide.repoName" color="slider-badge mb-20" />
134
+ <h1>{{ slide.chartNameDisplay }}</h1>
135
+ <p>{{ slide.chartDescription }}</p>
136
+ </div>
137
+ </div>
138
+ </div>
139
+ </div>
140
+ <div class="controls">
141
+ <div
142
+ v-for="(slide, i) in slider"
143
+ :key="i"
144
+ class="control-item"
145
+ :class="{'active': activeItemId === i}"
146
+ @click="scrollSlide(i, slider.length)"
147
+ ></div>
148
+ </div>
149
+ <div ref="prev" class="prev" :class="[activeItemId === 0 ? 'disabled' : 'prev']" @click="nextPrev('prev')">
150
+ <i class="icon icon-chevron-left icon-4x"></i>
151
+ </div>
152
+ <div ref="next" class="next" :class="[activeItemId === slider.length - 1 ? 'disabled' : 'next']" @click="nextPrev('next')">
153
+ <i class="icon icon-chevron-right icon-4x"></i>
154
+ </div>
155
+ </div>
156
+ </template>
157
+
158
+ <style lang='scss' scoped>
159
+ .slider {
160
+ margin: auto;
161
+ position: relative;
162
+ width: 100%;
163
+ place-items: center;
164
+ overflow: hidden;
165
+ margin-bottom: 30px;
166
+ min-width: 700px;
167
+
168
+ &:hover {
169
+ .prev,
170
+ .next {
171
+ display: block;
172
+ }
173
+ }
174
+ }
175
+
176
+ .slide-track {
177
+ display: flex;
178
+ animation: scrolls 10s ;
179
+ position: relative;
180
+ transition: 1s ease-in-out;
181
+ }
182
+
183
+ .slider-badge {
184
+ background: var(--app-partner-accent);
185
+ color: var(--body-bg);
186
+ }
187
+ .slide {
188
+ min-height: 210px;
189
+ width: 60%;
190
+ max-width: 60%;
191
+ margin: 0 10px;
192
+ position: relative;
193
+ border: 1px solid var(--tabbed-border);
194
+ border-radius: var(--border-radius);
195
+ left: 7%;
196
+ cursor: pointer;
197
+
198
+ &:last-child {
199
+ left: -93%;
200
+ }
201
+
202
+ .slide-header {
203
+ background: var(--default);
204
+ width: 100%;
205
+ padding: 10px 15px;
206
+ }
207
+ .slide-content {
208
+ display: flex;
209
+ padding: 30px;
210
+
211
+ .slide-img {
212
+ width: 150px;
213
+ background: var(--card-badge-text);
214
+ border-radius: calc(2 * var(--border-radius));
215
+
216
+ img {
217
+ width: 100%;
218
+ }
219
+ }
220
+
221
+ .slide-content-right {
222
+ border-left: 1px solid var(--tabbed-border);
223
+ margin-left: 30px;
224
+ padding-left: 30px;
225
+
226
+ span {
227
+ margin: 0;
228
+ }
229
+ }
230
+
231
+ }
232
+ }
233
+
234
+ .slider::before,
235
+ .slider::after {
236
+ background: linear-gradient(to right, var(--slider-light-bg) 0%, var(--slider-light-bg-right) 100%);
237
+ content: "";
238
+ height: 100%;
239
+ position: absolute;
240
+ width: 15%;
241
+ z-index: z-index('overContent');
242
+ }
243
+
244
+ .slider::before {
245
+ left: 0;
246
+ top: 0;
247
+ }
248
+ .slider::after{
249
+ right: -1px;
250
+ top: 0;
251
+ transform: rotate(180deg);
252
+ }
253
+
254
+ .controls {
255
+ width: 100%;
256
+ display: flex;
257
+ justify-content: center;
258
+ margin-top: 10px;
259
+
260
+ .control-item {
261
+ width: 10px;
262
+ height: 10px;
263
+ border-radius: 50%;
264
+ background: var(--scrollbar-thumb);
265
+ margin: 5px;
266
+ cursor: pointer;
267
+
268
+ &.active {
269
+ background:var(--body-text);
270
+ }
271
+ }
272
+ }
273
+ .prev,
274
+ .next {
275
+ position: absolute;
276
+ z-index: 20;
277
+ top: 90px;
278
+ display: none;
279
+ cursor: pointer;
280
+
281
+ &.disabled .icon {
282
+ color: var(--disabled-bg);
283
+ cursor: not-allowed;
284
+ }
285
+ }
286
+
287
+ .next {
288
+ right: 0;
289
+ }
290
+
291
+ </style>
@@ -46,14 +46,12 @@ export default {
46
46
  },
47
47
 
48
48
  created() {
49
- if ( process.client ) {
50
- if (window.__codeMirrorLoader) {
51
- window.__codeMirrorLoader().then(() => {
52
- this.loaded = true;
53
- });
54
- } else {
55
- console.error('Code mirror loader not available'); // eslint-disable-line no-console
56
- }
49
+ if (window.__codeMirrorLoader) {
50
+ window.__codeMirrorLoader().then(() => {
51
+ this.loaded = true;
52
+ });
53
+ } else {
54
+ console.error('Code mirror loader not available'); // eslint-disable-line no-console
57
55
  }
58
56
  },
59
57
 
@@ -7,6 +7,8 @@ import { SETTING } from '@shell/config/settings';
7
7
  import { mapGetters } from 'vuex';
8
8
 
9
9
  export default {
10
+ name: 'CommunityLinks',
11
+
10
12
  components: { SimpleBox },
11
13
 
12
14
  props: {
@@ -21,12 +23,27 @@ export default {
21
23
  mixins: [Closeable],
22
24
 
23
25
  async fetch() {
24
- this.uiIssuesSetting = await this.$store.dispatch('management/find', { type: MANAGEMENT.SETTING, id: SETTING.ISSUES });
25
- this.communitySetting = await this.$store.dispatch('management/find', { type: MANAGEMENT.SETTING, id: SETTING.COMMUNITY_LINKS });
26
+ // If user already have custom links and uiIssueSetting Doc URL set
27
+ // This should already be in the uiCustomLinks
28
+ try {
29
+ this.uiCustomLinks = await this.$store.dispatch('management/find', { type: MANAGEMENT.SETTING, id: SETTING.UI_CUSTOM_LINKS });
30
+ } catch (err) {
31
+
32
+ }
33
+
34
+ // Fallback:
35
+ // NB: this.uiIssueSetting is deprecated now.
36
+ if (!this.uiCustomLinks) {
37
+ try {
38
+ this.uiIssuesSetting = await this.$store.dispatch('management/find', { type: MANAGEMENT.SETTING, id: SETTING.ISSUES });
39
+ } catch (err) {
40
+
41
+ }
42
+ }
26
43
  },
27
44
 
28
45
  data() {
29
- return { uiIssuesSetting: null, communitySetting: null };
46
+ return { uiCustomLinks: null, uiIssuesSetting: null };
30
47
  },
31
48
 
32
49
  computed: {
@@ -35,25 +52,42 @@ export default {
35
52
  'selectedLocaleLabel'
36
53
  ]),
37
54
 
55
+ hasOptions() {
56
+ return !!Object.keys(this.options).length || !!Object.keys(this.$slots).length;
57
+ },
58
+
38
59
  options() {
60
+ // Link options are provided
39
61
  if (Object.keys(this.linkOptions).length > 0) {
40
62
  return this.linkOptions;
41
63
  }
42
64
 
43
- if (this.communitySetting?.value === 'false') {
44
- return options(this.uiIssuesSetting?.value, true);
65
+ // Custom links set from settings
66
+ if (!!this.uiCustomLinks?.value) {
67
+ try {
68
+ const customLinks = JSON.parse(this.uiCustomLinks.value);
69
+
70
+ if (Array.isArray(customLinks)) {
71
+ return customLinks.reduce((prev, curr) => {
72
+ prev[curr.key] = curr.value;
73
+
74
+ return prev;
75
+ }, {});
76
+ }
77
+ } catch (e) {
78
+ console.error('Could not parse custom links setting', e); // eslint-disable-line no-console
79
+ }
45
80
  }
46
81
 
47
- return options(this.uiIssuesSetting?.value);
82
+ // Fallback
83
+ return options(false, this.uiIssuesSetting?.value);
48
84
  },
49
-
50
- title() {
51
- const hasCustomizedFileIssueLink = this.uiIssuesSetting?.value;
52
-
53
- return hasCustomizedFileIssueLink ? 'landing.support' : 'landing.community.title';
54
- }
55
85
  },
56
86
  methods: {
87
+ getLabel(label) {
88
+ return this.$store.getters['i18n/withFallback'](`customLinks.defaults.${ label }`, null, label);
89
+ },
90
+
57
91
  show() {
58
92
  this.$modal.show('wechat-modal');
59
93
  },
@@ -65,12 +99,20 @@ export default {
65
99
  </script>
66
100
 
67
101
  <template>
68
- <div>
69
- <SimpleBox :title="t(title)" :pref="pref" :pref-key="prefKey">
102
+ <div v-if="hasOptions">
103
+ <SimpleBox :pref="pref" :pref-key="prefKey">
104
+ <template #title>
105
+ <h2>
106
+ {{ t('customLinks.displayTitle') }}
107
+ </h2>
108
+ </template>
70
109
  <div v-for="(value, name) in options" :key="name" class="support-link">
71
- <a v-t="name" :href="value" target="_blank" rel="noopener noreferrer nofollow" />
110
+ <n-link v-if="value.startsWith('/') " :to="value">
111
+ {{ getLabel(name) }}
112
+ </n-link>
113
+ <a v-else :href="value" rel="noopener noreferrer nofollow" target="_blank"> {{ getLabel(name) }} </a>
72
114
  </div>
73
-
115
+ <slot />
74
116
  <div v-if="selectedLocaleLabel === t('locale.zh-hans')" class="support-link">
75
117
  <a class="link" @click="show">
76
118
  {{ t('footer.wechat.title') }}
@@ -97,8 +139,17 @@ export default {
97
139
  </template>
98
140
 
99
141
  <style lang='scss' scoped>
100
- .support-link:not(:first-child) {
101
- margin-top: 15px;
142
+ h2 {
143
+ display: flex;
144
+ align-items: center;
145
+
146
+ i {
147
+ font-size: 12px;
148
+ margin-left: 5px;
149
+ }
150
+ }
151
+ .support-link:not(:last-child) {
152
+ margin-bottom: 15px;
102
153
  }
103
154
 
104
155
  .wechat-modal {
@@ -117,7 +168,7 @@ export default {
117
168
  }
118
169
 
119
170
  .qr-img {
120
- background-image: url('~shell/assets/images/wechat-qr-code.jpg');
171
+ background-image: url('../assets/images/wechat-qr-code.jpg');
121
172
  background-repeat: no-repeat;
122
173
  background-size: cover;
123
174
  background-position: center center;
@@ -47,6 +47,20 @@ export default {
47
47
  };
48
48
  },
49
49
 
50
+ watch: {
51
+ value() {
52
+ const {
53
+ limitsCpu, limitsMemory, requestsCpu, requestsMemory, limitsGpu
54
+ } = this.value;
55
+
56
+ this.limitsCpu = limitsCpu;
57
+ this.limitsMemory = limitsMemory;
58
+ this.requestsCpu = requestsCpu;
59
+ this.requestsMemory = requestsMemory;
60
+ this.limitsGpu = limitsGpu;
61
+ }
62
+ },
63
+
50
64
  computed: {
51
65
  detailTopColumns() {
52
66
  return [
@@ -2,7 +2,7 @@
2
2
  import isEmpty from 'lodash/isEmpty';
3
3
  import { createYaml } from '@shell/utils/create-yaml';
4
4
  import { clone, get } from '@shell/utils/object';
5
- import { SCHEMA } from '@shell/config/types';
5
+ import { SCHEMA, NAMESPACE } from '@shell/config/types';
6
6
  import ResourceYaml from '@shell/components/ResourceYaml';
7
7
  import { Banner } from '@components/Banner';
8
8
  import AsyncButton from '@shell/components/AsyncButton';
@@ -329,10 +329,18 @@ export default {
329
329
 
330
330
  async createNamespaceIfNeeded() {
331
331
  const inStore = this.$store.getters['currentStore'](this.resource);
332
+ const newNamespaceName = get(this.resource, this.namespaceKey);
333
+ let namespaceAlreadyExists = false;
332
334
 
333
- if (this.createNamespace) {
335
+ try {
336
+ // This is in a try-catch block because the call to fetch
337
+ // a namespace throws an error if the namespace is not found.
338
+ namespaceAlreadyExists = !!(await this.$store.dispatch(`${ inStore }/find`, { type: NAMESPACE, id: newNamespaceName }));
339
+ } catch {}
340
+
341
+ if (this.createNamespace && !namespaceAlreadyExists) {
334
342
  try {
335
- const newNamespace = await this.$store.dispatch(`${ inStore }/createNamespace`, { name: get(this.resource, this.namespaceKey) }, { root: true });
343
+ const newNamespace = await this.$store.dispatch(`${ inStore }/createNamespace`, { name: newNamespaceName }, { root: true });
336
344
 
337
345
  newNamespace.applyDefaults();
338
346
  await newNamespace.save();
@@ -0,0 +1,102 @@
1
+ <script>
2
+ import AsyncButton from '@shell/components/AsyncButton';
3
+
4
+ export default {
5
+ components: { AsyncButton },
6
+
7
+ props: {
8
+ name: {
9
+ type: String,
10
+ required: true,
11
+ },
12
+
13
+ title: {
14
+ type: String,
15
+ required: true,
16
+ },
17
+
18
+ mode: {
19
+ type: String,
20
+ default: '',
21
+ }
22
+ },
23
+
24
+ data() {
25
+ return { closed: false };
26
+ },
27
+
28
+ methods: {
29
+ beforeOpen() {
30
+ this.closed = false;
31
+ },
32
+
33
+ ok(btnCb) {
34
+ const callback = (ok) => {
35
+ btnCb(ok);
36
+ if (ok) {
37
+ this.closeDialog(true);
38
+ }
39
+ };
40
+
41
+ this.$emit('okay', callback);
42
+ },
43
+
44
+ closeDialog(result) {
45
+ if (!this.closed) {
46
+ this.$modal.hide(this.name);
47
+ this.$emit('closed', result);
48
+ this.closed = true;
49
+ }
50
+ },
51
+ }
52
+ };
53
+ </script>
54
+
55
+ <template>
56
+ <modal
57
+ :name="name"
58
+ height="auto"
59
+ :scrollable="true"
60
+ @closed="closeDialog(false)"
61
+ @before-open="beforeOpen"
62
+ >
63
+ <div class="modal-dialog">
64
+ <h4>
65
+ {{ title }}
66
+ </h4>
67
+ <slot></slot>
68
+ <div class="dialog-buttons mt-20">
69
+ <slot name="buttons"></slot>
70
+ <div v-if="!$slots.buttons">
71
+ <button class="btn role-secondary" @click="closeDialog(false)">
72
+ {{ t('generic.cancel') }}
73
+ </button>
74
+ <button v-if="!mode" class="btn role-primary ml-10" @click="closeDialog(true)">
75
+ {{ t('generic.ok') }}
76
+ </button>
77
+ <AsyncButton v-else :mode="mode" class="ml-10" @click="ok" />
78
+ </div>
79
+ </div>
80
+ </div>
81
+ </modal>
82
+ </template>
83
+
84
+ <style lang="scss" scoped>
85
+ .modal-dialog {
86
+ padding: 10px;
87
+
88
+ h4 {
89
+ font-weight: bold;
90
+ }
91
+
92
+ .dialog-buttons {
93
+ display: flex;
94
+ justify-content: flex-end;
95
+ margin-top: 10px;
96
+
97
+ > *:not(:last-child) {
98
+ margin-right: 10px;
99
+ }
100
+ }
101
+ }
102
+ </style>