mirror of
https://github.com/TryGhost/Ghost-Admin.git
synced 2023-12-14 02:33:04 +01:00
3c0516e824
Closes #2418, #2714 Ref #2446, #2565 - Added and injected `popover` service to globally control popovers - Added `gh-popover-button` component - Added `popover-mixin` for popover and popover-buttons to mixin - Added body-event-listener mixin for popover service to watch for body clicks with - Post settings and post save button both now use `gh-popover` - Added hacks to `ember-hacks.css` to make popovers work until ghost-ui consolidates functionality
38 lines
1.1 KiB
JavaScript
38 lines
1.1 KiB
JavaScript
/*
|
|
Code modified from Addepar/ember-widgets
|
|
https://github.com/Addepar/ember-widgets/blob/master/src/mixins.coffee#L39
|
|
*/
|
|
var BodyEventListener = Ember.Mixin.create({
|
|
bodyElementSelector: 'html',
|
|
bodyClick: Ember.K,
|
|
init: function () {
|
|
this._super();
|
|
return Ember.run.next(this, this._setupDocumentHandlers);
|
|
},
|
|
willDestroy: function () {
|
|
this._super();
|
|
return this._removeDocumentHandlers();
|
|
},
|
|
_setupDocumentHandlers: function () {
|
|
if (this._clickHandler) {
|
|
return;
|
|
}
|
|
var self = this;
|
|
this._clickHandler = function () {
|
|
return self.bodyClick();
|
|
};
|
|
return $(this.get('bodyElementSelector')).on('click', this._clickHandler);
|
|
},
|
|
_removeDocumentHandlers: function () {
|
|
$(this.get('bodyElementSelector')).off('click', this._clickHandler);
|
|
this._clickHandler = null;
|
|
},
|
|
/*
|
|
http://stackoverflow.com/questions/152975/how-to-detect-a-click-outside-an-element
|
|
*/
|
|
click: function (event) {
|
|
return event.stopPropagation();
|
|
}
|
|
});
|
|
|
|
export default BodyEventListener; |