1
0
Fork 0
mirror of https://gitlab.com/bramw/baserow.git synced 2025-04-22 20:32:24 +00:00
bramw_baserow/web-frontend/modules/database/components/field/FieldNumberSubForm.vue
2023-11-15 06:08:35 +00:00

75 lines
2.3 KiB
Vue

<template>
<div>
<div class="control">
<label class="control__label control__label--small">{{
$t('fieldNumberSubForm.decimalPlacesLabel')
}}</label>
<div class="control__elements">
<Dropdown
v-model="values.number_decimal_places"
:class="{ 'dropdown--error': $v.values.number_decimal_places.$error }"
:fixed-items="true"
small
@hide="$v.values.number_decimal_places.$touch()"
>
<DropdownItem name="0 (1)" :value="0"></DropdownItem>
<DropdownItem name="1 (1.0)" :value="1"></DropdownItem>
<DropdownItem name="2 (1.00)" :value="2"></DropdownItem>
<DropdownItem name="3 (1.000)" :value="3"></DropdownItem>
<DropdownItem name="4 (1.0000)" :value="4"></DropdownItem>
<DropdownItem name="5 (1.00000)" :value="5"></DropdownItem>
<DropdownItem name="6 (1.000000)" :value="6"></DropdownItem>
<DropdownItem name="7 (1.0000000)" :value="7"></DropdownItem>
<DropdownItem name="8 (1.00000000)" :value="8"></DropdownItem>
<DropdownItem name="9 (1.000000000)" :value="9"></DropdownItem>
<DropdownItem name="10 (1.0000000000)" :value="10"></DropdownItem>
</Dropdown>
</div>
</div>
<div v-if="allowSetNumberNegative" class="control">
<div class="control__elements">
<Checkbox v-model="values.number_negative">{{
$t('fieldNumberSubForm.allowNegative')
}}</Checkbox>
</div>
</div>
</div>
</template>
<script>
import { required } from 'vuelidate/lib/validators'
import form from '@baserow/modules/core/mixins/form'
import fieldSubForm from '@baserow/modules/database/mixins/fieldSubForm'
export default {
name: 'FieldNumberSubForm',
mixins: [form, fieldSubForm],
props: {
allowSetNumberNegative: {
type: Boolean,
required: false,
default: true,
},
},
data() {
let allowedValues = ['number_decimal_places']
let values = { number_decimal_places: 0 }
if (this.allowSetNumberNegative) {
allowedValues = [...allowedValues, 'number_negative']
values = { ...values, number_negative: false }
}
return {
allowedValues,
values,
}
},
validations: {
values: {
number_decimal_places: { required },
},
},
}
</script>