diff options
author | rginda@chromium.org <rginda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-07 22:53:01 +0000 |
---|---|---|
committer | rginda@chromium.org <rginda@chromium.org@0039d316-1c4b-4281-b951-d872f2087c98> | 2011-04-07 22:53:01 +0000 |
commit | b7fe05014e57b5859aad0749a0d5002e53831a16 (patch) | |
tree | 9cf968dd2246c13a951355ce128b52b380f69cd8 /chrome/browser | |
parent | 0150cfcb238a357ce4daaa9d9c6d5a4516f9a8eb (diff) | |
download | chromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.zip chromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.tar.gz chromium_src-b7fe05014e57b5859aad0749a0d5002e53831a16.tar.bz2 |
Make file manager work better as a component extension
This CL contains some changes necessary to make the file manager work better as a component extension (rather than just in the test harness.)
file_manager_dialogs.cc: turn off context menu
file_manager.css: add opacity transition, comments
file_manager.css: encode images as data: urls
file_manager.js: embed preview images, close window, fix path calculation
file_manager_dialogs.cc: allow closing, hide title
BUG=none
TEST=manual
Review URL: http://codereview.chromium.org/6816029
git-svn-id: svn://svn.chromium.org/chrome/trunk/src@80861 0039d316-1c4b-4281-b951-d872f2087c98
Diffstat (limited to 'chrome/browser')
-rw-r--r-- | chrome/browser/resources/file_manager/css/file_manager.css | 11 | ||||
-rw-r--r-- | chrome/browser/resources/file_manager/js/file_manager.js | 57 | ||||
-rw-r--r-- | chrome/browser/ui/views/file_manager_dialogs.cc | 3 |
3 files changed, 57 insertions, 14 deletions
diff --git a/chrome/browser/resources/file_manager/css/file_manager.css b/chrome/browser/resources/file_manager/css/file_manager.css index cacdce2..a80e51f 100644 --- a/chrome/browser/resources/file_manager/css/file_manager.css +++ b/chrome/browser/resources/file_manager/css/file_manager.css @@ -8,10 +8,12 @@ body { -webkit-box-flex: 1; -webkit-box-orient: vertical; + -webkit-transition: opacity 0.07s linear; -webkit-user-select: none; display: -webkit-box; height: 100%; margin: 0; + opacity: 0; padding: 0; position: absolute; width: 100%; @@ -154,7 +156,8 @@ body { /* The icon in the name column. */ .detail-icon { -webkit-margin-end: 3px; - background-image: url(../images/icon-unknown.png); + /* ../images/icon-unknown.png */ + background-image: url(); background-position: center; background-repeat: no-repeat; height: 24px; @@ -163,7 +166,8 @@ body { /* Icon for image files. */ .detail-icon[iconType="image"] { - background-image: url(../images/icon-image.png); + /* ../images/icon-image.png */ + background-image: url(); } /* The filename text in the preview pane. */ @@ -195,7 +199,8 @@ body { /* Checkboard background to distinguish images with alpha channels. */ .preview-img.transparent-background { - background-image: url(../images/preview-background.png); + /* ../images/preview-background.png */ + background-image: url(); } /* The selection summary text at the bottom of the preview pane. */ diff --git a/chrome/browser/resources/file_manager/js/file_manager.js b/chrome/browser/resources/file_manager/js/file_manager.js index 0171631..2407d40 100644 --- a/chrome/browser/resources/file_manager/js/file_manager.js +++ b/chrome/browser/resources/file_manager/js/file_manager.js @@ -41,9 +41,13 @@ function FileManager(dialogDom, filesystem, params) { this.initDom_(); this.initDialogType_(); - this.changeDirectory('/'); + // TODO(rginda): Fix this when we've got the root dir sorted out. + // http://code.google.com/p/chromium-os/issues/detail?id=13845 + this.changeDirectory('/tmp'); this.summarizeSelection_(); this.updatePreview_(); + + this.table.querySelector('.list').focus(); } FileManager.prototype = { @@ -56,11 +60,6 @@ FileManager.prototype = { // Private variables and helper functions. /** - * Directory where we can find icons. - */ - const ICON_PATH = 'images/'; - - /** * Unicode codepoint for 'BLACK RIGHT-POINTING SMALL TRIANGLE'. */ const RIGHT_TRIANGLE = '\u25b8'; @@ -88,6 +87,26 @@ FileManager.prototype = { }; /** + * Canned preview images for non-image files. + * + * When we're built as a component extension we won't be able to access urls + * that haven't been explicitly packed into the resource bundle. It's + * simpler to pack them here as data: urls than it is to maintain code that + * maps urls into the resource bundle. Please make sure to check any new + * source images, and refer to the file in the comment here. + * + * Pro Tip: On *nix, the base64 command line tool can be used to base64 + * encode arbitrary files. + */ + const previewArt = { + // ../images/preview-unknown.png + 'unknown': '', + + // ../images/preview-folder.png + 'folder': '', + }; + + /** * Return a translated string. * * Wrapper function to make dealing with translated strings more concise. @@ -125,8 +144,8 @@ FileManager.prototype = { if (entry.isDirectory) return 'folder'; - for (var name in this.iconTypes) { - var value = this.iconTypes[name]; + for (var name in iconTypes) { + var value = iconTypes[name]; if (value instanceof RegExp) { if (value.test(entry.name)) @@ -332,6 +351,8 @@ FileManager.prototype = { 'dblclick', this.onDetailDoubleClick_.bind(this)); this.table.selectionModel.addEventListener( 'change', this.onDetailSelectionChanged_.bind(this)); + + this.dialogDom_.style.opacity = '1'; }; /** @@ -600,9 +621,10 @@ FileManager.prototype = { var iconType = getIconType(entry); if (iconType != 'image') { // Not an image, display a canned clip-art graphic. - this.previewImage_.src = ICON_PATH + 'preview-' + iconType + '.png'; + this.previewImage_.src = previewArt[iconType]; } else { // File is an image, fetch the thumbnail. + var fileManager = this; batchAsyncCall(entry, 'file', function(file) { @@ -725,6 +747,9 @@ FileManager.prototype = { if (entry.isDirectory) return this.changeDirectory(entry.fullPath); + if (!this.okButton_.disabled) + this.onOk_(); + }; /** @@ -738,11 +763,19 @@ FileManager.prototype = { function onReadSome(entries) { if (entries.length == 0) - return; + return; // Splice takes the to-be-spliced-in array as individual parameters, // rather than as an array, so we need to perform some acrobatics... var spliceArgs = [].slice.call(entries); + + // Hide files that start with a dot ('.'). + // TODO(rginda): User should be able to override this. Support for other + // commonly hidden patterns might be nice too. + spliceArgs = spliceArgs.filter(function(e) { + return e.name.substr(0, 1) != '.'; + }); + spliceArgs.unshift(0, 0); // index, deleteCount self.table.dataModel.splice.apply(self.table.dataModel, spliceArgs); @@ -787,6 +820,7 @@ FileManager.prototype = { */ FileManager.prototype.onCancel_ = function(event) { chrome.fileBrowserPrivate.cancelDialog(); + window.close(); }; /** @@ -807,6 +841,7 @@ FileManager.prototype = { chrome.fileBrowserPrivate.selectFile(this.currentDirEntry_.fullPath + '/' + filename, 0); + window.close(); return; } @@ -832,6 +867,7 @@ FileManager.prototype = { // Multi-file selection has no other restrictions. if (this.dialogType_ == FileManager.DialogType.SELECT_OPEN_FILES) { chrome.fileBrowserPrivate.selectFiles(ary); + window.close(); return; } @@ -848,6 +884,7 @@ FileManager.prototype = { } chrome.fileBrowserPrivate.selectFile(ary[0], 0); + window.close(); }; })(); diff --git a/chrome/browser/ui/views/file_manager_dialogs.cc b/chrome/browser/ui/views/file_manager_dialogs.cc index 062bcc1..98b2952 100644 --- a/chrome/browser/ui/views/file_manager_dialogs.cc +++ b/chrome/browser/ui/views/file_manager_dialogs.cc @@ -118,12 +118,13 @@ class FileManagerDialog // windows.close() and you've allowed that. If the output parameter // is set to true, then the dialog is closed. The default is false. virtual void OnCloseContents(TabContents* source, bool* out_close_dialog) { + *out_close_dialog = true; } // A callback to allow the delegate to dictate that the window should not // have a title bar. This is useful when presenting branded interfaces. virtual bool ShouldShowDialogTitle() const { - return true; + return false; } // A callback to allow the delegate to inhibit context menu or show |