All files / web/bundles/pimui/js/menu user-navigation.js

80% Statements 12/15
50% Branches 2/4
66.67% Functions 4/6
80% Lines 12/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 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105                        1160x                                         1160x                       3604x   3604x             3669x               3669x           3669x 3669x   3669x                                               3669x 3669x 3669x              
'use strict';
 
/**
 * This extension will display the user navigation.
 * The user navigation contains:
 * - The link to display the user options
 * - The notification menu
 *
 * @author    Julien Sanchez <julien@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',
        'oro/translator',
        'pim/form',
        'pim/router',
        'pim/user-context',
        'pim/notifications',
        'pim/media-url-generator',
        'pim/template/menu/user-navigation'
    ],
    function (
        _,
        __,
        BaseForm,
        router,
        UserContext,
        Notifications,
        MediaUrlGenerator,
        template
    ) {
        return BaseForm.extend({
            className: 'AknTitleContainer-userMenu',
            template: _.template(template),
            events: {
                'click .logout': 'logout',
                'click .user-account': 'userAccount'
            },
 
            /**
             * {@inheritdoc}
             */
            initialize: function (config) {
                this.config = config.config;
 
                BaseForm.prototype.initialize.apply(this, arguments);
            },
 
            /**
             * {@inheritdoc}
             */
            render: function () {
                this.$el.html(this.template({
                    firstName: UserContext.get('first_name'),
                    lastName: UserContext.get('last_name'),
                    avatar: this.getAvatar(),
                    logoutLabel: __(this.config.logout),
                    userAccountLabel: __(this.config.userAccount)
                }));
 
                var notificationView = new Notifications({
                    imgUrl: 'bundles/pimimportexport/images/loading.gif',
                    loadingText: __('pim_common.loading'),
                    noNotificationsMessage: __('pim_notification.no_notifications'),
                    markAsReadMessage: __('pim_notification.mark_all_as_read')
                });
                notificationView.setElement(this.$('.notification')).render();
                notificationView.refresh();
 
                return BaseForm.prototype.render.apply(this, arguments);
            },
 
            /**
             * Redirect user to logout
             */
            logout: function () {
                window.location = router.generate('pim_user_logout_redirect');
            },
 
            /**
             * Redirect user it's account details
             */
            userAccount: function () {
                router.redirectToRoute(
                    'pim_user_edit',
                    {identifier: UserContext.get('meta').id}
                );
            },
 
            /**
             * Return user's avatar
             */
            getAvatar: function () {
                const filePath = UserContext.get('avatar').filePath;
                Eif (null === filePath || undefined === filePath) {
                    return null;
                }
 
                return MediaUrlGenerator.getMediaShowUrl(UserContext.get('avatar').filePath, 'thumbnail_small');
            }
        });
    });