@rancher/shell 3.0.8-rc.8 → 3.0.8

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 (260) hide show
  1. package/apis/impl/apis.ts +61 -0
  2. package/apis/index.ts +40 -0
  3. package/apis/intf/modal.ts +90 -0
  4. package/apis/intf/shell.ts +36 -0
  5. package/apis/intf/slide-in.ts +98 -0
  6. package/apis/intf/system.ts +41 -0
  7. package/apis/shell/__tests__/modal.test.ts +80 -0
  8. package/apis/shell/__tests__/notifications.test.ts +71 -0
  9. package/apis/shell/__tests__/slide-in.test.ts +54 -0
  10. package/apis/shell/__tests__/system.test.ts +129 -0
  11. package/apis/shell/index.ts +38 -0
  12. package/apis/shell/modal.ts +41 -0
  13. package/apis/shell/notifications.ts +65 -0
  14. package/apis/shell/slide-in.ts +33 -0
  15. package/apis/shell/system.ts +65 -0
  16. package/apis/vue-shim.d.ts +11 -0
  17. package/assets/brand/suse/dark/rancher-logo.svg +1 -64
  18. package/assets/styles/global/_tooltip.scss +6 -1
  19. package/assets/translations/en-us.yaml +14 -1
  20. package/components/ActionMenuShell.vue +3 -1
  21. package/components/BackLink.vue +8 -0
  22. package/components/BannerGraphic.vue +1 -5
  23. package/components/BrandImage.vue +17 -6
  24. package/components/Cron/CronExpressionEditor.vue +1 -1
  25. package/components/Cron/CronExpressionEditorModal.vue +1 -1
  26. package/components/CruResource.vue +8 -1
  27. package/components/Drawer/ResourceDetailDrawer/ConfigTab.vue +1 -0
  28. package/components/Drawer/ResourceDetailDrawer/__tests__/composables.test.ts +50 -1
  29. package/components/Drawer/ResourceDetailDrawer/composables.ts +19 -0
  30. package/components/Drawer/ResourceDetailDrawer/index.vue +4 -1
  31. package/components/Drawer/ResourceDetailDrawer/types.ts +2 -1
  32. package/components/LocaleSelector.vue +2 -2
  33. package/components/ModalManager.vue +11 -1
  34. package/components/Questions/__tests__/Yaml.test.ts +1 -1
  35. package/components/Questions/__tests__/index.test.ts +159 -0
  36. package/components/RelatedResources.vue +5 -0
  37. package/components/Resource/Detail/Metadata/Annotations/index.vue +2 -2
  38. package/components/Resource/Detail/Metadata/Labels/index.vue +2 -2
  39. package/components/Resource/Detail/Metadata/index.vue +3 -3
  40. package/components/Resource/Detail/ResourcePopover/index.vue +5 -1
  41. package/components/Resource/Detail/composables.ts +2 -2
  42. package/components/ResourceDetail/Masthead/latest.vue +23 -21
  43. package/components/ResourceDetail/index.vue +3 -0
  44. package/components/ResourceTable.vue +54 -21
  45. package/components/SlideInPanelManager.vue +16 -11
  46. package/components/SortableTable/THead.vue +2 -1
  47. package/components/SortableTable/index.vue +20 -2
  48. package/components/Tabbed/__tests__/index.test.ts +86 -0
  49. package/components/Tabbed/index.vue +37 -2
  50. package/components/__tests__/NamespaceFilter.test.ts +49 -0
  51. package/components/auth/SelectPrincipal.vue +28 -6
  52. package/components/auth/__tests__/SelectPrincipal.test.ts +119 -0
  53. package/components/auth/login/ldap.vue +3 -3
  54. package/components/fleet/FleetSecretSelector.vue +1 -1
  55. package/components/form/KeyValue.vue +1 -1
  56. package/components/form/NameNsDescription.vue +1 -1
  57. package/components/form/NodeScheduling.vue +2 -2
  58. package/components/form/ResourceTabs/composable.ts +2 -2
  59. package/components/form/ResourceTabs/index.vue +0 -2
  60. package/components/form/__tests__/NameNsDescription.test.ts +42 -0
  61. package/components/formatter/InternalExternalIP.vue +4 -1
  62. package/components/formatter/LinkName.vue +5 -0
  63. package/components/formatter/__tests__/InternalExternalIP.test.ts +1 -1
  64. package/components/nav/Group.vue +25 -7
  65. package/components/nav/Header.vue +1 -1
  66. package/components/nav/NamespaceFilter.vue +1 -0
  67. package/components/nav/Type.vue +17 -6
  68. package/components/nav/WindowManager/panels/TabBodyContainer.vue +1 -1
  69. package/components/nav/__tests__/Type.test.ts +59 -0
  70. package/components/templates/standalone.vue +1 -1
  71. package/composables/cruResource.ts +27 -0
  72. package/composables/focusTrap.ts +3 -1
  73. package/composables/resourceDetail.ts +15 -0
  74. package/composables/useI18n.ts +10 -1
  75. package/composables/useLabeledFormElement.ts +3 -4
  76. package/config/__test__/uiplugins.test.ts +309 -0
  77. package/config/labels-annotations.js +1 -0
  78. package/config/product/explorer.js +3 -1
  79. package/config/product/fleet.js +1 -1
  80. package/config/router/navigation-guards/clusters.js +3 -3
  81. package/config/router/navigation-guards/products.js +1 -1
  82. package/config/router/routes.js +7 -7
  83. package/config/types.js +7 -0
  84. package/config/uiplugins.js +46 -2
  85. package/core/__tests__/extension-manager-impl.test.js +437 -0
  86. package/core/extension-manager-impl.js +21 -25
  87. package/core/plugin-helpers.ts +2 -2
  88. package/core/plugin.ts +9 -1
  89. package/core/plugins-loader.js +2 -2
  90. package/core/types-provisioning.ts +5 -1
  91. package/core/types.ts +35 -0
  92. package/detail/provisioning.cattle.io.cluster.vue +9 -6
  93. package/dialog/DeveloperLoadExtensionDialog.vue +13 -4
  94. package/dialog/MoveNamespaceDialog.vue +20 -4
  95. package/dialog/RollbackWorkloadDialog.vue +2 -5
  96. package/dialog/SearchDialog.vue +1 -0
  97. package/dialog/__tests__/MoveNamespaceDialog.test.ts +249 -0
  98. package/directives/__tests__/clean-tooltip.test.ts +298 -0
  99. package/directives/clean-tooltip.ts +234 -0
  100. package/edit/__tests__/fleet.cattle.io.gitrepo.test.ts +2 -2
  101. package/edit/__tests__/fleet.cattle.io.helmop.test.ts +100 -3
  102. package/edit/autoscaling.horizontalpodautoscaler/index.vue +1 -0
  103. package/edit/configmap.vue +1 -0
  104. package/edit/constraints.gatekeeper.sh.constraint/index.vue +1 -0
  105. package/edit/fleet.cattle.io.helmop.vue +11 -6
  106. package/edit/helm.cattle.io.projecthelmchart.vue +1 -0
  107. package/edit/k8s.cni.cncf.io.networkattachmentdefinition.vue +1 -0
  108. package/edit/logging-flow/index.vue +1 -0
  109. package/edit/logging.banzaicloud.io.output/index.vue +1 -0
  110. package/edit/management.cattle.io.fleetworkspace.vue +1 -1
  111. package/edit/management.cattle.io.project.vue +1 -0
  112. package/edit/monitoring.coreos.com.alertmanagerconfig/index.vue +4 -1
  113. package/edit/monitoring.coreos.com.alertmanagerconfig/receiverConfig.vue +2 -1
  114. package/edit/monitoring.coreos.com.prometheusrule/index.vue +1 -0
  115. package/edit/monitoring.coreos.com.receiver/index.vue +2 -1
  116. package/edit/monitoring.coreos.com.route.vue +1 -1
  117. package/edit/namespace.vue +1 -0
  118. package/edit/networking.istio.io.destinationrule/index.vue +1 -0
  119. package/edit/networking.k8s.io.ingress/index.vue +1 -0
  120. package/edit/networking.k8s.io.networkpolicy/PolicyRules.vue +1 -0
  121. package/edit/networking.k8s.io.networkpolicy/index.vue +1 -0
  122. package/edit/node.vue +1 -0
  123. package/edit/persistentvolume/index.vue +27 -22
  124. package/edit/persistentvolume/plugins/awsElasticBlockStore.vue +13 -14
  125. package/edit/persistentvolume/plugins/azureDisk.vue +49 -48
  126. package/edit/persistentvolume/plugins/azureFile.vue +15 -14
  127. package/edit/persistentvolume/plugins/cephfs.vue +15 -14
  128. package/edit/persistentvolume/plugins/cinder.vue +15 -14
  129. package/edit/persistentvolume/plugins/csi.vue +18 -16
  130. package/edit/persistentvolume/plugins/fc.vue +13 -14
  131. package/edit/persistentvolume/plugins/flexVolume.vue +15 -14
  132. package/edit/persistentvolume/plugins/flocker.vue +1 -3
  133. package/edit/persistentvolume/plugins/gcePersistentDisk.vue +13 -14
  134. package/edit/persistentvolume/plugins/glusterfs.vue +15 -14
  135. package/edit/persistentvolume/plugins/hostPath.vue +40 -39
  136. package/edit/persistentvolume/plugins/iscsi.vue +13 -14
  137. package/edit/persistentvolume/plugins/local.vue +1 -3
  138. package/edit/persistentvolume/plugins/longhorn.vue +23 -22
  139. package/edit/persistentvolume/plugins/nfs.vue +15 -14
  140. package/edit/persistentvolume/plugins/photonPersistentDisk.vue +1 -14
  141. package/edit/persistentvolume/plugins/portworxVolume.vue +15 -14
  142. package/edit/persistentvolume/plugins/quobyte.vue +15 -14
  143. package/edit/persistentvolume/plugins/rbd.vue +15 -14
  144. package/edit/persistentvolume/plugins/scaleIO.vue +15 -14
  145. package/edit/persistentvolume/plugins/storageos.vue +15 -14
  146. package/edit/persistentvolume/plugins/vsphereVolume.vue +1 -3
  147. package/edit/provisioning.cattle.io.cluster/__tests__/rke2.test.ts +21 -21
  148. package/edit/provisioning.cattle.io.cluster/index.vue +5 -5
  149. package/edit/provisioning.cattle.io.cluster/rke2.vue +9 -8
  150. package/edit/resources.cattle.io.restore.vue +1 -1
  151. package/edit/secret/index.vue +1 -1
  152. package/edit/service.vue +1 -0
  153. package/edit/serviceaccount.vue +1 -0
  154. package/edit/storage.k8s.io.storageclass/index.vue +1 -0
  155. package/edit/workload/Job.vue +2 -2
  156. package/edit/workload/index.vue +2 -1
  157. package/edit/workload/mixins/workload.js +1 -1
  158. package/initialize/App.vue +4 -4
  159. package/initialize/install-plugins.js +19 -5
  160. package/machine-config/azure.vue +1 -1
  161. package/machine-config/components/GCEImage.vue +1 -1
  162. package/mixins/__tests__/brand.spec.ts +2 -2
  163. package/mixins/brand.js +1 -7
  164. package/mixins/create-edit-view/index.js +5 -0
  165. package/models/__tests__/provisioning.cattle.io.cluster.test.ts +128 -5
  166. package/models/chart.js +70 -74
  167. package/models/management.cattle.io.cluster.js +21 -3
  168. package/models/provisioning.cattle.io.cluster.js +31 -11
  169. package/package.json +11 -10
  170. package/pages/auth/login.vue +4 -6
  171. package/pages/auth/setup.vue +1 -1
  172. package/pages/auth/verify.vue +3 -3
  173. package/pages/c/_cluster/apps/charts/__tests__/chart.test.ts +135 -0
  174. package/pages/c/_cluster/apps/charts/chart.vue +33 -15
  175. package/pages/c/_cluster/apps/charts/index.vue +122 -24
  176. package/pages/c/_cluster/apps/charts/install.vue +33 -0
  177. package/pages/c/_cluster/explorer/__tests__/index.test.ts +1 -1
  178. package/pages/c/_cluster/explorer/index.vue +8 -6
  179. package/pages/c/_cluster/fleet/index.vue +4 -7
  180. package/pages/c/_cluster/manager/hostedprovider/index.vue +12 -6
  181. package/pages/c/_cluster/settings/brand.vue +1 -1
  182. package/pages/c/_cluster/settings/index.vue +5 -0
  183. package/pages/c/_cluster/uiplugins/__tests__/index.test.ts +7 -0
  184. package/pages/c/_cluster/uiplugins/catalogs.vue +147 -0
  185. package/pages/c/_cluster/uiplugins/index.vue +126 -184
  186. package/pkg/auto-import.js +3 -3
  187. package/pkg/dynamic-importer.lib.js +1 -1
  188. package/pkg/import.js +1 -1
  189. package/plugins/__tests__/mutations.tests.ts +179 -0
  190. package/plugins/dashboard-client-init.js +3 -0
  191. package/plugins/dashboard-store/getters.js +19 -2
  192. package/plugins/dashboard-store/model-loader.js +1 -1
  193. package/plugins/dashboard-store/mutations.js +23 -2
  194. package/plugins/dashboard-store/resource-class.js +11 -5
  195. package/plugins/i18n.js +8 -0
  196. package/plugins/plugin.js +2 -2
  197. package/plugins/steve/__tests__/steve-pagination-utils.test.ts +506 -0
  198. package/plugins/steve/steve-class.js +1 -1
  199. package/plugins/steve/steve-pagination-utils.ts +131 -47
  200. package/rancher-components/Form/Checkbox/Checkbox.vue +1 -1
  201. package/rancher-components/Form/LabeledInput/LabeledInput.vue +1 -1
  202. package/rancher-components/Pill/RcStatusBadge/RcStatusBadge.vue +6 -42
  203. package/rancher-components/Pill/RcStatusBadge/index.ts +0 -1
  204. package/rancher-components/Pill/RcStatusBadge/types.ts +1 -1
  205. package/rancher-components/Pill/RcStatusIndicator/RcStatusIndicator.vue +5 -28
  206. package/rancher-components/Pill/RcStatusIndicator/types.ts +2 -1
  207. package/rancher-components/Pill/types.ts +0 -1
  208. package/rancher-components/RcDropdown/useDropdownContext.ts +2 -4
  209. package/rancher-components/RcIcon/RcIcon.test.ts +51 -0
  210. package/rancher-components/RcIcon/RcIcon.vue +46 -0
  211. package/rancher-components/RcIcon/index.ts +1 -0
  212. package/rancher-components/RcIcon/types.ts +160 -0
  213. package/rancher-components/RcItemCard/RcItemCard.vue +1 -1
  214. package/rancher-components/utils/status.test.ts +67 -0
  215. package/rancher-components/utils/status.ts +77 -0
  216. package/scripts/publish-shell.sh +25 -0
  217. package/scripts/typegen.sh +1 -0
  218. package/store/__tests__/catalog.test.ts +1 -1
  219. package/store/__tests__/type-map.test.ts +164 -2
  220. package/store/action-menu.js +8 -0
  221. package/store/auth.js +25 -13
  222. package/store/catalog.js +6 -0
  223. package/store/i18n.js +3 -3
  224. package/store/index.js +8 -6
  225. package/store/notifications.ts +2 -0
  226. package/store/prefs.js +6 -7
  227. package/store/type-map.js +17 -7
  228. package/store/wm.ts +4 -4
  229. package/types/internal-api/shell/modal.d.ts +6 -6
  230. package/types/notifications/index.ts +126 -15
  231. package/types/rancher/index.d.ts +9 -0
  232. package/types/shell/index.d.ts +54 -3
  233. package/types/store/__tests__/pagination.types.spec.ts +137 -0
  234. package/types/store/pagination.types.ts +157 -9
  235. package/types/vue-shim.d.ts +5 -4
  236. package/utils/__tests__/provider.test.ts +98 -0
  237. package/utils/__tests__/router.test.js +238 -0
  238. package/utils/__tests__/selector-typed.test.ts +263 -0
  239. package/utils/cluster.js +4 -1
  240. package/utils/color.js +1 -1
  241. package/utils/dynamic-content/__tests__/info.test.ts +6 -0
  242. package/utils/dynamic-content/info.ts +43 -0
  243. package/utils/favicon.js +4 -4
  244. package/utils/fleet.ts +8 -1
  245. package/utils/pagination-utils.ts +2 -2
  246. package/utils/pagination-wrapper.ts +1 -1
  247. package/utils/provider.ts +14 -0
  248. package/utils/router.js +50 -0
  249. package/utils/selector-typed.ts +6 -2
  250. package/utils/unit-tests/pagination-utils.spec.ts +8 -8
  251. package/vue.config.js +3 -3
  252. package/composables/useExtensionManager.ts +0 -17
  253. package/core/plugins.js +0 -38
  254. package/directives/clean-tooltip.js +0 -32
  255. package/plugins/internal-api/index.ts +0 -37
  256. package/plugins/internal-api/shared/base-api.ts +0 -13
  257. package/plugins/internal-api/shell/shell.api.ts +0 -108
  258. package/plugins/nuxt-client-init.js +0 -3
  259. package/types/internal-api/shell/growl.d.ts +0 -25
  260. package/types/internal-api/shell/slideIn.d.ts +0 -15
