Compare commits
15 Commits
| Author | SHA1 | Date |
|---|---|---|
|
|
87d8d69686 | 4 years ago |
|
|
0b8a50e169 | 4 years ago |
|
|
56ff7144b2 | 4 years ago |
|
|
47e6d5e28a | 4 years ago |
|
|
ac44532da8 | 4 years ago |
|
|
bdf37a0aee | 4 years ago |
|
|
d9563f5d77 | 4 years ago |
|
|
c0efa62475 | 4 years ago |
|
|
61555fd87c | 4 years ago |
|
|
362faf7ba8 | 4 years ago |
|
|
78fd50b2d9 | 4 years ago |
|
|
7ab08218eb | 4 years ago |
|
|
a7145b9f19 | 4 years ago |
|
|
cba8828784 | 4 years ago |
|
|
4804f3164e | 4 years ago |
@ -0,0 +1,3 @@
|
||||
<Context> |
||||
<CookieProcessor sameSiteCookies="strict" /> |
||||
</Context> |
||||
@ -0,0 +1 @@
|
||||
samesite-cookie(mode=Lax) |
||||
@ -0,0 +1,18 @@
|
||||
<!DOCTYPE html><%@ |
||||
page import="java.util.Collection,org.leolo.web.dm.dao.*,org.leolo.web.dm.model.*,org.leolo.web.dm.util.*" |
||||
%><html> |
||||
<head> |
||||
<title>Download Manager</title> |
||||
</head> |
||||
<body> |
||||
<h1>Download Manager</h1> |
||||
<% Collection<Project> projs = new ProjectDao().getAllProjects(); %> |
||||
<h2>Project List</h2> |
||||
<ul><% for(Project proj:projs){ %> |
||||
<li> |
||||
<a href="project/<%=proj.getProjectPath()%>"><%= proj.getProjectName() %></a><br> |
||||
<%= JSPUtils.nl2br(proj.getDescription()) %> |
||||
</li> |
||||
<%} %></ul> |
||||
</body> |
||||
</html> |
||||
@ -1,18 +1,111 @@
|
||||
<!DOCTYPE html><%@ |
||||
page import="java.util.Collection,org.leolo.web.dm.dao.*,org.leolo.web.dm.model.*,org.leolo.web.dm.util.*" |
||||
%><html> |
||||
<head> |
||||
<title>Download Manager</title> |
||||
</head> |
||||
<body> |
||||
<h1>Download Manager</h1> |
||||
<% Collection<Project> projs = new ProjectDao().getAllProjects(); %> |
||||
<h2>Project List</h2> |
||||
<ul><% for(Project proj:projs){ %> |
||||
<li> |
||||
<a href="project/<%=proj.getProjectPath()%>"><%= proj.getProjectName() %></a><br> |
||||
<%= JSPUtils.nl2br(proj.getDescription()) %> |
||||
</li> |
||||
<%} %></ul> |
||||
</body> |
||||
<!DOCTYPE html> |
||||
<html> |
||||
<head> |
||||
<meta charset="ISO-8859-1"> |
||||
<title>Download Manager</title> |
||||
<script src="js/jquery-3.6.0.min.js"></script> |
||||
<script src="js/jquery-ui.js"></script> |
||||
<link href="js/jquery-ui.css" rel="stylesheet"> |
||||
<link href="js/main.css" rel="stylesheet"> |
||||
<script> |
||||
function updateUserInfo(){ |
||||
$.get( '<%=request.getContextPath()%>/UserInfo' , function(data){ |
||||
$('#sysname').text(data.system_name); |
||||
if(data.identified){ |
||||
//Handle userinfo box and logout link |
||||
$("#hdr-action").text("Welcome back, "+data.username); |
||||
$("#hdr-action").off('click').on('click',function(){ |
||||
$("#hdr-uinfo").toggle(); |
||||
}); |
||||
}else{ |
||||
//Display login link |
||||
$("#hdr-action").text("Login"); |
||||
$("#hdr-action").off('click').on('click',function(){ |
||||
$("#hdr-login").toggle(); |
||||
}); |
||||
} |
||||
}); |
||||
$.get('<%=request.getContextPath()%>/projects', function(data){ |
||||
console.log("There are "+data.projects.length+" projects"); |
||||
}); |
||||
} |
||||
</script> |
||||
</head> |
||||
<body> |
||||
<nav> |
||||
Download Manager - <span id="sysname"></span> |
||||
<span class="status" id="hdr-action">Login</span> |
||||
<div class="hidden hdr-info-box ui-corner-all" id="hdr-uinfo"> |
||||
<p class="hidden" id="hdr-uinfo-pllit">Last login time : <span id="hdr-uinfo-llit"></span></p> |
||||
<button id="hdr-uinfo-logout">Logout</button> |
||||
</div> |
||||
<div class="hidden hdr-info-box ui-corner-all" id="hdr-login"> |
||||
<div class="hidden ui-state-error ui-corner-all" style="padding:0.3em;" id="hdr-login-msg"> |
||||
<span class="ui-icon ui-icon-alert"></span> |
||||
<span id="hdr-login-msg-cont"></span> |
||||
</div> |
||||
<table> |
||||
<tr> |
||||
<th><label for="hdr-login-username" style="white-space: nowrap;">Username</label></th> |
||||
<td><input type="text" id="hdr-login-username"></td> |
||||
</tr> |
||||
<tr> |
||||
<th><label for="hdr-login-password">Password</label></th> |
||||
<td><input type="password" id="hdr-login-password"></td> |
||||
</tr> |
||||
<tr> |
||||
<td colspan="2"><button id="hdr-login-submit">Submit</button></td> |
||||
</tr> |
||||
</table> |
||||
</div> |
||||
</nav> |
||||
<main> |
||||
|
||||
</main> |
||||
<script> |
||||
//Perform post-load task |
||||
updateUserInfo(); |
||||
$("#hdr-login-submit").button(); |
||||
//$("#hdr-action").button(); |
||||
$("#hdr-login-submit").click(function(){ |
||||
var uname = $("#hdr-login-username").val(); |
||||
var pass = $("#hdr-login-password").val(); |
||||
if(uname==null || pass==null || uname=="" ||pass==""){ |
||||
//Display error message |
||||
$("#hdr-login-msg-cont").text("Username and password are required."); |
||||
$("#hdr-login-msg").show(); |
||||
return; |
||||
} |
||||
$.post('<%=request.getContextPath()%>/Login', |
||||
{username: uname, password: pass}, |
||||
function(data){ |
||||
if(data.status=="failed"){ |
||||
$("#hdr-login-msg-cont").text(data.message); |
||||
$("#hdr-login-msg").show(); |
||||
$("#hdr-login-password").val(""); |
||||
}else{ |
||||
updateUserInfo(); |
||||
$("#hdr-login-msg").hide(); |
||||
$("#hdr-login").hide(); |
||||
$("#hdr-login-username").val(""); |
||||
$("#hdr-login-password").val(""); |
||||
if(data.lastLogin==null){ |
||||
$("#hdr-uinfo-pllit").hide(); |
||||
}else{ |
||||
$("#hdr-uinfo-pllit").show(); |
||||
$("#hdr-uinfo-llit").text(data.lastLogin); |
||||
} |
||||
} |
||||
}) |
||||
}); |
||||
$("#hdr-uinfo-logout").button(); |
||||
$("#hdr-uinfo-logout").click(function (){ |
||||
$.post('<%=request.getContextPath()%>/Logout', function(data){ |
||||
updateUserInfo(); |
||||
$("#hdr-uinfo").hide(); |
||||
|
||||
}); |
||||
}); |
||||
</script> |
||||
</body> |
||||
</html> |
||||
@ -0,0 +1,367 @@
|
||||
Authors ordered by first contribution |
||||
A list of current team members is available at http://jqueryui.com/about |
||||
|
||||
Paul Bakaus <paul.bakaus@gmail.com> |
||||
Richard Worth <rdworth@gmail.com> |
||||
Yehuda Katz <wycats@gmail.com> |
||||
Sean Catchpole <sean@sunsean.com> |
||||
John Resig <jeresig@gmail.com> |
||||
Tane Piper <piper.tane@gmail.com> |
||||
Dmitri Gaskin <dmitrig01@gmail.com> |
||||
Klaus Hartl <klaus.hartl@gmail.com> |
||||
Stefan Petre <stefan.petre@gmail.com> |
||||
Gilles van den Hoven <gilles@webunity.nl> |
||||
Micheil Bryan Smith <micheil@brandedcode.com> |
||||
Jörn Zaefferer <joern.zaefferer@gmail.com> |
||||
Marc Grabanski <m@marcgrabanski.com> |
||||
Keith Wood <kbwood@iinet.com.au> |
||||
Brandon Aaron <brandon.aaron@gmail.com> |
||||
Scott González <scott.gonzalez@gmail.com> |
||||
Eduardo Lundgren <eduardolundgren@gmail.com> |
||||
Aaron Eisenberger <aaronchi@gmail.com> |
||||
Joan Piedra <theneojp@gmail.com> |
||||
Bruno Basto <b.basto@gmail.com> |
||||
Remy Sharp <remy@leftlogic.com> |
||||
Bohdan Ganicky <bohdan.ganicky@gmail.com> |
||||
David Bolter <david.bolter@gmail.com> |
||||
Chi Cheng <cloudream@gmail.com> |
||||
Ca-Phun Ung <pazu2k@gmail.com> |
||||
Ariel Flesler <aflesler@gmail.com> |
||||
Maggie Wachs <maggie@filamentgroup.com> |
||||
Scott Jehl <scottjehl@gmail.com> |
||||
Todd Parker <todd@filamentgroup.com> |
||||
Andrew Powell <andrew@shellscape.org> |
||||
Brant Burnett <btburnett3@gmail.com> |
||||
Douglas Neiner <doug@dougneiner.com> |
||||
Paul Irish <paul.irish@gmail.com> |
||||
Ralph Whitbeck <ralph.whitbeck@gmail.com> |
||||
Thibault Duplessis <thibault.duplessis@gmail.com> |
||||
Dominique Vincent <dominique.vincent@toitl.com> |
||||
Jack Hsu <jack.hsu@gmail.com> |
||||
Adam Sontag <ajpiano@ajpiano.com> |
||||
Carl Fürstenberg <carl@excito.com> |
||||
Kevin Dalman <development@allpro.net> |
||||
Alberto Fernández Capel <afcapel@gmail.com> |
||||
Jacek Jędrzejewski (http://jacek.jedrzejewski.name) |
||||
Ting Kuei <ting@kuei.com> |
||||
Samuel Cormier-Iijima <sam@chide.it> |
||||
Jon Palmer <jonspalmer@gmail.com> |
||||
Ben Hollis <bhollis@amazon.com> |
||||
Justin MacCarthy <Justin@Rubystars.biz> |
||||
Eyal Kobrigo <kobrigo@hotmail.com> |
||||
Tiago Freire <tiago.freire@gmail.com> |
||||
Diego Tres <diegotres@gmail.com> |
||||
Holger Rüprich <holger@rueprich.de> |
||||
Ziling Zhao <zilingzhao@gmail.com> |
||||
Mike Alsup <malsup@gmail.com> |
||||
Robson Braga Araujo <robsonbraga@gmail.com> |
||||
Pierre-Henri Ausseil <ph.ausseil@gmail.com> |
||||
Christopher McCulloh <cmcculloh@gmail.com> |
||||
Andrew Newcomb <ext.github@preceptsoftware.co.uk> |
||||
Lim Chee Aun <cheeaun@gmail.com> |
||||
Jorge Barreiro <yortx.barry@gmail.com> |
||||
Daniel Steigerwald <daniel@steigerwald.cz> |
||||
John Firebaugh <john_firebaugh@bigfix.com> |
||||
John Enters <github@darkdark.net> |
||||
Andrey Kapitcyn <ru.m157y@gmail.com> |
||||
Dmitry Petrov <dpetroff@gmail.com> |
||||
Eric Hynds <eric@hynds.net> |
||||
Chairat Sunthornwiphat <pipo@sixhead.com> |
||||
Josh Varner <josh.varner@gmail.com> |
||||
Stéphane Raimbault <stephane.raimbault@gmail.com> |
||||
Jay Merrifield <fracmak@gmail.com> |
||||
J. Ryan Stinnett <jryans@gmail.com> |
||||
Peter Heiberg <peter@heiberg.se> |
||||
Alex Dovenmuehle <adovenmuehle@gmail.com> |
||||
Jamie Gegerson <git@jamiegegerson.com> |
||||
Raymond Schwartz <skeetergraphics@gmail.com> |
||||
Phillip Barnes <philbar@gmail.com> |
||||
Kyle Wilkinson <kai@wikyd.org> |
||||
Khaled AlHourani <me@khaledalhourani.com> |
||||
Marian Rudzynski <mr@impaled.org> |
||||
Jean-Francois Remy <jeff@melix.org> |
||||
Doug Blood <dougblood@gmail.com> |
||||
Filippo Cavallarin <filippo.cavallarin@codseq.it> |
||||
Heiko Henning <heiko@thehennings.ch> |
||||
Aliaksandr Rahalevich <saksmlz@gmail.com> |
||||
Mario Visic <mario@mariovisic.com> |
||||
Xavi Ramirez <xavi.rmz@gmail.com> |
||||
Max Schnur <max.schnur@gmail.com> |
||||
Saji Nediyanchath <saji89@gmail.com> |
||||
Corey Frang <gnarf37@gmail.com> |
||||
Aaron Peterson <aaronp123@yahoo.com> |
||||
Ivan Peters <ivan@ivanpeters.com> |
||||
Mohamed Cherif Bouchelaghem <cherifbouchelaghem@yahoo.fr> |
||||
Marcos Sousa <falecomigo@marcossousa.com> |
||||
Michael DellaNoce <mdellanoce@mailtrust.com> |
||||
George Marshall <echosx@gmail.com> |
||||
Tobias Brunner <tobias@strongswan.org> |
||||
Martin Solli <msolli@gmail.com> |
||||
David Petersen <public@petersendidit.com> |
||||
Dan Heberden <danheberden@gmail.com> |
||||
William Kevin Manire <williamkmanire@gmail.com> |
||||
Gilmore Davidson <gilmoreorless@gmail.com> |
||||
Michael Wu <michaelmwu@gmail.com> |
||||
Adam Parod <mystic414@gmail.com> |
||||
Guillaume Gautreau <guillaume+github@ghusse.com> |
||||
Marcel Toele <EleotleCram@gmail.com> |
||||
Dan Streetman <ddstreet@ieee.org> |
||||
Matt Hoskins <matt@nipltd.com> |
||||
Giovanni Giacobbi <giovanni@giacobbi.net> |
||||
Kyle Florence <kyle.florence@gmail.com> |
||||
Pavol Hluchý <lopo@losys.sk> |
||||
Hans Hillen <hans.hillen@gmail.com> |
||||
Mark Johnson <virgofx@live.com> |
||||
Trey Hunner <treyhunner@gmail.com> |
||||
Shane Whittet <whittet@gmail.com> |
||||
Edward A Faulkner <ef@alum.mit.edu> |
||||
Adam Baratz <adam@adambaratz.com> |
||||
Kato Kazuyoshi <kato.kazuyoshi@gmail.com> |
||||
Eike Send <eike.send@gmail.com> |
||||
Kris Borchers <kris.borchers@gmail.com> |
||||
Eddie Monge <eddie@eddiemonge.com> |
||||
Israel Tsadok <itsadok@gmail.com> |
||||
Carson McDonald <carson@ioncannon.net> |
||||
Jason Davies <jason@jasondavies.com> |
||||
Garrison Locke <gplocke@gmail.com> |
||||
David Murdoch <david@davidmurdoch.com> |
||||
Benjamin Scott Boyle <benjamins.boyle@gmail.com> |
||||
Jesse Baird <jebaird@gmail.com> |
||||
Jonathan Vingiano <jvingiano@gmail.com> |
||||
Dylan Just <dev@ephox.com> |
||||
Hiroshi Tomita <tomykaira@gmail.com> |
||||
Glenn Goodrich <glenn.goodrich@gmail.com> |
||||
Tarafder Ashek-E-Elahi <mail.ashek@gmail.com> |
||||
Ryan Neufeld <ryan@neufeldmail.com> |
||||
Marc Neuwirth <marc.neuwirth@gmail.com> |
||||
Philip Graham <philip.robert.graham@gmail.com> |
||||
Benjamin Sterling <benjamin.sterling@kenzomedia.com> |
||||
Wesley Walser <waw325@gmail.com> |
||||
Kouhei Sutou <kou@clear-code.com> |
||||
Karl Kirch <karlkrch@gmail.com> |
||||
Chris Kelly <ckdake@ckdake.com> |
||||
Jason Oster <jay@kodewerx.org> |
||||
Felix Nagel <info@felixnagel.com> |
||||
Alexander Polomoshnov <alex.polomoshnov@gmail.com> |
||||
David Leal <dgleal@gmail.com> |
||||
Igor Milla <igor.fsp.milla@gmail.com> |
||||
Dave Methvin <dave.methvin@gmail.com> |
||||
Florian Gutmann <f.gutmann@chronimo.com> |
||||
Marwan Al Jubeh <marwan.aljubeh@gmail.com> |
||||
Milan Broum <midlis@googlemail.com> |
||||
Sebastian Sauer <info@dynpages.de> |
||||
Gaëtan Muller <m.gaetan89@gmail.com> |
||||
Michel Weimerskirch <michel@weimerskirch.net> |
||||
William Griffiths <william@ycymro.com> |
||||
Stojce Slavkovski <stojce@gmail.com> |
||||
David Soms <david.soms@gmail.com> |
||||
David De Sloovere <david.desloovere@outlook.com> |
||||
Michael P. Jung <michael.jung@terreon.de> |
||||
Shannon Pekary <spekary@gmail.com> |
||||
Dan Wellman <danwellman@hotmail.com> |
||||
Matthew Edward Hutton <meh@corefiling.co.uk> |
||||
James Khoury <james@jameskhoury.com> |
||||
Rob Loach <robloach@gmail.com> |
||||
Alberto Monteiro <betimbrasil@gmail.com> |
||||
Alex Rhea <alex.rhea@gmail.com> |
||||
Krzysztof Rosiński <rozwell69@gmail.com> |
||||
Ryan Olton <oltonr@gmail.com> |
||||
Genie <386@mail.com> |
||||
Rick Waldron <waldron.rick@gmail.com> |
||||
Ian Simpson <spoonlikesham@gmail.com> |
||||
Lev Kitsis <spam4lev@gmail.com> |
||||
TJ VanToll <tj.vantoll@gmail.com> |
||||
Justin Domnitz <jdomnitz@gmail.com> |
||||
Douglas Cerna <douglascerna@yahoo.com> |
||||
Bert ter Heide <bertjh@hotmail.com> |
||||
Jasvir Nagra <jasvir@gmail.com> |
||||
Yuriy Khabarov <13real008@gmail.com> |
||||
Harri Kilpiö <harri.kilpio@gmail.com> |
||||
Lado Lomidze <lado.lomidze@gmail.com> |
||||
Amir E. Aharoni <amir.aharoni@mail.huji.ac.il> |
||||
Simon Sattes <simon.sattes@gmail.com> |
||||
Jo Liss <joliss42@gmail.com> |
||||
Guntupalli Karunakar <karunakarg@yahoo.com> |
||||
Shahyar Ghobadpour <shahyar@gmail.com> |
||||
Lukasz Lipinski <uzza17@gmail.com> |
||||
Timo Tijhof <krinklemail@gmail.com> |
||||
Jason Moon <jmoon@socialcast.com> |
||||
Martin Frost <martinf55@hotmail.com> |
||||
Eneko Illarramendi <eneko@illarra.com> |
||||
EungJun Yi <semtlenori@gmail.com> |
||||
Courtland Allen <courtlandallen@gmail.com> |
||||
Viktar Varvanovich <non4eg@gmail.com> |
||||
Danny Trunk <dtrunk90@gmail.com> |
||||
Pavel Stetina <pavel.stetina@nangu.tv> |
||||
Michael Stay <metaweta@gmail.com> |
||||
Steven Roussey <sroussey@gmail.com> |
||||
Michael Hollis <hollis21@gmail.com> |
||||
Lee Rowlands <lee.rowlands@previousnext.com.au> |
||||
Timmy Willison <timmywillisn@gmail.com> |
||||
Karl Swedberg <kswedberg@gmail.com> |
||||
Baoju Yuan <the_guy_1987@hotmail.com> |
||||
Maciej Mroziński <maciej.k.mrozinski@gmail.com> |
||||
Luis Dalmolin <luis.nh@gmail.com> |
||||
Mark Aaron Shirley <maspwr@gmail.com> |
||||
Martin Hoch <martin@fidion.de> |
||||
Jiayi Yang <tr870829@gmail.com> |
||||
Philipp Benjamin Köppchen <xgxtpbk@gws.ms> |
||||
Sindre Sorhus <sindresorhus@gmail.com> |
||||
Bernhard Sirlinger <bernhard.sirlinger@tele2.de> |
||||
Jared A. Scheel <jared@jaredscheel.com> |
||||
Rafael Xavier de Souza <rxaviers@gmail.com> |
||||
John Chen <zhang.z.chen@intel.com> |
||||
Robert Beuligmann <robertbeuligmann@gmail.com> |
||||
Dale Kocian <dale.kocian@gmail.com> |
||||
Mike Sherov <mike.sherov@gmail.com> |
||||
Andrew Couch <andy@couchand.com> |
||||
Marc-Andre Lafortune <github@marc-andre.ca> |
||||
Nate Eagle <nate.eagle@teamaol.com> |
||||
David Souther <davidsouther@gmail.com> |
||||
Mathias Stenbom <mathias@stenbom.com> |
||||
Sergey Kartashov <ebishkek@yandex.ru> |
||||
Avinash R <nashpapa@gmail.com> |
||||
Ethan Romba <ethanromba@gmail.com> |
||||
Cory Gackenheimer <cory.gack@gmail.com> |
||||
Juan Pablo Kaniefsky <jpkaniefsky@gmail.com> |
||||
Roman Salnikov <bardt.dz@gmail.com> |
||||
Anika Henke <anika@selfthinker.org> |
||||
Samuel Bovée <samycookie2000@yahoo.fr> |
||||
Fabrício Matté <ult_combo@hotmail.com> |
||||
Viktor Kojouharov <vkojouharov@gmail.com> |
||||
Pawel Maruszczyk (http://hrabstwo.net) |
||||
Pavel Selitskas <p.selitskas@gmail.com> |
||||
Bjørn Johansen <post@bjornjohansen.no> |
||||
Matthieu Penant <thieum22@hotmail.com> |
||||
Dominic Barnes <dominic@dbarnes.info> |
||||
David Sullivan <david.sullivan@gmail.com> |
||||
Thomas Jaggi <thomas@responsive.ch> |
||||
Vahid Sohrabloo <vahid4134@gmail.com> |
||||
Travis Carden <travis.carden@gmail.com> |
||||
Bruno M. Custódio <bruno@brunomcustodio.com> |
||||
Nathanael Silverman <nathanael.silverman@gmail.com> |
||||
Christian Wenz <christian@wenz.org> |
||||
Steve Urmston <steve@urm.st> |
||||
Zaven Muradyan <megalivoithos@gmail.com> |
||||
Woody Gilk <shadowhand@deviantart.com> |
||||
Zbigniew Motyka <zbigniew.motyka@gmail.com> |
||||
Suhail Alkowaileet <xsoh.k7@gmail.com> |
||||
Toshi MARUYAMA <marutosijp2@yahoo.co.jp> |
||||
David Hansen <hansede@gmail.com> |
||||
Brian Grinstead <briangrinstead@gmail.com> |
||||
Christian Klammer <christian314159@gmail.com> |
||||
Steven Luscher <jquerycla@steveluscher.com> |
||||
Gan Eng Chin <engchin.gan@gmail.com> |
||||
Gabriel Schulhof <gabriel.schulhof@intel.com> |
||||
Alexander Schmitz <arschmitz@gmail.com> |
||||
Vilhjálmur Skúlason <vis@dmm.is> |
||||
Siebrand Mazeland <siebrand@kitano.nl> |
||||
Mohsen Ekhtiari <mohsenekhtiari@yahoo.com> |
||||
Pere Orga <gotrunks@gmail.com> |
||||
Jasper de Groot <mail@ugomobi.com> |
||||
Stephane Deschamps <stephane.deschamps@gmail.com> |
||||
Jyoti Deka <dekajp@gmail.com> |
||||
Andrei Picus <office.nightcrawler@gmail.com> |
||||
Ondrej Novy <novy@ondrej.org> |
||||
Jacob McCutcheon <jacob.mccutcheon@gmail.com> |
||||
Monika Piotrowicz <monika.piotrowicz@gmail.com> |
||||
Imants Horsts <imants.horsts@inbox.lv> |
||||
Eric Dahl <eric.c.dahl@gmail.com> |
||||
Dave Stein <dave@behance.com> |
||||
Dylan Barrell <dylan@barrell.com> |
||||
Daniel DeGroff <djdegroff@gmail.com> |
||||
Michael Wiencek <mwtuea@gmail.com> |
||||
Thomas Meyer <meyertee@gmail.com> |
||||
Ruslan Yakhyaev <ruslan@ruslan.io> |
||||
Brian J. Dowling <bjd-dev@simplicity.net> |
||||
Ben Higgins <ben@extrahop.com> |
||||
Yermo Lamers <yml@yml.com> |
||||
Patrick Stapleton <github@gdi2290.com> |
||||
Trisha Crowley <trisha.crowley@gmail.com> |
||||
Usman Akeju <akeju00+github@gmail.com> |
||||
Rodrigo Menezes <rod333@gmail.com> |
||||
Jacques Perrault <jacques_perrault@us.ibm.com> |
||||
Frederik Elvhage <frederik.elvhage@googlemail.com> |
||||
Will Holley <willholley@gmail.com> |
||||
Uri Gilad <antishok@gmail.com> |
||||
Richard Gibson <richard.gibson@gmail.com> |
||||
Simen Bekkhus <sbekkhus91@gmail.com> |
||||
Chen Eshchar <eshcharc@gmail.com> |
||||
Bruno Pérel <brunoperel@gmail.com> |
||||
Mohammed Alshehri <m@dralshehri.com> |
||||
Lisa Seacat DeLuca <ldeluca@us.ibm.com> |
||||
Anne-Gaelle Colom <coloma@westminster.ac.uk> |
||||
Adam Foster <slimfoster@gmail.com> |
||||
Luke Page <luke.a.page@gmail.com> |
||||
Daniel Owens <daniel@matchstickmixup.com> |
||||
Michael Orchard <morchard@scottlogic.co.uk> |
||||
Marcus Warren <marcus@envoke.com> |
||||
Nils Heuermann <nils@world-of-scripts.de> |
||||
Marco Ziech <marco@ziech.net> |
||||
Patricia Juarez <patrixd@gmail.com> |
||||
Ben Mosher <me@benmosher.com> |
||||
Ablay Keldibek <atomio.ak@gmail.com> |
||||
Thomas Applencourt <thomas.applencourt@irsamc.ups-tlse.fr> |
||||
Jiabao Wu <jiabao.foss@gmail.com> |
||||
Eric Lee Carraway <github@ericcarraway.com> |
||||
Victor Homyakov <vkhomyackov@gmail.com> |
||||
Myeongjin Lee <aranet100@gmail.com> |
||||
Liran Sharir <lsharir@gmail.com> |
||||
Weston Ruter <weston@xwp.co> |
||||
Mani Mishra <manimishra902@gmail.com> |
||||
Hannah Methvin <hannahmethvin@gmail.com> |
||||
Leonardo Balter <leonardo.balter@gmail.com> |
||||
Benjamin Albert <benjamin_a5@yahoo.com> |
||||
Michał Gołębiowski-Owczarek <m.goleb@gmail.com> |
||||
Alyosha Pushak <alyosha.pushak@gmail.com> |
||||
Fahad Ahmad <fahadahmad41@hotmail.com> |
||||
Matt Brundage <github@mattbrundage.com> |
||||
Francesc Baeta <francesc.baeta@gmail.com> |
||||
Piotr Baran <piotros@wp.pl> |
||||
Mukul Hase <mukulhase@gmail.com> |
||||
Konstantin Dinev <kdinev@mail.bw.edu> |
||||
Rand Scullard <rand@randscullard.com> |
||||
Dan Strohl <dan@wjcg.net> |
||||
Maksim Ryzhikov <rv.maksim@gmail.com> |
||||
Amine HADDAD <haddad@allegorie.tv> |
||||
Amanpreet Singh <apsdehal@gmail.com> |
||||
Alexey Balchunas <bleshik@gmail.com> |
||||
Peter Kehl <peter.kehl@gmail.com> |
||||
Peter Dave Hello <hsu@peterdavehello.org> |
||||
Johannes Schäfer <johnschaefer@gmx.de> |
||||
Ville Skyttä <ville.skytta@iki.fi> |
||||
Ryan Oriecuia <ryan.oriecuia@visioncritical.com> |
||||
Sergei Ratnikov <sergeir82@gmail.com> |
||||
milk54 <milk851@gmail.com> |
||||
Evelyn Masso <evoutofambit@gmail.com> |
||||
Robin <mail@robin-fowler.com> |
||||
Simon Asika <asika32764@gmail.com> |
||||
Kevin Cupp <kevin.cupp@gmail.com> |
||||
Jeremy Mickelson <Jeremy.Mickelson@gmail.com> |
||||
Kyle Rosenberg <kyle.rosenberg@gmail.com> |
||||
Petri Partio <petri.partio@gmail.com> |
||||
pallxk <github@pallxk.com> |
||||
Luke Brookhart <luke@onjax.com> |
||||
claudi <hirt-claudia@gmx.de> |
||||
Eirik Sletteberg <eiriksletteberg@gmail.com> |
||||
Albert Johansson <albert@intervaro.se> |
||||
A. Wells <borgboyone@users.noreply.github.com> |
||||
Robert Brignull <robertbrignull@gmail.com> |
||||
Horus68 <pauloizidoro@gmail.com> |
||||
Maksymenkov Eugene <foatei@gmail.com> |
||||
OskarNS <soerensen.oskar@gmail.com> |
||||
Gez Quinn <holla@gezquinn.design> |
||||
jigar gala <jigar.gala140291@gmail.com> |
||||
Florian Wegscheider <flo.wegscheider@gmail.com> |
||||
Fatér Zsolt <fater.zsolt@gmail.com> |
||||
Szabolcs Szabolcsi-Toth <nec@shell8.net> |
||||
Jérémy Munsch <github@jeremydev.ovh> |
||||
Hrvoje Novosel <hrvoje.novosel@gmail.com> |
||||
Paul Capron <PaulCapron@users.noreply.github.com> |
||||
Micah Miller <mikhey@runbox.com> |
||||
sakshi87 <53863764+sakshi87@users.noreply.github.com> |
||||
Mikolaj Wolicki <wolicki.mikolaj@gmail.com> |
||||
Patrick McKay <patrick.mckay@vumc.org> |
||||
c-lambert <58025159+c-lambert@users.noreply.github.com> |
||||
Josep Sanz <josepsanzcamp@gmail.com> |
||||
Ben Mullins <benm@umich.edu> |
||||
@ -0,0 +1,43 @@
|
||||
Copyright jQuery Foundation and other contributors, https://jquery.org/ |
||||
|
||||
This software consists of voluntary contributions made by many |
||||
individuals. For exact contribution history, see the revision history |
||||
available at https://github.com/jquery/jquery-ui |
||||
|
||||
The following license applies to all parts of this software except as |
||||
documented below: |
||||
|
||||
==== |
||||
|
||||
Permission is hereby granted, free of charge, to any person obtaining |
||||
a copy of this software and associated documentation files (the |
||||
"Software"), to deal in the Software without restriction, including |
||||
without limitation the rights to use, copy, modify, merge, publish, |
||||
distribute, sublicense, and/or sell copies of the Software, and to |
||||
permit persons to whom the Software is furnished to do so, subject to |
||||
the following conditions: |
||||
|
||||
The above copyright notice and this permission notice shall be |
||||
included in all copies or substantial portions of the Software. |
||||
|
||||
THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, |
||||
EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF |
||||
MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND |
||||
NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE |
||||
LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION |
||||
OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION |
||||
WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE. |
||||
|
||||
==== |
||||
|
||||
Copyright and related rights for sample code are waived via CC0. Sample |
||||
code is defined as all source code contained within the demos directory. |
||||
|
||||
CC0: http://creativecommons.org/publicdomain/zero/1.0/ |
||||
|
||||
==== |
||||
|
||||
All files located in the node_modules and external directories are |
||||
externally maintained libraries used by this software which have their |
||||
own licenses; we recommend you read them, as their terms may differ from |
||||
the terms above. |
||||
|
After Width: | Height: | Size: 476 B |
|
After Width: | Height: | Size: 384 B |
|
After Width: | Height: | Size: 324 B |
|
After Width: | Height: | Size: 406 B |
|
After Width: | Height: | Size: 265 B |
|
After Width: | Height: | Size: 5.7 KiB |
|
After Width: | Height: | Size: 342 B |
|
After Width: | Height: | Size: 386 B |
|
After Width: | Height: | Size: 6.9 KiB |
|
After Width: | Height: | Size: 4.5 KiB |
|
After Width: | Height: | Size: 4.5 KiB |
|
After Width: | Height: | Size: 4.5 KiB |
|
After Width: | Height: | Size: 6.3 KiB |
@ -0,0 +1,503 @@
|
||||
<!doctype html> |
||||
<html lang="us"> |
||||
<head> |
||||
<meta charset="utf-8"> |
||||
<title>jQuery UI Example Page</title> |
||||
<link href="jquery-ui.css" rel="stylesheet"> |
||||
<style> |
||||
body{ |
||||
font-family: "Trebuchet MS", sans-serif; |
||||
margin: 50px; |
||||
} |
||||
.demoHeaders { |
||||
margin-top: 2em; |
||||
} |
||||
#dialog-link { |
||||
padding: .4em 1em .4em 20px; |
||||
text-decoration: none; |
||||
position: relative; |
||||
} |
||||
#dialog-link span.ui-icon { |
||||
margin: 0 5px 0 0; |
||||
position: absolute; |
||||
left: .2em; |
||||
top: 50%; |
||||
margin-top: -8px; |
||||
} |
||||
#icons { |
||||
margin: 0; |
||||
padding: 0; |
||||
} |
||||
#icons li { |
||||
margin: 2px; |
||||
position: relative; |
||||
padding: 4px 0; |
||||
cursor: pointer; |
||||
float: left; |
||||
list-style: none; |
||||
} |
||||
#icons span.ui-icon { |
||||
float: left; |
||||
margin: 0 4px; |
||||
} |
||||
.fakewindowcontain .ui-widget-overlay { |
||||
position: absolute; |
||||
} |
||||
select { |
||||
width: 200px; |
||||
} |
||||
</style> |
||||
</head> |
||||
<body> |
||||
|
||||
<h1>Welcome to jQuery UI!</h1> |
||||
|
||||
<div class="ui-widget"> |
||||
<p>This page demonstrates the widgets and theme you selected in Download Builder. Please make sure you are using them with a compatible jQuery version.</p> |
||||
</div> |
||||
|
||||
<h1>YOUR COMPONENTS:</h1> |
||||
|
||||
<!-- Accordion --> |
||||
<h2 class="demoHeaders">Accordion</h2> |
||||
<div id="accordion"> |
||||
<h3>First</h3> |
||||
<div>Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet. Lorem ipsum dolor sit amet.</div> |
||||
<h3>Second</h3> |
||||
<div>Phasellus mattis tincidunt nibh.</div> |
||||
<h3>Third</h3> |
||||
<div>Nam dui erat, auctor a, dignissim quis.</div> |
||||
</div> |
||||
|
||||
<!-- Autocomplete --> |
||||
<h2 class="demoHeaders">Autocomplete</h2> |
||||
<div> |
||||
<input id="autocomplete" title="type "a""> |
||||
</div> |
||||
|
||||
<!-- Button --> |
||||
<h2 class="demoHeaders">Button</h2> |
||||
<button id="button">A button element</button> |
||||
<button id="button-icon">An icon-only button</button> |
||||
|
||||
<!-- Checkboxradio --> |
||||
<h2 class="demoHeaders">Checkboxradio</h2> |
||||
<form style="margin-top: 1em;"> |
||||
<div id="radioset"> |
||||
<input type="radio" id="radio1" name="radio"><label for="radio1">Choice 1</label> |
||||
<input type="radio" id="radio2" name="radio" checked="checked"><label for="radio2">Choice 2</label> |
||||
<input type="radio" id="radio3" name="radio"><label for="radio3">Choice 3</label> |
||||
</div> |
||||
</form> |
||||
|
||||
<!-- Controlgroup --> |
||||
<h2 class="demoHeaders">Controlgroup</h2> |
||||
<fieldset> |
||||
<legend>Rental Car</legend> |
||||
<div id="controlgroup"> |
||||
<select id="car-type"> |
||||
<option>Compact car</option> |
||||
<option>Midsize car</option> |
||||
<option>Full size car</option> |
||||
<option>SUV</option> |
||||
<option>Luxury</option> |
||||
<option>Truck</option> |
||||
<option>Van</option> |
||||
</select> |
||||
<label for="transmission-standard">Standard</label> |
||||
<input type="radio" name="transmission" id="transmission-standard"> |
||||
<label for="transmission-automatic">Automatic</label> |
||||
<input type="radio" name="transmission" id="transmission-automatic"> |
||||
<label for="insurance">Insurance</label> |
||||
<input type="checkbox" name="insurance" id="insurance"> |
||||
<label for="horizontal-spinner" class="ui-controlgroup-label"># of cars</label> |
||||
<input id="horizontal-spinner" class="ui-spinner-input"> |
||||
<button>Book Now!</button> |
||||
</div> |
||||
</fieldset> |
||||
|
||||
<!-- Tabs --> |
||||
<h2 class="demoHeaders">Tabs</h2> |
||||
<div id="tabs"> |
||||
<ul> |
||||
<li><a href="#tabs-1">First</a></li> |
||||
<li><a href="#tabs-2">Second</a></li> |
||||
<li><a href="#tabs-3">Third</a></li> |
||||
</ul> |
||||
<div id="tabs-1">Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</div> |
||||
<div id="tabs-2">Phasellus mattis tincidunt nibh. Cras orci urna, blandit id, pretium vel, aliquet ornare, felis. Maecenas scelerisque sem non nisl. Fusce sed lorem in enim dictum bibendum.</div> |
||||
<div id="tabs-3">Nam dui erat, auctor a, dignissim quis, sollicitudin eu, felis. Pellentesque nisi urna, interdum eget, sagittis et, consequat vestibulum, lacus. Mauris porttitor ullamcorper augue.</div> |
||||
</div> |
||||
|
||||
<h2 class="demoHeaders">Dialog</h2> |
||||
<p> |
||||
<button id="dialog-link" class="ui-button ui-corner-all ui-widget"> |
||||
<span class="ui-icon ui-icon-newwin"></span>Open Dialog |
||||
</button> |
||||
</p> |
||||
|
||||
<h2 class="demoHeaders">Overlay and Shadow Classes</h2> |
||||
<div style="position: relative; width: 96%; height: 200px; padding:1% 2%; overflow:hidden;" class="fakewindowcontain"> |
||||
<p>Lorem ipsum dolor sit amet, Nulla nec tortor. Donec id elit quis purus consectetur consequat. </p><p>Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. </p><p>Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. </p><p>Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. </p><p>Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. Aliquam ante. </p><p>Suspendisse scelerisque dui nec velit. Duis augue augue, gravida euismod, vulputate ac, facilisis id, sem. Morbi in orci. Nulla purus lacus, pulvinar vel, malesuada ac, mattis nec, quam. Nam molestie scelerisque quam. Nullam feugiat cursus lacus.orem ipsum dolor sit amet, consectetur adipiscing elit. Donec libero risus, commodo vitae, pharetra mollis, posuere eu, pede. Nulla nec tortor. Donec id elit quis purus consectetur consequat. Nam congue semper tellus. Sed erat dolor, dapibus sit amet, venenatis ornare, ultrices ut, nisi. </p> |
||||
|
||||
<!-- ui-dialog --> |
||||
<div class="ui-widget-overlay ui-front"></div> |
||||
<div style="position: absolute; width: 320px; left: 50px; top: 30px; padding: 1.2em" class="ui-widget ui-front ui-widget-content ui-corner-all ui-widget-shadow"> |
||||
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. |
||||
</div> |
||||
|
||||
</div> |
||||
|
||||
<!-- ui-dialog --> |
||||
<div id="dialog" title="Dialog Title"> |
||||
<p>Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat.</p> |
||||
</div> |
||||
|
||||
|
||||
<h2 class="demoHeaders">Framework Icons (content color preview)</h2> |
||||
<ul id="icons" class="ui-widget ui-helper-clearfix"> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-n"><span class="ui-icon ui-icon-caret-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-ne"><span class="ui-icon ui-icon-caret-1-ne"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-e"><span class="ui-icon ui-icon-caret-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-se"><span class="ui-icon ui-icon-caret-1-se"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-s"><span class="ui-icon ui-icon-caret-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-sw"><span class="ui-icon ui-icon-caret-1-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-w"><span class="ui-icon ui-icon-caret-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-1-nw"><span class="ui-icon ui-icon-caret-1-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-2-n-s"><span class="ui-icon ui-icon-caret-2-n-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-caret-2-e-w"><span class="ui-icon ui-icon-caret-2-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-n"><span class="ui-icon ui-icon-triangle-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-ne"><span class="ui-icon ui-icon-triangle-1-ne"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-e"><span class="ui-icon ui-icon-triangle-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-se"><span class="ui-icon ui-icon-triangle-1-se"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-s"><span class="ui-icon ui-icon-triangle-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-sw"><span class="ui-icon ui-icon-triangle-1-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-w"><span class="ui-icon ui-icon-triangle-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-1-nw"><span class="ui-icon ui-icon-triangle-1-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-2-n-s"><span class="ui-icon ui-icon-triangle-2-n-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-triangle-2-e-w"><span class="ui-icon ui-icon-triangle-2-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-n"><span class="ui-icon ui-icon-arrow-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-ne"><span class="ui-icon ui-icon-arrow-1-ne"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-e"><span class="ui-icon ui-icon-arrow-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-se"><span class="ui-icon ui-icon-arrow-1-se"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-s"><span class="ui-icon ui-icon-arrow-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-sw"><span class="ui-icon ui-icon-arrow-1-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-w"><span class="ui-icon ui-icon-arrow-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-1-nw"><span class="ui-icon ui-icon-arrow-1-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-n-s"><span class="ui-icon ui-icon-arrow-2-n-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-ne-sw"><span class="ui-icon ui-icon-arrow-2-ne-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-e-w"><span class="ui-icon ui-icon-arrow-2-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-2-se-nw"><span class="ui-icon ui-icon-arrow-2-se-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-n"><span class="ui-icon ui-icon-arrowstop-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-e"><span class="ui-icon ui-icon-arrowstop-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-s"><span class="ui-icon ui-icon-arrowstop-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowstop-1-w"><span class="ui-icon ui-icon-arrowstop-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-n"><span class="ui-icon ui-icon-arrowthick-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-ne"><span class="ui-icon ui-icon-arrowthick-1-ne"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-e"><span class="ui-icon ui-icon-arrowthick-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-se"><span class="ui-icon ui-icon-arrowthick-1-se"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-s"><span class="ui-icon ui-icon-arrowthick-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-sw"><span class="ui-icon ui-icon-arrowthick-1-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-w"><span class="ui-icon ui-icon-arrowthick-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-1-nw"><span class="ui-icon ui-icon-arrowthick-1-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-n-s"><span class="ui-icon ui-icon-arrowthick-2-n-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-ne-sw"><span class="ui-icon ui-icon-arrowthick-2-ne-sw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-e-w"><span class="ui-icon ui-icon-arrowthick-2-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthick-2-se-nw"><span class="ui-icon ui-icon-arrowthick-2-se-nw"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-n"><span class="ui-icon ui-icon-arrowthickstop-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-e"><span class="ui-icon ui-icon-arrowthickstop-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-s"><span class="ui-icon ui-icon-arrowthickstop-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowthickstop-1-w"><span class="ui-icon ui-icon-arrowthickstop-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-w"><span class="ui-icon ui-icon-arrowreturnthick-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-n"><span class="ui-icon ui-icon-arrowreturnthick-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-e"><span class="ui-icon ui-icon-arrowreturnthick-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturnthick-1-s"><span class="ui-icon ui-icon-arrowreturnthick-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-w"><span class="ui-icon ui-icon-arrowreturn-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-n"><span class="ui-icon ui-icon-arrowreturn-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-e"><span class="ui-icon ui-icon-arrowreturn-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowreturn-1-s"><span class="ui-icon ui-icon-arrowreturn-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-w"><span class="ui-icon ui-icon-arrowrefresh-1-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-n"><span class="ui-icon ui-icon-arrowrefresh-1-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-e"><span class="ui-icon ui-icon-arrowrefresh-1-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrowrefresh-1-s"><span class="ui-icon ui-icon-arrowrefresh-1-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-4"><span class="ui-icon ui-icon-arrow-4"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-arrow-4-diag"><span class="ui-icon ui-icon-arrow-4-diag"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-extlink"><span class="ui-icon ui-icon-extlink"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-newwin"><span class="ui-icon ui-icon-newwin"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-refresh"><span class="ui-icon ui-icon-refresh"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-shuffle"><span class="ui-icon ui-icon-shuffle"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-transfer-e-w"><span class="ui-icon ui-icon-transfer-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-transferthick-e-w"><span class="ui-icon ui-icon-transferthick-e-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-folder-collapsed"><span class="ui-icon ui-icon-folder-collapsed"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-folder-open"><span class="ui-icon ui-icon-folder-open"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-document"><span class="ui-icon ui-icon-document"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-document-b"><span class="ui-icon ui-icon-document-b"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-note"><span class="ui-icon ui-icon-note"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-mail-closed"><span class="ui-icon ui-icon-mail-closed"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-mail-open"><span class="ui-icon ui-icon-mail-open"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-suitcase"><span class="ui-icon ui-icon-suitcase"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-comment"><span class="ui-icon ui-icon-comment"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-person"><span class="ui-icon ui-icon-person"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-print"><span class="ui-icon ui-icon-print"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-trash"><span class="ui-icon ui-icon-trash"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-locked"><span class="ui-icon ui-icon-locked"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-unlocked"><span class="ui-icon ui-icon-unlocked"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-bookmark"><span class="ui-icon ui-icon-bookmark"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-tag"><span class="ui-icon ui-icon-tag"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-home"><span class="ui-icon ui-icon-home"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-flag"><span class="ui-icon ui-icon-flag"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-calculator"><span class="ui-icon ui-icon-calculator"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-cart"><span class="ui-icon ui-icon-cart"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-pencil"><span class="ui-icon ui-icon-pencil"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-clock"><span class="ui-icon ui-icon-clock"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-disk"><span class="ui-icon ui-icon-disk"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-calendar"><span class="ui-icon ui-icon-calendar"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-zoomin"><span class="ui-icon ui-icon-zoomin"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-zoomout"><span class="ui-icon ui-icon-zoomout"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-search"><span class="ui-icon ui-icon-search"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-wrench"><span class="ui-icon ui-icon-wrench"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-gear"><span class="ui-icon ui-icon-gear"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-heart"><span class="ui-icon ui-icon-heart"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-star"><span class="ui-icon ui-icon-star"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-link"><span class="ui-icon ui-icon-link"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-cancel"><span class="ui-icon ui-icon-cancel"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-plus"><span class="ui-icon ui-icon-plus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-plusthick"><span class="ui-icon ui-icon-plusthick"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-minus"><span class="ui-icon ui-icon-minus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-minusthick"><span class="ui-icon ui-icon-minusthick"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-close"><span class="ui-icon ui-icon-close"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-closethick"><span class="ui-icon ui-icon-closethick"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-key"><span class="ui-icon ui-icon-key"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-lightbulb"><span class="ui-icon ui-icon-lightbulb"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-scissors"><span class="ui-icon ui-icon-scissors"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-clipboard"><span class="ui-icon ui-icon-clipboard"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-copy"><span class="ui-icon ui-icon-copy"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-contact"><span class="ui-icon ui-icon-contact"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-image"><span class="ui-icon ui-icon-image"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-video"><span class="ui-icon ui-icon-video"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-script"><span class="ui-icon ui-icon-script"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-alert"><span class="ui-icon ui-icon-alert"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-info"><span class="ui-icon ui-icon-info"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-notice"><span class="ui-icon ui-icon-notice"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-help"><span class="ui-icon ui-icon-help"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-check"><span class="ui-icon ui-icon-check"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-bullet"><span class="ui-icon ui-icon-bullet"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-radio-off"><span class="ui-icon ui-icon-radio-off"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-radio-on"><span class="ui-icon ui-icon-radio-on"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-pin-w"><span class="ui-icon ui-icon-pin-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-pin-s"><span class="ui-icon ui-icon-pin-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-play"><span class="ui-icon ui-icon-play"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-pause"><span class="ui-icon ui-icon-pause"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-next"><span class="ui-icon ui-icon-seek-next"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-prev"><span class="ui-icon ui-icon-seek-prev"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-end"><span class="ui-icon ui-icon-seek-end"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-seek-first"><span class="ui-icon ui-icon-seek-first"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-stop"><span class="ui-icon ui-icon-stop"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-eject"><span class="ui-icon ui-icon-eject"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-volume-off"><span class="ui-icon ui-icon-volume-off"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-volume-on"><span class="ui-icon ui-icon-volume-on"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-power"><span class="ui-icon ui-icon-power"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-signal-diag"><span class="ui-icon ui-icon-signal-diag"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-signal"><span class="ui-icon ui-icon-signal"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-0"><span class="ui-icon ui-icon-battery-0"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-1"><span class="ui-icon ui-icon-battery-1"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-2"><span class="ui-icon ui-icon-battery-2"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-battery-3"><span class="ui-icon ui-icon-battery-3"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-plus"><span class="ui-icon ui-icon-circle-plus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-minus"><span class="ui-icon ui-icon-circle-minus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-close"><span class="ui-icon ui-icon-circle-close"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-e"><span class="ui-icon ui-icon-circle-triangle-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-s"><span class="ui-icon ui-icon-circle-triangle-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-w"><span class="ui-icon ui-icon-circle-triangle-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-triangle-n"><span class="ui-icon ui-icon-circle-triangle-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-e"><span class="ui-icon ui-icon-circle-arrow-e"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-s"><span class="ui-icon ui-icon-circle-arrow-s"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-w"><span class="ui-icon ui-icon-circle-arrow-w"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-arrow-n"><span class="ui-icon ui-icon-circle-arrow-n"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-zoomin"><span class="ui-icon ui-icon-circle-zoomin"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-zoomout"><span class="ui-icon ui-icon-circle-zoomout"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circle-check"><span class="ui-icon ui-icon-circle-check"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-plus"><span class="ui-icon ui-icon-circlesmall-plus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-minus"><span class="ui-icon ui-icon-circlesmall-minus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-circlesmall-close"><span class="ui-icon ui-icon-circlesmall-close"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-plus"><span class="ui-icon ui-icon-squaresmall-plus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-minus"><span class="ui-icon ui-icon-squaresmall-minus"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-squaresmall-close"><span class="ui-icon ui-icon-squaresmall-close"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-dotted-vertical"><span class="ui-icon ui-icon-grip-dotted-vertical"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-dotted-horizontal"><span class="ui-icon ui-icon-grip-dotted-horizontal"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-solid-vertical"><span class="ui-icon ui-icon-grip-solid-vertical"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-solid-horizontal"><span class="ui-icon ui-icon-grip-solid-horizontal"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-gripsmall-diagonal-se"><span class="ui-icon ui-icon-gripsmall-diagonal-se"></span></li> |
||||
<li class="ui-state-default ui-corner-all" title=".ui-icon-grip-diagonal-se"><span class="ui-icon ui-icon-grip-diagonal-se"></span></li> |
||||
</ul> |
||||
|
||||
<!-- Slider --> |
||||
<h2 class="demoHeaders">Slider</h2> |
||||
<div id="slider"></div> |
||||
|
||||
<!-- Datepicker --> |
||||
<h2 class="demoHeaders">Datepicker</h2> |
||||
<div id="datepicker"></div> |
||||
|
||||
<!-- Progressbar --> |
||||
<h2 class="demoHeaders">Progressbar</h2> |
||||
<div id="progressbar"></div> |
||||
|
||||
<!-- Progressbar --> |
||||
<h2 class="demoHeaders">Selectmenu</h2> |
||||
<select id="selectmenu"> |
||||
<option>Slower</option> |
||||
<option>Slow</option> |
||||
<option selected="selected">Medium</option> |
||||
<option>Fast</option> |
||||
<option>Faster</option> |
||||
</select> |
||||
|
||||
<!-- Spinner --> |
||||
<h2 class="demoHeaders">Spinner</h2> |
||||
<input id="spinner"> |
||||
|
||||
<!-- Menu --> |
||||
<h2 class="demoHeaders">Menu</h2> |
||||
<ul style="width:100px;" id="menu"> |
||||
<li><div>Item 1</div></li> |
||||
<li><div>Item 2</div></li> |
||||
<li><div>Item 3</div> |
||||
<ul> |
||||
<li><div>Item 3-1</div></li> |
||||
<li><div>Item 3-2</div></li> |
||||
<li><div>Item 3-3</div></li> |
||||
<li><div>Item 3-4</div></li> |
||||
<li><div>Item 3-5</div></li> |
||||
</ul> |
||||
</li> |
||||
<li><div>Item 4</div></li> |
||||
<li><div>Item 5</div></li> |
||||
</ul> |
||||
|
||||
<!-- Tooltip --> |
||||
<h2 class="demoHeaders">Tooltip</h2> |
||||
<p id="tooltip"> |
||||
<a href="#" title="That's what this widget is">Tooltips</a> can be attached to any element. When you hover |
||||
the element with your mouse, the title attribute is displayed in a little box next to the element, just like a native tooltip. |
||||
</p> |
||||
|
||||
<!-- Highlight / Error --> |
||||
<h2 class="demoHeaders">Highlight / Error</h2> |
||||
<div class="ui-widget"> |
||||
<div class="ui-state-highlight ui-corner-all" style="margin-top: 20px; padding: 0 .7em;"> |
||||
<p><span class="ui-icon ui-icon-info" style="float: left; margin-right: .3em;"></span> |
||||
<strong>Hey!</strong> Sample ui-state-highlight style.</p> |
||||
</div> |
||||
</div> |
||||
<br> |
||||
<div class="ui-widget"> |
||||
<div class="ui-state-error ui-corner-all" style="padding: 0 .7em;"> |
||||
<p><span class="ui-icon ui-icon-alert" style="float: left; margin-right: .3em;"></span> |
||||
<strong>Alert:</strong> Sample ui-state-error style.</p> |
||||
</div> |
||||
</div> |
||||
|
||||
<script src="external/jquery/jquery.js"></script> |
||||
<script src="jquery-ui.js"></script> |
||||
<script> |
||||
$( "#accordion" ).accordion(); |
||||
|
||||
var availableTags = [ |
||||
"ActionScript", |
||||
"AppleScript", |
||||
"Asp", |
||||
"BASIC", |
||||
"C", |
||||
"C++", |
||||
"Clojure", |
||||
"COBOL", |
||||
"ColdFusion", |
||||
"Erlang", |
||||
"Fortran", |
||||
"Groovy", |
||||
"Haskell", |
||||
"Java", |
||||
"JavaScript", |
||||
"Lisp", |
||||
"Perl", |
||||
"PHP", |
||||
"Python", |
||||
"Ruby", |
||||
"Scala", |
||||
"Scheme" |
||||
]; |
||||
$( "#autocomplete" ).autocomplete({ |
||||
source: availableTags |
||||
}); |
||||
|
||||
$( "#button" ).button(); |
||||
$( "#button-icon" ).button({ |
||||
icon: "ui-icon-gear", |
||||
showLabel: false |
||||
}); |
||||
|
||||
$( "#radioset" ).buttonset(); |
||||
|
||||
$( "#controlgroup" ).controlgroup(); |
||||
|
||||
$( "#tabs" ).tabs(); |
||||
|
||||
$( "#dialog" ).dialog({ |
||||
autoOpen: false, |
||||
width: 400, |
||||
buttons: [ |
||||
{ |
||||
text: "Ok", |
||||
click: function() { |
||||
$( this ).dialog( "close" ); |
||||
} |
||||
}, |
||||
{ |
||||
text: "Cancel", |
||||
click: function() { |
||||
$( this ).dialog( "close" ); |
||||
} |
||||
} |
||||
] |
||||
}); |
||||
|
||||
// Link to open the dialog |
||||
$( "#dialog-link" ).click(function( event ) { |
||||
$( "#dialog" ).dialog( "open" ); |
||||
event.preventDefault(); |
||||
}); |
||||
|
||||
$( "#datepicker" ).datepicker({ |
||||
inline: true |
||||
}); |
||||
|
||||
$( "#slider" ).slider({ |
||||
range: true, |
||||
values: [ 17, 67 ] |
||||
}); |
||||
|
||||
$( "#progressbar" ).progressbar({ |
||||
value: 20 |
||||
}); |
||||
|
||||
$( "#spinner" ).spinner(); |
||||
|
||||
$( "#menu" ).menu(); |
||||
|
||||
$( "#tooltip" ).tooltip(); |
||||
|
||||
$( "#selectmenu" ).selectmenu(); |
||||
|
||||
// Hover states on the static widgets |
||||
$( "#dialog-link, #icons li" ).hover( |
||||
function() { |
||||
$( this ).addClass( "ui-state-hover" ); |
||||
}, |
||||
function() { |
||||
$( this ).removeClass( "ui-state-hover" ); |
||||
} |
||||
); |
||||
</script> |
||||
</body> |
||||
</html> |
||||
@ -0,0 +1,886 @@
|
||||
/*! |
||||
* jQuery UI CSS Framework 1.13.1 |
||||
* http://jqueryui.com |
||||
* |
||||
* Copyright jQuery Foundation and other contributors |
||||
* Released under the MIT license. |
||||
* http://jquery.org/license |
||||
* |
||||
* http://api.jqueryui.com/category/theming/ |
||||
*/ |
||||
.ui-draggable-handle { |
||||
-ms-touch-action: none; |
||||
touch-action: none; |
||||
} |
||||
/* Layout helpers |
||||
----------------------------------*/ |
||||
.ui-helper-hidden { |
||||
display: none; |
||||
} |
||||
.ui-helper-hidden-accessible { |
||||
border: 0; |
||||
clip: rect(0 0 0 0); |
||||
height: 1px; |
||||
margin: -1px; |
||||
overflow: hidden; |
||||
padding: 0; |
||||
position: absolute; |
||||
width: 1px; |
||||
} |
||||
.ui-helper-reset { |
||||
margin: 0; |
||||
padding: 0; |
||||
border: 0; |
||||
outline: 0; |
||||
line-height: 1.3; |
||||
text-decoration: none; |
||||
font-size: 100%; |
||||
list-style: none; |
||||
} |
||||
.ui-helper-clearfix:before, |
||||
.ui-helper-clearfix:after { |
||||
content: ""; |
||||
display: table; |
||||
border-collapse: collapse; |
||||
} |
||||
.ui-helper-clearfix:after { |
||||
clear: both; |
||||
} |
||||
.ui-helper-zfix { |
||||
width: 100%; |
||||
height: 100%; |
||||
top: 0; |
||||
left: 0; |
||||
position: absolute; |
||||
opacity: 0; |
||||
-ms-filter: "alpha(opacity=0)"; /* support: IE8 */ |
||||
} |
||||
|
||||
.ui-front { |
||||
z-index: 100; |
||||
} |
||||
|
||||
|
||||
/* Interaction Cues |
||||
----------------------------------*/ |
||||
.ui-state-disabled { |
||||
cursor: default !important; |
||||
pointer-events: none; |
||||
} |
||||
|
||||
|
||||
/* Icons |
||||
----------------------------------*/ |
||||
.ui-icon { |
||||
display: inline-block; |
||||
vertical-align: middle; |
||||
margin-top: -.25em; |
||||
position: relative; |
||||
text-indent: -99999px; |
||||
overflow: hidden; |
||||
background-repeat: no-repeat; |
||||
} |
||||
|
||||
.ui-widget-icon-block { |
||||
left: 50%; |
||||
margin-left: -8px; |
||||
display: block; |
||||
} |
||||
|
||||
/* Misc visuals |
||||
----------------------------------*/ |
||||
|
||||
/* Overlays */ |
||||
.ui-widget-overlay { |
||||
position: fixed; |
||||
top: 0; |
||||
left: 0; |
||||
width: 100%; |
||||
height: 100%; |
||||
} |
||||
.ui-resizable { |
||||
position: relative; |
||||
} |
||||
.ui-resizable-handle { |
||||
position: absolute; |
||||
font-size: 0.1px; |
||||
display: block; |
||||
-ms-touch-action: none; |
||||
touch-action: none; |
||||
} |
||||
.ui-resizable-disabled .ui-resizable-handle, |
||||
.ui-resizable-autohide .ui-resizable-handle { |
||||
display: none; |
||||
} |
||||
.ui-resizable-n { |
||||
cursor: n-resize; |
||||
height: 7px; |
||||
width: 100%; |
||||
top: -5px; |
||||
left: 0; |
||||
} |
||||
.ui-resizable-s { |
||||
cursor: s-resize; |
||||
height: 7px; |
||||
width: 100%; |
||||
bottom: -5px; |
||||
left: 0; |
||||
} |
||||
.ui-resizable-e { |
||||
cursor: e-resize; |
||||
width: 7px; |
||||
right: -5px; |
||||
top: 0; |
||||
height: 100%; |
||||
} |
||||
.ui-resizable-w { |
||||
cursor: w-resize; |
||||
width: 7px; |
||||
left: -5px; |
||||
top: 0; |
||||
height: 100%; |
||||
} |
||||
.ui-resizable-se { |
||||
cursor: se-resize; |
||||
width: 12px; |
||||
height: 12px; |
||||
right: 1px; |
||||
bottom: 1px; |
||||
} |
||||
.ui-resizable-sw { |
||||
cursor: sw-resize; |
||||
width: 9px; |
||||
height: 9px; |
||||
left: -5px; |
||||
bottom: -5px; |
||||
} |
||||
.ui-resizable-nw { |
||||
cursor: nw-resize; |
||||
width: 9px; |
||||
height: 9px; |
||||
left: -5px; |
||||
top: -5px; |
||||
} |
||||
.ui-resizable-ne { |
||||
cursor: ne-resize; |
||||
width: 9px; |
||||
height: 9px; |
||||
right: -5px; |
||||
top: -5px; |
||||
} |
||||
.ui-selectable { |
||||
-ms-touch-action: none; |
||||
touch-action: none; |
||||
} |
||||
.ui-selectable-helper { |
||||
position: absolute; |
||||
z-index: 100; |
||||
border: 1px dotted black; |
||||
} |
||||
.ui-sortable-handle { |
||||
-ms-touch-action: none; |
||||
touch-action: none; |
||||
} |
||||
.ui-accordion .ui-accordion-header { |
||||
display: block; |
||||
cursor: pointer; |
||||
position: relative; |
||||
margin: 2px 0 0 0; |
||||
padding: .5em .5em .5em .7em; |
||||
font-size: 100%; |
||||
} |
||||
.ui-accordion .ui-accordion-content { |
||||
padding: 1em 2.2em; |
||||
border-top: 0; |
||||
overflow: auto; |
||||
} |
||||
.ui-autocomplete { |
||||
position: absolute; |
||||
top: 0; |
||||
left: 0; |
||||
cursor: default; |
||||
} |
||||
.ui-menu { |
||||
list-style: none; |
||||
padding: 0; |
||||
margin: 0; |
||||
display: block; |
||||
outline: 0; |
||||
} |
||||
.ui-menu .ui-menu { |
||||
position: absolute; |
||||
} |
||||
.ui-menu .ui-menu-item { |
||||
margin: 0; |
||||
cursor: pointer; |
||||
/* support: IE10, see #8844 */ |
||||
list-style-image: url(""); |
||||
} |
||||
.ui-menu .ui-menu-item-wrapper { |
||||
position: relative; |
||||
padding: 3px 1em 3px .4em; |
||||
} |
||||
.ui-menu .ui-menu-divider { |
||||
margin: 5px 0; |
||||
height: 0; |
||||
font-size: 0; |
||||
line-height: 0; |
||||
border-width: 1px 0 0 0; |
||||
} |
||||
.ui-menu .ui-state-focus, |
||||
.ui-menu .ui-state-active { |
||||
margin: -1px; |
||||
} |
||||
|
||||
/* icon support */ |
||||
.ui-menu-icons { |
||||
position: relative; |
||||
} |
||||
.ui-menu-icons .ui-menu-item-wrapper { |
||||
padding-left: 2em; |
||||
} |
||||
|
||||
/* left-aligned */ |
||||
.ui-menu .ui-icon { |
||||
position: absolute; |
||||
top: 0; |
||||
bottom: 0; |
||||
left: .2em; |
||||
margin: auto 0; |
||||
} |
||||
|
||||
/* right-aligned */ |
||||
.ui-menu .ui-menu-icon { |
||||
left: auto; |
||||
right: 0; |
||||
} |
||||
.ui-button { |
||||
padding: .4em 1em; |
||||
display: inline-block; |
||||
position: relative; |
||||
line-height: normal; |
||||
margin-right: .1em; |
||||
cursor: pointer; |
||||
vertical-align: middle; |
||||
text-align: center; |
||||
-webkit-user-select: none; |
||||
-moz-user-select: none; |
||||
-ms-user-select: none; |
||||
user-select: none; |
||||
|
||||
/* Support: IE <= 11 */ |
||||
overflow: visible; |
||||
} |
||||
|
||||
.ui-button, |
||||
.ui-button:link, |
||||
.ui-button:visited, |
||||
.ui-button:hover, |
||||
.ui-button:active { |
||||
text-decoration: none; |
||||
} |
||||
|
||||
/* to make room for the icon, a width needs to be set here */ |
||||
.ui-button-icon-only { |
||||
width: 2em; |
||||
box-sizing: border-box; |
||||
text-indent: -9999px; |
||||
white-space: nowrap; |
||||
} |
||||
|
||||
/* no icon support for input elements */ |
||||
input.ui-button.ui-button-icon-only { |
||||
text-indent: 0; |
||||
} |
||||
|
||||
/* button icon element(s) */ |
||||
.ui-button-icon-only .ui-icon { |
||||
position: absolute; |
||||
top: 50%; |
||||
left: 50%; |
||||
margin-top: -8px; |
||||
margin-left: -8px; |
||||
} |
||||
|
||||
.ui-button.ui-icon-notext .ui-icon { |
||||
padding: 0; |
||||
width: 2.1em; |
||||
height: 2.1em; |
||||
text-indent: -9999px; |
||||
white-space: nowrap; |
||||
|
||||
} |
||||
|
||||
input.ui-button.ui-icon-notext .ui-icon { |
||||
width: auto; |
||||
height: auto; |
||||
text-indent: 0; |
||||
white-space: normal; |
||||
padding: .4em 1em; |
||||
} |
||||
|
||||
/* workarounds */ |
||||
/* Support: Firefox 5 - 40 */ |
||||
input.ui-button::-moz-focus-inner, |
||||
button.ui-button::-moz-focus-inner { |
||||
border: 0; |
||||
padding: 0; |
||||
} |
||||
.ui-controlgroup { |
||||
vertical-align: middle; |
||||
display: inline-block; |
||||
} |
||||
.ui-controlgroup > .ui-controlgroup-item { |
||||
float: left; |
||||
margin-left: 0; |
||||
margin-right: 0; |
||||
} |
||||
.ui-controlgroup > .ui-controlgroup-item:focus, |
||||
.ui-controlgroup > .ui-controlgroup-item.ui-visual-focus { |
||||
z-index: 9999; |
||||
} |
||||
.ui-controlgroup-vertical > .ui-controlgroup-item { |
||||
display: block; |
||||
float: none; |
||||
width: 100%; |
||||
margin-top: 0; |
||||
margin-bottom: 0; |
||||
text-align: left; |
||||
} |
||||
.ui-controlgroup-vertical .ui-controlgroup-item { |
||||
box-sizing: border-box; |
||||
} |
||||
.ui-controlgroup .ui-controlgroup-label { |
||||
padding: .4em 1em; |
||||
} |
||||
.ui-controlgroup .ui-controlgroup-label span { |
||||
font-size: 80%; |
||||
} |
||||
.ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item { |
||||
border-left: none; |
||||
} |
||||
.ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item { |
||||
border-top: none; |
||||
} |
||||
.ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content { |
||||
border-right: none; |
||||
} |
||||
.ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content { |
||||
border-bottom: none; |
||||
} |
||||
|
||||
/* Spinner specific style fixes */ |
||||
.ui-controlgroup-vertical .ui-spinner-input { |
||||
|
||||
/* Support: IE8 only, Android < 4.4 only */ |
||||
width: 75%; |
||||
width: calc( 100% - 2.4em ); |
||||
} |
||||
.ui-controlgroup-vertical .ui-spinner .ui-spinner-up { |
||||
border-top-style: solid; |
||||
} |
||||
|
||||
.ui-checkboxradio-label .ui-icon-background { |
||||
box-shadow: inset 1px 1px 1px #ccc; |
||||
border-radius: .12em; |
||||
border: none; |
||||
} |
||||
.ui-checkboxradio-radio-label .ui-icon-background { |
||||
width: 16px; |
||||
height: 16px; |
||||
border-radius: 1em; |
||||
overflow: visible; |
||||
border: none; |
||||
} |
||||
.ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon, |
||||
.ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon { |
||||
background-image: none; |
||||
width: 8px; |
||||
height: 8px; |
||||
border-width: 4px; |
||||
border-style: solid; |
||||
} |
||||
.ui-checkboxradio-disabled { |
||||
pointer-events: none; |
||||
} |
||||
.ui-datepicker { |
||||
width: 17em; |
||||
padding: .2em .2em 0; |
||||
display: none; |
||||
} |
||||
.ui-datepicker .ui-datepicker-header { |
||||
position: relative; |
||||
padding: .2em 0; |
||||
} |
||||
.ui-datepicker .ui-datepicker-prev, |
||||
.ui-datepicker .ui-datepicker-next { |
||||
position: absolute; |
||||
top: 2px; |
||||
width: 1.8em; |
||||
height: 1.8em; |
||||
} |
||||
.ui-datepicker .ui-datepicker-prev-hover, |
||||
.ui-datepicker .ui-datepicker-next-hover { |
||||
top: 1px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-prev { |
||||
left: 2px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-next { |
||||
right: 2px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-prev-hover { |
||||
left: 1px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-next-hover { |
||||
right: 1px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-prev span, |
||||
.ui-datepicker .ui-datepicker-next span { |
||||
display: block; |
||||
position: absolute; |
||||
left: 50%; |
||||
margin-left: -8px; |
||||
top: 50%; |
||||
margin-top: -8px; |
||||
} |
||||
.ui-datepicker .ui-datepicker-title { |
||||
margin: 0 2.3em; |
||||
line-height: 1.8em; |
||||
text-align: center; |
||||
} |
||||
.ui-datepicker .ui-datepicker-title select { |
||||
font-size: 1em; |
||||
margin: 1px 0; |
||||
} |
||||
.ui-datepicker select.ui-datepicker-month, |
||||
.ui-datepicker select.ui-datepicker-year { |
||||
width: 45%; |
||||
} |
||||
.ui-datepicker table { |
||||
width: 100%; |
||||
font-size: .9em; |
||||
border-collapse: collapse; |
||||
margin: 0 0 .4em; |
||||
} |
||||
.ui-datepicker th { |
||||
padding: .7em .3em; |
||||
text-align: center; |
||||
font-weight: bold; |
||||
border: 0; |
||||
} |
||||
.ui-datepicker td { |
||||
border: 0; |
||||
padding: 1px; |
||||
} |
||||
.ui-datepicker td span, |
||||
.ui-datepicker td a { |
||||
display: block; |
||||
padding: .2em; |
||||
text-align: right; |
||||
text-decoration: none; |
||||
} |
||||
.ui-datepicker .ui-datepicker-buttonpane { |
||||
background-image: none; |
||||
margin: .7em 0 0 0; |
||||
padding: 0 .2em; |
||||
border-left: 0; |
||||
border-right: 0; |
||||
border-bottom: 0; |
||||
} |
||||
.ui-datepicker .ui-datepicker-buttonpane button { |
||||
float: right; |
||||
margin: .5em .2em .4em; |
||||
cursor: pointer; |
||||
padding: .2em .6em .3em .6em; |
||||
width: auto; |
||||
overflow: visible; |
||||
} |
||||
.ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current { |
||||
float: left; |
||||
} |
||||
|
||||
/* with multiple calendars */ |
||||
.ui-datepicker.ui-datepicker-multi { |
||||
width: auto; |
||||
} |
||||
.ui-datepicker-multi .ui-datepicker-group { |
||||
float: left; |
||||
} |
||||
.ui-datepicker-multi .ui-datepicker-group table { |
||||
width: 95%; |
||||
margin: 0 auto .4em; |
||||
} |
||||
.ui-datepicker-multi-2 .ui-datepicker-group { |
||||
width: 50%; |
||||
} |
||||
.ui-datepicker-multi-3 .ui-datepicker-group { |
||||
width: 33.3%; |
||||
} |
||||
.ui-datepicker-multi-4 .ui-datepicker-group { |
||||
width: 25%; |
||||
} |
||||
.ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header, |
||||
.ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header { |
||||
border-left-width: 0; |
||||
} |
||||
.ui-datepicker-multi .ui-datepicker-buttonpane { |
||||
clear: left; |
||||
} |
||||
.ui-datepicker-row-break { |
||||
clear: both; |
||||
width: 100%; |
||||
font-size: 0; |
||||
} |
||||
|
||||
/* RTL support */ |
||||
.ui-datepicker-rtl { |
||||
direction: rtl; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-prev { |
||||
right: 2px; |
||||
left: auto; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-next { |
||||
left: 2px; |
||||
right: auto; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-prev:hover { |
||||
right: 1px; |
||||
left: auto; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-next:hover { |
||||
left: 1px; |
||||
right: auto; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane { |
||||
clear: right; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button { |
||||
float: left; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current, |
||||
.ui-datepicker-rtl .ui-datepicker-group { |
||||
float: right; |
||||
} |
||||
.ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header, |
||||
.ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header { |
||||
border-right-width: 0; |
||||
border-left-width: 1px; |
||||
} |
||||
|
||||
/* Icons */ |
||||
.ui-datepicker .ui-icon { |
||||
display: block; |
||||
text-indent: -99999px; |
||||
overflow: hidden; |
||||
background-repeat: no-repeat; |
||||
left: .5em; |
||||
top: .3em; |
||||
} |
||||
.ui-dialog { |
||||
position: absolute; |
||||
top: 0; |
||||
left: 0; |
||||
padding: .2em; |
||||
outline: 0; |
||||
} |
||||
.ui-dialog .ui-dialog-titlebar { |
||||
padding: .4em 1em; |
||||
position: relative; |
||||
} |
||||
.ui-dialog .ui-dialog-title { |
||||
float: left; |
||||
margin: .1em 0; |
||||
white-space: nowrap; |
||||
width: 90%; |
||||
overflow: hidden; |
||||
text-overflow: ellipsis; |
||||
} |
||||
.ui-dialog .ui-dialog-titlebar-close { |
||||
position: absolute; |
||||
right: .3em; |
||||
top: 50%; |
||||
width: 20px; |
||||
margin: -10px 0 0 0; |
||||
padding: 1px; |
||||
height: 20px; |
||||
} |
||||
.ui-dialog .ui-dialog-content { |
||||
position: relative; |
||||
border: 0; |
||||
padding: .5em 1em; |
||||
background: none; |
||||
overflow: auto; |
||||
} |
||||
.ui-dialog .ui-dialog-buttonpane { |
||||
text-align: left; |
||||
border-width: 1px 0 0 0; |
||||
background-image: none; |
||||
margin-top: .5em; |
||||
padding: .3em 1em .5em .4em; |
||||
} |
||||
.ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset { |
||||
float: right; |
||||
} |
||||
.ui-dialog .ui-dialog-buttonpane button { |
||||
margin: .5em .4em .5em 0; |
||||
cursor: pointer; |
||||
} |
||||
.ui-dialog .ui-resizable-n { |
||||
height: 2px; |
||||
top: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-e { |
||||
width: 2px; |
||||
right: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-s { |
||||
height: 2px; |
||||
bottom: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-w { |
||||
width: 2px; |
||||
left: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-se, |
||||
.ui-dialog .ui-resizable-sw, |
||||
.ui-dialog .ui-resizable-ne, |
||||
.ui-dialog .ui-resizable-nw { |
||||
width: 7px; |
||||
height: 7px; |
||||
} |
||||
.ui-dialog .ui-resizable-se { |
||||
right: 0; |
||||
bottom: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-sw { |
||||
left: 0; |
||||
bottom: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-ne { |
||||
right: 0; |
||||
top: 0; |
||||
} |
||||
.ui-dialog .ui-resizable-nw { |
||||
left: 0; |
||||
top: 0; |
||||
} |
||||
.ui-draggable .ui-dialog-titlebar { |
||||
cursor: move; |
||||
} |
||||
.ui-progressbar { |
||||
height: 2em; |
||||
text-align: left; |
||||
overflow: hidden; |
||||
} |
||||
.ui-progressbar .ui-progressbar-value { |
||||
margin: -1px; |
||||
height: 100%; |
||||
} |
||||
.ui-progressbar .ui-progressbar-overlay { |
||||
background: url(""); |
||||
height: 100%; |
||||
-ms-filter: "alpha(opacity=25)"; /* support: IE8 */ |
||||
opacity: 0.25; |
||||
} |
||||
.ui-progressbar-indeterminate .ui-progressbar-value { |
||||
background-image: none; |
||||
} |
||||
.ui-selectmenu-menu { |
||||
padding: 0; |
||||
margin: 0; |
||||
position: absolute; |
||||
top: 0; |
||||
left: 0; |
||||
display: none; |
||||
} |
||||
.ui-selectmenu-menu .ui-menu { |
||||
overflow: auto; |
||||
overflow-x: hidden; |
||||
padding-bottom: 1px; |
||||
} |
||||
.ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup { |
||||
font-size: 1em; |
||||
font-weight: bold; |
||||
line-height: 1.5; |
||||
padding: 2px 0.4em; |
||||
margin: 0.5em 0 0 0; |
||||
height: auto; |
||||
border: 0; |
||||
} |
||||
.ui-selectmenu-open { |
||||
display: block; |
||||
} |
||||
.ui-selectmenu-text { |
||||
display: block; |
||||
margin-right: 20px; |
||||
overflow: hidden; |
||||
text-overflow: ellipsis; |
||||
} |
||||
.ui-selectmenu-button.ui-button { |
||||
text-align: left; |
||||
white-space: nowrap; |
||||
width: 14em; |
||||
} |
||||
.ui-selectmenu-icon.ui-icon { |
||||
float: right; |
||||
margin-top: 0; |
||||
} |
||||
.ui-slider { |
||||
position: relative; |
||||
text-align: left; |
||||
} |
||||
.ui-slider .ui-slider-handle { |
||||
position: absolute; |
||||
z-index: 2; |
||||
width: 1.2em; |
||||
height: 1.2em; |
||||
cursor: pointer; |
||||
-ms-touch-action: none; |
||||
touch-action: none; |
||||
} |
||||
.ui-slider .ui-slider-range { |
||||
position: absolute; |
||||
z-index: 1; |
||||
font-size: .7em; |
||||
display: block; |
||||
border: 0; |
||||
background-position: 0 0; |
||||
} |
||||
|
||||
/* support: IE8 - See #6727 */ |
||||
.ui-slider.ui-state-disabled .ui-slider-handle, |
||||
.ui-slider.ui-state-disabled .ui-slider-range { |
||||
filter: inherit; |
||||
} |
||||
|
||||
.ui-slider-horizontal { |
||||
height: .8em; |
||||
} |
||||
.ui-slider-horizontal .ui-slider-handle { |
||||
top: -.3em; |
||||
margin-left: -.6em; |
||||
} |
||||
.ui-slider-horizontal .ui-slider-range { |
||||
top: 0; |
||||
height: 100%; |
||||
} |
||||
.ui-slider-horizontal .ui-slider-range-min { |
||||
left: 0; |
||||
} |
||||
.ui-slider-horizontal .ui-slider-range-max { |
||||
right: 0; |
||||
} |
||||
|
||||
.ui-slider-vertical { |
||||
width: .8em; |
||||
height: 100px; |
||||
} |
||||
.ui-slider-vertical .ui-slider-handle { |
||||
left: -.3em; |
||||
margin-left: 0; |
||||
margin-bottom: -.6em; |
||||
} |
||||
.ui-slider-vertical .ui-slider-range { |
||||
left: 0; |
||||
width: 100%; |
||||
} |
||||
.ui-slider-vertical .ui-slider-range-min { |
||||
bottom: 0; |
||||
} |
||||
.ui-slider-vertical .ui-slider-range-max { |
||||
top: 0; |
||||
} |
||||
.ui-spinner { |
||||
position: relative; |
||||
display: inline-block; |
||||
overflow: hidden; |
||||
padding: 0; |
||||
vertical-align: middle; |
||||
} |
||||
.ui-spinner-input { |
||||
border: none; |
||||
background: none; |
||||
color: inherit; |
||||
padding: .222em 0; |
||||
margin: .2em 0; |
||||
vertical-align: middle; |
||||
margin-left: .4em; |
||||
margin-right: 2em; |
||||
} |
||||
.ui-spinner-button { |
||||
width: 1.6em; |
||||
height: 50%; |
||||
font-size: .5em; |
||||
padding: 0; |
||||
margin: 0; |
||||
text-align: center; |
||||
position: absolute; |
||||
cursor: default; |
||||
display: block; |
||||
overflow: hidden; |
||||
right: 0; |
||||
} |
||||
/* more specificity required here to override default borders */ |
||||
.ui-spinner a.ui-spinner-button { |
||||
border-top-style: none; |
||||
border-bottom-style: none; |
||||
border-right-style: none; |
||||
} |
||||
.ui-spinner-up { |
||||
top: 0; |
||||
} |
||||
.ui-spinner-down { |
||||
bottom: 0; |
||||
} |
||||
.ui-tabs { |
||||
position: relative;/* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */ |
||||
padding: .2em; |
||||
} |
||||
.ui-tabs .ui-tabs-nav { |
||||
margin: 0; |
||||
padding: .2em .2em 0; |
||||
} |
||||
.ui-tabs .ui-tabs-nav li { |
||||
list-style: none; |
||||
float: left; |
||||
position: relative; |
||||
top: 0; |
||||
margin: 1px .2em 0 0; |
||||
border-bottom-width: 0; |
||||
padding: 0; |
||||
white-space: nowrap; |
||||
} |
||||
.ui-tabs .ui-tabs-nav .ui-tabs-anchor { |
||||
float: left; |
||||
padding: .5em 1em; |
||||
text-decoration: none; |
||||
} |
||||
.ui-tabs .ui-tabs-nav li.ui-tabs-active { |
||||
margin-bottom: -1px; |
||||
padding-bottom: 1px; |
||||
} |
||||
.ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor, |
||||
.ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor, |
||||
.ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor { |
||||
cursor: text; |
||||
} |
||||
.ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor { |
||||
cursor: pointer; |
||||
} |
||||
.ui-tabs .ui-tabs-panel { |
||||
display: block; |
||||
border-width: 0; |
||||
padding: 1em 1.4em; |
||||
background: none; |
||||
} |
||||
.ui-tooltip { |
||||
padding: 8px; |
||||
position: absolute; |
||||
z-index: 9999; |
||||
max-width: 300px; |
||||
} |
||||
body .ui-tooltip { |
||||
border-width: 2px; |
||||
} |
||||
@ -0,0 +1,446 @@
|
||||
/*! |
||||
* jQuery UI CSS Framework 1.13.1 |
||||
* http://jqueryui.com |
||||
* |
||||
* Copyright jQuery Foundation and other contributors |
||||
* Released under the MIT license. |
||||
* http://jquery.org/license |
||||
* |
||||
* http://api.jqueryui.com/category/theming/ |
||||
* |
||||
* To view and modify this theme, visit http://jqueryui.com/themeroller/?scope=&folderName=ui-lightness&cornerRadiusShadow=5px&offsetLeftShadow=-5px&offsetTopShadow=-5px&thicknessShadow=5px&opacityShadow=20&bgImgOpacityShadow=10&bgTextureShadow=flat&bgColorShadow=000000&opacityOverlay=50&bgImgOpacityOverlay=20&bgTextureOverlay=diagonals_thick&bgColorOverlay=666666&iconColorError=ffd27a&fcError=ffffff&borderColorError=cd0a0a&bgImgOpacityError=18&bgTextureError=diagonals_thick&bgColorError=b81900&iconColorHighlight=228ef1&fcHighlight=363636&borderColorHighlight=fed22f&bgImgOpacityHighlight=75&bgTextureHighlight=highlight_soft&bgColorHighlight=ffe45c&iconColorActive=ef8c08&fcActive=eb8f00&borderColorActive=fbd850&bgImgOpacityActive=65&bgTextureActive=glass&bgColorActive=ffffff&iconColorHover=ef8c08&fcHover=c77405&borderColorHover=fbcb09&bgImgOpacityHover=100&bgTextureHover=glass&bgColorHover=fdf5ce&iconColorDefault=ef8c08&fcDefault=1c94c4&borderColorDefault=cccccc&bgImgOpacityDefault=100&bgTextureDefault=glass&bgColorDefault=f6f6f6&iconColorContent=222222&fcContent=333333&borderColorContent=dddddd&bgImgOpacityContent=100&bgTextureContent=highlight_soft&bgColorContent=eeeeee&iconColorHeader=ffffff&fcHeader=ffffff&borderColorHeader=e78f08&bgImgOpacityHeader=35&bgTextureHeader=gloss_wave&bgColorHeader=f6a828&cornerRadius=4px&fsDefault=1.1em&fwDefault=bold&ffDefault=Trebuchet%20MS%2CTahoma%2CVerdana%2CArial%2Csans-serif |
||||
*/ |
||||
|
||||
|
||||
/* Component containers |
||||
----------------------------------*/ |
||||
.ui-widget { |
||||
font-family: Trebuchet MS,Tahoma,Verdana,Arial,sans-serif; |
||||
font-size: 1.1em; |
||||
} |
||||
.ui-widget .ui-widget { |
||||
font-size: 1em; |
||||
} |
||||
.ui-widget input, |
||||
.ui-widget select, |
||||
.ui-widget textarea, |
||||
.ui-widget button { |
||||
font-family: Trebuchet MS,Tahoma,Verdana,Arial,sans-serif; |
||||
font-size: 1em; |
||||
} |
||||
.ui-widget.ui-widget-content { |
||||
border: 1px solid #cccccc; |
||||
} |
||||
.ui-widget-content { |
||||
border: 1px solid #dddddd; |
||||
background: #eeeeee url("images/ui-bg_highlight-soft_100_eeeeee_1x100.png") 50% top repeat-x; |
||||
color: #333333; |
||||
} |
||||
.ui-widget-content a { |
||||
color: #333333; |
||||
} |
||||
.ui-widget-header { |
||||
border: 1px solid #e78f08; |
||||
background: #f6a828 url("images/ui-bg_gloss-wave_35_f6a828_500x100.png") 50% 50% repeat-x; |
||||
color: #ffffff; |
||||
font-weight: bold; |
||||
} |
||||
.ui-widget-header a { |
||||
color: #ffffff; |
||||
} |
||||
|
||||
/* Interaction states |
||||
----------------------------------*/ |
||||
.ui-state-default, |
||||
.ui-widget-content .ui-state-default, |
||||
.ui-widget-header .ui-state-default, |
||||
.ui-button, |
||||
|
||||
/* We use html here because we need a greater specificity to make sure disabled |
||||
works properly when clicked or hovered */ |
||||
html .ui-button.ui-state-disabled:hover, |
||||
html .ui-button.ui-state-disabled:active { |
||||
border: 1px solid #cccccc; |
||||
background: #f6f6f6 url("images/ui-bg_glass_100_f6f6f6_1x400.png") 50% 50% repeat-x; |
||||
font-weight: bold; |
||||
color: #1c94c4; |
||||
} |
||||
.ui-state-default a, |
||||
.ui-state-default a:link, |
||||
.ui-state-default a:visited, |
||||
a.ui-button, |
||||
a:link.ui-button, |
||||
a:visited.ui-button, |
||||
.ui-button { |
||||
color: #1c94c4; |
||||
text-decoration: none; |
||||
} |
||||
.ui-state-hover, |
||||
.ui-widget-content .ui-state-hover, |
||||
.ui-widget-header .ui-state-hover, |
||||
.ui-state-focus, |
||||
.ui-widget-content .ui-state-focus, |
||||
.ui-widget-header .ui-state-focus, |
||||
.ui-button:hover, |
||||
.ui-button:focus { |
||||
border: 1px solid #fbcb09; |
||||
background: #fdf5ce url("images/ui-bg_glass_100_fdf5ce_1x400.png") 50% 50% repeat-x; |
||||
font-weight: bold; |
||||
color: #c77405; |
||||
} |
||||
.ui-state-hover a, |
||||
.ui-state-hover a:hover, |
||||
.ui-state-hover a:link, |
||||
.ui-state-hover a:visited, |
||||
.ui-state-focus a, |
||||
.ui-state-focus a:hover, |
||||
.ui-state-focus a:link, |
||||
.ui-state-focus a:visited, |
||||
a.ui-button:hover, |
||||
a.ui-button:focus { |
||||
color: #c77405; |
||||
text-decoration: none; |
||||
} |
||||
|
||||
.ui-visual-focus { |
||||
box-shadow: 0 0 3px 1px rgb(94, 158, 214); |
||||
} |
||||
.ui-state-active, |
||||
.ui-widget-content .ui-state-active, |
||||
.ui-widget-header .ui-state-active, |
||||
a.ui-button:active, |
||||
.ui-button:active, |
||||
.ui-button.ui-state-active:hover { |
||||
border: 1px solid #fbd850; |
||||
background: #ffffff url("images/ui-bg_glass_65_ffffff_1x400.png") 50% 50% repeat-x; |
||||
font-weight: bold; |
||||
color: #eb8f00; |
||||
} |
||||
.ui-icon-background, |
||||
.ui-state-active .ui-icon-background { |
||||
border: #fbd850; |
||||
background-color: #eb8f00; |
||||
} |
||||
.ui-state-active a, |
||||
.ui-state-active a:link, |
||||
.ui-state-active a:visited { |
||||
color: #eb8f00; |
||||
text-decoration: none; |
||||
} |
||||
|
||||
/* Interaction Cues |
||||
----------------------------------*/ |
||||
.ui-state-highlight, |
||||
.ui-widget-content .ui-state-highlight, |
||||
.ui-widget-header .ui-state-highlight { |
||||
border: 1px solid #fed22f; |
||||
background: #ffe45c url("images/ui-bg_highlight-soft_75_ffe45c_1x100.png") 50% top repeat-x; |
||||
color: #363636; |
||||
} |
||||
.ui-state-checked { |
||||
border: 1px solid #fed22f; |
||||
background: #ffe45c; |
||||
} |
||||
.ui-state-highlight a, |
||||
.ui-widget-content .ui-state-highlight a, |
||||
.ui-widget-header .ui-state-highlight a { |
||||
color: #363636; |
||||
} |
||||
.ui-state-error, |
||||
.ui-widget-content .ui-state-error, |
||||
.ui-widget-header .ui-state-error { |
||||
border: 1px solid #cd0a0a; |
||||
background: #b81900 url("images/ui-bg_diagonals-thick_18_b81900_40x40.png") 50% 50% repeat; |
||||
color: #ffffff; |
||||
} |
||||
.ui-state-error a, |
||||
.ui-widget-content .ui-state-error a, |
||||
.ui-widget-header .ui-state-error a { |
||||
color: #ffffff; |
||||
} |
||||
.ui-state-error-text, |
||||
.ui-widget-content .ui-state-error-text, |
||||
.ui-widget-header .ui-state-error-text { |
||||
color: #ffffff; |
||||
} |
||||
.ui-priority-primary, |
||||
.ui-widget-content .ui-priority-primary, |
||||
.ui-widget-header .ui-priority-primary { |
||||
font-weight: bold; |
||||
} |
||||
.ui-priority-secondary, |
||||
.ui-widget-content .ui-priority-secondary, |
||||
.ui-widget-header .ui-priority-secondary { |
||||
opacity: .7; |
||||
-ms-filter: "alpha(opacity=70)"; /* support: IE8 */ |
||||
font-weight: normal; |
||||
} |
||||
.ui-state-disabled, |
||||
.ui-widget-content .ui-state-disabled, |
||||
.ui-widget-header .ui-state-disabled { |
||||
opacity: .35; |
||||
-ms-filter: "alpha(opacity=35)"; /* support: IE8 */ |
||||
background-image: none; |
||||
} |
||||
.ui-state-disabled .ui-icon { |
||||
-ms-filter: "alpha(opacity=35)"; /* support: IE8 - See #6059 */ |
||||
} |
||||
|
||||
/* Icons |
||||
----------------------------------*/ |
||||
|
||||
/* states and images */ |
||||
.ui-icon { |
||||
width: 16px; |
||||
height: 16px; |
||||
} |
||||
.ui-icon, |
||||
.ui-widget-content .ui-icon { |
||||
background-image: url("images/ui-icons_222222_256x240.png"); |
||||
} |
||||
.ui-widget-header .ui-icon { |
||||
background-image: url("images/ui-icons_ffffff_256x240.png"); |
||||
} |
||||
.ui-state-hover .ui-icon, |
||||
.ui-state-focus .ui-icon, |
||||
.ui-button:hover .ui-icon, |
||||
.ui-button:focus .ui-icon { |
||||
background-image: url("images/ui-icons_ef8c08_256x240.png"); |
||||
} |
||||
.ui-state-active .ui-icon, |
||||
.ui-button:active .ui-icon { |
||||
background-image: url("images/ui-icons_ef8c08_256x240.png"); |
||||
} |
||||
.ui-state-highlight .ui-icon, |
||||
.ui-button .ui-state-highlight.ui-icon { |
||||
background-image: url("images/ui-icons_228ef1_256x240.png"); |
||||
} |
||||
.ui-state-error .ui-icon, |
||||
.ui-state-error-text .ui-icon { |
||||
background-image: url("images/ui-icons_ffd27a_256x240.png"); |
||||
} |
||||
.ui-button .ui-icon { |
||||
background-image: url("images/ui-icons_ef8c08_256x240.png"); |
||||
} |
||||
|
||||
/* positioning */ |
||||
/* Three classes needed to override `.ui-button:hover .ui-icon` */ |
||||
.ui-icon-blank.ui-icon-blank.ui-icon-blank { |
||||
background-image: none; |
||||
} |
||||
.ui-icon-caret-1-n { background-position: 0 0; } |
||||
.ui-icon-caret-1-ne { background-position: -16px 0; } |
||||
.ui-icon-caret-1-e { background-position: -32px 0; } |
||||
.ui-icon-caret-1-se { background-position: -48px 0; } |
||||
.ui-icon-caret-1-s { background-position: -65px 0; } |
||||
.ui-icon-caret-1-sw { background-position: -80px 0; } |
||||
.ui-icon-caret-1-w { background-position: -96px 0; } |
||||
.ui-icon-caret-1-nw { background-position: -112px 0; } |
||||
.ui-icon-caret-2-n-s { background-position: -128px 0; } |
||||
.ui-icon-caret-2-e-w { background-position: -144px 0; } |
||||
.ui-icon-triangle-1-n { background-position: 0 -16px; } |
||||
.ui-icon-triangle-1-ne { background-position: -16px -16px; } |
||||
.ui-icon-triangle-1-e { background-position: -32px -16px; } |
||||
.ui-icon-triangle-1-se { background-position: -48px -16px; } |
||||
.ui-icon-triangle-1-s { background-position: -65px -16px; } |
||||
.ui-icon-triangle-1-sw { background-position: -80px -16px; } |
||||
.ui-icon-triangle-1-w { background-position: -96px -16px; } |
||||
.ui-icon-triangle-1-nw { background-position: -112px -16px; } |
||||
.ui-icon-triangle-2-n-s { background-position: -128px -16px; } |
||||
.ui-icon-triangle-2-e-w { background-position: -144px -16px; } |
||||
.ui-icon-arrow-1-n { background-position: 0 -32px; } |
||||
.ui-icon-arrow-1-ne { background-position: -16px -32px; } |
||||
.ui-icon-arrow-1-e { background-position: -32px -32px; } |
||||
.ui-icon-arrow-1-se { background-position: -48px -32px; } |
||||
.ui-icon-arrow-1-s { background-position: -65px -32px; } |
||||
.ui-icon-arrow-1-sw { background-position: -80px -32px; } |
||||
.ui-icon-arrow-1-w { background-position: -96px -32px; } |
||||
.ui-icon-arrow-1-nw { background-position: -112px -32px; } |
||||
.ui-icon-arrow-2-n-s { background-position: -128px -32px; } |
||||
.ui-icon-arrow-2-ne-sw { background-position: -144px -32px; } |
||||
.ui-icon-arrow-2-e-w { background-position: -160px -32px; } |
||||
.ui-icon-arrow-2-se-nw { background-position: -176px -32px; } |
||||
.ui-icon-arrowstop-1-n { background-position: -192px -32px; } |
||||
.ui-icon-arrowstop-1-e { background-position: -208px -32px; } |
||||
.ui-icon-arrowstop-1-s { background-position: -224px -32px; } |
||||
.ui-icon-arrowstop-1-w { background-position: -240px -32px; } |
||||
.ui-icon-arrowthick-1-n { background-position: 1px -48px; } |
||||
.ui-icon-arrowthick-1-ne { background-position: -16px -48px; } |
||||
.ui-icon-arrowthick-1-e { background-position: -32px -48px; } |
||||
.ui-icon-arrowthick-1-se { background-position: -48px -48px; } |
||||
.ui-icon-arrowthick-1-s { background-position: -64px -48px; } |
||||
.ui-icon-arrowthick-1-sw { background-position: -80px -48px; } |
||||
.ui-icon-arrowthick-1-w { background-position: -96px -48px; } |
||||
.ui-icon-arrowthick-1-nw { background-position: -112px -48px; } |
||||
.ui-icon-arrowthick-2-n-s { background-position: -128px -48px; } |
||||
.ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; } |
||||
.ui-icon-arrowthick-2-e-w { background-position: -160px -48px; } |
||||
.ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; } |
||||
.ui-icon-arrowthickstop-1-n { background-position: -192px -48px; } |
||||
.ui-icon-arrowthickstop-1-e { background-position: -208px -48px; } |
||||
.ui-icon-arrowthickstop-1-s { background-position: -224px -48px; } |
||||
.ui-icon-arrowthickstop-1-w { background-position: -240px -48px; } |
||||
.ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; } |
||||
.ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; } |
||||
.ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; } |
||||
.ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; } |
||||
.ui-icon-arrowreturn-1-w { background-position: -64px -64px; } |
||||
.ui-icon-arrowreturn-1-n { background-position: -80px -64px; } |
||||
.ui-icon-arrowreturn-1-e { background-position: -96px -64px; } |
||||
.ui-icon-arrowreturn-1-s { background-position: -112px -64px; } |
||||
.ui-icon-arrowrefresh-1-w { background-position: -128px -64px; } |
||||
.ui-icon-arrowrefresh-1-n { background-position: -144px -64px; } |
||||
.ui-icon-arrowrefresh-1-e { background-position: -160px -64px; } |
||||
.ui-icon-arrowrefresh-1-s { background-position: -176px -64px; } |
||||
.ui-icon-arrow-4 { background-position: 0 -80px; } |
||||
.ui-icon-arrow-4-diag { background-position: -16px -80px; } |
||||
.ui-icon-extlink { background-position: -32px -80px; } |
||||
.ui-icon-newwin { background-position: -48px -80px; } |
||||
.ui-icon-refresh { background-position: -64px -80px; } |
||||
.ui-icon-shuffle { background-position: -80px -80px; } |
||||
.ui-icon-transfer-e-w { background-position: -96px -80px; } |
||||
.ui-icon-transferthick-e-w { background-position: -112px -80px; } |
||||
.ui-icon-folder-collapsed { background-position: 0 -96px; } |
||||
.ui-icon-folder-open { background-position: -16px -96px; } |
||||
.ui-icon-document { background-position: -32px -96px; } |
||||
.ui-icon-document-b { background-position: -48px -96px; } |
||||
.ui-icon-note { background-position: -64px -96px; } |
||||
.ui-icon-mail-closed { background-position: -80px -96px; } |
||||
.ui-icon-mail-open { background-position: -96px -96px; } |
||||
.ui-icon-suitcase { background-position: -112px -96px; } |
||||
.ui-icon-comment { background-position: -128px -96px; } |
||||
.ui-icon-person { background-position: -144px -96px; } |
||||
.ui-icon-print { background-position: -160px -96px; } |
||||
.ui-icon-trash { background-position: -176px -96px; } |
||||
.ui-icon-locked { background-position: -192px -96px; } |
||||
.ui-icon-unlocked { background-position: -208px -96px; } |
||||
.ui-icon-bookmark { background-position: -224px -96px; } |
||||
.ui-icon-tag { background-position: -240px -96px; } |
||||
.ui-icon-home { background-position: 0 -112px; } |
||||
.ui-icon-flag { background-position: -16px -112px; } |
||||
.ui-icon-calendar { background-position: -32px -112px; } |
||||
.ui-icon-cart { background-position: -48px -112px; } |
||||
.ui-icon-pencil { background-position: -64px -112px; } |
||||
.ui-icon-clock { background-position: -80px -112px; } |
||||
.ui-icon-disk { background-position: -96px -112px; } |
||||
.ui-icon-calculator { background-position: -112px -112px; } |
||||
.ui-icon-zoomin { background-position: -128px -112px; } |
||||
.ui-icon-zoomout { background-position: -144px -112px; } |
||||
.ui-icon-search { background-position: -160px -112px; } |
||||
.ui-icon-wrench { background-position: -176px -112px; } |
||||
.ui-icon-gear { background-position: -192px -112px; } |
||||
.ui-icon-heart { background-position: -208px -112px; } |
||||
.ui-icon-star { background-position: -224px -112px; } |
||||
.ui-icon-link { background-position: -240px -112px; } |
||||
.ui-icon-cancel { background-position: 0 -128px; } |
||||
.ui-icon-plus { background-position: -16px -128px; } |
||||
.ui-icon-plusthick { background-position: -32px -128px; } |
||||
.ui-icon-minus { background-position: -48px -128px; } |
||||
.ui-icon-minusthick { background-position: -64px -128px; } |
||||
.ui-icon-close { background-position: -80px -128px; } |
||||
.ui-icon-closethick { background-position: -96px -128px; } |
||||
.ui-icon-key { background-position: -112px -128px; } |
||||
.ui-icon-lightbulb { background-position: -128px -128px; } |
||||
.ui-icon-scissors { background-position: -144px -128px; } |
||||
.ui-icon-clipboard { background-position: -160px -128px; } |
||||
.ui-icon-copy { background-position: -176px -128px; } |
||||
.ui-icon-contact { background-position: -192px -128px; } |
||||
.ui-icon-image { background-position: -208px -128px; } |
||||
.ui-icon-video { background-position: -224px -128px; } |
||||
.ui-icon-script { background-position: -240px -128px; } |
||||
.ui-icon-alert { background-position: 0 -144px; } |
||||
.ui-icon-info { background-position: -16px -144px; } |
||||
.ui-icon-notice { background-position: -32px -144px; } |
||||
.ui-icon-help { background-position: -48px -144px; } |
||||
.ui-icon-check { background-position: -64px -144px; } |
||||
.ui-icon-bullet { background-position: -80px -144px; } |
||||
.ui-icon-radio-on { background-position: -96px -144px; } |
||||
.ui-icon-radio-off { background-position: -112px -144px; } |
||||
.ui-icon-pin-w { background-position: -128px -144px; } |
||||
.ui-icon-pin-s { background-position: -144px -144px; } |
||||
.ui-icon-play { background-position: 0 -160px; } |
||||
.ui-icon-pause { background-position: -16px -160px; } |
||||
.ui-icon-seek-next { background-position: -32px -160px; } |
||||
.ui-icon-seek-prev { background-position: -48px -160px; } |
||||
.ui-icon-seek-end { background-position: -64px -160px; } |
||||
.ui-icon-seek-start { background-position: -80px -160px; } |
||||
/* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */ |
||||
.ui-icon-seek-first { background-position: -80px -160px; } |
||||
.ui-icon-stop { background-position: -96px -160px; } |
||||
.ui-icon-eject { background-position: -112px -160px; } |
||||
.ui-icon-volume-off { background-position: -128px -160px; } |
||||
.ui-icon-volume-on { background-position: -144px -160px; } |
||||
.ui-icon-power { background-position: 0 -176px; } |
||||
.ui-icon-signal-diag { background-position: -16px -176px; } |
||||
.ui-icon-signal { background-position: -32px -176px; } |
||||
.ui-icon-battery-0 { background-position: -48px -176px; } |
||||
.ui-icon-battery-1 { background-position: -64px -176px; } |
||||
.ui-icon-battery-2 { background-position: -80px -176px; } |
||||
.ui-icon-battery-3 { background-position: -96px -176px; } |
||||
.ui-icon-circle-plus { background-position: 0 -192px; } |
||||
.ui-icon-circle-minus { background-position: -16px -192px; } |
||||
.ui-icon-circle-close { background-position: -32px -192px; } |
||||
.ui-icon-circle-triangle-e { background-position: -48px -192px; } |
||||
.ui-icon-circle-triangle-s { background-position: -64px -192px; } |
||||
.ui-icon-circle-triangle-w { background-position: -80px -192px; } |
||||
.ui-icon-circle-triangle-n { background-position: -96px -192px; } |
||||
.ui-icon-circle-arrow-e { background-position: -112px -192px; } |
||||
.ui-icon-circle-arrow-s { background-position: -128px -192px; } |
||||
.ui-icon-circle-arrow-w { background-position: -144px -192px; } |
||||
.ui-icon-circle-arrow-n { background-position: -160px -192px; } |
||||
.ui-icon-circle-zoomin { background-position: -176px -192px; } |
||||
.ui-icon-circle-zoomout { background-position: -192px -192px; } |
||||
.ui-icon-circle-check { background-position: -208px -192px; } |
||||
.ui-icon-circlesmall-plus { background-position: 0 -208px; } |
||||
.ui-icon-circlesmall-minus { background-position: -16px -208px; } |
||||
.ui-icon-circlesmall-close { background-position: -32px -208px; } |
||||
.ui-icon-squaresmall-plus { background-position: -48px -208px; } |
||||
.ui-icon-squaresmall-minus { background-position: -64px -208px; } |
||||
.ui-icon-squaresmall-close { background-position: -80px -208px; } |
||||
.ui-icon-grip-dotted-vertical { background-position: 0 -224px; } |
||||
.ui-icon-grip-dotted-horizontal { background-position: -16px -224px; } |
||||
.ui-icon-grip-solid-vertical { background-position: -32px -224px; } |
||||
.ui-icon-grip-solid-horizontal { background-position: -48px -224px; } |
||||
.ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; } |
||||
.ui-icon-grip-diagonal-se { background-position: -80px -224px; } |
||||
|
||||
|
||||
/* Misc visuals |
||||
----------------------------------*/ |
||||
|
||||
/* Corner radius */ |
||||
.ui-corner-all, |
||||
.ui-corner-top, |
||||
.ui-corner-left, |
||||
.ui-corner-tl { |
||||
border-top-left-radius: 4px; |
||||
} |
||||
.ui-corner-all, |
||||
.ui-corner-top, |
||||
.ui-corner-right, |
||||
.ui-corner-tr { |
||||
border-top-right-radius: 4px; |
||||
} |
||||
.ui-corner-all, |
||||
.ui-corner-bottom, |
||||
.ui-corner-left, |
||||
.ui-corner-bl { |
||||
border-bottom-left-radius: 4px; |
||||
} |
||||
.ui-corner-all, |
||||
.ui-corner-bottom, |
||||
.ui-corner-right, |
||||
.ui-corner-br { |
||||
border-bottom-right-radius: 4px; |
||||
} |
||||
|
||||
/* Overlays */ |
||||
.ui-widget-overlay { |
||||
background: #666666 url("images/ui-bg_diagonals-thick_20_666666_40x40.png") 50% 50% repeat; |
||||
opacity: .5; |
||||
-ms-filter: Alpha(Opacity=50); /* support: IE8 */ |
||||
} |
||||
.ui-widget-shadow { |
||||
-webkit-box-shadow: -5px -5px 5px #000000; |
||||
box-shadow: -5px -5px 5px #000000; |
||||
} |
||||
@ -0,0 +1,36 @@
|
||||
body{ |
||||
margin: 0; |
||||
} |
||||
|
||||
nav{ |
||||
font-size: 180%; |
||||
background-color: blue; |
||||
padding: 8px; |
||||
position: sticky; |
||||
top: 0; |
||||
} |
||||
|
||||
nav .name{ |
||||
float:left; |
||||
} |
||||
nav .status{ |
||||
float:right; |
||||
} |
||||
|
||||
.hidden{ |
||||
display: none; |
||||
} |
||||
|
||||
main{ |
||||
padding: 8px; |
||||
} |
||||
|
||||
.hdr-info-box{ |
||||
font-size: initial; |
||||
background-color: red; |
||||
position: fixed; |
||||
right: 1em; |
||||
padding: 1em; |
||||
width: 20%; |
||||
overflow: auto; |
||||
} |
||||
@ -0,0 +1,74 @@
|
||||
{ |
||||
"name": "jquery-ui", |
||||
"title": "jQuery UI", |
||||
"description": "A curated set of user interface interactions, effects, widgets, and themes built on top of the jQuery JavaScript Library.", |
||||
"version": "1.13.1", |
||||
"homepage": "http://jqueryui.com", |
||||
"author": { |
||||
"name": "jQuery Foundation and other contributors", |
||||
"url": "https://github.com/jquery/jquery-ui/blob/1.13.1/AUTHORS.txt" |
||||
}, |
||||
"main": "ui/widget.js", |
||||
"maintainers": [ |
||||
{ |
||||
"name": "Jörn Zaefferer", |
||||
"email": "joern.zaefferer@gmail.com", |
||||
"url": "http://bassistance.de" |
||||
}, |
||||
{ |
||||
"name": "Mike Sherov", |
||||
"email": "mike.sherov@gmail.com", |
||||
"url": "http://mike.sherov.com" |
||||
}, |
||||
{ |
||||
"name": "TJ VanToll", |
||||
"email": "tj.vantoll@gmail.com", |
||||
"url": "http://tjvantoll.com" |
||||
}, |
||||
{ |
||||
"name": "Felix Nagel", |
||||
"email": "info@felixnagel.com", |
||||
"url": "http://www.felixnagel.com" |
||||
}, |
||||
{ |
||||
"name": "Alex Schmitz", |
||||
"email": "arschmitz@gmail.com", |
||||
"url": "https://github.com/arschmitz" |
||||
} |
||||
], |
||||
"repository": { |
||||
"type": "git", |
||||
"url": "git://github.com/jquery/jquery-ui.git" |
||||
}, |
||||
"bugs": { |
||||
"url": "https://github.com/jquery/jquery-ui/issues" |
||||
}, |
||||
"license": "MIT", |
||||
"scripts": { |
||||
"test": "grunt" |
||||
}, |
||||
"dependencies": { |
||||
"jquery": ">=1.8.0 <4.0.0" |
||||
}, |
||||
"devDependencies": { |
||||
"commitplease": "3.2.0", |
||||
"eslint-config-jquery": "3.0.0", |
||||
"glob": "7.2.0", |
||||
"grunt": "1.4.1", |
||||
"grunt-bowercopy": "1.2.5", |
||||
"grunt-cli": "1.4.3", |
||||
"grunt-compare-size": "0.4.2", |
||||
"grunt-contrib-concat": "1.0.1", |
||||
"grunt-contrib-csslint": "2.0.0", |
||||
"grunt-contrib-qunit": "5.1.1", |
||||
"grunt-contrib-requirejs": "1.0.0", |
||||
"grunt-contrib-uglify": "5.0.1", |
||||
"grunt-eslint": "23.0.0", |
||||
"grunt-git-authors": "3.2.0", |
||||
"grunt-html": "14.5.0", |
||||
"load-grunt-tasks": "5.1.0", |
||||
"rimraf": "3.0.2", |
||||
"testswarm": "1.1.2" |
||||
}, |
||||
"keywords": [] |
||||
} |
||||
@ -0,0 +1,111 @@
|
||||
-- -------------------------------------------------------- |
||||
-- Host: vm1.private |
||||
-- Server version: 10.3.28-MariaDB - MariaDB Server |
||||
-- Server OS: Linux |
||||
-- HeidiSQL Version: 11.3.0.6295 |
||||
-- -------------------------------------------------------- |
||||
|
||||
/*!40101 SET @OLD_CHARACTER_SET_CLIENT=@@CHARACTER_SET_CLIENT */; |
||||
/*!40101 SET NAMES utf8 */; |
||||
/*!50503 SET NAMES utf8mb4 */; |
||||
/*!40014 SET @OLD_FOREIGN_KEY_CHECKS=@@FOREIGN_KEY_CHECKS, FOREIGN_KEY_CHECKS=0 */; |
||||
/*!40101 SET @OLD_SQL_MODE=@@SQL_MODE, SQL_MODE='NO_AUTO_VALUE_ON_ZERO' */; |
||||
/*!40111 SET @OLD_SQL_NOTES=@@SQL_NOTES, SQL_NOTES=0 */; |
||||
|
||||
|
||||
-- Dumping database structure for dm |
||||
CREATE DATABASE IF NOT EXISTS `dm` /*!40100 DEFAULT CHARACTER SET utf8 COLLATE utf8_bin */; |
||||
USE `dm`; |
||||
|
||||
-- Dumping structure for table dm.api_key |
||||
CREATE TABLE IF NOT EXISTS `api_key` ( |
||||
`api_key` char(48) CHARACTER SET ascii COLLATE ascii_bin NOT NULL, |
||||
`user` int(11) NOT NULL, |
||||
`key_name` varchar(255) COLLATE utf8_bin NOT NULL DEFAULT '', |
||||
`last_key_use` datetime DEFAULT NULL, |
||||
PRIMARY KEY (`api_key`), |
||||
KEY `FK__user` (`user`), |
||||
CONSTRAINT `FK__user` FOREIGN KEY (`user`) REFERENCES `user` (`user_id`) ON DELETE CASCADE ON UPDATE CASCADE |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.project |
||||
CREATE TABLE IF NOT EXISTS `project` ( |
||||
`project_id` int(10) unsigned NOT NULL AUTO_INCREMENT, |
||||
`project_path` varchar(128) COLLATE utf8_bin NOT NULL, |
||||
`project_name` varchar(1024) COLLATE utf8_bin NOT NULL, |
||||
`mode` enum('master','mirror') COLLATE utf8_bin NOT NULL DEFAULT 'master', |
||||
`description` text COLLATE utf8_bin DEFAULT NULL, |
||||
`owner` int(11) DEFAULT NULL, |
||||
PRIMARY KEY (`project_id`), |
||||
UNIQUE KEY `project_path` (`project_path`), |
||||
KEY `FK_project_user` (`owner`), |
||||
CONSTRAINT `FK_project_user` FOREIGN KEY (`owner`) REFERENCES `user` (`user_id`) ON UPDATE CASCADE |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.project_user |
||||
CREATE TABLE IF NOT EXISTS `project_user` ( |
||||
`project_id` int(11) unsigned NOT NULL, |
||||
`user_id` int(11) NOT NULL, |
||||
`read` tinyint(1) NOT NULL DEFAULT 1, |
||||
`modify` tinyint(1) NOT NULL DEFAULT 0, |
||||
PRIMARY KEY (`project_id`,`user_id`), |
||||
KEY `FK_project_user_user` (`user_id`), |
||||
CONSTRAINT `FK_project_user_project` FOREIGN KEY (`project_id`) REFERENCES `project` (`project_id`) ON DELETE NO ACTION ON UPDATE NO ACTION, |
||||
CONSTRAINT `FK_project_user_user` FOREIGN KEY (`user_id`) REFERENCES `user` (`user_id`) ON DELETE NO ACTION ON UPDATE CASCADE |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.role |
||||
CREATE TABLE IF NOT EXISTS `role` ( |
||||
`role_name` varchar(50) COLLATE utf8_bin NOT NULL, |
||||
`role_desc` text COLLATE utf8_bin NOT NULL, |
||||
PRIMARY KEY (`role_name`) |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.system_parameter |
||||
CREATE TABLE IF NOT EXISTS `system_parameter` ( |
||||
`parameter_id` varchar(50) COLLATE utf8_bin NOT NULL, |
||||
`parameter_value` text COLLATE utf8_bin NOT NULL, |
||||
PRIMARY KEY (`parameter_id`) USING BTREE |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.user |
||||
CREATE TABLE IF NOT EXISTS `user` ( |
||||
`user_id` int(11) NOT NULL AUTO_INCREMENT, |
||||
`user_name` varchar(200) CHARACTER SET ascii NOT NULL, |
||||
`password` varchar(200) CHARACTER SET ascii NOT NULL, |
||||
`email` varchar(500) COLLATE utf8_bin DEFAULT NULL, |
||||
`created` datetime DEFAULT NULL, |
||||
`password_date` datetime DEFAULT NULL, |
||||
`last_login` datetime DEFAULT NULL, |
||||
`pwd_err_cnt` tinyint(3) unsigned DEFAULT NULL, |
||||
PRIMARY KEY (`user_id`) |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
-- Dumping structure for table dm.user_role |
||||
CREATE TABLE IF NOT EXISTS `user_role` ( |
||||
`user_id` int(11) NOT NULL, |
||||
`role_name` varchar(50) COLLATE utf8_bin NOT NULL DEFAULT '', |
||||
PRIMARY KEY (`user_id`,`role_name`), |
||||
KEY `FK_user_role_role` (`role_name`), |
||||
CONSTRAINT `FK_user_role_role` FOREIGN KEY (`role_name`) REFERENCES `role` (`role_name`) ON DELETE NO ACTION ON UPDATE NO ACTION, |
||||
CONSTRAINT `FK_user_role_user` FOREIGN KEY (`user_id`) REFERENCES `user` (`user_id`) ON DELETE NO ACTION ON UPDATE NO ACTION |
||||
) ENGINE=InnoDB DEFAULT CHARSET=utf8 COLLATE=utf8_bin; |
||||
|
||||
-- Data exporting was unselected. |
||||
|
||||
/*!40101 SET SQL_MODE=IFNULL(@OLD_SQL_MODE, '') */; |
||||
/*!40014 SET FOREIGN_KEY_CHECKS=IFNULL(@OLD_FOREIGN_KEY_CHECKS, 1) */; |
||||
/*!40101 SET CHARACTER_SET_CLIENT=@OLD_CHARACTER_SET_CLIENT */; |
||||
/*!40111 SET SQL_NOTES=IFNULL(@OLD_SQL_NOTES, 1) */; |
||||
@ -0,0 +1,85 @@
|
||||
package org.leolo.web.dm.dao; |
||||
|
||||
import java.sql.Connection; |
||||
import java.sql.PreparedStatement; |
||||
import java.sql.ResultSet; |
||||
import java.sql.SQLException; |
||||
import java.util.Hashtable; |
||||
import java.util.Map; |
||||
|
||||
import org.leolo.web.dm.Constant; |
||||
import org.leolo.web.dm.model.User; |
||||
import org.slf4j.Logger; |
||||
import org.slf4j.LoggerFactory; |
||||
|
||||
public class UserDao extends BaseDao { |
||||
|
||||
private static Logger log = LoggerFactory.getLogger(UserDao.class); |
||||
|
||||
public Map<String, Object> getBasicUserInfoByUsernameWithPassword(String username) { |
||||
Map<String, Object> u = new Hashtable<>(); |
||||
try (Connection conn = getConnection()) { |
||||
// Step 1: get basic user info
|
||||
try (PreparedStatement pstmt = conn |
||||
.prepareStatement("SELECT user_id, user_name, password, pwd_err_cnt, last_login FROM user WHERE user_name = ?")) { |
||||
pstmt.setString(1, username); |
||||
try (ResultSet rs = pstmt.executeQuery()) { |
||||
if (rs.next()) { |
||||
u.put(Constant.BUI_KEY_USER_NAME, rs.getString(2)); |
||||
u.put(Constant.BUI_KEY_USER_ID, rs.getInt(1)); |
||||
u.put(Constant.BUI_KEY_PASSWORD, rs.getString(3)); |
||||
u.put(Constant.BUI_KEY_FAIL_CNT, rs.getInt(4)); |
||||
if(rs.getTimestamp(5)!=null) { |
||||
u.put(Constant.BUI_KEY_LAST_LOGIN, rs.getTimestamp(5)); |
||||
} |
||||
} else { |
||||
return null; |
||||
} |
||||
} |
||||
} |
||||
} catch (SQLException e) { |
||||
log.error(e.getMessage(), e); |
||||
return null; |
||||
} |
||||
return u; |
||||
} |
||||
|
||||
public void updateLastLogin(int userId) { |
||||
try( |
||||
Connection conn = getConnection(); |
||||
PreparedStatement pstmt = conn.prepareStatement("UPDATE user SET pwd_err_cnt = 0, last_login=NOW() WHERE user_id = ?") |
||||
){ |
||||
pstmt.setInt(1, userId); |
||||
pstmt.executeUpdate(); |
||||
}catch(SQLException e) { |
||||
log.error(e.getMessage(), e); |
||||
} |
||||
|
||||
} |
||||
|
||||
public void updateLoginFailedCount(int userId) { |
||||
try( |
||||
Connection conn = getConnection(); |
||||
PreparedStatement pstmt = conn.prepareStatement("UPDATE user SET pwd_err_cnt = nvl(pwd_err_cnt,0) + 1 WHERE user_id = ?") |
||||
){ |
||||
pstmt.setInt(1, userId); |
||||
pstmt.executeUpdate(); |
||||
}catch(SQLException e) { |
||||
log.error(e.getMessage(), e); |
||||
} |
||||
} |
||||
|
||||
public void lockUser(int userId) { |
||||
try( |
||||
Connection conn = getConnection(); |
||||
PreparedStatement pstmt = conn.prepareStatement("UPDATE user SET password = concat('!!',password) WHERE user_id = ? AND password NOT LIKE '!!%'") |
||||
){ |
||||
pstmt.setInt(1, userId); |
||||
pstmt.executeUpdate(); |
||||
|
||||
}catch(SQLException e) { |
||||
log.error(e.getMessage(), e); |
||||
} |
||||
|
||||
} |
||||
} |
||||
@ -1,5 +1,42 @@
|
||||
package org.leolo.web.dm.model; |
||||
|
||||
import java.util.HashSet; |
||||
import java.util.Set; |
||||
|
||||
public class User { |
||||
|
||||
private String userName; |
||||
private int userId; |
||||
private String password; |
||||
|
||||
private Set<String> roles = new HashSet<>(); |
||||
|
||||
public String getUserName() { |
||||
return userName; |
||||
} |
||||
|
||||
public void setUserName(String userName) { |
||||
this.userName = userName; |
||||
} |
||||
|
||||
public int getUserId() { |
||||
return userId; |
||||
} |
||||
|
||||
public void setUserId(int userId) { |
||||
this.userId = userId; |
||||
} |
||||
|
||||
public String getPassword() { |
||||
return password; |
||||
} |
||||
|
||||
public void setPassword(String password) { |
||||
this.password = password; |
||||
} |
||||
|
||||
public Set<String> getRoles() { |
||||
return roles; |
||||
} |
||||
|
||||
} |
||||
|
||||
@ -0,0 +1,103 @@
|
||||
package org.leolo.web.dm.servlet; |
||||
|
||||
import java.io.IOException; |
||||
import java.util.Date; |
||||
import java.util.Map; |
||||
|
||||
import javax.servlet.ServletException; |
||||
import javax.servlet.annotation.WebServlet; |
||||
import javax.servlet.http.HttpServlet; |
||||
import javax.servlet.http.HttpServletRequest; |
||||
import javax.servlet.http.HttpServletResponse; |
||||
|
||||
import org.json.JSONObject; |
||||
import org.leolo.web.dm.Constant; |
||||
import org.leolo.web.dm.dao.SystemParameterDao; |
||||
import org.leolo.web.dm.dao.UserDao; |
||||
import org.leolo.web.dm.util.CommonUtil; |
||||
import org.leolo.web.dm.util.QueuedJobs; |
||||
import org.leolo.web.dm.util.ServletUtil; |
||||
import org.slf4j.Logger; |
||||
import org.slf4j.LoggerFactory; |
||||
import org.slf4j.Marker; |
||||
import org.slf4j.MarkerFactory; |
||||
|
||||
import at.favre.lib.crypto.bcrypt.BCrypt; |
||||
|
||||
/** |
||||
* Servlet implementation class LoginServlet |
||||
*/ |
||||
@WebServlet("/Login") |
||||
public class LoginServlet extends HttpServlet { |
||||
private static Logger log = LoggerFactory.getLogger(LoginServlet.class); |
||||
private static Marker mark = MarkerFactory.getMarker("user"); |
||||
private static final long serialVersionUID = 1L; |
||||
|
||||
/** |
||||
* @see HttpServlet#HttpServlet() |
||||
*/ |
||||
public LoginServlet() { |
||||
super(); |
||||
// TODO Auto-generated constructor stub
|
||||
} |
||||
|
||||
/** |
||||
* @see HttpServlet#doPost(HttpServletRequest request, HttpServletResponse response) |
||||
*/ |
||||
protected void doPost(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
||||
// TODO Auto-generated method stub
|
||||
UserDao udao = new UserDao(); |
||||
SystemParameterDao spdao = new SystemParameterDao(); |
||||
log.info("Login attempted! {}@{}:{}", request.getParameter("username"), request.getRemoteHost(), request.getParameter("password")); |
||||
Map<String, Object> bui = udao.getBasicUserInfoByUsernameWithPassword(request.getParameter("username")); |
||||
if(bui!=null) { |
||||
if(BCrypt.verifyer().verify(request.getParameter("password").toCharArray(), bui.get(Constant.BUI_KEY_PASSWORD).toString().toCharArray()).verified) { |
||||
log.info(mark, "User {}@{} logged in successfully!", bui.get(Constant.BUI_KEY_USER_NAME), ServletUtil.getClientIpAddr(request)); |
||||
request.getSession().setAttribute(Constant.SESSION_USER_ID, (int)bui.get(Constant.BUI_KEY_USER_ID)); |
||||
request.getSession().setAttribute(Constant.SESSION_USER_NAME, bui.get(Constant.BUI_KEY_USER_NAME)); |
||||
sendSuccessResponse(response, bui); |
||||
QueuedJobs.getInstance().queue(()->{ |
||||
udao.updateLastLogin((int)bui.get(Constant.BUI_KEY_USER_ID)); |
||||
}); |
||||
}else { |
||||
log.info(mark, "User {}@{} attempted to login![ICP/UL]", bui.get(Constant.BUI_KEY_USER_NAME), ServletUtil.getClientIpAddr(request)); |
||||
sendFailedResponse(response); |
||||
QueuedJobs.getInstance().queue(()->{ |
||||
udao.updateLoginFailedCount((int)bui.get(Constant.BUI_KEY_USER_ID)); |
||||
int failedCount = (int) bui.get(Constant.BUI_KEY_FAIL_CNT); |
||||
failedCount++; |
||||
if(failedCount >= spdao.getInt(Constant.SP_MAX_LOGIN_FAIL_CNT, 5)) { |
||||
//lock account
|
||||
udao.lockUser((int)bui.get(Constant.BUI_KEY_USER_ID)); |
||||
} |
||||
}); |
||||
} |
||||
}else { |
||||
//User does not exist!
|
||||
log.info(mark, "User {}@{} attempted to login![UNE]", request.getParameter("username"), ServletUtil.getClientIpAddr(request)); |
||||
BCrypt.withDefaults().hashToString(spdao.getInt(Constant.SP_BCRYPT_COST, 12), request.getParameter("password").toCharArray()); |
||||
sendFailedResponse(response); |
||||
} |
||||
} |
||||
|
||||
private void sendFailedResponse(HttpServletResponse response) throws IOException{ |
||||
response.setContentType("application/json"); |
||||
JSONObject obj = new JSONObject(); |
||||
obj.put("status", "failed"); |
||||
obj.put("message", "Username and/or password incorrect, or account is being locked."); |
||||
obj.write(response.getWriter()); |
||||
} |
||||
|
||||
private void sendSuccessResponse(HttpServletResponse response, Map<String, Object> bui) throws IOException{ |
||||
response.setContentType("application/json"); |
||||
JSONObject obj = new JSONObject(); |
||||
if(bui.get(Constant.BUI_KEY_LAST_LOGIN)!=null) { |
||||
obj.put("lastLogin", CommonUtil.formatDate((Date)bui.get(Constant.BUI_KEY_LAST_LOGIN))); |
||||
}else { |
||||
obj.put("lastLogin", (Object)null); |
||||
} |
||||
obj.put("status", "success"); |
||||
obj.write(response.getWriter()); |
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,49 @@
|
||||
package org.leolo.web.dm.servlet; |
||||
|
||||
import java.io.IOException; |
||||
import javax.servlet.ServletException; |
||||
import javax.servlet.annotation.WebServlet; |
||||
import javax.servlet.http.HttpServletRequest; |
||||
import javax.servlet.http.HttpServletResponse; |
||||
|
||||
import org.json.JSONObject; |
||||
import org.leolo.web.dm.Constant; |
||||
import org.leolo.web.dm.dao.SystemParameterDao; |
||||
|
||||
/** |
||||
* Servlet implementation class UserInfoServlet |
||||
*/ |
||||
@WebServlet("/UserInfo") |
||||
public class UserInfoServlet extends BaseServlet { |
||||
private static final long serialVersionUID = 1L; |
||||
|
||||
/** |
||||
* @see BaseServlet#BaseServlet() |
||||
*/ |
||||
public UserInfoServlet() { |
||||
super(); |
||||
// TODO Auto-generated constructor stub
|
||||
} |
||||
|
||||
/** |
||||
* @see HttpServlet#doGet(HttpServletRequest request, HttpServletResponse response) |
||||
*/ |
||||
protected void doGet(HttpServletRequest request, HttpServletResponse response) throws ServletException, IOException { |
||||
super.doGet(request, response); |
||||
if(this.fatalError) { |
||||
return; |
||||
} |
||||
response.setContentType("application/json"); |
||||
JSONObject obj = new JSONObject(); |
||||
obj.put("status", "success"); |
||||
obj.put("identified", this.userName!=null); |
||||
if(this.userName!=null) { |
||||
obj.put("username", this.userName); |
||||
obj.put("method", identifiedByKey?"api-key":"session"); |
||||
} |
||||
obj.put("system_name", new SystemParameterDao().getString(Constant.SP_SYSNAME)); |
||||
obj.put("api-version", Constant.SI_API_VERSION); |
||||
obj.write(response.getWriter()); |
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,12 @@
|
||||
package org.leolo.web.dm.util; |
||||
|
||||
import java.text.SimpleDateFormat; |
||||
import java.util.Date; |
||||
|
||||
public class CommonUtil { |
||||
|
||||
public static String formatDate(Date date) { |
||||
return new SimpleDateFormat("dd/MM/yyyy HH:mm:ss").format(date); |
||||
} |
||||
|
||||
} |
||||
@ -0,0 +1,28 @@
|
||||
package org.leolo.web.dm.util; |
||||
|
||||
import java.util.concurrent.ExecutorService; |
||||
import java.util.concurrent.Executors; |
||||
|
||||
import org.leolo.web.dm.Constant; |
||||
import org.leolo.web.dm.dao.SystemParameterDao; |
||||
|
||||
|
||||
public class QueuedJobs { |
||||
private static QueuedJobs instance; |
||||
private ExecutorService pool = Executors.newFixedThreadPool(new SystemParameterDao().getInt(Constant.SP_QUEUED_JOB_THREAD, 10)); |
||||
|
||||
public static synchronized QueuedJobs getInstance() { |
||||
if(instance==null) { |
||||
instance=new QueuedJobs(); |
||||
} |
||||
return instance; |
||||
} |
||||
|
||||
private QueuedJobs() { |
||||
|
||||
} |
||||
|
||||
public void queue(Runnable r) { |
||||
pool.execute(r); |
||||
} |
||||
} |
||||
@ -0,0 +1,25 @@
|
||||
package org.leolo.web.dm.util; |
||||
|
||||
import javax.servlet.http.HttpServletRequest; |
||||
|
||||
public class ServletUtil { |
||||
public static String getClientIpAddr(HttpServletRequest request) { |
||||
String ip = request.getHeader("X-Forwarded-For"); |
||||
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { |
||||
ip = request.getHeader("Proxy-Client-IP"); |
||||
} |
||||
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { |
||||
ip = request.getHeader("WL-Proxy-Client-IP"); |
||||
} |
||||
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { |
||||
ip = request.getHeader("HTTP_CLIENT_IP"); |
||||
} |
||||
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { |
||||
ip = request.getHeader("HTTP_X_FORWARDED_FOR"); |
||||
} |
||||
if (ip == null || ip.length() == 0 || "unknown".equalsIgnoreCase(ip)) { |
||||
ip = request.getRemoteAddr(); |
||||
} |
||||
return ip; |
||||
} |
||||
} |
||||