dashboard-shell-shell 3.0.5-test.9 → 3.0.5-tsh.2

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 (164) hide show
  1. package/assets/brand/csp/favicon.png +0 -0
  2. package/assets/icons/iconfont.css +4 -1
  3. package/assets/images/pl/dark/logo.png +0 -0
  4. package/assets/styles/all.scss +23 -3
  5. package/assets/styles/base/_variables.scss +2 -2
  6. package/assets/styles/fonts/_icons.scss +3 -2
  7. package/assets/styles/global/_button.scss +1 -1
  8. package/assets/styles/global/_form.scss +1 -0
  9. package/assets/styles/global/_select.scss +1 -1
  10. package/assets/styles/global/_tooltip.scss +5 -1
  11. package/assets/styles/themes/_light.scss +3 -3
  12. package/assets/styles/vendor/vue-select.scss +2 -1
  13. package/assets/translations/en-us.yaml +60 -0
  14. package/assets/translations/zh-hans.yaml +164 -21
  15. package/components/ButtonDropdown.vue +3 -1
  16. package/components/ClusterIconMenu.vue +1 -1
  17. package/components/CodeMirror.vue +6 -4
  18. package/components/ConsumptionGauge.vue +1 -1
  19. package/components/ContainerResourceLimit.vue +2 -2
  20. package/components/CruResource.vue +3 -2
  21. package/components/Drawer/ResourceDetailDrawer/ConfigTab.vue +22 -19
  22. package/components/Drawer/ResourceDetailDrawer/index.vue +3 -3
  23. package/components/ExplorerMembers.vue +10 -1
  24. package/components/GlobalRoleBindings.vue +52 -112
  25. package/components/PodSecurityAdmission.vue +1 -1
  26. package/components/PromptRemove.vue +23 -1
  27. package/components/RelatedResources.vue +3 -0
  28. package/components/Resource/Detail/TitleBar/composables.ts +16 -1
  29. package/components/Resource/Detail/TitleBar/index.vue +37 -24
  30. package/components/ResourceDetail/Masthead/index.vue +1 -1
  31. package/components/ResourceDetail/Masthead/latest.vue +1 -1
  32. package/components/ResourceDetail/Masthead/legacy.vue +8 -7
  33. package/components/ResourceDetail/legacy.vue +15 -15
  34. package/components/ResourceList/Masthead.vue +11 -15
  35. package/components/ResourceTable.vue +16 -0
  36. package/components/SideNav.vue +21 -21
  37. package/components/SingleClusterInfo.vue +2 -1
  38. package/components/SortableTable/THead.vue +46 -1
  39. package/components/SortableTable/index.vue +54 -18
  40. package/components/Tabbed/index.vue +6 -1
  41. package/components/auth/Principal.vue +16 -8
  42. package/components/auth/RoleDetailEdit.vue +11 -7
  43. package/components/breadcrumb/index.vue +13 -210
  44. package/components/form/ArrayList.vue +164 -147
  45. package/components/form/ArrayListGrouped.vue +5 -3
  46. package/components/form/ChangePassword.vue +1 -1
  47. package/components/form/ClusterAppearance.vue +4 -3
  48. package/components/form/Command.vue +4 -5
  49. package/components/form/Conditions.vue +15 -1
  50. package/components/form/Footer.vue +1 -0
  51. package/components/form/HealthCheck.vue +0 -2
  52. package/components/form/HookOption.vue +87 -58
  53. package/components/form/InputWithSelect.vue +8 -7
  54. package/components/form/KeyValue.vue +20 -2
  55. package/components/form/LabeledSelect.vue +3 -1
  56. package/components/form/Labels.vue +2 -2
  57. package/components/form/MatchExpressions.vue +4 -4
  58. package/components/form/Members/ClusterMembershipEditor.vue +1 -1
  59. package/components/form/Members/ClusterPermissionsEditor.vue +31 -28
  60. package/components/form/Members/MembershipEditor.vue +3 -3
  61. package/components/form/Members/ProjectMembershipEditor.vue +1 -1
  62. package/components/form/NameNsDescription.vue +4 -2
  63. package/components/form/Networking.vue +6 -9
  64. package/components/form/NodeAffinity.vue +29 -28
  65. package/components/form/PodAffinity.vue +23 -23
  66. package/components/form/Probe.vue +15 -11
  67. package/components/form/ProjectMemberEditor.vue +28 -25
  68. package/components/form/ResourceQuota/Namespace.vue +4 -4
  69. package/components/form/ResourceQuota/NamespaceRow.vue +11 -9
  70. package/components/form/ResourceQuota/Project.vue +4 -4
  71. package/components/form/ResourceQuota/ProjectRow.vue +36 -30
  72. package/components/form/ResourceSelector.vue +1 -1
  73. package/components/form/Security.vue +1 -3
  74. package/components/form/Select.vue +7 -1
  75. package/components/form/ServiceNameSelect.vue +2 -5
  76. package/components/form/ServicePorts.vue +149 -75
  77. package/components/form/Tolerations.vue +13 -9
  78. package/components/form/ValueFromResource.vue +110 -96
  79. package/components/formatter/WorkloadHealthScale.vue +4 -3
  80. package/components/nav/Group.vue +6 -0
  81. package/components/nav/Header.vue +17 -137
  82. package/components/nav/NamespaceFilter.vue +14 -19
  83. package/components/nav/TopLevelMenu.vue +99 -125
  84. package/components/nav/Type.vue +11 -3
  85. package/config/menuRouteMap.js +10 -0
  86. package/config/product/explorer.js +32 -10
  87. package/config/product/manager.js +28 -17
  88. package/config/router/navigation-guards/index.js +61 -3
  89. package/detail/node.vue +28 -23
  90. package/dialog/AddCustomBadgeDialog.vue +17 -9
  91. package/dialog/RollbackWorkloadDialog.vue +1 -1
  92. package/edit/autoscaling.horizontalpodautoscaler/external-metric.vue +1 -1
  93. package/edit/autoscaling.horizontalpodautoscaler/hpa-scaling-rule.vue +9 -6
  94. package/edit/autoscaling.horizontalpodautoscaler/index.vue +3 -1
  95. package/edit/autoscaling.horizontalpodautoscaler/metric-identifier.vue +2 -2
  96. package/edit/autoscaling.horizontalpodautoscaler/metric-object-reference.vue +7 -5
  97. package/edit/autoscaling.horizontalpodautoscaler/metric-target.vue +5 -3
  98. package/edit/autoscaling.horizontalpodautoscaler/metrics-row.vue +2 -2
  99. package/edit/autoscaling.horizontalpodautoscaler/object-metric.vue +2 -2
  100. package/edit/autoscaling.horizontalpodautoscaler/pod-metric.vue +1 -1
  101. package/edit/autoscaling.horizontalpodautoscaler/resource-metric.vue +2 -2
  102. package/edit/configmap.vue +4 -0
  103. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +32 -8
  104. package/edit/monitoring.coreos.com.alertmanagerconfig/types/dingding.vue +32 -0
  105. package/edit/monitoring.coreos.com.alertmanagerconfig/types/message.vue +52 -0
  106. package/edit/monitoring.coreos.com.alertmanagerconfig/types/snmp.vue +45 -0
  107. package/edit/monitoring.coreos.com.alertmanagerconfig/types/work.vue +31 -0
  108. package/edit/networking.k8s.io.ingress/Certificate.vue +14 -5
  109. package/edit/networking.k8s.io.ingress/DefaultBackend.vue +2 -2
  110. package/edit/networking.k8s.io.ingress/Rule.vue +5 -11
  111. package/edit/networking.k8s.io.ingress/RulePath.vue +105 -96
  112. package/edit/networking.k8s.io.networkpolicy/PolicyRule.vue +3 -3
  113. package/edit/networking.k8s.io.networkpolicy/PolicyRulePort.vue +4 -2
  114. package/edit/networking.k8s.io.networkpolicy/PolicyRuleTarget.vue +12 -11
  115. package/edit/networking.k8s.io.networkpolicy/index.vue +1 -1
  116. package/edit/persistentvolume/index.vue +3 -1
  117. package/edit/persistentvolumeclaim.vue +2 -0
  118. package/edit/provisioning.cattle.io.cluster/tabs/Basics.vue +1 -1
  119. package/edit/secret/index.vue +2 -2
  120. package/edit/service.vue +4 -1
  121. package/edit/storage.k8s.io.storageclass/index.vue +10 -8
  122. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/aws-ebs.vue +34 -27
  123. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/gce-pd.vue +15 -13
  124. package/edit/storage.k8s.io.storageclass/provisioners/kubernetes.io/vsphere-volume.vue +41 -39
  125. package/edit/workload/Job.vue +31 -34
  126. package/edit/workload/Upgrading.vue +5 -5
  127. package/edit/workload/index.vue +19 -15
  128. package/edit/workload/storage/Mount.vue +1 -0
  129. package/edit/workload/storage/awsElasticBlockStore.vue +9 -7
  130. package/edit/workload/storage/azureDisk.vue +14 -10
  131. package/edit/workload/storage/azureFile.vue +9 -7
  132. package/edit/workload/storage/csi/index.vue +6 -9
  133. package/edit/workload/storage/emptyDir.vue +7 -5
  134. package/edit/workload/storage/gcePersistentDisk.vue +9 -7
  135. package/edit/workload/storage/hostPath.vue +7 -5
  136. package/edit/workload/storage/nfs.vue +8 -6
  137. package/edit/workload/storage/persistentVolumeClaim/index.vue +12 -10
  138. package/edit/workload/storage/persistentVolumeClaim/persistentvolumeclaim.vue +20 -15
  139. package/edit/workload/storage/secret.vue +9 -6
  140. package/edit/workload/storage/vsphereVolume.vue +11 -7
  141. package/initialize/app-extended.js +7 -1
  142. package/list/management.cattle.io.podsecurityadmissionconfigurationtemplate.vue +8 -6
  143. package/mixins/create-edit-view/impl.js +10 -0
  144. package/models/provisioning.cattle.io.cluster.js +19 -18
  145. package/models/workload.js +2 -2
  146. package/package.json +1 -1
  147. package/pages/account/index.vue +93 -58
  148. package/pages/auth/login.vue +1 -1
  149. package/pages/auth/setup.vue +36 -17
  150. package/pages/c/_cluster/explorer/ConfigBadge.vue +1 -1
  151. package/pages/c/_cluster/explorer/index.vue +2 -1
  152. package/pages/c/_cluster/explorer/tools/index.vue +6 -6
  153. package/pages/home.vue +55 -13
  154. package/plugins/dashboard-store/actions.js +1 -1
  155. package/rancher-components/Banner/Banner.vue +14 -2
  156. package/rancher-components/Form/Radio/RadioGroup.vue +9 -1
  157. package/rancher-components/LabeledTooltip/LabeledTooltip.vue +31 -2
  158. package/scripts/build-pkg.sh +18 -23
  159. package/scripts/publish-shell.sh +1 -1
  160. package/store/i18n.js +1 -0
  161. package/store/type-map.js +0 -2
  162. package/utils/error.js +23 -3
  163. package/utils/errorTranslate.json +377 -8
  164. package/utils/errorTranslateNew.json +39 -0
