Raw Source
mwfiae / Steemit-Sidebar dev mw

// ==UserScript==
// @name         Steemit-Sidebar dev mw
// @namespace    http://tampermonkey.net/
// @copyright 2018, mwfiae (https://steemit.com/@mwfiae)
// @version      0.5.1
// @description  try to take over the world!
// @author       MWFIAE
// @match        http*://steemit.com/*
// @match        http*://steemw.ga/*
// @license MIT
// @grant    GM_getValue
// @grant    GM_setValue
// @grant    GM_getResourceText
// @grant unsafeWindow
// @require http://code.jquery.com/jquery-1.12.4.min.js
// @require https://cdn.steemjs.com/lib/latest/steem.min.js
// @require https://momentjs.com/downloads/moment-with-locales.min.js
// @require https://github.com/inuyaksa/jquery.nicescroll/raw/master/jquery.nicescroll.min.js
// @require https://code.jquery.com/ui/1.12.1/jquery-ui.min.js
// @resource JQUI_CSS https://code.jquery.com/ui/1.12.1/themes/base/jquery-ui.css
// @updateURL https://openuserjs.org/meta/mwfiae/Steemit-Sidebar.meta.js
// ==/UserScript==
/* jshint -W097 */
'use strict';
const I18N = {
    "en":{
        "username": "Username",
        "vp": "Voting Power",
        "full": "Full",
        "bandwidth": "Bandwidth",
        "sp": "SteemPower",
        "settings_title": "Steemit Sidebar Settings",
        "settings_tab1": "Appearance",
        "settings_tab2": "Links",
        "settings_barcolor_low": "Bar Color Low",
        "settings_barcolor_high": "Bar Color High",
        "settings_warn_refresh": "The following settings require a site-refresh (F5).",
        "settings_sidebar_side": "Sidebar-Side",
        "settings_sidebar_side_left": "left",
        "settings_sidebar_side_right": "right",
        "settings_language": "Language",
        "settings_language_en": "English",
        "settings_restore_links": "Restore Links",
        "settings_links_icon": "Icon",
        "settings_links_url": "Url",
        "settings_links_text": "Text",
    },

}
const TEMPLATE_WITHOUT_USER = `
<style>
.ui-tabs{ height:100%; }
.ui-tabs-vertical .ui-tabs-nav { padding: .2em .1em .2em .2em; float: left; width: 20%; }
.ui-tabs-vertical .ui-tabs-nav li { clear: left; width: 100%; border-bottom-width: 1px !important; border-right-width: 0 !important; margin: 0 -1px .2em 0; }
.ui-tabs-vertical .ui-tabs-nav li a { display:inline-block;width: 100% }
.ui-tabs-vertical .ui-tabs-nav li.ui-tabs-active { padding-bottom: 0; padding-right: .1em; border-right-width: 1px; }
.ui-tabs-vertical .ui-tabs-panel { padding: 1em; float: left; width: 80%; }
.ui-button .ui-icon.ui-icon-closethick {
	background: url('') !important;
}

#mw-script-container{
    position: fixed;
    float: left;
    padding-top: 2.5rem;
    padding-left: 2em;
    padding-right: 2em;
    height:100vh;
    overflow-y: auto;
    z-index: 5;
    width: 200px;
    display: grid;
    grid-template-rows: 1fr 80px;
    grid-template-columns: 1fr;
}
.mw-right#mw-script-container{
    right: 0;
}
#mw-main{
  grid-row-start:1;
  grid-row-end:1;
}
#mw-footer{
  grid-row-start:2;
  grid-row-end:2;
}
#mw-collapse-button{
    float: left;
    margin-left: 110px;
    z-index: 100;
    position: fixed;
    cursor: pointer;
    font-weight: bolder;
    margin-top: -16px;
}
#mw-settings{
    float: left;
    z-index: 100;
    cursor: pointer;
    position: relative;
    top: -15px;
    left: -28px;
}
.theme-dark #mw-script-container, .theme-dark #mw-button{
    background-color: #1C252B;
}
.theme-light #mw-script-container, .theme-light #mw-button{
    background-color: #fcfcfc;
}
#username{display: inline;}
.mw-favicon{width:16px; height: 16px}
.mw-ul{list-style-type:none;}
.mw-button{background-color:transparent; border-width: 1px;}
.mw-nowrap{}
/* Tooltip container */
.mw-tooltip {
    position: relative;
    display: inline-block;
}

/* Tooltip text */
.mw-tooltip .mw-tooltiptext {
    visibility: hidden;
    width: 120px;
    background-color: #555;
    color: #fff;
    text-align: center;
    padding: 5px 0;
    border-radius: 6px;

    /* Position the tooltip text */
    position: absolute;
    z-index: 1;
    bottom: 125%;
    left: 50%;
    margin-left: -60px;

    /* Fade in tooltip */
    opacity: 0;
    transition: opacity 0.3s;
}


/* Show the tooltip text when you mouse over the tooltip container */
.mw-tooltip:hover .mw-tooltiptext {
    visibility: visible;
    opacity: 1;
    width: 100%;
}
</style>
<div id="mw-script-container" class="mw-{{settings.side}}">
<div id="mw-main">
<img id="mw-settings" width=32px height=32px src=""
></img>
<span id="mw-collapse-button">&lang;</span>
<p id="mw-username-p"><input id="mw-username" type="text" value="{{settings.username}}" placeholder="{{i18n.username}}"/></p>
<div id="mw-script-content"></div>
<hr id="mw-divider" />
<div id="mw-script-content-other"></div>
</div>
<div id="mw-footer">
© by <a href="https://steemit.com/@mwfiae">MWFIAE</a>
</div>
</div>
`;
const TEMPLATE_WITH_USER = `
<div id="{{temp.target}}">
<p>
<span><a href="https://steemit.com/@{{user.name}}">{{user.name}}</a> ({{user.displayRep}})</span>
</p>
<span>{{i18n.vp}}</span>
<div id="mw-votepower-{{temp.target}}" class="mw-tooltip" style="width:100%;background-color: lightgrey;">
<style>
#mw-votepower-bar-{{temp.target}} {
width: {{user.trueVotePower}}%;
height: 23px;
background-color: {{temp.vote_color}};
text-align: center; /* To center it horizontally (if you want) */
line-height: 30px; /* To center it vertically */
}
#mw-votepower-bar-text-{{temp.target}}{
color: white;
font-size: 0.8em;
text-align: center; /* To center it horizontally (if you want) */
float: left;
width: 100%;
}
</style>
  <span id="mw-votepower-bar-text-{{temp.target}}">{{user.trueVotePower}}%</span>
  <div id="mw-votepower-bar-{{temp.target}}"></div>
  <div class="mw-tooltiptext">{{i18n.full}}:<br />{{user.voteSpan}}<br />{{user.voteTime}}</div>
</div>
<span>{{i18n.bandwidth}} <span style="font-size: 0.8em">{{temp.bw_p}}%</span></span>
<div id="mw-bandwidth-{{temp.target}}" style="width:100%;background-color: lightgrey;">
<style>
#mw-bandwidth-bar-{{temp.target}} {
width: {{temp.bw_pno0}}%;
height: 23px;
background-color: {{temp.bw_color}};
line-height: 30px; /* To center it vertically */
}
#mw-bandwidth-bar-text-{{temp.target}}{
color: white;
font-size: 0.8em;
text-align: center; /* To center it horizontally (if you want) */
float: left;
width: 100%;
}
</style>
<span id="mw-bandwidth-bar-text-{{temp.target}}" class="mw-nowrap" nowrap>{{temp.bw_c}} \/ {{temp.bw_m}}</span>
<div id="mw-bandwidth-bar-{{temp.target}}"></div>
</div>
<div class="mw-tooltip">
{{i18n.sp}}: <a href="https://steemit.com/@{{user.name}}/transfers">{{user.sp}}</a>
  <div class="mw-tooltiptext">Own: {{user.ownSp}}<br>Received: {{user.recSp}}<br>Delegated: {{user.delSp}}<br></div>
</div>
</p>
<ul class="mw-ul">
{{temp.links}}
</ul>
</div>
`;

