mirror of
https://github.com/shlinkio/shlink-web-client.git
synced 2025-01-25 01:03:45 +03:00
Created TagCard test
This commit is contained in:
parent
53132fa900
commit
85cb849ba5
3 changed files with 59 additions and 35 deletions
|
@ -115,8 +115,9 @@ export class ShortUrlsListComponent extends React.Component {
|
||||||
));
|
));
|
||||||
}
|
}
|
||||||
|
|
||||||
renderMobileOrderingControls() {
|
render() {
|
||||||
return (
|
return (
|
||||||
|
<React.Fragment>
|
||||||
<div className="d-block d-md-none mb-3">
|
<div className="d-block d-md-none mb-3">
|
||||||
<SortingDropdown
|
<SortingDropdown
|
||||||
items={SORTABLE_FIELDS}
|
items={SORTABLE_FIELDS}
|
||||||
|
@ -125,13 +126,6 @@ export class ShortUrlsListComponent extends React.Component {
|
||||||
onChange={this.handleOrderBy}
|
onChange={this.handleOrderBy}
|
||||||
/>
|
/>
|
||||||
</div>
|
</div>
|
||||||
);
|
|
||||||
}
|
|
||||||
|
|
||||||
render() {
|
|
||||||
return (
|
|
||||||
<React.Fragment>
|
|
||||||
{this.renderMobileOrderingControls()}
|
|
||||||
<table className="table table-striped table-hover">
|
<table className="table table-striped table-hover">
|
||||||
<thead className="short-urls-list__header">
|
<thead className="short-urls-list__header">
|
||||||
<tr>
|
<tr>
|
||||||
|
|
|
@ -28,36 +28,20 @@ export default class TagCard extends React.Component {
|
||||||
return (
|
return (
|
||||||
<Card className="tag-card">
|
<Card className="tag-card">
|
||||||
<CardBody className="tag-card__body">
|
<CardBody className="tag-card__body">
|
||||||
<button
|
<button className="btn btn-light btn-sm tag-card__btn tag-card__btn--last" onClick={toggleDelete}>
|
||||||
className="btn btn-light btn-sm tag-card__btn tag-card__btn--last"
|
|
||||||
onClick={toggleDelete}
|
|
||||||
>
|
|
||||||
<FontAwesomeIcon icon={deleteIcon} />
|
<FontAwesomeIcon icon={deleteIcon} />
|
||||||
</button>
|
</button>
|
||||||
<button
|
<button className="btn btn-light btn-sm tag-card__btn" onClick={toggleEdit}>
|
||||||
className="btn btn-light btn-sm tag-card__btn"
|
|
||||||
onClick={toggleEdit}
|
|
||||||
>
|
|
||||||
<FontAwesomeIcon icon={editIcon} />
|
<FontAwesomeIcon icon={editIcon} />
|
||||||
</button>
|
</button>
|
||||||
<h5 className="tag-card__tag-title">
|
<h5 className="tag-card__tag-title">
|
||||||
<TagBullet tag={tag} />
|
<TagBullet tag={tag} />
|
||||||
<Link to={`/server/${currentServerId}/list-short-urls/1?tag=${tag}`}>
|
<Link to={`/server/${currentServerId}/list-short-urls/1?tag=${tag}`}>{tag}</Link>
|
||||||
{tag}
|
|
||||||
</Link>
|
|
||||||
</h5>
|
</h5>
|
||||||
</CardBody>
|
</CardBody>
|
||||||
|
|
||||||
<DeleteTagConfirmModal
|
<DeleteTagConfirmModal tag={tag} toggle={toggleDelete} isOpen={this.state.isDeleteModalOpen} />
|
||||||
tag={tag}
|
<EditTagModal tag={tag} toggle={toggleEdit} isOpen={this.state.isEditModalOpen} />
|
||||||
toggle={toggleDelete}
|
|
||||||
isOpen={this.state.isDeleteModalOpen}
|
|
||||||
/>
|
|
||||||
<EditTagModal
|
|
||||||
tag={tag}
|
|
||||||
toggle={toggleEdit}
|
|
||||||
isOpen={this.state.isEditModalOpen}
|
|
||||||
/>
|
|
||||||
</Card>
|
</Card>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
46
test/tags/TagCard.test.js
Normal file
46
test/tags/TagCard.test.js
Normal file
|
@ -0,0 +1,46 @@
|
||||||
|
import React from 'react';
|
||||||
|
import { shallow } from 'enzyme';
|
||||||
|
import { Link } from 'react-router-dom';
|
||||||
|
import TagCard from '../../src/tags/TagCard';
|
||||||
|
import TagBullet from '../../src/tags/helpers/TagBullet';
|
||||||
|
|
||||||
|
describe('<TagCard />', () => {
|
||||||
|
let wrapper;
|
||||||
|
|
||||||
|
beforeEach(() => {
|
||||||
|
wrapper = shallow(<TagCard tag="ssr" currentServerId="1" />);
|
||||||
|
});
|
||||||
|
afterEach(() => wrapper.unmount());
|
||||||
|
|
||||||
|
it('shows a TagBullet and a link to the list filtering by the tag', () => {
|
||||||
|
const link = wrapper.find(Link);
|
||||||
|
const bullet = wrapper.find(TagBullet);
|
||||||
|
|
||||||
|
expect(link.prop('to')).toEqual('/server/1/list-short-urls/1?tag=ssr');
|
||||||
|
expect(bullet.prop('tag')).toEqual('ssr');
|
||||||
|
});
|
||||||
|
|
||||||
|
it('displays delete modal when delete btn is clicked', (done) => {
|
||||||
|
const delBtn = wrapper.find('.tag-card__btn').at(0);
|
||||||
|
|
||||||
|
expect(wrapper.state('isDeleteModalOpen')).toEqual(false);
|
||||||
|
delBtn.simulate('click');
|
||||||
|
|
||||||
|
setImmediate(() => {
|
||||||
|
expect(wrapper.state('isDeleteModalOpen')).toEqual(true);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
|
||||||
|
it('displays edit modal when edit btn is clicked', (done) => {
|
||||||
|
const editBtn = wrapper.find('.tag-card__btn').at(1);
|
||||||
|
|
||||||
|
expect(wrapper.state('isEditModalOpen')).toEqual(false);
|
||||||
|
editBtn.simulate('click');
|
||||||
|
|
||||||
|
setImmediate(() => {
|
||||||
|
expect(wrapper.state('isEditModalOpen')).toEqual(true);
|
||||||
|
done();
|
||||||
|
});
|
||||||
|
});
|
||||||
|
});
|
Loading…
Add table
Reference in a new issue