@@ -17,25 +17,24 @@ export default {
17
17
  required: true,
18
18
  },
19
19
  },
20
- data() {
21
- const readOnlyOptions = [
22
- {
23
- label: this.t('generic.yes'),
24
- value: true
25
- },
26
- {
27
- label: this.t('generic.no'),
28
- value: false
29
- }
30
- ];
31
-
20
+ created() {
32
21
  this.value.spec['fc'] = this.value.spec.fc || {};
33
22
  this.value.spec.fc['readOnly'] = this.value.spec.fc.readOnly || false;
34
23
  this.value.spec.fc['secretRef'] = this.value.spec.fc.secretRef || {};
35
-
36
- return { readOnlyOptions };
37
24
  },
38
25
  computed: {
26
+ readOnlyOptions() {
27
+ return [
28
+ {
29
+ label: this.t('generic.yes'),
30
+ value: true
31
+ },
32
+ {
33
+ label: this.t('generic.no'),
34
+ value: false
35
+ }
36
+ ];
37
+ },
39
38
  lun: {
40
39
  get() {
41
40
  return this.value.spec.fc.lun;
@@ -17,24 +17,25 @@ export default {
17
17
  required: true,
18
18
  },
19
19
  },
20
- data() {
21
- const readOnlyOptions = [
22
- {
23
- label: this.t('generic.yes'),
24
- value: true
25
- },
26
- {
27
- label: this.t('generic.no'),
28
- value: false
29
- }
30
- ];
31
-
20
+ created() {
32
21
  this.value.spec['flexVolume'] = this.value.spec.flexVolume || {};
33
22
  this.value.spec.flexVolume['readOnly'] = this.value.spec.flexVolume.readOnly || false;
34
23
  this.value.spec.flexVolume['secretRef'] = this.value.spec.flexVolume.secretRef || {};
35
-
36
- return { readOnlyOptions };
37
24
  },
25
+ computed: {
26
+ readOnlyOptions() {
27
+ return [
28
+ {
29
+ label: this.t('generic.yes'),
30
+ value: true
31
+ },
32
+ {
33
+ label: this.t('generic.no'),
34
+ value: false
35
+ }
36
+ ];
37
+ }
38
+ }
38
39
  };
39
40
  </script>
40
41
 
@@ -13,10 +13,8 @@ export default {
13
13
  required: true,
14
14
  },
15
15
  },
16
- data() {
16
+ created() {
17
17
  this.value.spec['flocker'] = this.value.spec.flocker || {};
18
-
19
- return {};
20
18
  },
21
19
  };
22
20
  </script>
@@ -14,25 +14,24 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
17
+ created() {
18
18
  this.value.spec['gcePersistentDisk'] = this.value.spec.gcePersistentDisk || {};
19
19
  this.value.spec.gcePersistentDisk['readOnly'] = this.value.spec.gcePersistentDisk.readOnly || false;
20
20
  this.value.spec.gcePersistentDisk['partition'] = this.value.spec.gcePersistentDisk.partition || 0;
21
-
22
- const readOnlyOptions = [
23
- {
24
- label: this.t('generic.yes'),
25
- value: true
26
- },
27
- {
28
- label: this.t('generic.no'),
29
- value: false
30
- }
31
- ];
32
-
33
- return { readOnlyOptions };
34
21
  },
35
22
  computed: {
23
+ readOnlyOptions() {
24
+ return [
25
+ {
26
+ label: this.t('generic.yes'),
27
+ value: true
28
+ },
29
+ {
30
+ label: this.t('generic.no'),
31
+ value: false
32
+ }
33
+ ];
34
+ },
36
35
  partition: {
37
36
  get() {
38
37
  return this.value.spec.gcePersistentDisk.partition;
@@ -14,23 +14,24 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const readOnlyOptions = [
19
- {
20
- label: this.t('generic.yes'),
21
- value: true
22
- },
23
- {
24
- label: this.t('generic.no'),
25
- value: false
26
- }
27
- ];
28
-
17
+ created() {
29
18
  this.value.spec['glusterfs'] = this.value.spec.glusterfs || {};
30
19
  this.value.spec.glusterfs['readOnly'] = this.value.spec.glusterfs.readOnly || false;
31
-
32
- return { readOnlyOptions };
33
20
  },
21
+ computed: {
22
+ readOnlyOptions() {
23
+ return [
24
+ {
25
+ label: this.t('generic.yes'),
26
+ value: true
27
+ },
28
+ {
29
+ label: this.t('generic.no'),
30
+ value: false
31
+ }
32
+ ];
33
+ }
34
+ }
34
35
  };
35
36
  </script>
36
37
 
@@ -14,47 +14,48 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const mustBeOptions = [
19
- {
20
- label: this.t('persistentVolume.hostPath.mustBe.anything'),
21
- value: ''
22
- },
23
- {
24
- label: this.t('persistentVolume.hostPath.mustBe.directory'),
25
- value: 'DirectoryOrCreate'
26
- },
27
- {
28
- label: this.t('persistentVolume.hostPath.mustBe.file'),
29
- value: 'FileOrCreate'
30
- },
31
- {
32
- label: this.t('persistentVolume.hostPath.mustBe.existingDirectory'),
33
- value: 'Directory'
34
- },
35
- {
36
- label: this.t('persistentVolume.hostPath.mustBe.existingFile'),
37
- value: 'File'
38
- },
39
- {
40
- label: this.t('persistentVolume.hostPath.mustBe.existingSocket'),
41
- value: 'Socket'
42
- },
43
- {
44
- label: this.t('persistentVolume.hostPath.mustBe.existingCharacter'),
45
- value: 'CharDevice'
46
- },
47
- {
48
- label: this.t('persistentVolume.hostPath.mustBe.existingBlock'),
49
- value: 'BlockDevice'
50
- },
51
- ];
52
-
17
+ created() {
53
18
  this.value.spec['hostPath'] = this.value.spec.hostPath || {};
54
- this.value.spec.hostPath['type'] = this.value.spec.hostPath.type || mustBeOptions[0].value;
55
-
56
- return { mustBeOptions };
19
+ this.value.spec.hostPath['type'] = this.value.spec.hostPath.type || this.mustBeOptions[0].value;
57
20
  },
21
+ computed: {
22
+ mustBeOptions() {
23
+ return [
24
+ {
25
+ label: this.t('persistentVolume.hostPath.mustBe.anything'),
26
+ value: ''
27
+ },
28
+ {
29
+ label: this.t('persistentVolume.hostPath.mustBe.directory'),
30
+ value: 'DirectoryOrCreate'
31
+ },
32
+ {
33
+ label: this.t('persistentVolume.hostPath.mustBe.file'),
34
+ value: 'FileOrCreate'
35
+ },
36
+ {
37
+ label: this.t('persistentVolume.hostPath.mustBe.existingDirectory'),
38
+ value: 'Directory'
39
+ },
40
+ {
41
+ label: this.t('persistentVolume.hostPath.mustBe.existingFile'),
42
+ value: 'File'
43
+ },
44
+ {
45
+ label: this.t('persistentVolume.hostPath.mustBe.existingSocket'),
46
+ value: 'Socket'
47
+ },
48
+ {
49
+ label: this.t('persistentVolume.hostPath.mustBe.existingCharacter'),
50
+ value: 'CharDevice'
51
+ },
52
+ {
53
+ label: this.t('persistentVolume.hostPath.mustBe.existingBlock'),
54
+ value: 'BlockDevice'
55
+ },
56
+ ];
57
+ }
58
+ }
58
59
  };
59
60
  </script>
60
61
 
@@ -17,27 +17,26 @@ export default {
17
17
  required: true,
18
18
  },
19
19
  },
20
- data() {
21
- const yesNoOptions = [
22
- {
23
- label: this.t('generic.yes'),
24
- value: true
25
- },
26
- {
27
- label: this.t('generic.no'),
28
- value: false
29
- }
30
- ];
31
-
20
+ created() {
32
21
  this.value.spec['iscsi'] = this.value.spec.iscsi || {};
33
22
  this.value.spec.iscsi['readOnly'] = this.value.spec.iscsi.readOnly || false;
34
23
  this.value.spec.iscsi['secretRef'] = this.value.spec.iscsi.secretRef || {};
35
24
  this.value.spec.iscsi['chapAuthDiscovery'] = this.value.spec.iscsi.chapAuthDiscovery || false;
36
25
  this.value.spec.iscsi['chapAuthSession'] = this.value.spec.iscsi.chapAuthSession || false;
37
-
38
- return { yesNoOptions };
39
26
  },
40
27
  computed: {
28
+ yesNoOptions() {
29
+ return [
30
+ {
31
+ label: this.t('generic.yes'),
32
+ value: true
33
+ },
34
+ {
35
+ label: this.t('generic.no'),
36
+ value: false
37
+ }
38
+ ];
39
+ },
41
40
  lun: {
42
41
  get() {
43
42
  return this.value.spec.iscsi.lun;
@@ -13,10 +13,8 @@ export default {
13
13
  required: true,
14
14
  },
15
15
  },
16
- data() {
16
+ created() {
17
17
  this.value.spec['local'] = this.value.spec.local || {};
18
-
19
- return { };
20
18
  },
21
19
  };
22
20
  </script>
@@ -5,6 +5,13 @@ import { RadioGroup } from '@components/Form/Radio';
5
5
  import { _CREATE } from '@shell/config/query-params';
6
6
  import { LONGHORN_DRIVER } from '@shell/config/types';
7
7
 
8
+ const DEFAULT_VOLUME_ATTRIBUTES = {
9
+ size: '2Gi',
10
+ numberOfReplicas: '3',
11
+ staleReplicaTimeout: '20',
12
+ fromBackup: ''
13
+ };
14
+
8
15
  export default {
9
16
  components: {
10
17
  LabeledInput, KeyValue, RadioGroup
@@ -19,33 +26,27 @@ export default {
19
26
  required: true,
20
27
  },
21
28
  },
22
- data() {
23
- const defaultVolumeAttributes = {
24
- size: '2Gi',
25
- numberOfReplicas: '3',
26
- staleReplicaTimeout: '20',
27
- fromBackup: ''
28
- };
29
-
29
+ created() {
30
30
  if (this.mode === _CREATE) {
31
31
  this.value.spec['csi'] = this.value.spec.csi || {};
32
32
  this.value.spec.csi['driver'] = LONGHORN_DRIVER;
33
33
  this.value.spec.csi['readOnly'] = this.value.spec.csi.readOnly || false;
34
- this.value.spec.csi['volumeAttributes'] = this.value.spec.csi.volumeAttributes || defaultVolumeAttributes;
34
+ this.value.spec.csi['volumeAttributes'] = this.value.spec.csi.volumeAttributes || DEFAULT_VOLUME_ATTRIBUTES;
35
+ }
36
+ },
37
+ computed: {
38
+ readOnlyOptions() {
39
+ return [
40
+ {
41
+ label: this.t('generic.yes'),
42
+ value: true
43
+ },
44
+ {
45
+ label: this.t('generic.no'),
46
+ value: false
47
+ }
48
+ ];
35
49
  }
36
-
37
- const readOnlyOptions = [
38
- {
39
- label: this.t('generic.yes'),
40
- value: true
41
- },
42
- {
43
- label: this.t('generic.no'),
44
- value: false
45
- }
46
- ];
47
-
48
- return { readOnlyOptions };
49
50
  },
50
51
  };
51
52
  </script>
@@ -14,23 +14,24 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
17
+ created() {
18
18
  this.value.spec['nfs'] = this.value.spec.nfs || {};
19
19
  this.value.spec.nfs['readOnly'] = this.value.spec.nfs.readOnly || false;
20
-
21
- const readOnlyOptions = [
22
- {
23
- label: this.t('generic.yes'),
24
- value: true
25
- },
26
- {
27
- label: this.t('generic.no'),
28
- value: false
29
- }
30
- ];
31
-
32
- return { readOnlyOptions };
33
20
  },
21
+ computed: {
22
+ readOnlyOptions() {
23
+ return [
24
+ {
25
+ label: this.t('generic.yes'),
26
+ value: true
27
+ },
28
+ {
29
+ label: this.t('generic.no'),
30
+ value: false
31
+ }
32
+ ];
33
+ }
34
+ }
34
35
  };
35
36
  </script>
36
37
 
@@ -13,23 +13,10 @@ export default {
13
13
  required: true,
14
14
  },
15
15
  },
16
- data() {
17
- const readOnlyOptions = [
18
- {
19
- label: this.t('generic.yes'),
20
- value: true
21
- },
22
- {
23
- label: this.t('generic.no'),
24
- value: false
25
- }
26
- ];
27
-
16
+ created() {
28
17
  this.value.spec['photonPersistentDisk'] = this.value.spec.photonPersistentDisk || {};
29
18
  this.value.spec.photonPersistentDisk['readOnly'] = this.value.spec.photonPersistentDisk.readOnly || false;
30
19
  this.value.spec.photonPersistentDisk['secretRef'] = this.value.spec.photonPersistentDisk.secretRef || {};
31
-
32
- return { readOnlyOptions };
33
20
  },
34
21
  };
35
22
  </script>
@@ -14,24 +14,25 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const readOnlyOptions = [
19
- {
20
- label: this.t('generic.yes'),
21
- value: true
22
- },
23
- {
24
- label: this.t('generic.no'),
25
- value: false
26
- }
27
- ];
28
-
17
+ created() {
29
18
  this.value.spec['portworxVolume'] = this.value.spec.portworxVolume || {};
30
19
  this.value.spec.portworxVolume['readOnly'] = this.value.spec.portworxVolume.readOnly || false;
31
20
  this.value.spec.portworxVolume['secretRef'] = this.value.spec.portworxVolume.secretRef || {};
32
-
33
- return { readOnlyOptions };
34
21
  },
22
+ computed: {
23
+ readOnlyOptions() {
24
+ return [
25
+ {
26
+ label: this.t('generic.yes'),
27
+ value: true
28
+ },
29
+ {
30
+ label: this.t('generic.no'),
31
+ value: false
32
+ }
33
+ ];
34
+ }
35
+ }
35
36
  };
36
37
  </script>
37
38
 
@@ -14,23 +14,24 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const readOnlyOptions = [
19
- {
20
- label: this.t('generic.yes'),
21
- value: true
22
- },
23
- {
24
- label: this.t('generic.no'),
25
- value: false
26
- }
27
- ];
28
-
17
+ created() {
29
18
  this.value.spec['quobyte'] = this.value.spec.quobyte || {};
30
19
  this.value.spec.quobyte['readOnly'] = this.value.spec.quobyte.readOnly || false;
31
-
32
- return { readOnlyOptions };
33
20
  },
21
+ computed: {
22
+ readOnlyOptions() {
23
+ return [
24
+ {
25
+ label: this.t('generic.yes'),
26
+ value: true
27
+ },
28
+ {
29
+ label: this.t('generic.no'),
30
+ value: false
31
+ }
32
+ ];
33
+ }
34
+ }
34
35
  };
35
36
  </script>
36
37
 
@@ -17,24 +17,25 @@ export default {
17
17
  required: true,
18
18
  },
19
19
  },
20
- data() {
21
- const readOnlyOptions = [
22
- {
23
- label: this.t('generic.yes'),
24
- value: true
25
- },
26
- {
27
- label: this.t('generic.no'),
28
- value: false
29
- }
30
- ];
31
-
20
+ created() {
32
21
  this.value.spec['rbd'] = this.value.spec.rbd || {};
33
22
  this.value.spec.rbd['readOnly'] = this.value.spec.rbd.readOnly || false;
34
23
  this.value.spec.rbd['secretRef'] = this.value.spec.rbd.secretRef || {};
35
-
36
- return { readOnlyOptions };
37
24
  },
25
+ computed: {
26
+ readOnlyOptions() {
27
+ return [
28
+ {
29
+ label: this.t('generic.yes'),
30
+ value: true
31
+ },
32
+ {
33
+ label: this.t('generic.no'),
34
+ value: false
35
+ }
36
+ ];
37
+ }
38
+ }
38
39
  };
39
40
  </script>
40
41
 
@@ -14,25 +14,26 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const yesNoOptions = [
19
- {
20
- label: this.t('generic.yes'),
21
- value: true
22
- },
23
- {
24
- label: this.t('generic.no'),
25
- value: false
26
- }
27
- ];
28
-
17
+ created() {
29
18
  this.value.spec['scaleIO'] = this.value.spec.scaleIO || {};
30
19
  this.value.spec.scaleIO['readOnly'] = this.value.spec.scaleIO.readOnly || false;
31
20
  this.value.spec.scaleIO['secretRef'] = this.value.spec.scaleIO.secretRef || {};
32
21
  this.value.spec.scaleIO['sslEnabled'] = this.value.spec.scaleIO.sslEnabled || false;
33
-
34
- return { yesNoOptions };
35
22
  },
23
+ computed: {
24
+ yesNoOptions() {
25
+ return [
26
+ {
27
+ label: this.t('generic.yes'),
28
+ value: true
29
+ },
30
+ {
31
+ label: this.t('generic.no'),
32
+ value: false
33
+ }
34
+ ];
35
+ }
36
+ }
36
37
  };