@@ -0,0 +1,52 @@
1
+ <template>
2
+ <div>
3
+ <div class="mb-20">
4
+ <LabeledInput
5
+ v-model:value="message"
6
+ :placeholder="'请输入手机号'"
7
+ :label="'默认手机人电话'"
8
+ />
9
+ </div>
10
+ <div class="mb-20">
11
+ <LabeledInput
12
+ v-model:value="id"
13
+ :placeholder="'API密钥ID'"
14
+ :label="'默认API密钥ID'"
15
+ />
16
+ </div>
17
+ <div class="mb-20">
18
+ <LabeledInput
19
+ v-model:value="scret"
20
+ :placeholder="'API密钥secret'"
21
+ :label="'默认API密钥secret'"
22
+ />
23
+ </div>
24
+ <div class="mb-20">
25
+ <LabeledInput
26
+ v-model:value="templateId"
27
+ :placeholder="'请输入模板ID'"
28
+ :label="'模板ID'"
29
+ />
30
+ </div>
31
+ </div>
32
+ </template>
33
+ <script>
34
+ import { LabeledInput } from '@components/Form/LabeledInput';
35
+ // import { ref } from 'vue';
36
+ // const id = ref('');
37
+ // const scret = ref('');
38
+ // const message = ref('');
39
+ // const templateId = ref('');
40
+
41
+ export default {
42
+ components: { LabeledInput },
43
+ data() {
44
+ return {
45
+ message: '',
46
+ id: '',
47
+ scret: '',
48
+ templateId: ''
49
+ };
50
+ }
51
+ };
52
+ </script>
@@ -0,0 +1,45 @@
1
+ <template>
2
+ <div>
3
+ <div class="mb-20">
4
+ <LabeledInput
5
+ v-model:value="message"
6
+ :placeholder="'目标主机'"
7
+ :label="'目标主机'"
8
+ />
9
+ </div>
10
+ <div class="mb-20">
11
+ <LabeledInput
12
+ v-model:value="id"
13
+ :placeholder="'端口'"
14
+ :label="'端口'"
15
+ />
16
+ </div>
17
+ <div class="mb-20">
18
+ <LabeledInput
19
+ v-model:value="scret"
20
+ :placeholder="'团体字'"
21
+ :label="'团体字'"
22
+ />
23
+ </div>
24
+ </div>
25
+ </template>
26
+ <script>
27
+ import { LabeledInput } from '@components/Form/LabeledInput';
28
+ // import { ref } from 'vue';
29
+ // const id = ref('');
30
+ // const scret = ref('');
31
+ // const message = ref('');
32
+ // const templateId = ref('');
33
+
34
+ export default {
35
+ components: { LabeledInput },
36
+ data() {
37
+ return {
38
+ message: '',
39
+ id: '',
40
+ scret: '',
41
+ templateId: ''
42
+ };
43
+ }
44
+ };
45
+ </script>
@@ -0,0 +1,31 @@
1
+ <template>
2
+ <div>
3
+ <div class="mb-20">
4
+ <LabeledInput
5
+ v-model:value="message"
6
+ :placeholder="'webhook地址'"
7
+ :label="'webhook地址'"
8
+ />
9
+ </div>
10
+ </div>
11
+ </template>
12
+ <script>
13
+ import { LabeledInput } from '@components/Form/LabeledInput';
14
+ // import { ref } from 'vue';
15
+ // const id = ref('');
16
+ // const scret = ref('');
17
+ // const message = ref('');
18
+ // const templateId = ref('');
19
+
20
+ export default {
21
+ components: { LabeledInput },
22
+ data() {
23
+ return {
24
+ message: '',
25
+ id: '',
26
+ scret: '',
27
+ templateId: ''
28
+ };
29
+ }
30
+ };
31
+ </script>
@@ -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 class="col span-6">
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
- <div class="col span-6">
110
+ </div>
111
+ <div class="row ingressBox">
112
+ <div style="padding-left: 160px;">
111
113
  <ArrayList
