All files / web/bundles/pimui/js/form/common/fields select.js

100% Statements 13/13
85.71% Branches 12/14
100% Functions 7/7
100% Lines 13/13

Press n or j to go to the next uncovered block, b, p or k for the previous block.

1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88              76x                           76x     11x 11x 11x                 177x 2x     177x                               175x             177x                 86x                   11x   11x        
/**
 * @author    Yohan Blain <yohan.blain@akeneo.com>
 * @copyright 2017 Akeneo SAS (http://www.akeneo.com)
 * @license   http://opensource.org/licenses/osl-3.0.php Open Software License (OSL 3.0)
 */
'use strict';
 
define([
    'jquery',
    'underscore',
    'pim/form/common/fields/field',
    'oro/translator',
    'pim/template/form/common/fields/select'
],
function (
    $,
    _,
    BaseField,
    __,
    template
) {
    return BaseField.extend({
        events: {
            'change select': function (event) {
                this.errors = [];
                this.updateModel(this.getFieldValue(event.target));
                this.getRoot().render();
            }
        },
        template: _.template(template),
 
        /**
         * {@inheritdoc}
         */
        renderInput: function (templateContext) {
            if (undefined === this.getModelValue() && _.has(this.config, 'defaultValue')) {
                this.updateModel(this.config.defaultValue);
            }
 
            return this.template(_.extend(templateContext, {
                value: this.getModelValue(),
                choices: this.formatChoices(this.config.choices || []),
                multiple: this.config.isMultiple,
                labels: {
                    defaultLabel: this.getDefaultLabel()
                }
            }));
        },
 
        /**
         * Returns the default label for empty value
         *
         * @returns {string}
         */
        getDefaultLabel: function () {
            return '';
        },
 
        /**
         * {@inheritdoc}
         */
        postRender: function () {
            this.$('select.select2').select2({
                allowClear: this.config.allowClear !== undefined ? this.config.allowClear : true
            });
        },
 
        /**
         * @param {Array} choices
         */
        formatChoices: function (choices) {
            return Array.isArray(choices) ?
                _.object(choices, choices) :
                _.mapObject(choices, __)
            ;
        },
 
        /**
         * {@inheritdoc}
         */
        getFieldValue: function (field) {
            const value = $(field).val();
 
            return this.config.isMultiple && null === value ? [] : value;
        }
    });
});