New widget for a button that displays a folder selection in a standard

* evolution-folder-selector-button.c: New widget for a button that
	displays a folder selection in a standard form, and when clicked
	lets the user select a new folder.

	* Evolution-Shell.idl (FolderSelectionListener:notifySelected):
	Make this take an Evolution:Folder instead of a pair of uris.
	(Shell:getIconByType): New method to get the icon for a type from
	the folder type registry.

	* Evolution-common.idl (Folder): add "evolutionUri" to the folder
	structure.

	* Evolution-Storage.idl (StorageRegistry:getFolderByUri): get an
	Evolution:Folder for a given uri.

	* evolution-shell-client.c
	(evolution_shell_client_user_select_folder): Update this to
	reflect the IDL change: return a GNOME_Evolution_Folder instead of
	a pair of URIs. Make sure it always sets *@folder_return to %NULL
	if it fails (even if it's a g_return_if_fail).
	(evolution_shell_client_get_storage_registry_interface): New.
	(evolution_shell_client_get_pixbuf_for_type): New. Uses
	Shell_getIconByType, but caches results.

	* e-shell.c (folder_selection_dialog_folder_selected_cb): Update
	for API change. (Return a GNOME_Evolution_Folder.)
	(impl_Shell_getIconByType): Implement.

	* e-corba-storage-registry.c
	(impl_StorageRegistry_getFolderByUri): Implement.

	* evolution-storage.c (evolution_storage_new_folder): Add a
	(dummy) evolutionUri to the folder.

	* Makefile.am (libeshell_la_SOURCES): add
	evolution-folder-selector-button.c
	(eshellinclude_HEADERS): and .h

svn path=/trunk/; revision=16352
This commit is contained in:
Dan Winship
2002-04-04 20:01:31 +00:00
parent 97e99e459e
commit 54ddaa6e48
12 changed files with 712 additions and 75 deletions

View File

@ -41,6 +41,20 @@ module Evolution {
ShellComponent getComponentByType (in string type)
raises (NotReady, NotFound);
/**
* getIconByType:
* @type: name of a valid folder type
* @mini: whether or not to get a mini (16x16) icon
*
* Get an icon associated with a specific folder type.
*
* Return value: an Evolution::Icon interface for the
* component that handles @type.
*/
Icon getIconByType (in string type,
in boolean mini)
raises (NotReady, NotFound);
/**
* createNewView:
* @uri: URI for the view to open
@ -118,7 +132,7 @@ module Evolution {
};
interface FolderSelectionListener {
void notifySelected (in string uri, in string physical_uri);
void notifySelected (in Folder folder);
void notifyCanceled ();
};
};