37
38
  </script>
38
39
 
@@ -14,24 +14,25 @@ export default {
14
14
  required: true,
15
15
  },
16
16
  },
17
- data() {
18
- const yesNoOptions = [
19
- {
20
- label: this.t('generic.yes'),
21
- value: true
22
- },
23
- {
24
- label: this.t('generic.no'),
25
- value: false
26
- }
27
- ];
28
-
17
+ created() {
29
18
  this.value.spec['storageos'] = this.value.spec.storageos || {};
30
19
  this.value.spec.storageos['readOnly'] = this.value.spec.storageos.readOnly || false;
31
20
  this.value.spec.storageos['secretRef'] = this.value.spec.storageos.secretRef || {};
32
-
33
- return { yesNoOptions };
34
21
  },
22
+ computed: {
23
+ yesNoOptions() {
24
+ return [
25
+ {
26
+ label: this.t('generic.yes'),
27
+ value: true
28
+ },
29
+ {
30
+ label: this.t('generic.no'),
31
+ value: false
32
+ }
33
+ ];
34
+ }
35
+ }
35
36
  };
36
37
  </script>
37
38
 
@@ -13,10 +13,8 @@ export default {
13
13
  required: true,
14
14
  },
15
15
  },
16
- data() {
16
+ created() {
17
17
  this.value.spec['vsphereVolume'] = this.value.spec.vsphereVolume || {};
18
-
19
- return { };
20
18
  },
21
19
  };
22
20
  </script>