Raw Source
ApopheniaPays / DextAssistant

// ==UserScript==
// @name         DextAssistant
// @namespace    https://apopheniapays.com/
// @version      ALPHA-2020.08.28b
// @description  Adds some research tools and visual niceties to Dextools.io. Does not interfere with existing functionality, just adds cosmetics for user convenience.
// @author       @ApopheniaPays
// @updateURL    https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js
// @downloadURL  https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js
// @match        https://www.dextools.io/app/*
// @match        http://www.dextools.io/app/*
// @match        https://dextools.io/app/*
// @match        http://dextools.io/app/*c
// @grant        GM_addStyle
// @grant        GM.xmlHttpRequest
// @connect      github.com
// @connect      githubusercontent.com
// @run-at       document-start
// @icon         
// @require      https://code.jquery.com/jquery-3.3.1.min.js
// @require      https://gist.github.com/raw/2625891/waitForKeyElements.js
// @require      https://cdn.jsdelivr.net/npm/popper.js@1.16.0/dist/umd/popper.min.js
// @require      https://stackpath.bootstrapcdn.com/bootstrap/4.5.0/js/bootstrap.min.js
// @require      https://piyolab.github.io/sushiether/web3.js/libs/web3.js_v1.0.0-beta.33/web3.min.js
// @license      MIT
// ==/UserScript==

// Follow t.me/ApopheniaProjects for announcements.
// A block of user-configurable options are further down in the script, if you want to tinker.

/*

# BACKGROUND

The nice people at [http://DEXTools.io](http://DEXTools.io) have built a great information explorer
for Uniswap. However, I found that as I explored the information it gave me, I had to do far too
much clicking around to other websites to do my own research on the coins listed. I wanted a quicker
way to gather information and determine which coins might be worth investing in, and more importantly,
which look like scams and should be avoided. So I took all the research I was doing by hand, and coded
an add-on tool that set on top of DEXTools but gave quicker access to all that information, and in
some cases, embedded it right in the page without having to leave DEXTools.

Installation tips are included below. Yes, you're going to have to _read_.

# DISCLAIMER

## TO BE READ IN A STERN, GRUFF VOICE:

Despite my efforts to give it an easy-to-understand GUI, this is an advanced tool for technically
advanced traders.

If you are trading on Uniswap or other DEXs, you need to have a certain level of general knowledge in
order to avoid the high risks, and I'm not going to enable anyone to jump in and lose money. If there's
anything in this you don't understand, then you probably shouldn't be trading on Uniswap yet, so this
tool is not for you.

What's more, as this is under active development, you may find bugs, though I try hard to avoid that.

## Support? Support is for _closers_.

As I'm sharing this for free, I won't give you any support or any guarantees, and if you choose to use
it I don't owe you anything for any reason. It's presented as-is, use it only at your own risk. What
you see is what you get. If you have questions you'll have to do your own research and figure out the
answers yourself. I'm grouchy, don't bother me.

## The murky depths from whence this came

This is an independent project that bubbled up out of a single developer's needs. It's not affiliated
with DEXTools.io or its development team in any way, please *never bother them with questions about it*.

## In not so many words:

Essentially, YOU'RE ON YOUR OWN with this.

Do you think Indiana Jones needed someone holding his hand? No, never. When you're fighting for your
life in a remote jungle or far-flung desert outpost, there's no support, no instruction manual, no second
chances... just your own ingenuity, will to live, and the rich rewards that will come if you can figure
out on your own how to succeed.

As of right now, _that is your life._

(Metaphorically speaking.)

Enjoy!

# INSTRUCTIONS

## Installation

This script is for use with a browser plugin that allows you to install and manage user scripts, such as
Greasemonkey, Tampermonkey, or Violentmonkey. I chose to go with a userscript instead of a browser plugin
because it would allow the code to remain 100% open source and cross-platform.

(Here's where you need to bring a little knowledge to the table. If you're unfamiliar with userscripts or
Tampermonkey, Greasemonkey, Violentmonkey, etc, you should educate yourself from a page like
[https://simply-how.com/enhance-and-fine-tune-any-web-page-the-complete-user-scripts-guide](https://simply-how.com/enhance-and-fine-tune-any-web-page-the-complete-user-scripts-guide)
before you try to use this. BTW I use Tampermonkey [https://www.tampermonkey.net/](https://www.tampermonkey.net/)
myself, on Firefox, Brave, and Chrome, so I know for sure that this script works with that. But you'll
need to decide for yourself which userscript manager is right for you. Consult your doctor.)

*BONUS!* For users that already have a userscript manager extension installed in their browser, you can
install DextAssistant simply by clicking this link: [https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js](https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js).

This script is also hosted at [https://openuserjs.org/scripts/ApopheniaPays/DextAssistant](https://openuserjs.org/scripts/ApopheniaPays/DextAssistant)
for one-click install if you prefer to get a minified version. Supposedly that will stay current as I update
it here, but I haven't checked.

## Usage

This adds a few cosmetic changes to the DEXTools.io Pool Explorer, and soon will also add features to their
Pair Explorer page. You will notice them right away:

1.) The most prominent addition is a new icon under the Pool Explorer's Actions column, which opens a
"research assistant" popup that will allow you to view data from other websites pertaining to the token Name,
Contract Address, and Uniswap.info Pair Address for the token on that row. Next to the Contract addresses you
will see a little circled arrow that will show you Google search results for those contract addresses, embedded
right in the popup, when you hover your mouse over it.

2.) For tokens with a particularly low DEXT score or which are auto-generated by a lazy website token-generator
script, the distinguished monocle and handlebar mustache on the "research assistant" gear button are replaced
with a "poop" emoji.

3.) Rows in the the Pool Explorer are color-coded to indicate liquidity adds, removes, and new pools. 100%
liquidity removals are now labeled as "rugpull" instead of just "remove", to make sure you know to feel
extra-bitter.

4.) Columns are sortable on both the Pool and Pair explorers buy clicking on the column headings.

5.) In the Pair Explorer page, wallet addresses that have more than one transaction in the list are now color-
coded to make it easier to spot scammy trades, where one address buys and sells just to generate activity. Next
to these addresses, there is also now a "ƒ" button to filter the list to show all the transactions for just that
address, and a "Z" button that takes you to the Zerion overview for that wallet.

6.) DEXTools "Dark mode" is now supported, because I was too lazy to attempt any real work tonight.

7.) Rather than rely on the various browser plugins' hinky auto-update mechanism, the script adds an unobtrusive
"update available" link to the footer of the screen after a new version has been pushed to this repo, for
convenient one-click upgrading. (Some extremely nerdy people will notice the script phones home to github on page
load. This update check is why.)

As this script makes cosmetic changes only, there's no harm you can do by poking around. Explore it.

# KNOWN ISSUES

1.) Right now the list filtering and sorting only acts on existing rows. As new transactions or pools appear, they
come in at the top, exactly as if the list wasn't filtered or sorted. I'll get around to it. Hey, it's an open
source script, you don't like it, fix it yourself.

*/

