e.id === technician.id)[0];
return (
@@ -53,7 +59,7 @@ export function TechClockInComponent({ form, bodyshop, technician }) {
{item.cost_center === "timetickets.labels.shift"
? t(item.cost_center)
- : bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber
+ : bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber || Enhanced_Payroll.treatment === "on"
? t(
`joblines.fields.lbr_types.${item.cost_center.toUpperCase()}`
)
diff --git a/client/src/components/tech-job-clock-in-form/tech-job-clock-in-form.container.jsx b/client/src/components/tech-job-clock-in-form/tech-job-clock-in-form.container.jsx
index 7754c07f2..838c83851 100644
--- a/client/src/components/tech-job-clock-in-form/tech-job-clock-in-form.container.jsx
+++ b/client/src/components/tech-job-clock-in-form/tech-job-clock-in-form.container.jsx
@@ -12,6 +12,7 @@ import TechClockInComponent from "./tech-job-clock-in-form.component";
import TechJobPrintTickets from "../tech-job-print-tickets/tech-job-print-tickets.component";
import moment from "moment";
import { setModalContext } from "../../redux/modals/modals.actions";
+import { useTreatments } from "@splitsoftware/splitio-react";
const mapStateToProps = createStructuredSelector({
technician: selectTechnician,
@@ -26,9 +27,10 @@ export function TechClockInContainer({
technician,
bodyshop,
}) {
- console.log(
- "🚀 ~ file: tech-job-clock-in-form.container.jsx:29 ~ technician:",
- technician
+ const { Enhanced_Payroll } = useTreatments(
+ ["Enhanced_Payroll"],
+ {},
+ bodyshop.imexshopid
);
const [form] = Form.useForm();
const [loading, setLoading] = useState(false);
@@ -56,7 +58,7 @@ export function TechClockInContainer({
jobid: values.jobid,
cost_center: values.cost_center,
ciecacode:
- bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber
+ bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber || Enhanced_Payroll.treatment === 'on'
? values.cost_center
: Object.keys(
bodyshop.md_responsibility_centers.defaults.costs
diff --git a/client/src/components/tech-job-clock-out-button/tech-job-clock-out-button.component.jsx b/client/src/components/tech-job-clock-out-button/tech-job-clock-out-button.component.jsx
index d1c5c3528..321ef903d 100644
--- a/client/src/components/tech-job-clock-out-button/tech-job-clock-out-button.component.jsx
+++ b/client/src/components/tech-job-clock-out-button/tech-job-clock-out-button.component.jsx
@@ -24,6 +24,7 @@ import { selectBodyshop } from "../../redux/user/user.selectors";
import { CalculateAllocationsTotals } from "../labor-allocations-table/labor-allocations-table.utility";
import TechJobClockoutDelete from "../tech-job-clock-out-delete/tech-job-clock-out-delete.component";
import { LaborAllocationContainer } from "../time-ticket-modal/time-ticket-modal.component";
+import { useTreatments } from "@splitsoftware/splitio-react";
const mapStateToProps = createStructuredSelector({
bodyshop: selectBodyshop,
@@ -43,6 +44,12 @@ export function TechClockOffButton({
const [updateTimeticket] = useMutation(UPDATE_TIME_TICKET);
const [updateJobStatus] = useMutation(UPDATE_JOB_STATUS);
const [form] = Form.useForm();
+ const { Enhanced_Payroll } = useTreatments(
+ ["Enhanced_Payroll"],
+ {},
+ bodyshop.imexshopid
+ );
+
const { queryLoading, data: lineTicketData } = useQuery(
GET_LINE_TICKET_BY_PK,
{
@@ -76,7 +83,9 @@ export function TechClockOffButton({
?.rate,
flat_rate: emps && emps.flat_rate,
ciecacode:
- bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber
+ bodyshop.cdk_dealerid ||
+ bodyshop.pbs_serialnumber ||
+ Enhanced_Payroll.treatment === "on"
? values.cost_center
: Object.keys(
bodyshop.md_responsibility_centers.defaults.costs
diff --git a/client/src/components/tech-sider/tech-sider.component.jsx b/client/src/components/tech-sider/tech-sider.component.jsx
index ec68cd0f9..49f2487dc 100644
--- a/client/src/components/tech-sider/tech-sider.component.jsx
+++ b/client/src/components/tech-sider/tech-sider.component.jsx
@@ -1,6 +1,7 @@
import Icon, {
SearchOutlined,
ScheduleOutlined,
+ UserAddOutlined,
CarOutlined,
} from "@ant-design/icons";
import { Layout, Menu } from "antd";
@@ -72,19 +73,28 @@ export function TechSider({
{t("menus.tech.joblookup")}
{Enhanced_Payroll.treatment === "on" ? (
- }
- onClick={() => {
- setTimeTicketTaskContext({
- actions: {},
- context: { jobid: null },
- });
- }}
- >
- {t("menus.tech.claimtask")}
-
+ <>
+ }
+ >
+ {t("menus.tech.assignedjobs")}
+
+ }
+ onClick={() => {
+ setTimeTicketTaskContext({
+ actions: {},
+ context: { jobid: null },
+ });
+ }}
+ >
+ {t("menus.tech.claimtask")}
+
+ >
) : (
{t("menus.tech.productionboard")}
- }
- >
- {t("menus.tech.assignedjobs")}
-
+
{item.cost_center === "timetickets.labels.shift"
? t(item.cost_center)
- : bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber
+ : bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber || Enhanced_Payroll.treatment === 'on'
? t(
`joblines.fields.lbr_types.${item.cost_center.toUpperCase()}`
)
diff --git a/client/src/components/time-ticket-modal/time-ticket-modal.container.jsx b/client/src/components/time-ticket-modal/time-ticket-modal.container.jsx
index 4ae2913b6..e70cc4e5c 100644
--- a/client/src/components/time-ticket-modal/time-ticket-modal.container.jsx
+++ b/client/src/components/time-ticket-modal/time-ticket-modal.container.jsx
@@ -15,6 +15,7 @@ import { selectTimeTicket } from "../../redux/modals/modals.selectors";
import { selectBodyshop } from "../../redux/user/user.selectors";
import TimeTicketModalComponent from "./time-ticket-modal.component";
import TimeTicketsCommitToggleComponent from "../time-tickets-commit-toggle/time-tickets-commit-toggle.component";
+import { useTreatments } from "@splitsoftware/splitio-react";
const mapStateToProps = createStructuredSelector({
timeTicketModal: selectTimeTicket,
@@ -35,7 +36,11 @@ export function TimeTicketModalContainer({
const [enterAgain, setEnterAgain] = useState(false);
const [insertTicket] = useMutation(INSERT_NEW_TIME_TICKET);
const [updateTicket] = useMutation(UPDATE_TIME_TICKET);
-
+ const { Enhanced_Payroll } = useTreatments(
+ ["Enhanced_Payroll"],
+ {},
+ bodyshop.imexshopid
+ );
const { data: EmployeeAutoCompleteData } = useQuery(QUERY_ACTIVE_EMPLOYEES, {
skip: !timeTicketModal.visible,
fetchPolicy: "network-only",
@@ -147,7 +152,7 @@ export function TimeTicketModalContainer({
if (!!changedFields.cost_center && !!EmployeeAutoCompleteData) {
form.setFieldsValue({
ciecacode:
- bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber
+ bodyshop.cdk_dealerid || bodyshop.pbs_serialnumber || Enhanced_Payroll.treatments === 'on'
? changedFields.cost_center
: Object.keys(
bodyshop.md_responsibility_centers.defaults.costs
diff --git a/client/src/components/time-ticket-task-modal/time-ticket-task-modal.component.jsx b/client/src/components/time-ticket-task-modal/time-ticket-task-modal.component.jsx
index 4b2ddc76b..fc45add0d 100644
--- a/client/src/components/time-ticket-task-modal/time-ticket-task-modal.component.jsx
+++ b/client/src/components/time-ticket-task-modal/time-ticket-task-modal.component.jsx
@@ -74,7 +74,7 @@ export function TimeTicketTaskModalComponent({
{() => {
const { task } = form.getFieldsValue();
- const theTaskPreset = bodyshop.md_tasks_presets.presets.find(
+ const theTaskPreset = bodyshop.md_tasks_presets?.presets?.find(
(tp) => tp.name === task
);
diff --git a/client/src/pages/tech-assigned-prod-jobs/tech-assigned-prod-jobs.component.jsx b/client/src/pages/tech-assigned-prod-jobs/tech-assigned-prod-jobs.component.jsx
index b971bd368..65b71f409 100644
--- a/client/src/pages/tech-assigned-prod-jobs/tech-assigned-prod-jobs.component.jsx
+++ b/client/src/pages/tech-assigned-prod-jobs/tech-assigned-prod-jobs.component.jsx
@@ -178,7 +178,7 @@ export function TechAssignedProdJobs({
},
},
{
- title: t("jobs.labels.actions"),
+ title: t("general.labels.actions"),
dataIndex: "actions",
key: "actions",
render: (text, record) => (
diff --git a/client/src/translations/en_us/common.json b/client/src/translations/en_us/common.json
index 6b708787e..295562f11 100644
--- a/client/src/translations/en_us/common.json
+++ b/client/src/translations/en_us/common.json
@@ -2755,6 +2755,7 @@
"deleting": "Error deleting time ticket. {{message}}",
"noemployeeforuser": "Unable to use Shift Clock",
"noemployeeforuser_sub": "An employee record has not been created for this user. Please create one before using the shift clock. ",
+ "payall": "Error flagging hours. {{error}}",
"shiftalreadyclockedon": "You are already clocked onto a shift. Unable to create shift entry."
},
"fields": {
@@ -2805,7 +2806,8 @@
"clockedout": "Clocked out successfully.",
"committed": "Time Tickets Committed Successfully",
"created": "Time ticket entered successfully.",
- "deleted": "Time ticket deleted successfully."
+ "deleted": "Time ticket deleted successfully.",
+ "payall": "All hours paid out successfully."
},
"validation": {
"clockoffmustbeafterclockon": "Clock off time must be the same or after clock in time.",
diff --git a/client/src/translations/es/common.json b/client/src/translations/es/common.json
index 771ba8750..13077359b 100644
--- a/client/src/translations/es/common.json
+++ b/client/src/translations/es/common.json
@@ -2755,6 +2755,7 @@
"deleting": "",
"noemployeeforuser": "",
"noemployeeforuser_sub": "",
+ "payall": "",
"shiftalreadyclockedon": ""
},
"fields": {
@@ -2805,7 +2806,8 @@
"clockedout": "",
"committed": "",
"created": "",
- "deleted": ""
+ "deleted": "",
+ "payall": ""
},
"validation": {
"clockoffmustbeafterclockon": "",
diff --git a/client/src/translations/fr/common.json b/client/src/translations/fr/common.json
index 99bbc2254..aaa786ee7 100644
--- a/client/src/translations/fr/common.json
+++ b/client/src/translations/fr/common.json
@@ -2755,6 +2755,7 @@
"deleting": "",
"noemployeeforuser": "",
"noemployeeforuser_sub": "",
+ "payall": "",
"shiftalreadyclockedon": ""
},
"fields": {
@@ -2805,7 +2806,8 @@
"clockedout": "",
"committed": "",
"created": "",
- "deleted": ""
+ "deleted": "",
+ "payall": ""
},
"validation": {
"clockoffmustbeafterclockon": "",
diff --git a/server/payroll/pay-all.js b/server/payroll/pay-all.js
index 81f8ff9d5..935c7d566 100644
--- a/server/payroll/pay-all.js
+++ b/server/payroll/pay-all.js
@@ -32,7 +32,7 @@ exports.payall = async function (req, res) {
const { employeeHash, assignmentHash } = CalculateExpectedHoursForJob(job);
const ticketHash = CalculateTicketsHoursForJob(job);
if (assignmentHash.unassigned > 0) {
- res.json({ success: false, error: "Unassigned hours." });
+ res.json({ success: false, error: "Not all hours have been assigned." });
return;
}
@@ -65,7 +65,7 @@ exports.payall = async function (req, res) {
cost_center:
job.bodyshop.md_responsibility_centers.defaults.costs[key],
flat_rate: true,
- memo: `*SYS-PAY* Add unflagged hours. (${req.user.email})`,
+ memo: `Add unflagged hours. (${req.user.email})`,
});
});
} else {
@@ -83,7 +83,7 @@ exports.payall = async function (req, res) {
job.bodyshop.md_responsibility_centers.defaults.costs[
path.mod_lbr_ty
],
- memo: `*SYS-PAY* Add unflagged hours. (${req.user.email})`,
+ memo: `Add unflagged hours. (${req.user.email})`,
});
}
} else if (diff.op === "update") {
@@ -102,7 +102,7 @@ exports.payall = async function (req, res) {
job.bodyshop.md_responsibility_centers.defaults.costs[
path.mod_lbr_ty
],
- memo: `*SYS-PAY* Adjust flagged hours per assignment. (${req.user.email})`,
+ memo: `Adjust flagged hours per assignment. (${req.user.email})`,
});
} else {
//Has to be a delete
@@ -124,7 +124,7 @@ exports.payall = async function (req, res) {
cost_center:
job.bodyshop.md_responsibility_centers.defaults.costs[key],
flat_rate: true,
- memo: `*SYS-PAY* Remove flagged hours per assignment. (${req.user.email})`,
+ memo: `Remove flagged hours per assignment. (${req.user.email})`,
});
});
} else {
@@ -142,7 +142,7 @@ exports.payall = async function (req, res) {
path.mod_lbr_ty
],
flat_rate: true,
- memo: `*SYS-PAY* Remove flagged hours per assignment. (${req.user.email})`,
+ memo: `Remove flagged hours per assignment. (${req.user.email})`,
});
}
}
@@ -163,10 +163,10 @@ exports.payall = async function (req, res) {
jobid,
{
jobid: jobid,
- error,
+ error: JSON.stringify(error),
}
);
- res.status(503).send();
+ res.status(400).json({ error: error.message });
}
};