-
Notifications
You must be signed in to change notification settings - Fork 61
/
selection.min.js
1 lines (1 loc) · 8.6 KB
/
selection.min.js
1
const Selection=function(){function e(e,t,n,o){let c=screen.width/2-n/2,i=screen.height/2-o/2;return window.open(e,t,"toolbar=no, location=no, directories=no, status=no, menubar=no, scrollbars=no, resizable=no, copyhistory=no, width="+n+", height="+o+", top="+i+", left="+c)}function t(e,t){const n=document.createElement("div");return n.style="display:inline-block;margin:7px;cursor:pointer;transition:all .2s ease-in-out;",n.innerHTML=e,n.onclick=t,n.onmouseover=function(){this.style.transform="scale(1.2)"},n.onmouseout=function(){this.style.transform="scale(1)"},n}return function(){const n={twitter:!0,facebook:!0,search:!0,copy:!0,speak:!0,translate:!0,disable:!1},o={url:"https://twitter.com/intent/tweet?text=",icon:'<svg xmlns="http://www.w3.org/2000/svg" width="24" height="24" viewBox="0 0 24 24" class="selection__icon"><path d="M8.2,20.2c6.5,0,11.7-5.2,11.8-11.6c0-0.1,0-0.1,0-0.2c0-0.2,0-0.4,0-0.5c0.8-0.6,1.5-1.3,2.1-2.2c-0.8,0.3-1.6,0.6-2.4,0.7c0.9-0.5,1.5-1.3,1.8-2.3c-0.8,0.5-1.7,0.8-2.6,1c-1.6-1.7-4.2-1.7-5.9-0.1c-1.1,1-1.5,2.5-1.2,3.9C8.5,8.7,5.4,7.1,3.3,4.6c-1.1,1.9-0.6,4.3,1.3,5.5c-0.7,0-1.3-0.2-1.9-0.5l0,0c0,2,1.4,3.7,3.3,4.1c-0.6,0.2-1.2,0.2-1.9,0.1c0.5,1.7,2.1,2.8,3.9,2.9c-1.7,1.4-3.9,2-6.1,1.7C3.8,19.5,6,20.2,8.2,20.2"/></svg>'},c={url:"https://www.facebook.com/sharer/sharer.php?quote=",icon:'<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" enable-background="new 0 0 24 24" width="24" height="24" class="selection__icon"><path d="M20,2H4C2.9,2,2,2.9,2,4v16c0,1.1,0.9,2,2,2h16c1.1,0,2-0.9,2-2V4C22,2.9,21.1,2,20,2z M18.4,7.4H17c-0.9,0-1,0.3-1,1l0,1.3 h2.1L18,12h-1.9v7h-3.2v-7h-1.2V9.6h1.2V8.1c0-2,0.8-3.1,3.1-3.1h2.4V7.4z"/></svg>'},i={url:"https://www.google.co.in/search?q=",icon:'<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" enable-background="new 0 0 24 24" width="24" height="24" class="selection__icon"><path d="M23.111 20.058l-4.977-4.977c.965-1.52 1.523-3.322 1.523-5.251 0-5.42-4.409-9.83-9.829-9.83-5.42 0-9.828 4.41-9.828 9.83s4.408 9.83 9.829 9.83c1.834 0 3.552-.505 5.022-1.383l5.021 5.021c2.144 2.141 5.384-1.096 3.239-3.24zm-20.064-10.228c0-3.739 3.043-6.782 6.782-6.782s6.782 3.042 6.782 6.782-3.043 6.782-6.782 6.782-6.782-3.043-6.782-6.782zm2.01-1.764c1.984-4.599 8.664-4.066 9.922.749-2.534-2.974-6.993-3.294-9.922-.749z"/></svg>'},l={icon:'<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" enable-background="new 0 0 24 24" width="24" height="24" class="selection__icon"><path d="M18 6v-6h-18v18h6v6h18v-18h-6zm-12 10h-4v-14h14v4h-10v10zm16 6h-14v-14h14v14z"/></svg>'},s={icon:'<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" enable-background="new 0 0 24 24" width="24" height="24" class="selection__icon"><path d="M16 11c0 2.209-1.791 4-4 4s-4-1.791-4-4v-7c0-2.209 1.791-4 4-4s4 1.791 4 4v7zm4-2v2c0 4.418-3.582 8-8 8s-8-3.582-8-8v-2h2v2c0 3.309 2.691 6 6 6s6-2.691 6-6v-2h2zm-7 13v-2h-2v2h-4v2h10v-2h-4z"/></svg>'},a={url:"https://translate.google.com/#auto/",icon:'<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 24 24" enable-background="new 0 0 24 24" width="24" height="24" class="selection__icon"><path id="svg_3" d="m17,20l-14.5,0c-1.378,0 -2.5,-1.122 -2.5,-2.5l0,-15c0,-1.378 1.122,-2.5 2.5,-2.5l8,0c0.214,0 0.404,0.136 0.473,0.338l6.5,19c0.052,0.152 0.027,0.321 -0.066,0.452c-0.094,0.132 -0.245,0.21 -0.407,0.21zm-14.5,-19c-0.827,0 -1.5,0.673 -1.5,1.5l0,15c0,0.827 0.673,1.5 1.5,1.5l13.8,0l-6.157,-18l-7.643,0z"/><path id="svg_5" d="m21.5,24l-8,0c-0.208,0 -0.395,-0.129 -0.468,-0.324l-1.5,-4c-0.097,-0.259 0.034,-0.547 0.292,-0.644c0.259,-0.096 0.547,0.034 0.644,0.292l1.379,3.676l7.653,0c0.827,0 1.5,-0.673 1.5,-1.5l0,-15c0,-0.827 -0.673,-1.5 -1.5,-1.5l-9.5,0c-0.276,0 -0.5,-0.224 -0.5,-0.5s0.224,-0.5 0.5,-0.5l9.5,0c1.378,0 2.5,1.122 2.5,2.5l0,15c0,1.378 -1.122,2.5 -2.5,2.5z"/><path id="svg_7" d="m13.5,24c-0.117,0 -0.234,-0.041 -0.329,-0.124c-0.208,-0.182 -0.229,-0.498 -0.047,-0.706l3.5,-4c0.182,-0.209 0.498,-0.229 0.706,-0.047c0.208,0.182 0.229,0.498 0.047,0.706l-3.5,4c-0.1,0.113 -0.238,0.171 -0.377,0.171z"/><path id="svg_9" d="m9.5,14c-0.206,0 -0.398,-0.127 -0.471,-0.332l-2.029,-5.681l-2.029,5.681c-0.093,0.26 -0.38,0.396 -0.639,0.303c-0.26,-0.093 -0.396,-0.379 -0.303,-0.639l2.5,-7c0.142,-0.398 0.8,-0.398 0.941,0l2.5,7c0.093,0.26 -0.042,0.546 -0.303,0.639c-0.054,0.02 -0.111,0.029 -0.167,0.029z"/><path id="svg_11" d="m8,11l-2,0c-0.276,0 -0.5,-0.224 -0.5,-0.5s0.224,-0.5 0.5,-0.5l2,0c0.276,0 0.5,0.224 0.5,0.5s-0.224,0.5 -0.5,0.5z"/><path id="svg_13" d="m21.5,11l-7,0c-0.276,0 -0.5,-0.224 -0.5,-0.5s0.224,-0.5 0.5,-0.5l7,0c0.276,0 0.5,0.224 0.5,0.5s-0.224,0.5 -0.5,0.5z"/><path id="svg_15" d="m17.5,11c-0.276,0 -0.5,-0.224 -0.5,-0.5l0,-1c0,-0.276 0.224,-0.5 0.5,-0.5s0.5,0.224 0.5,0.5l0,1c0,0.276 -0.224,0.5 -0.5,0.5z"/><path id="svg_17" d="m16,17c-0.157,0 -0.311,-0.073 -0.408,-0.21c-0.16,-0.225 -0.107,-0.537 0.118,-0.697c2.189,-1.555 3.79,-4.727 3.79,-5.592c0,-0.276 0.224,-0.5 0.5,-0.5s0.5,0.224 0.5,0.5c0,1.318 -1.927,4.785 -4.21,6.408c-0.088,0.061 -0.189,0.091 -0.29,0.091z"/><path id="svg_19" d="m20,18c-0.121,0 -0.242,-0.043 -0.337,-0.131c-0.363,-0.332 -3.558,-3.283 -4.126,-4.681c-0.104,-0.256 0.02,-0.547 0.275,-0.651c0.253,-0.103 0.547,0.019 0.651,0.275c0.409,1.007 2.936,3.459 3.875,4.319c0.204,0.187 0.217,0.502 0.031,0.707c-0.099,0.107 -0.234,0.162 -0.369,0.162z"/></svg>'};let r="",d="",u="crimson",h="#fff",p={},g=5,w=38,v=0,m=0;function f(){return new t(l.icon,function(){!function(e){let t=document.createElement("textarea");t.style.position="fixed",t.style.top=0,t.style.left=0,t.style.width="2em",t.style.height="2em",t.style.padding=0,t.style.border="none",t.style.outline="none",t.style.boxShadow="none",t.style.background="transparent",t.value=e,document.body.appendChild(t),t.focus(),t.select();try{let e=document.execCommand("copy")?"successful":"unsuccessful";console.log("Copying text command was "+e)}catch(e){console.log("Oops, unable to copy")}document.body.removeChild(t)}(d)})}function b(){return new t(a.icon,function(){return e(a.url+(navigator.language||navigator.userLanguage||function(){if(navigator.languages,navigator.languages.length>0)return navigator.languages[0]}()||"en").split("-")[0]+"/"+d,"Translate",900,540),!1})}function y(){const l=[{feature:"twitter",call:function(){const n=window.location.href;return new t(o.icon,function(){return e(o.url+encodeURIComponent(d)+" "+n,"Share",550,295),!1})}()},{feature:"facebook",call:new t(c.icon,function(){let t=window.location.href,n=c.url;"http"!==t.substring(0,4)&&(t="http://www.demourl.com"),e(n+=d+"&u="+t,"Share",600,500)})},{feature:"search",call:new t(i.icon,function(){return e(i.url+encodeURIComponent(d),"Search",900,540),!1})},{feature:"translate",call:b()},{feature:"copy",call:f()},{feature:"speak",call:new t(s.icon,function(){let e=new SpeechSynthesisUtterance(d);window.speechSynthesis.speak(e)})}],a=document.createElement("div");let r=0;return l.forEach(e=>{n[e.feature]&&(a.appendChild(e.call),r++)}),{icons:a,length:r}}function x(){const e=r.getRangeAt(0).getBoundingClientRect(),t=window.pageXOffset||document.documentElement.scrollTop||document.body.scrollTop;v=e.top+t-w-g,m=e.left+(e.width-w*p.length)/2}function k(){function e(){return!!window.getSelection().toString()}window.addEventListener("mouseup",function(){setTimeout(function(){if(document.querySelector(".selection")){if(e())return r=window.getSelection(),d=r.toString(),void function(){x();let e=document.querySelector(".selection");e.style.top=`${v}px`,e.style.left=`${m}px`}();document.querySelector(".selection").remove()}e()&&(r=window.getSelection(),d=r.toString(),function(){p=y(),x();const e=document.createElement("div");e.className="selection",e.style="line-height:0;position:absolute;background-color:"+u+";border-radius:20px;top:"+v+"px;left:"+m+"px;transition:all .2s ease-in-out;box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22);z-index:99999;",e.appendChild(p.icons);const t=document.createElement("div");t.style="position:absolute;border-left:"+g+"px solid transparent;border-right:"+g+"px solid transparent;border-top:"+g+"px solid "+u+";bottom:-"+(g-1)+"px;left:"+(w*p.length/2-g)+"px;width:0;height:0;",n.disable||e.appendChild(t),document.body.appendChild(e)}())},10)},!1)}return{config:function(e){return n.twitter=void 0===e.twitter?n.twitter:e.twitter,n.facebook=void 0===e.facebook?n.facebook:e.facebook,n.search=void 0===e.search?n.search:e.search,n.translate=void 0===e.translate?n.translate:e.translate,n.copy=void 0===e.copy?n.copy:e.copy,n.speak=void 0===e.speak?n.speak:e.speak,n.disable=void 0===e.disable?n.disable:e.disable,u=e.backgroundColor||"#333",h=e.iconColor||"#fff",this},init:function(){return function(){const e=document.createElement("style");e.innerHTML=`.selection__icon{fill:${h};}`,document.body.appendChild(e)}(),k(),this}}}}();