1234567891011121314151617181920212223242526272829303132333435363738394041424344454647 |
- import Ember from 'ember';
- export default Ember.Service.extend({
- includedJs: false,
- loadedJs: false,
- load: function() {
- if (!this.get('includedJs')) {
- this._includeJs();
- }
- if (!this.get('loadedJs')) {
- return this._loadingPromise();
- } else {
- return this._loadedPromise();
- }
- },
- _includeJs: function() {
- this.loader.require('misago/js/cropit.js');
- this.set('includedJs', true);
- },
- _loadingPromise: function() {
- var self = this;
- return new Ember.RSVP.Promise(function(resolve) {
- var wait = function() {
- if (typeof Ember.$.fn.cropit === "undefined") {
- Ember.run.later(function () {
- wait();
- }, 200);
- } else {
- self.set('loadedJs', true);
- Ember.run(null, resolve);
- }
- };
- wait();
- });
- },
- _loadedPromise: function() {
- // we have already loaded croppic.js, resolve away!
- return new Ember.RSVP.Promise(function(resolve) {
- Ember.run(null, resolve);
- });
- }
- });
|