Files
SCM-Manager/scm-ui/src/groups/components/MemberNameTable.js

56 lines
1.4 KiB
JavaScript
Raw Normal View History

//@flow
import React from "react";
import { translate } from "react-i18next";
2018-10-02 13:34:04 +02:00
import {
RemoveEntryOfTableButton,
LabelWithHelpIcon
} from "@scm-manager/ui-components";
type Props = {
members: string[],
t: string => string,
memberListChanged: (string[]) => void
};
type State = {};
class MemberNameTable extends React.Component<Props, State> {
render() {
const { t } = this.props;
return (
<div>
2018-10-02 13:34:04 +02:00
<LabelWithHelpIcon
label={t("group.members")}
2018-10-02 14:03:54 +02:00
helpText={t("group-form.help.memberHelpText")}
2018-10-02 13:34:04 +02:00
/>
<table className="table is-hoverable is-fullwidth">
<tbody>
2018-08-08 13:43:24 +02:00
{this.props.members.map(member => {
return (
<tr key={member}>
<td key={member}>{member}</td>
<td>
<RemoveEntryOfTableButton
entryname={member}
removeEntry={this.removeEntry}
disabled={false}
label={t("remove-member-button.label")}
/>
</td>
</tr>
);
})}
</tbody>
</table>
</div>
);
}
removeEntry = (membername: string) => {
const newMembers = this.props.members.filter(name => name !== membername);
this.props.memberListChanged(newMembers);
};
}
export default translate("groups")(MemberNameTable);