/* * Copyright 2005 Richard Wilson <info@tinct.net> * Copyright 2010, 2011 Stephen Fryatt <stevef@netsurf-browser.org> * * This file is part of NetSurf, http://www.netsurf-browser.org/ * * NetSurf is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; version 2 of the License. * * NetSurf is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program. If not, see <http://www.gnu.org/licenses/>. */ /** \file * Window toolbars (interface). */ #include <stdbool.h> #include "riscos/theme.h" #include "riscos/gui/button_bar.h" #include "riscos/gui/throbber.h" #include "riscos/gui/url_bar.h" #ifndef _NETSURF_RISCOS_TOOLBAR_H_ #define _NETSURF_RISCOS_TOOLBAR_H_ typedef enum { TOOLBAR_FLAGS_NONE = 0x00, TOOLBAR_FLAGS_DISPLAY = 0x01, TOOLBAR_FLAGS_EDIT = 0x02, } toolbar_flags; /** * Widget action types that the toolbar can pass on to clients. */ typedef enum { TOOLBAR_ACTION_NONE = 0, TOOLBAR_ACTION_BUTTON, TOOLBAR_ACTION_URL } toolbar_action_type; /** * Union to hold the different widget action data that can be passed * from widget via toolbar to client. */ union toolbar_action { button_bar_action button; url_bar_action url; }; struct toolbar; struct toolbar_callbacks { /** Call on theme update */ void (*theme_update)(void *, bool); /** Call on bar size change */ void (*change_size)(void *); /** Call to update button states */ void (*update_buttons)(void *); /** Call to handle user actions */ void (*user_action)(void *, toolbar_action_type, union toolbar_action); /** Call to handle keypresses. */ bool (*key_press)(void *, wimp_key *); /** Call on change to button order. */ void (*save_buttons)(void *, char *); }; #define ro_toolbar_menu_option_shade(toolbar) \ (((toolbar) == NULL) || ro_toolbar_get_editing(toolbar)) #define ro_toolbar_menu_buttons_tick(toolbar) \ (ro_toolbar_get_display_buttons(toolbar) || \ ro_toolbar_get_editing(toolbar)) #define ro_toolbar_menu_url_tick(toolbar) \ (ro_toolbar_get_display_url(toolbar)) #define ro_toolbar_menu_throbber_tick(toolbar) \ (ro_toolbar_get_display_throbber(toolbar)) #define ro_toolbar_menu_edit_shade(toolbar) ((toolbar) == NULL) #define ro_toolbar_menu_edit_tick(toolbar) (ro_toolbar_get_editing(toolbar)) /* The new toolbar API */ /** * Initialise the RISC OS toolbar widget. */ void ro_toolbar_init(void); /** * Create a new toolbar, ready to have widgets added and to be attached to * a window. If a parent window is supplied, then the toolbar module will * handle the window attachments; if NULL, it is up to the client to sort this * out for itself. * * \param *descriptor The theme to apply, or NULL for the default. * \param parent The window to attach the toolbar to, or NULL. * \param style The theme style to apply. * \param bar_flags Toolbar flags for the new bar. * \param *callbacks A client callback block, or NULL for none. * \param *client_data A data pointer to pass to callbacks, or NULL. * \param *help The Help token prefix for interactive help. * \return The handle of the new bar, or NULL on failure. */ struct toolbar *ro_toolbar_create(struct theme_descriptor *descriptor, wimp_w parent, theme_style style, toolbar_flags bar_flags, const struct toolbar_callbacks *callbacks, void *client_data, const char *help); /** * Add a button bar to a toolbar, and configure the buttons. * * \param *toolbar The toolbar to take the button bar. * \param buttons[] The button definitions. * \param *button_order The initial button order to use. * \return true if the action completed; else false. */ bool ro_toolbar_add_buttons(struct toolbar *toolbar, const struct button_bar_buttons buttons[], char *button_order); /** * Add a throbber to a toolbar. * * \param *toolbar The toolbar to take the throbber. * \return true if the action completed; else false. */ bool ro_toolbar_add_throbber(struct toolbar *toolbar); /** * Add a URL bar to a toolbar. * * \param *toolbar The toolbar to take the URL bar. * \return true if the action completed; else false. */ bool ro_toolbar_add_url(struct toolbar *toolbar); /** * (Re-)build a toolbar to use the specified (or current) theme. If false * is returned, the toolbar may not be complete and should be deleted. * * \param *toolbar The toolbar to rebuild. * \return true if the action was successful; else false. */ bool ro_toolbar_rebuild(struct toolbar *toolbar); /** * Attach or re-attach a toolbar to its parent window. * * \param *toolbar The toolbar to attach. * \param parent The window to attach the toolbar to. * \return true if the operation succeeded; else false. */ bool ro_toolbar_attach(struct toolbar *toolbar, wimp_w parent); /** * Process a toolbar, updating its contents for a size or content change. * * \param *toolbar The toolbar to update. * \param width The width to reformat to, or -1 to use parent. * \param reformat true to force a widget reflow; else false. * \return true if the operation succeeded; else false. */ bool ro_toolbar_process(struct toolbar *toolbar, int width, bool reformat); /** * Destroy a toolbar after use. * * \param *toolbar The toolbar to destroy. */ void ro_toolbar_destroy(struct toolbar *toolbar); /** * Change the client data associated with a toolbar's callbacks. * * \param *toolbar the toolbar whose data is to be updated. * \param *client_data the new client data, or NULL for none. */ void ro_toolbar_update_client_data(struct toolbar *toolbar, void *client_data); /** * Force the update of all toolbars buttons to reflect the current state. */ void ro_toolbar_update_all_buttons(void); /** * Refresh a toolbar after it has been updated * * \param toolbar the toolbar to update */ void ro_toolbar_refresh(struct toolbar *toolbar); /** * Force the update of all toolbars to reflect the application of a new theme. */ void ro_toolbar_theme_update(void); /** * Find the toolbar associated with a given RO window handle. * * \param w the window handle to look up. * \return the toolbar handle, or NULL if a match wasn't found. */ struct toolbar *ro_toolbar_parent_window_lookup(wimp_w w); /** * Find the toolbar using a given RO window handle for its pane. * * \param w the window (pane) handle to look up. * \return the toolbar handle, or NULL if a match wasn't found. */ struct toolbar *ro_toolbar_window_lookup(wimp_w w); /** * Return the RO window handle of the parent window for a toolbar. * * \param *toolbar the toolbar to look up. * \return the RO window handle of the parent. */ wimp_w ro_toolbar_get_parent_window(struct toolbar *toolbar); /** * Return the RO window handle of a toolbar. * * \param *toolbar the toolbar to look up. * \return the RO window handle of the bar. */ wimp_w ro_toolbar_get_window(struct toolbar *toolbar); /** * Return the current height of a toolbar, allowing for available window * space. * * \param *toolbar The toolbar of interest. * \return The current toolbar height in OS units. */ int ro_toolbar_height(struct toolbar *toolbar); /** * Return the full height that a toolbar could grow to, if space is available. * * \param *toolbar The toolbar of interest. * \return The full toolbar height in OS units. */ int ro_toolbar_full_height(struct toolbar *toolbar); /** * Starts a toolbar throbber, if there is one active. * * \param *toolbar the toolbar to start throbbing. */ void ro_toolbar_start_throbbing(struct toolbar *toolbar); /** * Stops a toolbar throbber, if there is one active. * * \param *toolbar the toolbar to stop throbbing. */ void ro_toolbar_stop_throbbing(struct toolbar *toolbar); /** * Animate a toolbar throbber, if there is one active. * * \param *toolbar the toolbar to throb. */ void ro_toolbar_throb(struct toolbar *toolbar); /** * Change the arrangement of buttons and spacers on a button bar within a * toolbar. * * \param *toolbar The toolbar to change. * \param order[] The new button configuration. * \return true of the order was updated; else false. */ bool ro_toolbar_set_button_order(struct toolbar *toolbar, char order[]); /** * Set the shaded state of a toolbar button. * * \param *toolbar the toolbar to update. * \param action the button action to update. * \param shaded true if the button should be shaded; else false. */ void ro_toolbar_set_button_shaded_state(struct toolbar *toolbar, button_bar_action action, bool shaded); /** * Give a toolbar input focus, placing the caret into the URL bar if one is * present. Currently a toolbar can only accept focus if it has a URL bar. * * \param *toolbar The toolbar to take the caret. * \return true if the caret was taken; else false. */ bool ro_toolbar_take_caret(struct toolbar *toolbar); /** * Set the content of a toolbar's URL field. * * \param *toolbar the toolbar to update. * \param *url the new url to insert. * \param is_utf8 true if the string is in utf8 encoding; false * if it is in local encoding. * \param set_caret true if the caret should be placed in the field; * else false. */ void ro_toolbar_set_url(struct toolbar *toolbar, const char *url, bool is_utf8, bool set_caret); /** * Return a pointer to the URL contained in a browser toolbar. If the toolbar * doesn't have a URL field, then NULL is returned instead. * * \param *toolbar The toolbar to look up the URL from. * \return pointer to the URL, or NULL. */ const char *ro_toolbar_get_url(struct toolbar *toolbar); /** * Return the current work area coordinates of the URL and favicon field's * bounding box. * * \param *toolbar The toolbar to look up. * \param *extent Return the coordinates. * \return true if successful; else false. */ bool ro_toolbar_get_url_field_extent(struct toolbar *toolbar, os_box *extent); /** * Update the favicon in a browser window toolbar to the supplied content, or * revert to using filetype-based icons. * * \param *toolbar The toolbar to refresh. * \param *h The new favicon to use, or NULL for none. */ void ro_toolbar_set_site_favicon(struct toolbar *toolbar, struct hlcache_handle *h); /** * Update the favicon in a browser window toolbar to reflect the RISC OS * filetype of the supplied content. If the toolbar currently has a * site favicon set, then this call will be ignored. * * \param *toolbar The toolbar to refresh. * \param *h The page content to reflect. */ void ro_toolbar_set_content_favicon(struct toolbar *toolbar, struct hlcache_handle *h); /** * Update the state of the URL suggestion pop-up menu icon on a toolbar. * * \param *toolbar The toolbar to update. */ void ro_toolbar_update_urlsuggest(struct toolbar *toolbar); /** * Set the display button bar state for a toolbar. * * \param *toolbar the toolbar to update. * \param display true to display the button bar; else false. */ void ro_toolbar_set_display_buttons(struct toolbar *toolbar, bool display); /** * Set the display URL bar state for a toolbar. * * \param *toolbar the toolbar to update. * \param display true to display the URL bar; else false. */ void ro_toolbar_set_display_url(struct toolbar *toolbar, bool display); /** * Set the display throbber state for a toolbar. * * \param *toolbar the toolbar to update. * \param display true to display the throbber; else false. */ void ro_toolbar_set_display_throbber(struct toolbar *toolbar, bool display); /** * Return true or false depending on whether the given toolbar is set to * display the button bar. * * \param *toolbar the toolbar of interest. * \return true if the toolbar exists and the button bar is * shown; else false. */ bool ro_toolbar_get_display_buttons(struct toolbar *toolbar); /** * Return true or false depending on whether the given toolbar is set to * display the URL bar. * * \param *toolbar the toolbar of interest. * \return true if the toolbar exists and the URL bar is * shown; else false. */ bool ro_toolbar_get_display_url(struct toolbar *toolbar); /** * Return true or false depending on whether the given toolbar is set to * display the throbber. * * \param *toolbar the toolbar of interest. * \return true if the toolbar exists and the throbber is * shown; else false. */ bool ro_toolbar_get_display_throbber(struct toolbar *toolbar); /** * Return true or false depending on whether the given toolbar is currently * being edited. * * \param *toolbar the toolbar of interest. * \return true if the toolbar exists and is beng edited; * else false. */ bool ro_toolbar_get_editing(struct toolbar *toolbar); /** * Toggle toolbar edit mode on the given toolbar. Only a button bar can be * edited, so edit mode can only be toggled if there's an editor button * bar defined. * * \param *toolbar The toolbar to be toggled. * \return true if the action was successful; false if * the action failed and the toolbar was destroyed. */ bool ro_toolbar_toggle_edit(struct toolbar *toolbar); #endif