flaschengeist-frontend/src/plugins/pricelist/components/CalculationTable/BuildManual.vue

60 lines
1.3 KiB
Vue
Raw Normal View History

<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)"
/>
</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" dense />
<q-btn label="Schritt hinzufügen" dense @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>>,
},
editable: {
type: Boolean,
default: true,
},
},
emits: {
2021-03-30 13:40:02 +00:00
deleteStep: (index: number) => index,
addStep: (val: string) => val,
},
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>