All files / web/bundles/pimui/js/mass-edit/form/product mass-edit-field.js

100% Statements 8/8
100% Branches 2/2
100% Functions 1/1
100% Lines 8/8

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                    89x             89x             440x   440x             440x           440x             40x                 18x          
/**
 * This module displays a family with select2 for mass edit
 * The difference with standard select2 async is that this will listen to an event to enable or disable the element.
 *
 * @author    Pierre Allard <pierre.allard@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(
    [
        'pim/form/common/fields/simple-select-async'
    ],
    function (
        SimpleSelectAsync,
    ) {
        return SimpleSelectAsync.extend({
            readOnly: false,
 
            /**
             * {@inheritdoc}
             */
            initialize() {
                SimpleSelectAsync.prototype.initialize.apply(this, arguments);
 
                this.readOnly = false;
            },
 
            /**
             * {@inheritdoc}
             */
            configure() {
                this.listenTo(
                    this,
                    'mass-edit:update-read-only',
                    this.setReadOnly.bind(this)
                );
 
                return SimpleSelectAsync.prototype.configure.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            isReadOnly() {
                return this.readOnly || SimpleSelectAsync.prototype.isReadOnly.apply(this, arguments);
            },
 
            /**
             * Updates the readOnly parameter to avoid edition of the field
             *
             * @param {Boolean} readOnly
             */
            setReadOnly(readOnly) {
                this.readOnly = readOnly;
            }
        });
    }
);