Chromium Code Reviews| 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/views/location_bar/content_setting_image_view.h" | 5 #include "chrome/browser/ui/views/location_bar/content_setting_image_view.h" |
| 6 | 6 |
| 7 #include "base/strings/utf_string_conversions.h" | 7 #include "base/strings/utf_string_conversions.h" |
| 8 #include "chrome/browser/content_settings/tab_specific_content_settings.h" | 8 #include "chrome/browser/content_settings/tab_specific_content_settings.h" |
| 9 #include "chrome/browser/ui/content_settings/content_setting_bubble_model.h" | 9 #include "chrome/browser/ui/content_settings/content_setting_bubble_model.h" |
| 10 #include "chrome/browser/ui/content_settings/content_setting_image_model.h" | 10 #include "chrome/browser/ui/content_settings/content_setting_image_model.h" |
| (...skipping 76 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 87 | 87 |
| 88 slide_animator_.SetSlideDuration(kAnimationDurationMS); | 88 slide_animator_.SetSlideDuration(kAnimationDurationMS); |
| 89 slide_animator_.SetTweenType(ui::Tween::LINEAR); | 89 slide_animator_.SetTweenType(ui::Tween::LINEAR); |
| 90 } | 90 } |
| 91 | 91 |
| 92 ContentSettingImageView::~ContentSettingImageView() { | 92 ContentSettingImageView::~ContentSettingImageView() { |
| 93 if (bubble_widget_) | 93 if (bubble_widget_) |
| 94 bubble_widget_->RemoveObserver(this); | 94 bubble_widget_->RemoveObserver(this); |
| 95 } | 95 } |
| 96 | 96 |
| 97 void ContentSettingImageView::Update(content::WebContents* web_contents) { | 97 void ContentSettingImageView::UpdatePreLayout( |
| 98 content::WebContents* web_contents) { | |
| 98 // Note: We explicitly want to call this even if |web_contents| is NULL, so we | 99 // Note: We explicitly want to call this even if |web_contents| is NULL, so we |
| 99 // get hidden properly while the user is editing the omnibox. | 100 // get hidden properly while the user is editing the omnibox. |
| 100 content_setting_image_model_->UpdateFromWebContents(web_contents); | 101 content_setting_image_model_->UpdateFromWebContents(web_contents); |
| 101 | 102 |
| 102 if (!content_setting_image_model_->is_visible()) { | 103 if (!content_setting_image_model_->is_visible()) { |
| 103 SetVisible(false); | 104 SetVisible(false); |
| 104 return; | 105 return; |
| 105 } | 106 } |
| 106 | 107 |
| 107 icon_->SetImage(ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed( | 108 icon_->SetImage(ui::ResourceBundle::GetSharedInstance().GetImageSkiaNamed( |
| (...skipping 12 matching lines...) Expand all Loading... | |
| 120 | 121 |
| 121 // We just ignore this blockage if we're already showing some other string to | 122 // We just ignore this blockage if we're already showing some other string to |
| 122 // the user. If this becomes a problem, we could design some sort of queueing | 123 // the user. If this becomes a problem, we could design some sort of queueing |
| 123 // mechanism to show one after the other, but it doesn't seem important now. | 124 // mechanism to show one after the other, but it doesn't seem important now. |
| 124 int string_id = content_setting_image_model_->explanatory_string_id(); | 125 int string_id = content_setting_image_model_->explanatory_string_id(); |
| 125 if (string_id && !background_showing()) { | 126 if (string_id && !background_showing()) { |
| 126 text_label_->SetText(l10n_util::GetStringUTF16(string_id)); | 127 text_label_->SetText(l10n_util::GetStringUTF16(string_id)); |
| 127 text_label_->SetVisible(true); | 128 text_label_->SetVisible(true); |
| 128 slide_animator_.Show(); | 129 slide_animator_.Show(); |
| 129 } | 130 } |
| 131 } | |
| 130 | 132 |
| 131 content_settings->SetBlockageHasBeenIndicated( | 133 void ContentSettingImageView::UpdatePostLayout( |
| 132 content_setting_image_model_->get_content_settings_type()); | 134 content::WebContents* web_contents) { |
| 135 if (!content_setting_image_model_->is_visible()) | |
| 136 return; | |
| 137 | |
| 138 TabSpecificContentSettings* content_settings = web_contents ? | |
| 139 TabSpecificContentSettings::FromWebContents(web_contents) : NULL; | |
| 140 if (!content_settings) | |
| 141 return; | |
| 142 if (!content_settings->IsBlockageIndicated( | |
| 143 content_setting_image_model_->get_content_settings_type())) { | |
|
Peter Kasting
2013/09/04 20:59:11
Nit: Indent 4, not 9
npentrel
2013/09/04 21:50:18
Done.
| |
| 144 if (content_setting_image_model_->ShouldShowBubbleOnBlockage()) { | |
| 145 if (web_contents && !bubble_widget_) { | |
|
Peter Kasting
2013/09/04 20:59:11
|web_contents| cannot be NULL here or we'd have re
npentrel
2013/09/04 21:50:18
true.
| |
| 146 bubble_widget_ = parent_->delegate()->CreateViewsBubble( | |
| 147 new ContentSettingBubbleContents( | |
| 148 ContentSettingBubbleModel::CreateContentSettingBubbleModel( | |
| 149 parent_->delegate()->GetContentSettingBubbleModelDelegate(), | |
| 150 web_contents, parent_->profile(), | |
| 151 content_setting_image_model_->get_content_settings_type()), | |
| 152 web_contents, this, views::BubbleBorder::TOP_RIGHT)); | |
| 153 bubble_widget_->AddObserver(this); | |
| 154 bubble_widget_->Show(); | |
| 155 } | |
| 156 content_settings->SetBlockageHasBeenIndicated( | |
|
Peter Kasting
2013/09/04 20:59:11
This statement is one layer too deep.
npentrel
2013/09/04 21:50:18
Done.
| |
| 157 content_setting_image_model_->get_content_settings_type()); | |
| 158 } | |
| 159 } | |
| 133 } | 160 } |
| 134 | 161 |
| 135 // static | 162 // static |
| 136 int ContentSettingImageView::GetBubbleOuterPadding(bool by_icon) { | 163 int ContentSettingImageView::GetBubbleOuterPadding(bool by_icon) { |
| 137 return LocationBarView::GetItemPadding() - LocationBarView::kBubblePadding + | 164 return LocationBarView::GetItemPadding() - LocationBarView::kBubblePadding + |
| 138 (by_icon ? 0 : LocationBarView::kIconInternalPadding); | 165 (by_icon ? 0 : LocationBarView::kIconInternalPadding); |
| 139 } | 166 } |
| 140 | 167 |
| 141 void ContentSettingImageView::AnimationEnded(const ui::Animation* animation) { | 168 void ContentSettingImageView::AnimationEnded(const ui::Animation* animation) { |
| 142 slide_animator_.Reset(); | 169 slide_animator_.Reset(); |
| (...skipping 107 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... | |
| 250 parent_->delegate()->CreateViewsBubble(new ContentSettingBubbleContents( | 277 parent_->delegate()->CreateViewsBubble(new ContentSettingBubbleContents( |
| 251 ContentSettingBubbleModel::CreateContentSettingBubbleModel( | 278 ContentSettingBubbleModel::CreateContentSettingBubbleModel( |
| 252 parent_->delegate()->GetContentSettingBubbleModelDelegate(), | 279 parent_->delegate()->GetContentSettingBubbleModelDelegate(), |
| 253 web_contents, parent_->profile(), | 280 web_contents, parent_->profile(), |
| 254 content_setting_image_model_->get_content_settings_type()), | 281 content_setting_image_model_->get_content_settings_type()), |
| 255 web_contents, this, views::BubbleBorder::TOP_RIGHT)); | 282 web_contents, this, views::BubbleBorder::TOP_RIGHT)); |
| 256 bubble_widget_->AddObserver(this); | 283 bubble_widget_->AddObserver(this); |
| 257 bubble_widget_->Show(); | 284 bubble_widget_->Show(); |
| 258 } | 285 } |
| 259 } | 286 } |
| OLD | NEW |