const TEMPLATE_SETTINGS_MENU = `
<div id="mw-settings-window" title="{{i18n.settings_title}}">
<div id="tabs">
  <ul>
    <li><a href="#tabs-1">{{i18n.settings_tab1}}</a></li>
    <li><a href="#tabs-2">{{i18n.settings_tab2}}</a></li>
  </ul>
  <div id="tabs-1">
    <table>
      <tr>
         <td>{{i18n.settings_barcolor_low}}</td>
         <td><input id="mw-barColorLow" style="min-width:50px" class="mw-inline" type="color" value="{{settings.barColorLow}}"/></td>

         <td>{{i18n.settings_barcolor_high}}</td>
         <td><input id="mw-barColorHigh" style="min-width:50px" class="mw-inline" type="color" value="{{settings.barColorHigh}}"/></td>
      </tr>
      <tr>
         <td colspan=4 style="color:red">{{i18n.settings_warn_refresh}}</td>
      </tr>
      <tr>
         <td>{{i18n.settings_sidebar_side}}</td>
         <td>
             <select id="mw-sidebarSide" style="min-width:50px" class="mw-inline" value="{{settings.barColorLow}}">
                <option value="left">{{i18n.settings_sidebar_side_left}}</option>
                <option value="right">{{i18n.settings_sidebar_side_right}}</option>
             </select>
         </td>
         <td>{{i18n.settings_language}}</td>
         <td>
             <select id="mw-language" style="min-width:50px" class="mw-inline" value="{{settings.language}}">
                <option value="en">{{i18n.settings_language_en}}</option>
             </select>
         </td>
      </tr>
    </table>
  </div>
  <div id="tabs-2" style="overflow-y: auto">
    <input class="mw-button" type="button" id="mw-restore-links" value="{{i18n.settings_restore_links}}"/>
    <table id="mw-link-table">
      <tr><th>{{i18n.settings_links_icon}}</th><th>{{i18n.settings_links_url}}</th><th>{{i18n.settings_links_text}}</th></tr>
      <tr>
        <td><input id="mw-new-link-icon" type="text" value="" /></td>
        <td><input id="mw-new-link-url" type="text" value="" /></td>
        <td><input id="mw-new-link-text" type="text" value="" /></td>
        <td><input class="mw-button mw-button-add-link" style="background-color:lightgreen" type="button" value="+" /></td>
      </tr>
      {{links}}
    </table>
  </div>
</div>
</div>
`;
const TEMPLATE_LINK = `<li><a href="{{link.url}}" target="_blank"><img class="mw-favicon" src="{{link.icon}}" />{{link.text}}</a></li>`;
const TEMPLATE_LINK_SETTINGS = `<tr><td><img class="mw-favicon" src="{{link.icon}}" /></td><td>{{link.url}}</td><td>{{link.text}}</td><td><input class="mw-button mw-button-delete-link" style="background-color:pink" type="button" value="x" /></td></tr>`;

