Files
SCM-Manager/scm-ui-components/packages/ui-components/src/repos/changesets/ChangesetRow.js

131 lines
4.0 KiB
JavaScript
Raw Normal View History

//@flow
import React from "react";
2019-08-15 10:51:36 +02:00
import type {Changeset, Repository} from "@scm-manager/ui-types";
import classNames from "classnames";
2019-08-15 10:51:36 +02:00
import {Interpolate, translate} from "react-i18next";
import ChangesetId from "./ChangesetId";
import injectSheet from "react-jss";
2019-08-15 10:51:36 +02:00
import {DateFromNow} from "../..";
import ChangesetAuthor from "./ChangesetAuthor";
2019-08-15 10:51:36 +02:00
import {parseDescription} from "./changesets";
import {AvatarImage, AvatarWrapper} from "../../avatar";
import {ExtensionPoint} from "@scm-manager/ui-extensions";
2019-02-07 10:27:11 +01:00
import ChangesetTags from "./ChangesetTags";
import ChangesetButtonGroup from "./ChangesetButtonGroup";
const styles = {
2019-02-07 10:27:11 +01:00
changeset: {
// & references parent rule
// have a look at https://cssinjs.org/jss-plugin-nested?v=v10.0.0-alpha.9
"& + &": {
borderTop: "1px solid rgba(219, 219, 219, 0.5)",
marginTop: "1rem",
paddingTop: "1rem"
}
},
avatarFigure: {
marginTop: ".25rem",
marginRight: ".5rem",
},
avatarImage: {
height: "35px",
width: "35px"
},
2019-02-07 10:27:11 +01:00
isVcentered: {
marginTop: "auto",
marginBottom: "auto"
},
2019-02-07 10:27:11 +01:00
metadata: {
marginLeft: 0
},
tag: {
marginTop: ".5rem"
}
};
type Props = {
2018-09-19 16:05:35 +02:00
repository: Repository,
changeset: Changeset,
2018-09-19 09:49:24 +02:00
t: any,
classes: any
};
class ChangesetRow extends React.Component<Props> {
2019-02-07 10:27:11 +01:00
createChangesetId = (changeset: Changeset) => {
2018-09-19 16:05:35 +02:00
const { repository } = this.props;
return <ChangesetId changeset={changeset} repository={repository} />;
};
render() {
2019-02-07 10:27:11 +01:00
const { repository, changeset, classes } = this.props;
2018-10-18 14:40:35 +02:00
const description = parseDescription(changeset.description);
2019-02-07 10:27:11 +01:00
const changesetId = this.createChangesetId(changeset);
const dateFromNow = <DateFromNow date={changeset.date} />;
2018-10-17 13:22:06 +02:00
return (
2019-02-07 10:27:11 +01:00
<div className={classes.changeset}>
<div className="columns">
<div className="column is-three-fifths">
<h4 className="has-text-weight-bold is-ellipsis-overflow">
<ExtensionPoint
2019-02-07 11:57:06 +01:00
name="changeset.description"
2019-02-07 10:27:11 +01:00
props={{ changeset, value: description.title }}
renderAll={false}
>
{description.title}
</ExtensionPoint>
</h4>
<div className="media">
<AvatarWrapper>
<figure className={classNames(classes.avatarFigure, "media-left")}>
<div className={classNames("image", classes.avatarImage)}>
<AvatarImage person={changeset.author} />
</div>
</figure>
</AvatarWrapper>
<div className={classNames(classes.metadata, "media-right")}>
<p className="is-hidden-mobile is-hidden-tablet-only">
<Interpolate
2019-02-07 11:57:06 +01:00
i18nKey="changeset.summary"
2019-02-07 10:27:11 +01:00
id={changesetId}
time={dateFromNow}
/>
</p>
<p className="is-hidden-desktop">
<Interpolate
2019-02-07 11:57:06 +01:00
i18nKey="changeset.shortSummary"
2019-02-07 10:27:11 +01:00
id={changesetId}
time={dateFromNow}
/>
</p>
<p className="is-size-7">
<ChangesetAuthor changeset={changeset} />
</p>
</div>
</div>
2018-10-18 14:40:35 +02:00
</div>
2019-02-07 10:27:11 +01:00
<div className={classNames("column", classes.isVcentered)}>
<ChangesetTags changeset={changeset} />
2019-07-24 08:56:12 +02:00
<div className="is-pulled-right level">
<ChangesetButtonGroup repository={repository} changeset={changeset} />
<div className={classes.isVcentered}>
<ExtensionPoint
name="changeset.right"
props={{ repository, changeset }}
renderAll={true}
/>
</div>
</div>
</div>
</div>
2019-02-07 10:27:11 +01:00
</div>
);
}
}
export default injectSheet(styles)(translate("repos")(ChangesetRow));