@rancher/shell 0.1.1 → 0.1.3

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (294) hide show
  1. package/assets/translations/en-us.yaml +33 -769
  2. package/assets/translations/zh-hans.yaml +153 -781
  3. package/components/ActionMenu.vue +3 -3
  4. package/components/CodeMirror.vue +6 -8
  5. package/components/CommunityLinks.vue +1 -1
  6. package/components/ContainerResourceLimit.vue +14 -0
  7. package/components/ExplorerMembers.vue +123 -0
  8. package/components/ExplorerProjectsNamespaces.vue +405 -0
  9. package/components/GrafanaDashboard.vue +17 -2
  10. package/components/LocaleSelector.vue +81 -0
  11. package/components/PromptModal.vue +2 -3
  12. package/components/ResourceList/index.vue +1 -1
  13. package/components/ResourceTable.vue +3 -6
  14. package/components/SingleClusterInfo.vue +1 -1
  15. package/components/SortableTable/index.vue +23 -20
  16. package/components/SortableTable/selection.js +1 -0
  17. package/components/auth/AzureWarning.vue +5 -1
  18. package/components/auth/Principal.vue +1 -1
  19. package/components/auth/RoleDetailEdit.vue +32 -12
  20. package/components/fleet/FleetRepos.vue +0 -2
  21. package/components/form/NameNsDescription.vue +4 -6
  22. package/components/form/NodeScheduling.vue +1 -1
  23. package/components/form/ResourceTabs/index.vue +27 -18
  24. package/components/form/WorkloadPorts.vue +1 -1
  25. package/components/formatter/ClusterLink.vue +13 -0
  26. package/components/formatter/PodImages.vue +11 -1
  27. package/components/formatter/RKETemplateName.vue +37 -0
  28. package/components/formatter/WorkloadHealthScale.vue +1 -1
  29. package/components/nav/Header.vue +9 -9
  30. package/components/nav/NamespaceFilter.vue +7 -4
  31. package/components/nav/TopLevelMenu.vue +6 -43
  32. package/components/nav/WindowManager/ContainerLogs.vue +1 -1
  33. package/config/product/harvester-manager.js +64 -2
  34. package/config/product/manager.js +9 -0
  35. package/config/settings.js +17 -71
  36. package/config/table-headers.js +0 -1
  37. package/config/types.js +8 -26
  38. package/core/plugin-routes.ts +34 -22
  39. package/core/plugin.ts +15 -3
  40. package/core/plugins-loader.js +2 -0
  41. package/core/plugins.js +79 -36
  42. package/core/types.ts +7 -1
  43. package/creators/app/tsconfig.json +6 -1
  44. package/creators/pkg/init +3 -0
  45. package/creators/pkg/tsconfig.json +7 -2
  46. package/detail/provisioning.cattle.io.cluster.vue +23 -0
  47. package/detail/workload/index.vue +11 -5
  48. package/{components/dialog → dialog}/AddClusterMemberDialog.vue +0 -0
  49. package/{components/dialog → dialog}/AddCustomBadgeDialog.vue +0 -0
  50. package/{components/dialog → dialog}/AddProjectMemberDialog.vue +0 -0
  51. package/{components/dialog → dialog}/AddonConfigConfirmationDialog.vue +0 -0
  52. package/{components/dialog → dialog}/DrainNode.vue +0 -0
  53. package/{components/dialog → dialog}/ForceMachineRemoveDialog.vue +0 -0
  54. package/{components/dialog → dialog}/GenericPrompt.vue +0 -0
  55. package/{components/dialog → dialog}/RollbackWorkloadDialog.vue +0 -0
  56. package/{components/dialog → dialog}/RotateCertificatesDialog.vue +0 -0
  57. package/{components/dialog → dialog}/RotateEncryptionKeyDialog.vue +0 -0
  58. package/{components/dialog → dialog}/SaveAsRKETemplateDialog.vue +0 -0
  59. package/{components/dialog → dialog}/ScaleMachineDownDialog.vue +0 -0
  60. package/edit/auth/azuread.vue +20 -1
  61. package/edit/cloudcredential.vue +7 -1
  62. package/edit/management.cattle.io.project.vue +2 -2
  63. package/edit/namespace.vue +17 -10
  64. package/edit/networking.k8s.io.ingress/index.vue +2 -1
  65. package/edit/persistentvolumeclaim.vue +33 -2
  66. package/edit/provisioning.cattle.io.cluster/CustomCommand.vue +1 -1
  67. package/edit/provisioning.cattle.io.cluster/MachinePool.vue +34 -6
  68. package/edit/provisioning.cattle.io.cluster/index.vue +1 -1
  69. package/edit/provisioning.cattle.io.cluster/rke2.vue +21 -6
  70. package/edit/service.vue +1 -1
  71. package/edit/workload/index.vue +363 -15
  72. package/edit/workload/mixins/workload.js +62 -7
  73. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +1 -0
  74. package/layouts/default.vue +52 -27
  75. package/layouts/error.vue +5 -1
  76. package/layouts/home.vue +6 -2
  77. package/list/harvesterhci.io.management.cluster.vue +74 -33
  78. package/list/namespace.vue +3 -5
  79. package/list/provisioning.cattle.io.cluster.vue +6 -0
  80. package/machine-config/amazonec2.vue +2 -0
  81. package/machine-config/harvester.vue +96 -49
  82. package/middleware/authenticated.js +56 -52
  83. package/mixins/brand.js +3 -4
  84. package/mixins/create-edit-view/impl.js +0 -8
  85. package/mixins/form-validation.js +1 -1
  86. package/mixins/resource-fetch.js +3 -1
  87. package/models/chart.js +1 -1
  88. package/models/cluster/node.js +12 -1
  89. package/models/fleet.cattle.io.bundle.js +26 -19
  90. package/models/harvesterhci.io.management.cluster.js +194 -5
  91. package/models/management.cattle.io.cluster.js +1 -1
  92. package/models/management.cattle.io.clusterroletemplatebinding.js +9 -0
  93. package/models/management.cattle.io.globalrole.js +0 -19
  94. package/models/management.cattle.io.project.js +23 -2
  95. package/models/management.cattle.io.roletemplate.js +2 -21
  96. package/models/namespace.js +19 -3
  97. package/models/pod.js +19 -2
  98. package/models/provisioning.cattle.io.cluster.js +71 -0
  99. package/models/service.js +5 -1
  100. package/models/workload.js +4 -243
  101. package/models/workload.service.js +314 -0
  102. package/nuxt.config.js +14 -12
  103. package/package.json +3 -3
  104. package/pages/auth/login.vue +11 -2
  105. package/pages/auth/setup.vue +1 -1
  106. package/pages/c/_cluster/_product/members/index.vue +3 -93
  107. package/pages/c/_cluster/_product/projectsnamespaces.vue +6 -403
  108. package/pages/c/_cluster/apps/charts/install.vue +0 -6
  109. package/pages/c/_cluster/settings/performance.vue +19 -16
  110. package/pages/fail-whale.vue +1 -10
  111. package/pages/index.vue +18 -4
  112. package/pages/plugins.vue +2 -2
  113. package/pages/prefs.vue +8 -6
  114. package/pkg/auto-import.js +44 -7
  115. package/pkg/dynamic-plugin-loader.js +28 -0
  116. package/pkg/import.js +2 -2
  117. package/pkg/model-loader-require.lib.js +3 -0
  118. package/pkg/vue.config.js +9 -6
  119. package/plugins/console.js +10 -5
  120. package/plugins/dashboard-store/actions.js +8 -3
  121. package/plugins/dashboard-store/getters.js +7 -2
  122. package/plugins/dashboard-store/model-loader-require.js +12 -0
  123. package/plugins/dashboard-store/model-loader.js +4 -1
  124. package/plugins/dashboard-store/resource-class.js +10 -3
  125. package/plugins/steve/actions.js +1 -1
  126. package/plugins/steve/index.js +6 -4
  127. package/plugins/steve/steve-description-class.js +32 -0
  128. package/plugins/steve/subscribe.js +34 -23
  129. package/rancher-components/Banner/Banner.vue +2 -2
  130. package/rancher-components/Form/Checkbox/Checkbox.test.ts +77 -0
  131. package/rancher-components/Form/Checkbox/Checkbox.vue +12 -2
  132. package/rancher-components/Form/LabeledInput/LabeledInput.test.ts +0 -2
  133. package/rancher-components/Form/LabeledInput/LabeledInput.vue +2 -0
  134. package/rancher-components/Form/Radio/RadioButton.vue +14 -1
  135. package/rancher-components/Form/ToggleSwitch/ToggleSwitch.test.ts +107 -0
  136. package/{components/form → rancher-components/Form/ToggleSwitch}/ToggleSwitch.vue +18 -8
  137. package/rancher-components/Form/ToggleSwitch/index.ts +1 -0
  138. package/rancher-components/Form/index.ts +1 -0
  139. package/scripts/build-pkg.sh +48 -2
  140. package/scripts/drone-build-pkg.sh +31 -0
  141. package/scripts/publish-shell.sh +10 -11
  142. package/scripts/serve-pkgs +17 -10
  143. package/scripts/test-plugins-build.sh +18 -1
  144. package/store/catalog.js +3 -1
  145. package/store/i18n.js +16 -11
  146. package/store/index.js +4 -181
  147. package/store/prefs.js +30 -2
  148. package/store/type-map.js +16 -29
  149. package/types/{index.d.ts → rancher/index.d.ts} +0 -0
  150. package/utils/cluster.js +1 -1
  151. package/utils/custom-validators.js +1 -12
  152. package/utils/dynamic-importer.js +1 -1
  153. package/utils/validators/setting.js +0 -35
  154. package/components/FilterLabel.vue +0 -254
  155. package/components/HarvesterUpgradeProgressBarList.vue +0 -109
  156. package/components/VMConsoleBar.vue +0 -87
  157. package/components/dialog/harvester/AddHotplugModal.vue +0 -159
  158. package/components/dialog/harvester/BackupModal.vue +0 -117
  159. package/components/dialog/harvester/CloneTemplate.vue +0 -125
  160. package/components/dialog/harvester/EjectCDROMDialog.vue +0 -157
  161. package/components/dialog/harvester/ExportImageDialog.vue +0 -152
  162. package/components/dialog/harvester/MaintenanceDialog.vue +0 -94
  163. package/components/dialog/harvester/MigrationDialog.vue +0 -154
  164. package/components/dialog/harvester/RestoreDialog.vue +0 -153
  165. package/components/dialog/harvester/SupportBundle.vue +0 -217
  166. package/components/dialog/harvester/UnplugVolume.vue +0 -108
  167. package/components/form/SerialConsole/index.vue +0 -267
  168. package/components/formatter/AttachVMWithName.vue +0 -46
  169. package/components/formatter/CloudInitType.vue +0 -27
  170. package/components/formatter/HarvesterBackupTargetValidation.vue +0 -43
  171. package/components/formatter/HarvesterCPUUsed.vue +0 -122
  172. package/components/formatter/HarvesterDiskState.vue +0 -66
  173. package/components/formatter/HarvesterHostName.vue +0 -66
  174. package/components/formatter/HarvesterIpAddress.vue +0 -90
  175. package/components/formatter/HarvesterMemoryUsed.vue +0 -140
  176. package/components/formatter/HarvesterMigrationState.vue +0 -85
  177. package/components/formatter/HarvesterNodeName.vue +0 -49
  178. package/components/formatter/HarvesterStorageUsed.vue +0 -194
  179. package/components/formatter/HarvesterVmState.vue +0 -123
  180. package/components/nav/HarvesterUpgrade.vue +0 -232
  181. package/components/novnc/NovncConsole.vue +0 -93
  182. package/components/novnc/NovncConsoleItem.vue +0 -89
  183. package/components/novnc/NovncConsoleWrapper.vue +0 -243
  184. package/config/harvester-map.js +0 -44
  185. package/config/harvester-table-headers.js +0 -27
  186. package/config/product/harvester.js +0 -305
  187. package/detail/harvesterhci.io.host/HarvesterHostBasic.vue +0 -364
  188. package/detail/harvesterhci.io.host/HarvesterHostDisk.vue +0 -200
  189. package/detail/harvesterhci.io.host/HarvesterHostNetwork.vue +0 -89
  190. package/detail/harvesterhci.io.host/VirtualMachineInstance.vue +0 -134
  191. package/detail/harvesterhci.io.host/index.vue +0 -243
  192. package/detail/harvesterhci.io.virtualmachinebackup/index.vue +0 -221
  193. package/detail/harvesterhci.io.virtualmachineimage.vue +0 -118
  194. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineBasics.vue +0 -279
  195. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineEvents.vue +0 -75
  196. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineKeypairs.vue +0 -114
  197. package/detail/kubevirt.io.virtualmachine/VirtualMachineTabs/VirtualMachineMigration.vue +0 -79
  198. package/detail/kubevirt.io.virtualmachine/index.vue +0 -213
  199. package/edit/harvesterhci.io.cloudtemplate.vue +0 -123
  200. package/edit/harvesterhci.io.host/HarvesterDisk.vue +0 -262
  201. package/edit/harvesterhci.io.host/index.vue +0 -533
  202. package/edit/harvesterhci.io.keypair.vue +0 -112
  203. package/edit/harvesterhci.io.managedchart/index.vue +0 -25
  204. package/edit/harvesterhci.io.managedchart/rancher-monitoring.vue +0 -172
  205. package/edit/harvesterhci.io.networkattachmentdefinition.vue +0 -210
  206. package/edit/harvesterhci.io.setting/additional-ca.vue +0 -36
  207. package/edit/harvesterhci.io.setting/backup-target.vue +0 -182
  208. package/edit/harvesterhci.io.setting/http-proxy.vue +0 -79
  209. package/edit/harvesterhci.io.setting/index.vue +0 -201
  210. package/edit/harvesterhci.io.setting/overcommit-config.vue +0 -94
  211. package/edit/harvesterhci.io.setting/ssl-certificates.vue +0 -117
  212. package/edit/harvesterhci.io.setting/ssl-parameters.vue +0 -161
  213. package/edit/harvesterhci.io.setting/support-bundle-image.vue +0 -134
  214. package/edit/harvesterhci.io.setting/support-bundle-namespaces.vue +0 -73
  215. package/edit/harvesterhci.io.setting/vip-pools.vue +0 -244
  216. package/edit/harvesterhci.io.setting/vm-force-reset-policy.vue +0 -81
  217. package/edit/harvesterhci.io.virtualmachinebackup.vue +0 -256
  218. package/edit/harvesterhci.io.virtualmachineimage.vue +0 -364
  219. package/edit/harvesterhci.io.virtualmachinetemplateversion.vue +0 -340
  220. package/edit/harvesterhci.io.volume.vue +0 -195
  221. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/AccessCredentialsUsers.vue +0 -190
  222. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/index.vue +0 -212
  223. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/basicAuth.vue +0 -94
  224. package/edit/kubevirt.io.virtualmachine/VirtualMachineAccessCredentials/type/sshkey.vue +0 -85
  225. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/DataTemplate.vue +0 -153
  226. package/edit/kubevirt.io.virtualmachine/VirtualMachineCloudConfig/index.vue +0 -279
  227. package/edit/kubevirt.io.virtualmachine/VirtualMachineCpuMemory.vue +0 -113
  228. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/__tests__/HarvesterEditNetwork.test.ts +0 -41
  229. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/base.vue +0 -281
  230. package/edit/kubevirt.io.virtualmachine/VirtualMachineNetwork/index.vue +0 -142
  231. package/edit/kubevirt.io.virtualmachine/VirtualMachineReserved.vue +0 -54
  232. package/edit/kubevirt.io.virtualmachine/VirtualMachineSSHKey.vue +0 -256
  233. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/index.vue +0 -391
  234. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditContainer.test.ts +0 -40
  235. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditExisting.test.ts +0 -102
  236. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVMImage.test.ts +0 -117
  237. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/__tests__/HarvesterEditVolume.test.ts +0 -74
  238. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/container.vue +0 -132
  239. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/existing.vue +0 -303
  240. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/vmImage.vue +0 -285
  241. package/edit/kubevirt.io.virtualmachine/VirtualMachineVolume/type/volume.vue +0 -188
  242. package/edit/kubevirt.io.virtualmachine/index.vue +0 -642
  243. package/edit/network.harvesterhci.io.clusternetwork/index.vue +0 -19
  244. package/edit/network.harvesterhci.io.clusternetwork/vlan.vue +0 -134
  245. package/edit/workload/types/Deployment.vue +0 -377
  246. package/edit/workload/types/Generic.vue +0 -295
  247. package/list/harvesterhci.io.cloudtemplate.vue +0 -78
  248. package/list/harvesterhci.io.dashboard/HarvesterUpgrade.vue +0 -211
  249. package/list/harvesterhci.io.dashboard/UpgradeInfo.vue +0 -40
  250. package/list/harvesterhci.io.dashboard/index.vue +0 -752
  251. package/list/harvesterhci.io.host/index.vue +0 -186
  252. package/list/harvesterhci.io.networkattachmentdefinition.vue +0 -167
  253. package/list/harvesterhci.io.setting.vue +0 -241
  254. package/list/harvesterhci.io.virtualmachinebackup.vue +0 -172
  255. package/list/harvesterhci.io.virtualmachineimage.vue +0 -80
  256. package/list/harvesterhci.io.virtualmachinetemplateversion.vue +0 -173
  257. package/list/harvesterhci.io.volume.vue +0 -122
  258. package/list/kubevirt.io.virtualmachine.vue +0 -193
  259. package/mixins/harvester-vm/impl.js +0 -267
  260. package/mixins/harvester-vm/index.js +0 -1357
  261. package/models/harvester/configmap.js +0 -32
  262. package/models/harvester/harvesterhci.io.blockdevice.js +0 -55
  263. package/models/harvester/harvesterhci.io.keypair.js +0 -12
  264. package/models/harvester/harvesterhci.io.setting.js +0 -127
  265. package/models/harvester/harvesterhci.io.supportbundle.js +0 -35
  266. package/models/harvester/harvesterhci.io.upgrade.js +0 -226
  267. package/models/harvester/harvesterhci.io.virtualmachinebackup.js +0 -116
  268. package/models/harvester/harvesterhci.io.virtualmachineimage.js +0 -255
  269. package/models/harvester/harvesterhci.io.virtualmachinerestore.js +0 -43
  270. package/models/harvester/harvesterhci.io.virtualmachinetemplate.js +0 -69
  271. package/models/harvester/harvesterhci.io.virtualmachinetemplateversion.js +0 -227
  272. package/models/harvester/k8s.cni.cncf.io.networkattachmentdefinition.js +0 -32
  273. package/models/harvester/kubevirt.io.virtualmachine.js +0 -850
  274. package/models/harvester/kubevirt.io.virtualmachineinstance.js +0 -142
  275. package/models/harvester/management.cattle.io.managedchart.js +0 -191
  276. package/models/harvester/management.cattle.io.setting.js +0 -40
  277. package/models/harvester/network.harvesterhci.io.clusternetwork.js +0 -100
  278. package/models/harvester/network.harvesterhci.io.nodenetwork.js +0 -34
  279. package/models/harvester/node.js +0 -255
  280. package/models/harvester/persistentvolumeclaim.js +0 -166
  281. package/models/harvester/pod.js +0 -185
  282. package/pages/c/_cluster/harvester/airgapupgrade/index.vue +0 -309
  283. package/pages/c/_cluster/harvester/console/_uid/serial.vue +0 -51
  284. package/pages/c/_cluster/harvester/console/_uid/vnc.vue +0 -52
  285. package/pages/c/_cluster/harvester/index.vue +0 -24
  286. package/pages/c/_cluster/harvester/support/index.vue +0 -154
  287. package/pkg/model-loader.lib.js +0 -3
  288. package/plugins/lookup.js +0 -50
  289. package/promptRemove/kubevirt.io.virtualmachine.vue +0 -164
  290. package/store/harvester-common.js +0 -126
  291. package/utils/validators/vm-datavolumes.js +0 -38
  292. package/utils/validators/vm-image.js +0 -32
  293. package/utils/validators/vm.js +0 -221
  294. package/yarn-error.log +0 -196
