Merge pull request #3974 from leethomas/fix-devtools-api

Fix devtools api
This commit is contained in:
Cheng Zhao 2016-01-04 10:41:33 +08:00
commit 4cdee5547f
8 changed files with 78 additions and 0 deletions

View file

@ -780,6 +780,13 @@ bool WebContents::IsDevToolsOpened() {
return managed_web_contents()->IsDevToolsViewShowing(); return managed_web_contents()->IsDevToolsViewShowing();
} }
bool WebContents::IsDevToolsFocused() {
if (type_ == REMOTE)
return false;
return managed_web_contents()->GetView()->IsDevToolsViewFocused();
}
void WebContents::EnableDeviceEmulation( void WebContents::EnableDeviceEmulation(
const blink::WebDeviceEmulationParams& params) { const blink::WebDeviceEmulationParams& params) {
if (type_ == REMOTE) if (type_ == REMOTE)
@ -1080,6 +1087,7 @@ void WebContents::BuildPrototype(v8::Isolate* isolate,
.SetMethod("openDevTools", &WebContents::OpenDevTools) .SetMethod("openDevTools", &WebContents::OpenDevTools)
.SetMethod("closeDevTools", &WebContents::CloseDevTools) .SetMethod("closeDevTools", &WebContents::CloseDevTools)
.SetMethod("isDevToolsOpened", &WebContents::IsDevToolsOpened) .SetMethod("isDevToolsOpened", &WebContents::IsDevToolsOpened)
.SetMethod("isDevToolsFocused", &WebContents::IsDevToolsFocused)
.SetMethod("enableDeviceEmulation", .SetMethod("enableDeviceEmulation",
&WebContents::EnableDeviceEmulation) &WebContents::EnableDeviceEmulation)
.SetMethod("disableDeviceEmulation", .SetMethod("disableDeviceEmulation",

View file

@ -79,6 +79,7 @@ class WebContents : public mate::TrackableObject<WebContents>,
void OpenDevTools(mate::Arguments* args); void OpenDevTools(mate::Arguments* args);
void CloseDevTools(); void CloseDevTools();
bool IsDevToolsOpened(); bool IsDevToolsOpened();
bool IsDevToolsFocused();
void ToggleDevTools(); void ToggleDevTools();
void EnableDeviceEmulation(const blink::WebDeviceEmulationParams& params); void EnableDeviceEmulation(const blink::WebDeviceEmulationParams& params);
void DisableDeviceEmulation(); void DisableDeviceEmulation();

View file

@ -83,6 +83,7 @@ BrowserWindow::send = -> @webContents.send.apply @webContents, arguments
BrowserWindow::openDevTools = -> @webContents.openDevTools.apply @webContents, arguments BrowserWindow::openDevTools = -> @webContents.openDevTools.apply @webContents, arguments
BrowserWindow::closeDevTools = -> @webContents.closeDevTools() BrowserWindow::closeDevTools = -> @webContents.closeDevTools()
BrowserWindow::isDevToolsOpened = -> @webContents.isDevToolsOpened() BrowserWindow::isDevToolsOpened = -> @webContents.isDevToolsOpened()
BrowserWindow::isDevToolsFocused = -> @webContents.isDevToolsFocused()
BrowserWindow::toggleDevTools = -> @webContents.toggleDevTools() BrowserWindow::toggleDevTools = -> @webContents.toggleDevTools()
BrowserWindow::inspectElement = -> @webContents.inspectElement.apply @webContents, arguments BrowserWindow::inspectElement = -> @webContents.inspectElement.apply @webContents, arguments
BrowserWindow::inspectServiceWorker = -> @webContents.inspectServiceWorker() BrowserWindow::inspectServiceWorker = -> @webContents.inspectServiceWorker()

View file

@ -13,6 +13,9 @@ supportedWebViewEvents = [
'did-get-redirect-request' 'did-get-redirect-request'
'dom-ready' 'dom-ready'
'console-message' 'console-message'
'devtools-opened'
'devtools-closed'
'devtools-focused'
'new-window' 'new-window'
'close' 'close'
'crashed' 'crashed'

View file

@ -15,6 +15,9 @@ WEB_VIEW_EVENTS =
'did-get-redirect-request': ['oldURL', 'newURL', 'isMainFrame'] 'did-get-redirect-request': ['oldURL', 'newURL', 'isMainFrame']
'dom-ready': [] 'dom-ready': []
'console-message': ['level', 'message', 'line', 'sourceId'] 'console-message': ['level', 'message', 'line', 'sourceId']
'devtools-opened': []
'devtools-closed': []
'devtools-focused': []
'new-window': ['url', 'frameName', 'disposition', 'options'] 'new-window': ['url', 'frameName', 'disposition', 'options']
'close': [] 'close': []
'crashed': [] 'crashed': []

View file

@ -650,3 +650,15 @@ Emitted when a page's theme color changes. This is usually due to encountering a
```html ```html
<meta name='theme-color' content='#ff0000'> <meta name='theme-color' content='#ff0000'>
``` ```
### Event: 'devtools-opened'
Emitted when DevTools is opened.
### Event: 'devtools-closed'
Emitted when DevTools is closed.
### Event: 'devtools-focused'
Emitted when DevTools is focused / opened.

4
spec/fixtures/pages/base-page.html vendored Normal file
View file

@ -0,0 +1,4 @@
<html>
<body>
</body>
</html>

View file

@ -279,6 +279,52 @@ describe '<webview> tag', ->
webview.src = "file://#{fixtures}/pages/close.html" webview.src = "file://#{fixtures}/pages/close.html"
document.body.appendChild webview document.body.appendChild webview
describe 'devtools-opened event', ->
it 'should fire when webview.openDevTools() is called', (done) ->
listener = ->
webview.removeEventListener 'devtools-opened', listener
webview.closeDevTools()
done()
webview.addEventListener 'devtools-opened', listener
webview.addEventListener 'dom-ready', ->
webview.openDevTools()
webview.src = "file://#{fixtures}/pages/base-page.html"
document.body.appendChild webview
describe 'devtools-closed event', ->
it 'should fire when webview.closeDevTools() is called', (done) ->
listener2 = ->
webview.removeEventListener 'devtools-closed', listener2
done()
listener = ->
webview.removeEventListener 'devtools-opened', listener
webview.closeDevTools()
webview.addEventListener 'devtools-opened', listener
webview.addEventListener 'devtools-closed', listener2
webview.addEventListener 'dom-ready', ->
webview.openDevTools()
webview.src = "file://#{fixtures}/pages/base-page.html"
document.body.appendChild webview
describe 'devtools-focused event', ->
it 'should fire when webview.openDevTools() is called', (done) ->
listener = ->
webview.removeEventListener 'devtools-focused', listener
webview.closeDevTools()
done()
webview.addEventListener 'devtools-focused', listener
webview.addEventListener 'dom-ready', ->
webview.openDevTools()
webview.src = "file://#{fixtures}/pages/base-page.html"
document.body.appendChild webview
describe '<webview>.reload()', -> describe '<webview>.reload()', ->
it 'should emit beforeunload handler', (done) -> it 'should emit beforeunload handler', (done) ->
listener = (e) -> listener = (e) ->