projeto-hit/frontend/src/components/Ticket/TicketsManager/TicketsManager.jsx

63 lines
2.1 KiB
React
Raw Normal View History

2022-07-25 18:18:27 +00:00
import React from "react";
import NewTicketModal from "../../NewTicketModal";
import TicketsList from "../../TicketsList/TicketsList";
import { AuthContext } from "../../../context/Auth/AuthContext";
import { i18n } from "../../../translate/i18n";
import { Can } from "../../Can";
import TicketsQueueSelect from "../../TicketsQueueSelect";
import TicketsManagerStyled from "./TicketsManager.style";
import TicketsTabs from "./TicketsTabs/TicketsTabs";
const TicketsManager = () => {
const [valueTab, setValueTab] = React.useState("open");
const [searchParam, setSearchParam] = React.useState("");
const [newTicketModalOpen, setNewTicketModalOpen] = React.useState(false);
const [showAllTickets, setShowAllTickets] = React.useState(false);
const { user } = React.useContext(AuthContext);
const userQueueIds = user.queues.map((q) => q.id);
const [selectedQueueIds, setSelectedQueueIds] = React.useState(userQueueIds || []);
let searchTimeout;
const handleSearch = (e) => {
const searchedTerm = e.target.value.toLowerCase();
clearTimeout(searchTimeout);
if (searchedTerm === "") {
setSearchParam(searchedTerm);
return;
}
searchTimeout = setTimeout(() => {
setSearchParam(searchedTerm);
}, 200);
};
React.useEffect(() => {
if (user.profile.toUpperCase() === "ADMIN") {
setShowAllTickets(true);
}
}, [user.profile]);
return (
<TicketsManagerStyled>
<TicketsTabs setValueTab={setValueTab} valueTab={valueTab} />
<div style={{ display: "flex", flexDirection: "row", justifyContent: "center" }}>
<input type="text" style={{ width: "100%", margin: "0 6px" }} onChange={handleSearch}/>
<button onClick={() => setNewTicketModalOpen(true)}>+</button>
</div>
<TicketsList status={valueTab} selectedQueueIds={selectedQueueIds} searchParam={searchParam} />
<NewTicketModal
modalOpen={newTicketModalOpen}
onClose={(e) => setNewTicketModalOpen(false)}
/>
</TicketsManagerStyled>
);
};
export default TicketsManager;