dashboard/components/form/Container.vue

144 lines
3.7 KiB
Vue

<script>
import HealthCheck from '@/components/form/HealthCheck';
import Command from '@/components/form/Command';
import Security from '@/components/form/Security';
import WorkloadPorts from '@/components/form/WorkloadPorts';
import ContainerResourceLimit from '@/components/ContainerResourceLimit';
import LabeledInput from '@/components/form/LabeledInput';
import { _CREATE, _VIEW } from '@/config/query-params';
export default {
components: {
HealthCheck,
Command,
Security,
WorkloadPorts,
ContainerResourceLimit,
LabeledInput
},
props: {
// container spec
value: {
type: Object,
default: () => {
return {};
}
},
mode: {
type: String,
default: _CREATE,
}
},
data() {
const {
resources, readinessProbe, livenessProbe, startupProbe,
} = this.value;
const healthCheck = {
readinessProbe, livenessProbe, startupProbe
};
return { resources, healthCheck };
},
computed: {
isView() {
return this.mode === _VIEW;
},
flatResources() {
const { limits = {}, requests = {} } = this.resources || {};
const { cpu:limitsCpu, memory:limitsMemory } = limits;
const { cpu:requestsCpu, memory:requestsMemory } = requests;
return {
limitsCpu, limitsMemory, requestsCpu, requestsMemory
};
},
hasResourceLimits() {
const {
limitsCpu, limitsMemory, requestsCpu, requestsMemory
} = this.flatResources;
return !!limitsCpu || !!limitsMemory || !!requestsCpu || !!requestsMemory;
},
hasHealthCheck() {
const { readinessProbe, livenessProbe, startupProbe } = this.healthCheck;
return !!readinessProbe || !!livenessProbe || !!startupProbe;
}
},
};
</script>
<template>
<div v-if="isView">
<div class="spacer"></div>
<div>
<div class="row">
<div class="col span-4">
<LabeledInput :label="t('workload.container.name')" :mode="mode" :value="value.name" />
</div>
<div class="col span-4">
<LabeledInput
v-model="value.image"
:label="t('workload.container.image')"
placeholder="e.g. nginx:latest"
required
:mode="mode"
/>
</div>
<div class="col span-4">
<LabeledInput
:value="value.imagePullPolicy"
:label="t('workload.container.imagePullPolicy')"
:mode="mode"
/>
</div>
</div>
</div>
<div class="spacer"></div>
<div>
<h3><t k="workload.container.titles.ports" /></h3>
<WorkloadPorts v-if="value.ports" v-model="value.ports" :mode="mode" />
<div v-else>
<t k="workload.container.noPorts" />
</div>
</div>
<div class="spacer"></div>
<div>
<h3><t k="workload.container.titles.command" /></h3>
<Command v-model="value" :mode="mode" :secrets="[]" :config-maps="[]" />
</div>
<div class="spacer"></div>
<div>
<h3><t k="workload.container.titles.resources" /></h3>
<ContainerResourceLimit v-if="hasResourceLimits" v-model="flatResources" :mode="mode" :show-tip="false" />
<div v-else>
<t k="workload.container.noResourceLimits" />
</div>
</div>
<div class="spacer"></div>
<div>
<h3><t k="workload.container.titles.healthCheck" /></h3>
<HealthCheck v-if="hasHealthCheck" v-model="healthCheck" :mode="mode" />
<div v-else>
<t k="workload.container.healthCheck.noHealthCheck" />
</div>
</div>
<div>
<h3><t k="workload.container.titles.securityContext" /></h3>
<Security v-model="value.securityContext" :mode="mode" />
</div>
</div>
</template>