13 lines
30 KiB
JavaScript
13 lines
30 KiB
JavaScript
(function(k,S){typeof exports=="object"&&typeof module<"u"?S(exports):typeof define=="function"&&define.amd?define(["exports"],S):(k=typeof globalThis<"u"?globalThis:k||self,S(k["lib-app"]={}))})(this,function(k){var A,L,z,Q,x,E,X,Z,ie,V,H,P,_,j,ue,ee,me,te,he,be,Le,ge,Pe,we,Fe,Y,F,G,ne;"use strict";var Se=(k,S,M)=>{if(!S.has(k))throw TypeError("Cannot "+M)};var t=(k,S,M)=>(Se(k,S,"read from private field"),M?M.call(k):S.get(k)),C=(k,S,M)=>{if(S.has(k))throw TypeError("Cannot add the same private member more than once");S instanceof WeakSet?S.add(k):S.set(k,M)},T=(k,S,M,ae)=>(Se(k,S,"write to private field"),ae?ae.call(k,M):S.set(k,M),M);var xe=(k,S,M)=>(Se(k,S,"access private method"),M);const S="",M=window["lib-ui"].createElement;function ae(se,e){const n=M("div","comm"),a=M("div","title-bar",se,M("div","title-functions",...e));return n.appendChild(a),n}const De=window["lib-ui"].Dropdown,O=window["lib-ui"].createElement,$e=window["lib-ui"].createCheckbox,Ae=window["lib-ui"].createPopup,Ce=window["lib-ui"].showAlert,Ue=window["lib-utility"].isEmail,re=window["lib-utility"].nullOrEmpty,N=window["lib-utility"].r;class Ee{constructor(e={}){C(this,A,void 0);C(this,L,void 0);T(this,A,e)}async show(e=document.body){const n=Math.max.apply(null,[...document.querySelectorAll("[tabindex]")].map(i=>i.tabIndex??0))+3,a=t(this,A).contact,y=O("input",i=>{i.type="text",i.className="ui-input",i.tabIndex=n+1,i.maxLength=200,i.autocomplete="off"}),m=new De({tabIndex:n+2});m.source=[{value:"0",text:N("text","Text")},{value:"1",text:N("email","Email")},{value:"2",text:N("phone","Phone")}];const o=O("input",i=>{i.type="email",i.className="ui-input",i.tabIndex=n+3,i.maxLength=100,i.autocomplete="off"}),r=O("input",i=>{i.type="tel",i.className="ui-input",i.tabIndex=n+4,i.maxLength=50,i.autocomplete="off"}),s=$e({tabIndex:n+5}),d=O("textarea",i=>{i.className="ui-text",i.tabIndex=n+6,i.maxLength=2e3,i.style.height="100px"}),b=[];t(this,A).company&&b.push({text:a==null?N("addContactRecord","Add Contact Record"):N("editContactRecord","Edit Contact Record"),trigger:()=>{const i=this.prepare();if(i==null)return!1;if(i.SaveToCustomer=1,typeof t(this,A).onSave=="function")return t(this,A).onSave.call(this,i,"customerrecord")}}),b.push({text:N("workOrderOnly","Work Order Only"),trigger:()=>{const i=this.prepare();if(i==null)return!1;if(i.Id=-1,i.SaveToCustomer=0,typeof t(this,A).onSave=="function")return t(this,A).onSave.call(this,i,"workorder")}},{text:N("cancel","Cancel")});const p=Ae(a==null?N("addContact","Add Contact"):N("editContact","Edit Contact"),O("div",i=>{i.className="setting-wrapper",i.style.width="500px"},O("div","setting-item",O("span","setting-label setting-required",N("contactNameColon","Contact Name:")),y),O("div","setting-item",O("span","setting-label",N("contactPreferencesColon","Contact Preferences:")),m.create()),O("div","setting-item",O("span","setting-label",N("contactEmailColon","Email Address:")),o),O("div","setting-item",O("span","setting-label",N("contactMobileColon","Mobile:")),r),O("div","setting-item",O("span","setting-label",N("contactOptColon","Opt Out:")),s),O("div","setting-item",O("span","setting-label",N("contactNotesColon","Notes:")),d)),...b);a!=null?(y.value=a.Name,m.select(String(a.ContactPreference)),o.value=a.Email,r.value=a.MobilePhone,s.querySelector("input").checked=a.OptOut,d.value=a.Notes):m.select("0"),T(this,L,{contactName:y,preferences:m,contactEmail:o,contactMobile:r,checkOpt:s,contactNotes:d});const g=await p.show(e);return setTimeout(()=>y.focus()),g}prepare(){const e=t(this,L).contactName.value,n=t(this,L).preferences.selected.value,a=t(this,L).contactEmail.value,y=t(this,L).contactMobile.value,m=t(this,L).checkOpt.querySelector("input").checked,o=t(this,L).contactNotes.value,r=t(this,A).contact==null?N("addContact","Add Contact"):N("editContact","Edit Contact");if(re(e))return Ce(r,N("contactNameRequired","Contact Name cannot be empty."),"warn").then(()=>t(this,L).contactName.focus()),null;if(re(a)&&re(y))return Ce(r,N("contactEmailPhoneRequired","Email and Mobile Phone cannot both be empty."),"warn").then(()=>re(a)?t(this,L).contactEmail.focus():t(this,L).contactMobile.focus()),null;if(!re(a)&&!Ue(a))return Ce(r,N("contactEmailInvalid","The email address is invalid."),"warn").then(()=>t(this,L).contactEmail.focus()),null;let s=t(this,A).contact;return s==null?s={}:s.OptOut!==m&&(m!==!1||s.OptOut_BC===!1)&&(s.selected=!m),s.Name=e,s.ContactPreference=n,s.Email=a,s.MobilePhone=y,s.OptOut=m,s.Notes=o,s}}A=new WeakMap,L=new WeakMap;const ke=window["lib-ui"].Grid,pe=window["lib-ui"].createElement,We=window["lib-ui"].createPopup,Te=window["lib-utility"].nullOrEmpty,J=window["lib-utility"].r,He=window["lib-utility"].contains;class _e{constructor(e={}){C(this,z,void 0);C(this,Q,void 0);T(this,z,e)}async show(e=document.body){const n=Math.max.apply(null,[...document.querySelectorAll("[tabindex]")].map(r=>r.tabIndex??0))+3,a=pe("div","follower-grid"),m=await We(J("addFollowers","Add Followers"),pe("div","follower-wrapper",pe("div",r=>r.innerText=J("whoWantReceiveCustomerNotification","Who do you want to receive customer notifications?")),pe("input",r=>{r.type="text",r.tabIndex=n+3,r.className="ui-input follower-search",r.addEventListener("input",()=>{const s=r.value;Te(s)?t(this,Q).source=t(this,z).followers:t(this,Q).source=t(this,z).followers.filter(d=>d.Text||d.Email||He(d.DisplayName,s,!0))})}),a),{text:J("ok","OK"),key:"ok",trigger:()=>{if(typeof t(this,z).onOk=="function")return t(this,z).onOk.call(this,t(this,Q).source.filter(r=>r.Email||r.Text))}},{text:J("cancel","Cancel"),key:"cancel"}).show(e);m.querySelector(".follower-search").focus();const o=new ke(a);return o.columns=[{key:"DisplayName",caption:J("contactName","Contact Name"),width:240},{key:"ContactTypeName",caption:J("contactType","Contact Type"),width:120},{key:"Text",caption:J("text","Text"),type:ke.ColumnTypes.Checkbox,width:60,enabled:r=>!Te(r.Mobile)},{key:"Email",caption:J("email","Email"),type:ke.ColumnTypes.Checkbox,width:70}],o.init(),o.source=t(this,z).followers,T(this,Q,o),m}}z=new WeakMap,Q=new WeakMap;const K=window["lib-ui"].Grid,h=window["lib-ui"].createElement,I=window["lib-ui"].setTooltip,$=window["lib-ui"].createIcon,fe=window["lib-ui"].createCheckbox,Oe=window["lib-ui"].createRadiobox,qe=window["lib-ui"].createPopup,ce=window["lib-ui"].showAlert,de=window["lib-ui"].showConfirm,l=window["lib-utility"].r,v=window["lib-utility"].nullOrEmpty,Be=window["lib-utility"].formatUrl,ye=window["lib-utility"].isEmail,Ve=window["lib-utility"].isPhone;class je extends K.GridColumn{static create(){return h("div","contact-wrapper",h("div","contact-name"),h("div","contact-note"))}static setValue(e,n,a,y,m){const o=e.querySelector(".contact-name");o.innerText=a.Name,o.scrollWidth>o.offsetWidth&&I(o,a.Name,!1,m.element),e.querySelector(".contact-note").innerText=a.Notes}}class Ge{constructor(e){C(this,ee);C(this,te);C(this,be);C(this,ge);C(this,we);C(this,x,void 0);C(this,E,void 0);C(this,X,void 0);C(this,Z,void 0);C(this,ie,void 0);C(this,V,void 0);C(this,H,void 0);C(this,P,{});C(this,_,void 0);C(this,j,void 0);C(this,ue,void 0);T(this,E,e??{})}get autoUpdatesEnabled(){var e;return((e=t(this,ee,me))==null?void 0:e.disabled)!==!0}set autoUpdatesEnabled(e){var a,y,m,o;const n=t(this,ee,me);n!=null&&(e===!1?(n.disabled=!0,(y=(a=n.parentElement)==null?void 0:a.classList)==null||y.add("disabled")):(n.disabled=!1,(o=(m=n.parentElement)==null?void 0:m.classList)==null||o.remove("disabled")))}get autoUpdates(){var e;return(e=t(this,ee,me))==null?void 0:e.checked}set autoUpdates(e){const n=t(this,ee,me);n!=null&&(n.checked=e,n.dispatchEvent(new Event("change")))}get statusLinkEnabled(){var e;return((e=t(this,te,he))==null?void 0:e.disabled)!==!0}set statusLinkEnabled(e){var a,y,m,o;const n=t(this,te,he);n!=null&&(e===!1?(n.disabled=!0,(y=(a=n.parentElement)==null?void 0:a.classList)==null||y.add("disabled")):(n.disabled=!1,(o=(m=n.parentElement)==null?void 0:m.classList)==null||o.remove("disabled")))}get statusLink(){var e;return(e=t(this,te,he))==null?void 0:e.checked}set statusLink(e){const n=t(this,te,he);n!=null&&(n.checked=e,n.dispatchEvent(new Event("change")))}set loading(e){t(this,x)!=null&&(t(this,V).disabled=e,t(this,x).querySelector(".customer-name>.ui-input").disabled=e,t(this,x).querySelector(".button-send-message").disabled=e,t(this,x).querySelector(".button-edit-contacts").disabled=e,t(this,x).querySelector(".button-edit-followers").disabled=e)}get text(){var e;return(e=t(this,V))==null?void 0:e.value}set text(e){const n=t(this,V);n!=null&&(n.value=e,e=String(v(e)?0:val.length)+"/"+String(t(this,E).maxLength),t(this,x).querySelector(".message-bar .prompt-count").innerText=e)}get customerName(){var e;return(e=t(this,x).querySelector(".customer-name>.ui-input"))==null?void 0:e.value}set customerName(e){const n=t(this,x).querySelector(".customer-name>.ui-input");n!=null&&(n.value=e)}get contacts(){return[...t(this,X).children].map(e=>{const n=e.querySelector("span");return{Key:n.dataset.to,Value:n.dataset.name}})}set contacts(e){if(t(this,X).replaceChildren(),(e==null?void 0:e.length)>0){for(let n of e){if(n.OptOut||n.OptOut_BC||n.selected===!1)continue;const a=String(n.MobilePhoneDisplayText).trim(),y=String(n.Email).trim(),m=String(n.ContactPreference);if(m!=="1"&&!Ve(a)||m==="1"&&!ye(y))continue;const o=m==="1"?y:a;let r,s;switch(m){case"0":r="comment-lines",s=l("textsToColon","Texts to:");break;case"2":r="mobile",s=l("callsToColon","Calls to:");break;default:r="envelope",s=l("emailsToColon","Emails to:");break}const d=h("span",g=>{g.dataset.to=o,g.dataset.name=n.Name,g.innerText=n.Name}),b=h("div","contact-item",$("fa-light",r),d);t(this,X).appendChild(b);let p=`${s} ${o}`;d.scrollWidth>d.offsetWidth&&(p=l("nameColon","Name:")+` ${n.Name}
|
|
${p}`),I(d,p)}t(this,H).scrollTop=t(this,H).scrollHeight}}set readonly(e){if(t(this,E).readonly=e,t(this,x)==null)return;const n=t(this,x).querySelector(".check-status-link");e===!0?n.classList.add("disabled"):n.classList.remove("disabled"),n.querySelector("input").disabled=e;const a=e===!0?"none":"";t(this,x).querySelector(".button-edit-contacts").style.display=a,t(this,x).querySelector(".button-edit-followers").style.display=a,t(this,x).querySelector(".message-bar").style.display=a}set recordReadonly(e){t(this,E).recordReadonly=e,t(this,x)!=null&&(t(this,x).querySelector(".button-edit-contacts").style.display=e===!0?"none":"",t(this,x).querySelector(".button-edit-followers").style.display=e===!0?"none":"")}set companyName(e){t(this,E).companyName=e;const n=t(this,x).querySelector(".title-company");v(e)?n.style.display="none":(n.innerText=e,n.style.display="")}set companyCode(e){t(this,E).companyCode=e;const n=t(this,x).querySelector(".title-company");v(t(this,E).companyName)?n.style.display="none":(n.innerText=t(this,E).companyName,v(e)||(n.innerText=t(this,E).companyName+"/"+e),n.style.display="")}get followers(){return[...t(this,Z).children].map(e=>{const n=e.querySelector("span");return{Email:n.dataset.email,MobilePhone:n.dataset.mp,Value:n.dataset.name}})}set followers(e){if(t(this,P).followers=e,t(this,Z).replaceChildren(),(e==null?void 0:e.length)>0){t(this,x).querySelector(".follower-bar").style.display="",t(this,x).querySelector(".follower-bar>.bar-list").appendChild(t(this,ie));for(let n of e){if(n.OptOut)continue;const a=String(n.MobilePhone).trim(),y=String(n.Email).trim(),m=[];n.SendEmail&&m.push(l("emailsToColon","Emails to:")+` ${y}`),n.SendText&&m.push(l("textsToColon",`Texts to: ${a}`));let o;n.SendText&&n.SendEmail?o="at":o=n.SendText?"comment-lines":"envelope";const r=h("span",d=>{n.SendEmail&&(d.dataset.email=y),n.SendText&&(d.dataset.mp=a),d.dataset.name=n.Name,d.innerText=n.Name}),s=h("div","contact-item",$("fa-light",o),r);t(this,Z).appendChild(s),r.scrollWidth>r.offsetWidth&&m.splice(0,0,l("nameColon","Name:")+` ${c.Name}`),I(r,m.join(`
|
|
`))}}else t(this,x).querySelector(".follower-bar").style.display="none",t(this,x).querySelector(".button-edit-contacts").insertAdjacentElement("beforebegin",t(this,ie));t(this,H).scrollTop=t(this,H).scrollHeight}setData(e,n){t(this,P)[e]=n}create(){const e=t(this,E),n=e.readonly,a=fe({className:"check-auto-update",checked:e.autoUpdates,checkedNode:$("fa-regular","redo-alt"),uncheckedNode:$("fa-regular","ban"),onchange:function(){I(a,this.checked?l("autoUpdateEnabled","Auto Updates Enabled"):l("autoUpdateDisabled","Auto Updates Disabled"))}});e.autoUpdatesVisible===!1&&(a.style.display="none");const y=fe({className:"check-status-link",enabled:!n,checked:e.statusLink,checkedNode:$("fa-regular","link"),uncheckedNode:$("fa-regular","unlink"),onchange:function(){I(y,this.checked?l("statusLinkIncluded","Status Link Included"):l("statusLinkExcluded","Status Link Excluded"))}});e.statusLinkVisible===!1&&(y.style.display="none");const m=ae(h("div",null,h("div",s=>{s.className="title-module",s.innerText=e.title??l("messages","Customer Communication")}),h("div",s=>{s.className="title-company",v(e.companyName)?s.style.display="none":v(e.companyCode)?s.innerText=e.companyName:s.innerText=e.companyName+"/"+e.companyCode})),[I(a,l("autoUpdateEnabled","Auto Updates Enabled")),I(y,l("statusLinkExcluded","Status Link Excluded"))]);T(this,X,xe(this,be,Le).call(this,m,e)),T(this,Z,xe(this,ge,Pe).call(this,m,e));const o=h("textarea","ui-text");o.placeholder=l("typeMessage","Enter Message Here"),e.maxLength??(e.maxLength=3e3),o.maxLength=e.maxLength,o.addEventListener("input",()=>{const s=t(this,V).value,d=String(v(s)?0:s.length)+"/"+String(e.maxLength);t(this,x).querySelector(".message-bar .prompt-count").innerText=d}),T(this,V,o),m.appendChild(h("div",s=>{s.className="message-bar",n===!0&&(s.style.display="none")},o,h("div",s=>s.style.textAlign="right",h("div",s=>{s.className="customer-name",e.customerNameVisible!==!0&&(s.style.display="none")},h("span",s=>s.innerText=l("nameColon","Name:")),h("input",s=>{s.type="text",s.className="ui-input"})),h("div","prompt-count"),h("button",s=>{s.className="roundbtn button-send-message",s.style.backgroundColor="rgb(19, 150, 204)",s.appendChild($("fa-solid","paper-plane")),I(s,l("sendMessage","Send Message")),s.addEventListener("click",()=>{const d=t(this,V).value;if(v(d==null?void 0:d.trim())){ce(l("error","Error"),l("messageRequired","Please input the message."),"warn");return}typeof t(this,E).onAddMessage=="function"&&t(this,E).onAddMessage(t(this,V).value)})}))));const r=h("div","list-bar");return T(this,H,r),m.appendChild(r),T(this,x,m)}load(e,n,a){var m;const y=[];if((e==null?void 0:e.length)>0){n??(n=t(this,P).contacts),a??(a=t(this,P).allfollowers);for(let o of e){const r=h("div","item-div");let s;if(o.IsReply&&(n==null?void 0:n.length)>0){const p=ye(o.Sender)?n.find(g=>g.Email===o.Sender):n.find(g=>g.MobilePhone===o.Sender);s=p==null?void 0:p.Name}s??(s=o.IsReply&&String(o.FormatSender)!==""?o.FormatSender:o.Sender);let d="";if(!o.IsReply&&((m=o.OriPhoneNumbers)==null?void 0:m.length)>0)for(let p of o.OriPhoneNumbers){let g;const i=ye(p);if((n==null?void 0:n.length)>0){let w=i?n.find(f=>f.Email===p):n.find(f=>f.MobilePhone===p);w!=null?g=`${i?w.Email:w.MobilePhoneDisplayText} - ${w.Name}`:(a==null?void 0:a.length)>0&&(w=i?a.find(f=>f.Email===p):a.find(f=>f.MobilePhone===p),w!=null&&(g=`${i?w.Email:w.MobilePhoneDisplayText} - ${w.Name}`))}d+=(g??p)+`
|
|
`}d!==""&&(d=l("sendToColon","Send To :")+`
|
|
${d}`),r.appendChild(h("div",p=>{p.className="item-poster",p.innerText=s,!o.IsReply&&(d==null?void 0:d.length)>0&&I(p,d)}));const b=h("div","item-content");if(b.appendChild(h("span",p=>{/https?:\/\//i.test(o.Message)?p.innerHTML=Be(o.Message):p.innerText=o.Message})),o.IsReply)r.classList.add("item-other");else{r.classList.add("item-self");const[p,g]=xe(this,we,Fe).call(this,o);if(p!==-100){let i;switch(p){case 0:i=l("pending","Pending"),b.style.backgroundColor="#ffc107";break;case 1:i=l("sent","Sent");break;case 9:i=l("failed","Failed"),b.style.backgroundColor="#ffc107";break;case 10:i=l("optOut","Opt-Out"),b.style.backgroundColor="#ffc107";break;case 412:i=l("landline","Landline"),b.style.backgroundColor="#ffc107";break;default:i=l("undelivered","Undelivered"),b.style.backgroundColor="#ffc107";break}const w=h("div",f=>{f.className="item-status",f.innerText=i,p==-10&&I(f,g)});b.appendChild(w)}}r.append(b,h("div",p=>{p.className="item-time",p.innerText=o.TimeStr})),y.push(r)}y[0].style.marginTop="0"}t(this,H).replaceChildren(...y),t(this,H).scrollTop=t(this,H).scrollHeight}}x=new WeakMap,E=new WeakMap,X=new WeakMap,Z=new WeakMap,ie=new WeakMap,V=new WeakMap,H=new WeakMap,P=new WeakMap,_=new WeakMap,j=new WeakMap,ue=new WeakMap,ee=new WeakSet,me=function(){return t(this,x).querySelector(".check-auto-update>input")},te=new WeakSet,he=function(){return t(this,x).querySelector(".check-status-link>input")},be=new WeakSet,Le=function(e,n){const a=n.readonly,y=n.recordReadonly,m=h("div");return e.append(h("div","contact-bar",h("div","bar-icon",$("fa-solid","user-circle",{fill:"lightgray"})),h("div","bar-list",m,h("button",o=>{o.className="roundbtn button-edit-contacts",o.style.backgroundColor="rgb(1, 199, 172)",a===!0&&(o.style.display="none"),o.appendChild($("fa-solid","user-edit")),I(o,l("editContacts","Edit Contacts")),o.addEventListener("click",()=>{const r=qe(h("div",s=>{s.style.display="flex",s.style.alignItems="center",s.append(h("div",d=>{d.className="ui-popup-move",d.style.flex="1 1 auto"},h("div",d=>d.innerText=l("editContacts","Edit Contacts")),h("div",d=>{d.className="title-company",v(n.companyName)?d.style.display="none":v(n.companyCode)?d.innerText=n.companyName:d.innerText=n.companyName+"/"+n.companyCode})),h("button",d=>{d.style.flex="0 0 auto",d.style.backgroundColor="rgb(1, 199, 172)",d.style.marginRight="10px",d.className="roundbtn button-add-contact",y&&(d.style.display="none"),d.appendChild($("fa-solid","user-plus",{width:"16px",height:"16px"})),d.addEventListener("click",()=>{new Ee({company:!v(t(this,P).companyCode),onSave:p=>{if(t(this,_).source.some(i=>i.Name===p.Name&&i.MobilePhone===p.MobilePhone))return ce(l("addContact","Add Contact"),l("contactUniqueRequired","Contact name and contact mobile must be a unique combination."),"warn"),!1;if(typeof n.onSave=="function"){const i=n.onSave(p,!0);return typeof(i==null?void 0:i.then)=="function"?i.then(w=>(t(this,_).source=w.filter(f=>f.Id>=0).map(f=>(f.OptOut||f.OptOut_BC||typeof f.selected>"u"&&(f.selected=!0),f)),t(this,j).source=w.filter(f=>f.Id<0).map(f=>(f.OptOut||f.OptOut_BC||typeof f.selected>"u"&&(f.selected=!0),f)),w)):!1}}}).show(e)}),I(d,l("addContact","Add Contact"))}))}),h("div",null,h("div",s=>{v(t(this,P).companyCode)&&(s.style.display="none"),s.style.fontWeight="bold",s.innerText=l("contactFromRecord","Contacts from Customer Record")}),h("div",s=>{v(t(this,P).companyCode)&&(s.style.display="none"),s.className="contacts-record",s.style.maxHeight="400px",s.style.width="660px"}),h("div",s=>{s.style.fontWeight="bold",s.innerText=l("contactFromWorkOrder","Contacts not on Customer Record")}),h("div",s=>{s.className="contacts-wo",s.style.maxHeight="200px",s.style.width="660px"})));r.show(e).then(()=>{const s=u=>({key:"selected",type:K.ColumnTypes.Checkbox,width:50,enabled:D=>!D.OptOut&&!D.OptOut_BC,onchanged:function(){typeof n.onChanged=="function"&&n.onChanged([...t(u,_).source,...t(u,j).source])}}),d={key:"type",type:K.ColumnTypes.Icon,width:50,filter:u=>{switch(String(u.ContactPreference)){case"0":return"comment-lines";case"2":return"mobile";default:return"envelope"}},className:"icon-contact-type",iconType:"fa-light"},b={key:"Name",type:je,width:160},p={type:K.ColumnTypes.Icon,width:40,visible:!y,align:"center",iconType:"fa-light"},g=u=>({key:"edit",...p,text:"edit",tooltip:l("edit","Edit"),events:{onclick:function(){new Ee({contact:this,company:!v(t(u,P).companyCode),onSave:(U,le)=>{if(t(u,_).source.some(W=>W!==this&&W.Name===U.Name&&W.MobilePhone===U.MobilePhone)||t(u,j).source.some(W=>W!==this&&W.Name===U.Name&&W.MobilePhone===U.MobilePhone))return ce(l("editContact","Edit Contact"),l("contactUniqueRequired","Contact name and contact mobile must be a unique combination."),"warn"),!1;if(typeof n.onSave=="function"){const W=n.onSave(U);return typeof(W==null?void 0:W.then)=="function"?W.then(Ne=>(t(u,_).source=Ne.filter(q=>q.Id>=0).map(q=>(q.OptOut||q.OptOut_BC||typeof q.selected>"u"&&(q.selected=!0),q)),t(u,j).source=Ne.filter(q=>q.Id<0).map(q=>(q.OptOut||q.OptOut_BC||typeof q.selected>"u"&&(q.selected=!0),q)),Ne)):!1}}}).show(e)}}}),i=new K;i.height=0,i.allowHtml=!0,i.headerVisible=!1,i.columns=[s(this),d,b,{key:"Email",width:180},{key:"MobilePhoneDisplayText",width:130},g(this),{key:"delete",...p,text:"times",tooltip:l("delete","Delete"),events:{onclick:function(){de(l("remoteContact","Remove Contact"),h("div",null,h("div",u=>{u.style.paddingLeft="16px",u.innerText=l("removeFrom","Remove {name} from").replace("{name}",this.Name)}),h("div",u=>{u.style.display="flex",u.style.justifyContent="center",u.style.marginTop="10px"},Oe({name:"remove-type",label:l("customerRecord","Customer Record"),checked:!0,className:"radio-customer-record"}),Oe({name:"remove-type",label:l("workOrder","Work Order")}))),[{key:"ok",text:l("ok","OK")},{key:"cancel",text:l("cancel","Cancel")}]).then(u=>{if((u==null?void 0:u.key)==="ok"){const D=u.popup.container.querySelector(".radio-customer-record>input").checked;typeof n.onDelete=="function"&&n.onDelete(u.key,this,D);const U=i.source.indexOf(this);if(U>=0){const le=i.source;le.splice(U,1),i.extraRows=le.filter(Re=>!v(Re.Notes)).length,i.source=le}}})}}}],i.init(r.container.querySelector(".contacts-record"));const w=t(this,P).contacts.filter(u=>u.Id>=0).map(u=>(u.OptOut||u.OptOut_BC||typeof u.selected>"u"&&(u.selected=!0),u));i.extraRows=w.filter(u=>!v(u.Notes)).length,i.source=w,i.selectedRowChanged=u=>{var D;u>=0&&((D=t(this,j).selectedIndexes)==null?void 0:D.length)>0&&(t(this,j).selectedIndexes=[])},T(this,_,i);const f=new K;f.height=0,f.allowHtml=!0,f.headerVisible=!1,f.columns=[s(this),d,b,{key:"Email",width:180},{key:"MobilePhoneDisplayText",width:130},g(this),{key:"delete",...p,text:"times",tooltip:l("delete","Delete"),events:{onclick:function(){de(l("remoteContact","Remove Contact"),l("removeFromWorkorder",`You are removing {name} from work order.
|
|
|
|
Do you want to Continue?`).replace("{name}",this.Name),[{key:"continue",text:l("continue","Continue")},{key:"cancel",text:l("cancel","Cancel")}]).then(u=>{if((u==null?void 0:u.key)==="continue"){typeof n.onDelete=="function"&&n.onDelete(u.key,this);const D=f.source.indexOf(this);if(D>=0){const U=f.source;U.splice(D,1),f.extraRows=U.filter(le=>!v(le.Notes)).length,f.source=U}}})}}}],f.init(r.container.querySelector(".contacts-wo"));const B=t(this,P).contacts.filter(u=>u.Id<0).map(u=>(u.OptOut||u.OptOut_BC||typeof u.selected>"u"&&(u.selected=!0),u));f.extraRows=B.filter(u=>!v(u.Notes)).length,f.source=B,f.selectedRowChanged=u=>{var D;u>=0&&((D=t(this,_).selectedIndexes)==null?void 0:D.length)>0&&(t(this,_).selectedIndexes=[])},T(this,j,f)})})})))),m},ge=new WeakSet,Pe=function(e,n){const a=n.readonly,y=n.recordReadonly,m=h("div"),o=h("button",r=>{r.className="roundbtn button-edit-followers",r.style.backgroundColor="rgb(48, 107, 255)",(a===!0||y)&&(r.style.display="none"),r.appendChild($("fa-solid","pen")),I(r,l("editFollower","Edit Followers")),r.addEventListener("click",()=>{const s=qe(h("div",d=>{d.style.display="flex",d.style.alignItems="center",d.append(h("div",b=>{b.className="ui-popup-move",b.style.flex="1 1 auto",b.innerText=l("editContacts","Edit Contacts")+`
|
|
`+l("followers","Followers")}),h("button",b=>{b.style.flex="0 0 auto",b.style.backgroundColor="rgb(1, 199, 172)",b.style.marginRight="10px",b.className="roundbtn button-add-follower",b.appendChild($("fa-solid","user-plus",{width:"16px",height:"16px"})),b.addEventListener("click",()=>{typeof t(this,E).onInitFollower=="function"&&t(this,E).onInitFollower().then(p=>{if(typeof p=="string"){ce(l("customerRecord","Customer Record"),p,"warn");return}new _e({followers:p,onOk:i=>{if(typeof t(this,E).onAddFollower=="function"){const w=t(this,E).onAddFollower(i);return typeof(w==null?void 0:w.then)=="function"?w.then(f=>(t(this,ue).source=f,f)):!1}}}).show(e)})}),I(b,l("addFollower","Add Follower"))}))}),h("div",null,h("div",d=>{d.style.fontWeight="bold",d.innerText=l("contactFromRecord","Contacts from Customer Record")}),h("div",d=>{d.className="followers-record",d.style.maxHeight="400px",d.style.width="660px"})));s.show(e).then(()=>{const d={type:K.ColumnTypes.Icon,width:40,align:"center",iconType:"fa-light"},b=new K;b.height=0,b.allowHtml=!0,b.headerVisible=!1,b.columns=[{key:"type",type:K.ColumnTypes.Icon,width:50,filter:p=>p.SendText&&p.SendEmail?"at":p.SendText?"comment-lines":"envelope",className:"icon-contact-type",iconType:"fa-light"},{key:"Name",width:160},{key:"Email",width:180},{key:"MobilePhoneDisplayText",width:130},{key:"edit",...d,text:"edit",tooltip:l("edit","Edit"),events:{onclick:function(){typeof n.onInitFollower=="function"&&n.onInitFollower().then(p=>{if(typeof p=="string"){ce(l("customerRecord","Customer Record"),p,"warn");return}const g=p.find(i=>i.IID===this.UserIID);de(l("editContactMethod","Edit Contact Method"),h("div","wrapper-edit-method",h("div",i=>{i.style.display="flex",i.style.justifyContent="center",i.style.marginTop="20px"},fe({label:l("text","Text"),checked:this.SendText&&!v(g==null?void 0:g.Mobile),enabled:!v(g==null?void 0:g.Mobile),className:"check-method-text"}),fe({label:l("email","Email"),checked:this.SendEmail,className:"check-method-email"}))),[{key:"ok",text:l("ok","OK"),trigger:(i,w)=>{const f=i.container.querySelector(".check-method-text>input").checked,B=i.container.querySelector(".check-method-email>input").checked;return!f&&!B?de(l("editContactMethod","Edit Contact Method"),l("promptRemoveFollower","Contact method is required. If you continue, user will be removed as a follower."),[{key:"update",text:l("updateContactMethod","Update Contact Method")},{key:"remove",text:l("removeFollower","Remove Follower")}],"question").then(u=>(u==null?void 0:u.key)==="remove"?{key:u.key,popup:i}:!1):{key:w.key,popup:i}}},{key:"cancel",text:l("cancel","Cancel")}],null).then(i=>{const w=i==null?void 0:i.key;if(w==="remove"){typeof n.onDeleteFollower=="function"&&n.onDeleteFollower(i.key,this);const f=b.source.indexOf(this);if(f>=0){const B=b.source;B.splice(f,1),b.extraRows=B.filter(u=>!v(u.Notes)).length,b.source=B}}else if(w==="ok"){const f=i.popup.container.querySelector(".check-method-text>input").checked,B=i.popup.container.querySelector(".check-method-email>input").checked;typeof n.onChangeFollower=="function"&&n.onChangeFollower(i.key,this,f,B),this.SendText=f,this.SendEmail=B,b.refresh()}})})}}},{key:"delete",...d,text:"times",tooltip:l("delete","Delete"),events:{onclick:function(){de(l("deleteFollower","Delete Follower"),l("promptDeleteFollower","Do you want to delete this follower?")).then(p=>{if((p==null?void 0:p.key)==="yes"){typeof n.onDeleteFollower=="function"&&n.onDeleteFollower(p.key,this);const g=b.source.indexOf(this);if(g>=0){const i=b.source;i.splice(g,1),b.extraRows=i.filter(w=>!v(w.Notes)).length,b.source=i}}})}}}],b.init(s.container.querySelector(".followers-record")),b.source=t(this,P).followers,T(this,ue,b)})})});return T(this,ie,o),e.append(h("div",r=>{r.className="contact-bar follower-bar",r.style.display="none"},I(h("div","bar-icon",$("fa-solid","user-tag",{fill:"#fff","background-color":"lightgray","box-sizing":"border-box","border-radius":"15px",padding:"4px"})),l("copied","Copied")),h("div","bar-list",m,o))),m},we=new WeakSet,Fe=function(e){var m;let n=-100;const a=[];let y="";if(!e.StatusIncorrect&&((m=e.Participator)==null?void 0:m.length)>0){for(let o of e.Participator)if(!ye(o.CustomerNumber)){a.indexOf(o.Status)<0&&a.push(o.Status),y.length>0&&(y+=`
|
|
`),y+=`${o.CustomerNumber}: `;const r={0:l("undelivered","Undelivered"),1:l("sent","Sent"),9:l("failed","Failed")}[o.Status];r!=null&&(y+=r)}}return a.length===1?n=a[0]:a.length>1&&(n=-10),[n,y]};const R=window["lib-ui"].createElement,ve=window["lib-ui"].setTooltip,Me=window["lib-ui"].createIcon,oe=window["lib-utility"].r,Ie=window["lib-utility"].nullOrEmpty,Ke=window["lib-utility"].escapeHtml;class ze{constructor(e){C(this,Y,void 0);C(this,F,void 0);C(this,G,void 0);C(this,ne,void 0);T(this,F,e??{})}get text(){var e;return(e=t(this,G))==null?void 0:e.value}set text(e){const n=t(this,G);n!=null&&(n.value=e,e=String(Ie(e)?0:val.length)+"/"+String(t(this,F).maxLength),t(this,Y).querySelector(".message-bar .prompt-count").innerText=e)}set readonly(e){t(this,F).readonly=e,t(this,Y)!=null&&(t(this,G).disabled=e===!0,t(this,Y).querySelector(".button-send-message").style.display=e===!0?"none":"",t(this,Y).querySelector(".button-post-note").style.display=e===!0?"none":"")}create(){var m;const e=ae(R("div",null,R("div",o=>{o.className="title-module",o.innerText=oe("internalComments","Internal Comments")})),[]),n=t(this,F).readonly,a=R("textarea","ui-text");a.placeholder=oe("typeComment","Enter Comment Here"),a.maxLength=(m=t(this,F)).maxLength??(m.maxLength=3e3),a.addEventListener("input",()=>{const o=t(this,G).value,r=String(Ie(o)?0:o.length)+"/"+String(t(this,F).maxLength);t(this,Y).querySelector(".message-bar .prompt-count").innerText=r}),n===!0&&(a.disabled=!0),T(this,G,a),e.appendChild(R("div","message-bar",a,R("div",o=>o.style.textAlign="right",R("div","prompt-count"),R("button",o=>{o.className="roundbtn button-send-message",o.style.backgroundColor="rgb(19, 150, 204)",(n===!0||t(this,F).noMessage===!0)&&(o.style.display="none"),o.appendChild(Me("fa-solid","paper-plane")),ve(o,oe("sendMessage","Send Message")),o.addEventListener("click",()=>{typeof t(this,F).onAddMessage=="function"&&t(this,F).onAddMessage(t(this,G).value)})}),R("button",o=>{o.className="roundbtn button-post-note",o.style.border="1px solid rgb(19, 150, 204)",o.style.fill="rgb(19, 150, 204)",n===!0&&(o.style.display="none"),o.appendChild(Me("fa-solid","comment-alt-lines")),ve(o,oe("postNote","Post Note")),o.addEventListener("click",()=>{typeof t(this,F).onAddComment=="function"&&t(this,F).onAddComment(t(this,G).value)})}))));const y=R("div","list-bar");return T(this,ne,y),e.appendChild(y),T(this,Y,e)}load(e){var a;const n=[];if((e==null?void 0:e.length)>0){for(let y of e){const m=R("div","item-div");m.appendChild(R("div",r=>{r.className="item-poster",r.innerText=y.UserName}));const o=R("div","item-content");if(o.appendChild(R("span",r=>r.innerHTML=Ke(y.Comment))),((a=y.FollowUp)==null?void 0:a.length)>0){m.classList.add("item-sent");const r=oe("sendToColon","Send To :")+`\r
|
|
`+y.FollowUp.split(";").join(`\r
|
|
`);o.appendChild(R("div",s=>{s.className="item-status",s.innerText=oe("sent","Sent"),ve(s,r)}))}m.append(o,R("div",r=>{r.className="item-time",r.innerText=y.SubmitDateStr})),n.push(m)}n[0].style.marginTop="0"}t(this,ne).replaceChildren(...n),t(this,ne).scrollTop=t(this,ne).scrollHeight}}Y=new WeakMap,F=new WeakMap,G=new WeakMap,ne=new WeakMap,k.CustomerCommunication=Ge,k.InternalComment=ze,Object.defineProperty(k,Symbol.toStringTag,{value:"Module"})});
|
|
//# sourceMappingURL=app.min.js.map
|