Preserve order of tags as entered by the user.

Closes #3133
- Implement an ordered set for the tags property of the tag
  input controller.  Set order is by order added to the post.
This commit is contained in:
Jason Williams 2014-07-29 02:16:21 +00:00
parent cc471aedcb
commit 7a7138e534
2 changed files with 36 additions and 5 deletions

View File

@ -1,6 +1,33 @@
var PostTagsInputController = Ember.Controller.extend({ var PostTagsInputController = Ember.Controller.extend({
tags: Ember.computed.alias('parentController.tags'), tagEnteredOrder: Ember.A(),
tags: Ember.computed('parentController.tags', function () {
var proxyTags = Ember.ArrayProxy.create({
content: this.get('parentController.tags')
}),
temp = proxyTags.get('arrangedContent').slice();
proxyTags.get('arrangedContent').clear();
this.get('tagEnteredOrder').forEach(function (tagName) {
var tag = temp.find(function (tag) {
return tag.get('name') === tagName;
});
if (tag) {
proxyTags.get('arrangedContent').addObject(tag);
temp.removeObject(tag);
}
});
temp.forEach(function (tag) {
proxyTags.get('arrangedContent').addObject(tag);
});
return proxyTags;
}),
suggestions: null, suggestions: null,
newTagText: null, newTagText: null,
@ -36,21 +63,25 @@ var PostTagsInputController = Ember.Controller.extend({
// otherwise create a new one // otherwise create a new one
newTag = this.store.createRecord('tag'); newTag = this.store.createRecord('tag');
newTag.set('name', newTagText); newTag.set('name', newTagText);
this.get('tags').pushObject(newTag);
this.send('addTag', newTag);
} }
this.send('reset'); this.send('reset');
}, },
addTag: function (tag) { addTag: function (tag) {
if (!Ember.isEmpty(tag) && !this.hasTag(tag.get('name'))) { if (!Ember.isEmpty(tag)) {
this.get('tags').pushObject(tag); this.get('tags').addObject(tag);
this.get('tagEnteredOrder').addObject(tag.get('name'));
} }
this.send('reset'); this.send('reset');
}, },
deleteTag: function (tag) { deleteTag: function (tag) {
this.get('tags').removeObject(tag); this.get('tags').removeObject(tag);
this.get('tagEnteredOrder').removeObject(tag.get('name'));
}, },
deleteLastTag: function () { deleteLastTag: function () {

View File

@ -1,6 +1,6 @@
<label class="tag-label" for="tags" title="Tags"><span class="hidden">Tags</span></label> <label class="tag-label" for="tags" title="Tags"><span class="hidden">Tags</span></label>
<div class="tags"> <div class="tags">
{{#each tags}} {{#each controller.tags}}
{{#view view.tagView tag=this}} {{#view view.tagView tag=this}}
{{view.tag.name}} {{view.tag.name}}
{{/view}} {{/view}}