yazdmich

Untitled

Jun 12th, 2015
324
0
Never
Not a member of Pastebin yet? Sign Up, it unlocks many cool features!
  1. // ==UserScript==
  2. // @match        http://www.okcupid.com/*
  3. // @require      http://code.jquery.com/jquery-1.10.2.js
  4. // @grant      GM_addStyle
  5. // ==/UserScript==
  6. GM_addStyle(".spinner{-webkit-animation:rotator 1.4s linear infinite;animation:rotator 1.4s linear infinite}@-webkit-keyframes rotator{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(270deg);transform:rotate(270deg)}}@keyframes rotator{0%{-webkit-transform:rotate(0deg);transform:rotate(0deg)}100%{-webkit-transform:rotate(270deg);transform:rotate(270deg)}}.path{stroke-dasharray:187;stroke-dashoffset:0;-webkit-transform-origin:center;-ms-transform-origin:center;transform-origin:center;-webkit-animation:dash 1.4s ease-in-out infinite,colors 5.6s ease-in-out infinite;animation:dash 1.4s ease-in-out infinite,colors 5.6s ease-in-out infinite}@-webkit-keyframes colors{0%{stroke:#4285F4}25%{stroke:#DE3E35}50%{stroke:#F7C223}75%{stroke:#1B9A59}100%{stroke:#4285F4}}@keyframes colors{0%{stroke:#4285F4}25%{stroke:#DE3E35}50%{stroke:#F7C223}75%{stroke:#1B9A59}100%{stroke:#4285F4}}@-webkit-keyframes dash{0%{stroke-dashoffset:187}50%{stroke-dashoffset:46.75;-webkit-transform:rotate(135deg);transform:rotate(135deg)}100%{stroke-dashoffset:187;-webkit-transform:rotate(450deg);transform:rotate(450deg)}}@keyframes dash{0%{stroke-dashoffset:187}50%{stroke-dashoffset:46.75;-webkit-transform:rotate(135deg);transform:rotate(135deg)}100%{stroke-dashoffset:187;-webkit-transform:rotate(450deg);transform:rotate(450deg)}}#sidebar{position:fixed;background:#f3f5f9;border-radius:3px;padding:8px 5px 5px;margin-left:10px;margin-right:10px;max-width:295px}.user{display:inline-block;padding:5px;margin-bottom:-5px;border-radius:3px}h1{font-size:larger}");
  7. var spinner = '<svg class=spinner width=65px height=65px viewBox="0 0 66 66" xmlns=http://www.w3.org/2000/svg><circle class=path fill=none stroke-width=6 stroke-linecap=round cx=33 cy=33 r=30></circle></svg>'
  8. $('#navigation').after($('<div id="sidebar">' + spinner + '</div>'));
  9. this.$ = this.jQuery = jQuery.noConflict(true);
  10. function httpGet(theUrl) {
  11.     console.trace();
  12.     var deferred = $.Deferred();
  13.     var xmlHttp = new XMLHttpRequest();
  14.     xmlHttp.open("GET", theUrl, true);
  15.     xmlHttp.addEventListener('load', function() {
  16.         if (xmlHttp.status === 200) {
  17.             deferred.resolve(xmlHttp.response);
  18.         } else {
  19.             deferred.reject("HTTP error: " + xmlHttp.status);
  20.         }
  21.     }, false);
  22.     xmlHttp.send(null);
  23.     return deferred.promise();
  24. }
  25. function insertMatches(url) {
  26.     url = url.split('?')[0] + '?okc_api=1';
  27.     console.log(url)
  28.     var promise = httpGet(url);
  29.     promise.done(function(data) {
  30.         var page = JSON.parse(data);
  31.         var match = page.matchpercentage;
  32.         var enemy = page.enemypercentage;
  33.         var match2 = Math.round(Math.sqrt(match * (100 - enemy)));
  34.         var title = '' + match + '% | ' + enemy + '% | ' + match2 + '%';
  35.         $('#matches').html(title);
  36.         console.log(title);
  37.     });
  38. }
  39. var promise = httpGet('http://www.okcupid.com/visited');
  40. promise.done(function(data) {
  41.     String.prototype.repeat = function(num) {
  42.         return new Array(num + 1).join(this);
  43.     };
  44.     var users = $(data).find('div.user_row_item');
  45.     var userrow = '<div class="row">' + '<div class="user"></div>'.repeat(3) + '</div>';
  46.     var userbox = '<div id="userbox"><hr><center><h1>Mouse over a user above</h1></center></div>'
  47.     $('#sidebar').html('<center><h1>Visited</h1></center>' + userrow.repeat(3) + userbox);
  48.     var grid = $('[class=user]');
  49.     $(users).each(function(index) {
  50.         $(grid[index]).html($(this).find('.username').html().slice(0, -5 - $(this).find('.username > a').html().length) + '<img src=' + $(this).find('.user_image > img').prop('src') + ' width="85" height="85">');
  51.         console.log($(this).find('.name').prop('href'));
  52.         $(grid[index])[0].name = $(this).find('.name').prop('href').slice(31, -11);
  53.         $(grid[index])[0].on('mouseenter', function() {
  54.             $('#userbox > center > h1').html($(this).find('a').html() + '<br>' + this.name + '<br> <div id="matches"><br></div>');
  55.             insertMatches($(this).find('a')[0].href);
  56.         });
  57.     });
  58. });
Advertisement
Add Comment
Please, Sign In to add comment