Save as Shortcut

#4.5 / 107 rate

Save as Shortcut

10,000 users

2019-10-30

https://mythofechelon....

Extension Information

5 star
69%
4 star
19%
3 star
6%
2 star
5%
1 star
0%

Supported Languages

Permissions

Description

Offers the ability to save tab(s) and bookmarks as Internet shortcut files.

PLEASE NOTE: If you're experiencing a problem, please DO NOT SUBMIT A REVIEW. Email me for a fast reply or submit a support ticket for a slow reply.

-Description-
Personally, I've always used Internet shortcut files for a variety of reasons. For example:
1. To passively share links to content via shared folders.
2. To supersede the temporary use of pinned tabs and bookmarks.
3. As portable links.
4. To accompany resources (installers with links to the websites, projects with links to assets, etc).
However, I always found them so awkward to create, hence me creating this extension.

-FAQ-
Q: As Chrome manifest v2 is being depreciated in 2024, is this extension being updated to support v3?
A: Yes, after quite a lot of work, I have successfully rewritten Save as Shortcut to support Chrome manifest v3 and its asynchronous service workers.

Q: Why does this extension say that it reads my browsing history?
A: I don't know. It does not. To see the real permissions, check file "%localAppData%\Google\Chrome\User Data\Default\Extensions\flehofiklehmnnolpjcamplcnmhgcbkk\_0\manifest.json" → section / key "permissions".

Q: Are you aware of X issue?
A: As of 2024/07/20, I'm not aware of any issues.

Q: Can this extension be updated to do X?
A: I'm open to ideas so feel free to contact me.

Q: Can I test upcoming features and fixes?
A: Yes, there is a beta version available here: https://chrome.google.com/webstore/detail/save-as-shortcut-beta/kmemfmaclfmhaddkneldhbcmlpoanbmg

Q: Does this extension have any tracking or collect any personal information?
A: Nope. Simple as that. In fact, third parties regularly offer to pay me relatively large sums of money per month to inject their code into my app and I have always refused because I hate it when other developers do that so I don't want to be that person.

Q: Can I donate?
A: Sure. 😊 https://paypal.me/mythofechelon

-Version history-
• 5.67.2213, 2024/05/25 (published to beta first):
- Changed manifest version from 2 to 3 which required the following:
+ As background pages have been removed, replaced with a service worker.
+ As service workers cannot access localStorage, replaced usage with chrome.storage.local and message passing between service worker and popup.
+ As service workers are inherently asynchronous but code needs to be processed synchronously, changed all functions to be async and all function calls to use await.
+ As service workers don't have a page, changed download method from simulating a click on the background page to chrome.downloads.download (hence new permission "downloads").
+ Replaced chrome.contextMenus.create → onclick with chrome.contextMenus.onClicked.addListener.
+ As service workers cannot use chrome.extension.getViews to access the popup page, replaced usage with message passing.
- Upgraded JSZip from v3.2.1 to v3.10.1.

• 4.66.1952, 2024/06/06:
- So that user options / preferences are preserved, added code to frequently migrate the data from localStorage to chrome.storage.local (hence new permission "storage") in preparation for the migration to already-completed Save as Shortcut v5 which uses Chrome manifest v3 which cannot access localStorage.

• 4.65.1944, 2021/07/20 (published to beta first):
- Implemented trimming of file names larger than 225 characters (Windows NTFS maximum of 255 minus spacing for prefixes of 30), as these were breaking extraction of ZIP files.

• 4.64.1939, 2021/06/11:
- Implemented workaround for Google Chrome version ~91.0.4472.77 bug / error "Unchecked runtime.lastError: Tabs cannot be queried right now (user may be dragging a tab)." Refer to https://stackoverflow.com/questions/67806779/im-getting-an-error-tabs-cannot-be-edited-right-now-user-may-be-dragging-a-ta

• 4.64.1936, 2021/05/15:
- Fixed bug where context menu wouldn't be removed. This was due to an old localStorage variable name being referenced in a catchall if statement and, therefore, always being null and matching.

• 4.64, 2021/03/27 to 2021/03/28 (published to beta first):
- Changed option "Diagnostic log and console" from opening background page to including guidance on how to open the background page, as it was opening a secondary one that didn't include the logging data.
- Added copying to clipboard when selecting file name variables.
- Added help tooltips to the more obscure file name variables.
- Improved diagnostic logging details (greater detail, greater readability, consolidated background.js logging to also use function, removed 'background_Log("")' and added newline characters to actual logging line, fixed logging of tab info objects).
- Improved performance by removing calls to background_processData_Generate_Name_Shortcut() from background_Tabs_Single_setDetails_* and adding them to the end of each original function.
- Changed option "Preserve order in bookmarks archive" to default to enabled.
- Changed handling of unnamed bookmarks, appending host in parenthesis to give some indication.
- Added handling of 0 tabs (happens when DevTools window is focused).
- Updated description to include saving of bookmarks as a feature.
- Converted the URL and archive name pattern fields from to