Skip to content

Commit

Permalink
Add alert for mobile config download
Browse files Browse the repository at this point in the history
  • Loading branch information
Brandon-T committed Jan 3, 2025
1 parent b4c21dc commit 09591e4
Show file tree
Hide file tree
Showing 2 changed files with 34 additions and 1 deletion.
Original file line number Diff line number Diff line change
Expand Up @@ -744,7 +744,26 @@ extension BrowserViewController: WKNavigationDelegate {
let mimeType = response.mimeType.flatMap({ UTType(mimeType: $0) }),
mimeTypesThatRequireSFSafariViewControllerHandling.contains(mimeType)
{
handleLinkWithSafariViewController(url, tab: tab)
// Do what Chromium does: https://source.chromium.org/chromium/chromium/src/+/main:ios/chrome/browser/download/ui_bundled/safari_download_coordinator.mm;l=100;bpv=1;bpt=1?q=presentMobileConfigAlertFromURL&ss=chromium%2Fchromium%2Fsrc
// and present an alert before showing the Safari View Controller

let alert = UIAlertController(
title: Strings.openMobileConfigurationAlertTitle,
message: String.init(
format: Strings.openMobileConfigurationAlertDescription,
url.absoluteString
),
preferredStyle: .alert
)
alert.addAction(
UIAlertAction(title: Strings.OBContinueButton, style: .default) { [weak self] _ in
self?.handleLinkWithSafariViewController(url, tab: tab)
}
)

alert.addAction(UIAlertAction(title: Strings.cancelButtonTitle, style: .cancel))
present(alert, animated: true)

return .cancel
}

Expand Down
14 changes: 14 additions & 0 deletions ios/brave-ios/Sources/BraveStrings/BraveStrings.swift
Original file line number Diff line number Diff line change
Expand Up @@ -3619,6 +3619,20 @@ extension Strings {
value: "Don't Allow",
comment: "Don't allow Brave to open the external app URL"
)
public static let openMobileConfigurationAlertTitle = NSLocalizedString(
"OpenMobileConfigurationAlertTitle",
tableName: "BraveShared",
bundle: .module,
value: "Configuration profile available",
comment: "Title of the alert when a mobile configuration profile is available for download"
)
public static let openMobileConfigurationAlertDescription = NSLocalizedString(
"OpenMobileConfigurationAlertTitle",
tableName: "BraveShared",
bundle: .module,
value: "Continue download a configuration profile from %@",
comment: "Title of the alert when a mobile configuration profile is available for download. %@ is the URL placeholder of the website where the profile will be downloaded from"
)
public static let requestCameraPermissionPrompt = NSLocalizedString(
"requestCameraPermissionPrompt",
tableName: "BraveShared",
Expand Down

0 comments on commit 09591e4

Please sign in to comment.