mirror of
https://github.com/TryGhost/Ghost.git
synced 2025-01-06 22:40:14 -05:00
Added fadeout to gh-popover
Closes #2868 - Uses jQuery's `.fadeOut` whenever a popover is closed. - Reordered `gh-popover`'s code into something a bit more logical and, if I may, pretty - Renamed `open` property into `isOpen`. `isOpen` should only be manipulated via `close()` and `open()` - Added `closing` property to help track state in the case of rapid clicks on a popover's button, allowing us to abort ` Added `open()` function
This commit is contained in:
parent
f114f4f2f6
commit
b1584f63c6
1 changed files with 46 additions and 24 deletions
|
@ -2,12 +2,55 @@ import PopoverMixin from 'ghost/mixins/popover-mixin';
|
|||
|
||||
var GhostPopover = Ember.Component.extend(PopoverMixin, {
|
||||
classNames: 'ghost-popover fade-in',
|
||||
classNameBindings: ['open'],
|
||||
classNameBindings: ['isOpen:open'],
|
||||
name: null,
|
||||
|
||||
//Don't manipulate isOpen directly! Use open() and close()
|
||||
isOpen: false,
|
||||
open: function () {
|
||||
this.set('closing', false);
|
||||
this.set('isOpen', true);
|
||||
},
|
||||
|
||||
//Helps us track if the menu was opened again right after
|
||||
// it was closed.
|
||||
closing: false,
|
||||
close: function () {
|
||||
var self = this;
|
||||
this.set('closing', true);
|
||||
this.$().fadeOut(200, function () {
|
||||
//Make sure this wasn't an aborted fadeout by
|
||||
//checking `closing`.
|
||||
if (self.get('closing')) {
|
||||
self.set('isOpen', false);
|
||||
self.set('closing', false);
|
||||
}
|
||||
});
|
||||
},
|
||||
//Called by the popover service when any popover button is clicked.
|
||||
toggle: function (options) {
|
||||
var isClosing = this.get('closing'),
|
||||
isOpen = this.get('isOpen'),
|
||||
name = this.get('name'),
|
||||
targetPopoverName = options.target;
|
||||
|
||||
if (name === targetPopoverName && (!isOpen || isClosing)) {
|
||||
this.open();
|
||||
} else if (isOpen) {
|
||||
this.close();
|
||||
}
|
||||
},
|
||||
|
||||
closeOnClick: false,
|
||||
click: function (event) {
|
||||
this._super(event);
|
||||
if (this.get('closeOnClick')) {
|
||||
return this.close();
|
||||
}
|
||||
},
|
||||
|
||||
didInsertElement: function () {
|
||||
this._super();
|
||||
|
||||
var popoverService = this.get('popover');
|
||||
|
||||
popoverService.on('close', this, this.close);
|
||||
|
@ -19,28 +62,7 @@ var GhostPopover = Ember.Component.extend(PopoverMixin, {
|
|||
|
||||
popoverService.off('close', this, this.close);
|
||||
popoverService.off('toggle', this, this.toggle);
|
||||
},
|
||||
click: function (event) {
|
||||
this._super(event);
|
||||
if (this.get('closeOnClick')) {
|
||||
return this.close();
|
||||
}
|
||||
},
|
||||
close: function () {
|
||||
return this.set('open', false);
|
||||
},
|
||||
toggle: function (options) {
|
||||
/*
|
||||
Close all popovers whose button was not clicked,
|
||||
and toggle the actual target.
|
||||
*/
|
||||
var targetPopoverName = options.target;
|
||||
if (this.get('name') === targetPopoverName) {
|
||||
this.toggleProperty('open');
|
||||
} else {
|
||||
this.close();
|
||||
}
|
||||
}
|
||||
});
|
||||
|
||||
export default GhostPopover;
|
||||
export default GhostPopover;
|
||||
|
|
Loading…
Reference in a new issue