Sleazy Fork is available in English.

Chaturbate Age-Filter & Locations

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

Od 10.01.2017.. Pogledajte najnovija verzija.

  1. // ==UserScript==
  2. // @name Chaturbate Age-Filter & Locations
  3. // @version 1.03
  4. // @namespace Frank_Einstein@greasyfork.org
  5. // @description Age filter, Locations under each thumbnail, Locations list with links, and more!
  6. // @include /^https?:\/\/(\w+\.)?chaturbate\.com(\/.*)?/
  7. // @run-at document-end
  8. // @grant none
  9. // @icon 
  10. // ==/UserScript==
  11.  
  12.  
  13. console.log("Loading: " + GM_info.script.name + " " + GM_info.script.version);
  14.  
  15.  
  16. // MAIN SCRIPT FUNCTION
  17.  
  18. (function() {
  19.  
  20. // CURRENT URL //
  21. var _URL = location.href;
  22.  
  23. //====================================================================================================
  24.  
  25. // OPTIONS VARIABLES
  26. var AgeMin = 18;
  27. var AgeMax = 99;
  28. var AlwaysHideMales = 0;
  29. var AlwaysHideTrans = 0;
  30. var AlwaysHideGirls = 0;
  31. var AlwaysHideCouples = 0;
  32. var Filter_Interval = 2000;
  33. var Remove_Ads = 1;
  34.  
  35. //====================================================================================================
  36.  
  37. // GLOBAL VARIABLES
  38.  
  39. // AGE FILTER
  40. var AgeMin_Label;
  41. var AgeMin_Textbox;
  42. var AgeMax_Label;
  43. var AgeMax_Textbox;
  44.  
  45. // LOCATIONS
  46. var Locations_List;
  47. var CSS_Mod;
  48.  
  49. // LOCATION WINDOW
  50. var Locations_List_Text;
  51. var Locations_List_Link;
  52. var Locations_List_Window;
  53. var Locations_List_Window_ID;
  54. var Locations_List_Button;
  55. var Locations_List_Div;
  56.  
  57. // ID OF THE LOCATION WINDOW //
  58. Locations_List_Window_ID = "Locations_List_Window";
  59.  
  60. //====================================================================================================
  61.  
  62. // MAIN SCRIPT CODE
  63.  
  64. // Show_Profile_Locations();
  65.  
  66. var Pattern_Main = /^https?:\/\/(\w+\.)?chaturbate\.com(\/|\/\?page)?$/;
  67. var Pattern_Followed = /^https?:\/\/(\w+\.)?chaturbate\.com\/followed\-cams(\/.*)?$/;
  68. var Pattern_Exhibition = /^https?:\/\/(\w+\.)?chaturbate\.com\/exhibitionist\-cams(\/.*)?$/;
  69. var Pattern_Female = /^https?:\/\/(\w+\.)?chaturbate\.com\/female\-cams(\/.*)?$/;
  70. var Pattern_Male = /^https?:\/\/(\w+\.)?chaturbate\.com\/male\-cams(\/.*)?$/;
  71. var Pattern_Couple = /^https?:\/\/(\w+\.)?chaturbate\.com\/couple\-cams(\/.*)?$/;
  72. var Pattern_Trans = /^https?:\/\/(\w+\.)?chaturbate\.com\/trans\-cams(\/.*)?$/;
  73. var Pattern_Spy = /^https?:\/\/(\w+\.)?chaturbate\.com\/spy\-on\-cams(\/.*)?$/;
  74.  
  75. // Not seems to be needed here...
  76. // Patern = Pattern.source.replace(/\^http/g,'http').replace(/:/g,'%3A').replace(/\\\//g,'%2F').replace(/\//g,'%2F');
  77.  
  78. if ( Pattern_Main.test(_URL) ||
  79. Pattern_Exhibition.test(_URL) ||
  80. Pattern_Female.test(_URL) ||
  81. Pattern_Male.test(_URL) ||
  82. Pattern_Couple.test(_URL) ||
  83. Pattern_Trans.test(_URL) ||
  84. Pattern_Spy.test(_URL) ) {
  85. // MAIN PAGES //
  86. console.log("[" + GM_info.script.name + " " + GM_info.script.version + "] " + "MAIN PAGE");
  87. // REMOVE ADS //
  88. if (Remove_Ads) { Hide_Ads(); }
  89. Append_Age_Inputs();
  90. Age_Filter();
  91. Clone_Pages_Numbers();
  92. Show_All_Locations();
  93. var Filter_Loop = setInterval(function() {
  94. Show_Profile_Locations();
  95. Age_Filter();
  96. }, Filter_Interval);
  97.  
  98. } else {
  99. // WEBCAM PAGES //
  100. // REMOVE ADS //
  101. if (Remove_Ads) { Hide_Ads(); }
  102. }
  103.  
  104. //====================================================================================================
  105. // FUNCTIONS
  106. //====================================================================================================
  107.  
  108. function Hide_Ads() {
  109. Hide_This_Node(".ad");
  110. Hide_This_Node(".remove_ads");
  111. }
  112.  
  113. //====================================================================================================
  114.  
  115. function Show_All_Locations() {
  116. // LOCATIONS-LIST BUTTON //
  117. // Append the new controls inside this node.
  118. var Target = document.querySelector(".sub-nav");
  119. // NEW LINE BREAK
  120. Append_BR(Target);
  121. // Create & Append AgeMin DIV
  122. // function Append_Button(TARGET_NODE, NEW_TEXTBOX_ID, NEW_BUTTON_DISPLAY, NEW_TEXTBOX_CAPTION)
  123. Locations_List_Button = Append_Button(Target, "AgeMin_Label", "inline");
  124. Locations_List_Button.innerHTML = "Locations List";
  125. Locations_List_Button.style.margin = "10px";
  126. Locations_List_Button.addEventListener("click", Show_All_Locations_Click);
  127. }
  128.  
  129. //====================================================================================================
  130.  
  131. function Show_All_Locations_Click() {
  132. // LOCATIONS-LIST BUTTON //
  133. var Current_Location;
  134. var All_Locations = document.querySelectorAll("li.location");
  135. var i;
  136. Locations_List = [];
  137. Locations_List_Text = "";
  138. for (i = 0; i < All_Locations.length; i++) {
  139. // console.log("DEBUG: Show_Profile_Locations();");
  140. if (All_Locations[i].parentNode.childNodes.length < 7 ) {
  141. Current_Location = All_Locations[i].innerHTML;
  142. Locations_List[i] = Current_Location;
  143. Locations_List_Text += Current_Location + "\n";
  144. // DEBUG
  145. // console.log("Location = " + Location);
  146. }
  147. }
  148. // CHECK IF "LOCATIONS_LIST_WINDOW" IS ALREADY CREATED
  149. if (Locations_List_Window) {
  150.  
  151. Locations_List_Window.style.display = "block";
  152. } else {
  153. // NEW CUSTOM WINDOW FOR LOCATIONS LIST
  154. // function Custom_Window(WINDOW_ID, TITLE, WIDTH, HEIGHT, POS_LEFT, POS_TOP) {
  155. Locations_List_Window = Custom_Window(Locations_List_Window_ID, "Locations", "512px", "720px", "250px", "50px");
  156. // SET "LOCATIONS_LIST_WINDOW" ON CENTER OF THE SCREEN
  157. Locations_List_Window.style.position = "fixed"; // Bad if the screen is too small
  158. Locations_List_Window.style.position = "absolute"; // Good if the screen is too small
  159. // HORIZONTAL POSITION (SIMPLE - NOT CENTERED) //
  160. // Locations_List_Window.style.left = "33%";
  161. // OPEN THE CUSTOM WINDOW IN THE CENTER //
  162. // IT WORKS ALSO WITH THE DRAGGING CODE //
  163. var Win_Width = parseInt(Locations_List_Window.style.width);
  164. var Calc_Center = (parseInt(window.innerWidth) / 2) - (Win_Width / 2);
  165. Locations_List_Window.style.left = Calc_Center + "px";
  166. // OLD CENTER CODES //
  167. // MANUAL CALCULATION //
  168. // BREAKS THE DRAGGING CODE... (marginLeft) //
  169. // Locations_List_Window.style.marginLeft = "-256px";
  170. // FULL AUTOMATIC //
  171. // BREAKS THE DRAGGING CODE... (marginLeft) //
  172. /*
  173. // ((WIDTH / 2) * -1) //
  174. var Calc_Width;
  175. Calc_Width = Locations_List_Window.style.width;
  176. Calc_Width = parseInt(Calc_Width) / 2 * -1;
  177. Locations_List_Window.style.marginLeft = calc_width + "px";
  178. */
  179. }
  180. // BUILD AND INSERT THE LOCATIONS IN LOCATIONS_LIST_WINDOW
  181. Fill_Locations_List_Window();
  182. // DEBUG
  183. // alert(Locations_List_Text);
  184. }
  185.  
  186. //====================================================================================================
  187.  
  188. function Fill_Locations_List_Window() {
  189. // LOOP FOR BUILDING THE LOCATIONS LIST
  190. var i;
  191. var Current_Link;
  192. var Current_Location;
  193. var Link_Position_Top;
  194. // QUERY ALL LOCATIONS
  195. Locations_List_Link = document.querySelectorAll(".details .title a");
  196. if (Locations_List_Div) {
  197. Locations_List_Div.innerHTML = "";
  198. } else {
  199. Locations_List_Div = document.createElement( 'div' );
  200. }
  201. // LOOP: BUILD LOCATIONS LIST
  202. // console.log("DEBUG: Building the Locations List");
  203. for (i = 0; i < Locations_List.length; i++) {
  204. Current_Link = Locations_List_Link[i].outerHTML;
  205. Current_Location = Locations_List[i];
  206. Locations_List_Div.innerHTML += Current_Location + ' : ';
  207. Locations_List_Div.innerHTML += Current_Link + '<br>\n';
  208. //console.log('Locations_List_Link[i].outerHTML = ' + Locations_List_Link[i].outerHTML);
  209. }
  210. // APPEND LOCATIONS_LIST_DIV
  211. Locations_List_Window.appendChild(Locations_List_Div);
  212. // CALCULATE THE HEIGHT OF "LOCATIONS_LIST_DIV"
  213. var tmp_height = Locations_List_Window.style.height;
  214. Locations_List_Div.style.position = "relative";
  215. Locations_List_Div.style.display = "block";
  216. Locations_List_Div.style.top = "10px";
  217. Locations_List_Div.style.height = (parseInt(tmp_height) - 50) + "px";
  218. Locations_List_Div.style.overflowY = "scroll";
  219. Locations_List_Div.style.margin = "5px";
  220. }
  221.  
  222. //====================================================================================================
  223.  
  224. function Show_Profile_Locations() {
  225. // VARIABLES //
  226. var Target;
  227. var Location;
  228. var Div_Location;
  229. var Test;
  230. // LOCATION LOOP //
  231. var All_Locations = document.querySelectorAll("li.location");
  232. var i;
  233. if (!CSS_Mod) {
  234. Injection_CSS(".list li { max-height: 255px; } .details { min-height: 110px; }");
  235. CSS_Mod = 1;
  236. }
  237. for (i = 0; i < All_Locations.length; i++) {
  238. // console.log("DEBUG: Show_Profile_Locations();");
  239. if (All_Locations[i].parentNode.childNodes.length < 6 ) {
  240. Target = All_Locations[i].parentNode;
  241. Location = All_Locations[i].innerHTML;
  242. Div_Location = document.createElement( 'div' );
  243. Div_Location.innerHTML = "Location: " + Location;
  244. Target.appendChild(Div_Location);
  245. // Div_Location.setAttribute("class") = "ShowLocation"; // BAD
  246. // Div_Location.style.margin = "10px";
  247. // Div_Location.style.display="inline";
  248. }
  249. }
  250. }
  251.  
  252. //====================================================================================================
  253.  
  254. function Age_SetValue() {
  255. // AGE MIN //
  256. localStorage.setItem( 'CUB.AgeMin', AgeMin_Textbox.value );
  257. AgeMin = AgeMin_Textbox.value;
  258. // AGE MAX //
  259. localStorage.setItem( 'CUB.AgeMax', AgeMax_Textbox.value );
  260. AgeMax = AgeMax_Textbox.value;
  261. // HIDE YOUR MOM //
  262. Age_Filter();
  263. // Capturing the Enter Key (Not needed here, but it can be useful)
  264. //
  265. // var key = e.which || e.keyCode;
  266. //
  267. // 13 = Enter Key
  268. // if (key === 13) { ... }
  269. }
  270.  
  271. //====================================================================================================
  272.  
  273. function Append_Age_Inputs() {
  274. // APPEND THE NEW CONTROLS INSIDE THIS NODE.
  275. var Target = document.querySelector(".sub-nav");
  276. // NEW LINE BREAKS //
  277. Append_BR(Target);
  278. Append_BR(Target);
  279. // CREATE & APPEND THE AGE-MIN LABEL
  280. AgeMin_Label = Append_Div(Target, "AgeMin_Label", "inline");
  281. AgeMin_Label.innerHTML = "Age Min: ";
  282. AgeMin_Label.style.margin = "10px";
  283. // CREATE & APPEND AGE-MIN TEXTBOX (INPUT)
  284. AgeMin_Textbox = Append_Textbox(Target, "AgeMin_Textbox", "inline");
  285. AgeMin_Textbox.setAttribute("type", "text");
  286. AgeMin_Textbox.maxLength = 2;
  287. AgeMin_Textbox.style.width = "30px";
  288. // CREATE & APPEND THE AGE-MAX LABEL
  289. AgeMax_Label = Append_Div(Target, "AgeMax_Textbox", "inline");
  290. AgeMax_Label.innerHTML = "Age Max: ";
  291. AgeMax_Label.style.margin = "10px";
  292. // CREATE & APPEND AGE-MAX TEXTBOX (INPUT)
  293. AgeMax_Textbox = Append_Textbox(Target, "AgeMax_Textbox", "inline");
  294. AgeMax_Textbox.setAttribute("type", "text");
  295. AgeMax_Textbox.maxLength = 2;
  296. AgeMax_Textbox.style.width = "30px";
  297. // TEMPORARY VARIABLES //
  298. var tmp_AgeMin;
  299. var tmp_AgeMax;
  300. // GET THE STORED AGE-MIN //
  301. tmp_AgeMin = localStorage.getItem('CUB.AgeMin');
  302. console.log("localStorage.getItem('CUB.AgeMin') = " + tmp_AgeMin); // DEBUG
  303. if (tmp_AgeMin !== null) {
  304. AgeMin = tmp_AgeMin;
  305. }
  306.  
  307. // GET THE STORED AGE-MAX //
  308. tmp_AgeMax = localStorage.getItem('CUB.AgeMax');
  309. console.log("localStorage.getItem('CUB.AgeMax') = " + tmp_AgeMax); // DEBUG
  310. if (tmp_AgeMax !== null) {
  311. AgeMax = tmp_AgeMax;
  312. }
  313.  
  314. // SET VALUE FOR AGE INPUTS //
  315. AgeMin_Textbox.value = AgeMin;
  316. AgeMax_Textbox.value = AgeMax;
  317. // INPUTS CHANGE EVENTS //
  318. AgeMin_Textbox.addEventListener("change", Age_SetValue);
  319. AgeMax_Textbox.addEventListener("change", Age_SetValue);
  320. }
  321.  
  322. //====================================================================================================
  323.  
  324. function Age_Filter() {
  325.  
  326. var span = document.querySelectorAll("SPAN");
  327. var age_class;
  328. var i;
  329.  
  330. for (i = 0; i < span.length; i++) {
  331. age_class = span[i].getAttribute("class");
  332. if (
  333. age_class === "age genderc" ||
  334. age_class === "age genderf" ||
  335. age_class === "age genderm" ||
  336. age_class === "age genders"
  337. ) {
  338.  
  339. age = span[i].innerHTML;
  340. Parent = span[i].parentNode.parentNode.parentNode;
  341. if (age < AgeMin || age > AgeMax) {
  342. Parent.style.display = "none";
  343. } else if (AlwaysHideMales === 1 && age_class === "age genderm") {
  344. Parent.style.display = "none";
  345. } else if (AlwaysHideTrans === 1 && age_class === "age genders") {
  346. Parent.style.display = "none";
  347. } else if (AlwaysHideGirls === 1 && age_class === "age genderf") {
  348. Parent.style.display = "none";
  349. } else if (AlwaysHideCouples === 1 && age_class === "age genderc") {
  350. Parent.style.display = "none";
  351. } else {
  352. Parent.style.display = "block";
  353. }
  354.  
  355. }
  356.  
  357. }
  358.  
  359. }
  360.  
  361. //====================================================================================================
  362.  
  363. function Clone_Pages_Numbers() {
  364.  
  365. // Get the last <li> element ("Milk") of <ul> with id="myList2"
  366. var itm = document.querySelector("ul.paging");
  367.  
  368. // Copy the <li> element and its child nodes
  369. var cln = itm.cloneNode(true);
  370.  
  371. // Append the cloned <li> element to <ul> with id="myList1"
  372. document.querySelector("div.top-section").appendChild(cln);
  373. }
  374.  
  375. //====================================================================================================
  376.  
  377.  
  378.  
  379.  
  380.  
  381. //====================================================================================================
  382. // FUNCTIONS MODULES
  383. //====================================================================================================
  384.  
  385.  
  386. //====================================================================================================
  387. // MODULE
  388. // CODE INJECTIONS
  389. //====================================================================================================
  390.  
  391. function Injection_CSS(STR_CSS, CSS_ID, WhereToInject) {
  392. // REFERENCE:
  393. // http://stackoverflow.com/questions/11833759/add-stylesheet-to-head-using-javascript-in-body
  394.  
  395.  
  396. // if (BOOL_BODY == true) {
  397. // var Inject_Section = document.body;
  398. // } else {
  399. // var Inject_Section = document.head;
  400. // }
  401.  
  402.  
  403. var Inject_Section;
  404. if (WhereToInject != null) {
  405. Inject_Section = WhereToInject;
  406. } else {
  407. Inject_Section = document.head;
  408. }
  409. var style_css = document.createElement('style');
  410. if (CSS_ID != '') { style_css.id = CSS_ID; }
  411. // style_css.href = '{url}';
  412. style_css.type = 'text/css';
  413. style_css.rel = 'stylesheet';
  414. style_css.innerHTML = STR_CSS;
  415. Inject_Section.appendChild(style_css);
  416. //document.head.appendChild(style_css);
  417. }
  418.  
  419. //====================================================================================================
  420.  
  421.  
  422. //====================================================================================================
  423. // MODULE: HIDE_THIS_NODE
  424. // REQUIREMENT: Injection_CSS
  425. //====================================================================================================
  426.  
  427. function Hide_This_Node(Css_Element) {
  428. Injection_CSS(Css_Element + ' { display: none !important; }');
  429. }
  430.  
  431. //====================================================================================================
  432.  
  433.  
  434. //====================================================================================================
  435. // MODULE: ADD CONTROLS
  436. // BR, DIV, WINDOW, BUTTON, TEXTBOX
  437. //====================================================================================================
  438.  
  439. function Append_BR(TARGET_NODE) {
  440. // createElement
  441. var NEW_BR = document.createElement( 'br' );
  442. // appendChild
  443. TARGET_NODE.appendChild(NEW_BR);
  444. // Return Created Node
  445. return NEW_BR;
  446. }
  447.  
  448. //====================================================================================================
  449.  
  450. function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
  451. // createElement //
  452. var New_Div = document.createElement( 'div' );
  453. // APPEND PARAMETERS //
  454. if (NEW_DIV_ID) { New_Div.id = NEW_DIV_ID; }
  455. if (NEW_DIV_DISPLAY) { New_Div.style.display = NEW_DIV_DISPLAY; }
  456. // appendChild //
  457. TARGET_NODE.appendChild(New_Div);
  458. return New_Div;
  459. }
  460.  
  461. //====================================================================================================
  462. function Custom_Window(WINDOW_ID, TITLE, WIDTH, HEIGHT, POS_LEFT, POS_TOP) {
  463. // RESET THE POSITION EVERYTIME YOU OPEN THE WINDOW
  464. var Reset_Position = 0;
  465. // NEW_WINDOW //
  466. var New_Window = document.getElementById(WINDOW_ID);
  467. if (New_Window) {
  468. // POSITION RESET //
  469. if (Reset_Position) {
  470. New_Window.style.left = POS_LEFT;
  471. New_Window.style.top = POS_TOP;
  472. }
  473. // UNHIDE //
  474. New_Window.style.display = "block";
  475. // New_Window.style.visibility = "visible";
  476. // return New_Window;
  477. } else {
  478. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  479. // NEW_WINDOW
  480. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  481. New_Window = document.createElement( 'div' );
  482. New_Window.id = WINDOW_ID;
  483. // NEW_WINDOW STYLE
  484. New_Window.style.border = "1px solid";
  485. New_Window.style.position = "relative";
  486. New_Window.style.display = "none";
  487. // New_Window.style.visibility = "hidden"; // BAD
  488. // NEW_WINDOW SIZE
  489. New_Window.style.width = WIDTH;
  490. New_Window.style.height = HEIGHT;
  491. // NEW_WINDOW POSITION
  492. New_Window.style.left = POS_LEFT;
  493. New_Window.style.top = POS_TOP;
  494. // NEW_WINDOW BACKGROUND COLOR
  495. New_Window.style.backgroundColor = "white";
  496. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  497. // Div_Title_Bar
  498. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  499. var Div_Title_Bar_ID = WINDOW_ID + "_Title";
  500. // function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
  501. var Div_Title_Bar = Append_Div(New_Window, Div_Title_Bar_ID, "block");
  502. Div_Title_Bar.style.position = "relative";
  503. Div_Title_Bar.style.top = "5px";
  504. Div_Title_Bar.style.height = "30px";
  505. Div_Title_Bar.style.marginLeft = "5px";
  506. Div_Title_Bar.style.marginRight = "5px";
  507. Div_Title_Bar.style.backgroundColor = "blue";
  508. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  509. // Div_Title
  510. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  511. var Div_Title_ID = WINDOW_ID + "_Title";
  512. // function Append_Div(TARGET_NODE, NEW_DIV_ID, NEW_DIV_DISPLAY) {
  513. var Div_Title = Append_Div(Div_Title_Bar, Div_Title_ID, "inline");
  514. Div_Title.innerHTML = TITLE;
  515. Div_Title.style.position = "relative";
  516. Div_Title.style.fontSize = "24px";
  517. Div_Title.style.top = "5px";
  518. Div_Title.style.marginLeft = "5px";
  519. Div_Title.style.color = "white";
  520. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  521. // Close_Button
  522. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  523. var Close_Button;
  524. var Close_Button_ID = WINDOW_ID + "_Close_Button";
  525. Close_Button = Append_Button(Div_Title_Bar, Close_Button_ID, "inline");
  526. Close_Button.innerHTML = "X";
  527. Close_Button.style.position = "relative";
  528. Close_Button.style.marginRight = "5px";
  529. Close_Button.style.top = "5px";
  530. Close_Button.style.cssFloat = "right";
  531. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  532. // CloseButton Click Event
  533. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  534. Close_Button.addEventListener("click", function() {
  535. New_Window.style.display = "none";
  536. });
  537. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  538. // Line Breaks
  539. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  540. //Append_BR(New_Window);
  541. //Append_BR(New_Window);
  542. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  543. // APPEND NEW_WINDOW TO DOCUMENT
  544. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  545. New_Window.style.display = "block";
  546. document.body.appendChild(New_Window);
  547. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  548. // Drag_This
  549. // - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - //
  550. Div_Title_Bar.style.cursor = "move";
  551. Drag_This(Div_Title_Bar, New_Window);
  552. }
  553. return New_Window;
  554. }
  555. //====================================================================================================
  556.  
  557. function Append_Button(TARGET_NODE, NEW_BUTTON_ID, NEW_BUTTON_DISPLAY, NEW_BUTTON_CAPTION) {
  558. // createElement //
  559. var NEW_BUTTON = document.createElement( 'BUTTON' );
  560. // PARAMETERS //
  561. if (NEW_BUTTON_ID) { NEW_BUTTON.id = NEW_BUTTON_ID; }
  562. if (NEW_BUTTON_DISPLAY) { NEW_BUTTON.style.display = NEW_BUTTON_DISPLAY; }
  563. // BUTTON CAPTION //
  564. if (NEW_BUTTON_CAPTION) {
  565. var tmp_caption = document.createTextNode(NEW_BUTTON_CAPTION);
  566. NEW_BUTTON.appendChild(tmp_caption);
  567. // var t = document.createTextNode("Click me");
  568. // x.appendChild(t);
  569. }
  570. // appendChild //
  571. TARGET_NODE.appendChild(NEW_BUTTON);
  572. return NEW_BUTTON;
  573. }
  574.  
  575. //====================================================================================================
  576.  
  577.  
  578. function Append_Textbox(TARGET_NODE, NEW_TEXTBOX_ID, NEW_TEXTBOX_DISPLAY) {
  579. // createElement //
  580. var NEW_TEXTBOX = document.createElement( 'input' );
  581. // PARAMETERS //
  582. if (NEW_TEXTBOX_ID) { NEW_TEXTBOX.id = NEW_TEXTBOX_ID; }
  583. if (NEW_TEXTBOX_DISPLAY) { NEW_TEXTBOX.style.display = NEW_TEXTBOX_DISPLAY; }
  584. // appendChild //
  585. TARGET_NODE.appendChild(NEW_TEXTBOX);
  586. // Return Created Node
  587. return NEW_TEXTBOX;
  588. }
  589.  
  590. //====================================================================================================
  591.  
  592.  
  593. //====================================================================================================
  594. // MODULE: DRAGING OBJECTS
  595. // REQUIREMENT: ?
  596. // SOURCE: https://jsfiddle.net/tovic/Xcb8d/
  597. //====================================================================================================
  598.  
  599. var selected = null, // Object of the element to be moved
  600. x_pos = 0, y_pos = 0, // Stores x & y coordinates of the mouse pointer
  601. x_elem = 0, y_elem = 0; // Stores top, left values (edge) of the element
  602.  
  603. // Will be called when user starts dragging an element
  604. function _drag_init(elem) {
  605. // Store the object of the element which needs to be moved
  606. selected = elem;
  607. x_elem = x_pos - selected.offsetLeft;
  608. y_elem = y_pos - selected.offsetTop;
  609. }
  610.  
  611. // Will be called when user dragging an element
  612. function _move_elem(e) {
  613. x_pos = document.all ? window.event.clientX : e.pageX;
  614. y_pos = document.all ? window.event.clientY : e.pageY;
  615. if (selected !== null) {
  616. selected.style.left = (x_pos - x_elem) + 'px';
  617. selected.style.top = (y_pos - y_elem) + 'px';
  618. }
  619. }
  620.  
  621. // Destroy the object when we are done
  622. function _destroy() {
  623. selected = null;
  624. }
  625.  
  626. // Bind the functions...
  627.  
  628. function Drag_This(GRAB_ELEMENT, MOVE_ELEMENT) {
  629. // OR...
  630. // document.querySelector(GRAB_ELEMENT).onmousedown = function () {
  631. GRAB_ELEMENT.onmousedown = function () {
  632. _drag_init(MOVE_ELEMENT);
  633. return false;
  634. };
  635. }
  636.  
  637. // ORIGINAL CODE //
  638. /*
  639. // Bind the functions...
  640. document.getElementById('draggable-element').onmousedown = function () {
  641. _drag_init(this);
  642. return false;
  643. };
  644. */
  645.  
  646. document.onmousemove = _move_elem;
  647. document.onmouseup = _destroy;
  648.  
  649. //====================================================================================================
  650.  
  651.  
  652.  
  653. })();
  654.  
  655. // THE END
  656.  
  657.