Link between Github Pages and their repos

Adds a link to the DOM to quickly switch between github repos and their deployed Github Pages.

  1. // ==UserScript==
  2. // @name Link between Github Pages and their repos
  3. // @namespace https://jonas.ninja
  4. // @version 1.0.0
  5. // @description Adds a link to the DOM to quickly switch between github repos and their deployed Github Pages.
  6. // @author @iv_njonas
  7. // @match https://*.github.io/*
  8. // @match https://*.github.com/*
  9. // @grant GM_addStyle
  10. // ==/UserScript==
  11. /* jshint asi: true, multistr: true */
  12.  
  13. (function() {
  14. var imgs = {
  15. small: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABYAAAAWCAYAAADEtGw7AAAAAXNSR0IArs4c6QAAAARnQU1BAACxjwv8YQUAAAAJcEhZcwAADsMAAA7DAcdvqGQAAAAadEVYdFNvZnR3YXJlAFBhaW50Lk5FVCB2My41LjEwMPRyoQAAAqpJREFUSEuNlTtrVFEUha+DioKFoI0aER8pBMVCCwstxCKFIqI/wU7BKhCw1Eq0CGn0T2ihhSRVJJn3+/1OSpEYC4kiSSbj+m72nRwnk8ks2HDu3muts/c59854g1CrN44kU+nr8URyUvElHIl+X1gMbxKsyVGDA9dkw5EvFE/F4onXMmjIaEvR3SO24MBFY/LdqFRrB1PpzC2RcxLR3SCzQcEUObR4mN0O0pnsbRFKIg7rcq+g+xIeZrcNjXJahTyExXBkTeN91PNXrVfJKdbJE6yNtwoHruUxz+Plm3L4Kr5RwR9fpHa5Ur2ksY7qch5ForG3EnCJTwjW5KjBgYsGLR54+Rcqwg2RW1bAuFGt1c+yabPVPlBvNA+3l5b9JgBrctR4hosm0OOFp6cuppTonasKhVK5cs53GQFw0QR6vPD01Pqck+xqtyl1EzLdvoCLxvXA09NuK0FCI/1Vctw0IwMN2sAHT0+LjpP4EY3Fx4w/MtCgDXzwxNj9GNZFumj8kYEGreOzyVF8cxJdveQPjD8y0LgeePJWfHKTekfnsrn8CdPsC7hoXA88MX6uh9456xL+6DLe6Qs6Y9o9Ic4YXDSBHi88GeOqWi+quKIfklc6rw9a/1aulUimpnP5wn19FP7HALQOqcuHqs2Ix4flni3HUMTTazRbh7TDCyU3lKxmsrm7Mv+sZ/9SVZvu//KUmwmM+mIDLzx9skY6rnOaV6Gj0d5rx3F1/1QxqY7P+yQH4jzuMyQ6eOBltG3I7IoKqkd+ateXGvdmoVi6ViyV/ycKmujeANMFPIyyA7UfUoeXJZqV+S8dy7KCf4g7Rumhz5h3fxYtHkbZDXV4TBfzTB1EtMGaRBNW6oEcNThw0VhpOFrtJW7+goQTMjlp6R7IUYMD19IOPO8fPoW0c/VPyNAAAAAASUVORK5CYII=',
  16. medium: 'data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAACAAAAAgCAYAAABzenr0AAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAyRpVFh0WE1MOmNvbS5hZG9iZS54bXAAAAAAADw/eHBhY2tldCBiZWdpbj0i77u/IiBpZD0iVzVNME1wQ2VoaUh6cmVTek5UY3prYzlkIj8+IDx4OnhtcG1ldGEgeG1sbnM6eD0iYWRvYmU6bnM6bWV0YS8iIHg6eG1wdGs9IkFkb2JlIFhNUCBDb3JlIDUuMy1jMDExIDY2LjE0NTY2MSwgMjAxMi8wMi8wNi0xNDo1NjoyNyAgICAgICAgIj4gPHJkZjpSREYgeG1sbnM6cmRmPSJodHRwOi8vd3d3LnczLm9yZy8xOTk5LzAyLzIyLXJkZi1zeW50YXgtbnMjIj4gPHJkZjpEZXNjcmlwdGlvbiByZGY6YWJvdXQ9IiIgeG1sbnM6eG1wPSJodHRwOi8vbnMuYWRvYmUuY29tL3hhcC8xLjAvIiB4bWxuczp4bXBNTT0iaHR0cDovL25zLmFkb2JlLmNvbS94YXAvMS4wL21tLyIgeG1sbnM6c3RSZWY9Imh0dHA6Ly9ucy5hZG9iZS5jb20veGFwLzEuMC9zVHlwZS9SZXNvdXJjZVJlZiMiIHhtcDpDcmVhdG9yVG9vbD0iQWRvYmUgUGhvdG9zaG9wIENTNiAoTWFjaW50b3NoKSIgeG1wTU06SW5zdGFuY2VJRD0ieG1wLmlpZDpFMTZCRDY3REIzRjAxMUUyQUQzREIxQzRENUFFNUM5NiIgeG1wTU06RG9jdW1lbnRJRD0ieG1wLmRpZDpFMTZCRDY3RUIzRjAxMUUyQUQzREIxQzRENUFFNUM5NiI+IDx4bXBNTTpEZXJpdmVkRnJvbSBzdFJlZjppbnN0YW5jZUlEPSJ4bXAuaWlkOkUxNkJENjdCQjNGMDExRTJBRDNEQjFDNEQ1QUU1Qzk2IiBzdFJlZjpkb2N1bWVudElEPSJ4bXAuZGlkOkUxNkJENjdDQjNGMDExRTJBRDNEQjFDNEQ1QUU1Qzk2Ii8+IDwvcmRmOkRlc2NyaXB0aW9uPiA8L3JkZjpSREY+IDwveDp4bXBtZXRhPiA8P3hwYWNrZXQgZW5kPSJyIj8+SM9MCAAAA+5JREFUeNrEV11Ik1EY3s4+ddOp29Q5b0opCgKFsoKoi5Kg6CIhuwi6zLJLoYLopq4qsKKgi4i6CYIoU/q5iDAKs6syoS76IRWtyJ+p7cdt7sf1PGOD+e0c3dygAx/67ZzzPM95/877GYdHRg3ZjMXFxepQKNS6sLCwJxqNNuFpiMfjVs4ZjUa/pmmjeD6VlJS8NpvNT4QQ7mxwjSsJiEQim/1+/9lgMHgIr5ohuxG1WCw9Vqv1clFR0dCqBODElV6v90ogEDjGdYbVjXhpaendioqK07CIR7ZAqE49PT09BPL2PMgTByQGsYiZlQD4uMXtdr+JxWINhgINYhGT2MsKgMrm2dnZXgRXhaHAg5jEJodUAHxux4LudHJE9RdEdA+i3Juz7bGHe4mhE9FNrgwBCLirMFV9Okh5eflFh8PR5nK5nDabrR2BNJlKO0T35+Li4n4+/J+/JQCxhmu5h3uJoXNHPbmWZAHMshWB8l5/ipqammaAf0zPDDx1ONV3vurdidqwAQL+pEc8sLcAe1CCvQ3YHxIW8Pl85xSWNC1hADDIv0rIE/o4J0k3kww4xSlwIhcq3EFFOm7KN/hUGOQkt0CFa5WpNJlMvxBEz/IVQAxg/ZRZl9wiHA63yDYieM7DnLP5CiAGsC7I5sgtYKJGWe2A8seFqgFJrJjEPY1Cn3pJ8/9W1e5VWsFDTEmFrBcoDhZJEQkXuhICMyKpjhahqN21hRYATKfUOlDmkygrR4o4C0VOLGJKrOITKB4jijzdXygBKixyC5TDQdnk/Pz8qRw6oOWGlsTKGOQW6OH6FBWsyePxdOXLTgxiyebILZCjz+GLgMIKnXNzc49YMlcRdHXcSwxFVgTInQhC9G33UhNoJLuqq6t345p9y3eUy8OTk5PjAHuI9uo4b07FBaOhsu0A4Unc+T1TU1Nj3KsSSE5yJ65jqF2DDd8QqWYmAZrIM2VlZTdnZmb6AbpdV9V6ec9znf5Q7HjYumdRE0JOp3MjitO4SFa+cZz8Umqe3TCbSLvdfkR/kWDdNQl5InuTcysOcpFT35ZrbBxx4p3JAHlZVVW1D/634VRt+FvLBgK/v5LV9WS+10xMTEwtRw7XvqOL+e2Q8V3AYIOIAXQ26/heWVnZCVfcyKHg2CBgTpmPmjYM8l24GyaUHyaIh7XwfR9ErE8qHoDfn2LTNAVC0HX6MFcBIP8Bi+6F6cdW/DICkANRfx99fEYFQ7Nph5i/uQiA214gno7K+guhaiKg9gC62+M8eR7XsBsYJ4ilam60Fb7r7uAj8wFyuwM1oIOWgfmDy6RXEEQzJMPe23DXrVS7rtyD3Df8z/FPgAEAzWU5Ku59ZAUAAAAASUVORK5CYII='
  17. }
  18. function insertLinks() {
  19. var username
  20. var appname
  21. var url
  22. // detect whether we're on github.io or github.com and insert the appropriate markup
  23.  
  24. if ('io' === window.location.host.split('.')[2]) {
  25. username = window.location.origin.split(/[\.\/]/)[2]
  26. appname = window.location.pathname.split('/')[1]
  27. url = '//www.github.com/' + username + '/' + appname
  28. document.body.append(createLink(url, "Go to this project's repo", false, 'ijg-ghPagesToRepo'))
  29. } else {
  30. // ensure that this is a repo and not some other github page
  31. var repoHeadActions = document.querySelector('.repohead-details-container .pagehead-actions')
  32. if (!repoHeadActions) return
  33.  
  34. username = window.location.pathname.split('/')[1]
  35. appname = window.location.pathname.split('/')[2]
  36. url = '//' + username + '.github.io/' + appname
  37. var li = document.createElement('li')
  38. li.append(createLink(url, "Go to Github Pages", true))
  39. repoHeadActions.prepend(li)
  40. }
  41. }
  42.  
  43. function createLink(url, title, isSmall, optLinkClass) {
  44. var link = document.createElement('a')
  45. link.className = 'ijg-link ' + (optLinkClass || '')
  46. link.href = url
  47.  
  48. var img = document.createElement('img')
  49. img.src = isSmall ? imgs.small : imgs.medium
  50. img.title = title
  51.  
  52. link.append(img)
  53. return link
  54. }
  55.  
  56. var styles = '\
  57. a.ijg-link:hover {\
  58. background-color: gray;\
  59. }\
  60. a.ijg-link {\
  61. background-color: black;\
  62. padding: 3px;\
  63. line-height: 0;\
  64. border-radius: 4px;\
  65. display: inline-block;\
  66. text-decoration: none;\
  67. transition: background-color 150ms;\
  68. }\
  69. a.ijg-ghPagesToRepo {\
  70. top: 20px;\
  71. right: 20px;\
  72. border-radius: 6px;\
  73. position: absolute;\
  74. }'
  75.  
  76. GM_addStyle(styles)
  77.  
  78. insertLinks()
  79. document.addEventListener('pjax:complete', insertLinks)
  80. })();