Skip to content
Snippets Groups Projects
FeatureExtraForm.vue 3.54 KiB
Newer Older
  <div v-if="field && field.field_type === 'char'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
      type="text"
      :name="field.name"
  <div v-else-if="field && field.field_type === 'list'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
    <Dropdown
      :options="field.options"
      :selected="selected_extra_form_list"
      :selection.sync="selected_extra_form_list"
    />
  </div>
  <div v-else-if="field && field.field_type === 'integer'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
    <div class="ui input">
      <!-- //* si click sur fléche dans champ input, pas de focus, donc pas de blur, donc utilisation de @change -->
      <input
        :id="field.name"
        type="number"
        :name="field.name"
  <div v-else-if="field && field.field_type === 'boolean'">
        :id="field.name"
        type="checkbox"
        :checked="field.value"
        :name="field.name"
        @change="updateStore_extra_form"
        {{ displayLabels ? field.label : '' }}
  <div v-else-if="field && field.field_type === 'date'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
      type="date"
      :name="field.name"
  <div v-else-if="field && field.field_type === 'decimal'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
        :id="field.name"
        type="number"
        step=".01"
        :name="field.name"
        @change="updateStore_extra_form"
  <div v-else-if="field && field.field_type === 'text'">
      :for="field.name"
    >
      {{ field.label }}
    </label>
      :name="field.name"
      rows="3"
      @blur="updateStore_extra_form"
import Dropdown from '@/components/Dropdown.vue';
  name: 'FeatureExtraForm',
Timothee P's avatar
Timothee P committed
  props: {
    field: {
      type: Object,
      default: null,
    }
  },
        return this.field.value || '';
      },
      set(newValue) {
        //* set the value selected in the dropdown
Florent Lavelle's avatar
Florent Lavelle committed
        const newExtraForm = this.field;
        newExtraForm['value'] = newValue;
        this.$store.commit('feature/UPDATE_EXTRA_FORM', newExtraForm);

    displayLabels() {
      return this.$route.name === 'editer-signalement' || this.$route.name === 'ajouter-signalement';
    }
Florent Lavelle's avatar
Florent Lavelle committed
      const newExtraForm = this.field;
      if (this.field.field_type === 'boolean') {
        newExtraForm['value'] = evt.target.checked; //* if checkbox use "checked"
        newExtraForm['value'] = evt.target.value;
      this.$store.commit('feature/UPDATE_EXTRA_FORM', newExtraForm);
Florent Lavelle's avatar
Florent Lavelle committed
</script>