avanti con le funzionalità
This commit is contained in:
		
							
								
								
									
										29
									
								
								dist/mailgo.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										29
									
								
								dist/mailgo.js
									
									
									
									
										vendored
									
									
								
							@@ -150,9 +150,18 @@ mailgos.forEach((mailgo, index) => {
 | 
			
		||||
 | 
			
		||||
  // copia l'email
 | 
			
		||||
  let copy = document.createElement("a");
 | 
			
		||||
  copy.href = "#mailgo-copy";
 | 
			
		||||
  copy.className = "mailgo-copy";
 | 
			
		||||
  let copyContent = document.createTextNode("copy");
 | 
			
		||||
  copy.appendChild(copyContent);
 | 
			
		||||
  copy.addEventListener(
 | 
			
		||||
    "click",
 | 
			
		||||
    event => {
 | 
			
		||||
      copyToClipboard(mail);
 | 
			
		||||
      copy.innerHTML = "copied!";
 | 
			
		||||
    },
 | 
			
		||||
    false
 | 
			
		||||
  );
 | 
			
		||||
  modalContent.appendChild(copy);
 | 
			
		||||
 | 
			
		||||
  mailgo.parentNode.insertBefore(modal, mailgo.nextSibling);
 | 
			
		||||
@@ -182,3 +191,23 @@ function validateEmail(email) {
 | 
			
		||||
  var re = /^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/;
 | 
			
		||||
  return re.test(email);
 | 
			
		||||
}
 | 
			
		||||
 | 
			
		||||
function copyToClipboard(str) {
 | 
			
		||||
  const el = document.createElement("textarea");
 | 
			
		||||
  el.value = str;
 | 
			
		||||
  el.setAttribute("readonly", "");
 | 
			
		||||
  el.style.position = "absolute";
 | 
			
		||||
  el.style.left = "-9999px";
 | 
			
		||||
  document.body.appendChild(el);
 | 
			
		||||
  const selected =
 | 
			
		||||
    document.getSelection().rangeCount > 0
 | 
			
		||||
      ? document.getSelection().getRangeAt(0)
 | 
			
		||||
      : false;
 | 
			
		||||
  el.select();
 | 
			
		||||
  document.execCommand("copy");
 | 
			
		||||
  document.body.removeChild(el);
 | 
			
		||||
  if (selected) {
 | 
			
		||||
    document.getSelection().removeAllRanges();
 | 
			
		||||
    document.getSelection().addRange(selected);
 | 
			
		||||
  }
 | 
			
		||||
}
 | 
			
		||||
 
 | 
			
		||||
							
								
								
									
										2
									
								
								dist/mailgo.min.js
									
									
									
									
										vendored
									
									
								
							
							
						
						
									
										2
									
								
								dist/mailgo.min.js
									
									
									
									
										vendored
									
									
								
							@@ -1 +1 @@
 | 
			
		||||
let mailgos=document.querySelectorAll('a[href^="mailto:"]:not(.no-mailgo)'),styles='\n\n    .mailgo-modal {\n      all: initial;\n      * {\n        all: unset;\n      }\n    }\n\n    .mailgo-title {\n      display: block;\n      margin-bottom: 16px;\n    }\n\n    .mailgo-modal-background {\n      position: absolute;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      background-color: rgba(10,10,10,.86);\n      opacity: 0.8;\n    }\n    .mailgo-modal {\n      position: fixed;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      display: none;\n      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";\n    }\n    .mailgo-modal.is-active {\n      display: flex;\n      justify-content: center;\n      align-items: center;\n    }\n    .mailgo-modal-content {\n      z-index: 1000;\n      text-align: center;\n      width: 200px;\n      background-color: #fff;\n      border-radius: 6px;\n      box-shadow: 0 2px 3px rgba(10,10,10,.1), 0 0 0 1px rgba(10,10,10,.1);\n      color: #4a4a4a;\n      display: block;\n      padding: 1.25rem;\n    }\n    .mailgo-modal-content a {\n      display: block;\n      color: #4a4a4a;\n      padding: 10px;\n      border-radius: 4px;\n      text-decoration: none;\n    }\n    .mailgo-modal-content a:hover {\n      background-color: rgba(0, 0, 0, 0.08);\n    }\n    .mailgo-modal-content a.outlook {\n      color: rgba(0, 114, 198);\n    }\n    .mailgo-modal-content a.gmail {\n      color: rgba(212, 70, 56);\n    }\n    .mailgo-modal-content a.outlook:hover {\n      background-color: rgba(0, 114, 198, 0.08);\n    }\n    .mailgo-modal-content a.gmail:hover {\n      background-color: rgba(212, 70, 56, 0.08);\n    }\n    a.mailgo-copy {\n      margin-top: 10px;\n      padding: 16px 10px;\n    }\n',styleSheet=document.createElement("style");function validateEmail(e){return/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/.test(e)}styleSheet.type="text/css",styleSheet.innerText=styles,document.head.appendChild(styleSheet),console.log("mailgo is WIP!"),mailgos.forEach((e,n)=>{let t=e.href.split("?")[0].split("mailto:")[1].trim();if(!validateEmail(t))return;let o=new URL(e.href),a=new URLSearchParams(o.search),l=(a.get("subject"),a.get("body"),a.get("cc"),a.get("bcc"),document.createElement("div"));l.className="mailgo-modal",l.setAttribute("data-index",n);let i=document.createElement("div");i.className="mailgo-modal-background",l.appendChild(i);let d=document.createElement("div");d.className="mailgo-modal-content",l.appendChild(d);let c=document.createElement("strong");c.className="mailgo-title";let m=document.createTextNode(t);c.appendChild(m),d.appendChild(c);let r=document.createElement("a");r.href="https://mail.google.com/mail?extsrc=mailto&url="+e.href,r.classList.add("mailgo-open"),r.classList.add("gmail");let s=document.createTextNode("open in Gmail");r.appendChild(s),d.appendChild(r);let p=document.createElement("a");p.href="https://outlook.office.com/owa/?rru=compose&to="+t+o.search,p.classList.add("mailgo-open"),p.classList.add("outlook");let g=document.createTextNode("open in Outlook");p.appendChild(g),d.appendChild(p);let u=document.createElement("a");u.href=e.href,u.className="mailgo-open";let h=document.createTextNode("open");u.appendChild(h),d.appendChild(u);let b=document.createElement("a");b.className="mailgo-copy";let x=document.createTextNode("copy");b.appendChild(x),d.appendChild(b),e.parentNode.insertBefore(l,e.nextSibling),e.addEventListener("click",n=>{n.preventDefault(),e.nextElementSibling.classList.add("is-active")},!1),i.addEventListener("click",n=>{e.nextElementSibling.classList.remove("is-active")},!1)});
 | 
			
		||||
let mailgos=document.querySelectorAll('a[href^="mailto:"]:not(.no-mailgo)'),styles='\n\n    .mailgo-modal {\n      all: initial;\n      * {\n        all: unset;\n      }\n    }\n\n    .mailgo-title {\n      display: block;\n      margin-bottom: 16px;\n    }\n\n    .mailgo-modal-background {\n      position: absolute;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      background-color: rgba(10,10,10,.86);\n      opacity: 0.8;\n    }\n    .mailgo-modal {\n      position: fixed;\n      top: 0;\n      right: 0;\n      bottom: 0;\n      left: 0;\n      display: none;\n      font-family: -apple-system, BlinkMacSystemFont, "Segoe UI", Roboto, Helvetica, Arial, sans-serif, "Apple Color Emoji", "Segoe UI Emoji", "Segoe UI Symbol";\n    }\n    .mailgo-modal.is-active {\n      display: flex;\n      justify-content: center;\n      align-items: center;\n    }\n    .mailgo-modal-content {\n      z-index: 1000;\n      text-align: center;\n      width: 200px;\n      background-color: #fff;\n      border-radius: 6px;\n      box-shadow: 0 2px 3px rgba(10,10,10,.1), 0 0 0 1px rgba(10,10,10,.1);\n      color: #4a4a4a;\n      display: block;\n      padding: 1.25rem;\n    }\n    .mailgo-modal-content a {\n      display: block;\n      color: #4a4a4a;\n      padding: 10px;\n      border-radius: 4px;\n      text-decoration: none;\n    }\n    .mailgo-modal-content a:hover {\n      background-color: rgba(0, 0, 0, 0.08);\n    }\n    .mailgo-modal-content a.outlook {\n      color: rgba(0, 114, 198);\n    }\n    .mailgo-modal-content a.gmail {\n      color: rgba(212, 70, 56);\n    }\n    .mailgo-modal-content a.outlook:hover {\n      background-color: rgba(0, 114, 198, 0.08);\n    }\n    .mailgo-modal-content a.gmail:hover {\n      background-color: rgba(212, 70, 56, 0.08);\n    }\n    a.mailgo-copy {\n      margin-top: 10px;\n      padding: 16px 10px;\n    }\n',styleSheet=document.createElement("style");function validateEmail(e){return/^(([^<>()[\]\\.,;:\s@\"]+(\.[^<>()[\]\\.,;:\s@\"]+)*)|(\".+\"))@((\[[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\.[0-9]{1,3}\])|(([a-zA-Z\-0-9]+\.)+[a-zA-Z]{2,}))$/.test(e)}function copyToClipboard(e){const t=document.createElement("textarea");t.value=e,t.setAttribute("readonly",""),t.style.position="absolute",t.style.left="-9999px",document.body.appendChild(t);const n=document.getSelection().rangeCount>0&&document.getSelection().getRangeAt(0);t.select(),document.execCommand("copy"),document.body.removeChild(t),n&&(document.getSelection().removeAllRanges(),document.getSelection().addRange(n))}styleSheet.type="text/css",styleSheet.innerText=styles,document.head.appendChild(styleSheet),console.log("mailgo is WIP!"),mailgos.forEach((e,t)=>{let n=e.href.split("?")[0].split("mailto:")[1].trim();if(!validateEmail(n))return;let o=new URL(e.href),a=new URLSearchParams(o.search),l=(a.get("subject"),a.get("body"),a.get("cc"),a.get("bcc"),document.createElement("div"));l.className="mailgo-modal",l.setAttribute("data-index",t);let i=document.createElement("div");i.className="mailgo-modal-background",l.appendChild(i);let d=document.createElement("div");d.className="mailgo-modal-content",l.appendChild(d);let c=document.createElement("strong");c.className="mailgo-title";let m=document.createTextNode(n);c.appendChild(m),d.appendChild(c);let r=document.createElement("a");r.href="https://mail.google.com/mail?extsrc=mailto&url="+e.href,r.classList.add("mailgo-open"),r.classList.add("gmail");let s=document.createTextNode("open in Gmail");r.appendChild(s),d.appendChild(r);let p=document.createElement("a");p.href="https://outlook.office.com/owa/?rru=compose&to="+n+o.search,p.classList.add("mailgo-open"),p.classList.add("outlook");let g=document.createTextNode("open in Outlook");p.appendChild(g),d.appendChild(p);let u=document.createElement("a");u.href=e.href,u.className="mailgo-open";let h=document.createTextNode("open");u.appendChild(h),d.appendChild(u);let b=document.createElement("a");b.href="#mailgo-copy",b.className="mailgo-copy";let y=document.createTextNode("copy");b.appendChild(y),b.addEventListener("click",e=>{copyToClipboard(n),b.innerHTML="copied!"},!1),d.appendChild(b),e.parentNode.insertBefore(l,e.nextSibling),e.addEventListener("click",t=>{t.preventDefault(),e.nextElementSibling.classList.add("is-active")},!1),i.addEventListener("click",t=>{e.nextElementSibling.classList.remove("is-active")},!1)});
 | 
			
		||||
@@ -154,7 +154,14 @@ mailgos.forEach((mailgo, index) => {
 | 
			
		||||
  copy.className = "mailgo-copy";
 | 
			
		||||
  let copyContent = document.createTextNode("copy");
 | 
			
		||||
  copy.appendChild(copyContent);
 | 
			
		||||
  copy.addEventListener("click", event => {}, false);
 | 
			
		||||
  copy.addEventListener(
 | 
			
		||||
    "click",
 | 
			
		||||
    event => {
 | 
			
		||||
      copyToClipboard(mail);
 | 
			
		||||
      copy.innerHTML = "copied!";
 | 
			
		||||
    },
 | 
			
		||||
    false
 | 
			
		||||
  );
 | 
			
		||||
  modalContent.appendChild(copy);
 | 
			
		||||
 | 
			
		||||
  mailgo.parentNode.insertBefore(modal, mailgo.nextSibling);
 | 
			
		||||
 
 | 
			
		||||
		Reference in New Issue
	
	Block a user