2018-08-24 12:35:52 +02:00
|
|
|
import Mixin from '@ember/object/mixin';
|
|
|
|
import { get } from '@ember/object';
|
|
|
|
import { assert } from '@ember/debug';
|
|
|
|
export default Mixin.create({
|
|
|
|
resize: function(e) {
|
2018-09-21 10:18:32 +01:00
|
|
|
assert('with-resizing.resize needs to be overridden', false);
|
2018-08-24 12:35:52 +02:00
|
|
|
},
|
|
|
|
win: window,
|
|
|
|
init: function() {
|
|
|
|
this._super(...arguments);
|
|
|
|
this.handler = e => {
|
|
|
|
const win = e.target;
|
|
|
|
this.resize({
|
|
|
|
detail: { width: win.innerWidth, height: win.innerHeight },
|
|
|
|
});
|
|
|
|
};
|
|
|
|
},
|
|
|
|
didInsertElement: function() {
|
|
|
|
this._super(...arguments);
|
2018-09-21 10:18:32 +01:00
|
|
|
get(this, 'win').addEventListener('resize', this.handler, false);
|
2018-08-24 12:35:52 +02:00
|
|
|
this.didAppear();
|
|
|
|
},
|
|
|
|
didAppear: function() {
|
|
|
|
this.handler({ target: get(this, 'win') });
|
|
|
|
},
|
|
|
|
willDestroyElement: function() {
|
2018-09-21 10:18:32 +01:00
|
|
|
get(this, 'win').removeEventListener('resize', this.handler, false);
|
2018-08-24 12:35:52 +02:00
|
|
|
this._super(...arguments);
|
|
|
|
},
|
|
|
|
});
|