mirror of
https://github.com/franjsco/tick3t
synced 2025-01-19 12:39:56 +01:00
improvement: various
This commit is contained in:
parent
2267747fcd
commit
70a378f7cd
@ -1,11 +1,16 @@
|
|||||||
import React, { Component } from 'react';
|
import React, { Component } from 'react';
|
||||||
|
import { Link } from 'react-router-dom';
|
||||||
import {
|
import {
|
||||||
Row,
|
Row,
|
||||||
Col,
|
Col,
|
||||||
Table
|
Table
|
||||||
} from 'reactstrap';
|
} from 'reactstrap';
|
||||||
|
|
||||||
import { Link } from 'react-router-dom';
|
import PaginationComponent from "react-reactstrap-pagination";
|
||||||
|
|
||||||
|
import { formatDate, decode } from '../../utils/helper';
|
||||||
|
import { getTickets, findTicket, filterTicketStatus } from '../../api/tickets';
|
||||||
|
import { getAllTicketStatus } from '../../api/categories';
|
||||||
|
|
||||||
import Card from '../../components/Card';
|
import Card from '../../components/Card';
|
||||||
import SearchForm from '../../components/SearchForm';
|
import SearchForm from '../../components/SearchForm';
|
||||||
@ -15,69 +20,109 @@ import DropDown from '../../components/DropDown';
|
|||||||
class TicketList extends Component {
|
class TicketList extends Component {
|
||||||
constructor(props) {
|
constructor(props) {
|
||||||
super(props);
|
super(props);
|
||||||
|
|
||||||
this.state = {
|
this.state = {
|
||||||
|
totalPages: 1,
|
||||||
|
selectedPage: 1,
|
||||||
|
selectedStatus: '',
|
||||||
data: [],
|
data: [],
|
||||||
categories: [],
|
status: [],
|
||||||
|
type: [],
|
||||||
error: ''
|
error: ''
|
||||||
};
|
};
|
||||||
|
|
||||||
this.API_URL= process.env.REACT_APP_API_URL;
|
this.filterId = this.filterId.bind(this);
|
||||||
|
this.filterStatus = this.filterStatus.bind(this);
|
||||||
|
this.handleInputChange = this.handleInputChange.bind(this);
|
||||||
|
this.handleSelected = this.handleSelected.bind(this);
|
||||||
}
|
}
|
||||||
|
|
||||||
componentDidMount() {
|
componentDidMount() {
|
||||||
fetch(`${this.API_URL}tickets?_limit=10`)
|
this.setState({ isLoading: true });
|
||||||
.then(response => {
|
|
||||||
if (!response.ok) {
|
getTickets()
|
||||||
throw new Error('Error API');
|
.then((json) => {
|
||||||
}
|
this.setState({ data: json.data, isLoading: false, totalPages: json.totalPages });
|
||||||
return response.json();
|
|
||||||
})
|
})
|
||||||
.then(json => this.setState({ data: json, isLoading: false }))
|
.catch((error) => {
|
||||||
|
this.setState({ error, isLoading: false })
|
||||||
|
});
|
||||||
|
|
||||||
|
getAllTicketStatus()
|
||||||
|
.then((json) => this.setState({ status: json.data }))
|
||||||
.catch(error => this.setState({ error, isLoading: false }));
|
.catch(error => this.setState({ error, isLoading: false }));
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
fetch(`${this.API_URL}categories?type=ticketStatus`)
|
handleInputChange(event) {
|
||||||
.then((response) => {
|
const target = event.target;
|
||||||
if (!response.ok) {
|
const value = target.value;
|
||||||
throw new Error('Error API');
|
|
||||||
}
|
|
||||||
|
|
||||||
return response.json();
|
this.setState({
|
||||||
})
|
ticketId: value
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
filterId(event) {
|
||||||
|
event.preventDefault();
|
||||||
|
this.setState({ isLoading: true });
|
||||||
|
|
||||||
|
const ticketId = this.state.ticketId || '';
|
||||||
|
|
||||||
|
findTicket(ticketId)
|
||||||
|
.then(json => this.setState({ data: json.data, isLoading: false, totalPages: json.totalPages }))
|
||||||
|
.catch(error => this.setState({ error, isLoading: false }));
|
||||||
|
}
|
||||||
|
|
||||||
|
|
||||||
|
filterStatus(event) {
|
||||||
|
const target = event.target;
|
||||||
|
const value = target.value;
|
||||||
|
|
||||||
|
this.setState({ selectedStatus: value })
|
||||||
|
|
||||||
|
getTickets(1, value)
|
||||||
|
.then(json => this.setState({ data: json.data, isLoading: false, totalPages: json.totalPages, selectedPage: 1 }))
|
||||||
|
.catch(error => this.setState({ error, isLoading: false }));
|
||||||
|
}
|
||||||
|
|
||||||
|
handleSelected(selectedPage) {
|
||||||
|
this.setState( { isLoading: true })
|
||||||
|
const selectedStatus = this.state.selectedStatus;
|
||||||
|
getTickets(selectedPage, selectedStatus)
|
||||||
.then((json) => {
|
.then((json) => {
|
||||||
this.setState({
|
this.setState({ data: json.data, isLoading: false});
|
||||||
categories: json
|
|
||||||
});
|
|
||||||
})
|
})
|
||||||
.catch((err) => {
|
.catch((error) => {
|
||||||
this.setState({
|
this.setState({ error, isLoading: false })
|
||||||
error: err.message
|
|
||||||
});
|
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
||||||
render() {
|
render() {
|
||||||
let tickets = this.state.data;
|
let tickets = this.state.data;
|
||||||
|
if (tickets) {
|
||||||
if (tickets.length) {
|
|
||||||
tickets = tickets.map((ticket) => {
|
tickets = tickets.map((ticket) => {
|
||||||
return (
|
return (
|
||||||
<tr>
|
<tr key={ticket.ticketId}>
|
||||||
<th scope="row">
|
<th scope="row">
|
||||||
<Link to={`/admin/ticket/${ticket.id}`}>
|
<Link to={`/admin/ticket/${ticket.ticketId}`}>
|
||||||
{ticket.id}
|
{ticket.ticketId}
|
||||||
</Link>
|
</Link>
|
||||||
</th>
|
</th>
|
||||||
<td>
|
<td>
|
||||||
{ticket.status}
|
{decode(ticket.status)}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{ticket.type}
|
{decode(ticket.type)}
|
||||||
</td>
|
</td>
|
||||||
<td>
|
<td>
|
||||||
{ticket.subject}
|
{ticket.subject}
|
||||||
</td>
|
</td>
|
||||||
|
<td>
|
||||||
|
{formatDate(ticket.updatedAt)}
|
||||||
|
</td>
|
||||||
</tr>);
|
</tr>);
|
||||||
});
|
});
|
||||||
}
|
}
|
||||||
@ -90,9 +135,8 @@ class TicketList extends Component {
|
|||||||
name="search"
|
name="search"
|
||||||
id="search"
|
id="search"
|
||||||
placeholder="ticket ID"
|
placeholder="ticket ID"
|
||||||
onChange={this.handleChangeInput}
|
onSubmit={this.filterId}
|
||||||
onSubmit={this.handleSubmit}
|
onChange={this.handleInputChange}
|
||||||
value={this.state.ticketId}
|
|
||||||
buttonName="Search"
|
buttonName="Search"
|
||||||
/>
|
/>
|
||||||
|
|
||||||
@ -100,7 +144,8 @@ class TicketList extends Component {
|
|||||||
<Col md={5}></Col>
|
<Col md={5}></Col>
|
||||||
<Col md={3} className="float-right">
|
<Col md={3} className="float-right">
|
||||||
<DropDown
|
<DropDown
|
||||||
options={this.state.categories}
|
options={this.state.status}
|
||||||
|
onChange={this.filterStatus}
|
||||||
/>
|
/>
|
||||||
|
|
||||||
|
|
||||||
@ -108,21 +153,22 @@ class TicketList extends Component {
|
|||||||
</Row>
|
</Row>
|
||||||
<Row>
|
<Row>
|
||||||
<Col>
|
<Col>
|
||||||
<Table bordered responsive>
|
<Table responsive>
|
||||||
<thead>
|
<thead>
|
||||||
<tr>
|
<tr>
|
||||||
<th>id</th>
|
<th>id</th>
|
||||||
<th>status</th>
|
<th>status</th>
|
||||||
<th>type</th>
|
<th>type</th>
|
||||||
<th>subject</th>
|
<th>subject</th>
|
||||||
|
<th>updated</th>
|
||||||
</tr>
|
</tr>
|
||||||
</thead>
|
</thead>
|
||||||
<tbody>
|
<tbody>
|
||||||
{tickets.length ? tickets : (
|
{tickets || (
|
||||||
<tr>
|
<tr>
|
||||||
<td
|
<td
|
||||||
className="text-center font-weight-bold"
|
className="text-center font-weight-bold"
|
||||||
colspan="4"
|
colspan="5"
|
||||||
>
|
>
|
||||||
no ticket
|
no ticket
|
||||||
</td>
|
</td>
|
||||||
@ -131,6 +177,15 @@ class TicketList extends Component {
|
|||||||
</Table>
|
</Table>
|
||||||
</Col>
|
</Col>
|
||||||
</Row>
|
</Row>
|
||||||
|
<Row>
|
||||||
|
<Col>
|
||||||
|
<PaginationComponent
|
||||||
|
totalItems={this.state.totalPages}
|
||||||
|
pageSize={1}
|
||||||
|
onSelect={this.handleSelected}
|
||||||
|
/>
|
||||||
|
</Col>
|
||||||
|
</Row>
|
||||||
</Card>
|
</Card>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user