@rancher/shell 0.3.0 → 0.3.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/assets/styles/global/_button.scss +5 -1
- package/assets/styles/global/_columns.scss +4 -0
- package/assets/styles/global/_layout.scss +1 -2
- package/assets/styles/global/_select.scss +1 -4
- package/assets/styles/themes/_dark.scss +4 -4
- package/assets/styles/themes/_light.scss +4 -3
- package/assets/styles/themes/_suse.scss +1 -1
- package/assets/styles/vendor/vue-select.scss +4 -3
- package/assets/translations/en-us.yaml +669 -73
- package/assets/translations/zh-hans.yaml +547 -165
- package/chart/monitoring/steps/uninstall-v1.vue +2 -2
- package/cloud-credential/azure.vue +23 -0
- package/cloud-credential/harvester.vue +25 -62
- package/cloud-credential/pnap.vue +80 -0
- package/components/.DS_Store +0 -0
- package/components/AdvancedSection.vue +9 -2
- package/components/Alert.vue +2 -2
- package/components/ButtonDropdown.vue +0 -2
- package/components/ButtonGroup.vue +1 -0
- package/components/CollapsibleCard.vue +0 -1
- package/components/CruResource.vue +41 -4
- package/components/DetailTop.vue +58 -3
- package/components/DisableAuthProviderModal.vue +106 -0
- package/{rancher-components/components/Utils/DraggableZone → components}/DraggableZone.vue +0 -0
- package/components/ExplorerMembers.vue +253 -30
- package/components/ExplorerProjectsNamespaces.vue +77 -33
- package/components/GrowlManager.vue +3 -3
- package/components/IconOrSvg.vue +149 -0
- package/components/LogItem.vue +69 -0
- package/components/PodSecurityAdmission.vue +302 -0
- package/components/PromptModal.vue +1 -0
- package/components/ResourceDetail/Masthead.vue +54 -2
- package/components/ResourceDetail/index.vue +12 -5
- package/components/ResourceList/Masthead.vue +11 -1
- package/components/ResourceList/ResourceLoadingIndicator.vue +12 -2
- package/components/ResourceList/index.vue +53 -12
- package/components/ResourceList/resource-list.config.js +7 -0
- package/components/ResourceTable.vue +31 -6
- package/components/SimpleBox.vue +1 -1
- package/components/SortableTable/THead.vue +15 -5
- package/components/SortableTable/index.vue +21 -10
- package/components/Tabbed/index.vue +20 -15
- package/components/__tests__/.DS_Store +0 -0
- package/components/__tests__/AsyncButton.test.ts +140 -0
- package/components/__tests__/BackLink.test.ts +33 -0
- package/components/__tests__/ButtonGroup.test.ts +124 -0
- package/components/__tests__/ClusterBadge.test.ts +32 -0
- package/components/__tests__/CollapsibleCard.test.ts +64 -0
- package/components/__tests__/ConsumptionGauge.test.ts +88 -0
- package/components/__tests__/CruResource.test.ts +3 -2
- package/components/__tests__/FixedBanner.test.ts +129 -0
- package/components/__tests__/GrowlManager.test.ts +147 -0
- package/components/__tests__/NamespaceFilter.test.ts +33 -25
- package/components/__tests__/PercentageBar.test.ts +32 -0
- package/components/__tests__/PodSecurityAdmission.test.ts +398 -0
- package/components/auth/AuthBanner.vue +20 -10
- package/components/auth/RoleDetailEdit.vue +26 -17
- package/components/auth/SelectPrincipal.vue +36 -5
- package/components/form/ArrayList.vue +3 -35
- package/components/form/ArrayListGrouped.vue +13 -4
- package/components/form/ArrayListSelect.vue +5 -5
- package/components/form/Error.vue +8 -0
- package/components/form/KeyValue.vue +39 -7
- package/components/form/LabeledSelect.vue +5 -2
- package/components/form/Labels.vue +46 -16
- package/components/form/Members/ClusterPermissionsEditor.vue +17 -17
- package/components/form/Members/MembershipEditor.vue +12 -12
- package/components/form/NameNsDescription.vue +1 -1
- package/components/form/NodeScheduling.vue +1 -1
- package/components/form/Probe.vue +3 -3
- package/components/form/ResourceQuota/Project.vue +6 -6
- package/components/form/ResourceTabs/index.vue +1 -6
- package/components/form/Security.vue +7 -6
- package/components/form/Select.vue +3 -2
- package/components/form/SelectOrCreateAuthSecret.vue +22 -29
- package/components/form/ServicePorts.vue +8 -0
- package/components/form/WorkloadPorts.vue +7 -1
- package/components/form/__tests__/ArrayList.test.ts +74 -0
- package/components/form/__tests__/ArrayListGrouped.test.ts +6 -4
- package/components/formatter/Checked.vue +1 -1
- package/components/formatter/ClusterLink.vue +5 -0
- package/components/formatter/IconIsDefault.vue +2 -2
- package/components/formatter/InternalExternalIP.vue +11 -8
- package/components/formatter/LiveDuration.vue +78 -0
- package/components/formatter/WorkloadHealthScale.vue +5 -3
- package/components/nav/Header.vue +6 -3
- package/components/nav/NamespaceFilter.vue +146 -63
- package/components/nav/TopLevelMenu.vue +22 -19
- package/components/nav/WindowManager/ContainerLogs.vue +83 -126
- package/components/nav/WindowManager/ContainerShell.vue +9 -7
- package/components/nav/WindowManager/Window.vue +2 -0
- package/components/nav/WindowManager/index.vue +10 -0
- package/config/elemental-types.js +9 -0
- package/config/features.js +2 -0
- package/config/home-links.js +4 -1
- package/config/pod-security-admission.ts +82 -0
- package/config/product/apps.js +1 -1
- package/config/product/auth.js +6 -5
- package/config/product/explorer.js +6 -6
- package/config/product/fleet.js +1 -1
- package/config/product/manager.js +6 -2
- package/config/secret.js +0 -1
- package/config/settings.ts +26 -9
- package/config/table-headers.js +22 -11
- package/config/types.js +4 -1
- package/content/docs/zh-hans/getting-started.md +113 -137
- package/content/docs/zh-hans/whats-new.md +8 -46
- package/creators/pkg/package-lock.json +37 -0
- package/creators/pkg/package.json +1 -1
- package/detail/catalog.cattle.io.app.vue +1 -1
- package/detail/pod.vue +1 -1
- package/detail/provisioning.cattle.io.cluster.vue +35 -9
- package/detail/service.vue +2 -9
- package/detail/workload/index.vue +0 -1
- package/dialog/AddClusterMemberDialog.vue +22 -28
- package/dialog/AddProjectMemberDialog.vue +53 -9
- package/dialog/DiagnosticTimingsDialog.vue +8 -7
- package/dialog/DrainNode.vue +44 -48
- package/dialog/ForceMachineRemoveDialog.vue +5 -7
- package/dialog/GenericPrompt.vue +15 -20
- package/dialog/RollbackWorkloadDialog.vue +15 -46
- package/dialog/RotateCertificatesDialog.vue +5 -7
- package/dialog/RotateEncryptionKeyDialog.vue +5 -9
- package/dialog/SaveAsRKETemplateDialog.vue +5 -13
- package/dialog/ScaleMachineDownDialog.vue +1 -1
- package/dialog/ScalePoolDownDialog.vue +121 -0
- package/edit/__tests__/management.cattle.io.setting.test.ts +3 -3
- package/edit/auth/azuread.vue +16 -16
- package/edit/auth/github.vue +8 -0
- package/edit/auth/googleoauth.vue +10 -1
- package/edit/auth/ldap/index.vue +10 -0
- package/edit/auth/oidc.vue +10 -0
- package/edit/auth/saml.vue +10 -0
- package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -1
- package/edit/cloudcredential.vue +3 -7
- package/edit/logging-flow/Match.vue +39 -8
- package/edit/logging-flow/index.vue +27 -4
- package/edit/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +107 -0
- package/edit/management.cattle.io.project.vue +8 -1
- package/edit/management.cattle.io.setting.vue +5 -2
- package/edit/management.cattle.io.user.vue +7 -1
- package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +23 -7
- package/edit/monitoring.coreos.com.alertmanagerconfig/types/email.vue +2 -2
- package/edit/monitoring.coreos.com.prometheusrule/GroupRules.vue +14 -6
- package/edit/namespace.vue +18 -4
- package/edit/networking.k8s.io.ingress/Certificate.vue +1 -0
- package/edit/networking.k8s.io.ingress/IngressClass.vue +8 -6
- package/edit/networking.k8s.io.ingress/RulePath.vue +12 -6
- package/edit/networking.k8s.io.ingress/index.vue +8 -6
- package/edit/persistentvolume/index.vue +30 -27
- package/edit/persistentvolume/plugins/cephfs.vue +29 -29
- package/edit/persistentvolume/plugins/csi.vue +102 -62
- package/edit/persistentvolume/plugins/fc.vue +19 -19
- package/edit/persistentvolume/plugins/iscsi.vue +45 -45
- package/edit/persistentvolume/plugins/rbd.vue +39 -39
- package/edit/persistentvolumeclaim.vue +78 -75
- package/edit/provisioning.cattle.io.cluster/MachinePool.vue +11 -7
- package/edit/provisioning.cattle.io.cluster/RegistryConfigs.vue +10 -1
- package/edit/provisioning.cattle.io.cluster/RegistryMirrors.vue +87 -27
- package/edit/provisioning.cattle.io.cluster/SelectCredential.vue +3 -6
- package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +93 -0
- package/edit/provisioning.cattle.io.cluster/import.vue +1 -1
- package/edit/provisioning.cattle.io.cluster/index.vue +29 -6
- package/edit/provisioning.cattle.io.cluster/rke2.vue +440 -152
- package/edit/secret/index.vue +3 -7
- package/edit/service.vue +3 -1
- package/edit/storage.k8s.io.storageclass/index.vue +100 -16
- package/edit/storage.k8s.io.storageclass/provisioners/driver.harvesterhci.io.vue +114 -0
- package/edit/workload/__tests__/index.test.ts +98 -0
- package/edit/workload/index.vue +58 -8
- package/edit/workload/mixins/workload.js +107 -70
- package/edit/workload/storage/ContainerMountPaths.vue +0 -10
- package/edit/workload/storage/emptyDir.vue +88 -0
- package/edit/workload/storage/ephemeralVolume/index.vue +1 -1
- package/edit/workload/storage/index.vue +8 -0
- package/edit/workload/storage/persistentVolumeClaim/index.vue +1 -1
- package/layouts/default.vue +57 -44
- package/list/__tests__/workload.test.ts +5 -2
- package/list/catalog.cattle.io.app.vue +1 -0
- package/list/cis.cattle.io.clusterscan.vue +1 -0
- package/list/fleet.cattle.io.bundle.vue +5 -6
- package/list/fleet.cattle.io.cluster.vue +6 -3
- package/list/fleet.cattle.io.clusterregistrationtoken.vue +5 -6
- package/list/fleet.cattle.io.gitrepo.vue +4 -9
- package/list/helm.cattle.io.projecthelmchart.vue +1 -5
- package/list/logging.banzaicloud.io.clusterflow.vue +4 -1
- package/list/logging.banzaicloud.io.flow.vue +6 -5
- package/list/management.cattle.io.cluster.vue +1 -0
- package/list/management.cattle.io.feature.vue +3 -4
- package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +47 -0
- package/list/management.cattle.io.setting.vue +2 -2
- package/list/management.cattle.io.user.vue +4 -10
- package/list/monitoring.coreos.com.alertmanagerconfig.vue +2 -7
- package/list/node.vue +8 -5
- package/list/persistentvolume.vue +3 -3
- package/list/persistentvolumeclaim.vue +3 -4
- package/list/provisioning.cattle.io.cluster.vue +18 -19
- package/list/service.vue +6 -14
- package/list/workload.vue +43 -38
- package/machine-config/azure.vue +429 -60
- package/machine-config/pnap.vue +288 -0
- package/mixins/auth-config.js +1 -3
- package/mixins/browser-tab-visibility.js +8 -14
- package/mixins/chart.js +1 -1
- package/mixins/create-edit-view/impl.js +4 -0
- package/mixins/create-edit-view/index.js +4 -2
- package/mixins/resource-fetch-namespaced.js +98 -0
- package/mixins/resource-fetch.js +79 -45
- package/mixins/resource-manager.js +1 -23
- package/models/apps.controllerrevision.js +7 -0
- package/models/apps.daemonset.js +18 -0
- package/models/apps.deployment.js +44 -0
- package/models/apps.replicaset.js +7 -0
- package/models/apps.statefulset.js +18 -0
- package/models/batch.job.js +7 -14
- package/models/cluster/node.js +10 -2
- package/models/cluster.x-k8s.io.machine.js +26 -4
- package/models/cluster.x-k8s.io.machinedeployment.js +12 -2
- package/models/event.js +7 -0
- package/models/logging.banzaicloud.io.flow.js +4 -0
- package/models/management.cattle.io.cluster.js +1 -1
- package/models/management.cattle.io.clusterroletemplatebinding.js +1 -1
- package/models/management.cattle.io.globalrole.js +2 -2
- package/models/management.cattle.io.node.js +37 -2
- package/models/management.cattle.io.podsecurityadmissionconfigurationtemplate.ts +4 -0
- package/models/management.cattle.io.project.js +30 -11
- package/models/management.cattle.io.setting.js +1 -1
- package/models/management.cattle.io.user.js +37 -1
- package/models/namespace.js +42 -5
- package/models/persistentvolume.js +14 -2
- package/models/pod.js +15 -0
- package/models/projectroletemplatebinding.js +7 -0
- package/models/provisioning.cattle.io.cluster.js +61 -10
- package/models/rke-machine.cattle.io.pnapmachinetemplate.js +15 -0
- package/models/service.js +14 -13
- package/models/storage.k8s.io.storageclass.js +33 -18
- package/models/workload.js +38 -7
- package/nuxt.config.js +27 -17
- package/package.json +7 -7
- package/pages/about.vue +14 -2
- package/pages/c/_cluster/apps/charts/index.vue +4 -3
- package/pages/c/_cluster/apps/charts/install.vue +59 -22
- package/pages/c/_cluster/auth/config/_id.vue +6 -0
- package/pages/c/_cluster/auth/config/index.vue +8 -6
- package/pages/c/_cluster/auth/group.principal/assign-edit.vue +1 -1
- package/pages/c/_cluster/auth/roles/index.vue +1 -1
- package/pages/c/_cluster/explorer/index.vue +12 -6
- package/pages/c/_cluster/longhorn/index.vue +1 -1
- package/pages/c/_cluster/monitoring/alertmanagerconfig/_alertmanagerconfigid/receiver.vue +15 -4
- package/pages/c/_cluster/monitoring/index.vue +1 -1
- package/pages/c/_cluster/neuvector/index.vue +1 -1
- package/pages/c/_cluster/settings/performance.vue +48 -2
- package/pages/c/_cluster/uiplugins/PluginInfoPanel.vue +34 -1
- package/pages/c/_cluster/uiplugins/index.vue +28 -2
- package/pages/diagnostic.vue +5 -4
- package/pages/home.vue +105 -30
- package/pages/prefs.vue +23 -12
- package/pages/rio/mesh.vue +1 -1
- package/pkg/dynamic-importer.lib.js +8 -0
- package/pkg/vue.config.js +4 -0
- package/plugins/dashboard-store/__tests__/mutations.spec.js +406 -0
- package/plugins/dashboard-store/actions.js +32 -25
- package/plugins/dashboard-store/getters.js +50 -33
- package/plugins/dashboard-store/mutations.js +134 -28
- package/plugins/dashboard-store/resource-class.js +21 -41
- package/plugins/steve/actions.js +30 -0
- package/plugins/steve/caches/resourceCache.js +60 -0
- package/plugins/steve/getters.js +44 -1
- package/plugins/steve/mutations.js +97 -36
- package/plugins/steve/resourceWatcher.js +277 -0
- package/plugins/steve/schema.utils.js +25 -0
- package/plugins/steve/subscribe.js +288 -115
- package/plugins/steve/worker/index.js +17 -0
- package/plugins/steve/worker/web-worker.advanced.js +302 -0
- package/plugins/steve/{web-worker.steve-sub-worker.js → worker/web-worker.basic.js} +3 -44
- package/rancher-components/Card/Card.vue +3 -3
- package/rancher-components/Form/TextArea/TextAreaAutoGrow.vue +1 -0
- package/rancher-components/StringList/StringList.test.ts +45 -420
- package/rancher-components/StringList/StringList.vue +1 -10
- package/rancher-components/components/Banner/Banner.test.ts +44 -0
- package/rancher-components/components/Banner/Banner.vue +129 -61
- package/rancher-components/components/Form/Checkbox/Checkbox.test.ts +13 -22
- package/rancher-components/components/Form/Checkbox/Checkbox.vue +8 -6
- package/rancher-components/components/Form/ToggleSwitch/ToggleSwitch.test.ts +9 -9
- package/rancher-components/components/LabeledTooltip/LabeledTooltip.vue +0 -1
- package/rancher-components/components/StringList/StringList.test.ts +7 -7
- package/rancher-components/components/StringList/StringList.vue +21 -15
- package/scripts/test-plugins-build.sh +8 -0
- package/static/loading-indicator.html +1 -1
- package/store/index.js +54 -3
- package/store/plugins.js +0 -17
- package/store/pnap.js +128 -0
- package/store/prefs.js +4 -2
- package/store/type-map.js +55 -13
- package/types/pod-security-admission.ts +36 -0
- package/types/shell/index.d.ts +496 -396
- package/utils/__tests__/object.test.ts +17 -1
- package/utils/__tests__/pod-security-admission.test.ts +61 -0
- package/utils/async.ts +36 -0
- package/utils/color.js +45 -0
- package/utils/crypto/browserHashUtils.js +18 -0
- package/utils/dynamic-importer.js +8 -0
- package/utils/install-redirect.js +1 -1
- package/utils/object.js +24 -0
- package/utils/pod-security-admission.ts +39 -0
- package/utils/socket.js +61 -24
- package/utils/string.js +2 -0
- package/utils/svg-filter.js +301 -0
- package/utils/time.js +49 -0
- package/utils/validators/cidr.js +4 -0
- package/utils/validators/formRules/__tests__/index.test.ts +23 -3
- package/utils/validators/formRules/index.ts +14 -0
- package/config/product/harvester-manager.js +0 -162
- package/edit/harvesterhci.io.management.cluster.vue +0 -153
- package/list/harvesterhci.io.management.cluster.vue +0 -241
- package/machine-config/harvester.vue +0 -693
- package/models/harvesterhci.io.management.cluster.js +0 -228
- package/pages/c/_cluster/harvesterManager/index.vue +0 -24
- package/rancher-components/Card/Card.test.ts +0 -39
- package/rancher-components/Utils/DraggableZone/DraggableZone.vue +0 -181
- package/rancher-components/Utils/DraggableZone/index.ts +0 -1
- package/rancher-components/components/Utils/DraggableZone/index.ts +0 -1
|
@@ -1,8 +1,12 @@
|
|
|
1
1
|
<script>
|
|
2
2
|
import KeyValue from '@shell/components/form/KeyValue';
|
|
3
|
+
import { ToggleSwitch } from '@components/Form/ToggleSwitch';
|
|
3
4
|
|
|
4
5
|
export default {
|
|
5
|
-
components: {
|
|
6
|
+
components: {
|
|
7
|
+
ToggleSwitch,
|
|
8
|
+
KeyValue
|
|
9
|
+
},
|
|
6
10
|
|
|
7
11
|
props: {
|
|
8
12
|
value: {
|
|
@@ -41,6 +45,10 @@ export default {
|
|
|
41
45
|
}
|
|
42
46
|
},
|
|
43
47
|
|
|
48
|
+
data() {
|
|
49
|
+
return { toggler: false };
|
|
50
|
+
},
|
|
51
|
+
|
|
44
52
|
computed: {
|
|
45
53
|
containerClass() {
|
|
46
54
|
return `${ this.displaySideBySide ? 'row' : '' } ${ this.defaultContainerClass }`.trim();
|
|
@@ -48,24 +56,41 @@ export default {
|
|
|
48
56
|
|
|
49
57
|
sectionClass() {
|
|
50
58
|
return `${ this.displaySideBySide ? 'col span-6' : 'row' } ${ this.defaultSectionClass }`.trim();
|
|
51
|
-
}
|
|
59
|
+
},
|
|
60
|
+
|
|
52
61
|
}
|
|
53
62
|
};
|
|
54
63
|
</script>
|
|
55
64
|
<template>
|
|
56
65
|
<div :class="containerClass">
|
|
57
|
-
<div
|
|
58
|
-
<
|
|
59
|
-
|
|
60
|
-
|
|
61
|
-
|
|
62
|
-
|
|
63
|
-
|
|
64
|
-
|
|
65
|
-
|
|
66
|
-
|
|
67
|
-
|
|
68
|
-
|
|
66
|
+
<div class="labels">
|
|
67
|
+
<div class="labels__header">
|
|
68
|
+
<h3>
|
|
69
|
+
<t k="labels.labels.title" />
|
|
70
|
+
</h3>
|
|
71
|
+
<ToggleSwitch
|
|
72
|
+
v-if="value.hasSystemLabels"
|
|
73
|
+
v-model="toggler"
|
|
74
|
+
name="label-system-toggle"
|
|
75
|
+
:on-label="t('labels.labels.show')"
|
|
76
|
+
/>
|
|
77
|
+
</div>
|
|
78
|
+
<p class="mt-10 mb-10">
|
|
79
|
+
<t k="labels.labels.description" />
|
|
80
|
+
</p>
|
|
81
|
+
<div :class="sectionClass">
|
|
82
|
+
<KeyValue
|
|
83
|
+
key="labels"
|
|
84
|
+
:value="value.labels"
|
|
85
|
+
:protected-keys="value.systemLabels || []"
|
|
86
|
+
:toggle-filter="toggler"
|
|
87
|
+
:add-label="t('labels.addLabel')"
|
|
88
|
+
:mode="mode"
|
|
89
|
+
:read-allowed="false"
|
|
90
|
+
:value-can-be-empty="true"
|
|
91
|
+
@input="value.setLabels($event)"
|
|
92
|
+
/>
|
|
93
|
+
</div>
|
|
69
94
|
</div>
|
|
70
95
|
<div class="spacer" />
|
|
71
96
|
<div :class="sectionClass">
|
|
@@ -84,6 +109,11 @@ export default {
|
|
|
84
109
|
</div>
|
|
85
110
|
</template>
|
|
86
111
|
|
|
87
|
-
<style scoped>
|
|
88
|
-
|
|
112
|
+
<style lang="scss" scoped>
|
|
113
|
+
.labels {
|
|
114
|
+
&__header {
|
|
115
|
+
display: flex;
|
|
116
|
+
justify-content: space-between;
|
|
117
|
+
}
|
|
118
|
+
}
|
|
89
119
|
</style>
|
|
@@ -213,9 +213,9 @@ export default {
|
|
|
213
213
|
</script>
|
|
214
214
|
<template>
|
|
215
215
|
<Loading v-if="$fetchState.pending" />
|
|
216
|
-
<div
|
|
217
|
-
v-else
|
|
218
|
-
class="cluster-permissions-editor"
|
|
216
|
+
<div
|
|
217
|
+
v-else
|
|
218
|
+
class="cluster-permissions-editor"
|
|
219
219
|
>
|
|
220
220
|
<div class="row mt-10">
|
|
221
221
|
<div class="col span-12">
|
|
@@ -229,10 +229,10 @@ export default {
|
|
|
229
229
|
</div>
|
|
230
230
|
</div>
|
|
231
231
|
|
|
232
|
-
<Card
|
|
233
|
-
class="m-0"
|
|
234
|
-
:show-highlight-border="false"
|
|
235
|
-
:show-actions="false"
|
|
232
|
+
<Card
|
|
233
|
+
class="m-0"
|
|
234
|
+
:show-highlight-border="false"
|
|
235
|
+
:show-actions="false"
|
|
236
236
|
>
|
|
237
237
|
<template v-slot:title>
|
|
238
238
|
<div class="type-title">
|
|
@@ -248,17 +248,17 @@ export default {
|
|
|
248
248
|
:options="options"
|
|
249
249
|
name="permission-group"
|
|
250
250
|
/>
|
|
251
|
-
<div
|
|
252
|
-
v-if="permissionGroup === 'custom'"
|
|
253
|
-
class="custom-permissions ml-20 mt-10"
|
|
254
|
-
:class="{'two-column': useTwoColumnsForCustom}"
|
|
251
|
+
<div
|
|
252
|
+
v-if="permissionGroup === 'custom'"
|
|
253
|
+
class="custom-permissions ml-20 mt-10"
|
|
254
|
+
:class="{'two-column': useTwoColumnsForCustom}"
|
|
255
255
|
>
|
|
256
|
-
<Checkbox
|
|
257
|
-
v-for="permission in customPermissions"
|
|
258
|
-
:key="permission.key"
|
|
259
|
-
v-model="permission.value"
|
|
260
|
-
class="mb-5"
|
|
261
|
-
:label="permission.label"
|
|
256
|
+
<Checkbox
|
|
257
|
+
v-for="permission in customPermissions"
|
|
258
|
+
:key="permission.key"
|
|
259
|
+
v-model="permission.value"
|
|
260
|
+
class="mb-5"
|
|
261
|
+
:label="permission.label"
|
|
262
262
|
/>
|
|
263
263
|
</div>
|
|
264
264
|
</template>
|
|
@@ -138,9 +138,9 @@ export default {
|
|
|
138
138
|
methods: {
|
|
139
139
|
addMember() {
|
|
140
140
|
this.$store.dispatch('cluster/promptModal', {
|
|
141
|
-
component:
|
|
142
|
-
|
|
143
|
-
modalSticky:
|
|
141
|
+
component: this.addMemberDialogName,
|
|
142
|
+
componentProps: { onAdd: this.onAddMember },
|
|
143
|
+
modalSticky: this.modalSticky
|
|
144
144
|
});
|
|
145
145
|
},
|
|
146
146
|
|
|
@@ -173,9 +173,9 @@ export default {
|
|
|
173
173
|
<template #columns="{row}">
|
|
174
174
|
<div class="columns row">
|
|
175
175
|
<div class="col span-6">
|
|
176
|
-
<Principal
|
|
177
|
-
:key="row.value.principalId"
|
|
178
|
-
:value="row.value.principalId"
|
|
176
|
+
<Principal
|
|
177
|
+
:key="row.value.principalId"
|
|
178
|
+
:value="row.value.principalId"
|
|
179
179
|
/>
|
|
180
180
|
</div>
|
|
181
181
|
<div class="col span-6 role">
|
|
@@ -194,12 +194,12 @@ export default {
|
|
|
194
194
|
</template>
|
|
195
195
|
<template #remove-button="{remove, i}">
|
|
196
196
|
<span v-if="(isCreate && i === 0) || isView" />
|
|
197
|
-
<button
|
|
198
|
-
v-else
|
|
199
|
-
type="button"
|
|
200
|
-
:disabled="isView"
|
|
201
|
-
class="btn role-link"
|
|
202
|
-
@click="remove"
|
|
197
|
+
<button
|
|
198
|
+
v-else
|
|
199
|
+
type="button"
|
|
200
|
+
:disabled="isView"
|
|
201
|
+
class="btn role-link"
|
|
202
|
+
@click="remove"
|
|
203
203
|
>
|
|
204
204
|
{{ t('generic.remove') }}
|
|
205
205
|
</button>
|
|
@@ -3,7 +3,7 @@ import { mapGetters } from 'vuex';
|
|
|
3
3
|
import { RadioGroup } from '@components/Form/Radio';
|
|
4
4
|
import LabeledSelect from '@shell/components/form/LabeledSelect';
|
|
5
5
|
import NodeAffinity from '@shell/components/form/NodeAffinity';
|
|
6
|
-
import { HARVESTER_NAME as VIRTUAL } from '@shell/config/
|
|
6
|
+
import { HARVESTER_NAME as VIRTUAL } from '@shell/config/features';
|
|
7
7
|
import { _VIEW } from '@shell/config/query-params';
|
|
8
8
|
import { isEmpty } from '@shell/utils/object';
|
|
9
9
|
import { HOSTNAME } from '@shell/config/labels-annotations';
|
|
@@ -285,10 +285,10 @@ export default {
|
|
|
285
285
|
>
|
|
286
286
|
<UnitInput
|
|
287
287
|
v-model="probe.timeoutSeconds"
|
|
288
|
+
min="0"
|
|
288
289
|
:mode="mode"
|
|
289
290
|
:suffix="t('suffix.sec')"
|
|
290
|
-
:label="t('probe.timeout.
|
|
291
|
-
min="0"
|
|
291
|
+
:label="t('probe.timeout.label')"
|
|
292
292
|
:placeholder="t('probe.timeout.placeholder')"
|
|
293
293
|
@input="update"
|
|
294
294
|
/>
|
|
@@ -322,7 +322,7 @@ export default {
|
|
|
322
322
|
min="1"
|
|
323
323
|
:mode="mode"
|
|
324
324
|
:label="t('probe.failureThreshold.label')"
|
|
325
|
-
:placeholder="t('probe.failureThreshold.
|
|
325
|
+
:placeholder="t('probe.failureThreshold.placeholder')"
|
|
326
326
|
@input="update"
|
|
327
327
|
/>
|
|
328
328
|
</div>
|
|
@@ -72,12 +72,12 @@ export default {
|
|
|
72
72
|
@remove="emitRemove"
|
|
73
73
|
>
|
|
74
74
|
<template #columns="props">
|
|
75
|
-
<Row
|
|
76
|
-
v-model="value"
|
|
77
|
-
:mode="mode"
|
|
78
|
-
:types="remainingTypes(typeValues[props.i])"
|
|
79
|
-
:type="typeValues[props.i]"
|
|
80
|
-
@type-change="updateType(props.i, $event)"
|
|
75
|
+
<Row
|
|
76
|
+
v-model="value"
|
|
77
|
+
:mode="mode"
|
|
78
|
+
:types="remainingTypes(typeValues[props.i])"
|
|
79
|
+
:type="typeValues[props.i]"
|
|
80
|
+
@type-change="updateType(props.i, $event)"
|
|
81
81
|
/>
|
|
82
82
|
</template>
|
|
83
83
|
</ArrayList>
|
|
@@ -58,11 +58,6 @@ export default {
|
|
|
58
58
|
needRelated: {
|
|
59
59
|
type: Boolean,
|
|
60
60
|
default: true
|
|
61
|
-
},
|
|
62
|
-
|
|
63
|
-
alwaysShowEvents: {
|
|
64
|
-
type: Boolean,
|
|
65
|
-
default: false
|
|
66
61
|
}
|
|
67
62
|
},
|
|
68
63
|
|
|
@@ -92,7 +87,7 @@ export default {
|
|
|
92
87
|
return false;
|
|
93
88
|
},
|
|
94
89
|
showEvents() {
|
|
95
|
-
return this.isView && this.needEvents && this.hasEvents
|
|
90
|
+
return this.isView && this.needEvents && this.hasEvents;
|
|
96
91
|
},
|
|
97
92
|
showRelated() {
|
|
98
93
|
return this.isView && this.needRelated;
|
|
@@ -63,10 +63,10 @@ export default {
|
|
|
63
63
|
|
|
64
64
|
const {
|
|
65
65
|
capabilities = {},
|
|
66
|
-
|
|
66
|
+
runAsNonRoot = false,
|
|
67
67
|
readOnlyRootFilesystem = false,
|
|
68
68
|
privileged = false,
|
|
69
|
-
allowPrivilegeEscalation =
|
|
69
|
+
allowPrivilegeEscalation = false,
|
|
70
70
|
runAsUser
|
|
71
71
|
} = this.value;
|
|
72
72
|
const {
|
|
@@ -78,7 +78,7 @@ export default {
|
|
|
78
78
|
privileged,
|
|
79
79
|
allowPrivilegeEscalation,
|
|
80
80
|
allCapabilities,
|
|
81
|
-
|
|
81
|
+
runAsNonRoot,
|
|
82
82
|
readOnlyRootFilesystem,
|
|
83
83
|
add,
|
|
84
84
|
drop,
|
|
@@ -105,7 +105,7 @@ export default {
|
|
|
105
105
|
methods: {
|
|
106
106
|
update() {
|
|
107
107
|
const securityContext = {
|
|
108
|
-
|
|
108
|
+
runAsNonRoot: this.runAsNonRoot,
|
|
109
109
|
readOnlyRootFilesystem: this.readOnlyRootFilesystem,
|
|
110
110
|
capabilities: { add: this.add, drop: this.drop },
|
|
111
111
|
privileged: this.privileged,
|
|
@@ -115,6 +115,7 @@ export default {
|
|
|
115
115
|
|
|
116
116
|
this.$emit('input', securityContext);
|
|
117
117
|
}
|
|
118
|
+
|
|
118
119
|
}
|
|
119
120
|
};
|
|
120
121
|
</script>
|
|
@@ -164,13 +165,13 @@ export default {
|
|
|
164
165
|
class="col span-6"
|
|
165
166
|
>
|
|
166
167
|
<RadioGroup
|
|
168
|
+
v-model="runAsNonRoot"
|
|
167
169
|
name="runasNonRoot"
|
|
168
170
|
:label="t('workload.container.security.runAsNonRoot.label')"
|
|
169
|
-
:value="!runAsRoot"
|
|
170
171
|
:options="[false, true]"
|
|
171
172
|
:labels="[t('workload.container.security.runAsNonRoot.false'), t('workload.container.security.runAsNonRoot.true')]"
|
|
172
173
|
:mode="mode"
|
|
173
|
-
@input="
|
|
174
|
+
@input="update"
|
|
174
175
|
/>
|
|
175
176
|
</div>
|
|
176
177
|
<div
|
|
@@ -135,7 +135,7 @@ export default {
|
|
|
135
135
|
return true;
|
|
136
136
|
},
|
|
137
137
|
getOptionKey(opt) {
|
|
138
|
-
if (opt
|
|
138
|
+
if (opt?.optionKey) {
|
|
139
139
|
return get(opt, opt.optionKey);
|
|
140
140
|
}
|
|
141
141
|
|
|
@@ -279,9 +279,10 @@ export default {
|
|
|
279
279
|
|
|
280
280
|
::v-deep .vs__selected-options {
|
|
281
281
|
display: flex;
|
|
282
|
+
margin: 3px;
|
|
282
283
|
|
|
283
284
|
.vs__selected {
|
|
284
|
-
width:
|
|
285
|
+
width: initial;
|
|
285
286
|
}
|
|
286
287
|
}
|
|
287
288
|
|
|
@@ -1,6 +1,5 @@
|
|
|
1
1
|
<script>
|
|
2
2
|
import { _EDIT } from '@shell/config/query-params';
|
|
3
|
-
import Loading from '@shell/components/Loading';
|
|
4
3
|
import { LabeledInput } from '@components/Form/LabeledInput';
|
|
5
4
|
import LabeledSelect from '@shell/components/form/LabeledSelect';
|
|
6
5
|
import { AUTH_TYPE, NORMAN, SECRET } from '@shell/config/types';
|
|
@@ -13,7 +12,6 @@ export default {
|
|
|
13
12
|
name: 'SelectOrCreateAuthSecret',
|
|
14
13
|
|
|
15
14
|
components: {
|
|
16
|
-
Loading,
|
|
17
15
|
LabeledInput,
|
|
18
16
|
LabeledSelect,
|
|
19
17
|
},
|
|
@@ -131,8 +129,6 @@ export default {
|
|
|
131
129
|
} else {
|
|
132
130
|
this.allSecrets = await this.$store.dispatch(`${ this.inStore }/findAll`, { type: SECRET });
|
|
133
131
|
}
|
|
134
|
-
} else {
|
|
135
|
-
this.allSecrets = [];
|
|
136
132
|
}
|
|
137
133
|
|
|
138
134
|
if ( this.allowS3 && this.$store.getters['rancher/canList'](NORMAN.CLOUD_CREDENTIAL) ) {
|
|
@@ -170,10 +166,10 @@ export default {
|
|
|
170
166
|
this.update();
|
|
171
167
|
},
|
|
172
168
|
|
|
173
|
-
data() {
|
|
169
|
+
data(props) {
|
|
174
170
|
return {
|
|
175
|
-
allCloudCreds:
|
|
176
|
-
allSecrets:
|
|
171
|
+
allCloudCreds: [],
|
|
172
|
+
allSecrets: [],
|
|
177
173
|
selected: null,
|
|
178
174
|
|
|
179
175
|
publicKey: '',
|
|
@@ -279,11 +275,26 @@ export default {
|
|
|
279
275
|
disabled: true
|
|
280
276
|
});
|
|
281
277
|
}
|
|
278
|
+
if ( this.allowNone ) {
|
|
279
|
+
out.unshift({
|
|
280
|
+
label: this.t('generic.none'),
|
|
281
|
+
value: AUTH_TYPE._NONE,
|
|
282
|
+
});
|
|
283
|
+
}
|
|
284
|
+
|
|
285
|
+
if (this.allowSsh || this.allowS3 || this.allowBasic) {
|
|
286
|
+
out.unshift({
|
|
287
|
+
label: 'divider',
|
|
288
|
+
disabled: true,
|
|
289
|
+
kind: 'divider'
|
|
290
|
+
});
|
|
291
|
+
}
|
|
282
292
|
|
|
283
293
|
if ( this.allowSsh ) {
|
|
284
294
|
out.unshift({
|
|
285
295
|
label: this.t('selectOrCreateAuthSecret.createSsh'),
|
|
286
296
|
value: AUTH_TYPE._SSH,
|
|
297
|
+
kind: 'highlighted'
|
|
287
298
|
});
|
|
288
299
|
}
|
|
289
300
|
|
|
@@ -291,6 +302,7 @@ export default {
|
|
|
291
302
|
out.unshift({
|
|
292
303
|
label: this.t('selectOrCreateAuthSecret.createS3'),
|
|
293
304
|
value: AUTH_TYPE._S3,
|
|
305
|
+
kind: 'highlighted'
|
|
294
306
|
});
|
|
295
307
|
}
|
|
296
308
|
|
|
@@ -298,13 +310,7 @@ export default {
|
|
|
298
310
|
out.unshift({
|
|
299
311
|
label: this.t('selectOrCreateAuthSecret.createBasic'),
|
|
300
312
|
value: AUTH_TYPE._BASIC,
|
|
301
|
-
|
|
302
|
-
}
|
|
303
|
-
|
|
304
|
-
if ( this.allowNone ) {
|
|
305
|
-
out.unshift({
|
|
306
|
-
label: this.t('generic.none'),
|
|
307
|
-
value: AUTH_TYPE._NONE,
|
|
313
|
+
kind: 'highlighted'
|
|
308
314
|
});
|
|
309
315
|
}
|
|
310
316
|
|
|
@@ -455,9 +461,7 @@ export default {
|
|
|
455
461
|
</script>
|
|
456
462
|
|
|
457
463
|
<template>
|
|
458
|
-
<Loading v-if="$fetchState.pending" />
|
|
459
464
|
<div
|
|
460
|
-
v-else
|
|
461
465
|
class="select-or-create-auth-secret"
|
|
462
466
|
>
|
|
463
467
|
<div
|
|
@@ -469,21 +473,10 @@ export default {
|
|
|
469
473
|
v-model="selected"
|
|
470
474
|
:mode="mode"
|
|
471
475
|
:label-key="labelKey"
|
|
476
|
+
:loading="$fetchState.pending"
|
|
472
477
|
:options="options"
|
|
473
478
|
:selectable="option => !option.disabled"
|
|
474
|
-
|
|
475
|
-
<template v-slot:option="opt">
|
|
476
|
-
<template v-if="opt.kind === 'divider'">
|
|
477
|
-
<hr>
|
|
478
|
-
</template>
|
|
479
|
-
<template v-else-if="opt.kind === 'title'">
|
|
480
|
-
{{ opt.label }}
|
|
481
|
-
</template>
|
|
482
|
-
<template v-else>
|
|
483
|
-
{{ opt.label }}
|
|
484
|
-
</template>
|
|
485
|
-
</template>
|
|
486
|
-
</LabeledSelect>
|
|
479
|
+
/>
|
|
487
480
|
</div>
|
|
488
481
|
<template v-if="selected === _SSH">
|
|
489
482
|
<div :class="moreCols">
|
|
@@ -136,6 +136,10 @@ export default {
|
|
|
136
136
|
</span>
|
|
137
137
|
<span class="port">
|
|
138
138
|
<t k="servicePorts.rules.listening.label" />
|
|
139
|
+
<i
|
|
140
|
+
v-tooltip="t('servicesPage.listeningPorts')"
|
|
141
|
+
class="icon icon-info flex"
|
|
142
|
+
/>
|
|
139
143
|
<span class="text-error">*</span>
|
|
140
144
|
</span>
|
|
141
145
|
<span
|
|
@@ -146,6 +150,10 @@ export default {
|
|
|
146
150
|
</span>
|
|
147
151
|
<span class="target-port">
|
|
148
152
|
<t k="servicePorts.rules.target.label" />
|
|
153
|
+
<i
|
|
154
|
+
v-tooltip="t('servicesPage.targetPorts')"
|
|
155
|
+
class="icon icon-info flex"
|
|
156
|
+
/>
|
|
149
157
|
<span class="text-error">*</span>
|
|
150
158
|
|
|
151
159
|
</span>
|
|
@@ -8,7 +8,7 @@ import { LabeledInput } from '@components/Form/LabeledInput';
|
|
|
8
8
|
import LabeledSelect from '@shell/components/form/LabeledSelect';
|
|
9
9
|
import { HCI as HCI_LABELS_ANNOTATIONS } from '@shell/config/labels-annotations';
|
|
10
10
|
import { isHarvesterSatisfiesVersion } from '@shell/utils/cluster';
|
|
11
|
-
import { HARVESTER_NAME as HARVESTER } from '@shell/config/
|
|
11
|
+
import { HARVESTER_NAME as HARVESTER } from '@shell/config/features';
|
|
12
12
|
import { CAPI, SERVICE } from '@shell/config/types';
|
|
13
13
|
|
|
14
14
|
export default {
|
|
@@ -259,6 +259,12 @@ export default {
|
|
|
259
259
|
|
|
260
260
|
<template>
|
|
261
261
|
<div :style="{'width':'100%'}">
|
|
262
|
+
<p
|
|
263
|
+
v-if="rows.length > 0"
|
|
264
|
+
class="padded"
|
|
265
|
+
>
|
|
266
|
+
{{ t('workload.container.ports.detailedDescription') }}
|
|
267
|
+
</p>
|
|
262
268
|
<div
|
|
263
269
|
v-for="(row, idx) in rows"
|
|
264
270
|
:key="idx"
|
|
@@ -0,0 +1,74 @@
|
|
|
1
|
+
import { mount } from '@vue/test-utils';
|
|
2
|
+
import ArrayList from '@shell/components/form/ArrayList.vue';
|
|
3
|
+
import { _EDIT, _VIEW } from '@shell/config/query-params';
|
|
4
|
+
|
|
5
|
+
describe('the ArrayList', () => {
|
|
6
|
+
it('is empty', () => {
|
|
7
|
+
const wrapper = mount(ArrayList, {
|
|
8
|
+
propsData: {
|
|
9
|
+
value: [],
|
|
10
|
+
mode: _EDIT
|
|
11
|
+
},
|
|
12
|
+
});
|
|
13
|
+
const elements = wrapper.findAll('[data-testid^="array-list-box"]');
|
|
14
|
+
|
|
15
|
+
expect(elements).toHaveLength(0);
|
|
16
|
+
});
|
|
17
|
+
|
|
18
|
+
it('shows an initial empty row', () => {
|
|
19
|
+
const wrapper = mount(ArrayList, {
|
|
20
|
+
propsData: {
|
|
21
|
+
value: [],
|
|
22
|
+
mode: _EDIT,
|
|
23
|
+
initialEmptyRow: true
|
|
24
|
+
},
|
|
25
|
+
});
|
|
26
|
+
const arrayListBoxes = wrapper.findAll('[data-testid="array-list-box"]');
|
|
27
|
+
|
|
28
|
+
expect(arrayListBoxes).toHaveLength(1);
|
|
29
|
+
});
|
|
30
|
+
|
|
31
|
+
it('expands when the add button is clicked', async() => {
|
|
32
|
+
const wrapper = mount(ArrayList, {
|
|
33
|
+
propsData: {
|
|
34
|
+
value: [],
|
|
35
|
+
mode: _EDIT,
|
|
36
|
+
},
|
|
37
|
+
});
|
|
38
|
+
|
|
39
|
+
const arrayListButton = wrapper.find('[data-testid="array-list-button"]').element as HTMLElement;
|
|
40
|
+
|
|
41
|
+
await arrayListButton.click();
|
|
42
|
+
await arrayListButton.click();
|
|
43
|
+
const arrayListBoxes = wrapper.findAll('[data-testid="array-list-box"]');
|
|
44
|
+
|
|
45
|
+
expect(arrayListBoxes).toHaveLength(2);
|
|
46
|
+
});
|
|
47
|
+
|
|
48
|
+
it('contracts when a delete button is clicked', async() => {
|
|
49
|
+
const wrapper = mount(ArrayList, {
|
|
50
|
+
propsData: {
|
|
51
|
+
value: ['string 1', 'string 2'],
|
|
52
|
+
mode: _EDIT,
|
|
53
|
+
},
|
|
54
|
+
});
|
|
55
|
+
const deleteButton = wrapper.get('[data-testid^="remove-item"]').element as HTMLElement;
|
|
56
|
+
|
|
57
|
+
await deleteButton.click();
|
|
58
|
+
const arrayListBoxes = wrapper.findAll('[data-testid="array-list-box"]');
|
|
59
|
+
|
|
60
|
+
expect(arrayListBoxes).toHaveLength(1);
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('add button is hidden in read-only mode', () => {
|
|
64
|
+
const wrapper = mount(ArrayList, {
|
|
65
|
+
propsData: {
|
|
66
|
+
value: ['read-only example'],
|
|
67
|
+
mode: _VIEW,
|
|
68
|
+
},
|
|
69
|
+
});
|
|
70
|
+
const arrayListButtons = wrapper.findAll('[data-testid="array-list-button"]');
|
|
71
|
+
|
|
72
|
+
expect(arrayListButtons).toHaveLength(0);
|
|
73
|
+
});
|
|
74
|
+
});
|
|
@@ -4,7 +4,7 @@ import ArrayListGrouped from '@shell/components/form/ArrayListGrouped.vue';
|
|
|
4
4
|
describe('component: ArrayListGrouped', () => {
|
|
5
5
|
it('should display enabled add button', () => {
|
|
6
6
|
const wrapper = mount(ArrayListGrouped);
|
|
7
|
-
const button = wrapper.find('[data-testid
|
|
7
|
+
const button = wrapper.find('[data-testid="array-list-button"]').element as HTMLButtonElement;
|
|
8
8
|
|
|
9
9
|
expect(button.disabled).toBe(false);
|
|
10
10
|
});
|
|
@@ -14,7 +14,7 @@ describe('component: ArrayListGrouped', () => {
|
|
|
14
14
|
mocks: { propsData: { value: ['a', 'b'] } },
|
|
15
15
|
slots: { default: '<div id="test"/>' }
|
|
16
16
|
});
|
|
17
|
-
const button = wrapper.find('[data-testid^="
|
|
17
|
+
const button = wrapper.find('[data-testid^="array-list-button"]');
|
|
18
18
|
|
|
19
19
|
await button.trigger('click');
|
|
20
20
|
await button.trigger('click');
|
|
@@ -28,12 +28,14 @@ describe('component: ArrayListGrouped', () => {
|
|
|
28
28
|
mocks: { propsData: { value: ['a', 'b'] } },
|
|
29
29
|
slots: { default: '<div id="test"/>' }
|
|
30
30
|
});
|
|
31
|
+
const button = wrapper.find('[data-testid^="array-list-button"]');
|
|
31
32
|
|
|
32
|
-
await
|
|
33
|
+
await button.trigger('click');
|
|
34
|
+
await button.trigger('click');
|
|
33
35
|
await wrapper.find('[data-testid^="remove-item"]').trigger('click');
|
|
34
36
|
|
|
35
37
|
const elements = wrapper.findAll('#test');
|
|
36
38
|
|
|
37
|
-
expect(elements).toHaveLength(
|
|
39
|
+
expect(elements).toHaveLength(1);
|
|
38
40
|
});
|
|
39
41
|
});
|
|
@@ -62,6 +62,11 @@ export default {
|
|
|
62
62
|
{{ value }}
|
|
63
63
|
</n-link>
|
|
64
64
|
<span v-else>{{ value }}</span>
|
|
65
|
+
<i
|
|
66
|
+
v-if="row.unavailableMachines"
|
|
67
|
+
v-tooltip="row.unavailableMachines"
|
|
68
|
+
class="conditions-alert-icon icon-alert icon"
|
|
69
|
+
/>
|
|
65
70
|
<i
|
|
66
71
|
v-if="row.rkeTemplateUpgrade"
|
|
67
72
|
v-tooltip="t('cluster.rkeTemplateUpgrade', { name: row.rkeTemplateUpgrade })"
|
|
@@ -23,12 +23,12 @@ export default {
|
|
|
23
23
|
<template>
|
|
24
24
|
<span v-if="row[col.value]">
|
|
25
25
|
<span>
|
|
26
|
-
<i class="icon icon-
|
|
26
|
+
<i class="icon icon-checkmark" />
|
|
27
27
|
</span>
|
|
28
28
|
</span>
|
|
29
29
|
<span v-else>
|
|
30
30
|
<span>
|
|
31
|
-
<i class="icon icon-
|
|
31
|
+
<i class="icon icon-x" />
|
|
32
32
|
</span>
|
|
33
33
|
</span>
|
|
34
34
|
</template>
|