- // ==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
-
-