112
114
  :value="hosts"
113
115
  :add-label="t('ingress.certificates.addHost')"
@@ -127,6 +129,13 @@ export default {
127
129
  position: absolute;
128
130
  }
129
131
 
132
+ .ingressBox
133
+ :deep() .box {
134
+ border: 0px solid var(--tabbed-border);
135
+ >.remove {
136
+ top: 1px;
137
+ }
138
+ }
130
139
  .cert {
131
140
  position: relative;
132
141
 
@@ -135,8 +144,8 @@ export default {
135
144
  }
136
145
 
137
146
  &:not(:last-of-type) {
138
- padding-bottom: 10px;
139
- margin-bottom: 30px;
147
+ // padding-bottom: 10px;
148
+ // margin-bottom: 30px;
140
149
  }
141
150
  }
142
151
  </style>
@@ -96,7 +96,7 @@ export default {
96
96
  v-if="serviceName || !isView"
97
97
  class="row"
98
98
  >
99
- <div class="col span-4">
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-3"
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 mb-20">
110
+ <div class="row">
111
111
  <div
112
112
  id="host"
113
- class="col span-6"
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 mb-10"
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 row">
111
- <div
112
- v-if="ingress.showPathType"
113
- class="col span-6"
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" style="width: 400px;">
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="col"
140
- :class="{'span-3': ingress.showPathType, 'span-4': !ingress.showPathType}"
141
- >
142
- <Select
143
- v-model:value="serviceName"
144
- :options="serviceTargets"
145
- :status="serviceTargetStatus"
146
- :taggable="true"
147
- :searchable="true"
148
- :tooltip="serviceTargetTooltip"
149
- :hover-tooltip="true"
150
- @update:value="servicePort = ''; queueUpdate();"
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="col"
155
- :class="{'span-2': ingress.showPathType, 'span-3': !ingress.showPathType}"
156
- :style="{'margin-right': '0px'}"
157
- >
158
- <LabeledInput
159
- v-if="portOptions.length === 0"
160
- v-model:value="servicePort"
161
- class="fullHeightInput"
162
- :placeholder="t('ingress.rules.port.placeholder')"
163
- :rules="rules.port"
164
- @update:value="queueUpdate"
165
- />
166
- <Select
167
- v-else
168
- v-model:value="servicePort"
169
- :options="portOptions"
170
- :placeholder="t('ingress.rules.port.placeholder')"
171
- :rules="rules.port"
172
- @update:value="queueUpdate"
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
- $row-height: 40px;
186
- .rule-path {
187
- :deep(.labeled-input) {
188
- padding: 0 !important;
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
- &, :deep(.input-container) {
201
- height: $row-height;
198
+ .in-input.unlabeled-select{
199
+ margin-right: -1px;
200
+ margin-bottom: 24px;
201
+ width: 400px;
202
202
  }
203
+ }
203
204
 
204
- :deep(.input-container) :deep(.in-input.unlabeled-select) {
205
- width: initial;
206
- }
205
+ .flex{
206
+ display: flex;
207
+ align-items: center;
207
208
 
208
- button {
209
- line-height: $row-height;
209
+ .label{
210
+ min-width: 160px;
210
211
  }
212
+ }
211
213
 
212
- :deep(.v-select) INPUT {
213
- height: 50px;
214
- }
215
- :deep(.labeled-input) {
216
- padding-top: 6px;
214
+ ::v-deep .path_row{
215
+ width: 800px;
216
+ .input-container{
217
+ flex-direction: column;
217
218
  }
218
219
 
219
- :deep(.unlabeled-select) {
220
- height: 100%;
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 mb-40">
44
- <div class="col span-12">
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 mb-20">
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 span-4">
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
- <div class="col span-4">
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 mb-20">
225
- <div class="col span-6">
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 span-6">
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 span-12">
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 mt-20">
260
- <div class="col span-12">
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="col span-12">
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="col span-12">
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="col span-12">
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 span-11">
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 span-11">
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="col span-12">
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>
@@ -298,7 +298,7 @@ export default {
298
298
  :label="t('persistentVolume.customize.label')"
299
299
  :weight="0"
300
300
  >
301
- <div class="row mb-20">
301
+ <div class="row">
302
302
  <div class="col span-6">
303
303
  <h3>{{ t('persistentVolume.customize.accessModes.label') }}</h3>
304
304
  <div>
@@ -323,6 +323,8 @@ export default {
323
323
  />
324
324
  </div>
325
325
  </div>
326
+ </div>
327
+ <div class="row">
326
328
  <div class="col span-6">
327
329
  <ArrayList
328
330
  v-model:value="value.spec.mountOptions"
@@ -257,6 +257,8 @@ export default {
257
257
  @update:value="updateDefaults"
258
258
  />
259
259
  </div>
260
+ </div>
261
+ <div class="row">
260
262
  <div class="col span-6">
261
263
  <div class="row">
262
264
  <div
@@ -704,6 +704,6 @@ export default {
704
704
 
705
705
  <style lang="scss" scoped>
706
706
  .patch-version {
707
- margin-top: 5px;
707
+ margin-top: 10px;
708
708
  }
709
709
  </style>
@@ -444,7 +444,7 @@ export default {
444
444
  v-if="isCustomSecretCreate"
445
445
  class="row"
446
446
  >
447
- <div class="col span-3">
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-3">
461
+ <div class="col span-6">
462
462
  <LabeledInput
463
463
  v-if="showCustomSecretType"
464
464
  ref="customType"