Use stable sort for item lists

This commit is contained in:
Toby Zerner 2015-07-22 09:55:36 +09:30
parent 3e4b30695e
commit c60e37d88c

View File

@ -19,7 +19,7 @@ export default class ItemList {
* priority will be positioned before items with a lower priority. * priority will be positioned before items with a lower priority.
* @public * @public
*/ */
add(key, content, priority) { add(key, content, priority = 0) {
this[key] = new Item(content, priority); this[key] = new Item(content, priority);
} }
@ -52,10 +52,18 @@ export default class ItemList {
if (this.hasOwnProperty(i) && this[i] instanceof Item) { if (this.hasOwnProperty(i) && this[i] instanceof Item) {
this[i].content.itemName = i; this[i].content.itemName = i;
items.push(this[i]); items.push(this[i]);
this[i].key = items.length;
} }
} }
return items.sort((a, b) => b.priority - a.priority).map(item => item.content); return items.sort((a, b) => {
if (a.priority === b.priority) {
return a.key - b.key;
} else if (a.priority > b.priority) {
return -1;
}
return 1;
}).map(item => item.content);
} }
} }