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