@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,134 +0,0 @@
1
- <script>
2
- import Vue from 'vue';
3
- import LabeledSelect from '@shell/components/form/LabeledSelect';
4
- import { RadioGroup } from '@components/Form/Radio';
5
- import Tip from '@shell/components/Tip';
6
- import CreateEditView from '@shell/mixins/create-edit-view';
7
- import { allHash } from '@shell/utils/promise';
8
- import { HCI } from '@shell/config/types';
9
-
10
- export default {
11
- name: 'EditHarvesterVlan',
12
- components: {
13
- LabeledSelect,
14
- RadioGroup,
15
- Tip
16
- },
17
-
18
- mixins: [CreateEditView],
19
-
20
- props: {
21
- value: {
22
- type: Object,
23
- required: true,
24
- },
25
- },
26
-
27
- async fetch() {
28
- const inStore = this.$store.getters['currentProduct'].inStore;
29
-
30
- const hash = await allHash({ nodeNetworks: this.$store.dispatch(`${ inStore }/findAll`, { type: HCI.NODE_NETWORK }) });
31
-
32
- this.nodeNetworks = hash.nodeNetworks;
33
- },
34
-
35
- data() {
36
- if (!this.value.config) {
37
- Vue.set(this.value, 'config', { defaultPhysicalNIC: '' });
38
- }
39
-
40
- return { nodeNetworks: [] };
41
- },
42
-
43
- computed: {
44
- doneLocationOverride() {
45
- return this.value.listLocation;
46
- },
47
-
48
- nicOptions() {
49
- const allNics = [];
50
- const out = [];
51
-
52
- if (this.nodeNetworks.length === 0) {
53
- return out;
54
- }
55
-
56
- this.nodeNetworks.map((N) => {
57
- if (N?.nics?.length > 0) {
58
- const nics = N.nics.filter((nic) => {
59
- return !(nic.masterIndex !== undefined && nic.usedByVlanNetwork === undefined);
60
- }).map(nic => nic.name);
61
-
62
- allNics.push(...nics);
63
- } else {
64
- return [];
65
- }
66
- });
67
-
68
- allNics.map((N) => {
69
- const index = out.findIndex(nic => nic.value === N);
70
-
71
- if (index > -1) {
72
- out[index].num = out[index].num + 1;
73
- } else {
74
- out.push({
75
- label: N,
76
- value: N,
77
- num: 1,
78
- });
79
- }
80
- });
81
-
82
- return out.map((option) => {
83
- const percent = ((option.num / this.nodeNetworks.length) * 100).toFixed(2);
84
-
85
- return {
86
- ...option,
87
- percent: `${ percent } %`
88
- };
89
- });
90
- }
91
- },
92
- };
93
- </script>
94
-
95
- <template>
96
- <div>
97
- <RadioGroup
98
- v-model="value.enable"
99
- class="mb-20"
100
- name="model"
101
- :options="[true,false]"
102
- :labels="[t('generic.enabled'), t('generic.disabled')]"
103
- />
104
-
105
- <LabeledSelect
106
- v-if="value.enable"
107
- v-model="value.config.defaultPhysicalNIC"
108
- :options="nicOptions"
109
- :label="t('harvester.setting.defaultPhysicalNIC')"
110
- class="mb-5"
111
- :tooltip="mode === 'view' ? null : t('harvester.setting.percentTip')"
112
- :hover-tooltip="true"
113
- >
114
- <template v-slot:option="option">
115
- <template>
116
- <div class="nicOption">
117
- <span>{{ option.label }}({{ option.percent }}) </span>
118
- </div>
119
- </template>
120
- </template>
121
- </LabeledSelect>
122
-
123
- <Tip v-if="value.enable" icon="icons icon-info" :text="t('harvester.setting.vlanChangeTip')" />
124
- </div>
125
- </template>
126
-
127
- <style lang="scss" scoped>
128
- ::v-deep .radio-group {
129
- display: flex;
130
- .radio-container {
131
- margin-right: 30px;
132
- }
133
- }
134
- </style>
@@ -1,377 +0,0 @@
1
- <script>
2
- import CreateEditView from '@shell/mixins/create-edit-view';
3
- import FormValidation from '@shell/mixins/form-validation';
4
- import WorkLoadMixin from '@shell/edit/workload/mixins/workload';
5
-
6
- export default {
7
- name: 'WorkloadDeployments',
8
- mixins: [CreateEditView, FormValidation, WorkLoadMixin], // The order here is important since WorkLoadMixin contains some FormValidation configuration
9
-
10
- data() {
11
- return { selectedName: null };
12
- },
13
- methods: {
14
- changed(tab) {
15
- this.selectedName = tab.selectedName;
16
- const container = this.containerOptions.find( c => c.name === tab.selectedName);
17
-
18
- if ( container ) {
19
- this.selectContainer(container);
20
- }
21
- }
22
- }
23
- };
24
- </script>
25
-
26
- <template>
27
- <Loading v-if="$fetchState.pending" />
28
- <form v-else class="filled-height">
29
- <CruResource
30
- :validation-passed="fvFormIsValid"
31
- :selected-subtype="type"
32
- :resource="value"
33
- :mode="mode"
34
- :errors="fvUnreportedValidationErrors"
35
- :done-route="doneRoute"
36
- :subtypes="workloadSubTypes"
37
- :apply-hooks="applyHooks"
38
- :value="value"
39
- @finish="save"
40
- @select-type="selectType"
41
- @error="e=>errors = e"
42
- >
43
- <!-- <pre>{{ JSON.stringify(allContainers, null, 2) }}</pre> -->
44
- <NameNsDescription
45
- :value="value"
46
- :mode="mode"
47
- :rules="{name: fvGetAndReportPathRules('metadata.name'), namespace: fvGetAndReportPathRules('metadata.namespace'), description: []}"
48
- @change="name=value.metadata.name"
49
- />
50
- <div v-if="isCronJob || isReplicable || isStatefulSet || containerOptions.length > 1" class="row mb-20">
51
- <div v-if="isCronJob" class="col span-3">
52
- <LabeledInput
53
- v-model="spec.schedule"
54
- type="cron"
55
- required
56
- :mode="mode"
57
- :label="t('workload.cronSchedule')"
58
- :rules="fvGetAndReportPathRules('spec.schedule')"
59
- placeholder="0 * * * *"
60
- />
61
- </div>
62
- <div v-if="isReplicable" class="col span-3">
63
- <LabeledInput
64
- v-model.number="spec.replicas"
65
- type="number"
66
- min="0"
67
- required
68
- :mode="mode"
69
- :label="t('workload.replicas')"
70
- />
71
- </div>
72
- <div v-if="isStatefulSet" class="col span-3">
73
- <LabeledSelect
74
- v-model="spec.serviceName"
75
- option-label="metadata.name"
76
- :reduce="service=>service.metadata.name"
77
- :mode="mode"
78
- :label="t('workload.serviceName')"
79
- :options="headlessServices"
80
- required
81
- />
82
- </div>
83
- </div>
84
- <Tabbed class="deployment-tabs">
85
- <Tab :label="t('workload.tabs.labels.containers')" name="containers" :error="tabErrors.general">
86
- <Tabbed :side-tabs="true" @changed="changed">
87
- <Tab
88
- v-for="(tab, i) in allContainers"
89
- :key="i"
90
- :label="tab.name"
91
- :name="tab.name"
92
- :weight="tab.weight"
93
- :error="!!tab.error"
94
- >
95
- <template #tab-header-right class="tab-content-controls">
96
- <button v-if="allContainers.length > 1 && !isView" type="button" class="btn-sm role-link" @click="removeContainer(tab)">
97
- {{ t('workload.container.removeContainer') }}
98
- </button>
99
- </template>
100
- <div>
101
- <div :style="{'align-items':'center'}" class="row mb-20">
102
- <div class="col span-6">
103
- <LabeledInput v-model="container.name" :mode="mode" :label="t('workload.container.containerName')" />
104
- </div>
105
- <div class="col span-6">
106
- <RadioGroup
107
- :mode="mode"
108
- :value="isInitContainer"
109
- name="initContainer"
110
- :options="[true, false]"
111
- :labels="[t('workload.container.init'), t('workload.container.standard')]"
112
- @input="updateInitContainer"
113
- />
114
- </div>
115
- </div>
116
- <h3>{{ t('workload.container.titles.image') }}</h3>
117
- <div class="row mb-20">
118
- <div class="col span-6">
119
- <LabeledInput
120
- v-model.trim="container.image"
121
- :mode="mode"
122
- :label="t('workload.container.image')"
123
- :placeholder="t('generic.placeholder', {text: 'nginx:latest'}, true)"
124
- :rules="fvGetAndReportPathRules('image')"
125
- />
126
- </div>
127
- <div class="col span-6">
128
- <LabeledSelect
129
- v-model="container.imagePullPolicy"
130
- :label="t('workload.container.imagePullPolicy')"
131
- :options="pullPolicyOptions"
132
- :mode="mode"
133
- />
134
- </div>
135
- </div>
136
- <div class="row">
137
- <div class="col span-6">
138
- <LabeledSelect
139
- v-model="imagePullSecrets"
140
- :label="t('workload.container.imagePullSecrets')"
141
- :multiple="true"
142
- :taggable="true"
143
- :options="namespacedSecrets"
144
- :mode="mode"
145
- option-label="metadata.name"
146
- :reduce="service=>service.metadata.name"
147
- />
148
- </div>
149
- </div>
150
- </div>
151
- <div v-if="!isInitContainer" class="healthcheck">
152
- <div class="spacer" />
153
- <h2>{{ t('workload.container.titles.healthCheck') }} </h2>
154
- <HealthCheck v-model="healthCheck" :mode="mode" />
155
- </div>
156
- <div class="spacer" />
157
- <div>
158
- <h3>{{ t('workload.container.titles.ports') }}</h3>
159
- <div class="row">
160
- <WorkloadPorts v-model="container.ports" :name="value.metadata.name" :services="servicesOwned" :mode="mode" />
161
- </div>
162
- </div>
163
- <div class="spacer" />
164
- <!-- Resources and Limitations -->
165
- <div>
166
- <h2 class="mb-10">
167
- <t k="workload.scheduling.titles.limits" />
168
- </h2>
169
- <ContainerResourceLimit v-model="flatResources" :mode="mode" :show-tip="false" />
170
- </div>
171
- <div class="spacer" />
172
- <div>
173
- <h2>{{ t('workload.container.titles.securityContext') }} </h2>
174
- <Security v-model="container.securityContext" :mode="mode" />
175
- </div>
176
- <div class="spacer" />
177
- <div>
178
- <h3>{{ t('workload.container.titles.command') }}</h3>
179
- <Command v-model="container" :secrets="namespacedSecrets" :config-maps="namespacedConfigMaps" :mode="mode" />
180
- </div>
181
- <ServiceNameSelect
182
- :value="podTemplateSpec.serviceAccountName"
183
- :mode="mode"
184
- :select-label="t('workload.serviceAccountName.label')"
185
- :select-placeholder="t('workload.serviceAccountName.label')"
186
- :options="namespacedServiceNames"
187
- option-label="metadata.name"
188
- @input="updateServiceAccount"
189
- />
190
- <div class="spacer" />
191
- <div>
192
- <h3>{{ t('workload.container.titles.lifecycle') }}</h3>
193
- <LifecycleHooks v-model="container.lifecycle" :mode="mode" />
194
- </div>
195
- </Tab>
196
- <template #tab-row-extras>
197
- <div class="side-tablist-controls">
198
- <button v-if="!isView" type="button" class="btn-sm role-link" @click="addContainerBtn">
199
- {{ t('workload.container.addContainer') }}
200
- </button>
201
- </div>
202
- </template>
203
- </Tabbed>
204
- </Tab>
205
- <Tab :label="t('workload.tabs.labels.deployment')" :name="'deployment'" :weight="99">
206
- <Tabbed :side-tabs="true">
207
- <Tab name="labels" label-key="generic.labelsAndAnnotations" :weight="tabWeightMap['labels']">
208
- <Labels v-model="value" :mode="mode" />
209
- </Tab>
210
- <Tab :label="t('workload.container.titles.upgrading')" name="upgrading" :weight="tabWeightMap['upgrading']">
211
- <Job v-if="isJob || isCronJob" v-model="spec" :mode="mode" :type="type" />
212
- <Upgrading v-else v-model="spec" :mode="mode" :type="type" :no-pod-spec="true" />
213
- </Tab>
214
- </Tabbed>
215
- </Tab>
216
- <Tab :label="t('workload.tabs.labels.pod')" :name="'pod'" :weight="99">
217
- <Tabbed :side-tabs="true">
218
- <Tab :label="t('workload.storage.title')" name="storage" :weight="tabWeightMap['storage']">
219
- <Storage
220
- v-model="podTemplateSpec"
221
- :namespace="value.metadata.namespace"
222
- :register-before-hook="registerBeforeHook"
223
- :mode="mode"
224
- :secrets="namespacedSecrets"
225
- :config-maps="namespacedConfigMaps"
226
- :container="container"
227
- :save-pvc-hook-name="savePvcHookName"
228
- @removePvcForm="clearPvcFormState"
229
- />
230
- </Tab>
231
- <Tab :label="t('workload.container.titles.resources')" name="resources" :weight="tabWeightMap['resources']">
232
- <template>
233
- <div>
234
- <h3 class="mb-10">
235
- <t k="workload.scheduling.titles.tolerations" />
236
- </h3>
237
- <div class="row">
238
- <Tolerations v-model="podTemplateSpec.tolerations" :mode="mode" />
239
- </div>
240
- </div>
241
-
242
- <div>
243
- <div class="spacer" />
244
- <h3 class="mb-10">
245
- <t k="workload.scheduling.titles.priority" />
246
- </h3>
247
- <div class="row">
248
- <div class="col span-6">
249
- <LabeledInput v-model.number="podTemplateSpec.priority" :mode="mode" :label="t('workload.scheduling.priority.priority')" />
250
- </div>
251
- <div class="col span-6">
252
- <LabeledInput v-model="podTemplateSpec.priorityClassname" :mode="mode" :label="t('workload.scheduling.priority.className')" />
253
- </div>
254
- </div>
255
- </div>
256
- </template>
257
- </Tab>
258
- <Tab :label="t('workload.container.titles.podScheduling')" name="podScheduling" :weight="tabWeightMap['podScheduling']">
259
- <PodAffinity :mode="mode" :value="podTemplateSpec" :nodes="allNodeObjects" />
260
- </Tab>
261
- <Tab :label="t('workload.container.titles.nodeScheduling')" name="nodeScheduling" :weight="tabWeightMap['nodeScheduling']">
262
- <NodeScheduling :mode="mode" :value="podTemplateSpec" :nodes="allNodes" />
263
- </Tab>
264
- <Tab :label="t('workload.container.titles.upgrading')" name="upgrading" :weight="tabWeightMap['upgrading']">
265
- <Job v-if="isJob || isCronJob" v-model="spec" :mode="mode" :type="type" />
266
- <Upgrading v-else v-model="spec" :mode="mode" :type="type" :no-deployment-spec="true" />
267
- </Tab>
268
- <Tab :label="t('workload.container.titles.securityContext')" name="securityContext" :weight="tabWeightMap['securityContext']">
269
- <div>
270
- <h3>{{ t('workload.container.security.podFsGroup') }}</h3>
271
- <div class="row">
272
- <div class="col span-6">
273
- <LabeledInput v-model.number="podFsGroup" type="number" :mode="mode" :label="t('workload.container.security.fsGroup')" />
274
- </div>
275
- </div>
276
- </div>
277
- </Tab>
278
- <Tab :label="t('workload.container.titles.networking')" name="networking" :weight="tabWeightMap['networking']">
279
- <Networking v-model="podTemplateSpec" :mode="mode" />
280
- </Tab>
281
- <Tab v-if="isStatefulSet" :label="t('workload.container.titles.volumeClaimTemplates')" name="volumeClaimTemplates" :weight="tabWeightMap['volumeClaimTemplates']">
282
- <VolumeClaimTemplate v-model="spec" :mode="mode" />
283
- </Tab>
284
- <Tab name="labels" label-key="generic.labelsAndAnnotations" :weight="tabWeightMap['labels']">
285
- <div>
286
- <h3>{{ t('workload.container.titles.podLabels') }}</h3>
287
- <div class="row mb-20">
288
- <KeyValue
289
- key="labels"
290
- v-model="podLabels"
291
- :add-label="t('labels.addLabel')"
292
- :mode="mode"
293
- :read-allowed="false"
294
- :protip="false"
295
- />
296
- </div>
297
- <div class="spacer" />
298
- <h3>{{ t('workload.container.titles.podAnnotations') }}</h3>
299
- <div class="row">
300
- <KeyValue
301
- key="annotations"
302
- v-model="podAnnotations"
303
- :add-label="t('labels.addAnnotation')"
304
- :mode="mode"
305
- :read-allowed="false"
306
- :protip="false"
307
- />
308
- </div>
309
- </div>
310
- </Tab>
311
- </Tabbed>
312
- </Tab>
313
- </Tabbed>
314
- </CruResource>
315
- </form>
316
- </template>
317
-
318
- <style lang='scss'>
319
- .container-row {
320
- display: flex;
321
- align-items: center;
322
- margin-bottom: 20px;
323
- }
324
-
325
- .type-placeholder {
326
- color: white;
327
- font-size: 2.5em;
328
- height: 100%;
329
- width: 100%;
330
- background-color: var(--primary);
331
- display: flex;
332
- justify-content: center;
333
- align-items: center;
334
- }
335
-
336
- .type-description {
337
- color: var(--input-label);
338
- }
339
-
340
- .next-dropdown {
341
- display: inline-block;
342
- }
343
-
344
- .tab-external-controls {
345
- display: flex;
346
- justify-content: right;
347
- }
348
-
349
- .tab-content-controls {
350
- display: flex;
351
- justify-content: right;
352
- }
353
-
354
- .side-tablist-controls {
355
- border-top: 1px solid var(--border);
356
- padding: 15px;
357
-
358
- .role-link {
359
- &:focus {
360
- background: none;
361
- box-shadow: none;
362
- }
363
-
364
- &:hover {
365
- border: none;
366
- }
367
- }
368
-
369
- }
370
-
371
- .deployment-tabs {
372
- > .tabs.horizontal {
373
- border-bottom: 1px solid var(--border);
374
- margin-bottom: 10px;
375
- }
376
- }
377
- </style>