mirror of
https://github.com/pds-nest/nest.git
synced 2024-11-22 13:04:19 +00:00
59 lines
2.2 KiB
JavaScript
59 lines
2.2 KiB
JavaScript
import React, { useContext } from "react"
|
|
import SummaryRepository from "./SummaryRepository"
|
|
import { faFolderOpen } from "@fortawesome/free-solid-svg-icons"
|
|
import ContextUser from "../../contexts/ContextUser"
|
|
import Loading from "../base/Loading"
|
|
import BoxFullScrollable from "../base/BoxFullScrollable"
|
|
import ContextLanguage from "../../contexts/ContextLanguage"
|
|
|
|
|
|
/**
|
|
* A {@link BoxFull} listing all the user's active repositories.
|
|
*
|
|
* @param repositories - Array of repositories to display in the box.
|
|
* @param archiveRepository - Function to be called when archive is pressed on a repository summary.
|
|
* @param destroyRepository - Function to be called when delete is pressed on a repository summary.
|
|
* @param running - If an action is currently running.
|
|
* @param props - Additional props to pass to the box.
|
|
* @returns {JSX.Element}
|
|
* @constructor
|
|
*/
|
|
export default function BoxRepositoriesActive({
|
|
repositories,
|
|
archiveRepository,
|
|
destroyRepository,
|
|
running,
|
|
...props
|
|
}) {
|
|
const { user } = useContext(ContextUser)
|
|
const { strings } = useContext(ContextLanguage)
|
|
|
|
let contents
|
|
if(repositories === null) {
|
|
contents = <Loading/>
|
|
}
|
|
else if(repositories.length === 0) {
|
|
contents = <i>{strings.emptyMenu}.</i>
|
|
}
|
|
else {
|
|
contents = repositories.map(repo => (
|
|
<SummaryRepository
|
|
key={repo["id"]}
|
|
repo={repo}
|
|
icon={faFolderOpen}
|
|
archiveSelf={() => archiveRepository(repo["id"])}
|
|
deleteSelf={() => destroyRepository(repo["id"])}
|
|
canArchive={true}
|
|
canEdit={true}
|
|
canDelete={repo["owner"]["username"] === user["username"]}
|
|
running={running}
|
|
/>
|
|
))
|
|
}
|
|
|
|
return (
|
|
<BoxFullScrollable header={strings.menuActive} {...props}>
|
|
{contents}
|
|
</BoxFullScrollable>
|
|
)
|
|
}
|