@alauda-fe/common 1.4.28-beta.6 → 1.4.29-beta.0

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 (39) hide show
  1. package/array-form-table/form/component.d.ts +1 -1
  2. package/chart/common/series/bar-path.component.d.ts +1 -1
  3. package/chart/common/tooltip/tooltip.component.d.ts +1 -1
  4. package/code/code-editor-configs.d.ts +2 -0
  5. package/code/managed-fields-folder.util.d.ts +35 -0
  6. package/code/public-api.d.ts +4 -0
  7. package/code/resource-yaml-display/component.d.ts +64 -6
  8. package/code/resource-yaml-editor/component.d.ts +95 -0
  9. package/code/yaml-examples.d.ts +8 -0
  10. package/code/yaml-sidebar/component.d.ts +57 -0
  11. package/code/yaml-sidebar/types.d.ts +21 -0
  12. package/core/abstract/base-nested-form-control.d.ts +1 -1
  13. package/core/directives/scroll-to-first-invalid.directive.d.ts +1 -1
  14. package/core/services/feature-gate.service.d.ts +1 -1
  15. package/core/services/kubernetes-schema.service.d.ts +44 -0
  16. package/core/services/public-api.d.ts +1 -0
  17. package/core/types/openapi.d.ts +37 -0
  18. package/core/types/public-api.d.ts +1 -0
  19. package/core/utils/version.d.ts +1 -1
  20. package/esm2022/code/code-editor-configs.mjs +12 -2
  21. package/esm2022/code/managed-fields-folder.util.mjs +147 -0
  22. package/esm2022/code/public-api.mjs +5 -1
  23. package/esm2022/code/resource-yaml-display/component.mjs +256 -42
  24. package/esm2022/code/resource-yaml-editor/component.mjs +392 -0
  25. package/esm2022/code/yaml-examples.mjs +337 -0
  26. package/esm2022/code/yaml-sidebar/component.mjs +482 -0
  27. package/esm2022/code/yaml-sidebar/types.mjs +2 -0
  28. package/esm2022/core/services/kubernetes-schema.service.mjs +129 -0
  29. package/esm2022/core/services/public-api.mjs +2 -1
  30. package/esm2022/core/services/workspace-helper.service.mjs +4 -3
  31. package/esm2022/core/types/openapi.mjs +2 -0
  32. package/esm2022/core/types/public-api.mjs +2 -1
  33. package/esm2022/exec/terminal-group/component.mjs +2 -2
  34. package/esm2022/translate/translate.service.mjs +2 -2
  35. package/package.json +1 -1
  36. package/styles/global.scss +4 -0
  37. package/table/component.d.ts +1 -1
  38. package/table/helper.d.ts +1 -1
  39. package/view-chart/view-chart.component.d.ts +1 -1
