| 
									
										
										
										
											2016-08-12 16:31:17 +07: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.
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 13:56:58 -07:00
										 |  |  | #ifndef SHELL_BROWSER_UI_WIN_JUMP_LIST_H_
 | 
					
						
							|  |  |  | #define SHELL_BROWSER_UI_WIN_JUMP_LIST_H_
 | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | #include <atlbase.h>
 | 
					
						
							|  |  |  | #include <shobjidl.h>
 | 
					
						
							|  |  |  | #include <vector>
 | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | #include "base/files/file_path.h"
 | 
					
						
							|  |  |  | #include "base/macros.h"
 | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 14:23:04 -07:00
										 |  |  | namespace electron { | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  | enum class JumpListResult : int { | 
					
						
							|  |  |  |   SUCCESS = 0, | 
					
						
							|  |  |  |   // In JS code this error will manifest as an exception.
 | 
					
						
							|  |  |  |   ARGUMENT_ERROR = 1, | 
					
						
							|  |  |  |   // Generic error, the runtime logs may provide some clues.
 | 
					
						
							|  |  |  |   GENERIC_ERROR = 2, | 
					
						
							|  |  |  |   // Custom categories can't contain separators.
 | 
					
						
							|  |  |  |   CUSTOM_CATEGORY_SEPARATOR_ERROR = 3, | 
					
						
							|  |  |  |   // The app isn't registered to handle a file type found in a custom category.
 | 
					
						
							|  |  |  |   MISSING_FILE_TYPE_REGISTRATION_ERROR = 4, | 
					
						
							|  |  |  |   // Custom categories can't be created due to user privacy settings.
 | 
					
						
							|  |  |  |   CUSTOM_CATEGORY_ACCESS_DENIED_ERROR = 5, | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct JumpListItem { | 
					
						
							|  |  |  |   enum class Type { | 
					
						
							|  |  |  |     // A task will launch an app (usually the one that created the Jump List)
 | 
					
						
							|  |  |  |     // with specific arguments.
 | 
					
						
							|  |  |  |     TASK, | 
					
						
							|  |  |  |     // Separators can only be inserted between items in the standard Tasks
 | 
					
						
							|  |  |  |     // category, they can't appear in custom categories.
 | 
					
						
							|  |  |  |     SEPARATOR, | 
					
						
							|  |  |  |     // A file link will open a file using the app that created the Jump List,
 | 
					
						
							|  |  |  |     // for this to work the app must be registered as a handler for the file
 | 
					
						
							|  |  |  |     // type (though the app doesn't have to be the default handler).
 | 
					
						
							|  |  |  |     FILE | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Type type = Type::TASK; | 
					
						
							|  |  |  |   // For tasks this is the path to the program executable, for file links this
 | 
					
						
							|  |  |  |   // is the full filename.
 | 
					
						
							|  |  |  |   base::FilePath path; | 
					
						
							|  |  |  |   base::string16 arguments; | 
					
						
							|  |  |  |   base::string16 title; | 
					
						
							|  |  |  |   base::string16 description; | 
					
						
							| 
									
										
										
										
											2019-05-13 18:17:12 +02:00
										 |  |  |   base::FilePath working_dir; | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  |   base::FilePath icon_path; | 
					
						
							|  |  |  |   int icon_index = 0; | 
					
						
							| 
									
										
										
										
											2018-06-25 22:30:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   JumpListItem(); | 
					
						
							|  |  |  |   JumpListItem(const JumpListItem&); | 
					
						
							|  |  |  |   ~JumpListItem(); | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | struct JumpListCategory { | 
					
						
							|  |  |  |   enum class Type { | 
					
						
							|  |  |  |     // A custom category can contain tasks and files, but not separators.
 | 
					
						
							|  |  |  |     CUSTOM, | 
					
						
							|  |  |  |     // Frequent/Recent categories are managed by the OS, their name and items
 | 
					
						
							|  |  |  |     // can't be set by the app (though items can be set indirectly).
 | 
					
						
							|  |  |  |     FREQUENT, | 
					
						
							|  |  |  |     RECENT, | 
					
						
							|  |  |  |     // The standard Tasks category can't be renamed by the app, but the app
 | 
					
						
							|  |  |  |     // can set the items that should appear in this category, and those items
 | 
					
						
							|  |  |  |     // can include tasks, files, and separators.
 | 
					
						
							|  |  |  |     TASKS | 
					
						
							|  |  |  |   }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   Type type = Type::TASKS; | 
					
						
							|  |  |  |   base::string16 name; | 
					
						
							|  |  |  |   std::vector<JumpListItem> items; | 
					
						
							| 
									
										
										
										
											2018-06-25 22:30:00 +02:00
										 |  |  | 
 | 
					
						
							|  |  |  |   JumpListCategory(); | 
					
						
							|  |  |  |   JumpListCategory(const JumpListCategory&); | 
					
						
							|  |  |  |   ~JumpListCategory(); | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  | // Creates or removes a custom Jump List for an app.
 | 
					
						
							|  |  |  | // See https://msdn.microsoft.com/en-us/library/windows/desktop/gg281362.aspx
 | 
					
						
							|  |  |  | class JumpList { | 
					
						
							|  |  |  |  public: | 
					
						
							|  |  |  |   // |app_id| must be the Application User Model ID of the app for which the
 | 
					
						
							|  |  |  |   // custom Jump List should be created/removed, it's usually obtained by
 | 
					
						
							|  |  |  |   // calling GetCurrentProcessExplicitAppUserModelID().
 | 
					
						
							|  |  |  |   explicit JumpList(const base::string16& app_id); | 
					
						
							| 
									
										
										
										
											2018-06-25 22:30:00 +02:00
										 |  |  |   ~JumpList(); | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |   // Starts a new transaction, must be called before appending any categories,
 | 
					
						
							|  |  |  |   // aborting or committing. After the method returns |min_items| will indicate
 | 
					
						
							|  |  |  |   // the minimum number of items that will be displayed in the Jump List, and
 | 
					
						
							|  |  |  |   // |removed_items| (if not null) will contain all the items the user has
 | 
					
						
							|  |  |  |   // unpinned from the Jump List. Both parameters are optional.
 | 
					
						
							|  |  |  |   bool Begin(int* min_items = nullptr, | 
					
						
							|  |  |  |              std::vector<JumpListItem>* removed_items = nullptr); | 
					
						
							|  |  |  |   // Abandons any changes queued up since Begin() was called.
 | 
					
						
							|  |  |  |   bool Abort(); | 
					
						
							|  |  |  |   // Commits any changes queued up since Begin() was called.
 | 
					
						
							|  |  |  |   bool Commit(); | 
					
						
							|  |  |  |   // Deletes the custom Jump List and restores the default Jump List.
 | 
					
						
							|  |  |  |   bool Delete(); | 
					
						
							|  |  |  |   // Appends a category to the custom Jump List.
 | 
					
						
							|  |  |  |   JumpListResult AppendCategory(const JumpListCategory& category); | 
					
						
							|  |  |  |   // Appends categories to the custom Jump List.
 | 
					
						
							|  |  |  |   JumpListResult AppendCategories( | 
					
						
							| 
									
										
										
										
											2018-04-17 21:44:10 -04:00
										 |  |  |       const std::vector<JumpListCategory>& categories); | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | 
 | 
					
						
							|  |  |  |  private: | 
					
						
							|  |  |  |   base::string16 app_id_; | 
					
						
							|  |  |  |   CComPtr<ICustomDestinationList> destinations_; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |   DISALLOW_COPY_AND_ASSIGN(JumpList); | 
					
						
							|  |  |  | }; | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 14:23:04 -07:00
										 |  |  | }  // namespace electron
 | 
					
						
							| 
									
										
										
										
											2016-08-12 16:31:17 +07:00
										 |  |  | 
 | 
					
						
							| 
									
										
										
										
											2019-06-19 13:56:58 -07:00
										 |  |  | #endif  // SHELL_BROWSER_UI_WIN_JUMP_LIST_H_
 |