/* ******** USER-CONFIGURABLE OPTIONS *************/
// * Feel free to change any of the values after the equals signs in this block. Don't remove the semicolon from the end of the lines.
// * If you don't understand what they do, then you probably don't need to worry about them.
// *

var ShowAssistantOnHover = true;
//Show the Research Assistant popover immediately on hover, without needing to click the icon.

var ethplorerkey="freekey";
//NOT YET IN USE. When activatory, if you run into hourly limits on some of the EthPlorer info (not yet included) because you have looked at more than 50 tokens in an hour, you can sign up for an API key at https://ethplorer.io/wallet/#register, get an API key from https://ethplorer.io/wallet/#screen=api, and replace "freekey" with it to raise your limits.

// *
/****** END USER-CONFIGURABLE OPTIONS ***********/


/************** HISTORY *********************/
// 2020.08.28 - add visual higlight and prominent indication when there's contact info on pair page,
//                    add hover effects and pointer cursor for all clickable elements,
// 2020.08.27 - make compatible with DEXTools dark theme, because that's more important than
//                    working on real features. Add icon. Add functionality to display "update
//                    availalable" link. Update Pair Explorer filter icon to match default
//                    Pool Explorer one.
// 2020.08.25 - Alpha development. Color pool rows for added liquidity or new pools,
//                    popover menu of extra research tools, token icons from Trustwallet
//                    repo, mark 100% removes as "rugpull", integrate custom crypto search
//                    engine results into Research Assistant popover, integrate live
//                    CoinCompare pricing info, soooooperfast table sorting, color-coding and
//                    filtering hex addresses

/************** DEV TO-DOs *********************/
// Live coingecko prices
// show how many people in pool
// show POL score
// incorporate https://thegraph.com/explorer/subgraph/graphprotocol/uniswap
// incorporate https://github.com/EverexIO/Ethplorer/wiki/Ethplorer-API
// color-code eth addresses so can see wash trades more easily
// option to always open Pair Explorer in new tab
// "star" favorite tokens so get alerts when something happens
// make column filtering and sort order persist for new rows
// alerts for adds with over a certain amount of liquidity
// view maker contract addresses on Zerion
// show % increase in pool over initial
// Maybe gray out any row with no pool left. This requires keeping the ontimer() live, so, think about it.
// maybe provision to enter your own wellet addresses and hilight them to find your own transactions easily
// maybe switch to using mutationobservers per https://stackoverflow.com/questions/32233895/using-waitforkeyelements-is-it-possible-to-prevent-the-key-element-from-being-d
// show when liquidity has grown by a certain amount from initial add
// make mouse pointer into finger over all clickabl elements
// expand functions to work on other frequently used sites, like etherscan, Zerion
// total columns in pair explorer
// add an identifier as TD values are evaluated and screen for it so don't keep selecting same TD's over and over again
// alert if new pool doubles in size.
// user option to open Zerion in private window

/**/
/**/
/**/
/**/
/**/
/**/

/******************************************************************************/
/****** TOUCH NOTHING BELOW THIS LINE. IF YOU BREAK IT, YOU BOUGHT IT. ********/
/******************************************************************************/

/**/
/**/
/**/
/**/
/**/
/**/



this.$ = this.jQuery = jQuery.noConflict(true);
//required for compatilibilty in case they start using jQuery on Dextools

