From e97c990f000d8c8f5120eeb13a20bdf0d90be0ce Mon Sep 17 00:00:00 2001 From: sjengfred Date: Sun, 23 Jun 2013 22:19:16 +0200 Subject: [PATCH 1/8] added nzbget support --- data/interfaces/brink/config.html | 42 ++++++++++++++- data/interfaces/classic/config.html | 28 +++++++++- data/interfaces/default/config.html | 25 ++++++++- data/interfaces/remix/config.html | 28 +++++++++- headphones/__init__.py | 19 ++++++- headphones/nzbget.py | 84 +++++++++++++++++++++++++++++ headphones/searcher.py | 15 ++++-- headphones/webserve.py | 10 +++- 8 files changed, 240 insertions(+), 11 deletions(-) create mode 100644 headphones/nzbget.py diff --git a/data/interfaces/brink/config.html b/data/interfaces/brink/config.html index 7ce73c8e..5e7aa91a 100644 --- a/data/interfaces/brink/config.html +++ b/data/interfaces/brink/config.html @@ -187,7 +187,7 @@

uDownload Settings

- Setup SABnzbd or BitTorrent + Setup SABnzbd, NZBGET or BitTorrent
@@ -230,7 +230,7 @@ -
Full path to the directory where SAB downloads your music. +
Full path to the directory where SAB or NZBget downloads your music. @@ -238,6 +238,44 @@
+ +
+ + + + + + + + + + + + + + + + + + + + + +
+

NZBget

+ +
+
Usually http://localhost:9092 +
+
Type the user name for NZBget +
+
Enter the password for NZBget +
+ Write the category label name from NZBget +
+
+ +
diff --git a/data/interfaces/classic/config.html b/data/interfaces/classic/config.html index 88f6554e..0af437c5 100644 --- a/data/interfaces/classic/config.html +++ b/data/interfaces/classic/config.html @@ -116,10 +116,36 @@ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + diff --git a/data/interfaces/classic/config.html b/data/interfaces/classic/config.html index 0af437c5..eb024f5c 100644 --- a/data/interfaces/classic/config.html +++ b/data/interfaces/classic/config.html @@ -130,7 +130,7 @@ ]", "i"), - // checked="checked" or checked - rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, - rscriptType = /\/(java|ecma)script/i, - rcleanScript = /^\s*", "" ], - legend: [ 1, "
", "
" ], - thead: [ 1, "

Music Download Directory:


- Full path to the directory where SAB downloads your music
+ Full path to the directory where SAB or NZBget downloads your music
e.g. /Users/name/Downloads/music
+

NZBget:

+
+

NZBget Host:


+ + usually http://localhost:9092 +
+

NZBget Username:

+
+

NZBget Password:

+
+

NZBget Category:

+
diff --git a/data/interfaces/default/config.html b/data/interfaces/default/config.html index 5fc7b026..7d219c5e 100644 --- a/data/interfaces/default/config.html +++ b/data/interfaces/default/config.html @@ -134,10 +134,33 @@
- Full path where SAB downloads your music. e.g. /Users/name/Downloads/music + Full path where SAB or NZBget downloads your music. e.g. /Users/name/Downloads/music
+
+ NZBget +
+ + + usually http://localhost:9092 +
+
+ + +
+
+ + +
+
+ + +
+
+
diff --git a/data/interfaces/remix/config.html b/data/interfaces/remix/config.html index 88f6554e..d03a6a5e 100644 --- a/data/interfaces/remix/config.html +++ b/data/interfaces/remix/config.html @@ -116,10 +116,36 @@

Music Download Directory:


- Full path to the directory where SAB downloads your music
+ Full path to the directory where SAB or NZBget downloads your music
e.g. /Users/name/Downloads/music
+

NZBget:

+
+

NZBget Host:


+ + usually http://localhost:9092 +
+

NZBget Username:

+
+

NZBget Password:

+
+

NZBget Category:

+
diff --git a/headphones/__init__.py b/headphones/__init__.py index 6d555f48..d14e0232 100644 --- a/headphones/__init__.py +++ b/headphones/__init__.py @@ -128,6 +128,11 @@ SAB_PASSWORD = None SAB_APIKEY = None SAB_CATEGORY = None +NZBGET_USERNAME = None +NZBGET_PASSWORD = None +NZBGET_CATEGORY = None +NZBGET_HOST = None + NZBMATRIX = False NZBMATRIX_USERNAME = None NZBMATRIX_APIKEY = None @@ -285,7 +290,7 @@ def initialize(): TORRENTBLACKHOLE_DIR, NUMBEROFSEEDERS, ISOHUNT, KAT, MININOVA, WAFFLES, WAFFLES_UID, WAFFLES_PASSKEY, \ RUTRACKER, RUTRACKER_USER, RUTRACKER_PASSWORD, WHATCD, WHATCD_USERNAME, WHATCD_PASSWORD, DOWNLOAD_TORRENT_DIR, \ LIBRARYSCAN, LIBRARYSCAN_INTERVAL, DOWNLOAD_SCAN_INTERVAL, SAB_HOST, SAB_USERNAME, SAB_PASSWORD, SAB_APIKEY, SAB_CATEGORY, \ - NZBMATRIX, NZBMATRIX_USERNAME, NZBMATRIX_APIKEY, NEWZNAB, NEWZNAB_HOST, NEWZNAB_APIKEY, NEWZNAB_ENABLED, EXTRA_NEWZNABS, \ + NZBGET_USERNAME, NZBGET_PASSWORD, NZBGET_CATEGORY, NZBGET_HOST, NZBMATRIX, NZBMATRIX_USERNAME, NZBMATRIX_APIKEY, NEWZNAB, NEWZNAB_HOST, NEWZNAB_APIKEY, NEWZNAB_ENABLED, EXTRA_NEWZNABS, \ NZBSORG, NZBSORG_UID, NZBSORG_HASH, NEWZBIN, NEWZBIN_UID, NEWZBIN_PASSWORD, NZBSRUS, NZBSRUS_UID, NZBSRUS_APIKEY, NZBX, \ PREFERRED_WORDS, REQUIRED_WORDS, IGNORED_WORDS, \ LASTFM_USERNAME, INTERFACE, FOLDER_PERMISSIONS, ENCODERFOLDER, ENCODER_PATH, ENCODER, XLDPROFILE, BITRATE, SAMPLINGFREQUENCY, \ @@ -302,6 +307,7 @@ def initialize(): # Make sure all the config sections exist CheckSection('General') CheckSection('SABnzbd') + CheckSection('NZBget') CheckSection('NZBMatrix') CheckSection('Newznab') CheckSection('NZBsorg') @@ -407,6 +413,11 @@ def initialize(): SAB_APIKEY = check_setting_str(CFG, 'SABnzbd', 'sab_apikey', '') SAB_CATEGORY = check_setting_str(CFG, 'SABnzbd', 'sab_category', '') + NZBGET_USERNAME = check_setting_str(CFG, 'NZBget', 'nzbget_username', '') + NZBGET_PASSWORD = check_setting_str(CFG, 'NZBget', 'nzbget_password', '') + NZBGET_CATEGORY = check_setting_str(CFG, 'NZBget', 'nzbget_category', '') + NZBGET_HOST = check_setting_str(CFG, 'NZBget', 'nzbget_host', '') + NZBMATRIX = bool(check_setting_int(CFG, 'NZBMatrix', 'nzbmatrix', 0)) NZBMATRIX_USERNAME = check_setting_str(CFG, 'NZBMatrix', 'nzbmatrix_username', '') NZBMATRIX_APIKEY = check_setting_str(CFG, 'NZBMatrix', 'nzbmatrix_apikey', '') @@ -742,6 +753,12 @@ def config_write(): new_config['SABnzbd']['sab_password'] = SAB_PASSWORD new_config['SABnzbd']['sab_apikey'] = SAB_APIKEY new_config['SABnzbd']['sab_category'] = SAB_CATEGORY + + new_config['NZBget'] = {} + new_config['NZBget']['nzbget_username'] = NZBGET_USERNAME + new_config['NZBget']['nzbget_password'] = NZBGET_PASSWORD + new_config['NZBget']['nzbget_category'] = NZBGET_CATEGORY + new_config['NZBget']['nzbget_host'] = NZBGET_HOST new_config['NZBMatrix'] = {} new_config['NZBMatrix']['nzbmatrix'] = int(NZBMATRIX) diff --git a/headphones/nzbget.py b/headphones/nzbget.py new file mode 100644 index 00000000..cd0c3315 --- /dev/null +++ b/headphones/nzbget.py @@ -0,0 +1,84 @@ +# This file is part of Headphones. +# +# Headphones is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Headphones is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Headphones. If not, see . + +##################################### +## Stolen from Sick-Beard's nzbget.py ## +##################################### + + + +import httplib +import datetime + +import headphones + +from base64 import standard_b64encode +import xmlrpclib + +#from headphones.providers.generic import GenericProvider + +from headphones import logger + +def sendNZB(nzb): + + addToTop = False + nzbgetXMLrpc = "http://%(username)s:%(password)s@%(host)s/xmlrpc" + + if headphones.NZBGET_HOST == None: + logger.error(u"No NZBget host found in configuration. Please configure it.") + return False + + url = nzbgetXMLrpc % {"host": headphones.NZBGET_HOST, "username": headphones.NZBGET_USERNAME, "password": headphones.NZBGET_PASSWORD} + + nzbGetRPC = xmlrpclib.ServerProxy(url) + try: + if nzbGetRPC.writelog("INFO", "headphones connected to drop of %s any moment now." % (nzb.name + ".nzb")): + logger.debug(u"Successful connected to NZBget") + else: + logger.error(u"Successful connected to NZBget, but unable to send a message" % (nzb.name + ".nzb")) + + except httplib.socket.error: + logger.error(u"Please check your NZBget host and port (if it is running). NZBget is not responding to this combination") + return False + + except xmlrpclib.ProtocolError, e: + if (e.errmsg == "Unauthorized"): + logger.error(u"NZBget password is incorrect.") + else: + logger.error(u"Protocol Error: " + e.errmsg) + return False + + # if it's a normal result need to download the NZB content + if nzb.resultType == "nzb": + genProvider = GenericProvider("") + data = genProvider.getURL(nzb.url) + if (data == None): + return False + + # if we get a raw data result thats even better + elif nzb.resultType == "nzbdata": + data = nzb.extraInfo[0] + + nzbcontent64 = standard_b64encode(data) + + logger.error(u"Sending NZB to NZBget") + logger.debug(u"URL: " + url) + + if nzbGetRPC.append(nzb.name + ".nzb", headphones.NZBGET_CATEGORY, addToTop, nzbcontent64): + logger.debug(u"NZB sent to NZBget successfully") + return True + else: + logger.error(u"NZBget could not add %s to the queue" % (nzb.name + ".nzb")) + return False diff --git a/headphones/searcher.py b/headphones/searcher.py index 05f7506f..041cb30b 100644 --- a/headphones/searcher.py +++ b/headphones/searcher.py @@ -29,7 +29,7 @@ import os, re, time import string import headphones, exceptions -from headphones import logger, db, helpers, classes, sab +from headphones import logger, db, helpers, classes, sab, nzbget import lib.bencode as bencode @@ -109,7 +109,7 @@ def searchforalbum(albumid=None, new=False, lossless=False): for result in results: foundNZB = "none" - if (headphones.NEWZNAB or headphones.NZBSORG or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE): + if (headphones.NEWZNAB or headphones.NZBSORG or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE or headphones.NZBGET_HOST): if result['Status'] == "Wanted Lossless": foundNZB = searchNZB(result['AlbumID'], new, losslessOnly=True) else: @@ -125,7 +125,7 @@ def searchforalbum(albumid=None, new=False, lossless=False): else: foundNZB = "none" - if (headphones.NZBMATRIX or headphones.NEWZNAB or headphones.NZBSORG or headphones.NEWZBIN or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE): + if (headphones.NZBMATRIX or headphones.NEWZNAB or headphones.NZBSORG or headphones.NEWZBIN or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE or headphones.NZBGET_HOST): foundNZB = searchNZB(albumid, new, lossless) if (headphones.KAT or headphones.ISOHUNT or headphones.MININOVA or headphones.WAFFLES or headphones.RUTRACKER or headphones.WHATCD) and foundNZB == "none": @@ -533,7 +533,14 @@ def searchNZB(albumid=None, new=False, losslessOnly=False): logger.info(u'Found best result: %s - %s' % (bestqual[2], bestqual[0], helpers.bytes_to_mb(bestqual[1]))) # Get rid of any dodgy chars here so we can prevent sab from renaming our downloads nzb_folder_name = helpers.sab_sanitize_foldername(bestqual[0]) - if headphones.SAB_HOST and not headphones.BLACKHOLE: + if headphones.NZBGET_HOST and not headphones.BLACKHOLE and not headphones.SAB_HOST: + + nzb = classes.NZBDataSearchResult() + nzb.extraInfo.append(data) + nzb.name = nzb_folder_name + nzbget.sendNZB(nzb) + + elif headphones.SAB_HOST and not headphones.BLACKHOLE and not headphones.NZBGET_HOST: nzb = classes.NZBDataSearchResult() nzb.extraInfo.append(data) diff --git a/headphones/webserve.py b/headphones/webserve.py index 349e95b1..9e732e6b 100644 --- a/headphones/webserve.py +++ b/headphones/webserve.py @@ -573,6 +573,10 @@ class WebInterface(object): "sab_api" : headphones.SAB_APIKEY, "sab_pass" : headphones.SAB_PASSWORD, "sab_cat" : headphones.SAB_CATEGORY, + "nzbget_host" : headphones.NZBGET_HOST, + "nzbget_user" : headphones.NZBGET_USERNAME, + "nzbget_pass" : headphones.NZBGET_PASSWORD, + "nzbget_cat" : headphones.NZBGET_CATEGORY, "download_dir" : headphones.DOWNLOAD_DIR, "use_blackhole" : checked(headphones.BLACKHOLE), "blackhole_dir" : headphones.BLACKHOLE_DIR, @@ -702,7 +706,7 @@ class WebInterface(object): def configUpdate(self, http_host='0.0.0.0', http_username=None, http_port=8181, http_password=None, launch_browser=0, api_enabled=0, api_key=None, download_scan_interval=None, nzb_search_interval=None, libraryscan_interval=None, sab_host=None, sab_username=None, sab_apikey=None, sab_password=None, - sab_category=None, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, + sab_category=None, nzbget_host=None, nzbget_username=None, nzbget_password=None, nzbget_category=None, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, newznab_enabled=0, nzbsorg=0, nzbsorg_uid=None, nzbsorg_hash=None, nzbsrus=0, nzbsrus_uid=None, nzbsrus_apikey=None, nzbx=0, preferred_words=None, required_words=None, ignored_words=None, preferred_quality=0, preferred_bitrate=None, detect_bitrate=0, move_files=0, torrentblackhole_dir=None, download_torrent_dir=None, numberofseeders=10, use_isohunt=0, use_kat=0, use_mininova=0, waffles=0, waffles_uid=None, waffles_passkey=None, whatcd=0, whatcd_username=None, whatcd_password=None, @@ -730,6 +734,10 @@ class WebInterface(object): headphones.SAB_PASSWORD = sab_password headphones.SAB_APIKEY = sab_apikey headphones.SAB_CATEGORY = sab_category + headphones.NZBGET_HOST = nzbget_host + headphones.NZBGET_USERNAME = nzbget_username + headphones.NZBGET_PASSWORD = nzbget_password + headphones.NZBGET_CATEGORY = nzbget_category headphones.DOWNLOAD_DIR = download_dir headphones.BLACKHOLE = blackhole headphones.BLACKHOLE_DIR = blackhole_dir From 2771ca7dcfbf5afee24bc14eab3cbecd7048ac6e Mon Sep 17 00:00:00 2001 From: sjengfred Date: Mon, 24 Jun 2013 20:54:41 +0200 Subject: [PATCH 2/8] changed from xbian default to normal default + fixed license notifications --- data/interfaces/brink/config.html | 2 +- data/interfaces/classic/config.html | 2 +- data/interfaces/default/config.html | 2 +- data/interfaces/remix/config.html | 2 +- headphones/__init__.py | 4 +++- headphones/nzbget.py | 35 +++++++++++++++-------------- headphones/searcher.py | 2 ++ headphones/webserve.py | 4 +++- 8 files changed, 30 insertions(+), 23 deletions(-) diff --git a/data/interfaces/brink/config.html b/data/interfaces/brink/config.html index 5e7aa91a..44d50e09 100644 --- a/data/interfaces/brink/config.html +++ b/data/interfaces/brink/config.html @@ -250,7 +250,7 @@
-
Usually http://localhost:9092 +
Usually http://localhost:6789

NZBget Host:


- usually http://localhost:9092 + usually http://localhost:6789
diff --git a/data/interfaces/default/config.html b/data/interfaces/default/config.html index 7d219c5e..0979904d 100644 --- a/data/interfaces/default/config.html +++ b/data/interfaces/default/config.html @@ -145,7 +145,7 @@
- usually http://localhost:9092 + usually http://localhost:6789
diff --git a/data/interfaces/remix/config.html b/data/interfaces/remix/config.html index d03a6a5e..7f78d03e 100644 --- a/data/interfaces/remix/config.html +++ b/data/interfaces/remix/config.html @@ -130,7 +130,7 @@

NZBget Host:


- usually http://localhost:9092 + usually http://localhost:6789
diff --git a/headphones/__init__.py b/headphones/__init__.py index d14e0232..3dce3f57 100644 --- a/headphones/__init__.py +++ b/headphones/__init__.py @@ -13,6 +13,8 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi + from __future__ import with_statement import os, sys, subprocess @@ -413,7 +415,7 @@ def initialize(): SAB_APIKEY = check_setting_str(CFG, 'SABnzbd', 'sab_apikey', '') SAB_CATEGORY = check_setting_str(CFG, 'SABnzbd', 'sab_category', '') - NZBGET_USERNAME = check_setting_str(CFG, 'NZBget', 'nzbget_username', '') + NZBGET_USERNAME = check_setting_str(CFG, 'NZBget', 'nzbget_username', 'nzbget') NZBGET_PASSWORD = check_setting_str(CFG, 'NZBget', 'nzbget_password', '') NZBGET_CATEGORY = check_setting_str(CFG, 'NZBget', 'nzbget_category', '') NZBGET_HOST = check_setting_str(CFG, 'NZBget', 'nzbget_host', '') diff --git a/headphones/nzbget.py b/headphones/nzbget.py index cd0c3315..5176c9f3 100644 --- a/headphones/nzbget.py +++ b/headphones/nzbget.py @@ -1,21 +1,22 @@ -# This file is part of Headphones. -# -# Headphones is free software: you can redistribute it and/or modify -# it under the terms of the GNU General Public License as published by -# the Free Software Foundation, either version 3 of the License, or -# (at your option) any later version. -# -# Headphones is distributed in the hope that it will be useful, -# but WITHOUT ANY WARRANTY; without even the implied warranty of -# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the -# GNU General Public License for more details. -# -# You should have received a copy of the GNU General Public License -# along with Headphones. If not, see . +# This file is modified to work with headphones by CurlyMo as a part of XBian - XBMC on the Raspberry Pi -##################################### -## Stolen from Sick-Beard's nzbget.py ## -##################################### +# Author: Nic Wolfe +# URL: http://code.google.com/p/sickbeard/ +# +# This file is part of Sick Beard. +# +# Sick Beard is free software: you can redistribute it and/or modify +# it under the terms of the GNU General Public License as published by +# the Free Software Foundation, either version 3 of the License, or +# (at your option) any later version. +# +# Sick Beard is distributed in the hope that it will be useful, +# but WITHOUT ANY WARRANTY; without even the implied warranty of +# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the +# GNU General Public License for more details. +# +# You should have received a copy of the GNU General Public License +# along with Sick Beard. If not, see . diff --git a/headphones/searcher.py b/headphones/searcher.py index 041cb30b..100c485b 100644 --- a/headphones/searcher.py +++ b/headphones/searcher.py @@ -13,6 +13,8 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi + import urllib, urllib2, urlparse, httplib import lib.feedparser as feedparser from lib.pygazelle import api as gazelleapi diff --git a/headphones/webserve.py b/headphones/webserve.py index 9e732e6b..66ff59e1 100644 --- a/headphones/webserve.py +++ b/headphones/webserve.py @@ -13,6 +13,8 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi + import os import cherrypy @@ -706,7 +708,7 @@ class WebInterface(object): def configUpdate(self, http_host='0.0.0.0', http_username=None, http_port=8181, http_password=None, launch_browser=0, api_enabled=0, api_key=None, download_scan_interval=None, nzb_search_interval=None, libraryscan_interval=None, sab_host=None, sab_username=None, sab_apikey=None, sab_password=None, - sab_category=None, nzbget_host=None, nzbget_username=None, nzbget_password=None, nzbget_category=None, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, + sab_category=None, nzbget_host=None, nzbget_username='nzbget', nzbget_password=None, nzbget_category=None, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, newznab_enabled=0, nzbsorg=0, nzbsorg_uid=None, nzbsorg_hash=None, nzbsrus=0, nzbsrus_uid=None, nzbsrus_apikey=None, nzbx=0, preferred_words=None, required_words=None, ignored_words=None, preferred_quality=0, preferred_bitrate=None, detect_bitrate=0, move_files=0, torrentblackhole_dir=None, download_torrent_dir=None, numberofseeders=10, use_isohunt=0, use_kat=0, use_mininova=0, waffles=0, waffles_uid=None, waffles_passkey=None, whatcd=0, whatcd_username=None, whatcd_password=None, From d41ee52af3bdefe916393a2780329dad97b1f039 Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 29 Jun 2013 15:24:36 +0700 Subject: [PATCH 3/8] Got rid of the non-working interfaces --- data/interfaces/brink/CSS/websymbol.css | 104 - .../interfaces/brink/Images/no-artist-art.png | Bin 10486 -> 0 bytes .../Images/ui-bg_flat_0_aaaaaa_40x100.png | Bin 180 -> 0 bytes .../Images/ui-bg_flat_1000_283943_40x100.png | Bin 214 -> 0 bytes .../Images/ui-bg_flat_100_192126_40x100.png | Bin 182 -> 0 bytes .../Images/ui-bg_flat_65_0091ff_40x100.png | Bin 180 -> 0 bytes .../Images/ui-bg_flat_75_3c444b_40x100.png | Bin 213 -> 0 bytes .../Images/ui-bg_glass_55_fbf9ee_1x400.png | Bin 120 -> 0 bytes .../ui-bg_highlight-soft_20_252c34_1x100.png | Bin 163 -> 0 bytes .../ui-bg_inset-soft_95_fef1ec_1x100.png | Bin 123 -> 0 bytes .../brink/Images/ui-icons_0091ff_256x240.png | Bin 4369 -> 0 bytes .../brink/Images/ui-icons_2e83ff_256x240.png | Bin 4369 -> 0 bytes .../brink/Images/ui-icons_454545_256x240.png | Bin 4369 -> 0 bytes .../brink/Images/ui-icons_888888_256x240.png | Bin 4369 -> 0 bytes .../brink/Images/ui-icons_cd0a0a_256x240.png | Bin 4369 -> 0 bytes .../brink/Images/ui-icons_ffffff_256x240.png | Bin 4369 -> 0 bytes data/interfaces/brink/album.html | 161 - data/interfaces/brink/artist.html | 276 - data/interfaces/brink/base.html | 153 - data/interfaces/brink/config.html | 1017 -- .../css/jquery.dataTables_themeroller.css | 245 - .../brink/css/jquery.jscrollpane.css | 157 - data/interfaces/brink/css/libs/dataTable.css | 113 - .../css/libs/jquery-ui-1.8.23.custom.css | 563 - .../brink/css/libs/jquery.dataTables.css | 219 - .../libs/jquery.dataTables_themeroller.css | 243 - .../brink/css/libs/jquery.jscrollpane.css | 143 - .../interfaces/brink/css/libs/jquery.noty.css | 105 - .../brink/css/libs/noty_theme_default.css | 240 - data/interfaces/brink/css/style.css | 826 -- data/interfaces/brink/css/theme/default.css | 71 - data/interfaces/brink/extras.html | 25 - .../fonts/websymbols-regular-webfont.eot | Bin 12596 -> 0 bytes .../fonts/websymbols-regular-webfont.svg | 108 - .../fonts/websymbols-regular-webfont.ttf | Bin 12344 -> 0 bytes .../fonts/websymbols-regular-webfont.woff | Bin 7864 -> 0 bytes data/interfaces/brink/history.html | 80 - data/interfaces/brink/images/arrow-down.png | Bin 3136 -> 0 bytes data/interfaces/brink/images/arrow-up.png | Bin 3131 -> 0 bytes data/interfaces/brink/images/box-big.png | Bin 8209 -> 0 bytes data/interfaces/brink/images/cd-big.png | Bin 34456 -> 0 bytes data/interfaces/brink/images/no-cover.png | Bin 3738 -> 0 bytes data/interfaces/brink/images/sort_asc.png | Bin 2912 -> 0 bytes data/interfaces/brink/images/sort_both.png | Bin 2973 -> 0 bytes data/interfaces/brink/images/sort_desc.png | Bin 2873 -> 0 bytes data/interfaces/brink/index.html | 165 - data/interfaces/brink/js/configscript.js | 174 - .../brink/js/jquery-ui-1.8.21.custom.min.js | 125 - .../interfaces/brink/js/libs/dd_belatedpng.js | 13 - data/interfaces/brink/js/libs/jquery-1.7.2.js | 9404 ----------------- .../brink/js/libs/jquery-1.7.2.min.js | 4 - .../brink/js/libs/jquery-1.8.0.min.js | 2 - .../js/libs/jquery-ui-1.8.23.custom.min.js | 125 - .../brink/js/libs/jquery.dataTables.min.js | 153 - data/interfaces/brink/js/libs/jquery.form.js | 1089 -- .../brink/js/libs/jquery.jscrollpane.min.js | 11 - .../brink/js/libs/jquery.mousewheel.js | 84 - .../brink/js/libs/jquery.nicescroll.min.js | 56 - .../brink/js/libs/modernizr-1.7.min.js | 2 - data/interfaces/brink/js/noty/jquery.noty.js | 471 - .../brink/js/noty/layouts/bottom.js | 34 - .../brink/js/noty/layouts/bottomCenter.js | 41 - .../brink/js/noty/layouts/bottomLeft.js | 43 - .../brink/js/noty/layouts/bottomRight.js | 43 - .../brink/js/noty/layouts/center.js | 56 - .../brink/js/noty/layouts/centerLeft.js | 61 - .../brink/js/noty/layouts/centerRight.js | 61 - .../brink/js/noty/layouts/inline.js | 31 - data/interfaces/brink/js/noty/layouts/top.js | 34 - .../brink/js/noty/layouts/topCenter.js | 41 - .../brink/js/noty/layouts/topLeft.js | 43 - .../brink/js/noty/layouts/topRight.js | 43 - data/interfaces/brink/js/noty/promise.js | 432 - data/interfaces/brink/js/noty/themes/brink.js | 155 - .../brink/js/noty/themes/default.js | 156 - data/interfaces/brink/js/plugins.js | 41 - data/interfaces/brink/js/script.js | 194 - data/interfaces/brink/logs.html | 53 - data/interfaces/brink/manage.html | 105 - data/interfaces/brink/managealbums.html | 147 - data/interfaces/brink/manageartists.html | 105 - data/interfaces/brink/managenew.html | 52 - data/interfaces/brink/searchresults.html | 106 - data/interfaces/brink/shutdown.html | 20 - data/interfaces/brink/upcoming.html | 144 - data/interfaces/classic/album.html | 136 - data/interfaces/classic/artist.html | 165 - data/interfaces/classic/base.html | 107 - data/interfaces/classic/config.html | 697 -- data/interfaces/classic/extras.html | 13 - data/interfaces/classic/history.html | 85 - data/interfaces/classic/index.html | 86 - data/interfaces/classic/logs.html | 60 - data/interfaces/classic/manage.html | 74 - data/interfaces/classic/manageartists.html | 82 - data/interfaces/classic/managenew.html | 52 - data/interfaces/classic/searchresults.html | 70 - data/interfaces/classic/shutdown.html | 13 - data/interfaces/classic/upcoming.html | 86 - data/interfaces/remix/album.html | 128 - data/interfaces/remix/artist.html | 162 - data/interfaces/remix/base.html | 107 - data/interfaces/remix/config.html | 697 -- data/interfaces/remix/extras.html | 13 - data/interfaces/remix/history.html | 85 - data/interfaces/remix/index.html | 86 - data/interfaces/remix/logs.html | 60 - data/interfaces/remix/manage.html | 74 - data/interfaces/remix/manageartists.html | 82 - data/interfaces/remix/managenew.html | 52 - data/interfaces/remix/searchresults.html | 70 - data/interfaces/remix/shutdown.html | 13 - data/interfaces/remix/style.css | 303 - data/interfaces/remix/upcoming.html | 86 - 114 files changed, 22712 deletions(-) delete mode 100644 data/interfaces/brink/CSS/websymbol.css delete mode 100644 data/interfaces/brink/Images/no-artist-art.png delete mode 100644 data/interfaces/brink/Images/ui-bg_flat_0_aaaaaa_40x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_flat_1000_283943_40x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_flat_100_192126_40x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_flat_65_0091ff_40x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_flat_75_3c444b_40x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_glass_55_fbf9ee_1x400.png delete mode 100644 data/interfaces/brink/Images/ui-bg_highlight-soft_20_252c34_1x100.png delete mode 100644 data/interfaces/brink/Images/ui-bg_inset-soft_95_fef1ec_1x100.png delete mode 100644 data/interfaces/brink/Images/ui-icons_0091ff_256x240.png delete mode 100644 data/interfaces/brink/Images/ui-icons_2e83ff_256x240.png delete mode 100644 data/interfaces/brink/Images/ui-icons_454545_256x240.png delete mode 100644 data/interfaces/brink/Images/ui-icons_888888_256x240.png delete mode 100644 data/interfaces/brink/Images/ui-icons_cd0a0a_256x240.png delete mode 100644 data/interfaces/brink/Images/ui-icons_ffffff_256x240.png delete mode 100644 data/interfaces/brink/album.html delete mode 100644 data/interfaces/brink/artist.html delete mode 100644 data/interfaces/brink/base.html delete mode 100644 data/interfaces/brink/config.html delete mode 100644 data/interfaces/brink/css/jquery.dataTables_themeroller.css delete mode 100644 data/interfaces/brink/css/jquery.jscrollpane.css delete mode 100644 data/interfaces/brink/css/libs/dataTable.css delete mode 100644 data/interfaces/brink/css/libs/jquery-ui-1.8.23.custom.css delete mode 100644 data/interfaces/brink/css/libs/jquery.dataTables.css delete mode 100644 data/interfaces/brink/css/libs/jquery.dataTables_themeroller.css delete mode 100644 data/interfaces/brink/css/libs/jquery.jscrollpane.css delete mode 100644 data/interfaces/brink/css/libs/jquery.noty.css delete mode 100644 data/interfaces/brink/css/libs/noty_theme_default.css delete mode 100644 data/interfaces/brink/css/style.css delete mode 100644 data/interfaces/brink/css/theme/default.css delete mode 100644 data/interfaces/brink/extras.html delete mode 100644 data/interfaces/brink/fonts/websymbols-regular-webfont.eot delete mode 100644 data/interfaces/brink/fonts/websymbols-regular-webfont.svg delete mode 100644 data/interfaces/brink/fonts/websymbols-regular-webfont.ttf delete mode 100644 data/interfaces/brink/fonts/websymbols-regular-webfont.woff delete mode 100644 data/interfaces/brink/history.html delete mode 100644 data/interfaces/brink/images/arrow-down.png delete mode 100644 data/interfaces/brink/images/arrow-up.png delete mode 100644 data/interfaces/brink/images/box-big.png delete mode 100644 data/interfaces/brink/images/cd-big.png delete mode 100644 data/interfaces/brink/images/no-cover.png delete mode 100644 data/interfaces/brink/images/sort_asc.png delete mode 100644 data/interfaces/brink/images/sort_both.png delete mode 100644 data/interfaces/brink/images/sort_desc.png delete mode 100644 data/interfaces/brink/index.html delete mode 100644 data/interfaces/brink/js/configscript.js delete mode 100644 data/interfaces/brink/js/jquery-ui-1.8.21.custom.min.js delete mode 100644 data/interfaces/brink/js/libs/dd_belatedpng.js delete mode 100644 data/interfaces/brink/js/libs/jquery-1.7.2.js delete mode 100644 data/interfaces/brink/js/libs/jquery-1.7.2.min.js delete mode 100644 data/interfaces/brink/js/libs/jquery-1.8.0.min.js delete mode 100644 data/interfaces/brink/js/libs/jquery-ui-1.8.23.custom.min.js delete mode 100644 data/interfaces/brink/js/libs/jquery.dataTables.min.js delete mode 100644 data/interfaces/brink/js/libs/jquery.form.js delete mode 100644 data/interfaces/brink/js/libs/jquery.jscrollpane.min.js delete mode 100644 data/interfaces/brink/js/libs/jquery.mousewheel.js delete mode 100644 data/interfaces/brink/js/libs/jquery.nicescroll.min.js delete mode 100644 data/interfaces/brink/js/libs/modernizr-1.7.min.js delete mode 100644 data/interfaces/brink/js/noty/jquery.noty.js delete mode 100644 data/interfaces/brink/js/noty/layouts/bottom.js delete mode 100644 data/interfaces/brink/js/noty/layouts/bottomCenter.js delete mode 100644 data/interfaces/brink/js/noty/layouts/bottomLeft.js delete mode 100644 data/interfaces/brink/js/noty/layouts/bottomRight.js delete mode 100644 data/interfaces/brink/js/noty/layouts/center.js delete mode 100644 data/interfaces/brink/js/noty/layouts/centerLeft.js delete mode 100644 data/interfaces/brink/js/noty/layouts/centerRight.js delete mode 100644 data/interfaces/brink/js/noty/layouts/inline.js delete mode 100644 data/interfaces/brink/js/noty/layouts/top.js delete mode 100644 data/interfaces/brink/js/noty/layouts/topCenter.js delete mode 100644 data/interfaces/brink/js/noty/layouts/topLeft.js delete mode 100644 data/interfaces/brink/js/noty/layouts/topRight.js delete mode 100644 data/interfaces/brink/js/noty/promise.js delete mode 100644 data/interfaces/brink/js/noty/themes/brink.js delete mode 100644 data/interfaces/brink/js/noty/themes/default.js delete mode 100644 data/interfaces/brink/js/plugins.js delete mode 100644 data/interfaces/brink/js/script.js delete mode 100644 data/interfaces/brink/logs.html delete mode 100644 data/interfaces/brink/manage.html delete mode 100644 data/interfaces/brink/managealbums.html delete mode 100644 data/interfaces/brink/manageartists.html delete mode 100644 data/interfaces/brink/managenew.html delete mode 100644 data/interfaces/brink/searchresults.html delete mode 100644 data/interfaces/brink/shutdown.html delete mode 100644 data/interfaces/brink/upcoming.html delete mode 100644 data/interfaces/classic/album.html delete mode 100644 data/interfaces/classic/artist.html delete mode 100644 data/interfaces/classic/base.html delete mode 100644 data/interfaces/classic/config.html delete mode 100644 data/interfaces/classic/extras.html delete mode 100644 data/interfaces/classic/history.html delete mode 100644 data/interfaces/classic/index.html delete mode 100644 data/interfaces/classic/logs.html delete mode 100644 data/interfaces/classic/manage.html delete mode 100644 data/interfaces/classic/manageartists.html delete mode 100644 data/interfaces/classic/managenew.html delete mode 100644 data/interfaces/classic/searchresults.html delete mode 100644 data/interfaces/classic/shutdown.html delete mode 100644 data/interfaces/classic/upcoming.html delete mode 100644 data/interfaces/remix/album.html delete mode 100644 data/interfaces/remix/artist.html delete mode 100644 data/interfaces/remix/base.html delete mode 100644 data/interfaces/remix/config.html delete mode 100644 data/interfaces/remix/extras.html delete mode 100644 data/interfaces/remix/history.html delete mode 100644 data/interfaces/remix/index.html delete mode 100644 data/interfaces/remix/logs.html delete mode 100644 data/interfaces/remix/manage.html delete mode 100644 data/interfaces/remix/manageartists.html delete mode 100644 data/interfaces/remix/managenew.html delete mode 100644 data/interfaces/remix/searchresults.html delete mode 100644 data/interfaces/remix/shutdown.html delete mode 100644 data/interfaces/remix/style.css delete mode 100644 data/interfaces/remix/upcoming.html diff --git a/data/interfaces/brink/CSS/websymbol.css b/data/interfaces/brink/CSS/websymbol.css deleted file mode 100644 index 477bb427..00000000 --- a/data/interfaces/brink/CSS/websymbol.css +++ /dev/null @@ -1,104 +0,0 @@ -@font-face{ - font-family: 'WebSymbolsRegular'; - src: url('../fonts/websymbols-regular-webfont.eot'); - src: url('../fonts/websymbols-regular-webfont.eot?#iefix') format('embedded-opentype'), - url('../fonts/websymbols-regular-webfont.woff') format('woff'), - url('../fonts/websymbols-regular-webfont.ttf') format('truetype'), - url('../fonts/websymbols-regular-webfont.svg#WebSymbolsRegular') format('svg'); -} -.wsr{font-family: 'WebSymbolsRegular';} -.wsr.Wanted:Before{content: "I";} -.wsr.Skipped:Before{content: "I";} - - -/*Icons for content management systems*/ -.wsr.Image:Before{content: "I";} -.wsr.Settings:Before{content: "S";} -.wsr.Cloud:Before{content: "C";} -.wsr.Folder:Before{ content: "F";} -.wsr.Archive:Before{content: "Z";} -.wsr.Movie:Before{content: "M";} -.wsr.Code:Before{content: "H";} -.wsr.Text:Before{content: "T";} -.wsr.Terminal:Before{content: "_";} -.wsr.Attachment:Before{content: "A";} -.wsr.Logout:Before{ content: "X";} -.wsr.Text:Before{content: "T";} -.wsr.Indent:Before{ content: "n";} -.wsr.Outdent:Before{ content: "o"; } -.wsr.List:Before{ content: "p";} -.wsr.NumberList:Before{ content: "q"; } -.wsr.Move:Before { content: "~"; } -.wsr.User:Before { content: "U"; } -.wsr.OpenedLock:Before{ content: "w"; } -.wsr.ClosedLock:Before{ content: "x"; } -.wsr.PortraitView:Before{ content: "a"; } -.wsr.AlbumView:Before{ content: "b"; } -.wsr.Center:Before{ content: "`"; } - -/*Gallery navigation icons*/ -.wsr.ZoomIn:Before{ content: "+"; } -.wsr.ZoomOut:Before{ content: "-"; } -.wsr.Up:Before{ content: ":"; } -.wsr.Down:Before{ content: ";"; } -.wsr.Close:Before{ content: "×"; } -.wsr.Scale:Before{ content: "&"; } -.wsr.Back:Before{ content: "("; } -.wsr.Forward:Before{ content: ")"; } -.wsr.BackArrow:Before{ content: "<"; } -.wsr.ForwardArrow:Before{ content: ">"; } -.wsr.Rotate:Before{ content: "*"; } -.wsr.CloseX:Before{ content: "'"; } - - -/*Social networks*/ -.wsr.Twitter:Before{ content: "'"; } - - -/*Icons for service sites*/ -.wsr.Favorite:Before{ content: "R"; } -.wsr.Tag:Before{ content: ","; } -.wsr.Comment:Before{ content: "c"; } -.wsr.Chat:Before{ content: "d"; } -.wsr.OpenedChat:Before{ content: "e"; } -.wsr.Rating:Before{ content: "u"; } -.wsr.MapPin:Before{ content: "?"; } -.wsr.Like:Before{ content: "N"; } -.wsr.Unlike:Before{ content: "O"; } -.wsr.Search:Before{ content: "L"; } -.wsr.Reblog:Before{ content: "J"; } -.wsr.OpenNewWindow:Before{ content: "D"; } -.wsr.Clock:Before{ content: "P"; } -.wsr.Link:Before{ content: "K"; } - -/*Other*/ -.wsr.Mail:Before{ content: "@"; } -.wsr.SortUp:Before{ content: "{"; } -.wsr.SortDown:Before{ content: "}"; } -.wsr.Unfold:Before{ content: "["; } -.wsr.Icon:Before{ content: "¹"; } -.wsr.List:Before{ content: "²"; } -.wsr.ListWithIcons:Before{ content: "³"; } -.wsr.Reply:Before{ content: "h"; } -.wsr.ReplyAll:Before{ content: "i"; } -.wsr.Forward:Before{ content: "j"; } -.wsr.Fullscreen:Before{ content: "%"; } -.wsr.Done:Before{ content: "."; } -.wsr.Approved:Before{ content: "/"; } -.wsr.Alert:Before{ content: "W"; } -.wsr.Synchronize:Before{ content: "V"; } - - - - - - - - - - - - - - - diff --git a/data/interfaces/brink/Images/no-artist-art.png b/data/interfaces/brink/Images/no-artist-art.png deleted file mode 100644 index 3c373f8e333ef0ce335af47f331b04f7da68abbd..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 10486 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 diff --git a/data/interfaces/brink/Images/ui-bg_flat_0_aaaaaa_40x100.png b/data/interfaces/brink/Images/ui-bg_flat_0_aaaaaa_40x100.png deleted file mode 100644 index 5b5dab2ab7b1c50dea9cfe73dc5a269a92d2d4b4..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 180 zcmeAS@N?(olHy`uVBq!ia0vp^8bF-F!3HG1q!d*FscKIb$B>N1x91EQ4=4yQ7#`R^ z$vje}bP0l+XkK DSH>_4 diff --git a/data/interfaces/brink/Images/ui-bg_flat_1000_283943_40x100.png b/data/interfaces/brink/Images/ui-bg_flat_1000_283943_40x100.png deleted file mode 100644 index 7d6f3bf2485d21a542dfb5732beb59fb0020068b..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 214 zcmeAS@N?(olHy`uVBq!ia0vp^8bF-F!N$PA*qrS22FRJ~>EalY(fIcIM&4!zkpmYd zWJWa3`kU_cN`Xt|zevaPPhSl8IWuisbNgSVY=ykI+?E{{6XN~&pM1K?_TJ=0q_oM8 z2M15zopr0LKGOZ2$lO diff --git a/data/interfaces/brink/Images/ui-bg_flat_100_192126_40x100.png b/data/interfaces/brink/Images/ui-bg_flat_100_192126_40x100.png deleted file mode 100644 index 0cdb1235c77a223d7b4c4ba5c9f65b81c80fea6d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 182 zcmeAS@N?(olHy`uVBq!ia0vp^8bF-F!3HG1q!d*Fsaj7L$B>N1x91EQ8x$BA9G9>z z?*1$7#nL8S^258}`mXuqe{TG-DhLV?4Pgy+45coW%j3bM9$)9NALtMUPgg&ebxsLQ E0F%oxh5!Hn diff --git a/data/interfaces/brink/Images/ui-bg_flat_65_0091ff_40x100.png b/data/interfaces/brink/Images/ui-bg_flat_65_0091ff_40x100.png deleted file mode 100644 index e7c517a5a1d289f8ffd3e76659755b1e63b05aec..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 180 zcmeAS@N?(olHy`uVBq!ia0vp^8bF-F!3HG1q!d*FscKIb$B>N1x91izHW&ynY`pZB zSJ+-TWR8Z?Ooj7R>DT(--fk2==(Ry;4U0B)saMQEalY(fIbdAy>152*br0 z#gVrv|9@5~J>oQDzEe%G-u=Qd)}yI+zny=5;P;LX3yvOb{8Ln=FnzsQ#d62z UEim$g7SJdLPgg&ebxsLQ09~*s;{X5v diff --git a/data/interfaces/brink/Images/ui-bg_highlight-soft_20_252c34_1x100.png b/data/interfaces/brink/Images/ui-bg_highlight-soft_20_252c34_1x100.png deleted file mode 100644 index b0b0e13d74c21e871cb6c0c5c0ca5732ed23621e..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 163 zcmeAS@N?(olHy`uVBq!ia0vp^j6j^i!3Ja)XlH!`aS{Ou}E*`%9 zKPdOkfrN+ZlHSt7(uY{3{#;wiJb&Ugx1>W4qtrSDm(4hFaaY-$3p3x|sIU3`%J?Qj YcLn#R=pC)AfTl5cy85}Sb4q9e0MP_2(*OVf diff --git a/data/interfaces/brink/Images/ui-icons_0091ff_256x240.png b/data/interfaces/brink/Images/ui-icons_0091ff_256x240.png deleted file mode 100644 index 7bc916c4ca57ece38fdfc19f01b646e1bea61439..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4369 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 diff --git a/data/interfaces/brink/Images/ui-icons_454545_256x240.png b/data/interfaces/brink/Images/ui-icons_454545_256x240.png deleted file mode 100644 index 59bd45b907c4fd965697774ce8c5fc6b2fd9c105..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4369 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 oBo%DI*Kv;w;*%(i9W@f3_WCF#rGn diff --git a/data/interfaces/brink/Images/ui-icons_cd0a0a_256x240.png b/data/interfaces/brink/Images/ui-icons_cd0a0a_256x240.png deleted file mode 100644 index 2ab019b73ec11a485fa09378f3a0e155194f6a5d..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 4369 zcmd^?`8O2)_s3@pGmLE*`#M>&Z`mr_kcwz5Nh&gy7G+@45H9p05OJ)J0CH2owMSaGIN$+5!N; z<11j56?ANg=9hMl-IBGX-T8hf$N$b*H?$f4Xt&I`oABt1nR=k%#z{{*a!Axm|t}hCz zJg0Ln7;M4Zjx{$mwhMW+kWN;|j>qTx_-zNX!GzqEZRa}QF8_0yk6+=w}$QD^&hM4%OkT=uh$q9;5u~NL-I+NQyaVc|3l+iWI5~|(hA-G z08i8AMr@{uY_cWTxo^y|Qyb33mlZLvc7H2Zm~>mB7&=-1X^@|D z&0*~i?GBE&NM(Pv&Vt^zWu_bD3e|R?wTL{cSFwD^Ij9v%g=aLY@1U2Bxn#Te*{>%D zOOW-O-bfnJ7T8jd<*>8`Z2DsFQi~S$%^npJwXam5>>p zMd}QEjM)@~##n$LXpz1Hkl|2UGXi-JFFePXBWL+-5f%!S>L#KL3>Vl0w#d^21Jn<~_7q zWx^Xg1(>PsPGO&cu{S;(pRQ;=Vw2J<9NdQVWx<+g-`ia=Q@puS)75M+?u>DTa95e9 zt#1T?#a)uWC>Mia!K6>g|InPW{&Kp9$tC_3*;R_Xsz6^Eu|xW1$6j#0?XLs7^l+%O zlxddE)h^|=K(2UqS*0ECuDe0ic|H_^t*VOoTCKx0Qmn_^LyJ|b8l$Jvl3{2=3x8&7 z$1ik&YG>w#@x@y~$r`fhlUDo;yXecc6$`30m`3K8s{k8G&3RVp8n#|l6h(Xw`Axw9 z%6Y^J6k0P@4YAuSd%q7=eg)&u8EMoEmq$CWj1GY|rGQWw3ida!FHk&wCqrQh_0Bcw z!ZBS3CbxgZ+}~wzgGIQ#QId%T_TE~_qdUqxjqS#8#jPxdwO@(@-5_nSP&uT?aGYYD z6km36K9=gjUjImwO=5Hl#u85VF?r0HbW)#h^SR|s_L47Tl$&Z&Rz*ksl!t*(2O2;D z+8`6$qpLn}LchhCmv*X}moGMX5?F@juGeHQAddAn}0~r zS_0|d3*0v%Y)8+8K{ zGyoYPb|W9Grm9M4E?vb^@16ePbI4omZv+(NoZ##fLUmKlB(G_jEbtDCM*27t$v`JovAZa+%*Q5dDXF*Ftt*n!O>#ohCM4lZ)h5rdKV-3A za}2AO6@!`W>ROk5FN*>2Zza^Z%}8KT%*jBGH|rml2X1LR{wZhWx8V4>|5i}; zMnLIHn3!^)`87GYh}&Y`KMwyLbA#^pch}Z!`@P_qH&N^LS9SxpEy8mc!wFusq&Z@` zeO}<6PC@VNaII|=n(^cNUiLseig*$;NjG7;IwvfYCBN>kzv@v-V2eBQZ@oIs^)NLqMR935k|1}U;5<{s(Ebdj4r`?QtrrAPfQooq zmPs_(YTy|??+nitNIFDoR7~qLPPFFCf^_~8OUt{#!|9o*3Q{!@9ZAI$7O~piD!;WX8#v&RxNH27i59$`1{o zEYU_zE{bKEI%f3BbE0Fc;f2!4LjUlC`wgh4@R{1?O78r5t$hWKiLV{#QWWq{QZiPx zm3?x$;&DDRVt0SByRiFczw$-e)GSvpCRbzk^=E zz=(+LjEc{Ps_2(OYg=G(93!oS=IeJ|WA8STv+LgI*Oj1c-QC06N~mvJ&KKx{arGp5 zswvJ6{%BvBYo>#2$%O$~TITuh?Rr^jCpAUXh)}m74`O|aOU>w2KI`k<#efwa5=-l4Xx!o>Z9Evg`RLN5W7SQp3$@D3_hY4EV!0( ztMm6>zBcgY{RvHZ{9Ey&&)jr2B4s0qDPBUh1ITaAp&>rj3ng*B=VGXz* zs@eR<;J(XkpD6Q1U3}#FR)wlafiFMU(-=&e9(eQ`isrS-9aNwJ)7frS8RiXM4*SbC zL|4*c?h^jfYvSOpn%Z$W?C|TuZ;uy2pFWHXuGW`ZkGV&kPJsKqJJQ!NswAE!!cb2k zumi=AE$YIkm})cVlg>nn&PBjBRI*@mfhhRMsa5U8k#A!ztfiw)d7I_UyAif8$5sJ9a7WUv5!o%fL z(J7-8EQzv1YIc)BNeWkLK~m%y4vqe&q@|_ZR5;eC3-9rkf*T{_19jtuWKhdW4Bn|~ zZ-YyFLN!k)0AKg{dO)|v3K?=oy+dzb4%T1F4}JsByncB1Z(`2p@O0!E!JQelouN^* z%Q^YfQUh66D$Zx-RDZvLctsr9`_+1p#tz&4SMd@i_-8()tyg3OyhU~?Gt#-a{NKFN z0VGf+AH%@o6;-_*?$$T4QX-f_>Ny-5CV8Ccq+@>gNSeovbFr0@b}RiTcJbLx>ws&r zsvY!rR{4al#MpVKut~?&kTmF>_v3UaC!gvuxgg%5-{l{20}~&F6CUarF9N=u)BG71 zoQDlAwT+T=mfo&$Xy%4-kmW;4wuh6{{ABClybHV6L>t&k4?9_Ny8A_^?)ff#dEjhL z2RbC~cFVbz^fJ`$I0%prYc0g-9(7X3eUp}^#Mzv)Z1EsGW;qr3cY$+e2HU5d_O9L% zpbljP*1!A0PqpzNo3W&y(hD87qgweq5YQWYEkxrOuSain2-q@Z*P`x*ht-9)Fr5Ho zSTKduvc9h6`S^#$i)LgjDi3_PQ+RbaGP!!di^Y;4kB0lGo$y{if)rJIaXTbpRgO#B z1El6|18;s}$0FRjgK-7~ZwmI`_1{a`32+Y>&O_iTpm%vz6hNkjGR(#*! zpfJ2>OAQbTFba9S3j9BlRHXaG{)Zt(J<3ppA?}j+7F#{bV{M7zU)5e@~R&J_xf$+GKK~ z3{R;Y9fZGe^ifEqKL;!VMXv26=R~^TG(#*2!JKCWoo&c^$utAs#Gfq-?t!c&9TH5- zj&i5L4NWbdNs*djvsY}bC&ddUbh=iyc0;3-@Y#d^s8|Ql{ax(yenFcG#i|K%lRxy| zFys4w!@EPXp2AsbMUGc*eP|7uliAq-O6~(+MR>V(EZTd&9G+MY&gF2lZ=I8j*o`OC z`AxrmOGMeD=H_9Cq47clT|h34>-EI=%;E!my;o&wU(aKV&PymBzrV9q2uA62XS@JrjKYANZAU>;8mag#BU?Nv`+ZVhlAPV`HF_gKY_O zhbV2L`8qvR&f=@M5vH~geD+L&*L2s<)|5)clA0yt9TM{X)iWtx@wJO_!{vR#|AD6t z*OAg2&P_i8jjW5y0DdtOGcqvrCHD*1Uq_q1ZQmngPnf!2fHizH%sSX>#$2Rh!>1ur z+s(*-)abDuePc6~XNG8m@|KMXHVM#G4?~+V z1z!An!D0GD-7WqXE8ddUXLkI%u01$fTEhhytoqJ#RmwV2==ic*rz7lOw=eaq=H~;_ux21)-Jpcgw zdj+hrf&W^f<%Qk9Zpqf#;q3n5{{POY;f!wmTR1An9(4&I0z1LNX50QSTV2M%4|y9c z#{ZQIVJKu~aY5?ZaZP*GIGqGs=e@q6o|EPhZB3CC?@LnORK8O@z{{<0KtSn5?#~OW zy=L;x8T&*%xqElS;s5~Pjk7d2bqIaA)xZbovnZd7eX17WNxx=w`p(8vulwUZ zl{so}MuRNJx5!8S5G;$o2?BApPHt+)!^#*Ww`?rcVE}mcyuY`X2o|uVUyI9o1t11O zemGWR?;aD#0$vJhiPhv~0iXS#iLq!>Qd$` zU{}<|Vb9Md>$4TMbL7C3GP#r;4Wc$}Z;^j;n}yc!E3d;`wry$!JkmJP0%(tIh!!TET8=+{rhUi^60G0t2HJSxXv-*DgC(HrJd8`|Dp3NvL5yg>xAvU zho|fEA~w^-HrW&H-JwkqNX2I-bEXBR&Uhp+y2^)1h1IIlNCzC!v-Mz@&z&VPz+cl1 z=f&f6Y*U~C`ixm4Sy1hl$hg(4%Dy;bq~k7d1<@K&%%NLT`L+A)-QXyKVswX?op90( zB#yeFEih@c{OXU8Oq~1CFI_38GXmns3(`;W(i+bslovCx4u7gvK>DrGOug*?G|1nz z_OR}|ZYS3pq-p?rS7G0qa`TM}r5XqDT4cV>%Qyk#9ES}`jc+Ww|DcbZrF6UG>CeXp zOVIV}K1e#z9@tu#?X)Ri=?zXMB`X3G-_I7FL-Zq`nbfWtX_EO1*!+U6pJW-_k&+vk zMd}THh}{(Ch_wPk(PI4vVB_KT76kGxVytLxpWg}&bHw`a3G#QzxV@ICNax&@hk3<_ zBh`Tq66G{-tCw$V{(y0v7l!tp20~@gdFXjzFbF#bJE7i>T4ux zQdrF3org^wFcnw$#bQMv@SfN3$Fuo7HnB_`2ZGB{ZqGr>%xP;2_!Q{=N-ZhU1c~^5 zdt=OO#wmcpkXJyCG?{{&n=R{Sn=Ytg;<09CH)l7TA&wkt{Q;>RrA2Ia6-QixEPLrU z%0)N$3Nh0?U825&v($Sz}0G_(!v&xSSAzje4{rup+^W@^}ByqOb95$E0sbwK*%#GP}!6`%*Z@L;&C z3^dE&>5%bWAXmP*X1 z_m}Pivs*u7@9i>qA!58fDCwj^M<1P(u^m;urVdlM@>aIf+E3-d9ZW>fc4cS7w5O3sCmKKn z+94A?VyfSBb9{}rEbCIYtXORJBCv__fnZ>?a}edaA%bP$jI?J^q0UKO!mduA8U!3b z0CJ_Js}NWQZoebapVUHP%pPOUm?1<)zd%`hzUM-Y6g1z|@@3G_kio?S0bcbjQuxJd>vU$Uyz(4*peEDSVc-G;O;% z9Y97%Tq}TRsH+oN%2u(oyC=W<9`e@&m;i;jC%L;sP(9RBDQnth3;ZMEQNFH3GEf0c zU<3RF!hNG-vCDooYFS^nPlFnv4(ElI1=vNcr42TF^uq67f{MoN>{f&>xA91r4pz5Zc&@P^i-9||`98v$Si!U@}ouZ88W zg;YL=OQ;4}UQtkpyd~lD{qWy0H|lwJXKmenz#E=*9kt$YX*X!wDk7ITlIUGWnj>a7 z<_GQR752@J)Y(U)ncu(dIit7P}oBq8x$FP85)&Nsw<#rOW z8U_x(1J)Zgm(8tZXU%+(yYcO+Z7#ZszPwa2`ygiMPayX9KondtFMRK!7x`9uWN;(f zfWW?8yOdj;GA3We0YAW92gWipn(d>zcbA+vZ_21BxF?-pfcW` zbqY??6ie(6M)p@6@WQ?Tl7 zoKrKEj|x~2yZehhMLkFRRnOC>XL&L+N;m0B{_OQ9gzzTYb!!Jct=bk?_hIpY9rOwY zMnr69R(?8EN52qR+k!~qnCYc-KmV&*d$&NY?t5cjR)V+ncMor=puTRoo?{5dH;@!* z<~RrV!+ljAN+;Qx2LraY&JWnz^|sYbZjP+Y;|pC#DuHUH+>F~x3PqTkx)=OAE0X9( z(AO6gp~AH^{nq+n)LHYDD8mQN?DDFcd!U&d4PaajzSD1~lXq3p{x=^vItrq3gD^4O z=hYS`?&C-0&KuAV>Jv}T?ba0IafL$~+bZ}p$9lwyyx=-uPN`Hpvv<)Ia>OWHa4+N4 z6zscrW$^XA32EJw^7hYtkRJr{Q8 zQ|*1pp_q6Mno|D6EX!kgSv0h0I3~ef_l%$DTFjL`0y16n%^dGNQn;2V82mqoIi9i{15vu zLq&(BTl9CInUjZlTIa>^!!HlMK3W8Sd_Ow0+E8IT?h$=55$^Z)$WYIuig=O;Lp_1Q z4wOT;XbWQ!>Mh`pdXuSo=KBba;wT!wK`Hf1Ueh04*%D7Kfj*#b~BNfvz zsbf?uiMm5-xhaQ|7Om2OrYbU>ngUM9%F5nU<65IFyu(`yZ;Vb1)=wCd!L2K?c$ezE z4IbS|^?Z>)eEp}ZfjwF)Waw?pPJ?{~*g%;efxO~Nx7dQGLWZ)cPQ*T!((W- zGm2?tM)K}7oG<0Xz<`ltWjxvE<$AH!4*R{A2~uYGr@m!vm*j+e#CE9^*}Oc#uihB| z5;#kMY2^8mrr80%*+02bDx6B{Jsch(d7kQGV7~iGTgFZBu$Pf`tNf`B2{|t7fGhIq zos0xF#l$bfxOtcGDd*MDbdKBaCKxgCEbr8JTNd_1bjWC{Ubgk z9~)9;A1&=FyIt$l!VBXfD~6VCk0fjO%QwLJ7k00RH*%I8cCqF542VzP^;`OU-_?=< zbV}OoQE)HqV`|)X5+WbgSxGWH>t+7-O;(l~Z+FJJ)sygu^+eF01#Suj+pnAcw!s>p z$-xF}c>7t9X6H$^V9hvT5H{jKv+=zzWHA0pgw8e5fZpm9vIphVq3%S4*N3%&jsY^Q zK%sSPuj=?d{ATs0o0y6#0w3%YT^@-_sTuTUwI(Q{;l3KjeAbVk#Wmi%PDxm`zoqQ~ z((<-}*FSP%5gt7uI3t1&75ne{@1^bpdW1;MMGNkSr~UAuDbB4+VQi|x(gdO^zin_) zncfs2hj8xdiiy)@vVkfkItLKvsGtJhrTb0T~tFl4Q3J!flauS==b& z6Bm!g%dDvlCf(St$kVofvH90|9yl-gmvRvcKS&Ye9DdoTK@2m}iSvC{3m%4E0 z@TJD7c1V?!URM7+t?f3)%{X(6JXg~A9TvGQyX6n(^Yt0NX;>vDPcr~mICPooLWA_` z<1A>FuXr|C)dtDr*PQt%Xs5WePWUB&gBj$zZ#BIY%?jDdpbSA-PV0`dGf^oa_Jp}Z zlrGV7oe`#B^+nPIQ`ZDJeJas=ru#=*YL#+n?Go}f33>1GsZ{TTy2bdBihj}mz*mp! zOzn%{WgLM=*CpiuKUs*GnHa{B$2siJqfNi|Z;|rH%stM*8b26kAMCYY&NHwPGtlYn z7UVx_^sgR$Z8x27foS63FCPt|gtcG_ zy#@C|!VQV~TY}G5e57qp?F4jRxqq~@h6^?-cvD>ySwVLl2m7=gERtEn>Fw_@ND%pO oiVC*mbz<%I+0K1Z`+LWvZ$3~$+A!Gm?^hpSc@||}WrmLVKLvuzv;Y7A diff --git a/data/interfaces/brink/album.html b/data/interfaces/brink/album.html deleted file mode 100644 index c5b32aa2..00000000 --- a/data/interfaces/brink/album.html +++ /dev/null @@ -1,161 +0,0 @@ -<%inherit file="base.html" /> -<%! - from headphones import db, helpers - myDB = db.DBConnection() -%> - -<%def name="headerIncludes()"> -

- -
- - -<%def name="body()"> - -
- - Back to ${album['ArtistName']} - -
-
-
- albumart -
-
-
-

${album['AlbumTitle']}

- by ${album['ArtistName']} -
- <% - totalduration = myDB.action("SELECT SUM(TrackDuration) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - totaltracks = len(myDB.select("SELECT TrackTitle from tracks WHERE AlbumID=?", [album['AlbumID']])) - try: - albumduration = helpers.convert_milliseconds(totalduration) - except: - albumduration = 'n/a' - - %> -
- %if description: -

${description['Summary']}

- %endif -
    -
  • Tracks: ${totaltracks}
  • -
  • Duration: ${albumduration}
  • -
-
-
-
- - - - - - - - - - - - - %for track in tracks: - <% - if track['Location']: - grade = 'A' - location = track['Location'] - else: - grade = 'X' - location = '' - - if track['BitRate']: - bitrate = str(track['BitRate']/1000) + ' kbps' - else: - bitrate = '' - - try: - trackduration = helpers.convert_milliseconds(track['TrackDuration']) - except: - trackduration = 'n/a' - %> - - - - - - - - - %endfor - <% - unmatched = myDB.select('SELECT * from have WHERE ArtistName LIKE ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']]) - %> - %if unmatched: - %for track in unmatched: - <% - duration = helpers.convert_seconds(float(track['TrackLength'])) - %> - - - - - - - - - %endfor - %endif - -
#Track TitleDurationLocal FileBit RateFormat
${track['TrackNumber']}${track['TrackTitle']}${trackduration}${location}${bitrate}${format}
${track['TrackNumber']}${track['TrackTitle']}${duration}${track['Location']}${int(track['BitRate'])/1000} kbps${track['Format']}
-
-
- - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/artist.html b/data/interfaces/brink/artist.html deleted file mode 100644 index d2ddac43..00000000 --- a/data/interfaces/brink/artist.html +++ /dev/null @@ -1,276 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import db - import headphones - import string -%> - -<%def name="body()"> - - - - - - - -
-
-
- ${artist['ArtistName']} -
- %if artist['Status'] == 'Loading': -

Loading albums informations...

- %else: -

${artist['ArtistName']}

- %endif - -
-
-

Mark as: - - -

- Click CTRL + LMOUSE on albums to select them in grid view. -
- %for album in albums: - <% - %> -
-
-
- -
- %if album['Status'] == 'Skipped': - - %elif album['Status'] == 'Wanted': - - %else: - * - J - %endif - -
- -
- -
- ${artist['ArtistName']} - ${album['AlbumTitle']} -
-
- %endfor -
-
- - - - - - - - - - - - - - %for album in albums: - <% - if album['Status'] == 'Skipped': - grade = 'Z' - elif album['Status'] == 'Wanted': - grade = 'X' - elif album['Status'] == 'Snatched': - grade = 'C' - else: - grade = 'A' - - myDB = db.DBConnection() - totaltracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=?', [album['AlbumID']])) - havetracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=? AND Location IS NOT NULL', [album['AlbumID']])) + len(myDB.select('SELECT TrackTitle from have WHERE ArtistName like ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']])) - - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - avgbitrate = myDB.action("SELECT AVG(BitRate) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if avgbitrate: - bitrate = str(int(avgbitrate)/1000) + ' kbps' - else: - bitrate = '' - - %> - - - - - - - - - %endfor - -
NameDateTypeHaveBitrate
- -
- - - -
-
${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']} -
- ${percent} -
-
-
-
${bitrate}
-
-
- - -<%def name="headIncludes()"> - - %if artist['Status'] == 'Loading': - - %endif - - -<%def name="javascriptIncludes()"> - - diff --git a/data/interfaces/brink/base.html b/data/interfaces/brink/base.html deleted file mode 100644 index 5fcc20ed..00000000 --- a/data/interfaces/brink/base.html +++ /dev/null @@ -1,153 +0,0 @@ -<% - import headphones - from headphones import version -%> - - - - - - - - - - - Headphones - ${title} - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - ${next.headIncludes()} - ${next.javascriptIncludes()} - - - - - - - - - - - - - - - - - - - - -
-
- ${next.body()} -
-
- - - -<%def name="headIncludes()"> -<%def name="headerIncludes()"> -<%def name="javascriptIncludes()"> diff --git a/data/interfaces/brink/config.html b/data/interfaces/brink/config.html deleted file mode 100644 index 44d50e09..00000000 --- a/data/interfaces/brink/config.html +++ /dev/null @@ -1,1017 +0,0 @@ -<%inherit file="base.html"/> -<%! - import headphones - import string -%> - -<%def name="headIncludes()"> - - - -<%def name="headerIncludes()"> - - -<%def name="body()"> -
- -
-
-

CWeb Interface

- WWeb Interface changes require a restart to take effect -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
-

HTTP

-
Basic settings for Headphones. -
- -
Localhost or 0.0.0.0 -
- -
- -
Default is: 8181 -
- -
- -
Enter a desired username at login, or leave blank for none.

-
- -
- -
Enter a desired password at login, or leave blank for none. -
- -
- -
Enabling this feature will open Headphones at startup. -
- -
-
Choose from a verity of different themes -
- -

API:

-
- - - - -
- Current API:${config['api_key']} - -
-

PScan Intervals

-
- -
-
-
- - -
-
- -
-
-
- -

- -
-
-
- -
-
-
- - - -
-

uDownload Settings

- Setup SABnzbd, NZBGET or BitTorrent - - -
- - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
-

SABnzbd

- -
-
Usually http://localhost:8080 -
-
Type the user name for SABnzbd -
-
Enter the password for SABnzbd -
- Write the category label name from SABnzbd -
- -
Full path to the directory where SAB or NZBget downloads your music. -
-
- - - -
- - - - - - - - - - - - - - - - - - - - - -
-

NZBget

- -
-
Usually http://localhost:6789 -
-
Type the user name for NZBget -
-
Enter the password for NZBget -
- Write the category label name from NZBget -
-
- - - -
- - - - - - - - - - - - - - - - - - - - - - - - - -

~Torrents

- -
Folder your Download program watches for NZBs -
- -
-
Binary retention time -
- -
Folder your Download program watches for Torrents -
- -
-
Number of minimum seeders a torrent must have to be accepted -
- -
Full path to the directory where your torrent client downloads your music
i.e. /Users/name/Downloads/music
-
-
- - -
- - -
-

L Search Providers

- "We provide you with a automated search service to locate binary files/secgments that can be found on the public access network called Usenet." - - -
- - - - - -
-

DNewznab Providers

- -
-
-
- - - - - - - - - - - - -
- - -
e.g. http://nzb.su -
- - -
- - -
-
-
- %for newznab in config['extra_newznabs']: - - - - - - - - - - - - - -
- - -
- - -
- -
- -
- %endfor - -
-
-
- - - -
- - - - - -

DNzbs.org

- -
-
- - - - - -
-
-
- - - - - - - - -
-

BitTorrent:

- A peer-to-peer file sharing (P2P) communications protocol -
- - -

- - -

- - -
- - -
- - - -
-

I Quality & Post Processing

- - - - - - - - - - - - - - -

Album Quality:

- -
- - -

- - -

- - -

- - -
- - - - - - - - - - -

Post Processing:

- -
- - -

- - -

- - -

- - -

- - -

- - -

- - -
- i.e. /Users/name/Music/iTunes or /Volumes/share/music -
-
- -
-

SAdvanced Settings

-
- - - - - - - - - - - - -

TRenaming

- Use: $Artist/$artist, $Album/$album, $Year/$year, $Type/$type (release type) and $First/$first (first letter in artist name)
- E.g.: $Type/$First/$artist/$album [$year] = Album/G/girl talk/all day [2010]
-
- Use: $Disc/$disc (disc #), $Track/$track (track #), $Title/$title, $Artist/$artist, $Album/$album and $Year/$year -
-
-
- - - - - - - - - - - - - - - - - - - -

FMiscellaneous

- Customize what HP -
-

Automatically:

- EPs, Compilations, Live Albums, Remix Albums and Singles -
- - -

- - -

- - -
- - - -
- - - -
-
- - -
-

Re-Encoding Options

- Re-encode downloads during postprocessing.
This option requires the lame or ffmpeg encoder.
-
- - - - - - - - - - - - - - - - -

Encoder Options

- - <% - if config['encoder'] == 'lame': - lameselect = 'selected="selected"' - ffmpegselect = '' - else: - lameselect = '' - ffmpegselect = 'selected="selected"' - %> -
- -
- -
-
- -
-

Audio Properties

- - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
- - <% - if config["samplingfrequency"] == 44100: - freq44100 = 'selected="selected"' - freq48000 = '' - else: - freq44100 = '' - freq48000 = 'selected="selected"' - %>
- - Ignores audio properties -
-
-
- - -
-

W Notifications

- - -
- - - - - -

Prowl Options

- -
-
- - - - - - - - - - - - - -
-
-
- - -
- - - - - -

XBMC

- -
-
- - - - - - - - - - - - - - - - - - - - - -
- e.g. http://localhost:8080. Separate hosts with commas - -
-
-
- - - -
- - - - - -
-

Notify My Android

- -
-
- - - - - - - - - - - - - - - - - - - -
- Separate multiple api keys with ",". -
Get NotifyMyAndroid
- -
-
-
- -
-

Synology NAS

- - - - -
- -
-
- -
-

KMirror

- - - - - - -
- -
- - - - - - - - - - - - - - - - -

Custom Options

- - - - - - - - - - - - - - - - -

Headphones Server

- DGet an Account -
- - - -
- -
-
- - - -<%def name="javascriptIncludes()"> - - diff --git a/data/interfaces/brink/css/jquery.dataTables_themeroller.css b/data/interfaces/brink/css/jquery.dataTables_themeroller.css deleted file mode 100644 index ad40bbfe..00000000 --- a/data/interfaces/brink/css/jquery.dataTables_themeroller.css +++ /dev/null @@ -1,245 +0,0 @@ - - -/* - * Table - */ -table.dataTable { - margin: 0 auto; - clear: both; - width: 100%; - border-collapse: collapse; -} - -table.dataTable thead th { - padding: 3px 0px 3px 10px; - cursor: pointer; - *cursor: hand; -} - -table.dataTable tfoot th { - padding: 3px 10px; -} - -table.dataTable td { - margin: 0px 0px 0px 0px; -} - -table.dataTable td.center, -table.dataTable td.dataTables_empty { - text-align: center; -} - -table.dataTable tr.odd { background-color: rgba(0,0,0,0.2); } -table.dataTable tr.even { background-color: rgba(0,0,0,0.2); } - -table.dataTable tr.odd td.sorting_1 { background-color: #D3D6FF; } -table.dataTable tr.odd td.sorting_2 { background-color: #DADCFF; } -table.dataTable tr.odd td.sorting_3 { background-color: #E0E2FF; } -table.dataTable tr.even td.sorting_1 { background-color: #EAEBFF; } -table.dataTable tr.even td.sorting_2 { background-color: #F2F3FF; } -table.dataTable tr.even td.sorting_3 { background-color: #F9F9FF; } - - -/* - * Table wrapper - */ -.dataTables_wrapper { - position: relative; - clear: both; - *zoom: 1; -} -.dataTables_wrapper .ui-widget-header { - font-weight: normal; -} -.dataTables_wrapper .ui-toolbar { - padding: 5px; -} - - -/* - * Page length menu - */ -.dataTables_length { - float: left; -} - - -/* - * Filter - */ -.dataTables_filter { - float: right; - text-align: right; -} - - -/* - * Table information - */ -.dataTables_info { - padding-top: 3px; - clear: both; - float: left; -} - - -/* - * Pagination - */ -.dataTables_paginate { - float: right; - text-align: right; -} - -.dataTables_paginate .ui-button { - margin-right: -0.1em !important; -} - -.paging_two_button .ui-button { - float: left; - cursor: pointer; - * cursor: hand; -} - -.paging_full_numbers .ui-button { - padding: 2px 6px; - margin: 0; - cursor: pointer; - * cursor: hand; - color: #333 !important; -} - -/* Two button pagination - previous / next */ -.paginate_disabled_previous, -.paginate_enabled_previous, -.paginate_disabled_next, -.paginate_enabled_next { - height: 19px; - float: left; - cursor: pointer; - *cursor: hand; - color: #111 !important; -} -.paginate_disabled_previous:hover, -.paginate_enabled_previous:hover, -.paginate_disabled_next:hover, -.paginate_enabled_next:hover { - text-decoration: none !important; -} -.paginate_disabled_previous:active, -.paginate_enabled_previous:active, -.paginate_disabled_next:active, -.paginate_enabled_next:active { - outline: none; -} - -.paginate_disabled_previous, -.paginate_disabled_next { - color: #666 !important; -} -.paginate_disabled_previous, -.paginate_enabled_previous { - padding-left: 23px; -} -.paginate_disabled_next, -.paginate_enabled_next { - padding-right: 23px; - margin-left: 10px; -} - -.paginate_enabled_previous { background: url('../images/back_enabled.png') no-repeat top left; } -.paginate_enabled_previous:hover { background: url('../images/back_enabled_hover.png') no-repeat top left; } -.paginate_disabled_previous { background: url('../images/back_disabled.png') no-repeat top left; } - -.paginate_enabled_next { background: url('../images/forward_enabled.png') no-repeat top right; } -.paginate_enabled_next:hover { background: url('../images/forward_enabled_hover.png') no-repeat top right; } -.paginate_disabled_next { background: url('../images/forward_disabled.png') no-repeat top right; } - -/* Full number pagination */ -.paging_full_numbers a:active { - outline: none -} -.paging_full_numbers a:hover { - text-decoration: none; -} - -.paging_full_numbers a.paginate_button, -.paging_full_numbers a.paginate_active { - border: 1px solid #aaa; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - padding: 2px 5px; - margin: 0 3px; - cursor: pointer; - *cursor: hand; - color: #333 !important; -} - -.paging_full_numbers a.paginate_button { - background-color: #ddd; -} - -.paging_full_numbers a.paginate_button:hover { - background-color: #ccc; - text-decoration: none !important; -} - -.paging_full_numbers a.paginate_active { - background-color: #99B3FF; -} - - -/* - * Processing indicator - */ -.dataTables_processing { - position: absolute; - top: 50%; - left: 50%; - width: 250px; - height: 30px; - margin-left: -125px; - margin-top: -15px; - padding: 14px 0 2px 0; - border: 1px solid #ddd; - text-align: center; - color: #999; - font-size: 14px; - background-color: white; -} - - -/* - * Sorting - */ -table.dataTable thead th div.DataTables_sort_wrapper { - position: relative; - padding-right: 20px; - padding-right: 20px; -} - -table.dataTable thead th div.DataTables_sort_wrapper span { - position: absolute; - top: 50%; - margin-top: -8px; - right: 0; -} - -table.dataTable th:active { - outline: none; -} - - -/* - * Scrolling - */ -.dataTables_scroll { - clear: both; -} - -.dataTables_scrollBody { - *margin-top: -1px; - -webkit-overflow-scrolling: touch; -} - diff --git a/data/interfaces/brink/css/jquery.jscrollpane.css b/data/interfaces/brink/css/jquery.jscrollpane.css deleted file mode 100644 index c84a762c..00000000 --- a/data/interfaces/brink/css/jquery.jscrollpane.css +++ /dev/null @@ -1,157 +0,0 @@ -/* - * CSS Styles that are needed by jScrollPane for it to operate correctly. - * - * Include this stylesheet in your site or copy and paste the styles below into your stylesheet - jScrollPane - * may not operate correctly without them. - */ - -.jspContainer -{ - overflow: hidden; - position: fixed; -} - -.jspPane -{ - position: absolute; -} - -.jspVerticalBar -{ - position: absolute; - top: 0; - right: 0; - width: 14px; - height: 100%; - border-left: 1px solid rgba(255,255,255,0.1); - padding: 1px; - background: rgb(55,65,76); /* Old browsers */ - background: -moz-linear-gradient(left, rgba(55,65,76,1) 0%, rgba(45,53,63,1) 100%); /* FF3.6+ */ - background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(55,65,76,1)), color-stop(100%,rgba(45,53,63,1))); /* Chrome,Safari4+ */ - background: -webkit-linear-gradient(left, rgba(55,65,76,1) 0%,rgba(45,53,63,1) 100%); /* Chrome10+,Safari5.1+ */ - background: -o-linear-gradient(left, rgba(55,65,76,1) 0%,rgba(45,53,63,1) 100%); /* Opera 11.10+ */ - background: -ms-linear-gradient(left, rgba(55,65,76,1) 0%,rgba(45,53,63,1) 100%); /* IE10+ */ - background: linear-gradient(left, rgba(55,65,76,1) 0%,rgba(45,53,63,1) 100%); /* W3C */ - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#37414c', endColorstr='#2d353f',GradientType=1 ); /* IE6-9 */ -} - -.jspHorizontalBar -{ - position: absolute; - bottom: 0; - left: 0; - width: 100%; - height: 10px; -} - -.jspVerticalBar *, -.jspHorizontalBar * -{ - margin: 0; - padding: 0; - -} - -.jspCap -{ - display: none; -} - -.jspHorizontalBar .jspCap -{ - float: left; -} - -.jspTrack -{ - position: relative; - border-radius: 1em; - background: rgb(13,15,17); /* Old browsers */ -background: -moz-linear-gradient(left, rgba(13,15,17,1) 0%, rgba(23,28,33,1) 100%); /* FF3.6+ */ -background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(13,15,17,1)), color-stop(100%,rgba(23,28,33,1))); /* Chrome,Safari4+ */ -background: -webkit-linear-gradient(left, rgba(13,15,17,1) 0%,rgba(23,28,33,1) 100%); /* Chrome10+,Safari5.1+ */ -background: -o-linear-gradient(left, rgba(13,15,17,1) 0%,rgba(23,28,33,1) 100%); /* Opera 11.10+ */ -background: -ms-linear-gradient(left, rgba(13,15,17,1) 0%,rgba(23,28,33,1) 100%); /* IE10+ */ -background: linear-gradient(left, rgba(13,15,17,1) 0%,rgba(23,28,33,1) 100%); /* W3C */ -filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#0d0f11', endColorstr='#171c21',GradientType=1 ); /* IE6-9 */ -} - -.jspDrag -{ - position: relative; - top: 0; - left: 0; - cursor: pointer; - border-left: 1px solid rgba(255,255,255,0.1); - border-radius: 1em; - background: rgb(112,135,158); /* Old browsers */ -background: -moz-linear-gradient(left, rgba(112,135,158,1) 0%, rgba(76,90,107,1) 100%); /* FF3.6+ */ -background: -webkit-gradient(linear, left top, right top, color-stop(0%,rgba(112,135,158,1)), color-stop(100%,rgba(76,90,107,1))); /* Chrome,Safari4+ */ -background: -webkit-linear-gradient(left, rgba(112,135,158,1) 0%,rgba(76,90,107,1) 100%); /* Chrome10+,Safari5.1+ */ -background: -o-linear-gradient(left, rgba(112,135,158,1) 0%,rgba(76,90,107,1) 100%); /* Opera 11.10+ */ -background: -ms-linear-gradient(left, rgba(112,135,158,1) 0%,rgba(76,90,107,1) 100%); /* IE10+ */ -background: linear-gradient(left, rgba(112,135,158,1) 0%,rgba(76,90,107,1) 100%); /* W3C */ -filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#70879e', endColorstr='#4c5a6b',GradientType=1 ); /* IE6-9 */ -} -.jspDrag:active, -.jspDrag:hover -{ -} - -.jspHorizontalBar .jspTrack, -.jspHorizontalBar .jspDrag -{ - float: left; - height: 100%; -} - -.jspArrow -{ - display: block; - cursor: pointer; - font-family: 'WebSymbolsRegular'; - font-size: 0.1em; -} - -.jspArrow.jspDisabled -{ - cursor: default; -} - -.jspVerticalBar .jspArrow .jspArrowUp:after { - content: ':'; -} -.jspVerticalBar .jspArrow .jspArrowDown:after { - content: ';'; -} -.jspVerticalBar .jspArrow -{ - height: 16px; - width: 100%; -} - - -.jspHorizontalBar .jspArrow -{ - width: 16px; - float: left; - height: 100%; -} - -.jspVerticalBar .jspArrow:focus -{ - outline: none; -} - -.jspCorner -{ - background: #eeeef4; - float: left; - height: 100%; -} - -/* Yuk! CSS Hack for IE6 3 pixel bug :( */ -* html .jspCorner -{ - margin: 0 -3px 0 0; -} \ No newline at end of file diff --git a/data/interfaces/brink/css/libs/dataTable.css b/data/interfaces/brink/css/libs/dataTable.css deleted file mode 100644 index 3ce7e1a3..00000000 --- a/data/interfaces/brink/css/libs/dataTable.css +++ /dev/null @@ -1,113 +0,0 @@ -.dataTables_wrapper { - width: 100%; - background-color: #313131; - min-height: 155px; - clear: both; - _height: 302px; - zoom: 1; /* Feeling sorry for IE */ - z-index: 1; -} - -.dataTables_processing { - position: absolute; - top: 50%; - left: 50%; - width: 20px; - height: 30px; - margin-left: -125px; - margin-top: -15px; - padding: 14px 0 2px 0; - border: 1px solid #ddd; - text-align: center; - color: #999; - font-size: 14px; - background-color: #343434; -} - -.dataTables_length { - /* - * Look in styles.css - * */ -} - -.dataTables_filter { - /* - * Look in style.css - * */ -} - -.dataTables_info { - /* - * Look in style.css - * */ -} - -.dataTables_paginate { - width: 44px; - * width: 50px; - float: left; - text-align: right; - margin-top: 15px; - padding: 5px; -} - -/* Pagination nested */ -.paginate_disabled_previous, .paginate_enabled_previous, .paginate_disabled_next, .paginate_enabled_next { - height: 19px; - width: 19px; - margin-left: 3px; - float: left; -} - -.paginate_disabled_previous { - background-image: url('../images/back_disabled.jpg'); -} - -.paginate_enabled_previous { - background-image: url('../images/back_enabled.jpg'); -} - -.paginate_disabled_next { - background-image: url('../images/forward_disabled.jpg'); -} - -.paginate_enabled_next { - background-image: url('../images/forward_enabled.jpg'); -} - - - -/* * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * - * DataTables display - */ -table.display { - margin: auto; - width: 100%; - clear: both; - border-collapse: collapse; - -} -table.display tbody tr:hover td{ - background-color: rgba(255,255,255,0.1); -} - -table.display thead th { - /*Moved*/ -} - -table.display tfoot th { - /*Moved*/ -} - -table.display tr.heading2 td { - border-bottom: 1px solid #aaa; -} - -table.display td { - /* Moved */ -} - -table.display td.center { - text-align: center; -} - diff --git a/data/interfaces/brink/css/libs/jquery-ui-1.8.23.custom.css b/data/interfaces/brink/css/libs/jquery-ui-1.8.23.custom.css deleted file mode 100644 index f46e8031..00000000 --- a/data/interfaces/brink/css/libs/jquery-ui-1.8.23.custom.css +++ /dev/null @@ -1,563 +0,0 @@ -/*! - * jQuery UI CSS Framework 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Theming/API - */ - -/* Layout helpers -----------------------------------*/ -.ui-helper-hidden { display: none; } -.ui-helper-hidden-accessible { position: absolute !important; clip: rect(1px 1px 1px 1px); clip: rect(1px,1px,1px,1px); } -.ui-helper-reset { margin: 0; padding: 0; border: 0; outline: 0; line-height: 1.3; text-decoration: none; font-size: 100%; list-style: none; } -.ui-helper-clearfix:before, .ui-helper-clearfix:after { content: ""; display: table; } -.ui-helper-clearfix:after { clear: both; } -.ui-helper-clearfix { zoom: 1; } -.ui-helper-zfix { width: 100%; height: 100%; top: 0; left: 0; position: absolute; opacity: 0; filter:Alpha(Opacity=0); } - - -/* Interaction Cues -----------------------------------*/ -.ui-state-disabled { cursor: default !important; } - - -/* Icons -----------------------------------*/ - -/* states and images */ -.ui-icon { display: block; text-indent: -99999px; overflow: hidden; background-repeat: no-repeat; } - - -/* Misc visuals -----------------------------------*/ - -/* Overlays */ -.ui-widget-overlay { position: absolute; top: 0; left: 0; width: 100%; height: 100%; } - - -/*! - * jQuery UI CSS Framework 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Theming/API - * - * To view and modify this theme, visit http://jqueryui.com/themeroller/?ffDefault=Century%20Gothic,Verdana,Arial,sans-serif&fwDefault=normal&fsDefault=1em&cornerRadius=0px&bgColorHeader=252c34&bgTextureHeader=03_highlight_soft.png&bgImgOpacityHeader=20&borderColorHeader=000000&fcHeader=0091ff&iconColorHeader=0091ff&bgColorContent=192126&bgTextureContent=01_flat.png&bgImgOpacityContent=100&borderColorContent=363636&fcContent=ffffff&iconColorContent=ffffff&bgColorDefault=283943&bgTextureDefault=01_flat.png&bgImgOpacityDefault=1000&borderColorDefault=242424&fcDefault=a1a1a1&iconColorDefault=888888&bgColorHover=3c444b&bgTextureHover=01_flat.png&bgImgOpacityHover=75&borderColorHover=999999&fcHover=ffffff&iconColorHover=ffffff&bgColorActive=0091ff&bgTextureActive=01_flat.png&bgImgOpacityActive=65&borderColorActive=aaaaaa&fcActive=212121&iconColorActive=454545&bgColorHighlight=fbf9ee&bgTextureHighlight=02_glass.png&bgImgOpacityHighlight=55&borderColorHighlight=fcefa1&fcHighlight=363636&iconColorHighlight=2e83ff&bgColorError=fef1ec&bgTextureError=05_inset_soft.png&bgImgOpacityError=95&borderColorError=cd0a0a&fcError=cd0a0a&iconColorError=cd0a0a&bgColorOverlay=aaaaaa&bgTextureOverlay=01_flat.png&bgImgOpacityOverlay=0&opacityOverlay=30&bgColorShadow=aaaaaa&bgTextureShadow=01_flat.png&bgImgOpacityShadow=0&opacityShadow=30&thicknessShadow=8px&offsetTopShadow=-8px&offsetLeftShadow=-8px&cornerRadiusShadow=8px - */ - - -/* Component containers -----------------------------------*/ -.ui-widget { font-family: Century Gothic,Verdana,Arial,sans-serif; font-size: 1em; } -.ui-widget .ui-widget { font-size: 1em; } -.ui-widget input, .ui-widget select, .ui-widget textarea, .ui-widget button { font-family: Century Gothic,Verdana,Arial,sans-serif; font-size: 1em; } -.ui-widget-content { border: 1px solid #363636; background: #192126 url(images/ui-bg_flat_100_192126_40x100.png) 50% 50% repeat-x; color: #ffffff; } -.ui-widget-content a { color: #ffffff; } -.ui-widget-header { border: 1px solid #000000; background: #252c34 url(images/ui-bg_highlight-soft_20_252c34_1x100.png) 50% 50% repeat-x; color: #0091ff; font-weight: bold; } -.ui-widget-header a { color: #0091ff; } - -/* Interaction states -----------------------------------*/ -.ui-state-default, .ui-widget-content .ui-state-default, .ui-widget-header .ui-state-default { border: 1px solid #242424; background: #283943 url(images/ui-bg_flat_1000_283943_40x100.png) 50% 50% repeat-x; font-weight: normal; color: #a1a1a1; } -.ui-state-default a, .ui-state-default a:link, .ui-state-default a:visited { color: #a1a1a1; text-decoration: none; } -.ui-state-hover, .ui-widget-content .ui-state-hover, .ui-widget-header .ui-state-hover, .ui-state-focus, .ui-widget-content .ui-state-focus, .ui-widget-header .ui-state-focus { border: 1px solid #999999; background: #3c444b url(images/ui-bg_flat_75_3c444b_40x100.png) 50% 50% repeat-x; font-weight: normal; color: #ffffff; } -.ui-state-hover a, .ui-state-hover a:hover { color: #ffffff; text-decoration: none; } -.ui-state-active, .ui-widget-content .ui-state-active, .ui-widget-header .ui-state-active { border: 1px solid #aaaaaa; background: #0091ff url(images/ui-bg_flat_65_0091ff_40x100.png) 50% 50% repeat-x; font-weight: normal; color: #212121; } -.ui-state-active a, .ui-state-active a:link, .ui-state-active a:visited { color: #212121; text-decoration: none; } -.ui-widget :active { outline: none; } - -/* Interaction Cues -----------------------------------*/ -.ui-state-highlight, .ui-widget-content .ui-state-highlight, .ui-widget-header .ui-state-highlight {border: 1px solid #fcefa1; background: #fbf9ee url(images/ui-bg_glass_55_fbf9ee_1x400.png) 50% 50% repeat-x; color: #363636; } -.ui-state-highlight a, .ui-widget-content .ui-state-highlight a,.ui-widget-header .ui-state-highlight a { color: #363636; } -.ui-state-error, .ui-widget-content .ui-state-error, .ui-widget-header .ui-state-error {border: 1px solid #cd0a0a; background: #fef1ec url(images/ui-bg_inset-soft_95_fef1ec_1x100.png) 50% bottom repeat-x; color: #cd0a0a; } -.ui-state-error a, .ui-widget-content .ui-state-error a, .ui-widget-header .ui-state-error a { color: #cd0a0a; } -.ui-state-error-text, .ui-widget-content .ui-state-error-text, .ui-widget-header .ui-state-error-text { color: #cd0a0a; } -.ui-priority-primary, .ui-widget-content .ui-priority-primary, .ui-widget-header .ui-priority-primary { font-weight: bold; } -.ui-priority-secondary, .ui-widget-content .ui-priority-secondary, .ui-widget-header .ui-priority-secondary { opacity: .7; filter:Alpha(Opacity=70); font-weight: normal; } -.ui-state-disabled, .ui-widget-content .ui-state-disabled, .ui-widget-header .ui-state-disabled { opacity: .35; filter:Alpha(Opacity=35); background-image: none; } - -/* Icons -----------------------------------*/ - -/* states and images */ -.ui-icon { width: 16px; height: 16px; background-image: url(images/ui-icons_ffffff_256x240.png); } -.ui-widget-content .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } -.ui-widget-header .ui-icon {background-image: url(images/ui-icons_0091ff_256x240.png); } -.ui-state-default .ui-icon { background-image: url(images/ui-icons_888888_256x240.png); } -.ui-state-hover .ui-icon, .ui-state-focus .ui-icon {background-image: url(images/ui-icons_ffffff_256x240.png); } -.ui-state-active .ui-icon {background-image: url(images/ui-icons_454545_256x240.png); } -.ui-state-highlight .ui-icon {background-image: url(images/ui-icons_2e83ff_256x240.png); } -.ui-state-error .ui-icon, .ui-state-error-text .ui-icon {background-image: url(images/ui-icons_cd0a0a_256x240.png); } - -/* positioning */ -.ui-icon-carat-1-n { background-position: 0 0; } -.ui-icon-carat-1-ne { background-position: -16px 0; } -.ui-icon-carat-1-e { background-position: -32px 0; } -.ui-icon-carat-1-se { background-position: -48px 0; } -.ui-icon-carat-1-s { background-position: -64px 0; } -.ui-icon-carat-1-sw { background-position: -80px 0; } -.ui-icon-carat-1-w { background-position: -96px 0; } -.ui-icon-carat-1-nw { background-position: -112px 0; } -.ui-icon-carat-2-n-s { background-position: -128px 0; } -.ui-icon-carat-2-e-w { background-position: -144px 0; } -.ui-icon-triangle-1-n { background-position: 0 -16px; } -.ui-icon-triangle-1-ne { background-position: -16px -16px; } -.ui-icon-triangle-1-e { background-position: -32px -16px; } -.ui-icon-triangle-1-se { background-position: -48px -16px; } -.ui-icon-triangle-1-s { background-position: -64px -16px; } -.ui-icon-triangle-1-sw { background-position: -80px -16px; } -.ui-icon-triangle-1-w { background-position: -96px -16px; } -.ui-icon-triangle-1-nw { background-position: -112px -16px; } -.ui-icon-triangle-2-n-s { background-position: -128px -16px; } -.ui-icon-triangle-2-e-w { background-position: -144px -16px; } -.ui-icon-arrow-1-n { background-position: 0 -32px; } -.ui-icon-arrow-1-ne { background-position: -16px -32px; } -.ui-icon-arrow-1-e { background-position: -32px -32px; } -.ui-icon-arrow-1-se { background-position: -48px -32px; } -.ui-icon-arrow-1-s { background-position: -64px -32px; } -.ui-icon-arrow-1-sw { background-position: -80px -32px; } -.ui-icon-arrow-1-w { background-position: -96px -32px; } -.ui-icon-arrow-1-nw { background-position: -112px -32px; } -.ui-icon-arrow-2-n-s { background-position: -128px -32px; } -.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } -.ui-icon-arrow-2-e-w { background-position: -160px -32px; } -.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } -.ui-icon-arrowstop-1-n { background-position: -192px -32px; } -.ui-icon-arrowstop-1-e { background-position: -208px -32px; } -.ui-icon-arrowstop-1-s { background-position: -224px -32px; } -.ui-icon-arrowstop-1-w { background-position: -240px -32px; } -.ui-icon-arrowthick-1-n { background-position: 0 -48px; } -.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } -.ui-icon-arrowthick-1-e { background-position: -32px -48px; } -.ui-icon-arrowthick-1-se { background-position: -48px -48px; } -.ui-icon-arrowthick-1-s { background-position: -64px -48px; } -.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } -.ui-icon-arrowthick-1-w { background-position: -96px -48px; } -.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } -.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } -.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } -.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } -.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } -.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } -.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } -.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } -.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } -.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } -.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } -.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } -.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } -.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } -.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } -.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } -.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } -.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } -.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } -.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } -.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } -.ui-icon-arrow-4 { background-position: 0 -80px; } -.ui-icon-arrow-4-diag { background-position: -16px -80px; } -.ui-icon-extlink { background-position: -32px -80px; } -.ui-icon-newwin { background-position: -48px -80px; } -.ui-icon-refresh { background-position: -64px -80px; } -.ui-icon-shuffle { background-position: -80px -80px; } -.ui-icon-transfer-e-w { background-position: -96px -80px; } -.ui-icon-transferthick-e-w { background-position: -112px -80px; } -.ui-icon-folder-collapsed { background-position: 0 -96px; } -.ui-icon-folder-open { background-position: -16px -96px; } -.ui-icon-document { background-position: -32px -96px; } -.ui-icon-document-b { background-position: -48px -96px; } -.ui-icon-note { background-position: -64px -96px; } -.ui-icon-mail-closed { background-position: -80px -96px; } -.ui-icon-mail-open { background-position: -96px -96px; } -.ui-icon-suitcase { background-position: -112px -96px; } -.ui-icon-comment { background-position: -128px -96px; } -.ui-icon-person { background-position: -144px -96px; } -.ui-icon-print { background-position: -160px -96px; } -.ui-icon-trash { background-position: -176px -96px; } -.ui-icon-locked { background-position: -192px -96px; } -.ui-icon-unlocked { background-position: -208px -96px; } -.ui-icon-bookmark { background-position: -224px -96px; } -.ui-icon-tag { background-position: -240px -96px; } -.ui-icon-home { background-position: 0 -112px; } -.ui-icon-flag { background-position: -16px -112px; } -.ui-icon-calendar { background-position: -32px -112px; } -.ui-icon-cart { background-position: -48px -112px; } -.ui-icon-pencil { background-position: -64px -112px; } -.ui-icon-clock { background-position: -80px -112px; } -.ui-icon-disk { background-position: -96px -112px; } -.ui-icon-calculator { background-position: -112px -112px; } -.ui-icon-zoomin { background-position: -128px -112px; } -.ui-icon-zoomout { background-position: -144px -112px; } -.ui-icon-search { background-position: -160px -112px; } -.ui-icon-wrench { background-position: -176px -112px; } -.ui-icon-gear { background-position: -192px -112px; } -.ui-icon-heart { background-position: -208px -112px; } -.ui-icon-star { background-position: -224px -112px; } -.ui-icon-link { background-position: -240px -112px; } -.ui-icon-cancel { background-position: 0 -128px; } -.ui-icon-plus { background-position: -16px -128px; } -.ui-icon-plusthick { background-position: -32px -128px; } -.ui-icon-minus { background-position: -48px -128px; } -.ui-icon-minusthick { background-position: -64px -128px; } -.ui-icon-close { background-position: -80px -128px; } -.ui-icon-closethick { background-position: -96px -128px; } -.ui-icon-key { background-position: -112px -128px; } -.ui-icon-lightbulb { background-position: -128px -128px; } -.ui-icon-scissors { background-position: -144px -128px; } -.ui-icon-clipboard { background-position: -160px -128px; } -.ui-icon-copy { background-position: -176px -128px; } -.ui-icon-contact { background-position: -192px -128px; } -.ui-icon-image { background-position: -208px -128px; } -.ui-icon-video { background-position: -224px -128px; } -.ui-icon-script { background-position: -240px -128px; } -.ui-icon-alert { background-position: 0 -144px; } -.ui-icon-info { background-position: -16px -144px; } -.ui-icon-notice { background-position: -32px -144px; } -.ui-icon-help { background-position: -48px -144px; } -.ui-icon-check { background-position: -64px -144px; } -.ui-icon-bullet { background-position: -80px -144px; } -.ui-icon-radio-off { background-position: -96px -144px; } -.ui-icon-radio-on { background-position: -112px -144px; } -.ui-icon-pin-w { background-position: -128px -144px; } -.ui-icon-pin-s { background-position: -144px -144px; } -.ui-icon-play { background-position: 0 -160px; } -.ui-icon-pause { background-position: -16px -160px; } -.ui-icon-seek-next { background-position: -32px -160px; } -.ui-icon-seek-prev { background-position: -48px -160px; } -.ui-icon-seek-end { background-position: -64px -160px; } -.ui-icon-seek-start { background-position: -80px -160px; } -/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ -.ui-icon-seek-first { background-position: -80px -160px; } -.ui-icon-stop { background-position: -96px -160px; } -.ui-icon-eject { background-position: -112px -160px; } -.ui-icon-volume-off { background-position: -128px -160px; } -.ui-icon-volume-on { background-position: -144px -160px; } -.ui-icon-power { background-position: 0 -176px; } -.ui-icon-signal-diag { background-position: -16px -176px; } -.ui-icon-signal { background-position: -32px -176px; } -.ui-icon-battery-0 { background-position: -48px -176px; } -.ui-icon-battery-1 { background-position: -64px -176px; } -.ui-icon-battery-2 { background-position: -80px -176px; } -.ui-icon-battery-3 { background-position: -96px -176px; } -.ui-icon-circle-plus { background-position: 0 -192px; } -.ui-icon-circle-minus { background-position: -16px -192px; } -.ui-icon-circle-close { background-position: -32px -192px; } -.ui-icon-circle-triangle-e { background-position: -48px -192px; } -.ui-icon-circle-triangle-s { background-position: -64px -192px; } -.ui-icon-circle-triangle-w { background-position: -80px -192px; } -.ui-icon-circle-triangle-n { background-position: -96px -192px; } -.ui-icon-circle-arrow-e { background-position: -112px -192px; } -.ui-icon-circle-arrow-s { background-position: -128px -192px; } -.ui-icon-circle-arrow-w { background-position: -144px -192px; } -.ui-icon-circle-arrow-n { background-position: -160px -192px; } -.ui-icon-circle-zoomin { background-position: -176px -192px; } -.ui-icon-circle-zoomout { background-position: -192px -192px; } -.ui-icon-circle-check { background-position: -208px -192px; } -.ui-icon-circlesmall-plus { background-position: 0 -208px; } -.ui-icon-circlesmall-minus { background-position: -16px -208px; } -.ui-icon-circlesmall-close { background-position: -32px -208px; } -.ui-icon-squaresmall-plus { background-position: -48px -208px; } -.ui-icon-squaresmall-minus { background-position: -64px -208px; } -.ui-icon-squaresmall-close { background-position: -80px -208px; } -.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } -.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } -.ui-icon-grip-solid-vertical { background-position: -32px -224px; } -.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } -.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } -.ui-icon-grip-diagonal-se { background-position: -80px -224px; } - - -/* Misc visuals -----------------------------------*/ - -/* Corner radius */ -.ui-corner-all, .ui-corner-top, .ui-corner-left, .ui-corner-tl { -moz-border-radius-topleft: 0px; -webkit-border-top-left-radius: 0px; -khtml-border-top-left-radius: 0px; border-top-left-radius: 0px; } -.ui-corner-all, .ui-corner-top, .ui-corner-right, .ui-corner-tr { -moz-border-radius-topright: 0px; -webkit-border-top-right-radius: 0px; -khtml-border-top-right-radius: 0px; border-top-right-radius: 0px; } -.ui-corner-all, .ui-corner-bottom, .ui-corner-left, .ui-corner-bl { -moz-border-radius-bottomleft: 0px; -webkit-border-bottom-left-radius: 0px; -khtml-border-bottom-left-radius: 0px; border-bottom-left-radius: 0px; } -.ui-corner-all, .ui-corner-bottom, .ui-corner-right, .ui-corner-br { -moz-border-radius-bottomright: 0px; -webkit-border-bottom-right-radius: 0px; -khtml-border-bottom-right-radius: 0px; border-bottom-right-radius: 0px; } - -/* Overlays */ -.ui-widget-overlay { background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); } -.ui-widget-shadow { margin: -8px 0 0 -8px; padding: 8px; background: #aaaaaa url(images/ui-bg_flat_0_aaaaaa_40x100.png) 50% 50% repeat-x; opacity: .30;filter:Alpha(Opacity=30); -moz-border-radius: 8px; -khtml-border-radius: 8px; -webkit-border-radius: 8px; border-radius: 8px; }/*! - * jQuery UI Resizable 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Resizable#theming - */ -.ui-resizable { position: relative;} -.ui-resizable-handle { position: absolute;font-size: 0.1px; display: block; } -.ui-resizable-disabled .ui-resizable-handle, .ui-resizable-autohide .ui-resizable-handle { display: none; } -.ui-resizable-n { cursor: n-resize; height: 7px; width: 100%; top: -5px; left: 0; } -.ui-resizable-s { cursor: s-resize; height: 7px; width: 100%; bottom: -5px; left: 0; } -.ui-resizable-e { cursor: e-resize; width: 7px; right: -5px; top: 0; height: 100%; } -.ui-resizable-w { cursor: w-resize; width: 7px; left: -5px; top: 0; height: 100%; } -.ui-resizable-se { cursor: se-resize; width: 12px; height: 12px; right: 1px; bottom: 1px; } -.ui-resizable-sw { cursor: sw-resize; width: 9px; height: 9px; left: -5px; bottom: -5px; } -.ui-resizable-nw { cursor: nw-resize; width: 9px; height: 9px; left: -5px; top: -5px; } -.ui-resizable-ne { cursor: ne-resize; width: 9px; height: 9px; right: -5px; top: -5px;}/*! - * jQuery UI Selectable 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Selectable#theming - */ -.ui-selectable-helper { position: absolute; z-index: 100; border:1px dotted black; } -/*! - * jQuery UI Accordion 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Accordion#theming - */ -/* IE/Win - Fix animation bug - #4615 */ -.ui-accordion { width: 100%; } -.ui-accordion .ui-accordion-header { cursor: pointer; position: relative; margin-top: 1px; zoom: 1; } -.ui-accordion .ui-accordion-li-fix { display: inline; } -.ui-accordion .ui-accordion-header-active { border-bottom: 0 !important; } -.ui-accordion .ui-accordion-header a { display: block; font-size: 1em; padding: .5em .5em .5em .7em; } -.ui-accordion-icons .ui-accordion-header a { padding-left: 2.2em; } -.ui-accordion .ui-accordion-header .ui-icon { position: absolute; left: .5em; top: 50%; margin-top: -8px; } -.ui-accordion .ui-accordion-content { padding: 1em 2.2em; border-top: 0; margin-top: -2px; position: relative; top: 1px; margin-bottom: 2px; overflow: auto; display: none; zoom: 1; } -.ui-accordion .ui-accordion-content-active { display: block; } -/*! - * jQuery UI Autocomplete 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Autocomplete#theming - */ -.ui-autocomplete { position: absolute; cursor: default; } - -/* workarounds */ -* html .ui-autocomplete { width:1px; } /* without this, the menu expands to 100% in IE6 */ - -/* - * jQuery UI Menu 1.8.23 - * - * Copyright 2010, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Menu#theming - */ -.ui-menu { - list-style:none; - padding: 2px; - margin: 0; - display:block; - float: left; -} -.ui-menu .ui-menu { - margin-top: -3px; -} -.ui-menu .ui-menu-item { - margin:0; - padding: 0; - zoom: 1; - float: left; - clear: left; - width: 100%; -} -.ui-menu .ui-menu-item a { - text-decoration:none; - display:block; - padding:.2em .4em; - line-height:1.5; - zoom:1; -} -.ui-menu .ui-menu-item a.ui-state-hover, -.ui-menu .ui-menu-item a.ui-state-active { - font-weight: normal; - margin: -1px; -} -/*! - * jQuery UI Button 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Button#theming - */ -.ui-button { display: inline-block; position: relative; padding: 0; margin-right: .1em; text-decoration: none !important; cursor: pointer; text-align: center; zoom: 1; overflow: visible; } /* the overflow property removes extra width in IE */ -.ui-button-icon-only { width: 2.2em; } /* to make room for the icon, a width needs to be set here */ -button.ui-button-icon-only { width: 2.4em; } /* button elements seem to need a little more width */ -.ui-button-icons-only { width: 3.4em; } -button.ui-button-icons-only { width: 3.7em; } - -/*button text element */ -.ui-button .ui-button-text { display: block; line-height: 1.4; } -.ui-button-text-only .ui-button-text { padding: .4em 1em; } -.ui-button-icon-only .ui-button-text, .ui-button-icons-only .ui-button-text { padding: .4em; text-indent: -9999999px; } -.ui-button-text-icon-primary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 1em .4em 2.1em; } -.ui-button-text-icon-secondary .ui-button-text, .ui-button-text-icons .ui-button-text { padding: .4em 2.1em .4em 1em; } -.ui-button-text-icons .ui-button-text { padding-left: 2.1em; padding-right: 2.1em; } -/* no icon support for input elements, provide padding by default */ -input.ui-button { padding: .4em 1em; } - -/*button icon element(s) */ -.ui-button-icon-only .ui-icon, .ui-button-text-icon-primary .ui-icon, .ui-button-text-icon-secondary .ui-icon, .ui-button-text-icons .ui-icon, .ui-button-icons-only .ui-icon { position: absolute; top: 50%; margin-top: -8px; } -.ui-button-icon-only .ui-icon { left: 50%; margin-left: -8px; } -.ui-button-text-icon-primary .ui-button-icon-primary, .ui-button-text-icons .ui-button-icon-primary, .ui-button-icons-only .ui-button-icon-primary { left: .5em; } -.ui-button-text-icon-secondary .ui-button-icon-secondary, .ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } -.ui-button-text-icons .ui-button-icon-secondary, .ui-button-icons-only .ui-button-icon-secondary { right: .5em; } - -/*button sets*/ -.ui-buttonset { margin-right: 7px; } -.ui-buttonset .ui-button { margin-left: 0; margin-right: -.3em; } - -/* workarounds */ -button.ui-button::-moz-focus-inner { border: 0; padding: 0; } /* reset extra padding in Firefox */ -/*! - * jQuery UI Dialog 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Dialog#theming - */ -.ui-dialog { position: absolute; padding: .2em; width: 300px; overflow: hidden; } -.ui-dialog .ui-dialog-titlebar { padding: .4em 1em; position: relative; } -.ui-dialog .ui-dialog-title { float: left; margin: .1em 16px .1em 0; } -.ui-dialog .ui-dialog-titlebar-close { position: absolute; right: .3em; top: 50%; width: 19px; margin: -10px 0 0 0; padding: 1px; height: 18px; } -.ui-dialog .ui-dialog-titlebar-close span { display: block; margin: 1px; } -.ui-dialog .ui-dialog-titlebar-close:hover, .ui-dialog .ui-dialog-titlebar-close:focus { padding: 0; } -.ui-dialog .ui-dialog-content { position: relative; border: 0; padding: .5em 1em; background: none; overflow: auto; zoom: 1; } -.ui-dialog .ui-dialog-buttonpane { text-align: left; border-width: 1px 0 0 0; background-image: none; margin: .5em 0 0 0; padding: .3em 1em .5em .4em; } -.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { float: right; } -.ui-dialog .ui-dialog-buttonpane button { margin: .5em .4em .5em 0; cursor: pointer; } -.ui-dialog .ui-resizable-se { width: 14px; height: 14px; right: 3px; bottom: 3px; } -.ui-draggable .ui-dialog-titlebar { cursor: move; } -/*! - * jQuery UI Slider 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Slider#theming - */ -.ui-slider { position: relative; text-align: left; } -.ui-slider .ui-slider-handle { position: absolute; z-index: 2; width: 1.2em; height: 1.2em; cursor: default; } -.ui-slider .ui-slider-range { position: absolute; z-index: 1; font-size: .7em; display: block; border: 0; background-position: 0 0; } - -.ui-slider-horizontal { height: .8em; } -.ui-slider-horizontal .ui-slider-handle { top: -.3em; margin-left: -.6em; } -.ui-slider-horizontal .ui-slider-range { top: 0; height: 100%; } -.ui-slider-horizontal .ui-slider-range-min { left: 0; } -.ui-slider-horizontal .ui-slider-range-max { right: 0; } - -.ui-slider-vertical { width: .8em; height: 100px; } -.ui-slider-vertical .ui-slider-handle { left: -.3em; margin-left: 0; margin-bottom: -.6em; } -.ui-slider-vertical .ui-slider-range { left: 0; width: 100%; } -.ui-slider-vertical .ui-slider-range-min { bottom: 0; } -.ui-slider-vertical .ui-slider-range-max { top: 0; }/*! - * jQuery UI Tabs 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Tabs#theming - */ -.ui-tabs { position: relative; padding: .2em; zoom: 1; } /* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ -.ui-tabs .ui-tabs-nav { margin: 0; padding: .2em .2em 0; } -.ui-tabs .ui-tabs-nav li { list-style: none; float: left; position: relative; top: 1px; margin: 0 .2em 1px 0; border-bottom: 0 !important; padding: 0; white-space: nowrap; } -.ui-tabs .ui-tabs-nav li a { float: left; padding: .5em 1em; text-decoration: none; } -.ui-tabs .ui-tabs-nav li.ui-tabs-selected { margin-bottom: 0; padding-bottom: 1px; } -.ui-tabs .ui-tabs-nav li.ui-tabs-selected a, .ui-tabs .ui-tabs-nav li.ui-state-disabled a, .ui-tabs .ui-tabs-nav li.ui-state-processing a { cursor: text; } -.ui-tabs .ui-tabs-nav li a, .ui-tabs.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-selected a { cursor: pointer; } /* first selector in group seems obsolete, but required to overcome bug in Opera applying cursor: text overall if defined elsewhere... */ -.ui-tabs .ui-tabs-panel { display: block; border-width: 0; padding: 1em 1.4em; background: none; } -.ui-tabs .ui-tabs-hide { display: none !important; } -/*! - * jQuery UI Datepicker 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Datepicker#theming - */ -.ui-datepicker { width: 17em; padding: .2em .2em 0; display: none; } -.ui-datepicker .ui-datepicker-header { position:relative; padding:.2em 0; } -.ui-datepicker .ui-datepicker-prev, .ui-datepicker .ui-datepicker-next { position:absolute; top: 2px; width: 1.8em; height: 1.8em; } -.ui-datepicker .ui-datepicker-prev-hover, .ui-datepicker .ui-datepicker-next-hover { top: 1px; } -.ui-datepicker .ui-datepicker-prev { left:2px; } -.ui-datepicker .ui-datepicker-next { right:2px; } -.ui-datepicker .ui-datepicker-prev-hover { left:1px; } -.ui-datepicker .ui-datepicker-next-hover { right:1px; } -.ui-datepicker .ui-datepicker-prev span, .ui-datepicker .ui-datepicker-next span { display: block; position: absolute; left: 50%; margin-left: -8px; top: 50%; margin-top: -8px; } -.ui-datepicker .ui-datepicker-title { margin: 0 2.3em; line-height: 1.8em; text-align: center; } -.ui-datepicker .ui-datepicker-title select { font-size:1em; margin:1px 0; } -.ui-datepicker select.ui-datepicker-month-year {width: 100%;} -.ui-datepicker select.ui-datepicker-month, -.ui-datepicker select.ui-datepicker-year { width: 49%;} -.ui-datepicker table {width: 100%; font-size: .9em; border-collapse: collapse; margin:0 0 .4em; } -.ui-datepicker th { padding: .7em .3em; text-align: center; font-weight: bold; border: 0; } -.ui-datepicker td { border: 0; padding: 1px; } -.ui-datepicker td span, .ui-datepicker td a { display: block; padding: .2em; text-align: right; text-decoration: none; } -.ui-datepicker .ui-datepicker-buttonpane { background-image: none; margin: .7em 0 0 0; padding:0 .2em; border-left: 0; border-right: 0; border-bottom: 0; } -.ui-datepicker .ui-datepicker-buttonpane button { float: right; margin: .5em .2em .4em; cursor: pointer; padding: .2em .6em .3em .6em; width:auto; overflow:visible; } -.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { float:left; } - -/* with multiple calendars */ -.ui-datepicker.ui-datepicker-multi { width:auto; } -.ui-datepicker-multi .ui-datepicker-group { float:left; } -.ui-datepicker-multi .ui-datepicker-group table { width:95%; margin:0 auto .4em; } -.ui-datepicker-multi-2 .ui-datepicker-group { width:50%; } -.ui-datepicker-multi-3 .ui-datepicker-group { width:33.3%; } -.ui-datepicker-multi-4 .ui-datepicker-group { width:25%; } -.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header { border-left-width:0; } -.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { border-left-width:0; } -.ui-datepicker-multi .ui-datepicker-buttonpane { clear:left; } -.ui-datepicker-row-break { clear:both; width:100%; font-size:0em; } - -/* RTL support */ -.ui-datepicker-rtl { direction: rtl; } -.ui-datepicker-rtl .ui-datepicker-prev { right: 2px; left: auto; } -.ui-datepicker-rtl .ui-datepicker-next { left: 2px; right: auto; } -.ui-datepicker-rtl .ui-datepicker-prev:hover { right: 1px; left: auto; } -.ui-datepicker-rtl .ui-datepicker-next:hover { left: 1px; right: auto; } -.ui-datepicker-rtl .ui-datepicker-buttonpane { clear:right; } -.ui-datepicker-rtl .ui-datepicker-buttonpane button { float: left; } -.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current { float:right; } -.ui-datepicker-rtl .ui-datepicker-group { float:right; } -.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header { border-right-width:0; border-left-width:1px; } -.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { border-right-width:0; border-left-width:1px; } - -/* IE6 IFRAME FIX (taken from datepicker 1.5.3 */ -.ui-datepicker-cover { - position: absolute; /*must have*/ - z-index: -1; /*must have*/ - filter: mask(); /*must have*/ - top: -4px; /*must have*/ - left: -4px; /*must have*/ - width: 200px; /*must have*/ - height: 200px; /*must have*/ -}/*! - * jQuery UI Progressbar 1.8.23 - * - * Copyright 2012, AUTHORS.txt (http://jqueryui.com/about) - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * http://docs.jquery.com/UI/Progressbar#theming - */ -.ui-progressbar { height:2em; text-align: left; overflow: hidden; } -.ui-progressbar .ui-progressbar-value {margin: -1px; height:100%; } \ No newline at end of file diff --git a/data/interfaces/brink/css/libs/jquery.dataTables.css b/data/interfaces/brink/css/libs/jquery.dataTables.css deleted file mode 100644 index dda16c41..00000000 --- a/data/interfaces/brink/css/libs/jquery.dataTables.css +++ /dev/null @@ -1,219 +0,0 @@ - -/* - * Table - */ -table.dataTable { - margin: 0 auto; - clear: both; - width: 100%; -} - -table.dataTable thead th { - padding: 3px 18px 3px 10px; - border-bottom: 1px solid black; - font-weight: bold; - cursor: pointer; - *cursor: hand; -} - -table.dataTable tfoot th { - padding: 3px 18px 3px 10px; - border-top: 1px solid black; - font-weight: bold; -} - -table.dataTable td { - padding: 3px 10px; -} - -table.dataTable td.center, -table.dataTable td.dataTables_empty { - text-align: center; -} - -table.dataTable tr.odd { background-color: #E2E4FF; } -table.dataTable tr.even { background-color: white; } - -table.dataTable tr.odd td.sorting_1 { background-color: #D3D6FF; } -table.dataTable tr.odd td.sorting_2 { background-color: #DADCFF; } -table.dataTable tr.odd td.sorting_3 { background-color: #E0E2FF; } -table.dataTable tr.even td.sorting_1 { background-color: #EAEBFF; } -table.dataTable tr.even td.sorting_2 { background-color: #F2F3FF; } -table.dataTable tr.even td.sorting_3 { background-color: #F9F9FF; } - - -/* - * Table wrapper - */ -.dataTables_wrapper { - position: relative; - clear: both; - *zoom: 1; -} - - -/* - * Page length menu - */ -.dataTables_length { - float: left; -} - - -/* - * Filter - */ -.dataTables_filter { - float: right; - text-align: right; -} - - -/* - * Table information - */ -.dataTables_info { - clear: both; - float: left; -} - - -/* - * Pagination - */ -.dataTables_paginate { - float: right; - text-align: right; -} - -/* Two button pagination - previous / next */ -.paginate_disabled_previous, -.paginate_enabled_previous, -.paginate_disabled_next, -.paginate_enabled_next { - height: 19px; - float: left; - cursor: pointer; - *cursor: hand; - color: #111 !important; -} -.paginate_disabled_previous:hover, -.paginate_enabled_previous:hover, -.paginate_disabled_next:hover, -.paginate_enabled_next:hover { - text-decoration: none !important; -} -.paginate_disabled_previous:active, -.paginate_enabled_previous:active, -.paginate_disabled_next:active, -.paginate_enabled_next:active { - outline: none; -} - -.paginate_disabled_previous, -.paginate_disabled_next { - color: #666 !important; -} -.paginate_disabled_previous, -.paginate_enabled_previous { - padding-left: 23px; -} -.paginate_disabled_next, -.paginate_enabled_next { - padding-right: 23px; - margin-left: 10px; -} - -.paginate_enabled_previous { background: url('../images/back_enabled.png') no-repeat top left; } -.paginate_enabled_previous:hover { background: url('../images/back_enabled_hover.png') no-repeat top left; } -.paginate_disabled_previous { background: url('../images/back_disabled.png') no-repeat top left; } - -.paginate_enabled_next { background: url('../images/forward_enabled.png') no-repeat top right; } -.paginate_enabled_next:hover { background: url('../images/forward_enabled_hover.png') no-repeat top right; } -.paginate_disabled_next { background: url('../images/forward_disabled.png') no-repeat top right; } - -/* Full number pagination */ -.paging_full_numbers { - height: 22px; - line-height: 22px; -} -.paging_full_numbers a:active { - outline: none -} -.paging_full_numbers a:hover { - text-decoration: none; -} - -.paging_full_numbers a.paginate_button, -.paging_full_numbers a.paginate_active { - border: 1px solid #aaa; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - padding: 2px 5px; - margin: 0 3px; - cursor: pointer; - *cursor: hand; - color: #333 !important; -} - -.paging_full_numbers a.paginate_button { - background-color: #ddd; -} - -.paging_full_numbers a.paginate_button:hover { - background-color: #ccc; - text-decoration: none !important; -} - -.paging_full_numbers a.paginate_active { - background-color: #99B3FF; -} - - -/* - * Processing indicator - */ -.dataTables_processing { - position: absolute; - top: 50%; - left: 50%; - width: 250px; - height: 30px; - margin-left: -125px; - margin-top: -15px; - padding: 14px 0 2px 0; - border: 1px solid #ddd; - text-align: center; - color: #999; - font-size: 14px; - background-color: white; -} - - -/* - * Sorting - */ -.sorting { background: url('../images/sort_both.png') no-repeat center right; } -.sorting_asc { background: url('../images/sort_asc.png') no-repeat center right; } -.sorting_desc { background: url('../images/sort_desc.png') no-repeat center right; } - -.sorting_asc_disabled { background: url('../images/sort_asc_disabled.png') no-repeat center right; } -.sorting_desc_disabled { background: url('../images/sort_desc_disabled.png') no-repeat center right; } - -table.dataTable th:active { - outline: none; -} - - -/* - * Scrolling - */ -.dataTables_scroll { - clear: both; -} - -.dataTables_scrollBody { - *margin-top: -1px; -} - diff --git a/data/interfaces/brink/css/libs/jquery.dataTables_themeroller.css b/data/interfaces/brink/css/libs/jquery.dataTables_themeroller.css deleted file mode 100644 index 94a24c8c..00000000 --- a/data/interfaces/brink/css/libs/jquery.dataTables_themeroller.css +++ /dev/null @@ -1,243 +0,0 @@ - - -/* - * Table - */ -table.dataTable { - margin: 0 auto; - clear: both; - width: 100%; -} - -table.dataTable thead th { - padding: 3px 0px 3px 10px; - cursor: pointer; - *cursor: hand; -} - -table.dataTable tfoot th { - padding: 3px 10px; -} - -table.dataTable td { - padding: 3px 10px; -} - -table.dataTable td.center, -table.dataTable td.dataTables_empty { - text-align: center; -} - -table.dataTable tr.odd { background-color: #E2E4FF; } -table.dataTable tr.even { background-color: white; } - -table.dataTable tr.odd td.sorting_1 { background-color: #D3D6FF; } -table.dataTable tr.odd td.sorting_2 { background-color: #DADCFF; } -table.dataTable tr.odd td.sorting_3 { background-color: #E0E2FF; } -table.dataTable tr.even td.sorting_1 { background-color: #EAEBFF; } -table.dataTable tr.even td.sorting_2 { background-color: #F2F3FF; } -table.dataTable tr.even td.sorting_3 { background-color: #F9F9FF; } - - -/* - * Table wrapper - */ -.dataTables_wrapper { - position: relative; - clear: both; - *zoom: 1; -} -.dataTables_wrapper .ui-widget-header { - font-weight: normal; -} -.dataTables_wrapper .ui-toolbar { - padding: 5px; -} - - -/* - * Page length menu - */ -.dataTables_length { - float: left; -} - - -/* - * Filter - */ -.dataTables_filter { - float: right; - text-align: right; -} - - -/* - * Table information - */ -.dataTables_info { - padding-top: 3px; - clear: both; - float: left; -} - - -/* - * Pagination - */ -.dataTables_paginate { - float: right; - text-align: right; -} - -.dataTables_paginate .ui-button { - margin-right: -0.1em !important; -} - -.paging_two_button .ui-button { - float: left; - cursor: pointer; - * cursor: hand; -} - -.paging_full_numbers .ui-button { - padding: 2px 6px; - margin: 0; - cursor: pointer; - * cursor: hand; - color: #333 !important; -} - -/* Two button pagination - previous / next */ -.paginate_disabled_previous, -.paginate_enabled_previous, -.paginate_disabled_next, -.paginate_enabled_next { - height: 19px; - float: left; - cursor: pointer; - *cursor: hand; - color: #111 !important; -} -.paginate_disabled_previous:hover, -.paginate_enabled_previous:hover, -.paginate_disabled_next:hover, -.paginate_enabled_next:hover { - text-decoration: none !important; -} -.paginate_disabled_previous:active, -.paginate_enabled_previous:active, -.paginate_disabled_next:active, -.paginate_enabled_next:active { - outline: none; -} - -.paginate_disabled_previous, -.paginate_disabled_next { - color: #666 !important; -} -.paginate_disabled_previous, -.paginate_enabled_previous { - padding-left: 23px; -} -.paginate_disabled_next, -.paginate_enabled_next { - padding-right: 23px; - margin-left: 10px; -} - -.paginate_enabled_previous { background: url('../images/back_enabled.png') no-repeat top left; } -.paginate_enabled_previous:hover { background: url('../images/back_enabled_hover.png') no-repeat top left; } -.paginate_disabled_previous { background: url('../images/back_disabled.png') no-repeat top left; } - -.paginate_enabled_next { background: url('../images/forward_enabled.png') no-repeat top right; } -.paginate_enabled_next:hover { background: url('../images/forward_enabled_hover.png') no-repeat top right; } -.paginate_disabled_next { background: url('../images/forward_disabled.png') no-repeat top right; } - -/* Full number pagination */ -.paging_full_numbers a:active { - outline: none -} -.paging_full_numbers a:hover { - text-decoration: none; -} - -.paging_full_numbers a.paginate_button, -.paging_full_numbers a.paginate_active { - border: 1px solid #aaa; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - padding: 2px 5px; - margin: 0 3px; - cursor: pointer; - *cursor: hand; - color: #333 !important; -} - -.paging_full_numbers a.paginate_button { - background-color: #ddd; -} - -.paging_full_numbers a.paginate_button:hover { - background-color: #ccc; - text-decoration: none !important; -} - -.paging_full_numbers a.paginate_active { - background-color: #99B3FF; -} - - -/* - * Processing indicator - */ -.dataTables_processing { - position: absolute; - top: 50%; - left: 50%; - width: 250px; - height: 30px; - margin-left: -125px; - margin-top: -15px; - padding: 14px 0 2px 0; - border: 1px solid #ddd; - text-align: center; - color: #999; - font-size: 14px; - background-color: white; -} - - -/* - * Sorting - */ -table.dataTable thead th div.DataTables_sort_wrapper { - position: relative; - padding-right: 20px; - padding-right: 20px; -} - -table.dataTable thead th div.DataTables_sort_wrapper span { - position: absolute; - top: 50%; - margin-top: -8px; - right: 0; -} - -table.dataTable th:active { - outline: none; -} - - -/* - * Scrolling - */ -.dataTables_scroll { - clear: both; -} - -.dataTables_scrollBody { - *margin-top: -1px; -} - diff --git a/data/interfaces/brink/css/libs/jquery.jscrollpane.css b/data/interfaces/brink/css/libs/jquery.jscrollpane.css deleted file mode 100644 index e623bae5..00000000 --- a/data/interfaces/brink/css/libs/jquery.jscrollpane.css +++ /dev/null @@ -1,143 +0,0 @@ -/* - * CSS Styles that are needed by jScrollPane for it to operate correctly. - * - * Include this stylesheet in your site or copy and paste the styles below into your stylesheet - jScrollPane - * may not operate correctly without them. - */ - -.jspContainer -{ - overflow: hidden; - position: relative; - z-index: 9999; -} - -.jspPane -{ - position: absolute; -} - -.jspVerticalBar -{ - position: absolute; - top: 0; - right: 0; - width: 15px; - height: 100%; - background: rgb(90,90,90); - border-bottom: 1px solid rgb(20,20,20); - border-right: 1px solid rgb(20,20,20); - border-top: 1px solid rgb(130,130,130); - border-left: 1px solid rgb(130,130,130); - box-shadow: 0px 0px 5px #000; - padding-left: 2px; - padding-right: 2px; -} - -.jspHorizontalBar -{ - position: absolute; - bottom: 0; - left: 0; - width: 100%; - height: 15px; - background: rgb(160,160,160); -} - -.jspVerticalBar *, -.jspHorizontalBar * -{ - margin: 0; - padding: 0; -} - -.jspCap -{ - display: none; -} - -.jspHorizontalBar .jspCap -{ - float: left; - background: rgb(160,160,160); -} - -.jspTrack -{ - position: relative; - border-radius: 20px; -} - -.jspDrag -{ - position: relative; - top: 0; - left: 0; - cursor: pointer; - border-radius: 20px; - box-shadow: 0px 0px 3px #000; - border: 1px solid rgba(0,0,0,0.9); -} - -.jspHorizontalBar .jspTrack, -.jspHorizontalBar .jspDrag -{ - float: left; - height: 100%; -} - -.jspArrow -{ - background: rgb(160,160,160); - text-indent: 0px; - display: block; - cursor: pointer; - box-shadow: 0px 0px 3px #000; -} - -.jspArrow.jspDisabled -{ - cursor: default; - background: rgb(90,90,90); -} - -.jspVerticalBar .jspArrow -{ - height: 20px; - box-shadow: 1px 1px 3px; -} - -.jspHorizontalBar .jspArrow -{ - width: 20px; - float: left; - height: 100%; -} - -.jspVerticalBar .jspArrow:focus -{ - outline: none; -} - -.jspCorner -{ - background: rgb(160,160,160); - border: 1px solid #000; - float: left; - height: 100%; -} - -.jspArrowUp -{ - background: url(../images/arrow-up.png) center center no-repeat; -} -.jspArrowDown -{ - background: url(../images/arrow-down.png) center center no-repeat; -} - -/* Yuk! CSS Hack for IE6 3 pixel bug :( */ -* html .jspCorner -{ - margin: 0 -3px 0 0; -} \ No newline at end of file diff --git a/data/interfaces/brink/css/libs/jquery.noty.css b/data/interfaces/brink/css/libs/jquery.noty.css deleted file mode 100644 index b589ebfa..00000000 --- a/data/interfaces/brink/css/libs/jquery.noty.css +++ /dev/null @@ -1,105 +0,0 @@ - -/* CORE STYLES */ - - /* noty bar */ - .noty_bar { - position: fixed; - display: none; - z-index: 9999999; - } - - /* noty_message */ - .noty_bar .noty_message { - text-align: center; - } - - /* noty close button */ - .noty_bar .noty_close { - cursor: pointer; - } - - /* noty modal */ - .noty_modal { - position: fixed; - width: 100%; - height: 100%; - background-color: #000; - z-index: 10000; - opacity: 0.6; - display: none; - left: 0; - top: 0; - } - - /* noty container for noty_layout_topLeft & noty_layout_topRight */ - ul.noty_cont { - position: fixed; - z-index: 10000000; - margin: 0px; - padding: 0px; - list-style: none; - width: 300px; - } - ul.noty_cont li { - position: relative; - float: left; - clear: both; - list-style: none; - padding: 0px; - margin: 10px 0 0 0; - width: 300px; /* Fix for: http://bugs.jquery.com/ticket/2278 */ - } - ul.noty_cont.noty_layout_topLeft {left:20px; top:20px;} - ul.noty_cont.noty_layout_topRight {right:40px; top:20px;} - ul.noty_cont.noty_layout_bottomLeft {left:20px; bottom:20px} - ul.noty_cont.noty_layout_bottomRight {right:40px; bottom:20px} - ul.noty_cont.noty_layout_topRight li {float:right} - -/* LAYOUTS */ - - /* noty_layout_top */ - .noty_bar.noty_layout_top { - top: 0; - left: 0; - width: 100%; - -webkit-border-radius: 0px; - -moz-border-radius: 0px; - border-radius: 0px; - } - - /* noty_layout_bottom */ - .noty_bar.noty_layout_bottom { - bottom: 0; - left: 0; - width: 100%; - -webkit-border-radius: 0px; - -moz-border-radius: 0px; - border-radius: 0px; - } - - /* noty_layout_center */ - .noty_bar.noty_layout_center { - top: 40%; - } - - /* noty_layout_topLeft & noty_layout_topRight */ - .noty_bar.noty_layout_topLeft, - .noty_bar.noty_layout_topRight, - .noty_bar.noty_layout_bottomLeft, - .noty_bar.noty_layout_bottomRight { - width: 100%; - clear: both; - position: relative; - } - - .noty_bar.noty_layout_topLeft .noty_message, - .noty_bar.noty_layout_topRight .noty_message, - .noty_bar.noty_layout_bottomLeft .noty_message, - .noty_bar.noty_layout_bottomRight .noty_message { - text-align: left; - } - - /* noty_layout_topCenter */ - .noty_bar.noty_layout_topCenter { - top: 20px; - } \ No newline at end of file diff --git a/data/interfaces/brink/css/libs/noty_theme_default.css b/data/interfaces/brink/css/libs/noty_theme_default.css deleted file mode 100644 index da94e8c3..00000000 --- a/data/interfaces/brink/css/libs/noty_theme_default.css +++ /dev/null @@ -1,240 +0,0 @@ - -/* CORE STYLES*/ - - /* noty bar */ - .noty_bar.noty_theme_default { - background: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABsAAAAoCAYAAAAPOoFWAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAPZJREFUeNq81tsOgjAMANB2ov7/7ypaN7IlIwi9rGuT8QSc9EIDAsAznxvY4pXPKr05RUE5MEVB+TyWfCEl9LZApYopCmo9C4FKSMtYoI8Bwv79aQJU4l6hXXCZrQbokJEksxHo9KMOgc6w1atHXM8K9DVC7FQnJ0i8iK3QooGgbnyKgMDygBWyYFZoqx4qS27KqLZJjA1D0jK6QJcYEQEiWv9PGkTsbqxQ8oT+ZtZB6AkdsJnQDnMoHXHLGKOgDYuCWmYhEERCI5gaamW0bnHdA3k2ltlIN+2qKRyCND0bhqSYCyTB3CAOc4WusBEIpkeBuPgJMAAX8Hs1NfqHRgAAAABJRU5ErkJggg==') repeat-x scroll left top #fff; - } - - /* if you use noty with customContainer you can access noty with this way - * .noty_custom_container noty will add automaticly this class to your customContainer - * .noty_theme_default your theme - * .noty_layout_inline your layout - */ - - /* custom container */ - .noty_custom_container.noty_theme_default.noty_layout_inline { - position: relative; - } - - /* custom growl container */ - .noty_custom_container.noty_theme_default.noty_layout_inline .noty_cont.noty_layout_inline { - position: static; - } - /* custom noty bar */ - .noty_custom_container.noty_theme_default.noty_layout_inline .noty_bar { - border-width: 1px; - border-style: solid; - position: static; - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); - } - .noty_custom_container.noty_theme_default.noty_layout_inline .noty_bar .noty_message { - font-size: 13px; - padding: 4px; - } - .noty_custom_container.noty_theme_default.noty_layout_inline .noty_bar .noty_message .noty_buttons { - margin-top: -1px; - } - - /* noty_message */ - .noty_bar.noty_theme_default .noty_message { - padding: 8px 14px; - font-size: 16px; - font-weight: bold; - width: auto; - } - .noty_bar.noty_theme_default.noty_closable .noty_message { - padding: 8px 34px 8px 14px; - } - - /* noty_buttons */ - .noty_bar.noty_theme_default .noty_message .noty_buttons { - float: right; - font-size: 13px; - margin-top: -4px; - margin-left: 4px; - } - - /* noty_button */ - .noty_bar.noty_theme_default .noty_message .noty_buttons button { - margin-left: 5px; - } - - /* noty close button */ - .noty_bar.noty_theme_default .noty_close { - position: absolute; - top: 10px; - right: 10px; - background-image: url('data:image/png;base64,iVBORw0KGgoAAAANSUhEUgAAABQAAAAUCAYAAACNiR0NAAAAGXRFWHRTb2Z0d2FyZQBBZG9iZSBJbWFnZVJlYWR5ccllPAAAAORJREFUeNq0lU0OgjAQhRm5gUl3rLyBB3BDQjwI4TDcgmu4NqwNJGxdueqWA4zzCJoxtvxoeckLzbz2C5ShEDNHDiXis/gkPooPY/0uvomv4ov48bUSQGUSF+Ka51WPc0kzNGwvLnm9ynHtB5B+hGkoaWDB/6t4AZOFe7ZkTxMAc1dqreU0TbnrunetbVvOsmzIPMoBrFwJYGgCY8wAgjFGDZlHFYCNK9EAXPUYmUcNgL0v1dAFMKjfRSsVx/H0hC0eOfhLmWwbfTcYozbXNsEbO/int8nhEPz4CnbAUuhfwFOAAQAA48KKOuexjwAAAABJRU5ErkJggg=='); - width: 20px; - height: 20px; - } - - /* noty modal */ - .noty_modal.noty_theme_default { - opacity: 0.7; - } - -/* LAYOUTS */ - - /* noty_layout_top */ - .noty_bar.noty_theme_default.noty_layout_top { - border-bottom: 3px solid #eee; - } - - /* noty_layout_bottom */ - .noty_bar.noty_theme_default.noty_layout_bottom { - border-top: 3px solid #eee; - } - - .noty_bar.noty_theme_default.noty_layout_center .noty_close { - top: 8px; - } - - .noty_bar.noty_theme_default.noty_layout_center .noty_message .noty_buttons { - margin-top: -2px - } - - /* noty_layout_topLeft & noty_layout_topRight */ - .noty_bar.noty_theme_default.noty_layout_center, - .noty_bar.noty_theme_default.noty_layout_topLeft, - .noty_bar.noty_theme_default.noty_layout_topRight, - .noty_bar.noty_theme_default.noty_layout_bottomLeft, - .noty_bar.noty_theme_default.noty_layout_bottomRight { - border: 1px solid #eee; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - border-radius: 5px; - box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); - } - .noty_bar.noty_theme_default.noty_layout_center .noty_message, - .noty_bar.noty_theme_default.noty_layout_topLeft .noty_message, - .noty_bar.noty_theme_default.noty_layout_topRight .noty_message, - .noty_bar.noty_theme_default.noty_layout_bottomLeft .noty_message, - .noty_bar.noty_theme_default.noty_layout_bottomRight .noty_message { - font-size: 13px; - font-weight: normal; - } - .noty_bar.noty_theme_default.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_layout_bottomRight .noty_message .noty_buttons { - float: none; - border-top: 1px solid #ccc; - margin-left: 0; - margin-top: 10px; - padding-top: 10px; - text-align: right; - } - - /* noty_layout_topCenter */ - .noty_bar.noty_theme_default.noty_layout_topCenter { - -webkit-border-radius: 4px; - -moz-border-radius: 4px; - border-radius: 4px; - box-shadow: 0 2px 4px rgba(0, 0, 0, 0.2); - } - .noty_bar.noty_theme_default.noty_layout_topCenter .noty_message { - font-weight: normal; - font-size: 13px; - } - .noty_bar.noty_theme_default.noty_layout_topCenter .noty_close { - top: 50%; - margin-top: -10px; - -webkit-border-radius: 10px; - -moz-border-radius: 10px; - border-radius: 10px; - } - .noty_bar.noty_theme_default.noty_layout_topCenter.noty_success { - border: 1px solid #50C24E; - } - .noty_bar.noty_theme_default.noty_layout_topCenter .noty_message .noty_buttons { - margin-left: 15px; - margin-top: 0px - } - -/* NOTIFICATION TYPES */ - - /* noty_notification */ - .noty_bar.noty_theme_default.noty_notification { - background-color: #fff; - border-color: #ccc; - color: #555; - } - .noty_bar.noty_theme_default.noty_notification.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_notification.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_notification.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_notification.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: #ccc; - } - - /* noty_warning */ - .noty_bar.noty_theme_default.noty_warning { - background-color: #FFEAA8; - border-color: #FFC237; - color: #826200; - } - .noty_bar.noty_theme_default.noty_warning.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_warning.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_warning.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_warning.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: #FFC237; - } - - /* noty_alert */ - .noty_bar.noty_theme_default.noty_alert { - background-color: #fff; - border-color: #ccc; - } - .noty_bar.noty_theme_default.noty_alert.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_alert.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_alert.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_alert.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: #ccc; - } - - /* noty_error */ - .noty_bar.noty_theme_default.noty_error { - background-color: red; - color: #fff; - border-color: darkred; - } - .noty_bar.noty_theme_default.noty_error .noty_message { - font-weight: bold; - } - .noty_bar.noty_theme_default.noty_error.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_error.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_error.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_error.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: darkred; - } - - /* noty_success */ - .noty_bar.noty_theme_default.noty_success { - background-color: lightgreen; - color: darkgreen; - border-color: #50C24E; - } - .noty_bar.noty_theme_default.noty_success.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_success.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_success.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_success.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: #50C24E; - } - - /* noty_information */ - .noty_bar.noty_theme_default.noty_information { - background-color: #57B7E2; - border-color: #0B90C4; - color: #fff; - } - .noty_bar.noty_theme_default.noty_information.noty_layout_topLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_information.noty_layout_topRight .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_information.noty_layout_bottomLeft .noty_message .noty_buttons, - .noty_bar.noty_theme_default.noty_information.noty_layout_bottomRight .noty_message .noty_buttons { - border-color: #0B90C4; - } - \ No newline at end of file diff --git a/data/interfaces/brink/css/style.css b/data/interfaces/brink/css/style.css deleted file mode 100644 index 7bcb6eb7..00000000 --- a/data/interfaces/brink/css/style.css +++ /dev/null @@ -1,826 +0,0 @@ -body { - margin: 0px; - padding: 0px; - font-family: "Century Gothic", Verdana, Tahoma, Arial, sans-serif; - overflow: hidden; - font-size: 100%; -} - -/* - * Univarsal - * */ - - .clear{ - clear:both; - } - - /*Removes outline in Chrome*/ - *:focus{ - outline: none; - } - - /* - * Links Styles - * */ - -a:link { - color: rgb(200,200,200); - text-decoration: none; - } -a:visited { - color: rgb(200,200,200); - text-decoration: none; - } -a:hover { /*this effect is not shown in NN4.xx*/ - color: rgb(255,255,255); - text-decoration: none; - } -a:active {/*colour in NN4.xx is red*/ - color: rgb(200,200,200); - text-decoration: none; -} - -#container { width: 100%; margin: auto; } - -/*Text format*/ -h1,h2,h3,h4,h5,h6{padding-left: 10px,} - -h1 - { - font-size: 1.2em; - text-decoration: none; - margin: 0; - line-height: 2em; - color: rgb(0,145,255); -} -h2 { font-size: 1em; color: rgb(255,255,255); text-shadow: -1px -1px 0px rgb(10,10,10); margin-bottom: 0px; text-decoration: none; padding: 0px;} -h3 { font-size: .8em; font-weight: normal; color: rgb(140,140,140); } -h4 { padding: .6px; font-size: 0.8em; color: rgba(0,0,0,0.6); text-shadow: 1px 1px 0px rgba(255,255,255,0.1); text-decoration: none;} - -p { color: rgb(160,160,160); text-shadow: 1px 1px 1px #000; margin-top: 8px; margin-bottom: 8px; } -small { color: rgb(160,160,160); } -/*#table_body*/ -#table_body{ - width: 100%; - border-collapse: collapse; - overflow: hidden; -} -/*header*/ -#header -{ - box-sizing: border-box; - height: 45px; - border-bottom: 1px solid #000; - box-shadow: 1px 1px 2px #000; - vertical-align: middle; -} - -div#logo{ float: left; margin-left: .5em; width: 12em;} -div#logo img{ width: 2.5em; } - -/* * - * Search holder - */ -div#searchbar -{ - margin-top: .5em; - margin-right: .5em; - float: right; -} -div#searchbar input[type="text"]{ - margin: 0px; - padding: 0; - padding-left: 5px; - float: left; - width: 150px; -} -div#searchbar select{ - float: left; -} -/* - * end searchbar - * */ - -/*Noty*/ -div.custom_container /*Makes use of noty*/ -{ - width: 320px; - position: fixed; - top: 25px; - right: 25px; - z-index: 999999; -} - -/*Commits*/ -span#commits-behind { - position: relative; -} -span#commits-behind { - position: absolute; - background-color: red; - margin-top: -12px; - padding: 2px; - border: 1px solid white; - text-align: center; - border-radius: 4px; -} - -/*Menu*/ -ul#nav -{ - list-style-type: none; - padding: 0; - margin: 0; - float: left; - height: 100%; - width: 60%; -} - - -ul#nav li -{ - float: left; - padding: 0; - margin: 0; - line-height: 3em; - font-size: 1em; - text-align: center; - height: 100%; -} -ul#nav li a:hover{ - background-color: rgba(8,160,255,0.1); - color: rgba(0,145,255,0.8); - text-shadow: 1px 1px rgba(0,0,0,0.9); -} -ul#nav li a{ - padding-left: 10px; - padding-right: 10px; - display: block; - color: rgba(0,0,0,0.9); - text-shadow: 1px 1px rgba(0,145,255,0.2); -} - -/* * - * Sub navigation - */ - -#nav-sub-container { - width: 100%; - border-bottom: 1px solid rgb(0,145,255); - background: #000; - height: 2.3em; -} -#nav-sub-container li { - font-size: .8em; - text-align: center; - line-height: 2.8em; -} -#nav-sub-container.nav-sub-fixed { - position: fixed; - top: 53px; - width: 22em; - border-right: 1px solid rgb(0,145,255); - border-radius: 0 0 10em 0; -} - -ul#nav-sub { float: left; } -ul#nav-view { float:right; } - -/*DropDown*/ -ul#nav-sub li ul { display: none; list-style: none; padding: 0; margin: 0; box-shadow: 0px 5px 5px #000;} -ul#nav-sub li:hover ul { display: block; } -ul#nav-sub li ul li { background-color: rgba(0,0,0,.5); float: none; text-align: left;} -ul#nav-sub li ul li a{ display: block; -border-top:1px solid rgba(255,255,255,.1); -border-bottom:1px solid rgba(0,0,0,.1); - } -ul#nav-sub li ul li a:hover{ color: rgb(0,145,255); } - - -ul#nav-sub, -ul#nav-view { - list-style: none; - padding: 0px; - margin: 0px; - height: 100%; -} - -ul#nav-view li, -ul#nav-sub > li { - float: left; - border-right: 1px solid rgba(255,255,255,0.2); -} - -ul#nav-view li, -ul#nav-sub li a { - display: block; - padding: 0 10px 0 10px; - text-decoration: none; - color: rgba(255,255,255,.3); -} -ul#nav-view > li:hover, -ul#nav-sub > li:hover > a { - color: rgb(0,145,255); - border-bottom: 2px solid rgb(0,145,255); - cursor: pointer; -} -ul#nav-sub > li > a.active { - color: rgb(0,145,255); - border-bottom: 2px solid rgb(0,145,255); - cursor: pointer; -} - -ul#content-container{ - overflow: hidden; -} - -div#main { - overflow: hidden; -} - -.table_wrapper { - border-radius: 5px; - -webkit-border-radius: 5px; - -moz-border-radius: 5px; - width: 100%; - min-height: 50px; - clear: both; - _height: 302px; - zoom: 1; -} - -/*Inputs & Select*/ -input, textarea, select, option { - appearance:none; - -moz-appearance:none; /* Firefox */ - -webkit-appearance:none; /* Safari and Chrome */ - -0-appearance:none; /* Safari and Chrome */ - padding-left: 5px; - padding-right: 5px; - font-size: .8em; - color: rgba(255,255,255,0.6); - line-height: 2em; - font-weight: bold; - margin: 0; -} -input[type="text"]{ - height: 27px; -} - -input, textarea{ - border: 1px solid rgba(0,0,0,0.6); - background: rgba(0,0,0,.1); - border: 1px solid rgba(0,0,0,.3); -} -input[type=checkbox]:hover, -input[type=radio]:hover, -input[type='text']:focus, -input[type='password']:focus, -textarea:focus { - background-color: rgba(0,145,255,.1); - color: #fff; -} - -select, -input[type="button"], -input[type="submit"]{ - background-color: rgba(0,0,0,.1); - border: 1px solid rgba(0,0,0,.3); - height: 2.3em; - display: inline; -} -select:hover, -input[type="button"]:hover, -input[type="submit"]:hover{ - background-color: rgba(0,145,255,.1); - color: #fff; -} -select option{ - background: rgb(31,31,31); - border: 0; -} -select option:hover{ - background: rgb(255,255,255); - color: #000; -} - -input[type=checkbox], -input[type=radio] { - display: inline-block; - font-size: 15px; - line-height: 1em; - margin: 0 0.25em 0 0; - padding: 0; - width: 1.25em; - height: 1.25em; - vertical-align: text-top; -} - -input[type=radio] { - -webkit-border-radius: 2em; /* Make radios round */ -} - -input[type="radio"]:checked { - background: rgba(0,145,255,.8); -} - -input[type="checkbox"]:checked{ - background: rgb(0,145,255) no-repeat center center; -} -input[type="checkbox"]:checked:after{ - content: '.'; - color: rgb(255,255,255); - font-family: 'WebSymbolsRegular'; - font-weight: bold; - font-size: 1em; - text-shadow: 1px 1px 0px rgba(0,0,0,0.3); - margin-left: 1px; - margin-bottom: 2px; -} - -/*End Inputs & Select*/ - -.manage_wrapper { width: 88%; margin: 20px auto 0 auto; padding: 25px; min-height: 150px; clear: both; _height: 302px; zoom: 1; } - -/*config*/ -div#config_wrapper { margin: auto; width: 640px;} -div#config_wrapper div table { width: 100%; border-collapse:separate; border-spacing: 10px; } -div#config_wrapper div table tr td:first-child{ width: 50%; } -div#config_wrapper div table tr td{ vertical-align: middle; } -div.group { - padding: 5px; - background-color: rgba(0,0,0,0.1); - border-top: 1px solid rgba(0,0,0,0.1); - border-left: 1px solid rgba(0,0,0,0.1); - border-bottom: 1px solid rgba(255,255,255,0.1); - border-right: 1px solid rgba(255,255,255,0.1); - display: block; -} -/*end config*/ - -/* Artist Table Style*/ -table#artist_table { width: 100%;} -table#artist_table th#select { text-align: left; } -table#artist_table th#albumart { text-align: center; width: 100px; } -table#artist_table th#name { text-align: left; min-width: 150px; } -table#artist_table th#album { text-align: left; min-width: 100px; } -table#artist_table th#have { text-align: center; min-width: 50px; } - -table#artist_table td#select { vertical-align: middle; text-align: center; } -table#artist_table td#albumart { vertical-align: middle; text-align: left; } -table#artist_table td#name { vertical-align: middle; text-align: left; } -table#artist_table td#album { vertical-align: middle; text-align: left; } -table#artist_table td#have { vertical-align: middle; } - -table#album_table { width: 100%; } -/* Album Tableheader*/ -table#album_table th#select { vertical-align: middle; text-align: left; width: 25px; } -table#album_table th#albumart {vertical-align: middle; text-align: left; width: 70px; } -table#album_table th#albumname {vertical-align: middle; text-align: left; min-width: 150px; } -table#album_table th#reldate {vertical-align: middle; width: 175px; text-align: left; min-width: 70px; } -table#album_table th#status {vertical-align: middle; width: 175px; text-align: left; min-width: 80px; } -table#album_table th#type {vertical-align: middle; width: 175px; text-align: left; min-width: 60px; max-width: 100px; } -table#album_table th#bitrate {vertical-align: middle; text-align: left; min-width: 60px; } -/* Album tabledata */ -table#album_table td#select { vertical-align: middle; text-align: left; } -table#album_table td#albumart { vertical-align: middle; text-align: left; } -/*Artist Bio*/ -.artist-bio-container{ - width: 100%; - height: 240px; - background-color: rgba(0,0,0,0.5); - position: relative; -} -.artist-bio-container .artist-art{ - width: 240px; - max-height: 240px; - float: left; - margin: 10px; - box-shadow: 0 0 6px #000; - -moz-box-shadow: 0 0 6px #000; - -webkit-box-shadow: 0 0 6px #000; - -o-box-shadow: 0 0 6px #000; - overflow: hidden; -} -.artist-bio-container .artist-art img{ - width: 100%; -} -.artist-bio-container .artist-bio{ - float: left; - font-size: .8em; - display: block; - width: 35%; -} - -/*Grid View Artist*/ -.image-container { - position: relative; - display: none; - float: left; - width: 126px; - margin: 10px 10px 10px 10px; -} -.image-tag { - z-index: 2; - position: absolute; - top: 0px; - left: 10px; - width: .6em; - height: 1.2em; - border-radius: 0 0 2px 2px; - box-shadow: 1px 2px 2px #000; - display: none; -} -.image-tag.Wanted { - background-color: rgb(0,175,255); - display: block; -} -.image-tag.Downloaded { - background-color: #5DD345; - display: block; -} -.image-container .image-box{ - height: 126px; - width: 126px; - position: relative; -} -.image-container .image-box img { - width: 100%; - height: 100%; - position: absolute; - top: 0px; - left: 0px; - z-index: 1; - border: 0; - box-shadow: 0px 0px 10px rgb(0,0,0); - -moz-box-shadow: 0px 0px 10px rgb(0,0,0); - -webkit-box-shadow: 0px 0px 10px rgb(0,0,0); - -o-box-shadow: 0px 0px 10px rgb(0,0,0); -} - -.image-container .image-box input { - position: absolute; - top: 0px; - width: 100%; - height: 100%; - text-align: center; -} -.image-container .image-box input:checked { - box-shadow: 0px 0px 10px rgb(0,145,255); - -moz-box-shadow: 0px 0px 10px rgb(0,145,255); - -webkit-box-shadow: 0px 0px 10px rgb(0,145,255); - -0-box-shadow: 0px 0px 10px rgb(0,145,255); -} -.image-container .image-box .image-count { - width: 100%; - height: 100%; - font-size: 10em; -} -.image-container .image-actions { - display: none; - position: absolute; - bottom: 0; - left: 0; - z-index: 4; - width: 100%; - height: 20%; - font-size: 1em; - line-height: 1.5em; - text-align: center; - background-color: rgba(0,0,0,0.5); -} -.image-container:hover .image-actions{ - display: block; -} -.image-container .image-info{ - text-align: left; - font-size: 0.7em; - position: relative; - top: 5px; - left: 0px; - width: 100%; - height: 40px; - text-shadow: 1px 1px 2px #000; - overflow: hidden; - border-bottom: 1px solid rgba(0,0,0,0.1); -} -/* Album art image sizes */ -.album-art-small -{ - position: relative; - width: 61px; - height: 61px; - float: left; - overflow: visible; - background-color: rgb(255,255,255); - position: relative; - text-align: center; - box-shadow: 0 0 3px #000; - -moz-box-shadow: 0 0 3px #000; - -webkit-box-shadow: 0 0 3px #000; - -o-box-shadow: 0 0 3px #000; -} -.album-art-small img { width: 100%; height: 100%; } -.album-art-small .album-actions { - position: absolute; - bottom: 0px; - left: 0px; - width: 100%; - background-color: rgba(0,0,0,0.5); -} -.artist-status div{ - width: 100%; - height: 100%; - background-color: rgba(0,0,0,0.5); - position: absolute; - top: 0; - left: 0; - z-index: 2; - line-height: 3.8em; - text-align: center; -} -.album-art-small img { width: 100%; height: 100%; z-index: 200; border: 0; } -div.status:hover { } -.album-art-big -{ - background: url(../images/box-big.png) no-repeat top left; - float: left; - height: 200px; - margin-left: 20px; - margin-top. 20px; - padding-top:5px; - padding-left: 27px; - padding-bottom: 5px; - padding-right: 110px; - position: relative; - width: 200px; - z-index: 200; -} -.album-art-cd -{ - background: url(../images/cd-big.png); - width: 191px; - height: 191px; - position: absolute; - top: 9px; - right: 20px; - z-index: 1; -} -.album-art-big img { width: 200px; height: 200px; position: absolute; z-index: 2; } - -#album-describtion { float: left; width: 400px; min-height: 200px; margin-left: 20px; } -table#album_table td#albumname { vertical-align: middle; text-align: left; } -table#album_table td#reldate { vertical-align: middle; text-align: left; } -table#album_table td#status { vertical-align: middle; text-align: left; } -table#album_table td#type { vertical-align: middle; text-align: left; } -table#album_table td#have { vertical-align: middle; } -table#album_table td#bitrate { vertical-align: middle; text-align: left; } - -div#albumheader { margin: 20px 0px 40px 0px; min-height: 200px; } - -/* - Track -*/ -div#track_wrapper { font-size: 12px; width: 100%; clear:both; } -table#track_table { margin-top: 20px; width: 100%; } -table#track_table td { padding: 3px 10px 3px 10px; } -table#track_table th#number { text-align: left; width: 30px; padding-left: 4px; } -table#track_table th#name { text-align:left ; min-width: 160px; } -table#track_table th#duration { text-align: left; width: 90px; } -table#track_table th#location { text-align: left; min-width: 180px; } -table#track_table th#bitrate { text-align: left; min-width: 75px; } - -table#track_table td#number { vertical-align: middle; text-align: left; font-size: 12px; overflow: hidden; } -table#track_table td#name { vertical-align: middle; text-align: left; font-size: 12px; overflow: hidden; } -table#track_table td#duration { vertical-align: middle; text-align: left; font-size: 12px; overflow: hidden; } -table#track_table td#location { vertical-align: middle; text-align: left; font-size: 12px; overflow: hidden; } -table#track_table td#bitrate { vertical-align: middle; text-align: left; font-size: 12px; overflow: hidden; } - - - -/* History table*/ -table#history_table { width: 100%; font-size: 12px; } -table#history_table td#dateadded { vertical-align: middle; text-align: left; min-width: 150px; font-size: 14px; } -table#history_table td#filename { vertical-align: middle; text-align: left; min-width: 100px; font-size: 15px; } -table#history_table td#size { vertical-align: middle; text-align: left; min-width: 75px; font-size: 14px; } -table#history_table td#status { vertical-align: middle; text-align: left; font-size: 14px; } -table#history_table td#action { vertical-align: middle; text-align: left; font-size: 14px; } - -/* - Log -*/ -table#log_table { width: 100%; } -table#log_table th#timestamp { text-align: left; min-width: 150px; } -table#log_table th#level { text-align: left; min-width: 60px; } -table#log_table th#message { text-align: left; min-width: 500px; } -/* - Upcoming -*/ -/*Upcoming Tablehead*/ -table#upcoming_table {width: 100%;} -table#upcoming_table th#albumart { text-align: left; min-width: 20%; } -table#upcoming_table th#albumname { text-align: left; min-width: 200px; } -table#upcoming_table th#artistname { text-align: left; min-width: 150px; } -table#upcoming_table th#reldate { text-align: left; min-width: 100px; } -table#upcoming_table th#type { text-align: left; min-width: 75px; } - -/*Upcoming Tabledata*/ -table#upcoming_table td#select { vertical-align: middle; text-align: left; } -table#upcoming_table td#albumart { vertical-align: middle; text-align: left; min-width: 50px; } -table#upcoming_table td#albumname { vertical-align: middle; text-align: left; min-width: 200px; } -table#upcoming_table td#artistname { vertical-align: middle; text-align: left; min-width: 150px; } -table#upcoming_table td#reldate { vertical-align: middle; text-align: left; min-width: 100px; } -table#upcoming_table td#type { vertical-align: middle; text-align: left; min-width: 75px; } -table#upcoming_table td#status { vertical-align: middle; text-align: left; } - -/*Wanted Tablehead*/ -table#wanted_table { width: 100%; } -table#wanted_table th#albumart { text-align: left; min-width: 50px; } -table#wanted_table th#albumname { text-align: left; min-width: 200px; } -table#wanted_table th#artistname { text-align: left; min-width: 150px; } -table#wanted_table th#reldate { text-align: left; min-width: 100px; } -table#wanted_table th#type { text-align: left; min-width: 75px; } - -/*Wanted Tabledata*/ -table#wanted_table td#select { vertical-align: middle; text-align: left; } -table#wanted_table td#albumart { vertical-align: middle; text-align: left; min-width: 50px; } -table#wanted_table td#albumname { vertical-align: middle; text-align: left; min-width: 200px; } -table#wanted_table td#artistname { vertical-align: middle; text-align: left; min-width: 150px; } -table#wanted_table td#reldate { vertical-align: middle; text-align: left; min-width: 100px; } -table#wanted_table td#type { vertical-align: middle; text-align: left; min-width: 75px; } -table#wanted_table td#status { vertical-align: middle; text-align: left; } - -/*Search Results Tablehead*/ -table#searchresults_table { width: 100%; } -table#searchresults_table th#albumname { text-align: left; min-width: 225px; } -table#searchresults_table th#artistname { text-align: left; min-width: 325px; } -table#searchresults_table th#score { text-align: left; min-width: 75px; } - -table#searchresults_table td#albumname { vertical-align: middle; text-align: left; min-width: 200px; } -table#searchresults_table td#artistname { vertical-align: middle; text-align: left; min-width: 300px; } -table#searchresults_table td#score { vertical-align: middle; text-align: left; min-width: 75px; } - -/*progress container*/ - -div.progress-container span -{ - float: left; - margin: auto; - color: #fffff; -} -div.progress-container span:hover -{ - -} -div.progress-container -{ - width: 100%; - height: 15px; - margin: 2px 5px 2px 0px; - overflow: hidden; - text-align: center; - border: 1px solid rgb(10,10,10); - box-shadow: 1px 1px 0px rgba(255,255,255,0.2); - border-radius: 2px; - background: rgba(0,0,0,0.1); -} -/*Progress bar*/ -div.progress-container div -{ - height: 100%; - background: rgb(57,69,81); /* Old browsers */ -background: -moz-linear-gradient(top, rgba(57,69,81,1) 0%, rgba(54,64,76,1) 49%, rgba(36,43,51,1) 50%, rgba(36,43,51,1) 100%); /* FF3.6+ */ -background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(57,69,81,1)), color-stop(49%,rgba(54,64,76,1)), color-stop(50%,rgba(36,43,51,1)), color-stop(100%,rgba(36,43,51,1))); /* Chrome,Safari4+ */ -background: -webkit-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(54,64,76,1) 49%,rgba(36,43,51,1) 50%,rgba(36,43,51,1) 100%); /* Chrome10+,Safari5.1+ */ -background: -o-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(54,64,76,1) 49%,rgba(36,43,51,1) 50%,rgba(36,43,51,1) 100%); /* Opera 11.10+ */ -background: -ms-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(54,64,76,1) 49%,rgba(36,43,51,1) 50%,rgba(36,43,51,1) 100%); /* IE10+ */ -background: linear-gradient(top, rgba(57,69,81,1) 0%,rgba(54,64,76,1) 49%,rgba(36,43,51,1) 50%,rgba(36,43,51,1) 100%); /* W3C */ -filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#394551', endColorstr='#242b33',GradientType=0 ); /* IE6-9 */ -} - -/*text format for match/procent*/ -.searchmatch, -.havetracks -{ - display: block; - float: left; - width: 100%; - font-size: 12px; - position: relative; - text-align: center; -} - - -#footer /*#footer*/ -{ - /*ColorStyles.css*/ - height: 50px; - border-collapse: collapse; - box-sizing: border-box; -} - -#footer .btn a { - font-size: .8em; - background: rgba(0,0,0,.1); - border: 1px solid rgba(0,0,0,.3); - padding: 5px 10px 5px 10px; - margin: 0px 5px 0px 5px; -} -#footer .btn a:hover { - background: rgba(255,255,255,.1); -} -#footer .btn.left{ - float: left; -} -#footer .btn.right{ - float: right; -} - -/*Footer manage/settings*/ -#options -{ - float: left; - padding: 5px; - list-style-type: none; - position: relative; - background-color: #192126; - -} -#options li { } -#options li a{ - padding-left: 20px; - padding-right: 5px; - line-height: 25px; - display: block; - color: rgb(120,120,120); -} -#options li a:hover { background: rgb(255,255,255); } -#options li span{ width: 30px; text-align: center; display:inline-block; } -#options ul -{ - list-style-type: none; - padding: 0px; - margin: 0px; - position: absolute; - display: none; - background-color: rgba(0,0,0,0.5); - width: 200px; -} - -#options li:hover ul -{ - display: block; -} - -span#version { text-align: center; font-weight: bold; } -span#donate { text-align: center; margin: 20px auto 20px auto; } - -/* Shutdown - * */ - -div#shutdown -{ - position: fixed; - top: 0px; - left: 0px; - width: 100%; - height: 100%; - background-color: rgba(0,0,0,0.9); - z-index: 999; -} -div#shutdown div -{ - position: fixed; - top: 50%; - left: 50%; - width: 0px; - height: 0px; -} -div#shutdown div div -{ - text-align: center; - position: relative; - float: left; - left: -150px; - top: -100px; - width: 300px; - height: 200px; -} - - -.cloudtag { padding-top: 30px; font-size:16px; } -#cloud a.tag1 { font-size: 0.7em; font-weight: 100; } -#cloud a.tag2 { font-size: 0.8em; font-weight: 200; } -#cloud a.tag3 { font-size: 0.9em; font-weight: 300; } -#cloud a.tag4 { font-size: 1.0em; font-weight: 400; } -#cloud a.tag5 { font-size: 1.2em; font-weight: 500; } -#cloud a.tag6 { font-size: 1.4em; font-weight: 600; } -#cloud a.tag7 { font-size: 1.6em; font-weight: 700; } -#cloud a.tag8 { font-size: 1.8em; font-weight: 800; } -#cloud a.tag9 { font-size: 2.2em; font-weight: 900; } -#cloud a.tag10 { font-size: 2.5em; font-weight: 900; } - -#cloud { padding: 2px; line-height: 1.5em; text-align: center; } -#cloud a { padding: 0px; } -#cloud { margin: 0; } -#cloud li { display: inline; } \ No newline at end of file diff --git a/data/interfaces/brink/css/theme/default.css b/data/interfaces/brink/css/theme/default.css deleted file mode 100644 index 9f54f508..00000000 --- a/data/interfaces/brink/css/theme/default.css +++ /dev/null @@ -1,71 +0,0 @@ -/* - * * * * * * * * * - * Colors Styles * - * * * * * * * * * - * A great site to adjust the colors is: - * http://gradients.glrzad.com/ - * Just copy the lines, and replace it in here. - */ -/* Main Header */ -body{ - background: #192126; - color: #fff; -} -#header -{ -background: rgb(57,69,81); /* Old browsers */ -background: -moz-linear-gradient(top, rgba(57,69,81,1) 0%, rgba(36,43,51,1) 100%); /* FF3.6+ */ -background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(57,69,81,1)), color-stop(100%,rgba(36,43,51,1))); /* Chrome,Safari4+ */ -background: -webkit-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(36,43,51,1) 100%); /* Chrome10+,Safari5.1+ */ -background: -o-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(36,43,51,1) 100%); /* Opera 11.10+ */ -background: -ms-linear-gradient(top, rgba(57,69,81,1) 0%,rgba(36,43,51,1) 100%); /* IE10+ */ -background: linear-gradient(top, rgba(57,69,81,1) 0%,rgba(36,43,51,1) 100%); /* W3C */ -filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#394551', endColorstr='#242b33',GradientType=0 ); /* IE6-9 */ -} -#footer{ -background: rgb(45,54,63); /* Old browsers */ -background: -moz-linear-gradient(top, rgba(45,54,63,1) 0%, rgba(36,43,51,1) 100%); /* FF3.6+ */ -background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(45,54,63,1)), color-stop(100%,rgba(36,43,51,1))); /* Chrome,Safari4+ */ -background: -webkit-linear-gradient(top, rgba(45,54,63,1) 0%,rgba(36,43,51,1) 100%); /* Chrome10+,Safari5.1+ */ -background: -o-linear-gradient(top, rgba(45,54,63,1) 0%,rgba(36,43,51,1) 100%); /* Opera 11.10+ */ -background: -ms-linear-gradient(top, rgba(45,54,63,1) 0%,rgba(36,43,51,1) 100%); /* IE10+ */ -background: linear-gradient(top, rgba(45,54,63,1) 0%,rgba(36,43,51,1) 100%); /* W3C */ -filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#2d363f', endColorstr='#242b33',GradientType=0 ); /* IE6-9 */ -border-top: 1px solid rgb(100,122,132); -} -/*Tablehead color*/ -table.display { -border-collapse: collapse; -} -table.display tbody tr td{ - background: #192126; /* Old browsers */ - background: rgba(0,0,0,.1); /* Old browsers */ - border-bottom: 1px solid rgba(0,0,0,.1); - border-top: 1px solid rgba(0,0,0,.1); - padding: 5px 10px 5px 10px; -} -table.display thead tr th -{ - background: rgb(53,68,76); /* Old browsers */ - background: -moz-linear-gradient(top, rgba(53,68,76,1) 0%, rgba(44,57,63,1) 100%); /* FF3.6+ */ - background: -webkit-gradient(linear, left top, left bottom, color-stop(0%,rgba(53,68,76,1)), color-stop(100%,rgba(44,57,63,1))); /* Chrome,Safari4+ */ - background: -webkit-linear-gradient(top, rgba(53,68,76,1) 0%,rgba(44,57,63,1) 100%); /* Chrome10+,Safari5.1+ */ - background: -o-linear-gradient(top, rgba(53,68,76,1) 0%,rgba(44,57,63,1) 100%); /* Opera 11.10+ */ - background: -ms-linear-gradient(top, rgba(53,68,76,1) 0%,rgba(44,57,63,1) 100%); /* IE10+ */ - background: linear-gradient(top, rgba(53,68,76,1) 0%,rgba(44,57,63,1) 100%); /* W3C */ - filter: progid:DXImageTransform.Microsoft.gradient( startColorstr='#35444c', endColorstr='#2c393f',GradientType=0 ); /* IE6-9 */ - border-top: 1px solid rgba(255,255,255,0.2); - border-bottom: 1px solid rgba(0,0,0,0.2); - border-collapse: collapse; - padding: .4em; - font-size: .8em; - color: rgba(0,0,0,0.9); - text-shadow: 1px 1px rgba(255,255,255,0.1); - -moz-text-shadow: 1px 1px rgba(0,145,255,0.1); - border-right: 1px solid rgba(0,0,0,.1); - border-left: 1px solid rgba(255,255,255,.1); -} - -/* - * Scrollbar Colors - * */ \ No newline at end of file diff --git a/data/interfaces/brink/extras.html b/data/interfaces/brink/extras.html deleted file mode 100644 index 3bb120a4..00000000 --- a/data/interfaces/brink/extras.html +++ /dev/null @@ -1,25 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -
-

Suggestions

- %for artist in cloudlist: -
-
-
${artist['Count']}
- -
- %if artist['Status'] == 'Loading': - - %else: - ${havetracks}/${totaltracks} - %endif -
-
- -
- %endfor - -
- diff --git a/data/interfaces/brink/fonts/websymbols-regular-webfont.eot b/data/interfaces/brink/fonts/websymbols-regular-webfont.eot deleted file mode 100644 index 4bf9c07a4319669f95fc8e505d1b7c8022e618c0..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12596 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 XTeYmJsxg#)htuy`_MT8xRrS9BXhLbS diff --git a/data/interfaces/brink/fonts/websymbols-regular-webfont.svg b/data/interfaces/brink/fonts/websymbols-regular-webfont.svg deleted file mode 100644 index ecf0e309..00000000 --- a/data/interfaces/brink/fonts/websymbols-regular-webfont.svg +++ /dev/null @@ -1,108 +0,0 @@ - - - - -This is a custom SVG webfont generated by Font Squirrel. -Copyright : Copyright c 2011 by Just Be Nice studio All rights reserved -Designer : Igor Kiselev -Foundry : Just Be Nice studio -Foundry URL : httpwwwjustbenicestudiocom - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - \ No newline at end of file diff --git a/data/interfaces/brink/fonts/websymbols-regular-webfont.ttf b/data/interfaces/brink/fonts/websymbols-regular-webfont.ttf deleted file mode 100644 index e7da1ba15cecd51a1f4165dfcbb6856ff3a6c810..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 12344 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 -<%! - from headphones import helpers -%> - -<%def name="body()"> - - - - - - - - - - - - - %for item in history: - <% - if item['Status'] == 'Processed': - grade = 'A' - elif item['Status'] == 'Snatched': - grade = 'C' - elif item['Status'] == 'Unprocessed': - grade = 'X' - else: - grade = 'U' - - fileid = 'unknown' - if item['URL'].find('nzb') != -1: - fileid = 'nzb' - if item['URL'].find('torrent') != -1: - fileid = 'torrent' - %> - - - - - - - - %endfor - -
Date AddedFile NameSizeStatus
${item['DateAdded']}${item['Title']} [${fileid}][album page]${helpers.bytes_to_mb(item['Size'])}${item['Status']}[retry][new]
- - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/images/arrow-down.png b/data/interfaces/brink/images/arrow-down.png deleted file mode 100644 index 0f7be79eed0d9195eafa3630dd0f5e9eae3b3828..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3136 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 diff --git a/data/interfaces/brink/images/no-cover.png b/data/interfaces/brink/images/no-cover.png deleted file mode 100644 index aad9ba5fe334f71de73b490e254b52ce595a47e3..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 3738 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 KMNUMnLSTZ(|7cwR diff --git a/data/interfaces/brink/images/sort_both.png b/data/interfaces/brink/images/sort_both.png deleted file mode 100644 index 4d869170b84e6acb14dae7074a84bb29ec432ce2..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2973 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 TJ?T2C00000NkvXXu0mjfPjrS@ diff --git a/data/interfaces/brink/images/sort_desc.png b/data/interfaces/brink/images/sort_desc.png deleted file mode 100644 index b74e3d102a288a8feeba12ac2a1f153ac191b2c7..0000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 2873 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 XPxu%+%l-ID00000NkvXXu0mjf*U?Zb diff --git a/data/interfaces/brink/index.html b/data/interfaces/brink/index.html deleted file mode 100644 index 3e2f841a..00000000 --- a/data/interfaces/brink/index.html +++ /dev/null @@ -1,165 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="body()"> - - -
- - - - - - - - - - - %for artist in artists: - <% - totaltracks = artist['TotalTracks'] - havetracks = artist['HaveTracks'] - if not havetracks: - havetracks = 0 - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - if releasedate > helpers.today(): - grade = 'A' - else: - grade = 'Z' - elif artist['LatestAlbum']: - releasedate = '' - grade = 'Z' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - grade = 'Z' - albumdisplay = 'None' - - if artist['Status'] == 'Paused': - grade = 'X' - - %> - - - - - - - - - %endfor - -
Artist NameLatest AlbumHave
-
- -
- %if artist['Status'] == 'Loading': -
- -
- %endif -
-
-
${artist['ArtistName']}${albumdisplay} -
- ${havetracks}/${totaltracks} -
-
-
-
- - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/js/configscript.js b/data/interfaces/brink/js/configscript.js deleted file mode 100644 index 8382f5f9..00000000 --- a/data/interfaces/brink/js/configscript.js +++ /dev/null @@ -1,174 +0,0 @@ - -$(document).ready(function() { - // Ajax Config Form - $('.ajax').ajaxForm({ - success: function() { - var noty_id = noty({ - text:' Settings Saved!', - layout: 'bottomRight', - type:'success' - }); - /* - var noty_id = noty({ - text:'Carefull!', - layout: 'bottomRight', - type:'warning' - }); - var noty_id = noty({ - text:' Something went wrong!', - layout: 'bottomRight', - type:'error' - }); - var noty_id = noty({ - text:' Settings has been saved successfully!', - layout: 'bottomRight', - type:'information' - }); - var noty_id = noty({ - text:' Settings has been saved successfully!', - layout: 'bottomRight', - type:'success' - }); - var noty_id = noty({ - text:' Settings has been saved successfully!', - layout: 'bottomRight', - }); - */ - } - }); -}); - -// Enabled/disabled label -$(document).ready(function(){ - $( '.switch' ).each(function(){ - //set Label name to current active state - var labelName = 'label[for="' + $( this ).attr( "name" ) + '"]'; - var switchId = $( this ).attr( "name" ) + "_switch"; - if ( $( this ).is(':checked') ){ - $( labelName ).text( 'Enabled' ); - $("#" + switchId ).slideDown(); - enit(); - } - else { - $( labelName ).text( 'Disabled' ); - $("#" + switchId ).slideUp(); - enit(); - } - //Change label - $( this ).change(function(){ - if ( $( this ).is( ':checked' ) ){ - - $( labelName ).text( 'Enabled' ); - $("#" + switchId ).slideDown(); - enit(); - } - else{ - $( labelName ).text( 'Disabled' ); - $("#" + switchId ).slideUp(); - enit(); - } - }); - }); -}); - - -//Slider for interval -$(function(){ - $( '.sliderInterval' ).each(function(){ - var sliderName = $(this).attr("for"); - var a = $('input[name="' + sliderName + '"]').val(); - var b = 60; - var c = a % b; - if (a == 60){ - $('#' + sliderName ).text( (a-c)/b + " hour" ); - } - else if (c <= 0){ - $('#' + sliderName ).text( (a-c)/b + " hours" ); - } else if ( a >= b ){ - $('#' + sliderName ).text( (a-c)/b + " hours " + c + " minutes" ); - } else { - $('#' + sliderName ).text( a + " minutes" ); - } - // Slider Function - $( this ).slider({ - range: "max", - min: 30, - max: 1440, - step: 10, - value: a, - slide: function( event, ui ) { - a = ui.value; - c = a % b; - if (a == 60){ - $('input[name="' + sliderName + '"]').val( ui.value ); - $('#' + sliderName ).text( (a-c)/b + " hour" ); - } - else if (c <= 0){ - $('input[name="' + sliderName + '"]').val( ui.value ); - $('#' + sliderName ).text( (a-c)/b + " hours" ); - } else if ( a >= b ){ - $('input[name="' + sliderName + '"]').val( ui.value ); - $('#' + sliderName ).text( (a-c)/b + " hours " + c + " minutes" ); - } else { - $('input[name="' + sliderName + '"]').val( ui.value ); - $('#' + sliderName ).text( a + " minutes" ); - } - } - }); - }); -}); - -// Sliders -$(document).ready(function() { - var amountDwnld = $( "#amount-download-scan" ).val(); - $( "#slider-download-scan" ).slider({ - value: amountDwnld, - min: 1, - max: 120, - slide: function( event, ui ) { - $( "#amount-download-scan" ).val(ui.value); - } - }); -}); -$(function() { - var amountSearch = $( "#amount-nbz-search" ).val(); - $( "#slider-nbz-search" ).slider({ - value: amountSearch, - min: 1, - max: 120, - slide: function( event, ui ) { - $( "#amount-nbz-search" ).val(ui.value); - } - }); -}); -$(function() { - var amountLib = $( "#amount-lib-scan" ).val(); - $( "#slider-lib-scan" ).slider({ - value: amountLib, - min: 1, - max: 120, - slide: function( event, ui ) { - $( "#amount-lib-scan" ).val( ui.value ); - } - }); -}); - -hideServerDivs = function () { - $("#customoptions").hide("fast"); - $("#hpserveroptions").hide("fast"); -}; -// end sliders - -handleNewSelection = function () { - - hideServerDivs(); - - switch ($(this).val()) { - case 'custom': - $("#customoptions").show("fast"); - break; - case 'headphones': - $("#hpserveroptions").show("fast"); - break; - } -}; \ No newline at end of file diff --git a/data/interfaces/brink/js/jquery-ui-1.8.21.custom.min.js b/data/interfaces/brink/js/jquery-ui-1.8.21.custom.min.js deleted file mode 100644 index 3fe9ccb7..00000000 --- a/data/interfaces/brink/js/jquery-ui-1.8.21.custom.min.js +++ /dev/null @@ -1,125 +0,0 @@ -/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.core.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){function c(b,c){var e=b.nodeName.toLowerCase();if("area"===e){var f=b.parentNode,g=f.name,h;return!b.href||!g||f.nodeName.toLowerCase()!=="map"?!1:(h=a("img[usemap=#"+g+"]")[0],!!h&&d(h))}return(/input|select|textarea|button|object/.test(e)?!b.disabled:"a"==e?b.href||c:c)&&d(b)}function d(b){return!a(b).parents().andSelf().filter(function(){return a.curCSS(this,"visibility")==="hidden"||a.expr.filters.hidden(this)}).length}a.ui=a.ui||{};if(a.ui.version)return;a.extend(a.ui,{version:"1.8.21",keyCode:{ALT:18,BACKSPACE:8,CAPS_LOCK:20,COMMA:188,COMMAND:91,COMMAND_LEFT:91,COMMAND_RIGHT:93,CONTROL:17,DELETE:46,DOWN:40,END:35,ENTER:13,ESCAPE:27,HOME:36,INSERT:45,LEFT:37,MENU:93,NUMPAD_ADD:107,NUMPAD_DECIMAL:110,NUMPAD_DIVIDE:111,NUMPAD_ENTER:108,NUMPAD_MULTIPLY:106,NUMPAD_SUBTRACT:109,PAGE_DOWN:34,PAGE_UP:33,PERIOD:190,RIGHT:39,SHIFT:16,SPACE:32,TAB:9,UP:38,WINDOWS:91}}),a.fn.extend({propAttr:a.fn.prop||a.fn.attr,_focus:a.fn.focus,focus:function(b,c){return typeof b=="number"?this.each(function(){var d=this;setTimeout(function(){a(d).focus(),c&&c.call(d)},b)}):this._focus.apply(this,arguments)},scrollParent:function(){var b;return a.browser.msie&&/(static|relative)/.test(this.css("position"))||/absolute/.test(this.css("position"))?b=this.parents().filter(function(){return/(relative|absolute|fixed)/.test(a.curCSS(this,"position",1))&&/(auto|scroll)/.test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0):b=this.parents().filter(function(){return/(auto|scroll)/.test(a.curCSS(this,"overflow",1)+a.curCSS(this,"overflow-y",1)+a.curCSS(this,"overflow-x",1))}).eq(0),/fixed/.test(this.css("position"))||!b.length?a(document):b},zIndex:function(c){if(c!==b)return this.css("zIndex",c);if(this.length){var d=a(this[0]),e,f;while(d.length&&d[0]!==document){e=d.css("position");if(e==="absolute"||e==="relative"||e==="fixed"){f=parseInt(d.css("zIndex"),10);if(!isNaN(f)&&f!==0)return f}d=d.parent()}}return 0},disableSelection:function(){return this.bind((a.support.selectstart?"selectstart":"mousedown")+".ui-disableSelection",function(a){a.preventDefault()})},enableSelection:function(){return this.unbind(".ui-disableSelection")}}),a.each(["Width","Height"],function(c,d){function h(b,c,d,f){return a.each(e,function(){c-=parseFloat(a.curCSS(b,"padding"+this,!0))||0,d&&(c-=parseFloat(a.curCSS(b,"border"+this+"Width",!0))||0),f&&(c-=parseFloat(a.curCSS(b,"margin"+this,!0))||0)}),c}var e=d==="Width"?["Left","Right"]:["Top","Bottom"],f=d.toLowerCase(),g={innerWidth:a.fn.innerWidth,innerHeight:a.fn.innerHeight,outerWidth:a.fn.outerWidth,outerHeight:a.fn.outerHeight};a.fn["inner"+d]=function(c){return c===b?g["inner"+d].call(this):this.each(function(){a(this).css(f,h(this,c)+"px")})},a.fn["outer"+d]=function(b,c){return typeof b!="number"?g["outer"+d].call(this,b):this.each(function(){a(this).css(f,h(this,b,!0,c)+"px")})}}),a.extend(a.expr[":"],{data:function(b,c,d){return!!a.data(b,d[3])},focusable:function(b){return c(b,!isNaN(a.attr(b,"tabindex")))},tabbable:function(b){var d=a.attr(b,"tabindex"),e=isNaN(d);return(e||d>=0)&&c(b,!e)}}),a(function(){var b=document.body,c=b.appendChild(c=document.createElement("div"));c.offsetHeight,a.extend(c.style,{minHeight:"100px",height:"auto",padding:0,borderWidth:0}),a.support.minHeight=c.offsetHeight===100,a.support.selectstart="onselectstart"in c,b.removeChild(c).style.display="none"}),a.extend(a.ui,{plugin:{add:function(b,c,d){var e=a.ui[b].prototype;for(var f in d)e.plugins[f]=e.plugins[f]||[],e.plugins[f].push([c,d[f]])},call:function(a,b,c){var d=a.plugins[b];if(!d||!a.element[0].parentNode)return;for(var e=0;e0?!0:(b[d]=1,e=b[d]>0,b[d]=0,e)},isOverAxis:function(a,b,c){return a>b&&a=9||!!b.button?this._mouseStarted?(this._mouseDrag(b),b.preventDefault()):(this._mouseDistanceMet(b)&&this._mouseDelayMet(b)&&(this._mouseStarted=this._mouseStart(this._mouseDownEvent,b)!==!1,this._mouseStarted?this._mouseDrag(b):this._mouseUp(b)),!this._mouseStarted):this._mouseUp(b)},_mouseUp:function(b){return a(document).unbind("mousemove."+this.widgetName,this._mouseMoveDelegate).unbind("mouseup."+this.widgetName,this._mouseUpDelegate),this._mouseStarted&&(this._mouseStarted=!1,b.target==this._mouseDownEvent.target&&a.data(b.target,this.widgetName+".preventClickEvent",!0),this._mouseStop(b)),!1},_mouseDistanceMet:function(a){return Math.max(Math.abs(this._mouseDownEvent.pageX-a.pageX),Math.abs(this._mouseDownEvent.pageY-a.pageY))>=this.options.distance},_mouseDelayMet:function(a){return this.mouseDelayMet},_mouseStart:function(a){},_mouseDrag:function(a){},_mouseStop:function(a){},_mouseCapture:function(a){return!0}})})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.position.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.ui=a.ui||{};var c=/left|center|right/,d=/top|center|bottom/,e="center",f={},g=a.fn.position,h=a.fn.offset;a.fn.position=function(b){if(!b||!b.of)return g.apply(this,arguments);b=a.extend({},b);var h=a(b.of),i=h[0],j=(b.collision||"flip").split(" "),k=b.offset?b.offset.split(" "):[0,0],l,m,n;return i.nodeType===9?(l=h.width(),m=h.height(),n={top:0,left:0}):i.setTimeout?(l=h.width(),m=h.height(),n={top:h.scrollTop(),left:h.scrollLeft()}):i.preventDefault?(b.at="left top",l=m=0,n={top:b.of.pageY,left:b.of.pageX}):(l=h.outerWidth(),m=h.outerHeight(),n=h.offset()),a.each(["my","at"],function(){var a=(b[this]||"").split(" ");a.length===1&&(a=c.test(a[0])?a.concat([e]):d.test(a[0])?[e].concat(a):[e,e]),a[0]=c.test(a[0])?a[0]:e,a[1]=d.test(a[1])?a[1]:e,b[this]=a}),j.length===1&&(j[1]=j[0]),k[0]=parseInt(k[0],10)||0,k.length===1&&(k[1]=k[0]),k[1]=parseInt(k[1],10)||0,b.at[0]==="right"?n.left+=l:b.at[0]===e&&(n.left+=l/2),b.at[1]==="bottom"?n.top+=m:b.at[1]===e&&(n.top+=m/2),n.left+=k[0],n.top+=k[1],this.each(function(){var c=a(this),d=c.outerWidth(),g=c.outerHeight(),h=parseInt(a.curCSS(this,"marginLeft",!0))||0,i=parseInt(a.curCSS(this,"marginTop",!0))||0,o=d+h+(parseInt(a.curCSS(this,"marginRight",!0))||0),p=g+i+(parseInt(a.curCSS(this,"marginBottom",!0))||0),q=a.extend({},n),r;b.my[0]==="right"?q.left-=d:b.my[0]===e&&(q.left-=d/2),b.my[1]==="bottom"?q.top-=g:b.my[1]===e&&(q.top-=g/2),f.fractions||(q.left=Math.round(q.left),q.top=Math.round(q.top)),r={left:q.left-h,top:q.top-i},a.each(["left","top"],function(c,e){a.ui.position[j[c]]&&a.ui.position[j[c]][e](q,{targetWidth:l,targetHeight:m,elemWidth:d,elemHeight:g,collisionPosition:r,collisionWidth:o,collisionHeight:p,offset:k,my:b.my,at:b.at})}),a.fn.bgiframe&&c.bgiframe(),c.offset(a.extend(q,{using:b.using}))})},a.ui.position={fit:{left:function(b,c){var d=a(window),e=c.collisionPosition.left+c.collisionWidth-d.width()-d.scrollLeft();b.left=e>0?b.left-e:Math.max(b.left-c.collisionPosition.left,b.left)},top:function(b,c){var d=a(window),e=c.collisionPosition.top+c.collisionHeight-d.height()-d.scrollTop();b.top=e>0?b.top-e:Math.max(b.top-c.collisionPosition.top,b.top)}},flip:{left:function(b,c){if(c.at[0]===e)return;var d=a(window),f=c.collisionPosition.left+c.collisionWidth-d.width()-d.scrollLeft(),g=c.my[0]==="left"?-c.elemWidth:c.my[0]==="right"?c.elemWidth:0,h=c.at[0]==="left"?c.targetWidth:-c.targetWidth,i=-2*c.offset[0];b.left+=c.collisionPosition.left<0?g+h+i:f>0?g+h+i:0},top:function(b,c){if(c.at[1]===e)return;var d=a(window),f=c.collisionPosition.top+c.collisionHeight-d.height()-d.scrollTop(),g=c.my[1]==="top"?-c.elemHeight:c.my[1]==="bottom"?c.elemHeight:0,h=c.at[1]==="top"?c.targetHeight:-c.targetHeight,i=-2*c.offset[1];b.top+=c.collisionPosition.top<0?g+h+i:f>0?g+h+i:0}}},a.offset.setOffset||(a.offset.setOffset=function(b,c){/static/.test(a.curCSS(b,"position"))&&(b.style.position="relative");var d=a(b),e=d.offset(),f=parseInt(a.curCSS(b,"top",!0),10)||0,g=parseInt(a.curCSS(b,"left",!0),10)||0,h={top:c.top-e.top+f,left:c.left-e.left+g};"using"in c?c.using.call(b,h):d.css(h)},a.fn.offset=function(b){var c=this[0];return!c||!c.ownerDocument?null:b?a.isFunction(b)?this.each(function(c){a(this).offset(b.call(this,c,a(this).offset()))}):this.each(function(){a.offset.setOffset(this,b)}):h.call(this)}),function(){var b=document.getElementsByTagName("body")[0],c=document.createElement("div"),d,e,g,h,i;d=document.createElement(b?"div":"body"),g={visibility:"hidden",width:0,height:0,border:0,margin:0,background:"none"},b&&a.extend(g,{position:"absolute",left:"-1000px",top:"-1000px"});for(var j in g)d.style[j]=g[j];d.appendChild(c),e=b||document.documentElement,e.insertBefore(d,e.firstChild),c.style.cssText="position: absolute; left: 10.7432222px; top: 10.432325px; height: 30px; width: 201px;",h=a(c).offset(function(a,b){return b}).offset(),d.innerHTML="",e.removeChild(d),i=h.top+h.left+(b?2e3:0),f.fractions=i>21&&i<22}()})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.draggable.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.widget("ui.draggable",a.ui.mouse,{widgetEventPrefix:"drag",options:{addClasses:!0,appendTo:"parent",axis:!1,connectToSortable:!1,containment:!1,cursor:"auto",cursorAt:!1,grid:!1,handle:!1,helper:"original",iframeFix:!1,opacity:!1,refreshPositions:!1,revert:!1,revertDuration:500,scope:"default",scroll:!0,scrollSensitivity:20,scrollSpeed:20,snap:!1,snapMode:"both",snapTolerance:20,stack:!1,zIndex:!1},_create:function(){this.options.helper=="original"&&!/^(?:r|a|f)/.test(this.element.css("position"))&&(this.element[0].style.position="relative"),this.options.addClasses&&this.element.addClass("ui-draggable"),this.options.disabled&&this.element.addClass("ui-draggable-disabled"),this._mouseInit()},destroy:function(){if(!this.element.data("draggable"))return;return this.element.removeData("draggable").unbind(".draggable").removeClass("ui-draggable ui-draggable-dragging ui-draggable-disabled"),this._mouseDestroy(),this},_mouseCapture:function(b){var c=this.options;return this.helper||c.disabled||a(b.target).is(".ui-resizable-handle")?!1:(this.handle=this._getHandle(b),this.handle?(c.iframeFix&&a(c.iframeFix===!0?"iframe":c.iframeFix).each(function(){a('
').css({width:this.offsetWidth+"px",height:this.offsetHeight+"px",position:"absolute",opacity:"0.001",zIndex:1e3}).css(a(this).offset()).appendTo("body")}),!0):!1)},_mouseStart:function(b){var c=this.options;return this.helper=this._createHelper(b),this.helper.addClass("ui-draggable-dragging"),this._cacheHelperProportions(),a.ui.ddmanager&&(a.ui.ddmanager.current=this),this._cacheMargins(),this.cssPosition=this.helper.css("position"),this.scrollParent=this.helper.scrollParent(),this.offset=this.positionAbs=this.element.offset(),this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left},a.extend(this.offset,{click:{left:b.pageX-this.offset.left,top:b.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()}),this.originalPosition=this.position=this._generatePosition(b),this.originalPageX=b.pageX,this.originalPageY=b.pageY,c.cursorAt&&this._adjustOffsetFromHelper(c.cursorAt),c.containment&&this._setContainment(),this._trigger("start",b)===!1?(this._clear(),!1):(this._cacheHelperProportions(),a.ui.ddmanager&&!c.dropBehaviour&&a.ui.ddmanager.prepareOffsets(this,b),this._mouseDrag(b,!0),a.ui.ddmanager&&a.ui.ddmanager.dragStart(this,b),!0)},_mouseDrag:function(b,c){this.position=this._generatePosition(b),this.positionAbs=this._convertPositionTo("absolute");if(!c){var d=this._uiHash();if(this._trigger("drag",b,d)===!1)return this._mouseUp({}),!1;this.position=d.position}if(!this.options.axis||this.options.axis!="y")this.helper[0].style.left=this.position.left+"px";if(!this.options.axis||this.options.axis!="x")this.helper[0].style.top=this.position.top+"px";return a.ui.ddmanager&&a.ui.ddmanager.drag(this,b),!1},_mouseStop:function(b){var c=!1;a.ui.ddmanager&&!this.options.dropBehaviour&&(c=a.ui.ddmanager.drop(this,b)),this.dropped&&(c=this.dropped,this.dropped=!1);var d=this.element[0],e=!1;while(d&&(d=d.parentNode))d==document&&(e=!0);if(!e&&this.options.helper==="original")return!1;if(this.options.revert=="invalid"&&!c||this.options.revert=="valid"&&c||this.options.revert===!0||a.isFunction(this.options.revert)&&this.options.revert.call(this.element,c)){var f=this;a(this.helper).animate(this.originalPosition,parseInt(this.options.revertDuration,10),function(){f._trigger("stop",b)!==!1&&f._clear()})}else this._trigger("stop",b)!==!1&&this._clear();return!1},_mouseUp:function(b){return this.options.iframeFix===!0&&a("div.ui-draggable-iframeFix").each(function(){this.parentNode.removeChild(this)}),a.ui.ddmanager&&a.ui.ddmanager.dragStop(this,b),a.ui.mouse.prototype._mouseUp.call(this,b)},cancel:function(){return this.helper.is(".ui-draggable-dragging")?this._mouseUp({}):this._clear(),this},_getHandle:function(b){var c=!this.options.handle||!a(this.options.handle,this.element).length?!0:!1;return a(this.options.handle,this.element).find("*").andSelf().each(function(){this==b.target&&(c=!0)}),c},_createHelper:function(b){var c=this.options,d=a.isFunction(c.helper)?a(c.helper.apply(this.element[0],[b])):c.helper=="clone"?this.element.clone().removeAttr("id"):this.element;return d.parents("body").length||d.appendTo(c.appendTo=="parent"?this.element[0].parentNode:c.appendTo),d[0]!=this.element[0]&&!/(fixed|absolute)/.test(d.css("position"))&&d.css("position","absolute"),d},_adjustOffsetFromHelper:function(b){typeof b=="string"&&(b=b.split(" ")),a.isArray(b)&&(b={left:+b[0],top:+b[1]||0}),"left"in b&&(this.offset.click.left=b.left+this.margins.left),"right"in b&&(this.offset.click.left=this.helperProportions.width-b.right+this.margins.left),"top"in b&&(this.offset.click.top=b.top+this.margins.top),"bottom"in b&&(this.offset.click.top=this.helperProportions.height-b.bottom+this.margins.top)},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var b=this.offsetParent.offset();this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&a.ui.contains(this.scrollParent[0],this.offsetParent[0])&&(b.left+=this.scrollParent.scrollLeft(),b.top+=this.scrollParent.scrollTop());if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&a.browser.msie)b={top:0,left:0};return{top:b.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:b.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.element.position();return{top:a.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.element.css("marginLeft"),10)||0,top:parseInt(this.element.css("marginTop"),10)||0,right:parseInt(this.element.css("marginRight"),10)||0,bottom:parseInt(this.element.css("marginBottom"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var b=this.options;b.containment=="parent"&&(b.containment=this.helper[0].parentNode);if(b.containment=="document"||b.containment=="window")this.containment=[b.containment=="document"?0:a(window).scrollLeft()-this.offset.relative.left-this.offset.parent.left,b.containment=="document"?0:a(window).scrollTop()-this.offset.relative.top-this.offset.parent.top,(b.containment=="document"?0:a(window).scrollLeft())+a(b.containment=="document"?document:window).width()-this.helperProportions.width-this.margins.left,(b.containment=="document"?0:a(window).scrollTop())+(a(b.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(b.containment)&&b.containment.constructor!=Array){var c=a(b.containment),d=c[0];if(!d)return;var e=c.offset(),f=a(d).css("overflow")!="hidden";this.containment=[(parseInt(a(d).css("borderLeftWidth"),10)||0)+(parseInt(a(d).css("paddingLeft"),10)||0),(parseInt(a(d).css("borderTopWidth"),10)||0)+(parseInt(a(d).css("paddingTop"),10)||0),(f?Math.max(d.scrollWidth,d.offsetWidth):d.offsetWidth)-(parseInt(a(d).css("borderLeftWidth"),10)||0)-(parseInt(a(d).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left-this.margins.right,(f?Math.max(d.scrollHeight,d.offsetHeight):d.offsetHeight)-(parseInt(a(d).css("borderTopWidth"),10)||0)-(parseInt(a(d).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top-this.margins.bottom],this.relative_container=c}else b.containment.constructor==Array&&(this.containment=b.containment)},_convertPositionTo:function(b,c){c||(c=this.position);var d=b=="absolute"?1:-1,e=this.options,f=this.cssPosition=="absolute"&&(this.scrollParent[0]==document||!a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,g=/(html|body)/i.test(f[0].tagName);return{top:c.top+this.offset.relative.top*d+this.offset.parent.top*d-(a.browser.safari&&a.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():g?0:f.scrollTop())*d),left:c.left+this.offset.relative.left*d+this.offset.parent.left*d-(a.browser.safari&&a.browser.version<526&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():g?0:f.scrollLeft())*d)}},_generatePosition:function(b){var c=this.options,d=this.cssPosition=="absolute"&&(this.scrollParent[0]==document||!a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(d[0].tagName),f=b.pageX,g=b.pageY;if(this.originalPosition){var h;if(this.containment){if(this.relative_container){var i=this.relative_container.offset();h=[this.containment[0]+i.left,this.containment[1]+i.top,this.containment[2]+i.left,this.containment[3]+i.top]}else h=this.containment;b.pageX-this.offset.click.lefth[2]&&(f=h[2]+this.offset.click.left),b.pageY-this.offset.click.top>h[3]&&(g=h[3]+this.offset.click.top)}if(c.grid){var j=c.grid[1]?this.originalPageY+Math.round((g-this.originalPageY)/c.grid[1])*c.grid[1]:this.originalPageY;g=h?j-this.offset.click.toph[3]?j-this.offset.click.toph[2]?k-this.offset.click.left=0;k--){var l=d.snapElements[k].left,m=l+d.snapElements[k].width,n=d.snapElements[k].top,o=n+d.snapElements[k].height;if(!(l-f=k&&g<=l||h>=k&&h<=l||gl)&&(e>=i&&e<=j||f>=i&&f<=j||ej);default:return!1}},a.ui.ddmanager={current:null,droppables:{"default":[]},prepareOffsets:function(b,c){var d=a.ui.ddmanager.droppables[b.options.scope]||[],e=c?c.type:null,f=(b.currentItem||b.element).find(":data(droppable)").andSelf();g:for(var h=0;h
').css({position:this.element.css("position"),width:this.element.outerWidth(),height:this.element.outerHeight(),top:this.element.css("top"),left:this.element.css("left")})),this.element=this.element.parent().data("resizable",this.element.data("resizable")),this.elementIsWrapper=!0,this.element.css({marginLeft:this.originalElement.css("marginLeft"),marginTop:this.originalElement.css("marginTop"),marginRight:this.originalElement.css("marginRight"),marginBottom:this.originalElement.css("marginBottom")}),this.originalElement.css({marginLeft:0,marginTop:0,marginRight:0,marginBottom:0}),this.originalResizeStyle=this.originalElement.css("resize"),this.originalElement.css("resize","none"),this._proportionallyResizeElements.push(this.originalElement.css({position:"static",zoom:1,display:"block"})),this.originalElement.css({margin:this.originalElement.css("margin")}),this._proportionallyResize()),this.handles=c.handles||(a(".ui-resizable-handle",this.element).length?{n:".ui-resizable-n",e:".ui-resizable-e",s:".ui-resizable-s",w:".ui-resizable-w",se:".ui-resizable-se",sw:".ui-resizable-sw",ne:".ui-resizable-ne",nw:".ui-resizable-nw"}:"e,s,se");if(this.handles.constructor==String){this.handles=="all"&&(this.handles="n,e,s,w,se,sw,ne,nw");var d=this.handles.split(",");this.handles={};for(var e=0;e');h.css({zIndex:c.zIndex}),"se"==f&&h.addClass("ui-icon ui-icon-gripsmall-diagonal-se"),this.handles[f]=".ui-resizable-"+f,this.element.append(h)}}this._renderAxis=function(b){b=b||this.element;for(var c in this.handles){this.handles[c].constructor==String&&(this.handles[c]=a(this.handles[c],this.element).show());if(this.elementIsWrapper&&this.originalElement[0].nodeName.match(/textarea|input|select|button/i)){var d=a(this.handles[c],this.element),e=0;e=/sw|ne|nw|se|n|s/.test(c)?d.outerHeight():d.outerWidth();var f=["padding",/ne|nw|n/.test(c)?"Top":/se|sw|s/.test(c)?"Bottom":/^e$/.test(c)?"Right":"Left"].join("");b.css(f,e),this._proportionallyResize()}if(!a(this.handles[c]).length)continue}},this._renderAxis(this.element),this._handles=a(".ui-resizable-handle",this.element).disableSelection(),this._handles.mouseover(function(){if(!b.resizing){if(this.className)var a=this.className.match(/ui-resizable-(se|sw|ne|nw|n|e|s|w)/i);b.axis=a&&a[1]?a[1]:"se"}}),c.autoHide&&(this._handles.hide(),a(this.element).addClass("ui-resizable-autohide").hover(function(){if(c.disabled)return;a(this).removeClass("ui-resizable-autohide"),b._handles.show()},function(){if(c.disabled)return;b.resizing||(a(this).addClass("ui-resizable-autohide"),b._handles.hide())})),this._mouseInit()},destroy:function(){this._mouseDestroy();var b=function(b){a(b).removeClass("ui-resizable ui-resizable-disabled ui-resizable-resizing").removeData("resizable").unbind(".resizable").find(".ui-resizable-handle").remove()};if(this.elementIsWrapper){b(this.element);var c=this.element;c.after(this.originalElement.css({position:c.css("position"),width:c.outerWidth(),height:c.outerHeight(),top:c.css("top"),left:c.css("left")})).remove()}return this.originalElement.css("resize",this.originalResizeStyle),b(this.originalElement),this},_mouseCapture:function(b){var c=!1;for(var d in this.handles)a(this.handles[d])[0]==b.target&&(c=!0);return!this.options.disabled&&c},_mouseStart:function(b){var d=this.options,e=this.element.position(),f=this.element;this.resizing=!0,this.documentScroll={top:a(document).scrollTop(),left:a(document).scrollLeft()},(f.is(".ui-draggable")||/absolute/.test(f.css("position")))&&f.css({position:"absolute",top:e.top,left:e.left}),this._renderProxy();var g=c(this.helper.css("left")),h=c(this.helper.css("top"));d.containment&&(g+=a(d.containment).scrollLeft()||0,h+=a(d.containment).scrollTop()||0),this.offset=this.helper.offset(),this.position={left:g,top:h},this.size=this._helper?{width:f.outerWidth(),height:f.outerHeight()}:{width:f.width(),height:f.height()},this.originalSize=this._helper?{width:f.outerWidth(),height:f.outerHeight()}:{width:f.width(),height:f.height()},this.originalPosition={left:g,top:h},this.sizeDiff={width:f.outerWidth()-f.width(),height:f.outerHeight()-f.height()},this.originalMousePosition={left:b.pageX,top:b.pageY},this.aspectRatio=typeof d.aspectRatio=="number"?d.aspectRatio:this.originalSize.width/this.originalSize.height||1;var i=a(".ui-resizable-"+this.axis).css("cursor");return a("body").css("cursor",i=="auto"?this.axis+"-resize":i),f.addClass("ui-resizable-resizing"),this._propagate("start",b),!0},_mouseDrag:function(b){var c=this.helper,d=this.options,e={},f=this,g=this.originalMousePosition,h=this.axis,i=b.pageX-g.left||0,j=b.pageY-g.top||0,k=this._change[h];if(!k)return!1;var l=k.apply(this,[b,i,j]),m=a.browser.msie&&a.browser.version<7,n=this.sizeDiff;this._updateVirtualBoundaries(b.shiftKey);if(this._aspectRatio||b.shiftKey)l=this._updateRatio(l,b);return l=this._respectSize(l,b),this._propagate("resize",b),c.css({top:this.position.top+"px",left:this.position.left+"px",width:this.size.width+"px",height:this.size.height+"px"}),!this._helper&&this._proportionallyResizeElements.length&&this._proportionallyResize(),this._updateCache(l),this._trigger("resize",b,this.ui()),!1},_mouseStop:function(b){this.resizing=!1;var c=this.options,d=this;if(this._helper){var e=this._proportionallyResizeElements,f=e.length&&/textarea/i.test(e[0].nodeName),g=f&&a.ui.hasScroll(e[0],"left")?0:d.sizeDiff.height,h=f?0:d.sizeDiff.width,i={width:d.helper.width()-h,height:d.helper.height()-g},j=parseInt(d.element.css("left"),10)+(d.position.left-d.originalPosition.left)||null,k=parseInt(d.element.css("top"),10)+(d.position.top-d.originalPosition.top)||null;c.animate||this.element.css(a.extend(i,{top:k,left:j})),d.helper.height(d.size.height),d.helper.width(d.size.width),this._helper&&!c.animate&&this._proportionallyResize()}return a("body").css("cursor","auto"),this.element.removeClass("ui-resizable-resizing"),this._propagate("stop",b),this._helper&&this.helper.remove(),!1},_updateVirtualBoundaries:function(a){var b=this.options,c,e,f,g,h;h={minWidth:d(b.minWidth)?b.minWidth:0,maxWidth:d(b.maxWidth)?b.maxWidth:Infinity,minHeight:d(b.minHeight)?b.minHeight:0,maxHeight:d(b.maxHeight)?b.maxHeight:Infinity};if(this._aspectRatio||a)c=h.minHeight*this.aspectRatio,f=h.minWidth/this.aspectRatio,e=h.maxHeight*this.aspectRatio,g=h.maxWidth/this.aspectRatio,c>h.minWidth&&(h.minWidth=c),f>h.minHeight&&(h.minHeight=f),ea.width,k=d(a.height)&&e.minHeight&&e.minHeight>a.height;j&&(a.width=e.minWidth),k&&(a.height=e.minHeight),h&&(a.width=e.maxWidth),i&&(a.height=e.maxHeight);var l=this.originalPosition.left+this.originalSize.width,m=this.position.top+this.size.height,n=/sw|nw|w/.test(g),o=/nw|ne|n/.test(g);j&&n&&(a.left=l-e.minWidth),h&&n&&(a.left=l-e.maxWidth),k&&o&&(a.top=m-e.minHeight),i&&o&&(a.top=m-e.maxHeight);var p=!a.width&&!a.height;return p&&!a.left&&a.top?a.top=null:p&&!a.top&&a.left&&(a.left=null),a},_proportionallyResize:function(){var b=this.options;if(!this._proportionallyResizeElements.length)return;var c=this.helper||this.element;for(var d=0;d');var d=a.browser.msie&&a.browser.version<7,e=d?1:0,f=d?2:-1;this.helper.addClass(this._helper).css({width:this.element.outerWidth()+f,height:this.element.outerHeight()+f,position:"absolute",left:this.elementOffset.left-e+"px",top:this.elementOffset.top-e+"px",zIndex:++c.zIndex}),this.helper.appendTo("body").disableSelection()}else this.helper=this.element},_change:{e:function(a,b,c){return{width:this.originalSize.width+b}},w:function(a,b,c){var d=this.options,e=this.originalSize,f=this.originalPosition;return{left:f.left+b,width:e.width-b}},n:function(a,b,c){var d=this.options,e=this.originalSize,f=this.originalPosition;return{top:f.top+c,height:e.height-c}},s:function(a,b,c){return{height:this.originalSize.height+c}},se:function(b,c,d){return a.extend(this._change.s.apply(this,arguments),this._change.e.apply(this,[b,c,d]))},sw:function(b,c,d){return a.extend(this._change.s.apply(this,arguments),this._change.w.apply(this,[b,c,d]))},ne:function(b,c,d){return a.extend(this._change.n.apply(this,arguments),this._change.e.apply(this,[b,c,d]))},nw:function(b,c,d){return a.extend(this._change.n.apply(this,arguments),this._change.w.apply(this,[b,c,d]))}},_propagate:function(b,c){a.ui.plugin.call(this,b,[c,this.ui()]),b!="resize"&&this._trigger(b,c,this.ui())},plugins:{},ui:function(){return{originalElement:this.originalElement,element:this.element,helper:this.helper,position:this.position,size:this.size,originalSize:this.originalSize,originalPosition:this.originalPosition}}}),a.extend(a.ui.resizable,{version:"1.8.21"}),a.ui.plugin.add("resizable","alsoResize",{start:function(b,c){var d=a(this).data("resizable"),e=d.options,f=function(b){a(b).each(function(){var b=a(this);b.data("resizable-alsoresize",{width:parseInt(b.width(),10),height:parseInt(b.height(),10),left:parseInt(b.css("left"),10),top:parseInt(b.css("top"),10)})})};typeof e.alsoResize=="object"&&!e.alsoResize.parentNode?e.alsoResize.length?(e.alsoResize=e.alsoResize[0],f(e.alsoResize)):a.each(e.alsoResize,function(a){f(a)}):f(e.alsoResize)},resize:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d.originalSize,g=d.originalPosition,h={height:d.size.height-f.height||0,width:d.size.width-f.width||0,top:d.position.top-g.top||0,left:d.position.left-g.left||0},i=function(b,d){a(b).each(function(){var b=a(this),e=a(this).data("resizable-alsoresize"),f={},g=d&&d.length?d:b.parents(c.originalElement[0]).length?["width","height"]:["width","height","top","left"];a.each(g,function(a,b){var c=(e[b]||0)+(h[b]||0);c&&c>=0&&(f[b]=c||null)}),b.css(f)})};typeof e.alsoResize=="object"&&!e.alsoResize.nodeType?a.each(e.alsoResize,function(a,b){i(a,b)}):i(e.alsoResize)},stop:function(b,c){a(this).removeData("resizable-alsoresize")}}),a.ui.plugin.add("resizable","animate",{stop:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d._proportionallyResizeElements,g=f.length&&/textarea/i.test(f[0].nodeName),h=g&&a.ui.hasScroll(f[0],"left")?0:d.sizeDiff.height,i=g?0:d.sizeDiff.width,j={width:d.size.width-i,height:d.size.height-h},k=parseInt(d.element.css("left"),10)+(d.position.left-d.originalPosition.left)||null,l=parseInt(d.element.css("top"),10)+(d.position.top-d.originalPosition.top)||null;d.element.animate(a.extend(j,l&&k?{top:l,left:k}:{}),{duration:e.animateDuration,easing:e.animateEasing,step:function(){var c={width:parseInt(d.element.css("width"),10),height:parseInt(d.element.css("height"),10),top:parseInt(d.element.css("top"),10),left:parseInt(d.element.css("left"),10)};f&&f.length&&a(f[0]).css({width:c.width,height:c.height}),d._updateCache(c),d._propagate("resize",b)}})}}),a.ui.plugin.add("resizable","containment",{start:function(b,d){var e=a(this).data("resizable"),f=e.options,g=e.element,h=f.containment,i=h instanceof a?h.get(0):/parent/.test(h)?g.parent().get(0):h;if(!i)return;e.containerElement=a(i);if(/document/.test(h)||h==document)e.containerOffset={left:0,top:0},e.containerPosition={left:0,top:0},e.parentData={element:a(document),left:0,top:0,width:a(document).width(),height:a(document).height()||document.body.parentNode.scrollHeight};else{var j=a(i),k=[];a(["Top","Right","Left","Bottom"]).each(function(a,b){k[a]=c(j.css("padding"+b))}),e.containerOffset=j.offset(),e.containerPosition=j.position(),e.containerSize={height:j.innerHeight()-k[3],width:j.innerWidth()-k[1]};var l=e.containerOffset,m=e.containerSize.height,n=e.containerSize.width,o=a.ui.hasScroll(i,"left")?i.scrollWidth:n,p=a.ui.hasScroll(i)?i.scrollHeight:m;e.parentData={element:i,left:l.left,top:l.top,width:o,height:p}}},resize:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d.containerSize,g=d.containerOffset,h=d.size,i=d.position,j=d._aspectRatio||b.shiftKey,k={top:0,left:0},l=d.containerElement;l[0]!=document&&/static/.test(l.css("position"))&&(k=g),i.left<(d._helper?g.left:0)&&(d.size.width=d.size.width+(d._helper?d.position.left-g.left:d.position.left-k.left),j&&(d.size.height=d.size.width/d.aspectRatio),d.position.left=e.helper?g.left:0),i.top<(d._helper?g.top:0)&&(d.size.height=d.size.height+(d._helper?d.position.top-g.top:d.position.top),j&&(d.size.width=d.size.height*d.aspectRatio),d.position.top=d._helper?g.top:0),d.offset.left=d.parentData.left+d.position.left,d.offset.top=d.parentData.top+d.position.top;var m=Math.abs((d._helper?d.offset.left-k.left:d.offset.left-k.left)+d.sizeDiff.width),n=Math.abs((d._helper?d.offset.top-k.top:d.offset.top-g.top)+d.sizeDiff.height),o=d.containerElement.get(0)==d.element.parent().get(0),p=/relative|absolute/.test(d.containerElement.css("position"));o&&p&&(m-=d.parentData.left),m+d.size.width>=d.parentData.width&&(d.size.width=d.parentData.width-m,j&&(d.size.height=d.size.width/d.aspectRatio)),n+d.size.height>=d.parentData.height&&(d.size.height=d.parentData.height-n,j&&(d.size.width=d.size.height*d.aspectRatio))},stop:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d.position,g=d.containerOffset,h=d.containerPosition,i=d.containerElement,j=a(d.helper),k=j.offset(),l=j.outerWidth()-d.sizeDiff.width,m=j.outerHeight()-d.sizeDiff.height;d._helper&&!e.animate&&/relative/.test(i.css("position"))&&a(this).css({left:k.left-h.left-g.left,width:l,height:m}),d._helper&&!e.animate&&/static/.test(i.css("position"))&&a(this).css({left:k.left-h.left-g.left,width:l,height:m})}}),a.ui.plugin.add("resizable","ghost",{start:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d.size;d.ghost=d.originalElement.clone(),d.ghost.css({opacity:.25,display:"block",position:"relative",height:f.height,width:f.width,margin:0,left:0,top:0}).addClass("ui-resizable-ghost").addClass(typeof e.ghost=="string"?e.ghost:""),d.ghost.appendTo(d.helper)},resize:function(b,c){var d=a(this).data("resizable"),e=d.options;d.ghost&&d.ghost.css({position:"relative",height:d.size.height,width:d.size.width})},stop:function(b,c){var d=a(this).data("resizable"),e=d.options;d.ghost&&d.helper&&d.helper.get(0).removeChild(d.ghost.get(0))}}),a.ui.plugin.add("resizable","grid",{resize:function(b,c){var d=a(this).data("resizable"),e=d.options,f=d.size,g=d.originalSize,h=d.originalPosition,i=d.axis,j=e._aspectRatio||b.shiftKey;e.grid=typeof e.grid=="number"?[e.grid,e.grid]:e.grid;var k=Math.round((f.width-g.width)/(e.grid[0]||1))*(e.grid[0]||1),l=Math.round((f.height-g.height)/(e.grid[1]||1))*(e.grid[1]||1);/^(se|s|e)$/.test(i)?(d.size.width=g.width+k,d.size.height=g.height+l):/^(ne)$/.test(i)?(d.size.width=g.width+k,d.size.height=g.height+l,d.position.top=h.top-l):/^(sw)$/.test(i)?(d.size.width=g.width+k,d.size.height=g.height+l,d.position.left=h.left-k):(d.size.width=g.width+k,d.size.height=g.height+l,d.position.top=h.top-l,d.position.left=h.left-k)}});var c=function(a){return parseInt(a,10)||0},d=function(a){return!isNaN(parseInt(a,10))}})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.selectable.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.widget("ui.selectable",a.ui.mouse,{options:{appendTo:"body",autoRefresh:!0,distance:0,filter:"*",tolerance:"touch"},_create:function(){var b=this;this.element.addClass("ui-selectable"),this.dragged=!1;var c;this.refresh=function(){c=a(b.options.filter,b.element[0]),c.addClass("ui-selectee"),c.each(function(){var b=a(this),c=b.offset();a.data(this,"selectable-item",{element:this,$element:b,left:c.left,top:c.top,right:c.left+b.outerWidth(),bottom:c.top+b.outerHeight(),startselected:!1,selected:b.hasClass("ui-selected"),selecting:b.hasClass("ui-selecting"),unselecting:b.hasClass("ui-unselecting")})})},this.refresh(),this.selectees=c.addClass("ui-selectee"),this._mouseInit(),this.helper=a("
")},destroy:function(){return this.selectees.removeClass("ui-selectee").removeData("selectable-item"),this.element.removeClass("ui-selectable ui-selectable-disabled").removeData("selectable").unbind(".selectable"),this._mouseDestroy(),this},_mouseStart:function(b){var c=this;this.opos=[b.pageX,b.pageY];if(this.options.disabled)return;var d=this.options;this.selectees=a(d.filter,this.element[0]),this._trigger("start",b),a(d.appendTo).append(this.helper),this.helper.css({left:b.clientX,top:b.clientY,width:0,height:0}),d.autoRefresh&&this.refresh(),this.selectees.filter(".ui-selected").each(function(){var d=a.data(this,"selectable-item");d.startselected=!0,!b.metaKey&&!b.ctrlKey&&(d.$element.removeClass("ui-selected"),d.selected=!1,d.$element.addClass("ui-unselecting"),d.unselecting=!0,c._trigger("unselecting",b,{unselecting:d.element}))}),a(b.target).parents().andSelf().each(function(){var d=a.data(this,"selectable-item");if(d){var e=!b.metaKey&&!b.ctrlKey||!d.$element.hasClass("ui-selected");return d.$element.removeClass(e?"ui-unselecting":"ui-selected").addClass(e?"ui-selecting":"ui-unselecting"),d.unselecting=!e,d.selecting=e,d.selected=e,e?c._trigger("selecting",b,{selecting:d.element}):c._trigger("unselecting",b,{unselecting:d.element}),!1}})},_mouseDrag:function(b){var c=this;this.dragged=!0;if(this.options.disabled)return;var d=this.options,e=this.opos[0],f=this.opos[1],g=b.pageX,h=b.pageY;if(e>g){var i=g;g=e,e=i}if(f>h){var i=h;h=f,f=i}return this.helper.css({left:e,top:f,width:g-e,height:h-f}),this.selectees.each(function(){var i=a.data(this,"selectable-item");if(!i||i.element==c.element[0])return;var j=!1;d.tolerance=="touch"?j=!(i.left>g||i.righth||i.bottome&&i.rightf&&i.bottom *",opacity:!1,placeholder:!1,revert:!1,scroll:!0,scrollSensitivity:20,scrollSpeed:20,scope:"default",tolerance:"intersect",zIndex:1e3},_create:function(){var a=this.options;this.containerCache={},this.element.addClass("ui-sortable"),this.refresh(),this.floating=this.items.length?a.axis==="x"||/left|right/.test(this.items[0].item.css("float"))||/inline|table-cell/.test(this.items[0].item.css("display")):!1,this.offset=this.element.offset(),this._mouseInit(),this.ready=!0},destroy:function(){a.Widget.prototype.destroy.call(this),this.element.removeClass("ui-sortable ui-sortable-disabled"),this._mouseDestroy();for(var b=this.items.length-1;b>=0;b--)this.items[b].item.removeData(this.widgetName+"-item");return this},_setOption:function(b,c){b==="disabled"?(this.options[b]=c,this.widget()[c?"addClass":"removeClass"]("ui-sortable-disabled")):a.Widget.prototype._setOption.apply(this,arguments)},_mouseCapture:function(b,c){var d=this;if(this.reverting)return!1;if(this.options.disabled||this.options.type=="static")return!1;this._refreshItems(b);var e=null,f=this,g=a(b.target).parents().each(function(){if(a.data(this,d.widgetName+"-item")==f)return e=a(this),!1});a.data(b.target,d.widgetName+"-item")==f&&(e=a(b.target));if(!e)return!1;if(this.options.handle&&!c){var h=!1;a(this.options.handle,e).find("*").andSelf().each(function(){this==b.target&&(h=!0)});if(!h)return!1}return this.currentItem=e,this._removeCurrentsFromItems(),!0},_mouseStart:function(b,c,d){var e=this.options,f=this;this.currentContainer=this,this.refreshPositions(),this.helper=this._createHelper(b),this._cacheHelperProportions(),this._cacheMargins(),this.scrollParent=this.helper.scrollParent(),this.offset=this.currentItem.offset(),this.offset={top:this.offset.top-this.margins.top,left:this.offset.left-this.margins.left},a.extend(this.offset,{click:{left:b.pageX-this.offset.left,top:b.pageY-this.offset.top},parent:this._getParentOffset(),relative:this._getRelativeOffset()}),this.helper.css("position","absolute"),this.cssPosition=this.helper.css("position"),this.originalPosition=this._generatePosition(b),this.originalPageX=b.pageX,this.originalPageY=b.pageY,e.cursorAt&&this._adjustOffsetFromHelper(e.cursorAt),this.domPosition={prev:this.currentItem.prev()[0],parent:this.currentItem.parent()[0]},this.helper[0]!=this.currentItem[0]&&this.currentItem.hide(),this._createPlaceholder(),e.containment&&this._setContainment(),e.cursor&&(a("body").css("cursor")&&(this._storedCursor=a("body").css("cursor")),a("body").css("cursor",e.cursor)),e.opacity&&(this.helper.css("opacity")&&(this._storedOpacity=this.helper.css("opacity")),this.helper.css("opacity",e.opacity)),e.zIndex&&(this.helper.css("zIndex")&&(this._storedZIndex=this.helper.css("zIndex")),this.helper.css("zIndex",e.zIndex)),this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"&&(this.overflowOffset=this.scrollParent.offset()),this._trigger("start",b,this._uiHash()),this._preserveHelperProportions||this._cacheHelperProportions();if(!d)for(var g=this.containers.length-1;g>=0;g--)this.containers[g]._trigger("activate",b,f._uiHash(this));return a.ui.ddmanager&&(a.ui.ddmanager.current=this),a.ui.ddmanager&&!e.dropBehaviour&&a.ui.ddmanager.prepareOffsets(this,b),this.dragging=!0,this.helper.addClass("ui-sortable-helper"),this._mouseDrag(b),!0},_mouseDrag:function(b){this.position=this._generatePosition(b),this.positionAbs=this._convertPositionTo("absolute"),this.lastPositionAbs||(this.lastPositionAbs=this.positionAbs);if(this.options.scroll){var c=this.options,d=!1;this.scrollParent[0]!=document&&this.scrollParent[0].tagName!="HTML"?(this.overflowOffset.top+this.scrollParent[0].offsetHeight-b.pageY=0;e--){var f=this.items[e],g=f.item[0],h=this._intersectsWithPointer(f);if(!h)continue;if(g!=this.currentItem[0]&&this.placeholder[h==1?"next":"prev"]()[0]!=g&&!a.ui.contains(this.placeholder[0],g)&&(this.options.type=="semi-dynamic"?!a.ui.contains(this.element[0],g):!0)){this.direction=h==1?"down":"up";if(this.options.tolerance=="pointer"||this._intersectsWithSides(f))this._rearrange(b,f);else break;this._trigger("change",b,this._uiHash());break}}return this._contactContainers(b),a.ui.ddmanager&&a.ui.ddmanager.drag(this,b),this._trigger("sort",b,this._uiHash()),this.lastPositionAbs=this.positionAbs,!1},_mouseStop:function(b,c){if(!b)return;a.ui.ddmanager&&!this.options.dropBehaviour&&a.ui.ddmanager.drop(this,b);if(this.options.revert){var d=this,e=d.placeholder.offset();d.reverting=!0,a(this.helper).animate({left:e.left-this.offset.parent.left-d.margins.left+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollLeft),top:e.top-this.offset.parent.top-d.margins.top+(this.offsetParent[0]==document.body?0:this.offsetParent[0].scrollTop)},parseInt(this.options.revert,10)||500,function(){d._clear(b)})}else this._clear(b,c);return!1},cancel:function(){var b=this;if(this.dragging){this._mouseUp({target:null}),this.options.helper=="original"?this.currentItem.css(this._storedCSS).removeClass("ui-sortable-helper"):this.currentItem.show();for(var c=this.containers.length-1;c>=0;c--)this.containers[c]._trigger("deactivate",null,b._uiHash(this)),this.containers[c].containerCache.over&&(this.containers[c]._trigger("out",null,b._uiHash(this)),this.containers[c].containerCache.over=0)}return this.placeholder&&(this.placeholder[0].parentNode&&this.placeholder[0].parentNode.removeChild(this.placeholder[0]),this.options.helper!="original"&&this.helper&&this.helper[0].parentNode&&this.helper.remove(),a.extend(this,{helper:null,dragging:!1,reverting:!1,_noFinalSort:null}),this.domPosition.prev?a(this.domPosition.prev).after(this.currentItem):a(this.domPosition.parent).prepend(this.currentItem)),this},serialize:function(b){var c=this._getItemsAsjQuery(b&&b.connected),d=[];return b=b||{},a(c).each(function(){var c=(a(b.item||this).attr(b.attribute||"id")||"").match(b.expression||/(.+)[-=_](.+)/);c&&d.push((b.key||c[1]+"[]")+"="+(b.key&&b.expression?c[1]:c[2]))}),!d.length&&b.key&&d.push(b.key+"="),d.join("&")},toArray:function(b){var c=this._getItemsAsjQuery(b&&b.connected),d=[];return b=b||{},c.each(function(){d.push(a(b.item||this).attr(b.attribute||"id")||"")}),d},_intersectsWith:function(a){var b=this.positionAbs.left,c=b+this.helperProportions.width,d=this.positionAbs.top,e=d+this.helperProportions.height,f=a.left,g=f+a.width,h=a.top,i=h+a.height,j=this.offset.click.top,k=this.offset.click.left,l=d+j>h&&d+jf&&b+ka[this.floating?"width":"height"]?l:f0?"down":"up")},_getDragHorizontalDirection:function(){var a=this.positionAbs.left-this.lastPositionAbs.left;return a!=0&&(a>0?"right":"left")},refresh:function(a){return this._refreshItems(a),this.refreshPositions(),this},_connectWith:function(){var a=this.options;return a.connectWith.constructor==String?[a.connectWith]:a.connectWith},_getItemsAsjQuery:function(b){var c=this,d=[],e=[],f=this._connectWith();if(f&&b)for(var g=f.length-1;g>=0;g--){var h=a(f[g]);for(var i=h.length-1;i>=0;i--){var j=a.data(h[i],this.widgetName);j&&j!=this&&!j.options.disabled&&e.push([a.isFunction(j.options.items)?j.options.items.call(j.element):a(j.options.items,j.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"),j])}}e.push([a.isFunction(this.options.items)?this.options.items.call(this.element,null,{options:this.options,item:this.currentItem}):a(this.options.items,this.element).not(".ui-sortable-helper").not(".ui-sortable-placeholder"),this]);for(var g=e.length-1;g>=0;g--)e[g][0].each(function(){d.push(this)});return a(d)},_removeCurrentsFromItems:function(){var a=this.currentItem.find(":data("+this.widgetName+"-item)");for(var b=0;b=0;g--){var h=a(f[g]);for(var i=h.length-1;i>=0;i--){var j=a.data(h[i],this.widgetName);j&&j!=this&&!j.options.disabled&&(e.push([a.isFunction(j.options.items)?j.options.items.call(j.element[0],b,{item:this.currentItem}):a(j.options.items,j.element),j]),this.containers.push(j))}}for(var g=e.length-1;g>=0;g--){var k=e[g][1],l=e[g][0];for(var i=0,m=l.length;i=0;c--){var d=this.items[c];if(d.instance!=this.currentContainer&&this.currentContainer&&d.item[0]!=this.currentItem[0])continue;var e=this.options.toleranceElement?a(this.options.toleranceElement,d.item):d.item;b||(d.width=e.outerWidth(),d.height=e.outerHeight());var f=e.offset();d.left=f.left,d.top=f.top}if(this.options.custom&&this.options.custom.refreshContainers)this.options.custom.refreshContainers.call(this);else for(var c=this.containers.length-1;c>=0;c--){var f=this.containers[c].element.offset();this.containers[c].containerCache.left=f.left,this.containers[c].containerCache.top=f.top,this.containers[c].containerCache.width=this.containers[c].element.outerWidth(),this.containers[c].containerCache.height=this.containers[c].element.outerHeight()}return this},_createPlaceholder:function(b){var c=b||this,d=c.options;if(!d.placeholder||d.placeholder.constructor==String){var e=d.placeholder;d.placeholder={element:function(){var b=a(document.createElement(c.currentItem[0].nodeName)).addClass(e||c.currentItem[0].className+" ui-sortable-placeholder").removeClass("ui-sortable-helper")[0];return e||(b.style.visibility="hidden"),b},update:function(a,b){if(e&&!d.forcePlaceholderSize)return;b.height()||b.height(c.currentItem.innerHeight()-parseInt(c.currentItem.css("paddingTop")||0,10)-parseInt(c.currentItem.css("paddingBottom")||0,10)),b.width()||b.width(c.currentItem.innerWidth()-parseInt(c.currentItem.css("paddingLeft")||0,10)-parseInt(c.currentItem.css("paddingRight")||0,10))}}}c.placeholder=a(d.placeholder.element.call(c.element,c.currentItem)),c.currentItem.after(c.placeholder),d.placeholder.update(c,c.placeholder)},_contactContainers:function(b){var c=null,d=null;for(var e=this.containers.length-1;e>=0;e--){if(a.ui.contains(this.currentItem[0],this.containers[e].element[0]))continue;if(this._intersectsWith(this.containers[e].containerCache)){if(c&&a.ui.contains(this.containers[e].element[0],c.element[0]))continue;c=this.containers[e],d=e}else this.containers[e].containerCache.over&&(this.containers[e]._trigger("out",b,this._uiHash(this)),this.containers[e].containerCache.over=0)}if(!c)return;if(this.containers.length===1)this.containers[d]._trigger("over",b,this._uiHash(this)),this.containers[d].containerCache.over=1;else if(this.currentContainer!=this.containers[d]){var f=1e4,g=null,h=this.positionAbs[this.containers[d].floating?"left":"top"];for(var i=this.items.length-1;i>=0;i--){if(!a.ui.contains(this.containers[d].element[0],this.items[i].item[0]))continue;var j=this.containers[d].floating?this.items[i].item.offset().left:this.items[i].item.offset().top;Math.abs(j-h)0?"down":"up")}if(!g&&!this.options.dropOnEmpty)return;this.currentContainer=this.containers[d],g?this._rearrange(b,g,null,!0):this._rearrange(b,null,this.containers[d].element,!0),this._trigger("change",b,this._uiHash()),this.containers[d]._trigger("change",b,this._uiHash(this)),this.options.placeholder.update(this.currentContainer,this.placeholder),this.containers[d]._trigger("over",b,this._uiHash(this)),this.containers[d].containerCache.over=1}},_createHelper:function(b){var c=this.options,d=a.isFunction(c.helper)?a(c.helper.apply(this.element[0],[b,this.currentItem])):c.helper=="clone"?this.currentItem.clone():this.currentItem;return d.parents("body").length||a(c.appendTo!="parent"?c.appendTo:this.currentItem[0].parentNode)[0].appendChild(d[0]),d[0]==this.currentItem[0]&&(this._storedCSS={width:this.currentItem[0].style.width,height:this.currentItem[0].style.height,position:this.currentItem.css("position"),top:this.currentItem.css("top"),left:this.currentItem.css("left")}),(d[0].style.width==""||c.forceHelperSize)&&d.width(this.currentItem.width()),(d[0].style.height==""||c.forceHelperSize)&&d.height(this.currentItem.height()),d},_adjustOffsetFromHelper:function(b){typeof b=="string"&&(b=b.split(" ")),a.isArray(b)&&(b={left:+b[0],top:+b[1]||0}),"left"in b&&(this.offset.click.left=b.left+this.margins.left),"right"in b&&(this.offset.click.left=this.helperProportions.width-b.right+this.margins.left),"top"in b&&(this.offset.click.top=b.top+this.margins.top),"bottom"in b&&(this.offset.click.top=this.helperProportions.height-b.bottom+this.margins.top)},_getParentOffset:function(){this.offsetParent=this.helper.offsetParent();var b=this.offsetParent.offset();this.cssPosition=="absolute"&&this.scrollParent[0]!=document&&a.ui.contains(this.scrollParent[0],this.offsetParent[0])&&(b.left+=this.scrollParent.scrollLeft(),b.top+=this.scrollParent.scrollTop());if(this.offsetParent[0]==document.body||this.offsetParent[0].tagName&&this.offsetParent[0].tagName.toLowerCase()=="html"&&a.browser.msie)b={top:0,left:0};return{top:b.top+(parseInt(this.offsetParent.css("borderTopWidth"),10)||0),left:b.left+(parseInt(this.offsetParent.css("borderLeftWidth"),10)||0)}},_getRelativeOffset:function(){if(this.cssPosition=="relative"){var a=this.currentItem.position();return{top:a.top-(parseInt(this.helper.css("top"),10)||0)+this.scrollParent.scrollTop(),left:a.left-(parseInt(this.helper.css("left"),10)||0)+this.scrollParent.scrollLeft()}}return{top:0,left:0}},_cacheMargins:function(){this.margins={left:parseInt(this.currentItem.css("marginLeft"),10)||0,top:parseInt(this.currentItem.css("marginTop"),10)||0}},_cacheHelperProportions:function(){this.helperProportions={width:this.helper.outerWidth(),height:this.helper.outerHeight()}},_setContainment:function(){var b=this.options;b.containment=="parent"&&(b.containment=this.helper[0].parentNode);if(b.containment=="document"||b.containment=="window")this.containment=[0-this.offset.relative.left-this.offset.parent.left,0-this.offset.relative.top-this.offset.parent.top,a(b.containment=="document"?document:window).width()-this.helperProportions.width-this.margins.left,(a(b.containment=="document"?document:window).height()||document.body.parentNode.scrollHeight)-this.helperProportions.height-this.margins.top];if(!/^(document|window|parent)$/.test(b.containment)){var c=a(b.containment)[0],d=a(b.containment).offset(),e=a(c).css("overflow")!="hidden";this.containment=[d.left+(parseInt(a(c).css("borderLeftWidth"),10)||0)+(parseInt(a(c).css("paddingLeft"),10)||0)-this.margins.left,d.top+(parseInt(a(c).css("borderTopWidth"),10)||0)+(parseInt(a(c).css("paddingTop"),10)||0)-this.margins.top,d.left+(e?Math.max(c.scrollWidth,c.offsetWidth):c.offsetWidth)-(parseInt(a(c).css("borderLeftWidth"),10)||0)-(parseInt(a(c).css("paddingRight"),10)||0)-this.helperProportions.width-this.margins.left,d.top+(e?Math.max(c.scrollHeight,c.offsetHeight):c.offsetHeight)-(parseInt(a(c).css("borderTopWidth"),10)||0)-(parseInt(a(c).css("paddingBottom"),10)||0)-this.helperProportions.height-this.margins.top]}},_convertPositionTo:function(b,c){c||(c=this.position);var d=b=="absolute"?1:-1,e=this.options,f=this.cssPosition=="absolute"&&(this.scrollParent[0]==document||!a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,g=/(html|body)/i.test(f[0].tagName);return{top:c.top+this.offset.relative.top*d+this.offset.parent.top*d-(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollTop():g?0:f.scrollTop())*d),left:c.left+this.offset.relative.left*d+this.offset.parent.left*d-(a.browser.safari&&this.cssPosition=="fixed"?0:(this.cssPosition=="fixed"?-this.scrollParent.scrollLeft():g?0:f.scrollLeft())*d)}},_generatePosition:function(b){var c=this.options,d=this.cssPosition=="absolute"&&(this.scrollParent[0]==document||!a.ui.contains(this.scrollParent[0],this.offsetParent[0]))?this.offsetParent:this.scrollParent,e=/(html|body)/i.test(d[0].tagName);this.cssPosition=="relative"&&(this.scrollParent[0]==document||this.scrollParent[0]==this.offsetParent[0])&&(this.offset.relative=this._getRelativeOffset());var f=b.pageX,g=b.pageY;if(this.originalPosition){this.containment&&(b.pageX-this.offset.click.leftthis.containment[2]&&(f=this.containment[2]+this.offset.click.left),b.pageY-this.offset.click.top>this.containment[3]&&(g=this.containment[3]+this.offset.click.top));if(c.grid){var h=this.originalPageY+Math.round((g-this.originalPageY)/c.grid[1])*c.grid[1];g=this.containment?h-this.offset.click.topthis.containment[3]?h-this.offset.click.topthis.containment[2]?i-this.offset.click.left=0;f--)a.ui.contains(this.containers[f].element[0],this.currentItem[0])&&!c&&(d.push(function(a){return function(b){a._trigger("receive",b,this._uiHash(this))}}.call(this,this.containers[f])),d.push(function(a){return function(b){a._trigger("update",b,this._uiHash(this))}}.call(this,this.containers[f])))}for(var f=this.containers.length-1;f>=0;f--)c||d.push(function(a){return function(b){a._trigger("deactivate",b,this._uiHash(this))}}.call(this,this.containers[f])),this.containers[f].containerCache.over&&(d.push(function(a){return function(b){a._trigger("out",b,this._uiHash(this))}}.call(this,this.containers[f])),this.containers[f].containerCache.over=0);this._storedCursor&&a("body").css("cursor",this._storedCursor),this._storedOpacity&&this.helper.css("opacity",this._storedOpacity),this._storedZIndex&&this.helper.css("zIndex",this._storedZIndex=="auto"?"":this._storedZIndex),this.dragging=!1;if(this.cancelHelperRemoval){if(!c){this._trigger("beforeStop",b,this._uiHash());for(var f=0;f li > :first-child,> :not(li):even",icons:{header:"ui-icon-triangle-1-e",headerSelected:"ui-icon-triangle-1-s"},navigation:!1,navigationFilter:function(){return this.href.toLowerCase()===location.href.toLowerCase()}},_create:function(){var b=this,c=b.options;b.running=0,b.element.addClass("ui-accordion ui-widget ui-helper-reset").children("li").addClass("ui-accordion-li-fix"),b.headers=b.element.find(c.header).addClass("ui-accordion-header ui-helper-reset ui-state-default ui-corner-all").bind("mouseenter.accordion",function(){if(c.disabled)return;a(this).addClass("ui-state-hover")}).bind("mouseleave.accordion",function(){if(c.disabled)return;a(this).removeClass("ui-state-hover")}).bind("focus.accordion",function(){if(c.disabled)return;a(this).addClass("ui-state-focus")}).bind("blur.accordion",function(){if(c.disabled)return;a(this).removeClass("ui-state-focus")}),b.headers.next().addClass("ui-accordion-content ui-helper-reset ui-widget-content ui-corner-bottom");if(c.navigation){var d=b.element.find("a").filter(c.navigationFilter).eq(0);if(d.length){var e=d.closest(".ui-accordion-header");e.length?b.active=e:b.active=d.closest(".ui-accordion-content").prev()}}b.active=b._findActive(b.active||c.active).addClass("ui-state-default ui-state-active").toggleClass("ui-corner-all").toggleClass("ui-corner-top"),b.active.next().addClass("ui-accordion-content-active"),b._createIcons(),b.resize(),b.element.attr("role","tablist"),b.headers.attr("role","tab").bind("keydown.accordion",function(a){return b._keydown(a)}).next().attr("role","tabpanel"),b.headers.not(b.active||"").attr({"aria-expanded":"false","aria-selected":"false",tabIndex:-1}).next().hide(),b.active.length?b.active.attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}):b.headers.eq(0).attr("tabIndex",0),a.browser.safari||b.headers.find("a").attr("tabIndex",-1),c.event&&b.headers.bind(c.event.split(" ").join(".accordion ")+".accordion",function(a){b._clickHandler.call(b,a,this),a.preventDefault()})},_createIcons:function(){var b=this.options;b.icons&&(a("").addClass("ui-icon "+b.icons.header).prependTo(this.headers),this.active.children(".ui-icon").toggleClass(b.icons.header).toggleClass(b.icons.headerSelected),this.element.addClass("ui-accordion-icons"))},_destroyIcons:function(){this.headers.children(".ui-icon").remove(),this.element.removeClass("ui-accordion-icons")},destroy:function(){var b=this.options;this.element.removeClass("ui-accordion ui-widget ui-helper-reset").removeAttr("role"),this.headers.unbind(".accordion").removeClass("ui-accordion-header ui-accordion-disabled ui-helper-reset ui-state-default ui-corner-all ui-state-active ui-state-disabled ui-corner-top").removeAttr("role").removeAttr("aria-expanded").removeAttr("aria-selected").removeAttr("tabIndex"),this.headers.find("a").removeAttr("tabIndex"),this._destroyIcons();var c=this.headers.next().css("display","").removeAttr("role").removeClass("ui-helper-reset ui-widget-content ui-corner-bottom ui-accordion-content ui-accordion-content-active ui-accordion-disabled ui-state-disabled");return(b.autoHeight||b.fillHeight)&&c.css("height",""),a.Widget.prototype.destroy.call(this)},_setOption:function(b,c){a.Widget.prototype._setOption.apply(this,arguments),b=="active"&&this.activate(c),b=="icons"&&(this._destroyIcons(),c&&this._createIcons()),b=="disabled"&&this.headers.add(this.headers.next())[c?"addClass":"removeClass"]("ui-accordion-disabled ui-state-disabled")},_keydown:function(b){if(this.options.disabled||b.altKey||b.ctrlKey)return;var c=a.ui.keyCode,d=this.headers.length,e=this.headers.index(b.target),f=!1;switch(b.keyCode){case c.RIGHT:case c.DOWN:f=this.headers[(e+1)%d];break;case c.LEFT:case c.UP:f=this.headers[(e-1+d)%d];break;case c.SPACE:case c.ENTER:this._clickHandler({target:b.target},b.target),b.preventDefault()}return f?(a(b.target).attr("tabIndex",-1),a(f).attr("tabIndex",0),f.focus(),!1):!0},resize:function(){var b=this.options,c;if(b.fillSpace){if(a.browser.msie){var d=this.element.parent().css("overflow");this.element.parent().css("overflow","hidden")}c=this.element.parent().height(),a.browser.msie&&this.element.parent().css("overflow",d),this.headers.each(function(){c-=a(this).outerHeight(!0)}),this.headers.next().each(function(){a(this).height(Math.max(0,c-a(this).innerHeight()+a(this).height()))}).css("overflow","auto")}else b.autoHeight&&(c=0,this.headers.next().each(function(){c=Math.max(c,a(this).height("").height())}).height(c));return this},activate:function(a){this.options.active=a;var b=this._findActive(a)[0];return this._clickHandler({target:b},b),this},_findActive:function(b){return b?typeof b=="number"?this.headers.filter(":eq("+b+")"):this.headers.not(this.headers.not(b)):b===!1?a([]):this.headers.filter(":eq(0)")},_clickHandler:function(b,c){var d=this.options;if(d.disabled)return;if(!b.target){if(!d.collapsible)return;this.active.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header),this.active.next().addClass("ui-accordion-content-active");var e=this.active.next(),f={options:d,newHeader:a([]),oldHeader:d.active,newContent:a([]),oldContent:e},g=this.active=a([]);this._toggle(g,e,f);return}var h=a(b.currentTarget||c),i=h[0]===this.active[0];d.active=d.collapsible&&i?!1:this.headers.index(h);if(this.running||!d.collapsible&&i)return;var j=this.active,g=h.next(),e=this.active.next(),f={options:d,newHeader:i&&d.collapsible?a([]):h,oldHeader:this.active,newContent:i&&d.collapsible?a([]):g,oldContent:e},k=this.headers.index(this.active[0])>this.headers.index(h[0]);this.active=i?a([]):h,this._toggle(g,e,f,i,k),j.removeClass("ui-state-active ui-corner-top").addClass("ui-state-default ui-corner-all").children(".ui-icon").removeClass(d.icons.headerSelected).addClass(d.icons.header),i||(h.removeClass("ui-state-default ui-corner-all").addClass("ui-state-active ui-corner-top").children(".ui-icon").removeClass(d.icons.header).addClass(d.icons.headerSelected),h.next().addClass("ui-accordion-content-active"));return},_toggle:function(b,c,d,e,f){var g=this,h=g.options;g.toShow=b,g.toHide=c,g.data=d;var i=function(){if(!g)return;return g._completed.apply(g,arguments)};g._trigger("changestart",null,g.data),g.running=c.size()===0?b.size():c.size();if(h.animated){var j={};h.collapsible&&e?j={toShow:a([]),toHide:c,complete:i,down:f,autoHeight:h.autoHeight||h.fillSpace}:j={toShow:b,toHide:c,complete:i,down:f,autoHeight:h.autoHeight||h.fillSpace},h.proxied||(h.proxied=h.animated),h.proxiedDuration||(h.proxiedDuration=h.duration),h.animated=a.isFunction(h.proxied)?h.proxied(j):h.proxied,h.duration=a.isFunction(h.proxiedDuration)?h.proxiedDuration(j):h.proxiedDuration;var k=a.ui.accordion.animations,l=h.duration,m=h.animated;m&&!k[m]&&!a.easing[m]&&(m="slide"),k[m]||(k[m]=function(a){this.slide(a,{easing:m,duration:l||700})}),k[m](j)}else h.collapsible&&e?b.toggle():(c.hide(),b.show()),i(!0);c.prev().attr({"aria-expanded":"false","aria-selected":"false",tabIndex:-1}).blur(),b.prev().attr({"aria-expanded":"true","aria-selected":"true",tabIndex:0}).focus()},_completed:function(a){this.running=a?0:--this.running;if(this.running)return;this.options.clearStyle&&this.toShow.add(this.toHide).css({height:"",overflow:""}),this.toHide.removeClass("ui-accordion-content-active"),this.toHide.length&&(this.toHide.parent()[0].className=this.toHide.parent()[0].className),this._trigger("change",null,this.data)}}),a.extend(a.ui.accordion,{version:"1.8.21",animations:{slide:function(b,c){b=a.extend({easing:"swing",duration:300},b,c);if(!b.toHide.size()){b.toShow.animate({height:"show",paddingTop:"show",paddingBottom:"show"},b);return}if(!b.toShow.size()){b.toHide.animate({height:"hide",paddingTop:"hide",paddingBottom:"hide"},b);return}var d=b.toShow.css("overflow"),e=0,f={},g={},h=["height","paddingTop","paddingBottom"],i,j=b.toShow;i=j[0].style.width,j.width(j.parent().width()-parseFloat(j.css("paddingLeft"))-parseFloat(j.css("paddingRight"))-(parseFloat(j.css("borderLeftWidth"))||0)-(parseFloat(j.css("borderRightWidth"))||0)),a.each(h,function(c,d){g[d]="hide";var e=(""+a.css(b.toShow[0],d)).match(/^([\d+-.]+)(.*)$/);f[d]={value:e[1],unit:e[2]||"px"}}),b.toShow.css({height:0,overflow:"hidden"}).show(),b.toHide.filter(":hidden").each(b.complete).end().filter(":visible").animate(g,{step:function(a,c){c.prop=="height"&&(e=c.end-c.start===0?0:(c.now-c.start)/(c.end-c.start)),b.toShow[0].style[c.prop]=e*f[c.prop].value+f[c.prop].unit},duration:b.duration,easing:b.easing,complete:function(){b.autoHeight||b.toShow.css("height",""),b.toShow.css({width:i,overflow:d}),b.complete()}})},bounceslide:function(a){this.slide(a,{easing:a.down?"easeOutBounce":"swing",duration:a.down?1e3:200})}}})})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.autocomplete.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){var c=0;a.widget("ui.autocomplete",{options:{appendTo:"body",autoFocus:!1,delay:300,minLength:1,position:{my:"left top",at:"left bottom",collision:"none"},source:null},pending:0,_create:function(){var b=this,c=this.element[0].ownerDocument,d;this.isMultiLine=this.element.is("textarea"),this.element.addClass("ui-autocomplete-input").attr("autocomplete","off").attr({role:"textbox","aria-autocomplete":"list","aria-haspopup":"true"}).bind("keydown.autocomplete",function(c){if(b.options.disabled||b.element.propAttr("readOnly"))return;d=!1;var e=a.ui.keyCode;switch(c.keyCode){case e.PAGE_UP:b._move("previousPage",c);break;case e.PAGE_DOWN:b._move("nextPage",c);break;case e.UP:b._keyEvent("previous",c);break;case e.DOWN:b._keyEvent("next",c);break;case e.ENTER:case e.NUMPAD_ENTER:b.menu.active&&(d=!0,c.preventDefault());case e.TAB:if(!b.menu.active)return;b.menu.select(c);break;case e.ESCAPE:b.element.val(b.term),b.close(c);break;default:clearTimeout(b.searching),b.searching=setTimeout(function(){b.term!=b.element.val()&&(b.selectedItem=null,b.search(null,c))},b.options.delay)}}).bind("keypress.autocomplete",function(a){d&&(d=!1,a.preventDefault())}).bind("focus.autocomplete",function(){if(b.options.disabled)return;b.selectedItem=null,b.previous=b.element.val()}).bind("blur.autocomplete",function(a){if(b.options.disabled)return;clearTimeout(b.searching),b.closing=setTimeout(function(){b.close(a),b._change(a)},150)}),this._initSource(),this.menu=a("
    ").addClass("ui-autocomplete").appendTo(a(this.options.appendTo||"body",c)[0]).mousedown(function(c){var d=b.menu.element[0];a(c.target).closest(".ui-menu-item").length||setTimeout(function(){a(document).one("mousedown",function(c){c.target!==b.element[0]&&c.target!==d&&!a.ui.contains(d,c.target)&&b.close()})},1),setTimeout(function(){clearTimeout(b.closing)},13)}).menu({focus:function(a,c){var d=c.item.data("item.autocomplete");!1!==b._trigger("focus",a,{item:d})&&/^key/.test(a.originalEvent.type)&&b.element.val(d.value)},selected:function(a,d){var e=d.item.data("item.autocomplete"),f=b.previous;b.element[0]!==c.activeElement&&(b.element.focus(),b.previous=f,setTimeout(function(){b.previous=f,b.selectedItem=e},1)),!1!==b._trigger("select",a,{item:e})&&b.element.val(e.value),b.term=b.element.val(),b.close(a),b.selectedItem=e},blur:function(a,c){b.menu.element.is(":visible")&&b.element.val()!==b.term&&b.element.val(b.term)}}).zIndex(this.element.zIndex()+1).css({top:0,left:0}).hide().data("menu"),a.fn.bgiframe&&this.menu.element.bgiframe(),b.beforeunloadHandler=function(){b.element.removeAttr("autocomplete")},a(window).bind("beforeunload",b.beforeunloadHandler)},destroy:function(){this.element.removeClass("ui-autocomplete-input").removeAttr("autocomplete").removeAttr("role").removeAttr("aria-autocomplete").removeAttr("aria-haspopup"),this.menu.element.remove(),a(window).unbind("beforeunload",this.beforeunloadHandler),a.Widget.prototype.destroy.call(this)},_setOption:function(b,c){a.Widget.prototype._setOption.apply(this,arguments),b==="source"&&this._initSource(),b==="appendTo"&&this.menu.element.appendTo(a(c||"body",this.element[0].ownerDocument)[0]),b==="disabled"&&c&&this.xhr&&this.xhr.abort()},_initSource:function(){var b=this,c,d;a.isArray(this.options.source)?(c=this.options.source,this.source=function(b,d){d(a.ui.autocomplete.filter(c,b.term))}):typeof this.options.source=="string"?(d=this.options.source,this.source=function(c,e){b.xhr&&b.xhr.abort(),b.xhr=a.ajax({url:d,data:c,dataType:"json",success:function(a,b){e(a)},error:function(){e([])}})}):this.source=this.options.source},search:function(a,b){a=a!=null?a:this.element.val(),this.term=this.element.val();if(a.length").data("item.autocomplete",c).append(a("").text(c.label)).appendTo(b)},_move:function(a,b){if(!this.menu.element.is(":visible")){this.search(null,b);return}if(this.menu.first()&&/^previous/.test(a)||this.menu.last()&&/^next/.test(a)){this.element.val(this.term),this.menu.deactivate();return}this.menu[a](b)},widget:function(){return this.menu.element},_keyEvent:function(a,b){if(!this.isMultiLine||this.menu.element.is(":visible"))this._move(a,b),b.preventDefault()}}),a.extend(a.ui.autocomplete,{escapeRegex:function(a){return a.replace(/[-[\]{}()*+?.,\\^$|#\s]/g,"\\$&")},filter:function(b,c){var d=new RegExp(a.ui.autocomplete.escapeRegex(c),"i");return a.grep(b,function(a){return d.test(a.label||a.value||a)})}})})(jQuery),function(a){a.widget("ui.menu",{_create:function(){var b=this;this.element.addClass("ui-menu ui-widget ui-widget-content ui-corner-all").attr({role:"listbox","aria-activedescendant":"ui-active-menuitem"}).click(function(c){if(!a(c.target).closest(".ui-menu-item a").length)return;c.preventDefault(),b.select(c)}),this.refresh()},refresh:function(){var b=this,c=this.element.children("li:not(.ui-menu-item):has(a)").addClass("ui-menu-item").attr("role","menuitem");c.children("a").addClass("ui-corner-all").attr("tabindex",-1).mouseenter(function(c){b.activate(c,a(this).parent())}).mouseleave(function(){b.deactivate()})},activate:function(a,b){this.deactivate();if(this.hasScroll()){var c=b.offset().top-this.element.offset().top,d=this.element.scrollTop(),e=this.element.height();c<0?this.element.scrollTop(d+c):c>=e&&this.element.scrollTop(d+c-e+b.height())}this.active=b.eq(0).children("a").addClass("ui-state-hover").attr("id","ui-active-menuitem").end(),this._trigger("focus",a,{item:b})},deactivate:function(){if(!this.active)return;this.active.children("a").removeClass("ui-state-hover").removeAttr("id"),this._trigger("blur"),this.active=null},next:function(a){this.move("next",".ui-menu-item:first",a)},previous:function(a){this.move("prev",".ui-menu-item:last",a)},first:function(){return this.active&&!this.active.prevAll(".ui-menu-item").length},last:function(){return this.active&&!this.active.nextAll(".ui-menu-item").length},move:function(a,b,c){if(!this.active){this.activate(c,this.element.children(b));return}var d=this.active[a+"All"](".ui-menu-item").eq(0);d.length?this.activate(c,d):this.activate(c,this.element.children(b))},nextPage:function(b){if(this.hasScroll()){if(!this.active||this.last()){this.activate(b,this.element.children(".ui-menu-item:first"));return}var c=this.active.offset().top,d=this.element.height(),e=this.element.children(".ui-menu-item").filter(function(){var b=a(this).offset().top-c-d+a(this).height();return b<10&&b>-10});e.length||(e=this.element.children(".ui-menu-item:last")),this.activate(b,e)}else this.activate(b,this.element.children(".ui-menu-item").filter(!this.active||this.last()?":first":":last"))},previousPage:function(b){if(this.hasScroll()){if(!this.active||this.first()){this.activate(b,this.element.children(".ui-menu-item:last"));return}var c=this.active.offset().top,d=this.element.height(),e=this.element.children(".ui-menu-item").filter(function(){var b=a(this).offset().top-c+d-a(this).height();return b<10&&b>-10});e.length||(e=this.element.children(".ui-menu-item:first")),this.activate(b,e)}else this.activate(b,this.element.children(".ui-menu-item").filter(!this.active||this.first()?":last":":first"))},hasScroll:function(){return this.element.height()",this.element[0].ownerDocument).addClass("ui-button-text").html(this.options.label).appendTo(b.empty()).text(),d=this.options.icons,e=d.primary&&d.secondary,f=[];d.primary||d.secondary?(this.options.text&&f.push("ui-button-text-icon"+(e?"s":d.primary?"-primary":"-secondary")),d.primary&&b.prepend(""),d.secondary&&b.append(""),this.options.text||(f.push(e?"ui-button-icons-only":"ui-button-icon-only"),this.hasTitle||b.attr("title",c))):f.push("ui-button-text-only"),b.addClass(f.join(" "))}}),a.widget("ui.buttonset",{options:{items:":button, :submit, :reset, :checkbox, :radio, a, :data(button)"},_create:function(){this.element.addClass("ui-buttonset")},_init:function(){this.refresh()},_setOption:function(b,c){b==="disabled"&&this.buttons.button("option",b,c),a.Widget.prototype._setOption.apply(this,arguments)},refresh:function(){var b=this.element.css("direction")==="rtl";this.buttons=this.element.find(this.options.items).filter(":ui-button").button("refresh").end().not(":ui-button").button().end().map(function(){return a(this).button("widget")[0]}).removeClass("ui-corner-all ui-corner-left ui-corner-right").filter(":first").addClass(b?"ui-corner-right":"ui-corner-left").end().filter(":last").addClass(b?"ui-corner-left":"ui-corner-right").end().end()},destroy:function(){this.element.removeClass("ui-buttonset"),this.buttons.map(function(){return a(this).button("widget")[0]}).removeClass("ui-corner-left ui-corner-right").end().button("destroy"),a.Widget.prototype.destroy.call(this)}})})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.dialog.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){var c="ui-dialog ui-widget ui-widget-content ui-corner-all ",d={buttons:!0,height:!0,maxHeight:!0,maxWidth:!0,minHeight:!0,minWidth:!0,width:!0},e={maxHeight:!0,maxWidth:!0,minHeight:!0,minWidth:!0},f=a.attrFn||{val:!0,css:!0,html:!0,text:!0,data:!0,width:!0,height:!0,offset:!0,click:!0};a.widget("ui.dialog",{options:{autoOpen:!0,buttons:{},closeOnEscape:!0,closeText:"close",dialogClass:"",draggable:!0,hide:null,height:"auto",maxHeight:!1,maxWidth:!1,minHeight:150,minWidth:150,modal:!1,position:{my:"center",at:"center",collision:"fit",using:function(b){var c=a(this).css(b).offset().top;c<0&&a(this).css("top",b.top-c)}},resizable:!0,show:null,stack:!0,title:"",width:300,zIndex:1e3},_create:function(){this.originalTitle=this.element.attr("title"),typeof this.originalTitle!="string"&&(this.originalTitle=""),this.options.title=this.options.title||this.originalTitle;var b=this,d=b.options,e=d.title||" ",f=a.ui.dialog.getTitleId(b.element),g=(b.uiDialog=a("
    ")).appendTo(document.body).hide().addClass(c+d.dialogClass).css({zIndex:d.zIndex}).attr("tabIndex",-1).css("outline",0).keydown(function(c){d.closeOnEscape&&!c.isDefaultPrevented()&&c.keyCode&&c.keyCode===a.ui.keyCode.ESCAPE&&(b.close(c),c.preventDefault())}).attr({role:"dialog","aria-labelledby":f}).mousedown(function(a){b.moveToTop(!1,a)}),h=b.element.show().removeAttr("title").addClass("ui-dialog-content ui-widget-content").appendTo(g),i=(b.uiDialogTitlebar=a("
    ")).addClass("ui-dialog-titlebar ui-widget-header ui-corner-all ui-helper-clearfix").prependTo(g),j=a('').addClass("ui-dialog-titlebar-close ui-corner-all").attr("role","button").hover(function(){j.addClass("ui-state-hover")},function(){j.removeClass("ui-state-hover")}).focus(function(){j.addClass("ui-state-focus")}).blur(function(){j.removeClass("ui-state-focus")}).click(function(a){return b.close(a),!1}).appendTo(i),k=(b.uiDialogTitlebarCloseText=a("")).addClass("ui-icon ui-icon-closethick").text(d.closeText).appendTo(j),l=a("").addClass("ui-dialog-title").attr("id",f).html(e).prependTo(i);a.isFunction(d.beforeclose)&&!a.isFunction(d.beforeClose)&&(d.beforeClose=d.beforeclose),i.find("*").add(i).disableSelection(),d.draggable&&a.fn.draggable&&b._makeDraggable(),d.resizable&&a.fn.resizable&&b._makeResizable(),b._createButtons(d.buttons),b._isOpen=!1,a.fn.bgiframe&&g.bgiframe()},_init:function(){this.options.autoOpen&&this.open()},destroy:function(){var a=this;return a.overlay&&a.overlay.destroy(),a.uiDialog.hide(),a.element.unbind(".dialog").removeData("dialog").removeClass("ui-dialog-content ui-widget-content").hide().appendTo("body"),a.uiDialog.remove(),a.originalTitle&&a.element.attr("title",a.originalTitle),a},widget:function(){return this.uiDialog},close:function(b){var c=this,d,e;if(!1===c._trigger("beforeClose",b))return;return c.overlay&&c.overlay.destroy(),c.uiDialog.unbind("keypress.ui-dialog"),c._isOpen=!1,c.options.hide?c.uiDialog.hide(c.options.hide,function(){c._trigger("close",b)}):(c.uiDialog.hide(),c._trigger("close",b)),a.ui.dialog.overlay.resize(),c.options.modal&&(d=0,a(".ui-dialog").each(function(){this!==c.uiDialog[0]&&(e=a(this).css("z-index"),isNaN(e)||(d=Math.max(d,e)))}),a.ui.dialog.maxZ=d),c},isOpen:function(){return this._isOpen},moveToTop:function(b,c){var d=this,e=d.options,f;return e.modal&&!b||!e.stack&&!e.modal?d._trigger("focus",c):(e.zIndex>a.ui.dialog.maxZ&&(a.ui.dialog.maxZ=e.zIndex),d.overlay&&(a.ui.dialog.maxZ+=1,d.overlay.$el.css("z-index",a.ui.dialog.overlay.maxZ=a.ui.dialog.maxZ)),f={scrollTop:d.element.scrollTop(),scrollLeft:d.element.scrollLeft()},a.ui.dialog.maxZ+=1,d.uiDialog.css("z-index",a.ui.dialog.maxZ),d.element.attr(f),d._trigger("focus",c),d)},open:function(){if(this._isOpen)return;var b=this,c=b.options,d=b.uiDialog;return b.overlay=c.modal?new a.ui.dialog.overlay(b):null,b._size(),b._position(c.position),d.show(c.show),b.moveToTop(!0),c.modal&&d.bind("keydown.ui-dialog",function(b){if(b.keyCode!==a.ui.keyCode.TAB)return;var c=a(":tabbable",this),d=c.filter(":first"),e=c.filter(":last");if(b.target===e[0]&&!b.shiftKey)return d.focus(1),!1;if(b.target===d[0]&&b.shiftKey)return e.focus(1),!1}),a(b.element.find(":tabbable").get().concat(d.find(".ui-dialog-buttonpane :tabbable").get().concat(d.get()))).eq(0).focus(),b._isOpen=!0,b._trigger("open"),b},_createButtons:function(b){var c=this,d=!1,e=a("
    ").addClass("ui-dialog-buttonpane ui-widget-content ui-helper-clearfix"),g=a("
    ").addClass("ui-dialog-buttonset").appendTo(e);c.uiDialog.find(".ui-dialog-buttonpane").remove(),typeof b=="object"&&b!==null&&a.each(b,function(){return!(d=!0)}),d&&(a.each(b,function(b,d){d=a.isFunction(d)?{click:d,text:b}:d;var e=a('').click(function(){d.click.apply(c.element[0],arguments)}).appendTo(g);a.each(d,function(a,b){if(a==="click")return;a in f?e[a](b):e.attr(a,b)}),a.fn.button&&e.button()}),e.appendTo(c.uiDialog))},_makeDraggable:function(){function f(a){return{position:a.position,offset:a.offset}}var b=this,c=b.options,d=a(document),e;b.uiDialog.draggable({cancel:".ui-dialog-content, .ui-dialog-titlebar-close",handle:".ui-dialog-titlebar",containment:"document",start:function(d,g){e=c.height==="auto"?"auto":a(this).height(),a(this).height(a(this).height()).addClass("ui-dialog-dragging"),b._trigger("dragStart",d,f(g))},drag:function(a,c){b._trigger("drag",a,f(c))},stop:function(g,h){c.position=[h.position.left-d.scrollLeft(),h.position.top-d.scrollTop()],a(this).removeClass("ui-dialog-dragging").height(e),b._trigger("dragStop",g,f(h)),a.ui.dialog.overlay.resize()}})},_makeResizable:function(c){function h(a){return{originalPosition:a.originalPosition,originalSize:a.originalSize,position:a.position,size:a.size}}c=c===b?this.options.resizable:c;var d=this,e=d.options,f=d.uiDialog.css("position"),g=typeof c=="string"?c:"n,e,s,w,se,sw,ne,nw";d.uiDialog.resizable({cancel:".ui-dialog-content",containment:"document",alsoResize:d.element,maxWidth:e.maxWidth,maxHeight:e.maxHeight,minWidth:e.minWidth,minHeight:d._minHeight(),handles:g,start:function(b,c){a(this).addClass("ui-dialog-resizing"),d._trigger("resizeStart",b,h(c))},resize:function(a,b){d._trigger("resize",a,h(b))},stop:function(b,c){a(this).removeClass("ui-dialog-resizing"),e.height=a(this).height(),e.width=a(this).width(),d._trigger("resizeStop",b,h(c)),a.ui.dialog.overlay.resize()}}).css("position",f).find(".ui-resizable-se").addClass("ui-icon ui-icon-grip-diagonal-se")},_minHeight:function(){var a=this.options;return a.height==="auto"?a.minHeight:Math.min(a.minHeight,a.height)},_position:function(b){var c=[],d=[0,0],e;if(b){if(typeof b=="string"||typeof b=="object"&&"0"in b)c=b.split?b.split(" "):[b[0],b[1]],c.length===1&&(c[1]=c[0]),a.each(["left","top"],function(a,b){+c[a]===c[a]&&(d[a]=c[a],c[a]=b)}),b={my:c.join(" "),at:c.join(" "),offset:d.join(" ")};b=a.extend({},a.ui.dialog.prototype.options.position,b)}else b=a.ui.dialog.prototype.options.position;e=this.uiDialog.is(":visible"),e||this.uiDialog.show(),this.uiDialog.css({top:0,left:0}).position(a.extend({of:window},b)),e||this.uiDialog.hide()},_setOptions:function(b){var c=this,f={},g=!1;a.each(b,function(a,b){c._setOption(a,b),a in d&&(g=!0),a in e&&(f[a]=b)}),g&&this._size(),this.uiDialog.is(":data(resizable)")&&this.uiDialog.resizable("option",f)},_setOption:function(b,d){var e=this,f=e.uiDialog;switch(b){case"beforeclose":b="beforeClose";break;case"buttons":e._createButtons(d);break;case"closeText":e.uiDialogTitlebarCloseText.text(""+d);break;case"dialogClass":f.removeClass(e.options.dialogClass).addClass(c+d);break;case"disabled":d?f.addClass("ui-dialog-disabled"):f.removeClass("ui-dialog-disabled");break;case"draggable":var g=f.is(":data(draggable)");g&&!d&&f.draggable("destroy"),!g&&d&&e._makeDraggable();break;case"position":e._position(d);break;case"resizable":var h=f.is(":data(resizable)");h&&!d&&f.resizable("destroy"),h&&typeof d=="string"&&f.resizable("option","handles",d),!h&&d!==!1&&e._makeResizable(d);break;case"title":a(".ui-dialog-title",e.uiDialogTitlebar).html(""+(d||" "))}a.Widget.prototype._setOption.apply(e,arguments)},_size:function(){var b=this.options,c,d,e=this.uiDialog.is(":visible");this.element.show().css({width:"auto",minHeight:0,height:0}),b.minWidth>b.width&&(b.width=b.minWidth),c=this.uiDialog.css({height:"auto",width:b.width}).height(),d=Math.max(0,b.minHeight-c);if(b.height==="auto")if(a.support.minHeight)this.element.css({minHeight:d,height:"auto"});else{this.uiDialog.show();var f=this.element.css("height","auto").height();e||this.uiDialog.hide(),this.element.height(Math.max(f,d))}else this.element.height(Math.max(b.height-c,0));this.uiDialog.is(":data(resizable)")&&this.uiDialog.resizable("option","minHeight",this._minHeight())}}),a.extend(a.ui.dialog,{version:"1.8.21",uuid:0,maxZ:0,getTitleId:function(a){var b=a.attr("id");return b||(this.uuid+=1,b=this.uuid),"ui-dialog-title-"+b},overlay:function(b){this.$el=a.ui.dialog.overlay.create(b)}}),a.extend(a.ui.dialog.overlay,{instances:[],oldInstances:[],maxZ:0,events:a.map("focus,mousedown,mouseup,keydown,keypress,click".split(","),function(a){return a+".dialog-overlay"}).join(" "),create:function(b){this.instances.length===0&&(setTimeout(function(){a.ui.dialog.overlay.instances.length&&a(document).bind(a.ui.dialog.overlay.events,function(b){if(a(b.target).zIndex()").addClass("ui-widget-overlay")).appendTo(document.body).css({width:this.width(),height:this.height()});return a.fn.bgiframe&&c.bgiframe(),this.instances.push(c),c},destroy:function(b){var c=a.inArray(b,this.instances);c!=-1&&this.oldInstances.push(this.instances.splice(c,1)[0]),this.instances.length===0&&a([document,window]).unbind(".dialog-overlay"),b.remove();var d=0;a.each(this.instances,function(){d=Math.max(d,this.css("z-index"))}),this.maxZ=d},height:function(){var b,c;return a.browser.msie&&a.browser.version<7?(b=Math.max(document.documentElement.scrollHeight,document.body.scrollHeight),c=Math.max(document.documentElement.offsetHeight,document.body.offsetHeight),b").appendTo(this.element).addClass("ui-slider-range ui-widget-header"+(d.range==="min"||d.range==="max"?" ui-slider-range-"+d.range:"")));for(var i=e.length;ic&&(f=c,g=a(this),i=b)}),c.range===!0&&this.values(1)===c.min&&(i+=1,g=a(this.handles[i])),j=this._start(b,i),j===!1?!1:(this._mouseSliding=!0,h._handleIndex=i,g.addClass("ui-state-active").focus(),k=g.offset(),l=!a(b.target).parents().andSelf().is(".ui-slider-handle"),this._clickOffset=l?{left:0,top:0}:{left:b.pageX-k.left-g.width()/2,top:b.pageY-k.top-g.height()/2-(parseInt(g.css("borderTopWidth"),10)||0)-(parseInt(g.css("borderBottomWidth"),10)||0)+(parseInt(g.css("marginTop"),10)||0)},this.handles.hasClass("ui-state-hover")||this._slide(b,i,e),this._animateOff=!0,!0))},_mouseStart:function(a){return!0},_mouseDrag:function(a){var b={x:a.pageX,y:a.pageY},c=this._normValueFromMouse(b);return this._slide(a,this._handleIndex,c),!1},_mouseStop:function(a){return this.handles.removeClass("ui-state-active"),this._mouseSliding=!1,this._stop(a,this._handleIndex),this._change(a,this._handleIndex),this._handleIndex=null,this._clickOffset=null,this._animateOff=!1,!1},_detectOrientation:function(){this.orientation=this.options.orientation==="vertical"?"vertical":"horizontal"},_normValueFromMouse:function(a){var b,c,d,e,f;return this.orientation==="horizontal"?(b=this.elementSize.width,c=a.x-this.elementOffset.left-(this._clickOffset?this._clickOffset.left:0)):(b=this.elementSize.height,c=a.y-this.elementOffset.top-(this._clickOffset?this._clickOffset.top:0)),d=c/b,d>1&&(d=1),d<0&&(d=0),this.orientation==="vertical"&&(d=1-d),e=this._valueMax()-this._valueMin(),f=this._valueMin()+d*e,this._trimAlignValue(f)},_start:function(a,b){var c={handle:this.handles[b],value:this.value()};return this.options.values&&this.options.values.length&&(c.value=this.values(b),c.values=this.values()),this._trigger("start",a,c)},_slide:function(a,b,c){var d,e,f;this.options.values&&this.options.values.length?(d=this.values(b?0:1),this.options.values.length===2&&this.options.range===!0&&(b===0&&c>d||b===1&&c1){this.options.values[b]=this._trimAlignValue(c),this._refreshValue(),this._change(null,b);return}if(!arguments.length)return this._values();if(!a.isArray(arguments[0]))return this.options.values&&this.options.values.length?this._values(b):this.value();d=this.options.values,e=arguments[0];for(f=0;f=this._valueMax())return this._valueMax();var b=this.options.step>0?this.options.step:1,c=(a-this._valueMin())%b,d=a-c;return Math.abs(c)*2>=b&&(d+=c>0?b:-b),parseFloat(d.toFixed(5))},_valueMin:function(){return this.options.min},_valueMax:function(){return this.options.max},_refreshValue:function(){var b=this.options.range,c=this.options,d=this,e=this._animateOff?!1:c.animate,f,g={},h,i,j,k;this.options.values&&this.options.values.length?this.handles.each(function(b,i){f=(d.values(b)-d._valueMin())/(d._valueMax()-d._valueMin())*100,g[d.orientation==="horizontal"?"left":"bottom"]=f+"%",a(this).stop(1,1)[e?"animate":"css"](g,c.animate),d.options.range===!0&&(d.orientation==="horizontal"?(b===0&&d.range.stop(1,1)[e?"animate":"css"]({left:f+"%"},c.animate),b===1&&d.range[e?"animate":"css"]({width:f-h+"%"},{queue:!1,duration:c.animate})):(b===0&&d.range.stop(1,1)[e?"animate":"css"]({bottom:f+"%"},c.animate),b===1&&d.range[e?"animate":"css"]({height:f-h+"%"},{queue:!1,duration:c.animate}))),h=f}):(i=this.value(),j=this._valueMin(),k=this._valueMax(),f=k!==j?(i-j)/(k-j)*100:0,g[d.orientation==="horizontal"?"left":"bottom"]=f+"%",this.handle.stop(1,1)[e?"animate":"css"](g,c.animate),b==="min"&&this.orientation==="horizontal"&&this.range.stop(1,1)[e?"animate":"css"]({width:f+"%"},c.animate),b==="max"&&this.orientation==="horizontal"&&this.range[e?"animate":"css"]({width:100-f+"%"},{queue:!1,duration:c.animate}),b==="min"&&this.orientation==="vertical"&&this.range.stop(1,1)[e?"animate":"css"]({height:f+"%"},c.animate),b==="max"&&this.orientation==="vertical"&&this.range[e?"animate":"css"]({height:100-f+"%"},{queue:!1,duration:c.animate}))}}),a.extend(a.ui.slider,{version:"1.8.21"})})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.tabs.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){function e(){return++c}function f(){return++d}var c=0,d=0;a.widget("ui.tabs",{options:{add:null,ajaxOptions:null,cache:!1,cookie:null,collapsible:!1,disable:null,disabled:[],enable:null,event:"click",fx:null,idPrefix:"ui-tabs-",load:null,panelTemplate:"
    ",remove:null,select:null,show:null,spinner:"Loading…",tabTemplate:"
  • #{label}
  • "},_create:function(){this._tabify(!0)},_setOption:function(a,b){if(a=="selected"){if(this.options.collapsible&&b==this.options.selected)return;this.select(b)}else this.options[a]=b,this._tabify()},_tabId:function(a){return a.title&&a.title.replace(/\s/g,"_").replace(/[^\w\u00c0-\uFFFF-]/g,"")||this.options.idPrefix+e()},_sanitizeSelector:function(a){return a.replace(/:/g,"\\:")},_cookie:function(){var b=this.cookie||(this.cookie=this.options.cookie.name||"ui-tabs-"+f());return a.cookie.apply(null,[b].concat(a.makeArray(arguments)))},_ui:function(a,b){return{tab:a,panel:b,index:this.anchors.index(a)}},_cleanup:function(){this.lis.filter(".ui-state-processing").removeClass("ui-state-processing").find("span:data(label.tabs)").each(function(){var b=a(this);b.html(b.data("label.tabs")).removeData("label.tabs")})},_tabify:function(c){function m(b,c){b.css("display",""),!a.support.opacity&&c.opacity&&b[0].style.removeAttribute("filter")}var d=this,e=this.options,f=/^#.+/;this.list=this.element.find("ol,ul").eq(0),this.lis=a(" > li:has(a[href])",this.list),this.anchors=this.lis.map(function(){return a("a",this)[0]}),this.panels=a([]),this.anchors.each(function(b,c){var g=a(c).attr("href"),h=g.split("#")[0],i;h&&(h===location.toString().split("#")[0]||(i=a("base")[0])&&h===i.href)&&(g=c.hash,c.href=g);if(f.test(g))d.panels=d.panels.add(d.element.find(d._sanitizeSelector(g)));else if(g&&g!=="#"){a.data(c,"href.tabs",g),a.data(c,"load.tabs",g.replace(/#.*$/,""));var j=d._tabId(c);c.href="#"+j;var k=d.element.find("#"+j);k.length||(k=a(e.panelTemplate).attr("id",j).addClass("ui-tabs-panel ui-widget-content ui-corner-bottom").insertAfter(d.panels[b-1]||d.list),k.data("destroy.tabs",!0)),d.panels=d.panels.add(k)}else e.disabled.push(b)}),c?(this.element.addClass("ui-tabs ui-widget ui-widget-content ui-corner-all"),this.list.addClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all"),this.lis.addClass("ui-state-default ui-corner-top"),this.panels.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom"),e.selected===b?(location.hash&&this.anchors.each(function(a,b){if(b.hash==location.hash)return e.selected=a,!1}),typeof e.selected!="number"&&e.cookie&&(e.selected=parseInt(d._cookie(),10)),typeof e.selected!="number"&&this.lis.filter(".ui-tabs-selected").length&&(e.selected=this.lis.index(this.lis.filter(".ui-tabs-selected"))),e.selected=e.selected||(this.lis.length?0:-1)):e.selected===null&&(e.selected=-1),e.selected=e.selected>=0&&this.anchors[e.selected]||e.selected<0?e.selected:0,e.disabled=a.unique(e.disabled.concat(a.map(this.lis.filter(".ui-state-disabled"),function(a,b){return d.lis.index(a)}))).sort(),a.inArray(e.selected,e.disabled)!=-1&&e.disabled.splice(a.inArray(e.selected,e.disabled),1),this.panels.addClass("ui-tabs-hide"),this.lis.removeClass("ui-tabs-selected ui-state-active"),e.selected>=0&&this.anchors.length&&(d.element.find(d._sanitizeSelector(d.anchors[e.selected].hash)).removeClass("ui-tabs-hide"),this.lis.eq(e.selected).addClass("ui-tabs-selected ui-state-active"),d.element.queue("tabs",function(){d._trigger("show",null,d._ui(d.anchors[e.selected],d.element.find(d._sanitizeSelector(d.anchors[e.selected].hash))[0]))}),this.load(e.selected)),a(window).bind("unload",function(){d.lis.add(d.anchors).unbind(".tabs"),d.lis=d.anchors=d.panels=null})):e.selected=this.lis.index(this.lis.filter(".ui-tabs-selected")),this.element[e.collapsible?"addClass":"removeClass"]("ui-tabs-collapsible"),e.cookie&&this._cookie(e.selected,e.cookie);for(var g=0,h;h=this.lis[g];g++)a(h)[a.inArray(g,e.disabled)!=-1&&!a(h).hasClass("ui-tabs-selected")?"addClass":"removeClass"]("ui-state-disabled");e.cache===!1&&this.anchors.removeData("cache.tabs"),this.lis.add(this.anchors).unbind(".tabs");if(e.event!=="mouseover"){var i=function(a,b){b.is(":not(.ui-state-disabled)")&&b.addClass("ui-state-"+a)},j=function(a,b){b.removeClass("ui-state-"+a)};this.lis.bind("mouseover.tabs",function(){i("hover",a(this))}),this.lis.bind("mouseout.tabs",function(){j("hover",a(this))}),this.anchors.bind("focus.tabs",function(){i("focus",a(this).closest("li"))}),this.anchors.bind("blur.tabs",function(){j("focus",a(this).closest("li"))})}var k,l;e.fx&&(a.isArray(e.fx)?(k=e.fx[0],l=e.fx[1]):k=l=e.fx);var n=l?function(b,c){a(b).closest("li").addClass("ui-tabs-selected ui-state-active"),c.hide().removeClass("ui-tabs-hide").animate(l,l.duration||"normal",function(){m(c,l),d._trigger("show",null,d._ui(b,c[0]))})}:function(b,c){a(b).closest("li").addClass("ui-tabs-selected ui-state-active"),c.removeClass("ui-tabs-hide"),d._trigger("show",null,d._ui(b,c[0]))},o=k?function(a,b){b.animate(k,k.duration||"normal",function(){d.lis.removeClass("ui-tabs-selected ui-state-active"),b.addClass("ui-tabs-hide"),m(b,k),d.element.dequeue("tabs")})}:function(a,b,c){d.lis.removeClass("ui-tabs-selected ui-state-active"),b.addClass("ui-tabs-hide"),d.element.dequeue("tabs")};this.anchors.bind(e.event+".tabs",function(){var b=this,c=a(b).closest("li"),f=d.panels.filter(":not(.ui-tabs-hide)"),g=d.element.find(d._sanitizeSelector(b.hash));if(c.hasClass("ui-tabs-selected")&&!e.collapsible||c.hasClass("ui-state-disabled")||c.hasClass("ui-state-processing")||d.panels.filter(":animated").length||d._trigger("select",null,d._ui(this,g[0]))===!1)return this.blur(),!1;e.selected=d.anchors.index(this),d.abort();if(e.collapsible){if(c.hasClass("ui-tabs-selected"))return e.selected=-1,e.cookie&&d._cookie(e.selected,e.cookie),d.element.queue("tabs",function(){o(b,f)}).dequeue("tabs"),this.blur(),!1;if(!f.length)return e.cookie&&d._cookie(e.selected,e.cookie),d.element.queue("tabs",function(){n(b,g)}),d.load(d.anchors.index(this)),this.blur(),!1}e.cookie&&d._cookie(e.selected,e.cookie);if(g.length)f.length&&d.element.queue("tabs",function(){o(b,f)}),d.element.queue("tabs",function(){n(b,g)}),d.load(d.anchors.index(this));else throw"jQuery UI Tabs: Mismatching fragment identifier.";a.browser.msie&&this.blur()}),this.anchors.bind("click.tabs",function(){return!1})},_getIndex:function(a){return typeof a=="string"&&(a=this.anchors.index(this.anchors.filter("[href$='"+a+"']"))),a},destroy:function(){var b=this.options;return this.abort(),this.element.unbind(".tabs").removeClass("ui-tabs ui-widget ui-widget-content ui-corner-all ui-tabs-collapsible").removeData("tabs"),this.list.removeClass("ui-tabs-nav ui-helper-reset ui-helper-clearfix ui-widget-header ui-corner-all"),this.anchors.each(function(){var b=a.data(this,"href.tabs");b&&(this.href=b);var c=a(this).unbind(".tabs");a.each(["href","load","cache"],function(a,b){c.removeData(b+".tabs")})}),this.lis.unbind(".tabs").add(this.panels).each(function(){a.data(this,"destroy.tabs")?a(this).remove():a(this).removeClass(["ui-state-default","ui-corner-top","ui-tabs-selected","ui-state-active","ui-state-hover","ui-state-focus","ui-state-disabled","ui-tabs-panel","ui-widget-content","ui-corner-bottom","ui-tabs-hide"].join(" "))}),b.cookie&&this._cookie(null,b.cookie),this},add:function(c,d,e){e===b&&(e=this.anchors.length);var f=this,g=this.options,h=a(g.tabTemplate.replace(/#\{href\}/g,c).replace(/#\{label\}/g,d)),i=c.indexOf("#")?this._tabId(a("a",h)[0]):c.replace("#","");h.addClass("ui-state-default ui-corner-top").data("destroy.tabs",!0);var j=f.element.find("#"+i);return j.length||(j=a(g.panelTemplate).attr("id",i).data("destroy.tabs",!0)),j.addClass("ui-tabs-panel ui-widget-content ui-corner-bottom ui-tabs-hide"),e>=this.lis.length?(h.appendTo(this.list),j.appendTo(this.list[0].parentNode)):(h.insertBefore(this.lis[e]),j.insertBefore(this.panels[e])),g.disabled=a.map(g.disabled,function(a,b){return a>=e?++a:a}),this._tabify(),this.anchors.length==1&&(g.selected=0,h.addClass("ui-tabs-selected ui-state-active"),j.removeClass("ui-tabs-hide"),this.element.queue("tabs",function(){f._trigger("show",null,f._ui(f.anchors[0],f.panels[0]))}),this.load(0)),this._trigger("add",null,this._ui(this.anchors[e],this.panels[e])),this},remove:function(b){b=this._getIndex(b);var c=this.options,d=this.lis.eq(b).remove(),e=this.panels.eq(b).remove();return d.hasClass("ui-tabs-selected")&&this.anchors.length>1&&this.select(b+(b+1=b?--a:a}),this._tabify(),this._trigger("remove",null,this._ui(d.find("a")[0],e[0])),this},enable:function(b){b=this._getIndex(b);var c=this.options;if(a.inArray(b,c.disabled)==-1)return;return this.lis.eq(b).removeClass("ui-state-disabled"),c.disabled=a.grep(c.disabled,function(a,c){return a!=b}),this._trigger("enable",null,this._ui(this.anchors[b],this.panels[b])),this},disable:function(a){a=this._getIndex(a);var b=this,c=this.options;return a!=c.selected&&(this.lis.eq(a).addClass("ui-state-disabled"),c.disabled.push(a),c.disabled.sort(),this._trigger("disable",null,this._ui(this.anchors[a],this.panels[a]))),this},select:function(a){a=this._getIndex(a);if(a==-1)if(this.options.collapsible&&this.options.selected!=-1)a=this.options.selected;else return this;return this.anchors.eq(a).trigger(this.options.event+".tabs"),this},load:function(b){b=this._getIndex(b);var c=this,d=this.options,e=this.anchors.eq(b)[0],f=a.data(e,"load.tabs");this.abort();if(!f||this.element.queue("tabs").length!==0&&a.data(e,"cache.tabs")){this.element.dequeue("tabs");return}this.lis.eq(b).addClass("ui-state-processing");if(d.spinner){var g=a("span",e);g.data("label.tabs",g.html()).html(d.spinner)}return this.xhr=a.ajax(a.extend({},d.ajaxOptions,{url:f,success:function(f,g){c.element.find(c._sanitizeSelector(e.hash)).html(f),c._cleanup(),d.cache&&a.data(e,"cache.tabs",!0),c._trigger("load",null,c._ui(c.anchors[b],c.panels[b]));try{d.ajaxOptions.success(f,g)}catch(h){}},error:function(a,f,g){c._cleanup(),c._trigger("load",null,c._ui(c.anchors[b],c.panels[b]));try{d.ajaxOptions.error(a,f,b,e)}catch(g){}}})),c.element.dequeue("tabs"),this},abort:function(){return this.element.queue([]),this.panels.stop(!1,!0),this.element.queue("tabs",this.element.queue("tabs").splice(-2,2)),this.xhr&&(this.xhr.abort(),delete this.xhr),this._cleanup(),this},url:function(a,b){return this.anchors.eq(a).removeData("cache.tabs").data("load.tabs",b),this},length:function(){return this.anchors.length}}),a.extend(a.ui.tabs,{version:"1.8.21"}),a.extend(a.ui.tabs.prototype,{rotation:null,rotate:function(a,b){var c=this,d=this.options,e=c._rotate||(c._rotate=function(b){clearTimeout(c.rotation),c.rotation=setTimeout(function(){var a=d.selected;c.select(++a'))}function bindHover(a){var b="button, .ui-datepicker-prev, .ui-datepicker-next, .ui-datepicker-calendar td a";return a.bind("mouseout",function(a){var c=$(a.target).closest(b);if(!c.length)return;c.removeClass("ui-state-hover ui-datepicker-prev-hover ui-datepicker-next-hover")}).bind("mouseover",function(c){var d=$(c.target).closest(b);if($.datepicker._isDisabledDatepicker(instActive.inline?a.parent()[0]:instActive.input[0])||!d.length)return;d.parents(".ui-datepicker-calendar").find("a").removeClass("ui-state-hover"),d.addClass("ui-state-hover"),d.hasClass("ui-datepicker-prev")&&d.addClass("ui-datepicker-prev-hover"),d.hasClass("ui-datepicker-next")&&d.addClass("ui-datepicker-next-hover")})}function extendRemove(a,b){$.extend(a,b);for(var c in b)if(b[c]==null||b[c]==undefined)a[c]=b[c];return a}function isArray(a){return a&&($.browser.safari&&typeof a=="object"&&a.length||a.constructor&&a.constructor.toString().match(/\Array\(\)/))}$.extend($.ui,{datepicker:{version:"1.8.21"}});var PROP_NAME="datepicker",dpuuid=(new Date).getTime(),instActive;$.extend(Datepicker.prototype,{markerClassName:"hasDatepicker",maxRows:4,log:function(){this.debug&&console.log.apply("",arguments)},_widgetDatepicker:function(){return this.dpDiv},setDefaults:function(a){return extendRemove(this._defaults,a||{}),this},_attachDatepicker:function(target,settings){var inlineSettings=null;for(var attrName in this._defaults){var attrValue=target.getAttribute("date:"+attrName);if(attrValue){inlineSettings=inlineSettings||{};try{inlineSettings[attrName]=eval(attrValue)}catch(err){inlineSettings[attrName]=attrValue}}}var nodeName=target.nodeName.toLowerCase(),inline=nodeName=="div"||nodeName=="span";target.id||(this.uuid+=1,target.id="dp"+this.uuid);var inst=this._newInst($(target),inline);inst.settings=$.extend({},settings||{},inlineSettings||{}),nodeName=="input"?this._connectDatepicker(target,inst):inline&&this._inlineDatepicker(target,inst)},_newInst:function(a,b){var c=a[0].id.replace(/([^A-Za-z0-9_-])/g,"\\\\$1");return{id:c,input:a,selectedDay:0,selectedMonth:0,selectedYear:0,drawMonth:0,drawYear:0,inline:b,dpDiv:b?bindHover($('
    ')):this.dpDiv}},_connectDatepicker:function(a,b){var c=$(a);b.append=$([]),b.trigger=$([]);if(c.hasClass(this.markerClassName))return;this._attachments(c,b),c.addClass(this.markerClassName).keydown(this._doKeyDown).keypress(this._doKeyPress).keyup(this._doKeyUp).bind("setData.datepicker",function(a,c,d){b.settings[c]=d}).bind("getData.datepicker",function(a,c){return this._get(b,c)}),this._autoSize(b),$.data(a,PROP_NAME,b),b.settings.disabled&&this._disableDatepicker(a)},_attachments:function(a,b){var c=this._get(b,"appendText"),d=this._get(b,"isRTL");b.append&&b.append.remove(),c&&(b.append=$(''+c+""),a[d?"before":"after"](b.append)),a.unbind("focus",this._showDatepicker),b.trigger&&b.trigger.remove();var e=this._get(b,"showOn");(e=="focus"||e=="both")&&a.focus(this._showDatepicker);if(e=="button"||e=="both"){var f=this._get(b,"buttonText"),g=this._get(b,"buttonImage");b.trigger=$(this._get(b,"buttonImageOnly")?$("").addClass(this._triggerClass).attr({src:g,alt:f,title:f}):$('').addClass(this._triggerClass).html(g==""?f:$("").attr({src:g,alt:f,title:f}))),a[d?"before":"after"](b.trigger),b.trigger.click(function(){return $.datepicker._datepickerShowing&&$.datepicker._lastInput==a[0]?$.datepicker._hideDatepicker():$.datepicker._datepickerShowing&&$.datepicker._lastInput!=a[0]?($.datepicker._hideDatepicker(),$.datepicker._showDatepicker(a[0])):$.datepicker._showDatepicker(a[0]),!1})}},_autoSize:function(a){if(this._get(a,"autoSize")&&!a.inline){var b=new Date(2009,11,20),c=this._get(a,"dateFormat");if(c.match(/[DM]/)){var d=function(a){var b=0,c=0;for(var d=0;db&&(b=a[d].length,c=d);return c};b.setMonth(d(this._get(a,c.match(/MM/)?"monthNames":"monthNamesShort"))),b.setDate(d(this._get(a,c.match(/DD/)?"dayNames":"dayNamesShort"))+20-b.getDay())}a.input.attr("size",this._formatDate(a,b).length)}},_inlineDatepicker:function(a,b){var c=$(a);if(c.hasClass(this.markerClassName))return;c.addClass(this.markerClassName).append(b.dpDiv).bind("setData.datepicker",function(a,c,d){b.settings[c]=d}).bind("getData.datepicker",function(a,c){return this._get(b,c)}),$.data(a,PROP_NAME,b),this._setDate(b,this._getDefaultDate(b),!0),this._updateDatepicker(b),this._updateAlternate(b),b.settings.disabled&&this._disableDatepicker(a),b.dpDiv.css("display","block")},_dialogDatepicker:function(a,b,c,d,e){var f=this._dialogInst;if(!f){this.uuid+=1;var g="dp"+this.uuid;this._dialogInput=$(''),this._dialogInput.keydown(this._doKeyDown),$("body").append(this._dialogInput),f=this._dialogInst=this._newInst(this._dialogInput,!1),f.settings={},$.data(this._dialogInput[0],PROP_NAME,f)}extendRemove(f.settings,d||{}),b=b&&b.constructor==Date?this._formatDate(f,b):b,this._dialogInput.val(b),this._pos=e?e.length?e:[e.pageX,e.pageY]:null;if(!this._pos){var h=document.documentElement.clientWidth,i=document.documentElement.clientHeight,j=document.documentElement.scrollLeft||document.body.scrollLeft,k=document.documentElement.scrollTop||document.body.scrollTop;this._pos=[h/2-100+j,i/2-150+k]}return this._dialogInput.css("left",this._pos[0]+20+"px").css("top",this._pos[1]+"px"),f.settings.onSelect=c,this._inDialog=!0,this.dpDiv.addClass(this._dialogClass),this._showDatepicker(this._dialogInput[0]),$.blockUI&&$.blockUI(this.dpDiv),$.data(this._dialogInput[0],PROP_NAME,f),this},_destroyDatepicker:function(a){var b=$(a),c=$.data(a,PROP_NAME);if(!b.hasClass(this.markerClassName))return;var d=a.nodeName.toLowerCase();$.removeData(a,PROP_NAME),d=="input"?(c.append.remove(),c.trigger.remove(),b.removeClass(this.markerClassName).unbind("focus",this._showDatepicker).unbind("keydown",this._doKeyDown).unbind("keypress",this._doKeyPress).unbind("keyup",this._doKeyUp)):(d=="div"||d=="span")&&b.removeClass(this.markerClassName).empty()},_enableDatepicker:function(a){var b=$(a),c=$.data(a,PROP_NAME);if(!b.hasClass(this.markerClassName))return;var d=a.nodeName.toLowerCase();if(d=="input")a.disabled=!1,c.trigger.filter("button").each(function(){this.disabled=!1}).end().filter("img").css({opacity:"1.0",cursor:""});else if(d=="div"||d=="span"){var e=b.children("."+this._inlineClass);e.children().removeClass("ui-state-disabled"),e.find("select.ui-datepicker-month, select.ui-datepicker-year").removeAttr("disabled")}this._disabledInputs=$.map(this._disabledInputs,function(b){return b==a?null:b})},_disableDatepicker:function(a){var b=$(a),c=$.data(a,PROP_NAME);if(!b.hasClass(this.markerClassName))return;var d=a.nodeName.toLowerCase();if(d=="input")a.disabled=!0,c.trigger.filter("button").each(function(){this.disabled=!0}).end().filter("img").css({opacity:"0.5",cursor:"default"});else if(d=="div"||d=="span"){var e=b.children("."+this._inlineClass);e.children().addClass("ui-state-disabled"),e.find("select.ui-datepicker-month, select.ui-datepicker-year").attr("disabled","disabled")}this._disabledInputs=$.map(this._disabledInputs,function(b){return b==a?null:b}),this._disabledInputs[this._disabledInputs.length]=a},_isDisabledDatepicker:function(a){if(!a)return!1;for(var b=0;b-1}},_doKeyUp:function(a){var b=$.datepicker._getInst(a.target);if(b.input.val()!=b.lastVal)try{var c=$.datepicker.parseDate($.datepicker._get(b,"dateFormat"),b.input?b.input.val():null,$.datepicker._getFormatConfig(b));c&&($.datepicker._setDateFromField(b),$.datepicker._updateAlternate(b),$.datepicker._updateDatepicker(b))}catch(d){$.datepicker.log(d)}return!0},_showDatepicker:function(a){a=a.target||a,a.nodeName.toLowerCase()!="input"&&(a=$("input",a.parentNode)[0]);if($.datepicker._isDisabledDatepicker(a)||$.datepicker._lastInput==a)return;var b=$.datepicker._getInst(a);$.datepicker._curInst&&$.datepicker._curInst!=b&&($.datepicker._curInst.dpDiv.stop(!0,!0),b&&$.datepicker._datepickerShowing&&$.datepicker._hideDatepicker($.datepicker._curInst.input[0]));var c=$.datepicker._get(b,"beforeShow"),d=c?c.apply(a,[a,b]):{};if(d===!1)return;extendRemove(b.settings,d),b.lastVal=null,$.datepicker._lastInput=a,$.datepicker._setDateFromField(b),$.datepicker._inDialog&&(a.value=""),$.datepicker._pos||($.datepicker._pos=$.datepicker._findPos(a),$.datepicker._pos[1]+=a.offsetHeight);var e=!1;$(a).parents().each(function(){return e|=$(this).css("position")=="fixed",!e}),e&&$.browser.opera&&($.datepicker._pos[0]-=document.documentElement.scrollLeft,$.datepicker._pos[1]-=document.documentElement.scrollTop);var f={left:$.datepicker._pos[0],top:$.datepicker._pos[1]};$.datepicker._pos=null,b.dpDiv.empty(),b.dpDiv.css({position:"absolute",display:"block",top:"-1000px"}),$.datepicker._updateDatepicker(b),f=$.datepicker._checkOffset(b,f,e),b.dpDiv.css({position:$.datepicker._inDialog&&$.blockUI?"static":e?"fixed":"absolute",display:"none",left:f.left+"px",top:f.top+"px"});if(!b.inline){var g=$.datepicker._get(b,"showAnim"),h=$.datepicker._get(b,"duration"),i=function(){var a=b.dpDiv.find("iframe.ui-datepicker-cover");if(!!a.length){var c=$.datepicker._getBorders(b.dpDiv);a.css({left:-c[0],top:-c[1],width:b.dpDiv.outerWidth(),height:b.dpDiv.outerHeight()})}};b.dpDiv.zIndex($(a).zIndex()+1),$.datepicker._datepickerShowing=!0,$.effects&&$.effects[g]?b.dpDiv.show(g,$.datepicker._get(b,"showOptions"),h,i):b.dpDiv[g||"show"](g?h:null,i),(!g||!h)&&i(),b.input.is(":visible")&&!b.input.is(":disabled")&&b.input.focus(),$.datepicker._curInst=b}},_updateDatepicker:function(a){var b=this;b.maxRows=4;var c=$.datepicker._getBorders(a.dpDiv);instActive=a,a.dpDiv.empty().append(this._generateHTML(a));var d=a.dpDiv.find("iframe.ui-datepicker-cover");!d.length||d.css({left:-c[0],top:-c[1],width:a.dpDiv.outerWidth(),height:a.dpDiv.outerHeight()}),a.dpDiv.find("."+this._dayOverClass+" a").mouseover();var e=this._getNumberOfMonths(a),f=e[1],g=17;a.dpDiv.removeClass("ui-datepicker-multi-2 ui-datepicker-multi-3 ui-datepicker-multi-4").width(""),f>1&&a.dpDiv.addClass("ui-datepicker-multi-"+f).css("width",g*f+"em"),a.dpDiv[(e[0]!=1||e[1]!=1?"add":"remove")+"Class"]("ui-datepicker-multi"),a.dpDiv[(this._get(a,"isRTL")?"add":"remove")+"Class"]("ui-datepicker-rtl"),a==$.datepicker._curInst&&$.datepicker._datepickerShowing&&a.input&&a.input.is(":visible")&&!a.input.is(":disabled")&&a.input[0]!=document.activeElement&&a.input.focus();if(a.yearshtml){var h=a.yearshtml;setTimeout(function(){h===a.yearshtml&&a.yearshtml&&a.dpDiv.find("select.ui-datepicker-year:first").replaceWith(a.yearshtml),h=a.yearshtml=null},0)}},_getBorders:function(a){var b=function(a){return{thin:1,medium:2,thick:3}[a]||a};return[parseFloat(b(a.css("border-left-width"))),parseFloat(b(a.css("border-top-width")))]},_checkOffset:function(a,b,c){var d=a.dpDiv.outerWidth(),e=a.dpDiv.outerHeight(),f=a.input?a.input.outerWidth():0,g=a.input?a.input.outerHeight():0,h=document.documentElement.clientWidth+$(document).scrollLeft(),i=document.documentElement.clientHeight+$(document).scrollTop();return b.left-=this._get(a,"isRTL")?d-f:0,b.left-=c&&b.left==a.input.offset().left?$(document).scrollLeft():0,b.top-=c&&b.top==a.input.offset().top+g?$(document).scrollTop():0,b.left-=Math.min(b.left,b.left+d>h&&h>d?Math.abs(b.left+d-h):0),b.top-=Math.min(b.top,b.top+e>i&&i>e?Math.abs(e+g):0),b},_findPos:function(a){var b=this._getInst(a),c=this._get(b,"isRTL");while(a&&(a.type=="hidden"||a.nodeType!=1||$.expr.filters.hidden(a)))a=a[c?"previousSibling":"nextSibling"];var d=$(a).offset();return[d.left,d.top]},_hideDatepicker:function(a){var b=this._curInst;if(!b||a&&b!=$.data(a,PROP_NAME))return;if(this._datepickerShowing){var c=this._get(b,"showAnim"),d=this._get(b,"duration"),e=function(){$.datepicker._tidyDialog(b)};$.effects&&$.effects[c]?b.dpDiv.hide(c,$.datepicker._get(b,"showOptions"),d,e):b.dpDiv[c=="slideDown"?"slideUp":c=="fadeIn"?"fadeOut":"hide"](c?d:null,e),c||e(),this._datepickerShowing=!1;var f=this._get(b,"onClose");f&&f.apply(b.input?b.input[0]:null,[b.input?b.input.val():"",b]),this._lastInput=null,this._inDialog&&(this._dialogInput.css({position:"absolute",left:"0",top:"-100px"}),$.blockUI&&($.unblockUI(),$("body").append(this.dpDiv))),this._inDialog=!1}},_tidyDialog:function(a){a.dpDiv.removeClass(this._dialogClass).unbind(".ui-datepicker-calendar")},_checkExternalClick:function(a){if(!$.datepicker._curInst)return;var b=$(a.target),c=$.datepicker._getInst(b[0]);(b[0].id!=$.datepicker._mainDivId&&b.parents("#"+$.datepicker._mainDivId).length==0&&!b.hasClass($.datepicker.markerClassName)&&!b.closest("."+$.datepicker._triggerClass).length&&$.datepicker._datepickerShowing&&(!$.datepicker._inDialog||!$.blockUI)||b.hasClass($.datepicker.markerClassName)&&$.datepicker._curInst!=c)&&$.datepicker._hideDatepicker()},_adjustDate:function(a,b,c){var d=$(a),e=this._getInst(d[0]);if(this._isDisabledDatepicker(d[0]))return;this._adjustInstDate(e,b+(c=="M"?this._get(e,"showCurrentAtPos"):0),c),this._updateDatepicker(e)},_gotoToday:function(a){var b=$(a),c=this._getInst(b[0]);if(this._get(c,"gotoCurrent")&&c.currentDay)c.selectedDay=c.currentDay,c.drawMonth=c.selectedMonth=c.currentMonth,c.drawYear=c.selectedYear=c.currentYear;else{var d=new Date;c.selectedDay=d.getDate(),c.drawMonth=c.selectedMonth=d.getMonth(),c.drawYear=c.selectedYear=d.getFullYear()}this._notifyChange(c),this._adjustDate(b)},_selectMonthYear:function(a,b,c){var d=$(a),e=this._getInst(d[0]);e["selected"+(c=="M"?"Month":"Year")]=e["draw"+(c=="M"?"Month":"Year")]=parseInt(b.options[b.selectedIndex].value,10),this._notifyChange(e),this._adjustDate(d)},_selectDay:function(a,b,c,d){var e=$(a);if($(d).hasClass(this._unselectableClass)||this._isDisabledDatepicker(e[0]))return;var f=this._getInst(e[0]);f.selectedDay=f.currentDay=$("a",d).html(),f.selectedMonth=f.currentMonth=b,f.selectedYear=f.currentYear=c,this._selectDate(a,this._formatDate(f,f.currentDay,f.currentMonth,f.currentYear))},_clearDate:function(a){var b=$(a),c=this._getInst(b[0]);this._selectDate(b,"")},_selectDate:function(a,b){var c=$(a),d=this._getInst(c[0]);b=b!=null?b:this._formatDate(d),d.input&&d.input.val(b),this._updateAlternate(d);var e=this._get(d,"onSelect");e?e.apply(d.input?d.input[0]:null,[b,d]):d.input&&d.input.trigger("change"),d.inline?this._updateDatepicker(d):(this._hideDatepicker(),this._lastInput=d.input[0],typeof d.input[0]!="object"&&d.input.focus(),this._lastInput=null)},_updateAlternate:function(a){var b=this._get(a,"altField");if(b){var c=this._get(a,"altFormat")||this._get(a,"dateFormat"),d=this._getDate(a),e=this.formatDate(c,d,this._getFormatConfig(a));$(b).each(function(){$(this).val(e)})}},noWeekends:function(a){var b=a.getDay();return[b>0&&b<6,""]},iso8601Week:function(a){var b=new Date(a.getTime());b.setDate(b.getDate()+4-(b.getDay()||7));var c=b.getTime();return b.setMonth(0),b.setDate(1),Math.floor(Math.round((c-b)/864e5)/7)+1},parseDate:function(a,b,c){if(a==null||b==null)throw"Invalid arguments";b=typeof b=="object"?b.toString():b+"";if(b=="")return null;var d=(c?c.shortYearCutoff:null)||this._defaults.shortYearCutoff;d=typeof d!="string"?d:(new Date).getFullYear()%100+parseInt(d,10);var e=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,f=(c?c.dayNames:null)||this._defaults.dayNames,g=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort,h=(c?c.monthNames:null)||this._defaults.monthNames,i=-1,j=-1,k=-1,l=-1,m=!1,n=function(b){var c=s+1-1){j=1,k=l;do{var u=this._getDaysInMonth(i,j-1);if(k<=u)break;j++,k-=u}while(!0)}var t=this._daylightSavingAdjust(new Date(i,j-1,k));if(t.getFullYear()!=i||t.getMonth()+1!=j||t.getDate()!=k)throw"Invalid date";return t},ATOM:"yy-mm-dd",COOKIE:"D, dd M yy",ISO_8601:"yy-mm-dd",RFC_822:"D, d M y",RFC_850:"DD, dd-M-y",RFC_1036:"D, d M y",RFC_1123:"D, d M yy",RFC_2822:"D, d M yy",RSS:"D, d M y",TICKS:"!",TIMESTAMP:"@",W3C:"yy-mm-dd",_ticksTo1970:(718685+Math.floor(492.5)-Math.floor(19.7)+Math.floor(4.925))*24*60*60*1e7,formatDate:function(a,b,c){if(!b)return"";var d=(c?c.dayNamesShort:null)||this._defaults.dayNamesShort,e=(c?c.dayNames:null)||this._defaults.dayNames,f=(c?c.monthNamesShort:null)||this._defaults.monthNamesShort,g=(c?c.monthNames:null)||this._defaults.monthNames,h=function(b){var c=m+112?a.getHours()+2:0),a):null},_setDate:function(a,b,c){var d=!b,e=a.selectedMonth,f=a.selectedYear,g=this._restrictMinMax(a,this._determineDate(a,b,new Date));a.selectedDay=a.currentDay=g.getDate(),a.drawMonth=a.selectedMonth=a.currentMonth=g.getMonth(),a.drawYear=a.selectedYear=a.currentYear=g.getFullYear(),(e!=a.selectedMonth||f!=a.selectedYear)&&!c&&this._notifyChange(a),this._adjustInstDate(a),a.input&&a.input.val(d?"":this._formatDate(a))},_getDate:function(a){var b=!a.currentYear||a.input&&a.input.val()==""?null:this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay));return b},_generateHTML:function(a){var b=new Date;b=this._daylightSavingAdjust(new Date(b.getFullYear(),b.getMonth(),b.getDate()));var c=this._get(a,"isRTL"),d=this._get(a,"showButtonPanel"),e=this._get(a,"hideIfNoPrevNext"),f=this._get(a,"navigationAsDateFormat"),g=this._getNumberOfMonths(a),h=this._get(a,"showCurrentAtPos"),i=this._get(a,"stepMonths"),j=g[0]!=1||g[1]!=1,k=this._daylightSavingAdjust(a.currentDay?new Date(a.currentYear,a.currentMonth,a.currentDay):new Date(9999,9,9)),l=this._getMinMaxDate(a,"min"),m=this._getMinMaxDate(a,"max"),n=a.drawMonth-h,o=a.drawYear;n<0&&(n+=12,o--);if(m){var p=this._daylightSavingAdjust(new Date(m.getFullYear(),m.getMonth()-g[0]*g[1]+1,m.getDate()));p=l&&pp)n--,n<0&&(n=11,o--)}a.drawMonth=n,a.drawYear=o;var q=this._get(a,"prevText");q=f?this.formatDate(q,this._daylightSavingAdjust(new Date(o,n-i,1)),this._getFormatConfig(a)):q;var r=this._canAdjustMonth(a,-1,o,n)?''+q+"":e?"":''+q+"",s=this._get(a,"nextText");s=f?this.formatDate(s,this._daylightSavingAdjust(new Date(o,n+i,1)),this._getFormatConfig(a)):s;var t=this._canAdjustMonth(a,1,o,n)?''+s+"":e?"":''+s+"",u=this._get(a,"currentText"),v=this._get(a,"gotoCurrent")&&a.currentDay?k:b;u=f?this.formatDate(u,v,this._getFormatConfig(a)):u;var w=a.inline?"":'",x=d?'
    '+(c?w:"")+(this._isInRange(a,v)?'":"")+(c?"":w)+"
    ":"",y=parseInt(this._get(a,"firstDay"),10);y=isNaN(y)?0:y;var z=this._get(a,"showWeek"),A=this._get(a,"dayNames"),B=this._get(a,"dayNamesShort"),C=this._get(a,"dayNamesMin"),D=this._get(a,"monthNames"),E=this._get(a,"monthNamesShort"),F=this._get(a,"beforeShowDay"),G=this._get(a,"showOtherMonths"),H=this._get(a,"selectOtherMonths"),I=this._get(a,"calculateWeek")||this.iso8601Week,J=this._getDefaultDate(a),K="";for(var L=0;L1)switch(N){case 0:Q+=" ui-datepicker-group-first",P=" ui-corner-"+(c?"right":"left");break;case g[1]-1:Q+=" ui-datepicker-group-last",P=" ui-corner-"+(c?"left":"right");break;default:Q+=" ui-datepicker-group-middle",P=""}Q+='">'}Q+='
    '+(/all|left/.test(P)&&L==0?c?t:r:"")+(/all|right/.test(P)&&L==0?c?r:t:"")+this._generateMonthYearHeader(a,n,o,l,m,L>0||N>0,D,E)+'
    '+"";var R=z?'":"";for(var S=0;S<7;S++){var T=(S+y)%7;R+="=5?' class="ui-datepicker-week-end"':"")+">"+''+C[T]+""}Q+=R+"";var U=this._getDaysInMonth(o,n);o==a.selectedYear&&n==a.selectedMonth&&(a.selectedDay=Math.min(a.selectedDay,U));var V=(this._getFirstDayOfMonth(o,n)-y+7)%7,W=Math.ceil((V+U)/7),X=j?this.maxRows>W?this.maxRows:W:W;this.maxRows=X;var Y=this._daylightSavingAdjust(new Date(o,n,1-V));for(var Z=0;Z";var _=z?'":"";for(var S=0;S<7;S++){var ba=F?F.apply(a.input?a.input[0]:null,[Y]):[!0,""],bb=Y.getMonth()!=n,bc=bb&&!H||!ba[0]||l&&Ym;_+='",Y.setDate(Y.getDate()+1),Y=this._daylightSavingAdjust(Y)}Q+=_+""}n++,n>11&&(n=0,o++),Q+="
    '+this._get(a,"weekHeader")+"
    '+this._get(a,"calculateWeek")(Y)+""+(bb&&!G?" ":bc?''+Y.getDate()+"":''+Y.getDate()+"")+"
    "+(j?""+(g[0]>0&&N==g[1]-1?'
    ':""):""),M+=Q}K+=M}return K+=x+($.browser.msie&&parseInt($.browser.version,10)<7&&!a.inline?'':""),a._keyEvent=!1,K},_generateMonthYearHeader:function(a,b,c,d,e,f,g,h){var i=this._get(a,"changeMonth"),j=this._get(a,"changeYear"),k=this._get(a,"showMonthAfterYear"),l='
    ',m="";if(f||!i)m+=''+g[b]+"";else{var n=d&&d.getFullYear()==c,o=e&&e.getFullYear()==c;m+='"}k||(l+=m+(f||!i||!j?" ":""));if(!a.yearshtml){a.yearshtml="";if(f||!j)l+=''+c+"";else{var q=this._get(a,"yearRange").split(":"),r=(new Date).getFullYear(),s=function(a){var b=a.match(/c[+-].*/)?c+parseInt(a.substring(1),10):a.match(/[+-].*/)?r+parseInt(a,10):parseInt(a,10);return isNaN(b)?r:b},t=s(q[0]),u=Math.max(t,s(q[1]||""));t=d?Math.max(t,d.getFullYear()):t,u=e?Math.min(u,e.getFullYear()):u,a.yearshtml+='",l+=a.yearshtml,a.yearshtml=null}}return l+=this._get(a,"yearSuffix"),k&&(l+=(f||!i||!j?" ":"")+m),l+="
    ",l},_adjustInstDate:function(a,b,c){var d=a.drawYear+(c=="Y"?b:0),e=a.drawMonth+(c=="M"?b:0),f=Math.min(a.selectedDay,this._getDaysInMonth(d,e))+(c=="D"?b:0),g=this._restrictMinMax(a,this._daylightSavingAdjust(new Date(d,e,f)));a.selectedDay=g.getDate(),a.drawMonth=a.selectedMonth=g.getMonth(),a.drawYear=a.selectedYear=g.getFullYear(),(c=="M"||c=="Y")&&this._notifyChange(a)},_restrictMinMax:function(a,b){var c=this._getMinMaxDate(a,"min"),d=this._getMinMaxDate(a,"max"),e=c&&bd?d:e,e},_notifyChange:function(a){var b=this._get(a,"onChangeMonthYear");b&&b.apply(a.input?a.input[0]:null,[a.selectedYear,a.selectedMonth+1,a])},_getNumberOfMonths:function(a){var b=this._get(a,"numberOfMonths");return b==null?[1,1]:typeof b=="number"?[1,b]:b},_getMinMaxDate:function(a,b){return this._determineDate(a,this._get(a,b+"Date"),null)},_getDaysInMonth:function(a,b){return 32-this._daylightSavingAdjust(new Date(a,b,32)).getDate()},_getFirstDayOfMonth:function(a,b){return(new Date(a,b,1)).getDay()},_canAdjustMonth:function(a,b,c,d){var e=this._getNumberOfMonths(a),f=this._daylightSavingAdjust(new Date(c,d+(b<0?b:e[0]*e[1]),1));return b<0&&f.setDate(this._getDaysInMonth(f.getFullYear(),f.getMonth())),this._isInRange(a,f)},_isInRange:function(a,b){var c=this._getMinMaxDate(a,"min"),d=this._getMinMaxDate(a,"max");return(!c||b.getTime()>=c.getTime())&&(!d||b.getTime()<=d.getTime())},_getFormatConfig:function(a){var b=this._get(a,"shortYearCutoff");return b=typeof b!="string"?b:(new Date).getFullYear()%100+parseInt(b,10),{shortYearCutoff:b,dayNamesShort:this._get(a,"dayNamesShort"),dayNames:this._get(a,"dayNames"),monthNamesShort:this._get(a,"monthNamesShort"),monthNames:this._get(a,"monthNames")}},_formatDate:function(a,b,c,d){b||(a.currentDay=a.selectedDay,a.currentMonth=a.selectedMonth,a.currentYear=a.selectedYear);var e=b?typeof b=="object"?b:this._daylightSavingAdjust(new Date(d,c,b)):this._daylightSavingAdjust(new Date(a.currentYear,a.currentMonth,a.currentDay));return this.formatDate(this._get(a,"dateFormat"),e,this._getFormatConfig(a))}}),$.fn.datepicker=function(a){if(!this.length)return this;$.datepicker.initialized||($(document).mousedown($.datepicker._checkExternalClick).find("body").append($.datepicker.dpDiv),$.datepicker.initialized=!0);var b=Array.prototype.slice.call(arguments,1);return typeof a!="string"||a!="isDisabled"&&a!="getDate"&&a!="widget"?a=="option"&&arguments.length==2&&typeof arguments[1]=="string"?$.datepicker["_"+a+"Datepicker"].apply($.datepicker,[this[0]].concat(b)):this.each(function(){typeof a=="string"?$.datepicker["_"+a+"Datepicker"].apply($.datepicker,[this].concat(b)):$.datepicker._attachDatepicker(this,a)}):$.datepicker["_"+a+"Datepicker"].apply($.datepicker,[this[0]].concat(b))},$.datepicker=new Datepicker,$.datepicker.initialized=!1,$.datepicker.uuid=(new Date).getTime(),$.datepicker.version="1.8.21",window["DP_jQuery_"+dpuuid]=$})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.ui.progressbar.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.widget("ui.progressbar",{options:{value:0,max:100},min:0,_create:function(){this.element.addClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").attr({role:"progressbar","aria-valuemin":this.min,"aria-valuemax":this.options.max,"aria-valuenow":this._value()}),this.valueDiv=a("
    ").appendTo(this.element),this.oldValue=this._value(),this._refreshValue()},destroy:function(){this.element.removeClass("ui-progressbar ui-widget ui-widget-content ui-corner-all").removeAttr("role").removeAttr("aria-valuemin").removeAttr("aria-valuemax").removeAttr("aria-valuenow"),this.valueDiv.remove(),a.Widget.prototype.destroy.apply(this,arguments)},value:function(a){return a===b?this._value():(this._setOption("value",a),this)},_setOption:function(b,c){b==="value"&&(this.options.value=c,this._refreshValue(),this._value()===this.options.max&&this._trigger("complete")),a.Widget.prototype._setOption.apply(this,arguments)},_value:function(){var a=this.options.value;return typeof a!="number"&&(a=0),Math.min(this.options.max,Math.max(this.min,a))},_percentage:function(){return 100*this._value()/this.options.max},_refreshValue:function(){var a=this.value(),b=this._percentage();this.oldValue!==a&&(this.oldValue=a,this._trigger("change")),this.valueDiv.toggle(a>this.min).toggleClass("ui-corner-right",a===this.options.max).width(b.toFixed(0)+"%"),this.element.attr("aria-valuenow",a)}}),a.extend(a.ui.progressbar,{version:"1.8.21"})})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.effects.core.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -jQuery.effects||function(a,b){function c(b){var c;return b&&b.constructor==Array&&b.length==3?b:(c=/rgb\(\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*,\s*([0-9]{1,3})\s*\)/.exec(b))?[parseInt(c[1],10),parseInt(c[2],10),parseInt(c[3],10)]:(c=/rgb\(\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*,\s*([0-9]+(?:\.[0-9]+)?)\%\s*\)/.exec(b))?[parseFloat(c[1])*2.55,parseFloat(c[2])*2.55,parseFloat(c[3])*2.55]:(c=/#([a-fA-F0-9]{2})([a-fA-F0-9]{2})([a-fA-F0-9]{2})/.exec(b))?[parseInt(c[1],16),parseInt(c[2],16),parseInt(c[3],16)]:(c=/#([a-fA-F0-9])([a-fA-F0-9])([a-fA-F0-9])/.exec(b))?[parseInt(c[1]+c[1],16),parseInt(c[2]+c[2],16),parseInt(c[3]+c[3],16)]:(c=/rgba\(0, 0, 0, 0\)/.exec(b))?e.transparent:e[a.trim(b).toLowerCase()]}function d(b,d){var e;do{e=a.curCSS(b,d);if(e!=""&&e!="transparent"||a.nodeName(b,"body"))break;d="backgroundColor"}while(b=b.parentNode);return c(e)}function h(){var a=document.defaultView?document.defaultView.getComputedStyle(this,null):this.currentStyle,b={},c,d;if(a&&a.length&&a[0]&&a[a[0]]){var e=a.length;while(e--)c=a[e],typeof a[c]=="string"&&(d=c.replace(/\-(\w)/g,function(a,b){return b.toUpperCase()}),b[d]=a[c])}else for(c in a)typeof a[c]=="string"&&(b[c]=a[c]);return b}function i(b){var c,d;for(c in b)d=b[c],(d==null||a.isFunction(d)||c in g||/scrollbar/.test(c)||!/color/i.test(c)&&isNaN(parseFloat(d)))&&delete b[c];return b}function j(a,b){var c={_:0},d;for(d in b)a[d]!=b[d]&&(c[d]=b[d]);return c}function k(b,c,d,e){typeof b=="object"&&(e=c,d=null,c=b,b=c.effect),a.isFunction(c)&&(e=c,d=null,c={});if(typeof c=="number"||a.fx.speeds[c])e=d,d=c,c={};return a.isFunction(d)&&(e=d,d=null),c=c||{},d=d||c.duration,d=a.fx.off?0:typeof d=="number"?d:d in a.fx.speeds?a.fx.speeds[d]:a.fx.speeds._default,e=e||c.complete,[b,c,d,e]}function l(b){return!b||typeof b=="number"||a.fx.speeds[b]?!0:typeof b=="string"&&!a.effects[b]?!0:!1}a.effects={},a.each(["backgroundColor","borderBottomColor","borderLeftColor","borderRightColor","borderTopColor","borderColor","color","outlineColor"],function(b,e){a.fx.step[e]=function(a){a.colorInit||(a.start=d(a.elem,e),a.end=c(a.end),a.colorInit=!0),a.elem.style[e]="rgb("+Math.max(Math.min(parseInt(a.pos*(a.end[0]-a.start[0])+a.start[0],10),255),0)+","+Math.max(Math.min(parseInt(a.pos*(a.end[1]-a.start[1])+a.start[1],10),255),0)+","+Math.max(Math.min(parseInt(a.pos*(a.end[2]-a.start[2])+a.start[2],10),255),0)+")"}});var e={aqua:[0,255,255],azure:[240,255,255],beige:[245,245,220],black:[0,0,0],blue:[0,0,255],brown:[165,42,42],cyan:[0,255,255],darkblue:[0,0,139],darkcyan:[0,139,139],darkgrey:[169,169,169],darkgreen:[0,100,0],darkkhaki:[189,183,107],darkmagenta:[139,0,139],darkolivegreen:[85,107,47],darkorange:[255,140,0],darkorchid:[153,50,204],darkred:[139,0,0],darksalmon:[233,150,122],darkviolet:[148,0,211],fuchsia:[255,0,255],gold:[255,215,0],green:[0,128,0],indigo:[75,0,130],khaki:[240,230,140],lightblue:[173,216,230],lightcyan:[224,255,255],lightgreen:[144,238,144],lightgrey:[211,211,211],lightpink:[255,182,193],lightyellow:[255,255,224],lime:[0,255,0],magenta:[255,0,255],maroon:[128,0,0],navy:[0,0,128],olive:[128,128,0],orange:[255,165,0],pink:[255,192,203],purple:[128,0,128],violet:[128,0,128],red:[255,0,0],silver:[192,192,192],white:[255,255,255],yellow:[255,255,0],transparent:[255,255,255]},f=["add","remove","toggle"],g={border:1,borderBottom:1,borderColor:1,borderLeft:1,borderRight:1,borderTop:1,borderWidth:1,margin:1,padding:1};a.effects.animateClass=function(b,c,d,e){return a.isFunction(d)&&(e=d,d=null),this.queue(function(){var g=a(this),k=g.attr("style")||" ",l=i(h.call(this)),m,n=g.attr("class")||"";a.each(f,function(a,c){b[c]&&g[c+"Class"](b[c])}),m=i(h.call(this)),g.attr("class",n),g.animate(j(l,m),{queue:!1,duration:c,easing:d,complete:function(){a.each(f,function(a,c){b[c]&&g[c+"Class"](b[c])}),typeof g.attr("style")=="object"?(g.attr("style").cssText="",g.attr("style").cssText=k):g.attr("style",k),e&&e.apply(this,arguments),a.dequeue(this)}})})},a.fn.extend({_addClass:a.fn.addClass,addClass:function(b,c,d,e){return c?a.effects.animateClass.apply(this,[{add:b},c,d,e]):this._addClass(b)},_removeClass:a.fn.removeClass,removeClass:function(b,c,d,e){return c?a.effects.animateClass.apply(this,[{remove:b},c,d,e]):this._removeClass(b)},_toggleClass:a.fn.toggleClass,toggleClass:function(c,d,e,f,g){return typeof d=="boolean"||d===b?e?a.effects.animateClass.apply(this,[d?{add:c}:{remove:c},e,f,g]):this._toggleClass(c,d):a.effects.animateClass.apply(this,[{toggle:c},d,e,f])},switchClass:function(b,c,d,e,f){return a.effects.animateClass.apply(this,[{add:c,remove:b},d,e,f])}}),a.extend(a.effects,{version:"1.8.21",save:function(a,b){for(var c=0;c").addClass("ui-effects-wrapper").css({fontSize:"100%",background:"transparent",border:"none",margin:0,padding:0}),e=document.activeElement;try{e.id}catch(f){e=document.body}return b.wrap(d),(b[0]===e||a.contains(b[0],e))&&a(e).focus(),d=b.parent(),b.css("position")=="static"?(d.css({position:"relative"}),b.css({position:"relative"})):(a.extend(c,{position:b.css("position"),zIndex:b.css("z-index")}),a.each(["top","left","bottom","right"],function(a,d){c[d]=b.css(d),isNaN(parseInt(c[d],10))&&(c[d]="auto")}),b.css({position:"relative",top:0,left:0,right:"auto",bottom:"auto"})),d.css(c).show()},removeWrapper:function(b){var c,d=document.activeElement;return b.parent().is(".ui-effects-wrapper")?(c=b.parent().replaceWith(b),(b[0]===d||a.contains(b[0],d))&&a(d).focus(),c):b},setTransition:function(b,c,d,e){return e=e||{},a.each(c,function(a,c){var f=b.cssUnit(c);f[0]>0&&(e[c]=f[0]*d+f[1])}),e}}),a.fn.extend({effect:function(b,c,d,e){var f=k.apply(this,arguments),g={options:f[1],duration:f[2],callback:f[3]},h=g.options.mode,i=a.effects[b];return a.fx.off||!i?h?this[h](g.duration,g.callback):this.each(function(){g.callback&&g.callback.call(this)}):i.call(this,g)},_show:a.fn.show,show:function(a){if(l(a))return this._show.apply(this,arguments);var b=k.apply(this,arguments);return b[1].mode="show",this.effect.apply(this,b)},_hide:a.fn.hide,hide:function(a){if(l(a))return this._hide.apply(this,arguments);var b=k.apply(this,arguments);return b[1].mode="hide",this.effect.apply(this,b)},__toggle:a.fn.toggle,toggle:function(b){if(l(b)||typeof b=="boolean"||a.isFunction(b))return this.__toggle.apply(this,arguments);var c=k.apply(this,arguments);return c[1].mode="toggle",this.effect.apply(this,c)},cssUnit:function(b){var c=this.css(b),d=[];return a.each(["em","px","%","pt"],function(a,b){c.indexOf(b)>0&&(d=[parseFloat(c),b])}),d}}),a.easing.jswing=a.easing.swing,a.extend(a.easing,{def:"easeOutQuad",swing:function(b,c,d,e,f){return a.easing[a.easing.def](b,c,d,e,f)},easeInQuad:function(a,b,c,d,e){return d*(b/=e)*b+c},easeOutQuad:function(a,b,c,d,e){return-d*(b/=e)*(b-2)+c},easeInOutQuad:function(a,b,c,d,e){return(b/=e/2)<1?d/2*b*b+c:-d/2*(--b*(b-2)-1)+c},easeInCubic:function(a,b,c,d,e){return d*(b/=e)*b*b+c},easeOutCubic:function(a,b,c,d,e){return d*((b=b/e-1)*b*b+1)+c},easeInOutCubic:function(a,b,c,d,e){return(b/=e/2)<1?d/2*b*b*b+c:d/2*((b-=2)*b*b+2)+c},easeInQuart:function(a,b,c,d,e){return d*(b/=e)*b*b*b+c},easeOutQuart:function(a,b,c,d,e){return-d*((b=b/e-1)*b*b*b-1)+c},easeInOutQuart:function(a,b,c,d,e){return(b/=e/2)<1?d/2*b*b*b*b+c:-d/2*((b-=2)*b*b*b-2)+c},easeInQuint:function(a,b,c,d,e){return d*(b/=e)*b*b*b*b+c},easeOutQuint:function(a,b,c,d,e){return d*((b=b/e-1)*b*b*b*b+1)+c},easeInOutQuint:function(a,b,c,d,e){return(b/=e/2)<1?d/2*b*b*b*b*b+c:d/2*((b-=2)*b*b*b*b+2)+c},easeInSine:function(a,b,c,d,e){return-d*Math.cos(b/e*(Math.PI/2))+d+c},easeOutSine:function(a,b,c,d,e){return d*Math.sin(b/e*(Math.PI/2))+c},easeInOutSine:function(a,b,c,d,e){return-d/2*(Math.cos(Math.PI*b/e)-1)+c},easeInExpo:function(a,b,c,d,e){return b==0?c:d*Math.pow(2,10*(b/e-1))+c},easeOutExpo:function(a,b,c,d,e){return b==e?c+d:d*(-Math.pow(2,-10*b/e)+1)+c},easeInOutExpo:function(a,b,c,d,e){return b==0?c:b==e?c+d:(b/=e/2)<1?d/2*Math.pow(2,10*(b-1))+c:d/2*(-Math.pow(2,-10*--b)+2)+c},easeInCirc:function(a,b,c,d,e){return-d*(Math.sqrt(1-(b/=e)*b)-1)+c},easeOutCirc:function(a,b,c,d,e){return d*Math.sqrt(1-(b=b/e-1)*b)+c},easeInOutCirc:function(a,b,c,d,e){return(b/=e/2)<1?-d/2*(Math.sqrt(1-b*b)-1)+c:d/2*(Math.sqrt(1-(b-=2)*b)+1)+c},easeInElastic:function(a,b,c,d,e){var f=1.70158,g=0,h=d;if(b==0)return c;if((b/=e)==1)return c+d;g||(g=e*.3);if(h").css({position:"absolute",visibility:"visible",left:-j*(g/d),top:-i*(h/c)}).parent().addClass("ui-effects-explode").css({position:"absolute",overflow:"hidden",width:g/d,height:h/c,left:f.left+j*(g/d)+(b.options.mode=="show"?(j-Math.floor(d/2))*(g/d):0),top:f.top+i*(h/c)+(b.options.mode=="show"?(i-Math.floor(c/2))*(h/c):0),opacity:b.options.mode=="show"?0:1}).animate({left:f.left+j*(g/d)+(b.options.mode=="show"?0:(j-Math.floor(d/2))*(g/d)),top:f.top+i*(h/c)+(b.options.mode=="show"?0:(i-Math.floor(c/2))*(h/c)),opacity:b.options.mode=="show"?1:0},b.duration||500);setTimeout(function(){b.options.mode=="show"?e.css({visibility:"visible"}):e.css({visibility:"visible"}).hide(),b.callback&&b.callback.apply(e[0]),e.dequeue(),a("div.ui-effects-explode").remove()},b.duration||500)})}})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.effects.fade.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.effects.fade=function(b){return this.queue(function(){var c=a(this),d=a.effects.setMode(c,b.options.mode||"hide");c.animate({opacity:d},{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.effects.fold.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.effects.fold=function(b){return this.queue(function(){var c=a(this),d=["position","top","bottom","left","right"],e=a.effects.setMode(c,b.options.mode||"hide"),f=b.options.size||15,g=!!b.options.horizFirst,h=b.duration?b.duration/2:a.fx.speeds._default/2;a.effects.save(c,d),c.show();var i=a.effects.createWrapper(c).css({overflow:"hidden"}),j=e=="show"!=g,k=j?["width","height"]:["height","width"],l=j?[i.width(),i.height()]:[i.height(),i.width()],m=/([0-9]+)%/.exec(f);m&&(f=parseInt(m[1],10)/100*l[e=="hide"?0:1]),e=="show"&&i.css(g?{height:0,width:f}:{height:f,width:0});var n={},p={};n[k[0]]=e=="show"?l[0]:f,p[k[1]]=e=="show"?l[1]:0,i.animate(n,h,b.options.easing).animate(p,h,b.options.easing,function(){e=="hide"&&c.hide(),a.effects.restore(c,d),a.effects.removeWrapper(c),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()})})}})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.effects.highlight.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.effects.highlight=function(b){return this.queue(function(){var c=a(this),d=["backgroundImage","backgroundColor","opacity"],e=a.effects.setMode(c,b.options.mode||"show"),f={backgroundColor:c.css("backgroundColor")};e=="hide"&&(f.opacity=0),a.effects.save(c,d),c.show().css({backgroundImage:"none",backgroundColor:b.options.color||"#ffff99"}).animate(f,{queue:!1,duration:b.duration,easing:b.options.easing,complete:function(){e=="hide"&&c.hide(),a.effects.restore(c,d),e=="show"&&!a.support.opacity&&this.style.removeAttribute("filter"),b.callback&&b.callback.apply(this,arguments),c.dequeue()}})})}})(jQuery);;/*! jQuery UI - v1.8.21 - 2012-06-05 -* https://github.com/jquery/jquery-ui -* Includes: jquery.effects.pulsate.js -* Copyright (c) 2012 AUTHORS.txt; Licensed MIT, GPL */ -(function(a,b){a.effects.pulsate=function(b){return this.queue(function(){var c=a(this),d=a.effects.setMode(c,b.options.mode||"show"),e=(b.options.times||5)*2-1,f=b.duration?b.duration/2:a.fx.speeds._default/2,g=c.is(":visible"),h=0;g||(c.css("opacity",0).show(),h=1),(d=="hide"&&g||d=="show"&&!g)&&e--;for(var i=0;i').appendTo(document.body).addClass(b.options.className).css({top:g.top,left:g.left,height:c.innerHeight(),width:c.innerWidth(),position:"absolute"}).animate(f,b.duration,b.options.easing,function(){h.remove(),b.callback&&b.callback.apply(c[0],arguments),c.dequeue()})})}})(jQuery);; \ No newline at end of file diff --git a/data/interfaces/brink/js/libs/dd_belatedpng.js b/data/interfaces/brink/js/libs/dd_belatedpng.js deleted file mode 100644 index 6062fb3c..00000000 --- a/data/interfaces/brink/js/libs/dd_belatedpng.js +++ /dev/null @@ -1,13 +0,0 @@ -/** -* DD_belatedPNG: Adds IE6 support: PNG images for CSS background-image and HTML . -* Author: Drew Diller -* Email: drew.diller@gmail.com -* URL: http://www.dillerdesign.com/experiment/DD_belatedPNG/ -* Version: 0.0.8a -* Licensed under the MIT License: http://dillerdesign.com/experiment/DD_belatedPNG/#license -* -* Example usage: -* DD_belatedPNG.fix('.png_bg'); // argument is a CSS selector -* DD_belatedPNG.fixPng( someNode ); // argument is an HTMLDomElement -**/ -var DD_belatedPNG={ns:"DD_belatedPNG",imgSize:{},delay:10,nodesFixed:0,createVmlNameSpace:function(){if(document.namespaces&&!document.namespaces[this.ns]){document.namespaces.add(this.ns,"urn:schemas-microsoft-com:vml")}},createVmlStyleSheet:function(){var b,a;b=document.createElement("style");b.setAttribute("media","screen");document.documentElement.firstChild.insertBefore(b,document.documentElement.firstChild.firstChild);if(b.styleSheet){b=b.styleSheet;b.addRule(this.ns+"\\:*","{behavior:url(#default#VML)}");b.addRule(this.ns+"\\:shape","position:absolute;");b.addRule("img."+this.ns+"_sizeFinder","behavior:none; border:none; position:absolute; z-index:-1; top:-10000px; visibility:hidden;");this.screenStyleSheet=b;a=document.createElement("style");a.setAttribute("media","print");document.documentElement.firstChild.insertBefore(a,document.documentElement.firstChild.firstChild);a=a.styleSheet;a.addRule(this.ns+"\\:*","{display: none !important;}");a.addRule("img."+this.ns+"_sizeFinder","{display: none !important;}")}},readPropertyChange:function(){var b,c,a;b=event.srcElement;if(!b.vmlInitiated){return}if(event.propertyName.search("background")!=-1||event.propertyName.search("border")!=-1){DD_belatedPNG.applyVML(b)}if(event.propertyName=="style.display"){c=(b.currentStyle.display=="none")?"none":"block";for(a in b.vml){if(b.vml.hasOwnProperty(a)){b.vml[a].shape.style.display=c}}}if(event.propertyName.search("filter")!=-1){DD_belatedPNG.vmlOpacity(b)}},vmlOpacity:function(b){if(b.currentStyle.filter.search("lpha")!=-1){var a=b.currentStyle.filter;a=parseInt(a.substring(a.lastIndexOf("=")+1,a.lastIndexOf(")")),10)/100;b.vml.color.shape.style.filter=b.currentStyle.filter;b.vml.image.fill.opacity=a}},handlePseudoHover:function(a){setTimeout(function(){DD_belatedPNG.applyVML(a)},1)},fix:function(a){if(this.screenStyleSheet){var c,b;c=a.split(",");for(b=0;bn.H){i.B=n.H}d.vml.image.shape.style.clip="rect("+i.T+"px "+(i.R+a)+"px "+i.B+"px "+(i.L+a)+"px)"}else{d.vml.image.shape.style.clip="rect("+f.T+"px "+f.R+"px "+f.B+"px "+f.L+"px)"}},figurePercentage:function(d,c,f,a){var b,e;e=true;b=(f=="X");switch(a){case"left":case"top":d[f]=0;break;case"center":d[f]=0.5;break;case"right":case"bottom":d[f]=1;break;default:if(a.search("%")!=-1){d[f]=parseInt(a,10)/100}else{e=false}}d[f]=Math.ceil(e?((c[b?"W":"H"]*d[f])-(c[b?"w":"h"]*d[f])):parseInt(a,10));if(d[f]%2===0){d[f]++}return d[f]},fixPng:function(c){c.style.behavior="none";var g,b,f,a,d;if(c.nodeName=="BODY"||c.nodeName=="TD"||c.nodeName=="TR"){return}c.isImg=false;if(c.nodeName=="IMG"){if(c.src.toLowerCase().search(/\.png$/)!=-1){c.isImg=true;c.style.visibility="hidden"}else{return}}else{if(c.currentStyle.backgroundImage.toLowerCase().search(".png")==-1){return}}g=DD_belatedPNG;c.vml={color:{},image:{}};b={shape:{},fill:{}};for(a in c.vml){if(c.vml.hasOwnProperty(a)){for(d in b){if(b.hasOwnProperty(d)){f=g.ns+":"+d;c.vml[a][d]=document.createElement(f)}}c.vml[a].shape.stroked=false;c.vml[a].shape.appendChild(c.vml[a].fill);c.parentNode.insertBefore(c.vml[a].shape,c)}}c.vml.image.shape.fillcolor="none";c.vml.image.fill.type="tile";c.vml.color.fill.on=false;g.attachHandlers(c);g.giveLayout(c);g.giveLayout(c.offsetParent);c.vmlInitiated=true;g.applyVML(c)}};try{document.execCommand("BackgroundImageCache",false,true)}catch(r){}DD_belatedPNG.createVmlNameSpace();DD_belatedPNG.createVmlStyleSheet(); \ No newline at end of file diff --git a/data/interfaces/brink/js/libs/jquery-1.7.2.js b/data/interfaces/brink/js/libs/jquery-1.7.2.js deleted file mode 100644 index 3774ff98..00000000 --- a/data/interfaces/brink/js/libs/jquery-1.7.2.js +++ /dev/null @@ -1,9404 +0,0 @@ -/*! - * jQuery JavaScript Library v1.7.2 - * http://jquery.com/ - * - * Copyright 2011, John Resig - * Dual licensed under the MIT or GPL Version 2 licenses. - * http://jquery.org/license - * - * Includes Sizzle.js - * http://sizzlejs.com/ - * Copyright 2011, The Dojo Foundation - * Released under the MIT, BSD, and GPL Licenses. - * - * Date: Wed Mar 21 12:46:34 2012 -0700 - */ -(function( window, undefined ) { - -// Use the correct document accordingly with window argument (sandbox) -var document = window.document, - navigator = window.navigator, - location = window.location; -var jQuery = (function() { - -// Define a local copy of jQuery -var jQuery = function( selector, context ) { - // The jQuery object is actually just the init constructor 'enhanced' - return new jQuery.fn.init( selector, context, rootjQuery ); - }, - - // Map over jQuery in case of overwrite - _jQuery = window.jQuery, - - // Map over the $ in case of overwrite - _$ = window.$, - - // A central reference to the root jQuery(document) - rootjQuery, - - // A simple way to check for HTML strings or ID strings - // Prioritize #id over to avoid XSS via location.hash (#9521) - quickExpr = /^(?:[^#<]*(<[\w\W]+>)[^>]*$|#([\w\-]*)$)/, - - // Check if a string has a non-whitespace character in it - rnotwhite = /\S/, - - // Used for trimming whitespace - trimLeft = /^\s+/, - trimRight = /\s+$/, - - // Match a standalone tag - rsingleTag = /^<(\w+)\s*\/?>(?:<\/\1>)?$/, - - // JSON RegExp - rvalidchars = /^[\],:{}\s]*$/, - rvalidescape = /\\(?:["\\\/bfnrt]|u[0-9a-fA-F]{4})/g, - rvalidtokens = /"[^"\\\n\r]*"|true|false|null|-?\d+(?:\.\d*)?(?:[eE][+\-]?\d+)?/g, - rvalidbraces = /(?:^|:|,)(?:\s*\[)+/g, - - // Useragent RegExp - rwebkit = /(webkit)[ \/]([\w.]+)/, - ropera = /(opera)(?:.*version)?[ \/]([\w.]+)/, - rmsie = /(msie) ([\w.]+)/, - rmozilla = /(mozilla)(?:.*? rv:([\w.]+))?/, - - // Matches dashed string for camelizing - rdashAlpha = /-([a-z]|[0-9])/ig, - rmsPrefix = /^-ms-/, - - // Used by jQuery.camelCase as callback to replace() - fcamelCase = function( all, letter ) { - return ( letter + "" ).toUpperCase(); - }, - - // Keep a UserAgent string for use with jQuery.browser - userAgent = navigator.userAgent, - - // For matching the engine and version of the browser - browserMatch, - - // The deferred used on DOM ready - readyList, - - // The ready event handler - DOMContentLoaded, - - // Save a reference to some core methods - toString = Object.prototype.toString, - hasOwn = Object.prototype.hasOwnProperty, - push = Array.prototype.push, - slice = Array.prototype.slice, - trim = String.prototype.trim, - indexOf = Array.prototype.indexOf, - - // [[Class]] -> type pairs - class2type = {}; - -jQuery.fn = jQuery.prototype = { - constructor: jQuery, - init: function( selector, context, rootjQuery ) { - var match, elem, ret, doc; - - // Handle $(""), $(null), or $(undefined) - if ( !selector ) { - return this; - } - - // Handle $(DOMElement) - if ( selector.nodeType ) { - this.context = this[0] = selector; - this.length = 1; - return this; - } - - // The body element only exists once, optimize finding it - if ( selector === "body" && !context && document.body ) { - this.context = document; - this[0] = document.body; - this.selector = selector; - this.length = 1; - return this; - } - - // Handle HTML strings - if ( typeof selector === "string" ) { - // Are we dealing with HTML string or an ID? - if ( selector.charAt(0) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) { - // Assume that strings that start and end with <> are HTML and skip the regex check - match = [ null, selector, null ]; - - } else { - match = quickExpr.exec( selector ); - } - - // Verify a match, and that no context was specified for #id - if ( match && (match[1] || !context) ) { - - // HANDLE: $(html) -> $(array) - if ( match[1] ) { - context = context instanceof jQuery ? context[0] : context; - doc = ( context ? context.ownerDocument || context : document ); - - // If a single string is passed in and it's a single tag - // just do a createElement and skip the rest - ret = rsingleTag.exec( selector ); - - if ( ret ) { - if ( jQuery.isPlainObject( context ) ) { - selector = [ document.createElement( ret[1] ) ]; - jQuery.fn.attr.call( selector, context, true ); - - } else { - selector = [ doc.createElement( ret[1] ) ]; - } - - } else { - ret = jQuery.buildFragment( [ match[1] ], [ doc ] ); - selector = ( ret.cacheable ? jQuery.clone(ret.fragment) : ret.fragment ).childNodes; - } - - return jQuery.merge( this, selector ); - - // HANDLE: $("#id") - } else { - elem = document.getElementById( match[2] ); - - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document #6963 - if ( elem && elem.parentNode ) { - // Handle the case where IE and Opera return items - // by name instead of ID - if ( elem.id !== match[2] ) { - return rootjQuery.find( selector ); - } - - // Otherwise, we inject the element directly into the jQuery object - this.length = 1; - this[0] = elem; - } - - this.context = document; - this.selector = selector; - return this; - } - - // HANDLE: $(expr, $(...)) - } else if ( !context || context.jquery ) { - return ( context || rootjQuery ).find( selector ); - - // HANDLE: $(expr, context) - // (which is just equivalent to: $(context).find(expr) - } else { - return this.constructor( context ).find( selector ); - } - - // HANDLE: $(function) - // Shortcut for document ready - } else if ( jQuery.isFunction( selector ) ) { - return rootjQuery.ready( selector ); - } - - if ( selector.selector !== undefined ) { - this.selector = selector.selector; - this.context = selector.context; - } - - return jQuery.makeArray( selector, this ); - }, - - // Start with an empty selector - selector: "", - - // The current version of jQuery being used - jquery: "1.7.2", - - // The default length of a jQuery object is 0 - length: 0, - - // The number of elements contained in the matched element set - size: function() { - return this.length; - }, - - toArray: function() { - return slice.call( this, 0 ); - }, - - // Get the Nth element in the matched element set OR - // Get the whole matched element set as a clean array - get: function( num ) { - return num == null ? - - // Return a 'clean' array - this.toArray() : - - // Return just the object - ( num < 0 ? this[ this.length + num ] : this[ num ] ); - }, - - // Take an array of elements and push it onto the stack - // (returning the new matched element set) - pushStack: function( elems, name, selector ) { - // Build a new jQuery matched element set - var ret = this.constructor(); - - if ( jQuery.isArray( elems ) ) { - push.apply( ret, elems ); - - } else { - jQuery.merge( ret, elems ); - } - - // Add the old object onto the stack (as a reference) - ret.prevObject = this; - - ret.context = this.context; - - if ( name === "find" ) { - ret.selector = this.selector + ( this.selector ? " " : "" ) + selector; - } else if ( name ) { - ret.selector = this.selector + "." + name + "(" + selector + ")"; - } - - // Return the newly-formed element set - return ret; - }, - - // Execute a callback for every element in the matched set. - // (You can seed the arguments with an array of args, but this is - // only used internally.) - each: function( callback, args ) { - return jQuery.each( this, callback, args ); - }, - - ready: function( fn ) { - // Attach the listeners - jQuery.bindReady(); - - // Add the callback - readyList.add( fn ); - - return this; - }, - - eq: function( i ) { - i = +i; - return i === -1 ? - this.slice( i ) : - this.slice( i, i + 1 ); - }, - - first: function() { - return this.eq( 0 ); - }, - - last: function() { - return this.eq( -1 ); - }, - - slice: function() { - return this.pushStack( slice.apply( this, arguments ), - "slice", slice.call(arguments).join(",") ); - }, - - map: function( callback ) { - return this.pushStack( jQuery.map(this, function( elem, i ) { - return callback.call( elem, i, elem ); - })); - }, - - end: function() { - return this.prevObject || this.constructor(null); - }, - - // For internal use only. - // Behaves like an Array's method, not like a jQuery method. - push: push, - sort: [].sort, - splice: [].splice -}; - -// Give the init function the jQuery prototype for later instantiation -jQuery.fn.init.prototype = jQuery.fn; - -jQuery.extend = jQuery.fn.extend = function() { - var options, name, src, copy, copyIsArray, clone, - target = arguments[0] || {}, - i = 1, - length = arguments.length, - deep = false; - - // Handle a deep copy situation - if ( typeof target === "boolean" ) { - deep = target; - target = arguments[1] || {}; - // skip the boolean and the target - i = 2; - } - - // Handle case when target is a string or something (possible in deep copy) - if ( typeof target !== "object" && !jQuery.isFunction(target) ) { - target = {}; - } - - // extend jQuery itself if only one argument is passed - if ( length === i ) { - target = this; - --i; - } - - for ( ; i < length; i++ ) { - // Only deal with non-null/undefined values - if ( (options = arguments[ i ]) != null ) { - // Extend the base object - for ( name in options ) { - src = target[ name ]; - copy = options[ name ]; - - // Prevent never-ending loop - if ( target === copy ) { - continue; - } - - // Recurse if we're merging plain objects or arrays - if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) { - if ( copyIsArray ) { - copyIsArray = false; - clone = src && jQuery.isArray(src) ? src : []; - - } else { - clone = src && jQuery.isPlainObject(src) ? src : {}; - } - - // Never move original objects, clone them - target[ name ] = jQuery.extend( deep, clone, copy ); - - // Don't bring in undefined values - } else if ( copy !== undefined ) { - target[ name ] = copy; - } - } - } - } - - // Return the modified object - return target; -}; - -jQuery.extend({ - noConflict: function( deep ) { - if ( window.$ === jQuery ) { - window.$ = _$; - } - - if ( deep && window.jQuery === jQuery ) { - window.jQuery = _jQuery; - } - - return jQuery; - }, - - // Is the DOM ready to be used? Set to true once it occurs. - isReady: false, - - // A counter to track how many items to wait for before - // the ready event fires. See #6781 - readyWait: 1, - - // Hold (or release) the ready event - holdReady: function( hold ) { - if ( hold ) { - jQuery.readyWait++; - } else { - jQuery.ready( true ); - } - }, - - // Handle when the DOM is ready - ready: function( wait ) { - // Either a released hold or an DOMready/load event and not yet ready - if ( (wait === true && !--jQuery.readyWait) || (wait !== true && !jQuery.isReady) ) { - // Make sure body exists, at least, in case IE gets a little overzealous (ticket #5443). - if ( !document.body ) { - return setTimeout( jQuery.ready, 1 ); - } - - // Remember that the DOM is ready - jQuery.isReady = true; - - // If a normal DOM Ready event fired, decrement, and wait if need be - if ( wait !== true && --jQuery.readyWait > 0 ) { - return; - } - - // If there are functions bound, to execute - readyList.fireWith( document, [ jQuery ] ); - - // Trigger any bound ready events - if ( jQuery.fn.trigger ) { - jQuery( document ).trigger( "ready" ).off( "ready" ); - } - } - }, - - bindReady: function() { - if ( readyList ) { - return; - } - - readyList = jQuery.Callbacks( "once memory" ); - - // Catch cases where $(document).ready() is called after the - // browser event has already occurred. - if ( document.readyState === "complete" ) { - // Handle it asynchronously to allow scripts the opportunity to delay ready - return setTimeout( jQuery.ready, 1 ); - } - - // Mozilla, Opera and webkit nightlies currently support this event - if ( document.addEventListener ) { - // Use the handy event callback - document.addEventListener( "DOMContentLoaded", DOMContentLoaded, false ); - - // A fallback to window.onload, that will always work - window.addEventListener( "load", jQuery.ready, false ); - - // If IE event model is used - } else if ( document.attachEvent ) { - // ensure firing before onload, - // maybe late but safe also for iframes - document.attachEvent( "onreadystatechange", DOMContentLoaded ); - - // A fallback to window.onload, that will always work - window.attachEvent( "onload", jQuery.ready ); - - // If IE and not a frame - // continually check to see if the document is ready - var toplevel = false; - - try { - toplevel = window.frameElement == null; - } catch(e) {} - - if ( document.documentElement.doScroll && toplevel ) { - doScrollCheck(); - } - } - }, - - // See test/unit/core.js for details concerning isFunction. - // Since version 1.3, DOM methods and functions like alert - // aren't supported. They return false on IE (#2968). - isFunction: function( obj ) { - return jQuery.type(obj) === "function"; - }, - - isArray: Array.isArray || function( obj ) { - return jQuery.type(obj) === "array"; - }, - - isWindow: function( obj ) { - return obj != null && obj == obj.window; - }, - - isNumeric: function( obj ) { - return !isNaN( parseFloat(obj) ) && isFinite( obj ); - }, - - type: function( obj ) { - return obj == null ? - String( obj ) : - class2type[ toString.call(obj) ] || "object"; - }, - - isPlainObject: function( obj ) { - // Must be an Object. - // Because of IE, we also have to check the presence of the constructor property. - // Make sure that DOM nodes and window objects don't pass through, as well - if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { - return false; - } - - try { - // Not own constructor property must be Object - if ( obj.constructor && - !hasOwn.call(obj, "constructor") && - !hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) { - return false; - } - } catch ( e ) { - // IE8,9 Will throw exceptions on certain host objects #9897 - return false; - } - - // Own properties are enumerated firstly, so to speed up, - // if last one is own, then all properties are own. - - var key; - for ( key in obj ) {} - - return key === undefined || hasOwn.call( obj, key ); - }, - - isEmptyObject: function( obj ) { - for ( var name in obj ) { - return false; - } - return true; - }, - - error: function( msg ) { - throw new Error( msg ); - }, - - parseJSON: function( data ) { - if ( typeof data !== "string" || !data ) { - return null; - } - - // Make sure leading/trailing whitespace is removed (IE can't handle it) - data = jQuery.trim( data ); - - // Attempt to parse using the native JSON parser first - if ( window.JSON && window.JSON.parse ) { - return window.JSON.parse( data ); - } - - // Make sure the incoming data is actual JSON - // Logic borrowed from http://json.org/json2.js - if ( rvalidchars.test( data.replace( rvalidescape, "@" ) - .replace( rvalidtokens, "]" ) - .replace( rvalidbraces, "")) ) { - - return ( new Function( "return " + data ) )(); - - } - jQuery.error( "Invalid JSON: " + data ); - }, - - // Cross-browser xml parsing - parseXML: function( data ) { - if ( typeof data !== "string" || !data ) { - return null; - } - var xml, tmp; - try { - if ( window.DOMParser ) { // Standard - tmp = new DOMParser(); - xml = tmp.parseFromString( data , "text/xml" ); - } else { // IE - xml = new ActiveXObject( "Microsoft.XMLDOM" ); - xml.async = "false"; - xml.loadXML( data ); - } - } catch( e ) { - xml = undefined; - } - if ( !xml || !xml.documentElement || xml.getElementsByTagName( "parsererror" ).length ) { - jQuery.error( "Invalid XML: " + data ); - } - return xml; - }, - - noop: function() {}, - - // Evaluates a script in a global context - // Workarounds based on findings by Jim Driscoll - // http://weblogs.java.net/blog/driscoll/archive/2009/09/08/eval-javascript-global-context - globalEval: function( data ) { - if ( data && rnotwhite.test( data ) ) { - // We use execScript on Internet Explorer - // We use an anonymous function so that context is window - // rather than jQuery in Firefox - ( window.execScript || function( data ) { - window[ "eval" ].call( window, data ); - } )( data ); - } - }, - - // Convert dashed to camelCase; used by the css and data modules - // Microsoft forgot to hump their vendor prefix (#9572) - camelCase: function( string ) { - return string.replace( rmsPrefix, "ms-" ).replace( rdashAlpha, fcamelCase ); - }, - - nodeName: function( elem, name ) { - return elem.nodeName && elem.nodeName.toUpperCase() === name.toUpperCase(); - }, - - // args is for internal usage only - each: function( object, callback, args ) { - var name, i = 0, - length = object.length, - isObj = length === undefined || jQuery.isFunction( object ); - - if ( args ) { - if ( isObj ) { - for ( name in object ) { - if ( callback.apply( object[ name ], args ) === false ) { - break; - } - } - } else { - for ( ; i < length; ) { - if ( callback.apply( object[ i++ ], args ) === false ) { - break; - } - } - } - - // A special, fast, case for the most common use of each - } else { - if ( isObj ) { - for ( name in object ) { - if ( callback.call( object[ name ], name, object[ name ] ) === false ) { - break; - } - } - } else { - for ( ; i < length; ) { - if ( callback.call( object[ i ], i, object[ i++ ] ) === false ) { - break; - } - } - } - } - - return object; - }, - - // Use native String.trim function wherever possible - trim: trim ? - function( text ) { - return text == null ? - "" : - trim.call( text ); - } : - - // Otherwise use our own trimming functionality - function( text ) { - return text == null ? - "" : - text.toString().replace( trimLeft, "" ).replace( trimRight, "" ); - }, - - // results is for internal usage only - makeArray: function( array, results ) { - var ret = results || []; - - if ( array != null ) { - // The window, strings (and functions) also have 'length' - // Tweaked logic slightly to handle Blackberry 4.7 RegExp issues #6930 - var type = jQuery.type( array ); - - if ( array.length == null || type === "string" || type === "function" || type === "regexp" || jQuery.isWindow( array ) ) { - push.call( ret, array ); - } else { - jQuery.merge( ret, array ); - } - } - - return ret; - }, - - inArray: function( elem, array, i ) { - var len; - - if ( array ) { - if ( indexOf ) { - return indexOf.call( array, elem, i ); - } - - len = array.length; - i = i ? i < 0 ? Math.max( 0, len + i ) : i : 0; - - for ( ; i < len; i++ ) { - // Skip accessing in sparse arrays - if ( i in array && array[ i ] === elem ) { - return i; - } - } - } - - return -1; - }, - - merge: function( first, second ) { - var i = first.length, - j = 0; - - if ( typeof second.length === "number" ) { - for ( var l = second.length; j < l; j++ ) { - first[ i++ ] = second[ j ]; - } - - } else { - while ( second[j] !== undefined ) { - first[ i++ ] = second[ j++ ]; - } - } - - first.length = i; - - return first; - }, - - grep: function( elems, callback, inv ) { - var ret = [], retVal; - inv = !!inv; - - // Go through the array, only saving the items - // that pass the validator function - for ( var i = 0, length = elems.length; i < length; i++ ) { - retVal = !!callback( elems[ i ], i ); - if ( inv !== retVal ) { - ret.push( elems[ i ] ); - } - } - - return ret; - }, - - // arg is for internal usage only - map: function( elems, callback, arg ) { - var value, key, ret = [], - i = 0, - length = elems.length, - // jquery objects are treated as arrays - isArray = elems instanceof jQuery || length !== undefined && typeof length === "number" && ( ( length > 0 && elems[ 0 ] && elems[ length -1 ] ) || length === 0 || jQuery.isArray( elems ) ) ; - - // Go through the array, translating each of the items to their - if ( isArray ) { - for ( ; i < length; i++ ) { - value = callback( elems[ i ], i, arg ); - - if ( value != null ) { - ret[ ret.length ] = value; - } - } - - // Go through every key on the object, - } else { - for ( key in elems ) { - value = callback( elems[ key ], key, arg ); - - if ( value != null ) { - ret[ ret.length ] = value; - } - } - } - - // Flatten any nested arrays - return ret.concat.apply( [], ret ); - }, - - // A global GUID counter for objects - guid: 1, - - // Bind a function to a context, optionally partially applying any - // arguments. - proxy: function( fn, context ) { - if ( typeof context === "string" ) { - var tmp = fn[ context ]; - context = fn; - fn = tmp; - } - - // Quick check to determine if target is callable, in the spec - // this throws a TypeError, but we will just return undefined. - if ( !jQuery.isFunction( fn ) ) { - return undefined; - } - - // Simulated bind - var args = slice.call( arguments, 2 ), - proxy = function() { - return fn.apply( context, args.concat( slice.call( arguments ) ) ); - }; - - // Set the guid of unique handler to the same of original handler, so it can be removed - proxy.guid = fn.guid = fn.guid || proxy.guid || jQuery.guid++; - - return proxy; - }, - - // Mutifunctional method to get and set values to a collection - // The value/s can optionally be executed if it's a function - access: function( elems, fn, key, value, chainable, emptyGet, pass ) { - var exec, - bulk = key == null, - i = 0, - length = elems.length; - - // Sets many values - if ( key && typeof key === "object" ) { - for ( i in key ) { - jQuery.access( elems, fn, i, key[i], 1, emptyGet, value ); - } - chainable = 1; - - // Sets one value - } else if ( value !== undefined ) { - // Optionally, function values get executed if exec is true - exec = pass === undefined && jQuery.isFunction( value ); - - if ( bulk ) { - // Bulk operations only iterate when executing function values - if ( exec ) { - exec = fn; - fn = function( elem, key, value ) { - return exec.call( jQuery( elem ), value ); - }; - - // Otherwise they run against the entire set - } else { - fn.call( elems, value ); - fn = null; - } - } - - if ( fn ) { - for (; i < length; i++ ) { - fn( elems[i], key, exec ? value.call( elems[i], i, fn( elems[i], key ) ) : value, pass ); - } - } - - chainable = 1; - } - - return chainable ? - elems : - - // Gets - bulk ? - fn.call( elems ) : - length ? fn( elems[0], key ) : emptyGet; - }, - - now: function() { - return ( new Date() ).getTime(); - }, - - // Use of jQuery.browser is frowned upon. - // More details: http://docs.jquery.com/Utilities/jQuery.browser - uaMatch: function( ua ) { - ua = ua.toLowerCase(); - - var match = rwebkit.exec( ua ) || - ropera.exec( ua ) || - rmsie.exec( ua ) || - ua.indexOf("compatible") < 0 && rmozilla.exec( ua ) || - []; - - return { browser: match[1] || "", version: match[2] || "0" }; - }, - - sub: function() { - function jQuerySub( selector, context ) { - return new jQuerySub.fn.init( selector, context ); - } - jQuery.extend( true, jQuerySub, this ); - jQuerySub.superclass = this; - jQuerySub.fn = jQuerySub.prototype = this(); - jQuerySub.fn.constructor = jQuerySub; - jQuerySub.sub = this.sub; - jQuerySub.fn.init = function init( selector, context ) { - if ( context && context instanceof jQuery && !(context instanceof jQuerySub) ) { - context = jQuerySub( context ); - } - - return jQuery.fn.init.call( this, selector, context, rootjQuerySub ); - }; - jQuerySub.fn.init.prototype = jQuerySub.fn; - var rootjQuerySub = jQuerySub(document); - return jQuerySub; - }, - - browser: {} -}); - -// Populate the class2type map -jQuery.each("Boolean Number String Function Array Date RegExp Object".split(" "), function(i, name) { - class2type[ "[object " + name + "]" ] = name.toLowerCase(); -}); - -browserMatch = jQuery.uaMatch( userAgent ); -if ( browserMatch.browser ) { - jQuery.browser[ browserMatch.browser ] = true; - jQuery.browser.version = browserMatch.version; -} - -// Deprecated, use jQuery.browser.webkit instead -if ( jQuery.browser.webkit ) { - jQuery.browser.safari = true; -} - -// IE doesn't match non-breaking spaces with \s -if ( rnotwhite.test( "\xA0" ) ) { - trimLeft = /^[\s\xA0]+/; - trimRight = /[\s\xA0]+$/; -} - -// All jQuery objects should point back to these -rootjQuery = jQuery(document); - -// Cleanup functions for the document ready method -if ( document.addEventListener ) { - DOMContentLoaded = function() { - document.removeEventListener( "DOMContentLoaded", DOMContentLoaded, false ); - jQuery.ready(); - }; - -} else if ( document.attachEvent ) { - DOMContentLoaded = function() { - // Make sure body exists, at least, in case IE gets a little overzealous (ticket #5443). - if ( document.readyState === "complete" ) { - document.detachEvent( "onreadystatechange", DOMContentLoaded ); - jQuery.ready(); - } - }; -} - -// The DOM ready check for Internet Explorer -function doScrollCheck() { - if ( jQuery.isReady ) { - return; - } - - try { - // If IE is used, use the trick by Diego Perini - // http://javascript.nwbox.com/IEContentLoaded/ - document.documentElement.doScroll("left"); - } catch(e) { - setTimeout( doScrollCheck, 1 ); - return; - } - - // and execute any waiting functions - jQuery.ready(); -} - -return jQuery; - -})(); - - -// String to Object flags format cache -var flagsCache = {}; - -// Convert String-formatted flags into Object-formatted ones and store in cache -function createFlags( flags ) { - var object = flagsCache[ flags ] = {}, - i, length; - flags = flags.split( /\s+/ ); - for ( i = 0, length = flags.length; i < length; i++ ) { - object[ flags[i] ] = true; - } - return object; -} - -/* - * Create a callback list using the following parameters: - * - * flags: an optional list of space-separated flags that will change how - * the callback list behaves - * - * By default a callback list will act like an event callback list and can be - * "fired" multiple times. - * - * Possible flags: - * - * once: will ensure the callback list can only be fired once (like a Deferred) - * - * memory: will keep track of previous values and will call any callback added - * after the list has been fired right away with the latest "memorized" - * values (like a Deferred) - * - * unique: will ensure a callback can only be added once (no duplicate in the list) - * - * stopOnFalse: interrupt callings when a callback returns false - * - */ -jQuery.Callbacks = function( flags ) { - - // Convert flags from String-formatted to Object-formatted - // (we check in cache first) - flags = flags ? ( flagsCache[ flags ] || createFlags( flags ) ) : {}; - - var // Actual callback list - list = [], - // Stack of fire calls for repeatable lists - stack = [], - // Last fire value (for non-forgettable lists) - memory, - // Flag to know if list was already fired - fired, - // Flag to know if list is currently firing - firing, - // First callback to fire (used internally by add and fireWith) - firingStart, - // End of the loop when firing - firingLength, - // Index of currently firing callback (modified by remove if needed) - firingIndex, - // Add one or several callbacks to the list - add = function( args ) { - var i, - length, - elem, - type, - actual; - for ( i = 0, length = args.length; i < length; i++ ) { - elem = args[ i ]; - type = jQuery.type( elem ); - if ( type === "array" ) { - // Inspect recursively - add( elem ); - } else if ( type === "function" ) { - // Add if not in unique mode and callback is not in - if ( !flags.unique || !self.has( elem ) ) { - list.push( elem ); - } - } - } - }, - // Fire callbacks - fire = function( context, args ) { - args = args || []; - memory = !flags.memory || [ context, args ]; - fired = true; - firing = true; - firingIndex = firingStart || 0; - firingStart = 0; - firingLength = list.length; - for ( ; list && firingIndex < firingLength; firingIndex++ ) { - if ( list[ firingIndex ].apply( context, args ) === false && flags.stopOnFalse ) { - memory = true; // Mark as halted - break; - } - } - firing = false; - if ( list ) { - if ( !flags.once ) { - if ( stack && stack.length ) { - memory = stack.shift(); - self.fireWith( memory[ 0 ], memory[ 1 ] ); - } - } else if ( memory === true ) { - self.disable(); - } else { - list = []; - } - } - }, - // Actual Callbacks object - self = { - // Add a callback or a collection of callbacks to the list - add: function() { - if ( list ) { - var length = list.length; - add( arguments ); - // Do we need to add the callbacks to the - // current firing batch? - if ( firing ) { - firingLength = list.length; - // With memory, if we're not firing then - // we should call right away, unless previous - // firing was halted (stopOnFalse) - } else if ( memory && memory !== true ) { - firingStart = length; - fire( memory[ 0 ], memory[ 1 ] ); - } - } - return this; - }, - // Remove a callback from the list - remove: function() { - if ( list ) { - var args = arguments, - argIndex = 0, - argLength = args.length; - for ( ; argIndex < argLength ; argIndex++ ) { - for ( var i = 0; i < list.length; i++ ) { - if ( args[ argIndex ] === list[ i ] ) { - // Handle firingIndex and firingLength - if ( firing ) { - if ( i <= firingLength ) { - firingLength--; - if ( i <= firingIndex ) { - firingIndex--; - } - } - } - // Remove the element - list.splice( i--, 1 ); - // If we have some unicity property then - // we only need to do this once - if ( flags.unique ) { - break; - } - } - } - } - } - return this; - }, - // Control if a given callback is in the list - has: function( fn ) { - if ( list ) { - var i = 0, - length = list.length; - for ( ; i < length; i++ ) { - if ( fn === list[ i ] ) { - return true; - } - } - } - return false; - }, - // Remove all callbacks from the list - empty: function() { - list = []; - return this; - }, - // Have the list do nothing anymore - disable: function() { - list = stack = memory = undefined; - return this; - }, - // Is it disabled? - disabled: function() { - return !list; - }, - // Lock the list in its current state - lock: function() { - stack = undefined; - if ( !memory || memory === true ) { - self.disable(); - } - return this; - }, - // Is it locked? - locked: function() { - return !stack; - }, - // Call all callbacks with the given context and arguments - fireWith: function( context, args ) { - if ( stack ) { - if ( firing ) { - if ( !flags.once ) { - stack.push( [ context, args ] ); - } - } else if ( !( flags.once && memory ) ) { - fire( context, args ); - } - } - return this; - }, - // Call all the callbacks with the given arguments - fire: function() { - self.fireWith( this, arguments ); - return this; - }, - // To know if the callbacks have already been called at least once - fired: function() { - return !!fired; - } - }; - - return self; -}; - - - - -var // Static reference to slice - sliceDeferred = [].slice; - -jQuery.extend({ - - Deferred: function( func ) { - var doneList = jQuery.Callbacks( "once memory" ), - failList = jQuery.Callbacks( "once memory" ), - progressList = jQuery.Callbacks( "memory" ), - state = "pending", - lists = { - resolve: doneList, - reject: failList, - notify: progressList - }, - promise = { - done: doneList.add, - fail: failList.add, - progress: progressList.add, - - state: function() { - return state; - }, - - // Deprecated - isResolved: doneList.fired, - isRejected: failList.fired, - - then: function( doneCallbacks, failCallbacks, progressCallbacks ) { - deferred.done( doneCallbacks ).fail( failCallbacks ).progress( progressCallbacks ); - return this; - }, - always: function() { - deferred.done.apply( deferred, arguments ).fail.apply( deferred, arguments ); - return this; - }, - pipe: function( fnDone, fnFail, fnProgress ) { - return jQuery.Deferred(function( newDefer ) { - jQuery.each( { - done: [ fnDone, "resolve" ], - fail: [ fnFail, "reject" ], - progress: [ fnProgress, "notify" ] - }, function( handler, data ) { - var fn = data[ 0 ], - action = data[ 1 ], - returned; - if ( jQuery.isFunction( fn ) ) { - deferred[ handler ](function() { - returned = fn.apply( this, arguments ); - if ( returned && jQuery.isFunction( returned.promise ) ) { - returned.promise().then( newDefer.resolve, newDefer.reject, newDefer.notify ); - } else { - newDefer[ action + "With" ]( this === deferred ? newDefer : this, [ returned ] ); - } - }); - } else { - deferred[ handler ]( newDefer[ action ] ); - } - }); - }).promise(); - }, - // Get a promise for this deferred - // If obj is provided, the promise aspect is added to the object - promise: function( obj ) { - if ( obj == null ) { - obj = promise; - } else { - for ( var key in promise ) { - obj[ key ] = promise[ key ]; - } - } - return obj; - } - }, - deferred = promise.promise({}), - key; - - for ( key in lists ) { - deferred[ key ] = lists[ key ].fire; - deferred[ key + "With" ] = lists[ key ].fireWith; - } - - // Handle state - deferred.done( function() { - state = "resolved"; - }, failList.disable, progressList.lock ).fail( function() { - state = "rejected"; - }, doneList.disable, progressList.lock ); - - // Call given func if any - if ( func ) { - func.call( deferred, deferred ); - } - - // All done! - return deferred; - }, - - // Deferred helper - when: function( firstParam ) { - var args = sliceDeferred.call( arguments, 0 ), - i = 0, - length = args.length, - pValues = new Array( length ), - count = length, - pCount = length, - deferred = length <= 1 && firstParam && jQuery.isFunction( firstParam.promise ) ? - firstParam : - jQuery.Deferred(), - promise = deferred.promise(); - function resolveFunc( i ) { - return function( value ) { - args[ i ] = arguments.length > 1 ? sliceDeferred.call( arguments, 0 ) : value; - if ( !( --count ) ) { - deferred.resolveWith( deferred, args ); - } - }; - } - function progressFunc( i ) { - return function( value ) { - pValues[ i ] = arguments.length > 1 ? sliceDeferred.call( arguments, 0 ) : value; - deferred.notifyWith( promise, pValues ); - }; - } - if ( length > 1 ) { - for ( ; i < length; i++ ) { - if ( args[ i ] && args[ i ].promise && jQuery.isFunction( args[ i ].promise ) ) { - args[ i ].promise().then( resolveFunc(i), deferred.reject, progressFunc(i) ); - } else { - --count; - } - } - if ( !count ) { - deferred.resolveWith( deferred, args ); - } - } else if ( deferred !== firstParam ) { - deferred.resolveWith( deferred, length ? [ firstParam ] : [] ); - } - return promise; - } -}); - - - - -jQuery.support = (function() { - - var support, - all, - a, - select, - opt, - input, - fragment, - tds, - events, - eventName, - i, - isSupported, - div = document.createElement( "div" ), - documentElement = document.documentElement; - - // Preliminary tests - div.setAttribute("className", "t"); - div.innerHTML = "
    a"; - - all = div.getElementsByTagName( "*" ); - a = div.getElementsByTagName( "a" )[ 0 ]; - - // Can't get basic test support - if ( !all || !all.length || !a ) { - return {}; - } - - // First batch of supports tests - select = document.createElement( "select" ); - opt = select.appendChild( document.createElement("option") ); - input = div.getElementsByTagName( "input" )[ 0 ]; - - support = { - // IE strips leading whitespace when .innerHTML is used - leadingWhitespace: ( div.firstChild.nodeType === 3 ), - - // Make sure that tbody elements aren't automatically inserted - // IE will insert them into empty tables - tbody: !div.getElementsByTagName("tbody").length, - - // Make sure that link elements get serialized correctly by innerHTML - // This requires a wrapper element in IE - htmlSerialize: !!div.getElementsByTagName("link").length, - - // Get the style information from getAttribute - // (IE uses .cssText instead) - style: /top/.test( a.getAttribute("style") ), - - // Make sure that URLs aren't manipulated - // (IE normalizes it by default) - hrefNormalized: ( a.getAttribute("href") === "/a" ), - - // Make sure that element opacity exists - // (IE uses filter instead) - // Use a regex to work around a WebKit issue. See #5145 - opacity: /^0.55/.test( a.style.opacity ), - - // Verify style float existence - // (IE uses styleFloat instead of cssFloat) - cssFloat: !!a.style.cssFloat, - - // Make sure that if no value is specified for a checkbox - // that it defaults to "on". - // (WebKit defaults to "" instead) - checkOn: ( input.value === "on" ), - - // Make sure that a selected-by-default option has a working selected property. - // (WebKit defaults to false instead of true, IE too, if it's in an optgroup) - optSelected: opt.selected, - - // Test setAttribute on camelCase class. If it works, we need attrFixes when doing get/setAttribute (ie6/7) - getSetAttribute: div.className !== "t", - - // Tests for enctype support on a form(#6743) - enctype: !!document.createElement("form").enctype, - - // Makes sure cloning an html5 element does not cause problems - // Where outerHTML is undefined, this still works - html5Clone: document.createElement("nav").cloneNode( true ).outerHTML !== "<:nav>", - - // Will be defined later - submitBubbles: true, - changeBubbles: true, - focusinBubbles: false, - deleteExpando: true, - noCloneEvent: true, - inlineBlockNeedsLayout: false, - shrinkWrapBlocks: false, - reliableMarginRight: true, - pixelMargin: true - }; - - // jQuery.boxModel DEPRECATED in 1.3, use jQuery.support.boxModel instead - jQuery.boxModel = support.boxModel = (document.compatMode === "CSS1Compat"); - - // Make sure checked status is properly cloned - input.checked = true; - support.noCloneChecked = input.cloneNode( true ).checked; - - // Make sure that the options inside disabled selects aren't marked as disabled - // (WebKit marks them as disabled) - select.disabled = true; - support.optDisabled = !opt.disabled; - - // Test to see if it's possible to delete an expando from an element - // Fails in Internet Explorer - try { - delete div.test; - } catch( e ) { - support.deleteExpando = false; - } - - if ( !div.addEventListener && div.attachEvent && div.fireEvent ) { - div.attachEvent( "onclick", function() { - // Cloning a node shouldn't copy over any - // bound event handlers (IE does this) - support.noCloneEvent = false; - }); - div.cloneNode( true ).fireEvent( "onclick" ); - } - - // Check if a radio maintains its value - // after being appended to the DOM - input = document.createElement("input"); - input.value = "t"; - input.setAttribute("type", "radio"); - support.radioValue = input.value === "t"; - - input.setAttribute("checked", "checked"); - - // #11217 - WebKit loses check when the name is after the checked attribute - input.setAttribute( "name", "t" ); - - div.appendChild( input ); - fragment = document.createDocumentFragment(); - fragment.appendChild( div.lastChild ); - - // WebKit doesn't clone checked state correctly in fragments - support.checkClone = fragment.cloneNode( true ).cloneNode( true ).lastChild.checked; - - // Check if a disconnected checkbox will retain its checked - // value of true after appended to the DOM (IE6/7) - support.appendChecked = input.checked; - - fragment.removeChild( input ); - fragment.appendChild( div ); - - // Technique from Juriy Zaytsev - // http://perfectionkills.com/detecting-event-support-without-browser-sniffing/ - // We only care about the case where non-standard event systems - // are used, namely in IE. Short-circuiting here helps us to - // avoid an eval call (in setAttribute) which can cause CSP - // to go haywire. See: https://developer.mozilla.org/en/Security/CSP - if ( div.attachEvent ) { - for ( i in { - submit: 1, - change: 1, - focusin: 1 - }) { - eventName = "on" + i; - isSupported = ( eventName in div ); - if ( !isSupported ) { - div.setAttribute( eventName, "return;" ); - isSupported = ( typeof div[ eventName ] === "function" ); - } - support[ i + "Bubbles" ] = isSupported; - } - } - - fragment.removeChild( div ); - - // Null elements to avoid leaks in IE - fragment = select = opt = div = input = null; - - // Run tests that need a body at doc ready - jQuery(function() { - var container, outer, inner, table, td, offsetSupport, - marginDiv, conMarginTop, style, html, positionTopLeftWidthHeight, - paddingMarginBorderVisibility, paddingMarginBorder, - body = document.getElementsByTagName("body")[0]; - - if ( !body ) { - // Return for frameset docs that don't have a body - return; - } - - conMarginTop = 1; - paddingMarginBorder = "padding:0;margin:0;border:"; - positionTopLeftWidthHeight = "position:absolute;top:0;left:0;width:1px;height:1px;"; - paddingMarginBorderVisibility = paddingMarginBorder + "0;visibility:hidden;"; - style = "style='" + positionTopLeftWidthHeight + paddingMarginBorder + "5px solid #000;"; - html = "
    " + - "" + - "
    "; - - container = document.createElement("div"); - container.style.cssText = paddingMarginBorderVisibility + "width:0;height:0;position:static;top:0;margin-top:" + conMarginTop + "px"; - body.insertBefore( container, body.firstChild ); - - // Construct the test element - div = document.createElement("div"); - container.appendChild( div ); - - // Check if table cells still have offsetWidth/Height when they are set - // to display:none and there are still other visible table cells in a - // table row; if so, offsetWidth/Height are not reliable for use when - // determining if an element has been hidden directly using - // display:none (it is still safe to use offsets if a parent element is - // hidden; don safety goggles and see bug #4512 for more information). - // (only IE 8 fails this test) - div.innerHTML = "
    t
    "; - tds = div.getElementsByTagName( "td" ); - isSupported = ( tds[ 0 ].offsetHeight === 0 ); - - tds[ 0 ].style.display = ""; - tds[ 1 ].style.display = "none"; - - // Check if empty table cells still have offsetWidth/Height - // (IE <= 8 fail this test) - support.reliableHiddenOffsets = isSupported && ( tds[ 0 ].offsetHeight === 0 ); - - // Check if div with explicit width and no margin-right incorrectly - // gets computed margin-right based on width of container. For more - // info see bug #3333 - // Fails in WebKit before Feb 2011 nightlies - // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right - if ( window.getComputedStyle ) { - div.innerHTML = ""; - marginDiv = document.createElement( "div" ); - marginDiv.style.width = "0"; - marginDiv.style.marginRight = "0"; - div.style.width = "2px"; - div.appendChild( marginDiv ); - support.reliableMarginRight = - ( parseInt( ( window.getComputedStyle( marginDiv, null ) || { marginRight: 0 } ).marginRight, 10 ) || 0 ) === 0; - } - - if ( typeof div.style.zoom !== "undefined" ) { - // Check if natively block-level elements act like inline-block - // elements when setting their display to 'inline' and giving - // them layout - // (IE < 8 does this) - div.innerHTML = ""; - div.style.width = div.style.padding = "1px"; - div.style.border = 0; - div.style.overflow = "hidden"; - div.style.display = "inline"; - div.style.zoom = 1; - support.inlineBlockNeedsLayout = ( div.offsetWidth === 3 ); - - // Check if elements with layout shrink-wrap their children - // (IE 6 does this) - div.style.display = "block"; - div.style.overflow = "visible"; - div.innerHTML = "
    "; - support.shrinkWrapBlocks = ( div.offsetWidth !== 3 ); - } - - div.style.cssText = positionTopLeftWidthHeight + paddingMarginBorderVisibility; - div.innerHTML = html; - - outer = div.firstChild; - inner = outer.firstChild; - td = outer.nextSibling.firstChild.firstChild; - - offsetSupport = { - doesNotAddBorder: ( inner.offsetTop !== 5 ), - doesAddBorderForTableAndCells: ( td.offsetTop === 5 ) - }; - - inner.style.position = "fixed"; - inner.style.top = "20px"; - - // safari subtracts parent border width here which is 5px - offsetSupport.fixedPosition = ( inner.offsetTop === 20 || inner.offsetTop === 15 ); - inner.style.position = inner.style.top = ""; - - outer.style.overflow = "hidden"; - outer.style.position = "relative"; - - offsetSupport.subtractsBorderForOverflowNotVisible = ( inner.offsetTop === -5 ); - offsetSupport.doesNotIncludeMarginInBodyOffset = ( body.offsetTop !== conMarginTop ); - - if ( window.getComputedStyle ) { - div.style.marginTop = "1%"; - support.pixelMargin = ( window.getComputedStyle( div, null ) || { marginTop: 0 } ).marginTop !== "1%"; - } - - if ( typeof container.style.zoom !== "undefined" ) { - container.style.zoom = 1; - } - - body.removeChild( container ); - marginDiv = div = container = null; - - jQuery.extend( support, offsetSupport ); - }); - - return support; -})(); - - - - -var rbrace = /^(?:\{.*\}|\[.*\])$/, - rmultiDash = /([A-Z])/g; - -jQuery.extend({ - cache: {}, - - // Please use with caution - uuid: 0, - - // Unique for each copy of jQuery on the page - // Non-digits removed to match rinlinejQuery - expando: "jQuery" + ( jQuery.fn.jquery + Math.random() ).replace( /\D/g, "" ), - - // The following elements throw uncatchable exceptions if you - // attempt to add expando properties to them. - noData: { - "embed": true, - // Ban all objects except for Flash (which handle expandos) - "object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", - "applet": true - }, - - hasData: function( elem ) { - elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; - return !!elem && !isEmptyDataObject( elem ); - }, - - data: function( elem, name, data, pvt /* Internal Use Only */ ) { - if ( !jQuery.acceptData( elem ) ) { - return; - } - - var privateCache, thisCache, ret, - internalKey = jQuery.expando, - getByName = typeof name === "string", - - // We have to handle DOM nodes and JS objects differently because IE6-7 - // can't GC object references properly across the DOM-JS boundary - isNode = elem.nodeType, - - // Only DOM nodes need the global jQuery cache; JS object data is - // attached directly to the object so GC can occur automatically - cache = isNode ? jQuery.cache : elem, - - // Only defining an ID for JS objects if its cache already exists allows - // the code to shortcut on the same path as a DOM node with no cache - id = isNode ? elem[ internalKey ] : elem[ internalKey ] && internalKey, - isEvents = name === "events"; - - // Avoid doing any more work than we need to when trying to get data on an - // object that has no data at all - if ( (!id || !cache[id] || (!isEvents && !pvt && !cache[id].data)) && getByName && data === undefined ) { - return; - } - - if ( !id ) { - // Only DOM nodes need a new unique ID for each element since their data - // ends up in the global cache - if ( isNode ) { - elem[ internalKey ] = id = ++jQuery.uuid; - } else { - id = internalKey; - } - } - - if ( !cache[ id ] ) { - cache[ id ] = {}; - - // Avoids exposing jQuery metadata on plain JS objects when the object - // is serialized using JSON.stringify - if ( !isNode ) { - cache[ id ].toJSON = jQuery.noop; - } - } - - // An object can be passed to jQuery.data instead of a key/value pair; this gets - // shallow copied over onto the existing cache - if ( typeof name === "object" || typeof name === "function" ) { - if ( pvt ) { - cache[ id ] = jQuery.extend( cache[ id ], name ); - } else { - cache[ id ].data = jQuery.extend( cache[ id ].data, name ); - } - } - - privateCache = thisCache = cache[ id ]; - - // jQuery data() is stored in a separate object inside the object's internal data - // cache in order to avoid key collisions between internal data and user-defined - // data. - if ( !pvt ) { - if ( !thisCache.data ) { - thisCache.data = {}; - } - - thisCache = thisCache.data; - } - - if ( data !== undefined ) { - thisCache[ jQuery.camelCase( name ) ] = data; - } - - // Users should not attempt to inspect the internal events object using jQuery.data, - // it is undocumented and subject to change. But does anyone listen? No. - if ( isEvents && !thisCache[ name ] ) { - return privateCache.events; - } - - // Check for both converted-to-camel and non-converted data property names - // If a data property was specified - if ( getByName ) { - - // First Try to find as-is property data - ret = thisCache[ name ]; - - // Test for null|undefined property data - if ( ret == null ) { - - // Try to find the camelCased property - ret = thisCache[ jQuery.camelCase( name ) ]; - } - } else { - ret = thisCache; - } - - return ret; - }, - - removeData: function( elem, name, pvt /* Internal Use Only */ ) { - if ( !jQuery.acceptData( elem ) ) { - return; - } - - var thisCache, i, l, - - // Reference to internal data cache key - internalKey = jQuery.expando, - - isNode = elem.nodeType, - - // See jQuery.data for more information - cache = isNode ? jQuery.cache : elem, - - // See jQuery.data for more information - id = isNode ? elem[ internalKey ] : internalKey; - - // If there is already no cache entry for this object, there is no - // purpose in continuing - if ( !cache[ id ] ) { - return; - } - - if ( name ) { - - thisCache = pvt ? cache[ id ] : cache[ id ].data; - - if ( thisCache ) { - - // Support array or space separated string names for data keys - if ( !jQuery.isArray( name ) ) { - - // try the string as a key before any manipulation - if ( name in thisCache ) { - name = [ name ]; - } else { - - // split the camel cased version by spaces unless a key with the spaces exists - name = jQuery.camelCase( name ); - if ( name in thisCache ) { - name = [ name ]; - } else { - name = name.split( " " ); - } - } - } - - for ( i = 0, l = name.length; i < l; i++ ) { - delete thisCache[ name[i] ]; - } - - // If there is no data left in the cache, we want to continue - // and let the cache object itself get destroyed - if ( !( pvt ? isEmptyDataObject : jQuery.isEmptyObject )( thisCache ) ) { - return; - } - } - } - - // See jQuery.data for more information - if ( !pvt ) { - delete cache[ id ].data; - - // Don't destroy the parent cache unless the internal data object - // had been the only thing left in it - if ( !isEmptyDataObject(cache[ id ]) ) { - return; - } - } - - // Browsers that fail expando deletion also refuse to delete expandos on - // the window, but it will allow it on all other JS objects; other browsers - // don't care - // Ensure that `cache` is not a window object #10080 - if ( jQuery.support.deleteExpando || !cache.setInterval ) { - delete cache[ id ]; - } else { - cache[ id ] = null; - } - - // We destroyed the cache and need to eliminate the expando on the node to avoid - // false lookups in the cache for entries that no longer exist - if ( isNode ) { - // IE does not allow us to delete expando properties from nodes, - // nor does it have a removeAttribute function on Document nodes; - // we must handle all of these cases - if ( jQuery.support.deleteExpando ) { - delete elem[ internalKey ]; - } else if ( elem.removeAttribute ) { - elem.removeAttribute( internalKey ); - } else { - elem[ internalKey ] = null; - } - } - }, - - // For internal use only. - _data: function( elem, name, data ) { - return jQuery.data( elem, name, data, true ); - }, - - // A method for determining if a DOM node can handle the data expando - acceptData: function( elem ) { - if ( elem.nodeName ) { - var match = jQuery.noData[ elem.nodeName.toLowerCase() ]; - - if ( match ) { - return !(match === true || elem.getAttribute("classid") !== match); - } - } - - return true; - } -}); - -jQuery.fn.extend({ - data: function( key, value ) { - var parts, part, attr, name, l, - elem = this[0], - i = 0, - data = null; - - // Gets all values - if ( key === undefined ) { - if ( this.length ) { - data = jQuery.data( elem ); - - if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { - attr = elem.attributes; - for ( l = attr.length; i < l; i++ ) { - name = attr[i].name; - - if ( name.indexOf( "data-" ) === 0 ) { - name = jQuery.camelCase( name.substring(5) ); - - dataAttr( elem, name, data[ name ] ); - } - } - jQuery._data( elem, "parsedAttrs", true ); - } - } - - return data; - } - - // Sets multiple values - if ( typeof key === "object" ) { - return this.each(function() { - jQuery.data( this, key ); - }); - } - - parts = key.split( ".", 2 ); - parts[1] = parts[1] ? "." + parts[1] : ""; - part = parts[1] + "!"; - - return jQuery.access( this, function( value ) { - - if ( value === undefined ) { - data = this.triggerHandler( "getData" + part, [ parts[0] ] ); - - // Try to fetch any internally stored data first - if ( data === undefined && elem ) { - data = jQuery.data( elem, key ); - data = dataAttr( elem, key, data ); - } - - return data === undefined && parts[1] ? - this.data( parts[0] ) : - data; - } - - parts[1] = value; - this.each(function() { - var self = jQuery( this ); - - self.triggerHandler( "setData" + part, parts ); - jQuery.data( this, key, value ); - self.triggerHandler( "changeData" + part, parts ); - }); - }, null, value, arguments.length > 1, null, false ); - }, - - removeData: function( key ) { - return this.each(function() { - jQuery.removeData( this, key ); - }); - } -}); - -function dataAttr( elem, key, data ) { - // If nothing was found internally, try to fetch any - // data from the HTML5 data-* attribute - if ( data === undefined && elem.nodeType === 1 ) { - - var name = "data-" + key.replace( rmultiDash, "-$1" ).toLowerCase(); - - data = elem.getAttribute( name ); - - if ( typeof data === "string" ) { - try { - data = data === "true" ? true : - data === "false" ? false : - data === "null" ? null : - jQuery.isNumeric( data ) ? +data : - rbrace.test( data ) ? jQuery.parseJSON( data ) : - data; - } catch( e ) {} - - // Make sure we set the data so it isn't changed later - jQuery.data( elem, key, data ); - - } else { - data = undefined; - } - } - - return data; -} - -// checks a cache object for emptiness -function isEmptyDataObject( obj ) { - for ( var name in obj ) { - - // if the public data object is empty, the private is still empty - if ( name === "data" && jQuery.isEmptyObject( obj[name] ) ) { - continue; - } - if ( name !== "toJSON" ) { - return false; - } - } - - return true; -} - - - - -function handleQueueMarkDefer( elem, type, src ) { - var deferDataKey = type + "defer", - queueDataKey = type + "queue", - markDataKey = type + "mark", - defer = jQuery._data( elem, deferDataKey ); - if ( defer && - ( src === "queue" || !jQuery._data(elem, queueDataKey) ) && - ( src === "mark" || !jQuery._data(elem, markDataKey) ) ) { - // Give room for hard-coded callbacks to fire first - // and eventually mark/queue something else on the element - setTimeout( function() { - if ( !jQuery._data( elem, queueDataKey ) && - !jQuery._data( elem, markDataKey ) ) { - jQuery.removeData( elem, deferDataKey, true ); - defer.fire(); - } - }, 0 ); - } -} - -jQuery.extend({ - - _mark: function( elem, type ) { - if ( elem ) { - type = ( type || "fx" ) + "mark"; - jQuery._data( elem, type, (jQuery._data( elem, type ) || 0) + 1 ); - } - }, - - _unmark: function( force, elem, type ) { - if ( force !== true ) { - type = elem; - elem = force; - force = false; - } - if ( elem ) { - type = type || "fx"; - var key = type + "mark", - count = force ? 0 : ( (jQuery._data( elem, key ) || 1) - 1 ); - if ( count ) { - jQuery._data( elem, key, count ); - } else { - jQuery.removeData( elem, key, true ); - handleQueueMarkDefer( elem, type, "mark" ); - } - } - }, - - queue: function( elem, type, data ) { - var q; - if ( elem ) { - type = ( type || "fx" ) + "queue"; - q = jQuery._data( elem, type ); - - // Speed up dequeue by getting out quickly if this is just a lookup - if ( data ) { - if ( !q || jQuery.isArray(data) ) { - q = jQuery._data( elem, type, jQuery.makeArray(data) ); - } else { - q.push( data ); - } - } - return q || []; - } - }, - - dequeue: function( elem, type ) { - type = type || "fx"; - - var queue = jQuery.queue( elem, type ), - fn = queue.shift(), - hooks = {}; - - // If the fx queue is dequeued, always remove the progress sentinel - if ( fn === "inprogress" ) { - fn = queue.shift(); - } - - if ( fn ) { - // Add a progress sentinel to prevent the fx queue from being - // automatically dequeued - if ( type === "fx" ) { - queue.unshift( "inprogress" ); - } - - jQuery._data( elem, type + ".run", hooks ); - fn.call( elem, function() { - jQuery.dequeue( elem, type ); - }, hooks ); - } - - if ( !queue.length ) { - jQuery.removeData( elem, type + "queue " + type + ".run", true ); - handleQueueMarkDefer( elem, type, "queue" ); - } - } -}); - -jQuery.fn.extend({ - queue: function( type, data ) { - var setter = 2; - - if ( typeof type !== "string" ) { - data = type; - type = "fx"; - setter--; - } - - if ( arguments.length < setter ) { - return jQuery.queue( this[0], type ); - } - - return data === undefined ? - this : - this.each(function() { - var queue = jQuery.queue( this, type, data ); - - if ( type === "fx" && queue[0] !== "inprogress" ) { - jQuery.dequeue( this, type ); - } - }); - }, - dequeue: function( type ) { - return this.each(function() { - jQuery.dequeue( this, type ); - }); - }, - // Based off of the plugin by Clint Helfers, with permission. - // http://blindsignals.com/index.php/2009/07/jquery-delay/ - delay: function( time, type ) { - time = jQuery.fx ? jQuery.fx.speeds[ time ] || time : time; - type = type || "fx"; - - return this.queue( type, function( next, hooks ) { - var timeout = setTimeout( next, time ); - hooks.stop = function() { - clearTimeout( timeout ); - }; - }); - }, - clearQueue: function( type ) { - return this.queue( type || "fx", [] ); - }, - // Get a promise resolved when queues of a certain type - // are emptied (fx is the type by default) - promise: function( type, object ) { - if ( typeof type !== "string" ) { - object = type; - type = undefined; - } - type = type || "fx"; - var defer = jQuery.Deferred(), - elements = this, - i = elements.length, - count = 1, - deferDataKey = type + "defer", - queueDataKey = type + "queue", - markDataKey = type + "mark", - tmp; - function resolve() { - if ( !( --count ) ) { - defer.resolveWith( elements, [ elements ] ); - } - } - while( i-- ) { - if (( tmp = jQuery.data( elements[ i ], deferDataKey, undefined, true ) || - ( jQuery.data( elements[ i ], queueDataKey, undefined, true ) || - jQuery.data( elements[ i ], markDataKey, undefined, true ) ) && - jQuery.data( elements[ i ], deferDataKey, jQuery.Callbacks( "once memory" ), true ) )) { - count++; - tmp.add( resolve ); - } - } - resolve(); - return defer.promise( object ); - } -}); - - - - -var rclass = /[\n\t\r]/g, - rspace = /\s+/, - rreturn = /\r/g, - rtype = /^(?:button|input)$/i, - rfocusable = /^(?:button|input|object|select|textarea)$/i, - rclickable = /^a(?:rea)?$/i, - rboolean = /^(?:autofocus|autoplay|async|checked|controls|defer|disabled|hidden|loop|multiple|open|readonly|required|scoped|selected)$/i, - getSetAttribute = jQuery.support.getSetAttribute, - nodeHook, boolHook, fixSpecified; - -jQuery.fn.extend({ - attr: function( name, value ) { - return jQuery.access( this, jQuery.attr, name, value, arguments.length > 1 ); - }, - - removeAttr: function( name ) { - return this.each(function() { - jQuery.removeAttr( this, name ); - }); - }, - - prop: function( name, value ) { - return jQuery.access( this, jQuery.prop, name, value, arguments.length > 1 ); - }, - - removeProp: function( name ) { - name = jQuery.propFix[ name ] || name; - return this.each(function() { - // try/catch handles cases where IE balks (such as removing a property on window) - try { - this[ name ] = undefined; - delete this[ name ]; - } catch( e ) {} - }); - }, - - addClass: function( value ) { - var classNames, i, l, elem, - setClass, c, cl; - - if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { - jQuery( this ).addClass( value.call(this, j, this.className) ); - }); - } - - if ( value && typeof value === "string" ) { - classNames = value.split( rspace ); - - for ( i = 0, l = this.length; i < l; i++ ) { - elem = this[ i ]; - - if ( elem.nodeType === 1 ) { - if ( !elem.className && classNames.length === 1 ) { - elem.className = value; - - } else { - setClass = " " + elem.className + " "; - - for ( c = 0, cl = classNames.length; c < cl; c++ ) { - if ( !~setClass.indexOf( " " + classNames[ c ] + " " ) ) { - setClass += classNames[ c ] + " "; - } - } - elem.className = jQuery.trim( setClass ); - } - } - } - } - - return this; - }, - - removeClass: function( value ) { - var classNames, i, l, elem, className, c, cl; - - if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { - jQuery( this ).removeClass( value.call(this, j, this.className) ); - }); - } - - if ( (value && typeof value === "string") || value === undefined ) { - classNames = ( value || "" ).split( rspace ); - - for ( i = 0, l = this.length; i < l; i++ ) { - elem = this[ i ]; - - if ( elem.nodeType === 1 && elem.className ) { - if ( value ) { - className = (" " + elem.className + " ").replace( rclass, " " ); - for ( c = 0, cl = classNames.length; c < cl; c++ ) { - className = className.replace(" " + classNames[ c ] + " ", " "); - } - elem.className = jQuery.trim( className ); - - } else { - elem.className = ""; - } - } - } - } - - return this; - }, - - toggleClass: function( value, stateVal ) { - var type = typeof value, - isBool = typeof stateVal === "boolean"; - - if ( jQuery.isFunction( value ) ) { - return this.each(function( i ) { - jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); - }); - } - - return this.each(function() { - if ( type === "string" ) { - // toggle individual class names - var className, - i = 0, - self = jQuery( this ), - state = stateVal, - classNames = value.split( rspace ); - - while ( (className = classNames[ i++ ]) ) { - // check each className given, space seperated list - state = isBool ? state : !self.hasClass( className ); - self[ state ? "addClass" : "removeClass" ]( className ); - } - - } else if ( type === "undefined" || type === "boolean" ) { - if ( this.className ) { - // store className if set - jQuery._data( this, "__className__", this.className ); - } - - // toggle whole className - this.className = this.className || value === false ? "" : jQuery._data( this, "__className__" ) || ""; - } - }); - }, - - hasClass: function( selector ) { - var className = " " + selector + " ", - i = 0, - l = this.length; - for ( ; i < l; i++ ) { - if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) > -1 ) { - return true; - } - } - - return false; - }, - - val: function( value ) { - var hooks, ret, isFunction, - elem = this[0]; - - if ( !arguments.length ) { - if ( elem ) { - hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; - - if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { - return ret; - } - - ret = elem.value; - - return typeof ret === "string" ? - // handle most common string cases - ret.replace(rreturn, "") : - // handle cases where value is null/undef or number - ret == null ? "" : ret; - } - - return; - } - - isFunction = jQuery.isFunction( value ); - - return this.each(function( i ) { - var self = jQuery(this), val; - - if ( this.nodeType !== 1 ) { - return; - } - - if ( isFunction ) { - val = value.call( this, i, self.val() ); - } else { - val = value; - } - - // Treat null/undefined as ""; convert numbers to string - if ( val == null ) { - val = ""; - } else if ( typeof val === "number" ) { - val += ""; - } else if ( jQuery.isArray( val ) ) { - val = jQuery.map(val, function ( value ) { - return value == null ? "" : value + ""; - }); - } - - hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; - - // If set returns undefined, fall back to normal setting - if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { - this.value = val; - } - }); - } -}); - -jQuery.extend({ - valHooks: { - option: { - get: function( elem ) { - // attributes.value is undefined in Blackberry 4.7 but - // uses .value. See #6932 - var val = elem.attributes.value; - return !val || val.specified ? elem.value : elem.text; - } - }, - select: { - get: function( elem ) { - var value, i, max, option, - index = elem.selectedIndex, - values = [], - options = elem.options, - one = elem.type === "select-one"; - - // Nothing was selected - if ( index < 0 ) { - return null; - } - - // Loop through all the selected options - i = one ? index : 0; - max = one ? index + 1 : options.length; - for ( ; i < max; i++ ) { - option = options[ i ]; - - // Don't return options that are disabled or in a disabled optgroup - if ( option.selected && (jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null) && - (!option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" )) ) { - - // Get the specific value for the option - value = jQuery( option ).val(); - - // We don't need an array for one selects - if ( one ) { - return value; - } - - // Multi-Selects return an array - values.push( value ); - } - } - - // Fixes Bug #2551 -- select.val() broken in IE after form.reset() - if ( one && !values.length && options.length ) { - return jQuery( options[ index ] ).val(); - } - - return values; - }, - - set: function( elem, value ) { - var values = jQuery.makeArray( value ); - - jQuery(elem).find("option").each(function() { - this.selected = jQuery.inArray( jQuery(this).val(), values ) >= 0; - }); - - if ( !values.length ) { - elem.selectedIndex = -1; - } - return values; - } - } - }, - - attrFn: { - val: true, - css: true, - html: true, - text: true, - data: true, - width: true, - height: true, - offset: true - }, - - attr: function( elem, name, value, pass ) { - var ret, hooks, notxml, - nType = elem.nodeType; - - // don't get/set attributes on text, comment and attribute nodes - if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { - return; - } - - if ( pass && name in jQuery.attrFn ) { - return jQuery( elem )[ name ]( value ); - } - - // Fallback to prop when attributes are not supported - if ( typeof elem.getAttribute === "undefined" ) { - return jQuery.prop( elem, name, value ); - } - - notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); - - // All attributes are lowercase - // Grab necessary hook if one is defined - if ( notxml ) { - name = name.toLowerCase(); - hooks = jQuery.attrHooks[ name ] || ( rboolean.test( name ) ? boolHook : nodeHook ); - } - - if ( value !== undefined ) { - - if ( value === null ) { - jQuery.removeAttr( elem, name ); - return; - - } else if ( hooks && "set" in hooks && notxml && (ret = hooks.set( elem, value, name )) !== undefined ) { - return ret; - - } else { - elem.setAttribute( name, "" + value ); - return value; - } - - } else if ( hooks && "get" in hooks && notxml && (ret = hooks.get( elem, name )) !== null ) { - return ret; - - } else { - - ret = elem.getAttribute( name ); - - // Non-existent attributes return null, we normalize to undefined - return ret === null ? - undefined : - ret; - } - }, - - removeAttr: function( elem, value ) { - var propName, attrNames, name, l, isBool, - i = 0; - - if ( value && elem.nodeType === 1 ) { - attrNames = value.toLowerCase().split( rspace ); - l = attrNames.length; - - for ( ; i < l; i++ ) { - name = attrNames[ i ]; - - if ( name ) { - propName = jQuery.propFix[ name ] || name; - isBool = rboolean.test( name ); - - // See #9699 for explanation of this approach (setting first, then removal) - // Do not do this for boolean attributes (see #10870) - if ( !isBool ) { - jQuery.attr( elem, name, "" ); - } - elem.removeAttribute( getSetAttribute ? name : propName ); - - // Set corresponding property to false for boolean attributes - if ( isBool && propName in elem ) { - elem[ propName ] = false; - } - } - } - } - }, - - attrHooks: { - type: { - set: function( elem, value ) { - // We can't allow the type property to be changed (since it causes problems in IE) - if ( rtype.test( elem.nodeName ) && elem.parentNode ) { - jQuery.error( "type property can't be changed" ); - } else if ( !jQuery.support.radioValue && value === "radio" && jQuery.nodeName(elem, "input") ) { - // Setting the type on a radio button after the value resets the value in IE6-9 - // Reset value to it's default in case type is set after value - // This is for element creation - var val = elem.value; - elem.setAttribute( "type", value ); - if ( val ) { - elem.value = val; - } - return value; - } - } - }, - // Use the value property for back compat - // Use the nodeHook for button elements in IE6/7 (#1954) - value: { - get: function( elem, name ) { - if ( nodeHook && jQuery.nodeName( elem, "button" ) ) { - return nodeHook.get( elem, name ); - } - return name in elem ? - elem.value : - null; - }, - set: function( elem, value, name ) { - if ( nodeHook && jQuery.nodeName( elem, "button" ) ) { - return nodeHook.set( elem, value, name ); - } - // Does not return so that setAttribute is also used - elem.value = value; - } - } - }, - - propFix: { - tabindex: "tabIndex", - readonly: "readOnly", - "for": "htmlFor", - "class": "className", - maxlength: "maxLength", - cellspacing: "cellSpacing", - cellpadding: "cellPadding", - rowspan: "rowSpan", - colspan: "colSpan", - usemap: "useMap", - frameborder: "frameBorder", - contenteditable: "contentEditable" - }, - - prop: function( elem, name, value ) { - var ret, hooks, notxml, - nType = elem.nodeType; - - // don't get/set properties on text, comment and attribute nodes - if ( !elem || nType === 3 || nType === 8 || nType === 2 ) { - return; - } - - notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); - - if ( notxml ) { - // Fix name and attach hooks - name = jQuery.propFix[ name ] || name; - hooks = jQuery.propHooks[ name ]; - } - - if ( value !== undefined ) { - if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { - return ret; - - } else { - return ( elem[ name ] = value ); - } - - } else { - if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { - return ret; - - } else { - return elem[ name ]; - } - } - }, - - propHooks: { - tabIndex: { - get: function( elem ) { - // elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set - // http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ - var attributeNode = elem.getAttributeNode("tabindex"); - - return attributeNode && attributeNode.specified ? - parseInt( attributeNode.value, 10 ) : - rfocusable.test( elem.nodeName ) || rclickable.test( elem.nodeName ) && elem.href ? - 0 : - undefined; - } - } - } -}); - -// Add the tabIndex propHook to attrHooks for back-compat (different case is intentional) -jQuery.attrHooks.tabindex = jQuery.propHooks.tabIndex; - -// Hook for boolean attributes -boolHook = { - get: function( elem, name ) { - // Align boolean attributes with corresponding properties - // Fall back to attribute presence where some booleans are not supported - var attrNode, - property = jQuery.prop( elem, name ); - return property === true || typeof property !== "boolean" && ( attrNode = elem.getAttributeNode(name) ) && attrNode.nodeValue !== false ? - name.toLowerCase() : - undefined; - }, - set: function( elem, value, name ) { - var propName; - if ( value === false ) { - // Remove boolean attributes when set to false - jQuery.removeAttr( elem, name ); - } else { - // value is true since we know at this point it's type boolean and not false - // Set boolean attributes to the same name and set the DOM property - propName = jQuery.propFix[ name ] || name; - if ( propName in elem ) { - // Only set the IDL specifically if it already exists on the element - elem[ propName ] = true; - } - - elem.setAttribute( name, name.toLowerCase() ); - } - return name; - } -}; - -// IE6/7 do not support getting/setting some attributes with get/setAttribute -if ( !getSetAttribute ) { - - fixSpecified = { - name: true, - id: true, - coords: true - }; - - // Use this for any attribute in IE6/7 - // This fixes almost every IE6/7 issue - nodeHook = jQuery.valHooks.button = { - get: function( elem, name ) { - var ret; - ret = elem.getAttributeNode( name ); - return ret && ( fixSpecified[ name ] ? ret.nodeValue !== "" : ret.specified ) ? - ret.nodeValue : - undefined; - }, - set: function( elem, value, name ) { - // Set the existing or create a new attribute node - var ret = elem.getAttributeNode( name ); - if ( !ret ) { - ret = document.createAttribute( name ); - elem.setAttributeNode( ret ); - } - return ( ret.nodeValue = value + "" ); - } - }; - - // Apply the nodeHook to tabindex - jQuery.attrHooks.tabindex.set = nodeHook.set; - - // Set width and height to auto instead of 0 on empty string( Bug #8150 ) - // This is for removals - jQuery.each([ "width", "height" ], function( i, name ) { - jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { - set: function( elem, value ) { - if ( value === "" ) { - elem.setAttribute( name, "auto" ); - return value; - } - } - }); - }); - - // Set contenteditable to false on removals(#10429) - // Setting to empty string throws an error as an invalid value - jQuery.attrHooks.contenteditable = { - get: nodeHook.get, - set: function( elem, value, name ) { - if ( value === "" ) { - value = "false"; - } - nodeHook.set( elem, value, name ); - } - }; -} - - -// Some attributes require a special call on IE -if ( !jQuery.support.hrefNormalized ) { - jQuery.each([ "href", "src", "width", "height" ], function( i, name ) { - jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { - get: function( elem ) { - var ret = elem.getAttribute( name, 2 ); - return ret === null ? undefined : ret; - } - }); - }); -} - -if ( !jQuery.support.style ) { - jQuery.attrHooks.style = { - get: function( elem ) { - // Return undefined in the case of empty string - // Normalize to lowercase since IE uppercases css property names - return elem.style.cssText.toLowerCase() || undefined; - }, - set: function( elem, value ) { - return ( elem.style.cssText = "" + value ); - } - }; -} - -// Safari mis-reports the default selected property of an option -// Accessing the parent's selectedIndex property fixes it -if ( !jQuery.support.optSelected ) { - jQuery.propHooks.selected = jQuery.extend( jQuery.propHooks.selected, { - get: function( elem ) { - var parent = elem.parentNode; - - if ( parent ) { - parent.selectedIndex; - - // Make sure that it also works with optgroups, see #5701 - if ( parent.parentNode ) { - parent.parentNode.selectedIndex; - } - } - return null; - } - }); -} - -// IE6/7 call enctype encoding -if ( !jQuery.support.enctype ) { - jQuery.propFix.enctype = "encoding"; -} - -// Radios and checkboxes getter/setter -if ( !jQuery.support.checkOn ) { - jQuery.each([ "radio", "checkbox" ], function() { - jQuery.valHooks[ this ] = { - get: function( elem ) { - // Handle the case where in Webkit "" is returned instead of "on" if a value isn't specified - return elem.getAttribute("value") === null ? "on" : elem.value; - } - }; - }); -} -jQuery.each([ "radio", "checkbox" ], function() { - jQuery.valHooks[ this ] = jQuery.extend( jQuery.valHooks[ this ], { - set: function( elem, value ) { - if ( jQuery.isArray( value ) ) { - return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); - } - } - }); -}); - - - - -var rformElems = /^(?:textarea|input|select)$/i, - rtypenamespace = /^([^\.]*)?(?:\.(.+))?$/, - rhoverHack = /(?:^|\s)hover(\.\S+)?\b/, - rkeyEvent = /^key/, - rmouseEvent = /^(?:mouse|contextmenu)|click/, - rfocusMorph = /^(?:focusinfocus|focusoutblur)$/, - rquickIs = /^(\w*)(?:#([\w\-]+))?(?:\.([\w\-]+))?$/, - quickParse = function( selector ) { - var quick = rquickIs.exec( selector ); - if ( quick ) { - // 0 1 2 3 - // [ _, tag, id, class ] - quick[1] = ( quick[1] || "" ).toLowerCase(); - quick[3] = quick[3] && new RegExp( "(?:^|\\s)" + quick[3] + "(?:\\s|$)" ); - } - return quick; - }, - quickIs = function( elem, m ) { - var attrs = elem.attributes || {}; - return ( - (!m[1] || elem.nodeName.toLowerCase() === m[1]) && - (!m[2] || (attrs.id || {}).value === m[2]) && - (!m[3] || m[3].test( (attrs[ "class" ] || {}).value )) - ); - }, - hoverHack = function( events ) { - return jQuery.event.special.hover ? events : events.replace( rhoverHack, "mouseenter$1 mouseleave$1" ); - }; - -/* - * Helper functions for managing events -- not part of the public interface. - * Props to Dean Edwards' addEvent library for many of the ideas. - */ -jQuery.event = { - - add: function( elem, types, handler, data, selector ) { - - var elemData, eventHandle, events, - t, tns, type, namespaces, handleObj, - handleObjIn, quick, handlers, special; - - // Don't attach events to noData or text/comment nodes (allow plain objects tho) - if ( elem.nodeType === 3 || elem.nodeType === 8 || !types || !handler || !(elemData = jQuery._data( elem )) ) { - return; - } - - // Caller can pass in an object of custom data in lieu of the handler - if ( handler.handler ) { - handleObjIn = handler; - handler = handleObjIn.handler; - selector = handleObjIn.selector; - } - - // Make sure that the handler has a unique ID, used to find/remove it later - if ( !handler.guid ) { - handler.guid = jQuery.guid++; - } - - // Init the element's event structure and main handler, if this is the first - events = elemData.events; - if ( !events ) { - elemData.events = events = {}; - } - eventHandle = elemData.handle; - if ( !eventHandle ) { - elemData.handle = eventHandle = function( e ) { - // Discard the second event of a jQuery.event.trigger() and - // when an event is called after a page has unloaded - return typeof jQuery !== "undefined" && (!e || jQuery.event.triggered !== e.type) ? - jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : - undefined; - }; - // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events - eventHandle.elem = elem; - } - - // Handle multiple events separated by a space - // jQuery(...).bind("mouseover mouseout", fn); - types = jQuery.trim( hoverHack(types) ).split( " " ); - for ( t = 0; t < types.length; t++ ) { - - tns = rtypenamespace.exec( types[t] ) || []; - type = tns[1]; - namespaces = ( tns[2] || "" ).split( "." ).sort(); - - // If event changes its type, use the special event handlers for the changed type - special = jQuery.event.special[ type ] || {}; - - // If selector defined, determine special event api type, otherwise given type - type = ( selector ? special.delegateType : special.bindType ) || type; - - // Update special based on newly reset type - special = jQuery.event.special[ type ] || {}; - - // handleObj is passed to all event handlers - handleObj = jQuery.extend({ - type: type, - origType: tns[1], - data: data, - handler: handler, - guid: handler.guid, - selector: selector, - quick: selector && quickParse( selector ), - namespace: namespaces.join(".") - }, handleObjIn ); - - // Init the event handler queue if we're the first - handlers = events[ type ]; - if ( !handlers ) { - handlers = events[ type ] = []; - handlers.delegateCount = 0; - - // Only use addEventListener/attachEvent if the special events handler returns false - if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { - // Bind the global event handler to the element - if ( elem.addEventListener ) { - elem.addEventListener( type, eventHandle, false ); - - } else if ( elem.attachEvent ) { - elem.attachEvent( "on" + type, eventHandle ); - } - } - } - - if ( special.add ) { - special.add.call( elem, handleObj ); - - if ( !handleObj.handler.guid ) { - handleObj.handler.guid = handler.guid; - } - } - - // Add to the element's handler list, delegates in front - if ( selector ) { - handlers.splice( handlers.delegateCount++, 0, handleObj ); - } else { - handlers.push( handleObj ); - } - - // Keep track of which events have ever been used, for event optimization - jQuery.event.global[ type ] = true; - } - - // Nullify elem to prevent memory leaks in IE - elem = null; - }, - - global: {}, - - // Detach an event or set of events from an element - remove: function( elem, types, handler, selector, mappedTypes ) { - - var elemData = jQuery.hasData( elem ) && jQuery._data( elem ), - t, tns, type, origType, namespaces, origCount, - j, events, special, handle, eventType, handleObj; - - if ( !elemData || !(events = elemData.events) ) { - return; - } - - // Once for each type.namespace in types; type may be omitted - types = jQuery.trim( hoverHack( types || "" ) ).split(" "); - for ( t = 0; t < types.length; t++ ) { - tns = rtypenamespace.exec( types[t] ) || []; - type = origType = tns[1]; - namespaces = tns[2]; - - // Unbind all events (on this namespace, if provided) for the element - if ( !type ) { - for ( type in events ) { - jQuery.event.remove( elem, type + types[ t ], handler, selector, true ); - } - continue; - } - - special = jQuery.event.special[ type ] || {}; - type = ( selector? special.delegateType : special.bindType ) || type; - eventType = events[ type ] || []; - origCount = eventType.length; - namespaces = namespaces ? new RegExp("(^|\\.)" + namespaces.split(".").sort().join("\\.(?:.*\\.)?") + "(\\.|$)") : null; - - // Remove matching events - for ( j = 0; j < eventType.length; j++ ) { - handleObj = eventType[ j ]; - - if ( ( mappedTypes || origType === handleObj.origType ) && - ( !handler || handler.guid === handleObj.guid ) && - ( !namespaces || namespaces.test( handleObj.namespace ) ) && - ( !selector || selector === handleObj.selector || selector === "**" && handleObj.selector ) ) { - eventType.splice( j--, 1 ); - - if ( handleObj.selector ) { - eventType.delegateCount--; - } - if ( special.remove ) { - special.remove.call( elem, handleObj ); - } - } - } - - // Remove generic event handler if we removed something and no more handlers exist - // (avoids potential for endless recursion during removal of special event handlers) - if ( eventType.length === 0 && origCount !== eventType.length ) { - if ( !special.teardown || special.teardown.call( elem, namespaces ) === false ) { - jQuery.removeEvent( elem, type, elemData.handle ); - } - - delete events[ type ]; - } - } - - // Remove the expando if it's no longer used - if ( jQuery.isEmptyObject( events ) ) { - handle = elemData.handle; - if ( handle ) { - handle.elem = null; - } - - // removeData also checks for emptiness and clears the expando if empty - // so use it instead of delete - jQuery.removeData( elem, [ "events", "handle" ], true ); - } - }, - - // Events that are safe to short-circuit if no handlers are attached. - // Native DOM events should not be added, they may have inline handlers. - customEvent: { - "getData": true, - "setData": true, - "changeData": true - }, - - trigger: function( event, data, elem, onlyHandlers ) { - // Don't do events on text and comment nodes - if ( elem && (elem.nodeType === 3 || elem.nodeType === 8) ) { - return; - } - - // Event object or event type - var type = event.type || event, - namespaces = [], - cache, exclusive, i, cur, old, ontype, special, handle, eventPath, bubbleType; - - // focus/blur morphs to focusin/out; ensure we're not firing them right now - if ( rfocusMorph.test( type + jQuery.event.triggered ) ) { - return; - } - - if ( type.indexOf( "!" ) >= 0 ) { - // Exclusive events trigger only for the exact event (no namespaces) - type = type.slice(0, -1); - exclusive = true; - } - - if ( type.indexOf( "." ) >= 0 ) { - // Namespaced trigger; create a regexp to match event type in handle() - namespaces = type.split("."); - type = namespaces.shift(); - namespaces.sort(); - } - - if ( (!elem || jQuery.event.customEvent[ type ]) && !jQuery.event.global[ type ] ) { - // No jQuery handlers for this event type, and it can't have inline handlers - return; - } - - // Caller can pass in an Event, Object, or just an event type string - event = typeof event === "object" ? - // jQuery.Event object - event[ jQuery.expando ] ? event : - // Object literal - new jQuery.Event( type, event ) : - // Just the event type (string) - new jQuery.Event( type ); - - event.type = type; - event.isTrigger = true; - event.exclusive = exclusive; - event.namespace = namespaces.join( "." ); - event.namespace_re = event.namespace? new RegExp("(^|\\.)" + namespaces.join("\\.(?:.*\\.)?") + "(\\.|$)") : null; - ontype = type.indexOf( ":" ) < 0 ? "on" + type : ""; - - // Handle a global trigger - if ( !elem ) { - - // TODO: Stop taunting the data cache; remove global events and always attach to document - cache = jQuery.cache; - for ( i in cache ) { - if ( cache[ i ].events && cache[ i ].events[ type ] ) { - jQuery.event.trigger( event, data, cache[ i ].handle.elem, true ); - } - } - return; - } - - // Clean up the event in case it is being reused - event.result = undefined; - if ( !event.target ) { - event.target = elem; - } - - // Clone any incoming data and prepend the event, creating the handler arg list - data = data != null ? jQuery.makeArray( data ) : []; - data.unshift( event ); - - // Allow special events to draw outside the lines - special = jQuery.event.special[ type ] || {}; - if ( special.trigger && special.trigger.apply( elem, data ) === false ) { - return; - } - - // Determine event propagation path in advance, per W3C events spec (#9951) - // Bubble up to document, then to window; watch for a global ownerDocument var (#9724) - eventPath = [[ elem, special.bindType || type ]]; - if ( !onlyHandlers && !special.noBubble && !jQuery.isWindow( elem ) ) { - - bubbleType = special.delegateType || type; - cur = rfocusMorph.test( bubbleType + type ) ? elem : elem.parentNode; - old = null; - for ( ; cur; cur = cur.parentNode ) { - eventPath.push([ cur, bubbleType ]); - old = cur; - } - - // Only add window if we got to document (e.g., not plain obj or detached DOM) - if ( old && old === elem.ownerDocument ) { - eventPath.push([ old.defaultView || old.parentWindow || window, bubbleType ]); - } - } - - // Fire handlers on the event path - for ( i = 0; i < eventPath.length && !event.isPropagationStopped(); i++ ) { - - cur = eventPath[i][0]; - event.type = eventPath[i][1]; - - handle = ( jQuery._data( cur, "events" ) || {} )[ event.type ] && jQuery._data( cur, "handle" ); - if ( handle ) { - handle.apply( cur, data ); - } - // Note that this is a bare JS function and not a jQuery handler - handle = ontype && cur[ ontype ]; - if ( handle && jQuery.acceptData( cur ) && handle.apply( cur, data ) === false ) { - event.preventDefault(); - } - } - event.type = type; - - // If nobody prevented the default action, do it now - if ( !onlyHandlers && !event.isDefaultPrevented() ) { - - if ( (!special._default || special._default.apply( elem.ownerDocument, data ) === false) && - !(type === "click" && jQuery.nodeName( elem, "a" )) && jQuery.acceptData( elem ) ) { - - // Call a native DOM method on the target with the same name name as the event. - // Can't use an .isFunction() check here because IE6/7 fails that test. - // Don't do default actions on window, that's where global variables be (#6170) - // IE<9 dies on focus/blur to hidden element (#1486) - if ( ontype && elem[ type ] && ((type !== "focus" && type !== "blur") || event.target.offsetWidth !== 0) && !jQuery.isWindow( elem ) ) { - - // Don't re-trigger an onFOO event when we call its FOO() method - old = elem[ ontype ]; - - if ( old ) { - elem[ ontype ] = null; - } - - // Prevent re-triggering of the same event, since we already bubbled it above - jQuery.event.triggered = type; - elem[ type ](); - jQuery.event.triggered = undefined; - - if ( old ) { - elem[ ontype ] = old; - } - } - } - } - - return event.result; - }, - - dispatch: function( event ) { - - // Make a writable jQuery.Event from the native event object - event = jQuery.event.fix( event || window.event ); - - var handlers = ( (jQuery._data( this, "events" ) || {} )[ event.type ] || []), - delegateCount = handlers.delegateCount, - args = [].slice.call( arguments, 0 ), - run_all = !event.exclusive && !event.namespace, - special = jQuery.event.special[ event.type ] || {}, - handlerQueue = [], - i, j, cur, jqcur, ret, selMatch, matched, matches, handleObj, sel, related; - - // Use the fix-ed jQuery.Event rather than the (read-only) native event - args[0] = event; - event.delegateTarget = this; - - // Call the preDispatch hook for the mapped type, and let it bail if desired - if ( special.preDispatch && special.preDispatch.call( this, event ) === false ) { - return; - } - - // Determine handlers that should run if there are delegated events - // Avoid non-left-click bubbling in Firefox (#3861) - if ( delegateCount && !(event.button && event.type === "click") ) { - - // Pregenerate a single jQuery object for reuse with .is() - jqcur = jQuery(this); - jqcur.context = this.ownerDocument || this; - - for ( cur = event.target; cur != this; cur = cur.parentNode || this ) { - - // Don't process events on disabled elements (#6911, #8165) - if ( cur.disabled !== true ) { - selMatch = {}; - matches = []; - jqcur[0] = cur; - for ( i = 0; i < delegateCount; i++ ) { - handleObj = handlers[ i ]; - sel = handleObj.selector; - - if ( selMatch[ sel ] === undefined ) { - selMatch[ sel ] = ( - handleObj.quick ? quickIs( cur, handleObj.quick ) : jqcur.is( sel ) - ); - } - if ( selMatch[ sel ] ) { - matches.push( handleObj ); - } - } - if ( matches.length ) { - handlerQueue.push({ elem: cur, matches: matches }); - } - } - } - } - - // Add the remaining (directly-bound) handlers - if ( handlers.length > delegateCount ) { - handlerQueue.push({ elem: this, matches: handlers.slice( delegateCount ) }); - } - - // Run delegates first; they may want to stop propagation beneath us - for ( i = 0; i < handlerQueue.length && !event.isPropagationStopped(); i++ ) { - matched = handlerQueue[ i ]; - event.currentTarget = matched.elem; - - for ( j = 0; j < matched.matches.length && !event.isImmediatePropagationStopped(); j++ ) { - handleObj = matched.matches[ j ]; - - // Triggered event must either 1) be non-exclusive and have no namespace, or - // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). - if ( run_all || (!event.namespace && !handleObj.namespace) || event.namespace_re && event.namespace_re.test( handleObj.namespace ) ) { - - event.data = handleObj.data; - event.handleObj = handleObj; - - ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) - .apply( matched.elem, args ); - - if ( ret !== undefined ) { - event.result = ret; - if ( ret === false ) { - event.preventDefault(); - event.stopPropagation(); - } - } - } - } - } - - // Call the postDispatch hook for the mapped type - if ( special.postDispatch ) { - special.postDispatch.call( this, event ); - } - - return event.result; - }, - - // Includes some event props shared by KeyEvent and MouseEvent - // *** attrChange attrName relatedNode srcElement are not normalized, non-W3C, deprecated, will be removed in 1.8 *** - props: "attrChange attrName relatedNode srcElement altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), - - fixHooks: {}, - - keyHooks: { - props: "char charCode key keyCode".split(" "), - filter: function( event, original ) { - - // Add which for key events - if ( event.which == null ) { - event.which = original.charCode != null ? original.charCode : original.keyCode; - } - - return event; - } - }, - - mouseHooks: { - props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "), - filter: function( event, original ) { - var eventDoc, doc, body, - button = original.button, - fromElement = original.fromElement; - - // Calculate pageX/Y if missing and clientX/Y available - if ( event.pageX == null && original.clientX != null ) { - eventDoc = event.target.ownerDocument || document; - doc = eventDoc.documentElement; - body = eventDoc.body; - - event.pageX = original.clientX + ( doc && doc.scrollLeft || body && body.scrollLeft || 0 ) - ( doc && doc.clientLeft || body && body.clientLeft || 0 ); - event.pageY = original.clientY + ( doc && doc.scrollTop || body && body.scrollTop || 0 ) - ( doc && doc.clientTop || body && body.clientTop || 0 ); - } - - // Add relatedTarget, if necessary - if ( !event.relatedTarget && fromElement ) { - event.relatedTarget = fromElement === event.target ? original.toElement : fromElement; - } - - // Add which for click: 1 === left; 2 === middle; 3 === right - // Note: button is not normalized, so don't use it - if ( !event.which && button !== undefined ) { - event.which = ( button & 1 ? 1 : ( button & 2 ? 3 : ( button & 4 ? 2 : 0 ) ) ); - } - - return event; - } - }, - - fix: function( event ) { - if ( event[ jQuery.expando ] ) { - return event; - } - - // Create a writable copy of the event object and normalize some properties - var i, prop, - originalEvent = event, - fixHook = jQuery.event.fixHooks[ event.type ] || {}, - copy = fixHook.props ? this.props.concat( fixHook.props ) : this.props; - - event = jQuery.Event( originalEvent ); - - for ( i = copy.length; i; ) { - prop = copy[ --i ]; - event[ prop ] = originalEvent[ prop ]; - } - - // Fix target property, if necessary (#1925, IE 6/7/8 & Safari2) - if ( !event.target ) { - event.target = originalEvent.srcElement || document; - } - - // Target should not be a text node (#504, Safari) - if ( event.target.nodeType === 3 ) { - event.target = event.target.parentNode; - } - - // For mouse/key events; add metaKey if it's not there (#3368, IE6/7/8) - if ( event.metaKey === undefined ) { - event.metaKey = event.ctrlKey; - } - - return fixHook.filter? fixHook.filter( event, originalEvent ) : event; - }, - - special: { - ready: { - // Make sure the ready event is setup - setup: jQuery.bindReady - }, - - load: { - // Prevent triggered image.load events from bubbling to window.load - noBubble: true - }, - - focus: { - delegateType: "focusin" - }, - blur: { - delegateType: "focusout" - }, - - beforeunload: { - setup: function( data, namespaces, eventHandle ) { - // We only want to do this special case on windows - if ( jQuery.isWindow( this ) ) { - this.onbeforeunload = eventHandle; - } - }, - - teardown: function( namespaces, eventHandle ) { - if ( this.onbeforeunload === eventHandle ) { - this.onbeforeunload = null; - } - } - } - }, - - simulate: function( type, elem, event, bubble ) { - // Piggyback on a donor event to simulate a different one. - // Fake originalEvent to avoid donor's stopPropagation, but if the - // simulated event prevents default then we do the same on the donor. - var e = jQuery.extend( - new jQuery.Event(), - event, - { type: type, - isSimulated: true, - originalEvent: {} - } - ); - if ( bubble ) { - jQuery.event.trigger( e, null, elem ); - } else { - jQuery.event.dispatch.call( elem, e ); - } - if ( e.isDefaultPrevented() ) { - event.preventDefault(); - } - } -}; - -// Some plugins are using, but it's undocumented/deprecated and will be removed. -// The 1.7 special event interface should provide all the hooks needed now. -jQuery.event.handle = jQuery.event.dispatch; - -jQuery.removeEvent = document.removeEventListener ? - function( elem, type, handle ) { - if ( elem.removeEventListener ) { - elem.removeEventListener( type, handle, false ); - } - } : - function( elem, type, handle ) { - if ( elem.detachEvent ) { - elem.detachEvent( "on" + type, handle ); - } - }; - -jQuery.Event = function( src, props ) { - // Allow instantiation without the 'new' keyword - if ( !(this instanceof jQuery.Event) ) { - return new jQuery.Event( src, props ); - } - - // Event object - if ( src && src.type ) { - this.originalEvent = src; - this.type = src.type; - - // Events bubbling up the document may have been marked as prevented - // by a handler lower down the tree; reflect the correct value. - this.isDefaultPrevented = ( src.defaultPrevented || src.returnValue === false || - src.getPreventDefault && src.getPreventDefault() ) ? returnTrue : returnFalse; - - // Event type - } else { - this.type = src; - } - - // Put explicitly provided properties onto the event object - if ( props ) { - jQuery.extend( this, props ); - } - - // Create a timestamp if incoming event doesn't have one - this.timeStamp = src && src.timeStamp || jQuery.now(); - - // Mark it as fixed - this[ jQuery.expando ] = true; -}; - -function returnFalse() { - return false; -} -function returnTrue() { - return true; -} - -// jQuery.Event is based on DOM3 Events as specified by the ECMAScript Language Binding -// http://www.w3.org/TR/2003/WD-DOM-Level-3-Events-20030331/ecma-script-binding.html -jQuery.Event.prototype = { - preventDefault: function() { - this.isDefaultPrevented = returnTrue; - - var e = this.originalEvent; - if ( !e ) { - return; - } - - // if preventDefault exists run it on the original event - if ( e.preventDefault ) { - e.preventDefault(); - - // otherwise set the returnValue property of the original event to false (IE) - } else { - e.returnValue = false; - } - }, - stopPropagation: function() { - this.isPropagationStopped = returnTrue; - - var e = this.originalEvent; - if ( !e ) { - return; - } - // if stopPropagation exists run it on the original event - if ( e.stopPropagation ) { - e.stopPropagation(); - } - // otherwise set the cancelBubble property of the original event to true (IE) - e.cancelBubble = true; - }, - stopImmediatePropagation: function() { - this.isImmediatePropagationStopped = returnTrue; - this.stopPropagation(); - }, - isDefaultPrevented: returnFalse, - isPropagationStopped: returnFalse, - isImmediatePropagationStopped: returnFalse -}; - -// Create mouseenter/leave events using mouseover/out and event-time checks -jQuery.each({ - mouseenter: "mouseover", - mouseleave: "mouseout" -}, function( orig, fix ) { - jQuery.event.special[ orig ] = { - delegateType: fix, - bindType: fix, - - handle: function( event ) { - var target = this, - related = event.relatedTarget, - handleObj = event.handleObj, - selector = handleObj.selector, - ret; - - // For mousenter/leave call the handler if related is outside the target. - // NB: No relatedTarget if the mouse left/entered the browser window - if ( !related || (related !== target && !jQuery.contains( target, related )) ) { - event.type = handleObj.origType; - ret = handleObj.handler.apply( this, arguments ); - event.type = fix; - } - return ret; - } - }; -}); - -// IE submit delegation -if ( !jQuery.support.submitBubbles ) { - - jQuery.event.special.submit = { - setup: function() { - // Only need this for delegated form submit events - if ( jQuery.nodeName( this, "form" ) ) { - return false; - } - - // Lazy-add a submit handler when a descendant form may potentially be submitted - jQuery.event.add( this, "click._submit keypress._submit", function( e ) { - // Node name check avoids a VML-related crash in IE (#9807) - var elem = e.target, - form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? elem.form : undefined; - if ( form && !form._submit_attached ) { - jQuery.event.add( form, "submit._submit", function( event ) { - event._submit_bubble = true; - }); - form._submit_attached = true; - } - }); - // return undefined since we don't need an event listener - }, - - postDispatch: function( event ) { - // If form was submitted by the user, bubble the event up the tree - if ( event._submit_bubble ) { - delete event._submit_bubble; - if ( this.parentNode && !event.isTrigger ) { - jQuery.event.simulate( "submit", this.parentNode, event, true ); - } - } - }, - - teardown: function() { - // Only need this for delegated form submit events - if ( jQuery.nodeName( this, "form" ) ) { - return false; - } - - // Remove delegated handlers; cleanData eventually reaps submit handlers attached above - jQuery.event.remove( this, "._submit" ); - } - }; -} - -// IE change delegation and checkbox/radio fix -if ( !jQuery.support.changeBubbles ) { - - jQuery.event.special.change = { - - setup: function() { - - if ( rformElems.test( this.nodeName ) ) { - // IE doesn't fire change on a check/radio until blur; trigger it on click - // after a propertychange. Eat the blur-change in special.change.handle. - // This still fires onchange a second time for check/radio after blur. - if ( this.type === "checkbox" || this.type === "radio" ) { - jQuery.event.add( this, "propertychange._change", function( event ) { - if ( event.originalEvent.propertyName === "checked" ) { - this._just_changed = true; - } - }); - jQuery.event.add( this, "click._change", function( event ) { - if ( this._just_changed && !event.isTrigger ) { - this._just_changed = false; - jQuery.event.simulate( "change", this, event, true ); - } - }); - } - return false; - } - // Delegated event; lazy-add a change handler on descendant inputs - jQuery.event.add( this, "beforeactivate._change", function( e ) { - var elem = e.target; - - if ( rformElems.test( elem.nodeName ) && !elem._change_attached ) { - jQuery.event.add( elem, "change._change", function( event ) { - if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { - jQuery.event.simulate( "change", this.parentNode, event, true ); - } - }); - elem._change_attached = true; - } - }); - }, - - handle: function( event ) { - var elem = event.target; - - // Swallow native change events from checkbox/radio, we already triggered them above - if ( this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox") ) { - return event.handleObj.handler.apply( this, arguments ); - } - }, - - teardown: function() { - jQuery.event.remove( this, "._change" ); - - return rformElems.test( this.nodeName ); - } - }; -} - -// Create "bubbling" focus and blur events -if ( !jQuery.support.focusinBubbles ) { - jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { - - // Attach a single capturing handler while someone wants focusin/focusout - var attaches = 0, - handler = function( event ) { - jQuery.event.simulate( fix, event.target, jQuery.event.fix( event ), true ); - }; - - jQuery.event.special[ fix ] = { - setup: function() { - if ( attaches++ === 0 ) { - document.addEventListener( orig, handler, true ); - } - }, - teardown: function() { - if ( --attaches === 0 ) { - document.removeEventListener( orig, handler, true ); - } - } - }; - }); -} - -jQuery.fn.extend({ - - on: function( types, selector, data, fn, /*INTERNAL*/ one ) { - var origFn, type; - - // Types can be a map of types/handlers - if ( typeof types === "object" ) { - // ( types-Object, selector, data ) - if ( typeof selector !== "string" ) { // && selector != null - // ( types-Object, data ) - data = data || selector; - selector = undefined; - } - for ( type in types ) { - this.on( type, selector, data, types[ type ], one ); - } - return this; - } - - if ( data == null && fn == null ) { - // ( types, fn ) - fn = selector; - data = selector = undefined; - } else if ( fn == null ) { - if ( typeof selector === "string" ) { - // ( types, selector, fn ) - fn = data; - data = undefined; - } else { - // ( types, data, fn ) - fn = data; - data = selector; - selector = undefined; - } - } - if ( fn === false ) { - fn = returnFalse; - } else if ( !fn ) { - return this; - } - - if ( one === 1 ) { - origFn = fn; - fn = function( event ) { - // Can use an empty set, since event contains the info - jQuery().off( event ); - return origFn.apply( this, arguments ); - }; - // Use same guid so caller can remove using origFn - fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); - } - return this.each( function() { - jQuery.event.add( this, types, fn, data, selector ); - }); - }, - one: function( types, selector, data, fn ) { - return this.on( types, selector, data, fn, 1 ); - }, - off: function( types, selector, fn ) { - if ( types && types.preventDefault && types.handleObj ) { - // ( event ) dispatched jQuery.Event - var handleObj = types.handleObj; - jQuery( types.delegateTarget ).off( - handleObj.namespace ? handleObj.origType + "." + handleObj.namespace : handleObj.origType, - handleObj.selector, - handleObj.handler - ); - return this; - } - if ( typeof types === "object" ) { - // ( types-object [, selector] ) - for ( var type in types ) { - this.off( type, selector, types[ type ] ); - } - return this; - } - if ( selector === false || typeof selector === "function" ) { - // ( types [, fn] ) - fn = selector; - selector = undefined; - } - if ( fn === false ) { - fn = returnFalse; - } - return this.each(function() { - jQuery.event.remove( this, types, fn, selector ); - }); - }, - - bind: function( types, data, fn ) { - return this.on( types, null, data, fn ); - }, - unbind: function( types, fn ) { - return this.off( types, null, fn ); - }, - - live: function( types, data, fn ) { - jQuery( this.context ).on( types, this.selector, data, fn ); - return this; - }, - die: function( types, fn ) { - jQuery( this.context ).off( types, this.selector || "**", fn ); - return this; - }, - - delegate: function( selector, types, data, fn ) { - return this.on( types, selector, data, fn ); - }, - undelegate: function( selector, types, fn ) { - // ( namespace ) or ( selector, types [, fn] ) - return arguments.length == 1? this.off( selector, "**" ) : this.off( types, selector, fn ); - }, - - trigger: function( type, data ) { - return this.each(function() { - jQuery.event.trigger( type, data, this ); - }); - }, - triggerHandler: function( type, data ) { - if ( this[0] ) { - return jQuery.event.trigger( type, data, this[0], true ); - } - }, - - toggle: function( fn ) { - // Save reference to arguments for access in closure - var args = arguments, - guid = fn.guid || jQuery.guid++, - i = 0, - toggler = function( event ) { - // Figure out which function to execute - var lastToggle = ( jQuery._data( this, "lastToggle" + fn.guid ) || 0 ) % i; - jQuery._data( this, "lastToggle" + fn.guid, lastToggle + 1 ); - - // Make sure that clicks stop - event.preventDefault(); - - // and execute the function - return args[ lastToggle ].apply( this, arguments ) || false; - }; - - // link all the functions, so any of them can unbind this click handler - toggler.guid = guid; - while ( i < args.length ) { - args[ i++ ].guid = guid; - } - - return this.click( toggler ); - }, - - hover: function( fnOver, fnOut ) { - return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); - } -}); - -jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " + - "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + - "change select submit keydown keypress keyup error contextmenu").split(" "), function( i, name ) { - - // Handle event binding - jQuery.fn[ name ] = function( data, fn ) { - if ( fn == null ) { - fn = data; - data = null; - } - - return arguments.length > 0 ? - this.on( name, null, data, fn ) : - this.trigger( name ); - }; - - if ( jQuery.attrFn ) { - jQuery.attrFn[ name ] = true; - } - - if ( rkeyEvent.test( name ) ) { - jQuery.event.fixHooks[ name ] = jQuery.event.keyHooks; - } - - if ( rmouseEvent.test( name ) ) { - jQuery.event.fixHooks[ name ] = jQuery.event.mouseHooks; - } -}); - - - -/*! - * Sizzle CSS Selector Engine - * Copyright 2011, The Dojo Foundation - * Released under the MIT, BSD, and GPL Licenses. - * More information: http://sizzlejs.com/ - */ -(function(){ - -var chunker = /((?:\((?:\([^()]+\)|[^()]+)+\)|\[(?:\[[^\[\]]*\]|['"][^'"]*['"]|[^\[\]'"]+)+\]|\\.|[^ >+~,(\[\\]+)+|[>+~])(\s*,\s*)?((?:.|\r|\n)*)/g, - expando = "sizcache" + (Math.random() + '').replace('.', ''), - done = 0, - toString = Object.prototype.toString, - hasDuplicate = false, - baseHasDuplicate = true, - rBackslash = /\\/g, - rReturn = /\r\n/g, - rNonWord = /\W/; - -// Here we check if the JavaScript engine is using some sort of -// optimization where it does not always call our comparision -// function. If that is the case, discard the hasDuplicate value. -// Thus far that includes Google Chrome. -[0, 0].sort(function() { - baseHasDuplicate = false; - return 0; -}); - -var Sizzle = function( selector, context, results, seed ) { - results = results || []; - context = context || document; - - var origContext = context; - - if ( context.nodeType !== 1 && context.nodeType !== 9 ) { - return []; - } - - if ( !selector || typeof selector !== "string" ) { - return results; - } - - var m, set, checkSet, extra, ret, cur, pop, i, - prune = true, - contextXML = Sizzle.isXML( context ), - parts = [], - soFar = selector; - - // Reset the position of the chunker regexp (start from head) - do { - chunker.exec( "" ); - m = chunker.exec( soFar ); - - if ( m ) { - soFar = m[3]; - - parts.push( m[1] ); - - if ( m[2] ) { - extra = m[3]; - break; - } - } - } while ( m ); - - if ( parts.length > 1 && origPOS.exec( selector ) ) { - - if ( parts.length === 2 && Expr.relative[ parts[0] ] ) { - set = posProcess( parts[0] + parts[1], context, seed ); - - } else { - set = Expr.relative[ parts[0] ] ? - [ context ] : - Sizzle( parts.shift(), context ); - - while ( parts.length ) { - selector = parts.shift(); - - if ( Expr.relative[ selector ] ) { - selector += parts.shift(); - } - - set = posProcess( selector, set, seed ); - } - } - - } else { - // Take a shortcut and set the context if the root selector is an ID - // (but not if it'll be faster if the inner selector is an ID) - if ( !seed && parts.length > 1 && context.nodeType === 9 && !contextXML && - Expr.match.ID.test(parts[0]) && !Expr.match.ID.test(parts[parts.length - 1]) ) { - - ret = Sizzle.find( parts.shift(), context, contextXML ); - context = ret.expr ? - Sizzle.filter( ret.expr, ret.set )[0] : - ret.set[0]; - } - - if ( context ) { - ret = seed ? - { expr: parts.pop(), set: makeArray(seed) } : - Sizzle.find( parts.pop(), parts.length === 1 && (parts[0] === "~" || parts[0] === "+") && context.parentNode ? context.parentNode : context, contextXML ); - - set = ret.expr ? - Sizzle.filter( ret.expr, ret.set ) : - ret.set; - - if ( parts.length > 0 ) { - checkSet = makeArray( set ); - - } else { - prune = false; - } - - while ( parts.length ) { - cur = parts.pop(); - pop = cur; - - if ( !Expr.relative[ cur ] ) { - cur = ""; - } else { - pop = parts.pop(); - } - - if ( pop == null ) { - pop = context; - } - - Expr.relative[ cur ]( checkSet, pop, contextXML ); - } - - } else { - checkSet = parts = []; - } - } - - if ( !checkSet ) { - checkSet = set; - } - - if ( !checkSet ) { - Sizzle.error( cur || selector ); - } - - if ( toString.call(checkSet) === "[object Array]" ) { - if ( !prune ) { - results.push.apply( results, checkSet ); - - } else if ( context && context.nodeType === 1 ) { - for ( i = 0; checkSet[i] != null; i++ ) { - if ( checkSet[i] && (checkSet[i] === true || checkSet[i].nodeType === 1 && Sizzle.contains(context, checkSet[i])) ) { - results.push( set[i] ); - } - } - - } else { - for ( i = 0; checkSet[i] != null; i++ ) { - if ( checkSet[i] && checkSet[i].nodeType === 1 ) { - results.push( set[i] ); - } - } - } - - } else { - makeArray( checkSet, results ); - } - - if ( extra ) { - Sizzle( extra, origContext, results, seed ); - Sizzle.uniqueSort( results ); - } - - return results; -}; - -Sizzle.uniqueSort = function( results ) { - if ( sortOrder ) { - hasDuplicate = baseHasDuplicate; - results.sort( sortOrder ); - - if ( hasDuplicate ) { - for ( var i = 1; i < results.length; i++ ) { - if ( results[i] === results[ i - 1 ] ) { - results.splice( i--, 1 ); - } - } - } - } - - return results; -}; - -Sizzle.matches = function( expr, set ) { - return Sizzle( expr, null, null, set ); -}; - -Sizzle.matchesSelector = function( node, expr ) { - return Sizzle( expr, null, null, [node] ).length > 0; -}; - -Sizzle.find = function( expr, context, isXML ) { - var set, i, len, match, type, left; - - if ( !expr ) { - return []; - } - - for ( i = 0, len = Expr.order.length; i < len; i++ ) { - type = Expr.order[i]; - - if ( (match = Expr.leftMatch[ type ].exec( expr )) ) { - left = match[1]; - match.splice( 1, 1 ); - - if ( left.substr( left.length - 1 ) !== "\\" ) { - match[1] = (match[1] || "").replace( rBackslash, "" ); - set = Expr.find[ type ]( match, context, isXML ); - - if ( set != null ) { - expr = expr.replace( Expr.match[ type ], "" ); - break; - } - } - } - } - - if ( !set ) { - set = typeof context.getElementsByTagName !== "undefined" ? - context.getElementsByTagName( "*" ) : - []; - } - - return { set: set, expr: expr }; -}; - -Sizzle.filter = function( expr, set, inplace, not ) { - var match, anyFound, - type, found, item, filter, left, - i, pass, - old = expr, - result = [], - curLoop = set, - isXMLFilter = set && set[0] && Sizzle.isXML( set[0] ); - - while ( expr && set.length ) { - for ( type in Expr.filter ) { - if ( (match = Expr.leftMatch[ type ].exec( expr )) != null && match[2] ) { - filter = Expr.filter[ type ]; - left = match[1]; - - anyFound = false; - - match.splice(1,1); - - if ( left.substr( left.length - 1 ) === "\\" ) { - continue; - } - - if ( curLoop === result ) { - result = []; - } - - if ( Expr.preFilter[ type ] ) { - match = Expr.preFilter[ type ]( match, curLoop, inplace, result, not, isXMLFilter ); - - if ( !match ) { - anyFound = found = true; - - } else if ( match === true ) { - continue; - } - } - - if ( match ) { - for ( i = 0; (item = curLoop[i]) != null; i++ ) { - if ( item ) { - found = filter( item, match, i, curLoop ); - pass = not ^ found; - - if ( inplace && found != null ) { - if ( pass ) { - anyFound = true; - - } else { - curLoop[i] = false; - } - - } else if ( pass ) { - result.push( item ); - anyFound = true; - } - } - } - } - - if ( found !== undefined ) { - if ( !inplace ) { - curLoop = result; - } - - expr = expr.replace( Expr.match[ type ], "" ); - - if ( !anyFound ) { - return []; - } - - break; - } - } - } - - // Improper expression - if ( expr === old ) { - if ( anyFound == null ) { - Sizzle.error( expr ); - - } else { - break; - } - } - - old = expr; - } - - return curLoop; -}; - -Sizzle.error = function( msg ) { - throw new Error( "Syntax error, unrecognized expression: " + msg ); -}; - -/** - * Utility function for retreiving the text value of an array of DOM nodes - * @param {Array|Element} elem - */ -var getText = Sizzle.getText = function( elem ) { - var i, node, - nodeType = elem.nodeType, - ret = ""; - - if ( nodeType ) { - if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { - // Use textContent || innerText for elements - if ( typeof elem.textContent === 'string' ) { - return elem.textContent; - } else if ( typeof elem.innerText === 'string' ) { - // Replace IE's carriage returns - return elem.innerText.replace( rReturn, '' ); - } else { - // Traverse it's children - for ( elem = elem.firstChild; elem; elem = elem.nextSibling) { - ret += getText( elem ); - } - } - } else if ( nodeType === 3 || nodeType === 4 ) { - return elem.nodeValue; - } - } else { - - // If no nodeType, this is expected to be an array - for ( i = 0; (node = elem[i]); i++ ) { - // Do not traverse comment nodes - if ( node.nodeType !== 8 ) { - ret += getText( node ); - } - } - } - return ret; -}; - -var Expr = Sizzle.selectors = { - order: [ "ID", "NAME", "TAG" ], - - match: { - ID: /#((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, - CLASS: /\.((?:[\w\u00c0-\uFFFF\-]|\\.)+)/, - NAME: /\[name=['"]*((?:[\w\u00c0-\uFFFF\-]|\\.)+)['"]*\]/, - ATTR: /\[\s*((?:[\w\u00c0-\uFFFF\-]|\\.)+)\s*(?:(\S?=)\s*(?:(['"])(.*?)\3|(#?(?:[\w\u00c0-\uFFFF\-]|\\.)*)|)|)\s*\]/, - TAG: /^((?:[\w\u00c0-\uFFFF\*\-]|\\.)+)/, - CHILD: /:(only|nth|last|first)-child(?:\(\s*(even|odd|(?:[+\-]?\d+|(?:[+\-]?\d*)?n\s*(?:[+\-]\s*\d+)?))\s*\))?/, - POS: /:(nth|eq|gt|lt|first|last|even|odd)(?:\((\d*)\))?(?=[^\-]|$)/, - PSEUDO: /:((?:[\w\u00c0-\uFFFF\-]|\\.)+)(?:\((['"]?)((?:\([^\)]+\)|[^\(\)]*)+)\2\))?/ - }, - - leftMatch: {}, - - attrMap: { - "class": "className", - "for": "htmlFor" - }, - - attrHandle: { - href: function( elem ) { - return elem.getAttribute( "href" ); - }, - type: function( elem ) { - return elem.getAttribute( "type" ); - } - }, - - relative: { - "+": function(checkSet, part){ - var isPartStr = typeof part === "string", - isTag = isPartStr && !rNonWord.test( part ), - isPartStrNotTag = isPartStr && !isTag; - - if ( isTag ) { - part = part.toLowerCase(); - } - - for ( var i = 0, l = checkSet.length, elem; i < l; i++ ) { - if ( (elem = checkSet[i]) ) { - while ( (elem = elem.previousSibling) && elem.nodeType !== 1 ) {} - - checkSet[i] = isPartStrNotTag || elem && elem.nodeName.toLowerCase() === part ? - elem || false : - elem === part; - } - } - - if ( isPartStrNotTag ) { - Sizzle.filter( part, checkSet, true ); - } - }, - - ">": function( checkSet, part ) { - var elem, - isPartStr = typeof part === "string", - i = 0, - l = checkSet.length; - - if ( isPartStr && !rNonWord.test( part ) ) { - part = part.toLowerCase(); - - for ( ; i < l; i++ ) { - elem = checkSet[i]; - - if ( elem ) { - var parent = elem.parentNode; - checkSet[i] = parent.nodeName.toLowerCase() === part ? parent : false; - } - } - - } else { - for ( ; i < l; i++ ) { - elem = checkSet[i]; - - if ( elem ) { - checkSet[i] = isPartStr ? - elem.parentNode : - elem.parentNode === part; - } - } - - if ( isPartStr ) { - Sizzle.filter( part, checkSet, true ); - } - } - }, - - "": function(checkSet, part, isXML){ - var nodeCheck, - doneName = done++, - checkFn = dirCheck; - - if ( typeof part === "string" && !rNonWord.test( part ) ) { - part = part.toLowerCase(); - nodeCheck = part; - checkFn = dirNodeCheck; - } - - checkFn( "parentNode", part, doneName, checkSet, nodeCheck, isXML ); - }, - - "~": function( checkSet, part, isXML ) { - var nodeCheck, - doneName = done++, - checkFn = dirCheck; - - if ( typeof part === "string" && !rNonWord.test( part ) ) { - part = part.toLowerCase(); - nodeCheck = part; - checkFn = dirNodeCheck; - } - - checkFn( "previousSibling", part, doneName, checkSet, nodeCheck, isXML ); - } - }, - - find: { - ID: function( match, context, isXML ) { - if ( typeof context.getElementById !== "undefined" && !isXML ) { - var m = context.getElementById(match[1]); - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document #6963 - return m && m.parentNode ? [m] : []; - } - }, - - NAME: function( match, context ) { - if ( typeof context.getElementsByName !== "undefined" ) { - var ret = [], - results = context.getElementsByName( match[1] ); - - for ( var i = 0, l = results.length; i < l; i++ ) { - if ( results[i].getAttribute("name") === match[1] ) { - ret.push( results[i] ); - } - } - - return ret.length === 0 ? null : ret; - } - }, - - TAG: function( match, context ) { - if ( typeof context.getElementsByTagName !== "undefined" ) { - return context.getElementsByTagName( match[1] ); - } - } - }, - preFilter: { - CLASS: function( match, curLoop, inplace, result, not, isXML ) { - match = " " + match[1].replace( rBackslash, "" ) + " "; - - if ( isXML ) { - return match; - } - - for ( var i = 0, elem; (elem = curLoop[i]) != null; i++ ) { - if ( elem ) { - if ( not ^ (elem.className && (" " + elem.className + " ").replace(/[\t\n\r]/g, " ").indexOf(match) >= 0) ) { - if ( !inplace ) { - result.push( elem ); - } - - } else if ( inplace ) { - curLoop[i] = false; - } - } - } - - return false; - }, - - ID: function( match ) { - return match[1].replace( rBackslash, "" ); - }, - - TAG: function( match, curLoop ) { - return match[1].replace( rBackslash, "" ).toLowerCase(); - }, - - CHILD: function( match ) { - if ( match[1] === "nth" ) { - if ( !match[2] ) { - Sizzle.error( match[0] ); - } - - match[2] = match[2].replace(/^\+|\s*/g, ''); - - // parse equations like 'even', 'odd', '5', '2n', '3n+2', '4n-1', '-n+6' - var test = /(-?)(\d*)(?:n([+\-]?\d*))?/.exec( - match[2] === "even" && "2n" || match[2] === "odd" && "2n+1" || - !/\D/.test( match[2] ) && "0n+" + match[2] || match[2]); - - // calculate the numbers (first)n+(last) including if they are negative - match[2] = (test[1] + (test[2] || 1)) - 0; - match[3] = test[3] - 0; - } - else if ( match[2] ) { - Sizzle.error( match[0] ); - } - - // TODO: Move to normal caching system - match[0] = done++; - - return match; - }, - - ATTR: function( match, curLoop, inplace, result, not, isXML ) { - var name = match[1] = match[1].replace( rBackslash, "" ); - - if ( !isXML && Expr.attrMap[name] ) { - match[1] = Expr.attrMap[name]; - } - - // Handle if an un-quoted value was used - match[4] = ( match[4] || match[5] || "" ).replace( rBackslash, "" ); - - if ( match[2] === "~=" ) { - match[4] = " " + match[4] + " "; - } - - return match; - }, - - PSEUDO: function( match, curLoop, inplace, result, not ) { - if ( match[1] === "not" ) { - // If we're dealing with a complex expression, or a simple one - if ( ( chunker.exec(match[3]) || "" ).length > 1 || /^\w/.test(match[3]) ) { - match[3] = Sizzle(match[3], null, null, curLoop); - - } else { - var ret = Sizzle.filter(match[3], curLoop, inplace, true ^ not); - - if ( !inplace ) { - result.push.apply( result, ret ); - } - - return false; - } - - } else if ( Expr.match.POS.test( match[0] ) || Expr.match.CHILD.test( match[0] ) ) { - return true; - } - - return match; - }, - - POS: function( match ) { - match.unshift( true ); - - return match; - } - }, - - filters: { - enabled: function( elem ) { - return elem.disabled === false && elem.type !== "hidden"; - }, - - disabled: function( elem ) { - return elem.disabled === true; - }, - - checked: function( elem ) { - return elem.checked === true; - }, - - selected: function( elem ) { - // Accessing this property makes selected-by-default - // options in Safari work properly - if ( elem.parentNode ) { - elem.parentNode.selectedIndex; - } - - return elem.selected === true; - }, - - parent: function( elem ) { - return !!elem.firstChild; - }, - - empty: function( elem ) { - return !elem.firstChild; - }, - - has: function( elem, i, match ) { - return !!Sizzle( match[3], elem ).length; - }, - - header: function( elem ) { - return (/h\d/i).test( elem.nodeName ); - }, - - text: function( elem ) { - var attr = elem.getAttribute( "type" ), type = elem.type; - // IE6 and 7 will map elem.type to 'text' for new HTML5 types (search, etc) - // use getAttribute instead to test this case - return elem.nodeName.toLowerCase() === "input" && "text" === type && ( attr === type || attr === null ); - }, - - radio: function( elem ) { - return elem.nodeName.toLowerCase() === "input" && "radio" === elem.type; - }, - - checkbox: function( elem ) { - return elem.nodeName.toLowerCase() === "input" && "checkbox" === elem.type; - }, - - file: function( elem ) { - return elem.nodeName.toLowerCase() === "input" && "file" === elem.type; - }, - - password: function( elem ) { - return elem.nodeName.toLowerCase() === "input" && "password" === elem.type; - }, - - submit: function( elem ) { - var name = elem.nodeName.toLowerCase(); - return (name === "input" || name === "button") && "submit" === elem.type; - }, - - image: function( elem ) { - return elem.nodeName.toLowerCase() === "input" && "image" === elem.type; - }, - - reset: function( elem ) { - var name = elem.nodeName.toLowerCase(); - return (name === "input" || name === "button") && "reset" === elem.type; - }, - - button: function( elem ) { - var name = elem.nodeName.toLowerCase(); - return name === "input" && "button" === elem.type || name === "button"; - }, - - input: function( elem ) { - return (/input|select|textarea|button/i).test( elem.nodeName ); - }, - - focus: function( elem ) { - return elem === elem.ownerDocument.activeElement; - } - }, - setFilters: { - first: function( elem, i ) { - return i === 0; - }, - - last: function( elem, i, match, array ) { - return i === array.length - 1; - }, - - even: function( elem, i ) { - return i % 2 === 0; - }, - - odd: function( elem, i ) { - return i % 2 === 1; - }, - - lt: function( elem, i, match ) { - return i < match[3] - 0; - }, - - gt: function( elem, i, match ) { - return i > match[3] - 0; - }, - - nth: function( elem, i, match ) { - return match[3] - 0 === i; - }, - - eq: function( elem, i, match ) { - return match[3] - 0 === i; - } - }, - filter: { - PSEUDO: function( elem, match, i, array ) { - var name = match[1], - filter = Expr.filters[ name ]; - - if ( filter ) { - return filter( elem, i, match, array ); - - } else if ( name === "contains" ) { - return (elem.textContent || elem.innerText || getText([ elem ]) || "").indexOf(match[3]) >= 0; - - } else if ( name === "not" ) { - var not = match[3]; - - for ( var j = 0, l = not.length; j < l; j++ ) { - if ( not[j] === elem ) { - return false; - } - } - - return true; - - } else { - Sizzle.error( name ); - } - }, - - CHILD: function( elem, match ) { - var first, last, - doneName, parent, cache, - count, diff, - type = match[1], - node = elem; - - switch ( type ) { - case "only": - case "first": - while ( (node = node.previousSibling) ) { - if ( node.nodeType === 1 ) { - return false; - } - } - - if ( type === "first" ) { - return true; - } - - node = elem; - - /* falls through */ - case "last": - while ( (node = node.nextSibling) ) { - if ( node.nodeType === 1 ) { - return false; - } - } - - return true; - - case "nth": - first = match[2]; - last = match[3]; - - if ( first === 1 && last === 0 ) { - return true; - } - - doneName = match[0]; - parent = elem.parentNode; - - if ( parent && (parent[ expando ] !== doneName || !elem.nodeIndex) ) { - count = 0; - - for ( node = parent.firstChild; node; node = node.nextSibling ) { - if ( node.nodeType === 1 ) { - node.nodeIndex = ++count; - } - } - - parent[ expando ] = doneName; - } - - diff = elem.nodeIndex - last; - - if ( first === 0 ) { - return diff === 0; - - } else { - return ( diff % first === 0 && diff / first >= 0 ); - } - } - }, - - ID: function( elem, match ) { - return elem.nodeType === 1 && elem.getAttribute("id") === match; - }, - - TAG: function( elem, match ) { - return (match === "*" && elem.nodeType === 1) || !!elem.nodeName && elem.nodeName.toLowerCase() === match; - }, - - CLASS: function( elem, match ) { - return (" " + (elem.className || elem.getAttribute("class")) + " ") - .indexOf( match ) > -1; - }, - - ATTR: function( elem, match ) { - var name = match[1], - result = Sizzle.attr ? - Sizzle.attr( elem, name ) : - Expr.attrHandle[ name ] ? - Expr.attrHandle[ name ]( elem ) : - elem[ name ] != null ? - elem[ name ] : - elem.getAttribute( name ), - value = result + "", - type = match[2], - check = match[4]; - - return result == null ? - type === "!=" : - !type && Sizzle.attr ? - result != null : - type === "=" ? - value === check : - type === "*=" ? - value.indexOf(check) >= 0 : - type === "~=" ? - (" " + value + " ").indexOf(check) >= 0 : - !check ? - value && result !== false : - type === "!=" ? - value !== check : - type === "^=" ? - value.indexOf(check) === 0 : - type === "$=" ? - value.substr(value.length - check.length) === check : - type === "|=" ? - value === check || value.substr(0, check.length + 1) === check + "-" : - false; - }, - - POS: function( elem, match, i, array ) { - var name = match[2], - filter = Expr.setFilters[ name ]; - - if ( filter ) { - return filter( elem, i, match, array ); - } - } - } -}; - -var origPOS = Expr.match.POS, - fescape = function(all, num){ - return "\\" + (num - 0 + 1); - }; - -for ( var type in Expr.match ) { - Expr.match[ type ] = new RegExp( Expr.match[ type ].source + (/(?![^\[]*\])(?![^\(]*\))/.source) ); - Expr.leftMatch[ type ] = new RegExp( /(^(?:.|\r|\n)*?)/.source + Expr.match[ type ].source.replace(/\\(\d+)/g, fescape) ); -} -// Expose origPOS -// "global" as in regardless of relation to brackets/parens -Expr.match.globalPOS = origPOS; - -var makeArray = function( array, results ) { - array = Array.prototype.slice.call( array, 0 ); - - if ( results ) { - results.push.apply( results, array ); - return results; - } - - return array; -}; - -// Perform a simple check to determine if the browser is capable of -// converting a NodeList to an array using builtin methods. -// Also verifies that the returned array holds DOM nodes -// (which is not the case in the Blackberry browser) -try { - Array.prototype.slice.call( document.documentElement.childNodes, 0 )[0].nodeType; - -// Provide a fallback method if it does not work -} catch( e ) { - makeArray = function( array, results ) { - var i = 0, - ret = results || []; - - if ( toString.call(array) === "[object Array]" ) { - Array.prototype.push.apply( ret, array ); - - } else { - if ( typeof array.length === "number" ) { - for ( var l = array.length; i < l; i++ ) { - ret.push( array[i] ); - } - - } else { - for ( ; array[i]; i++ ) { - ret.push( array[i] ); - } - } - } - - return ret; - }; -} - -var sortOrder, siblingCheck; - -if ( document.documentElement.compareDocumentPosition ) { - sortOrder = function( a, b ) { - if ( a === b ) { - hasDuplicate = true; - return 0; - } - - if ( !a.compareDocumentPosition || !b.compareDocumentPosition ) { - return a.compareDocumentPosition ? -1 : 1; - } - - return a.compareDocumentPosition(b) & 4 ? -1 : 1; - }; - -} else { - sortOrder = function( a, b ) { - // The nodes are identical, we can exit early - if ( a === b ) { - hasDuplicate = true; - return 0; - - // Fallback to using sourceIndex (in IE) if it's available on both nodes - } else if ( a.sourceIndex && b.sourceIndex ) { - return a.sourceIndex - b.sourceIndex; - } - - var al, bl, - ap = [], - bp = [], - aup = a.parentNode, - bup = b.parentNode, - cur = aup; - - // If the nodes are siblings (or identical) we can do a quick check - if ( aup === bup ) { - return siblingCheck( a, b ); - - // If no parents were found then the nodes are disconnected - } else if ( !aup ) { - return -1; - - } else if ( !bup ) { - return 1; - } - - // Otherwise they're somewhere else in the tree so we need - // to build up a full list of the parentNodes for comparison - while ( cur ) { - ap.unshift( cur ); - cur = cur.parentNode; - } - - cur = bup; - - while ( cur ) { - bp.unshift( cur ); - cur = cur.parentNode; - } - - al = ap.length; - bl = bp.length; - - // Start walking down the tree looking for a discrepancy - for ( var i = 0; i < al && i < bl; i++ ) { - if ( ap[i] !== bp[i] ) { - return siblingCheck( ap[i], bp[i] ); - } - } - - // We ended someplace up the tree so do a sibling check - return i === al ? - siblingCheck( a, bp[i], -1 ) : - siblingCheck( ap[i], b, 1 ); - }; - - siblingCheck = function( a, b, ret ) { - if ( a === b ) { - return ret; - } - - var cur = a.nextSibling; - - while ( cur ) { - if ( cur === b ) { - return -1; - } - - cur = cur.nextSibling; - } - - return 1; - }; -} - -// Check to see if the browser returns elements by name when -// querying by getElementById (and provide a workaround) -(function(){ - // We're going to inject a fake input element with a specified name - var form = document.createElement("div"), - id = "script" + (new Date()).getTime(), - root = document.documentElement; - - form.innerHTML = ""; - - // Inject it into the root element, check its status, and remove it quickly - root.insertBefore( form, root.firstChild ); - - // The workaround has to do additional checks after a getElementById - // Which slows things down for other browsers (hence the branching) - if ( document.getElementById( id ) ) { - Expr.find.ID = function( match, context, isXML ) { - if ( typeof context.getElementById !== "undefined" && !isXML ) { - var m = context.getElementById(match[1]); - - return m ? - m.id === match[1] || typeof m.getAttributeNode !== "undefined" && m.getAttributeNode("id").nodeValue === match[1] ? - [m] : - undefined : - []; - } - }; - - Expr.filter.ID = function( elem, match ) { - var node = typeof elem.getAttributeNode !== "undefined" && elem.getAttributeNode("id"); - - return elem.nodeType === 1 && node && node.nodeValue === match; - }; - } - - root.removeChild( form ); - - // release memory in IE - root = form = null; -})(); - -(function(){ - // Check to see if the browser returns only elements - // when doing getElementsByTagName("*") - - // Create a fake element - var div = document.createElement("div"); - div.appendChild( document.createComment("") ); - - // Make sure no comments are found - if ( div.getElementsByTagName("*").length > 0 ) { - Expr.find.TAG = function( match, context ) { - var results = context.getElementsByTagName( match[1] ); - - // Filter out possible comments - if ( match[1] === "*" ) { - var tmp = []; - - for ( var i = 0; results[i]; i++ ) { - if ( results[i].nodeType === 1 ) { - tmp.push( results[i] ); - } - } - - results = tmp; - } - - return results; - }; - } - - // Check to see if an attribute returns normalized href attributes - div.innerHTML = ""; - - if ( div.firstChild && typeof div.firstChild.getAttribute !== "undefined" && - div.firstChild.getAttribute("href") !== "#" ) { - - Expr.attrHandle.href = function( elem ) { - return elem.getAttribute( "href", 2 ); - }; - } - - // release memory in IE - div = null; -})(); - -if ( document.querySelectorAll ) { - (function(){ - var oldSizzle = Sizzle, - div = document.createElement("div"), - id = "__sizzle__"; - - div.innerHTML = "

    "; - - // Safari can't handle uppercase or unicode characters when - // in quirks mode. - if ( div.querySelectorAll && div.querySelectorAll(".TEST").length === 0 ) { - return; - } - - Sizzle = function( query, context, extra, seed ) { - context = context || document; - - // Only use querySelectorAll on non-XML documents - // (ID selectors don't work in non-HTML documents) - if ( !seed && !Sizzle.isXML(context) ) { - // See if we find a selector to speed up - var match = /^(\w+$)|^\.([\w\-]+$)|^#([\w\-]+$)/.exec( query ); - - if ( match && (context.nodeType === 1 || context.nodeType === 9) ) { - // Speed-up: Sizzle("TAG") - if ( match[1] ) { - return makeArray( context.getElementsByTagName( query ), extra ); - - // Speed-up: Sizzle(".CLASS") - } else if ( match[2] && Expr.find.CLASS && context.getElementsByClassName ) { - return makeArray( context.getElementsByClassName( match[2] ), extra ); - } - } - - if ( context.nodeType === 9 ) { - // Speed-up: Sizzle("body") - // The body element only exists once, optimize finding it - if ( query === "body" && context.body ) { - return makeArray( [ context.body ], extra ); - - // Speed-up: Sizzle("#ID") - } else if ( match && match[3] ) { - var elem = context.getElementById( match[3] ); - - // Check parentNode to catch when Blackberry 4.6 returns - // nodes that are no longer in the document #6963 - if ( elem && elem.parentNode ) { - // Handle the case where IE and Opera return items - // by name instead of ID - if ( elem.id === match[3] ) { - return makeArray( [ elem ], extra ); - } - - } else { - return makeArray( [], extra ); - } - } - - try { - return makeArray( context.querySelectorAll(query), extra ); - } catch(qsaError) {} - - // qSA works strangely on Element-rooted queries - // We can work around this by specifying an extra ID on the root - // and working up from there (Thanks to Andrew Dupont for the technique) - // IE 8 doesn't work on object elements - } else if ( context.nodeType === 1 && context.nodeName.toLowerCase() !== "object" ) { - var oldContext = context, - old = context.getAttribute( "id" ), - nid = old || id, - hasParent = context.parentNode, - relativeHierarchySelector = /^\s*[+~]/.test( query ); - - if ( !old ) { - context.setAttribute( "id", nid ); - } else { - nid = nid.replace( /'/g, "\\$&" ); - } - if ( relativeHierarchySelector && hasParent ) { - context = context.parentNode; - } - - try { - if ( !relativeHierarchySelector || hasParent ) { - return makeArray( context.querySelectorAll( "[id='" + nid + "'] " + query ), extra ); - } - - } catch(pseudoError) { - } finally { - if ( !old ) { - oldContext.removeAttribute( "id" ); - } - } - } - } - - return oldSizzle(query, context, extra, seed); - }; - - for ( var prop in oldSizzle ) { - Sizzle[ prop ] = oldSizzle[ prop ]; - } - - // release memory in IE - div = null; - })(); -} - -(function(){ - var html = document.documentElement, - matches = html.matchesSelector || html.mozMatchesSelector || html.webkitMatchesSelector || html.msMatchesSelector; - - if ( matches ) { - // Check to see if it's possible to do matchesSelector - // on a disconnected node (IE 9 fails this) - var disconnectedMatch = !matches.call( document.createElement( "div" ), "div" ), - pseudoWorks = false; - - try { - // This should fail with an exception - // Gecko does not error, returns false instead - matches.call( document.documentElement, "[test!='']:sizzle" ); - - } catch( pseudoError ) { - pseudoWorks = true; - } - - Sizzle.matchesSelector = function( node, expr ) { - // Make sure that attribute selectors are quoted - expr = expr.replace(/\=\s*([^'"\]]*)\s*\]/g, "='$1']"); - - if ( !Sizzle.isXML( node ) ) { - try { - if ( pseudoWorks || !Expr.match.PSEUDO.test( expr ) && !/!=/.test( expr ) ) { - var ret = matches.call( node, expr ); - - // IE 9's matchesSelector returns false on disconnected nodes - if ( ret || !disconnectedMatch || - // As well, disconnected nodes are said to be in a document - // fragment in IE 9, so check for that - node.document && node.document.nodeType !== 11 ) { - return ret; - } - } - } catch(e) {} - } - - return Sizzle(expr, null, null, [node]).length > 0; - }; - } -})(); - -(function(){ - var div = document.createElement("div"); - - div.innerHTML = "
    "; - - // Opera can't find a second classname (in 9.6) - // Also, make sure that getElementsByClassName actually exists - if ( !div.getElementsByClassName || div.getElementsByClassName("e").length === 0 ) { - return; - } - - // Safari caches class attributes, doesn't catch changes (in 3.2) - div.lastChild.className = "e"; - - if ( div.getElementsByClassName("e").length === 1 ) { - return; - } - - Expr.order.splice(1, 0, "CLASS"); - Expr.find.CLASS = function( match, context, isXML ) { - if ( typeof context.getElementsByClassName !== "undefined" && !isXML ) { - return context.getElementsByClassName(match[1]); - } - }; - - // release memory in IE - div = null; -})(); - -function dirNodeCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) { - for ( var i = 0, l = checkSet.length; i < l; i++ ) { - var elem = checkSet[i]; - - if ( elem ) { - var match = false; - - elem = elem[dir]; - - while ( elem ) { - if ( elem[ expando ] === doneName ) { - match = checkSet[elem.sizset]; - break; - } - - if ( elem.nodeType === 1 && !isXML ){ - elem[ expando ] = doneName; - elem.sizset = i; - } - - if ( elem.nodeName.toLowerCase() === cur ) { - match = elem; - break; - } - - elem = elem[dir]; - } - - checkSet[i] = match; - } - } -} - -function dirCheck( dir, cur, doneName, checkSet, nodeCheck, isXML ) { - for ( var i = 0, l = checkSet.length; i < l; i++ ) { - var elem = checkSet[i]; - - if ( elem ) { - var match = false; - - elem = elem[dir]; - - while ( elem ) { - if ( elem[ expando ] === doneName ) { - match = checkSet[elem.sizset]; - break; - } - - if ( elem.nodeType === 1 ) { - if ( !isXML ) { - elem[ expando ] = doneName; - elem.sizset = i; - } - - if ( typeof cur !== "string" ) { - if ( elem === cur ) { - match = true; - break; - } - - } else if ( Sizzle.filter( cur, [elem] ).length > 0 ) { - match = elem; - break; - } - } - - elem = elem[dir]; - } - - checkSet[i] = match; - } - } -} - -if ( document.documentElement.contains ) { - Sizzle.contains = function( a, b ) { - return a !== b && (a.contains ? a.contains(b) : true); - }; - -} else if ( document.documentElement.compareDocumentPosition ) { - Sizzle.contains = function( a, b ) { - return !!(a.compareDocumentPosition(b) & 16); - }; - -} else { - Sizzle.contains = function() { - return false; - }; -} - -Sizzle.isXML = function( elem ) { - // documentElement is verified for cases where it doesn't yet exist - // (such as loading iframes in IE - #4833) - var documentElement = (elem ? elem.ownerDocument || elem : 0).documentElement; - - return documentElement ? documentElement.nodeName !== "HTML" : false; -}; - -var posProcess = function( selector, context, seed ) { - var match, - tmpSet = [], - later = "", - root = context.nodeType ? [context] : context; - - // Position selectors must be done after the filter - // And so must :not(positional) so we move all PSEUDOs to the end - while ( (match = Expr.match.PSEUDO.exec( selector )) ) { - later += match[0]; - selector = selector.replace( Expr.match.PSEUDO, "" ); - } - - selector = Expr.relative[selector] ? selector + "*" : selector; - - for ( var i = 0, l = root.length; i < l; i++ ) { - Sizzle( selector, root[i], tmpSet, seed ); - } - - return Sizzle.filter( later, tmpSet ); -}; - -// EXPOSE -// Override sizzle attribute retrieval -Sizzle.attr = jQuery.attr; -Sizzle.selectors.attrMap = {}; -jQuery.find = Sizzle; -jQuery.expr = Sizzle.selectors; -jQuery.expr[":"] = jQuery.expr.filters; -jQuery.unique = Sizzle.uniqueSort; -jQuery.text = Sizzle.getText; -jQuery.isXMLDoc = Sizzle.isXML; -jQuery.contains = Sizzle.contains; - - -})(); - - -var runtil = /Until$/, - rparentsprev = /^(?:parents|prevUntil|prevAll)/, - // Note: This RegExp should be improved, or likely pulled from Sizzle - rmultiselector = /,/, - isSimple = /^.[^:#\[\.,]*$/, - slice = Array.prototype.slice, - POS = jQuery.expr.match.globalPOS, - // methods guaranteed to produce a unique set when starting from a unique set - guaranteedUnique = { - children: true, - contents: true, - next: true, - prev: true - }; - -jQuery.fn.extend({ - find: function( selector ) { - var self = this, - i, l; - - if ( typeof selector !== "string" ) { - return jQuery( selector ).filter(function() { - for ( i = 0, l = self.length; i < l; i++ ) { - if ( jQuery.contains( self[ i ], this ) ) { - return true; - } - } - }); - } - - var ret = this.pushStack( "", "find", selector ), - length, n, r; - - for ( i = 0, l = this.length; i < l; i++ ) { - length = ret.length; - jQuery.find( selector, this[i], ret ); - - if ( i > 0 ) { - // Make sure that the results are unique - for ( n = length; n < ret.length; n++ ) { - for ( r = 0; r < length; r++ ) { - if ( ret[r] === ret[n] ) { - ret.splice(n--, 1); - break; - } - } - } - } - } - - return ret; - }, - - has: function( target ) { - var targets = jQuery( target ); - return this.filter(function() { - for ( var i = 0, l = targets.length; i < l; i++ ) { - if ( jQuery.contains( this, targets[i] ) ) { - return true; - } - } - }); - }, - - not: function( selector ) { - return this.pushStack( winnow(this, selector, false), "not", selector); - }, - - filter: function( selector ) { - return this.pushStack( winnow(this, selector, true), "filter", selector ); - }, - - is: function( selector ) { - return !!selector && ( - typeof selector === "string" ? - // If this is a positional selector, check membership in the returned set - // so $("p:first").is("p:last") won't return true for a doc with two "p". - POS.test( selector ) ? - jQuery( selector, this.context ).index( this[0] ) >= 0 : - jQuery.filter( selector, this ).length > 0 : - this.filter( selector ).length > 0 ); - }, - - closest: function( selectors, context ) { - var ret = [], i, l, cur = this[0]; - - // Array (deprecated as of jQuery 1.7) - if ( jQuery.isArray( selectors ) ) { - var level = 1; - - while ( cur && cur.ownerDocument && cur !== context ) { - for ( i = 0; i < selectors.length; i++ ) { - - if ( jQuery( cur ).is( selectors[ i ] ) ) { - ret.push({ selector: selectors[ i ], elem: cur, level: level }); - } - } - - cur = cur.parentNode; - level++; - } - - return ret; - } - - // String - var pos = POS.test( selectors ) || typeof selectors !== "string" ? - jQuery( selectors, context || this.context ) : - 0; - - for ( i = 0, l = this.length; i < l; i++ ) { - cur = this[i]; - - while ( cur ) { - if ( pos ? pos.index(cur) > -1 : jQuery.find.matchesSelector(cur, selectors) ) { - ret.push( cur ); - break; - - } else { - cur = cur.parentNode; - if ( !cur || !cur.ownerDocument || cur === context || cur.nodeType === 11 ) { - break; - } - } - } - } - - ret = ret.length > 1 ? jQuery.unique( ret ) : ret; - - return this.pushStack( ret, "closest", selectors ); - }, - - // Determine the position of an element within - // the matched set of elements - index: function( elem ) { - - // No argument, return index in parent - if ( !elem ) { - return ( this[0] && this[0].parentNode ) ? this.prevAll().length : -1; - } - - // index in selector - if ( typeof elem === "string" ) { - return jQuery.inArray( this[0], jQuery( elem ) ); - } - - // Locate the position of the desired element - return jQuery.inArray( - // If it receives a jQuery object, the first element is used - elem.jquery ? elem[0] : elem, this ); - }, - - add: function( selector, context ) { - var set = typeof selector === "string" ? - jQuery( selector, context ) : - jQuery.makeArray( selector && selector.nodeType ? [ selector ] : selector ), - all = jQuery.merge( this.get(), set ); - - return this.pushStack( isDisconnected( set[0] ) || isDisconnected( all[0] ) ? - all : - jQuery.unique( all ) ); - }, - - andSelf: function() { - return this.add( this.prevObject ); - } -}); - -// A painfully simple check to see if an element is disconnected -// from a document (should be improved, where feasible). -function isDisconnected( node ) { - return !node || !node.parentNode || node.parentNode.nodeType === 11; -} - -jQuery.each({ - parent: function( elem ) { - var parent = elem.parentNode; - return parent && parent.nodeType !== 11 ? parent : null; - }, - parents: function( elem ) { - return jQuery.dir( elem, "parentNode" ); - }, - parentsUntil: function( elem, i, until ) { - return jQuery.dir( elem, "parentNode", until ); - }, - next: function( elem ) { - return jQuery.nth( elem, 2, "nextSibling" ); - }, - prev: function( elem ) { - return jQuery.nth( elem, 2, "previousSibling" ); - }, - nextAll: function( elem ) { - return jQuery.dir( elem, "nextSibling" ); - }, - prevAll: function( elem ) { - return jQuery.dir( elem, "previousSibling" ); - }, - nextUntil: function( elem, i, until ) { - return jQuery.dir( elem, "nextSibling", until ); - }, - prevUntil: function( elem, i, until ) { - return jQuery.dir( elem, "previousSibling", until ); - }, - siblings: function( elem ) { - return jQuery.sibling( ( elem.parentNode || {} ).firstChild, elem ); - }, - children: function( elem ) { - return jQuery.sibling( elem.firstChild ); - }, - contents: function( elem ) { - return jQuery.nodeName( elem, "iframe" ) ? - elem.contentDocument || elem.contentWindow.document : - jQuery.makeArray( elem.childNodes ); - } -}, function( name, fn ) { - jQuery.fn[ name ] = function( until, selector ) { - var ret = jQuery.map( this, fn, until ); - - if ( !runtil.test( name ) ) { - selector = until; - } - - if ( selector && typeof selector === "string" ) { - ret = jQuery.filter( selector, ret ); - } - - ret = this.length > 1 && !guaranteedUnique[ name ] ? jQuery.unique( ret ) : ret; - - if ( (this.length > 1 || rmultiselector.test( selector )) && rparentsprev.test( name ) ) { - ret = ret.reverse(); - } - - return this.pushStack( ret, name, slice.call( arguments ).join(",") ); - }; -}); - -jQuery.extend({ - filter: function( expr, elems, not ) { - if ( not ) { - expr = ":not(" + expr + ")"; - } - - return elems.length === 1 ? - jQuery.find.matchesSelector(elems[0], expr) ? [ elems[0] ] : [] : - jQuery.find.matches(expr, elems); - }, - - dir: function( elem, dir, until ) { - var matched = [], - cur = elem[ dir ]; - - while ( cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { - if ( cur.nodeType === 1 ) { - matched.push( cur ); - } - cur = cur[dir]; - } - return matched; - }, - - nth: function( cur, result, dir, elem ) { - result = result || 1; - var num = 0; - - for ( ; cur; cur = cur[dir] ) { - if ( cur.nodeType === 1 && ++num === result ) { - break; - } - } - - return cur; - }, - - sibling: function( n, elem ) { - var r = []; - - for ( ; n; n = n.nextSibling ) { - if ( n.nodeType === 1 && n !== elem ) { - r.push( n ); - } - } - - return r; - } -}); - -// Implement the identical functionality for filter and not -function winnow( elements, qualifier, keep ) { - - // Can't pass null or undefined to indexOf in Firefox 4 - // Set to 0 to skip string check - qualifier = qualifier || 0; - - if ( jQuery.isFunction( qualifier ) ) { - return jQuery.grep(elements, function( elem, i ) { - var retVal = !!qualifier.call( elem, i, elem ); - return retVal === keep; - }); - - } else if ( qualifier.nodeType ) { - return jQuery.grep(elements, function( elem, i ) { - return ( elem === qualifier ) === keep; - }); - - } else if ( typeof qualifier === "string" ) { - var filtered = jQuery.grep(elements, function( elem ) { - return elem.nodeType === 1; - }); - - if ( isSimple.test( qualifier ) ) { - return jQuery.filter(qualifier, filtered, !keep); - } else { - qualifier = jQuery.filter( qualifier, filtered ); - } - } - - return jQuery.grep(elements, function( elem, i ) { - return ( jQuery.inArray( elem, qualifier ) >= 0 ) === keep; - }); -} - - - - -function createSafeFragment( document ) { - var list = nodeNames.split( "|" ), - safeFrag = document.createDocumentFragment(); - - if ( safeFrag.createElement ) { - while ( list.length ) { - safeFrag.createElement( - list.pop() - ); - } - } - return safeFrag; -} - -var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|" + - "header|hgroup|mark|meter|nav|output|progress|section|summary|time|video", - rinlinejQuery = / jQuery\d+="(?:\d+|null)"/g, - rleadingWhitespace = /^\s+/, - rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig, - rtagName = /<([\w:]+)/, - rtbody = /
    ", "
    " ], - tr: [ 2, "", "
    " ], - td: [ 3, "", "
    " ], - col: [ 2, "", "
    " ], - area: [ 1, "", "" ], - _default: [ 0, "", "" ] - }, - safeFragment = createSafeFragment( document ); - -wrapMap.optgroup = wrapMap.option; -wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; -wrapMap.th = wrapMap.td; - -// IE can't serialize and - - \ No newline at end of file diff --git a/data/interfaces/brink/manage.html b/data/interfaces/brink/manage.html deleted file mode 100644 index 1b31bdf8..00000000 --- a/data/interfaces/brink/manage.html +++ /dev/null @@ -1,105 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones - from headphones.helpers import checked -%> - -<%def name="body()"> - -
    -
    -

    Scan Music Library

    - - - - %if headphones.MUSIC_DIR: - - - %else: - - - %endif - - - - - - - - - - -
    -

    Local Music Directory:

    - - You can put in any directory, and it will scan for audio files in that folder - (including all subdirectories)
    - For example: '/Users/name/Music' -
    -
    -

    Local Music Directory:

    - - You can put in any directory, and it will scan for audio files in that folder - (including all subdirectories)
    - For example: '/Users/name/Music' -
    -
    - -
    - -
    - -
    - This process runs in the background. - -
    -
    - - - - - - - - -

    Import Last.FM Artists

    - - -
    - <% - if headphones.LASTFM_USERNAME: - lastfmvalue = headphones.LASTFM_USERNAME - else: - lastfmvalue = 'Last.fm Username' - %> - - -
    -
    -
    - -
    - diff --git a/data/interfaces/brink/managealbums.html b/data/interfaces/brink/managealbums.html deleted file mode 100644 index 7d2121f0..00000000 --- a/data/interfaces/brink/managealbums.html +++ /dev/null @@ -1,147 +0,0 @@ -<%inherit file="base.html" /> -<%! - from headphones import db - import headphones -%> - - -<%def name="body()"> - -
    -
    -
    Mark selected albums as - - -
    - - - - - - - - - - - - - - - - %for album in albums: - <% - if album['Status'] == 'Skipped': - grade = 'Z' - elif album['Status'] == 'Wanted': - grade = 'X' - elif album['Status'] == 'Snatched': - grade = 'C' - else: - grade = 'A' - - myDB = db.DBConnection() - totaltracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=?', [album['AlbumID']])) - havetracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=? AND Location IS NOT NULL', [album['AlbumID']])) + len(myDB.select('SELECT TrackTitle from have WHERE ArtistName like ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']])) - - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - avgbitrate = myDB.action("SELECT AVG(BitRate) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if avgbitrate: - bitrate = str(int(avgbitrate)/1000) + ' kbps' - else: - bitrate = '' - - albumformatcount = myDB.action("SELECT COUNT(DISTINCT Format) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if albumformatcount == 1: - albumformat = myDB.action("SELECT DISTINCT Format FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - elif albumformatcount > 1: - albumformat = 'Mixed' - else: - albumformat = '' - - lossy_formats = [str.upper(fmt) for fmt in headphones.LOSSY_MEDIA_FORMATS] - - %> - - - - - - - - - - - - %endfor - -
    AlbumArtistDateTypeStatusHaveBitrateFormat
    ${album['AlbumTitle']}${album['ArtistName']}${album['ReleaseDate']}${album['Type']}${album['Status']}
    ${havetracks}/${totaltracks}
    ${bitrate}${albumformat}
    -
    -
    - - -<%def name="headIncludes()"> - - -<%def name="javascriptIncludes()"> - - - - diff --git a/data/interfaces/brink/manageartists.html b/data/interfaces/brink/manageartists.html deleted file mode 100644 index 3fabadee..00000000 --- a/data/interfaces/brink/manageartists.html +++ /dev/null @@ -1,105 +0,0 @@ -<%inherit file="base.html" /> -<%! - from headphones import db - import headphones -%> - -<%def name="body()"> - -
    -

    - - selected artists - -

    - - - - - - - - - - - %for artist in artists: - <% - if artist['Status'] == 'Paused': - grade = 'X' - elif artist['Status'] == 'Loading': - grade = 'C' - else: - grade = 'Z' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - elif artist['LatestAlbum']: - releasedate = '' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - albumdisplay = 'None' - %> - - - - - - - %endfor - -
    StatusArtist NameLatest Album
    - - %if artist['Status'] == 'Paused': - - %elif artist['Status'] == 'Loading': - - %elif artist['Status'] == 'Active': - - %else: - - %endif - ${artist['Status']} - ${artist['ArtistName']}${albumdisplay}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/managenew.html b/data/interfaces/brink/managenew.html deleted file mode 100644 index 54d82339..00000000 --- a/data/interfaces/brink/managenew.html +++ /dev/null @@ -1,52 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones -%> -<%def name="body()"> - -
    -

    - Add selected artists - -

    - - - - - - - - - %for artist in headphones.NEW_ARTISTS: - - - - - %endfor - -
    Artist Name
    ${artist}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/searchresults.html b/data/interfaces/brink/searchresults.html deleted file mode 100644 index 95a9799a..00000000 --- a/data/interfaces/brink/searchresults.html +++ /dev/null @@ -1,106 +0,0 @@ -<%inherit file="base.html" /> - -<%def name="body()"> - - - - - - %if type == 'album': - - - %elif type == 'artist': - - %endif - - - - - - - %if searchresults: - %for result in searchresults: - <% - if result['score'] == 100: - grade = 'A' - else: - grade = 'Z' - %> - - - %if type == 'album': - - - %elif type == 'artist': - - %endif - - - %if type == 'album': - - %elif type == 'artist': - - %endif - - %endfor - %endif - -
    Album NameArtist NameScore
    -
    - -
    -
    ${result['title']} - -
    - ${result['uniquename']} -
    -
    ${result['uniquename']} -
    -
    - ${result['score']}% -
    -
    -
    -
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/brink/shutdown.html b/data/interfaces/brink/shutdown.html deleted file mode 100644 index 027d6a53..00000000 --- a/data/interfaces/brink/shutdown.html +++ /dev/null @@ -1,20 +0,0 @@ -<%inherit file="base.html"/> - -<%def name="headIncludes()"> - - - -<%def name="body()"> -
    -
    -
    -
    -

    ${message}

    -
    -
    -

    Estimate ${timer} seconds

    -
    -
    -
    -
    - \ No newline at end of file diff --git a/data/interfaces/brink/upcoming.html b/data/interfaces/brink/upcoming.html deleted file mode 100644 index 87ecaf63..00000000 --- a/data/interfaces/brink/upcoming.html +++ /dev/null @@ -1,144 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -
    -

    OUpcoming Albums

    - - - - - - - - - - - - %for album in upcoming: - - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateType
    -
    - - - -
    -
    - - ${album['ArtistName']} - - ${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}
    -
    - -
    -
    -

    Mark selected albums as - - -

    -
    -
    -

    NWanted Albums

    - - - - - - - - - - - - - %for album in wanted: - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateType
    - -
    - -
    - %if album['Status'] == 'Wanted': - / - - %else: - * - - %endif -
    -
    -
    - - ${album['ArtistName']} - ${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}
    - -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/album.html b/data/interfaces/classic/album.html deleted file mode 100644 index 16c1a4ef..00000000 --- a/data/interfaces/classic/album.html +++ /dev/null @@ -1,136 +0,0 @@ -<%inherit file="base.html" /> -<%! - from headphones import db, helpers - myDB = db.DBConnection() -%> - -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    <- Back to ${album['ArtistName']}

    -
    - albumart -

    ${album['AlbumTitle']}

    -

    ${album['ArtistName']}

    -
    - <% - totalduration = myDB.action("SELECT SUM(TrackDuration) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - totaltracks = len(myDB.select("SELECT TrackTitle from tracks WHERE AlbumID=?", [album['AlbumID']])) - try: - albumduration = helpers.convert_milliseconds(totalduration) - except: - albumduration = 'n/a' - - %> -

    Tracks: ${totaltracks}

    -

    Duration: ${albumduration}

    - %if description: -

    Description:

    - ${description['Summary']} - %endif -
    -
    - - - - - - - - - - - - - %for track in tracks: - <% - if track['Location']: - grade = 'A' - location = track['Location'] - else: - grade = 'X' - location = '' - - if track['BitRate']: - bitrate = str(track['BitRate']/1000) + ' kbps' - else: - bitrate = '' - - try: - trackduration = helpers.convert_milliseconds(track['TrackDuration']) - except: - trackduration = 'n/a' - - if not track['Format']: - format = 'Unknown' - else: - format = track['Format'] - %> - - - - - - - - - %endfor - <% - unmatched = myDB.select('SELECT * from have WHERE ArtistName LIKE ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']]) - %> - %if unmatched: - %for track in unmatched: - <% - duration = helpers.convert_seconds(float(track['TrackLength'])) - %> - - - - - - - - - %endfor - %endif - -
    #Track TitleDurationLocal FileBit RateFormat
    ${track['TrackNumber']}${track['TrackTitle']}${trackduration}${location}${bitrate}${format}
    ${track['TrackNumber']}${track['TrackTitle']}${duration}${track['Location']}${int(track['BitRate'])/1000} kbps${track['Format']}
    -
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/classic/artist.html b/data/interfaces/classic/artist.html deleted file mode 100644 index 98b539ad..00000000 --- a/data/interfaces/classic/artist.html +++ /dev/null @@ -1,165 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import db - import headphones -%> - -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    ${artist['ArtistName']}

    - %if artist['Status'] == 'Loading': -

    (Album information for this artist is currently being loaded)

    - %endif -
    - -

    Mark selected albums as - - -

    - - - - - - - - - - - - - - - - %for album in albums: - <% - if album['Status'] == 'Skipped': - grade = 'Z' - elif album['Status'] == 'Wanted': - grade = 'X' - elif album['Status'] == 'Snatched': - grade = 'C' - else: - grade = 'A' - - myDB = db.DBConnection() - totaltracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=?', [album['AlbumID']])) - havetracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=? AND Location IS NOT NULL', [album['AlbumID']])) + len(myDB.select('SELECT TrackTitle from have WHERE ArtistName like ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']])) - - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - avgbitrate = myDB.action("SELECT AVG(BitRate) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if avgbitrate: - bitrate = str(int(avgbitrate)/1000) + ' kbps' - else: - bitrate = '' - - albumformatcount = myDB.action("SELECT COUNT(DISTINCT Format) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if albumformatcount == 1: - albumformat = myDB.action("SELECT DISTINCT Format FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - elif albumformatcount > 1: - albumformat = 'Mixed' - else: - albumformat = '' - - lossy_formats = [str.upper(fmt) for fmt in headphones.LOSSY_MEDIA_FORMATS] - - %> - - - - - - - - - - - - %endfor - -
    NameDateTypeStatusHaveBitrateFormat
    ${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}${album['Status']} - %if album['Status'] == 'Skipped': - [want] - %elif (album['Status'] == 'Wanted' or album['Status'] == 'Wanted Lossless'): - [skip] - %else: - [retry][new] - %endif - %if albumformat in lossy_formats and album['Status'] == 'Skipped': - [want lossless] - %elif albumformat in lossy_formats and (album['Status'] == 'Snatched' or album['Status'] == 'Downloaded'): - [retry lossless] - %endif -
    ${havetracks}/${totaltracks}
    ${bitrate}${albumformat}
    -
    - - -<%def name="headIncludes()"> - - %if artist['Status'] == 'Loading': - - %endif - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/classic/base.html b/data/interfaces/classic/base.html deleted file mode 100644 index 7053f803..00000000 --- a/data/interfaces/classic/base.html +++ /dev/null @@ -1,107 +0,0 @@ -<% - import headphones - from headphones import version -%> - - - - - - - - - - - Headphones - ${title} - - - - - - - - - ${next.headIncludes()} - - - - -
    -
    - % if not headphones.CURRENT_VERSION: -
    - You're running an unknown version of Headphones. Click here to update -
    - % elif headphones.CURRENT_VERSION != headphones.LATEST_VERSION and headphones.INSTALL_TYPE != 'win': -
    - A newer version is available. You're ${headphones.COMMITS_BEHIND} commits behind. Click here to update -
    - % endif - - - -
    - ${next.headerIncludes()} -
    -
    - -
    - ${next.body()} -
    - -
    -
    - Version: ${headphones.CURRENT_VERSION} - %if version.HEADPHONES_VERSION != 'master': - (${version.HEADPHONES_VERSION}) - %endif -
    - -
    -
    - - - - ${next.javascriptIncludes()} - - - - - - - - -<%def name="javascriptIncludes()"> -<%def name="headIncludes()"> -<%def name="headerIncludes()"> diff --git a/data/interfaces/classic/config.html b/data/interfaces/classic/config.html deleted file mode 100644 index eb024f5c..00000000 --- a/data/interfaces/classic/config.html +++ /dev/null @@ -1,697 +0,0 @@ -<%inherit file="base.html"/> -<%! - import headphones -%> - -<%def name="headerIncludes()"> -
    - -
    - -<%def name="body()"> -
    -

    -

    -
    -
    -

    Web Interface

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    HTTP Host:

    -
    - e.g. localhost or 0.0.0.0 -
    -

    HTTP Username:

    - -
    -

    HTTP Port:

    - -
    -

    HTTP Password:

    - -
    -

    Launch Browser on Startup:

    -
    -

    Enable API:

    -
    -
    -

    API key:



    -
    -
    -

    NZB Search Interval:

    - mins -
    -

    Download Scan Interval:

    - mins -
    -

    Library Scan Interval:

    - mins -
    -
    -
    -

    Download Settings

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    SABnzbd:

    -
    -

    SABnzbd Host:


    - - usually http://localhost:8080 -
    -

    SABnzbd Username:

    -
    -

    SABnzbd API:

    -
    -

    SABnzbd Password:

    -
    -

    SABnzbd Category:

    -
    -

    Music Download Directory:


    - - Full path to the directory where SAB or NZBget downloads your music
    - e.g. /Users/name/Downloads/music
    -
    -

    NZBget:

    -
    -

    NZBget Host:


    - - usually http://localhost:6789 -
    -

    NZBget Username:

    -
    -

    NZBget Password:

    -
    -

    NZBget Category:

    -
    -

    Use Black Hole:

    -
    -

    Black Hole Directory:


    - - Folder your Download program watches for NZBs -
    -

    Usenet Retention:

    -
    -



    Torrent:

    -
    -

    Black Hole Directory:


    - - Folder your Download program watches for Torrents -
    -

    Minimum seeders:


    - - Number of minimum seeders a torrent must have to be accepted -
    -

    Music Download Directory:


    - - Full path to the directory where your torrent client downloads your music
    - e.g. /Users/name/Downloads/music
    -
    -
    -
    -

    Search Providers

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    SABnzbd:

    -
    -

    NZBMatrix:

    -
    -

    NZBMatrix Username:

    - -
    -

    NZBMatrix API:

    - -
    -

    Newznab:

    -
    -

    Newznab Host:

    -
    - e.g. http://nzb.su -
    -

    Newznab API:

    - -
    -

    NZBs.org:

    -
    - -

    NZBs.org API Key:

    - - -
    -

    Newzbin:

    -
    -

    Newzbin UID:

    - - -
    -

    Newzbin Password:

    - -
    -

    Torrent:


    -
    -

    Isohunt:


    -
    -

    Mininova:


    -
    -

    Kick Ass Torrents:

    -
    -
    -
    -

    Quality & Post Processing

    - - - - - - - - - - -
    -

    Album Quality:


    -

    Highest Quality excluding Lossless

    -

    Highest Quality including Lossless

    -

    Lossless Only

    -

    Preferred Bitrate: - kbps

    - Auto-Detect Preferred Bitrate -
    -

    Post-Processing:

    -

    Move downloads to Destination Folder

    -

    Rename files

    -

    Correct metadata

    -

    Delete leftover files (.m3u, .nfo, .sfv, .nzb, etc.)

    -

    Add album art as 'folder.jpg' to album folder

    -

    Embed album art in each file

    -

    Embed lyrics

    -
    -
    - -

    Path to Destination folder:

    -
    - e.g. /Users/name/Music/iTunes or /Volumes/share/music -
    -
    -
    -

    Advanced Settings

    - - - - - - - - - - - - - -
    -

    Renaming Options:

    -
    -

    Folder Format:


    - Use: $Artist/$artist, $Album/$album, $Year/$year, $Type/$type (release type) and $First/$first (first letter in artist name)
    - E.g.: $Type/$First/$artist/$album [$year] = Album/G/girl talk/all day [2010]
    -

    -

    File Format:

    -
    - Use: $Disc/$disc (disc #), $Track/$track (track #), $Title/$title, $Artist/$artist, $Album/$album and $Year/$year -
    -

    Miscellaneous:

    -
    -

    Automatically Include Extras When Adding an Artist

    - (EPs, Compilations, Live Albums, Remix Albums and Singles) -

    Automatically Mark Upcoming Albums as Wanted

    -

    Automatically Mark All Albums as Wanted

    -
    -

    Interface: -

    -

    Log Directory:

    -

    -

    Cache Directory:

    -
    -

    Re-Encoding Options:

    - Note: this option requires the lame or ffmpeg encoder -

    -

    Re-encode downloads during postprocessing

    -
    -
    -

    Only re-encode lossless files (.flac)

    -
    - <% - if config['encoder'] == 'lame': - lameselect = 'selected="selected"' - ffmpegselect = '' - else: - lameselect = '' - ffmpegselect = 'selected="selected"' - %> -

    Encoder: - - Format:

    -
    - -

    Audio Properties:

    -
    -

    VBR/CBR: - - Quality:

    - -
    -

    Bitrate: - - <% - if config["samplingfrequency"] == 44100: - freq44100 = 'selected="selected"' - freq48000 = '' - else: - freq44100 = '' - freq48000 = 'selected="selected"' - %> - Sampling:

    -
    -
    -

    Advanced Encoding Options:

    -

    - (ignores audio properties) -

    - -
    -

    Path to Encoder:

    -
    -
    -

    Notifications:


    -

    Enable Prowl Notifications


    -
    -

    API key:



    -

    Notify on snatch?


    -

    Priority (-2,-1,0,1 or 2):



    -
    -

    Enable XBMC Updates


    -
    -

    XBMC Host:Port:


    - e.g. http://localhost:8080. Separate hosts with commas
    -

    XBMC Username:



    -

    XBMC Password:



    -

    Update XBMC Library


    -

    Send Notification to XBMC


    -
    -

    Enable NotifyMyAndroid


    -
    -

    NotifyMyAndroid API Key:


    - Separate multiple api keys with commas
    -

    Priority: -

    -

    -
    -

    Muscbrainz Mirror: - -
    -

    Host:

    -

    Port:

    -

    Sleep Interval:

    -
    - -
    -

    Username:

    -

    Password:

    - Get an Account

    -
    -

    -
    - -


    - (Web Interface changes require a restart to take effect) - - - -<%def name="javascriptIncludes()"> - - diff --git a/data/interfaces/classic/extras.html b/data/interfaces/classic/extras.html deleted file mode 100644 index d9dbbe2f..00000000 --- a/data/interfaces/classic/extras.html +++ /dev/null @@ -1,13 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -

    -

    Artists You Might Like

    -
    - -
    -
    - diff --git a/data/interfaces/classic/history.html b/data/interfaces/classic/history.html deleted file mode 100644 index ac7c4f6d..00000000 --- a/data/interfaces/classic/history.html +++ /dev/null @@ -1,85 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="headerIncludes()"> - - - -<%def name="body()"> -
    - History -
    - - - - - - - - - - - - %for item in history: - <% - if item['Status'] == 'Processed': - grade = 'A' - elif item['Status'] == 'Snatched': - grade = 'C' - elif item['Status'] == 'Unprocessed': - grade = 'X' - else: - grade = 'U' - - fileid = 'unknown' - if item['URL'].find('nzb') != -1: - fileid = 'nzb' - if item['URL'].find('torrent') != -1: - fileid = 'torrent' - %> - - - - - - - - %endfor - -
    Date AddedFile NameSizeStatus
    ${item['DateAdded']}${item['Title']} [${fileid}][album page]${helpers.bytes_to_mb(item['Size'])}${item['Status']}[retry][new]
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/index.html b/data/interfaces/classic/index.html deleted file mode 100644 index 83a594b6..00000000 --- a/data/interfaces/classic/index.html +++ /dev/null @@ -1,86 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="body()"> - - - - - - - - - - - %for artist in artists: - <% - totaltracks = artist['TotalTracks'] - havetracks = artist['HaveTracks'] - if not havetracks: - havetracks = 0 - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - if releasedate > helpers.today(): - grade = 'A' - else: - grade = 'Z' - elif artist['LatestAlbum']: - releasedate = '' - grade = 'Z' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - grade = 'Z' - albumdisplay = 'None' - - if artist['Status'] == 'Paused': - grade = 'X' - - %> - - - - - - - %endfor - -
    Artist NameStatusLatest AlbumHave
    ${artist['ArtistName']}${artist['Status']}${albumdisplay}
    ${havetracks}/${totaltracks}
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/logs.html b/data/interfaces/classic/logs.html deleted file mode 100644 index 98004034..00000000 --- a/data/interfaces/classic/logs.html +++ /dev/null @@ -1,60 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="body()"> - - - - - - - - - - %for line in lineList: - <% - timestamp, message, level, threadname = line - - if level == 'WARNING' or level == 'ERROR': - grade = 'X' - else: - grade = 'Z' - %> - - - - - - %endfor - -
    TimestampLevelMessage
    ${timestamp}${level}${message}
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/manage.html b/data/interfaces/classic/manage.html deleted file mode 100644 index cf5a476a..00000000 --- a/data/interfaces/classic/manage.html +++ /dev/null @@ -1,74 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones - from headphones.helpers import checked -%> -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    -

    -
    -

    Scan Music Library


    - Where do you keep your music?

    - You can put in any directory, and it will scan for audio files in that folder - (including all subdirectories)

    For example: '/Users/name/Music' -

    - It may take a while depending on how many files you have. You can navigate away from the page
    - as soon as you click 'Submit' -

    -
    - %if headphones.MUSIC_DIR: - - %else: - - %endif -
    -

    Automatically add new artists

    -

    -
    -
    - -
    -

    Import Last.FM Artists


    - Enter the username whose artists you want to import:

    -
    - <% - if headphones.LASTFM_USERNAME: - lastfmvalue = headphones.LASTFM_USERNAME - else: - lastfmvalue = 'Last.fm Username' - %> - -


    -
    - -
    -

    Placeholder :-)


    -

    -
    - -


    -
    - - - \ No newline at end of file diff --git a/data/interfaces/classic/manageartists.html b/data/interfaces/classic/manageartists.html deleted file mode 100644 index 368d653c..00000000 --- a/data/interfaces/classic/manageartists.html +++ /dev/null @@ -1,82 +0,0 @@ -<%inherit file="base.html" /> - -<%def name="body()"> -
    -

    Manage Artists

    -

    -
    -

    - - selected artists - -

    - - - - - - - - - - - %for artist in artists: - <% - if artist['Status'] == 'Paused': - grade = 'X' - elif artist['Status'] == 'Loading': - grade = 'C' - else: - grade = 'Z' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - elif artist['LatestAlbum']: - releasedate = '' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - albumdisplay = 'None' - %> - - - - - - - %endfor - -
    Artist NameStatusLatest Album
    ${artist['ArtistName']}${artist['Status']}${albumdisplay}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/managenew.html b/data/interfaces/classic/managenew.html deleted file mode 100644 index ac329cda..00000000 --- a/data/interfaces/classic/managenew.html +++ /dev/null @@ -1,52 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones -%> -<%def name="body()"> -
    -

    Manage New Artists

    -

    Scan Music Library

    -
    -
    -

    - Add selected artists - -

    - - - - - - - - - %for artist in newartists: - - - - - %endfor - -
    Artist Name
    ${artist['ArtistName']}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/classic/searchresults.html b/data/interfaces/classic/searchresults.html deleted file mode 100644 index b02fedd6..00000000 --- a/data/interfaces/classic/searchresults.html +++ /dev/null @@ -1,70 +0,0 @@ -<%inherit file="base.html" /> - -<%def name="body()"> - -
    -

    Search Results

    -

    - - - - %if type == 'album': - - %endif - - - - - - - %if searchresults: - %for result in searchresults: - <% - if result['score'] == 100: - grade = 'A' - else: - grade = 'Z' - %> - - %if type == 'album': - - %endif - - - %if type == 'album': - - %else: - - %endif - - %endfor - %endif - -
    Album NameArtist NameScore
    ${result['title']}${result['uniquename']}${result['score']}Add this albumAdd this artist
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/classic/shutdown.html b/data/interfaces/classic/shutdown.html deleted file mode 100644 index be7ca21d..00000000 --- a/data/interfaces/classic/shutdown.html +++ /dev/null @@ -1,13 +0,0 @@ -<%inherit file="base.html"/> - -<%def name="headIncludes()"> - - - -<%def name="body()"> -
    -
    -

    Headphones is ${message}

    -
    -
    - \ No newline at end of file diff --git a/data/interfaces/classic/upcoming.html b/data/interfaces/classic/upcoming.html deleted file mode 100644 index 5c209056..00000000 --- a/data/interfaces/classic/upcoming.html +++ /dev/null @@ -1,86 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -
    -

    Upcoming Albums

    - - - - - - - - - - - - - %for album in upcoming: - - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateTypeStatus
    ${album['ArtistName']}${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}${album['Status']}
    -
    - -
    -

    Mark selected albums as - - -

    -
    -

    Wanted Albums

    - - - - - - - - - - - - - %for album in wanted: - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateType
    - ${album['ArtistName']}${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}
    - -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/album.html b/data/interfaces/remix/album.html deleted file mode 100644 index b5ba0d9d..00000000 --- a/data/interfaces/remix/album.html +++ /dev/null @@ -1,128 +0,0 @@ -<%inherit file="base.html" /> -<%! - from headphones import db, helpers - myDB = db.DBConnection() -%> - -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    <- Back to ${album['ArtistName']}

    -
    - albumart -

    ${album['AlbumTitle']}

    -

    ${album['ArtistName']}

    -
    - <% - totalduration = myDB.action("SELECT SUM(TrackDuration) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - totaltracks = len(myDB.select("SELECT TrackTitle from tracks WHERE AlbumID=?", [album['AlbumID']])) - try: - albumduration = helpers.convert_milliseconds(totalduration) - except: - albumduration = 'n/a' - - %> -

    Tracks: ${totaltracks}

    -

    Duration: ${albumduration}

    - %if description: -

    Description:

    - ${description['Summary']} - %endif -
    -
    - - - - - - - - - - - - %for track in tracks: - <% - if track['Location']: - grade = 'A' - location = track['Location'] - else: - grade = 'X' - location = '' - - if track['BitRate']: - bitrate = str(track['BitRate']/1000) + ' kbps' - else: - bitrate = '' - - try: - trackduration = helpers.convert_milliseconds(track['TrackDuration']) - except: - trackduration = 'n/a' - %> - - - - - - - - %endfor - <% - unmatched = myDB.select('SELECT * from have WHERE ArtistName LIKE ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']]) - %> - %if unmatched: - %for track in unmatched: - <% - duration = helpers.convert_seconds(float(track['TrackLength'])) - %> - - - - - - - - %endfor - %endif - -
    #Track TitleDurationLocal FileBit Rate
    ${track['TrackNumber']}${track['TrackTitle']}${trackduration}${location}${bitrate}
    ${track['TrackNumber']}${track['TrackTitle']}${duration}${track['Location']}${int(track['BitRate'])/1000} kbps
    -
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/remix/artist.html b/data/interfaces/remix/artist.html deleted file mode 100644 index 40d6dfa7..00000000 --- a/data/interfaces/remix/artist.html +++ /dev/null @@ -1,162 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import db - import headphones -%> - -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    ${artist['ArtistName']}

    - %if artist['Status'] == 'Loading': -

    (Album information for this artist is currently being loaded)

    - %endif -
    - -

    Mark selected albums as - - -

    - - - - - - - - - - - - - - - - %for album in albums: - <% - if album['Status'] == 'Skipped': - grade = 'Z' - elif album['Status'] == 'Wanted': - grade = 'X' - elif album['Status'] == 'Snatched': - grade = 'C' - else: - grade = 'A' - - myDB = db.DBConnection() - totaltracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=?', [album['AlbumID']])) - havetracks = len(myDB.select('SELECT TrackTitle from tracks WHERE AlbumID=? AND Location IS NOT NULL', [album['AlbumID']])) + len(myDB.select('SELECT TrackTitle from have WHERE ArtistName like ? AND AlbumTitle LIKE ?', [album['ArtistName'], album['AlbumTitle']])) - - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - avgbitrate = myDB.action("SELECT AVG(BitRate) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if avgbitrate: - bitrate = str(int(avgbitrate)/1000) + ' kbps' - else: - bitrate = '' - - albumformatcount = myDB.action("SELECT COUNT(DISTINCT Format) FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - if albumformatcount == 1: - albumformat = myDB.action("SELECT DISTINCT Format FROM tracks WHERE AlbumID=?", [album['AlbumID']]).fetchone()[0] - elif albumformatcount > 1: - albumformat = 'Mixed' - else: - albumformat = '' - - lossy_formats = [str.upper(fmt) for fmt in headphones.LOSSY_MEDIA_FORMATS] - - %> - - - - - - - - - - - - %endfor - -
    NameDateTypeStatusHaveBitrateFormat
    ${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}${album['Status']} - %if album['Status'] == 'Skipped': - [want] - %elif (album['Status'] == 'Wanted' or album['Status'] == 'Wanted Lossless'): - [skip] - %else: - [retry][new] - %endif - %if albumformat in lossy_formats and album['Status'] == 'Skipped': - [want lossless] - %elif albumformat in lossy_formats and (album['Status'] == 'Snatched' or album['Status'] == 'Downloaded'): - [retry lossless] - %endif -
    ${havetracks}/${totaltracks}
    ${bitrate}${albumformat}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/remix/base.html b/data/interfaces/remix/base.html deleted file mode 100644 index 5476e27d..00000000 --- a/data/interfaces/remix/base.html +++ /dev/null @@ -1,107 +0,0 @@ -<% - import headphones - from headphones import version -%> - - - - - - - - - - - Headphones::Remix - ${title} - - - - - - - - - ${next.headIncludes()} - - - - -
    -
    - % if not headphones.CURRENT_VERSION: -
    - You're running an unknown version of Headphones. Click here to update -
    - % elif headphones.CURRENT_VERSION != headphones.LATEST_VERSION and headphones.INSTALL_TYPE != 'win': -
    - A newer version is available. You're ${headphones.COMMITS_BEHIND} commits behind. Click here to update -
    - % endif - - - -
    - ${next.headerIncludes()} -
    -
    - -
    - ${next.body()} -
    - -
    -
    - Version: ${headphones.CURRENT_VERSION} - %if version.HEADPHONES_VERSION != 'master': - (${version.HEADPHONES_VERSION}) - %endif -
    - -
    -
    - - - - ${next.javascriptIncludes()} - - - - - - - - -<%def name="javascriptIncludes()"> -<%def name="headIncludes()"> -<%def name="headerIncludes()"> diff --git a/data/interfaces/remix/config.html b/data/interfaces/remix/config.html deleted file mode 100644 index 7f78d03e..00000000 --- a/data/interfaces/remix/config.html +++ /dev/null @@ -1,697 +0,0 @@ -<%inherit file="base.html"/> -<%! - import headphones -%> - -<%def name="headerIncludes()"> -
    - -
    - -<%def name="body()"> -
    -

    -

    -
    -
    -

    Web Interface

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    HTTP Host:

    -
    - e.g. localhost or 0.0.0.0 -
    -

    HTTP Username:

    - -
    -

    HTTP Port:

    - -
    -

    HTTP Password:

    - -
    -

    Launch Browser on Startup:

    -
    -

    Enable API:

    -
    -
    -

    API key:



    -
    -
    -

    NZB Search Interval:

    - mins -
    -

    Download Scan Interval:

    - mins -
    -

    Library Scan Interval:

    - mins -
    -
    -
    -

    Download Settings

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    SABnzbd:

    -
    -

    SABnzbd Host:


    - - usually http://localhost:8080 -
    -

    SABnzbd Username:

    -
    -

    SABnzbd API:

    -
    -

    SABnzbd Password:

    -
    -

    SABnzbd Category:

    -
    -

    Music Download Directory:


    - - Full path to the directory where SAB or NZBget downloads your music
    - e.g. /Users/name/Downloads/music
    -
    -

    NZBget:

    -
    -

    NZBget Host:


    - - usually http://localhost:6789 -
    -

    NZBget Username:

    -
    -

    NZBget Password:

    -
    -

    NZBget Category:

    -
    -

    Use Black Hole:

    -
    -

    Black Hole Directory:


    - - Folder your Download program watches for NZBs -
    -

    Usenet Retention:

    -
    -



    Torrent:

    -
    -

    Black Hole Directory:


    - - Folder your Download program watches for Torrents -
    -

    Minimum seeders:


    - - Number of minimum seeders a torrent must have to be accepted -
    -

    Music Download Directory:


    - - Full path to the directory where your torrent client downloads your music
    - e.g. /Users/name/Downloads/music
    -
    -
    -
    -

    Search Providers

    - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - - -
    -

    SABnzbd:

    -
    -

    NZBMatrix:

    -
    -

    NZBMatrix Username:

    - -
    -

    NZBMatrix API:

    - -
    -

    Newznab:

    -
    -

    Newznab Host:

    -
    - e.g. http://nzb.su -
    -

    Newznab API:

    - -
    -

    NZBs.org:

    -
    - -

    NZBs.org API Key:

    - - -
    -

    Newzbin:

    -
    -

    Newzbin UID:

    - - -
    -

    Newzbin Password:

    - -
    -

    Torrent:


    -
    -

    Isohunt:


    -
    -

    Mininova:


    -
    -

    Kick Ass Torrents:

    -
    -
    -
    -

    Quality & Post Processing

    - - - - - - - - - - -
    -

    Album Quality:


    -

    Highest Quality excluding Lossless

    -

    Highest Quality including Lossless

    -

    Lossless Only

    -

    Preferred Bitrate: - kbps

    - Auto-Detect Preferred Bitrate -
    -

    Post-Processing:

    -

    Move downloads to Destination Folder

    -

    Rename files

    -

    Correct metadata

    -

    Delete leftover files (.m3u, .nfo, .sfv, .nzb, etc.)

    -

    Add album art as 'folder.jpg' to album folder

    -

    Embed album art in each file

    -

    Embed lyrics

    -
    -
    - -

    Path to Destination folder:

    -
    - e.g. /Users/name/Music/iTunes or /Volumes/share/music -
    -
    -
    -

    Advanced Settings

    - - - - - - - - - - - - - -
    -

    Renaming Options:

    -
    -

    Folder Format:


    - Use: $Artist/$artist, $Album/$album, $Year/$year, $Type/$type (release type) and $First/$first (first letter in artist name)
    - E.g.: $Type/$First/$artist/$album [$year] = Album/G/girl talk/all day [2010]
    -

    -

    File Format:

    -
    - Use: $Disc/$disc (disc #), $Track/$track (track #), $Title/$title, $Artist/$artist, $Album/$album and $Year/$year -
    -

    Miscellaneous:

    -
    -

    Automatically Include Extras When Adding an Artist

    - (EPs, Compilations, Live Albums, Remix Albums and Singles) -

    Automatically Mark Upcoming Albums as Wanted

    -

    Automatically Mark All Albums as Wanted

    -
    -

    Interface: -

    -

    Log Directory:

    -

    -

    Cache Directory:

    -
    -

    Re-Encoding Options:

    - Note: this option requires the lame or ffmpeg encoder -

    -

    Re-encode downloads during postprocessing

    -
    -
    -

    Only re-encode lossless files (.flac)

    -
    - <% - if config['encoder'] == 'lame': - lameselect = 'selected="selected"' - ffmpegselect = '' - else: - lameselect = '' - ffmpegselect = 'selected="selected"' - %> -

    Encoder: - - Format:

    -
    - -

    Audio Properties:

    -
    -

    VBR/CBR: - - Quality:

    - -
    -

    Bitrate: - - <% - if config["samplingfrequency"] == 44100: - freq44100 = 'selected="selected"' - freq48000 = '' - else: - freq44100 = '' - freq48000 = 'selected="selected"' - %> - Sampling:

    -
    -
    -

    Advanced Encoding Options:

    -

    - (ignores audio properties) -

    - -
    -

    Path to Encoder:

    -
    -
    -

    Notifications:


    -

    Enable Prowl Notifications


    -
    -

    API key:



    -

    Notify on snatch?


    -

    Priority (-2,-1,0,1 or 2):



    -
    -

    Enable XBMC Updates


    -
    -

    XBMC Host:Port:


    - e.g. http://localhost:8080. Separate hosts with commas
    -

    XBMC Username:



    -

    XBMC Password:



    -

    Update XBMC Library


    -

    Send Notification to XBMC


    -
    -

    Enable NotifyMyAndroid


    -
    -

    NotifyMyAndroid API Key:


    - Separate multiple api keys with commas
    -

    Priority: -

    -

    -
    -

    Muscbrainz Mirror: - -
    -

    Host:

    -

    Port:

    -

    Sleep Interval:

    -
    - -
    -

    Username:

    -

    Password:

    - Get an Account

    -
    -

    -
    - -


    - (Web Interface changes require a restart to take effect) - - - -<%def name="javascriptIncludes()"> - - diff --git a/data/interfaces/remix/extras.html b/data/interfaces/remix/extras.html deleted file mode 100644 index d9dbbe2f..00000000 --- a/data/interfaces/remix/extras.html +++ /dev/null @@ -1,13 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -

    -

    Artists You Might Like

    -
    - -
    -
    - diff --git a/data/interfaces/remix/history.html b/data/interfaces/remix/history.html deleted file mode 100644 index ac7c4f6d..00000000 --- a/data/interfaces/remix/history.html +++ /dev/null @@ -1,85 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="headerIncludes()"> - - - -<%def name="body()"> -
    - History -
    - - - - - - - - - - - - %for item in history: - <% - if item['Status'] == 'Processed': - grade = 'A' - elif item['Status'] == 'Snatched': - grade = 'C' - elif item['Status'] == 'Unprocessed': - grade = 'X' - else: - grade = 'U' - - fileid = 'unknown' - if item['URL'].find('nzb') != -1: - fileid = 'nzb' - if item['URL'].find('torrent') != -1: - fileid = 'torrent' - %> - - - - - - - - %endfor - -
    Date AddedFile NameSizeStatus
    ${item['DateAdded']}${item['Title']} [${fileid}][album page]${helpers.bytes_to_mb(item['Size'])}${item['Status']}[retry][new]
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/index.html b/data/interfaces/remix/index.html deleted file mode 100644 index 83a594b6..00000000 --- a/data/interfaces/remix/index.html +++ /dev/null @@ -1,86 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="body()"> - - - - - - - - - - - %for artist in artists: - <% - totaltracks = artist['TotalTracks'] - havetracks = artist['HaveTracks'] - if not havetracks: - havetracks = 0 - try: - percent = (havetracks*100.0)/totaltracks - if percent > 100: - percent = 100 - except (ZeroDivisionError, TypeError): - percent = 0 - totaltracks = '?' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - if releasedate > helpers.today(): - grade = 'A' - else: - grade = 'Z' - elif artist['LatestAlbum']: - releasedate = '' - grade = 'Z' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - grade = 'Z' - albumdisplay = 'None' - - if artist['Status'] == 'Paused': - grade = 'X' - - %> - - - - - - - %endfor - -
    Artist NameStatusLatest AlbumHave
    ${artist['ArtistName']}${artist['Status']}${albumdisplay}
    ${havetracks}/${totaltracks}
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/logs.html b/data/interfaces/remix/logs.html deleted file mode 100644 index 98004034..00000000 --- a/data/interfaces/remix/logs.html +++ /dev/null @@ -1,60 +0,0 @@ -<%inherit file="base.html"/> -<%! - from headphones import helpers -%> - -<%def name="body()"> - - - - - - - - - - %for line in lineList: - <% - timestamp, message, level, threadname = line - - if level == 'WARNING' or level == 'ERROR': - grade = 'X' - else: - grade = 'Z' - %> - - - - - - %endfor - -
    TimestampLevelMessage
    ${timestamp}${level}${message}
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/manage.html b/data/interfaces/remix/manage.html deleted file mode 100644 index cf5a476a..00000000 --- a/data/interfaces/remix/manage.html +++ /dev/null @@ -1,74 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones - from headphones.helpers import checked -%> -<%def name="headerIncludes()"> -
    - -
    - - -<%def name="body()"> -
    -

    -

    -
    -

    Scan Music Library


    - Where do you keep your music?

    - You can put in any directory, and it will scan for audio files in that folder - (including all subdirectories)

    For example: '/Users/name/Music' -

    - It may take a while depending on how many files you have. You can navigate away from the page
    - as soon as you click 'Submit' -

    -
    - %if headphones.MUSIC_DIR: - - %else: - - %endif -
    -

    Automatically add new artists

    -

    -
    -
    - -
    -

    Import Last.FM Artists


    - Enter the username whose artists you want to import:

    -
    - <% - if headphones.LASTFM_USERNAME: - lastfmvalue = headphones.LASTFM_USERNAME - else: - lastfmvalue = 'Last.fm Username' - %> - -


    -
    - -
    -

    Placeholder :-)


    -

    -
    - -


    -
    - - - \ No newline at end of file diff --git a/data/interfaces/remix/manageartists.html b/data/interfaces/remix/manageartists.html deleted file mode 100644 index 368d653c..00000000 --- a/data/interfaces/remix/manageartists.html +++ /dev/null @@ -1,82 +0,0 @@ -<%inherit file="base.html" /> - -<%def name="body()"> -
    -

    Manage Artists

    -

    -
    -

    - - selected artists - -

    - - - - - - - - - - - %for artist in artists: - <% - if artist['Status'] == 'Paused': - grade = 'X' - elif artist['Status'] == 'Loading': - grade = 'C' - else: - grade = 'Z' - - if artist['ReleaseDate'] and artist['LatestAlbum']: - releasedate = artist['ReleaseDate'] - albumdisplay = '%s (%s)' % (artist['LatestAlbum'], artist['ReleaseDate']) - elif artist['LatestAlbum']: - releasedate = '' - albumdisplay = '%s' % artist['LatestAlbum'] - else: - releasedate = '' - albumdisplay = 'None' - %> - - - - - - - %endfor - -
    Artist NameStatusLatest Album
    ${artist['ArtistName']}${artist['Status']}${albumdisplay}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/managenew.html b/data/interfaces/remix/managenew.html deleted file mode 100644 index ac329cda..00000000 --- a/data/interfaces/remix/managenew.html +++ /dev/null @@ -1,52 +0,0 @@ -<%inherit file="base.html" /> -<%! - import headphones -%> -<%def name="body()"> -
    -

    Manage New Artists

    -

    Scan Music Library

    -
    -
    -

    - Add selected artists - -

    - - - - - - - - - %for artist in newartists: - - - - - %endfor - -
    Artist Name
    ${artist['ArtistName']}
    -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - diff --git a/data/interfaces/remix/searchresults.html b/data/interfaces/remix/searchresults.html deleted file mode 100644 index b02fedd6..00000000 --- a/data/interfaces/remix/searchresults.html +++ /dev/null @@ -1,70 +0,0 @@ -<%inherit file="base.html" /> - -<%def name="body()"> - -
    -

    Search Results

    -

    - - - - %if type == 'album': - - %endif - - - - - - - %if searchresults: - %for result in searchresults: - <% - if result['score'] == 100: - grade = 'A' - else: - grade = 'Z' - %> - - %if type == 'album': - - %endif - - - %if type == 'album': - - %else: - - %endif - - %endfor - %endif - -
    Album NameArtist NameScore
    ${result['title']}${result['uniquename']}${result['score']}Add this albumAdd this artist
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file diff --git a/data/interfaces/remix/shutdown.html b/data/interfaces/remix/shutdown.html deleted file mode 100644 index be7ca21d..00000000 --- a/data/interfaces/remix/shutdown.html +++ /dev/null @@ -1,13 +0,0 @@ -<%inherit file="base.html"/> - -<%def name="headIncludes()"> - - - -<%def name="body()"> -
    -
    -

    Headphones is ${message}

    -
    -
    - \ No newline at end of file diff --git a/data/interfaces/remix/style.css b/data/interfaces/remix/style.css deleted file mode 100644 index 43941305..00000000 --- a/data/interfaces/remix/style.css +++ /dev/null @@ -1,303 +0,0 @@ -/* HTML5 ✰ Boilerplate */ - -html, body, div, span, object, iframe, -h1, h2, h3, h4, h5, h6, p, blockquote, pre, -abbr, address, cite, code, del, dfn, em, img, ins, kbd, q, samp, -small, strong, sub, sup, var, b, i, dl, dt, dd, ol, ul, li, -fieldset, form, label, legend, -table, caption, tbody, tfoot, thead, tr, th, td, -article, aside, canvas, details, figcaption, figure, -footer, header, hgroup, menu, nav, section, summary, -time, mark, audio, video { - margin: 0; - padding: 0; - border: 0; - font-size: 100%; - font: inherit; - vertical-align: baseline; -} - -article, aside, details, figcaption, figure, -footer, header, hgroup, menu, nav, section { - display: block; -} - -blockquote, q { quotes: none; } -blockquote:before, blockquote:after, -q:before, q:after { content: ''; content: none; } -ins { background-color: #ff9; color: #000; text-decoration: none; } -mark { background-color: #ff9; color: #000; font-style: italic; font-weight: bold; } -del { text-decoration: line-through; } -abbr[title], dfn[title] { border-bottom: 1px dotted; cursor: help; } -table { border-collapse: collapse; border-spacing: 0; } -hr { display: block; height: 1px; border: 0; border-top: 1px solid #ccc; margin: 1em 0; padding: 0; } -input, select { vertical-align: middle; } - -body { font:13px/1.231 sans-serif; *font-size:small; } -select, input, textarea, button { font:99% sans-serif; } -pre, code, kbd, samp { font-family: monospace, sans-serif; } - -html { overflow-y: scroll; } -a:hover, a:active { outline: none; } -ul, ol { margin-left: 2em; } -ol { list-style-type: decimal; } -nav ul, nav li { margin: 0; list-style:none; list-style-image: none; } -small { font-size: 85%; } -strong, th { font-weight: bold; } -td { vertical-align: top; } - -sub, sup { font-size: 75%; line-height: 0; position: relative; } -sup { top: -0.5em; } -sub { bottom: -0.25em; } - -pre { white-space: pre; white-space: pre-wrap; word-wrap: break-word; padding: 15px; } -textarea { overflow: auto; } -.ie6 legend, .ie7 legend { margin-left: -7px; } -input[type="radio"] { vertical-align: text-bottom; } -input[type="checkbox"] { vertical-align: bottom; } -.ie7 input[type="checkbox"] { vertical-align: baseline; } -.ie6 input { vertical-align: text-bottom; } -label, input[type="button"], input[type="submit"], input[type="image"], button { cursor: pointer; } -button, input, select, textarea { margin: 0; } -input:valid, textarea:valid { } -input:invalid, textarea:invalid { border-radius: 1px; -moz-box-shadow: 0px 0px 5px red; -webkit-box-shadow: 0px 0px 5px red; box-shadow: 0px 0px 5px red; } -.no-boxshadow input:invalid, .no-boxshadow textarea:invalid { background-color: #f0dddd; } - -::-moz-selection{ background: grey; color:#fff; text-shadow: none; } -::selection { background: grey; color:#fff; text-shadow: none; } - -button { width: auto; overflow: visible; } -.ie7 img { -ms-interpolation-mode: bicubic; } - -body, select, input, textarea { color: #444; } -h1, h2, h3, h4, h5, h6 { font-weight: bold; } - -/* - // ========================================== \\ - || || - || Custom Styles || - || || - \\ ========================================== // -*/ - -a:link { - color: orange; - text-decoration: none; - } -a:visited { - color: orange; - text-decoration: none; - } -a:hover { /*this effect is not shown in NN4.xx*/ - color: #999999; - text-decoration: underline; - } -a:active {/*colour in NN4.xx is red*/ - color: #5E2612; - text-decoration: underline; - } -a.blue { - color: blue; - } - -container { } - -body { background-color: black; min-width: 935px; } - -header { min-height: 68px; width: 100%; min-width: 935px; padding-left: 0px; padding-right: 10px; background-color: #black; position: fixed; z-index: 998; } - -h1 { font-size: 24px; } -h2 { font-size: 20px; } -h3 { font-size: 16px; } - -p.indented { padding-top: 20px; margin-left: 20px; font-size: 14px; } -p.center { text-align: center; font-size: 18px; } -.smalltext2 { font-size: 11px; margin-left: 45px; } - -div#updatebar { text-align: center; min-width: 970px; width: 100%; background-color: light-blue; float: left; } -div#logo { float: left; padding-left: 10px; } - -ul#nav { margin: 25px 0 0 0; float: left; list-style-type: none; } -ul#nav li { margin: 40px 0px auto 10px; display: inline; } -ul#nav li a { padding: 5px; font-size: 16px; font-weight: bold; color: white; text-decoration: none; } -ul#nav li a:hover { background-color: #a3e532; } - -div#subhead_container { height: 30px; width:100%; min-width: 1000px; background-color: blue; float: left; list-style-type: none; z-index: 998; overflow: hidden; } -ul#subhead_menu { margin-top: 5px; } -ul#subhead_menu li { width: 100%; height: 100%; display: inline; } -ul#subhead_menu li a { padding: 5px 15px 10px 15px; vertical-align: middle; color: white; font-size: 16px; text-decoration: none; } -ul#subhead_menu li a:hover { width: 100%; height: 100%; background-color: #grey; } - -div#searchbar { margin: 24px 30px auto auto; float: right; } - -div#main { margin: 0; padding: 80px 0 0 0; } - -.table_wrapper { border-radius: 20px; -webkit-border-radius: 20px; -moz-border-radius: 20px; width: 88%; margin: 20px auto 0 auto; padding: 25px; background-color: white; position: relative; min-height: 200px; clear: both; _height: 302px; zoom: 1; } -.manage_wrapper { width: 88%; margin: 20px auto 0 auto; padding: 25px; min-height: 150px; clear: both; _height: 302px; zoom: 1; } -.table_wrapper_left { padding: 25px; background-color: #ffffff; float: left; width: 40%; min-height: 100px; margin-top: 25px; margin-left: 30px; margin-right: auto; -moz-border-radius: 20px; border-radius: 20px; } -.table_wrapper_right{ padding: 25px; background-color: #ffffff; width: 40%; min-height: 100px; margin-top: 25px; margin-left: auto; margin-right: 30px; -moz-border-radius: 20px; border-radius: 20px; } - -.configtable { font-size: 14px; line-height:18px; } -.configtable td { width: 350px; padding: 10px; } -.configtable td#middle { vertical-align: middle; } - -table#artist_table { background-color: white; width: 100%; padding: 20px; } - -table#artist_table th#name { text-align: left; min-width: 200px; } -table#artist_table th#status { text-align: left; min-width: 50px; } -table#artist_table th#album { text-align: left; min-width: 300px; } -table#artist_table th#have { text-align: center; } -table#artist_table td#name { vertical-align: middle; text-align: left; min-width:200px; } -table#artist_table td#status { vertical-align: middle; text-align: left; min-width: 50px; } -table#artist_table td#album { vertical-align: middle; text-align: left; min-width: 300px; } -table#artist_table td#have { vertical-align: middle; } - -div#paddingheader { padding-top: 48px; font-size: 24px; font-weight: bold; text-align: center; } -div#nopaddingheader { font-size: 24px; font-weight: bold; text-align: center; } -table#album_table { background-color: white; } - -table#album_table th#select { vertical-align: middle; text-align: left; min-width: 25px; } -table#album_table th#albumart { text-align: left; min-width: 50px; } -table#album_table th#albumname { text-align: center; min-width: 150px; } -table#album_table th#reldate { width: 175px; text-align: center; min-width: 100px; } -table#album_table th#status { width: 175px; text-align: center; min-width: 100px; } -table#album_table th#type { width: 175px; text-align: center; min-width: 100px; } -table#album_table th#bitrate { width: 175px; text-align: center; min-width: 60px; } -table#album_table th#albumformat { width: 175px; text-align: center; min-width: 60px; } -table#album_table td#select { vertical-align: middle; text-align: left; } -table#album_table td#albumart { vertical-align: middle; text-align: left; } -table#album_table td#albumname { vertical-align: middle; text-align: center; } -table#album_table td#reldate { vertical-align: middle; text-align: center; } -table#album_table td#status { vertical-align: middle; text-align: center; } -table#album_table td#status a#wantlossless { white-space: nowrap; } -table#album_table td#type { vertical-align: middle; text-align: center; } -table#album_table td#bitrate { vertical-align: middle; text-align: center; } -table#album_table td#albumformat { vertical-align: middle; text-align: center; } -table#album_table td#have { vertical-align: middle; } - -img.albumArt { float: left; padding-right: 5px; } -div#albumheader { padding-top: 48px; height: 200px; } -div#track_wrapper { padding-top: 20px; text-align: center; font-size: 16px; } - -table#track_table th#number { text-align: right; min-width: 20px; } -table#track_table th#name { text-align: center; min-width: 350px; } -table#track_table th#duration { width: 175px; text-align: center; min-width: 100px; } -table#track_table th#have { width: 175px; text-align: center; min-width: 100px; } - -table#track_table td#number { vertical-align: middle; text-align: right; } -table#track_table td#name { vertical-align: middle; text-align: center; } -table#track_table td#duration { vertical-align: middle; text-align: center; } -table#track_table td#have { vertical-align: middle; text-align: center; } - -table#history_table { background-color: white; width: 100%; } - -table#log_table { background-color: white; } - -table#log_table th#timestamp { text-align: left; min-width: 150px; } -table#log_table th#level { text-align: left; min-width: 60px; } -table#log_table th#message { text-align: left; min-width: 500px; } - -table#upcoming_table th#albumart { text-align: center; min-width: 50px; } -table#upcoming_table th#albumname { text-align: center; min-width: 200px; } -table#upcoming_table th#artistname { text-align: center; min-width: 150px; } -table#upcoming_table th#reldate { text-align: center; min-width: 100px; } -table#upcoming_table th#type { text-align: center; min-width: 75px; } - -table#upcoming_table td#select { vertical-align: middle; text-align: center; } -table#upcoming_table td#albumart { vertical-align: middle; text-align: center; min-width: 50px; } -table#upcoming_table td#albumname { vertical-align: middle; text-align: center; min-width: 200px; } -table#upcoming_table td#artistname { vertical-align: middle; text-align: center; min-width: 150px; } -table#upcoming_table td#reldate { vertical-align: middle; text-align: center; min-width: 100px; } -table#upcoming_table td#type { vertical-align: middle; text-align: center; min-width: 75px; } -table#upcoming_table td#status { vertical-align: middle; text-align: center; } - -table#wanted_table th#albumart { text-align: center; min-width: 50px; } -table#wanted_table th#albumname { text-align: center; min-width: 200px; } -table#wanted_table th#artistname { text-align: center; min-width: 150px; } -table#wanted_table th#reldate { text-align: center; min-width: 100px; } -table#wanted_table th#type { text-align: center; min-width: 75px; } - -table#wanted_table td#select { vertical-align: middle; text-align: center; } -table#wanted_table td#albumart { vertical-align: middle; text-align: center; min-width: 50px; } -table#wanted_table td#albumname { vertical-align: middle; text-align: center; min-width: 200px; } -table#wanted_table td#artistname { vertical-align: middle; text-align: center; min-width: 150px; } -table#wanted_table td#reldate { vertical-align: middle; text-align: center; min-width: 100px; } -table#wanted_table td#type { vertical-align: middle; text-align: center; min-width: 75px; } -table#wanted_table td#status { vertical-align: middle; text-align: center; } - -table#searchresults_table th#albumname { text-align: left; min-width: 225px; } -table#searchresults_table th#artistname { text-align: center; min-width: 325px; } -table#searchresults_table th#score { text-align: center; min-width: 75px; } - -table#searchresults_table td#albumname { vertical-align: middle; text-align: left; min-width: 200px; } -table#searchresults_table td#artistname { vertical-align: middle; text-align: left; min-width: 300px; } -table#searchresults_table td#score { vertical-align: middle; text-align: center; min-width: 75px; } - -div.progress-container { border: 1px solid #ccc; width: 100px; height: 14px; margin: 2px 5px 2px 0; padding: 1px; float: left; background: white; } -div.progress-container > div { background-color: #a3e532; height: 14px; } -.havetracks { font-size: 13px; margin-left: 36px; padding-bottom: 3px; vertical-align: middle; } - -footer { margin: 20px auto 20px auto; } -div#version { text-align: center; font-weight: bold; } -div#donate { text-align: center; margin: 20px auto 20px auto; } - -div#shutdown{ text-align: center; vertical-align: middle; } - -.cloudtag { padding-top: 30px; font-size:16px; } -#cloud a.tag1 { font-size: 0.7em; font-weight: 100; } -#cloud a.tag2 { font-size: 0.8em; font-weight: 200; } -#cloud a.tag3 { font-size: 0.9em; font-weight: 300; } -#cloud a.tag4 { font-size: 1.0em; font-weight: 400; } -#cloud a.tag5 { font-size: 1.2em; font-weight: 500; } -#cloud a.tag6 { font-size: 1.4em; font-weight: 600; } -#cloud a.tag7 { font-size: 1.6em; font-weight: 700; } -#cloud a.tag8 { font-size: 1.8em; font-weight: 800; } -#cloud a.tag9 { font-size: 2.2em; font-weight: 900; } -#cloud a.tag10 { font-size: 2.5em; font-weight: 900; } - -#cloud { padding: 2px; line-height: 1.5em; text-align: center; } -#cloud a { padding: 0px; } -#cloud { margin: 0; } -#cloud li { display: inline; } - - - -.ir { display: block; text-indent: -999em; overflow: hidden; background-repeat: no-repeat; text-align: left; direction: ltr; } -.hidden { display: none; visibility: hidden; } -.visuallyhidden { border: 0; clip: rect(0 0 0 0); height: 1px; margin: -1px; overflow: hidden; padding: 0; position: absolute; width: 1px; } -.visuallyhidden.focusable:active, -.visuallyhidden.focusable:focus { clip: auto; height: auto; margin: 0; overflow: visible; position: static; width: auto; } -.invisible { visibility: hidden; } -.clearfix:before, .clearfix:after { content: "\0020"; display: block; height: 0; overflow: hidden; } -.clearfix:after { clear: both; } -.clearfix { zoom: 1; } - - -@media all and (orientation:portrait) { - -} - -@media all and (orientation:landscape) { - -} - -@media screen and (max-device-width: 480px) { - - html { -webkit-text-size-adjust:none; -ms-text-size-adjust:none; } -} - - -@media print { - * { background: transparent !important; color: black !important; text-shadow: none !important; filter:none !important; - -ms-filter: none !important; } - a, a:visited { color: #444 !important; text-decoration: underline; } - a[href]:after { content: " (" attr(href) ")"; } - abbr[title]:after { content: " (" attr(title) ")"; } - .ir a:after, a[href^="javascript:"]:after, a[href^="#"]:after { content: ""; } - pre, blockquote { border: 1px solid #999; page-break-inside: avoid; } - thead { display: table-header-group; } - tr, img { page-break-inside: avoid; } - @page { margin: 0.5cm; } - p, h2, h3 { orphans: 3; widows: 3; } - h2, h3{ page-break-after: avoid; } -} diff --git a/data/interfaces/remix/upcoming.html b/data/interfaces/remix/upcoming.html deleted file mode 100644 index 5c209056..00000000 --- a/data/interfaces/remix/upcoming.html +++ /dev/null @@ -1,86 +0,0 @@ -<%inherit file="base.html" /> -<%def name="body()"> -
    -

    Upcoming Albums

    - - - - - - - - - - - - - %for album in upcoming: - - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateTypeStatus
    ${album['ArtistName']}${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}${album['Status']}
    -
    - -
    -

    Mark selected albums as - - -

    -
    -

    Wanted Albums

    - - - - - - - - - - - - - %for album in wanted: - - - - - - - - %endfor - -
    ArtistAlbum NameRelease DateType
    - ${album['ArtistName']}${album['AlbumTitle']}${album['ReleaseDate']}${album['Type']}
    - -
    - - -<%def name="headIncludes()"> - - - -<%def name="javascriptIncludes()"> - - - \ No newline at end of file From ad079e9ac9231f9a67f06e5e9c93a04271f9b8cc Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 6 Jul 2013 01:01:59 +0530 Subject: [PATCH 4/8] Initial changes to get NZBget working alongside sab & blackhole (mostly UI change, but updated logic --- data/interfaces/default/config.html | 111 ++++++++++++++++++---------- headphones/__init__.py | 12 ++- headphones/webserve.py | 18 ++--- 3 files changed, 86 insertions(+), 55 deletions(-) diff --git a/data/interfaces/default/config.html b/data/interfaces/default/config.html index 0979904d..1c89d2c9 100644 --- a/data/interfaces/default/config.html +++ b/data/interfaces/default/config.html @@ -104,9 +104,12 @@
    - + - + +
    +
    + + + Full path where SAB or NZBget downloads your music. e.g. /Users/name/Downloads/music +
    +
    +
    +
    + + + Folder your Download program watches for NZBs +
    +
    + +
    + +
    + @@ -367,9 +362,9 @@
    Quality
    - - - + + + Preferred Bitrate: kbps
    Reject if less than % or more than % of the target size (leave blank for no limit)

    @@ -1042,16 +1037,52 @@ { $("#preferred_bitrate_options").hide(); } - + + if ($("#nzb_downloader_sabnzbd").is(":checked")) + { + $("#sabnzbd_options,#nzb_download_dir").show(); + $("#nzbget_options,#blackhole_options").hide(); + } + if ($("#nzb_downloader_nzbget").is(":checked")) + { + $("#sabnzbd_options,#blackhole_options").hide(); + $("#nzbget_options,#nzb_download_dir").show(); + } + if ($("#nzb_downloader_blackhole").is(":checked")) + { + $("#sabnzbd_options,#nzbget_options,#nzb_download_dir").hide(); + $("#blackhole_options").show(); + } + $('input[type=radio]').change(function(){ if ($("#preferred_bitrate").is(":checked")) { $("#preferred_bitrate_options").slideDown("fast"); } - else + if ($("#preferred_quality0").is(":checked")) { $("#preferred_bitrate_options").slideUp("fast"); } + if ($("#preferred_quality1").is(":checked")) + { + $("#preferred_bitrate_options").slideUp("fast"); + } + if ($("#preferred_quality3").is(":checked")) + { + $("#preferred_bitrate_options").slideUp("fast"); + } + if ($("#nzb_downloader_sabnzbd").is(":checked")) + { + $("#nzbget_options,#blackhole_options").fadeOut("fast", function() { $("#sabnzbd_options,#nzb_download_dir").fadeIn() }); + } + if ($("#nzb_downloader_nzbget").is(":checked")) + { + $("#sabnzbd_options,#blackhole_options").fadeOut("fast", function() { $("#nzbget_options,#nzb_download_dir").fadeIn() }); + } + if ($("#nzb_downloader_blackhole").is(":checked")) + { + $("#sabnzbd_options,#nzbget_options,#nzb_download_dir").fadeOut("fast", function() { $("#blackhole_options").fadeIn() }); + } }); $("#mirror").change(handleNewServerSelection); diff --git a/headphones/__init__.py b/headphones/__init__.py index 3dce3f57..42906fe9 100644 --- a/headphones/__init__.py +++ b/headphones/__init__.py @@ -109,6 +109,7 @@ ADD_ALBUM_ART = False ALBUM_ART_FORMAT = None EMBED_ALBUM_ART = False EMBED_LYRICS = False +NZB_DOWNLOADER = None DOWNLOAD_DIR = None BLACKHOLE = None BLACKHOLE_DIR = None @@ -294,7 +295,7 @@ def initialize(): LIBRARYSCAN, LIBRARYSCAN_INTERVAL, DOWNLOAD_SCAN_INTERVAL, SAB_HOST, SAB_USERNAME, SAB_PASSWORD, SAB_APIKEY, SAB_CATEGORY, \ NZBGET_USERNAME, NZBGET_PASSWORD, NZBGET_CATEGORY, NZBGET_HOST, NZBMATRIX, NZBMATRIX_USERNAME, NZBMATRIX_APIKEY, NEWZNAB, NEWZNAB_HOST, NEWZNAB_APIKEY, NEWZNAB_ENABLED, EXTRA_NEWZNABS, \ NZBSORG, NZBSORG_UID, NZBSORG_HASH, NEWZBIN, NEWZBIN_UID, NEWZBIN_PASSWORD, NZBSRUS, NZBSRUS_UID, NZBSRUS_APIKEY, NZBX, \ - PREFERRED_WORDS, REQUIRED_WORDS, IGNORED_WORDS, \ + NZB_DOWNLOADER, PREFERRED_WORDS, REQUIRED_WORDS, IGNORED_WORDS, \ LASTFM_USERNAME, INTERFACE, FOLDER_PERMISSIONS, ENCODERFOLDER, ENCODER_PATH, ENCODER, XLDPROFILE, BITRATE, SAMPLINGFREQUENCY, \ MUSIC_ENCODER, ADVANCEDENCODER, ENCODEROUTPUTFORMAT, ENCODERQUALITY, ENCODERVBRCBR, ENCODERLOSSLESS, DELETE_LOSSLESS_FILES, \ PROWL_ENABLED, PROWL_PRIORITY, PROWL_KEYS, PROWL_ONSNATCH, PUSHOVER_ENABLED, PUSHOVER_PRIORITY, PUSHOVER_KEYS, PUSHOVER_ONSNATCH, MIRRORLIST, \ @@ -375,6 +376,7 @@ def initialize(): ALBUM_ART_FORMAT = check_setting_str(CFG, 'General', 'album_art_format', 'folder') EMBED_ALBUM_ART = bool(check_setting_int(CFG, 'General', 'embed_album_art', 0)) EMBED_LYRICS = bool(check_setting_int(CFG, 'General', 'embed_lyrics', 0)) + NZB_DOWNLOADER = check_setting_int(CFG, 'General', 'nzb_downloader', 0) DOWNLOAD_DIR = check_setting_str(CFG, 'General', 'download_dir', '') BLACKHOLE = bool(check_setting_int(CFG, 'General', 'blackhole', 0)) BLACKHOLE_DIR = check_setting_str(CFG, 'General', 'blackhole_dir', '') @@ -552,6 +554,12 @@ def initialize(): if ENCODERFOLDER: ENCODER_PATH = os.path.join(ENCODERFOLDER, ENCODER) CONFIG_VERSION = '3' + + if CONFIG_VERSION == '3': + #Update the BLACKHOLE option to the NZB_DOWNLOADER format + if BLACKHOLE: + NZB_DOWNLOADER = 2 + CONFIG_VERSION = '4' if not LOG_DIR: LOG_DIR = os.path.join(DATA_DIR, 'logs') @@ -712,8 +720,8 @@ def config_write(): new_config['General']['album_art_format'] = ALBUM_ART_FORMAT new_config['General']['embed_album_art'] = int(EMBED_ALBUM_ART) new_config['General']['embed_lyrics'] = int(EMBED_LYRICS) + new_config['General']['nzb_downloader'] = NZB_DOWNLOADER new_config['General']['download_dir'] = DOWNLOAD_DIR - new_config['General']['blackhole'] = int(BLACKHOLE) new_config['General']['blackhole_dir'] = BLACKHOLE_DIR new_config['General']['usenet_retention'] = USENET_RETENTION new_config['General']['include_extras'] = int(INCLUDE_EXTRAS) diff --git a/headphones/webserve.py b/headphones/webserve.py index 66ff59e1..6d1a0f12 100644 --- a/headphones/webserve.py +++ b/headphones/webserve.py @@ -579,13 +579,13 @@ class WebInterface(object): "nzbget_user" : headphones.NZBGET_USERNAME, "nzbget_pass" : headphones.NZBGET_PASSWORD, "nzbget_cat" : headphones.NZBGET_CATEGORY, + "nzb_downloader_sabnzbd" : radio(headphones.NZB_DOWNLOADER, 0), + "nzb_downloader_nzbget" : radio(headphones.NZB_DOWNLOADER, 1), + "nzb_downloader_blackhole" : radio(headphones.NZB_DOWNLOADER, 2), "download_dir" : headphones.DOWNLOAD_DIR, "use_blackhole" : checked(headphones.BLACKHOLE), "blackhole_dir" : headphones.BLACKHOLE_DIR, "usenet_retention" : headphones.USENET_RETENTION, -# "use_nzbmatrix" : checked(headphones.NZBMATRIX), -# "nzbmatrix_user" : headphones.NZBMATRIX_USERNAME, -# "nzbmatrix_api" : headphones.NZBMATRIX_APIKEY, "use_newznab" : checked(headphones.NEWZNAB), "newznab_host" : headphones.NEWZNAB_HOST, "newznab_api" : headphones.NEWZNAB_APIKEY, @@ -594,9 +594,6 @@ class WebInterface(object): "use_nzbsorg" : checked(headphones.NZBSORG), "nzbsorg_uid" : headphones.NZBSORG_UID, "nzbsorg_hash" : headphones.NZBSORG_HASH, -# "use_newzbin" : checked(headphones.NEWZBIN), -# "newzbin_uid" : headphones.NEWZBIN_UID, -# "newzbin_pass" : headphones.NEWZBIN_PASSWORD, "use_nzbsrus" : checked(headphones.NZBSRUS), "nzbsrus_uid" : headphones.NZBSRUS_UID, "nzbsrus_apikey" : headphones.NZBSRUS_APIKEY, @@ -708,7 +705,7 @@ class WebInterface(object): def configUpdate(self, http_host='0.0.0.0', http_username=None, http_port=8181, http_password=None, launch_browser=0, api_enabled=0, api_key=None, download_scan_interval=None, nzb_search_interval=None, libraryscan_interval=None, sab_host=None, sab_username=None, sab_apikey=None, sab_password=None, - sab_category=None, nzbget_host=None, nzbget_username='nzbget', nzbget_password=None, nzbget_category=None, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, + sab_category=None, nzbget_host=None, nzbget_username='nzbget', nzbget_password=None, nzbget_category=None, nzb_downloader=0, download_dir=None, blackhole=0, blackhole_dir=None, usenet_retention=None, newznab=0, newznab_host=None, newznab_apikey=None, newznab_enabled=0, nzbsorg=0, nzbsorg_uid=None, nzbsorg_hash=None, nzbsrus=0, nzbsrus_uid=None, nzbsrus_apikey=None, nzbx=0, preferred_words=None, required_words=None, ignored_words=None, preferred_quality=0, preferred_bitrate=None, detect_bitrate=0, move_files=0, torrentblackhole_dir=None, download_torrent_dir=None, numberofseeders=10, use_isohunt=0, use_kat=0, use_mininova=0, waffles=0, waffles_uid=None, waffles_passkey=None, whatcd=0, whatcd_username=None, whatcd_password=None, @@ -740,13 +737,11 @@ class WebInterface(object): headphones.NZBGET_USERNAME = nzbget_username headphones.NZBGET_PASSWORD = nzbget_password headphones.NZBGET_CATEGORY = nzbget_category + headphones.NZB_DOWNLOADER = int(nzb_downloader) headphones.DOWNLOAD_DIR = download_dir headphones.BLACKHOLE = blackhole headphones.BLACKHOLE_DIR = blackhole_dir headphones.USENET_RETENTION = usenet_retention -# headphones.NZBMATRIX = nzbmatrix -# headphones.NZBMATRIX_USERNAME = nzbmatrix_username -# headphones.NZBMATRIX_APIKEY = nzbmatrix_apikey headphones.NEWZNAB = newznab headphones.NEWZNAB_HOST = newznab_host headphones.NEWZNAB_APIKEY = newznab_apikey @@ -754,9 +749,6 @@ class WebInterface(object): headphones.NZBSORG = nzbsorg headphones.NZBSORG_UID = nzbsorg_uid headphones.NZBSORG_HASH = nzbsorg_hash -# headphones.NEWZBIN = newzbin -# headphones.NEWZBIN_UID = newzbin_uid -# headphones.NEWZBIN_PASSWORD = newzbin_password headphones.NZBSRUS = nzbsrus headphones.NZBSRUS_UID = nzbsrus_uid headphones.NZBSRUS_APIKEY = nzbsrus_apikey From 02fe4a13876d9d882380d782158d53ab0a466a51 Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 6 Jul 2013 01:04:08 +0530 Subject: [PATCH 5/8] Updated searcher.py to use the new NZB_DOWNLOADER format. That was easier than I thought --- headphones/searcher.py | 6 +++--- 1 file changed, 3 insertions(+), 3 deletions(-) diff --git a/headphones/searcher.py b/headphones/searcher.py index 100c485b..5fee7468 100644 --- a/headphones/searcher.py +++ b/headphones/searcher.py @@ -535,14 +535,14 @@ def searchNZB(albumid=None, new=False, losslessOnly=False): logger.info(u'Found best result: %s - %s' % (bestqual[2], bestqual[0], helpers.bytes_to_mb(bestqual[1]))) # Get rid of any dodgy chars here so we can prevent sab from renaming our downloads nzb_folder_name = helpers.sab_sanitize_foldername(bestqual[0]) - if headphones.NZBGET_HOST and not headphones.BLACKHOLE and not headphones.SAB_HOST: + if headphones.NZB_DOWNLOADER == 1: nzb = classes.NZBDataSearchResult() nzb.extraInfo.append(data) nzb.name = nzb_folder_name nzbget.sendNZB(nzb) - elif headphones.SAB_HOST and not headphones.BLACKHOLE and not headphones.NZBGET_HOST: + elif headphones.NZB_DOWNLOADER == 0: nzb = classes.NZBDataSearchResult() nzb.extraInfo.append(data) @@ -557,7 +557,7 @@ def searchNZB(albumid=None, new=False, losslessOnly=False): if replace_spaces: nzb_folder_name = helpers.sab_replace_spaces(nzb_folder_name) - elif headphones.BLACKHOLE: + else: nzb_name = nzb_folder_name + '.nzb' download_path = os.path.join(headphones.BLACKHOLE_DIR, nzb_name) From 53bbd5a2e0ddda7a5b8724e968700bfa3c6be03a Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 6 Jul 2013 01:13:52 +0530 Subject: [PATCH 6/8] Updated CurlyMoo email --- headphones/__init__.py | 2 +- headphones/nzbget.py | 2 +- headphones/searcher.py | 2 +- headphones/webserve.py | 2 +- 4 files changed, 4 insertions(+), 4 deletions(-) diff --git a/headphones/__init__.py b/headphones/__init__.py index 42906fe9..965c5e1b 100644 --- a/headphones/__init__.py +++ b/headphones/__init__.py @@ -13,7 +13,7 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . -# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi from __future__ import with_statement diff --git a/headphones/nzbget.py b/headphones/nzbget.py index 5176c9f3..710ee549 100644 --- a/headphones/nzbget.py +++ b/headphones/nzbget.py @@ -1,4 +1,4 @@ -# This file is modified to work with headphones by CurlyMo as a part of XBian - XBMC on the Raspberry Pi +# This file is modified to work with headphones by CurlyMo as a part of XBian - XBMC on the Raspberry Pi # Author: Nic Wolfe # URL: http://code.google.com/p/sickbeard/ diff --git a/headphones/searcher.py b/headphones/searcher.py index 5fee7468..761e2494 100644 --- a/headphones/searcher.py +++ b/headphones/searcher.py @@ -13,7 +13,7 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . -# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi import urllib, urllib2, urlparse, httplib import lib.feedparser as feedparser diff --git a/headphones/webserve.py b/headphones/webserve.py index 6d1a0f12..1f8167ab 100644 --- a/headphones/webserve.py +++ b/headphones/webserve.py @@ -13,7 +13,7 @@ # You should have received a copy of the GNU General Public License # along with Headphones. If not, see . -# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi +# NZBGet support added by CurlyMo as a part of XBian - XBMC on the Raspberry Pi import os import cherrypy From 0071a799b00d2574b9f711ac285829dd01f2be9c Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 6 Jul 2013 01:22:24 +0530 Subject: [PATCH 7/8] I guess we should keep the nzb download directory field available for the blackhole option --- data/interfaces/default/config.html | 29 +++++++++++++++-------------- 1 file changed, 15 insertions(+), 14 deletions(-) diff --git a/data/interfaces/default/config.html b/data/interfaces/default/config.html index 1c89d2c9..3e0641a6 100644 --- a/data/interfaces/default/config.html +++ b/data/interfaces/default/config.html @@ -153,14 +153,7 @@
    -
    -
    - - - Full path where SAB or NZBget downloads your music. e.g. /Users/name/Downloads/music -
    -
    - +
    @@ -168,6 +161,14 @@ Folder your Download program watches for NZBs
    + +
    +
    + + + Full path where SAB or NZBget downloads your music. e.g. /Users/name/Downloads/music +
    +
    @@ -1040,17 +1041,17 @@ if ($("#nzb_downloader_sabnzbd").is(":checked")) { - $("#sabnzbd_options,#nzb_download_dir").show(); + $("#sabnzbd_options").show(); $("#nzbget_options,#blackhole_options").hide(); } if ($("#nzb_downloader_nzbget").is(":checked")) { $("#sabnzbd_options,#blackhole_options").hide(); - $("#nzbget_options,#nzb_download_dir").show(); + $("#nzbget_options").show(); } if ($("#nzb_downloader_blackhole").is(":checked")) { - $("#sabnzbd_options,#nzbget_options,#nzb_download_dir").hide(); + $("#sabnzbd_options,#nzbget_options").hide(); $("#blackhole_options").show(); } @@ -1073,15 +1074,15 @@ } if ($("#nzb_downloader_sabnzbd").is(":checked")) { - $("#nzbget_options,#blackhole_options").fadeOut("fast", function() { $("#sabnzbd_options,#nzb_download_dir").fadeIn() }); + $("#nzbget_options,#blackhole_options").fadeOut("fast", function() { $("#sabnzbd_options").fadeIn() }); } if ($("#nzb_downloader_nzbget").is(":checked")) { - $("#sabnzbd_options,#blackhole_options").fadeOut("fast", function() { $("#nzbget_options,#nzb_download_dir").fadeIn() }); + $("#sabnzbd_options,#blackhole_options").fadeOut("fast", function() { $("#nzbget_options").fadeIn() }); } if ($("#nzb_downloader_blackhole").is(":checked")) { - $("#sabnzbd_options,#nzbget_options,#nzb_download_dir").fadeOut("fast", function() { $("#blackhole_options").fadeIn() }); + $("#sabnzbd_options,#nzbget_options").fadeOut("fast", function() { $("#blackhole_options").fadeIn() }); } }); From ad741cb91c0427eecc8398a5e6168cfc99907c1b Mon Sep 17 00:00:00 2001 From: rembo10 Date: Sat, 6 Jul 2013 01:28:17 +0530 Subject: [PATCH 8/8] Check if they have a blackhole_dir set for the blackhole option --- headphones/searcher.py | 4 ++-- 1 file changed, 2 insertions(+), 2 deletions(-) diff --git a/headphones/searcher.py b/headphones/searcher.py index 761e2494..8ec70247 100644 --- a/headphones/searcher.py +++ b/headphones/searcher.py @@ -111,7 +111,7 @@ def searchforalbum(albumid=None, new=False, lossless=False): for result in results: foundNZB = "none" - if (headphones.NEWZNAB or headphones.NZBSORG or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE or headphones.NZBGET_HOST): + if (headphones.NEWZNAB or headphones.NZBSORG or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE_DIR or headphones.NZBGET_HOST): if result['Status'] == "Wanted Lossless": foundNZB = searchNZB(result['AlbumID'], new, losslessOnly=True) else: @@ -127,7 +127,7 @@ def searchforalbum(albumid=None, new=False, lossless=False): else: foundNZB = "none" - if (headphones.NZBMATRIX or headphones.NEWZNAB or headphones.NZBSORG or headphones.NEWZBIN or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE or headphones.NZBGET_HOST): + if (headphones.NZBMATRIX or headphones.NEWZNAB or headphones.NZBSORG or headphones.NEWZBIN or headphones.NZBX or headphones.NZBSRUS) and (headphones.SAB_HOST or headphones.BLACKHOLE_DIR or headphones.NZBGET_HOST): foundNZB = searchNZB(albumid, new, lossless) if (headphones.KAT or headphones.ISOHUNT or headphones.MININOVA or headphones.WAFFLES or headphones.RUTRACKER or headphones.WHATCD) and foundNZB == "none":
    -
    - SABnzbd +
    +
    + Usenet + Sabnzbd NZBget Blackhole +
    +
    @@ -116,7 +119,7 @@
    -
    +
    @@ -128,20 +131,9 @@
    -
    -
    - Downloads -
    - - - Full path where SAB or NZBget downloads your music. e.g. /Users/name/Downloads/music -
    -
    -
    -
    - NZBget +
    @@ -151,7 +143,7 @@
    -
    +
    @@ -160,8 +152,27 @@
    -
    Torrents @@ -185,22 +196,6 @@
    -
    - Usenet -
    - -
    -
    -
    - - - Folder your Download program watches for NZBs -
    -
    -
    - -
    -