IO-950 Time Ticket editing fix.
This commit is contained in:
@@ -77,121 +77,83 @@ function Header({
|
|||||||
onClick={handleMenuClick}
|
onClick={handleMenuClick}
|
||||||
subMenuCloseDelay={0.3}
|
subMenuCloseDelay={0.3}
|
||||||
>
|
>
|
||||||
<Menu.Item key="home">
|
<Menu.Item key="home" icon={<HomeFilled />}>
|
||||||
<Link to="/manage">
|
<Link to="/manage">{t("menus.header.home")}</Link>
|
||||||
<HomeFilled />
|
|
||||||
{t("menus.header.home")}
|
|
||||||
</Link>
|
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="schedule">
|
<Menu.Item key="schedule" icon={<Icon component={FaCalendarAlt} />}>
|
||||||
<Link to="/manage/schedule">
|
<Link to="/manage/schedule">{t("menus.header.schedule")}</Link>
|
||||||
<Icon component={FaCalendarAlt} />
|
|
||||||
{t("menus.header.schedule")}
|
|
||||||
</Link>
|
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.SubMenu
|
<Menu.SubMenu
|
||||||
title={
|
icon={<Icon component={FaCarCrash} />}
|
||||||
<span>
|
title={t("menus.header.jobs")}
|
||||||
<Icon component={FaCarCrash} />
|
|
||||||
<span>{t("menus.header.jobs")}</span>
|
|
||||||
</span>
|
|
||||||
}
|
|
||||||
>
|
>
|
||||||
<Menu.Item key="activejobs">
|
<Menu.Item key="activejobs" icon={<FileFilled />}>
|
||||||
<FileFilled />
|
|
||||||
<Link to="/manage/jobs">{t("menus.header.activejobs")}</Link>
|
<Link to="/manage/jobs">{t("menus.header.activejobs")}</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="parts-queue">
|
<Menu.Item key="parts-queue" icon={<ToolFilled />}>
|
||||||
<Link to="/manage/partsqueue">
|
<Link to="/manage/partsqueue">{t("menus.header.parts-queue")}</Link>
|
||||||
<ToolFilled /> {t("menus.header.parts-queue")}
|
|
||||||
</Link>
|
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="availablejobs">
|
<Menu.Item key="availablejobs" icon={<ImportOutlined />}>
|
||||||
<Link to="/manage/available">
|
<Link to="/manage/available">
|
||||||
<ImportOutlined /> {t("menus.header.availablejobs")}
|
{t("menus.header.availablejobs")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Divider />
|
<Menu.Divider />
|
||||||
<Menu.Item key="alljobs">
|
<Menu.Item key="alljobs" icon={<UnorderedListOutlined />}>
|
||||||
<UnorderedListOutlined />
|
|
||||||
<Link to="/manage/jobs/all">{t("menus.header.alljobs")}</Link>
|
<Link to="/manage/jobs/all">{t("menus.header.alljobs")}</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Divider />
|
<Menu.Divider />
|
||||||
|
|
||||||
<Menu.Item key="productionlist">
|
<Menu.Item key="productionlist" icon={<ScheduleOutlined />}>
|
||||||
<Link to="/manage/production/list">
|
<Link to="/manage/production/list">
|
||||||
<ScheduleOutlined />
|
|
||||||
{t("menus.header.productionlist")}
|
{t("menus.header.productionlist")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="productionboard">
|
<Menu.Item key="productionboard" icon={<Icon component={BsKanban} />}>
|
||||||
<Link to="/manage/production/board">
|
<Link to="/manage/production/board">
|
||||||
<Icon component={BsKanban} />
|
|
||||||
{t("menus.header.productionboard")}
|
{t("menus.header.productionboard")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Divider />
|
<Menu.Divider />
|
||||||
|
|
||||||
<Menu.Item key="scoreboard">
|
<Menu.Item key="scoreboard" icon={<LineChartOutlined />}>
|
||||||
<LineChartOutlined />
|
|
||||||
<Link to="/manage/scoreboard">{t("menus.header.scoreboard")}</Link>
|
<Link to="/manage/scoreboard">{t("menus.header.scoreboard")}</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
</Menu.SubMenu>
|
</Menu.SubMenu>
|
||||||
<Menu.SubMenu
|
<Menu.SubMenu
|
||||||
title={
|
icon={<UserOutlined />}
|
||||||
<span>
|
title={t("menus.header.customers")}
|
||||||
<UserOutlined />
|
|
||||||
<span>{t("menus.header.customers")}</span>
|
|
||||||
</span>
|
|
||||||
}
|
|
||||||
>
|
>
|
||||||
<Menu.Item key="owners">
|
<Menu.Item key="owners" icon={<TeamOutlined />}>
|
||||||
<Link to="/manage/owners">
|
<Link to="/manage/owners">{t("menus.header.owners")}</Link>
|
||||||
<TeamOutlined />
|
|
||||||
{t("menus.header.owners")}
|
|
||||||
</Link>
|
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="vehicles">
|
<Menu.Item key="vehicles" icon={<CarFilled />}>
|
||||||
<Link to="/manage/vehicles">
|
<Link to="/manage/vehicles">{t("menus.header.vehicles")}</Link>
|
||||||
<CarFilled />
|
|
||||||
{t("menus.header.vehicles")}
|
|
||||||
</Link>
|
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
</Menu.SubMenu>
|
</Menu.SubMenu>
|
||||||
<Menu.SubMenu
|
<Menu.SubMenu
|
||||||
title={
|
icon={<CarFilled />}
|
||||||
<span>
|
title={t("menus.header.courtesycars")}
|
||||||
<CarFilled />
|
|
||||||
<span>{t("menus.header.courtesycars")}</span>
|
|
||||||
</span>
|
|
||||||
}
|
|
||||||
>
|
>
|
||||||
<Menu.Item key="courtesycarsall">
|
<Menu.Item key="courtesycarsall" icon={<CarFilled />}>
|
||||||
<Link to="/manage/courtesycars">
|
<Link to="/manage/courtesycars">
|
||||||
<CarFilled />
|
|
||||||
{t("menus.header.courtesycars-all")}
|
{t("menus.header.courtesycars-all")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="contracts">
|
<Menu.Item key="contracts" icon={<FileFilled />}>
|
||||||
<Link to="/manage/courtesycars/contracts">
|
<Link to="/manage/courtesycars/contracts">
|
||||||
<FileFilled />
|
|
||||||
{t("menus.header.courtesycars-contracts")}
|
{t("menus.header.courtesycars-contracts")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
<Menu.Item key="newcontract">
|
<Menu.Item key="newcontract" icon={<FileAddFilled />}>
|
||||||
<Link to="/manage/courtesycars/contracts/new">
|
<Link to="/manage/courtesycars/contracts/new">
|
||||||
<FileAddFilled />
|
|
||||||
{t("menus.header.courtesycars-newcontract")}
|
{t("menus.header.courtesycars-newcontract")}
|
||||||
</Link>
|
</Link>
|
||||||
</Menu.Item>
|
</Menu.Item>
|
||||||
</Menu.SubMenu>
|
</Menu.SubMenu>
|
||||||
<Menu.SubMenu
|
<Menu.SubMenu
|
||||||
title={
|
icon={<DollarCircleFilled />}
|
||||||
<span>
|
title={t("menus.header.accounting")}
|
||||||
<DollarCircleFilled />
|
|
||||||
<span>{t("menus.header.accounting")}</span>
|
|
||||||
</span>
|
|
||||||
}
|
|
||||||
>
|
>
|
||||||
<Menu.Item key="bills">
|
<Menu.Item key="bills">
|
||||||
<Link to="/manage/bills">{t("menus.header.bills")}</Link>
|
<Link to="/manage/bills">{t("menus.header.bills")}</Link>
|
||||||
|
|||||||
@@ -37,6 +37,33 @@ export function TimeTicketModalComponent({
|
|||||||
}) {
|
}) {
|
||||||
const { t } = useTranslation();
|
const { t } = useTranslation();
|
||||||
|
|
||||||
|
const CostCenterSelect = ({ emps, value, ...props }) => {
|
||||||
|
return (
|
||||||
|
<Select
|
||||||
|
value={value === "timetickets.labels.shift" ? t(value) : value}
|
||||||
|
{...props}
|
||||||
|
disabled={value === "timetickets.labels.shift"}
|
||||||
|
>
|
||||||
|
{emps &&
|
||||||
|
emps.rates.map((item) => (
|
||||||
|
<Select.Option key={item.cost_center}>
|
||||||
|
{item.cost_center}
|
||||||
|
</Select.Option>
|
||||||
|
))}
|
||||||
|
</Select>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
const MemoInput = ({ value, ...props }) => {
|
||||||
|
return (
|
||||||
|
<Input
|
||||||
|
value={value?.startsWith("timetickets.") ? t(value) : value}
|
||||||
|
{...props}
|
||||||
|
disabled={value?.startsWith("timetickets.")}
|
||||||
|
/>
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div>
|
<div>
|
||||||
<LayoutFormRow grow noDivider>
|
<LayoutFormRow grow noDivider>
|
||||||
@@ -102,14 +129,7 @@ export function TimeTicketModalComponent({
|
|||||||
},
|
},
|
||||||
]}
|
]}
|
||||||
>
|
>
|
||||||
<Select>
|
<CostCenterSelect emps={emps} />
|
||||||
{emps &&
|
|
||||||
emps.rates.map((item) => (
|
|
||||||
<Select.Option key={item.cost_center}>
|
|
||||||
{item.cost_center}
|
|
||||||
</Select.Option>
|
|
||||||
))}
|
|
||||||
</Select>
|
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
);
|
);
|
||||||
}}
|
}}
|
||||||
@@ -117,17 +137,23 @@ export function TimeTicketModalComponent({
|
|||||||
</LayoutFormRow>
|
</LayoutFormRow>
|
||||||
|
|
||||||
<LayoutFormRow>
|
<LayoutFormRow>
|
||||||
<Form.Item
|
<Form.Item shouldUpdate>
|
||||||
label={t("timetickets.fields.productivehrs")}
|
{() => (
|
||||||
name="productivehrs"
|
<Form.Item
|
||||||
rules={[
|
label={t("timetickets.fields.productivehrs")}
|
||||||
{
|
name="productivehrs"
|
||||||
required: true,
|
rules={[
|
||||||
message: t("general.validation.required"),
|
{
|
||||||
},
|
required:
|
||||||
]}
|
form.getFieldValue("cost_center") !==
|
||||||
>
|
"timetickets.labels.shift",
|
||||||
<InputNumber min={0} precision={1} />
|
message: t("general.validation.required"),
|
||||||
|
},
|
||||||
|
]}
|
||||||
|
>
|
||||||
|
<InputNumber min={0} precision={1} />
|
||||||
|
</Form.Item>
|
||||||
|
)}
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item label={t("timetickets.fields.actualhrs")} name="actualhrs">
|
<Form.Item label={t("timetickets.fields.actualhrs")} name="actualhrs">
|
||||||
<InputNumber min={0} precision={1} />
|
<InputNumber min={0} precision={1} />
|
||||||
@@ -155,7 +181,7 @@ export function TimeTicketModalComponent({
|
|||||||
/>
|
/>
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item label={t("timetickets.fields.memo")} name="memo">
|
<Form.Item label={t("timetickets.fields.memo")} name="memo">
|
||||||
<Input />
|
<MemoInput />
|
||||||
</Form.Item>
|
</Form.Item>
|
||||||
<Form.Item shouldUpdate>
|
<Form.Item shouldUpdate>
|
||||||
{() => (
|
{() => (
|
||||||
|
|||||||
@@ -54,7 +54,7 @@ export function TimeTicketModalContainer({
|
|||||||
emps.length === 1
|
emps.length === 1
|
||||||
? emps[0].rates.filter(
|
? emps[0].rates.filter(
|
||||||
(r) => r.cost_center === values.cost_center
|
(r) => r.cost_center === values.cost_center
|
||||||
)[0].rate
|
)[0]?.rate
|
||||||
: null,
|
: null,
|
||||||
},
|
},
|
||||||
},
|
},
|
||||||
@@ -205,7 +205,7 @@ export function TimeTicketModalContainer({
|
|||||||
timeTicketModal.context.timeticket.jobid ||
|
timeTicketModal.context.timeticket.jobid ||
|
||||||
null,
|
null,
|
||||||
date: timeTicketModal.context.timeticket.date
|
date: timeTicketModal.context.timeticket.date
|
||||||
? moment(timeTicketModal.context.date)
|
? moment(timeTicketModal.context.timeticket.date)
|
||||||
: null,
|
: null,
|
||||||
}
|
}
|
||||||
: { jobid: timeTicketModal.context.jobId || null }
|
: { jobid: timeTicketModal.context.jobId || null }
|
||||||
|
|||||||
Reference in New Issue
Block a user