2024-03-26 15:56:31 +08:00

9 lines
46 KiB
JavaScript

(function(R,O){typeof exports=="object"&&typeof module<"u"?O(exports):typeof define=="function"&&define.amd?define(["exports"],O):(R=typeof globalThis<"u"?globalThis:R||self,O(R["lib-app"]={}))})(this,function(R){"use strict";var Xe=Object.defineProperty;var ze=(R,O,U)=>O in R?Xe(R,O,{enumerable:!0,configurable:!0,writable:!0,value:U}):R[O]=U;var q=(R,O,U)=>(ze(R,typeof O!="symbol"?O+"":O,U),U);const O=window["lib-ui"].createElement,U=window["lib-ui"].setTooltip,ie=window["lib-ui"].showAlert,se=window["lib-ui"].createPicture,ge=window["lib-ui"].createAudio,Ee=window["lib-ui"].createVideo,D=window["lib-ui"].createFile,Oe=window["lib-ui"].createIcon,Te=window["lib-ui"].Popup,ae=window["lib-ui"].Grid;window["lib-ui"].Dropdown,window["lib-utility"].global;const oe=window["lib-utility"].isEmail;function Q(y,e){const t=O("div","comm"),l=O("div","title-bar",y,O("div","title-functions",...e));return t.appendChild(l),t}function Z(y,e,t){switch(e){case"application/pdf":case".pdf":y.appendChild(D(t,"file-pdf"));break;case"application/msword":case"application/vnd.ms-word":case"application/vnd.openxmlformats-officedocument.wordprocessingml.document":case".doc":case".docx":y.appendChild(D(t,"file-word"));break;case"application/vnd.ms-excel":case"application/vnd.openxmlformats-officedocument.spreadsheetml.sheet":case".xls":case".xlsx":y.appendChild(D(t,"file-excel"));break;case"application/vnd.ms-powerpoint":case"application/vnd.openxmlformats-officedocument.presentationml.presentation":case".ppt":case".pptx":y.appendChild(D(t,"file-powerpoint"));break;case"application/smil":case".smil":break;case"audio/aac":case"audio/amr":case"audio/mp3":case"audio/mpeg":case"audio/x-mpeg":case"audio/ogg":case"audio/opus":case"audio/wav":case"audio/webm":case".aac":case".amr":case".mp3":case".ogg":case".opus":case".wav":y.appendChild(ge(e,t));break;case"text/plain":case"text/x-vcard":case".txt":case".vcard":y.appendChild(D(t,"id-card"));break;case"video/3gpp":case"video/mp2t":case"video/mp4":case"video/mpeg":case"video/x-mpeg":case"video/quicktime":case"video/webm":case".3gp":case".3gpp":case".mp4":case".mpg":case".mov":case".webm":y.appendChild(Ee(t));break;case".jpg":case".jpeg":case".jfif":case".png":case".gif":case".bmp":y.appendChild(se(t));break;default:/^image\//.test(e)?y.appendChild(se(t)):/^audio\//.test(e)?y.appendChild(D(t,"music")):/^video\//.test(e)?y.appendChild(D(t,"video")):y.appendChild(D(t));break}return y}const re={limit:1258291,text:"1.2MB"},F=[".amr",".ogv","application/msword","application/vnd.ms-word","application/vnd.openxmlformats-officedocument.wordprocessingml.document","application/vnd.ms-excel","application/vnd.openxmlformats-officedocument.spreadsheetml.sheet","application/vnd.ms-powerpoint","application/vnd.openxmlformats-officedocument.presentationml.presentation","application/pdf","audio/aac","audio/amr","audio/mp3","audio/mpeg","audio/x-mpeg","audio/ogg","audio/opus","audio/wav","audio/webm","image/bmp","image/gif","image/jpeg","image/jfif","image/png","image/tiff","image/webp","text/plain","text/vcard","text/x-vcard","video/3gpp","video/mp2t","video/mp4","video/mpeg","video/x-mpeg","video/quicktime","video/webm"];function $(y,e,t){const l=y.querySelector(".file-selector>.selector-name");if(l!=null&&e!=null){let o=e.type;if((o==null||o.length===0)&&(o=e.name,o=o.substring(o.lastIndexOf("."))),F.indexOf(o)<0){ie(t("P_WO_ERROR","Error"),t("P_CU_TYPENOTSUPPORTED",'File type "{type}" is now not supported.').replace("{type}",o));return}const c=/^image\//.test(o);if(!c&&e.size>re.limit){ie(t("P_WO_ERROR","Error"),t("P_WO_ATTACHMENTSIZEEXCEEDSTHEMAXIMUMTIPS",`Attachment size exceeds the maximum allowed to be sent (${re.text})`),"warn");return}const n=e.name;if(l.style.display="",l.innerText=n,c){const a=new Image,i=new FileReader;i.onload=s=>{a.src=s.target.result,U(l,a)},i.onerror=()=>U(l,n),i.readAsDataURL(e)}else U(l,n);return e}}function be(y,e){switch(y){case 0:case 1:case 5:case 6:return e[y];case 9:case 10:case 412:return e[9];default:return e[9999]}}function le(y,e,t){var m;const l={0:e("P_CU_PENDING","Pending"),1:e("P_WO_SENT","Sent"),5:e("P_CU_DELIVERYCONFIRMED","Delivery Confirmed"),6:e("P_CU_RESENT","Resent"),9:e("P_MA_FAILED","Failed"),9999:e("P_CU_UNKNOWN","Unknown")},o=[0,1,5,6,9,10,412],c=[1,5,6],n=[9,10,412];let a=-100;const i=[],s=[];if(!y.StatusIncorrect&&((m=y.Participator)==null?void 0:m.length)>0)for(let C of y.Participator)oe(C.CustomerNumber)||(i.indexOf(C.Status)<0&&i.push(C.Status),C.statusText=be(C.Status,l),s.push(C));i.length===1?a=i[0]:i.length>1&&(a=i.filter(C=>c.indexOf(C)<0).sort((C,L)=>L-C)[0]??1);const d=l[n.includes(a)?9:a]??l[9999],_=c.includes(a)?null:"#ffc107",h=t.option.statusUpdatable;let r;return(h!==!1||i.length>1)&&(r=O("div",C=>{for(let L=0;L<s.length;++L)C.appendChild(O("div",u=>{const g=s[L];h!==!1&&g.StatusChanged?u.append(O("span",E=>E.innerText=`${g.CustomerNumber}: `),O("span",E=>{E.style.color="#2140fb",E.style.cursor="pointer",E.innerText=g.statusText,E.addEventListener("click",()=>{typeof t.option.onMessageStatusClicked=="function"&&t.option.onMessageStatusClicked(g)})})):u.innerText=`${g.CustomerNumber}: ${g.statusText}`}));h!==!1&&C.appendChild(O("div",L=>{L.className="tip-function-button",L.addEventListener("click",async()=>{for(let N of y.Participator)switch(N.Status){case 0:case 1:case 5:case 6:N.statusChanged=String(N.Status);break;case 9:case 10:case 412:N.statusChanged="9";break;default:N.statusChanged="-1";break}const u=O("div","status-grid");await new Te({onMasking:t.option.onMasking,title:e("P_CU_UPDATESTATUS","Update Status"),content:O("div",N=>{N.className="update-status-wrapper",N.style.width="500px"},u),buttons:[{text:e("P_WO_OK","OK"),key:"ok",trigger:()=>{const N=s.filter(A=>{switch(A.statusChanged){case"-1":return o.includes(A.Status);case"9":return n.indexOf(A.Status)<0;default:return String(A.Status)!==A.statusChanged}}).map(A=>{let S=Number(A.statusChanged);return(isNaN(S)||S<0)&&(S=9999),{Id:A.Id,Status:S}});typeof t.option.onUpdateMessageStatus=="function"&&t.option.onUpdateMessageStatus(N)}},{text:e("P_WO_CANCEL","Cancel"),key:"cancel"}]}).show();const E=new ae(u);E.allowHtml=!0,E.columns=[{key:"CustomerNumber",caption:e("P_JS_NUMBER","Number"),width:150},{key:"statusText",caption:e("P_CU_CURRENTSTATUS","Current Status"),width:155},{key:"statusChanged",caption:e("P_CU_REVISEDSTATUS","Revised Status"),width:155,type:ae.ColumnTypes.Dropdown,source:[{value:"-1",text:l[9999]},{value:"0",text:l[0]},{value:"1",text:l[1]},{value:"5",text:l[5]},{value:"6",text:l[6]},{value:"9",text:l[9]}]}],E.init(),E.source=s})},Oe("fa-light","wave-sine")))})),[a,d,_,r]}function ce(y,e,t,l){var c;let o="";if(!y.IsReply&&((c=y.OriPhoneNumbers)==null?void 0:c.length)>0)for(let n of y.OriPhoneNumbers){let a;const i=oe(n);if((e==null?void 0:e.length)>0){let s=i?e.find(d=>d.Email===n):e.find(d=>d.MobilePhone===n);s!=null?a=`${i?s.Email:s.MobilePhoneDisplayText} - ${s.Name}`:(t==null?void 0:t.length)>0&&(s=i?t.find(d=>d.Email===n):t.find(d=>d.MobilePhone===n),s!=null&&(a=`${i?s.Email:s.MobilePhoneDisplayText} - ${s.Name}`))}o+=(a??n)+`
`}return o!==""&&(o=l("P_CU_SENDTO_COLON","Sent to :")+`
${o}`),o}function V(y,e){var t;if((y==null?void 0:y.length)>0&&(e==null?void 0:e.length)>0){for(let l of y)if(((t=l.Participator)==null?void 0:t.length)>0)for(let o of l.Participator){const c=e.filter(n=>n.MobilePhoneDisplayText===o.CustomerNumber)[0];o.customerName=c==null?void 0:c.Name}}}const ee=window["lib-ui"].Grid,we=window["lib-ui"].Dropdown,b=window["lib-ui"].createElement,xe=window["lib-ui"].createCheckbox,de=window["lib-ui"].Popup,K=window["lib-ui"].showAlert,Ne=window["lib-utility"].isEmail,j=window["lib-utility"].nullOrEmpty;let v=window["lib-utility"].r;class ue{constructor(e={}){q(this,"_var",{});this._var.option=e;const t=e==null?void 0:e.getText;typeof t=="function"&&(v=t)}async show(e=document.body){const t=Math.max.apply(null,[...document.querySelectorAll("[tabindex]")].map(r=>r.tabIndex??0))+3,l=this._var.option.contact,o=b("input",r=>{r.type="text",r.className="ui-input",r.tabIndex=t+1,r.maxLength=200,r.autocomplete="off"}),c=new we({tabIndex:t+2});c.source=[{value:"0",text:v("P_CR_TEXT","Text")},{value:"1",text:v("P_CR_EMAIL","Email")},{value:"2",text:v("P_CR_PHONE","Phone")}];const n=b("input",r=>{r.type="email",r.className="ui-input",r.tabIndex=t+3,r.maxLength=100,r.autocomplete="off"}),a=b("input",r=>{r.type="tel",r.className="ui-input",r.tabIndex=t+4,r.maxLength=50,r.autocomplete="off"}),i=xe({tabIndex:t+5}),s=b("textarea",r=>{r.className="ui-text",r.tabIndex=t+6,r.maxLength=2e3,r.style.height="100px"}),d=[];this._var.option.company&&d.push({text:l==null?v("P_WO_ADDCONTACTRECORD","Add Contact Record"):v("P_WO_EDITCONTACTRECORD","Edit Contact Record"),trigger:()=>{const r=this.prepare();if(r==null)return!1;if(r.SaveToCustomer=1,typeof this._var.option.onSave=="function")return this._var.option.onSave.call(this,r,"customerrecord")}}),d.push({text:v("P_WO_WORKORDERONLY","Work Order Only"),trigger:()=>{const r=this.prepare();if(r==null)return!1;if(r.SaveToCustomer=0,typeof this._var.option.onSave=="function")return this._var.option.onSave.call(this,r,"workorder")}},{text:v("P_WO_CANCEL","Cancel")});const _=new de({onMasking:this._var.option.onMasking,title:l==null?v("P_CR_ADDCONTACT","Add Contact"):v("P_CR_EDITCONTACT","Edit Contact"),content:b("div",r=>{r.className="setting-wrapper",r.style.width="500px"},b("div","setting-item",b("span","setting-label setting-required",v("P_CR_CONTACTNAME_COLON","Contact Name:")),o),b("div","setting-item",b("span","setting-label",v("P_CR_CONTACTPREFERENCES_COLON","Contact Preferences:")),c.create()),b("div","setting-item",b("span","setting-label",v("P_CR_EMAILADDRESS_COLON","Email Address:")),n),b("div","setting-item",b("span","setting-label",v("P_WO_MOBILE_COLON","Mobile:")),a),b("div","setting-item",b("span","setting-label",v("P_CR_OPTOUT_COLON","Opt Out:")),i),b("div","setting-item",b("span","setting-label",v("P_CR_NOTES_COLON","Notes:")),s)),buttons:d});l!=null?(o.value=l.Name,c.select(String(l.ContactPreference)),n.value=l.Email,a.value=l.MobilePhone,i.querySelector("input").checked=l.OptOut,s.value=l.Notes):c.select("0"),this._var.refs={contactName:o,preferences:c,contactEmail:n,contactMobile:a,checkOpt:i,contactNotes:s};const h=await _.show(e);return setTimeout(()=>o.focus()),h}prepare(){const e=this._var.refs.contactName.value,t=this._var.refs.preferences.selected.value,l=this._var.refs.contactEmail.value,o=this._var.refs.contactMobile.value,c=this._var.refs.checkOpt.querySelector("input").checked,n=this._var.refs.contactNotes.value,a=this._var.option.contact==null?v("P_CR_ADDCONTACT","Add Contact"):v("P_CR_EDITCONTACT","Edit Contact");if(j(e))return K(a,v("P_CR_CONTACTNAMECANNOTBEEMPTY","Contact Name cannot be empty."),"warn").then(()=>this._var.refs.contactName.focus()),null;if((t==0||t==2)&&j(o))return K(a,v("P_CR_MOBILECANNOTBEEMPTY","Mobile cannot be empty."),"warn").then(()=>this._var.refs.contactMobile.focus()),null;if(t==1&&j(l))return K(a,v("P_CU_EMAILCANNOTBEEMPTY","Email cannot be empty."),"warn").then(()=>this._var.refs.contactEmail.focus()),null;if(!j(l)&&!Ne(l))return K(a,v("P_CR_EMAILISNOTAVALIDEMAILADDRESS","The email address is invalid."),"warn").then(()=>this._var.refs.contactEmail.focus()),null;let i=this._var.option.contact;return i==null?i={}:i.OptOut!==c&&(c!==!1||i.OptOut_BC===!1)&&(i.selected=!c),i.OldName=i.Name,i.OldMobilePhone=i.MobilePhone,i.Name=e,i.ContactPreference=t,i.Email=l,i.MobilePhone=o,i.OptOut=c,i.Notes=n,i}}class Se{constructor(e={}){q(this,"_var",{});this._var.option=e;const t=e==null?void 0:e.getText;typeof t=="function"&&(v=t)}async show(e,t=document.body){const l=b("div","selcontact-grid"),c=await new de({onMasking:this._var.option.onMasking,title:e,content:b("div","selcontact-wrapper",l),buttons:[{text:v("P_WO_OK","OK"),key:"ok",trigger:()=>{if(typeof this._var.option.onOk=="function")return this._var.option.onOk.call(this,this._var.grid.source.filter(a=>a.selected))}},{text:v("P_WO_CANCEL","Cancel"),key:"cancel"}]}).show(t),n=new ee(l);return n.columns=[{key:"selected",type:ee.ColumnTypes.Checkbox,width:40},{key:"Name",caption:v("P_CR_CONTACTNAME","Contact Name"),width:100},{key:"Email",caption:v("P_CR_CONTACTEMAIL","Contact Email"),css:{width:180,"text-align":"left"}},{key:"MobilePhoneDisplayText",caption:v("P_CR_CONTACTMOBILE","Contact Mobile"),width:130},{key:"ContactPreferenceStr",caption:v("P_CR_CONTACTPREFERENCES","Contact Preferences"),width:100},{key:"OptOut",caption:v("P_CR_OPTOUT","Opt Out"),type:ee.ColumnTypes.Checkbox,width:70,enabled:!1,align:"center"},{key:"Notes",caption:v("P_CR_NOTES","Notes"),width:120}],n.init(),n.source=this._var.option.contacts.sort(function(a,i){return(i.Text||i.Email?1:0)-(a.Text||a.Email?1:0)}),this._var.grid=n,c}set source(e){this._var.option.contacts=e,this._var.grid!=null&&(this._var.grid.source=e)}}const te=window["lib-ui"].Grid,G=window["lib-ui"].createElement,Pe=window["lib-ui"].Popup,pe=window["lib-utility"].nullOrEmpty,ke=window["lib-utility"].r,Me=window["lib-utility"].contains;let W=ke;class Re{constructor(e={}){q(this,"_var",{});this._var.option=e;const t=e==null?void 0:e.getText;typeof t=="function"&&(W=t)}async show(e,t=document.body){const l=Math.max.apply(null,[...document.querySelectorAll("[tabindex]")].map(i=>i.tabIndex??0))+3,o=G("div","follower-grid"),n=await new Pe({onMasking:this._var.option.onMasking,title:e,content:G("div","follower-wrapper",G("div",i=>i.innerText=W("P_CR_WHODOYOUWANTTORECEIVECUSTOMERNOTIFICATIONS","Who do you want to receive customer notifications?")),G("input",i=>{i.type="text",i.tabIndex=l+3,i.className="ui-input follower-search",i.addEventListener("input",()=>{const s=i.value;pe(s)?this._var.grid.source=this._var.option.followers.sort(function(d,_){return(_.Text||_.Email?1:0)-(d.Text||d.Email?1:0)}):this._var.grid.source=this._var.option.followers.filter(d=>d.Text||d.Email||Me(d.DisplayName,s,!0)).sort(function(d,_){return(_.Text||_.Email?1:0)-(d.Text||d.Email?1:0)})})}),o),buttons:[{text:W("P_WO_OK","OK"),key:"ok",trigger:()=>{if(typeof this._var.option.onOk=="function")return this._var.option.onOk.call(this,this._var.grid.source.filter(i=>i.Email||i.Text))}},{text:W("P_WO_CANCEL","Cancel"),key:"cancel"}]}).show(t);n.querySelector(".follower-search").focus();const a=new te(o);return a.columns=[{key:"DisplayName",caption:W("P_WO_CONTACTNAME","Contact Name"),width:240},{key:"ContactTypeName",caption:W("P_WO_CONTACTTYPE","Contact Type"),width:120},{key:"Text",caption:W("P_CR_TEXT","Text"),type:te.ColumnTypes.Checkbox,width:60,enabled:i=>!pe(i.Mobile)},{key:"Email",caption:W("P_CR_EMAIL","Email"),type:te.ColumnTypes.Checkbox,width:70}],a.init(),a.source=this._var.option.followers.sort(function(i,s){return(s.Text||s.Email?1:0)-(i.Text||i.Email?1:0)}),this._var.grid=a,n}}const B=window["lib-ui"].Grid,Le=window["lib-ui"].GridColumn,f=window["lib-ui"].createElement,w=window["lib-ui"].setTooltip,k=window["lib-ui"].createIcon,me=window["lib-ui"].createCheckbox,fe=window["lib-ui"].createRadiobox,Y=window["lib-ui"].showAlert,he=window["lib-ui"].showConfirm,Ae=window["lib-ui"].Popup,Ie=window["lib-utility"].r,x=window["lib-utility"].nullOrEmpty,Ue=window["lib-utility"].formatUrl,_e=window["lib-utility"].escapeEmoji,Ce=window["lib-utility"].isEmail,De=window["lib-utility"].isPhone;class We extends Le{static create(){return f("div","contact-wrapper",f("div","contact-name"),f("div","contact-note"))}static setValue(e,t,l,o,c){const n=l.values,a=e.querySelector(".contact-name");a.innerText=n.Name,a.scrollWidth>a.offsetWidth&&w(a,n.Name,!1,c.element);const i=e.querySelector(".contact-note");i.innerText=n.Notes,i.scrollWidth>i.offsetWidth&&w(i,n.Notes,!1,c.element)}}let p=Ie;class qe{constructor(e){q(this,"_var",{data:{}});this._var.option=e??{};const t=e==null?void 0:e.getText;typeof t=="function"&&(p=t)}get _autoUpdates(){return this._var.container.querySelector(".check-auto-update>input")}get autoUpdatesEnabled(){var e;return((e=this._autoUpdates)==null?void 0:e.disabled)!==!0}set autoUpdatesEnabled(e){var l,o,c,n;const t=this._autoUpdates;t!=null&&(e===!1?(t.disabled=!0,(o=(l=t.parentElement)==null?void 0:l.classList)==null||o.add("disabled")):(t.disabled=!1,(n=(c=t.parentElement)==null?void 0:c.classList)==null||n.remove("disabled")))}get autoUpdates(){var e;return(e=this._autoUpdates)==null?void 0:e.checked}set autoUpdates(e){const t=this._autoUpdates;t!=null&&(t.checked=e,t.dispatchEvent(new Event("change")))}get _statusLink(){return this._var.container.querySelector(".check-status-link>input")}get statusLinkEnabled(){var e;return((e=this._statusLink)==null?void 0:e.disabled)!==!0}set statusLinkEnabled(e){var l,o,c,n;const t=this._statusLink;t!=null&&(e===!1?(t.disabled=!0,(o=(l=t.parentElement)==null?void 0:l.classList)==null||o.add("disabled")):(t.disabled=!1,(n=(c=t.parentElement)==null?void 0:c.classList)==null||n.remove("disabled")))}get statusLink(){var e;return(e=this._statusLink)==null?void 0:e.checked}set statusLink(e){const t=this._statusLink;t!=null&&(t.checked=e,t.dispatchEvent(new Event("change")))}set loading(e){this._var.container!=null&&(this._var.enter.disabled=e,this._var.container.querySelector(".customer-name>.ui-input").disabled=e,this._var.container.querySelector(".button-send-message").disabled=e,this._var.container.querySelector(".button-edit-contacts").disabled=e,this._var.container.querySelector(".button-edit-followers").disabled=e)}get text(){var e;return(e=this._var.enter)==null?void 0:e.value}set text(e){const t=this._var.enter;t!=null&&(t.value=e,e=String(x(e)?0:val.length)+"/"+String(this._var.option.maxLength),this._var.container.querySelector(".message-bar .prompt-count").innerText=e)}get file(){var e,t;return this._var.file||((t=(e=this._var.fileControl)==null?void 0:e.files)==null?void 0:t[0])}set file(e){var l,o;(l=this._var.fileControl)==null||l.remove();const t=this._var.container.querySelector(".file-selector>.selector-name");if(e==null)this._var.fileControl=null,this._var.file=null,t!=null&&(t.style.display="none",t.innerText="",(o=t.querySelector(".ui-tooltip-wrapper"))==null||o.remove());else{if(e instanceof HTMLInputElement){this._var.fileControl=e,this._var.file=e.files[0];const c=this._var.container.querySelector(".file-selector>.selector-link");c!=null&&c.appendChild(e)}else this._var.fileControl=null,this._var.file=e;t!=null&&(t.style.display="",t.innerText=e.name,w(t,e.name))}}get customerName(){var e;return(e=this._var.container.querySelector(".customer-name>.ui-input"))==null?void 0:e.value}set customerName(e){const t=this._var.container.querySelector(".customer-name>.ui-input");t!=null&&(t.value=e)}get contacts(){return[...this._var.contacts.children].filter(e=>e.querySelector("span").dataset.notsend=="false").map(e=>{const t=e.querySelector("span");return{Key:t.dataset.to,Value:t.dataset.name}})}set contacts(e){if(this.setData("contacts",e),this._var.contacts.replaceChildren(),(e==null?void 0:e.length)>0){var t=e.sort(function(o,c){return o.Name==c.Name?0:o.Name>c.Name?1:-1});const l=this._var.data.messages;this._var.contactsUpdated!==!0&&(l==null?void 0:l.length)>0&&(V(l,e),this._var.contactsUpdated=!0);for(let o of t){const c=String(o.MobilePhoneDisplayText).trim(),n=String(o.Email).trim(),a=String(o.ContactPreference);if(a!=="1"&&!De(c)||a==="1"&&!Ce(n))continue;const i=a==="1"?n:c;let s,d,_;if(o.OptOut||o.OptOut_BC||o.selected===!1)s="times",_=p("P_CU_OPTEDOUT_PROMPT","User has opted out of messages");else switch(a){case"0":o.MobilePhoneStatus!==0?(s="times",o.MobilePhoneStatus===412&&(_=p("P_CU_LANDLINE","Landline"))):s="comment-lines",d=p("P_CU_TEXTSTO_COLON","Texts to:");break;case"2":s="phone",_=p("P_CU_NOMESSAGE","No Messages Sent");break;default:s="envelope",d=p("P_CU_EMAILSTO_COLON","Emails to:");break}const h=f("span",C=>{C.dataset.to=i,C.dataset.name=o.Name,C.dataset.notsend=o.OptOut||o.OptOut_BC||o.selected===!1,C.innerText=o.Name}),r=f("div","contact-item",k("fa-light",s,{fill:o.OptOut||o.OptOut_BC||o.selected===!1?"red":""}),h);this._var.contacts.appendChild(r);let m=_||`${d} ${i}`;h.scrollWidth>h.offsetWidth&&(m=p("P_WO_NAME_COLON","Name:")+` ${o.Name}
${m}`),w(h,m)}this._var.message.scrollTop=this._var.message.scrollHeight}}set readonly(e){if(this._var.option.readonly=e,this._var.container==null)return;const t=this._var.container.querySelector(".check-status-link");e===!0?t.classList.add("disabled"):t.classList.remove("disabled"),t.querySelector("input").disabled=e;const l=e===!0?"none":"";this._var.container.querySelector(".button-edit-contacts").style.display=l,this._var.container.querySelector(".button-edit-followers").style.display=l,this._var.container.querySelector(".message-bar").style.display=l}set recordReadonly(e){this._var.option.recordReadonly=e,this._var.container!=null&&(this._var.container.querySelector(".button-edit-contacts").style.display=e===!0?"none":"",this._var.container.querySelector(".button-edit-followers").style.display=e===!0?"none":"")}set companyName(e){this._var.option.companyName=e;const t=this._var.container.querySelector(".title-company");x(e)?t.style.display="none":(t.innerText=e,t.style.display="")}set companyCode(e){const t=this._var.option;t.companyCode=e;const l=this._var.container.querySelector(".title-company");x(t.companyName)?l.style.display="none":(l.innerText=t.companyName,x(e)||(l.innerText=t.companyName+"/"+e),l.style.display="")}get followers(){return[...this._var.followers.children].map(e=>{const t=e.querySelector("span");return{Email:t.dataset.email,MobilePhone:t.dataset.mp,Value:t.dataset.name}})}set followers(e){if(this._var.data.followers=e,this._var.followers.replaceChildren(),(e==null?void 0:e.length)>0){this._var.container.querySelector(".follower-bar").style.display="",w(this._var.buttonFollower,p("P_CU_EDITFOLLOWERS","Edit Followers")),this._var.container.querySelector(".follower-bar>.bar-list").appendChild(this._var.buttonFollower);for(let t of e){if(t.OptOut)continue;const l=String(t.MobilePhone).trim(),o=String(t.MobilePhoneDisplayText).trim(),c=String(t.Email).trim(),n=[];t.SendEmail&&n.push(p("P_CU_EMAILSTO_COLON","Emails to:")+` ${c}`),t.SendText&&n.push(p("P_CU_TEXTSTO_COLON","Texts to:")+` ${o}`);let a;t.SendText&&t.SendEmail?a="at":a=t.SendText?"comment-lines":"envelope";const i=f("span",d=>{t.SendEmail&&(d.dataset.email=c),t.SendText&&(d.dataset.mp=l),d.dataset.name=t.Name,d.innerText=t.Name}),s=f("div","contact-item",k("fa-light",a),i);this._var.followers.appendChild(s),i.scrollWidth>i.offsetWidth&&n.splice(0,0,p("P_WO_NAME_COLON","Name:")+` ${t.Name}`),w(i,n.join(`
`))}}else this._var.container.querySelector(".follower-bar").style.display="none",w(this._var.buttonFollower,p("P_CR_ADDFOLLOWERS","Add Followers")),this._var.container.querySelector(".button-edit-contacts").insertAdjacentElement("beforebegin",this._var.buttonFollower);this._var.message.scrollTop=this._var.message.scrollHeight}setData(e,t){this._var.data[e]=t}create(){const e=this._var.option,t=e.readonly,l=me({className:"check-auto-update",checked:e.autoUpdates,checkedNode:k("fa-regular","redo-alt"),uncheckedNode:k("fa-regular","ban"),onchange:function(){w(l,this.checked?p("P_CU_AUTOUPDATESENABLED","Auto Updates Enabled"):p("P_CU_AUTOUPDATESDISABLED","Auto Updates Disabled"))}});e.autoUpdatesVisible===!1&&(l.style.display="none");const o=this,c=me({className:"check-status-link",enabled:!t,checked:e.statusLink,checkedNode:k("fa-regular","link"),uncheckedNode:k("fa-regular","unlink"),onchange:function(){w(c,this.checked?p("P_WO_STATUSLINKINCLUDED","Status Link Included"):p("P_WO_STATUSLINKEXCLUDED","Status Link Excluded")),typeof e.onStatusLinkChanged=="function"&&e.onStatusLinkChanged.call(o,this.checked)}});e.statusLinkVisible===!1&&(c.style.display="none");const n=Q(f("div",null,f("div",s=>{s.className="title-module",s.innerText=e.title??p("P_WO_CUSTOMERCOMMUNICATION","Customer Communication")}),f("div",s=>{s.className="title-company",x(e.companyName)?s.style.display="none":x(e.companyCode)?s.innerText=e.companyName:s.innerText=e.companyName+"/"+e.companyCode})),[w(l,p("P_CU_AUTOUPDATESENABLED","Auto Updates Enabled")),w(c,p("P_WO_STATUSLINKEXCLUDED","Status Link Excluded"))]);this._var.contacts=this._createContacts(n,e),this._var.followers=this._createFollowers(n,e);const a=f("textarea","ui-text");a.placeholder=p("P_CU_ENTERMESSAGEHERE","Enter Message Here"),e.maxLength??(e.maxLength=3e3),a.maxLength=e.maxLength,a.addEventListener("input",()=>{const s=this.text,d=String(x(s)?0:s.length)+"/"+String(e.maxLength);this._var.container.querySelector(".message-bar .prompt-count").innerText=d}),a.addEventListener("paste",s=>{if(e.customerNameVisible===!0)return;const d=s.clipboardData.items;if((d==null?void 0:d.length)>0){const _=d[0],h=_.webkitGetAsEntry();if(_.kind==="file"&&(h==null||h.isFile)){const r=_.getAsFile();r!=null&&(s.preventDefault(),this.file=$(n,r,p))}}}),this._var.enter=a,n.appendChild(f("div",s=>{s.className="message-bar",t===!0&&(s.style.display="none"),s.addEventListener("dragover",d=>{if(e.readonly!==!0){const _=d.dataTransfer.items[0];(_==null?void 0:_.kind)==="file"&&(d.preventDefault(),_.type.length>0&&F.indexOf(_.type)<0?d.dataTransfer.dropEffect="none":d.dataTransfer.dropEffect="link")}}),s.addEventListener("drop",d=>{if(e.readonly!==!0){const _=d.dataTransfer.files[0];_!=null&&(d.preventDefault(),this.file=$(n,_,p))}})},a,f("div",s=>s.style.textAlign="right",f("div","customer-left",f("div",s=>{s.className="customer-name",e.customerNameVisible!==!0&&(s.style.display="none")},f("span",s=>s.innerText=p("P_WO_NAME_COLON","Name:")),f("input",s=>{s.type="text",s.className="ui-input"})),f("div","file-selector",f("div",s=>{s.className="selector-link",s.addEventListener("click",()=>{var _;(_=this._var.fileControl)==null||_.remove();const d=f("input",h=>{h.type="file",h.accept=F.join(","),h.addEventListener("change",()=>{var m;const r=$(n,(m=h.files)==null?void 0:m[0],p);r!=null&&(this.file=r)})});s.appendChild(this._var.fileControl=d),d.dispatchEvent(new MouseEvent("click"))})},k("fa-regular","link")),f("span",s=>{s.className="selector-name",s.style.display="none"}),f("layer",s=>{s.appendChild(k("fa-regular","times")),s.addEventListener("click",()=>this.file=null)}))),f("div","prompt-count"),f("button",s=>{s.className="roundbtn button-send-message",s.style.backgroundColor="rgb(19, 150, 204)",s.appendChild(k("fa-solid","paper-plane")),w(s,p("P_M3_SENDMESSAGE","Send Message")),s.addEventListener("click",()=>{const d=this.text;if(x(d==null?void 0:d.trim())){const _=Y(p("P_WO_ERROR","Error"),p("P_WO_PLEASEINPUTTHEMESSAGE","Please input the message."),"warn");typeof e.onMasking=="function"&&(e.onMasking(!0),_.then(()=>e.onMasking(!1)));return}typeof e.onAddMessage=="function"&&(this.loading=!0,e.onAddMessage(this.text,this.file))})}))));const i=f("div","list-bar");return this._var.message=i,n.appendChild(i),this._var.container=n}_createContacts(e,t){const l=t.readonly,o=t.recordReadonly,c=f("div","bar-list-container");return e.append(f("div","contact-bar",f("div","bar-icon",k("fa-solid","user-circle",{fill:"lightgray"})),f("div","bar-list",c,f("button",n=>{n.className="roundbtn button-edit-contacts",n.style.backgroundColor="rgb(1, 199, 172)",l===!0&&(n.style.display="none"),n.appendChild(k("fa-solid","user-edit")),w(n,p("P_CU_EDITCONTACTS","Edit Contacts")),n.addEventListener("click",()=>{const a=new Ae({onMasking:t.onMasking,title:f("div",i=>{i.style.display="flex",i.style.alignItems="center",i.style.padding="10px 0 6px 12px",i.append(f("div",s=>{s.className="ui-popup-move",s.style.flex="1 1 auto"},f("div",s=>s.innerText=p("P_CU_EDITCONTACTS","Edit Contacts")),f("div",s=>{s.className="title-company",s.style.maxWidth="540px",x(t.companyName)?s.style.display="none":x(t.companyCode)?s.innerText=t.companyName:s.innerText=t.companyName+"/"+t.companyCode})),f("button",s=>{s.style.flex="0 0 auto",s.style.backgroundColor="rgb(1, 199, 172)",s.style.marginRight="10px",s.className="roundbtn button-from-customer-record",o&&(s.style.display="none"),s.appendChild(k("fa-solid","handshake",{width:"16px",height:"16px"})),s.addEventListener("click",()=>{const d=new Se({getText:t.getText,contacts:[],onOk:h=>{typeof t.onSelectCRContacts=="function"&&(h==null||h.map(m=>(delete m.selected,m)),t.onSelectCRContacts(h));const r=this._var.data.contacts;this._var.gridContact.source=r.filter(m=>m.Id>=0).map(m=>(m.OptOut||m.OptOut_BC||typeof m.selected>"u"&&(m.selected=!0),m)),this._var.gridWo.source=r.filter(m=>m.Id<0).map(m=>(m.OptOut||m.OptOut_BC||typeof m.selected>"u"&&(m.selected=!0),m))}});var _=p("P_CU_SELECTFROMCUSTOMERRECORD","Select from Customer Record");if(d.show(_,e),typeof t.onOpenSelectCRContacts=="function"){const h=t.onOpenSelectCRContacts();return typeof(h==null?void 0:h.then)=="function"?h.then(r=>(r.map(m=>{for(let C of this._var.data.contacts)if(m.Id===C.Id){m.selected=!0;break}return typeof m.selected>"u"&&(m.selected=!1),m}),this._var.data.contacts.filter(m=>m.Id>=0).map(m=>(m.OptOut||m.OptOut_BC||typeof m.selected>"u"&&(m.selected=!0),m)),d.source=r,r)):!1}}),w(s,p("P_CU_SELECTFROMCUSTOMERRECORD","Select from Customer Record"))}),f("button",s=>{s.style.flex="0 0 auto",s.style.backgroundColor="rgb(1, 199, 172)",s.style.marginRight="10px",s.className="roundbtn button-add-contact",o&&(s.style.display="none"),s.appendChild(k("fa-solid","user-plus",{width:"16px",height:"16px"})),s.addEventListener("click",()=>{new ue({getText:t.getText,company:!x(t.companyName),onSave:_=>{if(this._var.gridContact.source.some(r=>r.Name===_.Name&&r.MobilePhone===_.MobilePhone))return Y(p("P_CR_ADDCONTACT","Add Contact"),p("P_WO_CONTACTNAMEANDMOBILEUNIQUECOMBINATION","Contact name and contact mobile must be a unique combination."),"warn"),!1;if(typeof t.onSave=="function"){const r=t.onSave(_,!0);return typeof(r==null?void 0:r.then)=="function"?r.then(m=>(this._var.gridContact.source=m.filter(C=>C.Id>=0).map(C=>(C.OptOut||C.OptOut_BC||typeof C.selected>"u"&&(C.selected=!0),C)),this._var.gridWo.source=m.filter(C=>C.Id<0).map(C=>(C.OptOut||C.OptOut_BC||typeof C.selected>"u"&&(C.selected=!0),C)),m)):!1}}}).show(e)}),w(s,p("P_CR_ADDCONTACT","Add Contact"))}))}),content:f("div",null,f("div",i=>{x(t.companyName)&&(i.style.display="none"),i.style.fontWeight="bold",i.innerText=p("P_CU_CONTACTSFROMCUSTOMERRECORD","Contacts from Customer Record")}),f("div",i=>{x(t.companyName)&&(i.style.display="none"),i.className="contacts-record",i.style.maxHeight="200px",i.style.width="675px",i.style.overflow="auto"}),f("div",i=>{i.style.fontWeight="bold",i.innerText=p("P_CU_CONTACTSNOTCUSTOMERRECORD","Contacts not on Customer Record")}),f("div",i=>{i.className="contacts-wo",i.style.maxHeight="200px",i.style.width="675px",i.style.overflow="auto"}))});a.show(e).then(()=>{const i=u=>({key:"selected",type:B.ColumnTypes.Checkbox,width:50,enabled:g=>!g.OptOut&&!g.OptOut_BC,onChanged:function(){typeof t.onChanged=="function"&&t.onChanged([...u._var.gridContact.source,...u._var.gridWo.source])},tooltip:g=>g.selected?p("P_CU_OPTEDIN","Opted In"):p("P_CU_OPTEDOUT","Opted Out")}),s={key:"type",type:B.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"},d={key:"Name",type:We,width:160},_={type:B.ColumnTypes.Icon,width:40,visible:!o,align:"center",iconType:"fa-light"},h=u=>({key:"edit",..._,text:"edit",tooltip:p("P_WO_EDIT","Edit"),events:{onclick:function(){new ue({getText:t.getText,contact:this,company:!x(t.companyName),onSave:(E,N)=>{if(u._var.gridContact.source.some(S=>S!==this&&S.Name===E.Name&&S.MobilePhone===E.MobilePhone)||u._var.gridWo.source.some(S=>S!==this&&S.Name===E.Name&&S.MobilePhone===E.MobilePhone))return Y(p("P_CR_EDITCONTACT","Edit Contact"),p("P_WO_CONTACTNAMEANDMOBILEUNIQUECOMBINATION","Contact name and contact mobile must be a unique combination."),"warn"),!1;if(typeof t.onSave=="function"){const S=t.onSave(E);return typeof(S==null?void 0:S.then)=="function"?S.then(ne=>(u._var.gridContact.source=ne.filter(P=>P.Id>=0).map(P=>(P.OptOut||P.OptOut_BC||typeof P.selected>"u"&&(P.selected=!0),P)),u._var.gridWo.source=ne.filter(P=>P.Id<0).map(P=>(P.OptOut||P.OptOut_BC||typeof P.selected>"u"&&(P.selected=!0),P)),ne)):!1}}}).show(e)}}}),r=new B;r.height=0,r.allowHtml=!0,r.headerVisible=!1,r.columns=[i(this),s,d,{key:"Email",width:180},{key:"MobilePhoneDisplayText",width:130},h(this),{key:"delete",..._,text:"times",tooltip:p("P_WO_DELETE","Delete"),events:{onclick:function(){he(p("P_CU_REMOVECONTACT","Remove Contact"),f("div",null,f("div",u=>{u.style.paddingLeft="16px",u.innerText=p("P_CU_REMOVEFROM","Remove {name} from").replace("{name}",this.Name)}),f("div",u=>{u.style.display="flex",u.style.justifyContent="center",u.style.marginTop="10px"},fe({name:"remove-type",label:p("P_CUSTOMERRECORD","Customer Record"),checked:!0,className:"radio-customer-record"}),fe({name:"remove-type",label:p("P_WORKORDER","Work Order")}))),[{key:"ok",text:p("P_WO_OK","OK")},{key:"cancel",text:p("P_WO_CANCEL","Cancel")}]).then(u=>{if((u==null?void 0:u.key)==="ok"){const g=u.popup.container.querySelector(".radio-customer-record>input").checked;typeof t.onDelete=="function"&&t.onDelete(u.key,this,g);const E=r.source.indexOf(this);if(E>=0){const N=r.source;N.splice(E,1),r.extraRows=N.filter(A=>!x(A.Notes)).length,r.source=N}}})}}}],r.init(a.container.querySelector(".contacts-record"));const m=this._var.data.contacts.filter(u=>u.Id>=0).map(u=>(u.OptOut||u.OptOut_BC||typeof u.selected>"u"&&(u.selected=!0),u));r.extraRows=m.filter(u=>!x(u.Notes)).length,r.source=m,r.onSelectedRowChanged=u=>{var g;u>=0&&((g=this._var.gridWo.selectedIndexes)==null?void 0:g.length)>0&&(this._var.gridWo.selectedIndexes=[])},this._var.gridContact=r;const C=new B;C.height=0,C.allowHtml=!0,C.headerVisible=!1,C.columns=[i(this),s,d,{key:"Email",width:180},{key:"MobilePhoneDisplayText",width:130},h(this),{key:"delete",..._,text:"times",tooltip:p("P_WO_DELETE","Delete"),events:{onclick:function(){he(p("P_CU_REMOVECONTACT","Remove Contact"),p("P_CU_REMOVEFROMWORKORDER",`You are removing {name} from work order.
Do you want to Continue?`).replace("{name}",this.Name),[{key:"continue",text:p("P_JS_CONTINUE","Continue")},{key:"cancel",text:p("P_WO_CANCEL","Cancel")}]).then(u=>{if((u==null?void 0:u.key)==="continue"){typeof t.onDelete=="function"&&t.onDelete(u.key,this);const g=C.source.indexOf(this);if(g>=0){const E=C.source;E.splice(g,1),C.extraRows=E.filter(N=>!x(N.Notes)).length,C.source=E}}})}}}],C.init(a.container.querySelector(".contacts-wo"));const L=this._var.data.contacts.filter(u=>u.Id<0).map(u=>(u.OptOut||u.OptOut_BC||typeof u.selected>"u"&&(u.selected=!0),u));C.extraRows=L.filter(u=>!x(u.Notes)).length,C.source=L,C.onSelectedRowChanged=u=>{var g;u>=0&&((g=this._var.gridContact.selectedIndexes)==null?void 0:g.length)>0&&(this._var.gridContact.selectedIndexes=[])},this._var.gridWo=C})})})),f("div",n=>{n.className="bar-info",n.innerText=p("P_CR_CONTACTINFORMATION","Contact Information")}),f("div",n=>{if(t.contactCollapserVisible===!1){n.style.display="none";return}t.contactCollapsed?(e.classList.add("collapsed"),n.className="bar-collapser collapsed"):n.className="bar-collapser",n.addEventListener("click",()=>{const a=n.classList.contains("collapsed");a?(n.classList.remove("collapsed"),e.classList.remove("collapsed")):(n.classList.add("collapsed"),e.classList.add("collapsed")),typeof t.onContactCollapsed=="function"&&t.onContactCollapsed.call(this,!a)}),n.append(f("span"))}))),c}_createFollowers(e,t){const l=t.readonly,o=t.recordReadonly,c=f("div","bar-list-container"),n=f("button",a=>{a.className="roundbtn button-edit-followers",a.style.backgroundColor="rgb(48, 107, 255)",(l===!0||o)&&(a.style.display="none"),a.appendChild(k("fa-solid","pen")),w(a,p("P_CU_EDITFOLLOWERS","Edit Followers")),a.addEventListener("click",()=>{typeof t.onInitFollower=="function"&&t.onInitFollower(this._var.data.followers).then(i=>{var _;if(typeof i=="string"){Y(p("P_CUSTOMERRECORD","Customer Record"),i,"warn");return}const s=new Re({getText:t.getText,onMasking:t.onMasking,followers:i,onOk:h=>{if(typeof t.onAddFollower=="function"){const r=t.onAddFollower(h);return typeof(r==null?void 0:r.then)=="function"?r.then(m=>m):!1}}});var d=((_=this._var.data.followers)==null?void 0:_.length)>0?p("P_CU_EDITFOLLOWERS","Edit Followers"):p("P_CR_ADDFOLLOWERS","Add Followers");s.show(d,e)})})});return this._var.buttonFollower=n,e.append(f("div",a=>{a.className="contact-bar follower-bar",a.style.display="none"},w(f("div","bar-icon",k("fa-solid","user-tag",{fill:"#fff","background-color":"lightgray","box-sizing":"border-box","border-radius":"15px",padding:"4px"})),p("P_CU_COPIED","Copied")),f("div","bar-list",c,n))),c}load(e,t,l){var c;const o=[];if((e==null?void 0:e.length)>0){if(t??(t=this._var.data.contacts),l??(l=this._var.data.allfollowers),this.setData("messages",e),this._var.contactsUpdated!==!0){const n=this._var.data.contacts;(n==null?void 0:n.length)>0&&(V(e,n),this._var.contactsUpdated=!0)}for(let n of e){const a=f("div","item-div");let i;if(n.IsReply&&(t==null?void 0:t.length)>0){const h=Ce(n.Sender)?t.find(r=>r.Email===n.Sender):t.find(r=>r.MobilePhone===n.Sender);i=h==null?void 0:h.Name}i??(i=n.IsReply&&String(n.FormatSender)!==""?n.FormatSender:n.Sender);const s=ce(n,t,l,p);a.appendChild(f("div",h=>{h.className="item-poster",h.innerText=i,!n.IsReply&&(s==null?void 0:s.length)>0&&w(h,s)}));const d=f("div","item-content"),_=f("div",h=>h.style.display="none");if(d.appendChild(f("span",h=>{/https?:\/\//i.test(n.Message)?h.innerHTML=Ue(_e(n.Message)):h.innerText=_e(n.Message),h.appendChild(_)})),((c=n.MMSParts)==null?void 0:c.length)>0){_.style.display="";for(let h of n.MMSParts)Z(_,h.Key,h.Value)}if(n.IsReply)a.classList.add("item-other");else{a.classList.add("item-self");const[h,r,m,C]=le(n,p,this._var);if(h!==-100){m!=null&&(d.style.backgroundColor=m);const L=f("div",u=>{u.className="item-status",u.innerText=r,C!=null&&w(u,C)});d.appendChild(L)}}a.append(d,f("div",h=>{h.className="item-time",h.innerText=n.TimeStr})),o.push(a)}o[0].style.marginTop="0"}this._var.message.replaceChildren(...o),this._var.message.scrollTop=this._var.message.scrollHeight}}const T=window["lib-ui"].createElement,H=window["lib-ui"].setTooltip,X=window["lib-ui"].createIcon,$e=window["lib-utility"].r,z=window["lib-utility"].nullOrEmpty,Fe=window["lib-utility"].escapeHtml,Be=window["lib-utility"].escapeEmoji;let I=$e;class He{constructor(e){q(this,"_var",{});this._var.option=e??{};const t=e==null?void 0:e.getText;typeof t=="function"&&(I=t)}get text(){var e;return(e=this._var.enter)==null?void 0:e.value}set text(e){const t=this._var.enter;t!=null&&(t.value=e,e=String(z(e)?0:val.length)+"/"+String(this._var.option.maxLength),this._var.container.querySelector(".message-bar .prompt-count").innerText=e)}set contacts(e){if(this._var.contacts=e,this._var.contactsUpdated!==!0&&(e==null?void 0:e.length)>0){const t=this._var.comments;(t==null?void 0:t.length)>0&&(V(this._var.comments,e),this._var.contactsUpdated=!0)}}set loading(e){this._var.container!=null&&(this._var.enter.disabled=e,this._var.container.querySelector(".button-send-message").disabled=e,this._var.container.querySelector(".button-post-note").disabled=e)}get file(){var e,t;return this._var.file||((t=(e=this._var.fileControl)==null?void 0:e.files)==null?void 0:t[0])}set file(e){var l,o;(l=this._var.fileControl)==null||l.remove();const t=this._var.container.querySelector(".file-selector>.selector-name");if(e==null)this._var.fileControl=null,this._var.file=null,t!=null&&(t.style.display="none",t.innerText="",(o=t.querySelector(".ui-tooltip-wrapper"))==null||o.remove());else{if(e instanceof HTMLInputElement){this._var.fileControl=e,this._var.file=e.files[0];const c=this._var.container.querySelector(".file-selector>.selector-link");c!=null&&c.appendChild(e)}else this._var.fileControl=null,this._var.file=e;t!=null&&(t.style.display="",t.innerText=e.name,H(t,e.name))}}set readonly(e){this._var.option.readonly=e,this._var.container!=null&&(this._var.enter.disabled=e===!0,this._var.container.querySelector(".button-send-message").style.display=e===!0?"none":"",this._var.container.querySelector(".button-post-note").style.display=e===!0?"none":"")}create(){const e=this._var.option,t=Q(T("div",null,T("div",n=>{n.className="title-module",n.innerText=I("P_WO_INTERNALCOMMENTS","Internal Comments")})),[]),l=e.readonly,o=T("textarea","ui-text");o.placeholder=I("P_CU_ENTERCOMMENTHERE","Enter Comment Here"),o.maxLength=e.maxLength??(e.maxLength=3e3),o.addEventListener("input",()=>{const n=this.text,a=String(z(n)?0:n.length)+"/"+String(e.maxLength);this._var.container.querySelector(".message-bar .prompt-count").innerText=a}),l===!0&&(o.disabled=!0),o.addEventListener("paste",n=>{const a=n.clipboardData.files[0];a!=null&&(n.preventDefault(),this.file=$(t,a,I))}),this._var.enter=o,t.appendChild(T("div",n=>{n.className="message-bar",n.addEventListener("dragover",a=>{if(e.readonly!==!0){const i=a.dataTransfer.items[0];(i==null?void 0:i.kind)==="file"&&(a.preventDefault(),i.type.length>0&&F.indexOf(i.type)<0?a.dataTransfer.dropEffect="none":a.dataTransfer.dropEffect="link")}}),n.addEventListener("drop",a=>{if(e.readonly!==!0){const i=a.dataTransfer.files[0];i!=null&&(a.preventDefault(),this.file=$(t,i,I))}})},o,T("div",n=>n.style.textAlign="right",T("div","customer-left",T("div","file-selector",T("div",n=>{n.className="selector-link",n.addEventListener("click",()=>{var i;(i=this._var.fileControl)==null||i.remove();const a=T("input",s=>{s.type="file",s.accept=F.join(","),s.addEventListener("change",()=>{var _;const d=$(t,(_=s.files)==null?void 0:_[0],I);d!=null&&(this.file=d)})});n.appendChild(this._var.fileControl=a),a.dispatchEvent(new MouseEvent("click"))})},X("fa-regular","link")),T("span",n=>{n.className="selector-name",n.style.display="none"}),T("layer",n=>{n.appendChild(X("fa-regular","times")),n.addEventListener("click",()=>this.file=null)}))),T("div","prompt-count"),T("button",n=>{n.className="roundbtn button-send-message",n.style.backgroundColor="rgb(19, 150, 204)",(l===!0||e.noMessage===!0)&&(n.style.display="none"),n.appendChild(X("fa-solid","paper-plane")),H(n,I("P_M3_SENDMESSAGE","Send Message")),n.addEventListener("click",()=>{const a=this.text;z(a==null?void 0:a.trim())||typeof e.onAddMessage=="function"&&(this.loading=!0,e.onAddMessage(this.text))})}),T("button",n=>{n.className="roundbtn button-post-note",n.style.border="1px solid rgb(19, 150, 204)",n.style.fill="rgb(19, 150, 204)",l===!0&&(n.style.display="none"),n.appendChild(X("fa-solid","comment-alt-lines")),H(n,I("P_CU_POSTNOTE","Post Note")),n.addEventListener("click",()=>{const a=this.text;z(a==null?void 0:a.trim())||typeof e.onAddComment=="function"&&(this.loading=!0,e.onAddComment(this.text,this.file))})}))));const c=T("div","list-bar");return this._var.message=c,t.appendChild(c),this._var.container=t}load(e){var l;const t=[];if((e==null?void 0:e.length)>0){if(this._var.comments=e,this._var.contactsUpdated!==!0){const o=this._var.contacts;(o==null?void 0:o.length)>0&&(V(e,o),this._var.contactsUpdated=!0)}for(let o of e){const c=T("div","item-div"),n=ce(o,null,null,I);c.appendChild(T("div",r=>{r.className="item-poster",r.innerText=o.Sender,(n==null?void 0:n.length)>0&&H(r,n)}));const a=T("div","item-content"),i=T("div",r=>r.style.display="none");if(a.appendChild(T("span",r=>r.innerHTML=Fe(Be(o.Message)),i)),((l=o.MMSParts)==null?void 0:l.length)>0){i.style.display="";for(let r of o.MMSParts)Z(i,r.Key,r.Value)}const[s,d,_,h]=le(o,I,this._var);if(s!==-100){_!=null&&(a.style.backgroundColor=_);const r=T("div",m=>{m.className="item-status",m.innerText=d,h!=null&&H(m,h)});a.appendChild(r)}c.append(a,T("div",r=>{r.className="item-time",r.innerText=o.TimeStr})),t.push(c)}t[0].style.marginTop="0"}this._var.message.replaceChildren(...t),this._var.message.scrollTop=this._var.message.scrollHeight}}const M=window["lib-ui"].createElement,Ve=window["lib-ui"].setTooltip,ye=window["lib-ui"].createIcon,Ke=window["lib-utility"].r,ve=window["lib-utility"].nullOrEmpty,je=window["lib-utility"].escapeHtml,Ge=window["lib-utility"].escapeEmoji;let J=Ke;class Ye{constructor(e){q(this,"_var",{});this._var.option=e??{};const t=e==null?void 0:e.getText;typeof t=="function"&&(J=t)}get text(){var e;return(e=this._var.enter)==null?void 0:e.value}set text(e){const t=this._var.enter;t!=null&&(t.value=e,e=String(ve(e)?0:val.length)+"/"+String(this._var.option.maxLength),this._var.container.querySelector(".message-bar .prompt-count").innerText=e)}set loading(e){this._var.container!=null&&(this._var.enter.disabled=e,this._var.container.querySelector(".button-send-message").disabled=e)}set readonly(e){this._var.option.readonly=e,this._var.container!=null&&(this._var.enter.disabled=e===!0,this._var.container.querySelector(".button-send-message").style.display=e===!0?"none":"",this._var.container.querySelector(".message-bar .prompt-count").style.display=e===!0?"none":"")}create(){var c;const e=this._var.option.readonly,t=Q(M("div",null,M("div",n=>{n.className="title-module",n.innerText=J("P_CR_COMMENTS","Comments")})),[M("button",n=>{if(n.className="roundbtn button-close",n.style.backgroundColor="transparent",this._var.option.hasClose!==!0){n.style.display="none";return}n.appendChild(ye("fa-solid","times",{fill:"#000"})),n.addEventListener("click",()=>{typeof this._var.option.onClose=="function"&&this._var.option.onClose()})})]),l=M("textarea","ui-text");l.placeholder=J("P_CU_ENTERCOMMENTHERE","Enter Comment Here"),l.maxLength=(c=this._var.option).maxLength??(c.maxLength=3e3),l.addEventListener("input",()=>{const n=this.text,a=String(ve(n)?0:n.length)+"/"+String(this._var.option.maxLength);this._var.container.querySelector(".message-bar .prompt-count").innerText=a}),e===!0&&(l.disabled=!0),this._var.enter=l,t.appendChild(M("div","message-bar",l,M("div",n=>n.style.textAlign="right",M("div","prompt-count"),M("button",n=>{n.className="roundbtn button-send-message",n.style.backgroundColor="rgb(19, 150, 204)",e===!0&&(n.style.display="none"),n.appendChild(ye("fa-solid","paper-plane")),Ve(n,J("P_CU_POSTNOTE","Post Note")),n.addEventListener("click",()=>{typeof this._var.option.onAddComment=="function"&&this._var.option.onAddComment(this.text)})}))));const o=M("div","list-bar");return this._var.message=o,t.appendChild(o),this._var.container=t}load(e){var l;const t=[];if((e==null?void 0:e.length)>0){for(let o of e){const c=M("div","item-div");c.appendChild(M("div",i=>{i.className="item-poster",i.innerText=o.UserName}));const n=M("div","item-content"),a=M("div",i=>i.style.display="none");if(n.appendChild(M("span",i=>i.innerHTML=je(Ge(o.Comment)),a)),((l=o.MMSParts)==null?void 0:l.length)>0){a.style.display="";for(let i of o.MMSParts)Z(a,i.Key,i.Value)}c.append(n,M("div",i=>{i.className="item-time",i.innerText=o.SubmitLocalDateStr})),t.push(c)}t[0].style.marginTop="0"}this._var.message.replaceChildren(...t),this._var.message.scrollTop=this._var.message.scrollHeight}}R.CustomerCommunication=qe,R.CustomerRecordComment=Ye,R.InternalComment=He,Object.defineProperty(R,Symbol.toStringTag,{value:"Module"})});
//# sourceMappingURL=app.min.js.map