2021-03-29 20:35:54 +00:00
|
|
|
<template>
|
2021-03-30 20:16:12 +00:00
|
|
|
<div
|
|
|
|
v-for="(step, index) in steps"
|
|
|
|
:key="index"
|
|
|
|
class="full-width row q-gutter-sm justify-between q-py-sm"
|
|
|
|
>
|
|
|
|
<div class="row">
|
2021-03-30 20:32:18 +00:00
|
|
|
<div>{{ index + 1 }}.</div>
|
2021-03-30 20:16:12 +00:00
|
|
|
<div class="q-pl-sm">
|
|
|
|
{{ step }}
|
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
<q-btn
|
|
|
|
v-if="editable"
|
|
|
|
round
|
|
|
|
color="negative"
|
|
|
|
size="sm"
|
|
|
|
icon="mdi-delete"
|
|
|
|
@click="deleteStep(index)"
|
|
|
|
/>
|
2021-03-29 20:35:54 +00:00
|
|
|
</div>
|
2021-03-30 20:16:12 +00:00
|
|
|
<div v-if="editable" class="full-width row q-gutter-sm justify-between">
|
|
|
|
<q-input v-model="newStep" filled label="Arbeitsschritt" />
|
2021-03-29 20:35:54 +00:00
|
|
|
<q-btn label="Schritt hinzufügen" @click="addStep" />
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
|
|
|
import { PropType, defineComponent, ref } from 'vue';
|
|
|
|
export default defineComponent({
|
|
|
|
name: 'BuildManual',
|
|
|
|
props: {
|
|
|
|
steps: {
|
|
|
|
type: Array as PropType<Array<string>>,
|
|
|
|
required: true,
|
|
|
|
},
|
|
|
|
editable: {
|
|
|
|
type: Boolean,
|
|
|
|
default: true,
|
|
|
|
},
|
|
|
|
},
|
|
|
|
emits: {
|
2021-03-30 13:40:02 +00:00
|
|
|
deleteStep: (index: number) => index,
|
|
|
|
addStep: (val: string) => val,
|
2021-03-29 20:35:54 +00:00
|
|
|
},
|
|
|
|
setup(_, { emit }) {
|
|
|
|
const newStep = ref('');
|
|
|
|
function deleteStep(index: number) {
|
|
|
|
emit('deleteStep', index);
|
|
|
|
}
|
|
|
|
function addStep() {
|
|
|
|
emit('addStep', newStep.value);
|
|
|
|
newStep.value = '';
|
|
|
|
}
|
|
|
|
return { newStep, addStep, deleteStep };
|
|
|
|
},
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
|
|
|
<style scoped></style>
|