76 lines
2.4 KiB
JavaScript
76 lines
2.4 KiB
JavaScript
import { DownCircleFilled } from "@ant-design/icons";
|
|
import { useApolloClient } from "@apollo/react-hooks";
|
|
import { Button, Dropdown, Menu, Popconfirm } from "antd";
|
|
import React from "react";
|
|
import { useTranslation } from "react-i18next";
|
|
import { connect } from "react-redux";
|
|
import { Link, useHistory } from "react-router-dom";
|
|
import { createStructuredSelector } from "reselect";
|
|
import { selectBodyshop } from "../../redux/user/user.selectors";
|
|
import AddToProduction from "./jobs-detail-header-actions.addtoproduction.util";
|
|
import DuplicateJob from "./jobs-detail-header-actions.duplicate.util";
|
|
|
|
const mapStateToProps = createStructuredSelector({
|
|
//currentUser: selectCurrentUser
|
|
bodyshop: selectBodyshop,
|
|
});
|
|
const mapDispatchToProps = (dispatch) => ({
|
|
//setUserLanguage: language => dispatch(setUserLanguage(language))
|
|
});
|
|
|
|
export function JobsDetailHeaderActions({ job, bodyshop }) {
|
|
const { t } = useTranslation();
|
|
const client = useApolloClient();
|
|
const history = useHistory();
|
|
const statusmenu = (
|
|
<Menu key='popovermenu'>
|
|
<Menu.Item key='cccontract'>
|
|
<Link
|
|
to={{
|
|
pathname: "/manage/courtesycars/contracts/new",
|
|
state: { jobId: job.id },
|
|
}}>
|
|
{t("menus.jobsactions.newcccontract")}
|
|
</Link>
|
|
</Menu.Item>
|
|
<Menu.Item
|
|
key='addtoproduction'
|
|
disabled={!!!job.converted}
|
|
onClick={() => AddToProduction(client, job.id)}>
|
|
{t("jobs.actions.addtoproduction")}
|
|
</Menu.Item>
|
|
<Menu.Item key='duplicatejob'>
|
|
<Popconfirm
|
|
title={t("jobs.labels.duplicateconfirm")}
|
|
okText='Yes'
|
|
cancelText='No'
|
|
onClick={(e) => e.stopPropagation()}
|
|
onConfirm={() =>
|
|
DuplicateJob(
|
|
client,
|
|
job.id,
|
|
{ defaultOpenStatus: bodyshop.md_ro_statuses.default_imported },
|
|
(newJobId) => {
|
|
history.push(`/manage/jobs/${newJobId}`);
|
|
}
|
|
)
|
|
}
|
|
getPopupContainer={(trigger) => trigger.parentNode}>
|
|
{t("menus.jobsactions.duplicate")}
|
|
</Popconfirm>
|
|
</Menu.Item>
|
|
</Menu>
|
|
);
|
|
return (
|
|
<Dropdown overlay={statusmenu} key='changestatus'>
|
|
<Button>
|
|
{t("general.labels.actions")} <DownCircleFilled />
|
|
</Button>
|
|
</Dropdown>
|
|
);
|
|
}
|
|
export default connect(
|
|
mapStateToProps,
|
|
mapDispatchToProps
|
|
)(JobsDetailHeaderActions);
|