| OLD | NEW |
| 1 // Copyright (c) 2006-2008 The Chromium Authors. All rights reserved. | 1 // Copyright (c) 2006-2008 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/dom_ui/history_ui.h" | 5 #include "chrome/browser/dom_ui/history_ui.h" |
| 6 | 6 |
| 7 #include "base/message_loop.h" | 7 #include "base/message_loop.h" |
| 8 #include "base/string_piece.h" | 8 #include "base/string_piece.h" |
| 9 #include "base/string_util.h" | 9 #include "base/string_util.h" |
| 10 #include "base/thread.h" | 10 #include "base/thread.h" |
| 11 #include "base/time.h" | 11 #include "base/time.h" |
| 12 #include "base/time_format.h" | 12 #include "base/time_format.h" |
| 13 #include "chrome/browser/browser_process.h" | 13 #include "chrome/browser/browser_process.h" |
| 14 #include "chrome/browser/metrics/user_metrics.h" | 14 #include "chrome/browser/metrics/user_metrics.h" |
| 15 #include "chrome/browser/history/history_types.h" | 15 #include "chrome/browser/history/history_types.h" |
| 16 #include "chrome/browser/profile.h" | 16 #include "chrome/browser/profile.h" |
| 17 #include "chrome/common/jstemplate_builder.h" | 17 #include "chrome/common/jstemplate_builder.h" |
| 18 #include "chrome/common/l10n_util.h" | 18 #include "chrome/common/l10n_util.h" |
| 19 #include "chrome/common/notification_service.h" | 19 #include "chrome/common/notification_service.h" |
| 20 #include "chrome/common/resource_bundle.h" | 20 #include "chrome/common/resource_bundle.h" |
| 21 #include "chrome/common/time_format.h" | 21 #include "chrome/common/time_format.h" |
| 22 #include "net/base/escape.h" |
| 23 |
| 22 #include "grit/browser_resources.h" | 24 #include "grit/browser_resources.h" |
| 23 #include "grit/chromium_strings.h" | 25 #include "grit/chromium_strings.h" |
| 24 #include "grit/generated_resources.h" | 26 #include "grit/generated_resources.h" |
| 25 | 27 |
| 26 using base::Time; | 28 using base::Time; |
| 27 using base::TimeDelta; | 29 using base::TimeDelta; |
| 28 | 30 |
| 29 // HistoryUI is accessible from chrome-ui://history. | 31 // HistoryUI is accessible from chrome-ui://history. |
| 30 static const char kHistoryHost[] = "history"; | 32 static const char kHistoryHost[] = "history"; |
| 31 | 33 |
| 32 // Maximum number of search results to return in a given search. We should | 34 // Maximum number of search results to return in a given search. We should |
| 33 // eventually remove this. | 35 // eventually remove this. |
| 34 static const int kMaxSearchResults = 100; | 36 static const int kMaxSearchResults = 100; |
| 35 | 37 |
| 36 //////////////////////////////////////////////////////////////////////////////// | 38 //////////////////////////////////////////////////////////////////////////////// |
| 37 // | 39 // |
| 38 // HistoryHTMLSource | 40 // HistoryHTMLSource |
| 39 // | 41 // |
| 40 //////////////////////////////////////////////////////////////////////////////// | 42 //////////////////////////////////////////////////////////////////////////////// |
| 41 | 43 |
| 42 HistoryUIHTMLSource::HistoryUIHTMLSource() | 44 HistoryUIHTMLSource::HistoryUIHTMLSource() |
| (...skipping 95 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 138 options.end_time = Time::Now().LocalMidnight(); | 140 options.end_time = Time::Now().LocalMidnight(); |
| 139 options.end_time -= TimeDelta::FromDays(day - 1); | 141 options.end_time -= TimeDelta::FromDays(day - 1); |
| 140 | 142 |
| 141 // Need to remember the query string for our results. | 143 // Need to remember the query string for our results. |
| 142 search_text_ = std::wstring(); | 144 search_text_ = std::wstring(); |
| 143 | 145 |
| 144 HistoryService* hs = | 146 HistoryService* hs = |
| 145 dom_ui_->get_profile()->GetHistoryService(Profile::EXPLICIT_ACCESS); | 147 dom_ui_->get_profile()->GetHistoryService(Profile::EXPLICIT_ACCESS); |
| 146 hs->QueryHistory(search_text_, | 148 hs->QueryHistory(search_text_, |
| 147 options, | 149 options, |
| 148 &cancelable_consumer_, | 150 &cancelable_consumer_, |
| 149 NewCallback(this, &BrowsingHistoryHandler::QueryComplete)); | 151 NewCallback(this, &BrowsingHistoryHandler::QueryComplete)); |
| 150 } | 152 } |
| 151 | 153 |
| 152 void BrowsingHistoryHandler::HandleSearchHistory(const Value* value) { | 154 void BrowsingHistoryHandler::HandleSearchHistory(const Value* value) { |
| 153 // Anything in-flight is invalid. | 155 // Anything in-flight is invalid. |
| 154 cancelable_consumer_.CancelAllRequests(); | 156 cancelable_consumer_.CancelAllRequests(); |
| 155 | 157 |
| 156 // Get arguments (if any). | 158 // Get arguments (if any). |
| 157 int month = 0; | 159 int month = 0; |
| 158 std::wstring query; | 160 std::wstring query; |
| 159 ExtractSearchHistoryArguments(value, &month, &query); | 161 ExtractSearchHistoryArguments(value, &month, &query); |
| 160 | 162 |
| 161 // Set the query ranges for the given month. | 163 // Set the query ranges for the given month. |
| 162 history::QueryOptions options = CreateMonthQueryOptions(month); | 164 history::QueryOptions options = CreateMonthQueryOptions(month); |
| 163 | 165 |
| 164 // When searching, limit the number of results returned and only show the | 166 // When searching, limit the number of results returned and only show the |
| 165 // most recent matches. | 167 // most recent matches. |
| 166 options.max_count = kMaxSearchResults; | 168 options.max_count = kMaxSearchResults; |
| 167 options.most_recent_visit_only = true; | 169 options.most_recent_visit_only = true; |
| 168 | 170 |
| 169 // Need to remember the query string for our results. | 171 // Need to remember the query string for our results. |
| 170 search_text_ = query; | 172 search_text_ = query; |
| 171 HistoryService* hs = | 173 HistoryService* hs = |
| 172 dom_ui_->get_profile()->GetHistoryService(Profile::EXPLICIT_ACCESS); | 174 dom_ui_->get_profile()->GetHistoryService(Profile::EXPLICIT_ACCESS); |
| 173 hs->QueryHistory(search_text_, | 175 hs->QueryHistory(search_text_, |
| 174 options, | 176 options, |
| 175 &cancelable_consumer_, | 177 &cancelable_consumer_, |
| 176 NewCallback(this, &BrowsingHistoryHandler::QueryComplete)); | 178 NewCallback(this, &BrowsingHistoryHandler::QueryComplete)); |
| 177 } | 179 } |
| 178 | 180 |
| 179 void BrowsingHistoryHandler::HandleDeleteDay(const Value* value) { | 181 void BrowsingHistoryHandler::HandleDeleteDay(const Value* value) { |
| 180 // Anything in-flight is invalid. | 182 // Anything in-flight is invalid. |
| 181 cancelable_consumer_.CancelAllRequests(); | 183 cancelable_consumer_.CancelAllRequests(); |
| 182 | 184 |
| 183 // Get time. | 185 // Get time. |
| 184 Time time; | 186 Time time; |
| 185 bool success = Time::FromString(ExtractStringValue(value).c_str(), &time); | 187 bool success = Time::FromString(ExtractStringValue(value).c_str(), &time); |
| (...skipping 24 matching lines...) Expand all Loading... |
| 210 | 212 |
| 211 ListValue results_value; | 213 ListValue results_value; |
| 212 Time midnight_today = Time::Now().LocalMidnight(); | 214 Time midnight_today = Time::Now().LocalMidnight(); |
| 213 | 215 |
| 214 for (size_t i = 0; i < results->size(); ++i) { | 216 for (size_t i = 0; i < results->size(); ++i) { |
| 215 history::URLResult const &page = (*results)[i]; | 217 history::URLResult const &page = (*results)[i]; |
| 216 DictionaryValue* page_value = new DictionaryValue(); | 218 DictionaryValue* page_value = new DictionaryValue(); |
| 217 SetURLAndTitle(page_value, page.title(), page.url()); | 219 SetURLAndTitle(page_value, page.title(), page.url()); |
| 218 | 220 |
| 219 // Need to pass the time in epoch time (fastest JS conversion). | 221 // Need to pass the time in epoch time (fastest JS conversion). |
| 220 page_value->SetInteger(L"time", | 222 page_value->SetInteger(L"time", |
| 221 static_cast<int>(page.visit_time().ToTimeT())); | 223 static_cast<int>(page.visit_time().ToTimeT())); |
| 222 | 224 |
| 223 // Until we get some JS i18n infrastructure, we also need to | 225 // Until we get some JS i18n infrastructure, we also need to |
| 224 // pass the dates in as strings. This could use some | 226 // pass the dates in as strings. This could use some |
| 225 // optimization. | 227 // optimization. |
| 226 | 228 |
| 227 // Only pass in the strings we need (search results need a shortdate | 229 // Only pass in the strings we need (search results need a shortdate |
| 228 // and snippet, browse results need day and time information). | 230 // and snippet, browse results need day and time information). |
| 229 if (search_text_.empty()) { | 231 if (search_text_.empty()) { |
| 230 // Figure out the relative date string. | 232 // Figure out the relative date string. |
| 231 std::wstring date_str = TimeFormat::RelativeDate(page.visit_time(), | 233 std::wstring date_str = TimeFormat::RelativeDate(page.visit_time(), |
| 232 &midnight_today); | 234 &midnight_today); |
| 233 if (date_str.empty()) { | 235 if (date_str.empty()) { |
| 234 date_str = base::TimeFormatFriendlyDate(page.visit_time()); | 236 date_str = base::TimeFormatFriendlyDate(page.visit_time()); |
| 235 } else { | 237 } else { |
| 236 date_str = l10n_util::GetStringF( | 238 date_str = l10n_util::GetStringF( |
| 237 IDS_HISTORY_DATE_WITH_RELATIVE_TIME, | 239 IDS_HISTORY_DATE_WITH_RELATIVE_TIME, |
| 238 date_str, base::TimeFormatFriendlyDate(page.visit_time())); | 240 date_str, base::TimeFormatFriendlyDate(page.visit_time())); |
| 239 } | 241 } |
| 240 page_value->SetString(L"dateRelativeDay", date_str); | 242 page_value->SetString(L"dateRelativeDay", date_str); |
| 241 page_value->SetString(L"dateTimeOfDay", | 243 page_value->SetString(L"dateTimeOfDay", |
| 242 base::TimeFormatTimeOfDay(page.visit_time())); | 244 base::TimeFormatTimeOfDay(page.visit_time())); |
| 243 } else { | 245 } else { |
| 244 page_value->SetString(L"dateShort", | 246 page_value->SetString(L"dateShort", |
| 245 base::TimeFormatShortDate(page.visit_time())); | 247 base::TimeFormatShortDate(page.visit_time())); |
| 246 page_value->SetString(L"snippet", page.snippet().text()); | 248 page_value->SetString(L"snippet", page.snippet().text()); |
| 247 } | 249 } |
| 248 | 250 |
| 249 results_value.Append(page_value); | 251 results_value.Append(page_value); |
| 250 } | 252 } |
| 251 | 253 |
| 252 StringValue temp(search_text_); | 254 StringValue temp(search_text_); |
| 253 dom_ui_->CallJavascriptFunction(L"historyResult", temp, results_value); | 255 dom_ui_->CallJavascriptFunction(L"historyResult", temp, results_value); |
| 254 } | 256 } |
| 255 | 257 |
| 256 void BrowsingHistoryHandler::ExtractSearchHistoryArguments(const Value* value, | 258 void BrowsingHistoryHandler::ExtractSearchHistoryArguments(const Value* value, |
| 257 int* month, std::wstring* query) { | 259 int* month, std::wstring* query) { |
| 258 *month = 0; | 260 *month = 0; |
| 259 | 261 |
| 260 if (value && value->GetType() == Value::TYPE_LIST) { | 262 if (value && value->GetType() == Value::TYPE_LIST) { |
| 261 const ListValue* list_value = static_cast<const ListValue*>(value); | 263 const ListValue* list_value = static_cast<const ListValue*>(value); |
| 262 Value* list_member; | 264 Value* list_member; |
| 263 | 265 |
| 264 // Get search string. | 266 // Get search string. |
| 265 if (list_value->Get(0, &list_member) && | 267 if (list_value->Get(0, &list_member) && |
| 266 list_member->GetType() == Value::TYPE_STRING) { | 268 list_member->GetType() == Value::TYPE_STRING) { |
| (...skipping 90 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
| 357 html_source)); | 359 html_source)); |
| 358 } | 360 } |
| 359 | 361 |
| 360 // static | 362 // static |
| 361 GURL HistoryUI::GetBaseURL() { | 363 GURL HistoryUI::GetBaseURL() { |
| 362 std::string url = DOMUIContents::GetScheme(); | 364 std::string url = DOMUIContents::GetScheme(); |
| 363 url += "://"; | 365 url += "://"; |
| 364 url += kHistoryHost; | 366 url += kHistoryHost; |
| 365 return GURL(url); | 367 return GURL(url); |
| 366 } | 368 } |
| 369 |
| 370 // static |
| 371 const GURL HistoryUI::GetHistoryURLWithSearchText( |
| 372 const std::wstring& text) { |
| 373 return GURL(GetBaseURL().spec() + "/?q=" + |
| 374 EscapeQueryParamValue(WideToUTF8(text))); |
| 375 } |
| OLD | NEW |