Github 仓库大小

在 github 搜索和存储库页面上的存储库名称旁边添加存储库大小

当前为 2024-09-25 提交的版本,查看 最新版本

  1. // ==UserScript==
  2. // @name Github Repo Size+
  3. // @name:zh-CN Github 仓库大小
  4. // @description:zh-CN 在 github 搜索和存储库页面上的存储库名称旁边添加存储库大小
  5. // @name:ar Github حجم المستودع
  6. // @description:ar يخرج github أضف حجم المستودع بجوار اسم المستودع في صفحات البحث والمستودع
  7. // @name:bg Github Размер на склада
  8. // @description:bg съществуват github Добавете размер на хранилището до името на хранилището на страниците за търсене и хранилище
  9. // @name:cs Github Velikost skladu
  10. // @description:cs existovat github Přidejte velikost úložiště vedle názvu úložiště na stránkách vyhledávání a úložiště
  11. // @name:da Github Lagerstørrelse
  12. // @description:da eksistere github Tilføj lagerstørrelse ud for lagernavn på søge- og lagersider
  13. // @name:de Github Lagergröße
  14. // @description:de existieren github Fügen Sie auf Such- und Repository-Seiten neben dem Repository-Namen die Repository-Größe hinzu
  15. // @name:el Github Μέγεθος αποθήκης
  16. // @description:el υπάρχω github Προσθέστε μέγεθος αποθετηρίου δίπλα στο όνομα χώρου αποθήκευσης στις σελίδες αναζήτησης και αποθετηρίου
  17. // @name:en Github Warehouse size
  18. // @description:en exist github Add repository size next to repository name on search and repository pages
  19. // @name:eo Github Grando de magazeno
  20. // @description:eo ekzisti github Aldonu deponejan grandecon apud la nomo de deponejo sur serĉo kaj deponejo paĝoj
  21. // @name:es Github Tamaño del almacén
  22. // @description:es existir github Agregue el tamaño del repositorio junto al nombre del repositorio en las páginas de búsqueda y repositorio
  23. // @name:fi Github Varaston koko
  24. // @description:fi olemassa github Lisää arkiston koko arkiston nimen viereen haku- ja arkistosivuilla
  25. // @name:fr Github Taille de l’entrepôt
  26. // @description:fr exister github Ajouter la taille du référentiel à côté du nom du référentiel sur les pages de recherche et du référentiel
  27. // @name:he Github גודל המחסן
  28. // @description:he לְהִתְקַיֵם github הוסף גודל מאגר ליד שם המאגר בדפי החיפוש והמאגר
  29. // @name:hr Github Veličina skladišta
  30. // @description:hr postojati github Dodajte veličinu repozitorija pored naziva repozitorija na stranicama pretraživanja i repozitorija
  31. // @name:hu Github Raktár mérete
  32. // @description:hu létezik github Adja hozzá a lerakat méretét a lerakat neve mellett a keresési és lerakatoldalakon
  33. // @name:id Github Ukuran gudang
  34. // @description:id ada github Tambahkan ukuran repositori di sebelah nama repositori pada halaman pencarian dan repositori
  35. // @name:it Github Dimensioni del magazzino
  36. // @description:it esistere github Aggiungi la dimensione del repository accanto al nome del repository nelle pagine di ricerca e del repository
  37. // @name:ja Github 倉庫のサイズ
  38. // @description:ja 存在する github 検索ページとリポジトリ ページでリポジトリ名の横にリポジトリ サイズを追加します
  39. // @name:ka Github საწყობის ზომა
  40. // @description:ka არსებობს github საძიებო და საცავის გვერდებზე საცავის სახელის გვერდით დაამატეთ საცავის ზომა
  41. // @name:ko Github 창고 규모
  42. // @description:ko 존재하다 github 검색 및 저장소 페이지의 저장소 이름 옆에 저장소 크기 추가
  43. // @name:nl Github Grootte van magazijn
  44. // @description:nl bestaan github Voeg de repositorygrootte toe naast de repositorynaam op zoek- en repositorypagina’s
  45. // @name:nb Github Lagerstørrelse
  46. // @description:nb eksistere github Legg til depotstørrelse ved siden av depotnavnet på søke- og depotsidene
  47. // @name:pl Github Wielkość magazynu
  48. // @description:pl istnieć github Dodaj rozmiar repozytorium obok nazwy repozytorium na stronach wyszukiwania i repozytorium
  49. // @name:pt-BR Github Tamanho do armazém
  50. // @description:pt-BR existir github Adicione o tamanho do repositório próximo ao nome do repositório nas páginas de pesquisa e do repositório
  51. // @name:ro Github Dimensiunea depozitului
  52. // @description:ro exista github Adăugați dimensiunea depozitului lângă numele depozitului pe paginile de căutare și depozit
  53. // @name:ru Github Размер склада
  54. // @description:ru существовать github Добавьте размер репозитория рядом с именем репозитория на страницах поиска и репозитория.
  55. // @name:sk Github Veľkosť skladu
  56. // @description:sk existujú github Pridajte veľkosť úložiska vedľa názvu úložiska na stránkach vyhľadávania a úložiska
  57. // @name:sr Github Величина магацина
  58. // @description:sr постоје github Додајте величину спремишта поред имена спремишта на страницама претраге и спремишта
  59. // @name:sv Github Lagerstorlek
  60. // @description:sv existera github Lägg till förvarsstorlek bredvid förvarets namn på sök- och förvarssidor
  61. // @name:th Github ขนาดคลังสินค้า
  62. // @description:th มีอยู่ github เพิ่มขนาดที่เก็บถัดจากชื่อที่เก็บในหน้าการค้นหาและที่เก็บ
  63. // @name:tr Github Depo boyutu
  64. // @description:tr var olmak github Arama ve depo sayfalarında depo adının yanına depo boyutunu ekleyin
  65. // @name:ug Github ئامبارنىڭ چوڭلۇقى
  66. // @description:ug مەۋجۇت github ئىزدەش ۋە ئامبار بېتىدىكى ئامبار نامىنىڭ يېنىغا ئامبار چوڭلۇقى قوشۇڭ
  67. // @name:uk Github Розмір складу
  68. // @description:uk існують github Додайте розмір сховища поруч із назвою сховища на сторінках пошуку та сховища
  69. // @name:vi Github Kích thước kho
  70. // @description:vi hiện hữu github Thêm kích thước kho lưu trữ bên cạnh tên kho lưu trữ trên các trang tìm kiếm và kho lưu trữ
  71. // @name:zh-TW Github 倉庫大小
  72. // @description:zh-TW 在 github 搜尋和儲存庫頁面上的儲存庫名稱旁邊新增儲存庫大小
  73. // @name:zh-HK Github 倉庫大小
  74. // @description:zh-HK 在 github 搜尋和儲存庫頁面上的儲存庫名稱旁邊新增儲存庫大小
  75. // @name:fr-CA Github Taille de l’entrepôt
  76. // @description:fr-CA exister github Ajouter la taille du référentiel à côté du nom du référentiel sur les pages de recherche et du référentiel
  77. // @namespace https://github.com/ChinaGodMan/UserScripts
  78. // @description Adds the repo size next to the repo name on github search and repo pages
  79. // @version 0.1.3.0
  80. // @author mshll & 人民的勤务员 <toniaiwanowskiskr47@gmail.com>
  81. // @match *://github.com/search*
  82. // @match *://github.com/*/*
  83. // @match *://github.com/*?tab=repositories*
  84. // @grant none
  85. // @grant GM_getValue
  86. // @grant GM_setValue
  87. // @grant GM_addStyle
  88. // @grant GM_registerMenuCommand
  89. // @grant none
  90. // @icon 
  91. // @iconbak https://github.githubassets.com/pinned-octocat.svg
  92. // @license MIT
  93. // @source https://github.com/qinwuyuan-cn/UserScripts
  94. // @supportURL https://github.com/ChinaGodMan/UserScripts/issues
  95. // @homepageURL https://github.com/ChinaGodMan/UserScripts
  96. // ==/UserScript==
  97. "use strict"
  98. const translate = (function () {
  99. const userLang = (navigator.languages && navigator.languages[0]) || navigator.language || 'en'
  100. const translations = {
  101. 'en': {
  102. save: 'Save',
  103. cancel: 'Cancel',
  104. modaltitle: 'Set GitHub Token',
  105. description: 'Enter your GitHub personal access token with "repo" scope.',
  106. githubtokeninput: 'Enter your GitHub personal access token',
  107. newtoken: 'Click here to create a new token',
  108. warncheckbox: ' Inactive Development Warning',
  109. menu: 'Set GitHub Token',
  110. renderWarning: 'WARNING: repo has not received an update in 1+ year(s)',
  111. renderCaution: 'Caution: repo has not received an update in 6+ months',
  112. confirm: 'You have not entered a Token, confirm to clear the GitHub Token?',
  113. }, 'zh-CN': {
  114. save: '保存',
  115. cancel: '取消',
  116. modaltitle: '设置 GitHub 令牌',
  117. description: '请输入您的 GitHub 个人访问令牌,需具备 "repo" 权限。',
  118. githubtokeninput: '请输入您的 GitHub 个人访问令牌',
  119. newtoken: '点击此处创建新的令牌',
  120. warncheckbox: ' 非活跃开发警告',
  121. menu: '设置 GitHub 令牌',
  122. renderWarning: '警告:该仓库在 1 年以上未更新',
  123. renderCaution: '注意:该仓库在 6 个月以上未更新',
  124. confirm: '你没有输入Token,确认清空GitHub Token?',
  125. },
  126. 'zh-TW': {
  127. save: '保存',
  128. cancel: '取消',
  129. modaltitle: '設定 GitHub 令牌',
  130. description: '請輸入您的 GitHub 個人訪問令牌,需具備 "repo" 權限。',
  131. githubtokeninput: '請輸入您的 GitHub 個人訪問令牌',
  132. newtoken: '點擊此處創建新的令牌',
  133. warncheckbox: ' 非活躍開發警告',
  134. menu: '設定 GitHub 令牌',
  135. renderWarning: '警告:該倉庫在 1 年以上未更新',
  136. renderCaution: '注意:該倉庫在 6 個月以上未更新',
  137. confirm: '你沒有輸入Token,確認清空GitHub Token?',
  138. },
  139. 'vi': {
  140. save: 'Lưu',
  141. cancel: 'Hủy',
  142. modaltitle: 'Đặt Token GitHub',
  143. description: 'Nhập token truy cập cá nhân GitHub của bạn với phạm vi "repo".',
  144. githubtokeninput: 'Nhập token truy cập cá nhân GitHub của bạn',
  145. newtoken: 'Nhấn vào đây để tạo token mới',
  146. warncheckbox: ' Cảnh báo phát triển không hoạt động',
  147. menu: 'Đặt Token GitHub',
  148. renderWarning: 'CẢNH BÁO: kho lưu trữ đã không nhận được cập nhật trong hơn 1 năm',
  149. renderCaution: 'Cảnh báo: kho lưu trữ đã không nhận được cập nhật trong hơn 6 tháng',
  150. confirm: 'Bạn chưa nhập Token, xác nhận xóa GitHub Token?',
  151. },
  152. 'ja': {
  153. save: '保存',
  154. cancel: 'キャンセル',
  155. modaltitle: 'GitHubトークンの設定',
  156. description: '「repo」スコープを持つGitHub個人アクセストークンを入力してください。',
  157. githubtokeninput: 'GitHub個人アクセストークンを入力してください',
  158. newtoken: '新しいトークンを作成するにはここをクリックしてください',
  159. warncheckbox: ' 非アクティブ開発警告',
  160. menu: 'GitHubトークンの設定',
  161. renderWarning: '警告:リポジトリは1年以上更新されていません',
  162. renderCaution: '注意:リポジトリは6ヶ月以上更新されていません',
  163. confirm: 'トークンが入力されていません。GitHubトークンをクリアしてもよろしいですか?',
  164. },
  165. 'ko': {
  166. save: '저장',
  167. cancel: '취소',
  168. modaltitle: 'GitHub 토큰 설정',
  169. description: '“repo” 범위를 가진 GitHub 개인 액세스 토큰을 입력하세요.',
  170. githubtokeninput: 'GitHub 개인 액세스 토큰을 입력하세요',
  171. newtoken: '여기를 클릭하여 새 토큰을 만드세요',
  172. warncheckbox: ' 비활성 개발 경고',
  173. menu: 'GitHub 토큰 설정',
  174. renderWarning: '경고: 이 저장소는 1년 이상 업데이트되지 않았습니다',
  175. renderCaution: '주의: 이 저장소는 6개월 이상 업데이트되지 않았습니다',
  176. confirm: '토큰을 입력하지 않았습니다. GitHub 토큰을 지우시겠습니까?',
  177. },
  178. }
  179. const getTranslations = (lang) => translations[lang] || translations['en']
  180. return new Proxy({}, {
  181. get(target, prop) {
  182. const lang = userLang
  183. const strings = getTranslations(lang)
  184. return strings[prop] || strings['en'][prop]
  185. }
  186. })
  187. }())
  188. //! Generate a new public access token from https://github.com/settings/tokens and insert it here
  189. //*Note: to be able to see the size of your private repos, you need to select the `repo` scope when generating the token
  190. let TOKEN = GM_getValue('githubToken', "")
  191. let WARNING = GM_getValue('warn', true)
  192. GM_addStyle(`
  193. .modal-overlay{position:fixed;top:0;left:0;width:100%;height:100%;background:rgba(0,0,0,0.5);display:flex;justify-content:center;align-items:center;z-index:1000;}
  194. .modal-content{background:white;padding:20px;border-radius:8px;width:400px;box-shadow:0 4px 15px rgba(0,0,0,0.2);position:relative;}
  195. .modal-title{margin:0 0 10px 0;font-size:20px;}
  196. .modal-description{margin-bottom:20px;font-size:14px;color:#666;}
  197. .modal-description a{color:#007bff;text-decoration:underline;}
  198. #github-token-input{width:100%;padding:8px;border:1px solid #ccc;border-radius:4px;margin-bottom:20px;font-size:14px;}
  199. #save-token{background-color:#28a745;color:white;border:none;padding:10px 20px;cursor:pointer;border-radius:4px;margin-right:10px;}
  200. #cancel-token{background-color:#dc3545;color:white;border:none;padding:10px 20px;cursor:pointer;border-radius:4px;}
  201. `)
  202. function createModal() {
  203. const modalHTML = `
  204. <div class="modal-overlay">
  205. <div class="modal-content">
  206. <h2 class="modal-title">${translate.modaltitle}</h2>
  207. <p class="modal-description">
  208. ${translate.description}
  209. <a href="https://github.com/settings/tokens/new?description=GitHub%20Repo%20Size%20UserScript&scopes=repo" target="_blank" rel="noopener noreferrer">
  210. ${translate.newtoken}
  211. </a>
  212. </p>
  213. <input type="text" id="github-token-input" placeholder="${translate.githubtokeninput}">
  214. <label><input type="checkbox" id="warn">${translate.warncheckbox}</label>
  215. <br>
  216. <hr>
  217. <button id="save-token">${translate.save}</button>
  218. <button id="cancel-token" class="cancel">${translate.cancel}</button>
  219. </div>
  220. </div>
  221. `
  222. const modalContainer = document.createElement('div')
  223. modalContainer.innerHTML = modalHTML
  224. document.body.appendChild(modalContainer)
  225. const input = document.getElementById('github-token-input')
  226. const warn = document.getElementById('warn')
  227. warn.checked = GM_getValue('warn', true)
  228. input.value = GM_getValue('githubToken', '')
  229. document.getElementById('save-token').addEventListener('click', () => {
  230. const token = input.value.trim()
  231. GM_setValue('warn', warn.checked)
  232. WARNING = warn.checked
  233. if (token) {
  234. GM_setValue('githubToken', token)
  235. modalContainer.remove()
  236. TOKEN = token
  237. } else {
  238. const userConfirmed = confirm(translate("confirm"))//提示是否删除
  239. if (userConfirmed) {
  240. GM_setValue('githubToken', token)
  241. modalContainer.remove()
  242. TOKEN = token
  243. }
  244. }
  245. })
  246. document.getElementById('cancel-token').addEventListener('click', () => modalContainer.remove())
  247. }
  248. GM_registerMenuCommand(translate.menu, function () {
  249. createModal()
  250. })
  251. const getPageType = () => {
  252. const { pathname, search } = window.location
  253. const params = new URLSearchParams(search)
  254. const [, username, repo] = pathname.split("/")
  255. const q = params.get("q")?.toLocaleLowerCase()
  256. const type = params.get("type")?.toLocaleLowerCase()
  257. if (window.location.pathname.split('/').pop() === "repositories") return "list-view-container"
  258. if (window.location.href.includes("?tab=repositories")) return "user-repositories"
  259. if (username && repo) return "repo"
  260. if (q && type === "code") return "code_search"
  261. if (q) return "search"
  262. }
  263. const addSizeToRepos = () => {
  264. const pageType = getPageType()
  265. // Get the repo selector based on the page type
  266. let repoSelector
  267. switch (pageType) {
  268. case "repo"://仓库详情界面
  269. repoSelector = "#repository-container-header strong a"
  270. break
  271. case "list-view-container"://ORG下的仓库列表
  272. repoSelector = 'div[data-testid="list-view-item-title-container"] h4 a'
  273. break
  274. case "user-repositories"://用户资料页面的仓库TAB
  275. repoSelector = '#user-repositories-list h3 a'
  276. break
  277. case "search"://搜索
  278. repoSelector = 'div[data-testid="results-list"] .search-title a'
  279. break
  280. case "code_search"://代码搜索
  281. repoSelector = 'div[data-testid="results-list"] .search-title a'
  282. break
  283. default:
  284. return
  285. }
  286. function extractPath(input) {
  287. const thirdSlashIndex = input.indexOf('/', input.indexOf('/', input.indexOf('/') + 1) + 1)
  288. if (thirdSlashIndex !== -1) {
  289. return input.substring(0, thirdSlashIndex)
  290. }
  291. return input
  292. }
  293. // Get all the repo links
  294. document.querySelectorAll(repoSelector).forEach(async (elem) => {
  295. // Get json data from github api to extract the size
  296. const tkn = TOKEN
  297. var href = elem.getAttribute("href")
  298. href = extractPath(href)
  299. console.log(href)
  300. const headers = tkn ? { authorization: `token ${tkn}` } : {}
  301. const jsn = await (
  302. await fetch(`https://api.github.com/repos${href}`, {
  303. headers: headers,
  304. })
  305. ).json()
  306. if (repoSelector == "#repository-container-header strong a" && WARNING) {
  307. checkCommitDate(jsn.pushed_at)
  308. }
  309. // If JSON failed to load, skip
  310. if (jsn.message) return
  311. // Get parent element to append the size to
  312. let parent = elem.parentElement
  313. if (pageType === "repo") {
  314. parent = elem.parentElement.parentElement
  315. }
  316. // Create the size container
  317. let sizeContainer = parent.querySelector(`#mshll-repo-size`)
  318. if (sizeContainer === null) {
  319. sizeContainer = document.createElement("span")
  320. sizeContainer.id = "mshll-repo-size"
  321. sizeContainer.classList.add("Label", "Label--info", "v-align-middle", "ml-1")
  322. sizeContainer.setAttribute("title", "Repository size")
  323. sizeContainer.innerText = "-"
  324. // Create the size icon
  325. let sizeSVG = document.createElementNS("http://www.w3.org/2000/svg", "svg")
  326. sizeSVG.setAttribute("aria-hidden", "true")
  327. sizeSVG.setAttribute("viewBox", "-4 -4 22 22")
  328. sizeSVG.setAttribute("width", "16")
  329. sizeSVG.setAttribute("height", "16")
  330. sizeSVG.setAttribute("fill", "currentColor")
  331. sizeSVG.setAttribute("data-view-component", "true")
  332. sizeSVG.classList.add("octicon", "octicon-file-directory", "mr-1")
  333. let sizeSVGPath = document.createElementNS("http://www.w3.org/2000/svg", "path")
  334. sizeSVGPath.setAttribute("fill-rule", "evenodd")
  335. sizeSVGPath.setAttribute("d", "M1 3.5c0-.626.292-1.165.7-1.59.406-.422.956-.767 1.579-1.041C4.525.32 6.195 0 8 0c1.805 0 3.475.32 4.722.869.622.274 1.172.62 1.578 1.04.408.426.7.965.7 1.591v9c0 .626-.292 1.165-.7 1.59-.406.422-.956.767-1.579 1.041C11.476 15.68 9.806 16 8 16c-1.805 0-3.475-.32-4.721-.869-.623-.274-1.173-.62-1.579-1.04-.408-.426-.7-.965-.7-1.591Zm1.5 0c0 .133.058.318.282.551.227.237.591.483 1.101.707C4.898 5.205 6.353 5.5 8 5.5c1.646 0 3.101-.295 4.118-.742.508-.224.873-.471 1.1-.708.224-.232.282-.417.282-.55 0-.133-.058-.318-.282-.551-.227-.237-.591-.483-1.101-.707C11.102 1.795 9.647 1.5 8 1.5c-1.646 0-3.101.295-4.118.742-.508.224-.873.471-1.1.708-.224.232-.282.417-.282.55Zm0 4.5c0 .133.058.318.282.551.227.237.591.483 1.101.707C4.898 9.705 6.353 10 8 10c1.646 0 3.101-.295 4.118-.742.508-.224.873-.471 1.1-.708.224-.232.282-.417.282-.55V5.724c-.241.15-.503.286-.778.407C11.475 6.68 9.805 7 8 7c-1.805 0-3.475-.32-4.721-.869a6.15 6.15 0 0 1-.779-.407Zm0 2.225V12.5c0 .133.058.318.282.55.227.237.592.484 1.1.708 1.016.447 2.471.742 4.118.742 1.647 0 3.102-.295 4.117-.742.51-.224.874-.47 1.101-.707.224-.233.282-.418.282-.551v-2.275c-.241.15-.503.285-.778.406-1.247.549-2.917.869-4.722.869-1.805 0-3.475-.32-4.721-.869a6.327 6.327 0 0 1-.779-.406Z")
  336. sizeSVG.appendChild(sizeSVGPath)
  337. // Convert the size to human readable
  338. const sizes = ["B", "KB", "MB", "GB", "TB"]
  339. const size = jsn.size * 1024 // Github API returns size in KB so convert to bytes
  340. let i = parseInt(Math.floor(Math.log(size) / Math.log(1024)))
  341. const humanReadableSize = (size / Math.pow(1024, i)).toFixed(1) + " " + sizes[i]
  342. // Insert the size into the size container
  343. sizeContainer.innerHTML = `${humanReadableSize}`
  344. sizeContainer.prepend(sizeSVG)
  345. // Insert the size container into the DOM
  346. if (pageType === "code_search") {
  347. parent.style.direction = 'ltr'
  348. }
  349. parent.appendChild(sizeContainer)
  350. }
  351. })
  352. }
  353. window.addSizeToRepos = addSizeToRepos
  354. // Add the size to the repos on the page
  355. //addSizeToRepos()
  356. window.onload = function () {
  357. addSizeToRepos()
  358. }
  359. // Watch for URL changes
  360. let lastUrl = location.href
  361. new MutationObserver(() => {
  362. const url = location.href
  363. if (url !== lastUrl) {
  364. lastUrl = url
  365. setTimeout(function () {
  366. //NOTE - 此处增加延时了,就这样得了
  367. addSizeToRepos()
  368. }, 1500)
  369. }
  370. }).observe(document, { subtree: true, childList: true })
  371. function displayMessage(el) {
  372. document
  373. .querySelector("#js-repo-pjax-container")
  374. .insertAdjacentElement("beforebegin", el)
  375. }
  376. function renderWarning() {
  377. const banner = document.createElement("div")
  378. banner.id = "zh-banner-warning"
  379. banner.setAttribute(
  380. "style",
  381. `
  382. background-color: red;
  383. height: 100px;
  384. margin-bottom: 20px;
  385. display: flex;
  386. justify-content: center;
  387. align-items: center;
  388. color: white;
  389. font-size: 36px;
  390. `
  391. )
  392. banner.textContent = translate.renderWarning
  393. displayMessage(banner)
  394. }
  395. function renderCaution() {
  396. const banner = document.createElement("div")
  397. banner.id = "zh-banner-warning"
  398. banner.setAttribute(
  399. "style",
  400. `
  401. background-color: yellow;
  402. height: 50px;
  403. margin-bottom: 20px;
  404. display: flex;
  405. justify-content: center;
  406. align-items: center;
  407. font-size: 24px;
  408. `
  409. )
  410. banner.textContent = translate.renderCaution
  411. displayMessage(banner)
  412. }
  413. function checkCommitDate(datetimeString) {
  414. if (document.querySelector("#zh-banner-warning")) return
  415. const date = new Date(datetimeString)
  416. const daysSinceLastCommit = (Date.now() - date.getTime()) / 1000 / 60 / 60 / 24
  417. if (daysSinceLastCommit > 365) {
  418. renderWarning()
  419. } else if (daysSinceLastCommit > 182.5) {
  420. renderCaution()
  421. } else {
  422. /* noop */
  423. }
  424. }