dashboard-shell-shell 3.0.5-test.13 → 3.0.5-test.16
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/_select.scss +1 -1
- package/assets/translations/zh-hans.yaml +4 -3
- package/components/Drawer/ResourceDetailDrawer/index.vue +2 -2
- package/components/ExplorerMembers.vue +10 -1
- package/components/SortableTable/index.vue +2 -2
- package/components/Tabbed/index.vue +5 -1
- package/components/auth/Principal.vue +1 -0
- package/components/form/ArrayList.vue +162 -146
- package/components/form/Command.vue +4 -5
- package/components/form/Footer.vue +1 -0
- package/components/form/HealthCheck.vue +0 -2
- package/components/form/HookOption.vue +83 -58
- package/components/form/InputWithSelect.vue +8 -7
- package/components/form/KeyValue.vue +1 -0
- package/components/form/MatchExpressions.vue +1 -2
- package/components/form/Networking.vue +0 -1
- package/components/form/NodeAffinity.vue +29 -28
- package/components/form/PodAffinity.vue +19 -21
- package/components/form/Probe.vue +15 -11
- package/components/form/ResourceSelector.vue +1 -1
- package/components/form/ServiceNameSelect.vue +1 -3
- package/components/form/ServicePorts.vue +149 -75
- package/components/form/Tolerations.vue +12 -9
- package/components/form/ValueFromResource.vue +110 -96
- package/components/nav/TopLevelMenu.vue +3 -2
- package/components/nav/Type.vue +1 -1
- package/edit/autoscaling.horizontalpodautoscaler/external-metric.vue +1 -1
- package/edit/autoscaling.horizontalpodautoscaler/index.vue +3 -1
- package/edit/autoscaling.horizontalpodautoscaler/metric-identifier.vue +2 -2
- package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +7 -5
- package/edit/autoscaling.horizontalpodautoscaler/metric-target.vue +5 -3
- package/edit/autoscaling.horizontalpodautoscaler/metrics-row.vue +2 -2
- package/edit/autoscaling.horizontalpodautoscaler/object-metric.vue +2 -2
- package/edit/autoscaling.horizontalpodautoscaler/pod-metric.vue +1 -1
- package/edit/autoscaling.horizontalpodautoscaler/resource-metric.vue +2 -2
- package/edit/networking.k8s.io.ingress/Certificate.vue +7 -5
- package/edit/networking.k8s.io.ingress/DefaultBackend.vue +2 -2
- package/edit/networking.k8s.io.ingress/Rule.vue +5 -11
- package/edit/networking.k8s.io.ingress/RulePath.vue +105 -96
- package/edit/networking.k8s.io.networkpolicy/PolicyRule.vue +3 -3
- package/edit/networking.k8s.io.networkpolicy/PolicyRulePort.vue +4 -2
- package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +12 -11
- package/edit/networking.k8s.io.networkpolicy/index.vue +1 -1
- package/edit/secret/index.vue +2 -2
- package/edit/service.vue +4 -1
- package/edit/storage.k8s.io.storageclass/index.vue +10 -8
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/aws-ebs.vue +34 -27
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/gce-pd.vue +15 -13
- package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/vsphere-volume.vue +41 -39
- package/edit/workload/Job.vue +27 -29
- package/edit/workload/Upgrading.vue +3 -3
- package/edit/workload/index.vue +2 -2
- package/edit/workload/storage/Mount.vue +1 -0
- package/edit/workload/storage/awsElasticBlockStore.vue +9 -7
- package/edit/workload/storage/azureDisk.vue +14 -10
- package/edit/workload/storage/azureFile.vue +9 -7
- package/edit/workload/storage/csi/index.vue +6 -9
- package/edit/workload/storage/emptyDir.vue +7 -5
- package/edit/workload/storage/gcePersistentDisk.vue +9 -7
- package/edit/workload/storage/hostPath.vue +7 -5
- package/edit/workload/storage/nfs.vue +8 -6
- package/edit/workload/storage/persistentVolumeClaim/index.vue +12 -10
- package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +18 -15
- package/edit/workload/storage/secret.vue +9 -6
- package/edit/workload/storage/vsphereVolume.vue +11 -7
- package/package.json +1 -1
- package/pages/account/index.vue +10 -0
- package/rancher-components/LabeledTooltip/LabeledTooltip.vue +31 -2
- package/scripts/publish-shell.sh +1 -1
- package/store/i18n.js +1 -0
|
@@ -21,9 +21,9 @@ export default {
|
|
|
21
21
|
</script>
|
|
22
22
|
|
|
23
23
|
<template>
|
|
24
|
-
<div class="
|
|
25
|
-
<div class="row
|
|
26
|
-
<div class="col
|
|
24
|
+
<div class="span-12">
|
|
25
|
+
<div class="row">
|
|
26
|
+
<div class="col">
|
|
27
27
|
<LabeledInput
|
|
28
28
|
v-model:value="value.apiVersion"
|
|
29
29
|
:mode="mode"
|
|
@@ -33,7 +33,9 @@ export default {
|
|
|
33
33
|
type="text"
|
|
34
34
|
/>
|
|
35
35
|
</div>
|
|
36
|
-
|
|
36
|
+
</div>
|
|
37
|
+
<div class="row">
|
|
38
|
+
<div class="col">
|
|
37
39
|
<LabeledInput
|
|
38
40
|
v-model:value="value.kind"
|
|
39
41
|
:mode="mode"
|
|
@@ -45,7 +47,7 @@ export default {
|
|
|
45
47
|
</div>
|
|
46
48
|
</div>
|
|
47
49
|
<div class="row">
|
|
48
|
-
<div class="col
|
|
50
|
+
<div class="col">
|
|
49
51
|
<LabeledInput
|
|
50
52
|
v-model:value="value.name"
|
|
51
53
|
:mode="mode"
|
|
@@ -149,7 +149,7 @@ export default {
|
|
|
149
149
|
<template>
|
|
150
150
|
<div class="metric-target">
|
|
151
151
|
<div class="row">
|
|
152
|
-
<div class="col
|
|
152
|
+
<div class="col">
|
|
153
153
|
<LabeledSelect
|
|
154
154
|
v-model:value="value.type"
|
|
155
155
|
:mode="mode"
|
|
@@ -157,9 +157,11 @@ export default {
|
|
|
157
157
|
:options="targetTypes"
|
|
158
158
|
/>
|
|
159
159
|
</div>
|
|
160
|
+
</div>
|
|
161
|
+
<div class="row">
|
|
160
162
|
<div
|
|
161
163
|
v-if="isResourceMetricType"
|
|
162
|
-
class="col
|
|
164
|
+
class="col"
|
|
163
165
|
>
|
|
164
166
|
<UnitInput
|
|
165
167
|
v-if="value.type === 'Utilization'"
|
|
@@ -197,7 +199,7 @@ export default {
|
|
|
197
199
|
</div>
|
|
198
200
|
<div
|
|
199
201
|
v-else
|
|
200
|
-
class="col
|
|
202
|
+
class="col"
|
|
201
203
|
>
|
|
202
204
|
<LabeledInput
|
|
203
205
|
v-model:value="quantity"
|
|
@@ -159,8 +159,8 @@ export default {
|
|
|
159
159
|
:label="t('hpa.warnings.resource')"
|
|
160
160
|
color="warning"
|
|
161
161
|
/>
|
|
162
|
-
<div class="row
|
|
163
|
-
<div class="col
|
|
162
|
+
<div class="row">
|
|
163
|
+
<div class="col">
|
|
164
164
|
<LabeledSelect
|
|
165
165
|
v-model:value="value.type"
|
|
166
166
|
:reduce="(val) => val.label"
|
|
@@ -48,14 +48,14 @@ export default {
|
|
|
48
48
|
|
|
49
49
|
<template>
|
|
50
50
|
<div>
|
|
51
|
-
<div class="row
|
|
51
|
+
<div class="row">
|
|
52
52
|
<MetricTarget
|
|
53
53
|
v-model:value="value.target"
|
|
54
54
|
:mode="mode"
|
|
55
55
|
metric-resource="object"
|
|
56
56
|
/>
|
|
57
57
|
</div>
|
|
58
|
-
<div class="row
|
|
58
|
+
<div class="row">
|
|
59
59
|
<MetricObjectReference
|
|
60
60
|
v-model:value="value.describedObject"
|
|
61
61
|
:mode="mode"
|
|
@@ -89,10 +89,10 @@ export default {
|
|
|
89
89
|
|
|
90
90
|
<template>
|
|
91
91
|
<div
|
|
92
|
-
class="cert row"
|
|
92
|
+
class="cert row mb-10"
|
|
93
93
|
@update:value="update"
|
|
94
94
|
>
|
|
95
|
-
<div
|
|
95
|
+
<div>
|
|
96
96
|
<LabeledSelect
|
|
97
97
|
v-model:value="secretVal"
|
|
98
98
|
class="secret-name"
|
|
@@ -107,7 +107,9 @@ export default {
|
|
|
107
107
|
@update:value="onSecretInput"
|
|
108
108
|
/>
|
|
109
109
|
</div>
|
|
110
|
-
|
|
110
|
+
</div>
|
|
111
|
+
<div class="row">
|
|
112
|
+
<div style="padding-left: 160px;">
|
|
111
113
|
<ArrayList
|
|
112
114
|
:value="hosts"
|
|
113
115
|
:add-label="t('ingress.certificates.addHost')"
|
|
@@ -135,8 +137,8 @@ export default {
|
|
|
135
137
|
}
|
|
136
138
|
|
|
137
139
|
&:not(:last-of-type) {
|
|
138
|
-
padding-bottom: 10px;
|
|
139
|
-
margin-bottom: 30px;
|
|
140
|
+
// padding-bottom: 10px;
|
|
141
|
+
// margin-bottom: 30px;
|
|
140
142
|
}
|
|
141
143
|
}
|
|
142
144
|
</style>
|
|
@@ -96,7 +96,7 @@ export default {
|
|
|
96
96
|
v-if="serviceName || !isView"
|
|
97
97
|
class="row"
|
|
98
98
|
>
|
|
99
|
-
<div class="col span-
|
|
99
|
+
<div class="col span-6">
|
|
100
100
|
<LabeledSelect
|
|
101
101
|
v-model:value="serviceName"
|
|
102
102
|
:taggable="true"
|
|
@@ -111,7 +111,7 @@ export default {
|
|
|
111
111
|
/>
|
|
112
112
|
</div>
|
|
113
113
|
<div
|
|
114
|
-
class="col span-
|
|
114
|
+
class="col span-6"
|
|
115
115
|
:style="{'margin-right': '0px'}"
|
|
116
116
|
>
|
|
117
117
|
<LabeledInput
|
|
@@ -107,10 +107,10 @@ export default {
|
|
|
107
107
|
|
|
108
108
|
<template>
|
|
109
109
|
<div class="rule">
|
|
110
|
-
<div class="row
|
|
110
|
+
<div class="row">
|
|
111
111
|
<div
|
|
112
112
|
id="host"
|
|
113
|
-
class="col
|
|
113
|
+
class="col"
|
|
114
114
|
>
|
|
115
115
|
<LabeledInput
|
|
116
116
|
ref="host"
|
|
@@ -121,12 +121,8 @@ export default {
|
|
|
121
121
|
@update:value="update"
|
|
122
122
|
/>
|
|
123
123
|
</div>
|
|
124
|
-
<div
|
|
125
|
-
id="spacer"
|
|
126
|
-
class="col span-5"
|
|
127
|
-
/>
|
|
128
124
|
</div>
|
|
129
|
-
<div class="rule-path-headings row">
|
|
125
|
+
<!-- <div class="rule-path-headings row">
|
|
130
126
|
<div
|
|
131
127
|
class="col"
|
|
132
128
|
:class="{'span-6': ingress.showPathType, 'span-4': !ingress.showPathType}"
|
|
@@ -134,20 +130,18 @@ export default {
|
|
|
134
130
|
<label>{{ t("ingress.rules.path.label") }}</label>
|
|
135
131
|
</div>
|
|
136
132
|
<div
|
|
137
|
-
class="col"
|
|
138
133
|
:class="{'span-3': ingress.showPathType, 'span-4': !ingress.showPathType}"
|
|
139
134
|
>
|
|
140
135
|
<label>{{ t("ingress.rules.target.label") }}</label>
|
|
141
136
|
</div>
|
|
142
137
|
<div
|
|
143
|
-
class="col"
|
|
144
138
|
:class="{'span-2': ingress.showPathType, 'span-3': !ingress.showPathType}"
|
|
145
139
|
:style="{ 'margin-right': '0px' }"
|
|
146
140
|
>
|
|
147
141
|
<label>{{ t("ingress.rules.port.label") }}</label>
|
|
148
142
|
</div>
|
|
149
143
|
<div class="col" />
|
|
150
|
-
</div>
|
|
144
|
+
</div> -->
|
|
151
145
|
<template
|
|
152
146
|
v-for="(path, i) in paths"
|
|
153
147
|
:key="path.id"
|
|
@@ -155,7 +149,7 @@ export default {
|
|
|
155
149
|
<RulePath
|
|
156
150
|
ref="paths"
|
|
157
151
|
v-model:value="paths[i]"
|
|
158
|
-
class="row
|
|
152
|
+
class="row"
|
|
159
153
|
:rule-mode="ruleMode"
|
|
160
154
|
:service-targets="serviceTargets"
|
|
161
155
|
:ingress="ingress"
|
|
@@ -107,118 +107,127 @@ export default {
|
|
|
107
107
|
};
|
|
108
108
|
</script>
|
|
109
109
|
<template>
|
|
110
|
-
<div class="rule-path
|
|
111
|
-
<div
|
|
112
|
-
|
|
113
|
-
|
|
114
|
-
|
|
115
|
-
<InputWithSelect
|
|
116
|
-
ref="first"
|
|
117
|
-
class="path-type"
|
|
118
|
-
:options="pathTypes"
|
|
119
|
-
:placeholder="t('ingress.rules.path.placeholder', undefined, true)"
|
|
120
|
-
:select-value="value.pathType"
|
|
121
|
-
:text-value="value.path"
|
|
122
|
-
:searchable="false"
|
|
123
|
-
:text-rules="rules.path"
|
|
124
|
-
@update:value="queueUpdatePathTypeAndPath"
|
|
125
|
-
/>
|
|
126
|
-
</div>
|
|
127
|
-
<div
|
|
128
|
-
v-else
|
|
129
|
-
class="col span-4"
|
|
130
|
-
>
|
|
131
|
-
<input
|
|
132
|
-
ref="first"
|
|
133
|
-
v-model="path"
|
|
134
|
-
:placeholder="t('ingress.rules.path.placeholder', undefined, true)"
|
|
135
|
-
@input="queueUpdate"
|
|
110
|
+
<div class="rule-path" style="display: block;">
|
|
111
|
+
<div class="row">
|
|
112
|
+
<button
|
|
113
|
+
class="btn btn-sm role-link remove"
|
|
114
|
+
@click="remove"
|
|
136
115
|
>
|
|
116
|
+
{{ t('ingress.rules.removePath') }}
|
|
117
|
+
</button>
|
|
118
|
+
</div>
|
|
119
|
+
<div class="flex col">
|
|
120
|
+
<div class="label">{{ t("ingress.rules.target.label") }}</div>
|
|
121
|
+
<div class="service">
|
|
122
|
+
<Select
|
|
123
|
+
v-model:value="serviceName"
|
|
124
|
+
:options="serviceTargets"
|
|
125
|
+
:status="serviceTargetStatus"
|
|
126
|
+
:taggable="true"
|
|
127
|
+
:searchable="true"
|
|
128
|
+
:tooltip="serviceTargetTooltip"
|
|
129
|
+
:hover-tooltip="true"
|
|
130
|
+
@update:value="servicePort = ''; queueUpdate();"
|
|
131
|
+
/>
|
|
132
|
+
</div>
|
|
137
133
|
</div>
|
|
138
|
-
<div
|
|
139
|
-
class="
|
|
140
|
-
|
|
141
|
-
|
|
142
|
-
|
|
143
|
-
|
|
144
|
-
|
|
145
|
-
|
|
146
|
-
|
|
147
|
-
|
|
148
|
-
|
|
149
|
-
|
|
150
|
-
|
|
151
|
-
|
|
134
|
+
<div class="flex col">
|
|
135
|
+
<div class="label">{{ t("ingress.rules.port.label") }}</div>
|
|
136
|
+
<div>
|
|
137
|
+
<LabeledInput
|
|
138
|
+
v-if="portOptions.length === 0"
|
|
139
|
+
v-model:value="servicePort"
|
|
140
|
+
class="fullHeightInput"
|
|
141
|
+
:placeholder="t('ingress.rules.port.placeholder')"
|
|
142
|
+
:rules="rules.port"
|
|
143
|
+
@update:value="queueUpdate"
|
|
144
|
+
/>
|
|
145
|
+
<Select
|
|
146
|
+
v-else
|
|
147
|
+
v-model:value="servicePort"
|
|
148
|
+
:options="portOptions"
|
|
149
|
+
:placeholder="t('ingress.rules.port.placeholder')"
|
|
150
|
+
:rules="rules.port"
|
|
151
|
+
@update:value="queueUpdate"
|
|
152
|
+
/>
|
|
153
|
+
</div>
|
|
152
154
|
</div>
|
|
153
|
-
<div
|
|
154
|
-
class="
|
|
155
|
-
|
|
156
|
-
|
|
157
|
-
|
|
158
|
-
|
|
159
|
-
|
|
160
|
-
|
|
161
|
-
|
|
162
|
-
|
|
163
|
-
|
|
164
|
-
|
|
165
|
-
|
|
166
|
-
|
|
167
|
-
|
|
168
|
-
|
|
169
|
-
|
|
170
|
-
|
|
171
|
-
|
|
172
|
-
|
|
173
|
-
|
|
155
|
+
<div class="flex" :style="{marginBottom: !ingress.showPathType ? '24px': '' }">
|
|
156
|
+
<div class="label">
|
|
157
|
+
<div style="padding-bottom: 43px;" v-if="ingress.showPathType">
|
|
158
|
+
匹配模式
|
|
159
|
+
</div>
|
|
160
|
+
<div :style="{paddingBottom: ingress.showPathType ? '15px' : ''}">
|
|
161
|
+
{{ t("ingress.rules.path.label") }}
|
|
162
|
+
</div>
|
|
163
|
+
</div>
|
|
164
|
+
<div
|
|
165
|
+
v-if="ingress.showPathType"
|
|
166
|
+
class="path_row"
|
|
167
|
+
>
|
|
168
|
+
<InputWithSelect
|
|
169
|
+
ref="first"
|
|
170
|
+
class="path-type"
|
|
171
|
+
:options="pathTypes"
|
|
172
|
+
:placeholder="t('ingress.rules.path.placeholder', undefined, true)"
|
|
173
|
+
:select-value="value.pathType"
|
|
174
|
+
:text-value="value.path"
|
|
175
|
+
:searchable="false"
|
|
176
|
+
:text-rules="rules.path"
|
|
177
|
+
@update:value="queueUpdatePathTypeAndPath"
|
|
178
|
+
/>
|
|
179
|
+
</div>
|
|
180
|
+
<div v-else class="path_row2">
|
|
181
|
+
<input
|
|
182
|
+
ref="first"
|
|
183
|
+
v-model="path"
|
|
184
|
+
:placeholder="t('ingress.rules.path.placeholder', undefined, true)"
|
|
185
|
+
@input="queueUpdate"
|
|
186
|
+
>
|
|
187
|
+
</div>
|
|
174
188
|
</div>
|
|
175
|
-
<button
|
|
176
|
-
class="btn btn-sm role-link col"
|
|
177
|
-
@click="remove"
|
|
178
|
-
>
|
|
179
|
-
{{ t('ingress.rules.removePath') }}
|
|
180
|
-
</button>
|
|
181
189
|
</div>
|
|
182
190
|
</template>
|
|
183
191
|
<style lang="scss" scoped>
|
|
184
192
|
// TODO #11952: Correct deep statement
|
|
185
|
-
|
|
186
|
-
|
|
187
|
-
|
|
188
|
-
|
|
189
|
-
height: 100%;
|
|
190
|
-
|
|
191
|
-
input.no-label {
|
|
192
|
-
height: calc($row-height - 2px);
|
|
193
|
-
padding: 10px;
|
|
194
|
-
}
|
|
195
|
-
}
|
|
196
|
-
|
|
197
|
-
:deep(.col), INPUT {
|
|
198
|
-
height: $row-height;
|
|
193
|
+
::v-deep .input-container{
|
|
194
|
+
display: flex !important;
|
|
195
|
+
.unlabeled-select{
|
|
196
|
+
height: 34px !important;
|
|
199
197
|
}
|
|
200
|
-
|
|
201
|
-
|
|
198
|
+
.in-input.unlabeled-select{
|
|
199
|
+
margin-right: -1px;
|
|
200
|
+
margin-bottom: 24px;
|
|
201
|
+
width: 400px;
|
|
202
202
|
}
|
|
203
|
+
}
|
|
203
204
|
|
|
204
|
-
|
|
205
|
-
|
|
206
|
-
|
|
205
|
+
.flex{
|
|
206
|
+
display: flex;
|
|
207
|
+
align-items: center;
|
|
207
208
|
|
|
208
|
-
|
|
209
|
-
|
|
209
|
+
.label{
|
|
210
|
+
min-width: 160px;
|
|
210
211
|
}
|
|
212
|
+
}
|
|
211
213
|
|
|
212
|
-
|
|
213
|
-
|
|
214
|
-
|
|
215
|
-
|
|
216
|
-
padding-top: 6px;
|
|
214
|
+
::v-deep .path_row{
|
|
215
|
+
width: 800px;
|
|
216
|
+
.input-container{
|
|
217
|
+
flex-direction: column;
|
|
217
218
|
}
|
|
218
219
|
|
|
219
|
-
|
|
220
|
-
|
|
221
|
-
min-width: 200px;
|
|
220
|
+
.labeled-container{
|
|
221
|
+
width: 0px !important;
|
|
222
222
|
}
|
|
223
223
|
}
|
|
224
|
+
|
|
225
|
+
.path_row2{
|
|
226
|
+
width: 400px;
|
|
227
|
+
}
|
|
228
|
+
|
|
229
|
+
.remove{
|
|
230
|
+
padding: 0px;
|
|
231
|
+
min-width: auto;
|
|
232
|
+
}
|
|
224
233
|
</style>
|
|
@@ -40,8 +40,8 @@ export default {
|
|
|
40
40
|
|
|
41
41
|
<template>
|
|
42
42
|
<div class="rule">
|
|
43
|
-
<div class="row
|
|
44
|
-
<div class="
|
|
43
|
+
<div class="row">
|
|
44
|
+
<div class="span-12">
|
|
45
45
|
<h2>
|
|
46
46
|
{{ t(`networkpolicy.${type}.ruleLabel`) }}
|
|
47
47
|
<i
|
|
@@ -68,7 +68,7 @@ export default {
|
|
|
68
68
|
</ArrayListGrouped>
|
|
69
69
|
</div>
|
|
70
70
|
</div>
|
|
71
|
-
<div class="row
|
|
71
|
+
<div class="row">
|
|
72
72
|
<div class="col span-12">
|
|
73
73
|
<h2>
|
|
74
74
|
{{ t('networkpolicy.rules.ports.label') }}
|
|
@@ -26,7 +26,7 @@ export default {
|
|
|
26
26
|
|
|
27
27
|
<template>
|
|
28
28
|
<div class="row">
|
|
29
|
-
<div class="col
|
|
29
|
+
<div class="col">
|
|
30
30
|
<LabeledInput
|
|
31
31
|
v-model:value.number="value.port"
|
|
32
32
|
:mode="mode"
|
|
@@ -37,7 +37,9 @@ export default {
|
|
|
37
37
|
:label="t('networkpolicy.rules.ports.port.label')"
|
|
38
38
|
/>
|
|
39
39
|
</div>
|
|
40
|
-
|
|
40
|
+
</div>
|
|
41
|
+
<div class="row">
|
|
42
|
+
<div class="col">
|
|
41
43
|
<LabeledSelect
|
|
42
44
|
v-model:value="value.protocol"
|
|
43
45
|
:mode="mode"
|
|
@@ -221,8 +221,8 @@ export default {
|
|
|
221
221
|
|
|
222
222
|
<template>
|
|
223
223
|
<div class="rule">
|
|
224
|
-
<div class="row
|
|
225
|
-
<div class="col
|
|
224
|
+
<div class="row">
|
|
225
|
+
<div class="col">
|
|
226
226
|
<LabeledSelect
|
|
227
227
|
v-model:value="targetType"
|
|
228
228
|
data-testid="policy-rule-target-type-labeled-select"
|
|
@@ -236,7 +236,7 @@ export default {
|
|
|
236
236
|
</div>
|
|
237
237
|
<div v-if="targetType === TARGET_OPTIONS.IP_BLOCK">
|
|
238
238
|
<div class="row">
|
|
239
|
-
<div class="col
|
|
239
|
+
<div class="col">
|
|
240
240
|
<LabeledInput
|
|
241
241
|
v-model:value="value[TARGET_OPTIONS.IP_BLOCK].cidr"
|
|
242
242
|
data-testid="labeled-input-ip-block-selector"
|
|
@@ -250,14 +250,15 @@ export default {
|
|
|
250
250
|
v-if="invalidCidr"
|
|
251
251
|
class="row"
|
|
252
252
|
>
|
|
253
|
-
<div class="col
|
|
253
|
+
<div class="col">
|
|
254
254
|
<Banner color="error">
|
|
255
255
|
<t k="networkpolicy.rules.ipBlock.invalidCidr" />
|
|
256
256
|
</Banner>
|
|
257
257
|
</div>
|
|
258
258
|
</div>
|
|
259
|
-
<div class="row
|
|
260
|
-
<div class="col
|
|
259
|
+
<div class="row">
|
|
260
|
+
<div class="col" style="display: flex;">
|
|
261
|
+
<div style="min-width: 160px;"></div>
|
|
261
262
|
<ArrayList
|
|
262
263
|
v-model:value="value[TARGET_OPTIONS.IP_BLOCK].except"
|
|
263
264
|
:add-label="t('networkpolicy.rules.ipBlock.addExcept')"
|
|
@@ -281,7 +282,7 @@ export default {
|
|
|
281
282
|
</div>
|
|
282
283
|
<div v-if="targetType === TARGET_OPTIONS.POD_SELECTOR">
|
|
283
284
|
<div class="row">
|
|
284
|
-
<div class="
|
|
285
|
+
<div class="span-12">
|
|
285
286
|
<Banner color="success">
|
|
286
287
|
<span v-clean-html="t('networkpolicy.selectors.matchingPods.matchesSome', matchingPods)" />
|
|
287
288
|
</Banner>
|
|
@@ -302,7 +303,7 @@ export default {
|
|
|
302
303
|
</div>
|
|
303
304
|
<div v-if="targetType === TARGET_OPTIONS.NAMESPACE_SELECTOR">
|
|
304
305
|
<div class="row">
|
|
305
|
-
<div class="
|
|
306
|
+
<div class="span-12">
|
|
306
307
|
<Banner color="success">
|
|
307
308
|
<span
|
|
308
309
|
v-clean-html="t('networkpolicy.selectors.matchingNamespaces.matchesSome', matchingNamespaces)"
|
|
@@ -326,7 +327,7 @@ export default {
|
|
|
326
327
|
</div>
|
|
327
328
|
<div v-if="targetType === TARGET_OPTIONS.NAMESPACE_AND_POD_SELECTOR">
|
|
328
329
|
<div class="row">
|
|
329
|
-
<div class="
|
|
330
|
+
<div class="span-12">
|
|
330
331
|
<Banner color="success">
|
|
331
332
|
<span
|
|
332
333
|
v-if="!namespaceSelectorExpressions.length"
|
|
@@ -345,7 +346,7 @@ export default {
|
|
|
345
346
|
{{ t('networkpolicy.rules.namespace') }}
|
|
346
347
|
</span>
|
|
347
348
|
</div>
|
|
348
|
-
<div class="col
|
|
349
|
+
<div class="col">
|
|
349
350
|
<MatchExpressions
|
|
350
351
|
v-model:value="namespaceSelectorExpressions"
|
|
351
352
|
data-testid="match-expression-namespace-and-pod-selector-ns-rule"
|
|
@@ -364,7 +365,7 @@ export default {
|
|
|
364
365
|
{{ t('networkpolicy.rules.pod') }}
|
|
365
366
|
</span>
|
|
366
367
|
</div>
|
|
367
|
-
<div class="col
|
|
368
|
+
<div class="col">
|
|
368
369
|
<MatchExpressions
|
|
369
370
|
v-model:value="podSelectorExpressions"
|
|
370
371
|
data-testid="match-expression-namespace-and-pod-selector-pod-rule"
|
|
@@ -252,7 +252,7 @@ export default {
|
|
|
252
252
|
</div>
|
|
253
253
|
</div>
|
|
254
254
|
<div class="row">
|
|
255
|
-
<div class="
|
|
255
|
+
<div class="span-12">
|
|
256
256
|
<Banner color="success">
|
|
257
257
|
<span v-clean-html="t('networkpolicy.selectors.matchingPods.matchesSome', matchingPods)" />
|
|
258
258
|
</Banner>
|
package/edit/secret/index.vue
CHANGED
|
@@ -444,7 +444,7 @@ export default {
|
|
|
444
444
|
v-if="isCustomSecretCreate"
|
|
445
445
|
class="row"
|
|
446
446
|
>
|
|
447
|
-
<div class="col span-
|
|
447
|
+
<div class="col span-6">
|
|
448
448
|
<LabeledSelect
|
|
449
449
|
v-model:value="secretType"
|
|
450
450
|
:options="secretTypes"
|
|
@@ -458,7 +458,7 @@ export default {
|
|
|
458
458
|
/>
|
|
459
459
|
</div>
|
|
460
460
|
|
|
461
|
-
<div class="col span-
|
|
461
|
+
<div class="col span-6">
|
|
462
462
|
<LabeledInput
|
|
463
463
|
v-if="showCustomSecretType"
|
|
464
464
|
ref="customType"
|
package/edit/service.vue
CHANGED
|
@@ -420,7 +420,7 @@ export default {
|
|
|
420
420
|
>
|
|
421
421
|
<div
|
|
422
422
|
v-if="hasClusterIp"
|
|
423
|
-
class="row
|
|
423
|
+
class="row"
|
|
424
424
|
>
|
|
425
425
|
<div class="col span-6">
|
|
426
426
|
<LabeledInput
|
|
@@ -485,6 +485,7 @@ export default {
|
|
|
485
485
|
:tooltip="t('servicesPage.affinity.helpText')"
|
|
486
486
|
>
|
|
487
487
|
<div class="row session-affinity">
|
|
488
|
+
<div style="min-width: 160px;padding-top: 3px;">会话保持</div>
|
|
488
489
|
<div class="col span-6">
|
|
489
490
|
<RadioGroup
|
|
490
491
|
v-model:value="value.spec.sessionAffinity"
|
|
@@ -495,6 +496,8 @@ export default {
|
|
|
495
496
|
:mode="mode"
|
|
496
497
|
/>
|
|
497
498
|
</div>
|
|
499
|
+
</div>
|
|
500
|
+
<div class="row">
|
|
498
501
|
<div
|
|
499
502
|
v-if="showAffinityTimeout"
|
|
500
503
|
class="col span-6"
|