/enhanced-github

:rocket: Browser extension to display size of each file, download link and copy file contents directly to the clipboard

Primary LanguageJavaScriptMIT LicenseMIT

Enhanced GitHub

Browser extension that adds useful features on GitHub website


Chrome Web Store Chrome Web Store

Firefox Users Firefox Add-on

Microsoft Edge Add-on

Build Status

github-plus - Chrome Extension to display file size, download & copy link | Product Hunt Embed

Supported Browsers

Chrome Install extension from Chrome Web Store

Firefox Install add-on from Firefox Add-ons

Microsoft Edge Install extension from Microsoft Edge Add-ons

Website

Home

Features

  • Displays repo size.
  • Displays each file size for every active branch (not applicable for folder / symlink).
  • Show download link for each file (not applicable for folder / symlink).
  • Copy file's contents directly to Clipboard (just won't work for markdown files).
  • Download file while viewing its contents.

The extension handles the SPA behavior of GitHub website from v3.0.0 onwards :)

Note: For private repos(Issue #6), GitHub Access Token is required. Follow the steps mentioned below to add your GitHub Access Token.

Permissions required

  • "*://*.github.com/*" - for running on github.com domain.
  • storage - for storing GitHub access token on your local system. GitHub Access token is required for private repos and for handling API rate-limiting issues.
  • webRequest - to support GitHub being a single-page-application now. Read this detailed blog.
  • webNavigation - to support GitHub being a single-page-application now. Read this detailed blog.

Author

Varun Malhotra Varun Malhotra Website 𝕏 StackOverflow LinkedIn GitHub

GitHub API Rate Limiting

Since this extension fetches data using GitHub public v3 API for showing file size and download_url, it consumes free quota which is very less GitHub API Rate Limiting.

To tackle this, create a new GitHub Access Token.

  1. If logged-in, visit https://github.com/settings/tokens

  2. Generate a new token, select repo scope and create a one.

  3. Copy and store the generated token which looks something like: 17c1a8d5b399d66b6212382d98d4c67a94d58955 (a fake one :P).

  4. Click on extension icon and then on Settings-Options on top right.

    OR

    Right-click on enhanced-github extension and click on Options in the dropdown menu.

  5. Enter the valid GitHub Access Token

  6. Click on SAVE and Enjoy the benefits.

This browser extension will automatically pick this valid access token and Bingo!

Screenshots

2024 - Updated GitHub UI

Screenshot of each file size and it's download link

New GitHub Design - Blog

Screenshot of each file size and it's download link

Screenshot of Copy file contents and download link

Old GitHub Design

Screenshot of each file size and it's download link

Screenshot of Copy fle contents and download link

Libraries Used

Development

  1. Clone this repo
  2. Run yarn dev for generating packaged folder specifically for extension stuff.
  3. Go to extension page. For chrome extensions chrome://extensions, Firefox Add-ons about:debugging, and Microsoft Edge Extensions edge://extensions/.
  4. Enable developer mode
  5. Click on load unpacked extension and select the generated folder.
  6. [Admin Access Only] - run yarn build for generating zip file to be uploaded on Chrome Web Store, Firefox Add-ons, and Microsoft Edge Addons.

PRs are most welcome :)

Changelog

CHANGELOG.md

Contributors

Author: Varun Malhotra(@softvar)

Code Contributors

This project exists thanks to all the people who contribute. [Contribute].

Financial Contributors

Become a financial contributor and help us sustain our community. [Contribute]

Individuals

Organizations

Support this project with your organization. Your logo will show up here with a link to your website. [Contribute]

Policy

Refer Privacy Policy.

Enhanced GitHub Extension doesn't collect/share/care about your data at all.

Asks for GitHub Access Token for private repos and if Rate Limiting is your concern.

Copyright and License

❗️ This extension is not sponsored by, endorsed by, or an official project of GitHub. This is a personal project and is developed solely for providing additional functionalities on GitHub website.

The MIT license (MIT)

Copyright (c) 2016-2024 Varun Malhotra

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.