You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.

152 lines
4.8 KiB

import { useParams } from "react-router-dom";
import { useCustomerOne } from "../../Hooks/Customers";
import {
Form,
Spin,
Watermark,
Space,
Tabs,
Row,
Col,
Input,
Button,
} from "antd";
import { customerController } from "../../API/LayoutApi/customers";
import Notfound from "../../Utils/Notfound";
import { useCompanyOne } from "../../Hooks/Companies";
import { role } from "../../App";
import { useState } from "react";
// @ts-ignore
import infoIcon from "../../assets/infoIcon.png";
// @ts-ignore
import infoIconActive from "../../assets/infoIconActive.png";
const TabPane = Tabs.TabPane;
type params = {
readonly id: any;
};
const CustomerEdit = () => {
const { id } = useParams<params>();
const { data, refetch, status } = useCustomerOne(id);
const onSubmit = async (value: any) => {
await customerController.customerPatch(value, id);
refetch();
window.location.replace("/#/customers/");
};
const companyData = useCompanyOne(data?.id);
const ClickDelete = () => {
const shouldDelete = window.confirm(
"Are you sure, you want to delete this Driver?"
);
if (shouldDelete && id !== undefined) {
customerController.deleteCustomerController(id).then((data: any) => {
document.location.replace(`/#/customers`);
});
}
};
const [activeTab, setActiveTab] = useState("1");
return (
<div>
<Spin size="large" spinning={!data}>
<Watermark style={{ height: "100%" }}>
{status === "loading" ? (
<Spin size="large" spinning={!data} />
) : data ? (
<Spin size="large" spinning={!data}>
<Space
direction="vertical"
size="middle"
style={{ display: "flex" }}
>
<Tabs
defaultActiveKey="1"
activeKey={activeTab}
onChange={(key) => setActiveTab(key)}
>
<TabPane
tab={
<span style={{ display: "flex", alignItems: "center" }}>
<img
style={{ marginRight: 10 }}
src={activeTab === "1" ? infoIconActive : infoIcon}
alt=""
/>
Information
</span>
}
key="1"
>
<Space
direction="vertical"
size="middle"
style={{ display: "flex" }}
>
<Form
name="basic"
layout="vertical"
wrapperCol={{ span: 16 }}
initialValues={{ ...data }}
onFinish={onSubmit}
autoComplete="off"
>
<Row gutter={[16, 10]}>
{companyData?.data && (
<Col span={6}>
<Form.Item
wrapperCol={{ span: "100%" }}
label="Company"
>
<Input
defaultValue={companyData?.data?.name}
readOnly
/>
</Form.Item>
</Col>
)}
<Col span={6}>
<Form.Item
wrapperCol={{ span: "100%" }}
label="Name"
name="name"
>
<Input />
</Form.Item>
</Col>
</Row>
<Form.Item>
{role === "Owner" && (
<Button
onClick={() => ClickDelete()}
type="primary"
style={{ marginRight: 10 }}
danger
>
Delete
</Button>
)}
<Button type="primary" htmlType="submit">
Submit
</Button>
</Form.Item>
</Form>
</Space>
</TabPane>
</Tabs>
</Space>
</Spin>
) : (
<Notfound />
)}
</Watermark>
</Spin>
</div>
);
};
export default CustomerEdit;