@@ -0,0 +1,337 @@
1
+ /**
2
+ * Kubernetes 资源的内置 YAML 示例
3
+ * 按照 apiVersion.kind 的格式组织
4
+ */
5
+ export const BUILT_IN_YAML_EXAMPLES = {
6
+ 'apps/v1.Deployment': [
7
+ {
8
+ title: 'Basic Deployment',
9
+ description: 'A basic deployment example with nginx container',
10
+ yaml: `apiVersion: apps/v1
11
+ kind: Deployment
12
+ metadata:
13
+ name: example
14
+ spec:
15
+ selector:
16
+ matchLabels:
17
+ app: httpd
18
+ replicas: 3
19
+ template:
20
+ metadata:
21
+ labels:
22
+ app: httpd
23
+ spec:
24
+ containers:
25
+ - name: httpd
26
+ image: nginx:1.7.9
27
+ ports:
28
+ - containerPort: 8080`,
29
+ },
30
+ ],
31
+ 'v1.ConfigMap': [
32
+ {
33
+ title: 'Basic ConfigMap',
34
+ description: 'A basic ConfigMap example with properties and file data',
35
+ yaml: `apiVersion: v1
36
+ kind: ConfigMap
37
+ metadata:
38
+ name: example
39
+ data:
40
+ example.property.1: hello
41
+ example.property.2: world
42
+ example.property.file: |-
43
+ property.1=value-1
44
+ property.2=value-2
45
+ property.3=value-3`,
46
+ },
47
+ ],
48
+ 'batch/v1.CronJob': [
49
+ {
50
+ title: 'Basic CronJob',
51
+ description: 'A basic CronJob example that runs daily',
52
+ yaml: `apiVersion: batch/v1
53
+ kind: CronJob
54
+ metadata:
55
+ name: example
56
+ spec:
57
+ schedule: "@daily"
58
+ jobTemplate:
59
+ spec:
60
+ template:
61
+ spec:
62
+ containers:
63
+ - name: hello
64
+ image: busybox
65
+ args:
66
+ - /bin/sh
67
+ - -c
68
+ - date; echo Hello from the Kubernetes cluster
69
+ restartPolicy: OnFailure`,
70
+ },
71
+ ],
72
+ 'v1.PersistentVolume': [
73
+ {
74
+ title: 'Basic PersistentVolume',
75
+ description: 'A basic PersistentVolume example with NFS storage',
76
+ yaml: `apiVersion: v1
77
+ kind: PersistentVolume
78
+ metadata:
79
+ name: example
80
+ spec:
81
+ capacity:
82
+ storage: 5Gi
83
+ accessModes:
84
+ - ReadWriteOnce
85
+ persistentVolumeReclaimPolicy: Retain
86
+ storageClassName: slow
87
+ nfs:
88
+ path: /tmp
89
+ server: 172.17.0.2`,
90
+ },
91
+ ],
92
+ 'autoscaling/v2.HorizontalPodAutoscaler': [
93
+ {
94
+ title: 'Basic HorizontalPodAutoscaler',
95
+ description: 'A basic HPA example with CPU utilization target',
96
+ yaml: `apiVersion: autoscaling/v2
97
+ kind: HorizontalPodAutoscaler
98
+ metadata:
99
+ name: example
100
+ spec:
101
+ scaleTargetRef:
102
+ apiVersion: apps/v1
103
+ kind: Deployment
104
+ name: example
105
+ minReplicas: 1
106
+ maxReplicas: 3
107
+ metrics:
108
+ - type: Resource
109
+ resource:
110
+ name: cpu
111
+ target:
112
+ averageUtilization: 50
113
+ type: Utilization`,
114
+ },
115
+ ],
116
+ 'apps/v1.DaemonSet': [
117
+ {
118
+ title: 'Basic DaemonSet',
119
+ description: 'A basic DaemonSet example with nginx container',
120
+ yaml: `apiVersion: apps/v1
121
+ kind: DaemonSet
122
+ metadata:
123
+ name: example
124
+ spec:
125
+ selector:
126
+ matchLabels:
127
+ app: httpd
128
+ template:
129
+ metadata:
130
+ labels:
131
+ app: httpd
132
+ spec:
133
+ containers:
134
+ - name: httpd
135
+ image: nginx:1.7.9
136
+ ports:
137
+ - containerPort: 8080`,
138
+ },
139
+ ],
140
+ 'v1.PersistentVolumeClaim': [
141
+ {
142
+ title: 'Basic PersistentVolumeClaim',
143
+ description: 'A basic PVC example requesting 1Gi storage',
144
+ yaml: `apiVersion: v1
145
+ kind: PersistentVolumeClaim
146
+ metadata:
147
+ name: example
148
+ spec:
149
+ accessModes:
150
+ - ReadWriteOnce
151
+ volumeMode: Filesystem
152
+ resources:
153
+ requests:
154
+ storage: 1Gi`,
155
+ },
156
+ ],
157
+ 'v1.ResourceQuota': [
158
+ {
159
+ title: 'Compute ResourceQuota',
160
+ description: 'A ResourceQuota example for compute resources',
161
+ yaml: `apiVersion: v1
162
+ kind: ResourceQuota
163
+ metadata:
164
+ name: compute-quota
165
+ namespace: default
166
+ spec:
167
+ hard:
168
+ requests.cpu: '1'
169
+ requests.memory: 1Gi
170
+ limits.cpu: '2'
171
+ limits.memory: 2Gi`,
172
+ },
173
+ {
174
+ title: 'Storage Class ResourceQuota',
175
+ description: 'A ResourceQuota example for storage class specific quotas',
176
+ yaml: `apiVersion: v1
177
+ kind: ResourceQuota
178
+ metadata:
179
+ name: storage-class-quota
180
+ namespace: default
181
+ spec:
182
+ hard:
183
+ requests.storage: 100Gi
184
+ persistentvolumeclaims: '100'
185
+ # For quota specific to a storage class, the storage class must have the same name
186
+ gold.storage-class.kubernetes.io/requests.storage: 3Gi
187
+ gold.storage-class.kubernetes.io/persistentvolumeclaims: '5'
188
+ silver.storage-class.kubernetes.io/requests.storage: 2Gi
189
+ silver.storage-class.kubernetes.io/persistentvolumeclaims: '3'
190
+ bronze.storage-class.kubernetes.io/requests.storage: 1Gi
191
+ bronze.storage-class.kubernetes.io/persistentvolumeclaims: '1'`,
192
+ },
193
+ {
194
+ title: 'Object Counts ResourceQuota',
195
+ description: 'A ResourceQuota example for object count limits',
196
+ yaml: `apiVersion: v1
197
+ kind: ResourceQuota
198
+ metadata:
199
+ name: object-counts
200
+ namespace: default
201
+ spec:
202
+ hard:
203
+ configmaps: "10"
204
+ persistentvolumeclaims: "4"
205
+ replicationcontrollers: "20"
206
+ secrets: "10"
207
+ services: "10"
208
+ services.loadbalancers: "2"`,
209
+ },
210
+ ],
211
+ 'v1.LimitRange': [
212
+ {
213
+ title: 'Memory LimitRange',
214
+ description: 'A LimitRange example for container memory limits',
215
+ yaml: `apiVersion: v1
216
+ kind: LimitRange
217
+ metadata:
218
+ name: mem-limit-range
219
+ spec:
220
+ limits:
221
+ - default:
222
+ memory: 512Mi
223
+ defaultRequest:
224
+ memory: 256Mi
225
+ type: Container`,
226
+ },
227
+ ],
228
+ 'apps/v1.StatefulSet': [
229
+ {
230
+ title: 'Basic StatefulSet',
231
+ description: 'A basic StatefulSet example with persistent storage',
232
+ yaml: `apiVersion: apps/v1
233
+ kind: StatefulSet
234
+ metadata:
235
+ name: example
236
+ spec:
237
+ serviceName: "httpd"
238
+ replicas: 3
239
+ selector:
240
+ matchLabels:
241
+ app: httpd
242
+ template:
243
+ metadata:
244
+ labels:
245
+ app: httpd
246
+ spec:
247
+ terminationGracePeriodSeconds: 10
248
+ containers:
249
+ - name: httpd
250
+ image: nginx:1.7.9
251
+ ports:
252
+ - containerPort: 8080
253
+ name: web
254
+ volumeMounts:
255
+ - name: www
256
+ mountPath: /var/www/html
257
+ volumeClaimTemplates:
258
+ - metadata:
259
+ name: www
260
+ spec:
261
+ accessModes: [ "ReadWriteOnce" ]
262
+ storageClassName: my-storage-class
263
+ resources:
264
+ requests:
265
+ storage: 1Gi`,
266
+ },
267
+ ],
268
+ 'storage.k8s.io/v1.StorageClass': [
269
+ {
270
+ title: 'Basic StorageClass',
271
+ description: 'A basic StorageClass example',
272
+ yaml: `apiVersion: storage.k8s.io/v1
273
+ kind: StorageClass
274
+ metadata:
275
+ name: example
276
+ provisioner: my-provisioner
277
+ reclaimPolicy: Delete`,
278
+ },
279
+ ],
280
+ 'v1.Secret': [
281
+ {
282
+ title: 'Basic Secret',
283
+ description: 'A basic Secret example with username and password',
284
+ yaml: `apiVersion: v1
285
+ kind: Secret
286
+ metadata:
287
+ name: example
288
+ type: Opaque
289
+ stringData:
290
+ username: admin
291
+ password: opensesame`,
292
+ },
293
+ ],
294
+ 'app.k8s.io/v1beta1.Application': [
295
+ {
296
+ title: 'Basic Application',
297
+ description: 'A basic Application example with Deployment and Service',
298
+ yaml: `apiVersion: apps/v1
299
+ kind: Deployment
300
+ metadata:
301
+ labels:
302
+ app: nginx
303
+ name: nginx-deployment
304
+ spec:
305
+ replicas: 1
306
+ selector:
307
+ matchLabels:
308
+ app: nginx
309
+ template:
310
+ metadata:
311
+ labels:
312
+ app: nginx
313
+ spec:
314
+ containers:
315
+ - image: nginx:1.7.9
316
+ name: nginx
317
+ ports:
318
+ - containerPort: 80
319
+ ---
320
+ apiVersion: v1
321
+ kind: Service
322
+ metadata:
323
+ labels:
324
+ app: nginx
325
+ name: nginx
326
+ spec:
327
+ ports:
328
+ - port: 80
329
+ protocol: TCP
330
+ targetPort: 80
331
+ selector:
332
+ app: nginx
333
+ type: ClusterIP`,
334
+ },
335
+ ],
336
+ };
337
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"yaml-examples.js","sourceRoot":"","sources":["../../../../../libs/common/src/code/yaml-examples.ts"],"names":[],"mappings":"AAEA;;;GAGG;AACH,MAAM,CAAC,MAAM,sBAAsB,GAAqC;IACtE,oBAAoB,EAAE;QACpB;YACE,KAAK,EAAE,kBAAkB;YACzB,WAAW,EAAE,iDAAiD;YAC9D,IAAI,EAAE;;;;;;;;;;;;;;;;;;8BAkBkB;SACzB;KACF;IAED,cAAc,EAAE;QACd;YACE,KAAK,EAAE,iBAAiB;YACxB,WAAW,EAAE,yDAAyD;YACtE,IAAI,EAAE;;;;;;;;;;uBAUW;SAClB;KACF;IAED,kBAAkB,EAAE;QAClB;YACE,KAAK,EAAE,eAAe;YACtB,WAAW,EAAE,yCAAyC;YACtD,IAAI,EAAE;;;;;;;;;;;;;;;;;mCAiBuB;SAC9B;KACF;IAED,qBAAqB,EAAE;QACrB;YACE,KAAK,EAAE,wBAAwB;YAC/B,WAAW,EAAE,mDAAmD;YAChE,IAAI,EAAE;;;;;;;;;;;;;uBAaW;SAClB;KACF;IAED,wCAAwC,EAAE;QACxC;YACE,KAAK,EAAE,+BAA+B;YACtC,WAAW,EAAE,iDAAiD;YAC9D,IAAI,EAAE;;;;;;;;;;;;;;;;;0BAiBc;SACrB;KACF;IAED,mBAAmB,EAAE;QACnB;YACE,KAAK,EAAE,iBAAiB;YACxB,WAAW,EAAE,gDAAgD;YAC7D,IAAI,EAAE;;;;;;;;;;;;;;;;;8BAiBkB;SACzB;KACF;IAED,0BAA0B,EAAE;QAC1B;YACE,KAAK,EAAE,6BAA6B;YACpC,WAAW,EAAE,4CAA4C;YACzD,IAAI,EAAE;;;;;;;;;;mBAUO;SACd;KACF;IAED,kBAAkB,EAAE;QAClB;YACE,KAAK,EAAE,uBAAuB;YAC9B,WAAW,EAAE,+CAA+C;YAC5D,IAAI,EAAE;;;;;;;;;;uBAUW;SAClB;QACD;YACE,KAAK,EAAE,6BAA6B;YACpC,WAAW,EAAE,2DAA2D;YACxE,IAAI,EAAE;;;;;;;;;;;;;;;mEAeuD;SAC9D;QACD;YACE,KAAK,EAAE,6BAA6B;YACpC,WAAW,EAAE,iDAAiD;YAC9D,IAAI,EAAE;;;;;;;;;;;;gCAYoB;SAC3B;KACF;IAED,eAAe,EAAE;QACf;YACE,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,kDAAkD;YAC/D,IAAI,EAAE;;;;;;;;;;oBAUQ;SACf;KACF;IAED,qBAAqB,EAAE;QACrB;YACE,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,qDAAqD;YAClE,IAAI,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;uBAiCW;SAClB;KACF;IAED,gCAAgC,EAAE;QAChC;YACE,KAAK,EAAE,oBAAoB;YAC3B,WAAW,EAAE,8BAA8B;YAC3C,IAAI,EAAE;;;;;sBAKU;SACjB;KACF;IAED,WAAW,EAAE;QACX;YACE,KAAK,EAAE,cAAc;YACrB,WAAW,EAAE,mDAAmD;YAChE,IAAI,EAAE;;;;;;;uBAOW;SAClB;KACF;IAED,gCAAgC,EAAE;QAChC;YACE,KAAK,EAAE,mBAAmB;YAC1B,WAAW,EAAE,yDAAyD;YACtE,IAAI,EAAE;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;;kBAmCM;SACb;KACF;CACF,CAAC","sourcesContent":["import { YamlExample } from './yaml-sidebar/types';\n\n/**\n * Kubernetes 资源的内置 YAML 示例\n * 按照 apiVersion.kind 的格式组织\n */\nexport const BUILT_IN_YAML_EXAMPLES: { [key: string]: YamlExample[] } = {\n  'apps/v1.Deployment': [\n    {\n      title: 'Basic Deployment',\n      description: 'A basic deployment example with nginx container',\n      yaml: `apiVersion: apps/v1\nkind: Deployment\nmetadata:\n  name: example\nspec:\n  selector:\n    matchLabels:\n      app: httpd\n  replicas: 3\n  template:\n    metadata:\n      labels:\n        app: httpd\n    spec:\n      containers:\n      - name: httpd\n        image: nginx:1.7.9\n        ports:\n        - containerPort: 8080`,\n    },\n  ],\n\n  'v1.ConfigMap': [\n    {\n      title: 'Basic ConfigMap',\n      description: 'A basic ConfigMap example with properties and file data',\n      yaml: `apiVersion: v1\nkind: ConfigMap\nmetadata:\n  name: example\ndata:\n  example.property.1: hello\n  example.property.2: world\n  example.property.file: |-\n    property.1=value-1\n    property.2=value-2\n    property.3=value-3`,\n    },\n  ],\n\n  'batch/v1.CronJob': [\n    {\n      title: 'Basic CronJob',\n      description: 'A basic CronJob example that runs daily',\n      yaml: `apiVersion: batch/v1\nkind: CronJob\nmetadata:\n  name: example\nspec:\n  schedule: \"@daily\"\n  jobTemplate:\n    spec:\n      template:\n        spec:\n          containers:\n          - name: hello\n            image: busybox\n            args:\n            - /bin/sh\n            - -c\n            - date; echo Hello from the Kubernetes cluster\n          restartPolicy: OnFailure`,\n    },\n  ],\n\n  'v1.PersistentVolume': [\n    {\n      title: 'Basic PersistentVolume',\n      description: 'A basic PersistentVolume example with NFS storage',\n      yaml: `apiVersion: v1\nkind: PersistentVolume\nmetadata:\n  name: example\nspec:\n  capacity:\n    storage: 5Gi\n  accessModes:\n    - ReadWriteOnce\n  persistentVolumeReclaimPolicy: Retain\n  storageClassName: slow\n  nfs:\n    path: /tmp\n    server: 172.17.0.2`,\n    },\n  ],\n\n  'autoscaling/v2.HorizontalPodAutoscaler': [\n    {\n      title: 'Basic HorizontalPodAutoscaler',\n      description: 'A basic HPA example with CPU utilization target',\n      yaml: `apiVersion: autoscaling/v2\nkind: HorizontalPodAutoscaler\nmetadata:\n  name: example\nspec:\n  scaleTargetRef:\n    apiVersion: apps/v1\n    kind: Deployment\n    name: example\n  minReplicas: 1\n  maxReplicas: 3\n  metrics:\n  - type: Resource\n    resource:\n      name: cpu\n      target:\n        averageUtilization: 50\n        type: Utilization`,\n    },\n  ],\n\n  'apps/v1.DaemonSet': [\n    {\n      title: 'Basic DaemonSet',\n      description: 'A basic DaemonSet example with nginx container',\n      yaml: `apiVersion: apps/v1\nkind: DaemonSet\nmetadata:\n  name: example\nspec:\n  selector:\n    matchLabels:\n      app: httpd\n  template:\n    metadata:\n      labels:\n        app: httpd\n    spec:\n      containers:\n      - name: httpd\n        image: nginx:1.7.9\n        ports:\n        - containerPort: 8080`,\n    },\n  ],\n\n  'v1.PersistentVolumeClaim': [\n    {\n      title: 'Basic PersistentVolumeClaim',\n      description: 'A basic PVC example requesting 1Gi storage',\n      yaml: `apiVersion: v1\nkind: PersistentVolumeClaim\nmetadata:\n  name: example\nspec:\n  accessModes:\n    - ReadWriteOnce\n  volumeMode: Filesystem\n  resources:\n    requests:\n      storage: 1Gi`,\n    },\n  ],\n\n  'v1.ResourceQuota': [\n    {\n      title: 'Compute ResourceQuota',\n      description: 'A ResourceQuota example for compute resources',\n      yaml: `apiVersion: v1\nkind: ResourceQuota\nmetadata:\n  name: compute-quota\n  namespace: default\nspec:\n  hard:\n    requests.cpu: '1'\n    requests.memory: 1Gi\n    limits.cpu: '2'\n    limits.memory: 2Gi`,\n    },\n    {\n      title: 'Storage Class ResourceQuota',\n      description: 'A ResourceQuota example for storage class specific quotas',\n      yaml: `apiVersion: v1\nkind: ResourceQuota\nmetadata:\n  name: storage-class-quota\n  namespace: default\nspec:\n  hard:\n    requests.storage: 100Gi\n    persistentvolumeclaims: '100'\n    # For quota specific to a storage class, the storage class must have the same name\n    gold.storage-class.kubernetes.io/requests.storage: 3Gi\n    gold.storage-class.kubernetes.io/persistentvolumeclaims: '5'\n    silver.storage-class.kubernetes.io/requests.storage: 2Gi\n    silver.storage-class.kubernetes.io/persistentvolumeclaims: '3'\n    bronze.storage-class.kubernetes.io/requests.storage: 1Gi\n    bronze.storage-class.kubernetes.io/persistentvolumeclaims: '1'`,\n    },\n    {\n      title: 'Object Counts ResourceQuota',\n      description: 'A ResourceQuota example for object count limits',\n      yaml: `apiVersion: v1\nkind: ResourceQuota\nmetadata:\n  name: object-counts\n  namespace: default\nspec:\n  hard:\n    configmaps: \"10\"\n    persistentvolumeclaims: \"4\"\n    replicationcontrollers: \"20\"\n    secrets: \"10\"\n    services: \"10\"\n    services.loadbalancers: \"2\"`,\n    },\n  ],\n\n  'v1.LimitRange': [\n    {\n      title: 'Memory LimitRange',\n      description: 'A LimitRange example for container memory limits',\n      yaml: `apiVersion: v1\nkind: LimitRange\nmetadata:\n  name: mem-limit-range\nspec:\n  limits:\n  - default:\n      memory: 512Mi\n    defaultRequest:\n      memory: 256Mi\n    type: Container`,\n    },\n  ],\n\n  'apps/v1.StatefulSet': [\n    {\n      title: 'Basic StatefulSet',\n      description: 'A basic StatefulSet example with persistent storage',\n      yaml: `apiVersion: apps/v1\nkind: StatefulSet\nmetadata:\n  name: example\nspec:\n  serviceName: \"httpd\"\n  replicas: 3\n  selector:\n    matchLabels:\n      app: httpd\n  template:\n    metadata:\n      labels:\n        app: httpd\n    spec:\n      terminationGracePeriodSeconds: 10\n      containers:\n      - name: httpd\n        image: nginx:1.7.9\n        ports:\n        - containerPort: 8080\n          name: web\n        volumeMounts:\n        - name: www\n          mountPath: /var/www/html\n  volumeClaimTemplates:\n  - metadata:\n      name: www\n    spec:\n      accessModes: [ \"ReadWriteOnce\" ]\n      storageClassName: my-storage-class\n      resources:\n        requests:\n          storage: 1Gi`,\n    },\n  ],\n\n  'storage.k8s.io/v1.StorageClass': [\n    {\n      title: 'Basic StorageClass',\n      description: 'A basic StorageClass example',\n      yaml: `apiVersion: storage.k8s.io/v1\nkind: StorageClass\nmetadata:\n  name: example\nprovisioner: my-provisioner\nreclaimPolicy: Delete`,\n    },\n  ],\n\n  'v1.Secret': [\n    {\n      title: 'Basic Secret',\n      description: 'A basic Secret example with username and password',\n      yaml: `apiVersion: v1\nkind: Secret\nmetadata:\n  name: example\ntype: Opaque\nstringData:\n  username: admin\n  password: opensesame`,\n    },\n  ],\n\n  'app.k8s.io/v1beta1.Application': [\n    {\n      title: 'Basic Application',\n      description: 'A basic Application example with Deployment and Service',\n      yaml: `apiVersion: apps/v1\nkind: Deployment\nmetadata:\n  labels:\n    app: nginx\n  name: nginx-deployment\nspec:\n  replicas: 1\n  selector:\n    matchLabels:\n      app: nginx\n  template:\n    metadata:\n      labels:\n        app: nginx\n    spec:\n      containers:\n        - image: nginx:1.7.9\n          name: nginx\n          ports:\n            - containerPort: 80\n---\napiVersion: v1\nkind: Service\nmetadata:\n  labels:\n    app: nginx\n  name: nginx\nspec:\n  ports:\n    - port: 80\n      protocol: TCP\n      targetPort: 80\n  selector:\n    app: nginx\n  type: ClusterIP`,\n    },\n  ],\n};\n"]}