Αυτός ο κώδικας δεν πρέπει να εγκατασταθεί άμεσα. Είναι μια βιβλιοθήκη για άλλους κώδικες που περιλαμβάνεται μέσω της οδηγίας meta // @require https://update.greasyfork.org/scripts/8972/136093/primewire%20fix.js
- // ==UserScript==
- // @name primewire fix
- // @namespace primewire fix
- // @description this is an include script meant for internal testing
- // @author drhouse
- // @include https://www.primewire.ag/*
- // @version 1.0.2
- // @run-at document-end
- // ==/UserScript==
-
- (function ($) {
-
-
- var lobject = $('.logged_username a').get()
- if (!lobject) {
- $('.warning_message').append($('<div>').css({
- color: 'red'
- }).setText("You must be logged in for this userscript to work").get())
- return
- }
- var queryString = (function (s) {
- var q = s.split('?')[1]
- var qs = {}
- if (q) {
- q.split('&').forEach(function (o) {
- var t = o.split('=');
- qs[unescape(t[0])] = unescape(t[1])
- })
- }
- return qs
- })(document.URL)
- var groups = __getValue('groups');
-
- // $('.header_search').swap($('.nav_tabs'))
- var uname = lobject.innerHTML;
- var DEBUG = false;
- var __groups = ['fav','towatch','watched'];
- if (!('watched' in groups) ) {
- set_up();
- }
- function set_up() {
-
- $('<div>').attr('id','blanket').css({
- 'position':'absolute',
- 'backgroundColor':'#666',
- 'opacity':'0.5',
- 'left':'0px',
- 'top':'0px',
- 'width':'100%',
- 'height':'100%'
- }).appendTo(document.body)
- $('<div>').attr('id','fs_info_box').css({
- 'backgroundColor':'white',
- 'width':'600px',
- 'border':'1px solid black',
- 'borderRadius': '20px',
- 'margin':'auto',
- 'height':'400px',
- 'position':'absolute',
- 'top':'25%',
- 'left':'25%',
- 'padding':'5px',
- 'fontSize':'14px'
- }).setText('1channel.ch Fix needs to set up. We need to get the list of Watched To Watch and Favorite groups so when browsing you can see which are in what group.')
- .append($('<ul>').css({'padding':'50px'})
- .append($('<li>').attr('id','fav').setText('Favorites').append($('<b>')).append($('<progress>')))
- .append($('<li>').attr('id','watched').setText('Watched').append($('<b>')).append($('<progress>')))
- .append($('<li>').attr('id','towatch').setText('To Watch').append($('<b>')).append($('<progress>')))
- )
- .appendTo(document.body)
- $('#fs_info_box ul li').css({'opacity':'1'})
- $('#fs_info_box progress').attr('value','0').attr('max','100').css({'display':'block'});
- var _groups = ['fav','watched','towatch'];
- $(document.body).css({
- 'overflowY':'hidden'
- })
- get_page();
- function get_page(page,n) {
- var page = page||_groups.shift()
- if (page) {
- groups[page] = groups[page]||[]
- var n = n||1
- var o = $('#'+page)
- _get('/profile.php?user='+uname+'&'+page+'=&page='+n,function(r) {
- var s = r.responseText;
- var tot = s.match(/\(( [1-9]\d* )\)<\/strong>/i) && RegExp.$1;
-
- if (tot) {
- var l_page = s.match(/&page=(\d+)"> >>/) && RegExp.$1
-
- var done = !l_page
- o.children('b',1).clear().setText(tot + " total items page: "+n+'/'+(l_page||n));
- var reg = /class="index_item"> <a href="\/(?:tv|watch)-(\d+)/g,t
- while ((t = reg.exec(s)) !== null) {
- // console.log("Group: '%s' Item: '%s'",page,t[1])
- groups[page].push(t[1]);
- }
- o.children('progress',1).attr('max',l_page||n).attr('value',n)
-
- if (done) {
- get_page()
- }
- else {
- get_page(page,++n)
- }
- }
- else {
- console.log(s)
- o.children('b',1).clear().setText(' No Items');
- o.children('progress',1).attr('value',100);
- get_page()
- }
- });
- }
- else {
- $('#fs_info_box').append($('<h1>').setText('DONE'));
- __setValue('groups',groups);
- setTimeout(function() {
- $('#fs_info_box,#blanket').fadeOut(1,function() {
- this.remove()
- $(document.body).css({'overflow-y':'auto'});
- });
- },1000)
- }
- }
-
- }
-
- GM_addStyle('x-btn-icon { \
- width: 11px;\
- height: 13px;\
- }\
- .x-btn:active,.options_menu + .x-btn { \
- border-color: #999 !important;\
- background: #DDD !important;\
- background-image: -moz-linear-gradient(top,#cccccc,#ffffff) !important;\
- background-image: -webkit-gradient(linear,left top,left bottom,from(#cccccc),to(#ffffff)) !important;\
- filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#cccccc,endColorStr=#ffffff) !important;\
- opacity:1 !important\
- }\
- .x-btn:hover { \
- border-color: #999;\
- background: #F3F3F3;\
- background-image: -moz-linear-gradient(top,#ffffff,#ebebeb);\
- background-image: -webkit-gradient(linear,left top,left bottom,from(#ffffff),to(#ebebeb));\
- filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#ffffff,endColorStr=#ebebeb);\
- outline: 0;\
- -moz-box-shadow: 0 0 3px #999;\
- -webkit-box-shadow: 0 0 3px #999;\
- box-shadow: 0 0 3px #999;\
- }\
- .x-btn,.options_menu {\
- padding: 0 .5em;\
- height: 2.0833em;\
- border: 1px solid #CCC;\
- color: black;\
- background: #F6F6F6;\
- background-image: -moz-linear-gradient(top,#ffffff,#efefef);\
- background-image: -webkit-gradient(linear,left top,left bottom,from(#ffffff),to(#efefef));\
- filter: progid:DXImageTransform.Microsoft.Gradient(startColorStr=#ffffff,endColorStr=#efefef);\
- -moz-border-radius: 3px;\
- -webkit-border-radius: 3px;\
- border-radius: 3px;\
- white-space: nowrap;\
- vertical-align: middle;\
- cursor: pointer;\
- overflow: visible;\
- opacity:0;\
- }\
- .episode_prev_next button {\
- padding:0 .5em;\
- -moz-border-radius: 3px;\
- -webkit-border-radius: 3px;\
- border-radius: 3px;\
- }\
- .index_item:hover .x-btn,.featured_movie_item:hover .x-btn,.item_similar:hover .x-btn {\
- opacity:1 !important;\
- }\
- .index_item {\
- max-height:305px;\
- min-height:305px;\
- }\
- .index_item img { \
- display:block !important;\
- width:150px;\
- min-height:222px\
- }\
- .index_container { \
- \
- }\
- .options_menu { \
- position: absolute;\
- height: auto !important;\
- width: auto !important;\
- opacity:1 !important;\
- top: 2.2em;\
- list-style:none;\
- width:100px;\
- }\
- \
- .options_menu li:not(.label) { \
- font-size: 12px;\
- padding-left:5px;\
- \
- }\
- .options_menu li:not(.label):hover {\
- background-color: #EFFFEF;\
- color:black;\
- }\
- .options_menu li {\
- min-width:100px;\
- }\
- .options_menu li.label { \
- font-size: 12px;\
- color: white;\
- padding:0px;\
- background-color: #3c3c3c;\
- height:10px\
- line-height:20px;\
- font-weight:bold;\
- border:1px solid black;\
- }\
- .loader {\
- opacity: .5;\
- position:absolute;\
- top:0;\
- left:5;\
- background-color:#EFEFEF;\
- }\
- .hide {\
- display:none !important;\
- }\
- .comments_box_vote { position: relative; }\
- #autoc {\
- position:absolute;\
- padding:3px;\
- border:2px solid black;\
- padding:5px;\
- background-color: #fff; \
- border: 2px solid #666;\
- border-top:none;\
- -webkit-border-radius: 0px 30px 30px; \
- -moz-border-radius: 0px 30px 30px; \
- border-radius: 0px 30px 30px; \
- -webkit-box-shadow: 2px 15px 15px #888; \
- -moz-box-shadow: 2px 15px 15px #888; \
- box-shadow: 2px 15px 15px #888;\
- width: 320px;\
- z-index:200;\
- display:none;\
- }\
- #autoc li {\
- \
- list-style: none;\
- background-color: white;\
- border: 1px solid #EEE;\
- color: black;\
- padding:2px;\
- }\
- #autoc li:first-child {\
- border-top-right-radius: 30px;\
- }\
- \
- #search_term:focus ~ ul {\
- display: block !important;\
- }\
- #autoc:hover {\
- display: block !important;\
- }\
- #autoc li:last-child {\
- border-bottom-right-radius: 30px;\
- border-bottom-left-radius: 30px;\
- }\
- #autoc li:hover,#autoc li.current {\
- background-color:#E8F0F4;\
- }\
- ');
- var waiting_image = "%3D%3D"
- var host = window.location.host;
-
- var show_menu = false
-
- function kill_menu(n) {
-
- setTimeout(function () {
- if (show_menu) return show_menu = false
- $('.options_menu').remove()
- }, 10);
- }
- $('body').listen('click', kill_menu);
-
- $('.search_container').css({
- 'position': 'relative'
- }).append($('<ul>').listen('click', function (e) {
- $(e.currentTarget).clear()
- }).attr('id', 'autoc'));
- $('#search_term').listen(['keyup', 'focus'], function (e) {
- if ([40, 38].indexOf(e.keyCode) > -1) return
- clearTimeout(_alist_t);
- if (this.value.trim().length > 2) _alist_t = setTimeout(Alist, 50);
- if (this.value.trim() === "") $('#autoc').clear();
-
- }).listen('keydown', function (e) {
- switch (e.keyCode) {
- case 40:
- $('#autoc li.current').removeClass('current').nextSibling(1).addClass('current')
- $('#search_term').get().value = $($('#autoc li.current').get() || $('#autoc li:first-child').get()).addClass('current').get().textContent
- break;
- case 38:
- $('#autoc li.current').removeClass('current').previousSibling(1).addClass('current')
- $('#search_term').get().value = $($('#autoc li.current,#autoc li:last-child').get()).addClass('current').get().textContent
- break;
- }
- }).listen('click', function () {
-
- }).listen('keydown', function (e) {
- clearTimeout(_alist_t);
- });
- var _alist, _alist_t, _alist_o = {};
-
- function Alist() {
- try {
- _alist.abort()
- }
- catch (err) {}
- var value = $('#search_term').addClass('ac_loading').get().value.trim();
- if (_alist_o[value.toLowerCase()]) return Ac(_alist_o[value.toLowerCase()]);
- $('#search_term').addClass('ac_loading')
- _alist = new XMLHttpRequest();
- _alist.open('GET', '/_get_active_movies.php?all&limit=10&q=' + encodeURIComponent(value), true);
- _alist.onreadystatechange = function (e) {
- if (_alist.readyState === 4) {
- if (_alist.status === 200) {
- $('#search_term').removeClass('ac_loading')
- Ac((_alist_o[value.toLowerCase()] = _alist.responseText.trim().split(/\n/)))
- }
- }
- }
- _alist.send()
- }
-
- function Ac(l) {
- var ac = $('#autoc').clear()
- l.forEach(function (o) {
- ac.append($('<li>').setText(o).listen('click', function (e) {
- e.preventDefault()
- $('#search_term').get().value = this.textContent;
- }))
- });
- }
- function XmlhttpRequest(obj) {
- if (obj.url.indexOf("http://") === 0 && obj.url.indexOf('http://'+host) === -1) {
- GM_xmlhttpRequest(obj)
- }
- else {
- var xhr = new XMLHttpRequest();
- xhr.open(obj.method, obj.url, true);
- xhr.onreadystatechange = function (e) {
- if (xhr.readyState === 4) {
- obj.onload(xhr)
- }
- }
- xhr.send(obj.data||null)
- }
-
- }
- function _get(url, cb, postData, headers) {
- XmlhttpRequest({
- method: postData ? 'POST' : 'GET',
- url: url,
- data: postData,
- headers: headers || null,
- onload: function (r) {
- cb(r);
- }
- });
- }
-
- function do_watched(what, action, id, page) {
-
- var url = "/addto" + (page || "watched") + ".php?whattodo=" + what + "&action=" + action + "&id=" + id;
- do_action.call(this, url)
-
- }
-
- function do_action(url, cb) {
-
- if (!$(this).children('.loader').length) {
- $(this).append($('<div>').attr('class', 'loader hide').append($('<img>').attr('src', waiting_image).get()).get())
- }
- $($(this).children('.loader')[0]).show()
- _get(url, function (r) {
- var ok = get_ok(r.responseText);
- if (ok) {
- var m = url.split('?')
- var t = m[0].match(/addto(.*?)s?\.php/i) && RegExp.$1,q={}
- m[1].split("&").forEach(function(i) {
- var v = i.split('=');
- q[v[0]] = v[1];
- })
- var g = q['action'] || t;
- console.log(url,g,q);
- if (q['whattodo'] == 'delete') {
- groups[g].splice(groups[g].indexOf(q['id']),1);
-
- }
- else if(q['whattodo'] == 'add') {
- if (g === 'watched' && (m = groups['towatch'].indexOf(q['id'])) > -1) {
- groups['towatch'].splice(m,1);
- }
- groups[g].indexOf(groups[g]) === -1 && groups[g].push(q['id'])
- }
- __setValue('groups',groups);
- }
- $($(this).children('.loader')[0]).hide()
- $(this).append($('<div>').css({
- 'backgroundColor': ok?'#EFFFEF':'red',
- "width": "100%",
- "position": "absolute",
- "top": "40%",
- "left": "0px"
- }).setText(ok || "An Error Occurred").get())
- if (cb) cb(ok)
- }.bind(this), null, {
- "Referer": document.URL
- });
- }
-
- function _menu(obj) {
- $('.options_menu').remove()
- var ul = $('<ul>').attr('class', 'options_menu')
- for (var i in obj) {
- if (/^wait/.test(i)) {
- var li = $('<li>').attr('class', 'wait').setText(i)
- ul.append(li)
- obj[i].call(null, li)
- }
- else {
- ul.append($('<li>').setText(i).attr('class', obj[i] ? '' : 'label').listen('click', typeof obj[i] == 'function' && obj[i]).get())
- }
-
- }
- return ul;
- }
-
- function build_menu(id) {
- // .bind(a)
- // look for playlists
- return _menu({
- "add To:": null,
- "To Watch": function () {
- do_watched.call(this, 'add', 'towatch', id)
- }.bind(this),
- "Watched": function () {
- do_watched.call(this, 'add', 'watched', id)
- }.bind(this),
- "Favorite": function () {
- do_watched.call(this, 'add', '', id, 'favs')
- }.bind(this),
- "wait1": function (xli) {
- if ('tv' in queryString || queryString['search_section'] == "2") {
- xli.addClass('label').clear().setText('Go To:')
- xli.insertAfter($('<li>').setText('Last Episode').listen('click', function (e) {
- show_menu = true
- $(e.target).clear().setText("Getting Last Page")
- _get("/watch-" + id, function (r) {
- var s = r.responseText,
- t = /href="(.*?)"/g
- if ((lI = s.lastIndexOf('tv_episode_item"> <a href="')) > -1) {
- t.lastIndex = lI
- var m = t.exec(s)
-
- window.location.assign("http://" + host + m[1])
- }
- else alert('No Episodes Found') && kill_menu()
- }.bind(this))
- }.bind(this)).get())
-
-
- }
- else {
- xli.remove()
- }
- }.bind(this),
- "Playlists": null,
- "wait2": function (xli) {
- xli.clear()
- xli.setText("waiting for playlists")
- var ul = xli.get().parentNode;
- var li = xli.get()
- _get('/playlists/' + uname, function (r) {
- var t = r.responseText;
- var reg = /"\/playlists\.php\?id=(\d+?)">([^<]+)<\/a>/g,
- m
- var has = false;
- while ((m = reg.exec(t)) !== null) {
- has = true
- var pid = m[1];
- var pname = m[2];
- ul.insertBefore($('<li>').setText(pname).listen('click', function () {
-
- do_action.call(ul.parentNode, 'http://' + host + '/playlists.php?user=' + uname + '&edit=' + pid + '&plistitemid=' + id + '&whattodo=add_existing')
-
- }).get(), li)
- }
- if (!has) {
- ul.insertBefore($('<li>').setText('No Playlists').get(), li)
- }
- xli.clear()
- });
- /*
- _get('http://' + host + '/playlists.php?create', function (r) {
- var s = r.responseText;
- var n = s.match(/<input name="play_title".*?value"(.*?)"/)
- xli.clear().setText((n && n[1]) || "Create New Playlist").listen('click', function (e) {
- if (n) {
- do_action.call(ul.parentNode, 'http://www.1channel.ch/playlists.php?plistitemid=' + id + '&whattodo=add')
- } else {
- show_menu = true
- e.stopPropagation()
- $(this).clear().append($('<input>').attr('placeholder', 'Type PlaylistName').listen('keypress', function (e) {
- if (e.keyCode == 13) {
- //do_action.call(ul.parentNode, 'http://' + host + '/playlists.php?user=' + uname + '&edit=' + pid + '&plistitemid=' + id + '&whattodo=add_existing')
- _get('http://' + host + '/playlists.php?create', function (r) {
- if (r.responseText.match(/<input name="play_title".*?value"(.*?)"/)) {
- $(this).clear().setText(RegExp.$1);
- do_action.call(ul.parentNode, 'http://www.1channel.ch/playlists.php?plistitemid=' + id + '&whattodo=add', function () {
- show_menu = false
- kill_menu();
- })
- } else {
- alert('no');
- }
- }.bind(this), "play_title=" + encodeURIComponent(this.value) + "&type=1&play_submit=Search");
- }
- }))
-
- }
- })
- });
- */
- }.bind(this)
-
-
- });
- }
-
-
- function __getValue(key) {
- var s = GM_getValue(key);
- return (s && JSON.parse(s)) || {}
- }
-
- function __setValue(key, value) {
- setTimeout(function() {
- GM_setValue(key, JSON.stringify(value));
- },0);
- }
-
- function get_ok(txt) {
- return txt.match(/<div class='ok_message'>(.*?)<\/div>/i) && RegExp.$1
-
- }
- __groups.forEach(function(o) { if (o === 'fav') return
- var lists = groups[o].map(function(oo) {
- return 'a[href*="-'+oo+'-"] img';
- });
- var rib = (o === 'towatch' && 'to_watch') || o
- $(lists.join(',')).i(function(o) {
- var tt = $(o)
- var im = tt.attr('src')
- if (im.indexOf('/images/ribbon') === -1) {
- tt.attr('height',tt.get().offsetHeight);
- tt.attr('src','/images/ribbon_'+rib+'.png').css({'background':'url('+im+')'})
- }
- });
- });
-
- $('a[href*="commentvote="]').listen('click', function (e) {
- e.preventDefault();
- do_action.call(this.parentNode.parentNode, this.href);
-
-
- });
- $('.favs_deleted a').listen('click', function (e) {
- e.preventDefault()
- do_action.call($(this).parent(1).parent(), this.href, function (ok, txt) {
- if (ok) {
- var t = $(this).parent(1).parent(1)
- var opts = {
- prop: 'opacity',
- from: 1,
- to: 0,
- time: .1,
- delta: function (p) {
- return 1 - Math.sin(Math.acos(p))
- }
- }
- t.animate(opts).__registerListener('animationEnd', function () {
- this.remove()
- })
- }
- else {
- alert("Could Not Complete Action");
- }
- }.bind(this))
-
-
- });
- $('.index_item,.featured_movie_item,.item_similar a').i(function (o) {
-
- $(o).css({
- 'position': 'relative'
- }).append($('<button>').attr('class', 'x-btn').setText("+").css({
- "position": "absolute",
- "left": "0px",
- "top": "0px",
- "textSize": "2em"
- }).listen('click', function (e) {
- show_menu = true
- if (this.parentNode.tagName.toLowerCase() == 'a') {
- e.preventDefault()
- }
-
- var id = (this.parentNode.href || this.parentNode.querySelector('a').href).match(/(?:tv|watch)-(\d+)/)[1];
- this.parentNode.insertBefore(build_menu.call(o, id).get(), this)
-
- }).get());
-
- });
- $('.index_item + .clearer').remove();
- $('.pagination').css({
- 'clear': 'both'
- })
-
- if (document.URL.match(/\/tv-(\d+).*?\/season-(\d+)-episode-(\d+)/i)) {
-
- var id = RegExp.$1,
- s = [Number(RegExp.$2), Number(RegExp.$3)].join("x");
- var tv = __getValue('watched');
- $('.episode_prev_next').append($('<button>').setText('Watched').listen('click', function () {
- var tv = __getValue('watched');
- if (!tv[id]) {
- tv[id] = {}
- }
-
- tv[id][s] = !tv[id][s];
- __setValue('watched', tv);
- this.style.backgroundColor = (tv[id] && tv[id][s]) ? "#EFFFEF" : "#FFF"
- }).css({
- backgroundColor: (tv[id] && tv[id][s]) ? "#EFFFEF" : "#FFF"
- }).get())
-
-
- }
- else if ($('.movie_navigation a').get() && $('.movie_navigation a').get().href.match(/\/tv-(\d+)/i)) {
- var id = RegExp.$1
- var tv = __getValue("watched");
-
- $('a[href*="/season-"]').i(function (o) {
- if (o.href.match(/\/tv-.*?\/season-(\d+)-episode-(\d+)/i)) {
- var s = [Number(RegExp.$1), Number(RegExp.$2)].join("x")
- if (tv[id][s]) {
- o.parentNode.style.backgroundColor = "#EFFFEF !important"
- }
- }
- });
- }
-
- })((function () {
- var __matches = (function () {
- var dE = document.documentElement
- return dE && dE.nodeType && (dE.matchesSelector || dE.webkitMatchesSelector || (dE.mozMatchesSelector &&
- function (sel) {
- return this.mozMatchesSelector(sel)
- }))
- })();
- var fs = function (m, el) { return new fs.fn(m,el) }
- fs.fn = function(m,el) {
- m = m || '';
- this.obj = []
- if (typeof (m) == 'object' && m.nodeType) {
- this.obj.push(m)
- }
- else if (m.match(/^<([^>]+)>$/)) {
- this.obj.push(document.createElement(RegExp.$1))
- }
- else {
- this.obj = Array.prototype.slice.call(m == '' ? [] : (el || document).querySelectorAll(m) || [], 0)
- }
- return this
- }
- fs.Extend = function (o) {
- for (var i in o) {
- fs.fn.prototype[i] = o[i];
- }
- }
- fs.isArray = function (o) {
- return typeof o === 'object' && o instanceof Array
- }
- fs.animate = function (opts) {
-
- var start = new Date
- var id = setInterval(function () {
- var timePassed = new Date - start
- var progress = timePassed / opts.duration
-
- if (progress > 1) progress = 1
-
- var delta = opts.delta(progress)
- opts.step(delta)
-
- if (progress == 1) {
- clearInterval(id)
- if (opts.onEnd) {
- opts.onEnd()
- }
- }
- }, opts.delay || 10)
-
- }
- fs.Animate = {
- linear: function (p) {
- return p
- },
- circ: function (progress) {
- return 1 - Math.sin(Math.acos(progress))
- }
- }
- fs.isObject = function (o) {
- return typeof o.__isFSObject === 'function' && o.__isFSObject();
- }
- fs.fn.prototype = {
- toString: function() {
- return this.obj.toString()
- },
- matches: function (sel) {
- if (__matches) return __matches.apply(this.get(), [sel])
- },
- __isFSObject: function () {
- return this instanceof fs.fn
- },
- append: function (e) {
- e = fs.isObject(e) ? e.get() : e;
- this.get().appendChild(e);
- return this
- },
- insertBefore: function (e) {
- this.parent().insertBefore(fs.isObject(e) ? e.get() : e, this.get());
- },
- insertAfter: function (e) {
- this.parent().insertBefore(fs.isObject(e) ? e.get() : e, this.get().nextSibling)
- },
- loaded: function (cb) {
- this.listen('DOMContentLoaded', cb);
- },
- clear: function () {
- this.i(function (o) {
- while (o.firstChild) {
- o.removeChild(o.firstChild)
- }
- });
- return this
- },
- get: function () {
- return this.obj[0];
- },
- appendTo: function (e) {
- if (typeof e === 'string') {
- e = $(e).get()
- }
- else if (fs.isObject(e)) {
- e = e.get()
- }
- e.appendChild(this.get());
-
- },
-
- children: function (sel,n) {
- var sel = sel || '*',
- cn = this.get().childNodes,
- length = cn.length,
- m = []
- for (var i = 0; i < length; i++) {
- if (cn[i].nodeType === 1 && fs(cn[i]).matches(sel)) m.push(cn[i])
- }
- if (n) { var x = fs('');x.obj = m;return x }
- return m;
- },
- listen: function (e, cb, cBool) {
- if (!fs.isArray(e)) {
- e = [e]
- }
- this.i(function (o) {
- e.forEach(function (ee) {
- o.addEventListener(ee, function (e) {
- cb.call(e.target || e.srcElement, e)
- }, cBool || false)
- })
- });
- return this
- },
- i: function (cb) {
- for (var i = 0; i < this.obj.length; i++) {
- cb(this.obj[i]);
- }
- return this;
- },
- nextSibling: function (f) {
- var ns = this.get();
- while (ns && (ns = ns.nextSibling) && ns.nodeType != 1) {}
- return f ? fs(ns) : ns
- },
- previousSibling: function (f) {
- var ps = this.get();
- while (ps && (ps = ps.previousSibling) && ps.nodeType != 1) {}
- return f ? fs(ps) : ps
- },
- parent: function (n) {
- var p = this.get().parentNode
- return n ? fs(p) : p
- },
- parents: function (until) {
- var m = fs('');
- m.obj = []
- var o = this.get();
- var p
- while ((o = o.parentNode) && ((until && !fs(o).matches(until)) || !until)) m.obj.push(o);
-
- return m;
- },
- attr: function (a, s) {
- if (s == null) {
- return this.get().getAttribute(a)
- }
- else {
- this.i(function (o) {
- o.setAttribute(a, s)
- });
- }
- return this;
- },
- setText: function (t) {
- this.i(function (o) {
- o.appendChild(document.createTextNode(t));
- });
- return this
- },
- toggle: function (cn, bool) {
- this.i(function (o) {
- if (typeof (bool) === "boolean") {
- if (bool) o.classList.add(cn)
- else {
- o.classList.remove(cn)
- }
- }
- else {
- o.classList.toggle(cn || "hide")
- }
- });
- return this
- },
- addClass: function (cn) {
- this.i(function (o) {
- o.classList.add(cn)
- });
- return this
- },
- removeClass: function (cn) {
- this.i(function (o) {
- o.classList.remove(cn)
- });
- return this
- },
- __listener: {},
- __registerListener: function (evt, cb) {
- this.__listener[evt] = this.__listener[evt] || [];
- this.__listener[evt].push(cb);
- },
- __fireListener: function (evt, cb) {
- if (this.__listener[evt]) {
- this.__listener[evt].forEach(function (o) {
- o.call(this)
- }, this);
- }
- },
- animate: function (aopts) {
- var a = aopts.to - aopts.from;
-
- fs.animate({
- delay: 10,
- duration: (aopts.duration || 1) * 1000,
- // 1 sec by default
- delta: aopts.delta || fs.Animate.linear,
- step: function (delta) {
- var p = aopts.from + (a * delta) + (aopts.unit || '');
- var o = new Object();
- o[aopts.prop] = p;
- this.css(o)
- }.bind(this),
- onEnd: function () {
- this.__fireListener('animationEnd');
- }.bind(this)
- });
- return this
- },
- fadeOut: function (time, cb) {
- if (cb) {
- this.__registerListener('animationEnd', cb)
- }
- this.animate({
- prop: 'opacity',
- duration: time,
- from: 1,
- to: 0
- });
- },
- remove: function () {
- this.i(function (o) {
- o.parentNode.removeChild(o);
- });
- },
- hide: function () {
- this.addClass('hide');
- },
- show: function () {
- this.removeClass('hide');
- },
- is: function (sel) {
- this.obj = this.obj.filter(function (o) {
- return fs(o).matches(sel);
- });
- return this
- },
- computed: function (attr) {
- return document.defaultView.getComputedStyle(this.get(), null).getPropertyValue(attr);
- },
- __getWH: function (s) {
- var c = parseFloat(this.computed('width'));
- var opts = ['margin-left', 'margin-right', 'border-left-width', 'border-right-width'];
- for (var i = 0, length = opts.length; i < length; ++i) {
- c -= parseFloat(this.computed(opts[i]));
- }
- return c;
- },
- width: function (n) {
- if (n != null) {
- this.css({
- width: parseFloat(n) + "px !important"
- });
- }
- else {
- return this.__getWH('w');
- }
- },
- swap: function (el) {
- var o = (el instanceof HTMLElement ? $(el) : el)
- var c = o.clone()
- var p = this.clone();
- o.replace(p);
- this.replace(c)
- return this
-
- },
- replace: function (el) {
- var o = (fs.isObject(el) ? el.get() : el)
- this.parent().replaceChild(o, this.get())
- },
- clone: function () {
- return this.get() && this.get().cloneNode(true)
- },
- css: function (s) {
- this.i(function (o) {
- for (var i in s) {
- try {
- o.style[i] = s[i]
- }
- catch (err) {}
- }
- });
- return this
- },
- count: function () {
- return this.obj.length;
- }
- }
- return fs
- })());