├── public ├── css │ └── customizacao.css ├── template │ ├── 404.php │ └── index.php └── js │ ├── jquery.validate.cpf.js │ ├── validaFormCliente.js │ ├── jquery.mask.min.js │ ├── jquery.validate.js │ └── jquery-3.1.1.min.js ├── index.php ├── vendor ├── autoload.php └── composer │ ├── autoload_classmap.php │ ├── autoload_namespaces.php │ ├── autoload_psr4.php │ ├── autoload_files.php │ ├── LICENSE │ ├── autoload_static.php │ ├── installed.json │ ├── autoload_real.php │ └── ClassLoader.php ├── composer.json ├── app ├── controller │ ├── ClienteController.php │ └── IndexController.php ├── config │ └── database.php ├── lib │ ├── Router.php │ └── Controller.php ├── view │ ├── cliente │ │ └── listar.php │ └── index │ │ ├── listar.php │ │ └── formularioCliente.php └── model │ └── clienteModel.php ├── README.md └── composer.lock /public/css/customizacao.css: -------------------------------------------------------------------------------- 1 | .error{ 2 | color: red; 3 | } -------------------------------------------------------------------------------- /index.php: -------------------------------------------------------------------------------- 1 | array($vendorDir), 10 | 'app\\' => array($baseDir . '/app'), 11 | ); 12 | -------------------------------------------------------------------------------- /vendor/composer/autoload_files.php: -------------------------------------------------------------------------------- 1 | $vendorDir . '/leeoniya/route66/Route66.php', 10 | ); 11 | -------------------------------------------------------------------------------- /composer.json: -------------------------------------------------------------------------------- 1 | { 2 | "name": "bd1-developer/crud-poo", 3 | "authors": [ 4 | { 5 | "name": "roberto", 6 | "email": "roberto.martins@allplats.com" 7 | } 8 | ], 9 | "require": { 10 | "php": "^5.6", 11 | "leeoniya/route66": "dev-master" 12 | }, 13 | "autoload": { 14 | "psr-4": { 15 | "app\\": "app/", 16 | "vendor\\": "vendor/" 17 | } 18 | } 19 | } 20 | -------------------------------------------------------------------------------- /app/controller/ClienteController.php: -------------------------------------------------------------------------------- 1 | model = new clienteModel(); 14 | parent::__construct($route); 15 | } 16 | 17 | public function listar() { 18 | $clientes = $this->model->listar(); 19 | $this->view('cliente/listar',array('clientes' => $clientes)); 20 | } 21 | 22 | 23 | } 24 | -------------------------------------------------------------------------------- /app/config/database.php: -------------------------------------------------------------------------------- 1 | conn = new \PDO("mysql:host=" . $this->host . ";dbname=" . $this->db, $this->usuario, $this->senha); 15 | } catch (PDOException $exc) { 16 | echo $exc->getMessage(); 17 | } 18 | } 19 | 20 | public function query($sql) { 21 | return $this->conn->query($sql); 22 | } 23 | 24 | public function prepare($sql) { 25 | return $this->conn->prepare($sql); 26 | } 27 | 28 | } 29 | -------------------------------------------------------------------------------- /public/template/404.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 |
9 | Página não encontrada! 10 |
11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | -------------------------------------------------------------------------------- /public/template/index.php: -------------------------------------------------------------------------------- 1 | 2 | 3 | 4 | 5 | 6 | 7 |
8 |
9 | content); 11 | ?> 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | -------------------------------------------------------------------------------- /app/lib/Router.php: -------------------------------------------------------------------------------- 1 | head(array('controller' => $controller, 'view' => $view, 'id' => $id)); 12 | }); 13 | 14 | R::dispatch(); 15 | } 16 | 17 | function head(Array $route) { 18 | if ($route['controller'] != NULL) { 19 | $controller = "\\app\controller\\" . $route['controller'] . 'Controller'; 20 | } else { 21 | $controller = "\\app\controller\\IndexController"; 22 | } 23 | 24 | if (class_exists($controller)) { 25 | $obj = new $controller(array('view'=>$route['view'], 'id' => $route['id'])); 26 | } else { 27 | header('HTTP/1.0 404 Not Found'); 28 | include './public/template/404.php'; 29 | exit(); 30 | } 31 | } 32 | 33 | } 34 | -------------------------------------------------------------------------------- /README.md: -------------------------------------------------------------------------------- 1 | # CRUD PHP 2 | 3 | Projeto de aplicação simples em php utilizando autoload e PDO. 4 | 5 | ### Instação 6 | 7 | Executar o comando do composer na pasta do projeto: 8 | 9 | ```sh 10 | $ composer update 11 | ``` 12 | 13 | (Obs):. Caso ouver problemas com o plugin de rotas basta remover ele e baixar novamente: https://github.com/leeoniya/Route66.php 14 | 15 | Configurar os dados de acesso ao banco no arquivo app/config/database.php 16 | 17 | Sql para criação da tabela: 18 | 19 | ```sh 20 | CREATE TABLE `cliente` ( 21 | `id` int(11) NOT NULL AUTO_INCREMENT, 22 | `nome` varchar(45) DEFAULT NULL, 23 | `cpf` varchar(45) DEFAULT NULL, 24 | `data_nascimento` varchar(45) DEFAULT NULL, 25 | `endereco` varchar(45) DEFAULT NULL, 26 | `bairro` varchar(45) DEFAULT NULL, 27 | `cidade` varchar(45) DEFAULT NULL, 28 | `cep` varchar(45) DEFAULT NULL, 29 | `estado` varchar(45) DEFAULT NULL, 30 | PRIMARY KEY (`id`) 31 | ) ENGINE=InnoDB AUTO_INCREMENT=2 DEFAULT CHARSET=latin1; 32 | ``` 33 | 34 | Execute o comando abaixo na pasta do index para iniciar o servidor: 35 | 36 | ```sh 37 | $ php -S localhost:8000 38 | ``` 39 | -------------------------------------------------------------------------------- /vendor/composer/LICENSE: -------------------------------------------------------------------------------- 1 | 2 | Copyright (c) Nils Adermann, Jordi Boggiano 3 | 4 | Permission is hereby granted, free of charge, to any person obtaining a copy 5 | of this software and associated documentation files (the "Software"), to deal 6 | in the Software without restriction, including without limitation the rights 7 | to use, copy, modify, merge, publish, distribute, sublicense, and/or sell 8 | copies of the Software, and to permit persons to whom the Software is furnished 9 | to do so, subject to the following conditions: 10 | 11 | The above copyright notice and this permission notice shall be included in all 12 | copies or substantial portions of the Software. 13 | 14 | THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR 15 | IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, 16 | FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE 17 | AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER 18 | LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, 19 | OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN 20 | THE SOFTWARE. 21 | 22 | -------------------------------------------------------------------------------- /app/lib/Controller.php: -------------------------------------------------------------------------------- 1 | route = $route; 12 | if(is_callable(array($this, $route['view']))){ 13 | $this->$route['view']($route['id']); 14 | }else{ 15 | $this->listar(); 16 | } 17 | 18 | $this->template(); 19 | } 20 | 21 | public function view($name, Array $options = null) { 22 | 23 | ob_start(); 24 | ob_implicit_flush(false); 25 | if (isset($options)) { 26 | foreach ($options as $key => $value) { 27 | $$key = $value; 28 | extract($$key, EXTR_OVERWRITE); 29 | } 30 | } 31 | 32 | require('./app/view/' . $name . '.php'); 33 | 34 | $this->content = ob_get_clean(); 35 | } 36 | 37 | public function template($name = null) { 38 | if ($name == null) 39 | $name = "index"; 40 | $request = $_REQUEST; 41 | include './public/template/' . $name . '.php'; 42 | } 43 | 44 | } 45 | -------------------------------------------------------------------------------- /vendor/composer/autoload_static.php: -------------------------------------------------------------------------------- 1 | __DIR__ . '/..' . '/leeoniya/route66/Route66.php', 11 | ); 12 | 13 | public static $prefixLengthsPsr4 = array ( 14 | 'v' => 15 | array ( 16 | 'vendor\\' => 7, 17 | ), 18 | 'a' => 19 | array ( 20 | 'app\\' => 4, 21 | ), 22 | ); 23 | 24 | public static $prefixDirsPsr4 = array ( 25 | 'vendor\\' => 26 | array ( 27 | 0 => 'C:\\xampp\\htdocs\\alura\\crud-mvc-php\\vendor', 28 | ), 29 | 'app\\' => 30 | array ( 31 | 0 => __DIR__ . '/../..' . '/app', 32 | ), 33 | ); 34 | 35 | public static function getInitializer(ClassLoader $loader) 36 | { 37 | return \Closure::bind(function () use ($loader) { 38 | $loader->prefixLengthsPsr4 = ComposerStaticInit7592c69ab09b96d54551be437de9c0f1::$prefixLengthsPsr4; 39 | $loader->prefixDirsPsr4 = ComposerStaticInit7592c69ab09b96d54551be437de9c0f1::$prefixDirsPsr4; 40 | 41 | }, null, ClassLoader::class); 42 | } 43 | } 44 | -------------------------------------------------------------------------------- /app/view/cliente/listar.php: -------------------------------------------------------------------------------- 1 | 10 | 11 | 12 | 13 | 14 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 33 | 34 | 35 | 36 | 37 | 38 | 39 | 40 |
idnomecpfdata de nascimentoendereçobairrocepcidadeestado
28 | 32 |
-------------------------------------------------------------------------------- /vendor/composer/installed.json: -------------------------------------------------------------------------------- 1 | [ 2 | { 3 | "name": "leeoniya/route66", 4 | "version": "dev-master", 5 | "version_normalized": "9999999-dev", 6 | "source": { 7 | "type": "git", 8 | "url": "https://github.com/leeoniya/Route66.php.git", 9 | "reference": "da4796601bdc50bc801fc483ab148ec4802b307d" 10 | }, 11 | "dist": { 12 | "type": "zip", 13 | "url": "https://api.github.com/repos/leeoniya/Route66.php/zipball/da4796601bdc50bc801fc483ab148ec4802b307d", 14 | "reference": "da4796601bdc50bc801fc483ab148ec4802b307d", 15 | "shasum": "" 16 | }, 17 | "require": { 18 | "php": ">=5.4.0" 19 | }, 20 | "time": "2016-01-05T09:12:21+00:00", 21 | "type": "library", 22 | "installation-source": "source", 23 | "autoload": { 24 | "files": [ 25 | "Route66.php" 26 | ] 27 | }, 28 | "notification-url": "https://packagist.org/downloads/", 29 | "license": [ 30 | "MIT" 31 | ], 32 | "authors": [ 33 | { 34 | "name": "Leon Sorokin", 35 | "email": "leeoniya@gmail.com", 36 | "homepage": "https://github.com/leeoniya", 37 | "role": "Developer" 38 | } 39 | ], 40 | "description": "PHP micro-router", 41 | "homepage": "https://github.com/leeoniya/Route66.php", 42 | "keywords": [ 43 | "route", 44 | "router", 45 | "routing", 46 | "sinatra" 47 | ] 48 | } 49 | ] 50 | -------------------------------------------------------------------------------- /app/view/index/listar.php: -------------------------------------------------------------------------------- 1 | 15 | 16 | 17 | 18 | 19 | 20 | 21 | 22 | 23 | 24 | 25 | 26 | 27 | 28 | 29 | 30 | 31 | 32 | 33 | 39 | 40 | 41 | 42 | 43 | 44 | 48 | 49 | 50 |
idnomecpfdata de nascimentoendereçobairrocepcidadeestado-
34 | 38 | 45 | Alterar 46 | Deletar 47 |
-------------------------------------------------------------------------------- /public/js/jquery.validate.cpf.js: -------------------------------------------------------------------------------- 1 | // anonymous original author, but here's a good source: http://www.tidbits.com.br/colecao-de-metodos-para-o-plugin-validate-do-jquery 2 | 3 | (function ($) { 4 | $.validator.addMethod('cpf',function(value,element,param) { 5 | $return = true; 6 | 7 | // this is mostly not needed 8 | var invalidos = [ 9 | '111.111.111-11', 10 | '222.222.222-22', 11 | '333.333.333-33', 12 | '444.444.444-44', 13 | '555.555.555-55', 14 | '666.666.666-66', 15 | '777.777.777-77', 16 | '888.888.888-88', 17 | '999.999.999-99', 18 | '000.000.000-00' 19 | ]; 20 | for(i=0;i=5.4.0" 25 | }, 26 | "type": "library", 27 | "autoload": { 28 | "files": [ 29 | "Route66.php" 30 | ] 31 | }, 32 | "notification-url": "https://packagist.org/downloads/", 33 | "license": [ 34 | "MIT" 35 | ], 36 | "authors": [ 37 | { 38 | "name": "Leon Sorokin", 39 | "email": "leeoniya@gmail.com", 40 | "homepage": "https://github.com/leeoniya", 41 | "role": "Developer" 42 | } 43 | ], 44 | "description": "PHP micro-router", 45 | "homepage": "https://github.com/leeoniya/Route66.php", 46 | "keywords": [ 47 | "route", 48 | "router", 49 | "routing", 50 | "sinatra" 51 | ], 52 | "time": "2016-01-05 09:12:21" 53 | } 54 | ], 55 | "packages-dev": [], 56 | "aliases": [], 57 | "minimum-stability": "stable", 58 | "stability-flags": { 59 | "leeoniya/route66": 20 60 | }, 61 | "prefer-stable": false, 62 | "prefer-lowest": false, 63 | "platform": { 64 | "php": "^5.6" 65 | }, 66 | "platform-dev": [] 67 | } 68 | -------------------------------------------------------------------------------- /app/controller/IndexController.php: -------------------------------------------------------------------------------- 1 | model = new clienteModel(); 14 | parent::__construct($route); 15 | } 16 | 17 | public function listar() { 18 | $clientes = $this->model->listar(); 19 | $this->view('index/listar',array('clientes' => $clientes)); 20 | } 21 | 22 | public function alterar($id) { 23 | if (isset($id)) { 24 | $cliente = $this->model->busca($id); 25 | if ($_POST) { 26 | if ($this->model->alterar($_POST, $id)) { 27 | echo ""; 31 | } else { 32 | echo ""; 36 | } 37 | } else { 38 | $this->view('index/formularioCliente',array('cliente' => $cliente)); 39 | } 40 | } 41 | } 42 | 43 | public function deletar() { 44 | if (isset($_GET['id'])) { 45 | if ($this->model->deletar($_GET['id'])) { 46 | echo ""; 50 | } else { 51 | echo ""; 55 | } 56 | } 57 | } 58 | 59 | public function inserir() { 60 | if ($_POST) { 61 | if ($this->model->inserir($_POST)) { 62 | echo ""; 66 | } else { 67 | echo ""; 71 | } 72 | } else { 73 | $this->view('index/formularioCliente'); 74 | } 75 | } 76 | 77 | } 78 | -------------------------------------------------------------------------------- /vendor/composer/autoload_real.php: -------------------------------------------------------------------------------- 1 | = 50600 && !defined('HHVM_VERSION') && (!function_exists('zend_loader_file_encoded') || !zend_loader_file_encoded()); 27 | if ($useStaticLoader) { 28 | require_once __DIR__ . '/autoload_static.php'; 29 | 30 | call_user_func(\Composer\Autoload\ComposerStaticInit7592c69ab09b96d54551be437de9c0f1::getInitializer($loader)); 31 | } else { 32 | $map = require __DIR__ . '/autoload_namespaces.php'; 33 | foreach ($map as $namespace => $path) { 34 | $loader->set($namespace, $path); 35 | } 36 | 37 | $map = require __DIR__ . '/autoload_psr4.php'; 38 | foreach ($map as $namespace => $path) { 39 | $loader->setPsr4($namespace, $path); 40 | } 41 | 42 | $classMap = require __DIR__ . '/autoload_classmap.php'; 43 | if ($classMap) { 44 | $loader->addClassMap($classMap); 45 | } 46 | } 47 | 48 | $loader->register(true); 49 | 50 | if ($useStaticLoader) { 51 | $includeFiles = Composer\Autoload\ComposerStaticInit7592c69ab09b96d54551be437de9c0f1::$files; 52 | } else { 53 | $includeFiles = require __DIR__ . '/autoload_files.php'; 54 | } 55 | foreach ($includeFiles as $fileIdentifier => $file) { 56 | composerRequire7592c69ab09b96d54551be437de9c0f1($fileIdentifier, $file); 57 | } 58 | 59 | return $loader; 60 | } 61 | } 62 | 63 | function composerRequire7592c69ab09b96d54551be437de9c0f1($fileIdentifier, $file) 64 | { 65 | if (empty($GLOBALS['__composer_autoload_files'][$fileIdentifier])) { 66 | require $file; 67 | 68 | $GLOBALS['__composer_autoload_files'][$fileIdentifier] = true; 69 | } 70 | } 71 | -------------------------------------------------------------------------------- /app/model/clienteModel.php: -------------------------------------------------------------------------------- 1 | conn = new database(); 13 | } 14 | 15 | public function listar($id = null) { 16 | $query = "select * from cliente"; 17 | if (isset($id)) { 18 | $query .= "where id=" . $id; 19 | } 20 | return $this->conn->query($query)->fetchAll(); 21 | } 22 | 23 | public function busca($id) { 24 | $query = "select * from cliente"; 25 | $query .= " where id=" . $id; 26 | return $this->conn->query($query)->fetch(); 27 | } 28 | 29 | public function inserir($cliente) { 30 | 31 | $query = "insert into cliente (" 32 | . "nome," 33 | . "cpf," 34 | . "data_nascimento," 35 | . "endereco," 36 | . "bairro," 37 | . "cidade," 38 | . "cep," 39 | . "estado" 40 | . ") values(" 41 | . ":nome," 42 | . ":cpf," 43 | . ":data_nascimento," 44 | . ":endereco," 45 | . ":bairro," 46 | . ":cidade," 47 | . ":cep," 48 | . ":estado" 49 | . ")"; 50 | 51 | $prepare = $this->conn->prepare($query); 52 | 53 | $prepare->bindValue(':nome', $cliente['nome']); 54 | $prepare->bindValue(':cpf', str_replace(array('.', '-'), '', $cliente['cpf'])); 55 | 56 | $data_nascimento = date_create($cliente['data_nascimento']); 57 | 58 | $prepare->bindValue(':data_nascimento', date_format($data_nascimento, 'Y-m-d')); 59 | $prepare->bindValue(':endereco', $cliente['endereco']); 60 | $prepare->bindValue(':bairro', $cliente['bairro']); 61 | $prepare->bindValue(':cidade', $cliente['cidade']); 62 | $prepare->bindValue(':cep', str_replace(array('.', '-'), '', $cliente['cep'])); 63 | $prepare->bindValue(':estado', $cliente['estado']); 64 | 65 | return $prepare->execute(); 66 | } 67 | 68 | public function alterar($cliente,$id) { 69 | 70 | $query = "update cliente " 71 | . "set " 72 | . "nome=:nome, " 73 | . "cpf=:cpf, " 74 | . "data_nascimento=:data_nascimento, " 75 | . "endereco=:endereco, " 76 | . "bairro=:bairro, " 77 | . "cidade=:cidade, " 78 | . "cep=:cep, " 79 | . "estado=:estado " 80 | . "where id=:id "; 81 | 82 | $prepare = $this->conn->prepare($query); 83 | 84 | $prepare->bindValue(':nome', $cliente['nome']); 85 | $prepare->bindValue(':cpf', str_replace(array('.', '-'), '', $cliente['cpf'])); 86 | 87 | $data_nascimento = date_create($cliente['data_nascimento']); 88 | 89 | $prepare->bindValue(':data_nascimento', date_format($data_nascimento, 'Y-m-d')); 90 | $prepare->bindValue(':endereco', $cliente['endereco']); 91 | $prepare->bindValue(':bairro', $cliente['bairro']); 92 | $prepare->bindValue(':cidade', $cliente['cidade']); 93 | $prepare->bindValue(':cep', str_replace(array('.', '-'), '', $cliente['cep'])); 94 | $prepare->bindValue(':estado', $cliente['estado']); 95 | $prepare->bindValue(':id', $id); 96 | 97 | return $prepare->execute(); 98 | } 99 | 100 | public function deletar($id) { 101 | $query = "delete from cliente where id = :id"; 102 | 103 | $prepare = $this->conn->prepare($query); 104 | $prepare->bindValue(':id', $id); 105 | 106 | return $prepare->execute(); 107 | } 108 | 109 | } 110 | -------------------------------------------------------------------------------- /app/view/index/formularioCliente.php: -------------------------------------------------------------------------------- 1 | 10 |
route['id']:$this->route['view'];?>"> 11 |
12 | 13 | "> 14 |
15 |
16 | 17 | "> 18 |
19 |
20 | 21 | "> 22 |
23 |
24 | 25 | "> 26 |
27 |
28 | 29 | "> 30 |
31 |
32 | 33 | "> 34 |
35 | 36 |
37 | 38 | 67 |
68 |
69 | 70 | "> 71 |
72 | 73 | 74 |
-------------------------------------------------------------------------------- /public/js/jquery.mask.min.js: -------------------------------------------------------------------------------- 1 | // jQuery Mask Plugin v1.14.10 2 | // github.com/igorescobar/jQuery-Mask-Plugin 3 | var $jscomp={scope:{},findInternal:function(a,f,c){a instanceof String&&(a=String(a));for(var l=a.length,g=0;g=k?h:a+(d.slice(0,a).length-e.slice(0,a).length));return a},behaviour:function(e){e=e||window.event;d.invalid=[];var h=b.data("mask-keycode");if(-1===a.inArray(h,m.byPassKeys)){var h=d.getMasked(),c=d.getCaret();setTimeout(function(a,b){d.setCaret(d.calculateCaretPosition(a,b))},10,c,h);d.val(h);d.setCaret(c);return d.callbacks(e)}},getMasked:function(a,b){var c= 11 | [],p=void 0===b?d.val():b+"",k=0,g=h.length,f=0,l=p.length,n=1,v="push",w=-1,r,u;e.reverse?(v="unshift",n=-1,r=0,k=g-1,f=l-1,u=function(){return-1 7 | * Jordi Boggiano 8 | * 9 | * For the full copyright and license information, please view the LICENSE 10 | * file that was distributed with this source code. 11 | */ 12 | 13 | namespace Composer\Autoload; 14 | 15 | /** 16 | * ClassLoader implements a PSR-0, PSR-4 and classmap class loader. 17 | * 18 | * $loader = new \Composer\Autoload\ClassLoader(); 19 | * 20 | * // register classes with namespaces 21 | * $loader->add('Symfony\Component', __DIR__.'/component'); 22 | * $loader->add('Symfony', __DIR__.'/framework'); 23 | * 24 | * // activate the autoloader 25 | * $loader->register(); 26 | * 27 | * // to enable searching the include path (eg. for PEAR packages) 28 | * $loader->setUseIncludePath(true); 29 | * 30 | * In this example, if you try to use a class in the Symfony\Component 31 | * namespace or one of its children (Symfony\Component\Console for instance), 32 | * the autoloader will first look for the class under the component/ 33 | * directory, and it will then fallback to the framework/ directory if not 34 | * found before giving up. 35 | * 36 | * This class is loosely based on the Symfony UniversalClassLoader. 37 | * 38 | * @author Fabien Potencier 39 | * @author Jordi Boggiano 40 | * @see http://www.php-fig.org/psr/psr-0/ 41 | * @see http://www.php-fig.org/psr/psr-4/ 42 | */ 43 | class ClassLoader 44 | { 45 | // PSR-4 46 | private $prefixLengthsPsr4 = array(); 47 | private $prefixDirsPsr4 = array(); 48 | private $fallbackDirsPsr4 = array(); 49 | 50 | // PSR-0 51 | private $prefixesPsr0 = array(); 52 | private $fallbackDirsPsr0 = array(); 53 | 54 | private $useIncludePath = false; 55 | private $classMap = array(); 56 | private $classMapAuthoritative = false; 57 | private $missingClasses = array(); 58 | private $apcuPrefix; 59 | 60 | public function getPrefixes() 61 | { 62 | if (!empty($this->prefixesPsr0)) { 63 | return call_user_func_array('array_merge', $this->prefixesPsr0); 64 | } 65 | 66 | return array(); 67 | } 68 | 69 | public function getPrefixesPsr4() 70 | { 71 | return $this->prefixDirsPsr4; 72 | } 73 | 74 | public function getFallbackDirs() 75 | { 76 | return $this->fallbackDirsPsr0; 77 | } 78 | 79 | public function getFallbackDirsPsr4() 80 | { 81 | return $this->fallbackDirsPsr4; 82 | } 83 | 84 | public function getClassMap() 85 | { 86 | return $this->classMap; 87 | } 88 | 89 | /** 90 | * @param array $classMap Class to filename map 91 | */ 92 | public function addClassMap(array $classMap) 93 | { 94 | if ($this->classMap) { 95 | $this->classMap = array_merge($this->classMap, $classMap); 96 | } else { 97 | $this->classMap = $classMap; 98 | } 99 | } 100 | 101 | /** 102 | * Registers a set of PSR-0 directories for a given prefix, either 103 | * appending or prepending to the ones previously set for this prefix. 104 | * 105 | * @param string $prefix The prefix 106 | * @param array|string $paths The PSR-0 root directories 107 | * @param bool $prepend Whether to prepend the directories 108 | */ 109 | public function add($prefix, $paths, $prepend = false) 110 | { 111 | if (!$prefix) { 112 | if ($prepend) { 113 | $this->fallbackDirsPsr0 = array_merge( 114 | (array) $paths, 115 | $this->fallbackDirsPsr0 116 | ); 117 | } else { 118 | $this->fallbackDirsPsr0 = array_merge( 119 | $this->fallbackDirsPsr0, 120 | (array) $paths 121 | ); 122 | } 123 | 124 | return; 125 | } 126 | 127 | $first = $prefix[0]; 128 | if (!isset($this->prefixesPsr0[$first][$prefix])) { 129 | $this->prefixesPsr0[$first][$prefix] = (array) $paths; 130 | 131 | return; 132 | } 133 | if ($prepend) { 134 | $this->prefixesPsr0[$first][$prefix] = array_merge( 135 | (array) $paths, 136 | $this->prefixesPsr0[$first][$prefix] 137 | ); 138 | } else { 139 | $this->prefixesPsr0[$first][$prefix] = array_merge( 140 | $this->prefixesPsr0[$first][$prefix], 141 | (array) $paths 142 | ); 143 | } 144 | } 145 | 146 | /** 147 | * Registers a set of PSR-4 directories for a given namespace, either 148 | * appending or prepending to the ones previously set for this namespace. 149 | * 150 | * @param string $prefix The prefix/namespace, with trailing '\\' 151 | * @param array|string $paths The PSR-4 base directories 152 | * @param bool $prepend Whether to prepend the directories 153 | * 154 | * @throws \InvalidArgumentException 155 | */ 156 | public function addPsr4($prefix, $paths, $prepend = false) 157 | { 158 | if (!$prefix) { 159 | // Register directories for the root namespace. 160 | if ($prepend) { 161 | $this->fallbackDirsPsr4 = array_merge( 162 | (array) $paths, 163 | $this->fallbackDirsPsr4 164 | ); 165 | } else { 166 | $this->fallbackDirsPsr4 = array_merge( 167 | $this->fallbackDirsPsr4, 168 | (array) $paths 169 | ); 170 | } 171 | } elseif (!isset($this->prefixDirsPsr4[$prefix])) { 172 | // Register directories for a new namespace. 173 | $length = strlen($prefix); 174 | if ('\\' !== $prefix[$length - 1]) { 175 | throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); 176 | } 177 | $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; 178 | $this->prefixDirsPsr4[$prefix] = (array) $paths; 179 | } elseif ($prepend) { 180 | // Prepend directories for an already registered namespace. 181 | $this->prefixDirsPsr4[$prefix] = array_merge( 182 | (array) $paths, 183 | $this->prefixDirsPsr4[$prefix] 184 | ); 185 | } else { 186 | // Append directories for an already registered namespace. 187 | $this->prefixDirsPsr4[$prefix] = array_merge( 188 | $this->prefixDirsPsr4[$prefix], 189 | (array) $paths 190 | ); 191 | } 192 | } 193 | 194 | /** 195 | * Registers a set of PSR-0 directories for a given prefix, 196 | * replacing any others previously set for this prefix. 197 | * 198 | * @param string $prefix The prefix 199 | * @param array|string $paths The PSR-0 base directories 200 | */ 201 | public function set($prefix, $paths) 202 | { 203 | if (!$prefix) { 204 | $this->fallbackDirsPsr0 = (array) $paths; 205 | } else { 206 | $this->prefixesPsr0[$prefix[0]][$prefix] = (array) $paths; 207 | } 208 | } 209 | 210 | /** 211 | * Registers a set of PSR-4 directories for a given namespace, 212 | * replacing any others previously set for this namespace. 213 | * 214 | * @param string $prefix The prefix/namespace, with trailing '\\' 215 | * @param array|string $paths The PSR-4 base directories 216 | * 217 | * @throws \InvalidArgumentException 218 | */ 219 | public function setPsr4($prefix, $paths) 220 | { 221 | if (!$prefix) { 222 | $this->fallbackDirsPsr4 = (array) $paths; 223 | } else { 224 | $length = strlen($prefix); 225 | if ('\\' !== $prefix[$length - 1]) { 226 | throw new \InvalidArgumentException("A non-empty PSR-4 prefix must end with a namespace separator."); 227 | } 228 | $this->prefixLengthsPsr4[$prefix[0]][$prefix] = $length; 229 | $this->prefixDirsPsr4[$prefix] = (array) $paths; 230 | } 231 | } 232 | 233 | /** 234 | * Turns on searching the include path for class files. 235 | * 236 | * @param bool $useIncludePath 237 | */ 238 | public function setUseIncludePath($useIncludePath) 239 | { 240 | $this->useIncludePath = $useIncludePath; 241 | } 242 | 243 | /** 244 | * Can be used to check if the autoloader uses the include path to check 245 | * for classes. 246 | * 247 | * @return bool 248 | */ 249 | public function getUseIncludePath() 250 | { 251 | return $this->useIncludePath; 252 | } 253 | 254 | /** 255 | * Turns off searching the prefix and fallback directories for classes 256 | * that have not been registered with the class map. 257 | * 258 | * @param bool $classMapAuthoritative 259 | */ 260 | public function setClassMapAuthoritative($classMapAuthoritative) 261 | { 262 | $this->classMapAuthoritative = $classMapAuthoritative; 263 | } 264 | 265 | /** 266 | * Should class lookup fail if not found in the current class map? 267 | * 268 | * @return bool 269 | */ 270 | public function isClassMapAuthoritative() 271 | { 272 | return $this->classMapAuthoritative; 273 | } 274 | 275 | /** 276 | * APCu prefix to use to cache found/not-found classes, if the extension is enabled. 277 | * 278 | * @param string|null $apcuPrefix 279 | */ 280 | public function setApcuPrefix($apcuPrefix) 281 | { 282 | $this->apcuPrefix = function_exists('apcu_fetch') && ini_get('apc.enabled') ? $apcuPrefix : null; 283 | } 284 | 285 | /** 286 | * The APCu prefix in use, or null if APCu caching is not enabled. 287 | * 288 | * @return string|null 289 | */ 290 | public function getApcuPrefix() 291 | { 292 | return $this->apcuPrefix; 293 | } 294 | 295 | /** 296 | * Registers this instance as an autoloader. 297 | * 298 | * @param bool $prepend Whether to prepend the autoloader or not 299 | */ 300 | public function register($prepend = false) 301 | { 302 | spl_autoload_register(array($this, 'loadClass'), true, $prepend); 303 | } 304 | 305 | /** 306 | * Unregisters this instance as an autoloader. 307 | */ 308 | public function unregister() 309 | { 310 | spl_autoload_unregister(array($this, 'loadClass')); 311 | } 312 | 313 | /** 314 | * Loads the given class or interface. 315 | * 316 | * @param string $class The name of the class 317 | * @return bool|null True if loaded, null otherwise 318 | */ 319 | public function loadClass($class) 320 | { 321 | if ($file = $this->findFile($class)) { 322 | includeFile($file); 323 | 324 | return true; 325 | } 326 | } 327 | 328 | /** 329 | * Finds the path to the file where the class is defined. 330 | * 331 | * @param string $class The name of the class 332 | * 333 | * @return string|false The path if found, false otherwise 334 | */ 335 | public function findFile($class) 336 | { 337 | // class map lookup 338 | if (isset($this->classMap[$class])) { 339 | return $this->classMap[$class]; 340 | } 341 | if ($this->classMapAuthoritative || isset($this->missingClasses[$class])) { 342 | return false; 343 | } 344 | if (null !== $this->apcuPrefix) { 345 | $file = apcu_fetch($this->apcuPrefix.$class, $hit); 346 | if ($hit) { 347 | return $file; 348 | } 349 | } 350 | 351 | $file = $this->findFileWithExtension($class, '.php'); 352 | 353 | // Search for Hack files if we are running on HHVM 354 | if (false === $file && defined('HHVM_VERSION')) { 355 | $file = $this->findFileWithExtension($class, '.hh'); 356 | } 357 | 358 | if (null !== $this->apcuPrefix) { 359 | apcu_add($this->apcuPrefix.$class, $file); 360 | } 361 | 362 | if (false === $file) { 363 | // Remember that this class does not exist. 364 | $this->missingClasses[$class] = true; 365 | } 366 | 367 | return $file; 368 | } 369 | 370 | private function findFileWithExtension($class, $ext) 371 | { 372 | // PSR-4 lookup 373 | $logicalPathPsr4 = strtr($class, '\\', DIRECTORY_SEPARATOR) . $ext; 374 | 375 | $first = $class[0]; 376 | if (isset($this->prefixLengthsPsr4[$first])) { 377 | $subPath = $class; 378 | while (false !== $lastPos = strrpos($subPath, '\\')) { 379 | $subPath = substr($subPath, 0, $lastPos); 380 | $search = $subPath.'\\'; 381 | if (isset($this->prefixDirsPsr4[$search])) { 382 | foreach ($this->prefixDirsPsr4[$search] as $dir) { 383 | $length = $this->prefixLengthsPsr4[$first][$search]; 384 | if (file_exists($file = $dir . DIRECTORY_SEPARATOR . substr($logicalPathPsr4, $length))) { 385 | return $file; 386 | } 387 | } 388 | } 389 | } 390 | } 391 | 392 | // PSR-4 fallback dirs 393 | foreach ($this->fallbackDirsPsr4 as $dir) { 394 | if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr4)) { 395 | return $file; 396 | } 397 | } 398 | 399 | // PSR-0 lookup 400 | if (false !== $pos = strrpos($class, '\\')) { 401 | // namespaced class name 402 | $logicalPathPsr0 = substr($logicalPathPsr4, 0, $pos + 1) 403 | . strtr(substr($logicalPathPsr4, $pos + 1), '_', DIRECTORY_SEPARATOR); 404 | } else { 405 | // PEAR-like class name 406 | $logicalPathPsr0 = strtr($class, '_', DIRECTORY_SEPARATOR) . $ext; 407 | } 408 | 409 | if (isset($this->prefixesPsr0[$first])) { 410 | foreach ($this->prefixesPsr0[$first] as $prefix => $dirs) { 411 | if (0 === strpos($class, $prefix)) { 412 | foreach ($dirs as $dir) { 413 | if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { 414 | return $file; 415 | } 416 | } 417 | } 418 | } 419 | } 420 | 421 | // PSR-0 fallback dirs 422 | foreach ($this->fallbackDirsPsr0 as $dir) { 423 | if (file_exists($file = $dir . DIRECTORY_SEPARATOR . $logicalPathPsr0)) { 424 | return $file; 425 | } 426 | } 427 | 428 | // PSR-0 include paths. 429 | if ($this->useIncludePath && $file = stream_resolve_include_path($logicalPathPsr0)) { 430 | return $file; 431 | } 432 | 433 | return false; 434 | } 435 | } 436 | 437 | /** 438 | * Scope isolated include. 439 | * 440 | * Prevents access to $this/self from included files. 441 | */ 442 | function includeFile($file) 443 | { 444 | include $file; 445 | } 446 | -------------------------------------------------------------------------------- /public/js/jquery.validate.js: -------------------------------------------------------------------------------- 1 | /*! 2 | * jQuery Validation Plugin v1.16.0 3 | * 4 | * http://jqueryvalidation.org/ 5 | * 6 | * Copyright (c) 2016 Jörn Zaefferer 7 | * Released under the MIT license 8 | */ 9 | (function( factory ) { 10 | if ( typeof define === "function" && define.amd ) { 11 | define( ["jquery"], factory ); 12 | } else if (typeof module === "object" && module.exports) { 13 | module.exports = factory( require( "jquery" ) ); 14 | } else { 15 | factory( jQuery ); 16 | } 17 | }(function( $ ) { 18 | 19 | $.extend( $.fn, { 20 | 21 | // http://jqueryvalidation.org/validate/ 22 | validate: function( options ) { 23 | 24 | // If nothing is selected, return nothing; can't chain anyway 25 | if ( !this.length ) { 26 | if ( options && options.debug && window.console ) { 27 | console.warn( "Nothing selected, can't validate, returning nothing." ); 28 | } 29 | return; 30 | } 31 | 32 | // Check if a validator for this form was already created 33 | var validator = $.data( this[ 0 ], "validator" ); 34 | if ( validator ) { 35 | return validator; 36 | } 37 | 38 | // Add novalidate tag if HTML5. 39 | this.attr( "novalidate", "novalidate" ); 40 | 41 | validator = new $.validator( options, this[ 0 ] ); 42 | $.data( this[ 0 ], "validator", validator ); 43 | 44 | if ( validator.settings.onsubmit ) { 45 | 46 | this.on( "click.validate", ":submit", function( event ) { 47 | if ( validator.settings.submitHandler ) { 48 | validator.submitButton = event.target; 49 | } 50 | 51 | // Allow suppressing validation by adding a cancel class to the submit button 52 | if ( $( this ).hasClass( "cancel" ) ) { 53 | validator.cancelSubmit = true; 54 | } 55 | 56 | // Allow suppressing validation by adding the html5 formnovalidate attribute to the submit button 57 | if ( $( this ).attr( "formnovalidate" ) !== undefined ) { 58 | validator.cancelSubmit = true; 59 | } 60 | } ); 61 | 62 | // Validate the form on submit 63 | this.on( "submit.validate", function( event ) { 64 | if ( validator.settings.debug ) { 65 | 66 | // Prevent form submit to be able to see console output 67 | event.preventDefault(); 68 | } 69 | function handle() { 70 | var hidden, result; 71 | if ( validator.settings.submitHandler ) { 72 | if ( validator.submitButton ) { 73 | 74 | // Insert a hidden input as a replacement for the missing submit button 75 | hidden = $( "" ) 76 | .attr( "name", validator.submitButton.name ) 77 | .val( $( validator.submitButton ).val() ) 78 | .appendTo( validator.currentForm ); 79 | } 80 | result = validator.settings.submitHandler.call( validator, validator.currentForm, event ); 81 | if ( validator.submitButton ) { 82 | 83 | // And clean up afterwards; thanks to no-block-scope, hidden can be referenced 84 | hidden.remove(); 85 | } 86 | if ( result !== undefined ) { 87 | return result; 88 | } 89 | return false; 90 | } 91 | return true; 92 | } 93 | 94 | // Prevent submit for invalid forms or custom submit handlers 95 | if ( validator.cancelSubmit ) { 96 | validator.cancelSubmit = false; 97 | return handle(); 98 | } 99 | if ( validator.form() ) { 100 | if ( validator.pendingRequest ) { 101 | validator.formSubmitted = true; 102 | return false; 103 | } 104 | return handle(); 105 | } else { 106 | validator.focusInvalid(); 107 | return false; 108 | } 109 | } ); 110 | } 111 | 112 | return validator; 113 | }, 114 | 115 | // http://jqueryvalidation.org/valid/ 116 | valid: function() { 117 | var valid, validator, errorList; 118 | 119 | if ( $( this[ 0 ] ).is( "form" ) ) { 120 | valid = this.validate().form(); 121 | } else { 122 | errorList = []; 123 | valid = true; 124 | validator = $( this[ 0 ].form ).validate(); 125 | this.each( function() { 126 | valid = validator.element( this ) && valid; 127 | if ( !valid ) { 128 | errorList = errorList.concat( validator.errorList ); 129 | } 130 | } ); 131 | validator.errorList = errorList; 132 | } 133 | return valid; 134 | }, 135 | 136 | // http://jqueryvalidation.org/rules/ 137 | rules: function( command, argument ) { 138 | var element = this[ 0 ], 139 | settings, staticRules, existingRules, data, param, filtered; 140 | 141 | // If nothing is selected, return empty object; can't chain anyway 142 | if ( element == null || element.form == null ) { 143 | return; 144 | } 145 | 146 | if ( command ) { 147 | settings = $.data( element.form, "validator" ).settings; 148 | staticRules = settings.rules; 149 | existingRules = $.validator.staticRules( element ); 150 | switch ( command ) { 151 | case "add": 152 | $.extend( existingRules, $.validator.normalizeRule( argument ) ); 153 | 154 | // Remove messages from rules, but allow them to be set separately 155 | delete existingRules.messages; 156 | staticRules[ element.name ] = existingRules; 157 | if ( argument.messages ) { 158 | settings.messages[ element.name ] = $.extend( settings.messages[ element.name ], argument.messages ); 159 | } 160 | break; 161 | case "remove": 162 | if ( !argument ) { 163 | delete staticRules[ element.name ]; 164 | return existingRules; 165 | } 166 | filtered = {}; 167 | $.each( argument.split( /\s/ ), function( index, method ) { 168 | filtered[ method ] = existingRules[ method ]; 169 | delete existingRules[ method ]; 170 | if ( method === "required" ) { 171 | $( element ).removeAttr( "aria-required" ); 172 | } 173 | } ); 174 | return filtered; 175 | } 176 | } 177 | 178 | data = $.validator.normalizeRules( 179 | $.extend( 180 | {}, 181 | $.validator.classRules( element ), 182 | $.validator.attributeRules( element ), 183 | $.validator.dataRules( element ), 184 | $.validator.staticRules( element ) 185 | ), element ); 186 | 187 | // Make sure required is at front 188 | if ( data.required ) { 189 | param = data.required; 190 | delete data.required; 191 | data = $.extend( { required: param }, data ); 192 | $( element ).attr( "aria-required", "true" ); 193 | } 194 | 195 | // Make sure remote is at back 196 | if ( data.remote ) { 197 | param = data.remote; 198 | delete data.remote; 199 | data = $.extend( data, { remote: param } ); 200 | } 201 | 202 | return data; 203 | } 204 | } ); 205 | 206 | // Custom selectors 207 | $.extend( $.expr.pseudos || $.expr[ ":" ], { // '|| $.expr[ ":" ]' here enables backwards compatibility to jQuery 1.7. Can be removed when dropping jQ 1.7.x support 208 | 209 | // http://jqueryvalidation.org/blank-selector/ 210 | blank: function( a ) { 211 | return !$.trim( "" + $( a ).val() ); 212 | }, 213 | 214 | // http://jqueryvalidation.org/filled-selector/ 215 | filled: function( a ) { 216 | var val = $( a ).val(); 217 | return val !== null && !!$.trim( "" + val ); 218 | }, 219 | 220 | // http://jqueryvalidation.org/unchecked-selector/ 221 | unchecked: function( a ) { 222 | return !$( a ).prop( "checked" ); 223 | } 224 | } ); 225 | 226 | // Constructor for validator 227 | $.validator = function( options, form ) { 228 | this.settings = $.extend( true, {}, $.validator.defaults, options ); 229 | this.currentForm = form; 230 | this.init(); 231 | }; 232 | 233 | // http://jqueryvalidation.org/jQuery.validator.format/ 234 | $.validator.format = function( source, params ) { 235 | if ( arguments.length === 1 ) { 236 | return function() { 237 | var args = $.makeArray( arguments ); 238 | args.unshift( source ); 239 | return $.validator.format.apply( this, args ); 240 | }; 241 | } 242 | if ( params === undefined ) { 243 | return source; 244 | } 245 | if ( arguments.length > 2 && params.constructor !== Array ) { 246 | params = $.makeArray( arguments ).slice( 1 ); 247 | } 248 | if ( params.constructor !== Array ) { 249 | params = [ params ]; 250 | } 251 | $.each( params, function( i, n ) { 252 | source = source.replace( new RegExp( "\\{" + i + "\\}", "g" ), function() { 253 | return n; 254 | } ); 255 | } ); 256 | return source; 257 | }; 258 | 259 | $.extend( $.validator, { 260 | 261 | defaults: { 262 | messages: {}, 263 | groups: {}, 264 | rules: {}, 265 | errorClass: "error", 266 | pendingClass: "pending", 267 | validClass: "valid", 268 | errorElement: "label", 269 | focusCleanup: false, 270 | focusInvalid: true, 271 | errorContainer: $( [] ), 272 | errorLabelContainer: $( [] ), 273 | onsubmit: true, 274 | ignore: ":hidden", 275 | ignoreTitle: false, 276 | onfocusin: function( element ) { 277 | this.lastActive = element; 278 | 279 | // Hide error label and remove error class on focus if enabled 280 | if ( this.settings.focusCleanup ) { 281 | if ( this.settings.unhighlight ) { 282 | this.settings.unhighlight.call( this, element, this.settings.errorClass, this.settings.validClass ); 283 | } 284 | this.hideThese( this.errorsFor( element ) ); 285 | } 286 | }, 287 | onfocusout: function( element ) { 288 | if ( !this.checkable( element ) && ( element.name in this.submitted || !this.optional( element ) ) ) { 289 | this.element( element ); 290 | } 291 | }, 292 | onkeyup: function( element, event ) { 293 | 294 | // Avoid revalidate the field when pressing one of the following keys 295 | // Shift => 16 296 | // Ctrl => 17 297 | // Alt => 18 298 | // Caps lock => 20 299 | // End => 35 300 | // Home => 36 301 | // Left arrow => 37 302 | // Up arrow => 38 303 | // Right arrow => 39 304 | // Down arrow => 40 305 | // Insert => 45 306 | // Num lock => 144 307 | // AltGr key => 225 308 | var excludedKeys = [ 309 | 16, 17, 18, 20, 35, 36, 37, 310 | 38, 39, 40, 45, 144, 225 311 | ]; 312 | 313 | if ( event.which === 9 && this.elementValue( element ) === "" || $.inArray( event.keyCode, excludedKeys ) !== -1 ) { 314 | return; 315 | } else if ( element.name in this.submitted || element.name in this.invalid ) { 316 | this.element( element ); 317 | } 318 | }, 319 | onclick: function( element ) { 320 | 321 | // Click on selects, radiobuttons and checkboxes 322 | if ( element.name in this.submitted ) { 323 | this.element( element ); 324 | 325 | // Or option elements, check parent select in that case 326 | } else if ( element.parentNode.name in this.submitted ) { 327 | this.element( element.parentNode ); 328 | } 329 | }, 330 | highlight: function( element, errorClass, validClass ) { 331 | if ( element.type === "radio" ) { 332 | this.findByName( element.name ).addClass( errorClass ).removeClass( validClass ); 333 | } else { 334 | $( element ).addClass( errorClass ).removeClass( validClass ); 335 | } 336 | }, 337 | unhighlight: function( element, errorClass, validClass ) { 338 | if ( element.type === "radio" ) { 339 | this.findByName( element.name ).removeClass( errorClass ).addClass( validClass ); 340 | } else { 341 | $( element ).removeClass( errorClass ).addClass( validClass ); 342 | } 343 | } 344 | }, 345 | 346 | // http://jqueryvalidation.org/jQuery.validator.setDefaults/ 347 | setDefaults: function( settings ) { 348 | $.extend( $.validator.defaults, settings ); 349 | }, 350 | 351 | messages: { 352 | required: "This field is required.", 353 | remote: "Please fix this field.", 354 | email: "Please enter a valid email address.", 355 | url: "Please enter a valid URL.", 356 | date: "Please enter a valid date.", 357 | dateISO: "Please enter a valid date (ISO).", 358 | number: "Please enter a valid number.", 359 | digits: "Please enter only digits.", 360 | equalTo: "Please enter the same value again.", 361 | maxlength: $.validator.format( "Please enter no more than {0} characters." ), 362 | minlength: $.validator.format( "Please enter at least {0} characters." ), 363 | rangelength: $.validator.format( "Please enter a value between {0} and {1} characters long." ), 364 | range: $.validator.format( "Please enter a value between {0} and {1}." ), 365 | max: $.validator.format( "Please enter a value less than or equal to {0}." ), 366 | min: $.validator.format( "Please enter a value greater than or equal to {0}." ), 367 | step: $.validator.format( "Please enter a multiple of {0}." ) 368 | }, 369 | 370 | autoCreateRanges: false, 371 | 372 | prototype: { 373 | 374 | init: function() { 375 | this.labelContainer = $( this.settings.errorLabelContainer ); 376 | this.errorContext = this.labelContainer.length && this.labelContainer || $( this.currentForm ); 377 | this.containers = $( this.settings.errorContainer ).add( this.settings.errorLabelContainer ); 378 | this.submitted = {}; 379 | this.valueCache = {}; 380 | this.pendingRequest = 0; 381 | this.pending = {}; 382 | this.invalid = {}; 383 | this.reset(); 384 | 385 | var groups = ( this.groups = {} ), 386 | rules; 387 | $.each( this.settings.groups, function( key, value ) { 388 | if ( typeof value === "string" ) { 389 | value = value.split( /\s/ ); 390 | } 391 | $.each( value, function( index, name ) { 392 | groups[ name ] = key; 393 | } ); 394 | } ); 395 | rules = this.settings.rules; 396 | $.each( rules, function( key, value ) { 397 | rules[ key ] = $.validator.normalizeRule( value ); 398 | } ); 399 | 400 | function delegate( event ) { 401 | 402 | // Set form expando on contenteditable 403 | if ( !this.form && this.hasAttribute( "contenteditable" ) ) { 404 | this.form = $( this ).closest( "form" )[ 0 ]; 405 | } 406 | 407 | var validator = $.data( this.form, "validator" ), 408 | eventType = "on" + event.type.replace( /^validate/, "" ), 409 | settings = validator.settings; 410 | if ( settings[ eventType ] && !$( this ).is( settings.ignore ) ) { 411 | settings[ eventType ].call( validator, this, event ); 412 | } 413 | } 414 | 415 | $( this.currentForm ) 416 | .on( "focusin.validate focusout.validate keyup.validate", 417 | ":text, [type='password'], [type='file'], select, textarea, [type='number'], [type='search'], " + 418 | "[type='tel'], [type='url'], [type='email'], [type='datetime'], [type='date'], [type='month'], " + 419 | "[type='week'], [type='time'], [type='datetime-local'], [type='range'], [type='color'], " + 420 | "[type='radio'], [type='checkbox'], [contenteditable], [type='button']", delegate ) 421 | 422 | // Support: Chrome, oldIE 423 | // "select" is provided as event.target when clicking a option 424 | .on( "click.validate", "select, option, [type='radio'], [type='checkbox']", delegate ); 425 | 426 | if ( this.settings.invalidHandler ) { 427 | $( this.currentForm ).on( "invalid-form.validate", this.settings.invalidHandler ); 428 | } 429 | 430 | // Add aria-required to any Static/Data/Class required fields before first validation 431 | // Screen readers require this attribute to be present before the initial submission http://www.w3.org/TR/WCAG-TECHS/ARIA2.html 432 | $( this.currentForm ).find( "[required], [data-rule-required], .required" ).attr( "aria-required", "true" ); 433 | }, 434 | 435 | // http://jqueryvalidation.org/Validator.form/ 436 | form: function() { 437 | this.checkForm(); 438 | $.extend( this.submitted, this.errorMap ); 439 | this.invalid = $.extend( {}, this.errorMap ); 440 | if ( !this.valid() ) { 441 | $( this.currentForm ).triggerHandler( "invalid-form", [ this ] ); 442 | } 443 | this.showErrors(); 444 | return this.valid(); 445 | }, 446 | 447 | checkForm: function() { 448 | this.prepareForm(); 449 | for ( var i = 0, elements = ( this.currentElements = this.elements() ); elements[ i ]; i++ ) { 450 | this.check( elements[ i ] ); 451 | } 452 | return this.valid(); 453 | }, 454 | 455 | // http://jqueryvalidation.org/Validator.element/ 456 | element: function( element ) { 457 | var cleanElement = this.clean( element ), 458 | checkElement = this.validationTargetFor( cleanElement ), 459 | v = this, 460 | result = true, 461 | rs, group; 462 | 463 | if ( checkElement === undefined ) { 464 | delete this.invalid[ cleanElement.name ]; 465 | } else { 466 | this.prepareElement( checkElement ); 467 | this.currentElements = $( checkElement ); 468 | 469 | // If this element is grouped, then validate all group elements already 470 | // containing a value 471 | group = this.groups[ checkElement.name ]; 472 | if ( group ) { 473 | $.each( this.groups, function( name, testgroup ) { 474 | if ( testgroup === group && name !== checkElement.name ) { 475 | cleanElement = v.validationTargetFor( v.clean( v.findByName( name ) ) ); 476 | if ( cleanElement && cleanElement.name in v.invalid ) { 477 | v.currentElements.push( cleanElement ); 478 | result = v.check( cleanElement ) && result; 479 | } 480 | } 481 | } ); 482 | } 483 | 484 | rs = this.check( checkElement ) !== false; 485 | result = result && rs; 486 | if ( rs ) { 487 | this.invalid[ checkElement.name ] = false; 488 | } else { 489 | this.invalid[ checkElement.name ] = true; 490 | } 491 | 492 | if ( !this.numberOfInvalids() ) { 493 | 494 | // Hide error containers on last error 495 | this.toHide = this.toHide.add( this.containers ); 496 | } 497 | this.showErrors(); 498 | 499 | // Add aria-invalid status for screen readers 500 | $( element ).attr( "aria-invalid", !rs ); 501 | } 502 | 503 | return result; 504 | }, 505 | 506 | // http://jqueryvalidation.org/Validator.showErrors/ 507 | showErrors: function( errors ) { 508 | if ( errors ) { 509 | var validator = this; 510 | 511 | // Add items to error list and map 512 | $.extend( this.errorMap, errors ); 513 | this.errorList = $.map( this.errorMap, function( message, name ) { 514 | return { 515 | message: message, 516 | element: validator.findByName( name )[ 0 ] 517 | }; 518 | } ); 519 | 520 | // Remove items from success list 521 | this.successList = $.grep( this.successList, function( element ) { 522 | return !( element.name in errors ); 523 | } ); 524 | } 525 | if ( this.settings.showErrors ) { 526 | this.settings.showErrors.call( this, this.errorMap, this.errorList ); 527 | } else { 528 | this.defaultShowErrors(); 529 | } 530 | }, 531 | 532 | // http://jqueryvalidation.org/Validator.resetForm/ 533 | resetForm: function() { 534 | if ( $.fn.resetForm ) { 535 | $( this.currentForm ).resetForm(); 536 | } 537 | this.invalid = {}; 538 | this.submitted = {}; 539 | this.prepareForm(); 540 | this.hideErrors(); 541 | var elements = this.elements() 542 | .removeData( "previousValue" ) 543 | .removeAttr( "aria-invalid" ); 544 | 545 | this.resetElements( elements ); 546 | }, 547 | 548 | resetElements: function( elements ) { 549 | var i; 550 | 551 | if ( this.settings.unhighlight ) { 552 | for ( i = 0; elements[ i ]; i++ ) { 553 | this.settings.unhighlight.call( this, elements[ i ], 554 | this.settings.errorClass, "" ); 555 | this.findByName( elements[ i ].name ).removeClass( this.settings.validClass ); 556 | } 557 | } else { 558 | elements 559 | .removeClass( this.settings.errorClass ) 560 | .removeClass( this.settings.validClass ); 561 | } 562 | }, 563 | 564 | numberOfInvalids: function() { 565 | return this.objectLength( this.invalid ); 566 | }, 567 | 568 | objectLength: function( obj ) { 569 | /* jshint unused: false */ 570 | var count = 0, 571 | i; 572 | for ( i in obj ) { 573 | if ( obj[ i ] ) { 574 | count++; 575 | } 576 | } 577 | return count; 578 | }, 579 | 580 | hideErrors: function() { 581 | this.hideThese( this.toHide ); 582 | }, 583 | 584 | hideThese: function( errors ) { 585 | errors.not( this.containers ).text( "" ); 586 | this.addWrapper( errors ).hide(); 587 | }, 588 | 589 | valid: function() { 590 | return this.size() === 0; 591 | }, 592 | 593 | size: function() { 594 | return this.errorList.length; 595 | }, 596 | 597 | focusInvalid: function() { 598 | if ( this.settings.focusInvalid ) { 599 | try { 600 | $( this.findLastActive() || this.errorList.length && this.errorList[ 0 ].element || [] ) 601 | .filter( ":visible" ) 602 | .focus() 603 | 604 | // Manually trigger focusin event; without it, focusin handler isn't called, findLastActive won't have anything to find 605 | .trigger( "focusin" ); 606 | } catch ( e ) { 607 | 608 | // Ignore IE throwing errors when focusing hidden elements 609 | } 610 | } 611 | }, 612 | 613 | findLastActive: function() { 614 | var lastActive = this.lastActive; 615 | return lastActive && $.grep( this.errorList, function( n ) { 616 | return n.element.name === lastActive.name; 617 | } ).length === 1 && lastActive; 618 | }, 619 | 620 | elements: function() { 621 | var validator = this, 622 | rulesCache = {}; 623 | 624 | // Select all valid inputs inside the form (no submit or reset buttons) 625 | return $( this.currentForm ) 626 | .find( "input, select, textarea, [contenteditable]" ) 627 | .not( ":submit, :reset, :image, :disabled" ) 628 | .not( this.settings.ignore ) 629 | .filter( function() { 630 | var name = this.name || $( this ).attr( "name" ); // For contenteditable 631 | if ( !name && validator.settings.debug && window.console ) { 632 | console.error( "%o has no name assigned", this ); 633 | } 634 | 635 | // Set form expando on contenteditable 636 | if ( this.hasAttribute( "contenteditable" ) ) { 637 | this.form = $( this ).closest( "form" )[ 0 ]; 638 | } 639 | 640 | // Select only the first element for each name, and only those with rules specified 641 | if ( name in rulesCache || !validator.objectLength( $( this ).rules() ) ) { 642 | return false; 643 | } 644 | 645 | rulesCache[ name ] = true; 646 | return true; 647 | } ); 648 | }, 649 | 650 | clean: function( selector ) { 651 | return $( selector )[ 0 ]; 652 | }, 653 | 654 | errors: function() { 655 | var errorClass = this.settings.errorClass.split( " " ).join( "." ); 656 | return $( this.settings.errorElement + "." + errorClass, this.errorContext ); 657 | }, 658 | 659 | resetInternals: function() { 660 | this.successList = []; 661 | this.errorList = []; 662 | this.errorMap = {}; 663 | this.toShow = $( [] ); 664 | this.toHide = $( [] ); 665 | }, 666 | 667 | reset: function() { 668 | this.resetInternals(); 669 | this.currentElements = $( [] ); 670 | }, 671 | 672 | prepareForm: function() { 673 | this.reset(); 674 | this.toHide = this.errors().add( this.containers ); 675 | }, 676 | 677 | prepareElement: function( element ) { 678 | this.reset(); 679 | this.toHide = this.errorsFor( element ); 680 | }, 681 | 682 | elementValue: function( element ) { 683 | var $element = $( element ), 684 | type = element.type, 685 | val, idx; 686 | 687 | if ( type === "radio" || type === "checkbox" ) { 688 | return this.findByName( element.name ).filter( ":checked" ).val(); 689 | } else if ( type === "number" && typeof element.validity !== "undefined" ) { 690 | return element.validity.badInput ? "NaN" : $element.val(); 691 | } 692 | 693 | if ( element.hasAttribute( "contenteditable" ) ) { 694 | val = $element.text(); 695 | } else { 696 | val = $element.val(); 697 | } 698 | 699 | if ( type === "file" ) { 700 | 701 | // Modern browser (chrome & safari) 702 | if ( val.substr( 0, 12 ) === "C:\\fakepath\\" ) { 703 | return val.substr( 12 ); 704 | } 705 | 706 | // Legacy browsers 707 | // Unix-based path 708 | idx = val.lastIndexOf( "/" ); 709 | if ( idx >= 0 ) { 710 | return val.substr( idx + 1 ); 711 | } 712 | 713 | // Windows-based path 714 | idx = val.lastIndexOf( "\\" ); 715 | if ( idx >= 0 ) { 716 | return val.substr( idx + 1 ); 717 | } 718 | 719 | // Just the file name 720 | return val; 721 | } 722 | 723 | if ( typeof val === "string" ) { 724 | return val.replace( /\r/g, "" ); 725 | } 726 | return val; 727 | }, 728 | 729 | check: function( element ) { 730 | element = this.validationTargetFor( this.clean( element ) ); 731 | 732 | var rules = $( element ).rules(), 733 | rulesCount = $.map( rules, function( n, i ) { 734 | return i; 735 | } ).length, 736 | dependencyMismatch = false, 737 | val = this.elementValue( element ), 738 | result, method, rule; 739 | 740 | // If a normalizer is defined for this element, then 741 | // call it to retreive the changed value instead 742 | // of using the real one. 743 | // Note that `this` in the normalizer is `element`. 744 | if ( typeof rules.normalizer === "function" ) { 745 | val = rules.normalizer.call( element, val ); 746 | 747 | if ( typeof val !== "string" ) { 748 | throw new TypeError( "The normalizer should return a string value." ); 749 | } 750 | 751 | // Delete the normalizer from rules to avoid treating 752 | // it as a pre-defined method. 753 | delete rules.normalizer; 754 | } 755 | 756 | for ( method in rules ) { 757 | rule = { method: method, parameters: rules[ method ] }; 758 | try { 759 | result = $.validator.methods[ method ].call( this, val, element, rule.parameters ); 760 | 761 | // If a method indicates that the field is optional and therefore valid, 762 | // don't mark it as valid when there are no other rules 763 | if ( result === "dependency-mismatch" && rulesCount === 1 ) { 764 | dependencyMismatch = true; 765 | continue; 766 | } 767 | dependencyMismatch = false; 768 | 769 | if ( result === "pending" ) { 770 | this.toHide = this.toHide.not( this.errorsFor( element ) ); 771 | return; 772 | } 773 | 774 | if ( !result ) { 775 | this.formatAndAdd( element, rule ); 776 | return false; 777 | } 778 | } catch ( e ) { 779 | if ( this.settings.debug && window.console ) { 780 | console.log( "Exception occurred when checking element " + element.id + ", check the '" + rule.method + "' method.", e ); 781 | } 782 | if ( e instanceof TypeError ) { 783 | e.message += ". Exception occurred when checking element " + element.id + ", check the '" + rule.method + "' method."; 784 | } 785 | 786 | throw e; 787 | } 788 | } 789 | if ( dependencyMismatch ) { 790 | return; 791 | } 792 | if ( this.objectLength( rules ) ) { 793 | this.successList.push( element ); 794 | } 795 | return true; 796 | }, 797 | 798 | // Return the custom message for the given element and validation method 799 | // specified in the element's HTML5 data attribute 800 | // return the generic message if present and no method specific message is present 801 | customDataMessage: function( element, method ) { 802 | return $( element ).data( "msg" + method.charAt( 0 ).toUpperCase() + 803 | method.substring( 1 ).toLowerCase() ) || $( element ).data( "msg" ); 804 | }, 805 | 806 | // Return the custom message for the given element name and validation method 807 | customMessage: function( name, method ) { 808 | var m = this.settings.messages[ name ]; 809 | return m && ( m.constructor === String ? m : m[ method ] ); 810 | }, 811 | 812 | // Return the first defined argument, allowing empty strings 813 | findDefined: function() { 814 | for ( var i = 0; i < arguments.length; i++ ) { 815 | if ( arguments[ i ] !== undefined ) { 816 | return arguments[ i ]; 817 | } 818 | } 819 | return undefined; 820 | }, 821 | 822 | // The second parameter 'rule' used to be a string, and extended to an object literal 823 | // of the following form: 824 | // rule = { 825 | // method: "method name", 826 | // parameters: "the given method parameters" 827 | // } 828 | // 829 | // The old behavior still supported, kept to maintain backward compatibility with 830 | // old code, and will be removed in the next major release. 831 | defaultMessage: function( element, rule ) { 832 | if ( typeof rule === "string" ) { 833 | rule = { method: rule }; 834 | } 835 | 836 | var message = this.findDefined( 837 | this.customMessage( element.name, rule.method ), 838 | this.customDataMessage( element, rule.method ), 839 | 840 | // 'title' is never undefined, so handle empty string as undefined 841 | !this.settings.ignoreTitle && element.title || undefined, 842 | $.validator.messages[ rule.method ], 843 | "Warning: No message defined for " + element.name + "" 844 | ), 845 | theregex = /\$?\{(\d+)\}/g; 846 | if ( typeof message === "function" ) { 847 | message = message.call( this, rule.parameters, element ); 848 | } else if ( theregex.test( message ) ) { 849 | message = $.validator.format( message.replace( theregex, "{$1}" ), rule.parameters ); 850 | } 851 | 852 | return message; 853 | }, 854 | 855 | formatAndAdd: function( element, rule ) { 856 | var message = this.defaultMessage( element, rule ); 857 | 858 | this.errorList.push( { 859 | message: message, 860 | element: element, 861 | method: rule.method 862 | } ); 863 | 864 | this.errorMap[ element.name ] = message; 865 | this.submitted[ element.name ] = message; 866 | }, 867 | 868 | addWrapper: function( toToggle ) { 869 | if ( this.settings.wrapper ) { 870 | toToggle = toToggle.add( toToggle.parent( this.settings.wrapper ) ); 871 | } 872 | return toToggle; 873 | }, 874 | 875 | defaultShowErrors: function() { 876 | var i, elements, error; 877 | for ( i = 0; this.errorList[ i ]; i++ ) { 878 | error = this.errorList[ i ]; 879 | if ( this.settings.highlight ) { 880 | this.settings.highlight.call( this, error.element, this.settings.errorClass, this.settings.validClass ); 881 | } 882 | this.showLabel( error.element, error.message ); 883 | } 884 | if ( this.errorList.length ) { 885 | this.toShow = this.toShow.add( this.containers ); 886 | } 887 | if ( this.settings.success ) { 888 | for ( i = 0; this.successList[ i ]; i++ ) { 889 | this.showLabel( this.successList[ i ] ); 890 | } 891 | } 892 | if ( this.settings.unhighlight ) { 893 | for ( i = 0, elements = this.validElements(); elements[ i ]; i++ ) { 894 | this.settings.unhighlight.call( this, elements[ i ], this.settings.errorClass, this.settings.validClass ); 895 | } 896 | } 897 | this.toHide = this.toHide.not( this.toShow ); 898 | this.hideErrors(); 899 | this.addWrapper( this.toShow ).show(); 900 | }, 901 | 902 | validElements: function() { 903 | return this.currentElements.not( this.invalidElements() ); 904 | }, 905 | 906 | invalidElements: function() { 907 | return $( this.errorList ).map( function() { 908 | return this.element; 909 | } ); 910 | }, 911 | 912 | showLabel: function( element, message ) { 913 | var place, group, errorID, v, 914 | error = this.errorsFor( element ), 915 | elementID = this.idOrName( element ), 916 | describedBy = $( element ).attr( "aria-describedby" ); 917 | 918 | if ( error.length ) { 919 | 920 | // Refresh error/success class 921 | error.removeClass( this.settings.validClass ).addClass( this.settings.errorClass ); 922 | 923 | // Replace message on existing label 924 | error.html( message ); 925 | } else { 926 | 927 | // Create error element 928 | error = $( "<" + this.settings.errorElement + ">" ) 929 | .attr( "id", elementID + "-error" ) 930 | .addClass( this.settings.errorClass ) 931 | .html( message || "" ); 932 | 933 | // Maintain reference to the element to be placed into the DOM 934 | place = error; 935 | if ( this.settings.wrapper ) { 936 | 937 | // Make sure the element is visible, even in IE 938 | // actually showing the wrapped element is handled elsewhere 939 | place = error.hide().show().wrap( "<" + this.settings.wrapper + "/>" ).parent(); 940 | } 941 | if ( this.labelContainer.length ) { 942 | this.labelContainer.append( place ); 943 | } else if ( this.settings.errorPlacement ) { 944 | this.settings.errorPlacement.call( this, place, $( element ) ); 945 | } else { 946 | place.insertAfter( element ); 947 | } 948 | 949 | // Link error back to the element 950 | if ( error.is( "label" ) ) { 951 | 952 | // If the error is a label, then associate using 'for' 953 | error.attr( "for", elementID ); 954 | 955 | // If the element is not a child of an associated label, then it's necessary 956 | // to explicitly apply aria-describedby 957 | } else if ( error.parents( "label[for='" + this.escapeCssMeta( elementID ) + "']" ).length === 0 ) { 958 | errorID = error.attr( "id" ); 959 | 960 | // Respect existing non-error aria-describedby 961 | if ( !describedBy ) { 962 | describedBy = errorID; 963 | } else if ( !describedBy.match( new RegExp( "\\b" + this.escapeCssMeta( errorID ) + "\\b" ) ) ) { 964 | 965 | // Add to end of list if not already present 966 | describedBy += " " + errorID; 967 | } 968 | $( element ).attr( "aria-describedby", describedBy ); 969 | 970 | // If this element is grouped, then assign to all elements in the same group 971 | group = this.groups[ element.name ]; 972 | if ( group ) { 973 | v = this; 974 | $.each( v.groups, function( name, testgroup ) { 975 | if ( testgroup === group ) { 976 | $( "[name='" + v.escapeCssMeta( name ) + "']", v.currentForm ) 977 | .attr( "aria-describedby", error.attr( "id" ) ); 978 | } 979 | } ); 980 | } 981 | } 982 | } 983 | if ( !message && this.settings.success ) { 984 | error.text( "" ); 985 | if ( typeof this.settings.success === "string" ) { 986 | error.addClass( this.settings.success ); 987 | } else { 988 | this.settings.success( error, element ); 989 | } 990 | } 991 | this.toShow = this.toShow.add( error ); 992 | }, 993 | 994 | errorsFor: function( element ) { 995 | var name = this.escapeCssMeta( this.idOrName( element ) ), 996 | describer = $( element ).attr( "aria-describedby" ), 997 | selector = "label[for='" + name + "'], label[for='" + name + "'] *"; 998 | 999 | // 'aria-describedby' should directly reference the error element 1000 | if ( describer ) { 1001 | selector = selector + ", #" + this.escapeCssMeta( describer ) 1002 | .replace( /\s+/g, ", #" ); 1003 | } 1004 | 1005 | return this 1006 | .errors() 1007 | .filter( selector ); 1008 | }, 1009 | 1010 | // See https://api.jquery.com/category/selectors/, for CSS 1011 | // meta-characters that should be escaped in order to be used with JQuery 1012 | // as a literal part of a name/id or any selector. 1013 | escapeCssMeta: function( string ) { 1014 | return string.replace( /([\\!"#$%&'()*+,./:;<=>?@\[\]^`{|}~])/g, "\\$1" ); 1015 | }, 1016 | 1017 | idOrName: function( element ) { 1018 | return this.groups[ element.name ] || ( this.checkable( element ) ? element.name : element.id || element.name ); 1019 | }, 1020 | 1021 | validationTargetFor: function( element ) { 1022 | 1023 | // If radio/checkbox, validate first element in group instead 1024 | if ( this.checkable( element ) ) { 1025 | element = this.findByName( element.name ); 1026 | } 1027 | 1028 | // Always apply ignore filter 1029 | return $( element ).not( this.settings.ignore )[ 0 ]; 1030 | }, 1031 | 1032 | checkable: function( element ) { 1033 | return ( /radio|checkbox/i ).test( element.type ); 1034 | }, 1035 | 1036 | findByName: function( name ) { 1037 | return $( this.currentForm ).find( "[name='" + this.escapeCssMeta( name ) + "']" ); 1038 | }, 1039 | 1040 | getLength: function( value, element ) { 1041 | switch ( element.nodeName.toLowerCase() ) { 1042 | case "select": 1043 | return $( "option:selected", element ).length; 1044 | case "input": 1045 | if ( this.checkable( element ) ) { 1046 | return this.findByName( element.name ).filter( ":checked" ).length; 1047 | } 1048 | } 1049 | return value.length; 1050 | }, 1051 | 1052 | depend: function( param, element ) { 1053 | return this.dependTypes[ typeof param ] ? this.dependTypes[ typeof param ]( param, element ) : true; 1054 | }, 1055 | 1056 | dependTypes: { 1057 | "boolean": function( param ) { 1058 | return param; 1059 | }, 1060 | "string": function( param, element ) { 1061 | return !!$( param, element.form ).length; 1062 | }, 1063 | "function": function( param, element ) { 1064 | return param( element ); 1065 | } 1066 | }, 1067 | 1068 | optional: function( element ) { 1069 | var val = this.elementValue( element ); 1070 | return !$.validator.methods.required.call( this, val, element ) && "dependency-mismatch"; 1071 | }, 1072 | 1073 | startRequest: function( element ) { 1074 | if ( !this.pending[ element.name ] ) { 1075 | this.pendingRequest++; 1076 | $( element ).addClass( this.settings.pendingClass ); 1077 | this.pending[ element.name ] = true; 1078 | } 1079 | }, 1080 | 1081 | stopRequest: function( element, valid ) { 1082 | this.pendingRequest--; 1083 | 1084 | // Sometimes synchronization fails, make sure pendingRequest is never < 0 1085 | if ( this.pendingRequest < 0 ) { 1086 | this.pendingRequest = 0; 1087 | } 1088 | delete this.pending[ element.name ]; 1089 | $( element ).removeClass( this.settings.pendingClass ); 1090 | if ( valid && this.pendingRequest === 0 && this.formSubmitted && this.form() ) { 1091 | $( this.currentForm ).submit(); 1092 | this.formSubmitted = false; 1093 | } else if ( !valid && this.pendingRequest === 0 && this.formSubmitted ) { 1094 | $( this.currentForm ).triggerHandler( "invalid-form", [ this ] ); 1095 | this.formSubmitted = false; 1096 | } 1097 | }, 1098 | 1099 | previousValue: function( element, method ) { 1100 | method = typeof method === "string" && method || "remote"; 1101 | 1102 | return $.data( element, "previousValue" ) || $.data( element, "previousValue", { 1103 | old: null, 1104 | valid: true, 1105 | message: this.defaultMessage( element, { method: method } ) 1106 | } ); 1107 | }, 1108 | 1109 | // Cleans up all forms and elements, removes validator-specific events 1110 | destroy: function() { 1111 | this.resetForm(); 1112 | 1113 | $( this.currentForm ) 1114 | .off( ".validate" ) 1115 | .removeData( "validator" ) 1116 | .find( ".validate-equalTo-blur" ) 1117 | .off( ".validate-equalTo" ) 1118 | .removeClass( "validate-equalTo-blur" ); 1119 | } 1120 | 1121 | }, 1122 | 1123 | classRuleSettings: { 1124 | required: { required: true }, 1125 | email: { email: true }, 1126 | url: { url: true }, 1127 | date: { date: true }, 1128 | dateISO: { dateISO: true }, 1129 | number: { number: true }, 1130 | digits: { digits: true }, 1131 | creditcard: { creditcard: true } 1132 | }, 1133 | 1134 | addClassRules: function( className, rules ) { 1135 | if ( className.constructor === String ) { 1136 | this.classRuleSettings[ className ] = rules; 1137 | } else { 1138 | $.extend( this.classRuleSettings, className ); 1139 | } 1140 | }, 1141 | 1142 | classRules: function( element ) { 1143 | var rules = {}, 1144 | classes = $( element ).attr( "class" ); 1145 | 1146 | if ( classes ) { 1147 | $.each( classes.split( " " ), function() { 1148 | if ( this in $.validator.classRuleSettings ) { 1149 | $.extend( rules, $.validator.classRuleSettings[ this ] ); 1150 | } 1151 | } ); 1152 | } 1153 | return rules; 1154 | }, 1155 | 1156 | normalizeAttributeRule: function( rules, type, method, value ) { 1157 | 1158 | // Convert the value to a number for number inputs, and for text for backwards compability 1159 | // allows type="date" and others to be compared as strings 1160 | if ( /min|max|step/.test( method ) && ( type === null || /number|range|text/.test( type ) ) ) { 1161 | value = Number( value ); 1162 | 1163 | // Support Opera Mini, which returns NaN for undefined minlength 1164 | if ( isNaN( value ) ) { 1165 | value = undefined; 1166 | } 1167 | } 1168 | 1169 | if ( value || value === 0 ) { 1170 | rules[ method ] = value; 1171 | } else if ( type === method && type !== "range" ) { 1172 | 1173 | // Exception: the jquery validate 'range' method 1174 | // does not test for the html5 'range' type 1175 | rules[ method ] = true; 1176 | } 1177 | }, 1178 | 1179 | attributeRules: function( element ) { 1180 | var rules = {}, 1181 | $element = $( element ), 1182 | type = element.getAttribute( "type" ), 1183 | method, value; 1184 | 1185 | for ( method in $.validator.methods ) { 1186 | 1187 | // Support for in both html5 and older browsers 1188 | if ( method === "required" ) { 1189 | value = element.getAttribute( method ); 1190 | 1191 | // Some browsers return an empty string for the required attribute 1192 | // and non-HTML5 browsers might have required="" markup 1193 | if ( value === "" ) { 1194 | value = true; 1195 | } 1196 | 1197 | // Force non-HTML5 browsers to return bool 1198 | value = !!value; 1199 | } else { 1200 | value = $element.attr( method ); 1201 | } 1202 | 1203 | this.normalizeAttributeRule( rules, type, method, value ); 1204 | } 1205 | 1206 | // 'maxlength' may be returned as -1, 2147483647 ( IE ) and 524288 ( safari ) for text inputs 1207 | if ( rules.maxlength && /-1|2147483647|524288/.test( rules.maxlength ) ) { 1208 | delete rules.maxlength; 1209 | } 1210 | 1211 | return rules; 1212 | }, 1213 | 1214 | dataRules: function( element ) { 1215 | var rules = {}, 1216 | $element = $( element ), 1217 | type = element.getAttribute( "type" ), 1218 | method, value; 1219 | 1220 | for ( method in $.validator.methods ) { 1221 | value = $element.data( "rule" + method.charAt( 0 ).toUpperCase() + method.substring( 1 ).toLowerCase() ); 1222 | this.normalizeAttributeRule( rules, type, method, value ); 1223 | } 1224 | return rules; 1225 | }, 1226 | 1227 | staticRules: function( element ) { 1228 | var rules = {}, 1229 | validator = $.data( element.form, "validator" ); 1230 | 1231 | if ( validator.settings.rules ) { 1232 | rules = $.validator.normalizeRule( validator.settings.rules[ element.name ] ) || {}; 1233 | } 1234 | return rules; 1235 | }, 1236 | 1237 | normalizeRules: function( rules, element ) { 1238 | 1239 | // Handle dependency check 1240 | $.each( rules, function( prop, val ) { 1241 | 1242 | // Ignore rule when param is explicitly false, eg. required:false 1243 | if ( val === false ) { 1244 | delete rules[ prop ]; 1245 | return; 1246 | } 1247 | if ( val.param || val.depends ) { 1248 | var keepRule = true; 1249 | switch ( typeof val.depends ) { 1250 | case "string": 1251 | keepRule = !!$( val.depends, element.form ).length; 1252 | break; 1253 | case "function": 1254 | keepRule = val.depends.call( element, element ); 1255 | break; 1256 | } 1257 | if ( keepRule ) { 1258 | rules[ prop ] = val.param !== undefined ? val.param : true; 1259 | } else { 1260 | $.data( element.form, "validator" ).resetElements( $( element ) ); 1261 | delete rules[ prop ]; 1262 | } 1263 | } 1264 | } ); 1265 | 1266 | // Evaluate parameters 1267 | $.each( rules, function( rule, parameter ) { 1268 | rules[ rule ] = $.isFunction( parameter ) && rule !== "normalizer" ? parameter( element ) : parameter; 1269 | } ); 1270 | 1271 | // Clean number parameters 1272 | $.each( [ "minlength", "maxlength" ], function() { 1273 | if ( rules[ this ] ) { 1274 | rules[ this ] = Number( rules[ this ] ); 1275 | } 1276 | } ); 1277 | $.each( [ "rangelength", "range" ], function() { 1278 | var parts; 1279 | if ( rules[ this ] ) { 1280 | if ( $.isArray( rules[ this ] ) ) { 1281 | rules[ this ] = [ Number( rules[ this ][ 0 ] ), Number( rules[ this ][ 1 ] ) ]; 1282 | } else if ( typeof rules[ this ] === "string" ) { 1283 | parts = rules[ this ].replace( /[\[\]]/g, "" ).split( /[\s,]+/ ); 1284 | rules[ this ] = [ Number( parts[ 0 ] ), Number( parts[ 1 ] ) ]; 1285 | } 1286 | } 1287 | } ); 1288 | 1289 | if ( $.validator.autoCreateRanges ) { 1290 | 1291 | // Auto-create ranges 1292 | if ( rules.min != null && rules.max != null ) { 1293 | rules.range = [ rules.min, rules.max ]; 1294 | delete rules.min; 1295 | delete rules.max; 1296 | } 1297 | if ( rules.minlength != null && rules.maxlength != null ) { 1298 | rules.rangelength = [ rules.minlength, rules.maxlength ]; 1299 | delete rules.minlength; 1300 | delete rules.maxlength; 1301 | } 1302 | } 1303 | 1304 | return rules; 1305 | }, 1306 | 1307 | // Converts a simple string to a {string: true} rule, e.g., "required" to {required:true} 1308 | normalizeRule: function( data ) { 1309 | if ( typeof data === "string" ) { 1310 | var transformed = {}; 1311 | $.each( data.split( /\s/ ), function() { 1312 | transformed[ this ] = true; 1313 | } ); 1314 | data = transformed; 1315 | } 1316 | return data; 1317 | }, 1318 | 1319 | // http://jqueryvalidation.org/jQuery.validator.addMethod/ 1320 | addMethod: function( name, method, message ) { 1321 | $.validator.methods[ name ] = method; 1322 | $.validator.messages[ name ] = message !== undefined ? message : $.validator.messages[ name ]; 1323 | if ( method.length < 3 ) { 1324 | $.validator.addClassRules( name, $.validator.normalizeRule( name ) ); 1325 | } 1326 | }, 1327 | 1328 | // http://jqueryvalidation.org/jQuery.validator.methods/ 1329 | methods: { 1330 | 1331 | // http://jqueryvalidation.org/required-method/ 1332 | required: function( value, element, param ) { 1333 | 1334 | // Check if dependency is met 1335 | if ( !this.depend( param, element ) ) { 1336 | return "dependency-mismatch"; 1337 | } 1338 | if ( element.nodeName.toLowerCase() === "select" ) { 1339 | 1340 | // Could be an array for select-multiple or a string, both are fine this way 1341 | var val = $( element ).val(); 1342 | return val && val.length > 0; 1343 | } 1344 | if ( this.checkable( element ) ) { 1345 | return this.getLength( value, element ) > 0; 1346 | } 1347 | return value.length > 0; 1348 | }, 1349 | 1350 | // http://jqueryvalidation.org/email-method/ 1351 | email: function( value, element ) { 1352 | 1353 | // From https://html.spec.whatwg.org/multipage/forms.html#valid-e-mail-address 1354 | // Retrieved 2014-01-14 1355 | // If you have a problem with this implementation, report a bug against the above spec 1356 | // Or use custom methods to implement your own email validation 1357 | return this.optional( element ) || /^[a-zA-Z0-9.!#$%&'*+\/=?^_`{|}~-]+@[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?(?:\.[a-zA-Z0-9](?:[a-zA-Z0-9-]{0,61}[a-zA-Z0-9])?)*$/.test( value ); 1358 | }, 1359 | 1360 | // http://jqueryvalidation.org/url-method/ 1361 | url: function( value, element ) { 1362 | 1363 | // Copyright (c) 2010-2013 Diego Perini, MIT licensed 1364 | // https://gist.github.com/dperini/729294 1365 | // see also https://mathiasbynens.be/demo/url-regex 1366 | // modified to allow protocol-relative URLs 1367 | return this.optional( element ) || /^(?:(?:(?:https?|ftp):)?\/\/)(?:\S+(?::\S*)?@)?(?:(?!(?:10|127)(?:\.\d{1,3}){3})(?!(?:169\.254|192\.168)(?:\.\d{1,3}){2})(?!172\.(?:1[6-9]|2\d|3[0-1])(?:\.\d{1,3}){2})(?:[1-9]\d?|1\d\d|2[01]\d|22[0-3])(?:\.(?:1?\d{1,2}|2[0-4]\d|25[0-5])){2}(?:\.(?:[1-9]\d?|1\d\d|2[0-4]\d|25[0-4]))|(?:(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)(?:\.(?:[a-z\u00a1-\uffff0-9]-*)*[a-z\u00a1-\uffff0-9]+)*(?:\.(?:[a-z\u00a1-\uffff]{2,})).?)(?::\d{2,5})?(?:[/?#]\S*)?$/i.test( value ); 1368 | }, 1369 | 1370 | // http://jqueryvalidation.org/date-method/ 1371 | date: function( value, element ) { 1372 | return this.optional( element ) || !/Invalid|NaN/.test( new Date( value ).toString() ); 1373 | }, 1374 | 1375 | // http://jqueryvalidation.org/dateISO-method/ 1376 | dateISO: function( value, element ) { 1377 | return this.optional( element ) || /^\d{4}[\/\-](0?[1-9]|1[012])[\/\-](0?[1-9]|[12][0-9]|3[01])$/.test( value ); 1378 | }, 1379 | 1380 | // http://jqueryvalidation.org/number-method/ 1381 | number: function( value, element ) { 1382 | return this.optional( element ) || /^(?:-?\d+|-?\d{1,3}(?:,\d{3})+)?(?:\.\d+)?$/.test( value ); 1383 | }, 1384 | 1385 | // http://jqueryvalidation.org/digits-method/ 1386 | digits: function( value, element ) { 1387 | return this.optional( element ) || /^\d+$/.test( value ); 1388 | }, 1389 | 1390 | // http://jqueryvalidation.org/minlength-method/ 1391 | minlength: function( value, element, param ) { 1392 | var length = $.isArray( value ) ? value.length : this.getLength( value, element ); 1393 | return this.optional( element ) || length >= param; 1394 | }, 1395 | 1396 | // http://jqueryvalidation.org/maxlength-method/ 1397 | maxlength: function( value, element, param ) { 1398 | var length = $.isArray( value ) ? value.length : this.getLength( value, element ); 1399 | return this.optional( element ) || length <= param; 1400 | }, 1401 | 1402 | // http://jqueryvalidation.org/rangelength-method/ 1403 | rangelength: function( value, element, param ) { 1404 | var length = $.isArray( value ) ? value.length : this.getLength( value, element ); 1405 | return this.optional( element ) || ( length >= param[ 0 ] && length <= param[ 1 ] ); 1406 | }, 1407 | 1408 | // http://jqueryvalidation.org/min-method/ 1409 | min: function( value, element, param ) { 1410 | return this.optional( element ) || value >= param; 1411 | }, 1412 | 1413 | // http://jqueryvalidation.org/max-method/ 1414 | max: function( value, element, param ) { 1415 | return this.optional( element ) || value <= param; 1416 | }, 1417 | 1418 | // http://jqueryvalidation.org/range-method/ 1419 | range: function( value, element, param ) { 1420 | return this.optional( element ) || ( value >= param[ 0 ] && value <= param[ 1 ] ); 1421 | }, 1422 | 1423 | // http://jqueryvalidation.org/step-method/ 1424 | step: function( value, element, param ) { 1425 | var type = $( element ).attr( "type" ), 1426 | errorMessage = "Step attribute on input type " + type + " is not supported.", 1427 | supportedTypes = [ "text", "number", "range" ], 1428 | re = new RegExp( "\\b" + type + "\\b" ), 1429 | notSupported = type && !re.test( supportedTypes.join() ), 1430 | decimalPlaces = function( num ) { 1431 | var match = ( "" + num ).match( /(?:\.(\d+))?$/ ); 1432 | if ( !match ) { 1433 | return 0; 1434 | } 1435 | 1436 | // Number of digits right of decimal point. 1437 | return match[ 1 ] ? match[ 1 ].length : 0; 1438 | }, 1439 | toInt = function( num ) { 1440 | return Math.round( num * Math.pow( 10, decimals ) ); 1441 | }, 1442 | valid = true, 1443 | decimals; 1444 | 1445 | // Works only for text, number and range input types 1446 | // TODO find a way to support input types date, datetime, datetime-local, month, time and week 1447 | if ( notSupported ) { 1448 | throw new Error( errorMessage ); 1449 | } 1450 | 1451 | decimals = decimalPlaces( param ); 1452 | 1453 | // Value can't have too many decimals 1454 | if ( decimalPlaces( value ) > decimals || toInt( value ) % toInt( param ) !== 0 ) { 1455 | valid = false; 1456 | } 1457 | 1458 | return this.optional( element ) || valid; 1459 | }, 1460 | 1461 | // http://jqueryvalidation.org/equalTo-method/ 1462 | equalTo: function( value, element, param ) { 1463 | 1464 | // Bind to the blur event of the target in order to revalidate whenever the target field is updated 1465 | var target = $( param ); 1466 | if ( this.settings.onfocusout && target.not( ".validate-equalTo-blur" ).length ) { 1467 | target.addClass( "validate-equalTo-blur" ).on( "blur.validate-equalTo", function() { 1468 | $( element ).valid(); 1469 | } ); 1470 | } 1471 | return value === target.val(); 1472 | }, 1473 | 1474 | // http://jqueryvalidation.org/remote-method/ 1475 | remote: function( value, element, param, method ) { 1476 | if ( this.optional( element ) ) { 1477 | return "dependency-mismatch"; 1478 | } 1479 | 1480 | method = typeof method === "string" && method || "remote"; 1481 | 1482 | var previous = this.previousValue( element, method ), 1483 | validator, data, optionDataString; 1484 | 1485 | if ( !this.settings.messages[ element.name ] ) { 1486 | this.settings.messages[ element.name ] = {}; 1487 | } 1488 | previous.originalMessage = previous.originalMessage || this.settings.messages[ element.name ][ method ]; 1489 | this.settings.messages[ element.name ][ method ] = previous.message; 1490 | 1491 | param = typeof param === "string" && { url: param } || param; 1492 | optionDataString = $.param( $.extend( { data: value }, param.data ) ); 1493 | if ( previous.old === optionDataString ) { 1494 | return previous.valid; 1495 | } 1496 | 1497 | previous.old = optionDataString; 1498 | validator = this; 1499 | this.startRequest( element ); 1500 | data = {}; 1501 | data[ element.name ] = value; 1502 | $.ajax( $.extend( true, { 1503 | mode: "abort", 1504 | port: "validate" + element.name, 1505 | dataType: "json", 1506 | data: data, 1507 | context: validator.currentForm, 1508 | success: function( response ) { 1509 | var valid = response === true || response === "true", 1510 | errors, message, submitted; 1511 | 1512 | validator.settings.messages[ element.name ][ method ] = previous.originalMessage; 1513 | if ( valid ) { 1514 | submitted = validator.formSubmitted; 1515 | validator.resetInternals(); 1516 | validator.toHide = validator.errorsFor( element ); 1517 | validator.formSubmitted = submitted; 1518 | validator.successList.push( element ); 1519 | validator.invalid[ element.name ] = false; 1520 | validator.showErrors(); 1521 | } else { 1522 | errors = {}; 1523 | message = response || validator.defaultMessage( element, { method: method, parameters: value } ); 1524 | errors[ element.name ] = previous.message = message; 1525 | validator.invalid[ element.name ] = true; 1526 | validator.showErrors( errors ); 1527 | } 1528 | previous.valid = valid; 1529 | validator.stopRequest( element, valid ); 1530 | } 1531 | }, param ) ); 1532 | return "pending"; 1533 | } 1534 | } 1535 | 1536 | } ); 1537 | 1538 | // Ajax mode: abort 1539 | // usage: $.ajax({ mode: "abort"[, port: "uniqueport"]}); 1540 | // if mode:"abort" is used, the previous request on that port (port can be undefined) is aborted via XMLHttpRequest.abort() 1541 | 1542 | var pendingRequests = {}, 1543 | ajax; 1544 | 1545 | // Use a prefilter if available (1.5+) 1546 | if ( $.ajaxPrefilter ) { 1547 | $.ajaxPrefilter( function( settings, _, xhr ) { 1548 | var port = settings.port; 1549 | if ( settings.mode === "abort" ) { 1550 | if ( pendingRequests[ port ] ) { 1551 | pendingRequests[ port ].abort(); 1552 | } 1553 | pendingRequests[ port ] = xhr; 1554 | } 1555 | } ); 1556 | } else { 1557 | 1558 | // Proxy ajax 1559 | ajax = $.ajax; 1560 | $.ajax = function( settings ) { 1561 | var mode = ( "mode" in settings ? settings : $.ajaxSettings ).mode, 1562 | port = ( "port" in settings ? settings : $.ajaxSettings ).port; 1563 | if ( mode === "abort" ) { 1564 | if ( pendingRequests[ port ] ) { 1565 | pendingRequests[ port ].abort(); 1566 | } 1567 | pendingRequests[ port ] = ajax.apply( this, arguments ); 1568 | return pendingRequests[ port ]; 1569 | } 1570 | return ajax.apply( this, arguments ); 1571 | }; 1572 | } 1573 | return $; 1574 | })); -------------------------------------------------------------------------------- /public/js/jquery-3.1.1.min.js: -------------------------------------------------------------------------------- 1 | /*! jQuery v3.1.1 | (c) jQuery Foundation | jquery.org/license */ 2 | !function(a,b){"use strict";"object"==typeof module&&"object"==typeof module.exports?module.exports=a.document?b(a,!0):function(a){if(!a.document)throw new Error("jQuery requires a window with a document");return b(a)}:b(a)}("undefined"!=typeof window?window:this,function(a,b){"use strict";var c=[],d=a.document,e=Object.getPrototypeOf,f=c.slice,g=c.concat,h=c.push,i=c.indexOf,j={},k=j.toString,l=j.hasOwnProperty,m=l.toString,n=m.call(Object),o={};function p(a,b){b=b||d;var c=b.createElement("script");c.text=a,b.head.appendChild(c).parentNode.removeChild(c)}var q="3.1.1",r=function(a,b){return new r.fn.init(a,b)},s=/^[\s\uFEFF\xA0]+|[\s\uFEFF\xA0]+$/g,t=/^-ms-/,u=/-([a-z])/g,v=function(a,b){return b.toUpperCase()};r.fn=r.prototype={jquery:q,constructor:r,length:0,toArray:function(){return f.call(this)},get:function(a){return null==a?f.call(this):a<0?this[a+this.length]:this[a]},pushStack:function(a){var b=r.merge(this.constructor(),a);return b.prevObject=this,b},each:function(a){return r.each(this,a)},map:function(a){return this.pushStack(r.map(this,function(b,c){return a.call(b,c,b)}))},slice:function(){return this.pushStack(f.apply(this,arguments))},first:function(){return this.eq(0)},last:function(){return this.eq(-1)},eq:function(a){var b=this.length,c=+a+(a<0?b:0);return this.pushStack(c>=0&&c0&&b-1 in a)}var x=function(a){var b,c,d,e,f,g,h,i,j,k,l,m,n,o,p,q,r,s,t,u="sizzle"+1*new Date,v=a.document,w=0,x=0,y=ha(),z=ha(),A=ha(),B=function(a,b){return a===b&&(l=!0),0},C={}.hasOwnProperty,D=[],E=D.pop,F=D.push,G=D.push,H=D.slice,I=function(a,b){for(var c=0,d=a.length;c+~]|"+K+")"+K+"*"),S=new RegExp("="+K+"*([^\\]'\"]*?)"+K+"*\\]","g"),T=new RegExp(N),U=new RegExp("^"+L+"$"),V={ID:new RegExp("^#("+L+")"),CLASS:new RegExp("^\\.("+L+")"),TAG:new RegExp("^("+L+"|[*])"),ATTR:new RegExp("^"+M),PSEUDO:new RegExp("^"+N),CHILD:new RegExp("^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\("+K+"*(even|odd|(([+-]|)(\\d*)n|)"+K+"*(?:([+-]|)"+K+"*(\\d+)|))"+K+"*\\)|)","i"),bool:new RegExp("^(?:"+J+")$","i"),needsContext:new RegExp("^"+K+"*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\("+K+"*((?:-\\d)?\\d*)"+K+"*\\)|)(?=[^-]|$)","i")},W=/^(?:input|select|textarea|button)$/i,X=/^h\d$/i,Y=/^[^{]+\{\s*\[native \w/,Z=/^(?:#([\w-]+)|(\w+)|\.([\w-]+))$/,$=/[+~]/,_=new RegExp("\\\\([\\da-f]{1,6}"+K+"?|("+K+")|.)","ig"),aa=function(a,b,c){var d="0x"+b-65536;return d!==d||c?b:d<0?String.fromCharCode(d+65536):String.fromCharCode(d>>10|55296,1023&d|56320)},ba=/([\0-\x1f\x7f]|^-?\d)|^-$|[^\0-\x1f\x7f-\uFFFF\w-]/g,ca=function(a,b){return b?"\0"===a?"\ufffd":a.slice(0,-1)+"\\"+a.charCodeAt(a.length-1).toString(16)+" ":"\\"+a},da=function(){m()},ea=ta(function(a){return a.disabled===!0&&("form"in a||"label"in a)},{dir:"parentNode",next:"legend"});try{G.apply(D=H.call(v.childNodes),v.childNodes),D[v.childNodes.length].nodeType}catch(fa){G={apply:D.length?function(a,b){F.apply(a,H.call(b))}:function(a,b){var c=a.length,d=0;while(a[c++]=b[d++]);a.length=c-1}}}function ga(a,b,d,e){var f,h,j,k,l,o,r,s=b&&b.ownerDocument,w=b?b.nodeType:9;if(d=d||[],"string"!=typeof a||!a||1!==w&&9!==w&&11!==w)return d;if(!e&&((b?b.ownerDocument||b:v)!==n&&m(b),b=b||n,p)){if(11!==w&&(l=Z.exec(a)))if(f=l[1]){if(9===w){if(!(j=b.getElementById(f)))return d;if(j.id===f)return d.push(j),d}else if(s&&(j=s.getElementById(f))&&t(b,j)&&j.id===f)return d.push(j),d}else{if(l[2])return G.apply(d,b.getElementsByTagName(a)),d;if((f=l[3])&&c.getElementsByClassName&&b.getElementsByClassName)return G.apply(d,b.getElementsByClassName(f)),d}if(c.qsa&&!A[a+" "]&&(!q||!q.test(a))){if(1!==w)s=b,r=a;else if("object"!==b.nodeName.toLowerCase()){(k=b.getAttribute("id"))?k=k.replace(ba,ca):b.setAttribute("id",k=u),o=g(a),h=o.length;while(h--)o[h]="#"+k+" "+sa(o[h]);r=o.join(","),s=$.test(a)&&qa(b.parentNode)||b}if(r)try{return G.apply(d,s.querySelectorAll(r)),d}catch(x){}finally{k===u&&b.removeAttribute("id")}}}return i(a.replace(P,"$1"),b,d,e)}function ha(){var a=[];function b(c,e){return a.push(c+" ")>d.cacheLength&&delete b[a.shift()],b[c+" "]=e}return b}function ia(a){return a[u]=!0,a}function ja(a){var b=n.createElement("fieldset");try{return!!a(b)}catch(c){return!1}finally{b.parentNode&&b.parentNode.removeChild(b),b=null}}function ka(a,b){var c=a.split("|"),e=c.length;while(e--)d.attrHandle[c[e]]=b}function la(a,b){var c=b&&a,d=c&&1===a.nodeType&&1===b.nodeType&&a.sourceIndex-b.sourceIndex;if(d)return d;if(c)while(c=c.nextSibling)if(c===b)return-1;return a?1:-1}function ma(a){return function(b){var c=b.nodeName.toLowerCase();return"input"===c&&b.type===a}}function na(a){return function(b){var c=b.nodeName.toLowerCase();return("input"===c||"button"===c)&&b.type===a}}function oa(a){return function(b){return"form"in b?b.parentNode&&b.disabled===!1?"label"in b?"label"in b.parentNode?b.parentNode.disabled===a:b.disabled===a:b.isDisabled===a||b.isDisabled!==!a&&ea(b)===a:b.disabled===a:"label"in b&&b.disabled===a}}function pa(a){return ia(function(b){return b=+b,ia(function(c,d){var e,f=a([],c.length,b),g=f.length;while(g--)c[e=f[g]]&&(c[e]=!(d[e]=c[e]))})})}function qa(a){return a&&"undefined"!=typeof a.getElementsByTagName&&a}c=ga.support={},f=ga.isXML=function(a){var b=a&&(a.ownerDocument||a).documentElement;return!!b&&"HTML"!==b.nodeName},m=ga.setDocument=function(a){var b,e,g=a?a.ownerDocument||a:v;return g!==n&&9===g.nodeType&&g.documentElement?(n=g,o=n.documentElement,p=!f(n),v!==n&&(e=n.defaultView)&&e.top!==e&&(e.addEventListener?e.addEventListener("unload",da,!1):e.attachEvent&&e.attachEvent("onunload",da)),c.attributes=ja(function(a){return a.className="i",!a.getAttribute("className")}),c.getElementsByTagName=ja(function(a){return a.appendChild(n.createComment("")),!a.getElementsByTagName("*").length}),c.getElementsByClassName=Y.test(n.getElementsByClassName),c.getById=ja(function(a){return o.appendChild(a).id=u,!n.getElementsByName||!n.getElementsByName(u).length}),c.getById?(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){return a.getAttribute("id")===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c=b.getElementById(a);return c?[c]:[]}}):(d.filter.ID=function(a){var b=a.replace(_,aa);return function(a){var c="undefined"!=typeof a.getAttributeNode&&a.getAttributeNode("id");return c&&c.value===b}},d.find.ID=function(a,b){if("undefined"!=typeof b.getElementById&&p){var c,d,e,f=b.getElementById(a);if(f){if(c=f.getAttributeNode("id"),c&&c.value===a)return[f];e=b.getElementsByName(a),d=0;while(f=e[d++])if(c=f.getAttributeNode("id"),c&&c.value===a)return[f]}return[]}}),d.find.TAG=c.getElementsByTagName?function(a,b){return"undefined"!=typeof b.getElementsByTagName?b.getElementsByTagName(a):c.qsa?b.querySelectorAll(a):void 0}:function(a,b){var c,d=[],e=0,f=b.getElementsByTagName(a);if("*"===a){while(c=f[e++])1===c.nodeType&&d.push(c);return d}return f},d.find.CLASS=c.getElementsByClassName&&function(a,b){if("undefined"!=typeof b.getElementsByClassName&&p)return b.getElementsByClassName(a)},r=[],q=[],(c.qsa=Y.test(n.querySelectorAll))&&(ja(function(a){o.appendChild(a).innerHTML="",a.querySelectorAll("[msallowcapture^='']").length&&q.push("[*^$]="+K+"*(?:''|\"\")"),a.querySelectorAll("[selected]").length||q.push("\\["+K+"*(?:value|"+J+")"),a.querySelectorAll("[id~="+u+"-]").length||q.push("~="),a.querySelectorAll(":checked").length||q.push(":checked"),a.querySelectorAll("a#"+u+"+*").length||q.push(".#.+[+~]")}),ja(function(a){a.innerHTML="";var b=n.createElement("input");b.setAttribute("type","hidden"),a.appendChild(b).setAttribute("name","D"),a.querySelectorAll("[name=d]").length&&q.push("name"+K+"*[*^$|!~]?="),2!==a.querySelectorAll(":enabled").length&&q.push(":enabled",":disabled"),o.appendChild(a).disabled=!0,2!==a.querySelectorAll(":disabled").length&&q.push(":enabled",":disabled"),a.querySelectorAll("*,:x"),q.push(",.*:")})),(c.matchesSelector=Y.test(s=o.matches||o.webkitMatchesSelector||o.mozMatchesSelector||o.oMatchesSelector||o.msMatchesSelector))&&ja(function(a){c.disconnectedMatch=s.call(a,"*"),s.call(a,"[s!='']:x"),r.push("!=",N)}),q=q.length&&new RegExp(q.join("|")),r=r.length&&new RegExp(r.join("|")),b=Y.test(o.compareDocumentPosition),t=b||Y.test(o.contains)?function(a,b){var c=9===a.nodeType?a.documentElement:a,d=b&&b.parentNode;return a===d||!(!d||1!==d.nodeType||!(c.contains?c.contains(d):a.compareDocumentPosition&&16&a.compareDocumentPosition(d)))}:function(a,b){if(b)while(b=b.parentNode)if(b===a)return!0;return!1},B=b?function(a,b){if(a===b)return l=!0,0;var d=!a.compareDocumentPosition-!b.compareDocumentPosition;return d?d:(d=(a.ownerDocument||a)===(b.ownerDocument||b)?a.compareDocumentPosition(b):1,1&d||!c.sortDetached&&b.compareDocumentPosition(a)===d?a===n||a.ownerDocument===v&&t(v,a)?-1:b===n||b.ownerDocument===v&&t(v,b)?1:k?I(k,a)-I(k,b):0:4&d?-1:1)}:function(a,b){if(a===b)return l=!0,0;var c,d=0,e=a.parentNode,f=b.parentNode,g=[a],h=[b];if(!e||!f)return a===n?-1:b===n?1:e?-1:f?1:k?I(k,a)-I(k,b):0;if(e===f)return la(a,b);c=a;while(c=c.parentNode)g.unshift(c);c=b;while(c=c.parentNode)h.unshift(c);while(g[d]===h[d])d++;return d?la(g[d],h[d]):g[d]===v?-1:h[d]===v?1:0},n):n},ga.matches=function(a,b){return ga(a,null,null,b)},ga.matchesSelector=function(a,b){if((a.ownerDocument||a)!==n&&m(a),b=b.replace(S,"='$1']"),c.matchesSelector&&p&&!A[b+" "]&&(!r||!r.test(b))&&(!q||!q.test(b)))try{var d=s.call(a,b);if(d||c.disconnectedMatch||a.document&&11!==a.document.nodeType)return d}catch(e){}return ga(b,n,null,[a]).length>0},ga.contains=function(a,b){return(a.ownerDocument||a)!==n&&m(a),t(a,b)},ga.attr=function(a,b){(a.ownerDocument||a)!==n&&m(a);var e=d.attrHandle[b.toLowerCase()],f=e&&C.call(d.attrHandle,b.toLowerCase())?e(a,b,!p):void 0;return void 0!==f?f:c.attributes||!p?a.getAttribute(b):(f=a.getAttributeNode(b))&&f.specified?f.value:null},ga.escape=function(a){return(a+"").replace(ba,ca)},ga.error=function(a){throw new Error("Syntax error, unrecognized expression: "+a)},ga.uniqueSort=function(a){var b,d=[],e=0,f=0;if(l=!c.detectDuplicates,k=!c.sortStable&&a.slice(0),a.sort(B),l){while(b=a[f++])b===a[f]&&(e=d.push(f));while(e--)a.splice(d[e],1)}return k=null,a},e=ga.getText=function(a){var b,c="",d=0,f=a.nodeType;if(f){if(1===f||9===f||11===f){if("string"==typeof a.textContent)return a.textContent;for(a=a.firstChild;a;a=a.nextSibling)c+=e(a)}else if(3===f||4===f)return a.nodeValue}else while(b=a[d++])c+=e(b);return c},d=ga.selectors={cacheLength:50,createPseudo:ia,match:V,attrHandle:{},find:{},relative:{">":{dir:"parentNode",first:!0}," ":{dir:"parentNode"},"+":{dir:"previousSibling",first:!0},"~":{dir:"previousSibling"}},preFilter:{ATTR:function(a){return a[1]=a[1].replace(_,aa),a[3]=(a[3]||a[4]||a[5]||"").replace(_,aa),"~="===a[2]&&(a[3]=" "+a[3]+" "),a.slice(0,4)},CHILD:function(a){return a[1]=a[1].toLowerCase(),"nth"===a[1].slice(0,3)?(a[3]||ga.error(a[0]),a[4]=+(a[4]?a[5]+(a[6]||1):2*("even"===a[3]||"odd"===a[3])),a[5]=+(a[7]+a[8]||"odd"===a[3])):a[3]&&ga.error(a[0]),a},PSEUDO:function(a){var b,c=!a[6]&&a[2];return V.CHILD.test(a[0])?null:(a[3]?a[2]=a[4]||a[5]||"":c&&T.test(c)&&(b=g(c,!0))&&(b=c.indexOf(")",c.length-b)-c.length)&&(a[0]=a[0].slice(0,b),a[2]=c.slice(0,b)),a.slice(0,3))}},filter:{TAG:function(a){var b=a.replace(_,aa).toLowerCase();return"*"===a?function(){return!0}:function(a){return a.nodeName&&a.nodeName.toLowerCase()===b}},CLASS:function(a){var b=y[a+" "];return b||(b=new RegExp("(^|"+K+")"+a+"("+K+"|$)"))&&y(a,function(a){return b.test("string"==typeof a.className&&a.className||"undefined"!=typeof a.getAttribute&&a.getAttribute("class")||"")})},ATTR:function(a,b,c){return function(d){var e=ga.attr(d,a);return null==e?"!="===b:!b||(e+="","="===b?e===c:"!="===b?e!==c:"^="===b?c&&0===e.indexOf(c):"*="===b?c&&e.indexOf(c)>-1:"$="===b?c&&e.slice(-c.length)===c:"~="===b?(" "+e.replace(O," ")+" ").indexOf(c)>-1:"|="===b&&(e===c||e.slice(0,c.length+1)===c+"-"))}},CHILD:function(a,b,c,d,e){var f="nth"!==a.slice(0,3),g="last"!==a.slice(-4),h="of-type"===b;return 1===d&&0===e?function(a){return!!a.parentNode}:function(b,c,i){var j,k,l,m,n,o,p=f!==g?"nextSibling":"previousSibling",q=b.parentNode,r=h&&b.nodeName.toLowerCase(),s=!i&&!h,t=!1;if(q){if(f){while(p){m=b;while(m=m[p])if(h?m.nodeName.toLowerCase()===r:1===m.nodeType)return!1;o=p="only"===a&&!o&&"nextSibling"}return!0}if(o=[g?q.firstChild:q.lastChild],g&&s){m=q,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n&&j[2],m=n&&q.childNodes[n];while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if(1===m.nodeType&&++t&&m===b){k[a]=[w,n,t];break}}else if(s&&(m=b,l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),j=k[a]||[],n=j[0]===w&&j[1],t=n),t===!1)while(m=++n&&m&&m[p]||(t=n=0)||o.pop())if((h?m.nodeName.toLowerCase()===r:1===m.nodeType)&&++t&&(s&&(l=m[u]||(m[u]={}),k=l[m.uniqueID]||(l[m.uniqueID]={}),k[a]=[w,t]),m===b))break;return t-=e,t===d||t%d===0&&t/d>=0}}},PSEUDO:function(a,b){var c,e=d.pseudos[a]||d.setFilters[a.toLowerCase()]||ga.error("unsupported pseudo: "+a);return e[u]?e(b):e.length>1?(c=[a,a,"",b],d.setFilters.hasOwnProperty(a.toLowerCase())?ia(function(a,c){var d,f=e(a,b),g=f.length;while(g--)d=I(a,f[g]),a[d]=!(c[d]=f[g])}):function(a){return e(a,0,c)}):e}},pseudos:{not:ia(function(a){var b=[],c=[],d=h(a.replace(P,"$1"));return d[u]?ia(function(a,b,c,e){var f,g=d(a,null,e,[]),h=a.length;while(h--)(f=g[h])&&(a[h]=!(b[h]=f))}):function(a,e,f){return b[0]=a,d(b,null,f,c),b[0]=null,!c.pop()}}),has:ia(function(a){return function(b){return ga(a,b).length>0}}),contains:ia(function(a){return a=a.replace(_,aa),function(b){return(b.textContent||b.innerText||e(b)).indexOf(a)>-1}}),lang:ia(function(a){return U.test(a||"")||ga.error("unsupported lang: "+a),a=a.replace(_,aa).toLowerCase(),function(b){var c;do if(c=p?b.lang:b.getAttribute("xml:lang")||b.getAttribute("lang"))return c=c.toLowerCase(),c===a||0===c.indexOf(a+"-");while((b=b.parentNode)&&1===b.nodeType);return!1}}),target:function(b){var c=a.location&&a.location.hash;return c&&c.slice(1)===b.id},root:function(a){return a===o},focus:function(a){return a===n.activeElement&&(!n.hasFocus||n.hasFocus())&&!!(a.type||a.href||~a.tabIndex)},enabled:oa(!1),disabled:oa(!0),checked:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&!!a.checked||"option"===b&&!!a.selected},selected:function(a){return a.parentNode&&a.parentNode.selectedIndex,a.selected===!0},empty:function(a){for(a=a.firstChild;a;a=a.nextSibling)if(a.nodeType<6)return!1;return!0},parent:function(a){return!d.pseudos.empty(a)},header:function(a){return X.test(a.nodeName)},input:function(a){return W.test(a.nodeName)},button:function(a){var b=a.nodeName.toLowerCase();return"input"===b&&"button"===a.type||"button"===b},text:function(a){var b;return"input"===a.nodeName.toLowerCase()&&"text"===a.type&&(null==(b=a.getAttribute("type"))||"text"===b.toLowerCase())},first:pa(function(){return[0]}),last:pa(function(a,b){return[b-1]}),eq:pa(function(a,b,c){return[c<0?c+b:c]}),even:pa(function(a,b){for(var c=0;c=0;)a.push(d);return a}),gt:pa(function(a,b,c){for(var d=c<0?c+b:c;++d1?function(b,c,d){var e=a.length;while(e--)if(!a[e](b,c,d))return!1;return!0}:a[0]}function va(a,b,c){for(var d=0,e=b.length;d-1&&(f[j]=!(g[j]=l))}}else r=wa(r===g?r.splice(o,r.length):r),e?e(null,g,r,i):G.apply(g,r)})}function ya(a){for(var b,c,e,f=a.length,g=d.relative[a[0].type],h=g||d.relative[" "],i=g?1:0,k=ta(function(a){return a===b},h,!0),l=ta(function(a){return I(b,a)>-1},h,!0),m=[function(a,c,d){var e=!g&&(d||c!==j)||((b=c).nodeType?k(a,c,d):l(a,c,d));return b=null,e}];i1&&ua(m),i>1&&sa(a.slice(0,i-1).concat({value:" "===a[i-2].type?"*":""})).replace(P,"$1"),c,i0,e=a.length>0,f=function(f,g,h,i,k){var l,o,q,r=0,s="0",t=f&&[],u=[],v=j,x=f||e&&d.find.TAG("*",k),y=w+=null==v?1:Math.random()||.1,z=x.length;for(k&&(j=g===n||g||k);s!==z&&null!=(l=x[s]);s++){if(e&&l){o=0,g||l.ownerDocument===n||(m(l),h=!p);while(q=a[o++])if(q(l,g||n,h)){i.push(l);break}k&&(w=y)}c&&((l=!q&&l)&&r--,f&&t.push(l))}if(r+=s,c&&s!==r){o=0;while(q=b[o++])q(t,u,g,h);if(f){if(r>0)while(s--)t[s]||u[s]||(u[s]=E.call(i));u=wa(u)}G.apply(i,u),k&&!f&&u.length>0&&r+b.length>1&&ga.uniqueSort(i)}return k&&(w=y,j=v),t};return c?ia(f):f}return h=ga.compile=function(a,b){var c,d=[],e=[],f=A[a+" "];if(!f){b||(b=g(a)),c=b.length;while(c--)f=ya(b[c]),f[u]?d.push(f):e.push(f);f=A(a,za(e,d)),f.selector=a}return f},i=ga.select=function(a,b,c,e){var f,i,j,k,l,m="function"==typeof a&&a,n=!e&&g(a=m.selector||a);if(c=c||[],1===n.length){if(i=n[0]=n[0].slice(0),i.length>2&&"ID"===(j=i[0]).type&&9===b.nodeType&&p&&d.relative[i[1].type]){if(b=(d.find.ID(j.matches[0].replace(_,aa),b)||[])[0],!b)return c;m&&(b=b.parentNode),a=a.slice(i.shift().value.length)}f=V.needsContext.test(a)?0:i.length;while(f--){if(j=i[f],d.relative[k=j.type])break;if((l=d.find[k])&&(e=l(j.matches[0].replace(_,aa),$.test(i[0].type)&&qa(b.parentNode)||b))){if(i.splice(f,1),a=e.length&&sa(i),!a)return G.apply(c,e),c;break}}}return(m||h(a,n))(e,b,!p,c,!b||$.test(a)&&qa(b.parentNode)||b),c},c.sortStable=u.split("").sort(B).join("")===u,c.detectDuplicates=!!l,m(),c.sortDetached=ja(function(a){return 1&a.compareDocumentPosition(n.createElement("fieldset"))}),ja(function(a){return a.innerHTML="","#"===a.firstChild.getAttribute("href")})||ka("type|href|height|width",function(a,b,c){if(!c)return a.getAttribute(b,"type"===b.toLowerCase()?1:2)}),c.attributes&&ja(function(a){return a.innerHTML="",a.firstChild.setAttribute("value",""),""===a.firstChild.getAttribute("value")})||ka("value",function(a,b,c){if(!c&&"input"===a.nodeName.toLowerCase())return a.defaultValue}),ja(function(a){return null==a.getAttribute("disabled")})||ka(J,function(a,b,c){var d;if(!c)return a[b]===!0?b.toLowerCase():(d=a.getAttributeNode(b))&&d.specified?d.value:null}),ga}(a);r.find=x,r.expr=x.selectors,r.expr[":"]=r.expr.pseudos,r.uniqueSort=r.unique=x.uniqueSort,r.text=x.getText,r.isXMLDoc=x.isXML,r.contains=x.contains,r.escapeSelector=x.escape;var y=function(a,b,c){var d=[],e=void 0!==c;while((a=a[b])&&9!==a.nodeType)if(1===a.nodeType){if(e&&r(a).is(c))break;d.push(a)}return d},z=function(a,b){for(var c=[];a;a=a.nextSibling)1===a.nodeType&&a!==b&&c.push(a);return c},A=r.expr.match.needsContext,B=/^<([a-z][^\/\0>:\x20\t\r\n\f]*)[\x20\t\r\n\f]*\/?>(?:<\/\1>|)$/i,C=/^.[^:#\[\.,]*$/;function D(a,b,c){return r.isFunction(b)?r.grep(a,function(a,d){return!!b.call(a,d,a)!==c}):b.nodeType?r.grep(a,function(a){return a===b!==c}):"string"!=typeof b?r.grep(a,function(a){return i.call(b,a)>-1!==c}):C.test(b)?r.filter(b,a,c):(b=r.filter(b,a),r.grep(a,function(a){return i.call(b,a)>-1!==c&&1===a.nodeType}))}r.filter=function(a,b,c){var d=b[0];return c&&(a=":not("+a+")"),1===b.length&&1===d.nodeType?r.find.matchesSelector(d,a)?[d]:[]:r.find.matches(a,r.grep(b,function(a){return 1===a.nodeType}))},r.fn.extend({find:function(a){var b,c,d=this.length,e=this;if("string"!=typeof a)return this.pushStack(r(a).filter(function(){for(b=0;b1?r.uniqueSort(c):c},filter:function(a){return this.pushStack(D(this,a||[],!1))},not:function(a){return this.pushStack(D(this,a||[],!0))},is:function(a){return!!D(this,"string"==typeof a&&A.test(a)?r(a):a||[],!1).length}});var E,F=/^(?:\s*(<[\w\W]+>)[^>]*|#([\w-]+))$/,G=r.fn.init=function(a,b,c){var e,f;if(!a)return this;if(c=c||E,"string"==typeof a){if(e="<"===a[0]&&">"===a[a.length-1]&&a.length>=3?[null,a,null]:F.exec(a),!e||!e[1]&&b)return!b||b.jquery?(b||c).find(a):this.constructor(b).find(a);if(e[1]){if(b=b instanceof r?b[0]:b,r.merge(this,r.parseHTML(e[1],b&&b.nodeType?b.ownerDocument||b:d,!0)),B.test(e[1])&&r.isPlainObject(b))for(e in b)r.isFunction(this[e])?this[e](b[e]):this.attr(e,b[e]);return this}return f=d.getElementById(e[2]),f&&(this[0]=f,this.length=1),this}return a.nodeType?(this[0]=a,this.length=1,this):r.isFunction(a)?void 0!==c.ready?c.ready(a):a(r):r.makeArray(a,this)};G.prototype=r.fn,E=r(d);var H=/^(?:parents|prev(?:Until|All))/,I={children:!0,contents:!0,next:!0,prev:!0};r.fn.extend({has:function(a){var b=r(a,this),c=b.length;return this.filter(function(){for(var a=0;a-1:1===c.nodeType&&r.find.matchesSelector(c,a))){f.push(c);break}return this.pushStack(f.length>1?r.uniqueSort(f):f)},index:function(a){return a?"string"==typeof a?i.call(r(a),this[0]):i.call(this,a.jquery?a[0]:a):this[0]&&this[0].parentNode?this.first().prevAll().length:-1},add:function(a,b){return this.pushStack(r.uniqueSort(r.merge(this.get(),r(a,b))))},addBack:function(a){return this.add(null==a?this.prevObject:this.prevObject.filter(a))}});function J(a,b){while((a=a[b])&&1!==a.nodeType);return a}r.each({parent:function(a){var b=a.parentNode;return b&&11!==b.nodeType?b:null},parents:function(a){return y(a,"parentNode")},parentsUntil:function(a,b,c){return y(a,"parentNode",c)},next:function(a){return J(a,"nextSibling")},prev:function(a){return J(a,"previousSibling")},nextAll:function(a){return y(a,"nextSibling")},prevAll:function(a){return y(a,"previousSibling")},nextUntil:function(a,b,c){return y(a,"nextSibling",c)},prevUntil:function(a,b,c){return y(a,"previousSibling",c)},siblings:function(a){return z((a.parentNode||{}).firstChild,a)},children:function(a){return z(a.firstChild)},contents:function(a){return a.contentDocument||r.merge([],a.childNodes)}},function(a,b){r.fn[a]=function(c,d){var e=r.map(this,b,c);return"Until"!==a.slice(-5)&&(d=c),d&&"string"==typeof d&&(e=r.filter(d,e)),this.length>1&&(I[a]||r.uniqueSort(e),H.test(a)&&e.reverse()),this.pushStack(e)}});var K=/[^\x20\t\r\n\f]+/g;function L(a){var b={};return r.each(a.match(K)||[],function(a,c){b[c]=!0}),b}r.Callbacks=function(a){a="string"==typeof a?L(a):r.extend({},a);var b,c,d,e,f=[],g=[],h=-1,i=function(){for(e=a.once,d=b=!0;g.length;h=-1){c=g.shift();while(++h-1)f.splice(c,1),c<=h&&h--}),this},has:function(a){return a?r.inArray(a,f)>-1:f.length>0},empty:function(){return f&&(f=[]),this},disable:function(){return e=g=[],f=c="",this},disabled:function(){return!f},lock:function(){return e=g=[],c||b||(f=c=""),this},locked:function(){return!!e},fireWith:function(a,c){return e||(c=c||[],c=[a,c.slice?c.slice():c],g.push(c),b||i()),this},fire:function(){return j.fireWith(this,arguments),this},fired:function(){return!!d}};return j};function M(a){return a}function N(a){throw a}function O(a,b,c){var d;try{a&&r.isFunction(d=a.promise)?d.call(a).done(b).fail(c):a&&r.isFunction(d=a.then)?d.call(a,b,c):b.call(void 0,a)}catch(a){c.call(void 0,a)}}r.extend({Deferred:function(b){var c=[["notify","progress",r.Callbacks("memory"),r.Callbacks("memory"),2],["resolve","done",r.Callbacks("once memory"),r.Callbacks("once memory"),0,"resolved"],["reject","fail",r.Callbacks("once memory"),r.Callbacks("once memory"),1,"rejected"]],d="pending",e={state:function(){return d},always:function(){return f.done(arguments).fail(arguments),this},"catch":function(a){return e.then(null,a)},pipe:function(){var a=arguments;return r.Deferred(function(b){r.each(c,function(c,d){var e=r.isFunction(a[d[4]])&&a[d[4]];f[d[1]](function(){var a=e&&e.apply(this,arguments);a&&r.isFunction(a.promise)?a.promise().progress(b.notify).done(b.resolve).fail(b.reject):b[d[0]+"With"](this,e?[a]:arguments)})}),a=null}).promise()},then:function(b,d,e){var f=0;function g(b,c,d,e){return function(){var h=this,i=arguments,j=function(){var a,j;if(!(b=f&&(d!==N&&(h=void 0,i=[a]),c.rejectWith(h,i))}};b?k():(r.Deferred.getStackHook&&(k.stackTrace=r.Deferred.getStackHook()),a.setTimeout(k))}}return r.Deferred(function(a){c[0][3].add(g(0,a,r.isFunction(e)?e:M,a.notifyWith)),c[1][3].add(g(0,a,r.isFunction(b)?b:M)),c[2][3].add(g(0,a,r.isFunction(d)?d:N))}).promise()},promise:function(a){return null!=a?r.extend(a,e):e}},f={};return r.each(c,function(a,b){var g=b[2],h=b[5];e[b[1]]=g.add,h&&g.add(function(){d=h},c[3-a][2].disable,c[0][2].lock),g.add(b[3].fire),f[b[0]]=function(){return f[b[0]+"With"](this===f?void 0:this,arguments),this},f[b[0]+"With"]=g.fireWith}),e.promise(f),b&&b.call(f,f),f},when:function(a){var b=arguments.length,c=b,d=Array(c),e=f.call(arguments),g=r.Deferred(),h=function(a){return function(c){d[a]=this,e[a]=arguments.length>1?f.call(arguments):c,--b||g.resolveWith(d,e)}};if(b<=1&&(O(a,g.done(h(c)).resolve,g.reject),"pending"===g.state()||r.isFunction(e[c]&&e[c].then)))return g.then();while(c--)O(e[c],h(c),g.reject);return g.promise()}});var P=/^(Eval|Internal|Range|Reference|Syntax|Type|URI)Error$/;r.Deferred.exceptionHook=function(b,c){a.console&&a.console.warn&&b&&P.test(b.name)&&a.console.warn("jQuery.Deferred exception: "+b.message,b.stack,c)},r.readyException=function(b){a.setTimeout(function(){throw b})};var Q=r.Deferred();r.fn.ready=function(a){return Q.then(a)["catch"](function(a){r.readyException(a)}),this},r.extend({isReady:!1,readyWait:1,holdReady:function(a){a?r.readyWait++:r.ready(!0)},ready:function(a){(a===!0?--r.readyWait:r.isReady)||(r.isReady=!0,a!==!0&&--r.readyWait>0||Q.resolveWith(d,[r]))}}),r.ready.then=Q.then;function R(){d.removeEventListener("DOMContentLoaded",R), 3 | a.removeEventListener("load",R),r.ready()}"complete"===d.readyState||"loading"!==d.readyState&&!d.documentElement.doScroll?a.setTimeout(r.ready):(d.addEventListener("DOMContentLoaded",R),a.addEventListener("load",R));var S=function(a,b,c,d,e,f,g){var h=0,i=a.length,j=null==c;if("object"===r.type(c)){e=!0;for(h in c)S(a,b,h,c[h],!0,f,g)}else if(void 0!==d&&(e=!0,r.isFunction(d)||(g=!0),j&&(g?(b.call(a,d),b=null):(j=b,b=function(a,b,c){return j.call(r(a),c)})),b))for(;h1,null,!0)},removeData:function(a){return this.each(function(){W.remove(this,a)})}}),r.extend({queue:function(a,b,c){var d;if(a)return b=(b||"fx")+"queue",d=V.get(a,b),c&&(!d||r.isArray(c)?d=V.access(a,b,r.makeArray(c)):d.push(c)),d||[]},dequeue:function(a,b){b=b||"fx";var c=r.queue(a,b),d=c.length,e=c.shift(),f=r._queueHooks(a,b),g=function(){r.dequeue(a,b)};"inprogress"===e&&(e=c.shift(),d--),e&&("fx"===b&&c.unshift("inprogress"),delete f.stop,e.call(a,g,f)),!d&&f&&f.empty.fire()},_queueHooks:function(a,b){var c=b+"queueHooks";return V.get(a,c)||V.access(a,c,{empty:r.Callbacks("once memory").add(function(){V.remove(a,[b+"queue",c])})})}}),r.fn.extend({queue:function(a,b){var c=2;return"string"!=typeof a&&(b=a,a="fx",c--),arguments.length\x20\t\r\n\f]+)/i,ka=/^$|\/(?:java|ecma)script/i,la={option:[1,""],thead:[1,"","
"],col:[2,"","
"],tr:[2,"","
"],td:[3,"","
"],_default:[0,"",""]};la.optgroup=la.option,la.tbody=la.tfoot=la.colgroup=la.caption=la.thead,la.th=la.td;function ma(a,b){var c;return c="undefined"!=typeof a.getElementsByTagName?a.getElementsByTagName(b||"*"):"undefined"!=typeof a.querySelectorAll?a.querySelectorAll(b||"*"):[],void 0===b||b&&r.nodeName(a,b)?r.merge([a],c):c}function na(a,b){for(var c=0,d=a.length;c-1)e&&e.push(f);else if(j=r.contains(f.ownerDocument,f),g=ma(l.appendChild(f),"script"),j&&na(g),c){k=0;while(f=g[k++])ka.test(f.type||"")&&c.push(f)}return l}!function(){var a=d.createDocumentFragment(),b=a.appendChild(d.createElement("div")),c=d.createElement("input");c.setAttribute("type","radio"),c.setAttribute("checked","checked"),c.setAttribute("name","t"),b.appendChild(c),o.checkClone=b.cloneNode(!0).cloneNode(!0).lastChild.checked,b.innerHTML="",o.noCloneChecked=!!b.cloneNode(!0).lastChild.defaultValue}();var qa=d.documentElement,ra=/^key/,sa=/^(?:mouse|pointer|contextmenu|drag|drop)|click/,ta=/^([^.]*)(?:\.(.+)|)/;function ua(){return!0}function va(){return!1}function wa(){try{return d.activeElement}catch(a){}}function xa(a,b,c,d,e,f){var g,h;if("object"==typeof b){"string"!=typeof c&&(d=d||c,c=void 0);for(h in b)xa(a,h,c,d,b[h],f);return a}if(null==d&&null==e?(e=c,d=c=void 0):null==e&&("string"==typeof c?(e=d,d=void 0):(e=d,d=c,c=void 0)),e===!1)e=va;else if(!e)return a;return 1===f&&(g=e,e=function(a){return r().off(a),g.apply(this,arguments)},e.guid=g.guid||(g.guid=r.guid++)),a.each(function(){r.event.add(this,b,e,d,c)})}r.event={global:{},add:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=V.get(a);if(q){c.handler&&(f=c,c=f.handler,e=f.selector),e&&r.find.matchesSelector(qa,e),c.guid||(c.guid=r.guid++),(i=q.events)||(i=q.events={}),(g=q.handle)||(g=q.handle=function(b){return"undefined"!=typeof r&&r.event.triggered!==b.type?r.event.dispatch.apply(a,arguments):void 0}),b=(b||"").match(K)||[""],j=b.length;while(j--)h=ta.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n&&(l=r.event.special[n]||{},n=(e?l.delegateType:l.bindType)||n,l=r.event.special[n]||{},k=r.extend({type:n,origType:p,data:d,handler:c,guid:c.guid,selector:e,needsContext:e&&r.expr.match.needsContext.test(e),namespace:o.join(".")},f),(m=i[n])||(m=i[n]=[],m.delegateCount=0,l.setup&&l.setup.call(a,d,o,g)!==!1||a.addEventListener&&a.addEventListener(n,g)),l.add&&(l.add.call(a,k),k.handler.guid||(k.handler.guid=c.guid)),e?m.splice(m.delegateCount++,0,k):m.push(k),r.event.global[n]=!0)}},remove:function(a,b,c,d,e){var f,g,h,i,j,k,l,m,n,o,p,q=V.hasData(a)&&V.get(a);if(q&&(i=q.events)){b=(b||"").match(K)||[""],j=b.length;while(j--)if(h=ta.exec(b[j])||[],n=p=h[1],o=(h[2]||"").split(".").sort(),n){l=r.event.special[n]||{},n=(d?l.delegateType:l.bindType)||n,m=i[n]||[],h=h[2]&&new RegExp("(^|\\.)"+o.join("\\.(?:.*\\.|)")+"(\\.|$)"),g=f=m.length;while(f--)k=m[f],!e&&p!==k.origType||c&&c.guid!==k.guid||h&&!h.test(k.namespace)||d&&d!==k.selector&&("**"!==d||!k.selector)||(m.splice(f,1),k.selector&&m.delegateCount--,l.remove&&l.remove.call(a,k));g&&!m.length&&(l.teardown&&l.teardown.call(a,o,q.handle)!==!1||r.removeEvent(a,n,q.handle),delete i[n])}else for(n in i)r.event.remove(a,n+b[j],c,d,!0);r.isEmptyObject(i)&&V.remove(a,"handle events")}},dispatch:function(a){var b=r.event.fix(a),c,d,e,f,g,h,i=new Array(arguments.length),j=(V.get(this,"events")||{})[b.type]||[],k=r.event.special[b.type]||{};for(i[0]=b,c=1;c=1))for(;j!==this;j=j.parentNode||this)if(1===j.nodeType&&("click"!==a.type||j.disabled!==!0)){for(f=[],g={},c=0;c-1:r.find(e,this,null,[j]).length),g[e]&&f.push(d);f.length&&h.push({elem:j,handlers:f})}return j=this,i\x20\t\r\n\f]*)[^>]*)\/>/gi,za=/\s*$/g;function Da(a,b){return r.nodeName(a,"table")&&r.nodeName(11!==b.nodeType?b:b.firstChild,"tr")?a.getElementsByTagName("tbody")[0]||a:a}function Ea(a){return a.type=(null!==a.getAttribute("type"))+"/"+a.type,a}function Fa(a){var b=Ba.exec(a.type);return b?a.type=b[1]:a.removeAttribute("type"),a}function Ga(a,b){var c,d,e,f,g,h,i,j;if(1===b.nodeType){if(V.hasData(a)&&(f=V.access(a),g=V.set(b,f),j=f.events)){delete g.handle,g.events={};for(e in j)for(c=0,d=j[e].length;c1&&"string"==typeof q&&!o.checkClone&&Aa.test(q))return a.each(function(e){var f=a.eq(e);s&&(b[0]=q.call(this,e,f.html())),Ia(f,b,c,d)});if(m&&(e=pa(b,a[0].ownerDocument,!1,a,d),f=e.firstChild,1===e.childNodes.length&&(e=f),f||d)){for(h=r.map(ma(e,"script"),Ea),i=h.length;l")},clone:function(a,b,c){var d,e,f,g,h=a.cloneNode(!0),i=r.contains(a.ownerDocument,a);if(!(o.noCloneChecked||1!==a.nodeType&&11!==a.nodeType||r.isXMLDoc(a)))for(g=ma(h),f=ma(a),d=0,e=f.length;d0&&na(g,!i&&ma(a,"script")),h},cleanData:function(a){for(var b,c,d,e=r.event.special,f=0;void 0!==(c=a[f]);f++)if(T(c)){if(b=c[V.expando]){if(b.events)for(d in b.events)e[d]?r.event.remove(c,d):r.removeEvent(c,d,b.handle);c[V.expando]=void 0}c[W.expando]&&(c[W.expando]=void 0)}}}),r.fn.extend({detach:function(a){return Ja(this,a,!0)},remove:function(a){return Ja(this,a)},text:function(a){return S(this,function(a){return void 0===a?r.text(this):this.empty().each(function(){1!==this.nodeType&&11!==this.nodeType&&9!==this.nodeType||(this.textContent=a)})},null,a,arguments.length)},append:function(){return Ia(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Da(this,a);b.appendChild(a)}})},prepend:function(){return Ia(this,arguments,function(a){if(1===this.nodeType||11===this.nodeType||9===this.nodeType){var b=Da(this,a);b.insertBefore(a,b.firstChild)}})},before:function(){return Ia(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this)})},after:function(){return Ia(this,arguments,function(a){this.parentNode&&this.parentNode.insertBefore(a,this.nextSibling)})},empty:function(){for(var a,b=0;null!=(a=this[b]);b++)1===a.nodeType&&(r.cleanData(ma(a,!1)),a.textContent="");return this},clone:function(a,b){return a=null!=a&&a,b=null==b?a:b,this.map(function(){return r.clone(this,a,b)})},html:function(a){return S(this,function(a){var b=this[0]||{},c=0,d=this.length;if(void 0===a&&1===b.nodeType)return b.innerHTML;if("string"==typeof a&&!za.test(a)&&!la[(ja.exec(a)||["",""])[1].toLowerCase()]){a=r.htmlPrefilter(a);try{for(;c1)}});function Ya(a,b,c,d,e){return new Ya.prototype.init(a,b,c,d,e)}r.Tween=Ya,Ya.prototype={constructor:Ya,init:function(a,b,c,d,e,f){this.elem=a,this.prop=c,this.easing=e||r.easing._default,this.options=b,this.start=this.now=this.cur(),this.end=d,this.unit=f||(r.cssNumber[c]?"":"px")},cur:function(){var a=Ya.propHooks[this.prop];return a&&a.get?a.get(this):Ya.propHooks._default.get(this)},run:function(a){var b,c=Ya.propHooks[this.prop];return this.options.duration?this.pos=b=r.easing[this.easing](a,this.options.duration*a,0,1,this.options.duration):this.pos=b=a,this.now=(this.end-this.start)*b+this.start,this.options.step&&this.options.step.call(this.elem,this.now,this),c&&c.set?c.set(this):Ya.propHooks._default.set(this),this}},Ya.prototype.init.prototype=Ya.prototype,Ya.propHooks={_default:{get:function(a){var b;return 1!==a.elem.nodeType||null!=a.elem[a.prop]&&null==a.elem.style[a.prop]?a.elem[a.prop]:(b=r.css(a.elem,a.prop,""),b&&"auto"!==b?b:0)},set:function(a){r.fx.step[a.prop]?r.fx.step[a.prop](a):1!==a.elem.nodeType||null==a.elem.style[r.cssProps[a.prop]]&&!r.cssHooks[a.prop]?a.elem[a.prop]=a.now:r.style(a.elem,a.prop,a.now+a.unit)}}},Ya.propHooks.scrollTop=Ya.propHooks.scrollLeft={set:function(a){a.elem.nodeType&&a.elem.parentNode&&(a.elem[a.prop]=a.now)}},r.easing={linear:function(a){return a},swing:function(a){return.5-Math.cos(a*Math.PI)/2},_default:"swing"},r.fx=Ya.prototype.init,r.fx.step={};var Za,$a,_a=/^(?:toggle|show|hide)$/,ab=/queueHooks$/;function bb(){$a&&(a.requestAnimationFrame(bb),r.fx.tick())}function cb(){return a.setTimeout(function(){Za=void 0}),Za=r.now()}function db(a,b){var c,d=0,e={height:a};for(b=b?1:0;d<4;d+=2-b)c=ba[d],e["margin"+c]=e["padding"+c]=a;return b&&(e.opacity=e.width=a),e}function eb(a,b,c){for(var d,e=(hb.tweeners[b]||[]).concat(hb.tweeners["*"]),f=0,g=e.length;f1)},removeAttr:function(a){return this.each(function(){r.removeAttr(this,a)})}}),r.extend({attr:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return"undefined"==typeof a.getAttribute?r.prop(a,b,c):(1===f&&r.isXMLDoc(a)||(e=r.attrHooks[b.toLowerCase()]||(r.expr.match.bool.test(b)?ib:void 0)), 4 | void 0!==c?null===c?void r.removeAttr(a,b):e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:(a.setAttribute(b,c+""),c):e&&"get"in e&&null!==(d=e.get(a,b))?d:(d=r.find.attr(a,b),null==d?void 0:d))},attrHooks:{type:{set:function(a,b){if(!o.radioValue&&"radio"===b&&r.nodeName(a,"input")){var c=a.value;return a.setAttribute("type",b),c&&(a.value=c),b}}}},removeAttr:function(a,b){var c,d=0,e=b&&b.match(K);if(e&&1===a.nodeType)while(c=e[d++])a.removeAttribute(c)}}),ib={set:function(a,b,c){return b===!1?r.removeAttr(a,c):a.setAttribute(c,c),c}},r.each(r.expr.match.bool.source.match(/\w+/g),function(a,b){var c=jb[b]||r.find.attr;jb[b]=function(a,b,d){var e,f,g=b.toLowerCase();return d||(f=jb[g],jb[g]=e,e=null!=c(a,b,d)?g:null,jb[g]=f),e}});var kb=/^(?:input|select|textarea|button)$/i,lb=/^(?:a|area)$/i;r.fn.extend({prop:function(a,b){return S(this,r.prop,a,b,arguments.length>1)},removeProp:function(a){return this.each(function(){delete this[r.propFix[a]||a]})}}),r.extend({prop:function(a,b,c){var d,e,f=a.nodeType;if(3!==f&&8!==f&&2!==f)return 1===f&&r.isXMLDoc(a)||(b=r.propFix[b]||b,e=r.propHooks[b]),void 0!==c?e&&"set"in e&&void 0!==(d=e.set(a,c,b))?d:a[b]=c:e&&"get"in e&&null!==(d=e.get(a,b))?d:a[b]},propHooks:{tabIndex:{get:function(a){var b=r.find.attr(a,"tabindex");return b?parseInt(b,10):kb.test(a.nodeName)||lb.test(a.nodeName)&&a.href?0:-1}}},propFix:{"for":"htmlFor","class":"className"}}),o.optSelected||(r.propHooks.selected={get:function(a){var b=a.parentNode;return b&&b.parentNode&&b.parentNode.selectedIndex,null},set:function(a){var b=a.parentNode;b&&(b.selectedIndex,b.parentNode&&b.parentNode.selectedIndex)}}),r.each(["tabIndex","readOnly","maxLength","cellSpacing","cellPadding","rowSpan","colSpan","useMap","frameBorder","contentEditable"],function(){r.propFix[this.toLowerCase()]=this});function mb(a){var b=a.match(K)||[];return b.join(" ")}function nb(a){return a.getAttribute&&a.getAttribute("class")||""}r.fn.extend({addClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).addClass(a.call(this,b,nb(this)))});if("string"==typeof a&&a){b=a.match(K)||[];while(c=this[i++])if(e=nb(c),d=1===c.nodeType&&" "+mb(e)+" "){g=0;while(f=b[g++])d.indexOf(" "+f+" ")<0&&(d+=f+" ");h=mb(d),e!==h&&c.setAttribute("class",h)}}return this},removeClass:function(a){var b,c,d,e,f,g,h,i=0;if(r.isFunction(a))return this.each(function(b){r(this).removeClass(a.call(this,b,nb(this)))});if(!arguments.length)return this.attr("class","");if("string"==typeof a&&a){b=a.match(K)||[];while(c=this[i++])if(e=nb(c),d=1===c.nodeType&&" "+mb(e)+" "){g=0;while(f=b[g++])while(d.indexOf(" "+f+" ")>-1)d=d.replace(" "+f+" "," ");h=mb(d),e!==h&&c.setAttribute("class",h)}}return this},toggleClass:function(a,b){var c=typeof a;return"boolean"==typeof b&&"string"===c?b?this.addClass(a):this.removeClass(a):r.isFunction(a)?this.each(function(c){r(this).toggleClass(a.call(this,c,nb(this),b),b)}):this.each(function(){var b,d,e,f;if("string"===c){d=0,e=r(this),f=a.match(K)||[];while(b=f[d++])e.hasClass(b)?e.removeClass(b):e.addClass(b)}else void 0!==a&&"boolean"!==c||(b=nb(this),b&&V.set(this,"__className__",b),this.setAttribute&&this.setAttribute("class",b||a===!1?"":V.get(this,"__className__")||""))})},hasClass:function(a){var b,c,d=0;b=" "+a+" ";while(c=this[d++])if(1===c.nodeType&&(" "+mb(nb(c))+" ").indexOf(b)>-1)return!0;return!1}});var ob=/\r/g;r.fn.extend({val:function(a){var b,c,d,e=this[0];{if(arguments.length)return d=r.isFunction(a),this.each(function(c){var e;1===this.nodeType&&(e=d?a.call(this,c,r(this).val()):a,null==e?e="":"number"==typeof e?e+="":r.isArray(e)&&(e=r.map(e,function(a){return null==a?"":a+""})),b=r.valHooks[this.type]||r.valHooks[this.nodeName.toLowerCase()],b&&"set"in b&&void 0!==b.set(this,e,"value")||(this.value=e))});if(e)return b=r.valHooks[e.type]||r.valHooks[e.nodeName.toLowerCase()],b&&"get"in b&&void 0!==(c=b.get(e,"value"))?c:(c=e.value,"string"==typeof c?c.replace(ob,""):null==c?"":c)}}}),r.extend({valHooks:{option:{get:function(a){var b=r.find.attr(a,"value");return null!=b?b:mb(r.text(a))}},select:{get:function(a){var b,c,d,e=a.options,f=a.selectedIndex,g="select-one"===a.type,h=g?null:[],i=g?f+1:e.length;for(d=f<0?i:g?f:0;d-1)&&(c=!0);return c||(a.selectedIndex=-1),f}}}}),r.each(["radio","checkbox"],function(){r.valHooks[this]={set:function(a,b){if(r.isArray(b))return a.checked=r.inArray(r(a).val(),b)>-1}},o.checkOn||(r.valHooks[this].get=function(a){return null===a.getAttribute("value")?"on":a.value})});var pb=/^(?:focusinfocus|focusoutblur)$/;r.extend(r.event,{trigger:function(b,c,e,f){var g,h,i,j,k,m,n,o=[e||d],p=l.call(b,"type")?b.type:b,q=l.call(b,"namespace")?b.namespace.split("."):[];if(h=i=e=e||d,3!==e.nodeType&&8!==e.nodeType&&!pb.test(p+r.event.triggered)&&(p.indexOf(".")>-1&&(q=p.split("."),p=q.shift(),q.sort()),k=p.indexOf(":")<0&&"on"+p,b=b[r.expando]?b:new r.Event(p,"object"==typeof b&&b),b.isTrigger=f?2:3,b.namespace=q.join("."),b.rnamespace=b.namespace?new RegExp("(^|\\.)"+q.join("\\.(?:.*\\.|)")+"(\\.|$)"):null,b.result=void 0,b.target||(b.target=e),c=null==c?[b]:r.makeArray(c,[b]),n=r.event.special[p]||{},f||!n.trigger||n.trigger.apply(e,c)!==!1)){if(!f&&!n.noBubble&&!r.isWindow(e)){for(j=n.delegateType||p,pb.test(j+p)||(h=h.parentNode);h;h=h.parentNode)o.push(h),i=h;i===(e.ownerDocument||d)&&o.push(i.defaultView||i.parentWindow||a)}g=0;while((h=o[g++])&&!b.isPropagationStopped())b.type=g>1?j:n.bindType||p,m=(V.get(h,"events")||{})[b.type]&&V.get(h,"handle"),m&&m.apply(h,c),m=k&&h[k],m&&m.apply&&T(h)&&(b.result=m.apply(h,c),b.result===!1&&b.preventDefault());return b.type=p,f||b.isDefaultPrevented()||n._default&&n._default.apply(o.pop(),c)!==!1||!T(e)||k&&r.isFunction(e[p])&&!r.isWindow(e)&&(i=e[k],i&&(e[k]=null),r.event.triggered=p,e[p](),r.event.triggered=void 0,i&&(e[k]=i)),b.result}},simulate:function(a,b,c){var d=r.extend(new r.Event,c,{type:a,isSimulated:!0});r.event.trigger(d,null,b)}}),r.fn.extend({trigger:function(a,b){return this.each(function(){r.event.trigger(a,b,this)})},triggerHandler:function(a,b){var c=this[0];if(c)return r.event.trigger(a,b,c,!0)}}),r.each("blur focus focusin focusout resize scroll click dblclick mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave change select submit keydown keypress keyup contextmenu".split(" "),function(a,b){r.fn[b]=function(a,c){return arguments.length>0?this.on(b,null,a,c):this.trigger(b)}}),r.fn.extend({hover:function(a,b){return this.mouseenter(a).mouseleave(b||a)}}),o.focusin="onfocusin"in a,o.focusin||r.each({focus:"focusin",blur:"focusout"},function(a,b){var c=function(a){r.event.simulate(b,a.target,r.event.fix(a))};r.event.special[b]={setup:function(){var d=this.ownerDocument||this,e=V.access(d,b);e||d.addEventListener(a,c,!0),V.access(d,b,(e||0)+1)},teardown:function(){var d=this.ownerDocument||this,e=V.access(d,b)-1;e?V.access(d,b,e):(d.removeEventListener(a,c,!0),V.remove(d,b))}}});var qb=a.location,rb=r.now(),sb=/\?/;r.parseXML=function(b){var c;if(!b||"string"!=typeof b)return null;try{c=(new a.DOMParser).parseFromString(b,"text/xml")}catch(d){c=void 0}return c&&!c.getElementsByTagName("parsererror").length||r.error("Invalid XML: "+b),c};var tb=/\[\]$/,ub=/\r?\n/g,vb=/^(?:submit|button|image|reset|file)$/i,wb=/^(?:input|select|textarea|keygen)/i;function xb(a,b,c,d){var e;if(r.isArray(b))r.each(b,function(b,e){c||tb.test(a)?d(a,e):xb(a+"["+("object"==typeof e&&null!=e?b:"")+"]",e,c,d)});else if(c||"object"!==r.type(b))d(a,b);else for(e in b)xb(a+"["+e+"]",b[e],c,d)}r.param=function(a,b){var c,d=[],e=function(a,b){var c=r.isFunction(b)?b():b;d[d.length]=encodeURIComponent(a)+"="+encodeURIComponent(null==c?"":c)};if(r.isArray(a)||a.jquery&&!r.isPlainObject(a))r.each(a,function(){e(this.name,this.value)});else for(c in a)xb(c,a[c],b,e);return d.join("&")},r.fn.extend({serialize:function(){return r.param(this.serializeArray())},serializeArray:function(){return this.map(function(){var a=r.prop(this,"elements");return a?r.makeArray(a):this}).filter(function(){var a=this.type;return this.name&&!r(this).is(":disabled")&&wb.test(this.nodeName)&&!vb.test(a)&&(this.checked||!ia.test(a))}).map(function(a,b){var c=r(this).val();return null==c?null:r.isArray(c)?r.map(c,function(a){return{name:b.name,value:a.replace(ub,"\r\n")}}):{name:b.name,value:c.replace(ub,"\r\n")}}).get()}});var yb=/%20/g,zb=/#.*$/,Ab=/([?&])_=[^&]*/,Bb=/^(.*?):[ \t]*([^\r\n]*)$/gm,Cb=/^(?:about|app|app-storage|.+-extension|file|res|widget):$/,Db=/^(?:GET|HEAD)$/,Eb=/^\/\//,Fb={},Gb={},Hb="*/".concat("*"),Ib=d.createElement("a");Ib.href=qb.href;function Jb(a){return function(b,c){"string"!=typeof b&&(c=b,b="*");var d,e=0,f=b.toLowerCase().match(K)||[];if(r.isFunction(c))while(d=f[e++])"+"===d[0]?(d=d.slice(1)||"*",(a[d]=a[d]||[]).unshift(c)):(a[d]=a[d]||[]).push(c)}}function Kb(a,b,c,d){var e={},f=a===Gb;function g(h){var i;return e[h]=!0,r.each(a[h]||[],function(a,h){var j=h(b,c,d);return"string"!=typeof j||f||e[j]?f?!(i=j):void 0:(b.dataTypes.unshift(j),g(j),!1)}),i}return g(b.dataTypes[0])||!e["*"]&&g("*")}function Lb(a,b){var c,d,e=r.ajaxSettings.flatOptions||{};for(c in b)void 0!==b[c]&&((e[c]?a:d||(d={}))[c]=b[c]);return d&&r.extend(!0,a,d),a}function Mb(a,b,c){var d,e,f,g,h=a.contents,i=a.dataTypes;while("*"===i[0])i.shift(),void 0===d&&(d=a.mimeType||b.getResponseHeader("Content-Type"));if(d)for(e in h)if(h[e]&&h[e].test(d)){i.unshift(e);break}if(i[0]in c)f=i[0];else{for(e in c){if(!i[0]||a.converters[e+" "+i[0]]){f=e;break}g||(g=e)}f=f||g}if(f)return f!==i[0]&&i.unshift(f),c[f]}function Nb(a,b,c,d){var e,f,g,h,i,j={},k=a.dataTypes.slice();if(k[1])for(g in a.converters)j[g.toLowerCase()]=a.converters[g];f=k.shift();while(f)if(a.responseFields[f]&&(c[a.responseFields[f]]=b),!i&&d&&a.dataFilter&&(b=a.dataFilter(b,a.dataType)),i=f,f=k.shift())if("*"===f)f=i;else if("*"!==i&&i!==f){if(g=j[i+" "+f]||j["* "+f],!g)for(e in j)if(h=e.split(" "),h[1]===f&&(g=j[i+" "+h[0]]||j["* "+h[0]])){g===!0?g=j[e]:j[e]!==!0&&(f=h[0],k.unshift(h[1]));break}if(g!==!0)if(g&&a["throws"])b=g(b);else try{b=g(b)}catch(l){return{state:"parsererror",error:g?l:"No conversion from "+i+" to "+f}}}return{state:"success",data:b}}r.extend({active:0,lastModified:{},etag:{},ajaxSettings:{url:qb.href,type:"GET",isLocal:Cb.test(qb.protocol),global:!0,processData:!0,async:!0,contentType:"application/x-www-form-urlencoded; charset=UTF-8",accepts:{"*":Hb,text:"text/plain",html:"text/html",xml:"application/xml, text/xml",json:"application/json, text/javascript"},contents:{xml:/\bxml\b/,html:/\bhtml/,json:/\bjson\b/},responseFields:{xml:"responseXML",text:"responseText",json:"responseJSON"},converters:{"* text":String,"text html":!0,"text json":JSON.parse,"text xml":r.parseXML},flatOptions:{url:!0,context:!0}},ajaxSetup:function(a,b){return b?Lb(Lb(a,r.ajaxSettings),b):Lb(r.ajaxSettings,a)},ajaxPrefilter:Jb(Fb),ajaxTransport:Jb(Gb),ajax:function(b,c){"object"==typeof b&&(c=b,b=void 0),c=c||{};var e,f,g,h,i,j,k,l,m,n,o=r.ajaxSetup({},c),p=o.context||o,q=o.context&&(p.nodeType||p.jquery)?r(p):r.event,s=r.Deferred(),t=r.Callbacks("once memory"),u=o.statusCode||{},v={},w={},x="canceled",y={readyState:0,getResponseHeader:function(a){var b;if(k){if(!h){h={};while(b=Bb.exec(g))h[b[1].toLowerCase()]=b[2]}b=h[a.toLowerCase()]}return null==b?null:b},getAllResponseHeaders:function(){return k?g:null},setRequestHeader:function(a,b){return null==k&&(a=w[a.toLowerCase()]=w[a.toLowerCase()]||a,v[a]=b),this},overrideMimeType:function(a){return null==k&&(o.mimeType=a),this},statusCode:function(a){var b;if(a)if(k)y.always(a[y.status]);else for(b in a)u[b]=[u[b],a[b]];return this},abort:function(a){var b=a||x;return e&&e.abort(b),A(0,b),this}};if(s.promise(y),o.url=((b||o.url||qb.href)+"").replace(Eb,qb.protocol+"//"),o.type=c.method||c.type||o.method||o.type,o.dataTypes=(o.dataType||"*").toLowerCase().match(K)||[""],null==o.crossDomain){j=d.createElement("a");try{j.href=o.url,j.href=j.href,o.crossDomain=Ib.protocol+"//"+Ib.host!=j.protocol+"//"+j.host}catch(z){o.crossDomain=!0}}if(o.data&&o.processData&&"string"!=typeof o.data&&(o.data=r.param(o.data,o.traditional)),Kb(Fb,o,c,y),k)return y;l=r.event&&o.global,l&&0===r.active++&&r.event.trigger("ajaxStart"),o.type=o.type.toUpperCase(),o.hasContent=!Db.test(o.type),f=o.url.replace(zb,""),o.hasContent?o.data&&o.processData&&0===(o.contentType||"").indexOf("application/x-www-form-urlencoded")&&(o.data=o.data.replace(yb,"+")):(n=o.url.slice(f.length),o.data&&(f+=(sb.test(f)?"&":"?")+o.data,delete o.data),o.cache===!1&&(f=f.replace(Ab,"$1"),n=(sb.test(f)?"&":"?")+"_="+rb++ +n),o.url=f+n),o.ifModified&&(r.lastModified[f]&&y.setRequestHeader("If-Modified-Since",r.lastModified[f]),r.etag[f]&&y.setRequestHeader("If-None-Match",r.etag[f])),(o.data&&o.hasContent&&o.contentType!==!1||c.contentType)&&y.setRequestHeader("Content-Type",o.contentType),y.setRequestHeader("Accept",o.dataTypes[0]&&o.accepts[o.dataTypes[0]]?o.accepts[o.dataTypes[0]]+("*"!==o.dataTypes[0]?", "+Hb+"; q=0.01":""):o.accepts["*"]);for(m in o.headers)y.setRequestHeader(m,o.headers[m]);if(o.beforeSend&&(o.beforeSend.call(p,y,o)===!1||k))return y.abort();if(x="abort",t.add(o.complete),y.done(o.success),y.fail(o.error),e=Kb(Gb,o,c,y)){if(y.readyState=1,l&&q.trigger("ajaxSend",[y,o]),k)return y;o.async&&o.timeout>0&&(i=a.setTimeout(function(){y.abort("timeout")},o.timeout));try{k=!1,e.send(v,A)}catch(z){if(k)throw z;A(-1,z)}}else A(-1,"No Transport");function A(b,c,d,h){var j,m,n,v,w,x=c;k||(k=!0,i&&a.clearTimeout(i),e=void 0,g=h||"",y.readyState=b>0?4:0,j=b>=200&&b<300||304===b,d&&(v=Mb(o,y,d)),v=Nb(o,v,y,j),j?(o.ifModified&&(w=y.getResponseHeader("Last-Modified"),w&&(r.lastModified[f]=w),w=y.getResponseHeader("etag"),w&&(r.etag[f]=w)),204===b||"HEAD"===o.type?x="nocontent":304===b?x="notmodified":(x=v.state,m=v.data,n=v.error,j=!n)):(n=x,!b&&x||(x="error",b<0&&(b=0))),y.status=b,y.statusText=(c||x)+"",j?s.resolveWith(p,[m,x,y]):s.rejectWith(p,[y,x,n]),y.statusCode(u),u=void 0,l&&q.trigger(j?"ajaxSuccess":"ajaxError",[y,o,j?m:n]),t.fireWith(p,[y,x]),l&&(q.trigger("ajaxComplete",[y,o]),--r.active||r.event.trigger("ajaxStop")))}return y},getJSON:function(a,b,c){return r.get(a,b,c,"json")},getScript:function(a,b){return r.get(a,void 0,b,"script")}}),r.each(["get","post"],function(a,b){r[b]=function(a,c,d,e){return r.isFunction(c)&&(e=e||d,d=c,c=void 0),r.ajax(r.extend({url:a,type:b,dataType:e,data:c,success:d},r.isPlainObject(a)&&a))}}),r._evalUrl=function(a){return r.ajax({url:a,type:"GET",dataType:"script",cache:!0,async:!1,global:!1,"throws":!0})},r.fn.extend({wrapAll:function(a){var b;return this[0]&&(r.isFunction(a)&&(a=a.call(this[0])),b=r(a,this[0].ownerDocument).eq(0).clone(!0),this[0].parentNode&&b.insertBefore(this[0]),b.map(function(){var a=this;while(a.firstElementChild)a=a.firstElementChild;return a}).append(this)),this},wrapInner:function(a){return r.isFunction(a)?this.each(function(b){r(this).wrapInner(a.call(this,b))}):this.each(function(){var b=r(this),c=b.contents();c.length?c.wrapAll(a):b.append(a)})},wrap:function(a){var b=r.isFunction(a);return this.each(function(c){r(this).wrapAll(b?a.call(this,c):a)})},unwrap:function(a){return this.parent(a).not("body").each(function(){r(this).replaceWith(this.childNodes)}),this}}),r.expr.pseudos.hidden=function(a){return!r.expr.pseudos.visible(a)},r.expr.pseudos.visible=function(a){return!!(a.offsetWidth||a.offsetHeight||a.getClientRects().length)},r.ajaxSettings.xhr=function(){try{return new a.XMLHttpRequest}catch(b){}};var Ob={0:200,1223:204},Pb=r.ajaxSettings.xhr();o.cors=!!Pb&&"withCredentials"in Pb,o.ajax=Pb=!!Pb,r.ajaxTransport(function(b){var c,d;if(o.cors||Pb&&!b.crossDomain)return{send:function(e,f){var g,h=b.xhr();if(h.open(b.type,b.url,b.async,b.username,b.password),b.xhrFields)for(g in b.xhrFields)h[g]=b.xhrFields[g];b.mimeType&&h.overrideMimeType&&h.overrideMimeType(b.mimeType),b.crossDomain||e["X-Requested-With"]||(e["X-Requested-With"]="XMLHttpRequest");for(g in e)h.setRequestHeader(g,e[g]);c=function(a){return function(){c&&(c=d=h.onload=h.onerror=h.onabort=h.onreadystatechange=null,"abort"===a?h.abort():"error"===a?"number"!=typeof h.status?f(0,"error"):f(h.status,h.statusText):f(Ob[h.status]||h.status,h.statusText,"text"!==(h.responseType||"text")||"string"!=typeof h.responseText?{binary:h.response}:{text:h.responseText},h.getAllResponseHeaders()))}},h.onload=c(),d=h.onerror=c("error"),void 0!==h.onabort?h.onabort=d:h.onreadystatechange=function(){4===h.readyState&&a.setTimeout(function(){c&&d()})},c=c("abort");try{h.send(b.hasContent&&b.data||null)}catch(i){if(c)throw i}},abort:function(){c&&c()}}}),r.ajaxPrefilter(function(a){a.crossDomain&&(a.contents.script=!1)}),r.ajaxSetup({accepts:{script:"text/javascript, application/javascript, application/ecmascript, application/x-ecmascript"},contents:{script:/\b(?:java|ecma)script\b/},converters:{"text script":function(a){return r.globalEval(a),a}}}),r.ajaxPrefilter("script",function(a){void 0===a.cache&&(a.cache=!1),a.crossDomain&&(a.type="GET")}),r.ajaxTransport("script",function(a){if(a.crossDomain){var b,c;return{send:function(e,f){b=r("