Skip to content

Commit b91ef7e

Browse files
committedJun 25, 2020
refcator(extension): support new GitHub Design
1 parent 5560eec commit b91ef7e

13 files changed

+164
-27
lines changed
 

‎CHANGELOG.md

+28-16
Original file line numberDiff line numberDiff line change
@@ -1,14 +1,26 @@
1-
- **v3.1.0** _- 6th Jan, 2020_
1+
# Changelog
2+
All notable changes to this project will be documented in this file.
3+
4+
The format is based on [Keep a Changelog](https://keepachangelog.com/en/1.0.0/),
5+
and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).
6+
7+
## **v4.0.0** - 26th June, 2020
8+
9+
- Support new GitHub Design. Refer [GitHub Blog](https://github.blog/changelog/2020-06-23-design-updates-to-repositories-and-github-ui/)
10+
- Backward compatibility to the old design, if new UI is not 100% publicly available.
11+
- Fix the options token validation message issue.
12+
13+
## **v3.1.0** - 6th Jan, 2020
214

315
- Extension only utilizes `webNavigation` history for GitHub website using webNavigation event filters. Rest assured, history of any other website is not permitted.
416
- Updated README with the doc link explaining introduction of `webRequest` and `webNavigation` API for supporting single-page GitHub website.
517

6-
- **v3.0.1** _- 3rd Jan, 2020_
18+
## **v3.0.1** - 3rd Jan, 2020
719

820
- Use `webNavigation` API in background to detect page-url changes
921
- Remove `setInterval` and `onpopstate` for page-url change listener from `inject.js`
1022

11-
- **v3.0.0** _- 28th Dec, 2019_
23+
## **v3.0.0** - 28th Dec, 2019
1224

1325
- Since GitHub is now SPA, changes are made to handle SPA behavior
1426
- Introduce background script to get web requests and append elements when page is rendered. For this, `webRequest` permission is required.
@@ -18,62 +30,62 @@
1830
- `webRequest` - to support GitHub being a single-page-application now. Read this [detailed blog](https://medium.com/@softvar/making-chrome-extension-smart-by-supporting-spa-websites-1f76593637e8).
1931
- `webNavigation` - to support GitHub being a single-page-application now. Read this [detailed blog](https://medium.com/@softvar/making-chrome-extension-smart-by-supporting-spa-websites-1f76593637e8).
2032

21-
- **v2.1.0** _- 16th Nov, 2019_
33+
## **v2.1.0** - 16th Nov, 2019
2234

2335
- Remove gulp and used webpack for bundling and automation
2436
- Remove clipboard from source code and instead use a dep bundled with (minified)inject.js
2537
- Remove jshint and used eslint for linting
2638
- Use prettier for auto-formatting files
2739
- Use husky and lint-staged to configure and run git-hooks
2840

29-
- **v2.0.3** _- 27th Oct, 2018_
41+
## **v2.0.3** - 27th Oct, 2018
3042

3143
- Fix selector path for inserting _copy file_ and _download file_ buttons while viewing a file
3244
- Minify content script thereby saving `4KB` per request. `inject.js` from `12KB` to `4KB`
3345

34-
- **v2.0.2** _- 26th Oct, 2018_
46+
## **v2.0.2** - 26th Oct, 2018
3547

3648
- Fix buttons alignment in options.js
3749

38-
- **v2.0.0** _- 09th Aug, 2018_
50+
## **v2.0.0** - 09th Aug, 2018
3951

4052
- Improvement :: Update logos/icons to adhere with [GitHub logo policy](https://github.com/logos)
4153
- Improvement :: Show GitHub-styled tooltip when hovering hover file download link
4254

43-
- **v1.0.8** _- 1st May, 2018_
55+
## **v1.0.8** - 1st May, 2018
4456

4557
- Fix :: Update classes to fix download. (Cmd/Ctr + Click) to download file
4658

47-
- **v0.1.8** _- 10th Mar, 2017_
59+
## **v0.1.8** - 10th Mar, 2017
4860

4961
- Imporvemnt :: Use `clipboard` as a dependency and use it via `manifest.json`
5062

51-
- **v0.1.7** _- 10th Mar, 2017_
63+
## **v0.1.7** - 10th Mar, 2017
5264

5365
- Fix :: Add proper toggle class [github changed class names] which fixes flickering while hover
5466
- Fix :: Dont add `td` when there's no file present.
5567

56-
- **v0.1.6** _- 27th Aug, 2016_
68+
## **v0.1.6** - 27th Aug, 2016
5769

5870
- Fix :: not showing repo size when navigating back; fix no hash change detection
5971

60-
- **v0.1.5** _- 22nd Aug, 2016_
72+
## **v0.1.5** - 22nd Aug, 2016
6173

6274
- Feature :: Show repo size on GitHub's repo homepage
6375
- Fix :: bugfix of default branch other than **master**
6476

65-
- **v0.1.4** _- 20th Aug, 2016_
77+
## **v0.1.4** - 20th Aug, 2016
6678

6779
- Improvement :: Better way of adding GitHub Access token - click extension or click options - Enhanced GitHub after opening _chrome://extension_
6880

69-
- **v0.1.3** _- 14th Aug, 2016_
81+
## **v0.1.3** - 14th Aug, 2016
7082

7183
- Fix :: fix focus effect on up-tree not removing blank td while navigating [#3](https://github.com/softvar/enhanced-github/pull/3)
7284

73-
- **v0.1.2** _- 14th Aug, 2016_
85+
## **v0.1.2** - 14th Aug, 2016
7486

7587
- Fix :: fix bug file on commits/<branch> url
7688

77-
- **v0.1.1** _- 13th Aug, 2016_
89+
## **v0.1.1** - 13th Aug, 2016
7890

7991
- Initial Launch

‎README.md

+23
Original file line numberDiff line numberDiff line change
@@ -67,6 +67,19 @@ This Chrome extension will automatically pick this valid access token and Bingo!
6767

6868
## Screenshots
6969

70+
### New GitHub Design - [Blog](https://github.blog/changelog/2020-06-23-design-updates-to-repositories-and-github-ui/)
71+
72+
#### Screenshot of each file size and it's download link
73+
74+
<img src="screenshots/github-repo-home-new.png">
75+
76+
#### Screenshot of Copy fle contents and download link
77+
78+
<img src="screenshots/github-file-new.png">
79+
80+
81+
### Old GitHub Design
82+
7083
#### Screenshot of each file size and it's download link
7184

7285
<img src="screenshots/github-repo-home.png">
@@ -79,6 +92,7 @@ This Chrome extension will automatically pick this valid access token and Bingo!
7992

8093
- Thanks to [@zenorocha](https://github.com/zenorocha/) for [Clipboard.js](https://github.com/zenorocha/clipboard.js) - Modern copy to clipboard. No Flash. Just 3kb gzipped.
8194

95+
8296
## Development
8397

8498
1. Clone this repo
@@ -117,6 +131,15 @@ Support this project with your organization. Your logo will show up here with a
117131

118132
<a href="https://opencollective.com/enhanced-github/organization/0/website"><img src="https://opencollective.com/enhanced-github/organization/0/avatar.svg"></a>
119133

134+
## Policy
135+
136+
❗️NO BS POLICY:
137+
138+
> Enahanced GitHub Chrome Extension doesn't collect/share/care about your data at all.
139+
>
140+
> Asks for GitHub Access Token for private repos and if Rate Limiting is your concern.
141+
142+
120143
## Copyright and License
121144

122145
❗️ 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.

‎manifest.json

+2-2
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
{
22
"name": "Enhanced GitHub",
33
"short_name": "Enhanced GitHub",
4-
"version": "3.1.0",
4+
"version": "4.0.0",
55
"manifest_version": 2,
66
"description": "Display repo size, size of each file, download link and option to copy file contents",
77
"homepage_url": "https://github.com/softvar/enhanced-github",
@@ -13,7 +13,7 @@
1313
},
1414
"browser_action": {
1515
"default_icon": "icons/enhanced-github48.png",
16-
"default_popup": "index.html",
16+
"default_popup": "popup.html",
1717
"default_title": "Enhanced GitHub"
1818
},
1919
"permissions": ["*://*.github.com/*", "storage", "webRequest", "webNavigation"],

‎options.js

+7-3
Original file line numberDiff line numberDiff line change
@@ -30,11 +30,15 @@ function saveOptions() {
3030
// Update statusText to let user know options were saved.
3131
var statusText = document.getElementById('status--text');
3232
var validationWarning = document.getElementById('validation-warning');
33+
var validationMessage = validateUserToken(token);
3334

34-
statusText.textContent = 'Options saved!!';
35-
validationWarning.textContent = validateUserToken(token);
35+
if (!validationMessage) {
36+
statusText.textContent = 'Options saved!!';
37+
document.getElementById('status').style.display = 'inline-block';
38+
}
39+
40+
validationWarning.textContent = validationMessage;
3641

37-
document.getElementById('status').style.display = 'inline-block';
3842
setTimeout(function() {
3943
statusText.textContent = '';
4044
document.getElementById('status').style.display = 'none';

‎package.json

+3-1
Original file line numberDiff line numberDiff line change
@@ -1,7 +1,7 @@
11
{
22
"name": "enhanced-github",
33
"version": "3.1.0",
4-
"description": "Add-ons for GitHub website - Download File, display size of each file and Copy file contents",
4+
"description": "Add-ons for GitHub website - Repo size, Download File, display size of each file and Copy file contents",
55
"main": "src/inject.js",
66
"scripts": {
77
"dev": "webpack --watch --mode=development",
@@ -25,6 +25,8 @@
2525
"extension",
2626
"github",
2727
"enhanced-github",
28+
"repo-size",
29+
"file-size",
2830
"file-download"
2931
],
3032
"dependencies": {

‎index.html ‎popup.html

+1-1
Original file line numberDiff line numberDiff line change
@@ -59,7 +59,7 @@ <h4>Works only on <i>github.com/*</i></h4>
5959
<li>Automatically displays each file size in every active branch (not applicable for folder / symlink).</li>
6060
<li>Show download link for each individual file (not applicable for folder / symlink).</li>
6161
<li>Copy file's contents directly to Clipboard (just won't work for markdown files).</li>
62-
<li>Download file while viewing it's contents.</li>
62+
<li>Download file content.</li>
6363
</ol>
6464
</div>
6565

‎screenshots/github-file-new.png

385 KB
Loading

‎screenshots/github-repo-home-new.png

518 KB
Loading

‎src/inject.js

+6
Original file line numberDiff line numberDiff line change
@@ -10,6 +10,12 @@ const storageUtil = require('./utils/storageUtil');
1010
const CommonEnum = require('./enums/CommonEnum');
1111

1212
window.chrome.extension.sendMessage({}, function(_response) {
13+
window.enhancedGithub = {
14+
config: {
15+
isNewDesign: localStorage.getItem('enhanced-github-for-new-design') || 1
16+
}
17+
};
18+
1319
let readyStateCheckInterval = setInterval(function() {
1420
if (document.readyState === 'complete') {
1521
clearInterval(readyStateCheckInterval);

‎src/utils/commonUtil.js

+7
Original file line numberDiff line numberDiff line change
@@ -94,6 +94,13 @@ let commonUtil = {
9494
[].forEach.call(document.querySelectorAll(selector), function(el) {
9595
el.parentNode.removeChild(el);
9696
});
97+
},
98+
isForGithUbNewUi: function() {
99+
if (window.enhancedGithub && window.enhancedGithub.config) {
100+
return window.enhancedGithub.config.isNewDesign;
101+
}
102+
103+
return false;
97104
}
98105
};
99106

‎src/utils/domUtil.js

+30
Original file line numberDiff line numberDiff line change
@@ -32,6 +32,29 @@ let domUtil = {
3232
commonUtil.removePrevInstancesOf('.repo-size');
3333

3434
let formattedFileSize = commonUtil.convertSizeToHumanReadableFormat(storageUtil.get('repoSize') * 1024); // GitHub API return size in KB for repo
35+
36+
if (commonUtil.isForGithUbNewUi()) {
37+
let formattedFileSize = commonUtil.convertSizeToHumanReadableFormat(storageUtil.get('repoSize') * 1024); // GitHub API return size in KB for repo
38+
let elem = document.querySelector('a[href="#readme"]');
39+
40+
if (elem) {
41+
let html = `
42+
<div class="mt-3">
43+
<a href="javascript:void(0)" class="muted-link">
44+
<svg class="octicon octicon-database mr-2" mr="2" aria-hidden="true" height="16" version="1.1" viewBox="0 0 12 16" width="16">
45+
<path d="M6 15c-3.31 0-6-.9-6-2v-2c0-.17.09-.34.21-.5.67.86 3 1.5 5.79 1.5s5.12-.64 5.79-1.5c.13.16.21.33.21.5v2c0 1.1-2.69 2-6 2zm0-4c-3.31 0-6-.9-6-2V7c0-.11.04-.21.09-.31.03-.06.07-.13.12-.19C.88 7.36 3.21 8 6 8s5.12-.64 5.79-1.5c.05.06.09.13.12.19.05.1.09.21.09.31v2c0 1.1-2.69 2-6 2zm0-4c-3.31 0-6-.9-6-2V3c0-1.1 2.69-2 6-2s6 .9 6 2v2c0 1.1-2.69 2-6 2zm0-5c-2.21 0-4 .45-4 1s1.79 1 4 1 4-.45 4-1-1.79-1-4-1z"></path>
46+
</svg>
47+
<span class="text-emphasized">${formattedFileSize.size}</span>
48+
<span>${formattedFileSize.measure}</span>
49+
</a>
50+
</div>
51+
`;
52+
53+
elem.parentElement.insertAdjacentHTML('beforeend', html);
54+
}
55+
56+
return;
57+
}
3558
let elem = document.querySelector('ul.numbers-summary');
3659

3760
if (elem) {
@@ -100,6 +123,13 @@ let domUtil = {
100123
}
101124
},
102125
addFileSizeAndDownloadLink: function() {
126+
if (commonUtil.isForGithUbNewUi()) {
127+
apiUtil.getRepoContent(function(data) {
128+
handlersUtil.onPathContentFetched(data);
129+
});
130+
131+
return;
132+
}
103133
let links = document.querySelectorAll('tr.js-navigation-item > td.content a');
104134
let elems = document.querySelectorAll('tr.js-navigation-item > td.age');
105135

‎src/utils/handlersUtil.js

+55-3
Original file line numberDiff line numberDiff line change
@@ -30,9 +30,6 @@ let handlersUtil = {
3030
return;
3131
}
3232

33-
commonUtil.removePrevInstancesOf('.download'); // remove before adding new ones
34-
35-
let uptree = document.querySelectorAll('tr.up-tree > td');
3633
let isAnyFilePresent = false;
3734

3835
for (let i = 0; i < data.length; i++) {
@@ -46,6 +43,61 @@ let handlersUtil = {
4643
return;
4744
}
4845

46+
if (commonUtil.isForGithUbNewUi()) {
47+
setTimeout(function() {
48+
const containerItems = document.querySelectorAll(
49+
'.js-navigation-container.js-active-navigation-container .js-navigation-item'
50+
);
51+
52+
let actualDataIndex = 0;
53+
54+
for (var i = 0; i < containerItems.length; i++) {
55+
const commitElem = containerItems[i].querySelector('.commit-message');
56+
57+
if (commitElem) {
58+
containerItems[i].querySelector('div:nth-of-type(2)').classList.remove('col-md-2', 'mr-3');
59+
containerItems[i].querySelector('div:nth-of-type(2)').classList.add('col-md-1', 'mr-2');
60+
61+
if (data[actualDataIndex].type === 'file') {
62+
let formattedFileSize = commonUtil.getFileSizeAndUnit(data[actualDataIndex]);
63+
64+
let html = `
65+
<div role="gridcell" class="mr-1 text-gray-light" style="width: 95px;">
66+
<span class="css-truncate css-truncate-target d-block">
67+
<span style="margin-right: 5px;">
68+
${formattedFileSize}
69+
</span>
70+
<a style="float: right" href="${data[actualDataIndex].download_url}" title="(Alt/Option/Ctrl + Click) to download File" aria-label="(Alt/Option/Ctrl + Click) to download File" class="tooltipped tooltipped-s"
71+
download="${data[actualDataIndex].name}">
72+
<svg class="octicon octicon-cloud-download" aria-hidden="true" height="16" version="1.1" viewBox="0 0 16 16" width="16">
73+
<path d="M9 12h2l-3 3-3-3h2V7h2v5zm3-8c0-.44-.91-3-4.5-3C5.08 1 3 2.92 3 5 1.02 5 0 6.52 0 8c0 1.53 1 3 3 3h3V9.7H3C1.38 9.7 1.3 8.28 1.3 8c0-.17.05-1.7 1.7-1.7h1.3V5c0-1.39 1.56-2.7 3.2-2.7 2.55 0 3.13 1.55 3.2 1.8v1.2H12c.81 0 2.7.22 2.7 2.2 0 2.09-2.25 2.2-2.7 2.2h-2V11h2c2.08 0 4-1.16 4-3.5C16 5.06 14.08 4 12 4z"></path>
74+
</svg>
75+
</a>
76+
</span>
77+
</div>
78+
`;
79+
80+
commitElem.insertAdjacentHTML('afterend', html);
81+
} else {
82+
const defaultHtml = `
83+
<div role="gridcell" class="mr-1" style="width: 90px;"></div>
84+
`;
85+
86+
commitElem.insertAdjacentHTML('afterend', defaultHtml);
87+
}
88+
89+
actualDataIndex++;
90+
}
91+
}
92+
}, 1000);
93+
94+
return;
95+
}
96+
97+
commonUtil.removePrevInstancesOf('.download'); // remove before adding new ones
98+
99+
let uptree = document.querySelectorAll('tr.up-tree > td');
100+
49101
if (uptree && uptree[3]) {
50102
uptree[3].insertAdjacentHTML('afterend', '<td class="download"></td>');
51103
}

‎webpack.config.js

+2-1
Original file line numberDiff line numberDiff line change
@@ -45,7 +45,8 @@ function addPlugins(argv) {
4545
{ from: '*html', to: destination },
4646
{ from: 'manifest.json', to: destination },
4747
{ from: 'icons/*.png', to: destination },
48-
{ from: 'src/background.js', to: destination }
48+
{ from: 'src/background.js', to: destination },
49+
{ from: 'LICENSE', to: destination }
4950
],
5051
{ copyUnmodified: true }
5152
)

0 commit comments

Comments
 (0)
Please sign in to comment.