All files / web/bundles/oroconfig/js/form/system/tab localization.js

100% Statements 17/17
100% Branches 0/0
100% Functions 6/6
100% Lines 17/17

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    2x                                     2x                         2x         2x             4x 4x   4x 4x   52x 52x         4x 4x     4x   4x                 1x 1x 1x          
"use strict";
 
define(
    [
        'underscore',
        'oro/translator',
        'pim/form',
        'pim/fetcher-registry',
        'oro/loading-mask',
        'oro/template/system/tab/localization',
        'pim/initselect2'
    ],
    function(
        _,
        __,
        BaseForm,
        FetcherRegistry,
        LoadingMask,
        template,
        initSelect2
    ) {
        return BaseForm.extend({
            events: {
                'change select': 'updateModel'
            },
            isGroup: true,
            label: __('oro_config.form.config.group.localization.title'),
            template: _.template(template),
            code: 'oro_config_localization',
 
            /**
             * {@inheritdoc}
             */
            configure: function () {
                this.trigger('tab:register', {
                    code: this.code,
                    label: this.label
                });
 
                return BaseForm.prototype.configure.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            render: function () {
                var loadingMask = new LoadingMask();
                loadingMask.render().$el.appendTo(this.getRoot().$el).show();
 
                FetcherRegistry.getFetcher('ui-locale').fetchAll().then(function (locales) {
                    this.$el.html(this.template({
                        locales: locales.reduce((result, locale) => {
                            result[locale.code] = locale.label;
                            return result;
                        }, {}),
                        selected: this.getFormData()['pim_ui___language'].value
                    }));
 
                    initSelect2.init(this.$('select'));
                    loadingMask.hide().$el.remove();
                }.bind(this));
 
                this.delegateEvents();
 
                return BaseForm.prototype.render.apply(this, arguments);
            },
 
            /**
             * Update model after value change
             *
             * @param {Event} event
             */
            updateModel: function (event) {
                var data = this.getFormData();
                data['pim_ui___language'].value = event.target.value;
                this.setData(data);
            }
        });
    }
);