Chaturbate Age-Filter & Locations

Age filter, Locations under each thumbnail, Locations list with links, and more!

As of 2017-01-10. See the latest version.

// ==UserScript==
// @name            Chaturbate Age-Filter & Locations
// @version         1.03
// @namespace       Frank_Einstein@greasyfork.org
// @description     Age filter, Locations under each thumbnail, Locations list with links, and more!
// @include         /^https?:\/\/(\w+\.)?chaturbate\.com(\/.*)?/
// @run-at          document-end
// @grant           none
// @icon            
// ==/UserScript==


console.log("Loading: " + GM_info.script.name + " " + GM_info.script.version);


// MAIN SCRIPT FUNCTION

(function() {

// CURRENT URL //
var _URL = location.href;

//====================================================================================================

// OPTIONS VARIABLES
var AgeMin = 18;
var AgeMax = 99;
var AlwaysHideMales = 0;
var AlwaysHideTrans = 0;
var AlwaysHideGirls = 0;
var AlwaysHideCouples = 0;
var Filter_Interval = 2000;
var Remove_Ads = 1;

//====================================================================================================

// GLOBAL VARIABLES

// AGE FILTER
var AgeMin_Label;
var AgeMin_Textbox;
var AgeMax_Label;
var AgeMax_Textbox;

// LOCATIONS 
var Locations_List;
var CSS_Mod;

// LOCATION WINDOW
var Locations_List_Text;
var Locations_List_Link;
var Locations_List_Window;
var Locations_List_Window_ID;
var Locations_List_Button;
var Locations_List_Div;

// ID OF THE LOCATION WINDOW //
Locations_List_Window_ID = "Locations_List_Window";

//====================================================================================================

// MAIN SCRIPT CODE

// Show_Profile_Locations();

var Pattern_Main       = /^https?:\/\/(\w+\.)?chaturbate\.com(\/|\/\?page)?$/;
var Pattern_Followed   = /^https?:\/\/(\w+\.)?chaturbate\.com\/followed\-cams(\/.*)?$/;
var Pattern_Exhibition = /^https?:\/\/(\w+\.)?chaturbate\.com\/exhibitionist\-cams(\/.*)?$/;
var Pattern_Female     = /^https?:\/\/(\w+\.)?chaturbate\.com\/female\-cams(\/.*)?$/;
var Pattern_Male       = /^https?:\/\/(\w+\.)?chaturbate\.com\/male\-cams(\/.*)?$/;
var Pattern_Couple     = /^https?:\/\/(\w+\.)?chaturbate\.com\/couple\-cams(\/.*)?$/;
var Pattern_Trans      = /^https?:\/\/(\w+\.)?chaturbate\.com\/trans\-cams(\/.*)?$/;
var Pattern_Spy        = /^https?:\/\/(\w+\.)?chaturbate\.com\/spy\-on\-cams(\/.*)?$/;

// Not seems to be needed here...
// Patern = Pattern.source.replace(/\^http/g,'http').replace(/:/g,'%3A').replace(/\\\//g,'%2F').replace(/\//g,'%2F');

if ( Pattern_Main.test(_URL) || 
    Pattern_Exhibition.test(_URL) || 
    Pattern_Female.test(_URL) || 
    Pattern_Male.test(_URL) || 
    Pattern_Couple.test(_URL) || 
    Pattern_Trans.test(_URL) || 
    Pattern_Spy.test(_URL) ) {
    
    // MAIN PAGES //
    
    console.log("[" + GM_info.script.name + " " + GM_info.script.version + "] " + "MAIN PAGE");
    
    // REMOVE ADS //
    if (Remove_Ads) { Hide_Ads(); }
    
    Append_Age_Inputs();
    Age_Filter();
    Clone_Pages_Numbers();
    Show_All_Locations();
    
    var Filter_Loop = setInterval(function() {
        Show_Profile_Locations();
        Age_Filter();
    }, Filter_Interval);

} else {
    
    // WEBCAM PAGES //
    
    // REMOVE ADS //
    if (Remove_Ads) { Hide_Ads(); }
    
}

//====================================================================================================
// FUNCTIONS
//====================================================================================================

function Hide_Ads() {
    Hide_This_Node(".ad");
    Hide_This_Node(".remove_ads");
}

//====================================================================================================

function Show_All_Locations() {
    
    // LOCATIONS-LIST BUTTON //
    
    // Append the new controls inside this node.
    var Target = document.querySelector(".sub-nav");
    
    // NEW LINE BREAK
    Append_BR(Target);
    
    // Create & Append AgeMin DIV
    // function Append_Button(TARGET_NODE, NEW_TEXTBOX_ID, NEW_BUTTON_DISPLAY, NEW_TEXTBOX_CAPTION)
    Locations_List_Button = Append_Button(Target, "AgeMin_Label", "inline");
    Locations_List_Button.innerHTML = "Locations List";
    Locations_List_Button.style.margin = "10px";
    Locations_List_Button.addEventListener("click", Show_All_Locations_Click);
    
}

//====================================================================================================

function Show_All_Locations_Click() {
    
    // LOCATIONS-LIST BUTTON //
    
    var Current_Location;
    var All_Locations = document.querySelectorAll("li.location");
    var i;
    
    Locations_List = [];
    Locations_List_Text = "";
    
    for (i = 0; i < All_Locations.length; i++) {
        
        // console.log("DEBUG: Show_Profile_Locations();");
        
        if (All_Locations[i].parentNode.childNodes.length < 7 ) {
            
            Current_Location = All_Locations[i].innerHTML;
            Locations_List[i] = Current_Location;
            Locations_List_Text += Current_Location + "\n";
            
            // DEBUG
            // console.log("Location = " + Location);
            
        }
    }
    
    
    // CHECK IF "LOCATIONS_LIST_WINDOW" IS ALREADY CREATED
    if (Locations_List_Window) {

        Locations_List_Window.style.display = "block";
        
    } else {
        
        // NEW CUSTOM WINDOW FOR LOCATIONS LIST
    
        // function Custom_Window(WINDOW_ID, TITLE, WIDTH, HEIGHT, POS_LEFT, POS_TOP) {
        Locations_List_Window = Custom_Window(Locations_List_Window_ID, "Locations", "512px", "720px", "250px", "50px");
        
        
        // SET "LOCATIONS_LIST_WINDOW" ON CENTER OF THE SCREEN
        
        Locations_List_Window.style.position = "fixed"; // Bad if the screen is too small
        Locations_List_Window.style.position = "absolute"; // Good if the screen is too small
        
        // HORIZONTAL POSITION (SIMPLE - NOT CENTERED) //
        // Locations_List_Window.style.left = "33%";
        
        
        // OPEN THE CUSTOM WINDOW IN THE CENTER //
        // IT WORKS ALSO WITH THE DRAGGING CODE //
        var Win_Width = parseInt(Locations_List_Window.style.width);
        var Calc_Center = (parseInt(window.innerWidth) / 2) - (Win_Width / 2);
        Locations_List_Window.style.left = Calc_Center + "px";
        
        
        // OLD CENTER CODES //
        
        // MANUAL CALCULATION //
        // BREAKS THE DRAGGING CODE... (marginLeft) //
        // Locations_List_Window.style.marginLeft = "-256px";
        
        
        // FULL AUTOMATIC //
        // BREAKS THE DRAGGING CODE... (marginLeft) //
        /*
        // ((WIDTH / 2) * -1) //
        var Calc_Width;
        Calc_Width = Locations_List_Window.style.width;
        Calc_Width = parseInt(Calc_Width) / 2 * -1;
        Locations_List_Window.style.marginLeft = calc_width + "px";
        */
        
    }
    
    // BUILD AND INSERT THE LOCATIONS IN LOCATIONS_LIST_WINDOW
    Fill_Locations_List_Window();
    
    // DEBUG
    // alert(Locations_List_Text);
    
}

//====================================================================================================

function Fill_Locations_List_Window() {
    
    // LOOP FOR BUILDING THE LOCATIONS LIST
    var i;
    var Current_Link;
    var Current_Location;
    var Link_Position_Top;
    
    // QUERY ALL LOCATIONS
    Locations_List_Link = document.querySelectorAll(".details .title a");
    
    if (Locations_List_Div) {
        Locations_List_Div.innerHTML = "";
    } else {
        Locations_List_Div = document.createElement( 'div' );
    }
    
    // LOOP: BUILD LOCATIONS LIST
    // console.log("DEBUG: Building the Locations List");
    for (i = 0; i < Locations_List.length; i++) {
        
        Current_Link = Locations_List_Link[i].outerHTML;
        Current_Location = Locations_List[i];
        
        Locations_List_Div.innerHTML += Current_Location + '  :  ';
        Locations_List_Div.innerHTML += Current_Link + '<br>\n';
        
        //console.log('Locations_List_Link[i].outerHTML = ' + Locations_List_Link[i].outerHTML);
    }
    
    // APPEND LOCATIONS_LIST_DIV
    Locations_List_Window.appendChild(Locations_List_Div);
    
    // CALCULATE THE HEIGHT OF "LOCATIONS_LIST_DIV"
    var tmp_height = Locations_List_Window.style.height;
    Locations_List_Div.style.position = "relative";
    Locations_List_Div.style.display = "block";
    Locations_List_Div.style.top = "10px";
    Locations_List_Div.style.height = (parseInt(tmp_height) - 50) + "px";
    Locations_List_Div.style.overflowY = "scroll";
    Locations_List_Div.style.margin = "5px";
    
}

//====================================================================================================

function Show_Profile_Locations() {
    
    // VARIABLES //
    var Target;
    var Location;
    var Div_Location;
    var Test;
    
    // LOCATION LOOP //
    var All_Locations = document.querySelectorAll("li.location");
    var i;
    
    if (!CSS_Mod) {
        Injection_CSS(".list li { max-height: 255px; } .details { min-height: 110px; }");
        CSS_Mod = 1;
    }
    
    for (i = 0; i < All_Locations.length; i++) {
        
        // console.log("DEBUG: Show_Profile_Locations();");
        
        if (All_Locations[i].parentNode.childNodes.length < 6 ) {
            
            Target = All_Locations[i].parentNode;         
            Location = All_Locations[i].innerHTML;
            Div_Location = document.createElement( 'div' );
            Div_Location.innerHTML = "Location: " + Location;
            Target.appendChild(Div_Location);
            
            // Div_Location.setAttribute("class") = "ShowLocation";  // BAD
            // Div_Location.style.margin = "10px";
            // Div_Location.style.display="inline";
            
        }
    }
}

//====================================================================================================

function Age_SetValue() {
    
    
    // AGE MIN //
    localStorage.setItem( 'CUB.AgeMin', AgeMin_Textbox.value );
    AgeMin = AgeMin_Textbox.value;
    
    // AGE MAX //
    localStorage.setItem( 'CUB.AgeMax', AgeMax_Textbox.value );
    AgeMax = AgeMax_Textbox.value;
    
    // HIDE YOUR MOM //
    Age_Filter();
    
    
    // Capturing the Enter Key (Not needed here, but it can be useful)
    // 
    // var key = e.which || e.keyCode;
    // 
    // 13 = Enter Key
    // if (key === 13) { ... }
    
}

//====================================================================================================

function Append_Age_Inputs() {
    
    // APPEND THE NEW CONTROLS INSIDE THIS NODE.
    var Target = document.querySelector(".sub-nav");
    
    // NEW LINE BREAKS //
    Append_BR(Target);
    Append_BR(Target);
    
    // CREATE & APPEND THE AGE-MIN LABEL
    AgeMin_Label = Append_Div(Target, "AgeMin_Label", "inline");
    AgeMin_Label.innerHTML = "Age Min: ";
    AgeMin_Label.style.margin = "10px";
    
    // CREATE & APPEND AGE-MIN TEXTBOX (INPUT)
    AgeMin_Textbox = Append_Textbox(Target, "AgeMin_Textbox", "inline");
    AgeMin_Textbox.setAttribute("type", "text"); 
    AgeMin_Textbox.maxLength = 2;
    AgeMin_Textbox.style.width = "30px";
    
    // CREATE & APPEND THE AGE-MAX LABEL
    AgeMax_Label = Append_Div(Target, "AgeMax_Textbox", "inline");
    AgeMax_Label.innerHTML = "Age Max: ";
    AgeMax_Label.style.margin = "10px";
    
    // CREATE & APPEND AGE-MAX TEXTBOX (INPUT)
    AgeMax_Textbox = Append_Textbox(Target, "AgeMax_Textbox", "inline");
    AgeMax_Textbox.setAttribute("type", "text"); 
    AgeMax_Textbox.maxLength = 2;
    AgeMax_Textbox.style.width = "30px";
    
    
    // TEMPORARY VARIABLES //
    var tmp_AgeMin;
    var tmp_AgeMax;
    
    // GET THE STORED AGE-MIN //
    tmp_AgeMin = localStorage.getItem('CUB.AgeMin');
    console.log("localStorage.getItem('CUB.AgeMin') = " + tmp_AgeMin);  // DEBUG
    
    if (tmp_AgeMin !== null) {
        AgeMin =  tmp_AgeMin;
    }

    // GET THE STORED AGE-MAX //
    tmp_AgeMax = localStorage.getItem('CUB.AgeMax');
    console.log("localStorage.getItem('CUB.AgeMax') = " + tmp_AgeMax);  // DEBUG
    
    if (tmp_AgeMax !== null) {
        AgeMax =  tmp_AgeMax;
    }

    // SET VALUE FOR AGE INPUTS //
    AgeMin_Textbox.value = AgeMin;
    AgeMax_Textbox.value = AgeMax;
    
    // INPUTS CHANGE EVENTS //
    AgeMin_Textbox.addEventListener("change", Age_SetValue);
    AgeMax_Textbox.addEventListener("change", Age_SetValue);
    
}

//====================================================================================================

function Age_Filter() {

    var span = document.querySelectorAll("SPAN");
    var age_class;
    var i;

    for (i = 0; i < span.length; i++) {
        
        age_class = span[i].getAttribute("class");
        if (
            age_class === "age genderc" || 
            age_class === "age genderf" || 
            age_class === "age genderm" || 
            age_class === "age genders"
        ) {

            age = span[i].innerHTML;
            
            Parent = span[i].parentNode.parentNode.parentNode;
            
            if (age < AgeMin || age > AgeMax) {
                Parent.style.display = "none";
            } else if (AlwaysHideMales === 1 && age_class === "age genderm") {
                Parent.style.display = "none";
            } else if (AlwaysHideTrans === 1 && age_class === "age genders") {
                Parent.style.display = "none";
            } else if (AlwaysHideGirls === 1 && age_class === "age genderf") {
                Parent.style.display = "none";
            } else if (AlwaysHideCouples === 1 && age_class === "age genderc") {
                Parent.style.display = "none";
            } else {
                Parent.style.display = "block";
            }

        }

    }

}

//====================================================================================================

function Clone_Pages_Numbers() {

    // Get the last <li> element ("Milk") of <ul> with id="myList2"
    var itm = document.querySelector("ul.paging");

    // Copy the <li> element and its child nodes
    var cln = itm.cloneNode(true);

    // Append the cloned <li> element to <ul> with id="myList1"
    document.querySelector("div.top-section").appendChild(cln);
    
}

//====================================================================================================





//====================================================================================================
// FUNCTIONS MODULES
//====================================================================================================


//====================================================================================================
// MODULE
// CODE INJECTIONS
//====================================================================================================

function Injection_CSS(STR_CSS, CSS_ID, WhereToInject) {
    
    // REFERENCE:
    // http://stackoverflow.com/questions/11833759/add-stylesheet-to-head-using-javascript-in-body


    // if (BOOL_BODY == true) {
    //     var Inject_Section = document.body;
    // } else {
    //     var Inject_Section = document.head;
    // }


    var Inject_Section;
        
    if (WhereToInject != null) {
        Inject_Section = WhereToInject;
    } else {
        Inject_Section = document.head;
    }
    
    var style_css = document.createElement('style');
    if (CSS_ID != '') { style_css.id = CSS_ID; }
    
    // style_css.href = '{url}';
    style_css.type = 'text/css';
    style_css.rel = 'stylesheet';
    style_css.innerHTML = STR_CSS;
    Inject_Section.appendChild(style_css);
    
    //document.head.appendChild(style_css);
}

//====================================================================================================


//====================================================================================================
// MODULE: HIDE_THIS_NODE
// REQUIREMENT: Injection_CSS
//====================================================================================================

function Hide_This_Node(Css_Element) {
    Injection_CSS(Css_Element + ' { display: none !important; }');
}

//====================================================================================================


//====================================================================================================
// MODULE: ADD CONTROLS
// BR, DIV, WINDOW, BUTTON, TEXTBOX
//====================================================================================================

function Append_BR(TARGET_NODE) {
    
    // createElement
    var NEW_BR = document.createElement( 'br' );
    
    // appendChild
    TARGET_NODE.appendChild(NEW_BR);
    
    // Return Created Node
    return NEW_BR;
}

//====================================================================================================

function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
    
    // createElement //
    var New_Div = document.createElement( 'div' );
    
    // APPEND PARAMETERS //
    if (NEW_DIV_ID)        { New_Div.id = NEW_DIV_ID; }
    if (NEW_DIV_DISPLAY)   { New_Div.style.display = NEW_DIV_DISPLAY; }
    
    // appendChild //
    TARGET_NODE.appendChild(New_Div);
    
    return New_Div;
    
}

//====================================================================================================
    
    function Custom_Window(WINDOW_ID, TITLE, WIDTH, HEIGHT, POS_LEFT, POS_TOP) {
    
    // RESET THE POSITION EVERYTIME YOU OPEN THE WINDOW
    var Reset_Position = 0;
    
    // NEW_WINDOW //
    var New_Window = document.getElementById(WINDOW_ID);
    
    if (New_Window) {
    
        // POSITION RESET //
        if (Reset_Position) {
            New_Window.style.left = POS_LEFT;
            New_Window.style.top = POS_TOP;
        }
        
        // UNHIDE //
        New_Window.style.display = "block";
        
        // New_Window.style.visibility = "visible";
        // return New_Window;
        
    } else {
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // NEW_WINDOW
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        New_Window = document.createElement( 'div' );
        New_Window.id = WINDOW_ID;
        
        // NEW_WINDOW STYLE
        New_Window.style.border = "1px solid";
        New_Window.style.position = "relative";
        New_Window.style.display = "none";
        // New_Window.style.visibility = "hidden"; // BAD
        
        // NEW_WINDOW SIZE
        New_Window.style.width = WIDTH;
        New_Window.style.height = HEIGHT;
        
        // NEW_WINDOW POSITION
        New_Window.style.left = POS_LEFT;
        New_Window.style.top = POS_TOP;
        
        // NEW_WINDOW BACKGROUND COLOR
        New_Window.style.backgroundColor = "white";
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // Div_Title_Bar
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        var Div_Title_Bar_ID = WINDOW_ID + "_Title";
        // function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
        var Div_Title_Bar = Append_Div(New_Window, Div_Title_Bar_ID, "block");
        
        Div_Title_Bar.style.position = "relative";
        Div_Title_Bar.style.top = "5px";
        Div_Title_Bar.style.height = "30px";
        Div_Title_Bar.style.marginLeft = "5px";
        Div_Title_Bar.style.marginRight = "5px";
        Div_Title_Bar.style.backgroundColor = "blue";
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // Div_Title
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        var Div_Title_ID = WINDOW_ID + "_Title";
        // function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
        var Div_Title = Append_Div(Div_Title_Bar, Div_Title_ID, "inline");
        
        Div_Title.innerHTML = TITLE;
        Div_Title.style.position = "relative";
        Div_Title.style.fontSize = "24px";
        Div_Title.style.top = "5px";
        Div_Title.style.marginLeft = "5px";
        Div_Title.style.color = "white";
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // Close_Button
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        var Close_Button;
        var Close_Button_ID = WINDOW_ID + "_Close_Button";
        Close_Button = Append_Button(Div_Title_Bar, Close_Button_ID, "inline");
        
        Close_Button.innerHTML = "X";
        
        Close_Button.style.position = "relative";
        Close_Button.style.marginRight = "5px";
        Close_Button.style.top = "5px";
        Close_Button.style.cssFloat = "right";
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // CloseButton Click Event
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        Close_Button.addEventListener("click", function() {
            New_Window.style.display = "none";
        });
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // Line Breaks
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        //Append_BR(New_Window);
        //Append_BR(New_Window);
        
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // APPEND NEW_WINDOW TO DOCUMENT
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        New_Window.style.display = "block";
        document.body.appendChild(New_Window);
        
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        // Drag_This
        // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
        
        Div_Title_Bar.style.cursor = "move";
        Drag_This(Div_Title_Bar, New_Window);
        
    }
    
    return New_Window;
    
}
    
//====================================================================================================

function Append_Button(TARGET_NODE, NEW_BUTTON_ID, NEW_BUTTON_DISPLAY, NEW_BUTTON_CAPTION) {
    
    // createElement //
    var NEW_BUTTON = document.createElement( 'BUTTON' );
    
    // PARAMETERS //
    if (NEW_BUTTON_ID)        { NEW_BUTTON.id = NEW_BUTTON_ID; }
    if (NEW_BUTTON_DISPLAY)   { NEW_BUTTON.style.display = NEW_BUTTON_DISPLAY; }
    
    // BUTTON CAPTION //
    if (NEW_BUTTON_CAPTION) {
        var tmp_caption = document.createTextNode(NEW_BUTTON_CAPTION);
        NEW_BUTTON.appendChild(tmp_caption);
        // var t = document.createTextNode("Click me");
        // x.appendChild(t);
    }
    
    // appendChild //
    TARGET_NODE.appendChild(NEW_BUTTON);
    
    return NEW_BUTTON;
    
}

//====================================================================================================


function Append_Textbox(TARGET_NODE, NEW_TEXTBOX_ID, NEW_TEXTBOX_DISPLAY) {
    
    // createElement //
    var NEW_TEXTBOX = document.createElement( 'input' );
    
    // PARAMETERS //
    if (NEW_TEXTBOX_ID)        { NEW_TEXTBOX.id = NEW_TEXTBOX_ID; }
    if (NEW_TEXTBOX_DISPLAY)   { NEW_TEXTBOX.style.display = NEW_TEXTBOX_DISPLAY; }
    
    // appendChild //
    TARGET_NODE.appendChild(NEW_TEXTBOX);
    
    // Return Created Node
    return NEW_TEXTBOX;
    
}

//====================================================================================================


//====================================================================================================
// MODULE: DRAGING OBJECTS
// REQUIREMENT: ?
// SOURCE: https://jsfiddle.net/tovic/Xcb8d/
//====================================================================================================

var selected = null, // Object of the element to be moved
    x_pos = 0, y_pos = 0, // Stores x & y coordinates of the mouse pointer
    x_elem = 0, y_elem = 0; // Stores top, left values (edge) of the element

// Will be called when user starts dragging an element
function _drag_init(elem) {
    // Store the object of the element which needs to be moved
    selected = elem;
    x_elem = x_pos - selected.offsetLeft;
    y_elem = y_pos - selected.offsetTop;
}

// Will be called when user dragging an element
function _move_elem(e) {
    x_pos = document.all ? window.event.clientX : e.pageX;
    y_pos = document.all ? window.event.clientY : e.pageY;
    if (selected !== null) {
        selected.style.left = (x_pos - x_elem) + 'px';
        selected.style.top = (y_pos - y_elem) + 'px';
    }
}

// Destroy the object when we are done
function _destroy() {
    selected = null;
}

// Bind the functions...

function Drag_This(GRAB_ELEMENT, MOVE_ELEMENT) {
    // OR...
    // document.querySelector(GRAB_ELEMENT).onmousedown = function () {
    GRAB_ELEMENT.onmousedown = function () {
        _drag_init(MOVE_ELEMENT);
        return false;
    };
}

// ORIGINAL CODE //
/*
// Bind the functions...
document.getElementById('draggable-element').onmousedown = function () {
    _drag_init(this);
    return false;
};
*/

document.onmousemove = _move_elem;
document.onmouseup = _destroy;

//====================================================================================================



})();

// THE END