2015-01-30 09:52:19 +08:00
|
|
|
import Ember from 'ember';
|
|
|
|
|
2015-02-03 14:29:53 +08:00
|
|
|
export var PositionEnum = {
|
|
|
|
HIDDEN: 'hidden',
|
|
|
|
NORMAL: 'normal',
|
|
|
|
MINIMIZED: 'minimized',
|
|
|
|
FULLSCREEN: 'fullscreen'
|
|
|
|
};
|
2015-01-30 09:52:19 +08:00
|
|
|
|
2015-02-03 14:29:53 +08:00
|
|
|
export default Ember.Controller.extend(Ember.Evented, {
|
2015-02-02 14:27:59 +08:00
|
|
|
content: null,
|
2015-02-03 14:29:53 +08:00
|
|
|
position: PositionEnum.HIDDEN,
|
2015-01-30 09:52:19 +08:00
|
|
|
|
2015-02-03 14:29:53 +08:00
|
|
|
visible: Ember.computed.or('normal', 'minimized', 'fullscreen'),
|
|
|
|
normal: Ember.computed.equal('position', PositionEnum.NORMAL),
|
|
|
|
minimized: Ember.computed.equal('position', PositionEnum.MINIMIZED),
|
|
|
|
fullscreen: Ember.computed.equal('position', PositionEnum.FULLSCREEN),
|
2015-02-02 14:27:59 +08:00
|
|
|
|
2015-02-03 14:29:53 +08:00
|
|
|
// Switch out the composer's content for a new component. The old
|
|
|
|
// component will be given the opportunity to abort the switch. Note:
|
|
|
|
// there appears to be a bug in Ember where the content binding won't
|
|
|
|
// update in the view if we switch the value out immediately. As a
|
|
|
|
// workaround, we set it to null, and then set it to its new value in the
|
|
|
|
// next run loop iteration.
|
2015-02-02 14:27:59 +08:00
|
|
|
switchContent: function(newContent) {
|
|
|
|
var composer = this;
|
|
|
|
this.confirmExit().then(function() {
|
|
|
|
composer.set('content', null);
|
|
|
|
Ember.run.next(function() {
|
|
|
|
composer.set('content', newContent);
|
|
|
|
});
|
|
|
|
});
|
|
|
|
},
|
2015-01-30 09:52:19 +08:00
|
|
|
|
2015-02-03 14:29:53 +08:00
|
|
|
// Ask the content component if it's OK to close it, and give it the
|
|
|
|
// opportunity to abort. The content component must respond to the
|
|
|
|
// `willExit(abort)` action, and call `abort()` if we should not proceed.
|
2015-02-02 14:27:59 +08:00
|
|
|
confirmExit: function() {
|
|
|
|
var composer = this;
|
|
|
|
var promise = new Ember.RSVP.Promise(function(resolve, reject) {
|
|
|
|
var content = composer.get('content');
|
|
|
|
if (content) {
|
|
|
|
content.send('willExit', reject);
|
|
|
|
}
|
|
|
|
resolve();
|
|
|
|
});
|
|
|
|
return promise;
|
|
|
|
},
|
2015-01-30 09:52:19 +08:00
|
|
|
|
|
|
|
actions: {
|
2015-02-03 14:29:53 +08:00
|
|
|
show: function() {
|
2015-02-02 14:27:59 +08:00
|
|
|
var composer = this;
|
2015-02-03 14:29:53 +08:00
|
|
|
|
|
|
|
// We do this in the next run loop because we need to wait for new
|
|
|
|
// content to be switched in. See `switchContent` above.
|
|
|
|
Ember.run.next(function() {
|
|
|
|
composer.set('position', PositionEnum.NORMAL);
|
|
|
|
composer.trigger('focus');
|
2015-02-02 14:27:59 +08:00
|
|
|
});
|
|
|
|
},
|
2015-02-03 14:29:53 +08:00
|
|
|
|
2015-02-02 14:27:59 +08:00
|
|
|
hide: function() {
|
2015-02-03 14:29:53 +08:00
|
|
|
this.set('position', PositionEnum.HIDDEN);
|
2015-02-02 14:27:59 +08:00
|
|
|
var content = this.get('content');
|
|
|
|
if (content) {
|
|
|
|
content.send('reset');
|
|
|
|
}
|
2015-01-30 09:52:19 +08:00
|
|
|
},
|
2015-02-03 14:29:53 +08:00
|
|
|
|
|
|
|
close: function() {
|
2015-02-02 14:27:59 +08:00
|
|
|
var composer = this;
|
2015-02-03 14:29:53 +08:00
|
|
|
this.confirmExit().then(function() {
|
|
|
|
composer.send('hide');
|
2015-02-02 14:27:59 +08:00
|
|
|
});
|
|
|
|
},
|
2015-02-03 14:29:53 +08:00
|
|
|
|
|
|
|
minimize: function() {
|
|
|
|
this.set('position', PositionEnum.MINIMIZED);
|
|
|
|
},
|
|
|
|
|
|
|
|
fullscreen: function() {
|
|
|
|
this.set('position', PositionEnum.FULLSCREEN);
|
2015-02-02 14:27:59 +08:00
|
|
|
this.trigger('focus');
|
2015-01-30 09:52:19 +08:00
|
|
|
},
|
2015-02-03 14:29:53 +08:00
|
|
|
|
|
|
|
exitFullscreen: function() {
|
|
|
|
this.set('position', PositionEnum.NORMAL);
|
2015-02-02 14:27:59 +08:00
|
|
|
this.trigger('focus');
|
2015-01-30 09:52:19 +08:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
});
|