├── img
├── triumph_big1.jpg
├── triumph_big2.jpg
├── triumph_big3.jpg
└── triumph_thumb1.jpg
├── js
├── page.css
├── jquery.jqzoom.css
├── jquery.easing.1.3.js
├── jquery.lazyload.js
├── jquery.stellar.min.js
├── common.js
├── circlr.js
├── jquery.color.js
├── layer.js
├── jquery.jqzoom-core.js
└── jquery-ui.css
└── jquery插件 - 放大镜.html
/img/triumph_big1.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/charmlng/magnifier/HEAD/img/triumph_big1.jpg
--------------------------------------------------------------------------------
/img/triumph_big2.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/charmlng/magnifier/HEAD/img/triumph_big2.jpg
--------------------------------------------------------------------------------
/img/triumph_big3.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/charmlng/magnifier/HEAD/img/triumph_big3.jpg
--------------------------------------------------------------------------------
/img/triumph_thumb1.jpg:
--------------------------------------------------------------------------------
https://raw.githubusercontent.com/charmlng/magnifier/HEAD/img/triumph_thumb1.jpg
--------------------------------------------------------------------------------
/js/page.css:
--------------------------------------------------------------------------------
1 | body {
2 | background-color: #fff;
3 | padding-top: 50px;
4 | padding-bottom: 50px;
5 | }
6 |
7 | #circlr {
8 | cursor: move;
9 | margin: 0 auto;
10 | min-height: 100px;
11 | position: relative;
12 | }
13 |
14 | #circlr #loader {
15 | background: url(../images/loader.gif) center center no-repeat;
16 | bottom: 0;
17 | display: none;
18 | left: 0;
19 | position: absolute;
20 | right: 0;
21 | top: 0;
22 | }
23 |
--------------------------------------------------------------------------------
/jquery插件 - 放大镜.html:
--------------------------------------------------------------------------------
1 |
2 |
3 |
4 |
5 | jquery插件 - 放大镜
6 |
15 |
16 |
17 |
18 |
19 |
20 |
21 |
22 |
23 |
24 |
25 |
26 |
27 |
32 |
33 |
--------------------------------------------------------------------------------
/js/jquery.jqzoom.css:
--------------------------------------------------------------------------------
1 | .zoomPad{
2 | position:relative;
3 | float:left;
4 | z-index:99;
5 | cursor:crosshair;
6 | }
7 |
8 |
9 | .zoomPreload{
10 | -moz-opacity:0.8;
11 | opacity: 0.8;
12 | filter: alpha(opacity = 80);
13 | color: #333;
14 | font-size: 12px;
15 | font-family: Tahoma;
16 | text-decoration: none;
17 | border: 1px solid #CCC;
18 | background-color: white;
19 | padding: 8px;
20 | text-align:center;
21 | background-image: url(../images/zoomloader.gif);
22 | background-repeat: no-repeat;
23 | background-position: 43px 30px;
24 | z-index:110;
25 | width:90px;
26 | height:43px;
27 | position:absolute;
28 | top:0px;
29 | left:0px;
30 | * width:100px;
31 | * height:49px;
32 | }
33 |
34 |
35 | .zoomPup{
36 | overflow:hidden;
37 | background-color: #FFF;
38 | -moz-opacity:0.6;
39 | opacity: 0.6;
40 | filter: alpha(opacity = 60);
41 | z-index:120;
42 | position:absolute;
43 | border:1px solid #CCC;
44 | z-index:101;
45 | cursor:crosshair;
46 | }
47 |
48 | .zoomOverlay{
49 | position:absolute;
50 | left:0px;
51 | top:0px;
52 | background:#FFF;
53 | /*opacity:0.5;*/
54 | z-index:5000;
55 | width:100%;
56 | height:100%;
57 | display:none;
58 | z-index:101;
59 | }
60 |
61 | .zoomWindow{
62 | position:absolute;
63 | left:110%;
64 | top:40px;
65 | background:#FFF;
66 | z-index:6000;
67 | height:auto;
68 | z-index:10000;
69 | z-index:110;
70 | }
71 | .zoomWrapper{
72 | position:relative;
73 | border:1px solid #999;
74 | z-index:110;
75 | }
76 | .zoomWrapperTitle{
77 | /*display:block;
78 | background:#999;
79 | color:#FFF;
80 | height:18px;
81 | line-height:18px;
82 | width:100%;
83 | overflow:hidden;
84 | text-align:center;
85 | font-size:10px;
86 | position:absolute;
87 | top:0px;
88 | left:0px;
89 | z-index:120;
90 | -moz-opacity:0.6;
91 | opacity: 0.6;
92 | filter: alpha(opacity = 60);*/
93 | }
94 | .zoomWrapperImage{
95 | display:block;
96 | position:relative;
97 | overflow:hidden;
98 | z-index:110;
99 |
100 | }
101 | .zoomWrapperImage img{
102 | border:0px;
103 | display:block;
104 | position:absolute;
105 | z-index:101;
106 | }
107 |
108 | .zoomIframe{
109 | z-index: -1;
110 | filter:alpha(opacity=0);
111 | -moz-opacity: 0.80;
112 | opacity: 0.80;
113 | position:absolute;
114 | display:block;
115 | }
116 |
117 | /*********************************************************
118 | / When clicking on thumbs jqzoom will add the class
119 | / "zoomThumbActive" on the anchor selected
120 | /*********************************************************/
--------------------------------------------------------------------------------
/js/jquery.easing.1.3.js:
--------------------------------------------------------------------------------
1 | /*
2 | * jQuery Easing v1.3 - http://gsgd.co.uk/sandbox/jquery/easing/
3 | * Download by http://www.codefans.net
4 | * Uses the built in easing capabilities added In jQuery 1.1
5 | * to offer multiple easing options
6 | *
7 | * TERMS OF USE - jQuery Easing
8 | *
9 | * Open source under the BSD License.
10 | *
11 | * Copyright © 2008 George McGinley Smith
12 | * All rights reserved.
13 | *
14 | * Redistribution and use in source and binary forms, with or without modification,
15 | * are permitted provided that the following conditions are met:
16 | *
17 | * Redistributions of source code must retain the above copyright notice, this list of
18 | * conditions and the following disclaimer.
19 | * Redistributions in binary form must reproduce the above copyright notice, this list
20 | * of conditions and the following disclaimer in the documentation and/or other materials
21 | * provided with the distribution.
22 | *
23 | * Neither the name of the author nor the names of contributors may be used to endorse
24 | * or promote products derived from this software without specific prior written permission.
25 | * download by http://www.codefans.net
26 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
27 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
28 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
29 | * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
30 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
31 | * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
32 | * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
33 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
34 | * OF THE POSSIBILITY OF SUCH DAMAGE.
35 | *
36 | */
37 |
38 | // t: current time, b: begInnIng value, c: change In value, d: duration
39 | jQuery.easing['jswing'] = jQuery.easing['swing'];
40 |
41 | jQuery.extend( jQuery.easing,
42 | {
43 | def: 'easeOutQuad',
44 | swing: function (x, t, b, c, d) {
45 | //alert(jQuery.easing.default);
46 | return jQuery.easing[jQuery.easing.def](x, t, b, c, d);
47 | },
48 | easeInQuad: function (x, t, b, c, d) {
49 | return c*(t/=d)*t + b;
50 | },
51 | easeOutQuad: function (x, t, b, c, d) {
52 | return -c *(t/=d)*(t-2) + b;
53 | },
54 | easeInOutQuad: function (x, t, b, c, d) {
55 | if ((t/=d/2) < 1) return c/2*t*t + b;
56 | return -c/2 * ((--t)*(t-2) - 1) + b;
57 | },
58 | easeInCubic: function (x, t, b, c, d) {
59 | return c*(t/=d)*t*t + b;
60 | },
61 | easeOutCubic: function (x, t, b, c, d) {
62 | return c*((t=t/d-1)*t*t + 1) + b;
63 | },
64 | easeInOutCubic: function (x, t, b, c, d) {
65 | if ((t/=d/2) < 1) return c/2*t*t*t + b;
66 | return c/2*((t-=2)*t*t + 2) + b;
67 | },
68 | easeInQuart: function (x, t, b, c, d) {
69 | return c*(t/=d)*t*t*t + b;
70 | },
71 | easeOutQuart: function (x, t, b, c, d) {
72 | return -c * ((t=t/d-1)*t*t*t - 1) + b;
73 | },
74 | easeInOutQuart: function (x, t, b, c, d) {
75 | if ((t/=d/2) < 1) return c/2*t*t*t*t + b;
76 | return -c/2 * ((t-=2)*t*t*t - 2) + b;
77 | },
78 | easeInQuint: function (x, t, b, c, d) {
79 | return c*(t/=d)*t*t*t*t + b;
80 | },
81 | easeOutQuint: function (x, t, b, c, d) {
82 | return c*((t=t/d-1)*t*t*t*t + 1) + b;
83 | },
84 | easeInOutQuint: function (x, t, b, c, d) {
85 | if ((t/=d/2) < 1) return c/2*t*t*t*t*t + b;
86 | return c/2*((t-=2)*t*t*t*t + 2) + b;
87 | },
88 | easeInSine: function (x, t, b, c, d) {
89 | return -c * Math.cos(t/d * (Math.PI/2)) + c + b;
90 | },
91 | easeOutSine: function (x, t, b, c, d) {
92 | return c * Math.sin(t/d * (Math.PI/2)) + b;
93 | },
94 | easeInOutSine: function (x, t, b, c, d) {
95 | return -c/2 * (Math.cos(Math.PI*t/d) - 1) + b;
96 | },
97 | easeInExpo: function (x, t, b, c, d) {
98 | return (t==0) ? b : c * Math.pow(2, 10 * (t/d - 1)) + b;
99 | },
100 | easeOutExpo: function (x, t, b, c, d) {
101 | return (t==d) ? b+c : c * (-Math.pow(2, -10 * t/d) + 1) + b;
102 | },
103 | easeInOutExpo: function (x, t, b, c, d) {
104 | if (t==0) return b;
105 | if (t==d) return b+c;
106 | if ((t/=d/2) < 1) return c/2 * Math.pow(2, 10 * (t - 1)) + b;
107 | return c/2 * (-Math.pow(2, -10 * --t) + 2) + b;
108 | },
109 | easeInCirc: function (x, t, b, c, d) {
110 | return -c * (Math.sqrt(1 - (t/=d)*t) - 1) + b;
111 | },
112 | easeOutCirc: function (x, t, b, c, d) {
113 | return c * Math.sqrt(1 - (t=t/d-1)*t) + b;
114 | },
115 | easeInOutCirc: function (x, t, b, c, d) {
116 | if ((t/=d/2) < 1) return -c/2 * (Math.sqrt(1 - t*t) - 1) + b;
117 | return c/2 * (Math.sqrt(1 - (t-=2)*t) + 1) + b;
118 | },
119 | easeInElastic: function (x, t, b, c, d) {
120 | var s=1.70158;var p=0;var a=c;
121 | if (t==0) return b; if ((t/=d)==1) return b+c; if (!p) p=d*.3;
122 | if (a < Math.abs(c)) { a=c; var s=p/4; }
123 | else var s = p/(2*Math.PI) * Math.asin (c/a);
124 | return -(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
125 | },
126 | easeOutElastic: function (x, t, b, c, d) {
127 | var s=1.70158;var p=0;var a=c;
128 | if (t==0) return b; if ((t/=d)==1) return b+c; if (!p) p=d*.3;
129 | if (a < Math.abs(c)) { a=c; var s=p/4; }
130 | else var s = p/(2*Math.PI) * Math.asin (c/a);
131 | return a*Math.pow(2,-10*t) * Math.sin( (t*d-s)*(2*Math.PI)/p ) + c + b;
132 | },
133 | easeInOutElastic: function (x, t, b, c, d) {
134 | var s=1.70158;var p=0;var a=c;
135 | if (t==0) return b; if ((t/=d/2)==2) return b+c; if (!p) p=d*(.3*1.5);
136 | if (a < Math.abs(c)) { a=c; var s=p/4; }
137 | else var s = p/(2*Math.PI) * Math.asin (c/a);
138 | if (t < 1) return -.5*(a*Math.pow(2,10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )) + b;
139 | return a*Math.pow(2,-10*(t-=1)) * Math.sin( (t*d-s)*(2*Math.PI)/p )*.5 + c + b;
140 | },
141 | easeInBack: function (x, t, b, c, d, s) {
142 | if (s == undefined) s = 1.70158;
143 | return c*(t/=d)*t*((s+1)*t - s) + b;
144 | },
145 | easeOutBack: function (x, t, b, c, d, s) {
146 | if (s == undefined) s = 1.70158;
147 | return c*((t=t/d-1)*t*((s+1)*t + s) + 1) + b;
148 | },
149 | easeInOutBack: function (x, t, b, c, d, s) {
150 | if (s == undefined) s = 1.70158;
151 | if ((t/=d/2) < 1) return c/2*(t*t*(((s*=(1.525))+1)*t - s)) + b;
152 | return c/2*((t-=2)*t*(((s*=(1.525))+1)*t + s) + 2) + b;
153 | },
154 | easeInBounce: function (x, t, b, c, d) {
155 | return c - jQuery.easing.easeOutBounce (x, d-t, 0, c, d) + b;
156 | },
157 | easeOutBounce: function (x, t, b, c, d) {
158 | if ((t/=d) < (1/2.75)) {
159 | return c*(7.5625*t*t) + b;
160 | } else if (t < (2/2.75)) {
161 | return c*(7.5625*(t-=(1.5/2.75))*t + .75) + b;
162 | } else if (t < (2.5/2.75)) {
163 | return c*(7.5625*(t-=(2.25/2.75))*t + .9375) + b;
164 | } else {
165 | return c*(7.5625*(t-=(2.625/2.75))*t + .984375) + b;
166 | }
167 | },
168 | easeInOutBounce: function (x, t, b, c, d) {
169 | if (t < d/2) return jQuery.easing.easeInBounce (x, t*2, 0, c, d) * .5 + b;
170 | return jQuery.easing.easeOutBounce (x, t*2-d, 0, c, d) * .5 + c*.5 + b;
171 | }
172 | });
173 |
174 | /*
175 | *
176 | * TERMS OF USE - EASING EQUATIONS
177 | *
178 | * Open source under the BSD License.
179 | *
180 | * Copyright © 2001 Robert Penner
181 | * All rights reserved.
182 | *
183 | * Redistribution and use in source and binary forms, with or without modification,
184 | * are permitted provided that the following conditions are met:
185 | *
186 | * Redistributions of source code must retain the above copyright notice, this list of
187 | * conditions and the following disclaimer.
188 | * Redistributions in binary form must reproduce the above copyright notice, this list
189 | * of conditions and the following disclaimer in the documentation and/or other materials
190 | * provided with the distribution.
191 | *
192 | * Neither the name of the author nor the names of contributors may be used to endorse
193 | * or promote products derived from this software without specific prior written permission.
194 | *
195 | * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS" AND ANY
196 | * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
197 | * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE
198 | * COPYRIGHT OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
199 | * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE
200 | * GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED
201 | * AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING
202 | * NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED
203 | * OF THE POSSIBILITY OF SUCH DAMAGE.
204 | *
205 | */
--------------------------------------------------------------------------------
/js/jquery.lazyload.js:
--------------------------------------------------------------------------------
1 | /*
2 | * Lazy Load - jQuery plugin for lazy loading images
3 | *
4 | * Copyright (c) 2007-2015 Mika Tuupola
5 | *
6 | * Licensed under the MIT license:
7 | * http://www.opensource.org/licenses/mit-license.php
8 | *
9 | * Project home:
10 | * http://www.appelsiini.net/projects/lazyload
11 | *
12 | * Version: 1.9.5
13 | *
14 | */
15 |
16 | (function($, window, document, undefined) {
17 | var $window = $(window);
18 |
19 | $.fn.lazyload = function(options) {
20 | var elements = this;
21 | var $container;
22 | var settings = {
23 | threshold : 0,
24 | failure_limit : 0,
25 | event : "scroll",
26 | effect : "show",
27 | container : window,
28 | data_attribute : "original",
29 | skip_invisible : false,
30 | appear : null,
31 | load : null,
32 | placeholder : ""
33 | };
34 |
35 | function update() {
36 | var counter = 0;
37 |
38 | elements.each(function() {
39 | var $this = $(this);
40 | if (settings.skip_invisible && !$this.is(":visible")) {
41 | return;
42 | }
43 | if ($.abovethetop(this, settings) ||
44 | $.leftofbegin(this, settings)) {
45 | /* Nothing. */
46 | } else if (!$.belowthefold(this, settings) &&
47 | !$.rightoffold(this, settings)) {
48 | $this.trigger("appear");
49 | /* if we found an image we'll load, reset the counter */
50 | counter = 0;
51 | } else {
52 | if (++counter > settings.failure_limit) {
53 | return false;
54 | }
55 | }
56 | });
57 |
58 | }
59 |
60 | if(options) {
61 | /* Maintain BC for a couple of versions. */
62 | if (undefined !== options.failurelimit) {
63 | options.failure_limit = options.failurelimit;
64 | delete options.failurelimit;
65 | }
66 | if (undefined !== options.effectspeed) {
67 | options.effect_speed = options.effectspeed;
68 | delete options.effectspeed;
69 | }
70 |
71 | $.extend(settings, options);
72 | }
73 |
74 | /* Cache container as jQuery as object. */
75 | $container = (settings.container === undefined ||
76 | settings.container === window) ? $window : $(settings.container);
77 |
78 | /* Fire one scroll event per scroll. Not one scroll event per image. */
79 | if (0 === settings.event.indexOf("scroll")) {
80 | $container.bind(settings.event, function() {
81 | return update();
82 | });
83 | }
84 |
85 | this.each(function() {
86 | var self = this;
87 | var $self = $(self);
88 |
89 | self.loaded = false;
90 |
91 | /* If no src attribute given use data:uri. */
92 | if ($self.attr("src") === undefined || $self.attr("src") === false) {
93 | if ($self.is("img")) {
94 | $self.attr("src", settings.placeholder);
95 | }
96 | }
97 |
98 | /* When appear is triggered load original image. */
99 | $self.one("appear", function() {
100 | if (!this.loaded) {
101 | if (settings.appear) {
102 | var elements_left = elements.length;
103 | settings.appear.call(self, elements_left, settings);
104 | }
105 | $("
")
106 | .bind("load", function() {
107 |
108 | var original = $self.attr("data-" + settings.data_attribute);
109 | $self.hide();
110 | if ($self.is("img")) {
111 | $self.attr("src", original);
112 | } else {
113 | $self.css("background-image", "url('" + original + "')");
114 | }
115 | $self[settings.effect](settings.effect_speed);
116 |
117 | self.loaded = true;
118 |
119 | /* Remove image from array so it is not looped next time. */
120 | var temp = $.grep(elements, function(element) {
121 | return !element.loaded;
122 | });
123 | elements = $(temp);
124 |
125 | if (settings.load) {
126 | var elements_left = elements.length;
127 | settings.load.call(self, elements_left, settings);
128 | }
129 | })
130 | .attr("src", $self.attr("data-" + settings.data_attribute));
131 | }
132 | });
133 |
134 | /* When wanted event is triggered load original image */
135 | /* by triggering appear. */
136 | if (0 !== settings.event.indexOf("scroll")) {
137 | $self.bind(settings.event, function() {
138 | if (!self.loaded) {
139 | $self.trigger("appear");
140 | }
141 | });
142 | }
143 | });
144 |
145 | /* Check if something appears when window is resized. */
146 | $window.bind("resize", function() {
147 | update();
148 | });
149 |
150 | /* With IOS5 force loading images when navigating with back button. */
151 | /* Non optimal workaround. */
152 | if ((/(?:iphone|ipod|ipad).*os 5/gi).test(navigator.appVersion)) {
153 | $window.bind("pageshow", function(event) {
154 | if (event.originalEvent && event.originalEvent.persisted) {
155 | elements.each(function() {
156 | $(this).trigger("appear");
157 | });
158 | }
159 | });
160 | }
161 |
162 | /* Force initial check if images should appear. */
163 | $(document).ready(function() {
164 | update();
165 | });
166 |
167 | return this;
168 | };
169 |
170 | /* Convenience methods in jQuery namespace. */
171 | /* Use as $.belowthefold(element, {threshold : 100, container : window}) */
172 |
173 | $.belowthefold = function(element, settings) {
174 | var fold;
175 |
176 | if (settings.container === undefined || settings.container === window) {
177 | fold = (window.innerHeight ? window.innerHeight : $window.height()) + $window.scrollTop();
178 | } else {
179 | fold = $(settings.container).offset().top + $(settings.container).height();
180 | }
181 |
182 | return fold <= $(element).offset().top - settings.threshold;
183 | };
184 |
185 | $.rightoffold = function(element, settings) {
186 | var fold;
187 |
188 | if (settings.container === undefined || settings.container === window) {
189 | fold = $window.width() + $window.scrollLeft();
190 | } else {
191 | fold = $(settings.container).offset().left + $(settings.container).width();
192 | }
193 |
194 | return fold <= $(element).offset().left - settings.threshold;
195 | };
196 |
197 | $.abovethetop = function(element, settings) {
198 | var fold;
199 |
200 | if (settings.container === undefined || settings.container === window) {
201 | fold = $window.scrollTop();
202 | } else {
203 | fold = $(settings.container).offset().top;
204 | }
205 |
206 | return fold >= $(element).offset().top + settings.threshold + $(element).height();
207 | };
208 |
209 | $.leftofbegin = function(element, settings) {
210 | var fold;
211 |
212 | if (settings.container === undefined || settings.container === window) {
213 | fold = $window.scrollLeft();
214 | } else {
215 | fold = $(settings.container).offset().left;
216 | }
217 |
218 | return fold >= $(element).offset().left + settings.threshold + $(element).width();
219 | };
220 |
221 | $.inviewport = function(element, settings) {
222 | return !$.rightoffold(element, settings) && !$.leftofbegin(element, settings) &&
223 | !$.belowthefold(element, settings) && !$.abovethetop(element, settings);
224 | };
225 |
226 | /* Custom selectors for your convenience. */
227 | /* Use as $("img:below-the-fold").something() or */
228 | /* $("img").filter(":below-the-fold").something() which is faster */
229 |
230 | $.extend($.expr[":"], {
231 | "below-the-fold" : function(a) { return $.belowthefold(a, {threshold : 0}); },
232 | "above-the-top" : function(a) { return !$.belowthefold(a, {threshold : 0}); },
233 | "right-of-screen": function(a) { return $.rightoffold(a, {threshold : 0}); },
234 | "left-of-screen" : function(a) { return !$.rightoffold(a, {threshold : 0}); },
235 | "in-viewport" : function(a) { return $.inviewport(a, {threshold : 0}); },
236 | /* Maintain BC for couple of versions. */
237 | "above-the-fold" : function(a) { return !$.belowthefold(a, {threshold : 0}); },
238 | "right-of-fold" : function(a) { return $.rightoffold(a, {threshold : 0}); },
239 | "left-of-fold" : function(a) { return !$.rightoffold(a, {threshold : 0}); }
240 | });
241 |
242 | })(jQuery, window, document);
243 |
--------------------------------------------------------------------------------
/js/jquery.stellar.min.js:
--------------------------------------------------------------------------------
1 | /*! Stellar.js v0.6.2 | Copyright 2014, Mark Dalgleish | http://markdalgleish.com/projects/stellar.js | http://markdalgleish.mit-license.org */
2 | !function(a,b,c,d){function e(b,c){this.element=b,this.options=a.extend({},g,c),this._defaults=g,this._name=f,this.init()}var f="stellar",g={scrollProperty:"scroll",positionProperty:"position",horizontalScrolling:!0,verticalScrolling:!0,horizontalOffset:0,verticalOffset:0,responsive:!1,parallaxBackgrounds:!0,parallaxElements:!0,hideDistantElements:!0,hideElement:function(a){a.hide()},showElement:function(a){a.show()}},h={scroll:{getLeft:function(a){return a.scrollLeft()},setLeft:function(a,b){a.scrollLeft(b)},getTop:function(a){return a.scrollTop()},setTop:function(a,b){a.scrollTop(b)}},position:{getLeft:function(a){return-1*parseInt(a.css("left"),10)},getTop:function(a){return-1*parseInt(a.css("top"),10)}},margin:{getLeft:function(a){return-1*parseInt(a.css("margin-left"),10)},getTop:function(a){return-1*parseInt(a.css("margin-top"),10)}},transform:{getLeft:function(a){var b=getComputedStyle(a[0])[k];return"none"!==b?-1*parseInt(b.match(/(-?[0-9]+)/g)[4],10):0},getTop:function(a){var b=getComputedStyle(a[0])[k];return"none"!==b?-1*parseInt(b.match(/(-?[0-9]+)/g)[5],10):0}}},i={position:{setLeft:function(a,b){a.css("left",b)},setTop:function(a,b){a.css("top",b)}},transform:{setPosition:function(a,b,c,d,e){a[0].style[k]="translate3d("+(b-c)+"px, "+(d-e)+"px, 0)"}}},j=function(){var b,c=/^(Moz|Webkit|Khtml|O|ms|Icab)(?=[A-Z])/,d=a("script")[0].style,e="";for(b in d)if(c.test(b)){e=b.match(c)[0];break}return"WebkitOpacity"in d&&(e="Webkit"),"KhtmlOpacity"in d&&(e="Khtml"),function(a){return e+(e.length>0?a.charAt(0).toUpperCase()+a.slice(1):a)}}(),k=j("transform"),l=a("",{style:"background:#fff"}).css("background-position-x")!==d,m=l?function(a,b,c){a.css({"background-position-x":b,"background-position-y":c})}:function(a,b,c){a.css("background-position",b+" "+c)},n=l?function(a){return[a.css("background-position-x"),a.css("background-position-y")]}:function(a){return a.css("background-position").split(" ")},o=b.requestAnimationFrame||b.webkitRequestAnimationFrame||b.mozRequestAnimationFrame||b.oRequestAnimationFrame||b.msRequestAnimationFrame||function(a){setTimeout(a,1e3/60)};e.prototype={init:function(){this.options.name=f+"_"+Math.floor(1e9*Math.random()),this._defineElements(),this._defineGetters(),this._defineSetters(),this._handleWindowLoadAndResize(),this._detectViewport(),this.refresh({firstLoad:!0}),"scroll"===this.options.scrollProperty?this._handleScrollEvent():this._startAnimationLoop()},_defineElements:function(){this.element===c.body&&(this.element=b),this.$scrollElement=a(this.element),this.$element=this.element===b?a("body"):this.$scrollElement,this.$viewportElement=this.options.viewportElement!==d?a(this.options.viewportElement):this.$scrollElement[0]===b||"scroll"===this.options.scrollProperty?this.$scrollElement:this.$scrollElement.parent()},_defineGetters:function(){var a=this,b=h[a.options.scrollProperty];this._getScrollLeft=function(){return b.getLeft(a.$scrollElement)},this._getScrollTop=function(){return b.getTop(a.$scrollElement)}},_defineSetters:function(){var b=this,c=h[b.options.scrollProperty],d=i[b.options.positionProperty],e=c.setLeft,f=c.setTop;this._setScrollLeft="function"==typeof e?function(a){e(b.$scrollElement,a)}:a.noop,this._setScrollTop="function"==typeof f?function(a){f(b.$scrollElement,a)}:a.noop,this._setPosition=d.setPosition||function(a,c,e,f,g){b.options.horizontalScrolling&&d.setLeft(a,c,e),b.options.verticalScrolling&&d.setTop(a,f,g)}},_handleWindowLoadAndResize:function(){var c=this,d=a(b);c.options.responsive&&d.bind("load."+this.name,function(){c.refresh()}),d.bind("resize."+this.name,function(){c._detectViewport(),c.options.responsive&&c.refresh()})},refresh:function(c){var d=this,e=d._getScrollLeft(),f=d._getScrollTop();c&&c.firstLoad||this._reset(),this._setScrollLeft(0),this._setScrollTop(0),this._setOffsets(),this._findParticles(),this._findBackgrounds(),c&&c.firstLoad&&/WebKit/.test(navigator.userAgent)&&a(b).load(function(){var a=d._getScrollLeft(),b=d._getScrollTop();d._setScrollLeft(a+1),d._setScrollTop(b+1),d._setScrollLeft(a),d._setScrollTop(b)}),this._setScrollLeft(e),this._setScrollTop(f)},_detectViewport:function(){var a=this.$viewportElement.offset(),b=null!==a&&a!==d;this.viewportWidth=this.$viewportElement.width(),this.viewportHeight=this.$viewportElement.height(),this.viewportOffsetTop=b?a.top:0,this.viewportOffsetLeft=b?a.left:0},_findParticles:function(){{var b=this;this._getScrollLeft(),this._getScrollTop()}if(this.particles!==d)for(var c=this.particles.length-1;c>=0;c--)this.particles[c].$element.data("stellar-elementIsActive",d);this.particles=[],this.options.parallaxElements&&this.$element.find("[data-stellar-ratio]").each(function(){var c,e,f,g,h,i,j,k,l,m=a(this),n=0,o=0,p=0,q=0;if(m.data("stellar-elementIsActive")){if(m.data("stellar-elementIsActive")!==this)return}else m.data("stellar-elementIsActive",this);b.options.showElement(m),m.data("stellar-startingLeft")?(m.css("left",m.data("stellar-startingLeft")),m.css("top",m.data("stellar-startingTop"))):(m.data("stellar-startingLeft",m.css("left")),m.data("stellar-startingTop",m.css("top"))),f=m.position().left,g=m.position().top,h="auto"===m.css("margin-left")?0:parseInt(m.css("margin-left"),10),i="auto"===m.css("margin-top")?0:parseInt(m.css("margin-top"),10),k=m.offset().left-h,l=m.offset().top-i,m.parents().each(function(){var b=a(this);return b.data("stellar-offset-parent")===!0?(n=p,o=q,j=b,!1):(p+=b.position().left,void(q+=b.position().top))}),c=m.data("stellar-horizontal-offset")!==d?m.data("stellar-horizontal-offset"):j!==d&&j.data("stellar-horizontal-offset")!==d?j.data("stellar-horizontal-offset"):b.horizontalOffset,e=m.data("stellar-vertical-offset")!==d?m.data("stellar-vertical-offset"):j!==d&&j.data("stellar-vertical-offset")!==d?j.data("stellar-vertical-offset"):b.verticalOffset,b.particles.push({$element:m,$offsetParent:j,isFixed:"fixed"===m.css("position"),horizontalOffset:c,verticalOffset:e,startingPositionLeft:f,startingPositionTop:g,startingOffsetLeft:k,startingOffsetTop:l,parentOffsetLeft:n,parentOffsetTop:o,stellarRatio:m.data("stellar-ratio")!==d?m.data("stellar-ratio"):1,width:m.outerWidth(!0),height:m.outerHeight(!0),isHidden:!1})})},_findBackgrounds:function(){var b,c=this,e=this._getScrollLeft(),f=this._getScrollTop();this.backgrounds=[],this.options.parallaxBackgrounds&&(b=this.$element.find("[data-stellar-background-ratio]"),this.$element.data("stellar-background-ratio")&&(b=b.add(this.$element)),b.each(function(){var b,g,h,i,j,k,l,o=a(this),p=n(o),q=0,r=0,s=0,t=0;if(o.data("stellar-backgroundIsActive")){if(o.data("stellar-backgroundIsActive")!==this)return}else o.data("stellar-backgroundIsActive",this);o.data("stellar-backgroundStartingLeft")?m(o,o.data("stellar-backgroundStartingLeft"),o.data("stellar-backgroundStartingTop")):(o.data("stellar-backgroundStartingLeft",p[0]),o.data("stellar-backgroundStartingTop",p[1])),h="auto"===o.css("margin-left")?0:parseInt(o.css("margin-left"),10),i="auto"===o.css("margin-top")?0:parseInt(o.css("margin-top"),10),j=o.offset().left-h-e,k=o.offset().top-i-f,o.parents().each(function(){var b=a(this);return b.data("stellar-offset-parent")===!0?(q=s,r=t,l=b,!1):(s+=b.position().left,void(t+=b.position().top))}),b=o.data("stellar-horizontal-offset")!==d?o.data("stellar-horizontal-offset"):l!==d&&l.data("stellar-horizontal-offset")!==d?l.data("stellar-horizontal-offset"):c.horizontalOffset,g=o.data("stellar-vertical-offset")!==d?o.data("stellar-vertical-offset"):l!==d&&l.data("stellar-vertical-offset")!==d?l.data("stellar-vertical-offset"):c.verticalOffset,c.backgrounds.push({$element:o,$offsetParent:l,isFixed:"fixed"===o.css("background-attachment"),horizontalOffset:b,verticalOffset:g,startingValueLeft:p[0],startingValueTop:p[1],startingBackgroundPositionLeft:isNaN(parseInt(p[0],10))?0:parseInt(p[0],10),startingBackgroundPositionTop:isNaN(parseInt(p[1],10))?0:parseInt(p[1],10),startingPositionLeft:o.position().left,startingPositionTop:o.position().top,startingOffsetLeft:j,startingOffsetTop:k,parentOffsetLeft:q,parentOffsetTop:r,stellarRatio:o.data("stellar-background-ratio")===d?1:o.data("stellar-background-ratio")})}))},_reset:function(){var a,b,c,d,e;for(e=this.particles.length-1;e>=0;e--)a=this.particles[e],b=a.$element.data("stellar-startingLeft"),c=a.$element.data("stellar-startingTop"),this._setPosition(a.$element,b,b,c,c),this.options.showElement(a.$element),a.$element.data("stellar-startingLeft",null).data("stellar-elementIsActive",null).data("stellar-backgroundIsActive",null);for(e=this.backgrounds.length-1;e>=0;e--)d=this.backgrounds[e],d.$element.data("stellar-backgroundStartingLeft",null).data("stellar-backgroundStartingTop",null),m(d.$element,d.startingValueLeft,d.startingValueTop)},destroy:function(){this._reset(),this.$scrollElement.unbind("resize."+this.name).unbind("scroll."+this.name),this._animationLoop=a.noop,a(b).unbind("load."+this.name).unbind("resize."+this.name)},_setOffsets:function(){var c=this,d=a(b);d.unbind("resize.horizontal-"+this.name).unbind("resize.vertical-"+this.name),"function"==typeof this.options.horizontalOffset?(this.horizontalOffset=this.options.horizontalOffset(),d.bind("resize.horizontal-"+this.name,function(){c.horizontalOffset=c.options.horizontalOffset()})):this.horizontalOffset=this.options.horizontalOffset,"function"==typeof this.options.verticalOffset?(this.verticalOffset=this.options.verticalOffset(),d.bind("resize.vertical-"+this.name,function(){c.verticalOffset=c.options.verticalOffset()})):this.verticalOffset=this.options.verticalOffset},_repositionElements:function(){var a,b,c,d,e,f,g,h,i,j,k=this._getScrollLeft(),l=this._getScrollTop(),n=!0,o=!0;if(this.currentScrollLeft!==k||this.currentScrollTop!==l||this.currentWidth!==this.viewportWidth||this.currentHeight!==this.viewportHeight){for(this.currentScrollLeft=k,this.currentScrollTop=l,this.currentWidth=this.viewportWidth,this.currentHeight=this.viewportHeight,j=this.particles.length-1;j>=0;j--)a=this.particles[j],b=a.isFixed?1:0,this.options.horizontalScrolling?(f=(k+a.horizontalOffset+this.viewportOffsetLeft+a.startingPositionLeft-a.startingOffsetLeft+a.parentOffsetLeft)*-(a.stellarRatio+b-1)+a.startingPositionLeft,h=f-a.startingPositionLeft+a.startingOffsetLeft):(f=a.startingPositionLeft,h=a.startingOffsetLeft),this.options.verticalScrolling?(g=(l+a.verticalOffset+this.viewportOffsetTop+a.startingPositionTop-a.startingOffsetTop+a.parentOffsetTop)*-(a.stellarRatio+b-1)+a.startingPositionTop,i=g-a.startingPositionTop+a.startingOffsetTop):(g=a.startingPositionTop,i=a.startingOffsetTop),this.options.hideDistantElements&&(o=!this.options.horizontalScrolling||h+a.width>(a.isFixed?0:k)&&h<(a.isFixed?0:k)+this.viewportWidth+this.viewportOffsetLeft,n=!this.options.verticalScrolling||i+a.height>(a.isFixed?0:l)&&i<(a.isFixed?0:l)+this.viewportHeight+this.viewportOffsetTop),o&&n?(a.isHidden&&(this.options.showElement(a.$element),a.isHidden=!1),this._setPosition(a.$element,f,a.startingPositionLeft,g,a.startingPositionTop)):a.isHidden||(this.options.hideElement(a.$element),a.isHidden=!0);for(j=this.backgrounds.length-1;j>=0;j--)c=this.backgrounds[j],b=c.isFixed?0:1,d=this.options.horizontalScrolling?(k+c.horizontalOffset-this.viewportOffsetLeft-c.startingOffsetLeft+c.parentOffsetLeft-c.startingBackgroundPositionLeft)*(b-c.stellarRatio)+"px":c.startingValueLeft,e=this.options.verticalScrolling?(l+c.verticalOffset-this.viewportOffsetTop-c.startingOffsetTop+c.parentOffsetTop-c.startingBackgroundPositionTop)*(b-c.stellarRatio)+"px":c.startingValueTop,m(c.$element,d,e)}},_handleScrollEvent:function(){var a=this,b=!1,c=function(){a._repositionElements(),b=!1},d=function(){b||(o(c),b=!0)};this.$scrollElement.bind("scroll."+this.name,d),d()},_startAnimationLoop:function(){var a=this;this._animationLoop=function(){o(a._animationLoop),a._repositionElements()},this._animationLoop()}},a.fn[f]=function(b){var c=arguments;return b===d||"object"==typeof b?this.each(function(){a.data(this,"plugin_"+f)||a.data(this,"plugin_"+f,new e(this,b))}):"string"==typeof b&&"_"!==b[0]&&"init"!==b?this.each(function(){var d=a.data(this,"plugin_"+f);d instanceof e&&"function"==typeof d[b]&&d[b].apply(d,Array.prototype.slice.call(c,1)),"destroy"===b&&a.data(this,"plugin_"+f,null)}):void 0},a[f]=function(){var c=a(b);return c.stellar.apply(c,Array.prototype.slice.call(arguments,0))},a[f].scrollProperty=h,a[f].positionProperty=i,b.Stellar=e}(jQuery,this,document);
--------------------------------------------------------------------------------
/js/common.js:
--------------------------------------------------------------------------------
1 | function my$(id){
2 | return document.getElementById(id);
3 | }
4 |
5 | function my$byTagName(tagname){
6 | return document.getElementsByTagName(tagname);
7 | }
8 |
9 | //设置文本内容
10 | function setInnerText(element,text){
11 | //判断element.textContent属性是否存在,如果不存在,说明我们的浏览器不是ie8,我们就使用innerText属性
12 | if(element.textContent == "undefined") {
13 | element.innerText = text;
14 | }
15 | //如果element.textContent存在,说明是ie8,就用textContent属性
16 | else{
17 | element.textContent = text;
18 | }
19 | }
20 |
21 | function getInnerText(element){
22 | //判断element.textContent属性是否存在,如果不存在,说明我们的浏览器不是ie8,我们就使用innerText属性
23 | if(element.textContent == "undefined") {
24 | return element.innerText;
25 | }
26 | //如果element.textContent存在,说明是ie8,就用textContent属性
27 | else{
28 | return element.textContent;
29 | }
30 | }
31 |
32 | //获取样式的兼容性的写法
33 | function getStyle(obj,attr){
34 | //IE
35 | if(obj.currentStyle) {
36 | return obj.currentStyle[attr];
37 | }
38 | //谷歌火狐
39 | else{
40 | return getComputedStyle(obj,false)[attr];
41 | }
42 | }
43 |
44 | //设置样式
45 | function css(obj,attr,value){
46 | if(arguments.length == 2){
47 | return getStyle(obj,attr);
48 | }
49 | else if(arguments.length == 3){
50 | obj.style[attr] = value;
51 | }
52 | }
53 |
54 | //获取第一个元素节点
55 | function getFirstElementChild(element){
56 | //如果是火狐谷歌
57 | if(element.firstElementChild){
58 | return element.firstElementChild;
59 | }
60 | //ie 8
61 | else{
62 | var node = element.firstChild;
63 | while(node && node.nodeType!=1){
64 | node = node.nextSibling;
65 | }
66 | return node;
67 | }
68 | }
69 |
70 | //获取最后一个元素
71 | function getLastElementChild(element) {
72 | if(element.lastElementChild){//true--->支持
73 | return element.lastElementChild;
74 | }else{
75 | var node=element.lastChild;//第一个节点
76 | while (node&&node.nodeType!=1){
77 | node=node.previousSibling;
78 | }
79 | return node;
80 | }
81 | }
82 |
83 |
84 | //绑定事件的代码封装
85 | function addEventListener(element,type,fn){
86 | //如果有addEventListener这个方法,说明是谷歌、火狐、ie11
87 | if(element.addEventListener){
88 | element.addEventListener(type,fn,false);
89 | }
90 | //IE 8
91 | else if(element.attachEvent){
92 | element.attachEvent("on"+type,fn);
93 | }
94 | //正常情况
95 | else {
96 | element["on" + type] = fn;
97 | }
98 | }
99 |
100 | function removeEventListener(element,type,fn){
101 | //如果是火狐、谷歌、IE11
102 | if(element.removeEventListener){
103 | element.removeEventListener(type,fn,false);
104 | }
105 | else if(element.detachEvent){
106 | element.detachEvent("on"+type,fn);
107 | }
108 | else{
109 | element["on" + type] = null;
110 | }
111 | }
112 |
113 | //得到滚动出去的位置
114 | function getScroll(){
115 | var scrollTop = document.body.scrollTop||document.documentElement.scrollTop;
116 | var scrollLeft = document.body.scrollLeft||document.documentElement.scrollLeft;
117 | return {
118 | scrollTop:scrollTop,
119 | scrollLeft:scrollLeft
120 | }
121 | }
122 |
123 | //得到鼠标在页面中的位置
124 | function getPage(e){
125 | var oev = e||window.event;
126 | //pageX = 可视区的位置 + 左边滚动出去的位置
127 | var pageX = oev.clientX + getScroll().scrollLeft;
128 | var pageY = oev.clientY + getScroll().scrollTop;
129 | return {
130 | pageX:pageX,
131 | pageY:pageY
132 | }
133 | }
134 |
135 | //获取到url中的参数信息
136 | function getQuery(queryStr) {
137 | var query = {};
138 | if (queryStr.indexOf('?') > -1) {
139 | var index = queryStr.indexOf('?');
140 | queryStr = queryStr.substr(index + 1);
141 | var array = queryStr.split('&');
142 | for (var i = 0; i < array.length; i++) {
143 | var tmpArr = array[i].split('=');
144 | if (tmpArr.length === 2) {
145 | query[tmpArr[0]] = tmpArr[1];
146 | }
147 | }
148 | }
149 | return query;
150 | }
151 |
152 |
153 | //动画函数的初步封装
154 | function animate(element,target){
155 | //1.先获取原来的值
156 | var current = element.offsetLeft;
157 |
158 | //2.先判断定时器有没有,如果有了就先终止定时器,再去开定时器
159 | if(element.timeid){
160 | clearInterval(element.timeid);
161 | element.timeid = null;
162 | }
163 | //3.开启定时器
164 | element.timeid = setInterval(function(){
165 | var step = 10;
166 | //目标值是 10
167 | //当前值是 390
168 | if(target - current < 0){
169 | step = -step;
170 | }
171 |
172 | if(Math.abs(target - current) < Math.abs(step)){
173 | element.style.left = target + "px";
174 | clearInterval(element.timeid);
175 | return;
176 | }
177 |
178 | current += step;
179 | element.style.left = current + "px";
180 | },10);
181 | }
182 |
183 | // element 哪个元素需要动画
184 | // json 包含所有需要进行动画的属性 {"width": 400, "height": 500, "left": 500, "top": 80, "opacity": 0.2};
185 | // fn 动画完成之后回调函数
186 | function animate(element, json, fn) {
187 | clearInterval(element.timeId);//清理定时器
188 | //定时器,返回的是定时器的id
189 | element.timeId = setInterval(function () {
190 | var flag = true;//默认,假设,全部到达目标
191 | //遍历json对象中的每个属性还有属性对应的目标值
192 | for (var attr in json) {
193 | //判断这个属性attr中是不是opacity
194 | if (attr == "opacity") {
195 | //获取元素的当前的透明度,当前的透明度放大100倍
196 | var current = getStyle(element, attr) * 100;
197 | //目标的透明度放大100倍
198 | var target = json[attr] * 100;
199 | var step = (target - current) / 10;
200 |
201 | //8.5 ---> 9
202 | //-8.5 ---> -9
203 | step = step > 0 ? Math.ceil(step) : Math.floor(step);
204 | if (Math.abs(current - target) <= Math.abs(step)){
205 | // 让定时器停止
206 | // 让盒子到target的位置
207 | element.style[attr] = target / 100;
208 | }
209 | else{
210 | current += step;//移动后的值
211 | element.style[attr] = current / 100;
212 | }
213 | } else if (attr == "zIndex") { //判断这个属性attr中是不是zIndex
214 | //层级改变就是直接改变这个属性的值
215 | element.style[attr] = json[attr];
216 | } else {
217 | //普通的属性
218 | //获取元素这个属性的当前的值
219 | var current = Math.ceil(parseFloat(getStyle(element, attr)));
220 | //var current = parseInt(getStyle(element, attr));
221 | //当前的属性对应的目标值
222 | var target = json[attr];
223 | //移动的步数
224 | var step = (target - current) / 10;
225 | step = step > 0 ? Math.ceil(step) : Math.floor(step);
226 | if (Math.abs(current - target) <= Math.abs(step)){
227 | // 让定时器停止
228 | // 让盒子到target的位置
229 | element.style[attr] = target + 'px';
230 | }
231 | else{
232 | current += step;//移动后的值
233 | element.style[attr] = current + "px";
234 | }
235 | }
236 | //测试代码
237 | //console.log("目标:" + target + ",当前:" + current + ",每次的移动步数:" + step);
238 | //是否到达目标
239 | if (current != target) {
240 | flag = false;
241 | }
242 | }
243 | if (flag) {
244 | //清理定时器
245 | clearInterval(element.timeId);
246 | //所有的属性到达目标才能使用这个函数,前提是用户传入了这个函数
247 | if (fn) {
248 | fn();
249 | }
250 | }
251 | }, 20);
252 | }
253 |
254 |
255 | //得到浏览器的若干信息
256 | function getUserAgent(){
257 | var browser = {
258 | versions: function() {
259 | var u = navigator.userAgent, app = navigator.appVersion;
260 | return { //移动终端浏览器版本信息
261 | trident: u.indexOf('Trident') > -1, //IE内核
262 | presto: u.indexOf('Presto') > -1, //opera内核
263 | webKit: u.indexOf('AppleWebKit') > -1, //苹果、谷歌内核
264 | gecko: u.indexOf('Gecko') > -1 && u.indexOf('KHTML') == -1, //火狐内核
265 | mobile: !!u.match(/AppleWebKit.*Mobile.*/), //是否为移动终端
266 | ios: !!u.match(/\(i[^;]+;( U;)? CPU.+Mac OS X/), //ios终端
267 | android: u.indexOf('Android') > -1 || u.indexOf('Linux') > -1, //android终端或uc浏览器
268 | iPhone: u.indexOf('iPhone') > -1, //是否为iPhone或者QQHD浏览器
269 | iPad: u.indexOf('iPad') > -1, //是否iPad
270 | webApp: u.indexOf('Safari') == -1 //是否web应该程序,没有头部与底部
271 | };
272 | } (),
273 | language: (navigator.browserLanguage || navigator.language).toLowerCase()
274 | }
275 | return browser;
276 | }
277 |
278 | function getDates(dt) {
279 | var str = "";//存储时间的字符串
280 | //获取年
281 | var year = dt.getFullYear();
282 | //获取月
283 | var month = dt.getMonth() + 1;
284 | //获取日
285 | var day = dt.getDate();
286 | //获取小时
287 | var hour = dt.getHours();
288 | //获取分钟
289 | var min = dt.getMinutes();
290 | //获取秒
291 | var sec = dt.getSeconds();
292 | month = month < 10 ? "0" + month : month;
293 | day = day < 10 ? "0" + day : day;
294 | hour = hour < 10 ? "0" + hour : hour;
295 | min = min < 10 ? "0" + min : min;
296 | sec = sec < 10 ? "0" + sec : sec;
297 | str = year + "年" + month + "月" + day + "日 " + hour + ":" + min + ":" + sec;
298 | return str;
299 | }
300 |
301 |
302 | /**
303 | * 获取父级元素中的第一个子元素
304 | * @param element 父级元素
305 | * @returns {*} 父级元素中的子级元素
306 | */
307 | function getFirstElement(element) {
308 | if (element.firstElementChild) {
309 | return element.firstElementChild;
310 | } else {
311 | var node = element.firstChild;
312 | while (node && node.nodeType != 1) {
313 | node = node.nextSibling;
314 | }
315 | return node;
316 | }
317 | }
318 | /**
319 | * 获取父级元素中的最后一个子元素
320 | * @param element 父级元素
321 | * @returns {*} 最后一个子元素
322 | */
323 | function getLastElement(element) {
324 | if (element.lastElementChild) {
325 | return element.lastElementChild;
326 | } else {
327 | var node = element.lastChild;
328 | while (node && node.nodeType != 1) {
329 | node = node.previousSibling;
330 | }
331 | return node;
332 | }
333 | }
334 | /**
335 | * 获取某个元素的前一个兄弟元素
336 | * @param element 某个元素
337 | * @returns {*} 前一个兄弟元素
338 | */
339 | function getPreviousElement(element) {
340 | if (element.previousElementSibling) {
341 | return element.previousElementSibling
342 | } else {
343 | var node = element.previousSibling;
344 | while (node && node.nodeType != 1) {
345 | node = node.previousSibling;
346 | }
347 | return node;
348 | }
349 | }
350 | /**
351 | * 获取某个元素的后一个兄弟元素
352 | * @param element 某个元素
353 | * @returns {*} 后一个兄弟元素
354 | */
355 | function getNextElement(element) {
356 | if (element.nextElementSibling) {
357 | return element.nextElementSibling
358 | } else {
359 | var node = element.nextSibling;
360 | while (node && node.nodeType != 1) {
361 | node = node.nextSibling;
362 | }
363 | return node;
364 | }
365 | }
366 |
367 | /**
368 | * 获取某个元素的所有兄弟元素
369 | * @param element 某个元素
370 | * @returns {Array} 兄弟元素
371 | */
372 | function getSiblings(element) {
373 | if (!element)return;
374 | var elements = [];
375 | var ele = element.previousSibling;
376 | while (ele) {
377 | if (ele.nodeType === 1) {
378 | elements.push(ele);
379 | }
380 | ele = ele.previousSibling;
381 | }
382 | ele = element.nextSibling;
383 | while (ele) {
384 | if (ele.nodeType === 1) {
385 | elements.push(ele);
386 |
387 | }
388 | ele = ele.nextSibling;
389 | }
390 | return elements;
391 | }
--------------------------------------------------------------------------------
/js/circlr.js:
--------------------------------------------------------------------------------
1 | // Circlr © 2014-2015 Andrey Polischuk
2 | // github.com/andrepolischuk/circlr
3 |
4 | !function() {
5 |
6 | 'use strict';
7 |
8 | /**
9 | * Mutable parameters
10 | */
11 |
12 | var mutable = [
13 | 'vertical',
14 | 'reverse',
15 | 'cycle',
16 | 'speed',
17 | 'playSpeed'
18 | ];
19 |
20 | /**
21 | * Initialize module
22 | * @param {Object} el
23 | * @param {Object} options
24 | */
25 |
26 | function Circlr(options) {
27 |
28 | /**
29 | * Mouse events enabled
30 | */
31 |
32 | options.mouse = options.mouse || true;
33 |
34 | /**
35 | * Scroll events enabled
36 | */
37 |
38 | options.scroll = options.scroll || false;
39 |
40 | /**
41 | * Orientation
42 | */
43 |
44 | options.vertical = options.vertical || false;
45 |
46 | /**
47 | * Turning reverse
48 | */
49 |
50 | options.reverse = options.reverse || false;
51 |
52 | /**
53 | * Turning cycle
54 | */
55 |
56 | options.cycle = options.cycle || true;
57 |
58 | /**
59 | * Start frame
60 | */
61 |
62 | options.start = options.start || 0;
63 |
64 | /**
65 | * Turn speed (ms)
66 | */
67 |
68 | options.speed = options.speed || 50;
69 |
70 | /**
71 | * Autoplay
72 | */
73 |
74 | var autoplay = options.autoplay || false;
75 |
76 | /**
77 | * Play speed (ms)
78 | */
79 |
80 | options.playSpeed = options.playSpeed || 100;
81 |
82 | /**
83 | * DOM element
84 | */
85 |
86 | var el = this.el = options.element;
87 |
88 | /**
89 | * Exclude duplication
90 | */
91 |
92 | el.setAttribute('data-circlr', true);
93 |
94 | /**
95 | * DOM loader
96 | */
97 |
98 | var loader = options.loader ? document.getElementById(options.loader) : undefined;
99 |
100 | /**
101 | * Frames length
102 | */
103 |
104 | var length = this.length = el.getElementsByTagName('img').length;
105 |
106 | /**
107 | * Frames area height
108 | */
109 |
110 | var height = options.height || undefined;
111 |
112 | /**
113 | * Frames area width
114 | */
115 |
116 | var width = options.width || undefined;
117 |
118 | /**
119 | * Move enable
120 | */
121 |
122 | var movable = false;
123 |
124 | /**
125 | * Loaded images length
126 | */
127 |
128 | var loaded = [];
129 |
130 | /**
131 | * Not loaded length
132 | */
133 |
134 | var errored = [];
135 |
136 | /**
137 | * Current frame
138 | */
139 |
140 | var current;
141 |
142 | /**
143 | * Prevous options
144 | */
145 |
146 | var pre = {};
147 |
148 | pre.Y = null;
149 | pre.X = null;
150 | pre.frame = 0;
151 |
152 | /**
153 | * Callbacks
154 | */
155 |
156 | var callbacks = {};
157 |
158 | // all images loaded callback
159 | callbacks.ready = options.ready || undefined;
160 |
161 | // turn callback
162 | callbacks.change = options.change || undefined;
163 |
164 | /**
165 | * Scroll events
166 | */
167 |
168 | var scrollEvents = [
169 | 'wheel',
170 | 'mousewheel',
171 | 'scroll',
172 | 'DOMMouseScroll'
173 | ];
174 |
175 | /**
176 | * Add event listener
177 | * @param {Object} target
178 | * @param {String} event
179 | * @param {Function} fn
180 | * @api private
181 | */
182 |
183 | function onEventListener(target, event, fn) {
184 |
185 | if (target.addEventListener) {
186 | target.addEventListener(event, fn, false);
187 | } else {
188 | target.attachEvent('on' + event, function() {
189 | fn.call(target, window.event);
190 | });
191 | }
192 |
193 | }
194 |
195 | /**
196 | * Prevent default
197 | * @param {Object} e
198 | */
199 |
200 | function preventDefault(e) {
201 |
202 | if (e.preventDefault) {
203 | e.preventDefault();
204 | } else {
205 | e.returnValue = false;
206 | }
207 |
208 | }
209 |
210 | /**
211 | * Pre moving event
212 | * @param {Object} e
213 | * @api private
214 | */
215 |
216 | function preMove(e) {
217 |
218 | autoplay = false;
219 |
220 | preventDefault(e);
221 | e = e.type === 'touchstart' ? e.changedTouches[0] : e;
222 |
223 | movable = true;
224 |
225 | if (options.vertical) {
226 | pre.Y = e.clientY - el.offsetTop;
227 | } else {
228 | pre.X = e.clientX - el.offsetLeft;
229 | }
230 |
231 | }
232 |
233 | /**
234 | * Normalize current frame
235 | * @param {Number} cur
236 | * @return {Number}
237 | * @api private
238 | */
239 |
240 | function normalize(cur) {
241 |
242 | if (cur < 0) {
243 | cur = options.cycle ? cur + length : 0;
244 | } else if (cur > length - 1) {
245 | cur = options.cycle ? cur - length : length - 1;
246 | }
247 |
248 | return cur;
249 |
250 | }
251 |
252 | /**
253 | * Moving event
254 | * @param {Object} e
255 | * @api private
256 | */
257 |
258 | function isMove(e) {
259 |
260 | if (movable) {
261 |
262 | preventDefault(e);
263 | e = e.type === 'touchmove' ? e.changedTouches[0] : e;
264 |
265 | // current offset (px)
266 | var offset = (options.vertical) ? ((e.clientY - el.offsetTop) - pre.Y) : ((e.clientX - el.offsetLeft) - pre.X);
267 | offset = options.reverse ? -offset : offset;
268 |
269 | // frame step (px)
270 | var step = width / length;
271 |
272 | // prevous frame
273 | var previous = current;
274 |
275 | // current offset (frame)
276 | offset = Math.floor(offset / step);
277 |
278 | if (offset !== current) {
279 |
280 | current = normalize(pre.frame + offset);
281 |
282 | if (previous !== current) {
283 |
284 | // show current frame
285 | el.getElementsByTagName('img')[previous].style.display = 'none';
286 | el.getElementsByTagName('img')[current].style.display = 'block';
287 |
288 | if (typeof callbacks.change === 'function') {
289 | callbacks.change(current, length);
290 | }
291 |
292 | }
293 |
294 | }
295 |
296 | }
297 |
298 | }
299 |
300 | /**
301 | * Post moving event
302 | * @param {Object} e
303 | * @api private
304 | */
305 |
306 | function stopMove(e) {
307 |
308 | preventDefault(e);
309 |
310 | movable = false;
311 | pre.frame = current;
312 |
313 | }
314 |
315 | /**
316 | * Moving via scroll
317 | * @param {Object} e
318 | * @api private
319 | */
320 |
321 | function scrollMove(e) {
322 |
323 | autoplay = false;
324 |
325 | preventDefault(e);
326 |
327 | // scroll delta
328 | var delta = e.deltaY || e.detail || (-e.wheelDelta);
329 | delta = delta / Math.abs(delta);
330 | delta = options.reverse ? -delta : delta;
331 |
332 | current = normalize(current + delta);
333 |
334 | // show current frame
335 | el.getElementsByTagName('img')[pre.frame].style.display = 'none';
336 | el.getElementsByTagName('img')[current].style.display = 'block';
337 |
338 | pre.frame = current;
339 |
340 | if (typeof callbacks.change === 'function') {
341 | callbacks.change(current, length);
342 | }
343 |
344 | }
345 |
346 | /**
347 | * Initialize events after success images loading
348 | * @api private
349 | */
350 |
351 | function initEvents() {
352 |
353 | // loader hide
354 | if (loader) {
355 | loader.style.display = 'none';
356 | }
357 |
358 | if (errored.length === 0) {
359 |
360 | var start = normalize(options.start);
361 |
362 | // all images loaded
363 | el.getElementsByTagName('img')[start].style.display = 'block';
364 | current = start;
365 |
366 | el.style.position = 'relative';
367 | el.style.width = '100%';
368 |
369 | if ('ontouchstart' in window || 'onmsgesturechange' in window) {
370 |
371 | if (options.mouse || options.scroll) {
372 | onEventListener(el, 'touchstart', preMove);
373 | onEventListener(el, 'touchmove', isMove);
374 | onEventListener(el, 'touchend', stopMove);
375 | }
376 |
377 | } else {
378 |
379 | if (options.mouse) {
380 | onEventListener(el, 'mousedown', preMove);
381 | onEventListener(el, 'mousemove', isMove);
382 | onEventListener(document, 'mouseup', stopMove);
383 | }
384 |
385 | if (options.scroll) {
386 | for (var e = 0; e < scrollEvents.length; e++) {
387 | if ('on' + scrollEvents[e] in window) {
388 | onEventListener(el, scrollEvents[e], scrollMove);
389 | break;
390 | }
391 | }
392 | }
393 |
394 | }
395 |
396 | if (autoplay) {
397 | play();
398 | }
399 |
400 | }
401 |
402 | if (typeof callbacks.ready === 'function') {
403 | callbacks.ready(errored);
404 | }
405 |
406 | }
407 |
408 | /**
409 | * Initialize images events
410 | * @param {Object} img
411 | */
412 |
413 | function loadImagesEvents(img) {
414 |
415 | img.onload = function() {
416 |
417 | loaded.push(this.src);
418 |
419 | // show first frame when all images loaded
420 | if (loaded.length + errored.length === length) {
421 | initEvents();
422 | }
423 |
424 | };
425 |
426 | img.onerror = function() {
427 |
428 | errored.push(this.src);
429 |
430 | // show first frame when images loaded
431 | if (loaded.length + errored.length === length) {
432 | initEvents();
433 | }
434 |
435 | };
436 |
437 | img.onreadystatechange = function() {
438 | this.onload();
439 | };
440 |
441 | }
442 |
443 | /**
444 | * Load Object images
445 | * @api private
446 | */
447 |
448 | function loadImages() {
449 |
450 | // adding elements
451 | var img;
452 |
453 | // show loader
454 | if (loader) {
455 | loader.style.display = 'block';
456 | }
457 |
458 | for (var i = 0; i < length; i++) {
459 |
460 | // get object
461 | img = el.getElementsByTagName('img')[i];
462 |
463 | // set object style
464 | img.style.display = 'none';
465 | img.style.width = '100%';
466 |
467 | // set object options
468 | img.setAttribute('src', img.getAttribute('data-src'));
469 | img.setAttribute('data-index', i);
470 | img.removeAttribute('data-src');
471 |
472 | loadImagesEvents(img);
473 |
474 | }
475 |
476 | // check elements sizes
477 | height = height || el.clientHeight;
478 | width = width || el.clientWidth;
479 |
480 | }
481 |
482 | /**
483 | * Initialize loading
484 | */
485 |
486 | loadImages();
487 |
488 | /**
489 | * Change current frame
490 | * @param {Number} i
491 | * @api private
492 | */
493 |
494 | function setFrame(i) {
495 |
496 | el.getElementsByTagName('img')[current].style.display = 'none';
497 | el.getElementsByTagName('img')[i].style.display = 'block';
498 |
499 | pre.frame = current = i;
500 |
501 | }
502 |
503 | /**
504 | * Turn to specific frame
505 | * @param {Number} i
506 | * @api public
507 | */
508 |
509 | var turn = this.turn = function(i) {
510 |
511 | i = normalize(i);
512 | autoplay = true;
513 |
514 | (function turnInterval() {
515 |
516 | if (i !== current && autoplay) {
517 |
518 | setFrame(normalize(i < current ? current - 1 : current + 1));
519 | setTimeout(turnInterval, typeof i === 'undefined' ? options.playSpeed : options.speed);
520 |
521 | } else if (i === current) {
522 |
523 | pre.frame = current = i;
524 | autoplay = false;
525 |
526 | if (typeof callbacks.change === 'function') {
527 | callbacks.change(current, length);
528 | }
529 |
530 | }
531 |
532 | })();
533 |
534 | };
535 |
536 | /**
537 | * Go to specific frame
538 | * @param {Number} i
539 | * @api public
540 | */
541 |
542 | this.go = function(i) {
543 |
544 | if (i !== current) {
545 |
546 | setFrame(i);
547 |
548 | if (typeof callbacks.change === 'function') {
549 | callbacks.change(current, length);
550 | }
551 |
552 | }
553 |
554 | };
555 |
556 | /**
557 | * Play sequence
558 | * @api public
559 | */
560 |
561 | var play = this.play = function() {
562 | autoplay = true;
563 | turn();
564 | };
565 |
566 | /**
567 | * Stop sequence playng
568 | * @api public
569 | */
570 |
571 | this.stop = function() {
572 | autoplay = false;
573 | };
574 |
575 | /**
576 | * Show object
577 | * @api public
578 | */
579 |
580 | this.show = function() {
581 | el.style.display = 'block';
582 | };
583 |
584 | /**
585 | * Hide object
586 | * @api public
587 | */
588 |
589 | this.hide = function() {
590 | el.style.display = 'none';
591 | };
592 |
593 | /**
594 | * Change Object options
595 | * @param {Object} options
596 | * @api public
597 | */
598 |
599 | this.set = function(set) {
600 | for (var i = 0, key; i < mutable.length; i++) {
601 | key = mutable[i];
602 | options[key] = typeof set[key] !== 'undefined' ? set[key] : options[key];
603 | }
604 | };
605 |
606 | }
607 |
608 | /**
609 | * Example creator
610 | */
611 |
612 | function Creator(element, options) {
613 |
614 | element = document.getElementById(element);
615 |
616 | if (element.getAttribute('data-circlr')) {
617 | return;
618 | }
619 |
620 | options = options || {};
621 | options.element = element;
622 |
623 | return new Circlr(options);
624 |
625 | }
626 |
627 | /**
628 | * Module exports
629 | */
630 |
631 | if (typeof define === 'function' && define.amd) {
632 |
633 | define([], function() {
634 | return Creator;
635 | });
636 |
637 | } else if (typeof module !== 'undefined' && module.exports) {
638 |
639 | module.exports = Creator;
640 |
641 | } else {
642 |
643 | this.circlr = Creator;
644 |
645 | }
646 |
647 | }.call(this);
648 |
--------------------------------------------------------------------------------
/js/jquery.color.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * jQuery Color Animations v@VERSION
3 | * https://github.com/jquery/jquery-color
4 | *
5 | * Copyright jQuery Foundation and other contributors
6 | * Released under the MIT license.
7 | * http://jquery.org/license
8 | *
9 | * Date: @DATE
10 | */
11 | (function( jQuery, undefined ) {
12 |
13 | var stepHooks = "backgroundColor borderBottomColor borderLeftColor borderRightColor borderTopColor color columnRuleColor outlineColor textDecorationColor textEmphasisColor",
14 |
15 | // plusequals test for += 100 -= 100
16 | rplusequals = /^([\-+])=\s*(\d+\.?\d*)/,
17 | // a set of RE's that can match strings and generate color tuples.
18 | stringParsers = [{
19 | re: /rgba?\(\s*(\d{1,3})\s*,\s*(\d{1,3})\s*,\s*(\d{1,3})\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
20 | parse: function( execResult ) {
21 | return [
22 | execResult[ 1 ],
23 | execResult[ 2 ],
24 | execResult[ 3 ],
25 | execResult[ 4 ]
26 | ];
27 | }
28 | }, {
29 | re: /rgba?\(\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
30 | parse: function( execResult ) {
31 | return [
32 | execResult[ 1 ] * 2.55,
33 | execResult[ 2 ] * 2.55,
34 | execResult[ 3 ] * 2.55,
35 | execResult[ 4 ]
36 | ];
37 | }
38 | }, {
39 | // this regex ignores A-F because it's compared against an already lowercased string
40 | re: /#([a-f0-9]{2})([a-f0-9]{2})([a-f0-9]{2})/,
41 | parse: function( execResult ) {
42 | return [
43 | parseInt( execResult[ 1 ], 16 ),
44 | parseInt( execResult[ 2 ], 16 ),
45 | parseInt( execResult[ 3 ], 16 )
46 | ];
47 | }
48 | }, {
49 | // this regex ignores A-F because it's compared against an already lowercased string
50 | re: /#([a-f0-9])([a-f0-9])([a-f0-9])/,
51 | parse: function( execResult ) {
52 | return [
53 | parseInt( execResult[ 1 ] + execResult[ 1 ], 16 ),
54 | parseInt( execResult[ 2 ] + execResult[ 2 ], 16 ),
55 | parseInt( execResult[ 3 ] + execResult[ 3 ], 16 )
56 | ];
57 | }
58 | }, {
59 | re: /hsla?\(\s*(\d+(?:\.\d+)?)\s*,\s*(\d+(?:\.\d+)?)\%\s*,\s*(\d+(?:\.\d+)?)\%\s*(?:,\s*(\d?(?:\.\d+)?)\s*)?\)/,
60 | space: "hsla",
61 | parse: function( execResult ) {
62 | return [
63 | execResult[ 1 ],
64 | execResult[ 2 ] / 100,
65 | execResult[ 3 ] / 100,
66 | execResult[ 4 ]
67 | ];
68 | }
69 | }],
70 |
71 | // jQuery.Color( )
72 | color = jQuery.Color = function( color, green, blue, alpha ) {
73 | return new jQuery.Color.fn.parse( color, green, blue, alpha );
74 | },
75 | spaces = {
76 | rgba: {
77 | props: {
78 | red: {
79 | idx: 0,
80 | type: "byte"
81 | },
82 | green: {
83 | idx: 1,
84 | type: "byte"
85 | },
86 | blue: {
87 | idx: 2,
88 | type: "byte"
89 | }
90 | }
91 | },
92 |
93 | hsla: {
94 | props: {
95 | hue: {
96 | idx: 0,
97 | type: "degrees"
98 | },
99 | saturation: {
100 | idx: 1,
101 | type: "percent"
102 | },
103 | lightness: {
104 | idx: 2,
105 | type: "percent"
106 | }
107 | }
108 | }
109 | },
110 | propTypes = {
111 | "byte": {
112 | floor: true,
113 | max: 255
114 | },
115 | "percent": {
116 | max: 1
117 | },
118 | "degrees": {
119 | mod: 360,
120 | floor: true
121 | }
122 | },
123 | support = color.support = {},
124 |
125 | // element for support tests
126 | supportElem = jQuery( "" )[ 0 ],
127 |
128 | // colors = jQuery.Color.names
129 | colors,
130 |
131 | // local aliases of functions called often
132 | each = jQuery.each;
133 |
134 | // determine rgba support immediately
135 | supportElem.style.cssText = "background-color:rgba(1,1,1,.5)";
136 | support.rgba = supportElem.style.backgroundColor.indexOf( "rgba" ) > -1;
137 |
138 | // define cache name and alpha properties
139 | // for rgba and hsla spaces
140 | each( spaces, function( spaceName, space ) {
141 | space.cache = "_" + spaceName;
142 | space.props.alpha = {
143 | idx: 3,
144 | type: "percent",
145 | def: 1
146 | };
147 | });
148 |
149 | function clamp( value, prop, allowEmpty ) {
150 | var type = propTypes[ prop.type ] || {};
151 |
152 | if ( value == null ) {
153 | return (allowEmpty || !prop.def) ? null : prop.def;
154 | }
155 |
156 | // ~~ is an short way of doing floor for positive numbers
157 | value = type.floor ? ~~value : parseFloat( value );
158 |
159 | // IE will pass in empty strings as value for alpha,
160 | // which will hit this case
161 | if ( isNaN( value ) ) {
162 | return prop.def;
163 | }
164 |
165 | if ( type.mod ) {
166 | // we add mod before modding to make sure that negatives values
167 | // get converted properly: -10 -> 350
168 | return (value + type.mod) % type.mod;
169 | }
170 |
171 | // for now all property types without mod have min and max
172 | return 0 > value ? 0 : type.max < value ? type.max : value;
173 | }
174 |
175 | function stringParse( string ) {
176 | var inst = color(),
177 | rgba = inst._rgba = [];
178 |
179 | string = string.toLowerCase();
180 |
181 | each( stringParsers, function( i, parser ) {
182 | var parsed,
183 | match = parser.re.exec( string ),
184 | values = match && parser.parse( match ),
185 | spaceName = parser.space || "rgba";
186 |
187 | if ( values ) {
188 | parsed = inst[ spaceName ]( values );
189 |
190 | // if this was an rgba parse the assignment might happen twice
191 | // oh well....
192 | inst[ spaces[ spaceName ].cache ] = parsed[ spaces[ spaceName ].cache ];
193 | rgba = inst._rgba = parsed._rgba;
194 |
195 | // exit each( stringParsers ) here because we matched
196 | return false;
197 | }
198 | });
199 |
200 | // Found a stringParser that handled it
201 | if ( rgba.length ) {
202 |
203 | // if this came from a parsed string, force "transparent" when alpha is 0
204 | // chrome, (and maybe others) return "transparent" as rgba(0,0,0,0)
205 | if ( rgba.join() === "0,0,0,0" ) {
206 | jQuery.extend( rgba, colors.transparent );
207 | }
208 | return inst;
209 | }
210 |
211 | // named colors
212 | return colors[ string ];
213 | }
214 |
215 | color.fn = jQuery.extend( color.prototype, {
216 | parse: function( red, green, blue, alpha ) {
217 | if ( red === undefined ) {
218 | this._rgba = [ null, null, null, null ];
219 | return this;
220 | }
221 | if ( red.jquery || red.nodeType ) {
222 | red = jQuery( red ).css( green );
223 | green = undefined;
224 | }
225 |
226 | var inst = this,
227 | type = jQuery.type( red ),
228 | rgba = this._rgba = [];
229 |
230 | // more than 1 argument specified - assume ( red, green, blue, alpha )
231 | if ( green !== undefined ) {
232 | red = [ red, green, blue, alpha ];
233 | type = "array";
234 | }
235 |
236 | if ( type === "string" ) {
237 | return this.parse( stringParse( red ) || colors._default );
238 | }
239 |
240 | if ( type === "array" ) {
241 | each( spaces.rgba.props, function( key, prop ) {
242 | rgba[ prop.idx ] = clamp( red[ prop.idx ], prop );
243 | });
244 | return this;
245 | }
246 |
247 | if ( type === "object" ) {
248 | if ( red instanceof color ) {
249 | each( spaces, function( spaceName, space ) {
250 | if ( red[ space.cache ] ) {
251 | inst[ space.cache ] = red[ space.cache ].slice();
252 | }
253 | });
254 | } else {
255 | each( spaces, function( spaceName, space ) {
256 | var cache = space.cache;
257 | each( space.props, function( key, prop ) {
258 |
259 | // if the cache doesn't exist, and we know how to convert
260 | if ( !inst[ cache ] && space.to ) {
261 |
262 | // if the value was null, we don't need to copy it
263 | // if the key was alpha, we don't need to copy it either
264 | if ( key === "alpha" || red[ key ] == null ) {
265 | return;
266 | }
267 | inst[ cache ] = space.to( inst._rgba );
268 | }
269 |
270 | // this is the only case where we allow nulls for ALL properties.
271 | // call clamp with alwaysAllowEmpty
272 | inst[ cache ][ prop.idx ] = clamp( red[ key ], prop, true );
273 | });
274 |
275 | // everything defined but alpha?
276 | if ( inst[ cache ] && jQuery.inArray( null, inst[ cache ].slice( 0, 3 ) ) < 0 ) {
277 | // use the default of 1
278 | inst[ cache ][ 3 ] = 1;
279 | if ( space.from ) {
280 | inst._rgba = space.from( inst[ cache ] );
281 | }
282 | }
283 | });
284 | }
285 | return this;
286 | }
287 | },
288 | is: function( compare ) {
289 | var is = color( compare ),
290 | same = true,
291 | inst = this;
292 |
293 | each( spaces, function( _, space ) {
294 | var localCache,
295 | isCache = is[ space.cache ];
296 | if (isCache) {
297 | localCache = inst[ space.cache ] || space.to && space.to( inst._rgba ) || [];
298 | each( space.props, function( _, prop ) {
299 | if ( isCache[ prop.idx ] != null ) {
300 | same = ( isCache[ prop.idx ] === localCache[ prop.idx ] );
301 | return same;
302 | }
303 | });
304 | }
305 | return same;
306 | });
307 | return same;
308 | },
309 | _space: function() {
310 | var used = [],
311 | inst = this;
312 | each( spaces, function( spaceName, space ) {
313 | if ( inst[ space.cache ] ) {
314 | used.push( spaceName );
315 | }
316 | });
317 | return used.pop();
318 | },
319 | transition: function( other, distance ) {
320 | var end = color( other ),
321 | spaceName = end._space(),
322 | space = spaces[ spaceName ],
323 | startColor = this.alpha() === 0 ? color( "transparent" ) : this,
324 | start = startColor[ space.cache ] || space.to( startColor._rgba ),
325 | result = start.slice();
326 |
327 | end = end[ space.cache ];
328 | each( space.props, function( key, prop ) {
329 | var index = prop.idx,
330 | startValue = start[ index ],
331 | endValue = end[ index ],
332 | type = propTypes[ prop.type ] || {};
333 |
334 | // if null, don't override start value
335 | if ( endValue === null ) {
336 | return;
337 | }
338 | // if null - use end
339 | if ( startValue === null ) {
340 | result[ index ] = endValue;
341 | } else {
342 | if ( type.mod ) {
343 | if ( endValue - startValue > type.mod / 2 ) {
344 | startValue += type.mod;
345 | } else if ( startValue - endValue > type.mod / 2 ) {
346 | startValue -= type.mod;
347 | }
348 | }
349 | result[ index ] = clamp( ( endValue - startValue ) * distance + startValue, prop );
350 | }
351 | });
352 | return this[ spaceName ]( result );
353 | },
354 | blend: function( opaque ) {
355 | // if we are already opaque - return ourself
356 | if ( this._rgba[ 3 ] === 1 ) {
357 | return this;
358 | }
359 |
360 | var rgb = this._rgba.slice(),
361 | a = rgb.pop(),
362 | blend = color( opaque )._rgba;
363 |
364 | return color( jQuery.map( rgb, function( v, i ) {
365 | return ( 1 - a ) * blend[ i ] + a * v;
366 | }));
367 | },
368 | toRgbaString: function() {
369 | var prefix = "rgba(",
370 | rgba = jQuery.map( this._rgba, function( v, i ) {
371 | return v == null ? ( i > 2 ? 1 : 0 ) : v;
372 | });
373 |
374 | if ( rgba[ 3 ] === 1 ) {
375 | rgba.pop();
376 | prefix = "rgb(";
377 | }
378 |
379 | return prefix + rgba.join() + ")";
380 | },
381 | toHslaString: function() {
382 | var prefix = "hsla(",
383 | hsla = jQuery.map( this.hsla(), function( v, i ) {
384 | if ( v == null ) {
385 | v = i > 2 ? 1 : 0;
386 | }
387 |
388 | // catch 1 and 2
389 | if ( i && i < 3 ) {
390 | v = Math.round( v * 100 ) + "%";
391 | }
392 | return v;
393 | });
394 |
395 | if ( hsla[ 3 ] === 1 ) {
396 | hsla.pop();
397 | prefix = "hsl(";
398 | }
399 | return prefix + hsla.join() + ")";
400 | },
401 | toHexString: function( includeAlpha ) {
402 | var rgba = this._rgba.slice(),
403 | alpha = rgba.pop();
404 |
405 | if ( includeAlpha ) {
406 | rgba.push( ~~( alpha * 255 ) );
407 | }
408 |
409 | return "#" + jQuery.map( rgba, function( v ) {
410 |
411 | // default to 0 when nulls exist
412 | v = ( v || 0 ).toString( 16 );
413 | return v.length === 1 ? "0" + v : v;
414 | }).join("");
415 | },
416 | toString: function() {
417 | return this._rgba[ 3 ] === 0 ? "transparent" : this.toRgbaString();
418 | }
419 | });
420 | color.fn.parse.prototype = color.fn;
421 |
422 | // hsla conversions adapted from:
423 | // https://code.google.com/p/maashaack/source/browse/packages/graphics/trunk/src/graphics/colors/HUE2RGB.as?r=5021
424 |
425 | function hue2rgb( p, q, h ) {
426 | h = ( h + 1 ) % 1;
427 | if ( h * 6 < 1 ) {
428 | return p + (q - p) * h * 6;
429 | }
430 | if ( h * 2 < 1) {
431 | return q;
432 | }
433 | if ( h * 3 < 2 ) {
434 | return p + (q - p) * ((2/3) - h) * 6;
435 | }
436 | return p;
437 | }
438 |
439 | spaces.hsla.to = function ( rgba ) {
440 | if ( rgba[ 0 ] == null || rgba[ 1 ] == null || rgba[ 2 ] == null ) {
441 | return [ null, null, null, rgba[ 3 ] ];
442 | }
443 | var r = rgba[ 0 ] / 255,
444 | g = rgba[ 1 ] / 255,
445 | b = rgba[ 2 ] / 255,
446 | a = rgba[ 3 ],
447 | max = Math.max( r, g, b ),
448 | min = Math.min( r, g, b ),
449 | diff = max - min,
450 | add = max + min,
451 | l = add * 0.5,
452 | h, s;
453 |
454 | if ( min === max ) {
455 | h = 0;
456 | } else if ( r === max ) {
457 | h = ( 60 * ( g - b ) / diff ) + 360;
458 | } else if ( g === max ) {
459 | h = ( 60 * ( b - r ) / diff ) + 120;
460 | } else {
461 | h = ( 60 * ( r - g ) / diff ) + 240;
462 | }
463 |
464 | // chroma (diff) == 0 means greyscale which, by definition, saturation = 0%
465 | // otherwise, saturation is based on the ratio of chroma (diff) to lightness (add)
466 | if ( diff === 0 ) {
467 | s = 0;
468 | } else if ( l <= 0.5 ) {
469 | s = diff / add;
470 | } else {
471 | s = diff / ( 2 - add );
472 | }
473 | return [ Math.round(h) % 360, s, l, a == null ? 1 : a ];
474 | };
475 |
476 | spaces.hsla.from = function ( hsla ) {
477 | if ( hsla[ 0 ] == null || hsla[ 1 ] == null || hsla[ 2 ] == null ) {
478 | return [ null, null, null, hsla[ 3 ] ];
479 | }
480 | var h = hsla[ 0 ] / 360,
481 | s = hsla[ 1 ],
482 | l = hsla[ 2 ],
483 | a = hsla[ 3 ],
484 | q = l <= 0.5 ? l * ( 1 + s ) : l + s - l * s,
485 | p = 2 * l - q;
486 |
487 | return [
488 | Math.round( hue2rgb( p, q, h + ( 1 / 3 ) ) * 255 ),
489 | Math.round( hue2rgb( p, q, h ) * 255 ),
490 | Math.round( hue2rgb( p, q, h - ( 1 / 3 ) ) * 255 ),
491 | a
492 | ];
493 | };
494 |
495 |
496 | each( spaces, function( spaceName, space ) {
497 | var props = space.props,
498 | cache = space.cache,
499 | to = space.to,
500 | from = space.from;
501 |
502 | // makes rgba() and hsla()
503 | color.fn[ spaceName ] = function( value ) {
504 |
505 | // generate a cache for this space if it doesn't exist
506 | if ( to && !this[ cache ] ) {
507 | this[ cache ] = to( this._rgba );
508 | }
509 | if ( value === undefined ) {
510 | return this[ cache ].slice();
511 | }
512 |
513 | var ret,
514 | type = jQuery.type( value ),
515 | arr = ( type === "array" || type === "object" ) ? value : arguments,
516 | local = this[ cache ].slice();
517 |
518 | each( props, function( key, prop ) {
519 | var val = arr[ type === "object" ? key : prop.idx ];
520 | if ( val == null ) {
521 | val = local[ prop.idx ];
522 | }
523 | local[ prop.idx ] = clamp( val, prop );
524 | });
525 |
526 | if ( from ) {
527 | ret = color( from( local ) );
528 | ret[ cache ] = local;
529 | return ret;
530 | } else {
531 | return color( local );
532 | }
533 | };
534 |
535 | // makes red() green() blue() alpha() hue() saturation() lightness()
536 | each( props, function( key, prop ) {
537 | // alpha is included in more than one space
538 | if ( color.fn[ key ] ) {
539 | return;
540 | }
541 | color.fn[ key ] = function( value ) {
542 | var vtype = jQuery.type( value ),
543 | fn = ( key === "alpha" ? ( this._hsla ? "hsla" : "rgba" ) : spaceName ),
544 | local = this[ fn ](),
545 | cur = local[ prop.idx ],
546 | match;
547 |
548 | if ( vtype === "undefined" ) {
549 | return cur;
550 | }
551 |
552 | if ( vtype === "function" ) {
553 | value = value.call( this, cur );
554 | vtype = jQuery.type( value );
555 | }
556 | if ( value == null && prop.empty ) {
557 | return this;
558 | }
559 | if ( vtype === "string" ) {
560 | match = rplusequals.exec( value );
561 | if ( match ) {
562 | value = cur + parseFloat( match[ 2 ] ) * ( match[ 1 ] === "+" ? 1 : -1 );
563 | }
564 | }
565 | local[ prop.idx ] = value;
566 | return this[ fn ]( local );
567 | };
568 | });
569 | });
570 |
571 | // add cssHook and .fx.step function for each named hook.
572 | // accept a space separated string of properties
573 | color.hook = function( hook ) {
574 | var hooks = hook.split( " " );
575 | each( hooks, function( i, hook ) {
576 | jQuery.cssHooks[ hook ] = {
577 | set: function( elem, value ) {
578 | var parsed, curElem,
579 | backgroundColor = "";
580 |
581 | if ( value !== "transparent" && ( jQuery.type( value ) !== "string" || ( parsed = stringParse( value ) ) ) ) {
582 | value = color( parsed || value );
583 | if ( !support.rgba && value._rgba[ 3 ] !== 1 ) {
584 | curElem = hook === "backgroundColor" ? elem.parentNode : elem;
585 | while (
586 | (backgroundColor === "" || backgroundColor === "transparent") &&
587 | curElem && curElem.style
588 | ) {
589 | try {
590 | backgroundColor = jQuery.css( curElem, "backgroundColor" );
591 | curElem = curElem.parentNode;
592 | } catch ( e ) {
593 | }
594 | }
595 |
596 | value = value.blend( backgroundColor && backgroundColor !== "transparent" ?
597 | backgroundColor :
598 | "_default" );
599 | }
600 |
601 | value = value.toRgbaString();
602 | }
603 | try {
604 | elem.style[ hook ] = value;
605 | } catch( e ) {
606 | // wrapped to prevent IE from throwing errors on "invalid" values like 'auto' or 'inherit'
607 | }
608 | }
609 | };
610 | jQuery.fx.step[ hook ] = function( fx ) {
611 | if ( !fx.colorInit ) {
612 | fx.start = color( fx.elem, hook );
613 | fx.end = color( fx.end );
614 | fx.colorInit = true;
615 | }
616 | jQuery.cssHooks[ hook ].set( fx.elem, fx.start.transition( fx.end, fx.pos ) );
617 | };
618 | });
619 |
620 | };
621 |
622 | color.hook( stepHooks );
623 |
624 | jQuery.cssHooks.borderColor = {
625 | expand: function( value ) {
626 | var expanded = {};
627 |
628 | each( [ "Top", "Right", "Bottom", "Left" ], function( i, part ) {
629 | expanded[ "border" + part + "Color" ] = value;
630 | });
631 | return expanded;
632 | }
633 | };
634 |
635 | // Basic color names only.
636 | // Usage of any of the other color names requires adding yourself or including
637 | // jquery.color.svg-names.js.
638 | colors = jQuery.Color.names = {
639 | // 4.1. Basic color keywords
640 | aqua: "#00ffff",
641 | black: "#000000",
642 | blue: "#0000ff",
643 | fuchsia: "#ff00ff",
644 | gray: "#808080",
645 | green: "#008000",
646 | lime: "#00ff00",
647 | maroon: "#800000",
648 | navy: "#000080",
649 | olive: "#808000",
650 | purple: "#800080",
651 | red: "#ff0000",
652 | silver: "#c0c0c0",
653 | teal: "#008080",
654 | white: "#ffffff",
655 | yellow: "#ffff00",
656 |
657 | // 4.2.3. "transparent" color keyword
658 | transparent: [ null, null, null, 0 ],
659 |
660 | _default: "#ffffff"
661 | };
662 |
663 | }( jQuery ));
664 |
--------------------------------------------------------------------------------
/js/layer.js:
--------------------------------------------------------------------------------
1 | /*! layer-v3.1.1 Web弹层组件 MIT License http://layer.layui.com/ By 贤心 */
2 | ;!function(e,t){"use strict";var i,n,a=e.layui&&layui.define,o={getPath:function(){var e=document.currentScript?document.currentScript.src:function(){for(var e,t=document.scripts,i=t.length-1,n=i;n>0;n--)if("interactive"===t[n].readyState){e=t[n].src;break}return e||t[i].src}();return e.substring(0,e.lastIndexOf("/")+1)}(),config:{},end:{},minIndex:0,minLeft:[],btn:["确定","取消"],type:["dialog","page","iframe","loading","tips"],getStyle:function(t,i){var n=t.currentStyle?t.currentStyle:e.getComputedStyle(t,null);return n[n.getPropertyValue?"getPropertyValue":"getAttribute"](i)},link:function(t,i,n){if(r.path){var a=document.getElementsByTagName("head")[0],s=document.createElement("link");"string"==typeof i&&(n=i);var l=(n||t).replace(/\.|\//g,""),f="layuicss-"+l,c=0;s.rel="stylesheet",s.href=r.path+t,s.id=f,document.getElementById(f)||a.appendChild(s),"function"==typeof i&&!function u(){return++c>80?e.console&&console.error("layer.css: Invalid"):void(1989===parseInt(o.getStyle(document.getElementById(f),"width"))?i():setTimeout(u,100))}()}}},r={v:"3.1.1",ie:function(){var t=navigator.userAgent.toLowerCase();return!!(e.ActiveXObject||"ActiveXObject"in e)&&((t.match(/msie\s(\d+)/)||[])[1]||"11")}(),index:e.layer&&e.layer.v?1e5:0,path:o.getPath,config:function(e,t){return e=e||{},r.cache=o.config=i.extend({},o.config,e),r.path=o.config.path||r.path,"string"==typeof e.extend&&(e.extend=[e.extend]),o.config.path&&r.ready(),e.extend?(a?layui.addcss("modules/layer/"+e.extend):o.link("theme/"+e.extend),this):this},ready:function(e){var t="layer",i="",n=(a?"modules/layer/":"theme/")+"default/layer.css?v="+r.v+i;return a?layui.addcss(n,e,t):o.link(n,e,t),this},alert:function(e,t,n){var a="function"==typeof t;return a&&(n=t),r.open(i.extend({content:e,yes:n},a?{}:t))},confirm:function(e,t,n,a){var s="function"==typeof t;return s&&(a=n,n=t),r.open(i.extend({content:e,btn:o.btn,yes:n,btn2:a},s?{}:t))},msg:function(e,n,a){var s="function"==typeof n,f=o.config.skin,c=(f?f+" "+f+"-msg":"")||"layui-layer-msg",u=l.anim.length-1;return s&&(a=n),r.open(i.extend({content:e,time:3e3,shade:!1,skin:c,title:!1,closeBtn:!1,btn:!1,resize:!1,end:a},s&&!o.config.skin?{skin:c+" layui-layer-hui",anim:u}:function(){return n=n||{},(n.icon===-1||n.icon===t&&!o.config.skin)&&(n.skin=c+" "+(n.skin||"layui-layer-hui")),n}()))},load:function(e,t){return r.open(i.extend({type:3,icon:e||0,resize:!1,shade:.01},t))},tips:function(e,t,n){return r.open(i.extend({type:4,content:[e,t],closeBtn:!1,time:3e3,shade:!1,resize:!1,fixed:!1,maxWidth:210},n))}},s=function(e){var t=this;t.index=++r.index,t.config=i.extend({},t.config,o.config,e),document.body?t.creat():setTimeout(function(){t.creat()},30)};s.pt=s.prototype;var l=["layui-layer",".layui-layer-title",".layui-layer-main",".layui-layer-dialog","layui-layer-iframe","layui-layer-content","layui-layer-btn","layui-layer-close"];l.anim=["layer-anim-00","layer-anim-01","layer-anim-02","layer-anim-03","layer-anim-04","layer-anim-05","layer-anim-06"],s.pt.config={type:0,shade:.3,fixed:!0,move:l[1],title:"信息",offset:"auto",area:"auto",closeBtn:1,time:0,zIndex:19891014,maxWidth:360,anim:0,isOutAnim:!0,icon:-1,moveType:1,resize:!0,scrollbar:!0,tips:2},s.pt.vessel=function(e,t){var n=this,a=n.index,r=n.config,s=r.zIndex+a,f="object"==typeof r.title,c=r.maxmin&&(1===r.type||2===r.type),u=r.title?'
'+(f?r.title[0]:r.title)+"
":"";return r.zIndex=s,t([r.shade?'':"",''+(e&&2!=r.type?"":u)+'
'+(0==r.type&&r.icon!==-1?'':"")+(1==r.type&&e?"":r.content||"")+'
'+function(){var e=c?'':"";return r.closeBtn&&(e+=''),e}()+""+(r.btn?function(){var e="";"string"==typeof r.btn&&(r.btn=[r.btn]);for(var t=0,i=r.btn.length;t
'+r.btn[t]+"";return''+e+"
"}():"")+(r.resize?'':"")+" "],u,i('')),n},s.pt.creat=function(){var e=this,t=e.config,a=e.index,s=t.content,f="object"==typeof s,c=i("body");if(!t.id||!i("#"+t.id)[0]){switch("string"==typeof t.area&&(t.area="auto"===t.area?["",""]:[t.area,""]),t.shift&&(t.anim=t.shift),6==r.ie&&(t.fixed=!1),t.type){case 0:t.btn="btn"in t?t.btn:o.btn[0],r.closeAll("dialog");break;case 2:var s=t.content=f?t.content:[t.content||"http://layer.layui.com","auto"];t.content='';break;case 3:delete t.title,delete t.closeBtn,t.icon===-1&&0===t.icon,r.closeAll("loading");break;case 4:f||(t.content=[t.content,"body"]),t.follow=t.content[1],t.content=t.content[0]+'',delete t.title,t.tips="object"==typeof t.tips?t.tips:[t.tips,!0],t.tipsMore||r.closeAll("tips")}if(e.vessel(f,function(n,r,u){c.append(n[0]),f?function(){2==t.type||4==t.type?function(){i("body").append(n[1])}():function(){s.parents("."+l[0])[0]||(s.data("display",s.css("display")).show().addClass("layui-layer-wrap").wrap(n[1]),i("#"+l[0]+a).find("."+l[5]).before(r))}()}():c.append(n[1]),i(".layui-layer-move")[0]||c.append(o.moveElem=u),e.layero=i("#"+l[0]+a),t.scrollbar||l.html.css("overflow","hidden").attr("layer-full",a)}).auto(a),i("#layui-layer-shade"+e.index).css({"background-color":t.shade[1]||"#000",opacity:t.shade[0]||t.shade}),2==t.type&&6==r.ie&&e.layero.find("iframe").attr("src",s[0]),4==t.type?e.tips():e.offset(),t.fixed&&n.on("resize",function(){e.offset(),(/^\d+%$/.test(t.area[0])||/^\d+%$/.test(t.area[1]))&&e.auto(a),4==t.type&&e.tips()}),t.time<=0||setTimeout(function(){r.close(e.index)},t.time),e.move().callback(),l.anim[t.anim]){var u="layer-anim "+l.anim[t.anim];e.layero.addClass(u).one("webkitAnimationEnd mozAnimationEnd MSAnimationEnd oanimationend animationend",function(){i(this).removeClass(u)})}t.isOutAnim&&e.layero.data("isOutAnim",!0)}},s.pt.auto=function(e){var t=this,a=t.config,o=i("#"+l[0]+e);""===a.area[0]&&a.maxWidth>0&&(r.ie&&r.ie<8&&a.btn&&o.width(o.innerWidth()),o.outerWidth()>a.maxWidth&&o.width(a.maxWidth));var s=[o.innerWidth(),o.innerHeight()],f=o.find(l[1]).outerHeight()||0,c=o.find("."+l[6]).outerHeight()||0,u=function(e){e=o.find(e),e.height(s[1]-f-c-2*(0|parseFloat(e.css("padding-top"))))};switch(a.type){case 2:u("iframe");break;default:""===a.area[1]?a.maxHeight>0&&o.outerHeight()>a.maxHeight?(s[1]=a.maxHeight,u("."+l[5])):a.fixed&&s[1]>=n.height()&&(s[1]=n.height(),u("."+l[5])):u("."+l[5])}return t},s.pt.offset=function(){var e=this,t=e.config,i=e.layero,a=[i.outerWidth(),i.outerHeight()],o="object"==typeof t.offset;e.offsetTop=(n.height()-a[1])/2,e.offsetLeft=(n.width()-a[0])/2,o?(e.offsetTop=t.offset[0],e.offsetLeft=t.offset[1]||e.offsetLeft):"auto"!==t.offset&&("t"===t.offset?e.offsetTop=0:"r"===t.offset?e.offsetLeft=n.width()-a[0]:"b"===t.offset?e.offsetTop=n.height()-a[1]:"l"===t.offset?e.offsetLeft=0:"lt"===t.offset?(e.offsetTop=0,e.offsetLeft=0):"lb"===t.offset?(e.offsetTop=n.height()-a[1],e.offsetLeft=0):"rt"===t.offset?(e.offsetTop=0,e.offsetLeft=n.width()-a[0]):"rb"===t.offset?(e.offsetTop=n.height()-a[1],e.offsetLeft=n.width()-a[0]):e.offsetTop=t.offset),t.fixed||(e.offsetTop=/%$/.test(e.offsetTop)?n.height()*parseFloat(e.offsetTop)/100:parseFloat(e.offsetTop),e.offsetLeft=/%$/.test(e.offsetLeft)?n.width()*parseFloat(e.offsetLeft)/100:parseFloat(e.offsetLeft),e.offsetTop+=n.scrollTop(),e.offsetLeft+=n.scrollLeft()),i.attr("minLeft")&&(e.offsetTop=n.height()-(i.find(l[1]).outerHeight()||0),e.offsetLeft=i.css("left")),i.css({top:e.offsetTop,left:e.offsetLeft})},s.pt.tips=function(){var e=this,t=e.config,a=e.layero,o=[a.outerWidth(),a.outerHeight()],r=i(t.follow);r[0]||(r=i("body"));var s={width:r.outerWidth(),height:r.outerHeight(),top:r.offset().top,left:r.offset().left},f=a.find(".layui-layer-TipsG"),c=t.tips[0];t.tips[1]||f.remove(),s.autoLeft=function(){s.left+o[0]-n.width()>0?(s.tipLeft=s.left+s.width-o[0],f.css({right:12,left:"auto"})):s.tipLeft=s.left},s.where=[function(){s.autoLeft(),s.tipTop=s.top-o[1]-10,f.removeClass("layui-layer-TipsB").addClass("layui-layer-TipsT").css("border-right-color",t.tips[1])},function(){s.tipLeft=s.left+s.width+10,s.tipTop=s.top,f.removeClass("layui-layer-TipsL").addClass("layui-layer-TipsR").css("border-bottom-color",t.tips[1])},function(){s.autoLeft(),s.tipTop=s.top+s.height+10,f.removeClass("layui-layer-TipsT").addClass("layui-layer-TipsB").css("border-right-color",t.tips[1])},function(){s.tipLeft=s.left-o[0]-10,s.tipTop=s.top,f.removeClass("layui-layer-TipsR").addClass("layui-layer-TipsL").css("border-bottom-color",t.tips[1])}],s.where[c-1](),1===c?s.top-(n.scrollTop()+o[1]+16)<0&&s.where[2]():2===c?n.width()-(s.left+s.width+o[0]+16)>0||s.where[3]():3===c?s.top-n.scrollTop()+s.height+o[1]+16-n.height()>0&&s.where[0]():4===c&&o[0]+16-s.left>0&&s.where[1](),a.find("."+l[5]).css({"background-color":t.tips[1],"padding-right":t.closeBtn?"30px":""}),a.css({left:s.tipLeft-(t.fixed?n.scrollLeft():0),top:s.tipTop-(t.fixed?n.scrollTop():0)})},s.pt.move=function(){var e=this,t=e.config,a=i(document),s=e.layero,l=s.find(t.move),f=s.find(".layui-layer-resize"),c={};return t.move&&l.css("cursor","move"),l.on("mousedown",function(e){e.preventDefault(),t.move&&(c.moveStart=!0,c.offset=[e.clientX-parseFloat(s.css("left")),e.clientY-parseFloat(s.css("top"))],o.moveElem.css("cursor","move").show())}),f.on("mousedown",function(e){e.preventDefault(),c.resizeStart=!0,c.offset=[e.clientX,e.clientY],c.area=[s.outerWidth(),s.outerHeight()],o.moveElem.css("cursor","se-resize").show()}),a.on("mousemove",function(i){if(c.moveStart){var a=i.clientX-c.offset[0],o=i.clientY-c.offset[1],l="fixed"===s.css("position");if(i.preventDefault(),c.stX=l?0:n.scrollLeft(),c.stY=l?0:n.scrollTop(),!t.moveOut){var f=n.width()-s.outerWidth()+c.stX,u=n.height()-s.outerHeight()+c.stY;af&&(a=f),ou&&(o=u)}s.css({left:a,top:o})}if(t.resize&&c.resizeStart){var a=i.clientX-c.offset[0],o=i.clientY-c.offset[1];i.preventDefault(),r.style(e.index,{width:c.area[0]+a,height:c.area[1]+o}),c.isResize=!0,t.resizing&&t.resizing(s)}}).on("mouseup",function(e){c.moveStart&&(delete c.moveStart,o.moveElem.hide(),t.moveEnd&&t.moveEnd(s)),c.resizeStart&&(delete c.resizeStart,o.moveElem.hide())}),e},s.pt.callback=function(){function e(){var e=a.cancel&&a.cancel(t.index,n);e===!1||r.close(t.index)}var t=this,n=t.layero,a=t.config;t.openLayer(),a.success&&(2==a.type?n.find("iframe").on("load",function(){a.success(n,t.index)}):a.success(n,t.index)),6==r.ie&&t.IE6(n),n.find("."+l[6]).children("a").on("click",function(){var e=i(this).index();if(0===e)a.yes?a.yes(t.index,n):a.btn1?a.btn1(t.index,n):r.close(t.index);else{var o=a["btn"+(e+1)]&&a["btn"+(e+1)](t.index,n);o===!1||r.close(t.index)}}),n.find("."+l[7]).on("click",e),a.shadeClose&&i("#layui-layer-shade"+t.index).on("click",function(){r.close(t.index)}),n.find(".layui-layer-min").on("click",function(){var e=a.min&&a.min(n);e===!1||r.min(t.index,a)}),n.find(".layui-layer-max").on("click",function(){i(this).hasClass("layui-layer-maxmin")?(r.restore(t.index),a.restore&&a.restore(n)):(r.full(t.index,a),setTimeout(function(){a.full&&a.full(n)},100))}),a.end&&(o.end[t.index]=a.end)},o.reselect=function(){i.each(i("select"),function(e,t){var n=i(this);n.parents("."+l[0])[0]||1==n.attr("layer")&&i("."+l[0]).length<1&&n.removeAttr("layer").show(),n=null})},s.pt.IE6=function(e){i("select").each(function(e,t){var n=i(this);n.parents("."+l[0])[0]||"none"===n.css("display")||n.attr({layer:"1"}).hide(),n=null})},s.pt.openLayer=function(){var e=this;r.zIndex=e.config.zIndex,r.setTop=function(e){var t=function(){r.zIndex++,e.css("z-index",r.zIndex+1)};return r.zIndex=parseInt(e[0].style.zIndex),e.on("mousedown",t),r.zIndex}},o.record=function(e){var t=[e.width(),e.height(),e.position().top,e.position().left+parseFloat(e.css("margin-left"))];e.find(".layui-layer-max").addClass("layui-layer-maxmin"),e.attr({area:t})},o.rescollbar=function(e){l.html.attr("layer-full")==e&&(l.html[0].style.removeProperty?l.html[0].style.removeProperty("overflow"):l.html[0].style.removeAttribute("overflow"),l.html.removeAttr("layer-full"))},e.layer=r,r.getChildFrame=function(e,t){return t=t||i("."+l[4]).attr("times"),i("#"+l[0]+t).find("iframe").contents().find(e)},r.getFrameIndex=function(e){return i("#"+e).parents("."+l[4]).attr("times")},r.iframeAuto=function(e){if(e){var t=r.getChildFrame("html",e).outerHeight(),n=i("#"+l[0]+e),a=n.find(l[1]).outerHeight()||0,o=n.find("."+l[6]).outerHeight()||0;n.css({height:t+a+o}),n.find("iframe").css({height:t})}},r.iframeSrc=function(e,t){i("#"+l[0]+e).find("iframe").attr("src",t)},r.style=function(e,t,n){var a=i("#"+l[0]+e),r=a.find(".layui-layer-content"),s=a.attr("type"),f=a.find(l[1]).outerHeight()||0,c=a.find("."+l[6]).outerHeight()||0;a.attr("minLeft");s!==o.type[3]&&s!==o.type[4]&&(n||(parseFloat(t.width)<=260&&(t.width=260),parseFloat(t.height)-f-c<=64&&(t.height=64+f+c)),a.css(t),c=a.find("."+l[6]).outerHeight(),s===o.type[2]?a.find("iframe").css({height:parseFloat(t.height)-f-c}):r.css({height:parseFloat(t.height)-f-c-parseFloat(r.css("padding-top"))-parseFloat(r.css("padding-bottom"))}))},r.min=function(e,t){var a=i("#"+l[0]+e),s=a.find(l[1]).outerHeight()||0,f=a.attr("minLeft")||181*o.minIndex+"px",c=a.css("position");o.record(a),o.minLeft[0]&&(f=o.minLeft[0],o.minLeft.shift()),a.attr("position",c),r.style(e,{width:180,height:s,left:f,top:n.height()-s,position:"fixed",overflow:"hidden"},!0),a.find(".layui-layer-min").hide(),"page"===a.attr("type")&&a.find(l[4]).hide(),o.rescollbar(e),a.attr("minLeft")||o.minIndex++,a.attr("minLeft",f)},r.restore=function(e){var t=i("#"+l[0]+e),n=t.attr("area").split(",");t.attr("type");r.style(e,{width:parseFloat(n[0]),height:parseFloat(n[1]),top:parseFloat(n[2]),left:parseFloat(n[3]),position:t.attr("position"),overflow:"visible"},!0),t.find(".layui-layer-max").removeClass("layui-layer-maxmin"),t.find(".layui-layer-min").show(),"page"===t.attr("type")&&t.find(l[4]).show(),o.rescollbar(e)},r.full=function(e){var t,a=i("#"+l[0]+e);o.record(a),l.html.attr("layer-full")||l.html.css("overflow","hidden").attr("layer-full",e),clearTimeout(t),t=setTimeout(function(){var t="fixed"===a.css("position");r.style(e,{top:t?0:n.scrollTop(),left:t?0:n.scrollLeft(),width:n.width(),height:n.height()},!0),a.find(".layui-layer-min").hide()},100)},r.title=function(e,t){var n=i("#"+l[0]+(t||r.index)).find(l[1]);n.html(e)},r.close=function(e){var t=i("#"+l[0]+e),n=t.attr("type"),a="layer-anim-close";if(t[0]){var s="layui-layer-wrap",f=function(){if(n===o.type[1]&&"object"===t.attr("conType")){t.children(":not(."+l[5]+")").remove();for(var a=t.find("."+s),r=0;r<2;r++)a.unwrap();a.css("display",a.data("display")).removeClass(s)}else{if(n===o.type[2])try{var f=i("#"+l[4]+e)[0];f.contentWindow.document.write(""),f.contentWindow.close(),t.find("."+l[5])[0].removeChild(f)}catch(c){}t[0].innerHTML="",t.remove()}"function"==typeof o.end[e]&&o.end[e](),delete o.end[e]};t.data("isOutAnim")&&t.addClass("layer-anim "+a),i("#layui-layer-moves, #layui-layer-shade"+e).remove(),6==r.ie&&o.reselect(),o.rescollbar(e),t.attr("minLeft")&&(o.minIndex--,o.minLeft.push(t.attr("minLeft"))),r.ie&&r.ie<10||!t.data("isOutAnim")?f():setTimeout(function(){f()},200)}},r.closeAll=function(e){i.each(i("."+l[0]),function(){var t=i(this),n=e?t.attr("type")===e:1;n&&r.close(t.attr("times")),n=null})};var f=r.cache||{},c=function(e){return f.skin?" "+f.skin+" "+f.skin+"-"+e:""};r.prompt=function(e,t){var a="";if(e=e||{},"function"==typeof e&&(t=e),e.area){var o=e.area;a='style="width: '+o[0]+"; height: "+o[1]+';"',delete e.area}var s,l=2==e.formType?'":function(){return''}(),f=e.success;return delete e.success,r.open(i.extend({type:1,btn:["确定","取消"],content:l,skin:"layui-layer-prompt"+c("prompt"),maxWidth:n.width(),success:function(e){s=e.find(".layui-layer-input"),s.focus(),"function"==typeof f&&f(e)},resize:!1,yes:function(i){var n=s.val();""===n?s.focus():n.length>(e.maxlength||500)?r.tips("最多输入"+(e.maxlength||500)+"个字数",s,{tips:1}):t&&t(n,i,s)}},e))},r.tab=function(e){e=e||{};var t=e.tab||{},n="layui-this",a=e.success;return delete e.success,r.open(i.extend({type:1,skin:"layui-layer-tab"+c("tab"),resize:!1,title:function(){var e=t.length,i=1,a="";if(e>0)for(a=''+t[0].title+"";i"+t[i].title+"";return a}(),content:''+function(){var e=t.length,i=1,a="";if(e>0)for(a='- '+(t[0].content||"no content")+"
";i'+(t[i].content||"no content")+"";return a}()+"
",success:function(t){var o=t.find(".layui-layer-title").children(),r=t.find(".layui-layer-tabmain").children();o.on("mousedown",function(t){t.stopPropagation?t.stopPropagation():t.cancelBubble=!0;var a=i(this),o=a.index();a.addClass(n).siblings().removeClass(n),r.eq(o).show().siblings().hide(),"function"==typeof e.change&&e.change(o)}),"function"==typeof a&&a(t)}},e))},r.photos=function(t,n,a){function o(e,t,i){var n=new Image;return n.src=e,n.complete?t(n):(n.onload=function(){n.onload=null,t(n)},void(n.onerror=function(e){n.onerror=null,i(e)}))}var s={};if(t=t||{},t.photos){var l=t.photos.constructor===Object,f=l?t.photos:{},u=f.data||[],d=f.start||0;s.imgIndex=(0|d)+1,t.img=t.img||"img";var y=t.success;if(delete t.success,l){if(0===u.length)return r.msg("没有图片")}else{var p=i(t.photos),h=function(){u=[],p.find(t.img).each(function(e){var t=i(this);t.attr("layer-index",e),u.push({alt:t.attr("alt"),pid:t.attr("layer-pid"),src:t.attr("layer-src")||t.attr("src"),thumb:t.attr("src")})})};if(h(),0===u.length)return;if(n||p.on("click",t.img,function(){var e=i(this),n=e.attr("layer-index");r.photos(i.extend(t,{photos:{start:n,data:u,tab:t.tab},full:t.full}),!0),h()}),!n)return}s.imgprev=function(e){s.imgIndex--,s.imgIndex<1&&(s.imgIndex=u.length),s.tabimg(e)},s.imgnext=function(e,t){s.imgIndex++,s.imgIndex>u.length&&(s.imgIndex=1,t)||s.tabimg(e)},s.keyup=function(e){if(!s.end){var t=e.keyCode;e.preventDefault(),37===t?s.imgprev(!0):39===t?s.imgnext(!0):27===t&&r.close(s.index)}},s.tabimg=function(e){if(!(u.length<=1))return f.start=s.imgIndex-1,r.close(s.index),r.photos(t,!0,e)},s.event=function(){s.bigimg.hover(function(){s.imgsee.show()},function(){s.imgsee.hide()}),s.bigimg.find(".layui-layer-imgprev").on("click",function(e){e.preventDefault(),s.imgprev()}),s.bigimg.find(".layui-layer-imgnext").on("click",function(e){e.preventDefault(),s.imgnext()}),i(document).on("keyup",s.keyup)},s.loadi=r.load(1,{shade:!("shade"in t)&&.9,scrollbar:!1}),o(u[d].src,function(n){r.close(s.loadi),s.index=r.open(i.extend({type:1,id:"layui-layer-photos",area:function(){var a=[n.width,n.height],o=[i(e).width()-100,i(e).height()-100];if(!t.full&&(a[0]>o[0]||a[1]>o[1])){var r=[a[0]/o[0],a[1]/o[1]];r[0]>r[1]?(a[0]=a[0]/r[0],a[1]=a[1]/r[0]):r[0]
",success:function(e,i){s.bigimg=e.find(".layui-layer-phimg"),s.imgsee=e.find(".layui-layer-imguide,.layui-layer-imgbar"),s.event(e),t.tab&&t.tab(u[d],e),"function"==typeof y&&y(e)},end:function(){s.end=!0,i(document).off("keyup",s.keyup)}},t))},function(){r.close(s.loadi),r.msg("当前图片地址异常
是否继续查看下一张?",{time:3e4,btn:["下一张","不看了"],yes:function(){u.length>1&&s.imgnext(!0,!0)}})})}},o.run=function(t){i=t,n=i(e),l.html=i("html"),r.open=function(e){var t=new s(e);return t.index}},e.layui&&layui.define?(r.ready(),layui.define("jquery",function(t){r.path=layui.cache.dir,o.run(layui.$),e.layer=r,t("layer",r)})):"function"==typeof define&&define.amd?define(["jquery"],function(){return o.run(e.jQuery),r}):function(){o.run(e.jQuery),r.ready()}()}(window);
--------------------------------------------------------------------------------
/js/jquery.jqzoom-core.js:
--------------------------------------------------------------------------------
1 | /*!
2 | * jQzoom Evolution Library v2.3 - Javascript Image magnifier
3 | * http://www.mind-projects.it
4 | *
5 | * Copyright 2011, Engineer Marco Renzi
6 | * Licensed under the BSD license.
7 | *
8 | * Redistribution and use in source and binary forms, with or without
9 | * modification, are permitted provided that the following conditions are met:
10 | * * Redistributions of source code must retain the above copyright
11 | * notice, this list of conditions and the following disclaimer.
12 | * * Redistributions in binary form must reproduce the above copyright
13 | * notice, this list of conditions and the following disclaimer in the
14 | * documentation and/or other materials provided with the distribution.
15 | * * Neither the name of the organization nor the
16 | * names of its contributors may be used to endorse or promote products
17 | * derived from this software without specific prior written permission.
18 | *
19 | * Date: 03 May 2011 22:16:00
20 | */
21 | (function ($) {
22 | //GLOBAL VARIABLES
23 | var isIE6 = ($.browser.msie && $.browser.version < 7);
24 | var body = $(document.body);
25 | var window = $(window);
26 | var jqzoompluging_disabled = false; //disabilita globalmente il plugin
27 | $.fn.jqzoom = function (options) {
28 | return this.each(function () {
29 | var node = this.nodeName.toLowerCase();
30 | if (node == 'a') {
31 | new jqzoom(this, options);
32 | }
33 | });
34 | };
35 | jqzoom = function (el, options) {
36 | var api = null;
37 | api = $(el).data("jqzoom");
38 | if (api) return api;
39 | var obj = this;
40 | var settings = $.extend({}, $.jqzoom.defaults, options || {});
41 | obj.el = el;
42 | el.rel = $(el).attr('rel');
43 | //ANCHOR ELEMENT
44 | el.zoom_active = false;
45 | el.zoom_disabled = false; //to disable single zoom instance
46 | el.largeimageloading = false; //tell us if large image is loading
47 | el.largeimageloaded = false; //tell us if large image is loaded
48 | el.scale = {};
49 | el.timer = null;
50 | el.mousepos = {};
51 | el.mouseDown = false;
52 | $(el).css({
53 | 'outline-style': 'none',
54 | 'text-decoration': 'none'
55 | });
56 | //BASE IMAGE
57 | var img = $("img:eq(0)", el);
58 | el.title = $(el).attr('title');
59 | el.imagetitle = img.attr('title');
60 | var zoomtitle = ($.trim(el.title).length > 0) ? el.title : el.imagetitle;
61 | var smallimage = new Smallimage(img);
62 | var lens = new Lens();
63 | var stage = new Stage();
64 | var largeimage = new Largeimage();
65 | var loader = new Loader();
66 | //preventing default click,allowing the onclick event [exmple: lightbox]
67 | $(el).bind('click', function (e) {
68 | e.preventDefault();
69 | return false;
70 | });
71 | //setting the default zoomType if not in settings
72 | var zoomtypes = ['standard', 'drag', 'innerzoom', 'reverse'];
73 | if ($.inArray($.trim(settings.zoomType), zoomtypes) < 0) {
74 | settings.zoomType = 'standard';
75 | }
76 | $.extend(obj, {
77 | create: function () { //create the main objects
78 | //create ZoomPad
79 | if ($(".zoomPad", el).length == 0) {
80 | el.zoomPad = $('').addClass('zoomPad');
81 | img.wrap(el.zoomPad);
82 | }
83 | if(settings.zoomType == 'innerzoom'){
84 | settings.zoomWidth = smallimage.w;
85 | settings.zoomHeight = smallimage.h;
86 | }
87 | //creating ZoomPup
88 | if ($(".zoomPup", el).length == 0) {
89 | lens.append();
90 | }
91 | //creating zoomWindow
92 | if ($(".zoomWindow", el).length == 0) {
93 | stage.append();
94 | }
95 | //creating Preload
96 | if ($(".zoomPreload", el).length == 0) {
97 | loader.append();
98 | }
99 | //preloading images
100 | if (settings.preloadImages || settings.zoomType == 'drag' || settings.alwaysOn) {
101 | obj.load();
102 | }
103 | obj.init();
104 | },
105 | init: function () {
106 | //drag option
107 | if (settings.zoomType == 'drag') {
108 | $(".zoomPad", el).mousedown(function () {
109 | el.mouseDown = true;
110 | });
111 | $(".zoomPad", el).mouseup(function () {
112 | el.mouseDown = false;
113 | });
114 | document.body.ondragstart = function () {
115 | return false;
116 | };
117 | $(".zoomPad", el).css({
118 | cursor: 'default'
119 | });
120 | $(".zoomPup", el).css({
121 | cursor: 'move'
122 | });
123 | }
124 | if (settings.zoomType == 'innerzoom') {
125 | $(".zoomWrapper", el).css({
126 | cursor: 'crosshair'
127 | });
128 | }
129 | $(".zoomPad", el).bind('mouseenter mouseover', function (event) {
130 | img.attr('title', '');
131 | $(el).attr('title', '');
132 | el.zoom_active = true;
133 | //if loaded then activate else load large image
134 | smallimage.fetchdata();
135 | if (el.largeimageloaded) {
136 | obj.activate(event);
137 | } else {
138 | obj.load();
139 | }
140 | });
141 | $(".zoomPad", el).bind('mouseleave', function (event) {
142 | obj.deactivate();
143 | });
144 | $(".zoomPad", el).bind('mousemove', function (e) {
145 |
146 | //prevent fast mouse mevements not to fire the mouseout event
147 | if (e.pageX > smallimage.pos.r || e.pageX < smallimage.pos.l || e.pageY < smallimage.pos.t || e.pageY > smallimage.pos.b) {
148 | lens.setcenter();
149 | return false;
150 | }
151 | el.zoom_active = true;
152 | if (el.largeimageloaded && !$('.zoomWindow', el).is(':visible')) {
153 | obj.activate(e);
154 | }
155 | if (el.largeimageloaded && (settings.zoomType != 'drag' || (settings.zoomType == 'drag' && el.mouseDown))) {
156 | lens.setposition(e);
157 | }
158 | });
159 | var thumb_preload = new Array();
160 | var i = 0;
161 | //binding click event on thumbnails
162 | var thumblist = new Array();
163 | thumblist = $('a').filter(function () {
164 | var regex = new RegExp("gallery[\\s]*:[\\s]*'" + $.trim(el.rel) + "'", "i");
165 | var rel = $(this).attr('rel');
166 | if (regex.test(rel)) {
167 | return this;
168 | }
169 | });
170 | if (thumblist.length > 0) {
171 | //getting the first to the last
172 | var first = thumblist.splice(0, 1);
173 | thumblist.push(first);
174 | }
175 | thumblist.each(function () {
176 | //preloading thumbs
177 | if (settings.preloadImages) {
178 | var thumb_options = $.extend({}, eval("(" + $.trim($(this).attr('rel')) + ")"));
179 | thumb_preload[i] = new Image();
180 | thumb_preload[i].src = thumb_options.largeimage;
181 | i++;
182 | }
183 | $(this).click(function (e) {
184 | if($(this).hasClass('zoomThumbActive')){
185 | return false;
186 | }
187 | thumblist.each(function () {
188 | $(this).removeClass('zoomThumbActive');
189 | });
190 | e.preventDefault();
191 | obj.swapimage(this);
192 | return false;
193 | });
194 | });
195 | },
196 | load: function () {
197 | if (el.largeimageloaded == false && el.largeimageloading == false) {
198 | var url = $(el).attr('href');
199 | el.largeimageloading = true;
200 | largeimage.loadimage(url);
201 | }
202 | },
203 | activate: function (e) {
204 | clearTimeout(el.timer);
205 | //show lens and zoomWindow
206 | lens.show();
207 | stage.show();
208 | },
209 | deactivate: function (e) {
210 | switch (settings.zoomType) {
211 | case 'drag':
212 | //nothing or lens.setcenter();
213 | break;
214 | default:
215 | img.attr('title', el.imagetitle);
216 | $(el).attr('title', el.title);
217 | if (settings.alwaysOn) {
218 | lens.setcenter();
219 | } else {
220 | stage.hide();
221 | lens.hide();
222 | }
223 | break;
224 | }
225 | el.zoom_active = false;
226 | },
227 | swapimage: function (link) {
228 | el.largeimageloading = false;
229 | el.largeimageloaded = false;
230 | var options = new Object();
231 | options = $.extend({}, eval("(" + $.trim($(link).attr('rel')) + ")"));
232 | if (options.smallimage && options.largeimage) {
233 | var smallimage = options.smallimage;
234 | var largeimage = options.largeimage;
235 | $(link).addClass('zoomThumbActive');
236 | $(el).attr('href', largeimage);
237 | img.attr('src', smallimage);
238 | lens.hide();
239 | stage.hide();
240 | obj.load();
241 | } else {
242 | alert('ERROR :: Missing parameter for largeimage or smallimage.');
243 | throw 'ERROR :: Missing parameter for largeimage or smallimage.';
244 | }
245 | return false;
246 | }
247 | });
248 | //sometimes image is already loaded and onload will not fire
249 | if (img[0].complete) {
250 | //fetching data from sallimage if was previously loaded
251 | smallimage.fetchdata();
252 | if ($(".zoomPad", el).length == 0) obj.create();
253 | }
254 | /*========================================================,
255 | | Smallimage
256 | |---------------------------------------------------------:
257 | | Base image into the anchor element
258 | `========================================================*/
259 |
260 | function Smallimage(image) {
261 | var $obj = this;
262 | this.node = image[0];
263 | this.findborder = function () {
264 | var bordertop = 0;
265 | bordertop = image.css('border-top-width');
266 | btop = '';
267 | var borderleft = 0;
268 | borderleft = image.css('border-left-width');
269 | bleft = '';
270 | if (bordertop) {
271 | for (i = 0; i < 3; i++) {
272 | var x = [];
273 | x = bordertop.substr(i, 1);
274 | if (isNaN(x) == false) {
275 | btop = btop + '' + bordertop.substr(i, 1);
276 | } else {
277 | break;
278 | }
279 | }
280 | }
281 | if (borderleft) {
282 | for (i = 0; i < 3; i++) {
283 | if (!isNaN(borderleft.substr(i, 1))) {
284 | bleft = bleft + borderleft.substr(i, 1)
285 | } else {
286 | break;
287 | }
288 | }
289 | }
290 | $obj.btop = (btop.length > 0) ? eval(btop) : 0;
291 | $obj.bleft = (bleft.length > 0) ? eval(bleft) : 0;
292 | };
293 | this.fetchdata = function () {
294 | $obj.findborder();
295 | $obj.w = image.width();
296 | $obj.h = image.height();
297 | $obj.ow = image.outerWidth();
298 | $obj.oh = image.outerHeight();
299 | $obj.pos = image.offset();
300 | $obj.pos.l = image.offset().left + $obj.bleft;
301 | $obj.pos.t = image.offset().top + $obj.btop;
302 | $obj.pos.r = $obj.w + $obj.pos.l;
303 | $obj.pos.b = $obj.h + $obj.pos.t;
304 | $obj.rightlimit = image.offset().left + $obj.ow;
305 | $obj.bottomlimit = image.offset().top + $obj.oh;
306 |
307 | };
308 | this.node.onerror = function () {
309 | alert('Problems while loading image.');
310 | throw 'Problems while loading image.';
311 | };
312 | this.node.onload = function () {
313 | $obj.fetchdata();
314 | if ($(".zoomPad", el).length == 0) obj.create();
315 | };
316 | return $obj;
317 | };
318 | /*========================================================,
319 | | Loader
320 | |---------------------------------------------------------:
321 | | Show that the large image is loading
322 | `========================================================*/
323 |
324 | function Loader() {
325 | var $obj = this;
326 | this.append = function () {
327 | this.node = $('').addClass('zoomPreload').css('visibility', 'hidden').html(settings.preloadText);
328 | $('.zoomPad', el).append(this.node);
329 | };
330 | this.show = function () {
331 | this.node.top = (smallimage.oh - this.node.height()) / 2;
332 | this.node.left = (smallimage.ow - this.node.width()) / 2;
333 | //setting position
334 | this.node.css({
335 | top: this.node.top,
336 | left: this.node.left,
337 | position: 'absolute',
338 | visibility: 'visible'
339 | });
340 | };
341 | this.hide = function () {
342 | this.node.css('visibility', 'hidden');
343 | };
344 | return this;
345 | }
346 | /*========================================================,
347 | | Lens
348 | |---------------------------------------------------------:
349 | | Lens over the image
350 | `========================================================*/
351 |
352 | function Lens() {
353 | var $obj = this;
354 | this.node = $('').addClass('zoomPup');
355 | //this.nodeimgwrapper = $("").addClass('zoomPupImgWrapper');
356 | this.append = function () {
357 | $('.zoomPad', el).append($(this.node).hide());
358 | if (settings.zoomType == 'reverse') {
359 | this.image = new Image();
360 | this.image.src = smallimage.node.src; // fires off async
361 | $(this.node).empty().append(this.image);
362 | }
363 | };
364 | this.setdimensions = function () {
365 | this.node.w = (parseInt((settings.zoomWidth) / el.scale.x) > smallimage.w ) ? smallimage.w : (parseInt(settings.zoomWidth / el.scale.x));
366 | this.node.h = (parseInt((settings.zoomHeight) / el.scale.y) > smallimage.h ) ? smallimage.h : (parseInt(settings.zoomHeight / el.scale.y));
367 | this.node.top = (smallimage.oh - this.node.h - 2) / 2;
368 | this.node.left = (smallimage.ow - this.node.w - 2) / 2;
369 | //centering lens
370 | this.node.css({
371 | top: 0,
372 | left: 0,
373 | width: this.node.w + 'px',
374 | height: this.node.h + 'px',
375 | position: 'absolute',
376 | display: 'none',
377 | borderWidth: 1 + 'px'
378 | });
379 |
380 |
381 |
382 | if (settings.zoomType == 'reverse') {
383 | this.image.src = smallimage.node.src;
384 | $(this.node).css({
385 | 'opacity': 1
386 | });
387 |
388 | $(this.image).css({
389 | position: 'absolute',
390 | display: 'block',
391 | left: -(this.node.left + 1 - smallimage.bleft) + 'px',
392 | top: -(this.node.top + 1 - smallimage.btop) + 'px'
393 | });
394 |
395 | }
396 | };
397 | this.setcenter = function () {
398 | //calculating center position
399 | this.node.top = (smallimage.oh - this.node.h - 2) / 2;
400 | this.node.left = (smallimage.ow - this.node.w - 2) / 2;
401 | //centering lens
402 | this.node.css({
403 | top: this.node.top,
404 | left: this.node.left
405 | });
406 | if (settings.zoomType == 'reverse') {
407 | $(this.image).css({
408 | position: 'absolute',
409 | display: 'block',
410 | left: -(this.node.left + 1 - smallimage.bleft) + 'px',
411 | top: -(this.node.top + 1 - smallimage.btop) + 'px'
412 | });
413 |
414 | }
415 | //centering large image
416 | largeimage.setposition();
417 | };
418 | this.setposition = function (e) {
419 | el.mousepos.x = e.pageX;
420 | el.mousepos.y = e.pageY;
421 | var lensleft = 0;
422 | var lenstop = 0;
423 |
424 | function overleft(lens) {
425 | return el.mousepos.x - (lens.w) / 2 < smallimage.pos.l;
426 | }
427 |
428 | function overright(lens) {
429 | return el.mousepos.x + (lens.w) / 2 > smallimage.pos.r;
430 |
431 | }
432 |
433 | function overtop(lens) {
434 | return el.mousepos.y - (lens.h) / 2 < smallimage.pos.t;
435 | }
436 |
437 | function overbottom(lens) {
438 | return el.mousepos.y + (lens.h) / 2 > smallimage.pos.b;
439 | }
440 |
441 | lensleft = el.mousepos.x + smallimage.bleft - smallimage.pos.l - (this.node.w + 2) / 2;
442 | lenstop = el.mousepos.y + smallimage.btop - smallimage.pos.t - (this.node.h + 2) / 2;
443 | if (overleft(this.node)) {
444 | lensleft = smallimage.bleft - 1;
445 | } else if (overright(this.node)) {
446 | lensleft = smallimage.w + smallimage.bleft - this.node.w - 1;
447 | }
448 | if (overtop(this.node)) {
449 | lenstop = smallimage.btop - 1;
450 | } else if (overbottom(this.node)) {
451 | lenstop = smallimage.h + smallimage.btop - this.node.h - 1;
452 | }
453 |
454 | this.node.left = lensleft;
455 | this.node.top = lenstop;
456 | this.node.css({
457 | 'left': lensleft + 'px',
458 | 'top': lenstop + 'px'
459 | });
460 | if (settings.zoomType == 'reverse') {
461 | if ($.browser.msie && $.browser.version > 7) {
462 | $(this.node).empty().append(this.image);
463 | }
464 |
465 | $(this.image).css({
466 | position: 'absolute',
467 | display: 'block',
468 | left: -(this.node.left + 1 - smallimage.bleft) + 'px',
469 | top: -(this.node.top + 1 - smallimage.btop) + 'px'
470 | });
471 | }
472 |
473 | largeimage.setposition();
474 | };
475 | this.hide = function () {
476 | img.css({
477 | 'opacity': 1
478 | });
479 | this.node.hide();
480 | };
481 | this.show = function () {
482 |
483 | if (settings.zoomType != 'innerzoom' && (settings.lens || settings.zoomType == 'drag')) {
484 | this.node.show();
485 | }
486 |
487 | if (settings.zoomType == 'reverse') {
488 | img.css({
489 | 'opacity': settings.imageOpacity
490 | });
491 | }
492 | };
493 | this.getoffset = function () {
494 | var o = {};
495 | o.left = $obj.node.left;
496 | o.top = $obj.node.top;
497 | return o;
498 | };
499 | return this;
500 | };
501 | /*========================================================,
502 | | Stage
503 | |---------------------------------------------------------:
504 | | Window area that contains the large image
505 | `========================================================*/
506 |
507 | function Stage() {
508 | var $obj = this;
509 | this.node = $("");
510 | this.ieframe = $('');
511 | this.setposition = function () {
512 | this.node.leftpos = 0;
513 | this.node.toppos = 0;
514 | if (settings.zoomType != 'innerzoom') {
515 | //positioning
516 | switch (settings.position) {
517 | case "left":
518 | this.node.leftpos = (smallimage.pos.l - smallimage.bleft - Math.abs(settings.xOffset) - settings.zoomWidth > 0) ? (0 - settings.zoomWidth - Math.abs(settings.xOffset)) : (smallimage.ow + Math.abs(settings.xOffset));
519 | this.node.toppos = Math.abs(settings.yOffset);
520 | break;
521 | case "top":
522 | this.node.leftpos = Math.abs(settings.xOffset);
523 | this.node.toppos = (smallimage.pos.t - smallimage.btop - Math.abs(settings.yOffset) - settings.zoomHeight > 0) ? (0 - settings.zoomHeight - Math.abs(settings.yOffset)) : (smallimage.oh + Math.abs(settings.yOffset));
524 | break;
525 | case "bottom":
526 | this.node.leftpos = Math.abs(settings.xOffset);
527 | this.node.toppos = (smallimage.pos.t - smallimage.btop + smallimage.oh + Math.abs(settings.yOffset) + settings.zoomHeight < screen.height) ? (smallimage.oh + Math.abs(settings.yOffset)) : (0 - settings.zoomHeight - Math.abs(settings.yOffset));
528 | break;
529 | default:
530 | this.node.leftpos = (smallimage.rightlimit + Math.abs(settings.xOffset) + settings.zoomWidth < screen.width) ? (smallimage.ow + Math.abs(settings.xOffset)) : (0 - settings.zoomWidth - Math.abs(settings.xOffset));
531 | this.node.toppos = Math.abs(settings.yOffset);
532 | break;
533 | }
534 | }
535 | this.node.css({
536 | 'left': this.node.leftpos + 'px',
537 | 'top': this.node.toppos + 'px'
538 | });
539 | return this;
540 | };
541 | this.append = function () {
542 | $('.zoomPad', el).append(this.node);
543 | this.node.css({
544 | position: 'absolute',
545 | display: 'none',
546 | zIndex: 5001
547 | });
548 | if (settings.zoomType == 'innerzoom') {
549 | this.node.css({
550 | cursor: 'default'
551 | });
552 | var thickness = (smallimage.bleft == 0) ? 1 : smallimage.bleft;
553 | $('.zoomWrapper', this.node).css({
554 | borderWidth: thickness + 'px'
555 | });
556 | }
557 |
558 | $('.zoomWrapper', this.node).css({
559 | width: Math.round(settings.zoomWidth) + 'px' ,
560 | borderWidth: thickness + 'px'
561 | });
562 | $('.zoomWrapperImage', this.node).css({
563 | width: '100%',
564 | height: Math.round(settings.zoomHeight) + 'px'
565 | });
566 | //zoom title
567 | $('.zoomWrapperTitle', this.node).css({
568 | width: '100%',
569 | position: 'absolute'
570 | });
571 |
572 | $('.zoomWrapperTitle', this.node).hide();
573 | if (settings.title && zoomtitle.length > 0) {
574 | $('.zoomWrapperTitle', this.node).html(zoomtitle).show();
575 | }
576 | $obj.setposition();
577 | };
578 | this.hide = function () {
579 | switch (settings.hideEffect) {
580 | case 'fadeout':
581 | this.node.fadeOut(settings.fadeoutSpeed, function () {});
582 | break;
583 | default:
584 | this.node.hide();
585 | break;
586 | }
587 | this.ieframe.hide();
588 | };
589 | this.show = function () {
590 | switch (settings.showEffect) {
591 | case 'fadein':
592 | this.node.fadeIn();
593 | this.node.fadeIn(settings.fadeinSpeed, function () {});
594 | break;
595 | default:
596 | this.node.show();
597 | break;
598 | }
599 | if (isIE6 && settings.zoomType != 'innerzoom') {
600 | this.ieframe.width = this.node.width();
601 | this.ieframe.height = this.node.height();
602 | this.ieframe.left = this.node.leftpos;
603 | this.ieframe.top = this.node.toppos;
604 | this.ieframe.css({
605 | display: 'block',
606 | position: "absolute",
607 | left: this.ieframe.left,
608 | top: this.ieframe.top,
609 | zIndex: 99,
610 | width: this.ieframe.width + 'px',
611 | height: this.ieframe.height + 'px'
612 | });
613 | $('.zoomPad', el).append(this.ieframe);
614 | this.ieframe.show();
615 | };
616 | };
617 | };
618 | /*========================================================,
619 | | LargeImage
620 | |---------------------------------------------------------:
621 | | The large detailed image
622 | `========================================================*/
623 |
624 | function Largeimage() {
625 | var $obj = this;
626 | this.node = new Image();
627 | this.loadimage = function (url) {
628 | //showing preload
629 | loader.show();
630 | this.url = url;
631 | this.node.style.position = 'absolute';
632 | this.node.style.border = '0px';
633 | this.node.style.display = 'none';
634 | this.node.style.left = '-5000px';
635 | this.node.style.top = '0px';
636 | document.body.appendChild(this.node);
637 | this.node.src = url; // fires off async
638 | };
639 | this.fetchdata = function () {
640 | var image = $(this.node);
641 | var scale = {};
642 | this.node.style.display = 'block';
643 | $obj.w = image.width();
644 | $obj.h = image.height();
645 | $obj.pos = image.offset();
646 | $obj.pos.l = image.offset().left;
647 | $obj.pos.t = image.offset().top;
648 | $obj.pos.r = $obj.w + $obj.pos.l;
649 | $obj.pos.b = $obj.h + $obj.pos.t;
650 | scale.x = ($obj.w / smallimage.w);
651 | scale.y = ($obj.h / smallimage.h);
652 | el.scale = scale;
653 | document.body.removeChild(this.node);
654 | $('.zoomWrapperImage', el).empty().append(this.node);
655 | //setting lens dimensions;
656 | lens.setdimensions();
657 | };
658 | this.node.onerror = function () {
659 | alert('Problems while loading the big image.');
660 | throw 'Problems while loading the big image.';
661 | };
662 | this.node.onload = function () {
663 | //fetching data
664 | $obj.fetchdata();
665 | loader.hide();
666 | el.largeimageloading = false;
667 | el.largeimageloaded = true;
668 | if (settings.zoomType == 'drag' || settings.alwaysOn) {
669 | lens.show();
670 | stage.show();
671 | lens.setcenter();
672 | }
673 | };
674 | this.setposition = function () {
675 | var left = -el.scale.x * (lens.getoffset().left - smallimage.bleft + 1);
676 | var top = -el.scale.y * (lens.getoffset().top - smallimage.btop + 1);
677 | $(this.node).css({
678 | 'left': left + 'px',
679 | 'top': top + 'px'
680 | });
681 | };
682 | return this;
683 | };
684 | $(el).data("jqzoom", obj);
685 | };
686 | //es. $.jqzoom.disable('#jqzoom1');
687 | $.jqzoom = {
688 | defaults: {
689 | zoomType: 'standard',
690 | //innerzoom/standard/reverse/drag
691 | zoomWidth: 300,
692 | //zoomWindow default width
693 | zoomHeight: 300,
694 | //zoomWindow default height
695 | xOffset: 10,
696 | //zoomWindow x offset, can be negative(more on the left) or positive(more on the right)
697 | yOffset: 0,
698 | //zoomWindow y offset, can be negative(more on the left) or positive(more on the right)
699 | position: "right",
700 | //zoomWindow default position
701 | preloadImages: true,
702 | //image preload
703 | preloadText: 'Loading zoom',
704 | title: true,
705 | lens: true,
706 | imageOpacity: 0.4,
707 | alwaysOn: false,
708 | showEffect: 'show',
709 | //show/fadein
710 | hideEffect: 'hide',
711 | //hide/fadeout
712 | fadeinSpeed: 'slow',
713 | //fast/slow/number
714 | fadeoutSpeed: '2000' //fast/slow/number
715 | },
716 | disable: function (el) {
717 | var api = $(el).data('jqzoom');
718 | api.disable();
719 | return false;
720 | },
721 | enable: function (el) {
722 | var api = $(el).data('jqzoom');
723 | api.enable();
724 | return false;
725 | },
726 | disableAll: function (el) {
727 | jqzoompluging_disabled = true;
728 | },
729 | enableAll: function (el) {
730 | jqzoompluging_disabled = false;
731 | }
732 | };
733 | })(jQuery);
--------------------------------------------------------------------------------
/js/jquery-ui.css:
--------------------------------------------------------------------------------
1 | /*! jQuery UI - v1.12.1 - 2017-10-08
2 | * http://jqueryui.com
3 | * Includes: draggable.css, core.css, resizable.css, selectable.css, sortable.css, accordion.css, autocomplete.css, menu.css, button.css, controlgroup.css, checkboxradio.css, datepicker.css, dialog.css, progressbar.css, selectmenu.css, slider.css, spinner.css, tabs.css, tooltip.css, theme.css
4 | * To view and modify this theme, visit http://jqueryui.com/themeroller/?scope=&folderName=base&cornerRadiusShadow=8px&offsetLeftShadow=0px&offsetTopShadow=0px&thicknessShadow=5px&opacityShadow=30&bgImgOpacityShadow=0&bgTextureShadow=flat&bgColorShadow=666666&opacityOverlay=30&bgImgOpacityOverlay=0&bgTextureOverlay=flat&bgColorOverlay=aaaaaa&iconColorError=cc0000&fcError=5f3f3f&borderColorError=f1a899&bgTextureError=flat&bgColorError=fddfdf&iconColorHighlight=777620&fcHighlight=777620&borderColorHighlight=dad55e&bgTextureHighlight=flat&bgColorHighlight=fffa90&iconColorActive=ffffff&fcActive=ffffff&borderColorActive=003eff&bgTextureActive=flat&bgColorActive=007fff&iconColorHover=555555&fcHover=2b2b2b&borderColorHover=cccccc&bgTextureHover=flat&bgColorHover=ededed&iconColorDefault=777777&fcDefault=454545&borderColorDefault=c5c5c5&bgTextureDefault=flat&bgColorDefault=f6f6f6&iconColorContent=444444&fcContent=333333&borderColorContent=dddddd&bgTextureContent=flat&bgColorContent=ffffff&iconColorHeader=444444&fcHeader=333333&borderColorHeader=dddddd&bgTextureHeader=flat&bgColorHeader=e9e9e9&cornerRadius=3px&fwDefault=normal&fsDefault=1em&ffDefault=Arial%2CHelvetica%2Csans-serif
5 | * Copyright jQuery Foundation and other contributors; Licensed MIT */
6 |
7 | .ui-draggable-handle {
8 | -ms-touch-action: none;
9 | touch-action: none;
10 | }
11 | /* Layout helpers
12 | ----------------------------------*/
13 | .ui-helper-hidden {
14 | display: none;
15 | }
16 | .ui-helper-hidden-accessible {
17 | border: 0;
18 | clip: rect(0 0 0 0);
19 | height: 1px;
20 | margin: -1px;
21 | overflow: hidden;
22 | padding: 0;
23 | position: absolute;
24 | width: 1px;
25 | }
26 | .ui-helper-reset {
27 | margin: 0;
28 | padding: 0;
29 | border: 0;
30 | outline: 0;
31 | line-height: 1.3;
32 | text-decoration: none;
33 | font-size: 100%;
34 | list-style: none;
35 | }
36 | .ui-helper-clearfix:before,
37 | .ui-helper-clearfix:after {
38 | content: "";
39 | display: table;
40 | border-collapse: collapse;
41 | }
42 | .ui-helper-clearfix:after {
43 | clear: both;
44 | }
45 | .ui-helper-zfix {
46 | width: 100%;
47 | height: 100%;
48 | top: 0;
49 | left: 0;
50 | position: absolute;
51 | opacity: 0;
52 | filter:Alpha(Opacity=0); /* support: IE8 */
53 | }
54 |
55 | .ui-front {
56 | z-index: 100;
57 | }
58 |
59 |
60 | /* Interaction Cues
61 | ----------------------------------*/
62 | .ui-state-disabled {
63 | cursor: default !important;
64 | pointer-events: none;
65 | }
66 |
67 |
68 | /* Icons
69 | ----------------------------------*/
70 | .ui-icon {
71 | display: inline-block;
72 | vertical-align: middle;
73 | margin-top: -.25em;
74 | position: relative;
75 | text-indent: -99999px;
76 | overflow: hidden;
77 | background-repeat: no-repeat;
78 | }
79 |
80 | .ui-widget-icon-block {
81 | left: 50%;
82 | margin-left: -8px;
83 | display: block;
84 | }
85 |
86 | /* Misc visuals
87 | ----------------------------------*/
88 |
89 | /* Overlays */
90 | .ui-widget-overlay {
91 | position: fixed;
92 | top: 0;
93 | left: 0;
94 | width: 100%;
95 | height: 100%;
96 | }
97 | .ui-resizable {
98 | position: relative;
99 | }
100 | .ui-resizable-handle {
101 | position: absolute;
102 | font-size: 0.1px;
103 | display: block;
104 | -ms-touch-action: none;
105 | touch-action: none;
106 | }
107 | .ui-resizable-disabled .ui-resizable-handle,
108 | .ui-resizable-autohide .ui-resizable-handle {
109 | display: none;
110 | }
111 | .ui-resizable-n {
112 | cursor: n-resize;
113 | height: 7px;
114 | width: 100%;
115 | top: -5px;
116 | left: 0;
117 | }
118 | .ui-resizable-s {
119 | cursor: s-resize;
120 | height: 7px;
121 | width: 100%;
122 | bottom: -5px;
123 | left: 0;
124 | }
125 | .ui-resizable-e {
126 | cursor: e-resize;
127 | width: 7px;
128 | right: -5px;
129 | top: 0;
130 | height: 100%;
131 | }
132 | .ui-resizable-w {
133 | cursor: w-resize;
134 | width: 7px;
135 | left: -5px;
136 | top: 0;
137 | height: 100%;
138 | }
139 | .ui-resizable-se {
140 | cursor: se-resize;
141 | width: 12px;
142 | height: 12px;
143 | right: 1px;
144 | bottom: 1px;
145 | }
146 | .ui-resizable-sw {
147 | cursor: sw-resize;
148 | width: 9px;
149 | height: 9px;
150 | left: -5px;
151 | bottom: -5px;
152 | }
153 | .ui-resizable-nw {
154 | cursor: nw-resize;
155 | width: 9px;
156 | height: 9px;
157 | left: -5px;
158 | top: -5px;
159 | }
160 | .ui-resizable-ne {
161 | cursor: ne-resize;
162 | width: 9px;
163 | height: 9px;
164 | right: -5px;
165 | top: -5px;
166 | }
167 | .ui-selectable {
168 | -ms-touch-action: none;
169 | touch-action: none;
170 | }
171 | .ui-selectable-helper {
172 | position: absolute;
173 | z-index: 100;
174 | border: 1px dotted black;
175 | }
176 | .ui-sortable-handle {
177 | -ms-touch-action: none;
178 | touch-action: none;
179 | }
180 | .ui-accordion .ui-accordion-header {
181 | display: block;
182 | cursor: pointer;
183 | position: relative;
184 | margin: 2px 0 0 0;
185 | padding: .5em .5em .5em .7em;
186 | font-size: 100%;
187 | }
188 | .ui-accordion .ui-accordion-content {
189 | padding: 1em 2.2em;
190 | border-top: 0;
191 | overflow: auto;
192 | }
193 | .ui-autocomplete {
194 | position: absolute;
195 | top: 0;
196 | left: 0;
197 | cursor: default;
198 | }
199 | .ui-menu {
200 | list-style: none;
201 | padding: 0;
202 | margin: 0;
203 | display: block;
204 | outline: 0;
205 | }
206 | .ui-menu .ui-menu {
207 | position: absolute;
208 | }
209 | .ui-menu .ui-menu-item {
210 | margin: 0;
211 | cursor: pointer;
212 | /* support: IE10, see #8844 */
213 | list-style-image: url("");
214 | }
215 | .ui-menu .ui-menu-item-wrapper {
216 | position: relative;
217 | padding: 3px 1em 3px .4em;
218 | }
219 | .ui-menu .ui-menu-divider {
220 | margin: 5px 0;
221 | height: 0;
222 | font-size: 0;
223 | line-height: 0;
224 | border-width: 1px 0 0 0;
225 | }
226 | .ui-menu .ui-state-focus,
227 | .ui-menu .ui-state-active {
228 | margin: -1px;
229 | }
230 |
231 | /* icon support */
232 | .ui-menu-icons {
233 | position: relative;
234 | }
235 | .ui-menu-icons .ui-menu-item-wrapper {
236 | padding-left: 2em;
237 | }
238 |
239 | /* left-aligned */
240 | .ui-menu .ui-icon {
241 | position: absolute;
242 | top: 0;
243 | bottom: 0;
244 | left: .2em;
245 | margin: auto 0;
246 | }
247 |
248 | /* right-aligned */
249 | .ui-menu .ui-menu-icon {
250 | left: auto;
251 | right: 0;
252 | }
253 | .ui-button {
254 | padding: .4em 1em;
255 | display: inline-block;
256 | position: relative;
257 | line-height: normal;
258 | margin-right: .1em;
259 | cursor: pointer;
260 | vertical-align: middle;
261 | text-align: center;
262 | -webkit-user-select: none;
263 | -moz-user-select: none;
264 | -ms-user-select: none;
265 | user-select: none;
266 |
267 | /* Support: IE <= 11 */
268 | overflow: visible;
269 | }
270 |
271 | .ui-button,
272 | .ui-button:link,
273 | .ui-button:visited,
274 | .ui-button:hover,
275 | .ui-button:active {
276 | text-decoration: none;
277 | }
278 |
279 | /* to make room for the icon, a width needs to be set here */
280 | .ui-button-icon-only {
281 | width: 2em;
282 | box-sizing: border-box;
283 | text-indent: -9999px;
284 | white-space: nowrap;
285 | }
286 |
287 | /* no icon support for input elements */
288 | input.ui-button.ui-button-icon-only {
289 | text-indent: 0;
290 | }
291 |
292 | /* button icon element(s) */
293 | .ui-button-icon-only .ui-icon {
294 | position: absolute;
295 | top: 50%;
296 | left: 50%;
297 | margin-top: -8px;
298 | margin-left: -8px;
299 | }
300 |
301 | .ui-button.ui-icon-notext .ui-icon {
302 | padding: 0;
303 | width: 2.1em;
304 | height: 2.1em;
305 | text-indent: -9999px;
306 | white-space: nowrap;
307 |
308 | }
309 |
310 | input.ui-button.ui-icon-notext .ui-icon {
311 | width: auto;
312 | height: auto;
313 | text-indent: 0;
314 | white-space: normal;
315 | padding: .4em 1em;
316 | }
317 |
318 | /* workarounds */
319 | /* Support: Firefox 5 - 40 */
320 | input.ui-button::-moz-focus-inner,
321 | button.ui-button::-moz-focus-inner {
322 | border: 0;
323 | padding: 0;
324 | }
325 | .ui-controlgroup {
326 | vertical-align: middle;
327 | display: inline-block;
328 | }
329 | .ui-controlgroup > .ui-controlgroup-item {
330 | float: left;
331 | margin-left: 0;
332 | margin-right: 0;
333 | }
334 | .ui-controlgroup > .ui-controlgroup-item:focus,
335 | .ui-controlgroup > .ui-controlgroup-item.ui-visual-focus {
336 | z-index: 9999;
337 | }
338 | .ui-controlgroup-vertical > .ui-controlgroup-item {
339 | display: block;
340 | float: none;
341 | width: 100%;
342 | margin-top: 0;
343 | margin-bottom: 0;
344 | text-align: left;
345 | }
346 | .ui-controlgroup-vertical .ui-controlgroup-item {
347 | box-sizing: border-box;
348 | }
349 | .ui-controlgroup .ui-controlgroup-label {
350 | padding: .4em 1em;
351 | }
352 | .ui-controlgroup .ui-controlgroup-label span {
353 | font-size: 80%;
354 | }
355 | .ui-controlgroup-horizontal .ui-controlgroup-label + .ui-controlgroup-item {
356 | border-left: none;
357 | }
358 | .ui-controlgroup-vertical .ui-controlgroup-label + .ui-controlgroup-item {
359 | border-top: none;
360 | }
361 | .ui-controlgroup-horizontal .ui-controlgroup-label.ui-widget-content {
362 | border-right: none;
363 | }
364 | .ui-controlgroup-vertical .ui-controlgroup-label.ui-widget-content {
365 | border-bottom: none;
366 | }
367 |
368 | /* Spinner specific style fixes */
369 | .ui-controlgroup-vertical .ui-spinner-input {
370 |
371 | /* Support: IE8 only, Android < 4.4 only */
372 | width: 75%;
373 | width: calc( 100% - 2.4em );
374 | }
375 | .ui-controlgroup-vertical .ui-spinner .ui-spinner-up {
376 | border-top-style: solid;
377 | }
378 |
379 | .ui-checkboxradio-label .ui-icon-background {
380 | box-shadow: inset 1px 1px 1px #ccc;
381 | border-radius: .12em;
382 | border: none;
383 | }
384 | .ui-checkboxradio-radio-label .ui-icon-background {
385 | width: 16px;
386 | height: 16px;
387 | border-radius: 1em;
388 | overflow: visible;
389 | border: none;
390 | }
391 | .ui-checkboxradio-radio-label.ui-checkboxradio-checked .ui-icon,
392 | .ui-checkboxradio-radio-label.ui-checkboxradio-checked:hover .ui-icon {
393 | background-image: none;
394 | width: 8px;
395 | height: 8px;
396 | border-width: 4px;
397 | border-style: solid;
398 | }
399 | .ui-checkboxradio-disabled {
400 | pointer-events: none;
401 | }
402 | .ui-datepicker {
403 | width: 17em;
404 | padding: .2em .2em 0;
405 | display: none;
406 | }
407 | .ui-datepicker .ui-datepicker-header {
408 | position: relative;
409 | padding: .2em 0;
410 | }
411 | .ui-datepicker .ui-datepicker-prev,
412 | .ui-datepicker .ui-datepicker-next {
413 | position: absolute;
414 | top: 2px;
415 | width: 1.8em;
416 | height: 1.8em;
417 | }
418 | .ui-datepicker .ui-datepicker-prev-hover,
419 | .ui-datepicker .ui-datepicker-next-hover {
420 | top: 1px;
421 | }
422 | .ui-datepicker .ui-datepicker-prev {
423 | left: 2px;
424 | }
425 | .ui-datepicker .ui-datepicker-next {
426 | right: 2px;
427 | }
428 | .ui-datepicker .ui-datepicker-prev-hover {
429 | left: 1px;
430 | }
431 | .ui-datepicker .ui-datepicker-next-hover {
432 | right: 1px;
433 | }
434 | .ui-datepicker .ui-datepicker-prev span,
435 | .ui-datepicker .ui-datepicker-next span {
436 | display: block;
437 | position: absolute;
438 | left: 50%;
439 | margin-left: -8px;
440 | top: 50%;
441 | margin-top: -8px;
442 | }
443 | .ui-datepicker .ui-datepicker-title {
444 | margin: 0 2.3em;
445 | line-height: 1.8em;
446 | text-align: center;
447 | }
448 | .ui-datepicker .ui-datepicker-title select {
449 | font-size: 1em;
450 | margin: 1px 0;
451 | }
452 | .ui-datepicker select.ui-datepicker-month,
453 | .ui-datepicker select.ui-datepicker-year {
454 | width: 45%;
455 | }
456 | .ui-datepicker table {
457 | width: 100%;
458 | font-size: .9em;
459 | border-collapse: collapse;
460 | margin: 0 0 .4em;
461 | }
462 | .ui-datepicker th {
463 | padding: .7em .3em;
464 | text-align: center;
465 | font-weight: bold;
466 | border: 0;
467 | }
468 | .ui-datepicker td {
469 | border: 0;
470 | padding: 1px;
471 | }
472 | .ui-datepicker td span,
473 | .ui-datepicker td a {
474 | display: block;
475 | padding: .2em;
476 | text-align: right;
477 | text-decoration: none;
478 | }
479 | .ui-datepicker .ui-datepicker-buttonpane {
480 | background-image: none;
481 | margin: .7em 0 0 0;
482 | padding: 0 .2em;
483 | border-left: 0;
484 | border-right: 0;
485 | border-bottom: 0;
486 | }
487 | .ui-datepicker .ui-datepicker-buttonpane button {
488 | float: right;
489 | margin: .5em .2em .4em;
490 | cursor: pointer;
491 | padding: .2em .6em .3em .6em;
492 | width: auto;
493 | overflow: visible;
494 | }
495 | .ui-datepicker .ui-datepicker-buttonpane button.ui-datepicker-current {
496 | float: left;
497 | }
498 |
499 | /* with multiple calendars */
500 | .ui-datepicker.ui-datepicker-multi {
501 | width: auto;
502 | }
503 | .ui-datepicker-multi .ui-datepicker-group {
504 | float: left;
505 | }
506 | .ui-datepicker-multi .ui-datepicker-group table {
507 | width: 95%;
508 | margin: 0 auto .4em;
509 | }
510 | .ui-datepicker-multi-2 .ui-datepicker-group {
511 | width: 50%;
512 | }
513 | .ui-datepicker-multi-3 .ui-datepicker-group {
514 | width: 33.3%;
515 | }
516 | .ui-datepicker-multi-4 .ui-datepicker-group {
517 | width: 25%;
518 | }
519 | .ui-datepicker-multi .ui-datepicker-group-last .ui-datepicker-header,
520 | .ui-datepicker-multi .ui-datepicker-group-middle .ui-datepicker-header {
521 | border-left-width: 0;
522 | }
523 | .ui-datepicker-multi .ui-datepicker-buttonpane {
524 | clear: left;
525 | }
526 | .ui-datepicker-row-break {
527 | clear: both;
528 | width: 100%;
529 | font-size: 0;
530 | }
531 |
532 | /* RTL support */
533 | .ui-datepicker-rtl {
534 | direction: rtl;
535 | }
536 | .ui-datepicker-rtl .ui-datepicker-prev {
537 | right: 2px;
538 | left: auto;
539 | }
540 | .ui-datepicker-rtl .ui-datepicker-next {
541 | left: 2px;
542 | right: auto;
543 | }
544 | .ui-datepicker-rtl .ui-datepicker-prev:hover {
545 | right: 1px;
546 | left: auto;
547 | }
548 | .ui-datepicker-rtl .ui-datepicker-next:hover {
549 | left: 1px;
550 | right: auto;
551 | }
552 | .ui-datepicker-rtl .ui-datepicker-buttonpane {
553 | clear: right;
554 | }
555 | .ui-datepicker-rtl .ui-datepicker-buttonpane button {
556 | float: left;
557 | }
558 | .ui-datepicker-rtl .ui-datepicker-buttonpane button.ui-datepicker-current,
559 | .ui-datepicker-rtl .ui-datepicker-group {
560 | float: right;
561 | }
562 | .ui-datepicker-rtl .ui-datepicker-group-last .ui-datepicker-header,
563 | .ui-datepicker-rtl .ui-datepicker-group-middle .ui-datepicker-header {
564 | border-right-width: 0;
565 | border-left-width: 1px;
566 | }
567 |
568 | /* Icons */
569 | .ui-datepicker .ui-icon {
570 | display: block;
571 | text-indent: -99999px;
572 | overflow: hidden;
573 | background-repeat: no-repeat;
574 | left: .5em;
575 | top: .3em;
576 | }
577 | .ui-dialog {
578 | position: absolute;
579 | top: 0;
580 | left: 0;
581 | padding: .2em;
582 | outline: 0;
583 | }
584 | .ui-dialog .ui-dialog-titlebar {
585 | padding: .4em 1em;
586 | position: relative;
587 | }
588 | .ui-dialog .ui-dialog-title {
589 | float: left;
590 | margin: .1em 0;
591 | white-space: nowrap;
592 | width: 90%;
593 | overflow: hidden;
594 | text-overflow: ellipsis;
595 | }
596 | .ui-dialog .ui-dialog-titlebar-close {
597 | position: absolute;
598 | right: .3em;
599 | top: 50%;
600 | width: 20px;
601 | margin: -10px 0 0 0;
602 | padding: 1px;
603 | height: 20px;
604 | }
605 | .ui-dialog .ui-dialog-content {
606 | position: relative;
607 | border: 0;
608 | padding: .5em 1em;
609 | background: none;
610 | overflow: auto;
611 | }
612 | .ui-dialog .ui-dialog-buttonpane {
613 | text-align: left;
614 | border-width: 1px 0 0 0;
615 | background-image: none;
616 | margin-top: .5em;
617 | padding: .3em 1em .5em .4em;
618 | }
619 | .ui-dialog .ui-dialog-buttonpane .ui-dialog-buttonset {
620 | float: right;
621 | }
622 | .ui-dialog .ui-dialog-buttonpane button {
623 | margin: .5em .4em .5em 0;
624 | cursor: pointer;
625 | }
626 | .ui-dialog .ui-resizable-n {
627 | height: 2px;
628 | top: 0;
629 | }
630 | .ui-dialog .ui-resizable-e {
631 | width: 2px;
632 | right: 0;
633 | }
634 | .ui-dialog .ui-resizable-s {
635 | height: 2px;
636 | bottom: 0;
637 | }
638 | .ui-dialog .ui-resizable-w {
639 | width: 2px;
640 | left: 0;
641 | }
642 | .ui-dialog .ui-resizable-se,
643 | .ui-dialog .ui-resizable-sw,
644 | .ui-dialog .ui-resizable-ne,
645 | .ui-dialog .ui-resizable-nw {
646 | width: 7px;
647 | height: 7px;
648 | }
649 | .ui-dialog .ui-resizable-se {
650 | right: 0;
651 | bottom: 0;
652 | }
653 | .ui-dialog .ui-resizable-sw {
654 | left: 0;
655 | bottom: 0;
656 | }
657 | .ui-dialog .ui-resizable-ne {
658 | right: 0;
659 | top: 0;
660 | }
661 | .ui-dialog .ui-resizable-nw {
662 | left: 0;
663 | top: 0;
664 | }
665 | .ui-draggable .ui-dialog-titlebar {
666 | cursor: move;
667 | }
668 | .ui-progressbar {
669 | height: 2em;
670 | text-align: left;
671 | overflow: hidden;
672 | }
673 | .ui-progressbar .ui-progressbar-value {
674 | margin: -1px;
675 | height: 100%;
676 | }
677 | .ui-progressbar .ui-progressbar-overlay {
678 | background: url("");
679 | height: 100%;
680 | filter: alpha(opacity=25); /* support: IE8 */
681 | opacity: 0.25;
682 | }
683 | .ui-progressbar-indeterminate .ui-progressbar-value {
684 | background-image: none;
685 | }
686 | .ui-selectmenu-menu {
687 | padding: 0;
688 | margin: 0;
689 | position: absolute;
690 | top: 0;
691 | left: 0;
692 | display: none;
693 | }
694 | .ui-selectmenu-menu .ui-menu {
695 | overflow: auto;
696 | overflow-x: hidden;
697 | padding-bottom: 1px;
698 | }
699 | .ui-selectmenu-menu .ui-menu .ui-selectmenu-optgroup {
700 | font-size: 1em;
701 | font-weight: bold;
702 | line-height: 1.5;
703 | padding: 2px 0.4em;
704 | margin: 0.5em 0 0 0;
705 | height: auto;
706 | border: 0;
707 | }
708 | .ui-selectmenu-open {
709 | display: block;
710 | }
711 | .ui-selectmenu-text {
712 | display: block;
713 | margin-right: 20px;
714 | overflow: hidden;
715 | text-overflow: ellipsis;
716 | }
717 | .ui-selectmenu-button.ui-button {
718 | text-align: left;
719 | white-space: nowrap;
720 | width: 14em;
721 | }
722 | .ui-selectmenu-icon.ui-icon {
723 | float: right;
724 | margin-top: 0;
725 | }
726 | .ui-slider {
727 | position: relative;
728 | text-align: left;
729 | }
730 | .ui-slider .ui-slider-handle {
731 | position: absolute;
732 | z-index: 2;
733 | width: 1.2em;
734 | height: 1.2em;
735 | cursor: default;
736 | -ms-touch-action: none;
737 | touch-action: none;
738 | }
739 | .ui-slider .ui-slider-range {
740 | position: absolute;
741 | z-index: 1;
742 | font-size: .7em;
743 | display: block;
744 | border: 0;
745 | background-position: 0 0;
746 | }
747 |
748 | /* support: IE8 - See #6727 */
749 | .ui-slider.ui-state-disabled .ui-slider-handle,
750 | .ui-slider.ui-state-disabled .ui-slider-range {
751 | filter: inherit;
752 | }
753 |
754 | .ui-slider-horizontal {
755 | height: .8em;
756 | }
757 | .ui-slider-horizontal .ui-slider-handle {
758 | top: -.3em;
759 | margin-left: -.6em;
760 | }
761 | .ui-slider-horizontal .ui-slider-range {
762 | top: 0;
763 | height: 100%;
764 | }
765 | .ui-slider-horizontal .ui-slider-range-min {
766 | left: 0;
767 | }
768 | .ui-slider-horizontal .ui-slider-range-max {
769 | right: 0;
770 | }
771 |
772 | .ui-slider-vertical {
773 | width: .8em;
774 | height: 100px;
775 | }
776 | .ui-slider-vertical .ui-slider-handle {
777 | left: -.3em;
778 | margin-left: 0;
779 | margin-bottom: -.6em;
780 | }
781 | .ui-slider-vertical .ui-slider-range {
782 | left: 0;
783 | width: 100%;
784 | }
785 | .ui-slider-vertical .ui-slider-range-min {
786 | bottom: 0;
787 | }
788 | .ui-slider-vertical .ui-slider-range-max {
789 | top: 0;
790 | }
791 | .ui-spinner {
792 | position: relative;
793 | display: inline-block;
794 | overflow: hidden;
795 | padding: 0;
796 | vertical-align: middle;
797 | }
798 | .ui-spinner-input {
799 | border: none;
800 | background: none;
801 | color: inherit;
802 | padding: .222em 0;
803 | margin: .2em 0;
804 | vertical-align: middle;
805 | margin-left: .4em;
806 | margin-right: 2em;
807 | }
808 | .ui-spinner-button {
809 | width: 1.6em;
810 | height: 50%;
811 | font-size: .5em;
812 | padding: 0;
813 | margin: 0;
814 | text-align: center;
815 | position: absolute;
816 | cursor: default;
817 | display: block;
818 | overflow: hidden;
819 | right: 0;
820 | }
821 | /* more specificity required here to override default borders */
822 | .ui-spinner a.ui-spinner-button {
823 | border-top-style: none;
824 | border-bottom-style: none;
825 | border-right-style: none;
826 | }
827 | .ui-spinner-up {
828 | top: 0;
829 | }
830 | .ui-spinner-down {
831 | bottom: 0;
832 | }
833 | .ui-tabs {
834 | position: relative;/* position: relative prevents IE scroll bug (element with position: relative inside container with overflow: auto appear as "fixed") */
835 | padding: .2em;
836 | }
837 | .ui-tabs .ui-tabs-nav {
838 | margin: 0;
839 | padding: .2em .2em 0;
840 | }
841 | .ui-tabs .ui-tabs-nav li {
842 | list-style: none;
843 | float: left;
844 | position: relative;
845 | top: 0;
846 | margin: 1px .2em 0 0;
847 | border-bottom-width: 0;
848 | padding: 0;
849 | white-space: nowrap;
850 | }
851 | .ui-tabs .ui-tabs-nav .ui-tabs-anchor {
852 | float: left;
853 | padding: .5em 1em;
854 | text-decoration: none;
855 | }
856 | .ui-tabs .ui-tabs-nav li.ui-tabs-active {
857 | margin-bottom: -1px;
858 | padding-bottom: 1px;
859 | }
860 | .ui-tabs .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor,
861 | .ui-tabs .ui-tabs-nav li.ui-state-disabled .ui-tabs-anchor,
862 | .ui-tabs .ui-tabs-nav li.ui-tabs-loading .ui-tabs-anchor {
863 | cursor: text;
864 | }
865 | .ui-tabs-collapsible .ui-tabs-nav li.ui-tabs-active .ui-tabs-anchor {
866 | cursor: pointer;
867 | }
868 | .ui-tabs .ui-tabs-panel {
869 | display: block;
870 | border-width: 0;
871 | padding: 1em 1.4em;
872 | background: none;
873 | }
874 | .ui-tooltip {
875 | padding: 8px;
876 | position: absolute;
877 | z-index: 9999;
878 | max-width: 300px;
879 | }
880 | body .ui-tooltip {
881 | border-width: 2px;
882 | }
883 |
884 | /* Component containers
885 | ----------------------------------*/
886 | .ui-widget {
887 | font-family: Arial,Helvetica,sans-serif;
888 | font-size: 1em;
889 | }
890 | .ui-widget .ui-widget {
891 | font-size: 1em;
892 | }
893 | .ui-widget input,
894 | .ui-widget select,
895 | .ui-widget textarea,
896 | .ui-widget button {
897 | font-family: Arial,Helvetica,sans-serif;
898 | font-size: 1em;
899 | }
900 | .ui-widget.ui-widget-content {
901 | border: 1px solid #c5c5c5;
902 | }
903 | .ui-widget-content {
904 | border: 1px solid #dddddd;
905 | background: #ffffff;
906 | color: #333333;
907 | }
908 | .ui-widget-content a {
909 | color: #333333;
910 | }
911 | .ui-widget-header {
912 | border: 1px solid #dddddd;
913 | background: #e9e9e9;
914 | color: #333333;
915 | font-weight: bold;
916 | }
917 | .ui-widget-header a {
918 | color: #333333;
919 | }
920 |
921 | /* Interaction states
922 | ----------------------------------*/
923 | .ui-state-default,
924 | .ui-widget-content .ui-state-default,
925 | .ui-widget-header .ui-state-default,
926 | .ui-button,
927 |
928 | /* We use html here because we need a greater specificity to make sure disabled
929 | works properly when clicked or hovered */
930 | html .ui-button.ui-state-disabled:hover,
931 | html .ui-button.ui-state-disabled:active {
932 | border: 1px solid #c5c5c5;
933 | background: #f6f6f6;
934 | font-weight: normal;
935 | color: #454545;
936 | }
937 | .ui-state-default a,
938 | .ui-state-default a:link,
939 | .ui-state-default a:visited,
940 | a.ui-button,
941 | a:link.ui-button,
942 | a:visited.ui-button,
943 | .ui-button {
944 | color: #454545;
945 | text-decoration: none;
946 | }
947 | .ui-state-hover,
948 | .ui-widget-content .ui-state-hover,
949 | .ui-widget-header .ui-state-hover,
950 | .ui-state-focus,
951 | .ui-widget-content .ui-state-focus,
952 | .ui-widget-header .ui-state-focus,
953 | .ui-button:hover,
954 | .ui-button:focus {
955 | border: 1px solid #cccccc;
956 | background: #ededed;
957 | font-weight: normal;
958 | color: #2b2b2b;
959 | }
960 | .ui-state-hover a,
961 | .ui-state-hover a:hover,
962 | .ui-state-hover a:link,
963 | .ui-state-hover a:visited,
964 | .ui-state-focus a,
965 | .ui-state-focus a:hover,
966 | .ui-state-focus a:link,
967 | .ui-state-focus a:visited,
968 | a.ui-button:hover,
969 | a.ui-button:focus {
970 | color: #2b2b2b;
971 | text-decoration: none;
972 | }
973 |
974 | .ui-visual-focus {
975 | box-shadow: 0 0 3px 1px rgb(94, 158, 214);
976 | }
977 | .ui-state-active,
978 | .ui-widget-content .ui-state-active,
979 | .ui-widget-header .ui-state-active,
980 | a.ui-button:active,
981 | .ui-button:active,
982 | .ui-button.ui-state-active:hover {
983 | border: 1px solid #003eff;
984 | background: #007fff;
985 | font-weight: normal;
986 | color: #ffffff;
987 | }
988 | .ui-icon-background,
989 | .ui-state-active .ui-icon-background {
990 | border: #003eff;
991 | background-color: #ffffff;
992 | }
993 | .ui-state-active a,
994 | .ui-state-active a:link,
995 | .ui-state-active a:visited {
996 | color: #ffffff;
997 | text-decoration: none;
998 | }
999 |
1000 | /* Interaction Cues
1001 | ----------------------------------*/
1002 | .ui-state-highlight,
1003 | .ui-widget-content .ui-state-highlight,
1004 | .ui-widget-header .ui-state-highlight {
1005 | border: 1px solid #dad55e;
1006 | background: #fffa90;
1007 | color: #777620;
1008 | }
1009 | .ui-state-checked {
1010 | border: 1px solid #dad55e;
1011 | background: #fffa90;
1012 | }
1013 | .ui-state-highlight a,
1014 | .ui-widget-content .ui-state-highlight a,
1015 | .ui-widget-header .ui-state-highlight a {
1016 | color: #777620;
1017 | }
1018 | .ui-state-error,
1019 | .ui-widget-content .ui-state-error,
1020 | .ui-widget-header .ui-state-error {
1021 | border: 1px solid #f1a899;
1022 | background: #fddfdf;
1023 | color: #5f3f3f;
1024 | }
1025 | .ui-state-error a,
1026 | .ui-widget-content .ui-state-error a,
1027 | .ui-widget-header .ui-state-error a {
1028 | color: #5f3f3f;
1029 | }
1030 | .ui-state-error-text,
1031 | .ui-widget-content .ui-state-error-text,
1032 | .ui-widget-header .ui-state-error-text {
1033 | color: #5f3f3f;
1034 | }
1035 | .ui-priority-primary,
1036 | .ui-widget-content .ui-priority-primary,
1037 | .ui-widget-header .ui-priority-primary {
1038 | font-weight: bold;
1039 | }
1040 | .ui-priority-secondary,
1041 | .ui-widget-content .ui-priority-secondary,
1042 | .ui-widget-header .ui-priority-secondary {
1043 | opacity: .7;
1044 | filter:Alpha(Opacity=70); /* support: IE8 */
1045 | font-weight: normal;
1046 | }
1047 | .ui-state-disabled,
1048 | .ui-widget-content .ui-state-disabled,
1049 | .ui-widget-header .ui-state-disabled {
1050 | opacity: .35;
1051 | filter:Alpha(Opacity=35); /* support: IE8 */
1052 | background-image: none;
1053 | }
1054 | .ui-state-disabled .ui-icon {
1055 | filter:Alpha(Opacity=35); /* support: IE8 - See #6059 */
1056 | }
1057 |
1058 | /* Icons
1059 | ----------------------------------*/
1060 |
1061 | /* states and images */
1062 | .ui-icon {
1063 | width: 16px;
1064 | height: 16px;
1065 | }
1066 | .ui-icon,
1067 | .ui-widget-content .ui-icon {
1068 | background-image: url("images/ui-icons_444444_256x240.png");
1069 | }
1070 | .ui-widget-header .ui-icon {
1071 | background-image: url("images/ui-icons_444444_256x240.png");
1072 | }
1073 | .ui-state-hover .ui-icon,
1074 | .ui-state-focus .ui-icon,
1075 | .ui-button:hover .ui-icon,
1076 | .ui-button:focus .ui-icon {
1077 | background-image: url("images/ui-icons_555555_256x240.png");
1078 | }
1079 | .ui-state-active .ui-icon,
1080 | .ui-button:active .ui-icon {
1081 | background-image: url("images/ui-icons_ffffff_256x240.png");
1082 | }
1083 | .ui-state-highlight .ui-icon,
1084 | .ui-button .ui-state-highlight.ui-icon {
1085 | background-image: url("images/ui-icons_777620_256x240.png");
1086 | }
1087 | .ui-state-error .ui-icon,
1088 | .ui-state-error-text .ui-icon {
1089 | background-image: url("images/ui-icons_cc0000_256x240.png");
1090 | }
1091 | .ui-button .ui-icon {
1092 | background-image: url("images/ui-icons_777777_256x240.png");
1093 | }
1094 |
1095 | /* positioning */
1096 | .ui-icon-blank { background-position: 16px 16px; }
1097 | .ui-icon-caret-1-n { background-position: 0 0; }
1098 | .ui-icon-caret-1-ne { background-position: -16px 0; }
1099 | .ui-icon-caret-1-e { background-position: -32px 0; }
1100 | .ui-icon-caret-1-se { background-position: -48px 0; }
1101 | .ui-icon-caret-1-s { background-position: -65px 0; }
1102 | .ui-icon-caret-1-sw { background-position: -80px 0; }
1103 | .ui-icon-caret-1-w { background-position: -96px 0; }
1104 | .ui-icon-caret-1-nw { background-position: -112px 0; }
1105 | .ui-icon-caret-2-n-s { background-position: -128px 0; }
1106 | .ui-icon-caret-2-e-w { background-position: -144px 0; }
1107 | .ui-icon-triangle-1-n { background-position: 0 -16px; }
1108 | .ui-icon-triangle-1-ne { background-position: -16px -16px; }
1109 | .ui-icon-triangle-1-e { background-position: -32px -16px; }
1110 | .ui-icon-triangle-1-se { background-position: -48px -16px; }
1111 | .ui-icon-triangle-1-s { background-position: -65px -16px; }
1112 | .ui-icon-triangle-1-sw { background-position: -80px -16px; }
1113 | .ui-icon-triangle-1-w { background-position: -96px -16px; }
1114 | .ui-icon-triangle-1-nw { background-position: -112px -16px; }
1115 | .ui-icon-triangle-2-n-s { background-position: -128px -16px; }
1116 | .ui-icon-triangle-2-e-w { background-position: -144px -16px; }
1117 | .ui-icon-arrow-1-n { background-position: 0 -32px; }
1118 | .ui-icon-arrow-1-ne { background-position: -16px -32px; }
1119 | .ui-icon-arrow-1-e { background-position: -32px -32px; }
1120 | .ui-icon-arrow-1-se { background-position: -48px -32px; }
1121 | .ui-icon-arrow-1-s { background-position: -65px -32px; }
1122 | .ui-icon-arrow-1-sw { background-position: -80px -32px; }
1123 | .ui-icon-arrow-1-w { background-position: -96px -32px; }
1124 | .ui-icon-arrow-1-nw { background-position: -112px -32px; }
1125 | .ui-icon-arrow-2-n-s { background-position: -128px -32px; }
1126 | .ui-icon-arrow-2-ne-sw { background-position: -144px -32px; }
1127 | .ui-icon-arrow-2-e-w { background-position: -160px -32px; }
1128 | .ui-icon-arrow-2-se-nw { background-position: -176px -32px; }
1129 | .ui-icon-arrowstop-1-n { background-position: -192px -32px; }
1130 | .ui-icon-arrowstop-1-e { background-position: -208px -32px; }
1131 | .ui-icon-arrowstop-1-s { background-position: -224px -32px; }
1132 | .ui-icon-arrowstop-1-w { background-position: -240px -32px; }
1133 | .ui-icon-arrowthick-1-n { background-position: 1px -48px; }
1134 | .ui-icon-arrowthick-1-ne { background-position: -16px -48px; }
1135 | .ui-icon-arrowthick-1-e { background-position: -32px -48px; }
1136 | .ui-icon-arrowthick-1-se { background-position: -48px -48px; }
1137 | .ui-icon-arrowthick-1-s { background-position: -64px -48px; }
1138 | .ui-icon-arrowthick-1-sw { background-position: -80px -48px; }
1139 | .ui-icon-arrowthick-1-w { background-position: -96px -48px; }
1140 | .ui-icon-arrowthick-1-nw { background-position: -112px -48px; }
1141 | .ui-icon-arrowthick-2-n-s { background-position: -128px -48px; }
1142 | .ui-icon-arrowthick-2-ne-sw { background-position: -144px -48px; }
1143 | .ui-icon-arrowthick-2-e-w { background-position: -160px -48px; }
1144 | .ui-icon-arrowthick-2-se-nw { background-position: -176px -48px; }
1145 | .ui-icon-arrowthickstop-1-n { background-position: -192px -48px; }
1146 | .ui-icon-arrowthickstop-1-e { background-position: -208px -48px; }
1147 | .ui-icon-arrowthickstop-1-s { background-position: -224px -48px; }
1148 | .ui-icon-arrowthickstop-1-w { background-position: -240px -48px; }
1149 | .ui-icon-arrowreturnthick-1-w { background-position: 0 -64px; }
1150 | .ui-icon-arrowreturnthick-1-n { background-position: -16px -64px; }
1151 | .ui-icon-arrowreturnthick-1-e { background-position: -32px -64px; }
1152 | .ui-icon-arrowreturnthick-1-s { background-position: -48px -64px; }
1153 | .ui-icon-arrowreturn-1-w { background-position: -64px -64px; }
1154 | .ui-icon-arrowreturn-1-n { background-position: -80px -64px; }
1155 | .ui-icon-arrowreturn-1-e { background-position: -96px -64px; }
1156 | .ui-icon-arrowreturn-1-s { background-position: -112px -64px; }
1157 | .ui-icon-arrowrefresh-1-w { background-position: -128px -64px; }
1158 | .ui-icon-arrowrefresh-1-n { background-position: -144px -64px; }
1159 | .ui-icon-arrowrefresh-1-e { background-position: -160px -64px; }
1160 | .ui-icon-arrowrefresh-1-s { background-position: -176px -64px; }
1161 | .ui-icon-arrow-4 { background-position: 0 -80px; }
1162 | .ui-icon-arrow-4-diag { background-position: -16px -80px; }
1163 | .ui-icon-extlink { background-position: -32px -80px; }
1164 | .ui-icon-newwin { background-position: -48px -80px; }
1165 | .ui-icon-refresh { background-position: -64px -80px; }
1166 | .ui-icon-shuffle { background-position: -80px -80px; }
1167 | .ui-icon-transfer-e-w { background-position: -96px -80px; }
1168 | .ui-icon-transferthick-e-w { background-position: -112px -80px; }
1169 | .ui-icon-folder-collapsed { background-position: 0 -96px; }
1170 | .ui-icon-folder-open { background-position: -16px -96px; }
1171 | .ui-icon-document { background-position: -32px -96px; }
1172 | .ui-icon-document-b { background-position: -48px -96px; }
1173 | .ui-icon-note { background-position: -64px -96px; }
1174 | .ui-icon-mail-closed { background-position: -80px -96px; }
1175 | .ui-icon-mail-open { background-position: -96px -96px; }
1176 | .ui-icon-suitcase { background-position: -112px -96px; }
1177 | .ui-icon-comment { background-position: -128px -96px; }
1178 | .ui-icon-person { background-position: -144px -96px; }
1179 | .ui-icon-print { background-position: -160px -96px; }
1180 | .ui-icon-trash { background-position: -176px -96px; }
1181 | .ui-icon-locked { background-position: -192px -96px; }
1182 | .ui-icon-unlocked { background-position: -208px -96px; }
1183 | .ui-icon-bookmark { background-position: -224px -96px; }
1184 | .ui-icon-tag { background-position: -240px -96px; }
1185 | .ui-icon-home { background-position: 0 -112px; }
1186 | .ui-icon-flag { background-position: -16px -112px; }
1187 | .ui-icon-calendar { background-position: -32px -112px; }
1188 | .ui-icon-cart { background-position: -48px -112px; }
1189 | .ui-icon-pencil { background-position: -64px -112px; }
1190 | .ui-icon-clock { background-position: -80px -112px; }
1191 | .ui-icon-disk { background-position: -96px -112px; }
1192 | .ui-icon-calculator { background-position: -112px -112px; }
1193 | .ui-icon-zoomin { background-position: -128px -112px; }
1194 | .ui-icon-zoomout { background-position: -144px -112px; }
1195 | .ui-icon-search { background-position: -160px -112px; }
1196 | .ui-icon-wrench { background-position: -176px -112px; }
1197 | .ui-icon-gear { background-position: -192px -112px; }
1198 | .ui-icon-heart { background-position: -208px -112px; }
1199 | .ui-icon-star { background-position: -224px -112px; }
1200 | .ui-icon-link { background-position: -240px -112px; }
1201 | .ui-icon-cancel { background-position: 0 -128px; }
1202 | .ui-icon-plus { background-position: -16px -128px; }
1203 | .ui-icon-plusthick { background-position: -32px -128px; }
1204 | .ui-icon-minus { background-position: -48px -128px; }
1205 | .ui-icon-minusthick { background-position: -64px -128px; }
1206 | .ui-icon-close { background-position: -80px -128px; }
1207 | .ui-icon-closethick { background-position: -96px -128px; }
1208 | .ui-icon-key { background-position: -112px -128px; }
1209 | .ui-icon-lightbulb { background-position: -128px -128px; }
1210 | .ui-icon-scissors { background-position: -144px -128px; }
1211 | .ui-icon-clipboard { background-position: -160px -128px; }
1212 | .ui-icon-copy { background-position: -176px -128px; }
1213 | .ui-icon-contact { background-position: -192px -128px; }
1214 | .ui-icon-image { background-position: -208px -128px; }
1215 | .ui-icon-video { background-position: -224px -128px; }
1216 | .ui-icon-script { background-position: -240px -128px; }
1217 | .ui-icon-alert { background-position: 0 -144px; }
1218 | .ui-icon-info { background-position: -16px -144px; }
1219 | .ui-icon-notice { background-position: -32px -144px; }
1220 | .ui-icon-help { background-position: -48px -144px; }
1221 | .ui-icon-check { background-position: -64px -144px; }
1222 | .ui-icon-bullet { background-position: -80px -144px; }
1223 | .ui-icon-radio-on { background-position: -96px -144px; }
1224 | .ui-icon-radio-off { background-position: -112px -144px; }
1225 | .ui-icon-pin-w { background-position: -128px -144px; }
1226 | .ui-icon-pin-s { background-position: -144px -144px; }
1227 | .ui-icon-play { background-position: 0 -160px; }
1228 | .ui-icon-pause { background-position: -16px -160px; }
1229 | .ui-icon-seek-next { background-position: -32px -160px; }
1230 | .ui-icon-seek-prev { background-position: -48px -160px; }
1231 | .ui-icon-seek-end { background-position: -64px -160px; }
1232 | .ui-icon-seek-start { background-position: -80px -160px; }
1233 | /* ui-icon-seek-first is deprecated, use ui-icon-seek-start instead */
1234 | .ui-icon-seek-first { background-position: -80px -160px; }
1235 | .ui-icon-stop { background-position: -96px -160px; }
1236 | .ui-icon-eject { background-position: -112px -160px; }
1237 | .ui-icon-volume-off { background-position: -128px -160px; }
1238 | .ui-icon-volume-on { background-position: -144px -160px; }
1239 | .ui-icon-power { background-position: 0 -176px; }
1240 | .ui-icon-signal-diag { background-position: -16px -176px; }
1241 | .ui-icon-signal { background-position: -32px -176px; }
1242 | .ui-icon-battery-0 { background-position: -48px -176px; }
1243 | .ui-icon-battery-1 { background-position: -64px -176px; }
1244 | .ui-icon-battery-2 { background-position: -80px -176px; }
1245 | .ui-icon-battery-3 { background-position: -96px -176px; }
1246 | .ui-icon-circle-plus { background-position: 0 -192px; }
1247 | .ui-icon-circle-minus { background-position: -16px -192px; }
1248 | .ui-icon-circle-close { background-position: -32px -192px; }
1249 | .ui-icon-circle-triangle-e { background-position: -48px -192px; }
1250 | .ui-icon-circle-triangle-s { background-position: -64px -192px; }
1251 | .ui-icon-circle-triangle-w { background-position: -80px -192px; }
1252 | .ui-icon-circle-triangle-n { background-position: -96px -192px; }
1253 | .ui-icon-circle-arrow-e { background-position: -112px -192px; }
1254 | .ui-icon-circle-arrow-s { background-position: -128px -192px; }
1255 | .ui-icon-circle-arrow-w { background-position: -144px -192px; }
1256 | .ui-icon-circle-arrow-n { background-position: -160px -192px; }
1257 | .ui-icon-circle-zoomin { background-position: -176px -192px; }
1258 | .ui-icon-circle-zoomout { background-position: -192px -192px; }
1259 | .ui-icon-circle-check { background-position: -208px -192px; }
1260 | .ui-icon-circlesmall-plus { background-position: 0 -208px; }
1261 | .ui-icon-circlesmall-minus { background-position: -16px -208px; }
1262 | .ui-icon-circlesmall-close { background-position: -32px -208px; }
1263 | .ui-icon-squaresmall-plus { background-position: -48px -208px; }
1264 | .ui-icon-squaresmall-minus { background-position: -64px -208px; }
1265 | .ui-icon-squaresmall-close { background-position: -80px -208px; }
1266 | .ui-icon-grip-dotted-vertical { background-position: 0 -224px; }
1267 | .ui-icon-grip-dotted-horizontal { background-position: -16px -224px; }
1268 | .ui-icon-grip-solid-vertical { background-position: -32px -224px; }
1269 | .ui-icon-grip-solid-horizontal { background-position: -48px -224px; }
1270 | .ui-icon-gripsmall-diagonal-se { background-position: -64px -224px; }
1271 | .ui-icon-grip-diagonal-se { background-position: -80px -224px; }
1272 |
1273 |
1274 | /* Misc visuals
1275 | ----------------------------------*/
1276 |
1277 | /* Corner radius */
1278 | .ui-corner-all,
1279 | .ui-corner-top,
1280 | .ui-corner-left,
1281 | .ui-corner-tl {
1282 | border-top-left-radius: 3px;
1283 | }
1284 | .ui-corner-all,
1285 | .ui-corner-top,
1286 | .ui-corner-right,
1287 | .ui-corner-tr {
1288 | border-top-right-radius: 3px;
1289 | }
1290 | .ui-corner-all,
1291 | .ui-corner-bottom,
1292 | .ui-corner-left,
1293 | .ui-corner-bl {
1294 | border-bottom-left-radius: 3px;
1295 | }
1296 | .ui-corner-all,
1297 | .ui-corner-bottom,
1298 | .ui-corner-right,
1299 | .ui-corner-br {
1300 | border-bottom-right-radius: 3px;
1301 | }
1302 |
1303 | /* Overlays */
1304 | .ui-widget-overlay {
1305 | background: #aaaaaa;
1306 | opacity: .3;
1307 | filter: Alpha(Opacity=30); /* support: IE8 */
1308 | }
1309 | .ui-widget-shadow {
1310 | -webkit-box-shadow: 0px 0px 5px #666666;
1311 | box-shadow: 0px 0px 5px #666666;
1312 | }
1313 |
--------------------------------------------------------------------------------