2016-08-31 23:30:51 +08:00
|
|
|
import { buildResolver } from 'discourse-common/resolver';
|
2016-07-04 01:33:05 +08:00
|
|
|
import { default as computed, observes } from 'ember-addons/ember-computed-decorators';
|
2014-08-07 23:47:45 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
const _pluginCallbacks = [];
|
2015-05-12 01:16:44 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
const Discourse = Ember.Application.extend({
|
2013-02-23 04:41:12 +08:00
|
|
|
rootElement: '#main',
|
2015-02-13 01:27:51 +08:00
|
|
|
_docTitle: document.title,
|
2016-04-26 03:55:15 +08:00
|
|
|
__TAGS_INCLUDED__: true,
|
2013-02-21 02:15:50 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
getURL(url) {
|
2015-07-16 05:00:11 +08:00
|
|
|
if (!url) return url;
|
2015-02-19 01:30:41 +08:00
|
|
|
|
2015-07-16 05:00:11 +08:00
|
|
|
// if it's a non relative URL, return it.
|
2015-10-22 01:13:19 +08:00
|
|
|
if (url !== '/' && !/^\/[^\/]/.test(url)) return url;
|
2013-05-08 01:30:12 +08:00
|
|
|
|
2015-09-07 11:20:59 +08:00
|
|
|
if (url.indexOf(Discourse.BaseUri) !== -1) return url;
|
|
|
|
if (url[0] !== "/") url = "/" + url;
|
2015-03-09 08:45:36 +08:00
|
|
|
|
2015-09-07 11:20:59 +08:00
|
|
|
return Discourse.BaseUri + url;
|
2013-03-14 20:01:52 +08:00
|
|
|
},
|
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
getURLWithCDN(url) {
|
2016-06-15 02:31:51 +08:00
|
|
|
url = Discourse.getURL(url);
|
2015-07-16 05:00:11 +08:00
|
|
|
// only relative urls
|
2015-07-16 01:24:23 +08:00
|
|
|
if (Discourse.CDN && /^\/[^\/]/.test(url)) {
|
2015-05-27 10:59:51 +08:00
|
|
|
url = Discourse.CDN + url;
|
|
|
|
} else if (Discourse.S3CDN) {
|
|
|
|
url = url.replace(Discourse.S3BaseUrl, Discourse.S3CDN);
|
|
|
|
}
|
2015-01-30 05:53:48 +08:00
|
|
|
return url;
|
|
|
|
},
|
|
|
|
|
2016-08-31 23:30:51 +08:00
|
|
|
Resolver: buildResolver('discourse'),
|
2013-06-04 04:12:24 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
@observes('_docTitle', 'hasFocus', 'notifyCount')
|
|
|
|
_titleChanged() {
|
|
|
|
let title = this.get('_docTitle') || Discourse.SiteSettings.title;
|
2014-06-17 09:32:59 +08:00
|
|
|
|
|
|
|
// if we change this we can trigger changes on document.title
|
|
|
|
// only set if changed.
|
2016-07-04 01:33:05 +08:00
|
|
|
if ($('title').text() !== title) {
|
2014-06-17 09:32:59 +08:00
|
|
|
$('title').text(title);
|
|
|
|
}
|
2013-06-03 08:38:57 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
const notifyCount = this.get('notifyCount');
|
2013-08-09 00:42:08 +08:00
|
|
|
if (notifyCount > 0 && !Discourse.User.currentProp('dynamic_favicon')) {
|
2016-07-04 01:33:05 +08:00
|
|
|
title = `(${notifyCount}) ${title}`;
|
2013-02-23 04:41:12 +08:00
|
|
|
}
|
2014-01-09 07:26:53 +08:00
|
|
|
|
2015-02-13 01:27:51 +08:00
|
|
|
document.title = title;
|
2016-07-04 01:33:05 +08:00
|
|
|
},
|
2013-02-21 02:15:50 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
@observes('notifyCount')
|
|
|
|
faviconChanged() {
|
|
|
|
if (Discourse.User.currentProp('dynamic_favicon')) {
|
|
|
|
let url = Discourse.SiteSettings.favicon_url;
|
2015-08-25 09:54:23 +08:00
|
|
|
if (/^http/.test(url)) {
|
|
|
|
url = Discourse.getURL("/favicon/proxied?" + encodeURIComponent(url));
|
|
|
|
}
|
2016-07-04 01:33:05 +08:00
|
|
|
new window.Favcount(url).set(this.get('notifyCount'));
|
2013-06-08 08:15:49 +08:00
|
|
|
}
|
2016-07-04 01:33:05 +08:00
|
|
|
},
|
2013-06-08 08:15:49 +08:00
|
|
|
|
2013-02-27 03:54:43 +08:00
|
|
|
// The classes of buttons to show on a post
|
2016-07-04 01:33:05 +08:00
|
|
|
@computed
|
|
|
|
postButtons() {
|
2013-02-27 03:54:43 +08:00
|
|
|
return Discourse.SiteSettings.post_menu.split("|").map(function(i) {
|
2015-08-12 05:34:02 +08:00
|
|
|
return i.replace(/\+/, '').capitalize();
|
2013-02-27 03:54:43 +08:00
|
|
|
});
|
2016-07-04 01:33:05 +08:00
|
|
|
},
|
2013-02-27 03:54:43 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
notifyTitle(count) {
|
2013-06-03 08:38:57 +08:00
|
|
|
this.set('notifyCount', count);
|
2013-02-23 04:41:12 +08:00
|
|
|
},
|
2013-02-21 02:15:50 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
notifyBackgroundCountIncrement() {
|
2015-09-21 06:28:45 +08:00
|
|
|
if (!this.get('hasFocus')) {
|
|
|
|
this.set('backgroundNotify', true);
|
|
|
|
this.set('notifyCount', (this.get('notifyCount') || 0) + 1);
|
|
|
|
}
|
|
|
|
},
|
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
@observes('hasFocus')
|
|
|
|
resetBackgroundNotifyCount() {
|
2015-09-21 06:28:45 +08:00
|
|
|
if (this.get('hasFocus') && this.get('backgroundNotify')) {
|
|
|
|
this.set('notifyCount', 0);
|
|
|
|
}
|
|
|
|
this.set('backgroundNotify', false);
|
2016-07-04 01:33:05 +08:00
|
|
|
},
|
2015-09-21 06:28:45 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
authenticationComplete(options) {
|
2013-05-31 02:12:33 +08:00
|
|
|
// TODO, how to dispatch this to the controller without the container?
|
2016-07-04 01:33:05 +08:00
|
|
|
const loginController = Discourse.__container__.lookup('controller:login');
|
2013-05-31 02:12:33 +08:00
|
|
|
return loginController.authenticationComplete(options);
|
2013-02-23 04:41:12 +08:00
|
|
|
},
|
2013-02-27 03:54:43 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
// Start up the Discourse application by running all the initializers we've defined.
|
|
|
|
start() {
|
2014-05-16 05:01:01 +08:00
|
|
|
|
2014-06-17 09:01:48 +08:00
|
|
|
$('noscript').remove();
|
|
|
|
|
2016-04-29 04:37:20 +08:00
|
|
|
Object.keys(requirejs._eak_seen).forEach(function(key) {
|
2015-08-12 05:34:02 +08:00
|
|
|
if (/\/pre\-initializers\//.test(key)) {
|
2016-07-04 01:33:05 +08:00
|
|
|
const module = require(key, null, null, true);
|
2014-05-29 03:32:42 +08:00
|
|
|
if (!module) { throw new Error(key + ' must export an initializer.'); }
|
|
|
|
Discourse.initializer(module.default);
|
|
|
|
}
|
2014-05-16 05:01:01 +08:00
|
|
|
});
|
|
|
|
|
2016-04-29 04:37:20 +08:00
|
|
|
Object.keys(requirejs._eak_seen).forEach(function(key) {
|
2015-08-12 05:34:02 +08:00
|
|
|
if (/\/initializers\//.test(key)) {
|
2016-07-04 01:33:05 +08:00
|
|
|
const module = require(key, null, null, true);
|
2015-08-12 05:34:02 +08:00
|
|
|
if (!module) { throw new Error(key + ' must export an initializer.'); }
|
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
const init = module.default;
|
|
|
|
const oldInitialize = init.initialize;
|
2015-08-12 05:34:02 +08:00
|
|
|
init.initialize = function(app) {
|
2015-08-18 23:10:50 +08:00
|
|
|
oldInitialize.call(this, app.container, Discourse);
|
2015-08-12 05:34:02 +08:00
|
|
|
};
|
|
|
|
|
|
|
|
Discourse.instanceInitializer(init);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
|
2016-03-19 02:41:27 +08:00
|
|
|
// Plugins that are registered via `<script>` tags.
|
2016-07-04 01:33:05 +08:00
|
|
|
const withPluginApi = require('discourse/lib/plugin-api').withPluginApi;
|
|
|
|
let initCount = 0;
|
2016-03-19 02:41:27 +08:00
|
|
|
_pluginCallbacks.forEach(function(cb) {
|
|
|
|
Discourse.instanceInitializer({
|
|
|
|
name: "_discourse_plugin_" + (++initCount),
|
|
|
|
after: 'inject-objects',
|
|
|
|
initialize: function() {
|
|
|
|
withPluginApi(cb.version, cb.code);
|
|
|
|
}
|
|
|
|
});
|
|
|
|
});
|
2016-06-15 02:31:51 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
const utils = require('discourse/lib/utilities');
|
2016-06-15 02:31:51 +08:00
|
|
|
Discourse.Utilities = {};
|
|
|
|
Object.keys(utils).forEach(function(k) {
|
|
|
|
Discourse.Utilities[k] = function() {
|
|
|
|
Ember.warn('Discourse.Utilities is deprecated. Import it as a module');
|
|
|
|
return utils[k].apply(utils, arguments);
|
|
|
|
};
|
|
|
|
});
|
2014-01-14 13:59:08 +08:00
|
|
|
},
|
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
@computed('currentAssetVersion', 'desiredAssetVersion')
|
|
|
|
requiresRefresh(currentAssetVersion, desiredAssetVersion) {
|
|
|
|
return desiredAssetVersion && currentAssetVersion !== desiredAssetVersion;
|
|
|
|
},
|
2014-01-15 09:07:42 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
_registerPluginCode(version, code) {
|
|
|
|
_pluginCallbacks.push({ version, code });
|
2016-03-19 02:41:27 +08:00
|
|
|
},
|
2015-08-12 05:34:02 +08:00
|
|
|
|
|
|
|
assetVersion: Ember.computed({
|
2016-07-04 01:33:05 +08:00
|
|
|
get() {
|
2015-08-12 05:34:02 +08:00
|
|
|
return this.get("currentAssetVersion");
|
|
|
|
},
|
2016-07-04 01:33:05 +08:00
|
|
|
set(key, val) {
|
2015-08-12 05:34:02 +08:00
|
|
|
if(val) {
|
|
|
|
if (this.get("currentAssetVersion")) {
|
|
|
|
this.set("desiredAssetVersion", val);
|
|
|
|
} else {
|
|
|
|
this.set("currentAssetVersion", val);
|
|
|
|
}
|
2014-01-14 13:59:08 +08:00
|
|
|
}
|
2015-08-12 05:34:02 +08:00
|
|
|
return this.get("currentAssetVersion");
|
2014-01-14 13:59:08 +08:00
|
|
|
}
|
2015-08-12 05:34:02 +08:00
|
|
|
})
|
2016-04-30 04:50:52 +08:00
|
|
|
}).create();
|
2015-02-27 04:54:39 +08:00
|
|
|
|
2016-07-04 01:33:05 +08:00
|
|
|
export default Discourse;
|