4583 lines
207 KiB
Plaintext
4583 lines
207 KiB
Plaintext
<%@ Page Title="" Language="C#" MasterPageFile="~/Maintenance/MaintenanceBase.master" AutoEventWireup="true" CodeFile="AddWorkOrder.aspx.cs" Inherits="AddWorkOrder" %>
|
||
|
||
|
||
<asp:Content ID="Content1" ContentPlaceHolderID="head" runat="Server">
|
||
<style type="text/css">
|
||
body {
|
||
min-height: 640px;
|
||
}
|
||
|
||
::-ms-clear, ::-ms-reveal {
|
||
display: none;
|
||
}
|
||
|
||
.dialog-content .dropdown .dropdown-wrapper > .dropdown-header {
|
||
min-height: 22px;
|
||
}
|
||
|
||
.dialog-content .dropdown .dropdown-wrapper > .dropdown-header > .dropdown-text {
|
||
line-height: 22px;
|
||
}
|
||
|
||
.edit-content table {
|
||
border-collapse: collapse;
|
||
width: 100%;
|
||
}
|
||
|
||
.edit-content table td.label {
|
||
width: 200px;
|
||
text-align: right;
|
||
padding-right: 10px;
|
||
line-height: 24px;
|
||
height: 24px;
|
||
vertical-align: middle;
|
||
}
|
||
|
||
.edit-content table td.cont {
|
||
width: 250px;
|
||
}
|
||
|
||
.edit-content table td input[type="text"], .edit-content table td textarea {
|
||
border: 1px solid #a9a9a9;
|
||
width: 240px;
|
||
height: 28px;
|
||
text-indent: 3px;
|
||
box-sizing: border-box;
|
||
border-radius: 2px;
|
||
}
|
||
|
||
.edit-content table td input[type="checkbox"] {
|
||
border: none;
|
||
}
|
||
|
||
.edit-content table td textarea {
|
||
height: 100px;
|
||
resize: none;
|
||
/*max-width: 200px;*/
|
||
}
|
||
|
||
#tab_estimates table td.label,
|
||
#tab_invoices table td.label {
|
||
width: 167px;
|
||
text-align: right;
|
||
padding-right: 10px;
|
||
line-height: 24px;
|
||
height: 24px;
|
||
vertical-align: middle;
|
||
}
|
||
|
||
|
||
#tab_estimates table td input[type="text"], #tab_estimates table td textarea,
|
||
#tab_invoices table td input[type="text"], #tab_invoices table td textarea {
|
||
border: 1px solid #a9a9a9;
|
||
width: 150px;
|
||
height: 28px;
|
||
text-indent: 3px;
|
||
box-sizing: border-box;
|
||
border-radius: 2px;
|
||
}
|
||
|
||
.subtitle {
|
||
margin: 20px 40px 5px 0px;
|
||
font-size: 16px;
|
||
color: gray;
|
||
}
|
||
|
||
.subtitle span {
|
||
margin-left: 10px;
|
||
}
|
||
|
||
.subtitle hr {
|
||
background-color: #d8d8d8;
|
||
border: none;
|
||
height: 1px;
|
||
}
|
||
|
||
#host_main {
|
||
overflow: hidden;
|
||
}
|
||
|
||
#tab_segments table td.label {
|
||
width: 130px;
|
||
vertical-align: top;
|
||
}
|
||
|
||
#tab_segments table td input,
|
||
#tab_segments table td textarea {
|
||
border: 1px solid #a9a9a9;
|
||
width: 320px;
|
||
height: 28px;
|
||
text-indent: 3px;
|
||
box-sizing: border-box;
|
||
border-radius: 2px;
|
||
}
|
||
|
||
#tab_segments table td select {
|
||
width: 324px;
|
||
}
|
||
|
||
#tab_segments table td input[type="checkbox"] {
|
||
border: none;
|
||
width: unset;
|
||
height: unset;
|
||
}
|
||
|
||
#tab_segments table td textarea {
|
||
height: 100px;
|
||
resize: none;
|
||
/*max-width: 200px;*/
|
||
}
|
||
|
||
.segments_table {
|
||
margin-top: 10px;
|
||
line-height: 25px;
|
||
}
|
||
|
||
#popupdialog table td.label {
|
||
width: 130px;
|
||
vertical-align: top;
|
||
}
|
||
|
||
#popupdialog table td input,
|
||
#popupdialog table td textarea {
|
||
border: 1px solid #a9a9a9;
|
||
width: 320px;
|
||
height: 24px;
|
||
text-indent: 3px;
|
||
box-sizing: border-box;
|
||
border-radius: 2px;
|
||
}
|
||
|
||
#popupdialog table td select {
|
||
width: 322px;
|
||
}
|
||
|
||
#popupdialog table td input[type="checkbox"] {
|
||
border: none;
|
||
width: 14px;
|
||
height: 14px;
|
||
}
|
||
|
||
#popupdialog table td textarea {
|
||
height: 100px;
|
||
resize: none;
|
||
/*max-width: 200px;*/
|
||
}
|
||
|
||
.popus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.popus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.estpopus-close,
|
||
.invoice-popup-close,
|
||
.publish-invoice-popup-close,
|
||
.woinvoiceattpopus-close,
|
||
.woinvoicemarkpaidpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.estpopus-close:before,
|
||
.invoice-popup-close::before,
|
||
.publish-invoice-popup-close::before,
|
||
.woinvoiceattpopus-close::before,
|
||
.woinvoicemarkpaidpopus-close::before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.pubestpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.pubestpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.compstatuspopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.compstatuspopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.woattpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.woattpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.woestattpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.woestattpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.alertpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.alertpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.emailpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.emailpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.icemailpopus-close {
|
||
float: right;
|
||
margin-right: 6px;
|
||
cursor: pointer;
|
||
}
|
||
|
||
.icemailpopus-close:before {
|
||
content: '\e600';
|
||
}
|
||
|
||
.workorder_table {
|
||
table-layout: fixed;
|
||
line-height: 30px;
|
||
}
|
||
|
||
.msgdiv {
|
||
border: solid 1px lightgray;
|
||
margin-top: 5px;
|
||
padding-left: 5px;
|
||
padding-right: 10px;
|
||
padding-top: 3px;
|
||
padding-bottom: 3px;
|
||
line-height: 24px;
|
||
white-space: normal;
|
||
word-break: break-word;
|
||
overflow: hidden;
|
||
}
|
||
|
||
.msgtime {
|
||
text-align: right;
|
||
}
|
||
|
||
.txtdiv {
|
||
padding-bottom: 10px;
|
||
}
|
||
|
||
.txttime {
|
||
padding-left: 10px;
|
||
padding-right: 10px;
|
||
margin-bottom: 2px;
|
||
}
|
||
|
||
.txtself {
|
||
white-space: pre-wrap;
|
||
max-width: 240px;
|
||
border-radius: 5px;
|
||
padding-top: 8px;
|
||
padding-bottom: 8px;
|
||
padding-right: 20px;
|
||
padding-left: 20px;
|
||
display: inline-block;
|
||
margin-right: 10px;
|
||
background-color: #9eea6a;
|
||
text-align: left;
|
||
word-break: break-word;
|
||
}
|
||
|
||
.txtother {
|
||
white-space: pre-wrap;
|
||
max-width: 240px;
|
||
border-radius: 5px;
|
||
padding-top: 8px;
|
||
padding-bottom: 8px;
|
||
padding-right: 20px;
|
||
padding-left: 20px;
|
||
display: inline-block;
|
||
margin-left: 10px;
|
||
background-color: white;
|
||
word-break: break-word;
|
||
}
|
||
|
||
#mask_over_bg {
|
||
top: 24px;
|
||
left: 0;
|
||
right: 0;
|
||
bottom: 0;
|
||
position: absolute;
|
||
background: #000;
|
||
opacity: 0.2;
|
||
}
|
||
|
||
.dialog-content table td.label {
|
||
width: 120px;
|
||
vertical-align: middle;
|
||
}
|
||
|
||
.dialog-content table td input[type="text"], .dialog-content table td textarea {
|
||
width: 320px;
|
||
height: 24px;
|
||
box-sizing: border-box;
|
||
border-radius: 2px;
|
||
}
|
||
|
||
.divattp {
|
||
width: 300px;
|
||
margin-right: 10px;
|
||
float: left;
|
||
position: relative;
|
||
}
|
||
|
||
.divatt {
|
||
width: 300px;
|
||
height: 300px;
|
||
margin-top: 5px;
|
||
margin-bottom: 5px;
|
||
margin-right: 10px;
|
||
cursor: pointer;
|
||
border: 1px solid #b0b0b0;
|
||
border-radius: 2px;
|
||
box-shadow: rgba(0, 0, 0, 0.4);
|
||
text-align: center;
|
||
float: left;
|
||
position: relative;
|
||
}
|
||
|
||
.picture {
|
||
max-height: 100%;
|
||
max-width: 100%;
|
||
margin: auto;
|
||
position: absolute;
|
||
top: 0;
|
||
bottom: 0;
|
||
left: 0;
|
||
right: 0;
|
||
}
|
||
|
||
|
||
.download {
|
||
line-height: 300px;
|
||
font-size: 200px;
|
||
margin: 0 auto;
|
||
font-family: 'Fontawesome';
|
||
color: silver;
|
||
}
|
||
|
||
.download::before {
|
||
content: '\f15c';
|
||
}
|
||
|
||
.wolist_download {
|
||
font-size: 60px;
|
||
margin: 0 auto;
|
||
font-family: 'Fontawesome';
|
||
color: silver;
|
||
}
|
||
|
||
.wolist_download::before {
|
||
content: '\f15c';
|
||
}
|
||
|
||
|
||
.file-word::before {
|
||
content: '\f1c2';
|
||
}
|
||
|
||
.file-excel::before {
|
||
content: '\f1c3';
|
||
}
|
||
|
||
.file-ppt::before {
|
||
content: '\f1c4';
|
||
}
|
||
|
||
.file-pdf::before {
|
||
content: '\f1c1';
|
||
}
|
||
|
||
.file-video::before {
|
||
content: '\f1c8';
|
||
}
|
||
|
||
.file-zip::before {
|
||
content: '\f1c6';
|
||
}
|
||
|
||
.file-msg::before {
|
||
content: '\f0e0';
|
||
}
|
||
|
||
|
||
.delete {
|
||
position: absolute;
|
||
vertical-align: top;
|
||
font-size: 20px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
right: 8px;
|
||
}
|
||
|
||
.delete::before {
|
||
content: '\f00d';
|
||
}
|
||
|
||
.attadownload {
|
||
position: absolute;
|
||
vertical-align: top;
|
||
font-size: 16px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
right: 5px;
|
||
bottom: 5px;
|
||
}
|
||
|
||
.attadownload::before {
|
||
content: '\f019';
|
||
}
|
||
|
||
.attaprint {
|
||
position: absolute;
|
||
vertical-align: top;
|
||
font-size: 16px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
right: 30px;
|
||
bottom: 5px;
|
||
}
|
||
|
||
.attaprint::before {
|
||
content: '\f02f';
|
||
}
|
||
|
||
.attaedit {
|
||
font-size: 14px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
padding: 3px;
|
||
}
|
||
|
||
.attaedit::before {
|
||
content: '\f044';
|
||
}
|
||
|
||
.attasave {
|
||
font-size: 18px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
margin-left: 3px;
|
||
}
|
||
|
||
.attasave::before {
|
||
content: '\f00c';
|
||
}
|
||
|
||
|
||
.dialog .dialog-func input {
|
||
width: unset;
|
||
}
|
||
|
||
.noinspection {
|
||
color: #444;
|
||
height: 30px;
|
||
line-height: 30px;
|
||
margin-top: 8px;
|
||
padding-left: 10px;
|
||
padding-right: 10px;
|
||
font-size: 20px;
|
||
font-style: italic;
|
||
}
|
||
|
||
#dialog_estimate table td.label,
|
||
#dialog_invoice table td.label {
|
||
width: 130px;
|
||
}
|
||
|
||
#dialog_estimate table td input[type="text"],
|
||
#dialog_invoice table td input[type="text"] {
|
||
width: 150px;
|
||
}
|
||
|
||
#dialog_estimate table td textarea,
|
||
#dialog_invoice table td textarea {
|
||
width: 450px;
|
||
height: 80px;
|
||
margin-top: 6px;
|
||
}
|
||
|
||
.dropdown {
|
||
width: 240px;
|
||
}
|
||
|
||
.dropdown .dropdown-wrapper {
|
||
border-color: #a9a9a9;
|
||
}
|
||
|
||
.dropdown .dropdown-wrapper > .dropdown-header {
|
||
min-height: 26px;
|
||
}
|
||
|
||
.dropdown .dropdown-wrapper > .dropdown-header > .dropdown-text {
|
||
line-height: 26px;
|
||
}
|
||
|
||
.subtitle .dropdown .dropdown-wrapper > .dropdown-header {
|
||
min-height: 24px;
|
||
}
|
||
|
||
.subtitle .dropdown .dropdown-wrapper > .dropdown-header > .dropdown-text {
|
||
line-height: 22px;
|
||
height: 22px;
|
||
min-height: 22px;
|
||
}
|
||
|
||
.maintenance {
|
||
table-layout: fixed;
|
||
border-bottom: none;
|
||
width: auto;
|
||
min-width: 100%;
|
||
}
|
||
|
||
#pm_tbody {
|
||
}
|
||
|
||
#pm_tbody .tr_noresults {
|
||
font-style: italic;
|
||
}
|
||
|
||
#pm_tbody .tr_noresults:hover {
|
||
background: none;
|
||
}
|
||
|
||
.maintenance tr {
|
||
border-bottom: 1px solid #e6e6e6;
|
||
}
|
||
|
||
.main_table .td_intervals {
|
||
padding: 0 0 0 60px;
|
||
}
|
||
|
||
.main_table .tr_intervals {
|
||
border-bottom: none;
|
||
}
|
||
|
||
.main_table .tr_intervals:hover {
|
||
background: none;
|
||
}
|
||
|
||
.icon {
|
||
float: left;
|
||
font-style: normal;
|
||
width: 20px;
|
||
font-size: 11px;
|
||
height: 16px;
|
||
line-height: 16px;
|
||
}
|
||
|
||
.expand:before {
|
||
content: '\e608';
|
||
}
|
||
|
||
.collapse:before {
|
||
content: '\e607';
|
||
}
|
||
|
||
.dialog_table {
|
||
width: 100%;
|
||
}
|
||
|
||
.dialog_table tr {
|
||
height: 40px;
|
||
}
|
||
|
||
.item_name {
|
||
width: unset;
|
||
font-size: 16px;
|
||
}
|
||
|
||
.wolist_picture {
|
||
width: 60px;
|
||
height: 60px;
|
||
margin: 0 auto;
|
||
}
|
||
|
||
.wolist_icon {
|
||
font-size: 14px;
|
||
font-family: 'Fontawesome';
|
||
color: rgb(123,28,33);
|
||
margin-left: 20px;
|
||
}
|
||
|
||
.wolist_delete::before {
|
||
content: '\f00d';
|
||
}
|
||
|
||
.wolist_attadownload::before {
|
||
content: '\f019';
|
||
}
|
||
|
||
.wolist_attaprint::before {
|
||
content: '\f02f';
|
||
}
|
||
|
||
.divattp input {
|
||
width: 60px;
|
||
border: 1px solid #fff;
|
||
}
|
||
|
||
.divattp input.focused,
|
||
.divattp input:hover {
|
||
border-color: #666;
|
||
}
|
||
|
||
.divattp input:disabled,
|
||
.divattp input:disabled:hover,
|
||
.divattp td input:disabled {
|
||
background: #ddd;
|
||
color: #ddd;
|
||
border-color: #ddd;
|
||
}
|
||
|
||
.inp_name {
|
||
height: 24px;
|
||
}
|
||
|
||
.loading_icon {
|
||
font-family: CalciteWebCoreIcons;
|
||
cursor: default;
|
||
left: 50%;
|
||
top: 48%;
|
||
}
|
||
|
||
.lable_attuploadname {
|
||
color: white;
|
||
max-height: 800px;
|
||
text-align: center;
|
||
line-height: 40px;
|
||
font-size: 16px;
|
||
position: absolute;
|
||
left: 50%;
|
||
top: 50%;
|
||
margin: -50px 0 0 -35px;
|
||
}
|
||
|
||
/*override*/
|
||
.ui-tooltip-content {
|
||
white-space: nowrap !important;
|
||
/*min-width: 160px;*/
|
||
}
|
||
</style>
|
||
|
||
<link href="<%=GetFileUrlWithVersion("../css/tabcontrol.css")%>" rel="stylesheet" />
|
||
<link href="<%=GetFileUrlWithVersion("../css/panel.css")%>" rel="stylesheet" />
|
||
<link href="<%=GetFileUrlWithVersion("css/maintenance.css")%>" rel="stylesheet" />
|
||
<link href="<%=GetFileUrlWithVersion("../css/jquery.datetimepicker.css")%>" rel="stylesheet" />
|
||
<script src="<%=GetFileUrlWithVersion("../Maintenance/js/inputdatactr.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("../js/jquery.datetimepicker.full.js")%>"></script>
|
||
<script src="<%=GetFileUrlWithVersion("../js/editableselect.js")%>"></script>
|
||
<script src="<%=GetFileUrlWithVersion("../js/controls.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/workorderattachments.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/workordersegment.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/workorderalert.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/workordersendemail.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/wocommunication.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("../js/assetselector.js")%>" type="text/javascript"></script>
|
||
<script src="<%=GetFileUrlWithVersion("js/addworkorder.js")%>" type="text/javascript"></script>
|
||
<script type="text/javascript">
|
||
var contacts;
|
||
var alertdata = [];
|
||
|
||
var workorderid = "<%=WorkOrderID %>";
|
||
var machineid = "<%=MachineID %>";
|
||
var workorderdata;
|
||
var customercontacts = [];
|
||
var followers = [];
|
||
var machine = null;
|
||
var alertids = [<%=AlertIDs%>];
|
||
var IsAdvisor =<%=IsAdvisor ?"true":"false"%>;
|
||
var IsAdmin =<%=IsAdmin ?"true":"false"%>;
|
||
var AllowCommunicate =<%=AllowCommunicate ?"true":"false"%>;
|
||
var AllowCustomer =<%=AllowCustomer ?"true":"false"%>;
|
||
var WOReadOnly =<%=WOReadOnly ?"true":"false"%>;
|
||
var CRReadOnly =<%=CRReadOnly ?"true":"false"%>;
|
||
var COMMReadOnly =<%=COMMReadOnly ?"true":"false"%>;
|
||
var AllowReopenWorkorders = <%=AllowReopenWorkorders ?"true":"false"%>;
|
||
var AllowReassignWorkorders = <%=AllowReassignWorkorders ?"true":"false"%>;
|
||
var AllowDeleteAtta = <%=AllowDeleteAtta ?"true":"false"%>;
|
||
var meterType = "<%=MeterType%>";
|
||
var nowDate = new DateFormatter().formatDate(new Date("<%=NowDate%>"), 'm/d/Y');
|
||
var currentdate = "<%=NowDate %>";
|
||
var userdata = [];
|
||
var jobsitedata = [];
|
||
var components = [];
|
||
var segmenttypes = [];
|
||
|
||
var _attachments = [];
|
||
|
||
var wotypedata = [];
|
||
var WorkorderParams;
|
||
|
||
//动态加载列表
|
||
var displayCountPerPage = 100;//每页显示的条数
|
||
var currentShownIndex = -1;//当前显示的索引
|
||
var needRefreshDataOnCancel = false;
|
||
|
||
// communication parameter
|
||
var customer;
|
||
var internal;
|
||
|
||
function worequest(method, param, callback, error) {
|
||
_network.request("Maintenance/AddWorkOrder.aspx", -1, method, param, callback, error || function (e) {
|
||
showAlert(GetTextByKey('P_WO_PAGEERROR', 'An unknown error occurred. Please refresh page.'), GetTextByKey('P_WO_QUERY', 'Query'));
|
||
});
|
||
}
|
||
|
||
function alertrequest(method, param, callback, error) {
|
||
_network.request("Maintenance/AlertsManagement.aspx", -1, method, param, callback, error || function (e) {
|
||
showAlert(GetTextByKey('P_WO_PAGEERROR', 'An unknown error occurred. Please refresh page.'), GetTextByKey('P_WO_QUERY', 'Query'));
|
||
});
|
||
}
|
||
|
||
customerquery = function (method, param, callback, error) {
|
||
_network.request("Maintenance/CustomerRecordManagement.aspx", -1, method, param, callback, error);
|
||
}
|
||
|
||
function showThreeButtonConfirm(msg, title, fyes, fno, fcancel) {
|
||
showmaskbg(true);
|
||
_dialog.showConfirmYesNoCancel(msg, title, function (e) {
|
||
showmaskbg(false);
|
||
if (typeof fyes === 'function') {
|
||
fyes(e);
|
||
}
|
||
}, function (e) {
|
||
showmaskbg(false);
|
||
if (typeof fno === 'function') {
|
||
fno(e);
|
||
}
|
||
}, function (e) {
|
||
showmaskbg(false);
|
||
if (typeof fcancel === 'function') {
|
||
fcancel(e);
|
||
}
|
||
});
|
||
}
|
||
|
||
_dialog.showInvoiceConfirm = function (msg, title, fedit, fcancel, fclose, iniframe, shownote) {
|
||
if (!fclose)
|
||
fclose = fcancel;
|
||
_dialog.showButtonDialog(msg, title, 'question', fclose, [{
|
||
value: GetTextByKey("P_WO_XXX", 'Mark as Customer Visible'),
|
||
func: fcancel
|
||
}, {
|
||
value: GetTextByKey("P_WO_XXX", 'Continue Without Making Visible'),
|
||
func: fedit
|
||
}], iniframe, shownote);
|
||
};
|
||
|
||
function showInvoiceConfirm(msg, title, fcancel, fedit, fclose) {
|
||
if ($("#dialog_invoice").is(":visible")) {
|
||
$("#dialog_invoice .maskbg").show();
|
||
$("#dialog_publish_invoice .maskbg").show();
|
||
}
|
||
else
|
||
showmaskbg(true);
|
||
_dialog.showInvoiceConfirm(msg, title, function (e) {
|
||
if ($("#dialog_invoice").is(":visible")) {
|
||
$("#dialog_invoice .maskbg").hide();
|
||
$("#dialog_publish_invoice .maskbg").hide();
|
||
}
|
||
else
|
||
showmaskbg(false);
|
||
if (typeof fedit === 'function') {
|
||
fedit(e);
|
||
}
|
||
}, function (e) {
|
||
if ($("#dialog_invoice").is(":visible")) {
|
||
$("#dialog_invoice .maskbg").hide();
|
||
$("#dialog_publish_invoice .maskbg").hide();
|
||
}
|
||
else
|
||
showmaskbg(false);
|
||
if (typeof fcancel === 'function') {
|
||
fcancel(e);
|
||
}
|
||
}, function (e) {
|
||
if ($("#dialog_invoice").is(":visible")) {
|
||
$("#dialog_invoice .maskbg").hide();
|
||
$("#dialog_publish_invoice .maskbg").hide();
|
||
}
|
||
else
|
||
showmaskbg(false);
|
||
if (typeof fclose === 'function') {
|
||
fclose(e);
|
||
}
|
||
});
|
||
}
|
||
|
||
function OnAdd() {
|
||
if (machineid === "")
|
||
$("#btnSelectAsset").show();
|
||
else
|
||
$("#btnSelectAsset").hide();
|
||
|
||
meterType = "HourMeter";
|
||
SetWorkOrderDisabled(false);
|
||
}
|
||
|
||
function SetWorkOrderDisabled(di) {
|
||
$('#dialog_wotype').dropdownDisabled(di);
|
||
$('#dialog_partsordernumber').attr('disabled', di);
|
||
$('#dialog_partsstatus').dropdownDisabled(di);
|
||
$('#dialog_wocomponent').dropdownDisabled(di);
|
||
$('#dialog_assignto').dropdownDisabled(di);
|
||
$('#dialog_status').dropdownDisabled(di);
|
||
$('#dialog_nextfollowupdate').attr('disabled', di);
|
||
$('#dialog_duedate').attr('disabled', di);
|
||
$('#dialog_description').attr('disabled', di);
|
||
//$('#dialog_workordercosts').attr('disabled', di);
|
||
$('#dialog_timetocomplete').attr('disabled', di);
|
||
$('#dialog_completeddate').attr('disabled', di);
|
||
$('#dialog_location').dropdownDisabled(di);
|
||
$('#dialog_department').dropdownDisabled(di);
|
||
$('#dialog_advisor').dropdownDisabled(di);
|
||
$('#dialog_salesperson').dropdownDisabled(di);
|
||
$('#dialog_isptemplate').dropdownDisabled(di);
|
||
$('#dialog_internalid').attr('disabled', di);
|
||
$('#dialog_notes').attr('disabled', di);
|
||
$('#dialog_metertype').dropdownDisabled(di);
|
||
$('#dialog_hourmeter').attr('disabled', di);
|
||
$('#dialog_odometer').attr('disabled', di);
|
||
$('#dig_odometeruom').dropdownDisabled(di);
|
||
if (!di)
|
||
setMeterType();
|
||
if (typeof customer !== 'undefined') {
|
||
customer.autoUpdatesEnabled = !di;
|
||
}
|
||
|
||
$('#dialog_partsexpecteddate').attr('disabled', di);
|
||
$('#dialog_lastlabordate').attr('disabled', di);
|
||
$('#dialog_inspectionrequired').attr('disabled', di);
|
||
$('#dialog_alternatestatus').attr('disabled', di);
|
||
$('#dialog_billable').attr('disabled', di);
|
||
$('#dialog_billtojob').dropdownDisabled(di);
|
||
|
||
if (di) {
|
||
$('#btnaddcustomer').hide();
|
||
$('#traddcontact').hide();
|
||
}
|
||
else {
|
||
$('#btnaddcustomer').show();
|
||
$('#traddcontact').show();
|
||
}
|
||
|
||
$('#dialog_custcontactname').attr('disabled', di);
|
||
$('#dialog_custcontactpreference').attr('disabled', di);
|
||
$('#dialog_custemailaddress').attr('disabled', di);
|
||
$('#dialog_custmobile').attr('disabled', di);
|
||
|
||
$('#dialog_othercost').attr('disabled', di);
|
||
$('#dialog_partscost').attr('disabled', di);
|
||
$('#dialog_traveltimecost').attr('disabled', di);
|
||
$('#dialog_invoicenumber').attr('disabled', di);
|
||
}
|
||
|
||
var loading = false;
|
||
function OnEdit() {
|
||
if (!workorderid || workorderid == "") return;
|
||
|
||
if (loading)
|
||
return;
|
||
loading = true;
|
||
|
||
contacts = undefined;
|
||
$("#tdExportReport").hide();
|
||
$("#btnSelectAsset").hide();
|
||
$('#tabAttachments').hide();
|
||
$("#tbAttas").empty();
|
||
$('#tabAssetAttachments').hide();
|
||
$("#tbAssetAttas").empty();
|
||
$('.iconsave').hide();
|
||
if (/*IsAdmin &&*/ AllowCustomer) {
|
||
$("#tdExportReport").show();
|
||
}
|
||
|
||
showloading(true);
|
||
getWorkOrderFollowers(workorderid);
|
||
worequest("GetWorkOrderInfo", workorderid, function (data) {
|
||
showloading(false);
|
||
loading = false;
|
||
if (typeof (data) === "string") {
|
||
showAlert(data, GetTextByKey("P_WO_ERROR", 'Error'));
|
||
return;
|
||
}
|
||
var wo = data;
|
||
if (wo.Id != workorderid) {
|
||
OnEdit();
|
||
return;
|
||
}
|
||
$('.iconsave').show();
|
||
|
||
workorderdata = wo;
|
||
customercontacts = wo.Contacts || [];
|
||
showCustomerContacts(customercontacts);
|
||
//editableSelectMachine.val(wo.AssetID);
|
||
meterType = wo.MeterType;
|
||
$('#dialog_metertype').dropdownVal(meterType);
|
||
setMeterType();
|
||
|
||
machineid = wo.AssetID;
|
||
machine = { Id: wo.AssetID, VIN: wo.VIN, DisplayName: wo.AssetName };
|
||
setMachineInfo(wo);
|
||
getAssetDetailInfo(machineid);
|
||
|
||
var isshowmachine = false;
|
||
if (!IsAdmin && wo.Completed && !AllowReopenWorkorders) {
|
||
SetWorkOrderDisabled(true);
|
||
isshowmachine = true;
|
||
//editableSelectMachine.setEnable(false);
|
||
$("#btnSelectAsset").hide();
|
||
}
|
||
else
|
||
SetWorkOrderDisabled(false);
|
||
|
||
if (wo.Completed) {
|
||
$('#span_addalerts').css('display', 'none');
|
||
$('#span_removealerts').css('display', 'none');
|
||
$('#btnaddpmalerts').css('display', 'none');
|
||
$('.span_required').show();
|
||
}
|
||
else {
|
||
if (!WOReadOnly) {
|
||
$('#span_addalerts').css('display', '');
|
||
$('#span_removealerts').css('display', '');
|
||
$('#btnaddpmalerts').css('display', '');
|
||
$('.span_required').hide();
|
||
}
|
||
}
|
||
|
||
setPageTitle(GetTextByKey("P_WORKORDER", "Work Order") + " " + (wo.WorkOrderNumber === "" ? wo.Id : wo.WorkOrderNumber), true);
|
||
$('#dialog_wonumber').text(wo.WorkOrderNumber === "" ? wo.Id : wo.WorkOrderNumber);
|
||
$('#divwonumber').show();
|
||
$('#dialog_wotype').dropdownVal(wo.WorkOrderType);
|
||
$('#dialog_partsordernumber').val(wo.PartsOrderNumber);
|
||
$('#dialog_partsstatus').dropdownVal(wo.PartsStatus);
|
||
$('#dialog_wocomponent').dropdownVal(wo.Component);
|
||
showContacts();//$('#dialog_assignto').dropdownVal(wo.AssignedTo);
|
||
showWorkOrderStatusSource();//$('#dialog_status').dropdownVal(wo.Status);
|
||
$('#dialog_description').val(wo.Description);
|
||
$('#dialog_nextfollowupdate').val(wo.NextFollowUpDateStr);
|
||
if (new Date(wo.NextFollowUpDateStr) < new Date(currentdate))
|
||
$('#dialog_nextfollowupdate').css("color", "red");
|
||
else
|
||
$('#dialog_nextfollowupdate').css("color", "unset");
|
||
$('#dialog_duedate').val(wo.DueDateStr);
|
||
$('#dialog_completeddate').val(wo.CompleteDateStr);
|
||
$('#dialog_workordercosts').val(wo.WorkOrderTotalCost == 0 ? "" : wo.WorkOrderTotalCost);
|
||
$('#dialog_timetocomplete').val(wo.HoursToComplete == 0 ? "" : wo.HoursToComplete);
|
||
$('#dialog_location').dropdownVal(wo.LocationId);
|
||
$('#dialog_department').dropdownVal(wo.DepartmentId);
|
||
$('#dialog_advisor').dropdownVal(wo.AdvisorId);
|
||
$('#dialog_internalid').val(wo.InternalID);
|
||
$('#dialog_notes').val(wo.Notes);
|
||
$('#dialog_hourmeter').val(wo.HourMeter < 0 ? "" : wo.HourMeter);
|
||
$('#dialog_odometer').val(wo.Odometer < 0 ? "" : wo.Odometer);
|
||
$('#dig_odometeruom').dropdownVal(wo.OdometerUnits);
|
||
$('#dialog_billable').prop('checked', wo.Billable);
|
||
if (!alljobsites) {
|
||
if (wo.BillToJob > 0)
|
||
$('#dialog_billtojob').dropdownSource([{ ID: wo.BillToJob, Name: wo.BillToJobName == "" ? " " : wo.BillToJobName }]).dropdownVal(wo.BillToJob);
|
||
}
|
||
else
|
||
$('#dialog_billtojob').dropdownVal(wo.BillToJob);
|
||
|
||
if (!allsalespersons) {
|
||
if (wo.SalespersonId !== "")
|
||
$('#dialog_salesperson').dropdownSource([{ Key: wo.SalespersonId, Value: wo.SalespersonName == "" ? " " : wo.SalespersonName }]).dropdownVal(wo.SalespersonId);
|
||
}
|
||
else
|
||
$('#dialog_salesperson').dropdownVal(wo.SalespersonId);
|
||
|
||
if (!allisptemplates) {
|
||
if (wo.InspectionTemplateId !== "")
|
||
$('#dialog_isptemplate').dropdownSource([{ Key: wo.InspectionTemplateId, Value: wo.InspectionTemplateName == "" ? " " : wo.InspectionTemplateName }]).dropdownVal(wo.InspectionTemplateId);
|
||
}
|
||
else
|
||
$('#dialog_isptemplate').dropdownVal(wo.InspectionTemplateId);
|
||
|
||
customerid = wo.CustomerId;
|
||
$('#dialog_custcustomername').text(wo.CustomerName);
|
||
$('#dialog_custcustomercode').text(wo.CustomerCode);
|
||
|
||
$('#dialog_othercost').val(wo.OtherCost == 0 ? "" : wo.OtherCost);
|
||
$('#dialog_partscost').val(wo.PartsCost == 0 ? "" : wo.PartsCost);
|
||
$('#dialog_traveltimecost').val(wo.TravelTimeCost == 0 ? "" : wo.TravelTimeCost);
|
||
$('#dialog_laborcost').val(wo.LaborCost == 0 ? "" : wo.LaborCost);
|
||
$('#dialog_hourlyrate').val(wo.HourlyRate == 0 ? "" : wo.HourlyRate);
|
||
$('#dialog_invoicenumber').val(wo.InvoiceNumber);
|
||
if (typeof customer !== 'undefined') {
|
||
customer.companyName = wo.CustomerName;
|
||
customer.companyCode = wo.CustomerCode;
|
||
customer.setData('companyCode', wo.CustomerCode);
|
||
customer.autoUpdates = wo.AutoText;
|
||
}
|
||
$('#dialog_partsexpecteddate').val(wo.PartsExpectedDateStr);
|
||
$('#dialog_lastlabordate').val(wo.LastLaborDateStr);
|
||
$('#dialog_inspectionrequired').prop('checked', wo.InspectionRequired);
|
||
$('#dialog_inspectioncount').text(wo.InspectionCount).css('color', 'unset');
|
||
if (wo.InspectionRequired && wo.InspectionCount > 0 && wo.InspectionTemplateId > 0) {
|
||
$('#dialog_inspectioncount').css('color', wo.RequiredInspectionCompleted ? '#2eda2e' : 'red');
|
||
}
|
||
$('#dialog_alternatestatus').val(wo.AlternateStatus);
|
||
|
||
$('#dialog_location').dropdownVal("" + wo.LocationId);
|
||
$('#dialog_department').dropdownVal("" + wo.DepartmentId);
|
||
|
||
if (AllowCustomer) {
|
||
$('#dialog_estimatestatus').text(getEstimateStatus(wo.EstimateStatus));
|
||
}
|
||
|
||
getLaborCost(false);
|
||
$('#dialog_assignto').dropdownSource([{ value: wo.AssignedTo.toLowerCase(), DisplayName: wo.AssignedTo == "" ? " " : wo.AssignedToName }]).dropdownVal(wo.AssignedTo.toLowerCase());
|
||
$('#dialog_advisor').dropdownSource([{ value: wo.AdvisorId, DisplayName: wo.AdvisorId == "" ? " " : wo.AdvisorName }]).dropdownVal(wo.AdvisorId);
|
||
getWorkOrderTypes();
|
||
getPartsStatuses();
|
||
getComments(true);
|
||
if (AllowCommunicate)
|
||
getCommunications(true);
|
||
|
||
//editableSelectMachine.val(wo.AssetID);
|
||
|
||
if (WOReadOnly || (!IsAdmin && wo.Completed && !AllowReopenWorkorders)) {
|
||
$('.iconsave').css("display", 'none');
|
||
$('#td_attachment input').attr('disabled', true);
|
||
}
|
||
else {
|
||
$('.iconsave').css("display", '');
|
||
$('#td_attachment input').attr('disabled', false);
|
||
}
|
||
|
||
if (IsAdvisor) {
|
||
if (!wo.CommunicationAcknowledged)
|
||
updateCommunicationAcknowledged(workorderid, true);
|
||
if (!wo.EstimateAcknowledged)
|
||
updateEstimateAcknowledged(workorderid, true);
|
||
}
|
||
|
||
}, function (err) {
|
||
loading = false;
|
||
showloading(false);
|
||
});
|
||
}
|
||
|
||
|
||
function setMachineInfo(asset) {
|
||
if (asset) {
|
||
$('#spassignedasset').text("" + (asset.DisplayName || asset.AssetName || asset.Name));
|
||
$('#dialog_vin').text(asset.VIN);
|
||
$('#dialog_make').text("" + (asset.Make || asset.MakeName));
|
||
$('#dialog_model').text("" + (asset.Model || asset.ModelName));
|
||
$('#dialog_type').text("" + (asset.MachineType || asset.TypeName));
|
||
|
||
if (meterType === "") {
|
||
meterType = asset.OnRoad ? "Odometer" : "HourMeter";
|
||
}
|
||
|
||
if (asset.CurrentHours) {
|
||
if (($('#dialog_hourmeter').val() === "" || $('#dialog_hourmeter').val() === "0") && (meterType == "HourMeter" || meterType == "Both")) {
|
||
$('#dialog_hourmeter').val(asset.CurrentHours.Corrected > 0 ? Math.round(asset.CurrentHours.Corrected) : "");
|
||
}
|
||
}
|
||
if (asset.CurrentOdometer) {
|
||
if (($('#dialog_odometer').val() === "" || $('#dialog_odometer').val() === "0") && (meterType == "Odometer" || meterType == "Both")) {
|
||
$('#dialog_odometer').val(asset.CurrentOdometer.Corrected > 0 ? Math.round(asset.CurrentOdometer.Corrected) : "");
|
||
}
|
||
}
|
||
|
||
if (asset.OnRoad) {
|
||
if (asset.CurrentOdometer)
|
||
$("#dialog_codometer").text("" + Math.round(asset.CurrentOdometer.Corrected));
|
||
else
|
||
$("#dialog_codometer").text("");
|
||
$("#trcodometer").show();
|
||
$("#trchours").hide();
|
||
} else {
|
||
if (asset.CurrentHours)
|
||
$("#dialog_chours").text("" + Math.round(asset.CurrentHours.Corrected));
|
||
else
|
||
$("#dialog_chours").text("");
|
||
$("#trcodometer").hide();
|
||
$("#trchours").show();
|
||
}
|
||
|
||
$('#dialog_metertype').dropdownVal(meterType);
|
||
setMeterType();
|
||
}
|
||
else {
|
||
$('#spassignedasset').text(GetTextByKey("P_MD_UNASSIGNED", 'Unassigned')).data("aid", -1);
|
||
$('#dialog_vin').text('');
|
||
$('#dialog_make').text('');
|
||
$('#dialog_model').text('');
|
||
$('#dialog_type').text('');
|
||
}
|
||
}
|
||
|
||
function GetContacts() {
|
||
if (!machineid)
|
||
return;
|
||
var loc = $('#dialog_location').dropdownVal();
|
||
var dep = $('#dialog_department').dropdownVal();
|
||
worequest("GetContacts", JSON.stringify([machineid, loc, dep]), function (data) {
|
||
if (data && data.length > 0) {
|
||
contacts = data;
|
||
showContacts();
|
||
showAdvisors();
|
||
}
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function showContacts() {
|
||
if ((!workorderid && workorderid != "" && !workorderdata) || !contacts) return;
|
||
var exists = false;
|
||
var sel = null;
|
||
if (workorderdata)
|
||
sel = workorderdata.AssignedTo;
|
||
if (!sel || sel == "" || sel == "-1")
|
||
exists = true;
|
||
|
||
var selector = $("#dialog_assignto");
|
||
var selCurrent = selector.val();
|
||
var source = [{ value: '', DisplayName: ' ' }];
|
||
for (var i = 0; i < contacts.length; i++) {
|
||
var kv = contacts[i];
|
||
if (!kv.AssignedWorkOrders) continue;
|
||
kv.value = kv.IID.toLowerCase();
|
||
source.push(kv);
|
||
|
||
if (!exists && sel.toLowerCase() == kv.IID.toLowerCase())
|
||
exists = true;
|
||
}
|
||
if (!exists) {
|
||
source.push({ value: workorderdata.AssignedTo.toLowerCase(), DisplayName: workorderdata.AssignedToName });
|
||
}
|
||
$('#dialog_assignto').dropdownSource(source);
|
||
if (sel && sel != "")
|
||
selector.dropdownVal(sel.toLowerCase());
|
||
else if (selCurrent)
|
||
selector.dropdownVal(selCurrent);
|
||
}
|
||
|
||
function showAdvisors() {//使用contacts的数据
|
||
if ((!workorderid && workorderid != "" && !workorderdata) || !contacts) return;
|
||
var exists = false;
|
||
var sel = null;
|
||
if (workorderdata)
|
||
sel = workorderdata.AdvisorId;
|
||
if (!sel && $.isGuid(sel))
|
||
sel = sel.toLowerCase();
|
||
if (!sel || sel == "" || sel == "-1")
|
||
exists = true;
|
||
|
||
var selector = $("#dialog_advisor");
|
||
var selCurrent = selector.dropdownVal();
|
||
var source = [{ value: '', DisplayName: ' ' }];
|
||
for (var i = 0; i < contacts.length; i++) {
|
||
var kv = contacts[i];
|
||
if (kv.ContactType != 7) continue;
|
||
kv.value = kv.IID.toLowerCase();
|
||
source.push(kv);
|
||
|
||
if (!exists && sel.toLowerCase() == kv.IID.toLowerCase())
|
||
exists = true;
|
||
}
|
||
if (!exists) {
|
||
source.push({ value: workorderdata.AdvisorId, DisplayName: workorderdata.AdvisorName });
|
||
}
|
||
selector.dropdownSource(source);
|
||
if (sel && sel != "")
|
||
selector.dropdownVal(sel);
|
||
else if (selCurrent)
|
||
selector.dropdownVal(selCurrent);
|
||
}
|
||
|
||
function getWorkorderParams() {
|
||
worequest("GetWorkorderParams", null, function (data) {
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
WorkorderParams = data;
|
||
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
var allWorkOrderStatuses = [];
|
||
var completedWorkOrderStatuses = [];
|
||
var uncompletedWorkOrderStatuses = [];
|
||
function getWorkOrderStatuses() {
|
||
worequest("GetWorkOrderStatuses", null, function (data) {
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
|
||
for (var i = 0; i < data.length; i++) {
|
||
var s = data[i];
|
||
allWorkOrderStatuses.push(s);
|
||
if (s.Completed)
|
||
completedWorkOrderStatuses.push(s);
|
||
else
|
||
uncompletedWorkOrderStatuses.push(s);
|
||
}
|
||
showWorkOrderStatusSource();
|
||
$('#dialog_completed_status').dropdownSource(completedWorkOrderStatuses);
|
||
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function showWorkOrderStatusSource() {
|
||
var statuses = allWorkOrderStatuses;
|
||
if (workorderdata && !workorderdata.CanClose)
|
||
statuses = uncompletedWorkOrderStatuses;
|
||
|
||
var source = [{ Id: '-1', Name: ' ' }];
|
||
var defaultOnOpenStatus = "-1";
|
||
var exists = false;
|
||
for (var i = 0; i < statuses.length; i++) {
|
||
var s = statuses[i];
|
||
if (s.DefaultOnOpen)
|
||
defaultOnOpenStatus = s.Id;
|
||
|
||
if (workorderdata && workorderdata.Status == s.Id) {
|
||
exists = true;
|
||
}
|
||
source.push(s);
|
||
}
|
||
|
||
$('#dialog_status').dropdownSource(source);
|
||
if (workorderdata) {
|
||
if (!exists && !isNaN(workorderdata.Status)) {
|
||
source.push({
|
||
Id: workorderdata.Status,
|
||
Name: workorderdata.StatusName,
|
||
Color: workorderdata.StatusColor,
|
||
StatusType: workorderdata.StatusType
|
||
});
|
||
}
|
||
$('#dialog_status').dropdownVal(workorderdata.Status)
|
||
}
|
||
else
|
||
$('#dialog_status').dropdownVal(defaultOnOpenStatus);
|
||
}
|
||
|
||
var workOrderTypes = null;
|
||
function getWorkOrderTypes() {
|
||
if (workOrderTypes != null) {
|
||
if (workorderdata && workOrderTypes.indexOf(workorderdata.WorkOrderType) < 0) {
|
||
workOrderTypes.push(workorderdata.WorkOrderType);
|
||
workOrderTypes.sort();
|
||
var source = [];
|
||
for (var type of workOrderTypes) {
|
||
source.push({ value: type });
|
||
}
|
||
|
||
$('#dialog_wotype').dropdownSource(source);
|
||
}
|
||
return;
|
||
}
|
||
worequest("GetWorkOrderTypes", null, function (data) {
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
workOrderTypes = data;
|
||
|
||
var source = [];
|
||
for (var type of data) {
|
||
source.push({ value: type });
|
||
}
|
||
|
||
$('#dialog_wotype').dropdownSource(source);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_wotype').dropdownVal(workorderdata.WorkOrderType);
|
||
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
var partsStatuses = null;
|
||
function getPartsStatuses() {
|
||
if (partsStatuses != null) {
|
||
if (workorderdata && partsStatuses.indexOf(workorderdata.PartsStatus) < 0) {
|
||
partsStatuses.push(workorderdata.PartsStatus);
|
||
partsStatuses.sort();
|
||
var source = [];
|
||
for (var type of partsStatuses) {
|
||
source.push({ value: type });
|
||
}
|
||
|
||
$('#dialog_partsstatus').dropdownSource(source);
|
||
}
|
||
return;
|
||
}
|
||
worequest("GetPartsStatuses", null, function (data) {
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
partsStatuses = data;
|
||
|
||
var source = [];
|
||
for (var type of data) {
|
||
source.push({ value: type });
|
||
}
|
||
|
||
$('#dialog_partsstatus').dropdownSource(source);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_partsstatus').dropdownVal(workorderdata.PartsStatus);
|
||
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
var allcomponents;
|
||
var londingcomp = false;
|
||
function GetComponents() {
|
||
if (londingcomp) return;
|
||
londingcomp = true;
|
||
worequest("GetComponents", 0, function (data) {
|
||
londingcomp = false;
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
|
||
var source = [];
|
||
for (var type of data) {
|
||
source.push({ value: type });
|
||
}
|
||
allcomponents = source;
|
||
|
||
$('#dialog_wocomponent').dropdownSource(source);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_wocomponent').dropdownVal(workorderdata.Component);
|
||
|
||
}, function (err) {
|
||
londingcomp = false;
|
||
});
|
||
}
|
||
|
||
var alljobsites;
|
||
var londingjobsites = false;
|
||
function GetJobsites() {
|
||
if (londingjobsites) return;
|
||
londingjobsites = true;
|
||
worequest("GetJobsites", null, function (data) {
|
||
londingjobsites = false;
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
data.splice(0, 0, { ID: -1, Name: " " })
|
||
alljobsites = data;
|
||
$('#dialog_billtojob').dropdownSource(data);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_billtojob').dropdownVal(workorderdata.BillToJob);
|
||
|
||
}, function (err) {
|
||
londingjobsites = false;
|
||
});
|
||
}
|
||
|
||
var allsalespersons;
|
||
var londingsalespersons = false;
|
||
function getSalespersons() {
|
||
if (londingsalespersons) return;
|
||
londingsalespersons = true;
|
||
worequest("GetSalespersons", null, function (data) {
|
||
londingsalespersons = false;
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
data.splice(0, 0, { Key: "", Value: " " })
|
||
allsalespersons = data;
|
||
$('#dialog_salesperson').dropdownSource(data);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_salesperson').dropdownVal(workorderdata.SalespersonId);
|
||
|
||
}, function (err) {
|
||
londingsalespersons = false;
|
||
});
|
||
}
|
||
|
||
var allisptemplates;
|
||
var londingisptemplates = false;
|
||
function getInspectionTemplateItems() {
|
||
if (londingisptemplates) return;
|
||
londingisptemplates = true;
|
||
worequest("GetInspectionTemplateItems", null, function (data) {
|
||
londingisptemplates = false;
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
data.splice(0, 0, { Key: "", Value: " " })
|
||
allisptemplates = data;
|
||
$('#dialog_isptemplate').dropdownSource(data);
|
||
|
||
if (workorderdata)
|
||
$('#dialog_isptemplate').dropdownVal(workorderdata.InspectionTemplateId);
|
||
|
||
}, function (err) {
|
||
londingisptemplates = false;
|
||
});
|
||
}
|
||
|
||
|
||
function getLocationsAndDepartments() {
|
||
worequest("GetLocationsAndDepartments", null, function (data) {
|
||
if (!data || typeof (data) === "string") {
|
||
return;
|
||
}
|
||
|
||
var locs = [{ ID: '-1', Name: ' ', html: ' ' }];
|
||
var depts = [{ Id: '-1', Name: ' ', html: ' ' }];
|
||
|
||
if (data.Locations && data.Locations.length > 0) {
|
||
for (var i = 0; i < data.Locations.length; i++) {
|
||
var s = data.Locations[i];
|
||
if (s.PId > 0) {
|
||
s.html = ' ' + s.Name;
|
||
} else {
|
||
s.html = s.Name;
|
||
}
|
||
locs.push(s);
|
||
}
|
||
}
|
||
if (data.Departments && data.Departments.length > 0) {
|
||
for (var i = 0; i < data.Departments.length; i++) {
|
||
var s = data.Departments[i];
|
||
if (s.PId > 0) {
|
||
s.html = ' ' + s.Name;
|
||
} else {
|
||
s.html = s.Name;
|
||
}
|
||
depts.push(s);
|
||
}
|
||
}
|
||
$('#dialog_location').dropdownSource(locs);
|
||
$('#dialog_department').dropdownSource(depts);
|
||
if (workorderdata) {
|
||
$('#dialog_location').dropdownVal(workorderdata.LocationId);
|
||
$('#dialog_department').dropdownVal(workorderdata.DepartmentId);
|
||
}
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
|
||
function getLaborCost(isassignto, istotalcost) {
|
||
if (isassignto === true) {
|
||
$('#dialog_hourlyrate').val("0");
|
||
var contact = $("#dialog_assignto").data('dropdown').selected;
|
||
if (contact && contact.ContactType === 6) {
|
||
$('#dialog_hourlyrate').val(contact.HourlyRate);
|
||
}
|
||
}
|
||
|
||
var hourlyrate = $('#dialog_hourlyrate').val();
|
||
var time = $('#dialog_timetocomplete').val();
|
||
var labor = 0;
|
||
if (hourlyrate !== "" && !isNaN(hourlyrate) && time !== "" && !isNaN(time))
|
||
labor = eval(hourlyrate) * eval(time);
|
||
$('#dialog_laborcost').val(labor);
|
||
if (isassignto || istotalcost)
|
||
getTotalCost();
|
||
}
|
||
|
||
function getTotalCost() {
|
||
if (segmentdata && segmentdata.length > 0)
|
||
return;
|
||
var othercost = $('#dialog_othercost').val();
|
||
var partscost = $('#dialog_partscost').val();
|
||
var traveltimecost = $('#dialog_traveltimecost').val();
|
||
var laborcost = $('#dialog_laborcost').val();
|
||
var totalcost = 0;
|
||
if (othercost !== "" && !isNaN(othercost))
|
||
totalcost += eval(othercost);
|
||
if (partscost !== "" && !isNaN(partscost))
|
||
totalcost += eval(partscost);
|
||
if (traveltimecost !== "" && !isNaN(traveltimecost))
|
||
totalcost += eval(traveltimecost);
|
||
if (laborcost !== "" && !isNaN(laborcost))
|
||
totalcost += eval(laborcost);
|
||
$('#dialog_workordercosts').val(totalcost.toFixed(2));
|
||
}
|
||
|
||
function OnSave(exit, callback) {
|
||
var item = {
|
||
'WorkOrderType': $.trim($('#dialog_wotype').dropdownVal()),
|
||
'PartsOrderNumber': $.trim($('#dialog_partsordernumber').val()),
|
||
'PartsStatus': $.trim($('#dialog_partsstatus').dropdownVal()),
|
||
'Component': $.trim($('#dialog_wocomponent').dropdownVal()),
|
||
'AssignedTo': $.trim($('#dialog_assignto').dropdownVal()),
|
||
'Description': $.trim($('#dialog_description').val()),
|
||
'NextFollowUpDate': $('#dialog_nextfollowupdate').val(),
|
||
'DueDate': $('#dialog_duedate').val(),
|
||
'CompleteDate': $('#dialog_completeddate').val(),
|
||
'WorkOrderTotalCost': $.trim($('#dialog_workordercosts').val()),
|
||
'HoursToComplete': $.trim($('#dialog_timetocomplete').val()),
|
||
'LocationId': $.trim($('#dialog_location').dropdownVal()),
|
||
'DepartmentId': $.trim($('#dialog_department').dropdownVal()),
|
||
'AdvisorId': $.trim($('#dialog_advisor').dropdownVal()),
|
||
'InternalID': $.trim($('#dialog_internalid').val()),
|
||
'Notes': $.trim($('#dialog_notes').val()),
|
||
'MeterType': $('#dialog_metertype').dropdownVal(),
|
||
'HourMeter': $('#dialog_hourmeter').val(),
|
||
'Odometer': $('#dialog_odometer').val(),
|
||
'OdometerUnits': $('#dig_odometeruom').dropdownVal(),
|
||
'OtherCost': $.trim($('#dialog_othercost').val()),
|
||
'PartsCost': $.trim($('#dialog_partscost').val()),
|
||
'TravelTimeCost': $.trim($('#dialog_traveltimecost').val()),
|
||
'LaborCost': $.trim($('#dialog_laborcost').val()),
|
||
'HourlyRate': $.trim($('#dialog_hourlyrate').val()),
|
||
'InvoiceNumber': $.trim($('#dialog_invoicenumber').val()),
|
||
'CustomerId': customerid,
|
||
'CustomerName': $.trim($('#dialog_custcustomername').text()),
|
||
'AutoText': customer?.autoUpdates,
|
||
'PartsExpectedDate': $('#dialog_partsexpecteddate').val(),
|
||
'LastLaborDate': $('#dialog_lastlabordate').val(),
|
||
'InspectionRequired': $('#dialog_inspectionrequired').prop('checked'),
|
||
'AlternateStatus': $.trim($('#dialog_alternatestatus').val()),
|
||
'Billable': $('#dialog_billable').prop('checked'),
|
||
'BillToJob': $('#dialog_billtojob').dropdownVal(),
|
||
'SalespersonId': $('#dialog_salesperson').dropdownVal(),
|
||
'InspectionTemplateId': $('#dialog_isptemplate').dropdownVal()
|
||
};
|
||
var s = $('#dialog_status').data('dropdown').selected;
|
||
item.Status = s.Id;
|
||
item.StatusType = s.StatusType;
|
||
item.StatusName = s.Name;
|
||
item.StatusAutoText = s.AutoText;
|
||
item.StatusMessage = s.Message;
|
||
item.Contacts = customercontacts;
|
||
item.ContactsClient = customercontacts;
|
||
item.Followers = followers;
|
||
|
||
if (!item.CustomerId)
|
||
item.CustomerId = -1;
|
||
|
||
var alerttitle;
|
||
if (workorderid && workorderid !== '') {
|
||
item.Id = workorderid;
|
||
alerttitle = GetTextByKey("P_WO_EDITWORKORDER", 'Edit Work Order');
|
||
} else {
|
||
item.Id = -1;
|
||
alerttitle = GetTextByKey("P_WO_ADDWORKORDER", "Add Work Order");
|
||
}
|
||
|
||
if (machine == null) {
|
||
showAlert(GetTextByKey("P_WO_ASSETNOTEMPTY", 'Asset cannot be empty.'), alerttitle);
|
||
$('#dialog_machine').focus();
|
||
return;
|
||
}
|
||
else {
|
||
item.AssetID = machine.Id || machine.ID;
|
||
item.VIN = machine.VIN;
|
||
item.AssetName = machine.DisplayName;
|
||
}
|
||
|
||
if (item.WorkOrderTotalCost !== "" && isNaN(item.WorkOrderTotalCost)) {
|
||
showAlert(GetTextByKey("P_WO_WORKORDERCOSTSFORMATERROR", 'Work Order Costs format error.'), alerttitle);
|
||
return;
|
||
}
|
||
|
||
if (item.OtherCost !== "" && isNaN(item.OtherCost)) {
|
||
showAlert(GetTextByKey("P_WO_OTHERCOSTFORMATERROR", 'Other Cost format error.'), alerttitle);
|
||
return;
|
||
}
|
||
if (item.PartsCost !== "" && isNaN(item.PartsCost)) {
|
||
showAlert(GetTextByKey("P_WO_PARTSCOSTFORMATERROR", 'Parts Cost format error.'), alerttitle);
|
||
return;
|
||
}
|
||
if (item.TravelTimeCost !== "" && isNaN(item.TravelTimeCost)) {
|
||
showAlert(GetTextByKey("P_WO_TRAVELTIMECOSTFORMATERROR", 'Travel Time Cost format error.'), alerttitle);
|
||
return;
|
||
}
|
||
|
||
if (item.HoursToComplete !== "" && isNaN(item.HoursToComplete)) {
|
||
showAlert(GetTextByKey("P_WO_TIMETOCOMPLETEFORMATERROR", 'Time To Complete format error.'), alerttitle);
|
||
return;
|
||
}
|
||
if (item.NextFollowUpDate.length > 0) {
|
||
if (!checkDate(item.NextFollowUpDate)) {
|
||
showAlert(GetTextByKey("P_WO_NEXTFOLLOWUPDATEFORMATERROR", "Next Follow Up Date format error."), alerttitle);
|
||
return false;
|
||
}
|
||
}
|
||
else {
|
||
item.NextFollowUpDate = "";
|
||
}
|
||
|
||
if (item.DueDate.length > 0) {
|
||
if (!checkDate(item.DueDate)) {
|
||
showAlert(GetTextByKey("P_WO_DUEDATEFORMATERROR", "Due Date format error."), alerttitle);
|
||
return false;
|
||
}
|
||
}
|
||
else {
|
||
item.DueDate = "";
|
||
}
|
||
if (!item.LocationId || item.LocationId == "") item.LocationId = -1;
|
||
if (!item.DepartmentId || item.DepartmentId == "") item.DepartmentId = -1;
|
||
|
||
if (item.CompleteDate.length > 0) {
|
||
if (!checkDate(item.CompleteDate)) {
|
||
showAlert(GetTextByKey("P_WO_COMPLETEDDATEFORMATERROR", "Completed Date format error."), alerttitle);
|
||
return false;
|
||
}
|
||
}
|
||
else {
|
||
item.CompleteDate = "";
|
||
}
|
||
|
||
if (!item.Description || item.Description.length == 0) {
|
||
showAlert(GetTextByKey("P_WO_DESCRIPTIONCANNOTBEEMPTY", 'Description cannot be empty.'), alerttitle);
|
||
//$('#dialog_description').focus();
|
||
return;
|
||
}
|
||
|
||
if (item.MeterType === "HourMeter") {
|
||
if (item.HourMeter !== "" && isNaN(item.HourMeter)) {
|
||
showAlert(GetTextByKey("P_WO_HOURMETERFORMATERROR", 'Hour Meter format error.'), alerttitle);
|
||
$('#dialog_hourmeter').focus();
|
||
return;
|
||
}
|
||
}
|
||
else if (item.MeterType === "Odometer") {
|
||
if (item.Odometer !== "" && isNaN(item.Odometer)) {
|
||
showAlert(GetTextByKey("P_WO_ODOMETERFORMATERROR", 'Odometer format error.'), alerttitle);
|
||
$('#dialog_odometer').focus();
|
||
return;
|
||
}
|
||
}
|
||
else if (item.MeterType === "Both") {
|
||
if (item.HourMeter !== "" && isNaN(item.HourMeter)) {
|
||
showAlert(GetTextByKey("P_WO_HOURMETERFORMATERROR", 'Hour Meter format error.'), alerttitle);
|
||
$('#dialog_odometer').focus();
|
||
return;
|
||
}
|
||
if (item.Odometer !== "" && isNaN(item.Odometer)) {
|
||
showAlert(GetTextByKey("P_WO_ODOMETERFORMATERROR", 'Odometer format error.'), alerttitle);
|
||
$('#dialog_odometer').focus();
|
||
return;
|
||
}
|
||
}
|
||
if (isNaN(item.Status))
|
||
item.Status = -1;
|
||
|
||
if (item.Status == 100 || s.StatusType == 100) {
|
||
if (item.CompleteDate === "") {
|
||
showAlert(GetTextByKey("P_WO_COMPLETEDDATECANNOTBEEMPTY", 'Completed Date cannot be empty.'), alerttitle);
|
||
$('#dialog_completeddate').focus();
|
||
return;
|
||
}
|
||
|
||
if (item.MeterType === "HourMeter") {
|
||
if (item.HourMeter === "") {
|
||
showAlert(GetTextByKey("P_WO_HOURMETERCANNOTBEEMPTY", 'Hour Meter cannot be empty.'), alerttitle);
|
||
$('#dialog_hourmeter').focus();
|
||
return;
|
||
}
|
||
item.Odometer = -1;
|
||
item.OdometerUnits = "";
|
||
}
|
||
else if (item.MeterType === "Odometer") {
|
||
if (item.Odometer === "") {
|
||
showAlert(GetTextByKey("P_WO_ODOMETERCANNOTBEEMPTY", 'Odometer cannot be empty.'), alerttitle);
|
||
$('#dialog_odometer').focus();
|
||
return;
|
||
}
|
||
item.HourMeter = -1;
|
||
}
|
||
else if (item.MeterType === "Both") {
|
||
if (item.HourMeter === "") {
|
||
showAlert(GetTextByKey("P_WO_HOURMETERCANNOTBEEMPTY", 'Hour Meter cannot be empty.'), alerttitle);
|
||
$('#dialog_hourmeter').focus();
|
||
return;
|
||
}
|
||
if (item.Odometer === "") {
|
||
showAlert(GetTextByKey("P_WO_ODOMETERCANNOTBEEMPTY", 'Odometer cannot be empty.'), alerttitle);
|
||
$('#dialog_odometer').focus();
|
||
return;
|
||
}
|
||
}
|
||
}
|
||
|
||
if (item.InspectionRequired && (item.Status === 100 || item.StatusType === 100)) {
|
||
if (item.Id === -1 || (workorderdata && workorderdata.InspectionCount === 0)) {
|
||
showAlert(GetTextByKey('P_WO_INSPECTIONREQUIREDTIP', 'The work order cannot be updated Until an inspection is completed.'), alerttitle);
|
||
return;
|
||
}
|
||
}
|
||
|
||
if (item.CompleteDate !== "" && item.Status !== 100 && item.StatusType !== 100) {
|
||
if (workorderdata && !workorderdata.CanClose)
|
||
item.CompleteDate = "";
|
||
else {
|
||
$('#sptitle_completedstatus').text(alerttitle);
|
||
openCompletedStatusDialog(exit, callback);
|
||
return;
|
||
}
|
||
}
|
||
|
||
if (item.HourMeter === "")
|
||
item.HourMeter = -1;
|
||
if (item.Odometer === "") {
|
||
item.Odometer = -1;
|
||
//item.OdometerUnits = "";
|
||
}
|
||
|
||
if (item.WorkOrderTotalCost === "" || item.WorkOrderTotalCost === 0)
|
||
item.WorkOrderTotalCost = -1;
|
||
if (item.HoursToComplete === "" || item.HoursToComplete === 0)
|
||
item.HoursToComplete = -1;
|
||
|
||
if (item.OtherCost === "" || item.OtherCost === 0)
|
||
item.OtherCost = -1;
|
||
if (item.PartsCost === "" || item.PartsCost === 0)
|
||
item.PartsCost = -1;
|
||
if (item.TravelTimeCost === "" || item.TravelTimeCost === 0)
|
||
item.TravelTimeCost = -1;
|
||
if (item.LaborCost === "" || item.LaborCost === 0)
|
||
item.LaborCost = -1;
|
||
if (item.HourlyRate === "" || item.HourlyRate === 0)
|
||
item.HourlyRate = -1;
|
||
|
||
if (item.InspectionTemplateId === "")
|
||
item.InspectionTemplateId = -1;
|
||
|
||
if (item.CompleteDate !== "" && item.CompleteDate !== nowDate) {
|
||
var rst = false;
|
||
var msg = "";
|
||
if ((item.MeterType === "Odometer" || item.MeterType === "Both")
|
||
&& machine.CurrentOdometer && parseFloat(item.Odometer) === Math.round(machine.CurrentOdometer.Corrected)) {
|
||
if ((item.OdometerUnits.toLowerCase() === "mile" && ['mi', 'm'].indexOf(machine.CurrentOdometer.UOM) >= 0)
|
||
|| (item.OdometerUnits.toLowerCase() === "kilometre" && ['km', 'Kilometres'].indexOf(machine.CurrentOdometer.UOM) >= 0)
|
||
) {
|
||
rst = true;
|
||
var odoumits = (item.OdometerUnits == "Mile" ? "miles" : "kilometers");
|
||
msg = 'mileage (' + parseFloat(item.Odometer).toLocaleString() + ' ' + odoumits + ')';
|
||
}
|
||
}
|
||
if ((item.MeterType === "HourMeter" || item.MeterType === "Both")
|
||
&& machine.CurrentHours && parseFloat(item.HourMeter) === Math.round(machine.CurrentHours.Corrected)) {
|
||
rst = true;
|
||
msg = 'hours (' + parseFloat(item.HourMeter).toLocaleString() + ' hours)';
|
||
}
|
||
|
||
if (rst) {
|
||
showConfirm(GetTextByKey("P_WO_XXX", "This work order was completed on {1} but is using the current {0} is this correct? ").replace('{0}', msg).replace('{1}', item.CompleteDate), alerttitle, function () {
|
||
checkStatusChange(item, function (phoneemail) {
|
||
saveWorkOrder(item, alerttitle, exit, callback, phoneemail);
|
||
});
|
||
}, function (err) {
|
||
});
|
||
}
|
||
else
|
||
checkStatusChange(item, function (phoneemail) {
|
||
saveWorkOrder(item, alerttitle, exit, callback, phoneemail);
|
||
});
|
||
}
|
||
else
|
||
checkStatusChange(item, function (phoneemail) {
|
||
saveWorkOrder(item, alerttitle, exit, callback, phoneemail);
|
||
});
|
||
}
|
||
|
||
function checkStatusChange(item, next) {
|
||
if (AllowCommunicate && !COMMReadOnly && (!workorderdata || item.Status != workorderdata.Status)) {
|
||
showmaskbg(true);
|
||
$('#dialog_statuschange .dialog-title span.title').text(GetTextByKey("P_WO_STATUSCHANGE", 'Status Change') + " - " + item.StatusName);
|
||
$('#dialog_statuschange')
|
||
.css({
|
||
'top': (document.documentElement.clientHeight - $('#dialog_statuschange').height()) / 3,
|
||
'left': (document.documentElement.clientWidth - $('#dialog_statuschange').width()) / 2
|
||
}).showDialogfixed();
|
||
|
||
|
||
$('#dialog_chksendtextmsg').prop('checked', item.StatusAutoText && !COMMReadOnly).prop('disabled', COMMReadOnly).change();
|
||
if (!COMMReadOnly)
|
||
$('#dialog_textmsg').val(item.StatusMessage);
|
||
|
||
$("#btn_savestatuschange").unbind().click(function () {
|
||
showmaskbg(false);
|
||
$('#dialog_statuschange').hideDialog();
|
||
if (next) {
|
||
var phoneemail = null;
|
||
if ($('#dialog_chksendtextmsg').prop('checked'))
|
||
phoneemail = $('#txtphonenum_statuschange').val();
|
||
next(phoneemail);//需先取txtphonenum_statuschange值,否则会被通知刷新掉
|
||
}
|
||
});
|
||
}
|
||
else if (next)
|
||
next(null);
|
||
}
|
||
|
||
|
||
function saveWorkOrder(item, alerttitle, exit, callback, phoneemail) {
|
||
var param = JSON.stringify(item);
|
||
param = htmlencode(param);
|
||
|
||
showloading(true);
|
||
worequest("SaveWorkOrder", param + String.fromCharCode(170) + JSON.stringify(alertids), function (data) {
|
||
showloading(false);
|
||
if (typeof (data) === "string") {
|
||
showAlert(data, alerttitle);
|
||
} else {
|
||
var isadd = true;
|
||
if (workorderid)
|
||
isadd = false;
|
||
|
||
workorderid = data[0];
|
||
item.Id = workorderid;
|
||
resetComments();
|
||
$(".comm").show();
|
||
|
||
$('#dialog_wonumber').text(data[1]);
|
||
$('#divwonumber').show();
|
||
|
||
if (isadd) {
|
||
getAlerts();
|
||
//GetInvoiceNumber();
|
||
}
|
||
|
||
if (phoneemail)
|
||
SendTextMsg(item, phoneemail);
|
||
|
||
if (callback) {
|
||
callback(item);
|
||
needRefreshDataOnCancel = true;
|
||
loadworkorder(workorderid, true);
|
||
//getWorkOrderTypes();
|
||
//getPartsStatuses();
|
||
}
|
||
else {
|
||
if (exit == 0) {
|
||
needRefreshDataOnCancel = true;
|
||
showAlert(GetTextByKey("P_WO_SAVSUCCESSFULLY", "Saved successfully."), alerttitle);
|
||
loadworkorder(workorderid, true);
|
||
//getWorkOrderTypes();
|
||
//getPartsStatuses();
|
||
}
|
||
if (exit == 1)
|
||
OnExit(exit);
|
||
else
|
||
$("#btnSelectAsset").hide();
|
||
}
|
||
}
|
||
}, function (err) {
|
||
showloading(false);
|
||
showAlert(GetTextByKey("P_WO_FAILEDTOSAVEWORKORDER", 'Failed to save Work Order.'), alerttitle);
|
||
});
|
||
}
|
||
|
||
var exited = false;
|
||
function OnExit(type) {
|
||
exited = true;
|
||
workorderid = "";
|
||
clearWorkOrderInfo();
|
||
if (type === 0) {
|
||
if (needRefreshDataOnCancel) {
|
||
type = 1;
|
||
needRefreshDataOnCancel = false;
|
||
}
|
||
}
|
||
if (window.parent && typeof window.parent.CloseDialog == 'function')
|
||
window.parent.CloseDialog(type);
|
||
else
|
||
window.location = "maintenance.aspx#nav_workorder";
|
||
}
|
||
|
||
function SendTextMsg(wo, phoneemail) {
|
||
var phoneemail = phoneemail;// $('#txtphonenum_statuschange').val();
|
||
if ($.trim(phoneemail) == "") {
|
||
return;
|
||
}
|
||
|
||
var phoneemails = phoneemail.split(';');
|
||
var pmemails = [];
|
||
for (var i = 0; i < phoneemails.length; i++) {
|
||
var pm = phoneemails[i];
|
||
if (checkPhoneNumber(pm) || isEmail(pm)) {
|
||
pmemails.push({ 'Key': pm, 'Value': pm });
|
||
}
|
||
else {
|
||
if (wo && wo.Contacts) {
|
||
for (var j = 0; j < wo.Contacts.length; j++) {
|
||
var c = wo.Contacts[j];
|
||
if (c.OptOut || c.OptOut_BC) continue;
|
||
var mp = $.trim(c.MobilePhone);
|
||
var email = $.trim(c.Email);
|
||
if (c.Name === pm) {
|
||
if (c.ContactPreference == "0" && checkPhoneNumber(mp)) {
|
||
pmemails.push({ 'Key': mp, 'Value': pm });
|
||
break;
|
||
}
|
||
if (c.ContactPreference == "1" && isEmail(email)) {
|
||
pmemails.push({ 'Key': email, 'Value': pm });
|
||
break;
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
}
|
||
|
||
var comm = $('#dialog_textmsg').val();
|
||
if ($.trim(comm) == "") {
|
||
//showAlert(GetTextByKey("P_WO_PLEASEINPUTTHEMESSAGE", "Please input the message."), GetTextByKey("P_WO_ERROR", 'Error'));
|
||
return;
|
||
}
|
||
var includeStatusLink = $('#dialog_chkIncludeStatusLink').prop("checked");
|
||
|
||
var param = JSON.stringify([wo.Id.Value || wo.Id, JSON.stringify(pmemails), comm, (includeStatusLink ? "1" : "0")]);
|
||
param = htmlencode(param);
|
||
worequest("AddWorkOrderCommunication", param, function (data) {
|
||
if (data !== "") {
|
||
showAlert(data, GetTextByKey("P_WO_ERROR", 'Error'));
|
||
return;
|
||
}
|
||
}, function (err) {
|
||
//showmaskbg(false);
|
||
});
|
||
}
|
||
|
||
function setPhoneNumber_statuschange() {
|
||
if (customercontacts && !COMMReadOnly) {
|
||
var names = "";
|
||
for (var i = 0; i < customercontacts.length; i++) {
|
||
var c = customercontacts[i];
|
||
if (c.OptOut || c.OptOut_BC) continue;
|
||
var mp = $.trim(c.MobilePhone);
|
||
var email = $.trim(c.Email);
|
||
if ((c.ContactPreference == "0" && (checkPhoneNumber(mp))
|
||
|| (c.ContactPreference == "1" && isEmail(email)))) {
|
||
if (names == "")
|
||
names = c.Name;
|
||
else
|
||
names += ";" + c.Name;
|
||
}
|
||
}
|
||
$('#txtphonenum_statuschange').val(names);
|
||
}
|
||
else
|
||
$('#txtphonenum_statuschange').val("");
|
||
}
|
||
|
||
function clearWorkOrderInfo() {
|
||
machine = null;
|
||
$('#spassignedasset').text(GetTextByKey("P_MD_UNASSIGNED", 'Unassigned')).data("aid", -1);
|
||
$('#dialog_vin').text('');
|
||
$('#dialog_make').text('');
|
||
$('#dialog_model').text('');
|
||
$('#dialog_type').text('');
|
||
$("#dialog_clocation").text("");
|
||
$("#dialog_cjobsite").text("");
|
||
|
||
contacts = undefined;
|
||
$('#dialog_assignto').dropdownSource([]);
|
||
$('#dialog_advisor').dropdownSource([]);
|
||
$("#btnSelectAsset").hide();
|
||
if (AllowCustomer) {
|
||
$('#dialog_estimatestatus').text("");
|
||
}
|
||
$('#dialog_wonumber').text("");
|
||
$('#divwonumber').hide();
|
||
$('#dialog_wotype').dropdownVal('');
|
||
$('#dialog_partsordernumber').val('');
|
||
$('#dialog_partsstatus').dropdownVal('');
|
||
$('#dialog_wocomponent').dropdownVal('');
|
||
$('#dialog_assignto').dropdownVal('-1');
|
||
$('#dialog_status').dropdownVal('-1');
|
||
$('#dialog_nextfollowupdate').val('');
|
||
$('#dialog_nextfollowupdate').css("color", "unset");
|
||
$('#dialog_duedate').val('');
|
||
$('#dialog_description').val('');
|
||
$('#dialog_workordercosts').val('');
|
||
$('#dialog_timetocomplete').val('');
|
||
$('#dialog_completeddate').val('');
|
||
$('#dialog_location').dropdownVal('-1');
|
||
$('#dialog_department').dropdownVal('-1');
|
||
$('#dialog_advisor').dropdownVal('-1');
|
||
$('#dialog_internalid').val('');
|
||
$('#dialog_notes').val('');
|
||
$('#dialog_hourmeter').val('');
|
||
$('#dialog_expectedcost').val('');
|
||
$('#dialog_odometer').val('');
|
||
$('#dig_odometeruom').dropdownVal(systemunitofodometer);
|
||
|
||
$('#dialog_billable').prop('checked', false);
|
||
$('#dialog_billtojob').dropdownVal('-1');
|
||
$('#dialog_salesperson').dropdownVal('');
|
||
|
||
customerid = null;
|
||
$('#dialog_custcustomername').text('');
|
||
$('#dialog_custcustomercode').text('');
|
||
showCustomerContacts([]);
|
||
|
||
$('#dialog_othercost').val('');
|
||
$('#dialog_partscost').val('');
|
||
$('#dialog_laborcost').val('');
|
||
$('#dialog_traveltimecost').val('');
|
||
$('#dialog_hourlyrate').val('');
|
||
$('#dialog_invoicenumber').val('');
|
||
if (typeof customer !== 'undefined') {
|
||
customer.autoUpdates = false;
|
||
}
|
||
$('#dialog_partsexpecteddate').val('');
|
||
$('#dialog_lastlabordate').val('');
|
||
$('#dialog_inspectionrequired').prop('checked', false);
|
||
$('#dialog_inspectioncount').text('0').css('color', 'unset');
|
||
$('#dialog_alternatestatus').val('');
|
||
|
||
$('#tabAttachments').hide();
|
||
$("#tbAttas").empty();
|
||
$('#tabAssetAttachments').hide();
|
||
$("#tbAssetAttas").empty();
|
||
clearWorkOrderOther();
|
||
|
||
resetComments();
|
||
resetCommunications();
|
||
$('#tab_segments .segments_table').remove();
|
||
}
|
||
|
||
function loadworkorder(woid, keepinfo) {
|
||
exited = false;
|
||
workorderid = woid;
|
||
allcomponents = null;//这是为null,展开时重新取allcomponents
|
||
if (!keepinfo)
|
||
clearWorkOrderInfo();
|
||
if (workorderid && workorderid !== '') {
|
||
$("#li_workorder").click();
|
||
$("#li_segments").data("dataload", false);
|
||
$("#li_attachments").data("dataload", false);
|
||
$("#li_inspections").data("dataload", false);
|
||
$("#li_estimates").data("dataload", false);
|
||
$("#li_invoices").data("dataload", false);
|
||
|
||
$('#spanopenworkorders').hide();
|
||
$(".comm").show();
|
||
$("#li_inspections").show();
|
||
$("#li_estimates").show();
|
||
$("#li_invoices").show();
|
||
//getWorkOrderStatuses();
|
||
OnEdit();
|
||
getAlerts();
|
||
}
|
||
else {
|
||
$('#spanopenworkorders').show();
|
||
$(".comm").hide();
|
||
$("#li_inspections").hide();
|
||
$("#li_estimates").hide();
|
||
$("#li_invoices").hide();
|
||
OnAdd();
|
||
machineid = "";
|
||
}
|
||
}
|
||
|
||
function refreshstatus() {
|
||
getWorkOrderStatuses();
|
||
getWorkorderParams();
|
||
}
|
||
|
||
//判断是否显示状态变化弹窗 21749
|
||
function CheckIfShowStatusPopup(requiredFiledChanged) {
|
||
var item = {};
|
||
//if (requiredFiledChanged) {
|
||
// item = {
|
||
// 'Description': $.trim($('#dialog_description').val()),
|
||
// };
|
||
// if (machine == null) {
|
||
// return;
|
||
// }
|
||
// if (!item.Description || item.Description.length == 0) {
|
||
// return;
|
||
// }
|
||
//}
|
||
var s = $('#dialog_status').data('dropdown').selected;
|
||
item.Status = s.Id;
|
||
if (AllowCommunicate && !COMMReadOnly && (workorderdata && item.Status != workorderdata.Status)) {//新建WO在Save的时候弹窗
|
||
OnSave(0);
|
||
}
|
||
}
|
||
|
||
var inspectionloaded = false;
|
||
function init() {
|
||
if (AllowCustomer) {
|
||
$(".contactinfo").show();
|
||
$(".alternatestatus").show();
|
||
}
|
||
else {
|
||
$(".contactinfo").hide();
|
||
$(".alternatestatus").hide();
|
||
}
|
||
|
||
// dropdown
|
||
|
||
$('#dialog_status').dropdown([
|
||
{ Id: '-1', Name: ' ' }
|
||
], {
|
||
search: false,
|
||
valueKey: 'Id',
|
||
textKey: 'Name'
|
||
}).on('select', function (_e, st) {
|
||
if (st.Id == 100 || st.StatusType == 100) {
|
||
$('.span_required').show();
|
||
if ($('#dialog_completeddate').val() === "")
|
||
if (workorderdata && !workorderdata.CanClose)
|
||
$('#dialog_completeddate').val(workorderdata.CompleteDateStr);
|
||
else
|
||
$('#dialog_completeddate').val(nowDate);
|
||
|
||
if (machine) {
|
||
var mtype = $('#dialog_metertype').dropdownVal();
|
||
if (machine.CurrentHours) {
|
||
if (($('#dialog_hourmeter').val() === "" || $('#dialog_hourmeter').val() === "0") && (mtype == "HourMeter" || mtype == "Both")) {
|
||
$('#dialog_hourmeter').val(machine.CurrentHours.Corrected > 0 ? Math.round(machine.CurrentHours.Corrected) : "");
|
||
}
|
||
}
|
||
if (machine.CurrentOdometer) {
|
||
if (($('#dialog_odometer').val() === "" || $('#dialog_odometer').val() === "0") && (mtype == "Odometer" || mtype == "Both")) {
|
||
$('#dialog_odometer').val(machine.CurrentOdometer.Corrected > 0 ? Math.round(machine.CurrentOdometer.Corrected) : "");
|
||
}
|
||
}
|
||
}
|
||
} else {
|
||
$('.span_required').hide();
|
||
$('#dialog_completeddate').val('');
|
||
}
|
||
|
||
CheckIfShowStatusPopup();
|
||
});
|
||
|
||
$('#dialog_description').blur(function () {
|
||
setTimeout(function () {
|
||
if (!exited)
|
||
CheckIfShowStatusPopup();
|
||
}, 100);
|
||
});
|
||
|
||
$('#dialog_completed_status').dropdown([], {
|
||
search: false,
|
||
valueKey: 'Id',
|
||
textKey: 'Name'
|
||
});
|
||
|
||
$('#dialog_metertype').dropdown([
|
||
{ value: 'HourMeter', text: GetTextByKey('P_WO_HOURMETER', 'Hour Meter') },
|
||
{ value: 'Odometer', text: GetTextByKey('P_WO_ODOMETER', 'Odometer') },
|
||
{ value: 'Both', text: GetTextByKey('P_WO_BOTH', 'Both') }
|
||
], {
|
||
selected: 'HourMeter'
|
||
}).on('select', function (_e, type) {
|
||
meterType = type.value;
|
||
setMeterType();
|
||
if (machine) {
|
||
if (machine.CurrentHours) {
|
||
if (($('#dialog_hourmeter').val() === "" || $('#dialog_hourmeter').val() === "0") && (meterType == "HourMeter" || meterType == "Both")) {
|
||
$('#dialog_hourmeter').val(machine.CurrentHours.Corrected > 0 ? Math.round(machine.CurrentHours.Corrected) : "");
|
||
}
|
||
}
|
||
if (machine.CurrentOdometer) {
|
||
if (($('#dialog_odometer').val() === "" || $('#dialog_odometer').val() === "0") && (meterType == "Odometer" || meterType == "Both")) {
|
||
$('#dialog_odometer').val(machine.CurrentOdometer.Corrected > 0 ? Math.round(machine.CurrentOdometer.Corrected) : "");
|
||
}
|
||
}
|
||
}
|
||
});
|
||
$('#dig_odometeruom').dropdown([
|
||
{ value: 'Mile', text: GetTextByKey('P_WO_MILE', 'Mile') },
|
||
{ value: 'Kilometre', text: GetTextByKey('P_WO_KILOMETER', 'Kilometer') }
|
||
], {
|
||
selected: 'Mile',
|
||
disabled: true
|
||
});
|
||
|
||
$('#dialog_location').dropdown([
|
||
{ ID: '-1', Name: ' ', html: ' ' }
|
||
], {
|
||
valueKey: 'ID',
|
||
textKey: 'Name'
|
||
}).on('select', function () {
|
||
GetContacts();
|
||
});
|
||
|
||
$('#dialog_department').dropdown([
|
||
{ Id: '-1', Name: ' ', html: ' ' }
|
||
], {
|
||
valueKey: 'Id',
|
||
textKey: 'Name'
|
||
}).on('select', function () {
|
||
GetContacts();
|
||
});
|
||
|
||
$("#dialog_advisor")
|
||
.dropdown([{ value: '', DisplayName: ' ' }], { textKey: 'DisplayName' })
|
||
.on('expand', function () {
|
||
if (!contacts)
|
||
GetContacts();
|
||
});
|
||
|
||
|
||
$("#dialog_assignto")
|
||
.dropdown([{ value: '', DisplayName: ' ' }], { textKey: 'DisplayName' })
|
||
.on('select', function () {
|
||
getLaborCost(true);
|
||
})
|
||
.on('expand', function () {
|
||
if (!contacts)
|
||
GetContacts();
|
||
});
|
||
|
||
$('#dialog_wotype').dropdown([], {
|
||
input: true,
|
||
maxlength: 50,
|
||
textKey: 'value'
|
||
});
|
||
|
||
$('#dialog_partsstatus').dropdown([], {
|
||
input: true,
|
||
maxlength: 50,
|
||
textKey: 'value'
|
||
});
|
||
|
||
$('#dialog_wocomponent').dropdown([{ value: '' }], {
|
||
input: true,
|
||
maxlength: 50,
|
||
textKey: 'value'
|
||
}).on('expand', function () {
|
||
if (!allcomponents)
|
||
GetComponents();
|
||
});;
|
||
|
||
$('#dialog_contactpreference').dropdown([
|
||
{ value: '0', text: GetTextByKey('P_CR_TEXT', 'Text') },
|
||
{ value: '1', text: GetTextByKey('P_CR_EMAIL', 'Email') },
|
||
{ value: '2', text: GetTextByKey('P_CR_PHONE', 'Phone') }
|
||
]);
|
||
|
||
$('#dialog_billtojob').dropdown([{ ID: '', Name: ' ' }], {
|
||
search: true,
|
||
valueKey: 'ID',
|
||
textKey: 'Name'
|
||
}).on('expand', function () {
|
||
if (!alljobsites)
|
||
GetJobsites();
|
||
});
|
||
|
||
$('#dialog_salesperson').dropdown([{ Key: '', Value: ' ' }], {
|
||
search: true,
|
||
valueKey: 'Key',
|
||
textKey: 'Value'
|
||
});
|
||
|
||
$('#dialog_isptemplate').dropdown([{ Key: '', Value: ' ' }], {
|
||
search: true,
|
||
valueKey: 'Key',
|
||
textKey: 'Value'
|
||
});
|
||
|
||
$('#dialog_segmentuser').dropdown([], {
|
||
search: true,
|
||
valueKey: 'IID',
|
||
textKey: 'DisplayName',
|
||
parent: '.dialog-content'
|
||
});
|
||
$('#dialog_segmentjobsite').dropdown([], {
|
||
search: true,
|
||
valueKey: 'ID',
|
||
textKey: 'Name',
|
||
parent: '.dialog-content'
|
||
});
|
||
$('#dialog_segmenttype').dropdown([], {
|
||
input: true,
|
||
maxlength: 50,
|
||
textKey: 'value',
|
||
parent: '.dialog-content'
|
||
});
|
||
$('#dialog_segmentcomponent').dropdown([], {
|
||
input: true,
|
||
maxlength: 40,
|
||
textKey: 'value',
|
||
parent: '.dialog-content'
|
||
});
|
||
|
||
// end dropdown
|
||
getWorkorderParams();
|
||
getWorkOrderStatuses();
|
||
getWorkOrderTypes();
|
||
getPartsStatuses();
|
||
getLocationsAndDepartments();
|
||
if (!allsalespersons)
|
||
getSalespersons();
|
||
if (!allisptemplates)
|
||
getInspectionTemplateItems();
|
||
if (workorderid && workorderid !== '') {
|
||
$("#li_workorder").click();
|
||
$("#li_segments").data("dataload", false);
|
||
$("#li_attachments").data("dataload", false);
|
||
$("#li_inspections").data("dataload", false);
|
||
$("#li_estimates").data("dataload", false);
|
||
$("#li_invoices").data("dataload", false);
|
||
|
||
$(".comm").show();
|
||
$("#li_inspections").show();
|
||
$("#li_estimates").show();
|
||
$("#li_invoices").show();
|
||
OnEdit();
|
||
getAlerts();
|
||
}
|
||
else {
|
||
$(".comm").hide();
|
||
$("#li_inspections").hide();
|
||
$("#li_estimates").hide();
|
||
$("#li_invoices").hide();
|
||
OnAdd();
|
||
if (machineid !== "")
|
||
getAssetAlerts();
|
||
}
|
||
if (machineid !== "") {
|
||
GetOpenWorkOrderID(machineid);
|
||
getAssetDetailInfo(machineid);
|
||
}
|
||
}
|
||
|
||
function setMeterType() {
|
||
//$('#tr_hourmeter').css('display', 'none');
|
||
//$('#tr_odometer').css('display', 'none');
|
||
//if (meterType == "HourMeter" || meterType == "Both") {
|
||
// $('#tr_hourmeter').css('display', '');
|
||
//}
|
||
//if (meterType == "Odometer" || meterType == "Both") {
|
||
// $('#tr_odometer').css('display', '');
|
||
//}
|
||
|
||
if (meterType == "HourMeter" || meterType == "Both") {
|
||
$("#dialog_hourmeter").prop("disabled", false);
|
||
}
|
||
else {
|
||
$("#dialog_hourmeter").prop("disabled", true).val("");
|
||
}
|
||
|
||
if (meterType == "Odometer" || meterType == "Both") {
|
||
$("#dialog_odometer").prop("disabled", false);
|
||
$('#dig_odometeruom').dropdownDisabled(false);
|
||
}
|
||
else {
|
||
$("#dialog_odometer").prop("disabled", true).val("");
|
||
$('#dig_odometeruom').dropdownDisabled(true);
|
||
}
|
||
}
|
||
|
||
function GetOpenWorkOrderID(mid) {
|
||
$('#spanopenworkorders').css('display', 'none');
|
||
$('#spanopenworkorderstext').text('');
|
||
|
||
worequest("GetOpenWorkOrderID", mid, function (data) {
|
||
var ary = [];
|
||
if (data !== "")
|
||
ary = data.split("|")
|
||
if (ary[0] == mid && ary[1] !== "") {
|
||
$('#spanopenworkorders').css('display', "");
|
||
$('#spanopenworkorderstext').text(ary[1]);
|
||
}
|
||
else {
|
||
$('#spanopenworkorders').css('display', "none");
|
||
$('#spanopenworkorderstext').text('');
|
||
}
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function updateCommunicationAcknowledged(id, chk) {
|
||
var item = [id, chk];
|
||
var param = JSON.stringify(item);
|
||
param = htmlencode(param);
|
||
|
||
worequest('UpdateCommunicationAcknowledged', param, function (data) {
|
||
if (data !== 'OK') {
|
||
showAlert(data, GetTextByKey("P_WORKORDER", 'Work Order'));
|
||
}
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function updateEstimateAcknowledged(id, chk) {
|
||
var item = [id, chk];
|
||
var param = JSON.stringify(item);
|
||
param = htmlencode(param);
|
||
|
||
worequest('UpdateEstimateAcknowledged', param, function (data) {
|
||
if (data !== 'OK') {
|
||
showAlert(data, GetTextByKey("P_WORKORDER", 'Work Order'));
|
||
}
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function OnPrint() {
|
||
var alerttitle = GetTextByKey("P_WO_PRINTWORKORDER", "Print Work Order");
|
||
if (!workorderid || workorderid === "") {
|
||
showAlert(GetTextByKey("P_WO_SAVEWORKORDERFIRST", "Please save work order first."), alerttitle);
|
||
return;
|
||
}
|
||
window.open("../Print.aspx?pt=1&wo=" + workorderid);
|
||
}
|
||
|
||
function workorderreportyes() {
|
||
window.open("WorkOrderMaintenance.aspx?tt=1&id=" + workorderid + "&t=3&rt=f");
|
||
}
|
||
|
||
function workorderreportno() {
|
||
window.open("WorkOrderMaintenance.aspx?tt=0&id=" + workorderid + "&t=3&rt=f");
|
||
}
|
||
|
||
|
||
function OnExportReport() {
|
||
if (!(/*IsAdmin && */AllowCustomer)) {
|
||
return;
|
||
}
|
||
var alerttitle = GetTextByKey("P_WO_WORKORDERREPORT", "Work Order Report");
|
||
if (!workorderid || workorderid === "") {
|
||
showAlert(GetTextByKey("P_WO_SAVEWORKORDERFIRST", "Please save work order first."), alerttitle);
|
||
return;
|
||
}
|
||
showThreeButtonConfirm(GetTextByKey("P_WO_WORKORDERREPORT_CONFIM", "Should only customer facing items be included?"), alerttitle, workorderreportyes, workorderreportno);
|
||
//window.open("../Print.aspx?pt=1&wo=" + workorderid);
|
||
}
|
||
|
||
function getAssetDetailInfo(mid) {
|
||
$("#dialog_clocation").text("");
|
||
$("#dialog_cjobsite").text("");
|
||
worequest("GetAssetDetailInfo", "" + String.fromCharCode(170) + mid, function (data) {
|
||
if (typeof (data) === "string") {
|
||
return;
|
||
}
|
||
if (data.ID != machineid)
|
||
return;
|
||
|
||
machine = data;
|
||
setMachineInfo(machine);
|
||
if (data.CurrentLocation) {
|
||
$("#dialog_clocation").text(data.CurrentLocation.Address);
|
||
}
|
||
$("#dialog_cjobsite").text(data.CurrentJobSiteNames);
|
||
}, function (err) {
|
||
});
|
||
}
|
||
|
||
function OnExpend(e) {
|
||
var t = $(e);
|
||
var tid = t.attr("target");
|
||
if (t.hasClass("iconchevrondown")) {
|
||
t.removeClass("iconchevrondown").addClass("iconchevronright");
|
||
$("#" + tid).hide();
|
||
}
|
||
else {
|
||
t.removeClass("iconchevronright").addClass("iconchevrondown");
|
||
$("#" + tid).show();
|
||
if (tid == "tbcustomer") {
|
||
grid_dtcontact && grid_dtcontact.resize();
|
||
}
|
||
else if (tid == "tbfollower") {
|
||
grid_dtfollower && grid_dtfollower.resize();
|
||
}
|
||
}
|
||
saveWorkOrderCollapsed();
|
||
}
|
||
|
||
|
||
var dialogAssets;
|
||
$(function () {
|
||
createAttachment($('#tab_attachments'));
|
||
createSegment($('#tab_segments'));
|
||
createAlert($('#tab_alerts'));
|
||
createEstimate($('#tab_estimates'))
|
||
createInvoice($('#tab_invoices'))
|
||
|
||
InitDTCAlertGridData();
|
||
InitPMAAlertGridData();
|
||
InitInspectAlertGridData();
|
||
InitOilAlertGridData();
|
||
|
||
InitNoneAssignedAlertGridData();
|
||
InitAllPMSchedulesGridData();
|
||
|
||
InitGridCustomers();
|
||
|
||
if (WOReadOnly) {
|
||
$(".iconadd").hide();
|
||
$(".icondelete").hide();
|
||
}
|
||
|
||
dialogAssets = new $assetselector('dialog_machines');
|
||
dialogAssets.forceSingle = true;
|
||
dialogAssets.onDialogClosed = function () {
|
||
showmaskbg(false);
|
||
};
|
||
dialogAssets.onOK = function (source, selectedIndex) {
|
||
meterType = "";
|
||
var selectedAsset = null;
|
||
if (selectedIndex >= 0)
|
||
selectedAsset = source[selectedIndex].Values;
|
||
setMachineInfo(selectedAsset);
|
||
if (selectedAsset) {
|
||
machineid = selectedAsset.Id;
|
||
machine = selectedAsset;
|
||
|
||
CheckIfShowStatusPopup();
|
||
|
||
if (!machine.OnRoad && (meterType == "HourMeter" || meterType == "Both")) {
|
||
$('#dialog_hourmeter').val(machine.EngineHours > 0 ? Math.round(machine.EngineHours) : "");
|
||
}
|
||
if (machine.OnRoad && (meterType == "Odometer" || meterType == "Both")) {
|
||
$('#dialog_odometer').val(machine.Odometer > 0 ? Math.round(machine.Odometer) : "");
|
||
}
|
||
|
||
GetOpenWorkOrderID(machineid);
|
||
alertids = [];
|
||
getAssetAlerts(machineid);
|
||
getAssetDetailInfo(machineid);
|
||
GetContacts();
|
||
}
|
||
showmaskbg(false);
|
||
};
|
||
|
||
$("#btnSelectAsset").click(function () {
|
||
showmaskbg(true);
|
||
dialogAssets.companyId = $('#sel_contractor').val();
|
||
dialogAssets.showSelector();
|
||
});
|
||
|
||
//if (!AllowCommunicate) {
|
||
// $("#divCommunicate").remove();
|
||
//}
|
||
const ui = window['lib-ui'];
|
||
const app = window['lib-app'];
|
||
if (AllowCommunicate) {
|
||
customer = new app.CustomerCommunication({
|
||
autoUpdates: false,
|
||
readonly: WOReadOnly || COMMReadOnly,
|
||
recordReadonly: !AllowCustomer || WOReadOnly || CRReadOnly,
|
||
onAddMessage: addWorkOrderCommunication,
|
||
onSave: function (item, add) {
|
||
if (!add) {
|
||
contact = customercontacts.filter(function (f) { return f.Id < 0 ? f.Name === item.Name && f.MobilePhone === item.MobilePhone : f.Id === item.Id })[0];
|
||
}
|
||
var array = [];
|
||
for (let c of customercontacts) {
|
||
if (c === contact) {
|
||
let ct = {
|
||
...contact,
|
||
Name: item.Name,
|
||
ContactPreference: item.ContactPreference,
|
||
Email: item.Email,
|
||
MobilePhone: item.MobilePhone,
|
||
OptOut: item.OptOut,
|
||
Notes: item.Notes,
|
||
SaveToCustomer: item.SaveToCustomer
|
||
};
|
||
|
||
if (parseInt(ct.ContactPreference) == 0) {
|
||
ct.ContactPreferenceStr = GetTextByKey("P_CR_TEXT", "Text");
|
||
} else if (parseInt(ct.ContactPreference) == 1) {
|
||
ct.ContactPreferenceStr = GetTextByKey("P_CR_EMAIL", "Email");
|
||
} else if (parseInt(ct.ContactPreference) == 2) {
|
||
ct.ContactPreferenceStr = GetTextByKey("P_CR_PHONE", "Phone");
|
||
}
|
||
array.push(ct)
|
||
} else {
|
||
array.push(c);
|
||
}
|
||
}
|
||
if (add) {
|
||
item.Id = -1;
|
||
array.push(item);
|
||
}
|
||
|
||
return new Promise(function (resolve, reject) {
|
||
SaveWorkorderContact(array, function (data) {
|
||
if (typeof data === 'string') {
|
||
ui.showAlert(GetTextByKey("P_WO_ERROR", 'Error'), data, 'error')
|
||
reject();
|
||
} else {
|
||
for (let d of data) {
|
||
const c = customercontacts.find(function (c) {
|
||
return c.Id < 0 ?
|
||
c.Name === d.Name && c.MobilePhone === d.MobilePhone :
|
||
c.Id === d.Id
|
||
});
|
||
if (c != null) {
|
||
d.selected = c.selected;
|
||
} else {
|
||
d.selected = true;
|
||
}
|
||
}
|
||
showCustomerContacts(customercontacts = data);
|
||
resolve(data);
|
||
}
|
||
});
|
||
});
|
||
//showCustomerContacts(customercontacts);
|
||
},
|
||
onDelete: function (_op, item, customer) {
|
||
var index;
|
||
if (customer) {
|
||
index = customercontacts.findIndex(function (c) { return c.Id === item.Id });
|
||
} else {
|
||
index = customercontacts.findIndex(function (c) { return c.Name === item.Name && c.MobilePhone === item.MobilePhone });
|
||
}
|
||
if (index >= 0) {
|
||
customercontacts.splice(index, 1);
|
||
SaveWorkorderContact();
|
||
showCustomerContacts(customercontacts);
|
||
|
||
// from customer record
|
||
if (customer) {
|
||
_network.request("Maintenance/AddCustomerRecord.aspx", -1, 'DeleteContact', item.Id, function () { }, function (e) {
|
||
console.log(e);
|
||
ui.showAlert(GetTextByKey("P_WO_ERROR", 'Error'), GetTextByKey('P_UM_PAGEERROR', 'An unknown error occurred. Please refresh page.'), 'error');
|
||
});
|
||
}
|
||
}
|
||
},
|
||
onChanged: function (source) {
|
||
customer.contacts = source;
|
||
},
|
||
onDeleteFollower: function (_op, f) {
|
||
var index = followers.findIndex(function (c) { return c.UserIID === f.UserIID });
|
||
if (index < 0) {
|
||
return;
|
||
}
|
||
followers.splice(index, 1);
|
||
SaveWorkOrderFollower();
|
||
showWorkOrderFollowers(followers);
|
||
},
|
||
onChangeFollower: function (_op, f, text, email) {
|
||
var follower = followers.find(function (c) { return c.UserIID === f.UserIID });
|
||
if (follower != null) {
|
||
follower.SendText = text;
|
||
follower.SendEmail = email;
|
||
SaveWorkOrderFollower();
|
||
showWorkOrderFollowers(followers);
|
||
}
|
||
},
|
||
onInitFollower: function () {
|
||
if (isloadfollower && allfollowers?.length > 0) {
|
||
for (let f of allfollowers) {
|
||
f.Email = false;
|
||
f.Text = false;
|
||
}
|
||
return Promise.resolve(allfollowers);
|
||
}
|
||
return new Promise(function (resolve) {
|
||
getAllFollowers(function (data) {
|
||
if (Array.isArray(data)) {
|
||
isloadfollower = true;
|
||
allfollowers = data;
|
||
}
|
||
resolve(data);
|
||
});
|
||
});
|
||
},
|
||
onAddFollower: function (list) {
|
||
for (let f of list) {
|
||
let iid = f.IID.toLowerCase();
|
||
let o = followers?.find(function (a) { return a.UserIID.toLowerCase() === iid });
|
||
if (o == null) {
|
||
o = {
|
||
Id: -1,
|
||
UserIID: f.IID
|
||
};
|
||
followers.push(o);
|
||
}
|
||
o.Name = f.DisplayName;
|
||
o.Email = f.ID;
|
||
o.MobilePhone = f.Mobile;
|
||
o.SendEmail = f.Email;
|
||
o.SendText = f.Text;
|
||
}
|
||
return new Promise(function (resolve, reject) {
|
||
SaveWorkOrderFollower(function (data) {
|
||
if (data !== 'OK') {
|
||
ui.showAlert(GetTextByKey("P_WO_ERROR", 'Error'), data, 'error')
|
||
reject();
|
||
} else {
|
||
showWorkOrderFollowers(followers);
|
||
resolve(followers);
|
||
}
|
||
});
|
||
});
|
||
}
|
||
});
|
||
|
||
document.querySelector('#communication_holder').append(customer.create());
|
||
}
|
||
internal = new app.InternalComment({
|
||
readonly: WOReadOnly,
|
||
onAddMessage: openSendICEmail,
|
||
onAddComment: addWorkOrderComment
|
||
});
|
||
document.querySelector('#communication_holder').append(internal.create());
|
||
|
||
init();
|
||
|
||
$('#div_container').tab();
|
||
|
||
$('.popus-close').click(function (e) {
|
||
hidePopup();
|
||
}).keydown(resettab);
|
||
function resettab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#popupdialog').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
|
||
$('.estpopus-close').click(function (e) {
|
||
hideEstimatePopup();
|
||
}).keydown(resetesttab);
|
||
function resetesttab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_estimate').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.invoice-popup-close').click(function (e) {
|
||
hideInvoicePopup();
|
||
}).keydown(resetinvoicetab);
|
||
function resetinvoicetab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_invoice').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.pubestpopus-close').click(function (e) {
|
||
hidePublishEstimatePopup();
|
||
}).keydown(resetpubesttab);
|
||
function resetpubesttab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_publishestimate').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.publish-invoice-popup-close').click(function (e) {
|
||
hidePublishInvoicePopup();
|
||
}).keydown(resetpubinvoicetab);
|
||
function resetpubinvoicetab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_publish_invoice').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.compstatuspopus-close').click(function (e) {
|
||
hideCompletedStatusPopup();
|
||
}).keydown(resetcompstatustab);
|
||
function resetcompstatustab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_completedstatus').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.woestattpopus-close').click(function (e) {
|
||
hideWOEstAttachmentPopup();
|
||
}).keydown(resetwoestatttab);
|
||
function resetwoestatttab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_woestattachment').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.woinvoiceattpopus-close').click(function (e) {
|
||
hideWOInvoiceAttachmentPopup();
|
||
}).keydown(resetwoinvoiceatttab);
|
||
|
||
function resetwoinvoiceatttab(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#dialog_woinvoice_attachment').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
|
||
$('.woinvoicemarkpaidpopus-close').click(function (e) {
|
||
hideWOInvoiceMakePaidPopup();
|
||
}).keydown();
|
||
|
||
$('.alertpopus-close').click(function (e) {
|
||
hideAlertPopup();
|
||
}).keydown(resettabs);
|
||
$('.nottrgalertpopus-close').click(function (e) {
|
||
hideAllPMSchedulePopup();
|
||
}).keydown(resettabs);
|
||
function resettabs(e) {
|
||
if (e.keyCode == 9) {
|
||
var input = $('#alertpopupdialog').find("input:not(:disabled),select:not(:disabled)").eq(0);
|
||
input.focus();
|
||
return false;
|
||
}
|
||
}
|
||
$('.emailpopus-close').click(function (e) {
|
||
hideSendEmailPopup();
|
||
}).keydown();
|
||
|
||
$('.icemailpopus-close').click(function (e) {
|
||
hideSendICEmailPopup();
|
||
}).keydown();
|
||
|
||
$('#dialog_nextfollowupdate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
if (new Date(date) < new Date(currentdate))
|
||
$('#dialog_nextfollowupdate').css("color", "red");
|
||
else
|
||
$('#dialog_nextfollowupdate').css("color", "unset");
|
||
}
|
||
});
|
||
|
||
$('#dialog_duedate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
}
|
||
});
|
||
$('#dialog_partsexpecteddate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
}
|
||
});
|
||
$('#dialog_lastlabordate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
}
|
||
});
|
||
|
||
$('#dialog_completeddate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
}
|
||
});
|
||
$('#dialog_segmentcompleteddate').datetimepicker({
|
||
timepicker: false,
|
||
format: 'm/d/Y',
|
||
enterLikeTab: false,
|
||
scrollInput: false,
|
||
onSelectDate: function (v, inp) {
|
||
var date = new DateFormatter().formatDate(v, 'm/d/Y 00:00:00');
|
||
inp.parent().data('val', [date]);
|
||
}
|
||
});
|
||
//$('#dialog_completeddate').change(function () {
|
||
// var date = $('#dialog_completeddate').val();
|
||
// if (date.length > 0 && checkDate(date)) {
|
||
// $('#dialog_status').dropdownVal('100');
|
||
// $('.span_required').show();
|
||
// }
|
||
//});
|
||
|
||
$('#span_viewatttype').click(function (ev) {
|
||
if ($('.panel_holder.attviewtypemenus').is(':visible')) {
|
||
return;
|
||
}
|
||
hidePanels();
|
||
var left = $(this).offset().left;
|
||
var top = $(this).offset().top;
|
||
$('.panel_holder.attviewtypemenus').css({
|
||
'opacity': 0,
|
||
'left': left + $(this).width() - $('.panel_holder.attviewtypemenus').width() / 2,
|
||
'right': 'auto',
|
||
'top': top + 20
|
||
}).show().animate({ 'opacity': 1 }, 100);
|
||
$('.panel_holder.attviewtypemenus .trigledown').css({
|
||
'left': left + $(this).width() - $('.panel_holder.attviewtypemenus').offset().left - 20,
|
||
'right': 'auto',
|
||
});
|
||
return false;
|
||
});
|
||
|
||
$('.span_vieuploadmsg').click(function (ev) {
|
||
if ($('.panel_holder.attuoloadmsgmenus').is(':visible')) {
|
||
return;
|
||
}
|
||
hidePanels();
|
||
var left = $(this).offset().left;
|
||
var top = $(this).offset().top;
|
||
$('.panel_holder.attuoloadmsgmenus').css({
|
||
'opacity': 0,
|
||
'left': left,
|
||
'right': 'auto',
|
||
'top': top + $(this).height() + 7
|
||
}).show().animate({ 'opacity': 1 }, 100);
|
||
$('.panel_holder.attuoloadmsgmenus .trigledown').css({
|
||
'left': left + $(this).width() - $('.panel_holder.attuoloadmsgmenus').offset().left - 14,
|
||
'right': 'auto'
|
||
});
|
||
return false;
|
||
});
|
||
|
||
$('#dialog_segmentcompleteddate').change(function () {
|
||
var date = $('#dialog_segmentcompleteddate').val();
|
||
if (date.length > 0 && checkDate(date)) {
|
||
$('#dialog_segmentcompleted').prop('checked', true);
|
||
}
|
||
});
|
||
|
||
$('#dialog_customer').prop('iframe', true).dialog(function () {
|
||
showmaskbg(false);
|
||
});
|
||
$("#txt_customer_key").keypress(onCustomerKeyPress);
|
||
|
||
$('#dialog_est_chksendtextmsg').change(function () {
|
||
var checked = $('#dialog_est_chksendtextmsg').prop('checked');
|
||
$('#dialog_est_phonenum').prop('disabled', !checked);
|
||
$('#dialog_est_chkIncludeStatusLink').prop('disabled', !checked);
|
||
$('#dialog_est_textmsg').prop('disabled', !checked);
|
||
});
|
||
|
||
$('#dialog_invoice_chksendtextmsg').change(function () {
|
||
var checked = $('#dialog_invoice_chksendtextmsg').prop('checked');
|
||
$('#dialog_invoice_phonenum').prop('disabled', !checked);
|
||
$('#dialog_invoice_chkIncludeStatusLink').prop('disabled', !checked);
|
||
$('#dialog_invoice_textmsg').prop('disabled', !checked);
|
||
});
|
||
|
||
function resizeContent() {
|
||
$('#divcontent').css('height', $(window).height() - $('#divcontent').offset().top - 4);
|
||
//$('#div_atts').css('height', $(window).height() - $('#divcontent').offset().top - 4);
|
||
$('#divinspections').css('height', $(window).height() - $('#divinspections').offset().top - 4);
|
||
$('.content_main').css('min-height', 0);
|
||
|
||
$("#dtcalertslist").css("height", $('#divdtcalerts').height() - $("#divdtcalerts").offset().top - 4);
|
||
grid_dtcalertdt && grid_dtcalertdt.resize();
|
||
$("#pmaalertslist").css("height", $('#divpmaalerts').height() - $("#divpmaalerts").offset().top - 4);
|
||
grid_pmaalertdt && grid_pmaalertdt.resize();
|
||
$("#inspectalertslist").css("height", $('#divinspectalerts').height() - $("#divinspectalerts").offset().top - 4);
|
||
grid_inspectalertdt && grid_inspectalertdt.resize();
|
||
$("#oilalertslist").css("height", $('#divoilalerts').height() - $("#divoilalerts").offset().top - 4);
|
||
grid_oilalertdt && grid_oilalertdt.resize();
|
||
$("#noneassignedalertlist").css("height", $('#alertpopupdialog').height() - $("#alertpopupdialog").offset().top - 4);
|
||
grid_noneassignedalertdt && grid_noneassignedalertdt.resize();
|
||
$("#allpmschedulelist").css("height", $('#allpmschedulepopupdialog').height() - $("#allpmschedulepopupdialog").offset().top - 4);
|
||
grid_pmschedulesdt && grid_pmschedulesdt.resize();
|
||
}
|
||
|
||
$("#li_segments").click(function () {
|
||
if (!$("#li_segments").data("dataload")) {
|
||
if (workorderid && workorderid !== '')
|
||
GetSegmentDataSource(getSegments);
|
||
else
|
||
GetSegmentDataSource();
|
||
$("#li_segments").data("dataload", true);
|
||
}
|
||
});
|
||
|
||
$("#li_attachments").click(function () {
|
||
if (!$("#li_attachments").data("dataload")) {
|
||
viewtype = getCookie("woattachmentviewtype");
|
||
getWorkOrderAttachments();
|
||
$("#li_attachments").data("dataload", true);
|
||
}
|
||
});
|
||
|
||
$("#li_inspections").click(function () {
|
||
if (!$("#li_inspections").data("dataload")) {
|
||
getWOInspectItems();
|
||
$("#li_inspections").data("dataload", true);
|
||
}
|
||
});
|
||
|
||
$("#li_estimates").click(function () {
|
||
if (!$("#li_estimates").data("dataload")) {
|
||
getEstimates();
|
||
$("#li_estimates").data("dataload", true);
|
||
}
|
||
});
|
||
|
||
$("#li_invoices").click(function () {
|
||
if (!$("#li_invoices").data("dataload")) {
|
||
getInvoices();
|
||
$("#li_invoices").data("dataload", true);
|
||
}
|
||
});
|
||
|
||
$("#dialog_invoice_status").change(function () {
|
||
var status = $("#dialog_invoice_status").val();
|
||
if (status == "6")
|
||
$("#tr_payment").show();
|
||
else
|
||
$("#tr_payment").hide();
|
||
|
||
if (status == "0" || status == "10")
|
||
$("#dialog_invoice_customervisible").prop('checked', false).attr('disabled', true);
|
||
else
|
||
$("#dialog_invoice_customervisible").attr('disabled', false);
|
||
});
|
||
|
||
$('#dialog_statuschange').dialog(function () {
|
||
showmaskbg(false);
|
||
});
|
||
|
||
if (!canExport) {
|
||
$('#btnExportReport').hide();
|
||
$('#btnPrint').hide();
|
||
$('#spPrint').hide();
|
||
$('#spDownload').hide();
|
||
}
|
||
|
||
$('#dialog_chksendtextmsg').change(function () {
|
||
var checked = $('#dialog_chksendtextmsg').prop('checked');
|
||
$('#txtphonenum_statuschange').prop('disabled', !checked);
|
||
$('#dialog_chkIncludeStatusLink').prop('disabled', !checked);
|
||
$('#dialog_textmsg').prop('disabled', !checked);
|
||
$('#dialog_variables').prop('disabled', !checked);
|
||
$('#dialog_insertfield').prop('disabled', !checked);
|
||
});
|
||
|
||
window.onresize = resizeContent;
|
||
resizeContent();
|
||
});
|
||
|
||
function insertfield() {
|
||
var field = $("#dialog_variables").find("option:selected").text();
|
||
$("#dialog_textmsg").focus();
|
||
document.execCommand('insertText', false, field);
|
||
}
|
||
|
||
function insertestfield() {
|
||
var field = $("#dialog_est_variables").find("option:selected").text();
|
||
$("#dialog_est_textmsg").focus();
|
||
document.execCommand('insertText', false, field);
|
||
}
|
||
|
||
function insertinvoicefield() {
|
||
var field = $("#dialog_invoice_variables").find("option:selected").text();
|
||
$("#dialog_invoice_textmsg").focus();
|
||
document.execCommand('insertText', false, field);
|
||
}
|
||
|
||
function onmsgreceived(data) {
|
||
console.log(JSON.stringify(data));
|
||
if (data.Message != workorderid)
|
||
return;
|
||
|
||
if (data && data.Code == "501")
|
||
loadworkorder(workorderid);
|
||
else if (data && data.Code == "502")
|
||
OnExit(0);
|
||
else if (data && (data.Code == "503" || data.Code == "504"))
|
||
getCommunications();
|
||
else if (data && (data.Code == "505"))
|
||
getComments();
|
||
else if (data && (data.Code == "506")) {
|
||
if (workorderid)
|
||
getWorkOrderContacts(workorderid);
|
||
}
|
||
else if (data && (data.Code == "507")) {
|
||
if (workorderid)
|
||
getWorkOrderFollowers(workorderid);
|
||
}
|
||
}
|
||
|
||
var loadingCount = 0;
|
||
function showLoading() {
|
||
loadingCount++;
|
||
$("#dialogattmask").show();
|
||
}
|
||
|
||
function hideLoading() {
|
||
loadingCount--;
|
||
if (loadingCount === 0)
|
||
$("#dialogattmask").hide();
|
||
}
|
||
|
||
function clearWorkOrderOther() {
|
||
$('#div_aatts').empty();
|
||
$('#div_woatts').empty();
|
||
$('#div_iatts').empty();
|
||
$('#woattslist_tbody').empty();
|
||
$('#woassetattslist_tbody').empty();
|
||
$('#woiptattslist_tbody').empty();
|
||
//attachment上传提示信息
|
||
$('.lable_attuploadname').empty();
|
||
$('.span_vieuploadmsg').hide();
|
||
$('.span_attupload').hide();
|
||
$('#attupload_ul').empty();
|
||
$('#divinspections').empty();
|
||
$('#tab_segments .segments_table').remove();
|
||
$('#tab_estimates .estimates_div').remove();
|
||
$('#tab_estimates .estimates_table').remove();
|
||
$('#tab_invoices .estimates_div').remove();
|
||
$('#tab_invoices .estimates_table').remove();
|
||
}
|
||
</script>
|
||
</asp:Content>
|
||
<asp:Content ID="Content2" ContentPlaceHolderID="ContentPlaceHolder1" runat="Server">
|
||
<div class="function_title">
|
||
<span class="sbutton iconsave" onclick="OnSave(0);" data-lgid="P_WO_SAVE">Save</span>
|
||
<span class="sbutton iconsave" onclick="OnSave(1);" data-lgid="P_WO_SAVE1">Save and Exit</span>
|
||
<span class="sbutton iconexit" onclick="OnExit(0);" data-lgid="P_WO_SAVE2">Exit Without Saving</span>
|
||
</div>
|
||
<div id="div_container">
|
||
<ul id="ul_container" class="tab_header">
|
||
<li id="li_workorder" data-href="tab_workorder" class="selected" data-lgid="P_WORKORDER">Work Order</li>
|
||
<li data-href="tab_alerts" onclick="reshowgrid();" data-lgid="P_WO_ALERTS">Alerts</li>
|
||
<li id="li_segments" data-href="tab_segments" data-lgid="P_WO_SEGMENTS">Segments</li>
|
||
<li id="li_attachments" data-href="tab_attachments" data-lgid="P_WO_ATTACHMENTS">Attachments</li>
|
||
<%if (AllowInspection)
|
||
{ %>
|
||
<li id="li_inspections" data-href="tab_inspections" data-lgid="P_WO_INSPECTIONS">Inspections</li>
|
||
<%} %>
|
||
<%if (AllowCustomer)
|
||
{ %>
|
||
<li id="li_estimates" data-href="tab_estimates" data-lgid="P_WO_ESTIMATES">Estimates</li>
|
||
<li id="li_invoices" data-href="tab_invoices" data-lgid="P_WO_INVOICES">Invoices</li>
|
||
<%} %>
|
||
</ul>
|
||
|
||
<div id="tab_workorder" data-page="tab_workorder">
|
||
<div id="divcontent" style="overflow: auto; min-width: 1610px;">
|
||
<div class="edit-content">
|
||
<div style="width: 920px;">
|
||
<div class="subtitle">
|
||
<table>
|
||
<tr>
|
||
<td style="width: 36px;">
|
||
<span class="sbutton iconchevrondown" id="spanasset" target="tbasset" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span></td>
|
||
<td><span data-lgid="P_WO_ASSETINFORMATION">Asset Information</span></td>
|
||
<td style="width: 400px;">
|
||
<div id="divwonumber" style="display: none; margin-left: 15px; color: black; font-weight: bold; font-size: 12px;">
|
||
<span data-lgid="P_WO_WORKORDERNUMBER_COLON">Work Order Number:</span>
|
||
<span id="dialog_wonumber"></span>
|
||
</div>
|
||
<div id="spanopenworkorders" style="display: none; margin-left: 15px; color: red; font-weight: bold; font-size: 12px;">
|
||
<span data-lgid="P_WO_OPENWORKORDERNUMBERS">Open Work Order Numbers:</span>
|
||
<span id="spanopenworkorderstext"></span>
|
||
</div>
|
||
</td>
|
||
<td style="width: 100px;">
|
||
<button id="input_emaildetails" onclick="openSendEmail();" style="width: unset;" data-lgid="P_WO_EMAILDETAILS">Email Details</button>
|
||
</td>
|
||
<td style="width: 60px;">
|
||
<button id="btnPrint" value="Print" onclick="OnPrint();" style="width: unset; margin-left: 10px;" data-lgid="P_WO_PRINT">Print</button>
|
||
</td>
|
||
<td id="tdExportReport" style="width: 80px;">
|
||
<button id="btnExportReport" value="Report" onclick="OnExportReport();" style="width: unset; margin-left: 10px;" data-lgid="P_WO_WORKORDERREPORT">Work Order Report</button>
|
||
</td>
|
||
<td></td>
|
||
</tr>
|
||
</table>
|
||
<hr />
|
||
</div>
|
||
<table class="workorder_table" id="tbasset">
|
||
<tr>
|
||
<td class="label">
|
||
<span data-lgid="P_WO_ASSET_COLON">Asset:</span><span class="redasterisk">*</span></td>
|
||
<td class="cont">
|
||
<span id="spassignedasset"></span>
|
||
<span class="sbutton iconsearch" id="btnSelectAsset" style="display: none;" data-title-lgid="P_MD_ASSETASSIGNMENT"></span>
|
||
</td>
|
||
<td class="label" style="width: 110px;"></td>
|
||
<td class="cont"></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_VIN_COLON">VIN:</td>
|
||
<td class="cont" id="dialog_vin"></td>
|
||
<td class="label" style="width: 110px;" data-lgid="P_WO_ASSETTYPE_COLON">Type:</td>
|
||
<td class="cont" id="dialog_type"></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_MAKE_COLON">Make:</td>
|
||
<td id="dialog_make"></td>
|
||
<td class="label" data-lgid="P_WO_MODEL_COLON">Model:</td>
|
||
<td id="dialog_model"></td>
|
||
</tr>
|
||
<tr id="trchours">
|
||
<td class="label" data-lgid="P_WO_CURRENTHOURS_COLON">Current Hours:</td>
|
||
<td id="dialog_chours" colspan="4"></td>
|
||
</tr>
|
||
<tr id="trcodometer" style="display: none;">
|
||
<td class="label" data-lgid="P_WO_CURRENTODOMETER_COLON">Current Odometer:</td>
|
||
<td id="dialog_codometer" colspan="4"></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_CURRJOBSITE_COLON">Current Jobsite:</td>
|
||
<td id="dialog_cjobsite"></td>
|
||
<td class="label" data-lgid="P_WO_CURRLOCATION_COLON">Current Location:</td>
|
||
<td id="dialog_clocation"></td>
|
||
</tr>
|
||
</table>
|
||
|
||
<div class="subtitle contactinfo" style="display: none;">
|
||
<span class="sbutton iconchevronright" id="spancustomer" target="tbcustomer" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_CONTACTINFORMATION">Contact Information</span>
|
||
<hr />
|
||
</div>
|
||
<table class="workorder_table" style="display: none;" id="tbcustomer">
|
||
<tr>
|
||
<td class="label" data-lgid="P_CR_COMPANYNAME_COLON" style="white-space: nowrap;">Company Name:</td>
|
||
<td>
|
||
<span id="dialog_custcustomername"></span>
|
||
<%if (!CRReadOnly)
|
||
{%>
|
||
<span class="sbutton iconsearch" id="btnaddcustomer" onclick="onSelectCustomer()" data-title-lgid="P_WO_CONTACTINFORMATION" title="Select Customer"></span>
|
||
<%}%>
|
||
<div style="float: right;">
|
||
<span class="label" data-lgid="P_CR_COMPANYCODE_COLON" style="white-space: nowrap;">Company Code:</span>
|
||
<span id="dialog_custcustomercode"></span>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
<tr id="traddcontact">
|
||
<td colspan="2" style="padding-left: 135px;">
|
||
<%if (!CRReadOnly)
|
||
{%>
|
||
<span class="sbutton iconadd" onclick="onAddContact()" data-lgid="P_CR_ADDCONTACT">Add Contact</span>
|
||
<%}%>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td colspan="2" style="padding-left: 135px;">
|
||
<div id="cusomercontactlist" style="height: 190px; width: 792px;"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<div class="subtitle contactinfo" style="display: none;">
|
||
<span class="sbutton iconchevronright" id="spanfollower" target="tbfollower" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_XXXXXX">Following</span>
|
||
<hr />
|
||
</div>
|
||
<table class="workorder_table" style="display: none;" id="tbfollower">
|
||
<tr id="traddfollower">
|
||
<td colspan="2" style="padding-left: 135px;">
|
||
<%if (!CRReadOnly)
|
||
{%>
|
||
<span class="sbutton iconadd" onclick="onAddFollower()" data-lgid="P_CR_ADDCONTACT">Add Contact</span>
|
||
<%}%>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td colspan="2" style="padding-left: 135px;">
|
||
<div id="followerlist" style="height: 190px; width: 784px;"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<div class="subtitle">
|
||
<span class="sbutton iconchevrondown" id="spansummary" target="tbsummary" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_SUMMARY">Summary</span>
|
||
<hr />
|
||
</div>
|
||
<table class="workorder_table" id="tbsummary" style="position: relative">
|
||
<tr>
|
||
<td class="label"></td>
|
||
<td class="cont"></td>
|
||
<td class="label"></td>
|
||
<td class="cont"></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" style="vertical-align: top;">
|
||
<span data-lgid="P_WO_DESCRIPTION_COLON">Description:</span><span class="redasterisk">*</span></td>
|
||
<td colspan="3">
|
||
<textarea id="dialog_description" class="inputbox" maxlength="1000" tabindex="2" style="width: 703px; height: 80px;"></textarea></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_INSPECTIONREQUIRED_COLON">Inspection Required:</td>
|
||
<td class="cont">
|
||
<div style="float: left; width: 30px;">
|
||
<input type="checkbox" id="dialog_inspectionrequired" style="width: auto; margin-left: 5px;" tabindex="2" />
|
||
</div>
|
||
<div style="float: left;">
|
||
<div id="dialog_isptemplate" tabindex="2" class="dropdown" style="width: 210px;"></div>
|
||
</div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_INSPECTIONCOMPLETED_COLON">Inspection Completed:</td>
|
||
<td class="cont">
|
||
<label id="dialog_inspectioncount" style="font-weight: bold;"></label>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_STATUS_COLON">Status:</td>
|
||
<td>
|
||
<div id="dialog_status" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_ASSIGNEDTO_COLON">Assigned To:</td>
|
||
<td>
|
||
<div id="dialog_assignto" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label">
|
||
<span data-lgid="P_WO_COMPLETEDDATE_COLON">Completed Date:</span><span class="span_required redasterisk" style="display: none;">*</span>
|
||
</td>
|
||
<td>
|
||
<input type="text" id="dialog_completeddate" class="inputbox" maxlength="200" tabindex="2" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_DUEDATE_COLON">Due Date:</td>
|
||
<td>
|
||
<input type="text" id="dialog_duedate" tabindex="2" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_METERTYPE_COLON">Meter Type:</td>
|
||
<td>
|
||
<div id="dialog_metertype" tabindex="3" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_WORKORDERTYPE_COLON">Work Order Type:</td>
|
||
<td>
|
||
<div id="dialog_wotype" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr id="tr_hourmeter">
|
||
<td class="label">
|
||
<span data-lgid="P_WO_HOURMETER_COLON">Hour Meter:</span><span class="span_required redasterisk" style="display: none;">*</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_hourmeter" class="inputbox" maxlength="12" tabindex="3" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Parts Order Number:</td>
|
||
<td>
|
||
<input type="text" id="dialog_partsordernumber" tabindex="2" class="inputbox" maxlength="50" autocomplete="off" />
|
||
</td>
|
||
</tr>
|
||
<tr id="tr_odometer">
|
||
<td class="label">
|
||
<span data-lgid="P_WO_ODOMETER_COLON">Odometer:</span><span class="span_required redasterisk" style="display: none;">*</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_odometer" disabled="disabled" class="inputbox" maxlength="12" tabindex="3" style="width: 147px;" autocomplete="off" />
|
||
<div id="dig_odometeruom" style="width: 90px; display: inline-block" tabindex="3" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Parts Status:</td>
|
||
<td>
|
||
<div id="dialog_partsstatus" tabindex="3" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_LOCATION_COLON">Location:</td>
|
||
<td>
|
||
<div id="dialog_location" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_COMPONENT_COLON">Component:</td>
|
||
<td>
|
||
<div id="dialog_wocomponent" tabindex="3" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_DEPARTMENT_COLON">Department:</td>
|
||
<td>
|
||
<div id="dialog_department" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_PARTSEXPECTEDDATE_COLON">Parts Expected Date:</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_partsexpecteddate" tabindex="2" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ADVISOR_COLON">Advisor:</td>
|
||
<td>
|
||
<%--<input type="text" id="dialog_advisor" class="inputbox" maxlength="50" tabindex="2" autocomplete="off" />--%>
|
||
<div id="dialog_advisor" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_NEXTFOLLOWUPDATE_COLON">Next Follow Up Date:</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_nextfollowupdate" tabindex="2" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_XXX">Salesperson:</td>
|
||
<td colspan="3">
|
||
<div id="dialog_salesperson" tabindex="2" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"><span class="alternatestatus" style="display: none;" data-lgid="P_WO_ALTERNATESTATUS_COLON">Alternate Status:</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_alternatestatus" style="display: none;" class="inputbox alternatestatus" maxlength="30" tabindex="2" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_LASTLABORDATE_COLON">Last Labor Date:</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_lastlabordate" tabindex="2" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_NOTES_COLON" style="vertical-align: top;">Notes:</td>
|
||
<td colspan="3">
|
||
<textarea id="dialog_notes" class="inputbox" maxlength="500" tabindex="3" style="width: 703px; height: 80px;"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
|
||
<div class="subtitle">
|
||
<span class="sbutton iconchevronright" id="spancost" target="tbcost" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_COST">Cost</span>
|
||
<hr />
|
||
</div>
|
||
<table class="workorder_table" id="tbcost" style="display: none; position: relative;">
|
||
<tr>
|
||
<td class="label" data-lgid="P_PM_EXPECTEDCOST_COLON">Expected Cost:</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_expectedcost" disabled="disabled" class="inputbox" maxlength="12" tabindex="3" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_WORKORDERTOTALCOST_COLON">Work Order Total Cost ($):</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_workordercosts" class="inputbox" maxlength="12" tabindex="3" disabled="disabled" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_OTHERCOST_COLON">Other Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_othercost" class="inputbox" maxlength="12" tabindex="3" onblur="getTotalCost();" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_PARTSCOST_COLON">Parts Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_partscost" class="inputbox" maxlength="12" tabindex="3" onblur="getTotalCost();" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_TRAVELTIMECOST_COLON">Travel Time Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_traveltimecost" class="inputbox" maxlength="12" tabindex="3" onblur="getTotalCost();" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_LABORCOST_COLON">Labor Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_laborcost" class="inputbox" maxlength="12" tabindex="3" disabled="disabled" onblur="getTotalCost();" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_HOURLYRATE_COLON">Hourly Rate:</td>
|
||
<td>
|
||
<input type="text" id="dialog_hourlyrate" class="inputbox" maxlength="12" tabindex="3" disabled="disabled" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_TIMETOCOMPLATEHOURS_COLON">Time To Complete(Hrs):</td>
|
||
<td>
|
||
<input type="text" id="dialog_timetocomplete" class="inputbox" maxlength="12" tabindex="3" onblur="getLaborCost(false,true);" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_INVOICENUMBER_COLON">Invoice Number:</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoicenumber" class="inputbox" maxlength="50" tabindex="3" autocomplete="off" />
|
||
<%--<select id="dialog_invoicenumber" tabindex="3" style="height: 22px; width: 244px;"></select>--%>
|
||
</td>
|
||
<%if (AllowCustomer)
|
||
{ %>
|
||
<td class="label" data-lgid="P_WO_ESTIMATESTATUS_COLON">Estimate Status:</td>
|
||
<td>
|
||
<span id="dialog_estimatestatus"></span></td>
|
||
<%} %>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_INTERNALID_COLON">Internal ID:</td>
|
||
<td>
|
||
<input type="text" id="dialog_internalid" class="inputbox" maxlength="50" tabindex="2" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Billable:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_billable" tabindex="3" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Bill to job:</td>
|
||
<td>
|
||
<div id="dialog_billtojob" tabindex="3" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div style="position: absolute; left: 930px; top: 66px; bottom: 10px; width: 670px; min-height: 600px;">
|
||
<div id="communication_holder" style="position: absolute; left: 0; top: 10px; bottom: 0; display: flex"></div>
|
||
</div>
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="tab_alerts" data-page="tab_alerts">
|
||
<%-- <div class="function_title">
|
||
<span class="sbutton iconadd" id="span_addalerts" onclick="OnAddAlerts();" data-lgid="P_WO_ADDALERTS">Add Alerts</span>
|
||
<span class="sbutton icondelete" id="span_removealerts" onclick="OnRemoveAlerts();" data-lgid="P_WO_REMOVEALERTS">Remove Alerts</span>
|
||
</div>
|
||
<div class="clear"></div>
|
||
<div id="divdtcalerts" style="height: 260px; display: none;">
|
||
<div class="subtitle">
|
||
<span data-lgid="P_WO_DTCALERTS">DTC Alerts</span>
|
||
</div>
|
||
<div id="dtcalertslist" style="border-bottom:1px solid #aaa;">
|
||
</div>
|
||
</div>
|
||
|
||
<div id="divpmaalerts" style="height: 260px;">
|
||
<div class="subtitle">
|
||
<span data-lgid="P_WO_PMALERTS">PM Alerts</span>
|
||
<span class="sbutton iconadd" id="btnaddpmalerts" style="color: black;" onclick="OnAddAllPMSchedules();" data-lgid="P_WO_ADDPMALERTS">Add PM Alerts (Alerts not yet triggered)</span>
|
||
</div>
|
||
<div id="pmaalertslist" style="border-bottom:1px solid #aaa;">
|
||
</div>
|
||
</div>
|
||
|
||
<div id="divinspectalerts" style="height: 260px; display: none;">
|
||
<div class="subtitle">
|
||
<span data-lgid="P_WO_INSPECTALERTS">Inspect Alerts</span>
|
||
</div>
|
||
<div id="inspectalertslist" style="border-bottom:1px solid #aaa;">
|
||
</div>
|
||
</div>
|
||
<div id="divoilalerts" style="height: 260px; display: none;">
|
||
<div class="subtitle">
|
||
<span data-lgid="P_WO_OILALERTS">Oil Alerts</span>
|
||
</div>
|
||
<div id="oilalertslist" style="border-bottom:1px solid #aaa;">
|
||
</div>
|
||
</div>--%>
|
||
</div>
|
||
|
||
<div id="tab_segments" data-page="tab_segments">
|
||
<%-- <div class="function_title">
|
||
<span class="sbutton iconadd" onclick="OnAddSegment();" data-lgid="P_WO_ADDSEGMENT">Add Segment</span>
|
||
</div>--%>
|
||
</div>
|
||
|
||
<div id="tab_attachments" data-page="tab_attachments">
|
||
<%--<div class="function_title">
|
||
<span class="sbutton iconadd" onclick="UpLoadWorkOrderAttachment();" data-lgid="P_WO_ADDFILE">Add File</span>
|
||
<span id="spPrint" class="sbutton iconprint" onclick="openPAndDGDialog(0);" data-lgid="P_WO_PRINT">Print</span>
|
||
<span id="spDownload" class="sbutton icondownload" onclick="openPAndDGDialog(1);" data-lgid="P_WO_DOWNLOAD">Download</span>
|
||
<span class="sbutton iconviewatt" id="span_viewatttype" data-lgid="P_WO_XXX">View</span>
|
||
</div>
|
||
<div class="panel_holder attviewtypemenus">
|
||
<div id="attviewtypemenu_panel" class="panel" style="min-width: 150px; background-color: white;">
|
||
<ul class="lefttitlemenu_ul">
|
||
<li onclick="onViewAttachment(0);" style="line-height: 32px;">
|
||
<a style="padding-left: 0;">
|
||
<span class="spanbtn iconlarge" style="padding: 6px; width: auto; font-size: 14px;"></span>
|
||
<span style="padding-left: 6px;" data-lgid="P_WO_XXX">Large</span></a></li>
|
||
<li onclick="onViewAttachment(1);" style="line-height: 32px;">
|
||
<a style="padding-left: 0;">
|
||
<span class="spanbtn iconlist" style="padding: 6px; width: auto; font-size: 14px;"></span>
|
||
<span style="padding-left: 6px;" data-lgid="P_WO_XXX">List</span></a></li>
|
||
</ul>
|
||
<div class="trigledown"></div>
|
||
<div class="trigledown white"></div>
|
||
</div>
|
||
</div>
|
||
<div id="dialogattdragmask" class="maskbg" style="display: none; z-index: 501;"></div>
|
||
<div id="div_attlarge">
|
||
<table id="tb_woattlarge" class="main_table maintenance" ondrop="dropWOAttachment(event)" ondragover="dragOverWOAttachment(event)" onpaste="cutWOAttachment(event)">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woaatts_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_WORKORDERATTACHMENTS">Work Order Attachments</span>
|
||
</td>
|
||
</tr>
|
||
<tr id="woaatts_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<div id="div_woatts" style="min-height: 80px; overflow: auto; padding-left: 20px;"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
<table class="main_table maintenance">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woassetatts_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_ASSETATTACHMENTS">Asset Attachments</span>
|
||
</td>
|
||
</tr>
|
||
<tr id="woassetatts_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<div id="div_aatts" style="min-height: 80px; overflow: auto; padding-left: 20px;">
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<table class="main_table maintenance">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woiptatts_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_INSPECTIONATTACHMENTS">Inspection Attachments</span>
|
||
</td>
|
||
</tr>
|
||
<tr id="woiptatts_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<div id="div_iatts" style="min-height: 80px; overflow: auto; padding-left: 20px;">
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div id="div_attlist" style="display: none;">
|
||
<table class="main_table maintenance" ondrop="dropWOAttachment(event)" ondragover="dragOverWOAttachment(event)" onpaste="cutWOAttachment(event)">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woattslist_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_WORKORDERATTACHMENTS">Work Order Attachments</span>
|
||
<lable class="lable_attuploadname" style="margin-left: 200px;"></lable>
|
||
</td>
|
||
</tr>
|
||
<tr id="woattslist_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<table class="table_intervals">
|
||
<thead>
|
||
<tr>
|
||
<th style="width: 30px;"></th>
|
||
<th style="width: 60px;"></th>
|
||
<th style="width: 400px; padding-left: 20px;" data-lgid="P_WO_XXX">Caption</th>
|
||
<th style="width: 130px;" data-lgid="P_WO_AVAILABLETOCUSTOMER"></th>
|
||
<th class="td_funcs"></th>
|
||
</tr>
|
||
</thead>
|
||
<tbody id="woattslist_tbody">
|
||
</tbody>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<table class="main_table maintenance">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woassetattslist_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_ASSETATTACHMENTS">Asset Attachments</span>
|
||
</td>
|
||
</tr>
|
||
<tr id="woassetattslist_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<table class="table_intervals">
|
||
<thead>
|
||
<tr>
|
||
<th style="width: 30px;"></th>
|
||
<th style="width: 60px;"></th>
|
||
<th style="width: 400px; padding-left: 20px;" data-lgid="P_WO_XXX">Caption</th>
|
||
<th style="width: 130px;"></th>
|
||
<th class="td_funcs"></th>
|
||
</tr>
|
||
</thead>
|
||
<tbody id="woassetattslist_tbody">
|
||
</tbody>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
|
||
<table class="main_table maintenance">
|
||
<tr style="line-height: 35px;">
|
||
<td class="subtitle">
|
||
<span class="sbutton iconchevrondown woattafoldicon" target="woiptattslist_tr" onclick="OnExpend(this)" style="margin-left: 0; padding-right: 5px;"></span>
|
||
<span data-lgid="P_WO_INSPECTIONATTACHMENTS">Inspection Attachments</span>
|
||
</td>
|
||
</tr>
|
||
<tr id="woiptattslist_tr" class="tr_intervals woattafoldtr">
|
||
<td>
|
||
<table class="table_intervals">
|
||
<thead>
|
||
<tr>
|
||
<th style="width: 30px;"></th>
|
||
<th style="width: 60px;"></th>
|
||
<th style="width: 400px; padding-left: 20px;" data-lgid="P_WO_XXX">Caption</th>
|
||
<th style="width: 130px;"></th>
|
||
<th class="td_funcs"></th>
|
||
</tr>
|
||
</thead>
|
||
<tbody id="woiptattslist_tbody">
|
||
</tbody>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="panel_holder attuoloadmsgmenus">
|
||
<div id="attuplodmsg_panel" class="panel" style="min-width: 150px; background-color: white; max-width: 480px; max-height: 400px;">
|
||
<ul class="lefttitlemenu_ul" id="attupload_ul">
|
||
</ul>
|
||
<div class="trigledown"></div>
|
||
<div class="trigledown white"></div>
|
||
</div>
|
||
</div>--%>
|
||
</div>
|
||
|
||
<div id="tab_inspections" data-page="tab_inspections">
|
||
<div id="divinspections" style="overflow: auto; min-width: 1610px; height: 668px;">
|
||
</div>
|
||
</div>
|
||
|
||
<div id="tab_estimates" class="edit-content" data-page="tab_estimates">
|
||
<%--<div class="function_title">
|
||
<span class="sbutton iconadd" onclick="OnAddEstimate();" data-lgid="P_WO_ADDESTIMATE">Add Estimate</span>
|
||
</div>--%>
|
||
</div>
|
||
|
||
<div id="tab_invoices" class="edit-content" data-page="tab_invoices">
|
||
<%-- <div class="function_title">
|
||
<span class="sbutton iconadd" onclick="OnAddInvoice();" data-lgid="P_WO_ADDINVOICE">Add Invoice</span>
|
||
</div>--%>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="mask_bg" style="display: none;">
|
||
<div class="loading c-spin"></div>
|
||
</div>
|
||
<div id="popupmask" class="maskbg" style="display: none;"></div>
|
||
<div id="popupdialog" class="dialog" style="display: none;">
|
||
<div class="dialog-title"><span class="title" id="popupTitle" data-lgid="P_WO_ADDSEGMENT">Add Segment</span><em class="popus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 28px;">
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_USER_COLON">User:</td>
|
||
<td>
|
||
<div id="dialog_segmentuser" tabindex="101" style="width: 320px" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_HOURS_COLON">Hours:</td>
|
||
<td>
|
||
<input type="text" id="dialog_segmenthour" tabindex="102" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_JOBSITE_COLON">Jobsite:</td>
|
||
<td>
|
||
<div id="dialog_segmentjobsite" tabindex="103" style="width: 320px" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_COST_COLON">Cost:</td>
|
||
<td>
|
||
<input type="text" id="dialog_segmentcost" tabindex="104" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Segment Type:</td>
|
||
<td>
|
||
<div id="dialog_segmenttype" tabindex="104" style="width: 320px" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_COMPONENT_COLON">Component:</td>
|
||
<td>
|
||
<div id="dialog_segmentcomponent" tabindex="104" style="width: 320px" class="dropdown"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Billable:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_segmentbillable" tabindex="105" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_COMPLETED_COLON">Completed:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_segmentcompleted" tabindex="105" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_COMPLETEDDATE_COLON">Completed Date:</td>
|
||
<td>
|
||
<input type="text" id="dialog_segmentcompleteddate" tabindex="106" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"><span data-lgid="P_WO_DESCRIPTION_COLON">Description:</span><span class="redasterisk">*</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_segmentdesc" tabindex="107" class="inputbox" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_NOTES_COLON">Notes:</td>
|
||
<td>
|
||
<textarea id="dialog_segmentnotes" class="inputbox" maxlength="1000" tabindex="108" style="width: 540px; height: 120px;"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="popus-close" tabindex="110" style="margin-right: 30px;" />
|
||
<input type="button" id="btn_savesegment" onclick="SaveSegment('');" value="OK" data-lgid="P_WO_OK" tabindex="109" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="alertpopupmask" class="maskbg" style="display: none;"></div>
|
||
<div id="alertpopupdialog" class="dialog" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ADDALERTS">Add Alerts</span><em class="alertpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<div id="noneassignedalertlist" style="width: 820px; height: 120px;">
|
||
</div>
|
||
</div>
|
||
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="alertpopus-close" tabindex="53" style="margin-right: 30px;" />
|
||
<input type="button" onclick="OnSaveAlerts();" value="OK" data-lgid="P_WO_OK" tabindex="52" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="sendemailpopupmask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="sendemailpopupdialog" style="display: none; width: 480px;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_SENDWORKORDER">Send Work Order</span><em class="emailpopus-close"></em></div>
|
||
<div class="dialog-content" style="height: 430px;">
|
||
<table>
|
||
<tr>
|
||
<td data-lgid="P_WO_SENDTHISTO">Who do you want to send this to? Select from existing relationships or manual entry.</td>
|
||
</tr>
|
||
<tr>
|
||
<td colspan="2">
|
||
<input type="text" id="sendworkorder_search" style="width: 445px; margin-left: 10px;" placeholder="Search" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div id="contactlist" style="height: 240px; width: 420px; margin-left: 10px; margin-right: 10px;"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td data-lgid="P_WO_EMAILADDRESSESTIPS">Separate multiple manually entered email addresses with a semi-colon (;).</td>
|
||
</tr>
|
||
<tr>
|
||
<td><span data-lgid="P_WO_OTHEREMAILADDRESS">Other Email Address</span>
|
||
<input type="text" id="sendworkorder_otheremailaddress" style="width: 312px;" autocomplete="off" /></td>
|
||
</tr>
|
||
<%-- <tr>
|
||
<td><span>Other Text Address</span>
|
||
<input type="text" id="sendlocation_othertextaddress" style="width: 312px; margin-left: 7px;" autocomplete="off" />
|
||
</td>
|
||
</tr>--%>
|
||
<tr>
|
||
<td data-lgid="P_WO_DESCRIPTION_COLON">Description:</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<textarea id="sendworkorder_desc" style="width: 410px; height: 80px; resize: none; margin-left: 12px;" tabindex="151"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="emailpopus-close" tabindex="153" />
|
||
<input type="button" onclick="onSendWorkOrder();" value="OK" data-lgid="P_WO_OK" tabindex="152" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
|
||
<div id="sendicemailpopupmask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="sendicemailpopupdialog" style="display: none; width: 485px;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_SENDINTERNALCOMMENTS">Send Internal Comments</span><em class="icemailpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 25px;">
|
||
<tr>
|
||
<td data-lgid="P_WO_SENDTHISTO">Who do you want to send this to? Select from existing relationships or manual entry.</td>
|
||
</tr>
|
||
<tr>
|
||
<td colspan="2">
|
||
<input type="text" id="sendinternalcomments_search" style="width: 445px; margin-left: 10px;" placeholder="Search" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div id="iccontactlist" style="height: 240px; width: 440px; margin-left: 10px; margin-right: 10px;"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td data-lgid="P_WO_EMAILADDRESSESTIPS">Separate multiple manually entered email addresses with a semi-colon (;).</td>
|
||
</tr>
|
||
<tr>
|
||
<td><span data-lgid="P_WO_OTHEREMAILADDRESS">Other Email Address</span>
|
||
<input type="text" id="sendic_otheremailaddress" style="width: 332px;" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td><span data-lgid="P_WO_PHONENUMBER">Phone Number</span>
|
||
<input type="text" id="sendic_phonenumber" style="width: 353px; margin-left: 7px;" autocomplete="off" />
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="icemailpopus-close" tabindex="153" />
|
||
<input type="button" onclick="onSendInternalComments();" value="OK" data-lgid="P_WO_OK" tabindex="152" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
|
||
<div id="addfollowerpopupmask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="addfollowerpopupdialog" style="display: none; width: 560px;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_XXXXXX">Add Followers</span><em class="dialog-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 25px;">
|
||
<tr>
|
||
<td data-lgid="P_WO_XXXXXX">Who do you want to receive customer notifications?</td>
|
||
</tr>
|
||
<tr>
|
||
<td colspan="2">
|
||
<input type="text" id="selfollower_search" style="width: 445px; margin-left: 10px;" placeholder="Search" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div id="allfollowerlist" style="height: 240px; width: 520px; margin-left: 10px; margin-right: 10px;"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="dialog-close" tabindex="153" />
|
||
<input type="button" onclick="onSelectFollowers();" value="OK" data-lgid="P_WO_OK" tabindex="152" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<div id="allpmschedulepopupmask" class="maskbg" style="display: none;"></div>
|
||
<div id="allpmschedulepopupdialog" class="dialog" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_SELECTPLANFORALERT">Select Plan for Alert</span><em class="nottrgalertpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<div id="allpmpmalertslist" style="width: 420px; height: 200px;">
|
||
</div>
|
||
</div>
|
||
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="nottrgalertpopus-close" tabindex="53" style="margin-right: 30px;" />
|
||
<input type="button" onclick="GenerateManualPMAlerts();" value="OK" data-lgid="P_WO_OK" tabindex="52" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="dialog" id="dialog_customercontact" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_CR_ADDCONTACT">Add Contact</span><em class="dialog-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; table-layout: fixed; width: 480px;">
|
||
<tr>
|
||
<td class="label"><span data-lgid="P_CR_CONTACTNAME_COLON">Contact Name:</span><span class="redasterisk">*</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_contactname" tabindex="1" maxlength="200" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_CR_CONTACTPREFERENCES_COLON">Contact Preferences:</td>
|
||
<td>
|
||
<div id="dialog_contactpreference" tabindex="1" class="dropdown" style="width: 320px"></div>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_CR_EMAILADDRESS_COLON">Email Address:</td>
|
||
<td>
|
||
<input type="text" id="dialog_emailaddress" tabindex="1" maxlength="100" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_UM_MOBILE_COLON">Mobile:</td>
|
||
<td>
|
||
<input type="text" id="dialog_mobile" tabindex="1" maxlength="50" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr style="display: none;">
|
||
<td class="label" data-lgid="P_UM_ADDRESS_COLON">Address:</td>
|
||
<td>
|
||
<input type="text" id="dialog_address" tabindex="1" maxlength="500" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_CR_XXXXXX">Opt Out:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_optout" tabindex="1" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_CR_NOTES_COLON">Notes:</td>
|
||
<td>
|
||
<textarea id="dialog_contactnotes" tabindex="1" style="width: 320px; height: 100px; margin-top: 6px;" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="dialog-close" tabindex="18" style="height: 26px;" />
|
||
<input type="button" onclick="onSaveContact(0);" value="Work Order Only" data-lgid="P_WO_WORKORDERONLY" tabindex="17" />
|
||
<input type="button" id="btn_contactrecord" onclick="onSaveContact(1);" style="display: none;" value="Add Contact Record" data-lgid="P_WO_ADDCONTACTRECORD" tabindex="17" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" id="contatcmask" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div class="dialog" id="dialog_customer" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_SELECTCUSTOMER">Select Customer</span><em class="dialog-close"></em></div>
|
||
<div class="dialog-content">
|
||
<div style="position: relative; width: 500px; margin-top: 4px; float: left">
|
||
<input type="text" placeholder="Search" id="txt_customer_key" disabled="disabled" autocomplete="off" style="width: 100%; padding-right: 28px; height: 25px; line-height: 25px; box-sizing: border-box; text-indent: 4px;" />
|
||
<div style="position: absolute; top: 0px; right: 0px; height: 25px; width: 28px; text-align: center; line-height: 25px; font-size: 1.2em; font-family: FontAwesome; font-weight: 900; color: rgb(123, 28, 33); cursor: pointer;" onclick="GetCustomerList()"></div>
|
||
</div>
|
||
<div style="float: left; margin-top: 10px;">
|
||
<input id="chkshowallcust" type="checkbox" onclick="GetCustomerList();" style="margin-left: 20px;" /><label for="chkshowallcust" data-lgid="P_WO_SHOWALLCUSTOMER">Show All Customer</label>
|
||
</div>
|
||
<div style="float: left; margin-top: 10px;">
|
||
<span class="sbutton iconadd" onclick="OnAddCustomer()" data-lgid="P_CR_ADDCUSTOMER">Add Customer</span>
|
||
</div>
|
||
<div style="clear: both;"></div>
|
||
<div id="customerlist" style="height: 400px; width: 750px; margin: 10px 0 4px;"></div>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="dialog-close" tabindex="18" style="height: 26px;" />
|
||
<input type="button" onclick="OnSetSelectCustomer();" value="OK" data-lgid="P_UM_OK" tabindex="17" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div class="dialog" id="dialog_addcustomer" style="display: none; height: 100%; border-bottom: 0; border-top: 0;">
|
||
<iframe id="iframeuser" src="AddCustomerRecord.aspx" style="width: 100%; height: 100%; display: block; border: none;"></iframe>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popupestimatemask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_estimate" style="display: none;" ondrop="dropAddEstimateAttachment(event)" ondragover="dragOverAddEstimateAttachment(event)" onpaste="cutAddEstimateAttachment(event)">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ADDESTIMATE">Add Estimate</span><em class="estpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ESTIMATENUMBER_COLON">Estimate #:</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_number" tabindex="1" class="inputbox" maxlength="50" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_ESTIMATESTATUS_COLON">Estimate Status:</td>
|
||
<td>
|
||
<span id="dialog_est_status"></span></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ESTIMATETOTALCOST_COLON">Estimate Total Cost ($):</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_est_totalcosts" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" />
|
||
<span class='sbutton iconequel' style="padding: 3px 1px 3px 6px; font-size: 12px;" onclick="getEstimateTotalCost('');" data-title-lgid="P_WO_CALCULATINGTOTALS"></span>
|
||
</td>
|
||
<td class="label" data-lgid="P_WO_OTHERCOST_COLON">Other Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_othercost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_PARTSCOST_COLON">Parts Cost ($):</td>
|
||
<td style="display: inline-flex;">
|
||
<input type="text" id="dialog_est_partscost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_TRAVELTIMECOST_COLON">Travel Time Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_traveltimecost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_LABORCOST_COLON">Labor Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_laborcost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_TIMETOCOMPLATEHOURS_COLON">Time To Complete(Hrs):</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_timetocomplete" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_TAXES_COLON">Taxes ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_taxes" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_XXX">PO Required:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_est_porequired" style="width: auto;" tabindex="1" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_CUSTOMERISSUES_COLON" style="vertical-align: top;">Customer Issues:</td>
|
||
<td colspan="3">
|
||
<textarea id="dialog_est_custissues" tabindex="1" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_TECHNICIANNOTES_COLON" style="vertical-align: top;">Technician Notes:</td>
|
||
<td colspan="3">
|
||
<textarea id="dialog_est_technotes" tabindex="1" maxlength="500"></textarea></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ATTACHMENTS_COLON" style="vertical-align: top;">Attachments:</td>
|
||
<td colspan="3">
|
||
<span class="sbutton iconadd" onclick="openWOEstAttachmentDialog('');" data-lgid="P_WO_ADDFILE">Add File</span>
|
||
<%--<input id="dialog_est_uploadattfile" type="button" value="Add File..." data-lgid="P_FR_ADDFILE" onclick="openWOEstAttachmentDialog('')" tabindex="1" style="background-color: #0099FF; color: #FFFFFF; height: 20px; width: 200px;" />--%>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"></td>
|
||
<td colspan="3">
|
||
<table id="tab_est_attachments" style="border: 1px solid #a8a8a8; line-height: 25px; width: 450px; display: none;">
|
||
<tr>
|
||
<td>
|
||
<div class="content_main" style="max-height: 80px; overflow: auto;">
|
||
<table id="tab_est_atts" style="table-layout: fixed;"></table>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="estpopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" onclick="openPublishDialog(-1);" value="Publish" data-lgid="P_WO_PUBLISH" tabindex="11" />
|
||
<input type="button" id="btn_estimatesave" onclick="onSaveWorkOrderEstimate('');" value="Save As Draft" data-lgid="P_WO_XXX" tabindex="11" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popupinvoicemask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_invoice" style="display: none;" ondrop="dropAddInvoiceAttachment(event)" ondragover="dragOverAddInvoiceAttachment(event)" onpaste="cutAddInvoiceAttachment(event)">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ADDINVOICE">Add Invoice</span><em class="invoice-popup-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_INVOICENUMBER">Invoice #:</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_number" tabindex="1" class="inputbox" maxlength="50" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_OTHERCOST_COLON">Other Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_othercost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_INVOICETOTALCOST">Invoice Total Cost ($):</td>
|
||
<td class="cont">
|
||
<input type="text" id="dialog_invoice_totalcosts" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_TRAVELTIMECOST_COLON">Travel Time Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_traveltimecost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_PARTSCOST_COLON">Parts Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_partscost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_TAXES_COLON">Taxes ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_taxes" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_LABORCOST_COLON">Labor Cost ($):</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_laborcost" class="inputbox" maxlength="12" tabindex="1" autocomplete="off" /></td>
|
||
<td class="label" data-lgid="P_WO_INVOICESTATUS">Invoice Status:</td>
|
||
<td>
|
||
<select id="dialog_invoice_status" style="width: 150px; height: 24px;">
|
||
<option value="0">Draft</option>
|
||
<option value="1">Awaiting Payment</option>
|
||
<option value="6">Paid</option>
|
||
<option value="10">Revoked</option>
|
||
</select></td>
|
||
</tr>
|
||
<tr id="tr_payment">
|
||
<td class="label" data-lgid="P_WO_XXXXXX">Payment By:</td>
|
||
<td>
|
||
<select id="dialog_invoice_paymentby" style="width: 150px; height: 24px;">
|
||
<option value="Credit Card">Credit Card</option>
|
||
<option value="Check">Check</option>
|
||
<option value="Cash">Cash</option>
|
||
</select></td>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Check #:</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_checknumber" class="inputbox" maxlength="200" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td></td>
|
||
<td></td>
|
||
<td class="label" data-lgid="P_WO_XXXXXX_COLON">Customer Visible:</td>
|
||
<td>
|
||
<input type="checkbox" id="dialog_invoice_customervisible" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WOS_NOTES_COLON" style="vertical-align: top;">Notes:</td>
|
||
<td colspan="3">
|
||
<textarea id="dialog_invoice_notes" tabindex="1" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ATTACHMENTS_COLON" style="vertical-align: top;">Attachments:</td>
|
||
<td colspan="3">
|
||
<span class="sbutton iconadd" onclick="openWOInvoiceAttachmentDialog('');" data-lgid="P_WO_ADDFILE">Add File</span>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"></td>
|
||
<td colspan="3">
|
||
<table id="tab_invoice_attachments" style="border: 1px solid #a8a8a8; line-height: 25px; width: 450px; display: none;">
|
||
<tr>
|
||
<td>
|
||
<div class="content_main" style="max-height: 80px; overflow: auto;">
|
||
<table id="tab_invoice_atts" style="table-layout: fixed;"></table>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="invoice-popup-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" id="btn_invoice_save" onclick="onAddWorkOrderInvoice();" value="Save" data-lgid="P_WO_SAVE" tabindex="11" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popupepublishstimatemask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_publishestimate" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_PUBLISHESTIMATE">Publish Estimate</span><em class="pubestpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_est_chksendtextmsg" type="checkbox" checked="checked" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_est_chksendtextmsg" data-lgid="P_WO_SENDUPDATETOCUSTOMER" style="user-select: none;">Send Update To Customer</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div style="font-size: 20px; margin-right: 5px; float: right;"><em class="spanbtn iconmobile" style="font-weight: 900; font-size: 14px; cursor: default; padding-left: 0; padding-right: 3px; padding-top: 0;"></em></div>
|
||
</td>
|
||
<td>
|
||
<input type="text" id="dialog_est_phonenum" tabindex="1" autocomplete="off" maxlength="100" style="width: 320px;" />
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_est_chkIncludeStatusLink" type="checkbox" checked="checked" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_est_chkIncludeStatusLink" data-lgid="P_WO_INCLUDESTATUSLINK" style="user-select: none;">Include Status Link</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" style="width: unset;"><span data-lgid="P_WO_MESSAGE_COLON">Message:</span></td>
|
||
<td>
|
||
<select id="dialog_est_variables" style="width: 156px;">
|
||
<option value="0">[Site_Name]</option>
|
||
<option value="1">[Location]</option>
|
||
<option value="13">[Asset]</option>
|
||
<option value="4">[VIN]</option>
|
||
<option value="2">[Make]</option>
|
||
<option value="3">[Model]</option>
|
||
<option value="5">[Id_Phone]</option>
|
||
<option value="6">[Advisor]</option>
|
||
<option value="7">[Company_Name]</option>
|
||
<option value="8">[Contact_Name]</option>
|
||
<option value="9">[Contact_First_Name]</option>
|
||
<option value="10">[Status_Link]</option>
|
||
<option value="11">[Technician_Name]</option>
|
||
<option value="12">[Work_Order_Number]</option>
|
||
<option value="13">[Parts_Order_Number]</option>
|
||
</select>
|
||
<input type="button" id="dialog_est_insertfield" onclick="insertestfield();" data-lgid="P_WO_ADD" style="width: 35px; height: auto; margin-left: 5px;" tabindex="1" />
|
||
<br />
|
||
<textarea id="dialog_est_textmsg" tabindex="1" style="width: 320px; height: 120px; margin-top: 6px;" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="pubestpopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" onclick="onPublishEstimate();" value="Publish" data-lgid="P_WO_PUBLISH" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popup_publish_invoice_mask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_publish_invoice" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_PUBLISH_INVOICE">Publish Invoice</span><em class="publish-invoice-popup-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_invoice_chksendtextmsg" type="checkbox" checked="checked" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_invoice_chksendtextmsg" data-lgid="P_WO_SENDUPDATETOCUSTOMER" style="user-select: none;">Send Update To Customer</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div style="font-size: 20px; margin-right: 5px; float: right;"><em class="spanbtn iconmobile" style="font-weight: 900; font-size: 14px; cursor: default; padding-left: 0; padding-right: 3px; padding-top: 0;"></em></div>
|
||
</td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_phonenum" tabindex="1" autocomplete="off" maxlength="100" style="width: 320px;" />
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_invoice_chkIncludeStatusLink" type="checkbox" checked="checked" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_invoice_chkIncludeStatusLink" data-lgid="P_WO_INCLUDESTATUSLINK" style="user-select: none;">Include Status Link</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" style="width: unset;"><span data-lgid="P_WO_MESSAGE_COLON">Message:</span></td>
|
||
<td>
|
||
<select id="dialog_invoice_variables" style="width: 156px;">
|
||
<option value="0">[Site_Name]</option>
|
||
<option value="1">[Location]</option>
|
||
<option value="13">[Asset]</option>
|
||
<option value="4">[VIN]</option>
|
||
<option value="2">[Make]</option>
|
||
<option value="3">[Model]</option>
|
||
<option value="5">[Id_Phone]</option>
|
||
<option value="6">[Advisor]</option>
|
||
<option value="7">[Company_Name]</option>
|
||
<option value="8">[Contact_Name]</option>
|
||
<option value="9">[Contact_First_Name]</option>
|
||
<option value="10">[Status_Link]</option>
|
||
<option value="11">[Technician_Name]</option>
|
||
<option value="12">[Work_Order_Number]</option>
|
||
<option value="13">[Parts_Order_Number]</option>
|
||
</select>
|
||
<input type="button" id="dialog_invoice_insertfield" onclick="insertinvoicefield();" data-lgid="P_WO_ADD" style="width: 35px; height: auto; margin-left: 5px;" tabindex="1" />
|
||
<br />
|
||
<textarea id="dialog_invoice_textmsg" tabindex="1" style="width: 320px; height: 120px; margin-top: 6px;" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="publish-invoice-popup-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" onclick="onPublishInvoice();" value="Publish" data-lgid="P_WO_PUBLISH" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popupewoestattachmentmask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_woestattachment" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ADDATTACHMENT">Add Attachment</span><em class="woestattpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td class="label" style="width: unset;"><span data-lgid="P_WO_CAPTION_COLON">Caption:</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_estatt_notes" class="inputbox" maxlength="200" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ATTACHMENTS_COLON" style="vertical-align: top; width: unset;">Attachments:</td>
|
||
<td>
|
||
<input id="dialog_woestatt_uploadattfile" type="button" value="Add File..." data-lgid="P_FR_ADDFILE" onclick="UpLoadEstimateAttachment()" tabindex="1" style="background-color: #0099FF; color: #FFFFFF; height: 20px; width: 200px;" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td></td>
|
||
<td>
|
||
<table id="tab_woest_attachments" style="border: 1px solid #a8a8a8; line-height: 25px; width: 320px; display: none;">
|
||
<tr>
|
||
<td>
|
||
<div class="content_main" style="max-height: 80px; overflow: auto;">
|
||
<table id="tab_woest_atts" style="table-layout: fixed;"></table>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="woestattpopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" id="btn_woestattasave" onclick="onSaveWOEstAttachment();" value="Save" data-lgid="P_WO_SAVE" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
|
||
<div id="popup_woinvoice_attachment_mask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_woinvoice_attachment" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ADDATTACHMENT">Add Attachment</span><em class="woinvoiceattpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td class="label" style="width: unset;"><span data-lgid="P_WO_CAPTION_COLON">Caption:</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_att_notes" class="inputbox" maxlength="200" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label" data-lgid="P_WO_ATTACHMENTS_COLON" style="vertical-align: top; width: unset;">Attachments:</td>
|
||
<td>
|
||
<input id="dialog_woinvoiceatt_uploadattfile" type="button" value="Add File..." data-lgid="P_FR_ADDFILE" onclick="UpLoadInvoiceAttachment()" tabindex="1" style="background-color: #0099FF; color: #FFFFFF; height: 20px; width: 200px;" /></td>
|
||
</tr>
|
||
<tr>
|
||
<td></td>
|
||
<td>
|
||
<table id="tab_woinvoice_attachments" style="border: 1px solid #a8a8a8; line-height: 25px; width: 320px; display: none;">
|
||
<tr>
|
||
<td>
|
||
<div class="content_main" style="max-height: 80px; overflow: auto;">
|
||
<table id="tab_woinvoice_atts" style="table-layout: fixed;"></table>
|
||
</div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="woinvoiceattpopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" id="btn_woinvoice_att_save" onclick="onSaveWOInvoiceAttachment();" value="Save" data-lgid="P_WO_SAVE" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popup_woinvoice_markpaid_mask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_woinvoice_markpaid" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_XXX">Mark as Paid</span><em class="woinvoicemarkpaidpopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 40px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td class="label"><span data-lgid="P_WO_XXXXXX">Payment By:</span></td>
|
||
<td>
|
||
<select id="dialog_invoice_markpaid_paymentby" style="width: 320px; height: 24px;">
|
||
<option value="Credit Card">Credit Card</option>
|
||
<option value="Check">Check</option>
|
||
<option value="Cash">Cash</option>
|
||
</select>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"><span data-lgid="P_WO_XXX">Check #:</span></td>
|
||
<td>
|
||
<input type="text" id="dialog_invoice_markpaid_number" class="inputbox" maxlength="200" tabindex="1" autocomplete="off" /></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="woinvoicemarkpaidpopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" id="btn_woinvoice_maikpaid_save" onclick="OnMarkAsPaid();" value="OK" data-lgid="P_WO_OK" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="popupecompletedstatusmask" class="maskbg" style="display: none;"></div>
|
||
<div class="dialog" id="dialog_completedstatus" style="display: none;">
|
||
<div class="dialog-title"><span class="title" id="sptitle_completedstatus" data-lgid="P_WO_ADDWORKORDER">Add Work Order</span><em class="compstatuspopus-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td>
|
||
<span data-lgid="P_WO_COMPLETEDDATETIPS">Completed Date has been entered. Plese choose a Completed Status.</span>
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div id="dialog_completed_status" tabindex="1" class="dropdown" style="width: 320px"></div>
|
||
</td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="compstatuspopus-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" onclick="onSaveCompletedStatus();" value="OK" data-lgid="P_WO_OK" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div class="dialog" id="dialog_panddattachments" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_ATTACHMENTS">Attachments</span><em class="dialog-close"></em></div>
|
||
<div class="dialog-content">
|
||
<div id="dialog_wopanddattachmentlist" style="height: 320px;"></div>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_UM_CANCEL" class="dialog-close" tabindex="1" style="height: 26px;" />
|
||
<input type="button" id="btnPrintWOAttachments" onclick="printWOAttachments();" value="Print" data-lgid="P_WO_PRINT" tabindex="1" />
|
||
<input type="button" id="btnDownloadWOAttachments" onclick="downloadWOAttachments();" value="Download" data-lgid="P_WO_DOWNLOAD" tabindex="1" />
|
||
<div style="clear: both;"></div>
|
||
</div>
|
||
</div>
|
||
|
||
<div class="dialog" id="dialog_statuschange" style="display: none;">
|
||
<div class="dialog-title"><span class="title" data-lgid="P_WO_STATUSCHANGE">Status Change</span><em class="dialog-close"></em></div>
|
||
<div class="dialog-content">
|
||
<table style="line-height: 30px; margin-left: 10px; margin-right: 10px;">
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_chksendtextmsg" type="checkbox" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_chksendtextmsg" data-lgid="P_WO_SENDUPDATETOCUSTOMER" style="user-select: none;">Send Update To Customer</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td>
|
||
<div style="font-size: 20px; margin-right: 5px; float: right;"><em class="spanbtn iconmobile" style="font-weight: 900; font-size: 14px; cursor: default; padding-left: 0; padding-right: 3px; padding-top: 0;"></em></div>
|
||
</td>
|
||
<td>
|
||
<input type="text" id="txtphonenum_statuschange" tabindex="1" autocomplete="off" maxlength="100" style="width: 320px;" />
|
||
</td>
|
||
</tr>
|
||
<tr>
|
||
<td style="text-align: right;">
|
||
<input id="dialog_chkIncludeStatusLink" type="checkbox" style="width: unset;" /></td>
|
||
<td style="text-align: left;">
|
||
<label for="dialog_chkIncludeStatusLink" data-lgid="P_WO_INCLUDESTATUSLINK" style="user-select: none;">Include Status Link</label></td>
|
||
</tr>
|
||
<tr>
|
||
<td class="label"><span data-lgid="P_WO_MESSAGE_COLON">Message:</span></td>
|
||
<td>
|
||
<select id="dialog_variables" style="width: 156px;">
|
||
<option value="0">[Site_Name]</option>
|
||
<option value="1">[Location]</option>
|
||
<option value="13">[Asset]</option>
|
||
<option value="4">[VIN]</option>
|
||
<option value="2">[Make]</option>
|
||
<option value="3">[Model]</option>
|
||
<option value="5">[Id_Phone]</option>
|
||
<option value="6">[Advisor]</option>
|
||
<option value="7">[Company_Name]</option>
|
||
<option value="8">[Contact_Name]</option>
|
||
<option value="9">[Contact_First_Name]</option>
|
||
<option value="10">[Status_Link]</option>
|
||
<option value="11">[Technician_Name]</option>
|
||
<option value="12">[Work_Order_Number]</option>
|
||
<option value="13">[Parts_Order_Number]</option>
|
||
</select>
|
||
<input type="button" id="dialog_insertfield" onclick="insertfield();" data-lgid="P_WO_ADD" style="width: 35px; height: auto; margin-left: 5px;" tabindex="1" />
|
||
<br />
|
||
<textarea id="dialog_textmsg" tabindex="1" style="width: 320px; height: 120px; margin-top: 6px;" maxlength="2000"></textarea></td>
|
||
</tr>
|
||
</table>
|
||
</div>
|
||
<div class="dialog-func">
|
||
<input type="button" value="Cancel" data-lgid="P_WO_CANCEL" class="dialog-close" tabindex="1" />
|
||
<input type="button" id="btn_savestatuschange" value="Save Work Order and Send" data-lgid="P_WO_XXXXXX" style="width: unset;" tabindex="1" />
|
||
<div class="clear"></div>
|
||
</div>
|
||
<div class="maskbg" style="display: none;"></div>
|
||
</div>
|
||
|
||
<div id="dialogattmask" class="maskbg" style="display: none; z-index: 500;">
|
||
<%-- 放到最后--%>
|
||
<div class="loading_icon c-spin"></div>
|
||
<lable class="lable_attuploadname"></lable>
|
||
</div>
|
||
</asp:Content>
|