// Copyright (c) 2012 The Chromium Authors. All rights reserved. // Use of this source code is governed by a BSD-style license that can be // found in the LICENSE file. // Custom bindings for the Media Gallery API. var mediaGalleriesNatives = requireNative('mediaGalleries'); var chromeHidden = requireNative('chrome_hidden').GetChromeHidden(); var mediaGalleriesMetadata = {}; chromeHidden.registerCustomHook('mediaGalleries', function(bindingsAPI, extensionId) { var apiFunctions = bindingsAPI.apiFunctions; // getMediaFileSystems uses a custom callback so that it can instantiate and // return an array of file system objects. apiFunctions.setCustomCallback('getMediaFileSystems', function(name, request, response) { var result = null; mediaGalleriesMetadata = {}; // Clear any previous metadata. if (response) { result = []; for (var i = 0; i < response.length; i++) { var filesystem = mediaGalleriesNatives.GetMediaFileSystemObject( response[i].fsid, response[i].name); result.push(filesystem); var metadata = response[i]; delete metadata.fsid; // TODO(vandebo) Until we remove the JSON name string (one release), we // need to pull out the real name part for metadata. metadata.name = JSON.parse(metadata.name).name; mediaGalleriesMetadata[filesystem.name] = metadata; } } if (request.callback) request.callback(result); request.callback = null; }); apiFunctions.setHandleRequest('getMediaFileSystemMetadata', function(filesystem) { if (filesystem && filesystem.name && mediaGalleriesMetadata[filesystem.name]) { return mediaGalleriesMetadata[filesystem.name]; } return {}; }); });