@@ -1,117 +0,0 @@
1
- <script>
2
- import { exceptionToErrorsArray } from '@shell/utils/error';
3
- import { mapGetters } from 'vuex';
4
- import { Card } from '@components/Card';
5
- import { Banner } from '@components/Banner';
6
- import AsyncButton from '@shell/components/AsyncButton';
7
- import { LabeledInput } from '@components/Form/LabeledInput';
8
-
9
- export default {
10
- name: 'BackupModal',
11
-
12
- components: {
13
- AsyncButton, Card, LabeledInput, Banner
14
- },
15
-
16
- props: {
17
- resources: {
18
- type: Array,
19
- required: true
20
- }
21
- },
22
-
23
- data() {
24
- return {
25
- backUpName: '',
26
- errors: []
27
- };
28
- },
29
-
30
- computed: {
31
- ...mapGetters({ t: 'i18n/t' }),
32
-
33
- actionResource() {
34
- return this.resources[0];
35
- },
36
- },
37
-
38
- methods: {
39
- close() {
40
- this.backUpName = '';
41
- this.$emit('close');
42
- },
43
-
44
- async save(buttonCb) {
45
- if (this.actionResource) {
46
- try {
47
- const res = await this.actionResource.doAction('backup', { name: this.backUpName }, {}, false);
48
-
49
- if (res._status === 200 || res._status === 204) {
50
- this.$store.dispatch('growl/success', {
51
- title: this.t('harvester.notification.title.succeed'),
52
- message: this.t('harvester.modal.backup.success', { backUpName: this.backUpName })
53
- }, { root: true });
54
-
55
- this.close();
56
-
57
- buttonCb(true);
58
- } else {
59
- const error = [res?.data] || exceptionToErrorsArray(res);
60
-
61
- this.$set(this, 'errors', error);
62
- buttonCb(false);
63
- }
64
- } catch (err) {
65
- const error = err?.data || err;
66
- const message = exceptionToErrorsArray(error);
67
-
68
- this.$set(this, 'errors', message);
69
- buttonCb(false);
70
- }
71
- }
72
- },
73
- }
74
- };
75
- </script>
76
-
77
- <template>
78
- <Card :show-highlight-border="false">
79
- <h4 slot="title" class="text-default-text" v-html="t('harvester.modal.backup.addBackup')" />
80
-
81
- <template #body>
82
- <LabeledInput
83
- v-model="backUpName"
84
- :label="t('generic.name')"
85
- required
86
- />
87
- </template>
88
-
89
- <div slot="actions" class="actions">
90
- <div class="buttons">
91
- <button class="btn role-secondary mr-10" @click="close">
92
- {{ t('generic.cancel') }}
93
- </button>
94
-
95
- <AsyncButton
96
- mode="create"
97
- :disabled="!backUpName"
98
- @click="save"
99
- />
100
- </div>
101
-
102
- <Banner v-for="(err, i) in errors" :key="i" color="error" :label="err" />
103
- </div>
104
- </Card>
105
- </template>
106
-
107
- <style lang="scss" scoped>
108
- .actions {
109
- width: 100%;
110
- }
111
-
112
- .buttons {
113
- display: flex;
114
- justify-content: flex-end;
115
- width: 100%;
116
- }
117
- </style>
@@ -1,125 +0,0 @@
1
- <script>
2
- import { exceptionToErrorsArray } from '@shell/utils/error';
3
- import { mapGetters } from 'vuex';
4
-
5
- import { Card } from '@components/Card';
6
- import { Banner } from '@components/Banner';
7
- import AsyncButton from '@shell/components/AsyncButton';
8
- import { LabeledInput } from '@components/Form/LabeledInput';
9
-
10
- export default {
11
- name: 'CloneTemplateModal',
12
-
13
- components: {
14
- AsyncButton, Banner, Card, LabeledInput
15
- },
16
-
17
- props: {
18
- resources: {
19
- type: Array,
20
- required: true
21
- }
22
- },
23
-
24
- data() {
25
- return {
26
- templateName: '',
27
- description: '',
28
- errors: []
29
- };
30
- },
31
-
32
- computed: {
33
- ...mapGetters({ t: 'i18n/t' }),
34
-
35
- actionResource() {
36
- return this.resources[0];
37
- },
38
- },
39
-
40
- methods: {
41
- close() {
42
- this.templateName = '';
43
- this.description = '';
44
- this.$emit('close');
45
- },
46
-
47
- async saveRestore(buttonCb) {
48
- try {
49
- const res = await this.actionResource.doAction('createTemplate', { name: this.templateName, description: this.description }, {}, false);
50
-
51
- if (res._status === 200 || res._status === 204) {
52
- this.$store.dispatch('growl/success', {
53
- title: this.t('harvester.notification.title.succeed'),
54
- message: this.t('harvester.modal.createTemplate.message.success', { templateName: this.templateName })
55
- }, { root: true });
56
-
57
- this.close();
58
- buttonCb(true);
59
- } else {
60
- const error = [res?.data] || exceptionToErrorsArray(res);
61
-
62
- this.$set(this, 'errors', error);
63
- buttonCb(false);
64
- }
65
- } catch (err) {
66
- const error = err?.data || err;
67
- const message = exceptionToErrorsArray(error);
68
-
69
- this.$set(this, 'errors', message);
70
- buttonCb(false);
71
- }
72
- }
73
- },
74
- };
75
- </script>
76
-
77
- <template>
78
- <Card :show-highlight-border="false">
79
- <template #title>
80
- {{ t('harvester.modal.createTemplate.title') }}
81
- </template>
82
-
83
- <template #body>
84
- <LabeledInput
85
- v-model="templateName"
86
- class="mb-20"
87
- :label="t('harvester.modal.createTemplate.name')"
88
- required
89
- />
90
-
91
- <LabeledInput
92
- v-model="description"
93
- :label="t('harvester.modal.createTemplate.description')"
94
- />
95
- </template>
96
-
97
- <div slot="actions" class="actions">
98
- <div class="buttons">
99
- <button class="btn role-secondary mr-10" @click="close">
100
- {{ t('generic.cancel') }}
101
- </button>
102
-
103
- <AsyncButton
104
- mode="create"
105
- :disabled="!templateName"
106
- @click="saveRestore"
107
- />
108
- </div>
109
-
110
- <Banner v-for="(err, i) in errors" :key="i" color="error" :label="err" />
111
- </div>
112
- </Card>
113
- </template>
114
-
115
- <style lang="scss" scoped>
116
- .actions {
117
- width: 100%;
118
- }
119
-
120
- .buttons {
121
- display: flex;
122
- justify-content: flex-end;
123
- width: 100%;
124
- }
125
- </style>
@@ -1,157 +0,0 @@
1
- <script>
2
- import { mapGetters } from 'vuex';
3
-
4
- import { Card } from '@components/Card';
5
- import { Banner } from '@components/Banner';
6
- import AsyncButton from '@shell/components/AsyncButton';
7
- import { Checkbox } from '@components/Form/Checkbox';
8
- import { exceptionToErrorsArray } from '@shell/utils/error';
9
-
10
- export default {
11
- name: 'EjectCDROMModal',
12
-
13
- components: {
14
- AsyncButton, Card, Checkbox, Banner
15
- },
16
-
17
- props: {
18
- resources: {
19
- type: Array,
20
- required: true
21
- }
22
- },
23
-
24
- data() {
25
- const allDisk = [];
26
- const disks = this.resources[0].spec.template.spec.domain.devices.disks;
27
-
28
- if (Array.isArray(disks)) {
29
- disks.forEach((D) => {
30
- if (D.cdrom) {
31
- allDisk.push({
32
- name: D.name,
33
- value: false
34
- });
35
- }
36
- });
37
- }
38
-
39
- return {
40
- allDisk,
41
- errors: [],
42
- diskNames: []
43
- };
44
- },
45
-
46
- computed: {
47
- ...mapGetters({ t: 'i18n/t' }),
48
-
49
- actionResource() {
50
- return this.resources[0];
51
- },
52
-
53
- isDeleteDisabled() {
54
- return this.diskNames.length === 0;
55
- },
56
- },
57
-
58
- methods: {
59
- updateNames(names) {
60
- this.diskNames = names;
61
- },
62
-
63
- async remove(buttonDone) {
64
- try {
65
- await this.actionResource.doAction('ejectCdRom', { diskNames: this.diskNames });
66
- this.close();
67
- buttonDone(true);
68
- } catch (err) {
69
- const error = err?.data || err;
70
- const message = exceptionToErrorsArray(error);
71
-
72
- this.$set(this, 'errors', message);
73
- buttonDone(false);
74
- }
75
- },
76
-
77
- close() {
78
- this.backupName = '';
79
- this.errors = [];
80
- this.$emit('close');
81
- },
82
- },
83
-
84
- watch: {
85
- allDisk: {
86
- handler(neu) {
87
- const diskNames = [];
88
-
89
- neu.forEach((D) => {
90
- if (D.value) {
91
- diskNames.push(D.name);
92
- }
93
- });
94
-
95
- this.$set(this, 'diskNames', diskNames);
96
- },
97
- deep: true
98
- }
99
- }
100
- };
101
- </script>
102
-
103
- <template>
104
- <Card :show-highlight-border="false">
105
- <template #title>
106
- {{ t('harvester.modal.ejectCDROM.title') }}
107
- </template>
108
-
109
- <template #body>
110
- <span class="text-info mb-10">
111
- {{ t('harvester.modal.ejectCDROM.operationTip') }}
112
- </span>
113
-
114
- <div>
115
- <Checkbox
116
- v-for="disk in allDisk"
117
- :key="disk.name"
118
- v-model="disk.value"
119
- :label="disk.name"
120
- />
121
- </div>
122
-
123
- <Banner color="warning">
124
- <span>{{ t('harvester.modal.ejectCDROM.warnTip') }}</span>
125
- </Banner>
126
- </template>
127
-
128
- <div slot="actions" class="actions">
129
- <div class="buttons">
130
- <button class="btn role-secondary mr-10" @click="close">
131
- {{ t('generic.cancel') }}
132
- </button>
133
-
134
- <AsyncButton
135
- mode="delete"
136
- :disabled="!diskNames.length"
137
- class="btn bg-error ml-10"
138
- @click="remove"
139
- />
140
- </div>
141
-
142
- <Banner v-for="(err, i) in errors" :key="i" color="error" :label="err" />
143
- </div>
144
- </Card>
145
- </template>
146
-
147
- <style lang="scss" scoped>
148
- .actions {
149
- width: 100%;
150
- }
151
-
152
- .buttons {
153
- display: flex;
154
- justify-content: flex-end;
155
- width: 100%;
156
- }
157
- </style>
@@ -1,152 +0,0 @@
1
- <script>
2
- import { mapGetters } from 'vuex';
3
- import { exceptionToErrorsArray } from '@shell/utils/error';
4
-
5
- import { sortBy } from '@shell/utils/sort';
6
- import { Card } from '@components/Card';
7
- import { Banner } from '@components/Banner';
8
- import AsyncButton from '@shell/components/AsyncButton';
9
- import { LabeledInput } from '@components/Form/LabeledInput';
10
- import LabeledSelect from '@shell/components/form/LabeledSelect';
11
- import { NAMESPACE } from '@shell/config/types';
12
-
13
- export default {
14
- name: 'HarvesterExportImageDialog',
15
-
16
- components: {
17
- AsyncButton, Banner, Card, LabeledInput, LabeledSelect
18
- },
19
-
20
- props: {
21
- resources: {
22
- type: Array,
23
- required: true
24
- }
25
- },
26
-
27
- data() {
28
- const namespace = this.$store.getters['defaultNamespace'] || '';
29
-
30
- return {
31
- name: '',
32
- namespace,
33
- errors: []
34
- };
35
- },
36
-
37
- computed: {
38
- ...mapGetters({ t: 'i18n/t' }),
39
-
40
- actionResource() {
41
- return this.resources[0];
42
- },
43
-
44
- namespaces() {
45
- const choices = this.$store.getters['harvester/all'](NAMESPACE).filter( N => !N.isSystem);
46
-
47
- const out = sortBy(
48
- choices.map((obj) => {
49
- return {
50
- label: obj.nameDisplay,
51
- value: obj.id,
52
- };
53
- }),
54
- 'label'
55
- );
56
-
57
- return out;
58
- },
59
-
60
- disableSave() {
61
- return !(this.name && this.namespace);
62
- }
63
- },
64
-
65
- methods: {
66
- close() {
67
- this.name = '';
68
- this.namespace = '';
69
- this.$emit('close');
70
- },
71
-
72
- async save(buttonCb) {
73
- try {
74
- const res = await this.actionResource.doAction('export', { displayName: this.name, namespace: this.namespace });
75
-
76
- if (res._status === 200 || res._status === 204) {
77
- this.$store.dispatch('growl/success', {
78
- title: this.t('harvester.notification.title.succeed'),
79
- message: this.t('harvester.modal.exportImage.message.success', { name: this.name })
80
- }, { root: true });
81
-
82
- this.close();
83
- buttonCb(true);
84
- } else {
85
- const error = [res?.data] || exceptionToErrorsArray(res);
86
-
87
- this.$set(this, 'errors', error);
88
- buttonCb(false);
89
- }
90
- } catch (err) {
91
- const error = err?.data || err;
92
- const message = exceptionToErrorsArray(error);
93
-
94
- this.$set(this, 'errors', message);
95
- buttonCb(false);
96
- }
97
- }
98
- },
99
- };
100
- </script>
101
-
102
- <template>
103
- <Card :show-highlight-border="false">
104
- <template #title>
105
- {{ t('harvester.modal.exportImage.title') }}
106
- </template>
107
-
108
- <template #body>
109
- <LabeledSelect
110
- v-model="namespace"
111
- :label="t('harvester.modal.exportImage.namespace')"
112
- :options="namespaces"
113
- class="mb-20"
114
- required
115
- />
116
-
117
- <LabeledInput
118
- v-model="name"
119
- :label="t('harvester.modal.exportImage.name')"
120
- required
121
- />
122
- </template>
123
-
124
- <div slot="actions" class="actions">
125
- <div class="buttons">
126
- <button class="btn role-secondary mr-10" @click="close">
127
- {{ t('generic.cancel') }}
128
- </button>
129
-
130
- <AsyncButton
131
- mode="create"
132
- :disabled="disableSave"
133
- @click="save"
134
- />
135
- </div>
136
-
137
- <Banner v-for="(err, i) in errors" :key="i" color="error" :label="err" />
138
- </div>
139
- </Card>
140
- </template>
141
-
142
- <style lang="scss" scoped>
143
- .actions {
144
- width: 100%;
145
- }
146
-
147
- .buttons {
148
- display: flex;
149
- justify-content: flex-end;
150
- width: 100%;
151
- }
152
- </style>
@@ -1,94 +0,0 @@
1
- <script>
2
- import { mapGetters } from 'vuex';
3
- import AsyncButton from '@shell/components/AsyncButton';
4
- import { Card } from '@components/Card';
5
- import { Banner } from '@components/Banner';
6
- import { exceptionToErrorsArray } from '@shell/utils/error';
7
-
8
- export default {
9
- components: {
10
- Card,
11
- AsyncButton,
12
- Banner,
13
- },
14
-
15
- props: {
16
- resources: {
17
- type: Array,
18
- required: true
19
- }
20
- },
21
-
22
- data() {
23
- return { errors: [] };
24
- },
25
-
26
- computed: {
27
- ...mapGetters({ t: 'i18n/t' }),
28
-
29
- actionResource() {
30
- return this.resources[0];
31
- },
32
- },
33
-
34
- methods: {
35
- close() {
36
- this.$emit('close');
37
- },
38
-
39
- async apply(buttonCb) {
40
- this.errors = [];
41
-
42
- try {
43
- await this.actionResource.doAction('enableMaintenanceMode', {});
44
-
45
- buttonCb(true);
46
- this.close();
47
- } catch (e) {
48
- const error = [e?.data] || exceptionToErrorsArray(e);
49
-
50
- this.errors = error;
51
- buttonCb(false);
52
- }
53
- }
54
- }
55
- };
56
- </script>
57
-
58
- <template>
59
- <Card :show-highlight-border="false">
60
- <template #title>
61
- {{ t('harvester.host.enableMaintenance.title') }}
62
- </template>
63
-
64
- <template #body>
65
- <Banner color="warning" :label="t('harvester.host.enableMaintenance.protip')" class="mt-20" />
66
- <Banner v-for="(err, i) in errors" :key="i" color="error" :label="err" />
67
- </template>
68
-
69
- <div slot="actions" class="actions">
70
- <div class="buttons">
71
- <button class="btn role-secondary mr-10" @click="close">
72
- {{ t('generic.cancel') }}
73
- </button>
74
-
75
- <AsyncButton
76
- mode="apply"
77
- @click="apply"
78
- />
79
- </div>
80
- </div>
81
- </Card>
82
- </template>
83
-
84
- <style lang="scss" scoped>
85
- .actions {
86
- width: 100%;
87
- }
88
-
89
- .buttons {
90
- display: flex;
91
- justify-content: flex-end;
92
- width: 100%;
93
- }
94
- </style>