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 }); 71