Chaturbate Age-Filter & Locations

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

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

You will need to install an extension such as Tampermonkey, Greasemonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Violentmonkey to install this script.

You will need to install an extension such as Tampermonkey or Userscripts to install this script.

You will need to install an extension such as Tampermonkey to install this script.

You will need to install a user script manager extension to install this script.

(I already have a user script manager, let me install it!)

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install an extension such as Stylus to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

You will need to install a user style manager extension to install this style.

(I already have a user style manager, let me install it!)

// ==UserScript==
// @name            Chaturbate Age-Filter & Locations
// @version         1.01
// @namespace       [email protected]
// @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(\/)?$/;
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