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();
}
});
}
);
|