Your IP : 216.73.216.220


Current Path : /var/www/surf/TYPO3/vendor/mask/mask/Build/Sources/js/components/
Upload File :
Current File : /var/www/surf/TYPO3/vendor/mask/mask/Build/Sources/js/components/form-field.js

import Vue from 'vue';
import DateTimePicker from '@typo3/backend/date-time-picker.js';
import Colorpicker from './colorpicker.js';
import KeyValueList from './key-value-list.js';
import ItemList from './item-list.js';
import SelectMultipleSideBySide from './select-multiple-side-by-side.js';

export default Vue.component(
  'form-field',
  {
    components: {
      Colorpicker,
      KeyValueList,
      ItemList,
      SelectMultipleSideBySide,
    },
    props: {
      column: Number,
      tcaFields: Object,
      onlineMedia: Array,
      linkHandlerList: Array,
      tcaKey: String,
      global: Object,
      language: Object,
      icons: Object,
      fieldErrors: Object,
      forceRenderer: Function,
      isAllowedToOverride: Function,
      id: String
    },
    beforeMount: function () {
      // Load richtextConfiguration with presets
      if (this.tcaKey === 'config.richtextConfiguration') {
        this.tcaFields[this.tcaKey].items = this.global.richtextConfiguration;
      }
    },
    mounted: function () {
      // Initialize datepicker.
      if ((this.tcaKey in this.$refs) && this.$refs[this.tcaKey].classList.contains('t3js-datetimepicker')) {
        this.bootDateTimePicker();
      }

      if (this.global.activeField.name === 'timestamp' && this.tcaKey === 'config.default') {
        this.$watch(
          function () {
            return this.global.activeField.tca['config.eval'] ?? this.global.activeField.tca['config.format'];
          },
          function () {
            // Destroy bootstrap datepicker and remove data attributes added by TYPO3 DateTimePicker
            this.forceRenderer();
          }
        );
      }
    },
    methods: {
      bootDateTimePicker: function () {
        DateTimePicker.initialize(this.$refs[this.tcaKey]);
      },
      switchDependsOn: function (tcaKey, dependsOn) {
        if (!!dependsOn && this.global.activeField.tca[tcaKey] === this.valueOn) {
          this.global.activeField.tca[dependsOn] = 1;
        }
      },
      checkPrefixLangTitle: function (key) {
        if (key !== 'prefixLangTitle') {
          return true;
        }
        return ['string', 'text', 'richtext'].includes(this.global.activeField.name);
      },
    },
    computed: {
      field: function () {
        if (typeof this.tcaFields[this.tcaKey] === 'undefined') {
          return {available: false};
        }
        if (this.global.activeField.name in this.tcaFields[this.tcaKey]) {
          return this.tcaFields[this.tcaKey][this.global.activeField.name];
        } else if ('other' in this.tcaFields[this.tcaKey]) {
          return this.tcaFields[this.tcaKey]['other'];
        } else {
          return this.tcaFields[this.tcaKey];
        }
      },
      valueOn: function () {
        return 'valueOn' in this.field ? this.field.valueOn : 1;
      },
      valueOff: function () {
        return 'valueOff' in this.field ? this.field.valueOff : 0;
      },
      type: function () {
        if (this.field.type !== 'variable') {
          return this.field.type;
        }

        if ('types' in this.field) {
          if (this.global.activeField.name in this.field.types) {
            return this.field.types[this.global.activeField.name];
          }
          return 'text';
        }

        const formFieldMap = {
          'integer': 'number',
          'float': 'number',
          'date': 'date',
          'datetime': 'date',
          'timestamp': 'date',
          'text': 'textarea',
          'richtext': 'textarea',
          'colorpicker': 'colorpicker'
        };
        if (this.global.activeField.name in formFieldMap) {
          return formFieldMap[this.global.activeField.name];
        }
        return 'text';
      },
      dateType: function () {
        if (['date', 'datetime'].includes(this.global.activeField.name)) {
          return this.global.activeField.name;
        }
        if (this.global.activeField.name === 'timestamp') {
          return this.global.activeField.tca['config.eval'] ?? this.global.activeField.tca['config.format'];
        }
        return 'date';
      },
      hasError: function () {
        return (this.fieldErrors.emptyGroupAllowedFields.includes(this.global.activeField) && this.tcaKey === 'config.allowed')
          || (this.fieldErrors.emptyRadioItems.includes(this.global.activeField) && this.tcaKey === 'config.items')
      }
    },
    template: `
          <div v-if="field.available !== false" :class="['form-group', 'col-sm-12 col-xl-' + column, {'has-error': hasError}]">
            <label class="t3js-formengine-label form-label" :for="tcaKey">
                {{ field.label }}
            </label>
            <code :class="{'me-1': field.documentation !== ''}">[{{ field.code }}]</code><a v-if="field.documentation !== ''" :href="field.documentation" target="_blank" title="Show option in official TYPO3 documentation"><span v-html="icons.questionCircle"></span></a>
            <div class="t3js-formengine-field-item">
              <span class="formengine-field-item-description text-muted" v-if="field.description">{{ field.description }}</span>
              <div v-if="type == 'text'" class="form-control-wrap">
                <input :id="id" class="form-control" :placeholder="field.placeholder" v-model="global.activeField.tca[tcaKey]">
              </div>
              <div v-if="type == 'textarea'" class="form-control-wrap">
                <textarea :id="id" class="form-control" :placeholder="field.placeholder" :rows="field.rows" v-model="global.activeField.tca[tcaKey]"></textarea>
              </div>
              <div v-if="type == 'number'" class="form-control-wrap">
                <input v-model="global.activeField.tca[tcaKey]" :id="id" :placeholder="field.placeholder" :min="field.min" :max="field.max" :step="field.step" class="form-control" type="number">
              </div>
              <colorpicker v-if="type == 'colorpicker'" :global="global" :tcaKey="tcaKey"/>
              <div v-if="type == 'checkbox'" class="form-control-wrap">
                <div class="checkbox checkbox-type-toggle form-check form-switch" :class="{'checkbox-invert': field.invert}">
                    <input :id="id" class="checkbox-input form-check-input" v-model="global.activeField.tca[tcaKey]" type="checkbox" :true-value="valueOn" :false-value="valueOff" @change="switchDependsOn(tcaKey, field.dependsOn)">
                    <label class="checkbox-label form-check-label" :for="id">
                        <span class="checkbox-label-text form-check-label-text">[{{ global.activeField.tca[tcaKey] ? global.activeField.tca[tcaKey] : 0 }}]</span>
                    </label>
                </div>
              </div>
              <div v-if="type == 'select'" class="form-control-wrap">
                <select v-model="global.activeField.tca[tcaKey]" class="form-control form-select">
                    <option v-for="(item, key) in field.items" :value="key">{{ item }} <span v-if="key !== ''">[{{ key }}]</span></option>
                </select>
              </div>
              <div v-if="type == 'date'" class="form-control-wrap">
                <div class="input-group">
                    <div v-if="global.typo3Version < 12" class="form-control-clearable form-control">
                        <input :id="id" v-model="global.activeField.tca[tcaKey]" :ref="tcaKey" :data-date-type="dateType" class="t3js-datetimepicker form-control t3js-clearable flatpickr-input">
                    </div>
                    <div v-else class="form-control-clearable-wrapper">
                        <input :id="id" v-model="global.activeField.tca[tcaKey]" :ref="tcaKey" :data-date-type="dateType" class="t3js-datetimepicker form-control form-control-clearable t3js-clearable flatpickr-input">
                    </div>
                    <input type="hidden">
                    <span class="input-group-btn">
                        <label class="btn btn-default" :for="id" v-html="icons.date"></label>
                    </span>
                </div>
              </div>
              <div class="form-wizards-wrap" v-if="type == 'radio'">
                <div class="form-wizards-element">
                  <div v-if="checkPrefixLangTitle(value)" class="radio" v-for="(label, value) in field.items">
                      <label>
                          <input type="radio" v-model="global.activeField.tca[tcaKey]" :value="value"> {{ label }} <span v-if="value !== ''">[{{ value }}]</span></option>
                      </label>
                  </div>
                </div>
              </div>
              <p class="mask-shared-info" v-if="!isAllowedToOverride(this.tcaKey)">
                {{ language.multiuseTitle }}
                <small>{{ language.multiuseMessage }}</small>
              </p>
            </div>
            <div v-if="type == 'cTypes'" class="form-control-wrap">
              <select-multiple-side-by-side v-model="global.activeField.tca[tcaKey]" :items="global.ctypes" :language="language" :version="global.typo3Version"/>
            </div>
            <div v-if="type == 'onlineMedia'" class="form-control-wrap">
                <div class="form-wizards-wrap">
                    <div class="form-wizards-element">
                      <div v-for="media in onlineMedia" class="checkbox checkbox-type-toggle form-check form-switch">
                        <input :id="id + media" class="checkbox-input form-check-input" v-model="global.activeField.tca[tcaKey]" type="checkbox" :value="media">
                        <label class="checkbox-label form-check-label" :for="id + media">
                            <span class="checkbox-label-text form-check-label-text">[{{ media }}]</span>
                        </label>
                      </div>
                    </div>
                </div>
            </div>
            <div v-if="type == 'linkHandlerInverted'" class="form-control-wrap">
                <div class="form-wizards-wrap">
                    <div class="form-wizards-element row">
                      <div v-for="linkHandler in linkHandlerList" class="form-group col-sm-4">
                        <label class="t3js-formengine-label form-label" :for="id + linkHandler.identifier">{{ linkHandler.label }}</label>
                        <div class="checkbox checkbox-type-toggle form-check form-switch checkbox-invert">
                            <input :id="id + linkHandler.identifier" class="checkbox-input form-check-input" v-model="global.activeField.tca[tcaKey]" type="checkbox" :value="linkHandler.identifier">
                            <label class="checkbox-label form-check-label" :for="id + linkHandler.identifier">
                                <span class="checkbox-label-text form-check-label-text">[{{ linkHandler.identifier }}]</span>
                            </label>
                        </div>
                      </div>
                    </div>
                </div>
            </div>
            <div v-if="type == 'linkHandler'" class="form-control-wrap">
              <div class="form-wizards-wrap">
                <div class="form-wizards-element row">
                  <div v-for="linkHandler in linkHandlerList" class="form-group col-sm-4">
                    <label class="t3js-formengine-label form-label" :for="id + linkHandler.identifier">{{ linkHandler.label }}</label>
                    <div class="checkbox checkbox-type-toggle form-check form-switch">
                      <input :id="id + linkHandler.identifier" class="checkbox-input form-check-input" v-model="global.activeField.tca[tcaKey]" type="checkbox" :value="linkHandler.identifier">
                      <label class="checkbox-label form-check-label" :for="id + linkHandler.identifier">
                        <span class="checkbox-label-text form-check-label-text">[{{ linkHandler.identifier }}]</span>
                      </label>
                    </div>
                  </div>
                </div>
              </div>
            </div>
            <div v-if="type == 'foreign_table'" class="form-control-wrap">
              <select v-model="global.activeField.tca[tcaKey]" class="form-control form-select">
                <option v-for="(item, key) in global.foreignTables" :value="key">{{ key }} <span v-if="key !== ''">({{ item }})</span></option>
              </select>
            </div>
            <key-value-list v-model="global.activeField.tca[tcaKey]" v-if="type == 'keyValue'" :global="global" :tcaKey="tcaKey" :icons="icons" :tca-fields="tcaFields" :language="language"/>
            <item-list v-model="global.activeField.tca[tcaKey]" v-if="type == 'itemList'" :global="global" :tcaKey="tcaKey" :icons="icons" :tca-fields="tcaFields" :language="language"/>
          </div>
        `
  }
);