action-link.js 2.44 KB
Newer Older
Ketan's avatar
Ketan committed
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
/**
 * Copyright © Magento, Inc. All rights reserved.
 * See COPYING.txt for license details.
 */

define([
    'jquery',
    'jquery/ui'
], function ($) {
    'use strict';

    $.widget('mage.actionLink', {
        /**
         * Button creation
         * @protected
         */
        _create: function () {
            this._bind();
        },

        /**
         * Bind handler on button click
         * @protected
         */
        _bind: function () {
            var keyCode = $.ui.keyCode;

            this._on({
                /**
                 * @param {jQuery.Event} e
                 */
                mousedown: function (e) {
                    this._stopPropogation(e);
                },

                /**
                 * @param {jQuery.Event} e
                 */
                mouseup: function (e) {
                    this._stopPropogation(e);
                },

                /**
                 * @param {jQuery.Event} e
                 */
                click: function (e) {
                    this._stopPropogation(e);
                    this._triggerEvent();
                },

                /**
                 * @param {jQuery.Event} e
                 */
                keydown: function (e) {
                    switch (e.keyCode) {
                        case keyCode.ENTER:
                        case keyCode.NUMPAD_ENTER:
                            this._stopPropogation(e);
                            this._triggerEvent();
                            break;
                    }
                },

                /**
                 * @param {jQuery.Event} e
                 */
                keyup: function (e) {
                    switch (e.keyCode) {
                        case keyCode.ENTER:
                        case keyCode.NUMPAD_ENTER:
                            this._stopPropogation(e);
                            break;
                    }
                }
            });
        },

        /**
         * @param {Object} e - event object
         * @private
         */
        _stopPropogation: function (e) {
            e.stopImmediatePropagation();
            e.preventDefault();
        },

        /**
         * @private
         */
        _triggerEvent: function () {
            $(this.options.related || this.element)
                .trigger(this.options.event, this.options.eventData ? [this.options.eventData] : [{}]);
        }
    });

    return $.mage.actionLink;
});