Files
DiceCloud/app/imports/ui/properties/forms/ItemForm.vue
2020-06-05 22:39:21 +02:00

132 lines
3.5 KiB
Vue

<template lang="html">
<div class="item-form">
<div class="layout row justify-space-around">
<div>
<icon-picker
label="Icon"
:value="model.icon"
:error-messages="errors.icon"
@change="change('icon', ...arguments)"
/>
</div>
<div>
<smart-switch
label="Equipped"
:value="model.equipped"
:error-messages="errors.equipped"
@change="change('equipped', ...arguments)"
/>
</div>
</div>
<div class="layout row wrap">
<text-field
ref="focusFirst"
label="Name"
:value="model.name"
:error-messages="errors.name"
@change="change('name', ...arguments)"
/>
<text-field
label="Plural name"
:value="model.plural"
:error-messages="errors.plural"
@change="change('plural', ...arguments)"
/>
</div>
<div class="layout row wrap">
<text-field
label="Value"
suffix="gp"
type="number"
min="0"
hint="The value of the item in gold pieces, using decimals for values less than 1 gp"
class="mx-1"
style="flex-basis: 300px;"
prepend-inner-icon="$vuetify.icons.two_coins"
:value="model.value"
:error-messages="errors.value"
@change="change('value', ...arguments)"
/>
<text-field
label="Weight"
suffix="lb"
type="number"
min="0"
class="mx-1"
style="flex-basis: 300px;"
prepend-inner-icon="$vuetify.icons.weight"
:value="model.weight"
:error-messages="errors.weight"
@change="change('weight', ...arguments)"
/>
</div>
<text-field
label="Quantity"
type="number"
min="0"
prepend-inner-icon="$vuetify.icons.abacus"
:value="model.quantity"
:error-messages="errors.quantity"
@change="change('quantity', ...arguments)"
/>
<text-area
label="Description"
:value="model.description"
:error-messages="errors.description"
@change="change('description', ...arguments)"
/>
<form-section
name="Advanced"
standalone
>
<smart-switch
label="Show increment button"
:value="model.showIncrement"
:error-messages="errors.showIncrement"
@change="change('showIncrement', ...arguments)"
/>
<smart-combobox
label="Tags"
class="mr-2"
multiple
chips
deletable-chips
:value="model.tags"
:error-messages="errors.tags"
@change="change('tags', ...arguments)"
/>
<smart-switch
label="Requires attunement"
:value="model.requiresAttunement"
:error-messages="errors.requiresAttunement"
@change="change('requiresAttunement', ...arguments)"
/>
<v-expand-transition>
<div
v-show="model.requiresAttunement"
style="padding-top: 0.1px;"
>
<smart-switch
label="Attuned"
:value="model.attuned"
:error-messages="errors.attuned"
@change="change('attuned', ...arguments)"
/>
</div>
</v-expand-transition>
</form-section>
</div>
</template>
<script>
import FormSection from '/imports/ui/properties/forms/shared/FormSection.vue';
import propertyFormMixin from '/imports/ui/properties/forms/shared/propertyFormMixin.js';
export default {
components: {
FormSection,
},
mixins: [propertyFormMixin],
}
</script>