feat(plugins/repositories): add options for starred/random repositories (#1179)
This commit is contained in:
@@ -7,24 +7,67 @@ export default async function({login, q, imports, graphql, queries, data, accoun
|
||||
return null
|
||||
|
||||
//Load inputs
|
||||
let {featured, pinned} = imports.metadata.plugins.repositories.inputs({data, account, q})
|
||||
let {featured, pinned, starred, random, order, affiliations:_affiliations} = imports.metadata.plugins.repositories.inputs({data, account, q})
|
||||
const affiliations = _affiliations?.length ? `ownerAffiliations: [${_affiliations.map(x => x.toLocaleUpperCase()).join(", ")}]` : ""
|
||||
|
||||
//Initialization
|
||||
const repositories = {list: []}
|
||||
const processed = new Set()
|
||||
|
||||
//Fetch pinned repositories
|
||||
if (pinned) {
|
||||
const {user: {pinnedItems: {edges}}} = await graphql(queries.repositories.pinned({login, limit: pinned}))
|
||||
repositories.list.push(...edges.map(({node}) => format(node)))
|
||||
}
|
||||
|
||||
//Fetch repositories informations
|
||||
//Featured repositories
|
||||
for (const repo of featured) {
|
||||
const {owner = login, name} = repo.match(/^(?:(?<owner>[\s\S]*)[/])?(?<name>[\s\S]+)$/)?.groups ?? {}
|
||||
const {repository} = await graphql(queries.repositories.repository({owner, name}))
|
||||
repositories.list.push(format(repository))
|
||||
repositories.list.push(format(repository, {sorting:"featured"}))
|
||||
processed.add(repository.nameWithOwner)
|
||||
}
|
||||
|
||||
//Fetch pinned repositories
|
||||
if (pinned) {
|
||||
const {user: {pinnedItems: {edges}}} = await graphql(queries.repositories.pinned({login, limit: 6}))
|
||||
repositories.list.push(...edges.map(({node}) => {
|
||||
if (processed.has(node.nameWithOwner))
|
||||
return null
|
||||
processed.add(node.nameWithOwner)
|
||||
return format(node, {sorting: "pinned"})
|
||||
}).filter(repository => repository).slice(0, pinned))
|
||||
}
|
||||
|
||||
//Fetch starred repositories
|
||||
if (starred) {
|
||||
const {user:{ repositories: {nodes}}} = await graphql(queries.repositories.starred({login, limit: Math.min(starred+10, 100), affiliations}))
|
||||
let count = 0
|
||||
for (const node of nodes) {
|
||||
if (processed.has(node.nameWithOwner))
|
||||
continue
|
||||
const [owner, name] = node.nameWithOwner.split("/")
|
||||
const {repository} = await graphql(queries.repositories.repository({owner, name}))
|
||||
repositories.list.push(format(repository, {sorting:"starred"}))
|
||||
processed.add(repository.nameWithOwner)
|
||||
if (++count >= starred)
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
//Fetch random repositories
|
||||
if (random) {
|
||||
const {user:{ repositories: {nodes}}} = await graphql(queries.repositories.random({login, affiliations}))
|
||||
let count = 0
|
||||
for (const node of imports.shuffle(nodes)) {
|
||||
if (processed.has(node.nameWithOwner))
|
||||
continue
|
||||
const [owner, name] = node.nameWithOwner.split("/")
|
||||
const {repository} = await graphql(queries.repositories.repository({owner, name}))
|
||||
repositories.list.push(format(repository, {sorting:"random"}))
|
||||
processed.add(repository.nameWithOwner)
|
||||
if (++count >= random)
|
||||
break
|
||||
}
|
||||
}
|
||||
|
||||
//Sorting
|
||||
repositories.list = repositories.list.sort((a, b) => order.indexOf(a.sorting) - order.indexOf(b.sorting))
|
||||
|
||||
//Results
|
||||
return repositories
|
||||
}
|
||||
@@ -35,7 +78,7 @@ export default async function({login, q, imports, graphql, queries, data, accoun
|
||||
}
|
||||
|
||||
/**Format repository data */
|
||||
function format(repository) {
|
||||
function format(repository, {sorting} = {}) {
|
||||
//Format date
|
||||
const time = (Date.now() - new Date(repository.createdAt).getTime()) / (24 * 60 * 60 * 1000)
|
||||
let created = new Date(repository.createdAt).toDateString().substring(4)
|
||||
@@ -45,5 +88,9 @@ function format(repository) {
|
||||
created = `${Math.floor(time)} day${time >= 2 ? "s" : ""} ago`
|
||||
repository.created = created
|
||||
|
||||
//Sorting
|
||||
if (sorting)
|
||||
repository.sorting = sorting
|
||||
|
||||
return repository
|
||||
}
|
||||
|
||||
Reference in New Issue
Block a user