Merge pull request #1438 from Elegios/composer_use_category_id

Make the composer and TopicCreator use category id instead of category name
This commit is contained in:
Robin Ward
2013-09-17 08:03:48 -07:00
7 changed files with 26 additions and 26 deletions
@@ -115,7 +115,7 @@ Discourse.ListController = Discourse.Controller.extend({
// Create topic button
createTopic: function() {
this.get('controllers.composer').open({
categoryName: this.get('category.name'),
categoryId: this.get('category.id'),
action: Discourse.Composer.CREATE_TOPIC,
draft: this.get('draft'),
draftKey: this.get('draft_key'),
@@ -121,10 +121,10 @@ Discourse.Composer = Discourse.Model.extend({
// reply is always required
if (this.get('missingReplyCharacters') > 0) return true;
if (this.get('canCategorize') && !Discourse.SiteSettings.allow_uncategorized_topics && !this.get('categoryName')) return true;
if (this.get('canCategorize') && !Discourse.SiteSettings.allow_uncategorized_topics && !this.get('categoryId')) return true;
return false;
}.property('loading', 'canEditTitle', 'titleLength', 'targetUsernames', 'replyLength', 'categoryName', 'missingReplyCharacters'),
}.property('loading', 'canEditTitle', 'titleLength', 'targetUsernames', 'replyLength', 'categoryId', 'missingReplyCharacters'),
/**
Is the title's length valid?
@@ -328,14 +328,14 @@ Discourse.Composer = Discourse.Model.extend({
}
this.setProperties({
categoryName: opts.categoryName || this.get('topic.category.name'),
categoryId: opts.categoryId || this.get('topic.category.id'),
archetypeId: opts.archetypeId || Discourse.Site.currentProp('default_archetype'),
metaData: opts.metaData ? Em.Object.create(opts.metaData) : null,
reply: opts.reply || this.get("reply") || ""
});
if (!this.get('categoryName') && !Discourse.SiteSettings.allow_uncategorized_topics && Discourse.Category.list().length > 0) {
this.set('categoryName', Discourse.Category.list()[0].get('name'));
if (!this.get('categoryId') && !Discourse.SiteSettings.allow_uncategorized_topics && Discourse.Category.list().length > 0) {
this.set('categoryId', Discourse.Category.list()[0].get('id'));
}
if (opts.postId) {
@@ -398,16 +398,9 @@ Discourse.Composer = Discourse.Model.extend({
var topic = this.get('topic');
topic.setProperties({
title: this.get('title'),
fancy_title: this.get('title')
fancy_title: this.get('title'),
category_id: parseInt(this.get('categoryId'), 10)
});
var category = Discourse.Category.list().findProperty('name', this.get('categoryName'));
if (category) {
topic.setProperties({
categoryName: category.get('name'),
category_id: category.get('id')
});
}
topic.save();
}
@@ -447,7 +440,7 @@ Discourse.Composer = Discourse.Model.extend({
var createdPost = Discourse.Post.create({
raw: this.get('reply'),
title: this.get('title'),
category: this.get('categoryName'),
category: this.get('categoryId'),
topic_id: this.get('topic.id'),
reply_to_post_number: post ? post.get('post_number') : null,
imageSizes: opts.imageSizes,
@@ -544,7 +537,7 @@ Discourse.Composer = Discourse.Model.extend({
reply: this.get('reply'),
action: this.get('action'),
title: this.get('title'),
categoryName: this.get('categoryName'),
categoryId: this.get('categoryId'),
postId: this.get('post.id'),
archetypeId: this.get('archetypeId'),
metaData: this.get('metaData'),
@@ -599,7 +592,7 @@ Discourse.Composer.reopenClass({
topic: topic,
action: draft.action,
title: draft.title,
categoryName: draft.categoryName,
categoryId: draft.categoryId,
postId: draft.postId,
archetypeId: draft.archetypeId,
reply: draft.reply,
@@ -30,7 +30,7 @@
{{#unless model.creatingPrivateMessage}}
<div class="category-input">
{{categoryChooser valueAttribute="name" value=model.categoryName}}
{{categoryChooser valueAttribute="id" value=model.categoryId}}
{{popupInputTip validation=view.categoryValidation shownAt=view.showCategoryTip}}
</div>
{{#if model.archetype.hasOptions}}