mirror of
https://github.com/netsurf-browser/netsurf
synced 2024-12-21 03:32:35 +03:00
Add web search bar to haiku frontend
This commit is contained in:
parent
f266eb1c5d
commit
9a64e9302e
@ -99,7 +99,7 @@ RDEF_IMP_BEOS := $(addprefix $(OBJROOT)/,$(subst /,_,$(RDEF_IMP_BEOS)))
|
||||
RDEP_BEOS := \
|
||||
adblock.css beosdefault.css default.css internal.css quirks.css \
|
||||
netsurf.png favicon.png ca-bundle.txt \
|
||||
credits.html licence.html welcome.html maps.html
|
||||
credits.html licence.html welcome.html maps.html SearchEngines
|
||||
RDEP_BEOS := $(addprefix beos/res/,$(RDEP_BEOS)) \
|
||||
$(wildcard beos/res/icons/*.png) \
|
||||
$(wildcard beos/res/??/*) \
|
||||
|
@ -1,4 +1,5 @@
|
||||
/*
|
||||
* Copyright 2015 Adrián Arroyo Calle <adrian.arroyocalle@gmail.com>
|
||||
* Copyright 2008 François Revol <mmu_man@users.sourceforge.net>
|
||||
* Copyright 2005 James Bursa <bursa@users.sourceforge.net>
|
||||
*
|
||||
@ -137,6 +138,7 @@ NSBrowserApplication::MessageReceived(BMessage *message)
|
||||
case 'home':
|
||||
case 'urlc':
|
||||
case 'urle':
|
||||
case 'sear':
|
||||
case 'menu':
|
||||
// NetPositive messages
|
||||
case B_NETPOSITIVE_OPEN_URL:
|
||||
@ -254,7 +256,7 @@ image_id nsbeos_find_app_path(char *path)
|
||||
* \param def default to return if file not found
|
||||
* \return path to resource.
|
||||
*/
|
||||
static char *find_resource(char *buf, const char *filename, const char *def)
|
||||
char *find_resource(char *buf, const char *filename, const char *def)
|
||||
{
|
||||
const char *cdir = NULL;
|
||||
status_t err;
|
||||
|
@ -1,4 +1,5 @@
|
||||
/*
|
||||
* Copyright 2015 Adrián Arroyo Calle <adrian.arroyocalle@gmail.com>
|
||||
* Copyright 2008 François Revol <mmu_man@users.sourceforge.net>
|
||||
* Copyright 2005 James Bursa <bursa@users.sourceforge.net>
|
||||
*
|
||||
@ -65,6 +66,7 @@ void nsbeos_pipe_message_top(BMessage *message, BWindow *_this, struct beos_scaf
|
||||
|
||||
void nsbeos_gui_view_source(struct hlcache_handle *content);
|
||||
image_id nsbeos_find_app_path(char *path);
|
||||
char *find_resource(char *buf, const char *filename, const char *def);
|
||||
|
||||
void nsbeos_update_system_ui_colors(void);
|
||||
|
||||
|
@ -1,4 +1,5 @@
|
||||
/*
|
||||
* Copyright 2015 Adrián Arroyo Calle <adrian.arroyocalle@gmail.com>
|
||||
* Copyright 2008 François Revol <mmu_man@users.sourceforge.net>
|
||||
* Copyright 2006 Rob Kendrick <rjek@rjek.com>
|
||||
*
|
||||
@ -56,6 +57,8 @@ extern "C" {
|
||||
#include "desktop/browser.h"
|
||||
#include "desktop/netsurf.h"
|
||||
#include "desktop/version.h"
|
||||
#include "desktop/searchweb.h"
|
||||
#include "desktop/search.h"
|
||||
#include "desktop/plotters.h"
|
||||
#include "utils/nsoption.h"
|
||||
#include "desktop/textinput.h"
|
||||
@ -111,6 +114,7 @@ struct beos_scaffolding {
|
||||
BControl *home_button;
|
||||
|
||||
NSIconTextControl *url_bar;
|
||||
NSIconTextControl *search_bar;
|
||||
//BMenuField *url_bar_completion;
|
||||
|
||||
NSThrobber *throbber;
|
||||
@ -478,6 +482,7 @@ NSBaseView::MessageReceived(BMessage *message)
|
||||
case 'home':
|
||||
case 'urlc':
|
||||
case 'urle':
|
||||
case 'sear':
|
||||
case 'menu':
|
||||
case NO_ACTION:
|
||||
case HELP_OPEN_CONTENTS:
|
||||
@ -653,6 +658,7 @@ NSBaseView::AllAttached()
|
||||
g->home_button->SetTarget(this);
|
||||
|
||||
g->url_bar->SetTarget(this);
|
||||
g->search_bar->SetTarget(this);
|
||||
|
||||
rgb_color c = ui_color(B_PANEL_BACKGROUND_COLOR);
|
||||
SetViewColor(c);
|
||||
@ -669,6 +675,7 @@ NSBaseView::AllAttached()
|
||||
g->home_button->SetViewColor(c);
|
||||
g->home_button->SetLowColor(c);
|
||||
g->url_bar->SetViewColor(c);
|
||||
g->search_bar->SetViewColor(c);
|
||||
g->throbber->SetViewColor(c);
|
||||
g->scroll_view->SetViewColor(c);
|
||||
|
||||
@ -806,6 +813,7 @@ static void nsbeos_scaffolding_update_colors(nsbeos_scaffolding *g)
|
||||
g->reload_button->SetViewColor(c);
|
||||
g->home_button->SetViewColor(c);
|
||||
g->url_bar->SetViewColor(c);
|
||||
g->search_bar->SetViewColor(c);
|
||||
g->throbber->SetViewColor(c);
|
||||
g->scroll_view->SetViewColor(c);
|
||||
|
||||
@ -1073,6 +1081,41 @@ void nsbeos_scaffolding_dispatch_event(nsbeos_scaffolding *scaffold, BMessage *m
|
||||
//nsbeos_completion_update(text.String());
|
||||
break;
|
||||
}
|
||||
case 'sear':
|
||||
{
|
||||
nserror ret;
|
||||
nsurl* url;
|
||||
BString text;
|
||||
if (!scaffold->search_bar->LockLooper())
|
||||
break;
|
||||
text = scaffold->search_bar->Text();
|
||||
scaffold->search_bar->UnlockLooper();
|
||||
|
||||
char t[PATH_MAX];
|
||||
find_resource(t,"SearchEngines","./beos/res/SearchEngines");
|
||||
|
||||
search_web_init();
|
||||
|
||||
ret = search_web_omni(text.String(),SEARCH_WEB_OMNI_SEARCHONLY
|
||||
,&url);
|
||||
if (ret == NSERROR_OK) {
|
||||
ret = browser_window_create(
|
||||
(browser_window_create_flags)(BW_CREATE_HISTORY | BW_CREATE_TAB),
|
||||
url,
|
||||
NULL,
|
||||
bw,
|
||||
NULL);
|
||||
nsurl_unref(url);
|
||||
}
|
||||
|
||||
if (ret != NSERROR_OK) {
|
||||
warn_user(messages_get_errorcode(ret), 0);
|
||||
}
|
||||
|
||||
search_web_finalise();
|
||||
|
||||
break;
|
||||
}
|
||||
/*
|
||||
case 'menu':
|
||||
{
|
||||
@ -2113,6 +2156,21 @@ nsbeos_scaffolding *nsbeos_new_scaffolding(struct gui_window *toplevel)
|
||||
g->url_bar->TextView()->SetTextRect(rect);
|
||||
g->tool_bar->AddChild(g->url_bar);
|
||||
|
||||
// search bar
|
||||
|
||||
rect = g->tool_bar->Bounds();
|
||||
rect.left += TOOLBAR_HEIGHT * nButtons + (g->url_bar->Bounds().right - g->url_bar->Bounds().left);
|
||||
rect.right -= TOOLBAR_HEIGHT * 1;
|
||||
rect.InsetBy(5,5);
|
||||
message = new BMessage('sear');
|
||||
message->AddPointer("scaffolding", g);
|
||||
g->search_bar = new NSIconTextControl(rect,"search_bar","","Search...",message,
|
||||
B_FOLLOW_RIGHT);
|
||||
g->search_bar->SetDivider(0);
|
||||
rect = g->search_bar->TextView()->TextRect();
|
||||
rect.left += 0;
|
||||
g->search_bar->TextView()->TextRect();
|
||||
g->tool_bar->AddChild(g->search_bar);
|
||||
|
||||
// throbber
|
||||
rect.Set(0, 0, 24, 24);
|
||||
|
Loading…
Reference in New Issue
Block a user