Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
feat: add methods to allow customization of save dialog during will-d…
…ownload event (#15497) * feat: add method to DownloadItem that allows customization of dialog options * docs: add docs for get/setSaveDialogOptions * add missing copy constructor for DialogSettings on mac and linux * fix: don't filter dialog options for mas build, don't return properties * test: add test for get/setSaveDialogOptions * fix: remove openDevtools added for debugging * test: fix failing test because of new event parameter * docs: use SaveDialogOptions instead of Object
- Loading branch information
Showing
13 changed files
with
203 additions
and
49 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
76 changes: 76 additions & 0 deletions
76
atom/common/native_mate_converters/file_dialog_converter.cc
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,76 @@ | ||
// Copyright (c) 2015 GitHub, Inc. | ||
// Use of this source code is governed by the MIT license that can be | ||
// found in the LICENSE file. | ||
|
||
#include "atom/common/native_mate_converters/file_dialog_converter.h" | ||
|
||
#include "atom/browser/api/atom_api_browser_window.h" | ||
#include "atom/browser/ui/file_dialog.h" | ||
#include "atom/common/native_mate_converters/file_path_converter.h" | ||
#include "native_mate/dictionary.h" | ||
|
||
namespace mate { | ||
|
||
bool Converter<file_dialog::Filter>::FromV8(v8::Isolate* isolate, | ||
v8::Local<v8::Value> val, | ||
file_dialog::Filter* out) { | ||
mate::Dictionary dict; | ||
if (!ConvertFromV8(isolate, val, &dict)) | ||
return false; | ||
if (!dict.Get("name", &(out->first))) | ||
return false; | ||
if (!dict.Get("extensions", &(out->second))) | ||
return false; | ||
return true; | ||
} | ||
|
||
v8::Local<v8::Value> Converter<file_dialog::Filter>::ToV8( | ||
v8::Isolate* isolate, | ||
const file_dialog::Filter& in) { | ||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate); | ||
|
||
dict.Set("name", in.first); | ||
dict.Set("extensions", in.second); | ||
|
||
return dict.GetHandle(); | ||
} | ||
|
||
bool Converter<file_dialog::DialogSettings>::FromV8( | ||
v8::Isolate* isolate, | ||
v8::Local<v8::Value> val, | ||
file_dialog::DialogSettings* out) { | ||
mate::Dictionary dict; | ||
if (!ConvertFromV8(isolate, val, &dict)) | ||
return false; | ||
dict.Get("window", &(out->parent_window)); | ||
dict.Get("title", &(out->title)); | ||
dict.Get("message", &(out->message)); | ||
dict.Get("buttonLabel", &(out->button_label)); | ||
dict.Get("nameFieldLabel", &(out->name_field_label)); | ||
dict.Get("defaultPath", &(out->default_path)); | ||
dict.Get("filters", &(out->filters)); | ||
dict.Get("properties", &(out->properties)); | ||
dict.Get("showsTagField", &(out->shows_tag_field)); | ||
dict.Get("securityScopedBookmarks", &(out->security_scoped_bookmarks)); | ||
return true; | ||
} | ||
|
||
v8::Local<v8::Value> Converter<file_dialog::DialogSettings>::ToV8( | ||
v8::Isolate* isolate, | ||
const file_dialog::DialogSettings& in) { | ||
mate::Dictionary dict = mate::Dictionary::CreateEmpty(isolate); | ||
|
||
dict.Set("window", atom::api::BrowserWindow::From(isolate, in.parent_window)); | ||
dict.Set("title", in.title); | ||
dict.Set("message", in.message); | ||
dict.Set("buttonLabel", in.button_label); | ||
dict.Set("nameFieldLabel", in.name_field_label); | ||
dict.Set("defaultPath", in.default_path); | ||
dict.Set("filters", in.filters); | ||
dict.Set("showsTagField", in.shows_tag_field); | ||
dict.Set("securityScopedBookmarks", in.security_scoped_bookmarks); | ||
|
||
return dict.GetHandle(); | ||
} | ||
|
||
} // namespace mate |
33 changes: 33 additions & 0 deletions
33
atom/common/native_mate_converters/file_dialog_converter.h
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,33 @@ | ||
// Copyright (c) 2014 GitHub, Inc. | ||
// Use of this source code is governed by the MIT license that can be | ||
// found in the LICENSE file. | ||
|
||
#ifndef ATOM_COMMON_NATIVE_MATE_CONVERTERS_FILE_DIALOG_CONVERTER_H_ | ||
#define ATOM_COMMON_NATIVE_MATE_CONVERTERS_FILE_DIALOG_CONVERTER_H_ | ||
|
||
#include "atom/browser/ui/file_dialog.h" | ||
#include "native_mate/converter.h" | ||
|
||
namespace mate { | ||
|
||
template <> | ||
struct Converter<file_dialog::Filter> { | ||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, | ||
const file_dialog::Filter& in); | ||
static bool FromV8(v8::Isolate* isolate, | ||
v8::Local<v8::Value> val, | ||
file_dialog::Filter* out); | ||
}; | ||
|
||
template <> | ||
struct Converter<file_dialog::DialogSettings> { | ||
static v8::Local<v8::Value> ToV8(v8::Isolate* isolate, | ||
const file_dialog::DialogSettings& in); | ||
static bool FromV8(v8::Isolate* isolate, | ||
v8::Local<v8::Value> val, | ||
file_dialog::DialogSettings* out); | ||
}; | ||
|
||
} // namespace mate | ||
|
||
#endif // ATOM_COMMON_NATIVE_MATE_CONVERTERS_FILE_DIALOG_CONVERTER_H_ |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Oops, something went wrong.