| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | // Copyright (c) 2016 GitHub, Inc. | 
					
						
							|  |  |  | // Use of this source code is governed by the MIT license that can be | 
					
						
							|  |  |  | // found in the LICENSE file. | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2023-01-09 10:00:47 +01:00
										 |  |  | #include "shell/browser/ui/drag_util.h" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | #import <Cocoa/Cocoa.h> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-05-02 14:05:37 +02:00
										 |  |  | #include <vector> | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
											![electron-roller[bot]](/assets/img/avatar_default.png)  
											
												chore: bump chromium to 118.0.5975.0 (main) (#39531)
* chore: bump chromium in DEPS to 118.0.5951.0
* chore: update printing.patch
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4727894
No logic changes, but patch needed to be manually re-applied due to upstream code shear
* chore: update port_autofill_colors_to_the_color_pipeline.patch
No manual changes; patch applied with fuzz
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5953.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5955.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5957.0
* chore: update patches
* chore: include path of native_web_keyboard_event.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
* chore: remove reference to eextensions/browser/notification-types.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4771627
* chore: update references to renamed upstream field NativeWebKeyboardEvent.skip_if_unhandled (formerly known as skip_in_browser
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
Need a second pair of eyes on this commit. In particular the reference in content_converter.cc, skipInBrowser, seems to not be set or documented anywhere? Is this unused/vestigal code?
* chore: sync signature of ElectronExtensionsBrowserClient::IsValidContext() to upstream change
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4784198
* chore: add auto_pip_setting_helper.[cc,h] to chromium_src build
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4688277
Exiting upstream code used by chromium_src now depends on this new upstream class
* chore: bump chromium in DEPS to 118.0.5959.0
* chore: update add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
Xref: add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
manually adjust patch to minor upstream chagnes
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5961.0
* chore: bump chromium in DEPS to 118.0.5963.0
* chore: update patches
* 4780994: Rename various base files to "apple" since iOS uses them too
https://chromium-review.googlesource.com/c/chromium/src/+/4780994
* Many files moved from `mac` -> `apple`
This commit follows a handful of CLs that simply rename files/symbols to change `mac`
to `apple`
to signify their use across both macOS and iOS:
- 4784010: Move scoped_nsautorelease_pool to base/apple, leave a forwarding header
- 4790744: Move foundation_util to base/apple, leave a forwarding header
- 4790741: Move scoped_cftypreref to base/apple, leave a forwarding header
- 4787627: Move and rename macOS+iOS base/ files in PA to "apple"
- 4780399: Move OSStatus logging to base/apple
- 4787387: Remove forwarding headers
- 4781113: Rename message_pump_mac to "apple" because iOS uses it too
* fixup minor patch update error
A function param got dropped from this patch somewhere earlier
* chore: bump chromium in DEPS to 118.0.5965.2
* chore: update patches
* 4799213: Move ScopedTypeRef and ScopedCFTypeRef into base::apple::
https://chromium-review.googlesource.com/c/chromium/src/+/4799213
* Fix removed include to BrowserContext
In crrev.com/c/4767962 an include to BrowserContext was removed,
which was necessary for compilation. This broke only for us because
"chrome/browser/profiles/profile.h" includes that class, but we remove
all references to profiles.
* chore: bump chromium in DEPS to 118.0.5967.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5969.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5971.0
* chore: bump chromium in DEPS to 118.0.5973.0
* chore: update patches
* 4772121: [OOPIF PDF] Replace PDFWebContentsHelper with PDFDocumentHelper
https://chromium-review.googlesource.com/c/chromium/src/+/4772121
* 4811164: [Extensions] Do some cleanup in ChromeManagementAPIDelegate.
https://chromium-review.googlesource.com/c/chromium/src/+/4811164
* 4809488: Remove duplicate dnd functionality between Web and Renderer prefs
https://chromium-review.googlesource.com/c/chromium/src/+/4809488
Given that this is no longer an option of web preferences, we should
consider deprecating this option and then removing it.
* chore: bump chromium in DEPS to 118.0.5975.0
* chore: update patches
* fixup! chore: add auto_pip_settings_helper.{cc|h} to chromium_src build
* Reland "[windows] Remove RegKey::DeleteEmptyKey"
Refs https://chromium-review.googlesource.com/c/chromium/src/+/4813255
* Ensure StrCat means StrCat
Refs https://chromium-review.googlesource.com/c/chromium/src/+/1117180
* fixup! Remove RegKey::DeleteEmptyKey
* Consistently reject large p and large q in DH
Refs https://boringssl-review.googlesource.com/c/boringssl/+/62226
---------
Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
Co-authored-by: Charles Kerr <charles@charleskerr.com>
Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
Co-authored-by: clavin <clavin@electronjs.org>
Co-authored-by: deepak1556 <hop2deep@gmail.com>
											
										 
											2023-09-01 15:54:59 +09:00
										 |  |  | #include "base/apple/foundation_util.h" | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | #include "base/files/file_path.h" | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  | // Contents largely copied from | 
					
						
							|  |  |  | // chrome/browser/download/drag_download_item_mac.mm. | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @interface DragDownloadItemSource : NSObject <NSDraggingSource> | 
					
						
							|  |  |  | @end | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @implementation DragDownloadItemSource | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | - (NSDragOperation)draggingSession:(NSDraggingSession*)session | 
					
						
							|  |  |  |     sourceOperationMaskForDraggingContext:(NSDraggingContext)context { | 
					
						
							| 
									
										
										
										
											2022-10-11 09:19:59 -07:00
										 |  |  |   return context == NSDraggingContextOutsideApplication ? NSDragOperationCopy | 
					
						
							|  |  |  |                                                         : NSDragOperationEvery; | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | @end | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  | namespace { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  | id<NSDraggingSource> GetDraggingSource() { | 
					
						
							|  |  |  |   static id<NSDraggingSource> source = [[DragDownloadItemSource alloc] init]; | 
					
						
							|  |  |  |   return source; | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }  // namespace | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  | namespace electron { | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2016-07-03 13:58:31 +09:00
										 |  |  | void DragFileItems(const std::vector<base::FilePath>& files, | 
					
						
							|  |  |  |                    const gfx::Image& icon, | 
					
						
							|  |  |  |                    gfx::NativeView view) { | 
					
						
							| 
									
										
										
										
											2023-01-09 10:00:47 +01:00
										 |  |  |   DCHECK(view); | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |   auto* native_view = view.GetNativeNSView(); | 
					
						
							|  |  |  |   NSPoint current_position = | 
					
						
							| 
									
										
										
										
											2023-01-09 10:00:47 +01:00
										 |  |  |       native_view.window.mouseLocationOutsideOfEventStream; | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |   current_position = | 
					
						
							|  |  |  |       [native_view backingAlignedRect:NSMakeRect(current_position.x, | 
					
						
							|  |  |  |                                                  current_position.y, 0, 0) | 
					
						
							|  |  |  |                               options:NSAlignAllEdgesOutward] | 
					
						
							|  |  |  |           .origin; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   NSMutableArray* file_items = [NSMutableArray array]; | 
					
						
							|  |  |  |   for (auto const& file : files) { | 
					
						
							| 
									
										
											![electron-roller[bot]](/assets/img/avatar_default.png)  
											
												chore: bump chromium to 118.0.5975.0 (main) (#39531)
* chore: bump chromium in DEPS to 118.0.5951.0
* chore: update printing.patch
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4727894
No logic changes, but patch needed to be manually re-applied due to upstream code shear
* chore: update port_autofill_colors_to_the_color_pipeline.patch
No manual changes; patch applied with fuzz
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5953.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5955.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5957.0
* chore: update patches
* chore: include path of native_web_keyboard_event.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
* chore: remove reference to eextensions/browser/notification-types.h
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4771627
* chore: update references to renamed upstream field NativeWebKeyboardEvent.skip_if_unhandled (formerly known as skip_in_browser
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4758689
Need a second pair of eyes on this commit. In particular the reference in content_converter.cc, skipInBrowser, seems to not be set or documented anywhere? Is this unused/vestigal code?
* chore: sync signature of ElectronExtensionsBrowserClient::IsValidContext() to upstream change
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4784198
* chore: add auto_pip_setting_helper.[cc,h] to chromium_src build
Xref: https://chromium-review.googlesource.com/c/chromium/src/+/4688277
Exiting upstream code used by chromium_src now depends on this new upstream class
* chore: bump chromium in DEPS to 118.0.5959.0
* chore: update add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
Xref: add_maximized_parameter_to_linuxui_getwindowframeprovider.patch
manually adjust patch to minor upstream chagnes
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5961.0
* chore: bump chromium in DEPS to 118.0.5963.0
* chore: update patches
* 4780994: Rename various base files to "apple" since iOS uses them too
https://chromium-review.googlesource.com/c/chromium/src/+/4780994
* Many files moved from `mac` -> `apple`
This commit follows a handful of CLs that simply rename files/symbols to change `mac`
to `apple`
to signify their use across both macOS and iOS:
- 4784010: Move scoped_nsautorelease_pool to base/apple, leave a forwarding header
- 4790744: Move foundation_util to base/apple, leave a forwarding header
- 4790741: Move scoped_cftypreref to base/apple, leave a forwarding header
- 4787627: Move and rename macOS+iOS base/ files in PA to "apple"
- 4780399: Move OSStatus logging to base/apple
- 4787387: Remove forwarding headers
- 4781113: Rename message_pump_mac to "apple" because iOS uses it too
* fixup minor patch update error
A function param got dropped from this patch somewhere earlier
* chore: bump chromium in DEPS to 118.0.5965.2
* chore: update patches
* 4799213: Move ScopedTypeRef and ScopedCFTypeRef into base::apple::
https://chromium-review.googlesource.com/c/chromium/src/+/4799213
* Fix removed include to BrowserContext
In crrev.com/c/4767962 an include to BrowserContext was removed,
which was necessary for compilation. This broke only for us because
"chrome/browser/profiles/profile.h" includes that class, but we remove
all references to profiles.
* chore: bump chromium in DEPS to 118.0.5967.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5969.0
* chore: update patches
* chore: bump chromium in DEPS to 118.0.5971.0
* chore: bump chromium in DEPS to 118.0.5973.0
* chore: update patches
* 4772121: [OOPIF PDF] Replace PDFWebContentsHelper with PDFDocumentHelper
https://chromium-review.googlesource.com/c/chromium/src/+/4772121
* 4811164: [Extensions] Do some cleanup in ChromeManagementAPIDelegate.
https://chromium-review.googlesource.com/c/chromium/src/+/4811164
* 4809488: Remove duplicate dnd functionality between Web and Renderer prefs
https://chromium-review.googlesource.com/c/chromium/src/+/4809488
Given that this is no longer an option of web preferences, we should
consider deprecating this option and then removing it.
* chore: bump chromium in DEPS to 118.0.5975.0
* chore: update patches
* fixup! chore: add auto_pip_settings_helper.{cc|h} to chromium_src build
* Reland "[windows] Remove RegKey::DeleteEmptyKey"
Refs https://chromium-review.googlesource.com/c/chromium/src/+/4813255
* Ensure StrCat means StrCat
Refs https://chromium-review.googlesource.com/c/chromium/src/+/1117180
* fixup! Remove RegKey::DeleteEmptyKey
* Consistently reject large p and large q in DH
Refs https://boringssl-review.googlesource.com/c/boringssl/+/62226
---------
Co-authored-by: electron-roller[bot] <84116207+electron-roller[bot]@users.noreply.github.com>
Co-authored-by: Charles Kerr <charles@charleskerr.com>
Co-authored-by: PatchUp <73610968+patchup[bot]@users.noreply.github.com>
Co-authored-by: clavin <clavin@electronjs.org>
Co-authored-by: deepak1556 <hop2deep@gmail.com>
											
										 
											2023-09-01 15:54:59 +09:00
										 |  |  |     NSURL* file_url = base::apple::FilePathToNSURL(file); | 
					
						
							| 
									
										
										
										
											2023-08-04 10:47:29 +02:00
										 |  |  |     NSDraggingItem* file_item = | 
					
						
							|  |  |  |         [[NSDraggingItem alloc] initWithPasteboardWriter:file_url]; | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |     NSImage* file_image = icon.ToNSImage(); | 
					
						
							|  |  |  |     NSSize image_size = file_image.size; | 
					
						
							|  |  |  |     NSRect image_rect = NSMakeRect(current_position.x - image_size.width / 2, | 
					
						
							|  |  |  |                                    current_position.y - image_size.height / 2, | 
					
						
							|  |  |  |                                    image_size.width, image_size.height); | 
					
						
							|  |  |  |     [file_item setDraggingFrame:image_rect contents:file_image]; | 
					
						
							|  |  |  |     [file_items addObject:file_item]; | 
					
						
							|  |  |  |   } | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Synthesize a drag event, since we don't have access to the actual event | 
					
						
							|  |  |  |   // that initiated a drag (possibly consumed by the Web UI, for example). | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |   NSEvent* dragEvent = | 
					
						
							|  |  |  |       [NSEvent mouseEventWithType:NSEventTypeLeftMouseDragged | 
					
						
							| 
									
										
										
										
											2023-01-09 10:00:47 +01:00
										 |  |  |                          location:current_position | 
					
						
							| 
									
										
										
										
											2022-10-11 09:19:59 -07:00
										 |  |  |                     modifierFlags:0 | 
					
						
							| 
									
										
										
										
											2023-01-09 10:00:47 +01:00
										 |  |  |                         timestamp:NSApp.currentEvent.timestamp | 
					
						
							|  |  |  |                      windowNumber:native_view.window.windowNumber | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |                           context:nil | 
					
						
							|  |  |  |                       eventNumber:0 | 
					
						
							|  |  |  |                        clickCount:1 | 
					
						
							|  |  |  |                          pressure:1.0]; | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Run the drag operation. | 
					
						
							| 
									
										
										
										
											2022-06-20 15:17:53 +02:00
										 |  |  |   [native_view beginDraggingSessionWithItems:file_items | 
					
						
							|  |  |  |                                        event:dragEvent | 
					
						
							|  |  |  |                                       source:GetDraggingSource()]; | 
					
						
							| 
									
										
										
										
											2016-07-03 12:26:43 +09:00
										 |  |  | } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | }  // namespace electron |