All files / web/bundles/pimui/js/group/form products.js

100% Statements 16/16
100% Branches 4/4
100% Functions 6/6
100% Lines 15/15

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                  8x                           8x             8x   8x             8x         8x             16x 8x                     8x 3x     8x 3x 3x       16x   16x          
'use strict';
 
/**
 * Module used to display the product datagrid in a group
 *
 * @author    Nicolas Dupont <nicolas@akeneo.com>
 * @copyright 2016 Akeneo SAS (http://www.akeneo.com)
 * @license   http://opensource.org/licenses/osl-3.0.php  Open Software License (OSL 3.0)
 */
define([
        'oro/translator',
        'pim/form',
        'pim/fetcher-registry',
        'pim/user-context',
        'pim/common/grid'
    ],
    function (
        __,
        BaseForm,
        FetcherRegistry,
        UserContext,
        Grid
    ) {
        return BaseForm.extend({
            className: 'products',
 
            /**
             * {@inheritdoc}
             */
            initialize: function (config) {
                this.config = config.config;
 
                BaseForm.prototype.initialize.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            configure: function () {
                this.trigger('tab:register', {
                    code: this.code,
                    label: __(this.config.label)
                });
 
                return BaseForm.prototype.configure.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            render: function () {
                if (!this.productGroupGrid) {
                    this.productGroupGrid = new Grid(
                        this.config.gridId,
                        {
                            locale: UserContext.get('catalogLocale'),
                            currentGroup: this.getFormData().meta.id,
                            id: this.getFormData().meta.id,
                            selection: this.getFormData().products,
                            selectionIdentifier: 'identifier'
                        }
                    );
 
                    this.productGroupGrid.on('grid:selection:updated', function (selection) {
                        this.setData('products', selection);
                    }.bind(this));
 
                    this.getRoot().on('pim_enrich:form:entity:post_fetch', () => {
                        const shouldRefresh = this.code === this.getParent().getCurrentTab()
                        if (shouldRefresh) this.productGroupGrid.refresh();
                    });
                }
 
                this.$el.empty().append(this.productGroupGrid.render().$el);
 
                this.renderExtensions();
            }
        });
    }
);