(function() {'use strict';

             //Hey ho, let's go

             var currentVersion="ALPHA-2020.08.28b";



             GM.xmlHttpRequest({
                 method: "GET",
                 url: "https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js",
                 onload: function(scrptTxt) {
                     var versionMtch = scrptTxt.response.match(/\/\/\s+@version\s+(.+)/i);
                     if (versionMtch  &&  versionMtch.length > 1) {
                         var newVersionAvail = versionMtch[1];
                         if(newVersionAvail!=currentVersion) {waitForKeyElements('span#newVersion',addNewVersion);}
                     };
                 }
             });

             function addNewVersion (jNode) {
                 jNode.html('<a href="https://github.com/ApopheniaPays/dextassistant/raw/master/dextAssistant.user.js" class="AP-DAJS-element">update available</a>');
                 //yeah, it's hinky. This runs asynchronously so there's two different places this can happen: here, or synchronously down below.
             }

             var IDcounter=1

             // Hash any string into an integer value
             // Then we'll use the int and convert to hex.
             function hashCode(str) {
                 var hash = 0;
                 for (var i = 0; i < str.length; i++) {
                     hash = str.charCodeAt(i) + ((hash << 5) - hash);
                 }
                 return hash;
             }

             // Convert an int to hexadecimal with a max length
             // of six characters.
             function intToARGB(i) {
                 var hex = ((i>>24)&0xFF).toString(16) +
                     ((i>>16)&0xFF).toString(16) +
                     ((i>>8)&0xFF).toString(16) +
                     (i&0xFF).toString(16);
                 // Sometimes the string returned will be too short so we
                 // add zeros to pad it out, which later get removed if
                 // the length is greater than six.
                 hex += '000000';
                 return hex.substring(0, 6);
             }

             // Extend the string type to allow converting to hex for quick access.
             String.prototype.toHexColour = function() {
                 return intToARGB(hashCode(this));
             }



             var allPagesScripts=`
<script id="AP-DAJS-allPageScripts">
function sortTable(n,tableId) {
    var table = document.getElementById(tableId);
    document.getElementById("AP-DAJS-th"+tableId+n).classList.toggle(".sorting");
    window.setTimeout(sortTableMain(n,tableId), 100);
    return;}

function sortTableMain(n,tableId) {
    var table, rows, switching, i, x, y, shouldSwitch, dir, switchcount = 0;
    table = document.getElementById(tableId);
    try { document.getElementById("AP-DAJS-th"+tableId+table.getAttribute("lastSortedBy")).textContent="⇅";
         document.getElementById("AP-DAJS-th"+tableId+table.getAttribute("lastSortedBy")).classList.toggle("text-info");
        } catch {}
            table.setAttribute("lastSortedBy",n);

    switching = true;
    // Set the sorting direction to ascending:
    dir = "asc";
    /* Make a loop that will continue until no switching has been done: */
    while (switching) {
        // Start by saying: no switching is done:
        switching = false;
        rows = table.rows;
        /* Loop through all table rows (except the
    first, which contains table headers): */
        for (i = 1; i < (rows.length - 1); i++) {
            // Start by saying there should be no switching:
            shouldSwitch = false;
            /* Get the two elements you want to compare,
      one from current row and one from the next: */
            x = rows[i].getElementsByTagName("TD")[n];
            y = rows[i + 1].getElementsByTagName("TD")[n];
            /* Check if the two rows should switch place,
      based on the direction, asc or desc: */
            xValue=isNaN(x.getAttribute('AP-DAJS-valueCalc'))?x.getAttribute('AP-DAJS-valueCalc') :(+x.getAttribute('AP-DAJS-valueCalc') );
            yValue=isNaN(y.getAttribute('AP-DAJS-valueCalc'))?y.getAttribute('AP-DAJS-valueCalc') :(+y.getAttribute('AP-DAJS-valueCalc') );
            if (dir == "asc") {
                if (xValue < yValue) {
                    // If so, mark as a switch and break the loop:
                    shouldSwitch = true;
                    break;
                }
            } else if (dir == "desc") {
                if (xValue > yValue) {
                    // If so, mark as a switch and break the loop:
                    shouldSwitch = true;
                    break;
                }
            }
        }
        if (shouldSwitch) {
            /* If a switch has been marked, make the switch
      and mark that a switch has been done: */
            rows[i].parentNode.insertBefore(rows[i + 1], rows[i]);
            switching = true;
            // Each time a switch is done, increase this count by 1:
            switchcount ++;
        } else {
            /* If no switching has been done AND the direction is "asc",
      set the direction to "desc" and run the while loop again. */
            if (switchcount == 0 && dir == "asc") {
                dir = "desc";
                switching = true;
            }
        }
    }
    document.getElementById("AP-DAJS-th"+tableId+n).textContent=(dir=="desc"?"↓":"↑");
    document.getElementById("AP-DAJS-th"+tableId+n).classList.toggle("text-info");
    document.getElementById("AP-DAJS-th"+tableId+n).classList.toggle(".sorting");
}


</script>

`;

             function timeStringToSeconds (timeString) {

                 var hms = timeString.replace(/ *[hmdHMD] */g,":").replace(/ *[s] *$/g,"");   // your input string
                 var a = hms.split(':'); // split it at the colons
                 // minutes are worth 60 seconds. Hours are worth 60 minutes.
                 var seconds = (typeof a[3] !== "undefined")?(+a[0]) * 60 * 60 * 60 + (+a[1]) * 60 + (+a[2])*60+(+a[3]):(typeof a[2] !== "undefined")?(+a[0]) * 60 * 60 + (+a[1]) * 60 + (+a[2]):
                 (typeof a[1] !== "undefined")?(+a[0]) * 60+ (+a[1]):(+a[0]);


                 return(seconds);
             }

             waitForKeyElements ( "th", prepareTable);
             waitForKeyElements ("td.ng-tns-c46-2,td.ng-tns-c49-2", setTDvalue);
             waitForKeyElements ( ".circle", addLogo);
             waitForKeyElements ( "span.copyright.ml-auto.my-auto.mr-2", addDisclaimer);

             function setTDvalue(jNode) {
                 var rightNow = (new Date().getTime()/1000 );



                 jNode.attr("AP-DAJS-valueCalc",
                            ( jNode.text()!="" && jNode.text().replace(/[ 0-9hdmsHDMS]*/g,"")=="" )?timeStringToSeconds(jNode.text()):(isNaN(jNode.text().replace(/[$,]/g,"")))?jNode.text().toLowerCase():parseFloat(jNode.text().replace(/[$,]/g,""))
                           ); /*convert relative times to epoch time so don't have to worry about cell value updating, as it does. */
                 return true;
                 /* jNode.on('DOMSubtreeModified', setTDvalue(jNode)); NOPE! Infinit loop */
             }

             function prepareTable (jNode) {
                 if (!jNode.closest("table").attr("id"))
                 {  jNode.closest("table").attr("id",Math.floor(Math.random() * Math.floor(Math.random() * Date.now())));}
                 jNode.addClass("AP-DAJS-clickable");
                 jNode.attr("onclick","sortTable("+jNode.index()+","+jNode.closest("table").attr("id")+")");
                 jNode.append('<span class="AP-DAJS-element DAsorter" id="AP-DAJS-th'+jNode.closest("table").attr("id")+jNode.index()+'">⇅</span>');
             }


             /* Watch for window URL change: */
             history.pushState = ( function (f) {return function pushState(){
                 var ret = f.apply(this, arguments);
                 window.dispatchEvent(new Event('pushstate'));
                 window.dispatchEvent(new Event('locationchange'));
                 return ret;
             }})(history.pushState);

             history.replaceState = ( function (f) { return function replaceState(){
                 var ret = f.apply(this, arguments);
                 window.dispatchEvent(new Event('replacestate'));
                 window.dispatchEvent(new Event('locationchange'));
                 return ret;
             }})(history.replaceState);

             window.addEventListener('popstate',function(){ return function(){
                 window.dispatchEvent(new Event('locationchange'))
             }});


             window.addEventListener('locationchange', function(){
                 initPage();
             })


             /* End Watch for window URL change. from https://stackoverflow.com/questions/6390341/how-to-detect-if-url-has-changed-after-hash-in-javascript/52809105#52809105 */


             window.addEventListener('popstate', function (event) {
                 // back and forward buttons, etc.
                 initPage();
             });

             function initPage(){
                 var thisPage = (document.location.href.match('www.dextools.io/app/uniswap/pair-explorer'))?"pair":"pool";
                 //   waitForKeyElements ( "div.card-header.border-bottom.ng-tns-c46-2>h6", addLink);
                 if(thisPage=="pool"){
                     $(document).ready(function(){
                         $(document.head).append(allPagesScripts+`
<script id="AP-DAJS-poolScripts">
    async function DAgetCCPrice(symbol,identifier) {
    var xhr = new XMLHttpRequest();
    xhr.open("GET", "https://min-api.cryptocompare.com/data/price?fsym="+symbol+"&tsyms=USD,ETH", true);
    xhr.onload = function () {
        var ret=JSON.parse(xhr.responseText);
        var result=ret.Message?(ret.Message.replace("There is no data for the symbol ","No data on ").replace("There is no data for any of the toSymbols",symbol+" not listed in")):"USD$"+(ret.USD||"unknown")+" ETHΞ"+(ret.ETH||"unknown");document.getElementById("priceSpan"+identifier).innerText=result;
    };
    xhr.send();

}

function resizeIFrameToFitContent( iFrame ) {

    iFrame.width  = iFrame.contentWindow.document.body.scrollWidth;
    iFrame.height = iFrame.contentWindow.document.body.scrollHeight;
}

function previewToggle (thisCounter,url,section){
    if(document.getElementById('AP-DAJS-previewResults'+thisCounter).style.display=='block'
       && document.getElementById('AP-DAJS-results'+thisCounter).src==decodeURIComponent(url))
    {document.getElementById('AP-DAJS-previewResults'+thisCounter).style.display='none';
     document.getElementById('AP-DAJS-floaterlink'+section+thisCounter).innerHTML='&gt;🔎'}
    else
    {document.getElementById('AP-DAJS-results'+thisCounter).src=decodeURIComponent(url);
     document.getElementById('AP-DAJS-previewResults'+thisCounter).style.display='block';
     document.getElementById('AP-DAJS-floaterlink'+section+thisCounter).innerHTML='&lt;🔍'}
}
</script>
`);
                     });


                     waitForKeyElements ( "td:nth-child(4) > a.badge-danger", makeRed);
                     waitForKeyElements ( "td:nth-child(4) > a.badge-success", makeGreen);
                     waitForKeyElements ( "td:nth-child(3) > a > i.fa-wpexplorer.pools-icon-warning:not(i.gAdded)", addGoog);
                     waitForKeyElements ( "td:nth-child(4) > i.fa-info-circle.pools-icon-warning", poolWarning);
                     waitForKeyElements ( "td:nth-child(9) > a.ng-tns-c46-2.badge.badge-danger", rugPull);
                     //            waitForKeyElements ( "td:nth-child(5) > span", ccAdd);

                     waitForKeyElements ( "#AP-DAJS-popupframe[src='']", togglePreview);
                     //End page=pool
                 }
                 else
                 {
                     //page=pair
                     $(document).ready(function(){
                         $(document.head).append(
                             allPagesScripts+`
<script id="AP-DAJS-pairScripts">
var filterState="";

function filterFunction(filterAddr,tableId,theColor) {
    var filter= (filterState=="")?filterAddr:"";
    filterState=filter;
    var  table, tr, td, i, txtValue;
    table = document.getElementById(tableId);


    tr = table.getElementsByTagName("tr");
    var hTD = table.getElementsByTagName("th")[6];

    for (i = 0; i < tr.length; i++) {
        td = tr[i].getElementsByTagName("td")[6];
        if (td) {
            txtValue = td.textContent || td.innerText;
            if (txtValue.indexOf(filter) > -1 || filter=="" ) {
                tr[i].style.display = "";
            } else {
                tr[i].style.display = "none";
            }
        }
    }
    if (filter == "") {hTD.innerHTML = hTD.getAttribute("oldText");} else {hTD.setAttribute("oldText",hTD.innerHTML);hTD.innerHTML = 'Maker <span style="color:#'+theColor+' !important" class="AP-DAJS-element">'+filter+' only</span>';}
}
</script>
`);
                     });
                     waitForKeyElements ( "td.ng-tns-c49-2:nth-child(7)", colorCodeHex);
                     waitForKeyElements ( "h3.page-title:has(a.ng-tns-c49-2+a.ng-tns-c49-2)",hiliteExtraInfo); //nth-child(2) didn't work because 2nd child isn't 'a'!

                     // end page=pair
                 }


             } /*end initPage*/


             function hiliteExtraInfo(jNode) { //visually highlight when there's extra contact info for a token

                 jNode.children("a").addClass("badge-warning");
                 jNode.append("<span class='text-warning'>Contact info found!</span>"); //let's only post it once.
             }

             function colorCodeHex(jNode) {
                 var thisNode = jNode.children("a").first();
                 var theHex= thisNode.text().replace(/ /g,'');

                 if( thisNode.closest("table").attr("id")==""){thisNode.closest("table").attr('id','AddressesTable');}

                 if(jNode.next("td:has(>a.ng-tns-c49-2>span.badge-secondary)").length)
                 { /* next cell indicates multiple transactions from this address */
                     thisNode.attr('style','color: #'+theHex.toHexColour()+' !important');
                     thisNode.parent().prepend('<i title="filter on this address" class="AP-DAJS-element AP-DAJS-clickable filterbutton fa fa-filter pools-icon-warning ng-tns-c46-2" onclick="filterFunction(\''+theHex+'\',\''+thisNode.closest("table").attr("id")+'\',\''+theHex.toHexColour()+'\')"></i>');
                     //style="background:#'+theHex.toHexColour()+' !important"
                     //  jNode.closest("td").next().attr('style','background: #'+theHex.toHexColour()+' !important');
                 }
                 thisNode.parent().append('<a title="Zerion wallet overview" onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                          +' href="https://app.zerion.io/'+theHex+'/overview">'
                                          +' <div class="AP-DAJS-element backImg zeriImg hide"></div></a>');
             }

             function togglePreview (jNode) {$("#AP-DAJS-preview").toggle();}

             function addLogo (jNode)
             {jNode.addClass("gearImg").css({"background-repeat":"no-repeat","background-position":"center"})};

             function rugPull(jNode) { if (jNode.text()=="-100%") { //var rugHTML='<span class="AP-DAJS-element text-warning badge-danger">RUGPULL</span> ';
                 jNode.addClass("badge-dark");
                 // jNode.parent().prev().addClass("badge-danger");
                 // jNode.parent().prevAll().eq(4).first().first().remove();
                 jNode.parent().prevAll().eq(4).children(":first").addClass("badge-dark");
                 jNode.parent().prevAll().eq(4).children(":first").text("RUGPULL");
                 //jNode.parent().next().addClass("badge-danger");
             } }

             function addLink(jNode) { var creditHTML='<div style="float:right" class="AP-DAJS-element"><div class="AP-DAJS-element sirImg backImg"></div> <a href="#" class="AP-DAJS-element">DextAssistant Installed</a></div>';
                                      jNode.parent().prepend(creditHTML);
                                     }
             function addDisclaimer(jNode) { var creditHTML='<div style="margin:auto 0 auto auto;" class="AP-DAJS-element text-muted bottomdiv"><a href="#" class="AP-DAJS-element">DextAssistant</a><div class="AP-DAJS-element sirImg backImg" onclick="javascript:this.classList.toggle(\'anim\');"></div> '+currentVersion+' installed <span id="newVersion" class="AP-DAJS-element"></span></div>';
                                            //              var creditHTML='<div style="margin:auto 0 auto auto;" class="AP-DAJS-element text-muted"><a href="#" class="AP-DAJS-element">DextAssistant</a><div class="AP-DAJS-element sirImg backImg"></div> is an independent community project not affiliated with DEXTools.io</div>';
                                            jNode.before(creditHTML);
                                            $("div.navbar-toggler").on('click', 'div.navbar-toggler', function (e) {

                                            });
                                           }
             function makeRed(jNode){ jNode.parent().parent().addClass("redBkgd");
                                     jNode.parent().next().addClass("redBkgd");
                                    }

             function makeGreen(jNode){ jNode.parent().parent().addClass("greenBkgd");
                                       jNode.parent().next().addClass("greenBkgd");
                                      }

             function addGoog(jNode){ jNode.addClass("gAdded");
                                     var theAbbreviation=jNode.parent().parent().siblings().first().children(0).text();
                                     var theContract=jNode.parent().parent().siblings().first().children(0).attr('href')
                                     var thePair=jNode.parent().parent().next().children(0).attr('href')
                                     theContract=theContract.substring(theContract.lastIndexOf("/")+1);
                                     thePair=thePair.substring(thePair.lastIndexOf("/")+1);
                                     var theIcon='https://raw.githubusercontent.com/trustwallet/assets/master/blockchains/ethereum/assets/'+Web3.utils.toChecksumAddress(theContract)+'/logo.png'
                                     //var theHTML='<a _ngcontent-apl-c46 target="_blank" class="AP-DAJS-element mr-2 ng-tns-c46-2 ng-star-inserted" href="https://www.google.com/search?q=%22'+theContract+'%22+OR+%22$'+theAbbreviation+'%22"><div _ngcontent-apl-c46 class="AP-DAJS-element googImg ng-tns-c46-2"></div></a>';


                                     var thisCounter = IDcounter.toString();
                                     //let's create the row icon while we're here
                                     jNode.parent().parent().siblings("td:first-child").prepend('<img id="AP-DAJS-theCoinRow'+thisCounter+'" class="AP-DAJS-element smallImg hide" src="'+theIcon+'" onerror="document.getElementById(\'AP-DAJS-theCoinRow'+thisCounter+'\').classList.add(\'pHide\')"> ');


                                     var theTD = jNode.parent().parent()||{};
                                     var theNextTD = theTD.next()||{};
                                     function displayPreviewOpener(thisCounter,url,section){
                                         var theResult = '<div style="float:right" id="AP-DAJS-floater'+section+thisCounter+'" class="AP-DAJS-element">'
                                         +' <a class="AP-DAJS-element floaterlink" id="AP-DAJS-floaterlink'+section+thisCounter+'" onmouseenter="previewToggle(\''+thisCounter+'\',\''+encodeURIComponent(url)+'\',\''+section+'\')">'
                                         +'&gt;🔎</a></div>';
                                         return theResult;
                                     }

                                     var thePreviewResults= '<div id="AP-DAJS-previewResults'+thisCounter+'" style="padding-left: 12px;margin:0; float: right; background: white; width: 285px !important; height: 275px !important; display: block;" class="AP-DAJS-element"><span class="AP-DAJS-element"><b>Quick search results for contract addresses:</b></span><br><iframe style="background:white;border-style:none;position:relative;top:0px;width:285px !important;height:95% !important;" id="AP-DAJS-results'+thisCounter+'" class="AP-DAJS-element"></iframe></div>';


                                     var theHTML=
                                         //~popover button
                                         '<div class="AP-DAJS-element '+(theNextTD.children("i.text-success,i.text-info,i.text-warning,i.text-muted,i.text-secondary")[0]?'sirImg':'sirImg') //was 'sirImg':'gearImg'
                                     +' text-'+(theNextTD.children("i.text-info")[0]?'info':theNextTD.children("i.text-warning")[0]?'warning':
                                                theNextTD.children("i.text-danger")[0]?'danger':theNextTD.children("i.text-success")[0]?'success':'muted')
                                     +' backImg" id="popButton'+thisCounter+'" data-toggle="popover"'
                                     + ' data-container="body" data-boundary="viewport" data-placement="top" type="button" data-html="true">'
                                     + (theNextTD.children("i.text-success,i.text-info,i.text-warning,i.text-muted")[0]?'':theNextTD.children("i.text-danger,i.fa-warning.text-danger")[0]?'<span class="AP-DAJS-element">💩</span>':theNextTD.children("i")[0]?'N':'')
                                     + '</div>'


                                     + '<div id="popover-content'+thisCounter+'" class="AP-DAJS-element pHide"></div>'
                                     var contractFloatOpener=displayPreviewOpener(thisCounter,"https://apopheniapays.com/cryptosearch/resultsOnly.html?q=%22"+theContract+"%22+OR+%22"+thePair+"%22",'contract');
                                     var chartexFloatOpener=displayPreviewOpener(thisCounter,"https://chartex.pro/?symbol=UNISWAP:"+theAbbreviation,'chartex');
                                     var thisHTML= '<table class="AP-DAJS-element"><tr><td><div class="AP-DAJS-element centered AP-DAJS-popupItem">'

                                     //~initialize side popup
                                     + '<script id="AP-DAJS-hidePreviewResults">'
                                     +'document.getElementById("AP-DAJS-previewResults'+thisCounter+'").style.display="none";'
                                     +'</script>'

                                     //~popover headers
                                     + '<img id="AP-DAJS-theCoin'+thisCounter+'" class="AP-DAJS-element smallImg hide" src="'+theIcon+'" onerror="document.getElementById(\'AP-DAJS-theCoin'+thisCounter+'\').classList.add(\'coinImg\');document.getElementById(\'AP-DAJS-warning'+thisCounter+'\').classList.remove(\'pHide\')"><span contentediable="true"  class="AP-DAJS-element abbrev" id="abbrev'+thisCounter+'">'+theAbbreviation+'</span> <div id="AP-DAJS-warning'+thisCounter+'" class="AP-DAJS-element badge badge-danger pHide">no icon!</div>'
                                     + '<br />'
                                     + contractFloatOpener

                                     //~Uniswap etherscan addr
                                     + '<a class="AP-DAJS-element AP-DAJS-popupWin"  href="https://etherscan.io/token/'+theContract+'"><div class="AP-DAJS-element smallImg addrImg hide"></div></a><span contentediable="true" class="AP-DAJS-element contract text-muted">'+ theContract.substring(0,14)+'...'+theContract.substring(theContract.length-14,theContract.length)
                                     + '</span>'

                                     //~Uniswap pool addr
                                     + '<br />'
                                     + '<a  class="AP-DAJS-element AP-DAJS-popupWin" href="https://uniswap.info/pair/'+thePair+'"><div class="AP-DAJS-element smallImg unisImg hide"></div></a> <span contentediable="true" class="AP-DAJS-element contract text-muted">'+ thePair.substring(0,14)+'...'+thePair.substring(thePair.length-14,thePair.length)
                                     + '</span>'
                                     + '</div>'

                                     //CryptoCompare Price
                                     + '<hr class="AP-DAJS-element"><span class="AP-DAJS-element">Cryptocompare price:</span> <span id="priceSpanUSD'+thisCounter+'" class="AP-DAJS-element"></span> <span onclick="javascript:alert(\'CryptoCompare\\\'s free API is not reliable and returns incorrect data. Sorry, I\\\'ll reenable this when I can find a reliable free data source. Love, your developer\')" class="AP-DAJS-element"><u>disabled</u></span>'
                                     + '<!-- script>DAgetCCPrice("'+theAbbreviation+'","USD'+thisCounter+'");DAgetCCPrice("'+theAbbreviation+'","ETH'+thisCounter+'")</script -->'
                                     + '<hr class="AP-DAJS-element">'

                                     //~Google Custom Seach Enging - crypto web search, include crypto news & social media, exclude block explorers
                                     + '<div class="AP-DAJS-element backImg googImg hide"></div>'
                                     + '<a onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin makeBold"'
                                     + ' href="https://apopheniapays.com/cryptosearch/results.html?q=%22'+theContract+'%22+OR+%22'+thePair+'%22&orig='+theAbbreviation+'&icon='+encodeURIComponent(theIcon)+'">'
                                     +' Ox Addresses</a> | <a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://apopheniapays.com/cryptosearch/results.html?q=%22$'+theAbbreviation+'%22&orig=Token%20addr%20'+theContract+'%20and%20Uniswap%20liquidity%20pool%20address'+thePair+'&icon='+encodeURIComponent(theIcon)+'">&quot;$'+theAbbreviation+'&quot;</a> <br> Crypto Filtered Web Search'
                                     +'<hr class="AP-DAJS-element"> '

                                     //~whole web search
                                     + '<div class="AP-DAJS-element backImg googImg hide"></div> <a '
                                     +'  onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin makeBold"'
                                     +' href="https://www.google.com/search?q=%22'+theContract+'%22+OR+%22'+thePair+'%22">'
                                     +' Ox Addresses</a> | <a '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://www.google.com/search?q=%22$'+theAbbreviation+'%22">&quot;$'+theAbbreviation+'&quot;</a> <br> Whole Web Search'
                                     +'<hr class="AP-DAJS-element"> '

                                     //~zerion
                                     +'<a '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://app.zerion.io/explore/asset/'+theAbbreviation+'-'+theContract+'">'
                                     +' <div class="AP-DAJS-element backImg zeriImg hide"></div>Token/Portfolio Analytics</a> <br>Zerion'
                                     +'<hr class="AP-DAJS-element">'

                                     //~Uniswap
                                     +'<div class="AP-DAJS-element backImg unisImg hide"></div> <a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://uniswap.info/token/'+theContract+'">Token Analytics</a> | '
                                     +' <a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://uniswap.info/pair/'+thePair+'">Pool Stats</a> <br>Uniswap'
                                     +'<hr class="AP-DAJS-element">'

                                     //~Mooniswap
                                     +'<div class="AP-DAJS-element backImg moonImg hide"></div> <a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://mooniswap.info/token/'+theContract+'">Token Analytics</a> | '
                                     +' <a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://mooniswap.exchange/#/swap?inputCurrency='+theContract+'">Live trading</a> <br>1inch Mooniswap'
                                     +'<hr class="AP-DAJS-element">'

                                     //~unicrypt
                                     +'<a  '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://unicrypt.network/uniswap-browser/pair/'+thePair+'">'
                                     +' <div class="AP-DAJS-element backImg crypImg hide"></div>Verify liquidity lock</a> <br>Unicrypt'
                                     +'<hr class="AP-DAJS-element"> '

                                     //~cerberus.saren
                                     +'<a '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://cerberus.saren.io/coins/'+theContract+'">'
                                     +' <div class="AP-DAJS-element backImg cerbImg hide"></div> Token analytics</a> <br> cerberus.saren'
                                     +'<hr class="AP-DAJS-element"> '

                                     //~Chartex
                                     /*  + chartexFloatOpener No, don't the popover is really too small for Chartex */
                                     +'<a '
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://chartex.pro/?symbol=UNISWAP:'+theAbbreviation+'">'
                                     +' <div class="AP-DAJS-element backImg chexImg hide"></div> Candlestick chart</a> <br> ChartEX'
                                     +'<hr class="AP-DAJS-element">'

                                     //~Uniswap.vision
                                     +'<a'
                                     +'   onclick="window.open(this.href, \'windowName\', \'width=1000, height=700, right=24, top=24, scrollbars, resizable\'); return false;" class="AP-DAJS-element AP-DAJS-popupItem AP-DAJS-popupWin"'
                                     +' href="https://uniswap.vision/?ticker=UniswapV2:'+theAbbreviation+'ETH">'
                                     +' <div class="AP-DAJS-element backImg visiImg hide"></div> Candlestick chart</a> <br> uniswap.vision'
                                     +'</td><td>'+thePreviewResults
                                     +'</td></tr></table>' //end links



                                     +''; // just leave this at bottom so I don't have to keep moving semicolon as I add things

                                     //                 var theHTML = '<Div href="#" data-toggle="popover" title="Popover Header" data-html="true" data-content="'+theInnerHTML.replace(/"/g,'\\"')+'" class="AP-DAJS-element">Toggle popover</div>';
                                     //gotta use a DIV anot an IMG, because IMG with SRC="" or missing SRC attribute causes visual glitches, unwanted borders, etc
                                     jNode.parent().parent().append( theHTML);
                                     var showFunction=function() { var _this = this;
                                                                  $("div.sirImg").not(this).popover('hide');
                                                                  $(this).popover("show");//$('#frame'+thisCounter).src='https://apopheniapays.com/cryptosearch/results.html?q=%22'+theContract+'%22+OR+%22'+thePair+'%22';
                                                                  $(".popover")
                                                                      .on("mouseleave", function() {
                                                                      $(_this).popover('hide');
                                                                  });
                                                                 }
                                     $("div#popButton"+thisCounter).popover({ trigger: "manual",
                                                                             html: true,
                                                                             animation: false,
                                                                             sanitize:false,
                                                                             content: function() { return thisHTML;} /* prevent duplicate elements */
                                                                            })
                                         .on("mouseenter",ShowAssistantOnHover?showFunction:"" )
                                         .on("click",showFunction ).on("mouseleave", function() {
                                         var _this = this;
                                         setTimeout(function() { if (!$(".popover:hover").length) { $(_this).popover("hide");
                                                                                                  }
                                                               }, 300);
                                     });



                                     /* didn't work, forget it     (function(){ new Clipboard('#copy-buttonContract'+thisCounter);
                     new Clipboard('#copy-buttonAbbrev'+thisCounter);
 })(); */

                                     //.popover({ html: true,trigger : 'hover',	content: function() { return $('#popover-content'+thisCounter).html(); }});
                                     IDcounter++;
                                    }

             function poolWarning(jNode) { var theClasses= jNode.prop("class");

                                          var theClass = (theClasses.match(/\btext\-[^ ]*\b/g, '')||[""])[0];
                                          var thePoolLeft = jNode.closest("td").siblings().last().prev()
                                          thePoolLeft.addClass(theClass).addClass("makeBold");
                                          thePoolLeft.prev().prev().addClass(theClass).addClass("makeBold");
                                          //<i _ngcontent-ljj-c46="" class="AP-DAJS-element ng-tns-c46-2 fa fa-info-circle ml-1 pools-icon-warning  text-danger ng-star-inserted" style=""></i>
                                         }

             //add Styles
             GM_addStyle ( `


/*body {max-width: 100% ;max-height: 100% ; overflow: hidden} yes, need this to prevent scrollbars during animation, but, breaks pair explorer */

       #AP-DAJS-preview {position:fixed;display:none;top:15px;bottom:15px;right:15px;left:50%;z-index:9998;padding:12px;}
                 #AP-DAJS-closebutton {height:24px;widht:24px;position:fixed;top:5px;right:5px;border:1px solid black;content:'X';color:red;background-color:white;font-size:24px;font-weight:bold;}
#AP-DAJS-popupframe {height:100%;width:100%};

.invisible{ display:none; }




div.AP-DAJS-popupItem, a.AP-DAJS-popupItem, a.AP-DAJS-popupItem:hover{ font-size:10px;color:black;font-style:normal;
 }

.centered{ text-align:center
 }

.pHide{ display:none !important
 }

.backImg{ -webkit-background-size: contain !important;
        -moz-background-size: contain !important;
        -o-background-size: contain !important;
        background-size: contain !important;
        background-position: center;
        background-repeat: no-repeat;
        width:21px !important;
        height:21px !important;
        display:inline-block;
        vertical-align:middle;


 }
.smallImg{ -webkit-background-size: contain !important;
        -moz-background-size: contain !important;
        -o-background-size: contain !important;
        background-size: contain !important;
        background-position: center;
        background-repeat: no-repeat;
width:12px !important;
        height:12px !important;
        display:inline-block;
        vertical-align:middle;
margin:0 1px 3px 1px;


 }


.floaterlink {display:inline-block;text-align:center;border:1px solid #00b8d8;width:1.5em;height:1.5em;margin-top:.5em;font-size:2em;font-weight:bold;-webkit-border-radius: 24px;
-moz-border-radius: 24px;
border-radius: 24px;}

.popover {max-width: none !important; } /*otherwise can't make them wider*/ //550
.popover-body * {font-weight:normal;}
.popover-body .backImg {float:left;margin:2px 2px !important;}

span.abbrev.badge-danger:after{content:'[no icon]'}


.filterbutton {-webkit-tap-highlight-color: rgba(0,0,0,0);
border-collapse: collapse;
box-sizing: border-box;
text-decoration: none;
display: inline-block;
line-height: 1;
text-align: center;
white-space: nowrap;
vertical-align: baseline;
padding: 0;
color:#00b8d8;
font-weight: 500;
border-radius: .375rem;

    font-size: 1.6em;}

.filterbutton::before{
content:'\\f0b0';
}

.circle {

    -webkit-animation: animate 1s linear infinite;
    animation: animate 1s linear infinite
}




@-webkit-keyframes circleanimate {
    0% {
        transform: rotate(1turn) scale(0%)
    }

    to {
        transform: rotate(0deg) scale(100%)
    }
}

@keyframes cirleanimate {
    0% {
        transform: rotate(1turn)  scale(0%)
    }

    to {
        transform: rotate(0deg)  scale(100%)
    }
}


.popover-body{ padding: .5rem .75rem .5rem .5rem;

 }

.popover-body a,.popover-body a:hover {line-height: 1.25em !important;color:#00b8d8;font-size: 12px}
.popover-body a:not(.makeBold) {font-weight:normal;}

.popover{ box-shadow: 0 3px 15px rgba(90,97,105,.15), 0 2px 3px rgba(90,97,105,.25),0px 3px 6px 3px rgba(16,75,95,0.25) !important;
        -webkit-box-shadow: 0 3px 15px rgba(90,97,105,.15), 0 2px 3px rgba(90,97,105,.25),0px 3px 6px 3px rgba(16,75,95,0.25) !important;
        -moz-box-shadow: 0 3px 15px rgba(90,97,105,.15), 0 2px 3px rgba(90,97,105,.25),0px 3px 6px 3px rgba(16,75,95,0.25) !important;
 }

.sorting {text-decoration:underline;}

.sorting:after {content:'<span class="AP-DAJS-element"><i>(sorting...)</i></span>';}

div.popover-body hr {margin:0px !important;}

div.popover-body div.backImg{ margin: 3px 4px !important;
 }

div.popover-body input {width:9px;height:9px;}

div.popover-body {font-weight:bold}

.redBkgd, td.bg-light.redBkgd{ background-color: #FFF2F2 !important;
 }

body.dark-theme .redBkgd, body.dark-theme td.bg-light.redBkgd{ background-color: #440000 !important;
 }

body.dark-theme .text-secondary {color:#bbbbbb !important;}
body.dark-theme .badge-secondary {background-color:#bbbbbb !important;}

.greenBkgd, td.bg-light.greenBkgd{ background-color: #CCFFCC !important;
 }
body.dark-theme .greenBkgd, body.dark-theme td.bg-light.greenBkgd{ background-color: #006900 !important;
 }

.makeBold{ font-weight:bold;
 }

.AP-DAJS-clickable, a.AP-DAJS-element {cursor:pointer;}
.AP-DAJS-clickable:hover, a.AP-DAJS-element:hover {cursor:pointer; opacity: .5; color:#007bff;}

i.fa-warning{ background-color:#FFFF00 !important;
 }

  .googImg { background-image: url()
!important;
}

.zeriImg { background-image: url()
!important;}

.sirImg { background-image: url()
!important;


 margin-left: 7px !important;}

.cerbImg{ background-image: url()
!important;
}

.chexImg{ background-image: url()
!important;}

.coinImg-DISABLE{ background-image: url()
!important;}


.chanImg{ background-image: url()
!important;}


.moonImgOLD { background-image: url()
!important;}

.moonImg { background-image: url()
!important;}



.unisImgx { background-image: url()
!important;}

.unisImg {background-image: url( https://www.dextools.io/app/assets/img/uniswap-logo-home.png) !important;}

.gearImg{ background-image: url()
!important;
 margin-left: 7px !important;
text-align:center;
font-weight:bold;
font-size:15px;
padding: 0 2px 6px 0;}



.crypImg{ background-image: url()
!important;}

.visiImg{ background-image: url()
!important;}


.addrImgOld{ background-image: url()
!important;}


.addrImg{ background-image: url()
!important;}

.iconImg{ -webkit-background-size: contain !important;
        -moz-background-size: contain !important;
        -o-background-size: contain !important;
        background-size: contain !important;
        background-position: center;
        background-repeat: no-repeat;
        width:1em !important;
        height:1em !important;
        display:inline-block;
        vertical-align:middle;
 }


.anim {opacity:0;
overflow: hidden !important;
  animation: animationFrames linear .5s;
  animation-iteration-count: 1;
  transform-origin: 50% 50%;
  -webkit-animation: animationFrames linear .5s;
  -webkit-animation-iteration-count: 1;
  -webkit-transform-origin: 50% 50%;
  -moz-animation: animationFrames linear .5s;
  -moz-animation-iteration-count: 1;
  -moz-transform-origin: 50% 50%;
  -o-animation: animationFrames linear .5s;
  -o-animation-iteration-count: 1;
  -o-transform-origin: 50% 50%;
  -ms-animation: animationFrames linear .5s;
  -ms-animation-iteration-count: 1;
  -ms-transform-origin: 50% 50%;
}

@keyframes animationFrames{
  0% {
    opacity:1;
    transform:  translate(0px,0px)  rotate(0deg) scaleX(1.00) scaleY(1.00) ;
 overflow: hidden;
 }
  50% {
    opacity:0.5;
    transform:  translate(-56px,-260px)  rotate(360deg) scaleX(30.00) scaleY(30.00) ;
 overflow: hidden;
 }
  100% {
    opacity:0;
    transform:  translate(-56px,-720px)  rotate(720deg) scaleX(90.00) scaleY(90.00) ;
 overflow: hidden;
 }
}

@-moz-keyframes animationFrames{
  0% {
    opacity:1;
    -moz-transform:  translate(0px,0px)  rotate(0deg) scaleX(1.00) scaleY(1.00) ;
 overflow: hidden;
 }
  50% {
    opacity:0.5;
    -moz-transform:  translate(-56px,-260px)  rotate(360deg) scaleX(30.00) scaleY(30.00) ;
 overflow: hidden;
 }
  100% {
    opacity:0;
    -moz-transform:  translate(-56px,-720px)  rotate(720deg) scaleX(90.00) scaleY(90.00) ;
 overflow: hidden;
 }
}

@-webkit-keyframes animationFrames {
  0% {
    opacity:1;
    -webkit-transform:  translate(0px,0px)  rotate(0deg) scaleX(1.00) scaleY(1.00) ;
 overflow: hidden;
 }
  50% {
    opacity:0.5;
    -webkit-transform:  translate(-56px,-260px)  rotate(360deg) scaleX(30.00) scaleY(30.00) ;
 overflow: hidden;
 }
  100% {
    opacity:0;
    -webkit-transform:  translate(-56px,-720px)  rotate(720deg) scaleX(90.00) scaleY(90.00) ;
 overflow: hidden;
 }
}

@-o-keyframes animationFrames {
  0% {
    opacity:1;
    -o-transform:  translate(0px,0px)  rotate(0deg) scaleX(1.00) scaleY(1.00) ;
 overflow: hidden;
 }
  50% {
    opacity:0.5;
    -o-transform:  translate(-56px,-260px)  rotate(360deg) scaleX(30.00) scaleY(30.00) ;
 overflow: hidden;
 }
  100% {
    opacity:0;
    -o-transform:  translate(-56px,-720px)  rotate(720deg) scaleX(90.00) scaleY(90.00) ;
 overflow: hidden;
 }
}

@-ms-keyframes animationFrames {
  0% {
    opacity:1;
    -ms-transform:  translate(0px,0px)  rotate(0deg) scaleX(1.00) scaleY(1.00) ;
 overflow: hidden;
 }
  50% {
    opacity:0.5;
    -ms-transform:  translate(-56px,-260px)  rotate(360deg) scaleX(30.00) scaleY(30.00) ;
 overflow: hidden;
 }
  100% {
    opacity:0;
    -ms-transform:  translate(-56px,-720px)  rotate(720deg) scaleX(90.00) scaleY(90.00) ;
 overflow: hidden;
 }
}






` );

             //old sirImg 
             initPage();

             //All finished

            })();