ES6: `AvatarSelector` and `HeaderController` - also includes support for controllers with
camelcase via an error message.
This commit is contained in:
parent
a4e30e8f93
commit
eee5f85654
|
@ -7,7 +7,7 @@
|
|||
@uses Discourse.ModalFunctionality
|
||||
@module Discourse
|
||||
**/
|
||||
Discourse.AvatarSelectorController = Discourse.Controller.extend(Discourse.ModalFunctionality, {
|
||||
export default Discourse.Controller.extend(Discourse.ModalFunctionality, {
|
||||
|
||||
actions: {
|
||||
useUploadedAvatar: function() { this.set("use_uploaded_avatar", true); },
|
|
@ -6,7 +6,7 @@
|
|||
@namespace Discourse
|
||||
@module Discourse
|
||||
**/
|
||||
Discourse.HeaderController = Discourse.Controller.extend({
|
||||
export default Discourse.Controller.extend({
|
||||
topic: null,
|
||||
showExtraInfo: null,
|
||||
notifications: null,
|
|
@ -9,11 +9,29 @@
|
|||
**/
|
||||
Discourse.Resolver = Ember.DefaultResolver.extend({
|
||||
|
||||
/**
|
||||
For our ES6 modules, Discourse standardizes on dashed, lower case names.
|
||||
This method converts camelCase to that format.
|
||||
|
||||
@method normalizeName
|
||||
@param {String} name to convert
|
||||
@returns {String} the converted name
|
||||
|
||||
**/
|
||||
normalizeName: function(name) {
|
||||
return name.replace(/([a-z])([A-Z])/g, '$1-$2').replace('_', '-').toLowerCase();
|
||||
},
|
||||
|
||||
resolveController: function(parsedName) {
|
||||
var moduleName = "discourse/controllers/" + parsedName.fullNameWithoutType,
|
||||
var normalized = this.normalizeName(parsedName.fullNameWithoutType),
|
||||
moduleName = "discourse/controllers/" + normalized,
|
||||
module = requirejs.entries[moduleName];
|
||||
|
||||
if (module) {
|
||||
if (normalized !== parsedName.fullNameWithoutType) {
|
||||
Em.Logger.error(parsedName.fullNameWithoutType + " was used to look up an ES6 module. You should use " + normalized+ " instead.");
|
||||
}
|
||||
|
||||
module = require(moduleName, null, null, true /* force sync */);
|
||||
if (module && module['default']) { module = module['default']; }
|
||||
}
|
||||
|
|
|
@ -18,18 +18,17 @@ Discourse.PreferencesRoute = Discourse.RestrictedUserRoute.extend({
|
|||
|
||||
actions: {
|
||||
showAvatarSelector: function() {
|
||||
Discourse.Route.showModal(this, 'avatarSelector');
|
||||
Discourse.Route.showModal(this, 'avatar-selector');
|
||||
// all the properties needed for displaying the avatar selector modal
|
||||
var avatarSelector = this.modelFor('user').getProperties(
|
||||
this.controllerFor('avatar-selector').setProperties(this.modelFor('user').getProperties(
|
||||
'username', 'email',
|
||||
'has_uploaded_avatar', 'use_uploaded_avatar',
|
||||
'gravatar_template', 'uploaded_avatar_template');
|
||||
this.controllerFor('avatarSelector').setProperties(avatarSelector);
|
||||
'gravatar_template', 'uploaded_avatar_template'));
|
||||
},
|
||||
|
||||
saveAvatarSelection: function() {
|
||||
var user = this.modelFor('user');
|
||||
var avatarSelector = this.controllerFor('avatarSelector');
|
||||
var avatarSelector = this.controllerFor('avatar-selector');
|
||||
// sends the information to the server if it has changed
|
||||
if (avatarSelector.get('use_uploaded_avatar') !== user.get('use_uploaded_avatar')) {
|
||||
user.toggleAvatarSelection(avatarSelector.get('use_uploaded_avatar'));
|
||||
|
|
|
@ -4,10 +4,10 @@ var avatarSelector = Em.Object.create({
|
|||
uploaded_avatar_template: "//cdn.discourse.org/uploads/meta_discourse/avatars/093/607/185cff113e/{size}.jpg"
|
||||
});
|
||||
|
||||
module("Discourse.AvatarSelectorController");
|
||||
module("controller:avatar-selector");
|
||||
|
||||
test("avatarTemplate", function() {
|
||||
var avatarSelectorController = testController(Discourse.AvatarSelectorController);
|
||||
var avatarSelectorController = controllerFor('avatar-selector');
|
||||
avatarSelectorController.setProperties(avatarSelector);
|
||||
|
||||
equal(avatarSelectorController.get("avatarTemplate"),
|
||||
|
|
|
@ -1,4 +1,4 @@
|
|||
module("Discourse.HeaderController");
|
||||
module("controller:header", "Header Controller");
|
||||
|
||||
test("showNotifications action", function() {
|
||||
var resolveRequestWith;
|
||||
|
@ -7,7 +7,7 @@ test("showNotifications action", function() {
|
|||
});
|
||||
|
||||
|
||||
var controller = Discourse.HeaderController.create();
|
||||
var controller = controllerFor('header');
|
||||
var viewSpy = {
|
||||
showDropdownBySelector: sinon.spy()
|
||||
};
|
||||
|
|
|
@ -14,6 +14,11 @@ function setTemplates(lookupStrings) {
|
|||
});
|
||||
}
|
||||
|
||||
function normalized(input, expected, desc) {
|
||||
var resolver = Discourse.Resolver.create({namespace: Discourse});
|
||||
equal(resolver.normalizeName(input), expected, desc);
|
||||
}
|
||||
|
||||
module("Discourse.Resolver", {
|
||||
setup: function() {
|
||||
originalTemplates = Ember.TEMPLATES;
|
||||
|
@ -29,6 +34,12 @@ module("Discourse.Resolver", {
|
|||
}
|
||||
});
|
||||
|
||||
test("normalizeName", function() {
|
||||
normalized('header', 'header', 'a single word stays the same');
|
||||
normalized('avatarSelector', 'avatar-selector', 'camel case is converted to dashed');
|
||||
normalized('avatar_selector', 'avatar-selector', 'underscores are converted to dashes');
|
||||
});
|
||||
|
||||
test("finds templates in top level dir", function() {
|
||||
setTemplates([
|
||||
"foobar",
|
||||
|
|
Loading…
Reference in New Issue