Files
DiceCloud/app/imports/ui/properties/forms/FeatureForm.vue

87 lines
2.1 KiB
Vue

<template lang="html">
<div class="feature-form">
<text-field
label="Name"
:value="model.name"
:error-messages="errors.name"
:debounce-time="debounceTime"
@change="(value, ack) => $emit('change', {path: ['name'], value, ack})"
/>
<text-area
label="Summary"
hint="This will appear in the feature card in the character sheet"
:value="model.summary"
:error-messages="errors.summary"
:debounce-time="debounceTime"
@change="(value, ack) => $emit('change', {path: ['summary'], value, ack})"
/>
<text-area
label="Description"
hint="The rest of the description that doesn't fit in the summary goes here"
:value="model.description"
:error-messages="errors.description"
:debounce-time="debounceTime"
@change="(value, ack) => $emit('change', {path: ['description'], value, ack})"
/>
</div>
</template>
<script>
export default {
props: {
model: {
type: Object,
default: () => ({}),
},
errors: {
type: Object,
default: () => ({}),
},
debounceTime: {
type: Number,
default: undefined,
},
},
data(){ return{
enabledOptions: [
{
text: 'Always enabled',
value: 'always',
}, {
text: 'Enabled',
value: 'enabled',
}, {
text: 'Disabled',
value: 'disabled',
}
],
}},
computed: {
enabledStatus(){
if (!this.model) return;
if (this.model.alwaysEnabled) return 'always';
if (this.model.enabled) return 'enabled';
return 'disabled';
},
},
methods: {
changeEnabled(value, ack){
let change = ({enabled, alwaysEnabled}) => {
this.$emit('change', {path: ['enabled'], value: enabled, ack});
this.$emit('change', {path: ['alwaysEnabled'], value: alwaysEnabled, ack});
}
if (value === 'always'){
change({enabled: true, alwaysEnabled: true});
} else if (value === 'enabled'){
change({enabled: true, alwaysEnabled: false});
} else if (value === 'disabled'){
change({enabled: false, alwaysEnabled: false});
}
},
},
};
</script>
<style lang="css" scoped>
</style>