Merged in bugfix/show_groups_in_me (pull request #194)

Show own groups in me page
This commit is contained in:
Philipp Czora
2019-02-20 09:40:29 +00:00
2 changed files with 143 additions and 89 deletions

View File

@@ -1,19 +1,30 @@
// @flow // @flow
import React from "react"; import React from "react";
import type { Me } from "@scm-manager/ui-types"; import type { Me } from "@scm-manager/ui-types";
import { MailLink, AvatarWrapper, AvatarImage } from "@scm-manager/ui-components"; import {
MailLink,
AvatarWrapper,
AvatarImage
} from "@scm-manager/ui-components";
import { compose } from "redux"; import { compose } from "redux";
import { translate } from "react-i18next"; import { translate } from "react-i18next";
import injectSheet from "react-jss";
type Props = { type Props = {
me: Me, me: Me,
// Context props // Context props
classes: any,
t: string => string t: string => string
}; };
type State = {};
class ProfileInfo extends React.Component<Props, State> { const styles = {
spacing: {
padding: "0 !important"
}
};
class ProfileInfo extends React.Component<Props> {
render() { render() {
const { me, t } = this.props; const { me, t } = this.props;
return ( return (
@@ -21,33 +32,64 @@ class ProfileInfo extends React.Component<Props, State> {
<AvatarWrapper> <AvatarWrapper>
<figure className="media-left"> <figure className="media-left">
<p className="image is-64x64"> <p className="image is-64x64">
<AvatarImage person={ me }/> <AvatarImage person={me} />
</p> </p>
</figure> </figure>
</AvatarWrapper> </AvatarWrapper>
<div className="media-content"> <div className="media-content">
<table className="table"> <table className="table content">
<tbody> <tbody>
<tr> <tr>
<td className="has-text-weight-semibold">{t("profile.username")}</td> <th>
{t("profile.username")}
</th>
<td>{me.name}</td> <td>{me.name}</td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("profile.displayName")}</td> <th>
{t("profile.displayName")}
</th>
<td>{me.displayName}</td> <td>{me.displayName}</td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("profile.mail")}</td> <th>
{t("profile.mail")}
</th>
<td> <td>
<MailLink address={me.mail} /> <MailLink address={me.mail} />
</td> </td>
</tr> </tr>
{this.renderGroups()}
</tbody> </tbody>
</table> </table>
</div> </div>
</div> </div>
); );
} }
renderGroups() {
const { me, t, classes } = this.props;
let groups = null;
if (me.groups.length > 0) {
groups = (
<tr>
<th>{t("profile.groups")}</th>
<td className={classes.spacing}>
<ul>
{me.groups.map(group => {
return <li>{group}</li>;
})}
</ul>
</td>
</tr>
);
}
return groups;
}
} }
export default compose(translate("commons"))(ProfileInfo); export default compose(
injectSheet(styles),
translate("commons")
)(ProfileInfo);

View File

@@ -1,15 +1,25 @@
//@flow //@flow
import React from "react"; import React from "react";
import type { Group } from "@scm-manager/ui-types"; import type { Group } from "@scm-manager/ui-types";
import { translate } from "react-i18next";
import GroupMember from "./GroupMember"; import GroupMember from "./GroupMember";
import { DateFromNow } from "@scm-manager/ui-components"; import { DateFromNow } from "@scm-manager/ui-components";
import { translate } from "react-i18next";
import injectSheet from "react-jss";
type Props = { type Props = {
group: Group, group: Group,
// Context props
classes: any,
t: string => string t: string => string
}; };
const styles = {
spacing: {
padding: "0 !important"
}
};
class Details extends React.Component<Props> { class Details extends React.Component<Props> {
render() { render() {
const { group, t } = this.props; const { group, t } = this.props;
@@ -17,25 +27,25 @@ class Details extends React.Component<Props> {
<table className="table content"> <table className="table content">
<tbody> <tbody>
<tr> <tr>
<td className="has-text-weight-semibold">{t("group.name")}</td> <th>{t("group.name")}</th>
<td>{group.name}</td> <td>{group.name}</td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("group.description")}</td> <th>{t("group.description")}</th>
<td>{group.description}</td> <td>{group.description}</td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("group.type")}</td> <th>{t("group.type")}</th>
<td>{group.type}</td> <td>{group.type}</td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("group.creationDate")}</td> <th>{t("group.creationDate")}</th>
<td> <td>
<DateFromNow date={group.creationDate} /> <DateFromNow date={group.creationDate} />
</td> </td>
</tr> </tr>
<tr> <tr>
<td className="has-text-weight-semibold">{t("group.lastModified")}</td> <th>{t("group.lastModified")}</th>
<td> <td>
<DateFromNow date={group.lastModified} /> <DateFromNow date={group.lastModified} />
</td> </td>
@@ -47,23 +57,25 @@ class Details extends React.Component<Props> {
} }
renderMembers() { renderMembers() {
if (this.props.group.members.length > 0) { const { group, t, classes } = this.props;
return (
let member = null;
if (group.members.length > 0) {
member = (
<tr> <tr>
<td> <th>{t("group.members")}</th>
{this.props.t("group.members")} <td className={classes.spacing}>
<ul> <ul>
{this.props.group._embedded.members.map((member, index) => { {group._embedded.members.map((member, index) => {
return <GroupMember key={index} member={member} />; return <GroupMember key={index} member={member}/>;
})} })}
</ul> </ul>
</td> </td>
</tr> </tr>
); );
} else {
return;
} }
return member;
} }
} }
export default translate("groups")(Details); export default injectSheet(styles)(translate("groups")(Details));