+
- {partsStatus.total}
+ {partsStatus.total}
-
- {partsStatus["null"]}
-
+ {partsStatus["null"]}
+
-
- {partsStatus[bodyshop.md_order_statuses.default_bo]}
-
+ {partsStatus[bodyshop.md_order_statuses.default_bo]}
-
- {partsStatus[bodyshop.md_order_statuses.default_ordered]}
-
+ {partsStatus[bodyshop.md_order_statuses.default_ordered]}
-
- {partsStatus[bodyshop.md_order_statuses.default_received]}
-
+ {partsStatus[bodyshop.md_order_statuses.default_received]}
-
- {partsStatus[bodyshop.md_order_statuses.default_returned]}
-
+ {partsStatus[bodyshop.md_order_statuses.default_returned]}
);
diff --git a/client/src/components/job-parts-received/job-parts-received.component.jsx b/client/src/components/job-parts-received/job-parts-received.component.jsx
index 64521fb5f..27ca915b2 100644
--- a/client/src/components/job-parts-received/job-parts-received.component.jsx
+++ b/client/src/components/job-parts-received/job-parts-received.component.jsx
@@ -18,10 +18,17 @@ const mapStateToProps = createStructuredSelector({
* @param parts
* @param displayMode
* @param popoverPlacement
+ * @param countsOnly
* @returns {JSX.Element}
* @constructor
*/
-export function JobPartsReceived({ bodyshop, parts, displayMode = "full", popoverPlacement = "top" }) {
+export function JobPartsReceived({
+ bodyshop,
+ parts,
+ displayMode = "full",
+ popoverPlacement = "top",
+ countsOnly = false
+}) {
const [open, setOpen] = useState(false);
const { t } = useTranslation();
@@ -61,6 +68,8 @@ export function JobPartsReceived({ bodyshop, parts, displayMode = "full", popove
[canOpen]
);
+ if (countsOnly) return
;
+
const displayText =
displayMode === "compact" ? summary.percentLabel : `${summary.percentLabel} (${summary.received}/${summary.total})`;
@@ -99,7 +108,8 @@ JobPartsReceived.propTypes = {
bodyshop: PropTypes.object,
parts: PropTypes.array,
displayMode: PropTypes.oneOf(["full", "compact"]),
- popoverPlacement: PropTypes.string
+ popoverPlacement: PropTypes.string,
+ countsOnly: PropTypes.bool
};
export default connect(mapStateToProps)(JobPartsReceived);
diff --git a/client/src/components/owner-name-display/owner-name-display.component.jsx b/client/src/components/owner-name-display/owner-name-display.component.jsx
index 0b211fbf5..15172bd12 100644
--- a/client/src/components/owner-name-display/owner-name-display.component.jsx
+++ b/client/src/components/owner-name-display/owner-name-display.component.jsx
@@ -2,6 +2,7 @@ import { connect } from "react-redux";
import { createStructuredSelector } from "reselect";
import { store } from "../../redux/store";
import { selectBodyshop } from "../../redux/user/user.selectors";
+import { Tooltip } from "antd";
const mapStateToProps = createStructuredSelector({
bodyshop: selectBodyshop
@@ -11,15 +12,23 @@ const mapDispatchToProps = () => ({
});
export default connect(mapStateToProps, mapDispatchToProps)(OwnerNameDisplay);
-export function OwnerNameDisplay({ bodyshop, ownerObject }) {
+export function OwnerNameDisplay({ bodyshop, ownerObject, withToolTip = false }) {
const emptyTest = ownerObject?.ownr_fn + ownerObject?.ownr_ln + ownerObject?.ownr_co_nm;
if (!emptyTest || emptyTest === "null" || emptyTest.trim() === "") return "N/A";
- if (bodyshop.last_name_first)
- return `${ownerObject?.ownr_ln || ""}, ${ownerObject?.ownr_fn || ""} ${ownerObject?.ownr_co_nm || ""}`.trim();
-
- return `${ownerObject?.ownr_fn || ""} ${ownerObject?.ownr_ln || ""} ${ownerObject.ownr_co_nm || ""}`.trim();
+ let returnString;
+ if (bodyshop.last_name_first) {
+ returnString =
+ `${ownerObject?.ownr_ln || ""}, ${ownerObject?.ownr_fn || ""} ${ownerObject?.ownr_co_nm || ""}`.trim();
+ } else {
+ return `${ownerObject?.ownr_fn || ""} ${ownerObject?.ownr_ln || ""} ${ownerObject.ownr_co_nm || ""}`.trim();
+ }
+ if (withToolTip) {
+ return
{returnString};
+ } else {
+ return returnString;
+ }
}
export function OwnerNameDisplayFunction(ownerObject, forceFirstLast = false) {
diff --git a/client/src/components/parts-queue-list/parts-queue.list.component.jsx b/client/src/components/parts-queue-list/parts-queue.list.component.jsx
index 6459d7a96..766ff9564 100644
--- a/client/src/components/parts-queue-list/parts-queue.list.component.jsx
+++ b/client/src/components/parts-queue-list/parts-queue.list.component.jsx
@@ -1,6 +1,6 @@
import { SyncOutlined } from "@ant-design/icons";
import { useQuery } from "@apollo/client/react";
-import { Button, Card, Input, Space, Table } from "antd";
+import { Button, Card, Checkbox, Input, Space, Table } from "antd";
import _ from "lodash";
import queryString from "query-string";
import { useState } from "react";
@@ -31,6 +31,8 @@ export function PartsQueueListComponent({ bodyshop }) {
const { selected, sortcolumn, sortorder, statusFilters } = searchParams;
const history = useNavigate();
const [filter, setFilter] = useLocalStorage("filter_parts_queue", null);
+ const [viewTimeStamp, setViewTimeStamp] = useLocalStorage("parts_queue_timestamps", false);
+ const [countsOnly, setCountsOnly] = useLocalStorage("parts_queue_counts_only", false);
const { loading, error, data, refetch } = useQuery(QUERY_PARTS_QUEUE, {
fetchPolicy: "network-only",
@@ -92,6 +94,7 @@ export function PartsQueueListComponent({ bodyshop }) {
title: t("jobs.fields.ro_number"),
dataIndex: "ro_number",
key: "ro_number",
+ width: "110px",
sorter: (a, b) => alphaSort(a.ro_number, b.ro_number),
sortOrder: sortcolumn === "ro_number" && sortorder,
@@ -103,16 +106,20 @@ export function PartsQueueListComponent({ bodyshop }) {
title: t("jobs.fields.owner"),
dataIndex: "ownr_ln",
key: "ownr_ln",
+ width: "8%",
+ ellipsis: {
+ showTitle: true
+ },
sorter: (a, b) => alphaSort(OwnerNameDisplayFunction(a), OwnerNameDisplayFunction(b)),
sortOrder: sortcolumn === "ownr_ln" && sortorder,
render: (text, record) => {
return record.ownerid ? (
-
+
) : (
-
+
);
}
@@ -187,7 +194,7 @@ export function PartsQueueListComponent({ bodyshop }) {
ellipsis: true,
sorter: (a, b) => dateSort(a.scheduled_in, b.scheduled_in),
sortOrder: sortcolumn === "scheduled_in" && sortorder,
- render: (text, record) =>
{record.scheduled_in}
+ render: (text, record) =>
{record.scheduled_in}
},
{
title: t("jobs.fields.scheduled_completion"),
@@ -196,7 +203,9 @@ export function PartsQueueListComponent({ bodyshop }) {
ellipsis: true,
sorter: (a, b) => dateSort(a.scheduled_completion, b.scheduled_completion),
sortOrder: sortcolumn === "scheduled_completion" && sortorder,
- render: (text, record) =>
{record.scheduled_completion}
+ render: (text, record) => (
+
{record.scheduled_completion}
+ )
},
// {
// title: t("vehicles.fields.plate_no"),
@@ -227,16 +236,23 @@ export function PartsQueueListComponent({ bodyshop }) {
title: t("jobs.fields.updated_at"),
dataIndex: "updated_at",
key: "updated_at",
+ width: "110px",
sorter: (a, b) => dateSort(a.updated_at, b.updated_at),
sortOrder: sortcolumn === "updated_at" && sortorder,
- render: (text, record) =>
{record.updated_at}
+ render: (text, record) =>
{record.updated_at}
},
{
title: t("jobs.fields.partsstatus"),
dataIndex: "partsstatus",
key: "partsstatus",
+ width: countsOnly ? "180px" : "110px",
render: (text, record) => (
-
+
)
},
{
@@ -249,6 +265,7 @@ export function PartsQueueListComponent({ bodyshop }) {
title: t("jobs.fields.queued_for_parts"),
dataIndex: "queued_for_parts",
key: "queued_for_parts",
+ width: "120px",
sorter: (a, b) => a.queued_for_parts - b.queued_for_parts,
sortOrder: sortcolumn === "queued_for_parts" && sortorder,
filteredValue: filter?.queued_for_parts || null,
@@ -275,6 +292,12 @@ export function PartsQueueListComponent({ bodyshop }) {
+
setCountsOnly(e.target.checked)}>
+ {t("parts.labels.view_counts_only")}
+
+
setViewTimeStamp(e.target.checked)}>
+ {t("parts.labels.view_timestamps")}
+
{
diff --git a/client/src/translations/en_us/common.json b/client/src/translations/en_us/common.json
index c95876666..8d44f02f1 100644
--- a/client/src/translations/en_us/common.json
+++ b/client/src/translations/en_us/common.json
@@ -48,6 +48,7 @@
"arrivedon": "Arrived on: ",
"arrivingjobs": "Arriving Jobs",
"blocked": "Blocked",
+ "bp": "B/P",
"cancelledappointment": "Canceled appointment for: ",
"completingjobs": "Completing Jobs",
"dataconsistency": "<0>{{ro_number}}0> has a data consistency issue. It may have been excluded for scheduling purposes. CODE: {{code}}.",
@@ -59,18 +60,17 @@
"noarrivingjobs": "No Jobs are arriving.",
"nocompletingjobs": "No Jobs scheduled for completion.",
"nodateselected": "No date has been selected.",
+ "owner": "Owner",
"priorappointments": "Previous Appointments",
"reminder": "This is {{shopname}} reminding you about an appointment on {{date}} at {{time}}. Please let us know if you are not able to make the appointment. We look forward to seeing you soon. ",
+ "ro_number": "RO #",
+ "scheduled_completion": "Scheduled Completion",
"scheduledfor": "Scheduled appointment for: ",
"severalerrorsfound": "Several Jobs have issues which may prevent accurate smart scheduling. Click to expand.",
"smartscheduling": "Smart Scheduling",
"smspaymentreminder": "This is {{shopname}} reminding you about your remaining balance of {{amount}}. To pay for the said balance click the link {{payment_link}}.",
"suggesteddates": "Suggested Dates",
- "ro_number": "RO #",
- "owner": "Owner",
- "vehicle": "Vehicle",
- "bp": "B/P",
- "scheduled_completion": "Scheduled Completion"
+ "vehicle": "Vehicle"
},
"successes": {
"canceled": "Appointment canceled successfully.",
@@ -90,6 +90,11 @@
"actions": "Actions"
}
},
+ "audio": {
+ "manager": {
+ "description": "Click anywhere to enable the message ding."
+ }
+ },
"audit": {
"fields": {
"cc": "CC",
@@ -149,11 +154,6 @@
"tasks_updated": "Task '{{title}}' updated by {{updatedBy}}"
}
},
- "audio": {
- "manager": {
- "description": "Click anywhere to enable the message ding."
- }
- },
"billlines": {
"actions": {
"newline": "New Line"
@@ -281,9 +281,9 @@
},
"errors": {
"creatingdefaultview": "Error creating default view.",
+ "duplicate_insurance_company": "Duplicate insurance company name. Each insurance company name must be unique",
"loading": "Unable to load shop details. Please call technical support.",
- "saving": "Error encountered while saving. {{message}}",
- "duplicate_insurance_company": "Duplicate insurance company name. Each insurance company name must be unique"
+ "saving": "Error encountered while saving. {{message}}"
},
"fields": {
"ReceivableCustomField": "QBO Receivable Custom Field {{number}}",
@@ -564,21 +564,18 @@
"responsibilitycenter_tax_tier": "Tax {{typeNum}} Tier {{typeNumIterator}}",
"responsibilitycenter_tax_type": "Tax {{typeNum}} Type",
"responsibilitycenters": {
- "gogcode": "GOG Code (BreakOut)",
- "item_type": "Item Type",
- "item_type_gog": "GOG",
- "item_type_paint": "Paint Materials",
- "item_type_freight": "Freight",
- "taxable_flag": "Taxable?",
- "taxable": "Taxable",
- "nontaxable": "Non-taxable",
"ap": "Accounts Payable",
"ar": "Accounts Receivable",
"ats": "ATS",
"federal_tax": "Federal Tax",
"federal_tax_itc": "Federal Tax Credit",
+ "gogcode": "GOG Code (BreakOut)",
"gst_override": "GST Override Account #",
"invoiceexemptcode": "QuickBooks US - Invoice Tax Exempt Code",
+ "item_type": "Item Type",
+ "item_type_freight": "Freight",
+ "item_type_gog": "GOG",
+ "item_type_paint": "Paint Materials",
"itemexemptcode": "QuickBooks US - Line Item Tax Exempt Code",
"la1": "LA1",
"la2": "LA2",
@@ -597,6 +594,7 @@
"local_tax": "Local Tax",
"mapa": "Paint Materials",
"mash": "Shop Materials",
+ "nontaxable": "Non-taxable",
"paa": "Aftermarket",
"pac": "Chrome",
"pag": "Glass",
@@ -617,6 +615,8 @@
"state": "State Tax Applies"
},
"state_tax": "State Tax",
+ "taxable": "Taxable",
+ "taxable_flag": "Taxable?",
"tow": "Towing"
},
"schedule_end_time": "Schedule Ending Time",
@@ -678,8 +678,6 @@
"zip_post": "Zip/Postal Code"
},
"labels": {
- "parts_shop_management": "Shop Management",
- "parts_vendor_management": "Vendor Management",
"2tiername": "Name => RO",
"2tiersetup": "2 Tier Setup",
"2tiersource": "Source => RO",
@@ -702,11 +700,11 @@
"payers": "Payers"
},
"cdk_dealerid": "CDK Dealer ID",
- "rr_dealerid": "Reynolds Store Number",
"costsmapping": "Costs Mapping",
"dms_allocations": "DMS Allocations",
"pbs_serialnumber": "PBS Serial Number",
"profitsmapping": "Profits Mapping",
+ "rr_dealerid": "Reynolds Store Number",
"title": "DMS"
},
"emaillater": "Email Later",
@@ -733,6 +731,8 @@
"followers": "Notifications"
},
"orderstatuses": "Order Statuses",
+ "parts_shop_management": "Shop Management",
+ "parts_vendor_management": "Vendor Management",
"partslocations": "Parts Locations",
"partsscan": "Parts Scanning",
"printlater": "Print Later",
@@ -1228,8 +1228,6 @@
},
"general": {
"actions": {
- "select": "Select",
- "optional": "Optional",
"add": "Add",
"autoupdate": "{{app}} will automatically update in {{time}} seconds. Please save all changes.",
"calculate": "Calculate",
@@ -1249,6 +1247,7 @@
"login": "Login",
"next": "Next",
"ok": "Ok",
+ "optional": "Optional",
"previous": "Previous",
"print": "Print",
"refresh": "Refresh",
@@ -1259,6 +1258,7 @@
"save": "Save",
"saveandnew": "Save and New",
"saveas": "Save As",
+ "select": "Select",
"selectall": "Select All",
"send": "Send",
"sendbysms": "Send by SMS",
@@ -1288,8 +1288,6 @@
"vehicle": "Vehicle"
},
"labels": {
- "selected": "Selected",
- "settings": "Settings",
"actions": "Actions",
"areyousure": "Are you sure?",
"barcode": "Barcode",
@@ -1343,8 +1341,10 @@
"search": "Search...",
"searchresults": "Results for {{search}}",
"selectdate": "Select date...",
+ "selected": "Selected",
"sendagain": "Send Again",
"sendby": "Send By",
+ "settings": "Settings",
"signin": "Sign In",
"sms": "SMS",
"status": "Status",
@@ -1587,13 +1587,13 @@
"labels": {
"adjustmenttobeadded": "Adjustment to be added: {{adjustment}}",
"billref": "Latest Bill",
+ "bulk_location_help": "This will set the same location on all selected lines.",
"convertedtolabor": "This line has been converted to labor. Ensure you adjust the profit center for the amount accordingly.",
"edit": "Edit Line",
"ioucreated": "IOU",
"new": "New Line",
"nostatus": "No Status",
- "presets": "Jobline Presets",
- "bulk_location_help": "This will set the same location on all selected lines."
+ "presets": "Jobline Presets"
},
"successes": {
"created": "Job line created successfully.",
@@ -1701,9 +1701,9 @@
"actual_delivery": "Actual Delivery",
"actual_in": "Actual In",
"acv_amount": "ACV Amount",
- "admin_clerk": "Admin Clerk",
"adjustment_bottom_line": "Adjustments",
"adjustmenthours": "Adjustment Hours",
+ "admin_clerk": "Admin Clerk",
"alt_transport": "Alt. Trans.",
"area_of_damage_impact": {
"10": "Left Front Side",
@@ -1784,9 +1784,8 @@
"ded_status": "Deductible Status",
"depreciation_taxes": "Betterment/Depreciation/Taxes",
"dms": {
- "first_name": "First Name",
- "last_name": "Last Name",
"address": "Customer Address",
+ "advisor": "Advisor #",
"amount": "Amount",
"center": "Center",
"control_type": {
@@ -1799,12 +1798,13 @@
"dms_model_override": "Override DMS Make/Model",
"dms_unsold": "New, Unsold Vehicle",
"dms_wip_acctnumber": "Cost WIP DMS Acct #",
+ "first_name": "First Name",
"id": "DMS ID",
"inservicedate": "In Service Date",
"journal": "Journal #",
- "make_override": "Make Override",
- "advisor": "Advisor #",
+ "last_name": "Last Name",
"lines": "Posting Lines",
+ "make_override": "Make Override",
"name1": "Customer Name",
"payer": {
"amount": "Amount",
@@ -1945,7 +1945,7 @@
"amount": "Amount",
"name": "Name"
},
- "queued_for_parts": "Queued for Parts",
+ "queued_for_parts": "Queued",
"rate_ats": "ATS Rate",
"rate_ats_flat": "ATS Flat Rate",
"rate_la1": "LA1",
@@ -2447,6 +2447,7 @@
"labels": {
"addlabel": "Add a label to this conversation.",
"archive": "Archive",
+ "mark_unread": "Mark as unread",
"maxtenimages": "You can only select up to a maximum of 10 images at a time.",
"messaging": "Messaging",
"no_consent": "Opted-out",
@@ -2459,8 +2460,7 @@
"selectmedia": "Select Media",
"sentby": "Sent by {{by}} at {{time}}",
"typeamessage": "Send a message...",
- "unarchive": "Unarchive",
- "mark_unread": "Mark as unread"
+ "unarchive": "Unarchive"
},
"render": {
"conversation_list": "Conversation List"
@@ -2614,20 +2614,20 @@
"name": "Owner Details"
},
"labels": {
+ "cell": "Cell",
"create_new": "Create a new owner record.",
"deleteconfirm": "Are you sure you want to delete this owner? This cannot be undone.",
+ "email": "Email",
"existing_owners": "Existing Owners",
"fromclaim": "Current Claim",
"fromowner": "Historical Owner Record",
- "relatedjobs": "Related Jobs",
- "updateowner": "Update Owner",
- "work": "Work",
"home": "Home",
- "cell": "Cell",
"other": "Other",
- "email": "Email",
"phone": "Phone",
- "sms": "SMS"
+ "relatedjobs": "Related Jobs",
+ "sms": "SMS",
+ "updateowner": "Update Owner",
+ "work": "Work"
},
"successes": {
"delete": "Owner deleted successfully.",
@@ -2638,6 +2638,10 @@
"actions": {
"order": "Order Parts",
"orderinhouse": "Order as In House"
+ },
+ "labels": {
+ "view_counts_only": "View Parts Counts Only",
+ "view_timestamps": "Show timestamps"
}
},
"parts_dispatch": {
@@ -2987,8 +2991,6 @@
"settings": "Error saving board settings: {{error}}"
},
"labels": {
- "click_for_statuses": "Click to view parts statuses",
- "partsreceived": "Parts Received",
"actual_in": "Actual In",
"addnewprofile": "Add New Profile",
"alert": "Alert",
@@ -3007,6 +3009,7 @@
"card_size": "Card Size",
"cardcolor": "Colored Cards",
"cardsettings": "Card Settings",
+ "click_for_statuses": "Click to view parts statuses",
"clm_no": "Claim Number",
"comment": "Comment",
"compact": "Compact Cards",
@@ -3027,6 +3030,7 @@
"orientation": "Board Orientation",
"ownr_nm": "Customer Name",
"paintpriority": "P/P",
+ "partsreceived": "Parts Received",
"partsstatus": "Parts Status",
"production_note": "Production Note",
"refinishhours": "R",
@@ -3573,17 +3577,12 @@
}
},
"titles": {
- "parts_settings": "Parts Management Settings | {{app}}",
- "simplified-parts-jobs": "Parts Management | {{app}}",
"accounting-payables": "Payables | {{app}}",
"accounting-payments": "Payments | {{app}}",
"accounting-receivables": "Receivables | {{app}}",
"all_tasks": "All Tasks | {{app}}",
"app": "",
"bc": {
- "simplified-parts-jobs": "Jobs",
- "parts": "Parts",
- "parts_settings": "Settings",
"accounting-payables": "Payables",
"accounting-payments": "Payments",
"accounting-receivables": "Receivables",
@@ -3615,7 +3614,9 @@
"my_tasks": "My Tasks",
"owner-detail": "{{name}}",
"owners": "Owners",
+ "parts": "Parts",
"parts-queue": "Parts Queue",
+ "parts_settings": "Settings",
"payments-all": "All Payments",
"phonebook": "Phonebook",
"productionboard": "Production Board - Visual",
@@ -3627,6 +3628,7 @@
"shop-csi": "CSI Responses",
"shop-templates": "Shop Templates",
"shop-vendors": "Vendors",
+ "simplified-parts-jobs": "Jobs",
"tasks": "Tasks",
"temporarydocs": "Temporary Documents",
"timetickets": "Time Tickets",
@@ -3662,7 +3664,9 @@
"my_tasks": "My Tasks | {{app}}",
"owners": "All Owners | {{app}}",
"owners-detail": "{{name}} | {{app}}",
+ "parts": "",
"parts-queue": "Parts Queue | {{app}}",
+ "parts_settings": "Parts Management Settings | {{app}}",
"payments-all": "Payments | {{app}}",
"phonebook": "Phonebook | {{app}}",
"productionboard": "Production Board - Visual | {{app}}",
@@ -3678,6 +3682,7 @@
"shop-csi": "CSI Responses | {{app}}",
"shop-templates": "Shop Templates | {{app}}",
"shop_vendors": "Vendors | {{app}}",
+ "simplified-parts-jobs": "Parts Management | {{app}}",
"tasks": "Tasks",
"techconsole": "Technician Console | {{app}}",
"techjobclock": "Technician Job Clock | {{app}}",
@@ -3838,10 +3843,10 @@
"user": {
"actions": {
"changepassword": "Change Password",
- "signout": "Sign Out",
- "updateprofile": "Update Profile",
+ "dark_theme": "Switch to Dark Theme",
"light_theme": "Switch to Light Theme",
- "dark_theme": "Switch to Dark Theme"
+ "signout": "Sign Out",
+ "updateprofile": "Update Profile"
},
"errors": {
"updating": "Error updating user or association {{message}}"
@@ -3855,14 +3860,14 @@
"labels": {
"actions": "Actions",
"changepassword": "Change Password",
- "profileinfo": "Profile Info",
- "user_settings": "User Settings",
- "play_sound_for_new_messages": "Play a sound for new messages",
- "notification_sound_on": "Sound is ON",
- "notification_sound_off": "Sound is OFF",
- "notification_sound_enabled": "Notification sound enabled",
"notification_sound_disabled": "Notification sound disabled",
- "notification_sound_help": "Toggle the ding for incoming chat messages."
+ "notification_sound_enabled": "Notification sound enabled",
+ "notification_sound_help": "Toggle the ding for incoming chat messages.",
+ "notification_sound_off": "Sound is OFF",
+ "notification_sound_on": "Sound is ON",
+ "play_sound_for_new_messages": "Play a sound for new messages",
+ "profileinfo": "Profile Info",
+ "user_settings": "User Settings"
},
"successess": {
"passwordchanged": "Password changed successfully. "
diff --git a/client/src/translations/es/common.json b/client/src/translations/es/common.json
index 70cd2b5da..d91462672 100644
--- a/client/src/translations/es/common.json
+++ b/client/src/translations/es/common.json
@@ -48,6 +48,7 @@
"arrivedon": "Llegado el:",
"arrivingjobs": "",
"blocked": "",
+ "bp": "",
"cancelledappointment": "Cita cancelada para:",
"completingjobs": "",
"dataconsistency": "",
@@ -59,18 +60,17 @@
"noarrivingjobs": "",
"nocompletingjobs": "",
"nodateselected": "No se ha seleccionado ninguna fecha.",
+ "owner": "",
"priorappointments": "Nombramientos previos",
"reminder": "",
+ "ro_number": "",
+ "scheduled_completion": "",
"scheduledfor": "Cita programada para:",
"severalerrorsfound": "",
"smartscheduling": "",
"smspaymentreminder": "",
"suggesteddates": "",
- "ro_number": "",
- "owner": "",
- "vehicle": "",
- "bp": "",
- "scheduled_completion": ""
+ "vehicle": ""
},
"successes": {
"canceled": "Cita cancelada con éxito.",
@@ -90,6 +90,11 @@
"actions": "Comportamiento"
}
},
+ "audio": {
+ "manager": {
+ "description": ""
+ }
+ },
"audit": {
"fields": {
"cc": "",
@@ -149,11 +154,6 @@
"tasks_updated": ""
}
},
- "audio": {
- "manager": {
- "description": ""
- }
- },
"billlines": {
"actions": {
"newline": ""
@@ -281,9 +281,9 @@
},
"errors": {
"creatingdefaultview": "",
+ "duplicate_insurance_company": "",
"loading": "No se pueden cargar los detalles de la tienda. Por favor llame al soporte técnico.",
- "saving": "",
- "duplicate_insurance_company": ""
+ "saving": ""
},
"fields": {
"ReceivableCustomField": "",
@@ -564,21 +564,18 @@
"responsibilitycenter_tax_tier": "",
"responsibilitycenter_tax_type": "",
"responsibilitycenters": {
- "gogcode": "",
- "item_type": "Item Type",
- "item_type_gog": "",
- "item_type_paint": "",
- "item_type_freight": "",
- "taxable_flag": "",
- "taxable": "",
- "nontaxable": "",
"ap": "",
"ar": "",
"ats": "",
"federal_tax": "",
"federal_tax_itc": "",
+ "gogcode": "",
"gst_override": "",
"invoiceexemptcode": "",
+ "item_type": "Item Type",
+ "item_type_freight": "",
+ "item_type_gog": "",
+ "item_type_paint": "",
"itemexemptcode": "",
"la1": "",
"la2": "",
@@ -597,6 +594,7 @@
"local_tax": "",
"mapa": "",
"mash": "",
+ "nontaxable": "",
"paa": "",
"pac": "",
"pag": "",
@@ -617,6 +615,8 @@
"state": ""
},
"state_tax": "",
+ "taxable": "",
+ "taxable_flag": "",
"tow": ""
},
"schedule_end_time": "",
@@ -678,8 +678,6 @@
"zip_post": ""
},
"labels": {
- "parts_shop_management": "",
- "parts_vendor_management": "",
"2tiername": "",
"2tiersetup": "",
"2tiersource": "",
@@ -702,11 +700,11 @@
"payers": ""
},
"cdk_dealerid": "",
- "rr_dealerid": "",
"costsmapping": "",
"dms_allocations": "",
"pbs_serialnumber": "",
"profitsmapping": "",
+ "rr_dealerid": "",
"title": ""
},
"emaillater": "",
@@ -733,6 +731,8 @@
"followers": ""
},
"orderstatuses": "",
+ "parts_shop_management": "",
+ "parts_vendor_management": "",
"partslocations": "",
"partsscan": "",
"printlater": "",
@@ -1247,6 +1247,7 @@
"login": "",
"next": "",
"ok": "",
+ "optional": "",
"previous": "",
"print": "",
"refresh": "",
@@ -1257,6 +1258,7 @@
"save": "Salvar",
"saveandnew": "",
"saveas": "",
+ "select": "",
"selectall": "",
"send": "",
"sendbysms": "",
@@ -1286,9 +1288,7 @@
"vehicle": ""
},
"labels": {
- "selected": "",
"actions": "Comportamiento",
- "settings": "",
"areyousure": "",
"barcode": "código de barras",
"cancel": "",
@@ -1341,8 +1341,10 @@
"search": "Buscar...",
"searchresults": "",
"selectdate": "",
+ "selected": "",
"sendagain": "",
"sendby": "",
+ "settings": "",
"signin": "",
"sms": "",
"status": "",
@@ -1585,13 +1587,13 @@
"labels": {
"adjustmenttobeadded": "",
"billref": "",
+ "bulk_location_help": "",
"convertedtolabor": "",
"edit": "Línea de edición",
"ioucreated": "",
"new": "Nueva línea",
"nostatus": "",
- "presets": "",
- "bulk_location_help": ""
+ "presets": ""
},
"successes": {
"created": "",
@@ -1700,8 +1702,8 @@
"actual_in": "Real en",
"acv_amount": "",
"adjustment_bottom_line": "Ajustes",
- "admin_clerk": "",
"adjustmenthours": "",
+ "admin_clerk": "",
"alt_transport": "",
"area_of_damage_impact": {
"10": "",
@@ -1782,9 +1784,8 @@
"ded_status": "Estado deducible",
"depreciation_taxes": "Depreciación / Impuestos",
"dms": {
- "first_name": "",
- "last_name": "",
"address": "",
+ "advisor": "",
"amount": "",
"center": "",
"control_type": {
@@ -1795,21 +1796,23 @@
"dms_make": "",
"dms_model": "",
"dms_model_override": "",
- "make_override": "",
- "advisor": "",
"dms_unsold": "",
"dms_wip_acctnumber": "",
+ "first_name": "",
"id": "",
"inservicedate": "",
"journal": "",
+ "last_name": "",
"lines": "",
+ "make_override": "",
"name1": "",
"payer": {
"amount": "",
"control_type": "",
"controlnumber": "",
"dms_acctnumber": "",
- "name": ""
+ "name": "",
+ "payer_type": ""
},
"sale": "",
"sale_dms_acctnumber": "",
@@ -2444,6 +2447,7 @@
"labels": {
"addlabel": "",
"archive": "",
+ "mark_unread": "",
"maxtenimages": "",
"messaging": "Mensajería",
"no_consent": "",
@@ -2456,8 +2460,7 @@
"selectmedia": "",
"sentby": "",
"typeamessage": "Enviar un mensaje...",
- "unarchive": "",
- "mark_unread": ""
+ "unarchive": ""
},
"render": {
"conversation_list": ""
@@ -2611,20 +2614,20 @@
"name": ""
},
"labels": {
+ "cell": "",
"create_new": "Crea un nuevo registro de propietario.",
"deleteconfirm": "",
+ "email": "",
"existing_owners": "Propietarios existentes",
"fromclaim": "",
"fromowner": "",
- "relatedjobs": "",
- "updateowner": "",
- "work": "",
"home": "",
- "cell": "",
"other": "",
- "email": "",
"phone": "",
- "sms": ""
+ "relatedjobs": "",
+ "sms": "",
+ "updateowner": "",
+ "work": ""
},
"successes": {
"delete": "",
@@ -2635,6 +2638,10 @@
"actions": {
"order": "Pedido de piezas",
"orderinhouse": ""
+ },
+ "labels": {
+ "view_counts_only": "",
+ "view_timestamps": ""
}
},
"parts_dispatch": {
@@ -2984,8 +2991,6 @@
"settings": ""
},
"labels": {
- "click_for_statuses": "",
- "partsreceived": "",
"actual_in": "",
"addnewprofile": "",
"alert": "",
@@ -3004,6 +3009,7 @@
"card_size": "",
"cardcolor": "",
"cardsettings": "",
+ "click_for_statuses": "",
"clm_no": "",
"comment": "",
"compact": "",
@@ -3024,6 +3030,7 @@
"orientation": "",
"ownr_nm": "",
"paintpriority": "",
+ "partsreceived": "",
"partsstatus": "",
"production_note": "",
"refinishhours": "",
@@ -3570,18 +3577,12 @@
}
},
"titles": {
- "simplified-parts-jobs": "",
- "parts": "",
- "parts_settings": "",
"accounting-payables": "",
"accounting-payments": "",
"accounting-receivables": "",
"all_tasks": "",
"app": "",
"bc": {
- "simplified-parts-jobs": "",
- "parts": "",
- "parts_settings": "",
"accounting-payables": "",
"accounting-payments": "",
"accounting-receivables": "",
@@ -3613,7 +3614,9 @@
"my_tasks": "",
"owner-detail": "",
"owners": "",
+ "parts": "",
"parts-queue": "",
+ "parts_settings": "",
"payments-all": "",
"phonebook": "",
"productionboard": "",
@@ -3625,6 +3628,7 @@
"shop-csi": "",
"shop-templates": "",
"shop-vendors": "",
+ "simplified-parts-jobs": "",
"tasks": "",
"temporarydocs": "",
"timetickets": "",
@@ -3660,7 +3664,9 @@
"my_tasks": "",
"owners": "Todos los propietarios | {{app}}",
"owners-detail": "",
+ "parts": "",
"parts-queue": "",
+ "parts_settings": "",
"payments-all": "",
"phonebook": "",
"productionboard": "",
@@ -3676,6 +3682,7 @@
"shop-csi": "",
"shop-templates": "",
"shop_vendors": "Vendedores | {{app}}",
+ "simplified-parts-jobs": "",
"tasks": "",
"techconsole": "{{app}}",
"techjobclock": "{{app}}",
@@ -3836,10 +3843,10 @@
"user": {
"actions": {
"changepassword": "",
- "signout": "desconectar",
- "updateprofile": "Actualización del perfil",
+ "dark_theme": "",
"light_theme": "",
- "dark_theme": ""
+ "signout": "desconectar",
+ "updateprofile": "Actualización del perfil"
},
"errors": {
"updating": ""
@@ -3853,14 +3860,14 @@
"labels": {
"actions": "",
"changepassword": "",
- "profileinfo": "",
- "user_settings": "",
- "play_sound_for_new_messages": "",
- "notification_sound_on": "",
- "notification_sound_off": "",
- "notification_sound_enabled": "",
"notification_sound_disabled": "",
- "notification_sound_help": ""
+ "notification_sound_enabled": "",
+ "notification_sound_help": "",
+ "notification_sound_off": "",
+ "notification_sound_on": "",
+ "play_sound_for_new_messages": "",
+ "profileinfo": "",
+ "user_settings": ""
},
"successess": {
"passwordchanged": ""
diff --git a/client/src/translations/fr/common.json b/client/src/translations/fr/common.json
index e199a33b2..9542b4b16 100644
--- a/client/src/translations/fr/common.json
+++ b/client/src/translations/fr/common.json
@@ -48,6 +48,7 @@
"arrivedon": "Arrivé le:",
"arrivingjobs": "",
"blocked": "",
+ "bp": "",
"cancelledappointment": "Rendez-vous annulé pour:",
"completingjobs": "",
"dataconsistency": "",
@@ -59,18 +60,17 @@
"noarrivingjobs": "",
"nocompletingjobs": "",
"nodateselected": "Aucune date n'a été sélectionnée.",
+ "owner": "",
"priorappointments": "Rendez-vous précédents",
"reminder": "",
+ "ro_number": "",
+ "scheduled_completion": "",
"scheduledfor": "Rendez-vous prévu pour:",
"severalerrorsfound": "",
"smartscheduling": "",
"smspaymentreminder": "",
"suggesteddates": "",
- "ro_number": "",
- "owner": "",
- "vehicle": "",
- "bp": "",
- "scheduled_completion": ""
+ "vehicle": ""
},
"successes": {
"canceled": "Rendez-vous annulé avec succès.",
@@ -90,6 +90,11 @@
"actions": "actes"
}
},
+ "audio": {
+ "manager": {
+ "description": ""
+ }
+ },
"audit": {
"fields": {
"cc": "",
@@ -149,11 +154,6 @@
"tasks_updated": ""
}
},
- "audio": {
- "manager": {
- "description": ""
- }
- },
"billlines": {
"actions": {
"newline": ""
@@ -281,9 +281,9 @@
},
"errors": {
"creatingdefaultview": "",
+ "duplicate_insurance_company": "",
"loading": "Impossible de charger les détails de la boutique. Veuillez appeler le support technique.",
- "saving": "",
- "duplicate_insurance_company": ""
+ "saving": ""
},
"fields": {
"ReceivableCustomField": "",
@@ -564,21 +564,18 @@
"responsibilitycenter_tax_tier": "",
"responsibilitycenter_tax_type": "",
"responsibilitycenters": {
- "gogcode": "",
- "item_type": "Item Type",
- "item_type_gog": "",
- "item_type_paint": "",
- "item_type_freight": "",
- "taxable_flag": "",
- "taxable": "",
- "nontaxable": "",
"ap": "",
"ar": "",
"ats": "",
"federal_tax": "",
"federal_tax_itc": "",
+ "gogcode": "",
"gst_override": "",
"invoiceexemptcode": "",
+ "item_type": "Item Type",
+ "item_type_freight": "",
+ "item_type_gog": "",
+ "item_type_paint": "",
"itemexemptcode": "",
"la1": "",
"la2": "",
@@ -597,6 +594,7 @@
"local_tax": "",
"mapa": "",
"mash": "",
+ "nontaxable": "",
"paa": "",
"pac": "",
"pag": "",
@@ -617,6 +615,8 @@
"state": ""
},
"state_tax": "",
+ "taxable": "",
+ "taxable_flag": "",
"tow": ""
},
"schedule_end_time": "",
@@ -678,8 +678,6 @@
"zip_post": ""
},
"labels": {
- "parts_shop_management": "",
- "parts_vendor_management": "",
"2tiername": "",
"2tiersetup": "",
"2tiersource": "",
@@ -702,11 +700,11 @@
"payers": ""
},
"cdk_dealerid": "",
- "rr_dealerid": "",
"costsmapping": "",
"dms_allocations": "",
"pbs_serialnumber": "",
"profitsmapping": "",
+ "rr_dealerid": "",
"title": ""
},
"emaillater": "",
@@ -733,6 +731,8 @@
"followers": ""
},
"orderstatuses": "",
+ "parts_shop_management": "",
+ "parts_vendor_management": "",
"partslocations": "",
"partsscan": "",
"printlater": "",
@@ -1247,6 +1247,7 @@
"login": "",
"next": "",
"ok": "",
+ "optional": "",
"previous": "",
"print": "",
"refresh": "",
@@ -1257,6 +1258,7 @@
"save": "sauvegarder",
"saveandnew": "",
"saveas": "",
+ "select": "",
"selectall": "",
"send": "",
"sendbysms": "",
@@ -1286,8 +1288,6 @@
"vehicle": ""
},
"labels": {
- "selected": "",
- "settings": "",
"actions": "actes",
"areyousure": "",
"barcode": "code à barre",
@@ -1341,8 +1341,10 @@
"search": "Chercher...",
"searchresults": "",
"selectdate": "",
+ "selected": "",
"sendagain": "",
"sendby": "",
+ "settings": "",
"signin": "",
"sms": "",
"status": "",
@@ -1585,13 +1587,13 @@
"labels": {
"adjustmenttobeadded": "",
"billref": "",
+ "bulk_location_help": "",
"convertedtolabor": "",
"edit": "Ligne d'édition",
"ioucreated": "",
"new": "Nouvelle ligne",
"nostatus": "",
- "presets": "",
- "bulk_location_help": ""
+ "presets": ""
},
"successes": {
"created": "",
@@ -1699,9 +1701,9 @@
"actual_delivery": "Livraison réelle",
"actual_in": "En réel",
"acv_amount": "",
- "admin_clerk": "",
"adjustment_bottom_line": "Ajustements",
"adjustmenthours": "",
+ "admin_clerk": "",
"alt_transport": "",
"area_of_damage_impact": {
"10": "",
@@ -1782,9 +1784,8 @@
"ded_status": "Statut de franchise",
"depreciation_taxes": "Amortissement / taxes",
"dms": {
- "first_name": "",
- "last_name": "",
"address": "",
+ "advisor": "",
"amount": "",
"center": "",
"control_type": {
@@ -1795,21 +1796,23 @@
"dms_make": "",
"dms_model": "",
"dms_model_override": "",
- "make_override": "",
- "advisor": "",
"dms_unsold": "",
"dms_wip_acctnumber": "",
+ "first_name": "",
"id": "",
"inservicedate": "",
"journal": "",
+ "last_name": "",
"lines": "",
+ "make_override": "",
"name1": "",
"payer": {
"amount": "",
"control_type": "",
"controlnumber": "",
"dms_acctnumber": "",
- "name": ""
+ "name": "",
+ "payer_type": ""
},
"sale": "",
"sale_dms_acctnumber": "",
@@ -2433,7 +2436,6 @@
"actions": {
"link": "",
"new": "",
-
"openchat": ""
},
"errors": {
@@ -2445,6 +2447,7 @@
"labels": {
"addlabel": "",
"archive": "",
+ "mark_unread": "",
"maxtenimages": "",
"messaging": "Messagerie",
"no_consent": "",
@@ -2457,8 +2460,7 @@
"selectmedia": "",
"sentby": "",
"typeamessage": "Envoyer un message...",
- "unarchive": "",
- "mark_unread": ""
+ "unarchive": ""
},
"render": {
"conversation_list": ""
@@ -2612,20 +2614,20 @@
"name": ""
},
"labels": {
+ "cell": "",
"create_new": "Créez un nouvel enregistrement de propriétaire.",
"deleteconfirm": "",
+ "email": "",
"existing_owners": "Propriétaires existants",
"fromclaim": "",
"fromowner": "",
- "relatedjobs": "",
- "updateowner": "",
- "work": "",
"home": "",
- "cell": "",
"other": "",
- "email": "",
"phone": "",
- "sms": ""
+ "relatedjobs": "",
+ "sms": "",
+ "updateowner": "",
+ "work": ""
},
"successes": {
"delete": "",
@@ -2636,6 +2638,10 @@
"actions": {
"order": "Commander des pièces",
"orderinhouse": ""
+ },
+ "labels": {
+ "view_counts_only": "",
+ "view_timestamps": ""
}
},
"parts_dispatch": {
@@ -2985,8 +2991,6 @@
"settings": ""
},
"labels": {
- "click_for_statuses": "",
- "partsreceived": "",
"actual_in": "",
"addnewprofile": "",
"alert": "",
@@ -3005,6 +3009,7 @@
"card_size": "",
"cardcolor": "",
"cardsettings": "",
+ "click_for_statuses": "",
"clm_no": "",
"comment": "",
"compact": "",
@@ -3025,6 +3030,7 @@
"orientation": "",
"ownr_nm": "",
"paintpriority": "",
+ "partsreceived": "",
"partsstatus": "",
"production_note": "",
"refinishhours": "",
@@ -3571,18 +3577,12 @@
}
},
"titles": {
- "simplified-parts-jobs": "",
- "parts": "",
- "parts_settings": "",
"accounting-payables": "",
"accounting-payments": "",
"accounting-receivables": "",
"all_tasks": "",
"app": "",
"bc": {
- "simplified-parts-jobs": "",
- "parts": "",
- "parts_settings": "",
"accounting-payables": "",
"accounting-payments": "",
"accounting-receivables": "",
@@ -3614,7 +3614,9 @@
"my_tasks": "",
"owner-detail": "",
"owners": "",
+ "parts": "",
"parts-queue": "",
+ "parts_settings": "",
"payments-all": "",
"phonebook": "",
"productionboard": "",
@@ -3626,6 +3628,7 @@
"shop-csi": "",
"shop-templates": "",
"shop-vendors": "",
+ "simplified-parts-jobs": "",
"tasks": "",
"temporarydocs": "",
"timetickets": "",
@@ -3661,7 +3664,9 @@
"my_tasks": "",
"owners": "Tous les propriétaires | {{app}}",
"owners-detail": "",
+ "parts": "",
"parts-queue": "",
+ "parts_settings": "",
"payments-all": "",
"phonebook": "",
"productionboard": "",
@@ -3677,6 +3682,7 @@
"shop-csi": "",
"shop-templates": "",
"shop_vendors": "Vendeurs | {{app}}",
+ "simplified-parts-jobs": "",
"tasks": "",
"techconsole": "{{app}}",
"techjobclock": "{{app}}",
@@ -3837,10 +3843,10 @@
"user": {
"actions": {
"changepassword": "",
- "signout": "Déconnexion",
- "updateprofile": "Mettre à jour le profil",
+ "dark_theme": "",
"light_theme": "",
- "dark_theme": ""
+ "signout": "Déconnexion",
+ "updateprofile": "Mettre à jour le profil"
},
"errors": {
"updating": ""
@@ -3854,14 +3860,14 @@
"labels": {
"actions": "",
"changepassword": "",
- "profileinfo": "",
- "user_settings": "",
- "play_sound_for_new_messages": "",
- "notification_sound_on": "",
- "notification_sound_off": "",
- "notification_sound_enabled": "",
"notification_sound_disabled": "",
- "notification_sound_help": ""
+ "notification_sound_enabled": "",
+ "notification_sound_help": "",
+ "notification_sound_off": "",
+ "notification_sound_on": "",
+ "play_sound_for_new_messages": "",
+ "profileinfo": "",
+ "user_settings": ""
},
"successess": {
"passwordchanged": ""
diff --git a/client/src/utils/DateFormatter.jsx b/client/src/utils/DateFormatter.jsx
index 574c1d229..f261a0d6d 100644
--- a/client/src/utils/DateFormatter.jsx
+++ b/client/src/utils/DateFormatter.jsx
@@ -5,8 +5,10 @@ export function DateFormatter(props) {
return props.children ? dayjs(props.children).format(props.includeDay ? "ddd MM/DD/YYYY" : "MM/DD/YYYY") : null;
}
-export function DateTimeFormatter(props) {
- return props.children ? dayjs(props.children).format(props.format ? props.format : "MM/DD/YYYY hh:mm a") : null;
+export function DateTimeFormatter({ hideTime, ...props }) {
+ return props.children
+ ? dayjs(props.children).format(props.format ? props.format : `MM/DD/YYYY${hideTime ? "" : " hh:mm a"}`)
+ : null;
}
export function DateTimeFormatterFunction(date) {
@@ -17,11 +19,11 @@ export function TimeFormatter(props) {
return props.children ? dayjs(props.children).format(props.format ? props.format : "hh:mm a") : null;
}
-export function TimeAgoFormatter(props) {
+export function TimeAgoFormatter({ removeAgoString = false, ...props }) {
const m = dayjs(props.children);
return props.children ? (
-
- {m.fromNow()}
+
+ {m.fromNow(removeAgoString)}
) : null;
}