Add/Remove sketch to collection by clicking on entire row
This commit is contained in:
parent
c981bc8b04
commit
3573253504
2 changed files with 68 additions and 8 deletions
|
@ -9,9 +9,13 @@ import * as ProjectActions from '../../actions/project';
|
||||||
import * as CollectionsActions from '../../actions/collections';
|
import * as CollectionsActions from '../../actions/collections';
|
||||||
import * as IdeActions from '../../actions/ide';
|
import * as IdeActions from '../../actions/ide';
|
||||||
import * as ToastActions from '../../actions/toast';
|
import * as ToastActions from '../../actions/toast';
|
||||||
import AddRemoveButton from '../../../../components/AddRemoveButton';
|
|
||||||
|
|
||||||
const downFilledTriangle = require('../../../../images/down-filled-triangle.svg');
|
const downFilledTriangle = require('../../../../images/down-filled-triangle.svg');
|
||||||
|
const check = require('../../../../images/check.svg');
|
||||||
|
|
||||||
|
const checkIcon = (
|
||||||
|
<InlineSVG className="sketch-list__check-icon" src={check} alt="In collection" />
|
||||||
|
);
|
||||||
|
|
||||||
class CollectionListRowBase extends React.Component {
|
class CollectionListRowBase extends React.Component {
|
||||||
static projectInCollection(project, collection) {
|
static projectInCollection(project, collection) {
|
||||||
|
@ -139,16 +143,30 @@ class CollectionListRowBase extends React.Component {
|
||||||
this.props.removeFromCollection(this.props.collection.id, this.props.project.id);
|
this.props.removeFromCollection(this.props.collection.id, this.props.project.id);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
handleAddRemove = (evt) => {
|
||||||
|
// Clicking on View action should not perform add/remove
|
||||||
|
const didOriginateInLink = evt.target.nodeName === 'A';
|
||||||
|
|
||||||
|
if (didOriginateInLink) {
|
||||||
|
return;
|
||||||
|
}
|
||||||
|
|
||||||
|
if (CollectionListRowBase.projectInCollection(this.props.project, this.props.collection)) {
|
||||||
|
this.handleCollectionRemove();
|
||||||
|
} else {
|
||||||
|
this.handleCollectionAdd();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
renderActions = () => {
|
renderActions = () => {
|
||||||
const { optionsOpen } = this.state;
|
const { optionsOpen } = this.state;
|
||||||
const userIsOwner = this.props.user.username === this.props.username;
|
const userIsOwner = this.props.user.username === this.props.username;
|
||||||
|
|
||||||
if (this.props.addMode === true && this.props.project) {
|
if (this.props.addMode === true && this.props.project) {
|
||||||
return CollectionListRowBase.projectInCollection(this.props.project, this.props.collection) ?
|
return <Link to={`/${this.props.collection.owner.username}/collections/${this.props.collection.id}`}>View</Link>;
|
||||||
<AddRemoveButton type="remove" onClick={this.handleCollectionRemove} /> :
|
|
||||||
<AddRemoveButton type="add" onClick={this.handleCollectionAdd} />;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<React.Fragment>
|
<React.Fragment>
|
||||||
<button
|
<button
|
||||||
|
@ -180,6 +198,14 @@ class CollectionListRowBase extends React.Component {
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
renderIsInCollectionStatus = () => {
|
||||||
|
if (CollectionListRowBase.projectInCollection(this.props.project, this.props.collection)) {
|
||||||
|
return checkIcon;
|
||||||
|
}
|
||||||
|
|
||||||
|
return null;
|
||||||
|
}
|
||||||
|
|
||||||
renderCollectionName = () => {
|
renderCollectionName = () => {
|
||||||
const { addMode, collection, username } = this.props;
|
const { addMode, collection, username } = this.props;
|
||||||
const { renameOpen, renameValue } = this.state;
|
const { renameOpen, renameValue } = this.state;
|
||||||
|
@ -208,15 +234,19 @@ class CollectionListRowBase extends React.Component {
|
||||||
}
|
}
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
const { collection } = this.props;
|
const { addMode, collection } = this.props;
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<tr
|
<tr
|
||||||
className="sketches-table__row"
|
className={`sketches-table__row ${addMode ? 'sketches-table__row--is-add-mode' : ''}`}
|
||||||
key={collection.id}
|
key={collection.id}
|
||||||
|
onClick={addMode ? this.handleAddRemove : null}
|
||||||
>
|
>
|
||||||
<th scope="row">
|
<th scope="row">
|
||||||
{this.renderCollectionName()}
|
<span className="sketches-table__name">
|
||||||
|
{addMode && this.renderIsInCollectionStatus()}
|
||||||
|
{this.renderCollectionName()}
|
||||||
|
</span>
|
||||||
</th>
|
</th>
|
||||||
<td>{format(new Date(collection.createdAt), 'MMM D, YYYY')}</td>
|
<td>{format(new Date(collection.createdAt), 'MMM D, YYYY')}</td>
|
||||||
<td>{format(new Date(collection.updatedAt), 'MMM D, YYYY')}</td>
|
<td>{format(new Date(collection.updatedAt), 'MMM D, YYYY')}</td>
|
||||||
|
@ -234,7 +264,10 @@ CollectionListRowBase.propTypes = {
|
||||||
removeFromCollection: PropTypes.func.isRequired,
|
removeFromCollection: PropTypes.func.isRequired,
|
||||||
collection: PropTypes.shape({
|
collection: PropTypes.shape({
|
||||||
id: PropTypes.string.isRequired,
|
id: PropTypes.string.isRequired,
|
||||||
name: PropTypes.string.isRequired
|
name: PropTypes.string.isRequired,
|
||||||
|
owner: PropTypes.shape({
|
||||||
|
username: PropTypes.string.isRequired,
|
||||||
|
}).isRequired,
|
||||||
}).isRequired,
|
}).isRequired,
|
||||||
addMode: PropTypes.bool.isRequired,
|
addMode: PropTypes.bool.isRequired,
|
||||||
project: PropTypes.shape({
|
project: PropTypes.shape({
|
||||||
|
|
|
@ -95,6 +95,10 @@
|
||||||
font-weight: normal;
|
font-weight: normal;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.sketches-table__row--is-add-mode {
|
||||||
|
cursor: pointer;
|
||||||
|
}
|
||||||
|
|
||||||
.sketch-list__dropdown-button {
|
.sketch-list__dropdown-button {
|
||||||
width:#{25 / $base-font-size}rem;
|
width:#{25 / $base-font-size}rem;
|
||||||
height:#{25 / $base-font-size}rem;
|
height:#{25 / $base-font-size}rem;
|
||||||
|
@ -105,6 +109,29 @@
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
.sketches-table__name {
|
||||||
|
display: flex;
|
||||||
|
align-items: center;
|
||||||
|
}
|
||||||
|
|
||||||
|
.sketch-list__check-icon {
|
||||||
|
display: inline-block;
|
||||||
|
margin-right:#{10 / $base-font-size}rem;
|
||||||
|
width:#{25 / $base-font-size}rem;
|
||||||
|
height:#{25 / $base-font-size}rem;
|
||||||
|
@include icon();
|
||||||
|
@include themify() {
|
||||||
|
& path {
|
||||||
|
fill: getThemifyVariable('dropdown-color');
|
||||||
|
}
|
||||||
|
|
||||||
|
& svg {
|
||||||
|
width:#{25 / $base-font-size}rem;
|
||||||
|
height:#{25 / $base-font-size}rem;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
.sketch-list__action-dialogue {
|
.sketch-list__action-dialogue {
|
||||||
@extend %dropdown-open-right;
|
@extend %dropdown-open-right;
|
||||||
top: 63%;
|
top: 63%;
|
||||||
|
|
Loading…
Reference in a new issue