Files snapshot from mithril-server-side-rendering
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
18e543 Tucker McKnight
18e543 Tucker McKnight
a62ca2 Tucker McKnight
87bcc2 Tucker McKnight
4f267d Tucker McKnight
87bcc2 Tucker McKnight
7f8822 Tucker McKnight
7f8822 Tucker McKnight
7f8822 Tucker McKnight
7f8822 Tucker McKnight
87bcc2 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
1b6528 Tucker McKnight
1b6528 Tucker McKnight
8df7e5 Tucker McKnight
8df7e5 Tucker McKnight
8df7e5 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
073785 Tucker McKnight
87bcc2 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
29688f Tucker McKnight
29688f Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
29688f Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
f8e00d Tucker McKnight
18e543 Tucker McKnight
18e543 Tucker McKnight
4f267d Tucker McKnight
import m from 'mithril'
import render from 'mithril-node-render'
import { type Repository } from '../src/dataTypes.ts'
import { NavHelper } from './helpers/nav.ts'
export default async (eleventyConfig: any, data: any, nav: ReturnType<typeof NavHelper>) => {
const repo: Repository = data.currentRepo
const branch: Repository['branches'][0] = data.currentBranch
const renderContentIfAvailable = eleventyConfig.getFilter("renderContentIfAvailable")
const getReadMe = eleventyConfig.getFilter("getReadMe")
const latestCommit = repo.commits.get(branch.head)
const latestCommitMessage = latestCommit.message.length > 72
? latestCommit.message.split('\n')[0].substr(0, 72) + '...'
: latestCommit.message
const languageCounts = branch.fileList.reduce((counts, currentFile) => {
const fileParts = currentFile.split(".")
const fileExtension = fileParts[fileParts.length - 1]
// todo: add more ignoreable extensions or specific files
// (like package-lock.json). Allow glob patterns?
if (fileExtension === 'gitignore') {
return counts
}
counts.set(fileExtension, (counts.get(fileExtension) + 1) || 1)
return counts
}, new Map<string, number>())
// todo: this is probably broken for repos that use fewer than 6 languages
let languagePercentages: Array<[string, number]> = []
const total = branch.fileList.length
for (const entry of languageCounts) {
languagePercentages.push([entry[0], entry[1] / total])
}
languagePercentages.sort((a, b) => {
return b[1] - a[1]
})
const topLanguagePercentages = languagePercentages.slice(0, 5)
const otherLanguagePercent = languagePercentages.slice(6, languagePercentages.length - 6).reduce((sum, current) => {
return sum + current[1]
}, 0)
const largestPercent = Math.max(...topLanguagePercentages.map(tuple => tuple[1]), otherLanguagePercent)
const readmeContent = await renderContentIfAvailable(await getReadMe(repo.name, branch.name), branch.name)
return render([
m('div', {class: "row"}, [
m('div', {class: "col"}, [
m('div', {class: "px-4 pt-3 bezel-header"}, [
m('div', {class: "row"}, [
m('div', {class: "col-12 col-xl-6"}, [
m('h1', {class: "display-3 text-white"},
m('em', repo.name)
),
repo.description
? m('p', {class: "text-white fs-4"}, repo.description)
: null
]),
m('div', {class: "col-12 col-xl-6 d-flex flex-column justify-content-around"}, [
m('div', {class: "row flex-grow-1 align-items-stretch language-percent-row"}, [
m('div', {class: "col-12 d-flex align-items-stretch"}, [
m('div', {class: "d-flex flex-grow-1 flex-nowrap"}, topLanguagePercentages.map((percentTuple) => {
return m('div', {class: 'language-col flex-grow-1 overflow-hidden'}, [
m('div', {class: "language-name text-light font-monospace"}, percentTuple[0]),
m('div', {class: "language-percent", style: `flex-grow: ${percentTuple[1] / largestPercent};`})
])
}).concat([m('div', {class: 'language-col flex-grow-1 overflow-hidden'},
m('div', {class: "language-name text-light font-monospace"}, 'other'),
m('div', {class: "language-percent", style: `flex-grow: ${otherLanguagePercent / largestPercent};`})
)])),
])
]),
m('div', {class: "row align-items-center"}, [
m('div', {class: "col-12"}, [
m('div', {class: "header-button-container"}, [
m('button', {class: "btn btn-info btn-lg dropdown-toggle clone-popover-btn"}, 'Clone'),
nav.homepageButtons.map((buttonConfig) => {
return m('a', {
class: "btn btn-outline-info btn-lg shadow-none",
href: buttonConfig.url,
target: buttonConfig.newTab ? "_blank" : "_self"
}, m.trust(buttonConfig.text + `${buttonConfig.newTab ? ' <span>⧉</span>' : ''}`))
})
])
])
])
])
]),
m('noscript',
m('div', {class: "row mt-2"},
m('div', {class: "col"},
m('p', {class: "font-monospace text-white"},
`Clone URL: ${repo.cloneUrl}`
)
)
)
),
m('div', {class: "row mt-2"}, [
m('div', {class: "col"}, [
m('p', {class: "font-monospace text-white mb-2 d-inline-block"}, [
m('a', {class: "btn btn-outline-info badge shadow-none me-2", href: nav.repoCurrentBranchRssFeed()}, [
m('img', {src: `${nav.rootPath()}frontend/img/rss-icon.svg`, style: "width: 11px; margin-right: 5px;"}),
'RSS'
]),
`Latest commit: ${latestCommit.date.toDateString()} `,
m('a', {class: "fw-bold link-info", href: `${nav.repoBranchCommitsBase()}${latestCommit.hash}`}, latestCommit.hash.substr(0, 6)),
' ',
latestCommitMessage,
])
])
])
])
])
]),
m('div', {class: "row my-4 mx-1"},
m('div', {class: "col readme"}, m.trust(readmeContent))
)
])
}