OLD | NEW |
1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2012 The Chromium Authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "chrome/browser/ui/panels/panel.h" | 5 #include "chrome/browser/ui/panels/panel.h" |
6 | 6 |
7 #include "base/logging.h" | 7 #include "base/logging.h" |
8 #include "base/message_loop/message_loop.h" | 8 #include "base/message_loop/message_loop.h" |
9 #include "base/strings/utf_string_conversions.h" | 9 #include "base/strings/utf_string_conversions.h" |
10 #include "chrome/app/chrome_command_ids.h" | 10 #include "chrome/app/chrome_command_ids.h" |
(...skipping 419 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
430 default: | 430 default: |
431 LOG(WARNING) << "Received unimplemented command: " << id; | 431 LOG(WARNING) << "Received unimplemented command: " << id; |
432 break; | 432 break; |
433 } | 433 } |
434 } | 434 } |
435 | 435 |
436 void Panel::Observe(int type, | 436 void Panel::Observe(int type, |
437 const content::NotificationSource& source, | 437 const content::NotificationSource& source, |
438 const content::NotificationDetails& details) { | 438 const content::NotificationDetails& details) { |
439 switch (type) { | 439 switch (type) { |
440 case content::NOTIFICATION_RENDER_VIEW_HOST_CHANGED: | |
441 ConfigureAutoResize(content::Source<content::WebContents>(source).ptr()); | |
442 break; | |
443 case chrome::NOTIFICATION_APP_TERMINATING: | 440 case chrome::NOTIFICATION_APP_TERMINATING: |
444 Close(); | 441 Close(); |
445 break; | 442 break; |
446 default: | 443 default: |
447 NOTREACHED() << "Received unexpected notification " << type; | 444 NOTREACHED() << "Received unexpected notification " << type; |
448 } | 445 } |
449 } | 446 } |
450 | 447 |
| 448 void Panel::RenderViewHostChanged(content::RenderViewHost* old_host, |
| 449 content::RenderViewHost* new_host) { |
| 450 ConfigureAutoResize(web_contents()); |
| 451 } |
| 452 |
451 void Panel::OnExtensionUnloaded( | 453 void Panel::OnExtensionUnloaded( |
452 content::BrowserContext* browser_context, | 454 content::BrowserContext* browser_context, |
453 const extensions::Extension* extension, | 455 const extensions::Extension* extension, |
454 extensions::UnloadedExtensionInfo::Reason reason) { | 456 extensions::UnloadedExtensionInfo::Reason reason) { |
455 if (extension->id() == extension_id()) | 457 if (extension->id() == extension_id()) |
456 Close(); | 458 Close(); |
457 } | 459 } |
458 void Panel::OnTitlebarClicked(panel::ClickModifier modifier) { | 460 void Panel::OnTitlebarClicked(panel::ClickModifier modifier) { |
459 if (collection_) | 461 if (collection_) |
460 collection_->OnPanelTitlebarClicked(this, modifier); | 462 collection_->OnPanelTitlebarClicked(this, modifier); |
(...skipping 125 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
586 if (auto_resizable_ == resizable) | 588 if (auto_resizable_ == resizable) |
587 return; | 589 return; |
588 | 590 |
589 auto_resizable_ = resizable; | 591 auto_resizable_ = resizable; |
590 content::WebContents* web_contents = GetWebContents(); | 592 content::WebContents* web_contents = GetWebContents(); |
591 if (auto_resizable_) { | 593 if (auto_resizable_) { |
592 if (web_contents) | 594 if (web_contents) |
593 EnableWebContentsAutoResize(web_contents); | 595 EnableWebContentsAutoResize(web_contents); |
594 } else { | 596 } else { |
595 if (web_contents) { | 597 if (web_contents) { |
596 registrar_.Remove(this, content::NOTIFICATION_RENDER_VIEW_HOST_CHANGED, | 598 content::WebContentsObserver::Observe(nullptr); |
597 content::Source<content::WebContents>(web_contents)); | |
598 | 599 |
599 // NULL might be returned if the tab has not been added. | 600 // NULL might be returned if the tab has not been added. |
600 RenderViewHost* render_view_host = web_contents->GetRenderViewHost(); | 601 RenderViewHost* render_view_host = web_contents->GetRenderViewHost(); |
601 if (render_view_host) | 602 if (render_view_host) |
602 render_view_host->DisableAutoResize(full_size_); | 603 render_view_host->DisableAutoResize(full_size_); |
603 } | 604 } |
604 } | 605 } |
605 } | 606 } |
606 | 607 |
607 void Panel::EnableWebContentsAutoResize(content::WebContents* web_contents) { | 608 void Panel::EnableWebContentsAutoResize(content::WebContents* web_contents) { |
608 DCHECK(web_contents); | 609 DCHECK(web_contents); |
609 ConfigureAutoResize(web_contents); | 610 ConfigureAutoResize(web_contents); |
610 | 611 |
611 // We also need to know when the render view host changes in order | 612 // We also need to know when the render view host changes in order |
612 // to turn on auto-resize notifications in the new render view host. | 613 // to turn on auto-resize notifications in the new render view host. |
613 if (!registrar_.IsRegistered( | 614 content::WebContentsObserver::Observe(web_contents); |
614 this, content::NOTIFICATION_RENDER_VIEW_HOST_CHANGED, | |
615 content::Source<content::WebContents>(web_contents))) { | |
616 registrar_.Add( | |
617 this, | |
618 content::NOTIFICATION_RENDER_VIEW_HOST_CHANGED, | |
619 content::Source<content::WebContents>(web_contents)); | |
620 } | |
621 } | 615 } |
622 | 616 |
623 void Panel::OnContentsAutoResized(const gfx::Size& new_content_size) { | 617 void Panel::OnContentsAutoResized(const gfx::Size& new_content_size) { |
624 DCHECK(auto_resizable_); | 618 DCHECK(auto_resizable_); |
625 if (!collection_) | 619 if (!collection_) |
626 return; | 620 return; |
627 | 621 |
628 gfx::Size new_window_size = | 622 gfx::Size new_window_size = |
629 native_panel_->WindowSizeFromContentSize(new_content_size); | 623 native_panel_->WindowSizeFromContentSize(new_content_size); |
630 | 624 |
(...skipping 265 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
896 // static | 890 // static |
897 void Panel::FormatTitleForDisplay(base::string16* title) { | 891 void Panel::FormatTitleForDisplay(base::string16* title) { |
898 size_t current_index = 0; | 892 size_t current_index = 0; |
899 size_t match_index; | 893 size_t match_index; |
900 while ((match_index = title->find(L'\n', current_index)) != | 894 while ((match_index = title->find(L'\n', current_index)) != |
901 base::string16::npos) { | 895 base::string16::npos) { |
902 title->replace(match_index, 1, base::string16()); | 896 title->replace(match_index, 1, base::string16()); |
903 current_index = match_index; | 897 current_index = match_index; |
904 } | 898 } |
905 } | 899 } |
OLD | NEW |