const DEFAULT_LINKS=[
    {url: "https://steemd.com/@{{user.name}}", icon: "https://steemd.com/favicon-steem9.png", text: "Steemd"},
    {url: "https://steemworld.org/@{{user.name}}", icon: "https://steemworld.org/favicon.png", text: "Steemworld"},
    {url: "https://steemnow.com/@{{user.name}}", icon: "https://steemnow.com/favicon.ico", text: "Steemnow"},
    {url: "https://zappl.com/@{{user.name}}", icon: "https://zappl.com/1/images/favicon.png", text: "Zappl"},
    {url: "https://d.tube/#!/c/{{user.name}}", icon: "https://d.tube/DTube_files/images/dtubefavicon.png", text: "D.Tube"},
    {url: "https://dmania.lol/profile/{{user.name}}", icon: "https://dmania.lol/favicon.ico", text: "D.Mania"},
    {url: "https://alpha.steepshot.io/@{{user.name}}", icon: "https://alpha.steepshot.io/static/images/faviconNew.ico", text: "Steepshot"},
];
steem.api.setOptions({
  url: 'https://api.steemit.com'
});
//Attaching it to the window of the current site to make debugging alot easier :)
var privPostKey= null;
unsafeWindow.MWSidebar ={
    otherUsername: null,
    settingsMenu: null,
    globalProps:{
        totalVestingFund: 0,
        totalVestingShares: 0,
        maxVirtualBandwidth: 0,
    },
    settings: {
        username: null,
        dateTimeFormat: 'DD.MM. HH:mm:ss',
        collapsed: false,
        barColorLow: "#FF0000",
        barColorHigh: "#00FF00",
        links: DEFAULT_LINKS,
        side: "left",
        lastSaved: 0,
    },
    helper:{
        regexVariable: new RegExp("{{([^}]*)}}", "gim"),
        lerpColor: function(a, b, amount) {

           var ah = parseInt(a.replace(/#/g, ''), 16),
               ar = ah >> 16, ag = ah >> 8 & 0xff, ab = ah & 0xff,
               bh = parseInt(b.replace(/#/g, ''), 16),
               br = bh >> 16, bg = bh >> 8 & 0xff, bb = bh & 0xff,
               rr = ar + amount * (br - ar),
               rg = ag + amount * (bg - ag),
               rb = ab + amount * (bb - ab);

            return '#' + ((1 << 24) + (rr << 16) + (rg << 8) + rb | 0).toString(16).slice(1);
        },
        prettyPrintBytes: function(bytes){

            if(Math.abs(bytes)>1000*1000*1000*1000)
                return (bytes/(1000*1000*1000*1000)).toFixed(2)+" TB";
            if(Math.abs(bytes)>1000*1000*1000)
                return (bytes/(1000*1000*1000)).toFixed(2)+" GB";
            if(Math.abs(bytes)>1000*1000)
                return (bytes/(1000*1000)).toFixed(2)+" MB";
            if(Math.abs(bytes)>1000)
                return (bytes/1000).toFixed(2)+" KB";
            return bytes+" B"
        },
        formatSeconds: function(timeForVotePower){
            let voteSpan = "";
            if(timeForVotePower>24*60*60){
                let days=parseInt(timeForVotePower/(24*60*60));
                timeForVotePower -= days*24*60*60;
                voteSpan = voteSpan + days+"d ";
            }
            if(timeForVotePower>60*60){
                let hours=parseInt(timeForVotePower/(60*60));
                timeForVotePower -= hours*60*60;
                voteSpan = voteSpan + hours+"h ";
            }
            if(timeForVotePower>60){
                let minutes=parseInt(timeForVotePower/60);
                timeForVotePower -= minutes*60;
                voteSpan = voteSpan + minutes+"m ";
            }
            return voteSpan;
        },
        addGlobalStyle: function(css, id) {
            $("head:first").append($('<style' + (id !== undefined ? ' id="' + id + '"' : '') + ' type="text/css">' + css + '</style>'));
        },
        fillTemplate: function(template, values, depth){

            if(depth==undefined)
                depth = 1;
            if(depth > 5)
                return template;
            let result = template;
            let regex = new RegExp(MWSidebar.helper.regexVariable);
            let matches=null;
            while(matches = regex.exec(template)){
                let match = matches[1];
                try{
                    let object = values;
                    match.split(".").forEach(function(single){
                        object = object[single];
                    });
                    if((typeof object)=="string" && object.match(new RegExp(MWSidebar.helper.regexVariable))){
                        object = MWSidebar.helper.fillTemplate(object, values, depth+1);
                    }
                    result = result.replace(matches[0], object);
                }
                catch(e){ console.log(e); }
            };
            return result;
        },
    },
    ui: {

        toggleCollapse: function(){
            MWSidebar.settings.collapsed = ! MWSidebar.settings.collapsed;
            MWSidebar.saveSettings();
            MWSidebar.refreshCollapse();
        },
        openSettings: function (){
            console.log("opening Settings...");
            MWSidebar.settingsMenu.dialog("open");
            $( "#tabs" ).tabs().addClass( "ui-tabs-vertical ui-helper-clearfix" );
            $( "#tabs li" ).removeClass( "ui-corner-top" ).addClass( "ui-corner-left" );

            jQuery('#mw-barColorHigh').change(MWSidebar.ui.changeBarColorHigh);
            jQuery('#mw-barColorLow').change(MWSidebar.ui.changeBarColorLow);

            $("#mw-sidebarSide").val(MWSidebar.settings.side) //initialize with the current value.
            jQuery('#mw-sidebarSide').change(MWSidebar.ui.changeSidebarSide);

            $("#mw-language").val(MWSidebar.settings.language) //initialize with the current value.
            jQuery('#mw-language').change(MWSidebar.ui.changeLanguage);


            jQuery("#mw-restore-links").click(MWSidebar.ui.restoreLinks);
            jQuery(".mw-button-delete-link").click(MWSidebar.ui.deleteLink);
            jQuery(".mw-button-add-link").click(MWSidebar.ui.addLink);

            /*$('.ui-dialog').css({
                'width': $(window).width(),
                'height': $(window).height(),
                'left': '0px',
                'top':'0px'
            });*/
        },
        changeSidebarSide: function(){
            MWSidebar.settings.side = $("#mw-sidebarSide").val();
        },
        changeLanguage: function(){
            MWSidebar.settings.language = $("#mw-language").val();
            MWSidebar.update();
            MWSidebar.updateOther();
        },
        changeBarColorLow: function(){
            MWSidebar.settings.barColorLow= $("#mw-barColorLow").val();
            MWSidebar.update();
            MWSidebar.updateOther();
        },
        changeBarColorHigh: function(){
            MWSidebar.settings.barColorHigh= $("#mw-barColorHigh").val();
            MWSidebar.update();
            MWSidebar.updateOther();
        },
        removeAllLinks: function(){
            jQuery("#mw-link-table tr:has(.mw-button-delete-link)").remove();
        },
        addAllLinks: function(){
            jQuery("#mw-link-table").append(MWSidebar.settings.links.reduce((result,link)=>{
                return result + MWSidebar.helper.fillTemplate(TEMPLATE_LINK_SETTINGS, {link: link, i18n: I18N[MWSidebar.settings.language]}, 5);
            },""));
            jQuery(".mw-button-delete-link").click(MWSidebar.ui.deleteLink);

            MWSidebar.doUpdate();
            MWSidebar.doUpdateOther();
        },
        addLink: function(){
            let icon = jQuery("#mw-new-link-icon").val();
            let url = jQuery("#mw-new-link-url").val();
            let text = jQuery("#mw-new-link-text").val();
            if(url==""){
                alert("You have to enter an url!");
                return;
            }
            if(icon==""&&text==""){
                alert("You have to enter an icon or text!");
                return;
            }
            jQuery("#mw-new-link-icon").val("");
            jQuery("#mw-new-link-url").val("");
            jQuery("#mw-new-link-text").val("");
            let link = {icon: icon, url: url, text: text};
            MWSidebar.settings.links.push(link);
            MWSidebar.saveSettings();
            MWSidebar.ui.removeAllLinks()
            MWSidebar.ui.addAllLinks();
        },
        deleteLink: function(e){
            var i= jQuery(".mw-button-delete-link").index(e.target);
            MWSidebar.settings.links.splice(i, 1);
            MWSidebar.saveSettings();
            MWSidebar.ui.removeAllLinks()
            MWSidebar.ui.addAllLinks();
        },
        restoreLinks: function(){
            MWSidebar.settings.links = DEFAULT_LINKS.slice(0);
            MWSidebar.saveSettings();
            MWSidebar.ui.removeAllLinks()
            MWSidebar.ui.addAllLinks();
        }
    },

    calcBandwidth: function(data){
        const STEEMIT_BANDWIDTH_AVERAGE_WINDOW_SECONDS = 60 * 60 * 24 * 7;
        let vestingShares = parseFloat(data.vesting_shares)
        let receivedVestingShares = parseFloat(data.received_vesting_shares)

        let average_bandwidth = parseInt(data.average_bandwidth, 10)

        let delta_time = (new Date - new Date(data.last_bandwidth_update + "Z")) / 1000

        let bandwidthAllocated = (MWSidebar.globalProps.maxVirtualBandwidth  * (vestingShares + receivedVestingShares) / MWSidebar.globalProps.totalVestingShares)
        bandwidthAllocated = Math.round(bandwidthAllocated / 1000000);

        let new_bandwidth = 0
        if (delta_time < STEEMIT_BANDWIDTH_AVERAGE_WINDOW_SECONDS) {
            new_bandwidth = (((STEEMIT_BANDWIDTH_AVERAGE_WINDOW_SECONDS - delta_time)*average_bandwidth)/STEEMIT_BANDWIDTH_AVERAGE_WINDOW_SECONDS)
        }
        new_bandwidth = Math.round(new_bandwidth / 1000000)
        let remaining = 100 - (100 * new_bandwidth / bandwidthAllocated);

        return [new_bandwidth, bandwidthAllocated, remaining];
    },
    updateUser: function(newData) {
        if (newData == undefined) {
            user = null;
            return;
        }
        newData.displayRep = steem.formatter.reputation(newData.reputation);

        let base_voting_power = newData.voting_power;
        let last_time = moment.utc(newData.last_vote_time).valueOf();
        let now = moment.utc().valueOf();
        let delta = (now-last_time) /1000;
        let updated_voting_power = base_voting_power +(10000*delta/432000);
        if( updated_voting_power > 10000 ) {
            updated_voting_power = 10000;
        }
        newData.trueVotePower = (updated_voting_power/100).toFixed(2);
        let timeForVotePower = (10000-updated_voting_power)/2000*24*60*60;
        let voteTimeStamp = moment.utc(moment.utc().valueOf() + timeForVotePower*1000);
        newData.voteTime = voteTimeStamp.local().format(MWSidebar.settings.dateTimeFormat);

        newData.voteSpan = MWSidebar.helper.formatSeconds(timeForVotePower);

        newData.sp = 0;
        let effective_vesting_shares =0;
        newData.vesting_shares = parseFloat(newData.vesting_shares.replace(" VESTS",""));
        newData.delegated_vesting_shares = parseFloat(newData.delegated_vesting_shares.replace(" VESTS",""));
        newData.received_vesting_shares = parseFloat(newData.received_vesting_shares.replace(" VESTS",""));
        effective_vesting_shares= newData.vesting_shares - newData.delegated_vesting_shares + newData.received_vesting_shares;
        newData.sp= MWSidebar.globalProps.totalVestingFund * (effective_vesting_shares / MWSidebar.globalProps.totalVestingShares)
        newData.ownSp= (MWSidebar.globalProps.totalVestingFund * ( newData.vesting_shares / MWSidebar.globalProps.totalVestingShares)).toFixed(3)
        newData.recSp= (MWSidebar.globalProps.totalVestingFund * (newData.received_vesting_shares / MWSidebar.globalProps.totalVestingShares)).toFixed(3)
        newData.delSp= (MWSidebar.globalProps.totalVestingFund * (newData.delegated_vesting_shares / MWSidebar.globalProps.totalVestingShares)).toFixed(3)

        newData.sp = newData.sp.toFixed(3);

        let bandwidthData= MWSidebar.calcBandwidth(newData);
        newData.bw_a = bandwidthData[0];
        newData.bw_m = bandwidthData[1];
        newData.bw_p = bandwidthData[2];

        return newData;
    },

    updateDisplay :function(target, user) {
        if (user == undefined)
            return;
        let content = TEMPLATE_WITH_USER;
        let links = MWSidebar.settings.links.reduce((result,link)=>{
            return (result=={}?"":result) + MWSidebar.helper.fillTemplate(TEMPLATE_LINK, {link: link, user: user, i18n: I18N[MWSidebar.settings.language]});
        },"");
        temp = {
            target: target,
            links: links,
            bw_c: MWSidebar.helper.prettyPrintBytes(user.bw_m-user.bw_a),
            bw_m: MWSidebar.helper.prettyPrintBytes(user.bw_m),
            bw_p: user.bw_p.toFixed(2),
            vote_color: MWSidebar.helper.lerpColor(MWSidebar.settings.barColorHigh, MWSidebar.settings.barColorLow, (100-user.trueVotePower)/100),
            bw_color: MWSidebar.helper.lerpColor(MWSidebar.settings.barColorHigh, MWSidebar.settings.barColorLow, (100-user.bw_p)/100),
            bw_pno0: user.bw_p>0?user.bw_p.toFixed(2):"0"
        };
        content = MWSidebar.helper.fillTemplate(TEMPLATE_WITH_USER, {settings: MWSidebar.settings, user: user, temp:temp, i18n: I18N[MWSidebar.settings.language]});

        jQuery("#" + target).replaceWith(content);
        jQuery('#mw-script-container').niceScroll({cursorcolor:"lightblue"});
        MWSidebar.refreshCollapse();
    },
    updateAccountInfo : function updateAccountInfo(account, target) {
        if (account == null || account == "") {
            jQuery("#" + target).replaceWith('<div id="{target}"></div>'.replace("{target}", target));
            return;
        }
        steem.api.getAccounts([account], function (err, result) {
            if ( ( err != null && err != "") || result.length == 0) {
                user = null;
                console.log(err);
                return;
            }
            var user = MWSidebar.updateUser(result[0]);
            MWSidebar.updateDisplay(target, user);
        });
    },
    update: function() {
        MWSidebar.updateAccountInfo( MWSidebar.settings.username, "mw-script-content", false);
    },
    updateOther:function() {

        var newOtherUser;
        splits = document.location.pathname.split('/');
        for (i = 0; i < splits.length; i++) {

            if (splits[i].startsWith('@')) {
                newOtherUser = splits[i].replace("@", "");
                break;
            }
            newOtherUser = "";
        }
        if (newOtherUser == MWSidebar.settings.username){
            newOtherUser = "";
        }
        if (newOtherUser !=  MWSidebar.otherUsername) {
            MWSidebar.otherUsername = newOtherUser;
            MWSidebar.updateAccountInfo( MWSidebar.otherUsername, "mw-script-content-other", true);
        }
    },
    updateUsername : function(e) {
        if (e.which == 13) {
            MWSidebar.settings.username = jQuery('#mw-username').val().toLowerCase();
            MWSidebar.update();
            MWSidebar.saveSettings();
            return false;
        };
    },
    refreshCollapse: function(){
        if( MWSidebar.settings.collapsed){
            jQuery('#mw-script-content').hide();
            jQuery('#mw-script-content-other').hide();
            jQuery('#mw-username-p').hide();
            jQuery('#mw-divider').hide();
            jQuery('#mw-footer').hide();
            jQuery('#mw-collapse-button').css('margin-left','2px');
            jQuery('#mw-script-container').css('width','2px');
            jQuery('#mw-script-container').css('padding-left','9px');
            jQuery('#mw-script-container').css('height','auto');
            jQuery('#mw-script-container').css('background-color','transparent');

            if(MWSidebar.settings.side=="left"){
                jQuery('#mw-collapse-button').html("&rang;");
            }else{
                jQuery('#mw-collapse-button').html("&lang;");
            }
        }else{
            jQuery('#mw-script-content').show();
            jQuery('#mw-script-content-other').show();
            jQuery('#mw-username-p').show();
            jQuery('#mw-divider').show();
            jQuery('#mw-footer').show();
            jQuery('#mw-script-container').css('width','200px');
            jQuery('#mw-script-container').css('padding-left','2em');
            jQuery('#mw-script-container').css('height','100vh');
            jQuery('#mw-script-container').css('background-color','');
            jQuery('#mw-collapse-button').css('margin-left','110px');

            if(MWSidebar.settings.side=="left"){
                jQuery('#mw-collapse-button').html("&lang;");
            }else{
                jQuery('#mw-collapse-button').html("&rang;");
            }
        }
    },
    loadSettings: function(){
        MWSidebar.settings.username = MWSidebar.getSetting("mw-username","");
        MWSidebar.settings.barColorHigh = MWSidebar.getSetting("mw-barColorHigh", "#00FF00");
        MWSidebar.settings.barColorLow = MWSidebar.getSetting("mw-barColorLow", "#FF0000");
        MWSidebar.settings.side = MWSidebar.getSetting("mw-side", "left");
        MWSidebar.settings.language = MWSidebar.getSetting("mw-language", "en");
        MWSidebar.settings.lastSaved = MWSidebar.getSetting("mw-lastSaved", 0);

        let collapsed = MWSidebar.getSetting("mw-collapsed", false);
        MWSidebar.settings.collapsed = collapsed==true || collapsed=="true";

        let json =  MWSidebar.getSetting("mw-links", null);
        if(json==null||json=="")
            MWSidebar.settings.links = DEFAULT_LINKS;
        else
            MWSidebar.settings.links = JSON.parse(json);
        const autopost2 = localStorage.getItem('autopost2');
        if (data) {
            [username, password, memoWif, login_owner_pubkey] = new Buffer(autopost2,'hex').toString().split('\t');
            privPostKey = password;
            if(!MWSidebar.settings.username|| MWSidebar.settings.username=="")
                MWSidebar.settings.username = username;
        }
    },
    saveSettings: function(){
        MWSidebar.settings.lastSaved = moment.utc().valueOf();
        MWSidebar.setSetting("mw-username", MWSidebar.settings.username);
        MWSidebar.setSetting("mw-collapsed", MWSidebar.settings.collapsed);
        MWSidebar.setSetting("mw-barColorHigh", MWSidebar.settings.barColorHigh);
        MWSidebar.setSetting("mw-barColorLow", MWSidebar.settings.barColorLow);
        MWSidebar.setSetting("mw-links", JSON.stringify(MWSidebar.settings.links));
        MWSidebar.setSetting("mw-side", MWSidebar.settings.side);
        MWSidebar.setSetting("mw-language", MWSidebar.settings.language);
        MWSidebar.setSetting("mw-lastSaved", MWSidebar.settings.lastSaved);
    },
    setup: function() {
        MWSidebar.loadSettings();

        jQuery('.App__content').eq(0).before(
            MWSidebar.helper.fillTemplate(TEMPLATE_WITHOUT_USER, {settings: MWSidebar.settings, i18n: I18N[MWSidebar.settings.language]})
        );
        MWSidebar.refreshCollapse();
        jQuery('#mw-username').keypress(MWSidebar.updateUsername);
        jQuery('#mw-collapse-button').click(MWSidebar.ui.toggleCollapse);
        jQuery('#mw-settings').click(MWSidebar.ui.openSettings);

        let index = 0;
        let links = MWSidebar.settings.links.reduce((result,link)=>{
            return (result=={}?"":result) + MWSidebar.helper.fillTemplate(TEMPLATE_LINK_SETTINGS, {link: link, i18n: I18N[MWSidebar.settings.language]}, 5);
        },"");
        jQuery("body").append(MWSidebar.helper.fillTemplate(TEMPLATE_SETTINGS_MENU, {settings: MWSidebar.settings, links:links, i18n: I18N[MWSidebar.settings.language]}));

        MWSidebar.settingsMenu = jQuery("#mw-settings-window").dialog({
            autoOpen: false,
            resizable: false,
            height: 600,
            width: "80vw",
            modal: true,
            buttons: {
                "Save Changes": function(){
                    MWSidebar.saveSettings();
                    MWSidebar.settingsMenu.dialog("close");
                    MWSidebar.update();
                    MWSidebar.updateOther();
                }
            },
            close: function() {
                MWSidebar.loadSettings();
                MWSidebar.update();
                MWSidebar.updateOther();
            }
        });
        MWSidebar.helper.addGlobalStyle(GM_getResourceText("JQUI_CSS"));
    },
    setSetting: function(cname, cvalue) {
        GM_setValue(cname, cvalue);
    },
    getSetting: function(cname, defaultValue) {
        var val=GM_getValue(cname);
        if(val!=null)
            return val;

        var name = cname + "=";
        var decodedCookie = decodeURIComponent(document.cookie);
        var ca = decodedCookie.split(';');
        for (var i = 0; i < ca.length; i++) {
            var c = ca[i];
            while (c.charAt(0) == ' ') {
                c = c.substring(1);
            }
            if (c.indexOf(name) == 0) {
                return c.substring(name.length, c.length);
            }
        }
        if(defaultValue!=null)
            return defaultValue;
        return "";

    },
    updateGlobalProperties: function(){
        steem.api.getDynamicGlobalProperties(function(err, result) {

            MWSidebar.globalProps.totalVestingFund=parseFloat(result.total_vesting_fund_steem.replace(" STEEM", ""));
            MWSidebar.globalProps.totalVestingShares = parseFloat(result.total_vesting_shares.replace(" VESTS", ""));
            MWSidebar.globalProps.maxVirtualBandwidth = parseInt(result.max_virtual_bandwidth, 10);
        });
    },
    doUpdate: function(){
        MWSidebar.update();
        setTimeout(MWSidebar.doUpdate, 10000); //Alle 10 Sekunden das eigene Profil updaten
    },
    doUpdateOther: function(){
        MWSidebar.updateOther();
        setTimeout(MWSidebar.doUpdateOther, 100); //Jede 1/10 Sekunde überprüfen ob man jetzt das Profil eines anderen Users offen hat :)
    },
    doUpdateGlobalProperties: function(){
        MWSidebar.updateGlobalProperties();
        setTimeout(MWSidebar.doUpdateGlobalProperties, 60000); // Jede Minute die neuen Properties holen
    },
    doReloadSettings: function(){
        //Falls eine neuere Version der Settings existiert Settings neu laden
        let latest=MWSidebar.getSetting("mw-lastSaved",0)
        if(latest>MWSidebar.settings.lastSaved)
            MWSidebar.loadSettings();
        setTimeout(MWSidebar.doReloadSettings, 1000); // Jede Sekunde prüfen ob neue Einstellungen vorhanden sind
    }
}


$(document).ready(function () {
    steem.api.getDynamicGlobalProperties(function(err, result) {

        MWSidebar.globalProps.totalVestingFund=parseFloat(result.total_vesting_fund_steem.replace(" STEEM", ""));
        MWSidebar.globalProps.totalVestingShares = parseFloat(result.total_vesting_shares.replace(" VESTS", ""));
        MWSidebar.globalProps.maxVirtualBandwidth = parseInt(result.max_virtual_bandwidth, 10);

        MWSidebar.setup();
        MWSidebar.doUpdate();
        MWSidebar.doUpdateOther();
        MWSidebar.doUpdateGlobalProperties();
        MWSidebar.doReloadSettings();
    });
});