OLD | NEW |
| (Empty) |
1 // Copyright (c) 2011 The Chromium Authors. All rights reserved. | |
2 // Use of this source code is governed by a BSD-style license that can be | |
3 // found in the LICENSE file. | |
4 | |
5 cr.define('media', function() { | |
6 | |
7 /** | |
8 * This class stores hashes by their id field and provides basic methods for | |
9 * iterating over the collection. | |
10 * @constructor | |
11 */ | |
12 function ItemStore() { | |
13 this.items_ = {}; | |
14 } | |
15 | |
16 ItemStore.prototype = { | |
17 /** | |
18 * Get a sorted list of item ids. | |
19 * @return {Array} A sorted array of ids. | |
20 */ | |
21 ids: function() { | |
22 var ids = []; | |
23 for (var i in this.items_) | |
24 ids.push(i); | |
25 return ids.sort(); | |
26 }, | |
27 | |
28 /** | |
29 * Add an item to the store. | |
30 * @param {Object} item The item to be added. | |
31 * @param {string} item.id The id of the item. | |
32 */ | |
33 addItem: function(item) { | |
34 this.items_[item.id] = item; | |
35 }, | |
36 | |
37 /** | |
38 * Add a dictionary of items to the store. | |
39 * @param {Object} items A dictionary of individual items. The keys are | |
40 * irrelevant but each must have an id field. | |
41 */ | |
42 addItems: function(items) { | |
43 for (id in items) | |
44 this.addItem(items[id]); | |
45 }, | |
46 | |
47 /** | |
48 * Remove an item from the store. | |
49 * @param {string} id The id of the item to be removed. | |
50 */ | |
51 removeItem: function(id) { | |
52 delete this.items_[id]; | |
53 }, | |
54 | |
55 /** | |
56 * Map this itemStore to an Array. Items are sorted by id. | |
57 * @param {function(*)} mapper The mapping function applied to each item. | |
58 * @return {Array} An array of mapped items. | |
59 */ | |
60 map: function(mapper) { | |
61 var items = this.items_; | |
62 var ids = this.ids(); | |
63 return ids.map(function(id) { return mapper(items[id]); }); | |
64 } | |
65 }; | |
66 | |
67 return { | |
68 ItemStore: ItemStore | |
69 }; | |
70 }); | |
OLD | NEW |