diff --git a/shell/browser/api/electron_api_web_contents.cc b/shell/browser/api/electron_api_web_contents.cc index 0f868896e65..93721dce95a 100644 --- a/shell/browser/api/electron_api_web_contents.cc +++ b/shell/browser/api/electron_api_web_contents.cc @@ -392,10 +392,20 @@ base::string16 GetDefaultPrinterAsync() { base::ScopedBlockingCall scoped_blocking_call(FROM_HERE, base::BlockingType::MAY_BLOCK); - scoped_refptr backend = + scoped_refptr print_backend = printing::PrintBackend::CreateInstance( g_browser_process->GetApplicationLocale()); - std::string printer_name = backend->GetDefaultPrinterName(); + std::string printer_name = print_backend->GetDefaultPrinterName(); + + // Some devices won't have a default printer, so we should + // also check for existing printers and pick the first + // one should it exist. + if (printer_name.empty()) { + printing::PrinterList printers; + print_backend->EnumeratePrinters(&printers); + if (printers.size() > 0) + printer_name = printers.front().printer_name; + } return base::UTF8ToUTF16(printer_name); } #endif @@ -2184,8 +2194,8 @@ void WebContents::Print(gin::Arguments* args) { std::move(callback), device_name, silent)); } -std::vector WebContents::GetPrinterList() { - std::vector printers; +printing::PrinterList WebContents::GetPrinterList() { + printing::PrinterList printers; auto print_backend = printing::PrintBackend::CreateInstance( g_browser_process->GetApplicationLocale()); { diff --git a/shell/browser/api/electron_api_web_contents.h b/shell/browser/api/electron_api_web_contents.h index 022480195f2..c47e1dfe8bd 100644 --- a/shell/browser/api/electron_api_web_contents.h +++ b/shell/browser/api/electron_api_web_contents.h @@ -263,7 +263,7 @@ class WebContents : public gin::Wrappable, bool silent, base::string16 default_printer); void Print(gin::Arguments* args); - std::vector GetPrinterList(); + printing::PrinterList GetPrinterList(); // Print current page as PDF. v8::Local PrintToPDF(base::DictionaryValue settings); #endif