diff --git a/web/src/app/containers/Circle.js b/web/src/app/containers/Circle.js index 6f8f6ac..5b20717 100644 --- a/web/src/app/containers/Circle.js +++ b/web/src/app/containers/Circle.js @@ -2,7 +2,7 @@ import React, { PropTypes } from 'react' import { graphql, compose } from 'react-apollo' import gql from 'graphql-tag' import { Link } from 'react-router-dom' -import { Container, Header, Segment, Form, Button, Grid, Menu, Card, List, Table, Popup, Icon, Dropdown, Label, TextArea } from 'semantic-ui-react' +import { Container, Header, Segment, Form, Button, Grid, Menu, Card, List, Table, Popup, Icon, Dropdown, Label, TextArea, Accordion } from 'semantic-ui-react' import moment from 'moment' import marked from 'marked' @@ -310,6 +310,7 @@ class Circle extends React.Component { const roleType = r.roleType let fillers = [] + let extras = [] if (roleType === 'normal') { for (let i = 0, len = r.roleMembers.length; i < len; i++) { // Only display max 3 fillers @@ -322,7 +323,7 @@ class Circle extends React.Component { focusString = ` (${focus})` } const memberLink = Util.memberUrl(member.uid, timeLine) - fillers.push( + extras.push( @@ -331,13 +332,40 @@ class Circle extends React.Component { {focusString} ) } + fillers.push({extras}) if (fillers.length === 0) { - /* TODO(sgotti) limit showed fillers when exceeding a choosed number and show a "more" button */ fillers.push(
no members assigned to role
) } - if (r.roleMembers.length > 3) { + if (r.roleMembers.length > 3) { // Other members accordion + extras = [] const moreFillersCount = r.roleMembers.length - 3 - fillers.push(
... {moreFillersCount} other {moreFillersCount > 1 ? 'members' : 'member' }
) + for (let i = 3, len = r.roleMembers.length; i < len; i++) { + let focus = r.roleMembers[i].focus + let focusString = '' + if (focus) { + focusString = ` (${focus})` + } + let extramember = r.roleMembers[i].member + const extramemberLink = Util.memberUrl(extramember.uid, timeLine) + extras.push( + + + + {extramember.userName} + + {focusString} + ) + } + fillers.push( + + {moreFillersCount} other {moreFillersCount > 1 ? 'members' : 'member' } + + + {extras} + + + + ) } } @@ -357,13 +385,16 @@ class Circle extends React.Component { const memberLink = Util.memberUrl(leadlinkMember.uid, timeLine) fillers.push( - - - - {leadlinkMember.userName} - - (Lead Link) - ) + + + + + {leadlinkMember.userName} + + (Lead Link) + + + ) } else { fillers.push(
no leadlink assigned
) } @@ -400,9 +431,7 @@ class Circle extends React.Component { - - {fillers} - + {fillers}