providing option to undock devtools from browser-window

This commit is contained in:
deepak1556 2015-03-26 14:43:35 +05:30
parent ae5586408f
commit 69d958b94e
7 changed files with 16 additions and 10 deletions

View file

@ -322,8 +322,8 @@ bool Window::IsKiosk() {
return window_->IsKiosk(); return window_->IsKiosk();
} }
void Window::OpenDevTools() { void Window::OpenDevTools(bool dock) {
window_->OpenDevTools(); window_->OpenDevTools(!dock);
} }
void Window::CloseDevTools() { void Window::CloseDevTools() {

View file

@ -105,7 +105,7 @@ class Window : public mate::EventEmitter,
void SetSkipTaskbar(bool skip); void SetSkipTaskbar(bool skip);
void SetKiosk(bool kiosk); void SetKiosk(bool kiosk);
bool IsKiosk(); bool IsKiosk();
void OpenDevTools(); void OpenDevTools(bool dock);
void CloseDevTools(); void CloseDevTools();
bool IsDevToolsOpened(); bool IsDevToolsOpened();
void InspectElement(int x, int y); void InspectElement(int x, int y);

View file

@ -40,8 +40,9 @@ BrowserWindow::_init = ->
@once 'closed', => @once 'closed', =>
BrowserWindow.windows.remove @id if BrowserWindow.windows.has @id BrowserWindow.windows.remove @id if BrowserWindow.windows.has @id
BrowserWindow::openDevTools = -> BrowserWindow::openDevTools = (options={}) ->
@_openDevTools() options.detach ?= false
@_openDevTools(options.detach)
# Force devToolsWebContents to be created. # Force devToolsWebContents to be created.
@devToolsWebContents = @getDevToolsWebContents() @devToolsWebContents = @getDevToolsWebContents()

View file

@ -284,7 +284,9 @@ bool NativeWindow::HasModalDialog() {
return has_dialog_attached_; return has_dialog_attached_;
} }
void NativeWindow::OpenDevTools() { void NativeWindow::OpenDevTools(bool dock) {
if (!dock)
inspectable_web_contents()->SetCanDock(false);
inspectable_web_contents()->ShowDevTools(); inspectable_web_contents()->ShowDevTools();
} }
@ -297,7 +299,7 @@ bool NativeWindow::IsDevToolsOpened() {
} }
void NativeWindow::InspectElement(int x, int y) { void NativeWindow::InspectElement(int x, int y) {
OpenDevTools(); OpenDevTools(true);
scoped_refptr<content::DevToolsAgentHost> agent( scoped_refptr<content::DevToolsAgentHost> agent(
content::DevToolsAgentHost::GetOrCreateFor(GetWebContents())); content::DevToolsAgentHost::GetOrCreateFor(GetWebContents()));
agent->InspectElement(x, y); agent->InspectElement(x, y);

View file

@ -146,7 +146,7 @@ class NativeWindow : public brightray::DefaultWebContentsDelegate,
const std::string& description) = 0; const std::string& description) = 0;
virtual bool IsClosed() const { return is_closed_; } virtual bool IsClosed() const { return is_closed_; }
virtual void OpenDevTools(); virtual void OpenDevTools(bool dock);
virtual void CloseDevTools(); virtual void CloseDevTools();
virtual bool IsDevToolsOpened(); virtual bool IsDevToolsOpened();
virtual void InspectElement(int x, int y); virtual void InspectElement(int x, int y);

View file

@ -190,7 +190,7 @@ static const CGFloat kAtomWindowCornerRadius = 4.0;
} }
- (IBAction)showDevTools:(id)sender { - (IBAction)showDevTools:(id)sender {
shell_->OpenDevTools(); shell_->OpenDevTools(true);
} }
// Returns an empty array for AXChildren attribute, this will force the // Returns an empty array for AXChildren attribute, this will force the

View file

@ -457,7 +457,10 @@ Whether the window's document has been edited.
__Note__: This API is available only on OS X. __Note__: This API is available only on OS X.
### BrowserWindow.openDevTools() ### BrowserWindow.openDevTools([options])
* `options` Object
* `detach` Boolean - opens devtools in a new window
Opens the developer tools. Opens the developer tools.