all files / src/js/lite/ui/ PopoverUI.js

5.66% Statements 3/53
0% Branches 0/22
12.5% Functions 1/8
3.85% Lines 2/52
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                                                                                                                                                                                                
(function(global){global.wrappers['/Users/lqez/Dev/summernote/src/js/lite/ui/PopoverUI.js']=[function(require,module,exports,__dirname,__filename){ "use strict";
exports.__esModule = true;
var PopoverUI = /** @class */ (function () {
    function PopoverUI($node, options) {
        this.$node = $node;
        this.options = $.extend({}, {
            title: '',
            content: '',
            target: options.container,
            trigger: 'hover focus',
            placement: 'bottom'
        }, options);
        // create popover node
        this.$popover = $([
            '<div class="note-popover in">',
            ' <div class="note-popover-arrow" />',
            ' <div class="note-popover-content" />',
            '</div>',
        ].join(''));
        // define event
        if (this.options.trigger !== 'manual') {
            var showCallback_1 = this.show.bind(this);
            var hideCallback_1 = this.hide.bind(this);
            var toggleCallback_1 = this.toggle.bind(this);
            this.options.trigger.split(' ').forEach(function (eventName) {
                if (eventName === 'hover') {
                    $node.off('mouseenter').on('mouseenter', showCallback_1);
                    $node.off('mouseleave').on('mouseleave', hideCallback_1);
                }
                else if (eventName === 'click') {
                    $node.on('click', toggleCallback_1);
                }
                else if (eventName === 'focus') {
                    $node.on('focus', showCallback_1);
                    $node.on('blur', hideCallback_1);
                }
            });
        }
    }
    PopoverUI.prototype.show = function () {
        var $node = this.$node;
        var offset = $node.offset();
        var $popover = this.$popover;
        var content = this.options.content || $node.data('content');
        var placement = $node.data('placement') || this.options.placement;
        var dist = 6;
        $popover.addClass(placement);
        $popover.addClass('in');
        $popover.find('.note-popover-content').html(content);
        $popover.appendTo(this.options.target);
        var nodeWidth = $node.outerWidth();
        var nodeHeight = $node.outerHeight();
        var popoverWidth = $popover.outerWidth();
        var popoverHeight = $popover.outerHeight();
        if (placement === 'bottom') {
            $popover.css({
                top: offset.top + nodeHeight + dist,
                left: offset.left + (nodeWidth / 2 - popoverWidth / 2)
            });
        }
        else if (placement === 'top') {
            $popover.css({
                top: offset.top - popoverHeight - dist,
                left: offset.left + (nodeWidth / 2 - popoverWidth / 2)
            });
        }
        else if (placement === 'left') {
            $popover.css({
                top: offset.top + (nodeHeight / 2 - popoverHeight / 2),
                left: offset.left - popoverWidth - dist
            });
        }
        else if (placement === 'right') {
            $popover.css({
                top: offset.top + (nodeHeight / 2 - popoverHeight / 2),
                left: offset.left + nodeWidth + dist
            });
        }
    };
    PopoverUI.prototype.hide = function () {
        this.$popover.removeClass('in');
        this.$popover.remove();
    };
    PopoverUI.prototype.toggle = function () {
        if (this.$popover.hasClass('in')) {
            this.hide();
        }
        else {
            this.show();
        }
    };
    return PopoverUI;
}());
exports["default"] = PopoverUI;
 
},'src/js/lite/ui/PopoverUI.js',{}];})(this);
//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"PopoverUI.js","sourceRoot":"","sources":["PopoverUI.js"],"names":[],"mappings":"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","sourcesContent":["class PopoverUI {\n  constructor($node, options) {\n    this.$node = $node;\n    this.options = $.extend({}, {\n      title: '',\n      content: '',\n      target: options.container,\n      trigger: 'hover focus',\n      placement: 'bottom',\n    }, options);\n\n    // create popover node\n    this.$popover = $([\n      '<div class=\"note-popover in\">',\n      ' <div class=\"note-popover-arrow\" />',\n      ' <div class=\"note-popover-content\" />',\n      '</div>',\n    ].join(''));\n\n    // define event\n    if (this.options.trigger !== 'manual') {\n      const showCallback = this.show.bind(this);\n      const hideCallback = this.hide.bind(this);\n      const toggleCallback = this.toggle.bind(this);\n      this.options.trigger.split(' ').forEach(function(eventName) {\n        if (eventName === 'hover') {\n          $node.off('mouseenter').on('mouseenter', showCallback);\n          $node.off('mouseleave').on('mouseleave', hideCallback);\n        } else if (eventName === 'click') {\n          $node.on('click', toggleCallback);\n        } else if (eventName === 'focus') {\n          $node.on('focus', showCallback);\n          $node.on('blur', hideCallback);\n        }\n      });\n    }\n  }\n\n  show() {\n    const $node = this.$node;\n    const offset = $node.offset();\n    const $popover = this.$popover;\n    const content = this.options.content || $node.data('content');\n    const placement = $node.data('placement') || this.options.placement;\n    const dist = 6;\n\n    $popover.addClass(placement);\n    $popover.addClass('in');\n    $popover.find('.note-popover-content').html(content);\n    $popover.appendTo(this.options.target);\n\n    const nodeWidth = $node.outerWidth();\n    const nodeHeight = $node.outerHeight();\n    const popoverWidth = $popover.outerWidth();\n    const popoverHeight = $popover.outerHeight();\n\n    if (placement === 'bottom') {\n      $popover.css({\n        top: offset.top + nodeHeight + dist,\n        left: offset.left + (nodeWidth / 2 - popoverWidth / 2),\n      });\n    } else if (placement === 'top') {\n      $popover.css({\n        top: offset.top - popoverHeight - dist,\n        left: offset.left + (nodeWidth / 2 - popoverWidth / 2),\n      });\n    } else if (placement === 'left') {\n      $popover.css({\n        top: offset.top + (nodeHeight / 2 - popoverHeight / 2),\n        left: offset.left - popoverWidth - dist,\n      });\n    } else if (placement === 'right') {\n      $popover.css({\n        top: offset.top + (nodeHeight / 2 - popoverHeight / 2),\n        left: offset.left + nodeWidth + dist,\n      });\n    }\n  }\n\n  hide() {\n    this.$popover.removeClass('in');\n    this.$popover.remove();\n  }\n\n  toggle() {\n    if (this.$popover.hasClass('in')) {\n      this.hide();\n    } else {\n      this.show();\n    }\n  }\n}\n\nexport default PopoverUI;\n"]}