All files / web/bundles/pimui/js/form/common main-image.js

93.33% Statements 14/15
87.5% Branches 7/8
100% Functions 4/4
93.33% Lines 14/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                1126x                         1126x                 1958x   1958x             825x             2601x       2601x   2601x                 2938x 1770x     1168x   1168x 88x     1080x          
'use strict';
/**
 * Main image extension
 *
 * @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)
 */
define(
    [
        'underscore',
        'pim/form',
        'pim/template/form/main-image',
        'pim/media-url-generator'
    ],
    function (
        _,
        BaseForm,
        template,
        MediaUrlGenerator
    ) {
        return BaseForm.extend({
            tagName: 'img',
            className: 'AknTitleContainer-image',
            template: _.template(template),
 
            /**
             * {@inheritdoc}
             */
            initialize: function (config) {
                this.config = config.config;
 
                BaseForm.prototype.initialize.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            configure() {
                this.listenTo(this.getRoot(), 'pim_enrich:form:entity:post_fetch', this.render.bind(this));
            },
 
            /**
             * {@inheritdoc}
             */
            render: function () {
                Iif (null === this.getPath()) {
                    return;
                }
 
                this.el.src = this.getPath();
 
                return BaseForm.prototype.render.apply(this, arguments);
            },
 
            /**
             * Returns the path of the image to display
             *
             * @returns {string}
             */
            getPath: function () {
                if (undefined !== this.config.path) {
                    return this.config.path;
                }
 
                const filePath = _.result(this.getFormData().meta.image, 'filePath', null);
 
                if (filePath === null && undefined !== this.config.fallbackPath) {
                    return this.config.fallbackPath;
                }
 
                return MediaUrlGenerator.getMediaShowUrl(filePath, 'thumbnail_small');
            }
        });
    }
);