Item logo image for Diff Navigator for GitHub

Diff Navigator for GitHub

deanattali.com
5.0(

3 ratings

)
Item media 5 screenshot
Item media 1 screenshot
Item media 2 screenshot
Item media 3 screenshot
Item media 4 screenshot
Item media 5 screenshot
Item media 1 screenshot
Item media 1 screenshot
Item media 2 screenshot
Item media 3 screenshot
Item media 4 screenshot
Item media 5 screenshot

Overview

GitHub Diff Navigator allows you to easily navigate through the changes in a file that has been edited on GitHub.

Code available at: https://github.com/daattali/github-diff-navigator-extension/ Description ========= This is a Chrome extension that allows you to easily navigate through the changes in a file that has been edited on GitHub. You may have noticed that after editing a file through GitHub and previewing your changes, there is no easy way to navigate through the changes in a nice "next/previous change" manner. Most file formats only show the lines that were changed and several surrounding lines, so it's usually not a terrible inconvenience, but for any markdown document (.md) the situation is different. GitHub shows the entire markdown document when previewing the changes made, which means that if you're making a few tiny edits to a large document, it's very hard to find those edits and see what's changed. Rmarkdown (.Rmd) documents behave similarly, and potentially other markdown-type documents as well. Enter: GitHub Diff Navigator. Motivation ========= The idea for this extension came when I was reading through Hadley Wickham's Advanced R book. Every time I found a few typos in a chapter (which is a single markdown document), I would edit it on GitHub and make a pull request. To make sure I didn't make an idiot out of myself, I wanted to double-check my edits in the Preview tab, but I noticed the problem described above. I didn't trust my eyes in finding the few edits in such large files, and I ended up using the DOM + JavaScript console to help me find where the edits were. Then I decided that playing in the JavaScript console wasn't hardcore enough and I decided to spend the next two days making an extension that will help me find such changes quickly in the future. Features ========= - GitHub Diff Navigator is non-intrusive and will only show up when looking at the Preview of edits made on a file using GitHub. - GitHub Diff Navigator will not take up any resources or show up in Chrome's Task Manager when you don't have a valid GitHub edited page open. - Works with multiple GitHub tabs that are open simultaneously (every time you switch tabs, the extension will update to show you the edits in that tab). - Automatically detect whether the file being edited is markdown-type or not, and seamlessly works for both. - Clean and intuitive UI with helpful messages shown when no edits are found. Disclaimer ========= I would not advise using my code as a template or resource for learning how to write Chrome extensions. I learned how to write the extension and fully built it within two days, so I'm not sure what the best practices are and how to properly organize the code. It was just an excuse to test out how Chrome extensions work. I also left a little bit of ugly code in there -- please dont judge :)

5 out of 53 ratings

Google doesn't verify reviews. Learn more about results and reviews.

Review's profile picture

Keshini D.Jan 10, 2015

This extension is extremely helpful and useful!!

1 out of 2 found this helpful
Review's profile picture

Justin ChuJan 8, 2015

Useful for large markdown documents!

1 out of 2 found this helpful

Details

  • Version
    1.0
  • Updated
    April 28, 2023
  • Size
    43.72KiB
  • Languages
    English
  • Developer
    Website
    Email
    dean@attalitech.com
  • Non-trader
    This developer has not identified itself as a trader. For consumers in the European Union, please note that consumer rights do not apply to contracts between you and this developer.

Privacy

The developer has disclosed that it will not collect or use your data.

This developer declares that your data is

  • Not being sold to third parties, outside of the approved use cases
  • Not being used or transferred for purposes that are unrelated to the item's core functionality
  • Not being used or transferred to determine creditworthiness or for lending purposes

Support

Google apps