mirror of
https://github.com/LinkStackOrg/LinkStack.git
synced 2025-04-04 21:51:00 +02:00
Fixed Button Editor not working on Touch devices
Fixed button editor not working on Touch enabled devices such as smartphones.
This commit is contained in:
parent
7a9a7381c5
commit
a78a80e2df
164
studio/button-editor/css/colorpicker.css
vendored
Normal file
164
studio/button-editor/css/colorpicker.css
vendored
Normal file
@ -0,0 +1,164 @@
|
|||||||
|
.colorpicker * {
|
||||||
|
-webkit-tap-highlight-color: rgba(0, 0, 0, 0);
|
||||||
|
}
|
||||||
|
.colorpicker {
|
||||||
|
width: 356px;
|
||||||
|
height: 176px;
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
background: url(../images/colorpicker_background.png);
|
||||||
|
font-family: Arial, Helvetica, sans-serif;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.colorpicker_color {
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
left: 14px;
|
||||||
|
top: 13px;
|
||||||
|
position: absolute;
|
||||||
|
background: #f00;
|
||||||
|
overflow: hidden;
|
||||||
|
cursor: crosshair;
|
||||||
|
}
|
||||||
|
.colorpicker_color div {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 150px;
|
||||||
|
height: 150px;
|
||||||
|
background: url(../images/colorpicker_overlay.png);
|
||||||
|
}
|
||||||
|
.colorpicker_color div div {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 11px;
|
||||||
|
height: 11px;
|
||||||
|
overflow: hidden;
|
||||||
|
background: url(../images/colorpicker_select.gif);
|
||||||
|
margin: -5px 0 0 -5px;
|
||||||
|
}
|
||||||
|
.colorpicker_hue {
|
||||||
|
position: absolute;
|
||||||
|
top: 13px;
|
||||||
|
left: 171px;
|
||||||
|
width: 35px;
|
||||||
|
height: 150px;
|
||||||
|
cursor: n-resize;
|
||||||
|
}
|
||||||
|
.colorpicker_hue div {
|
||||||
|
position: absolute;
|
||||||
|
width: 35px;
|
||||||
|
height: 9px;
|
||||||
|
overflow: hidden;
|
||||||
|
background: url(../images/colorpicker_indic.gif) left top;
|
||||||
|
margin: -4px 0 0 0;
|
||||||
|
left: 0px;
|
||||||
|
}
|
||||||
|
.colorpicker_new_color {
|
||||||
|
position: absolute;
|
||||||
|
width: 60px;
|
||||||
|
height: 30px;
|
||||||
|
left: 213px;
|
||||||
|
top: 13px;
|
||||||
|
background: #f00;
|
||||||
|
}
|
||||||
|
.colorpicker_current_color {
|
||||||
|
position: absolute;
|
||||||
|
width: 60px;
|
||||||
|
height: 30px;
|
||||||
|
left: 283px;
|
||||||
|
top: 13px;
|
||||||
|
background: #f00;
|
||||||
|
}
|
||||||
|
.colorpicker input {
|
||||||
|
background-color: transparent;
|
||||||
|
border: 1px solid transparent;
|
||||||
|
position: absolute;
|
||||||
|
font-size: 10px;
|
||||||
|
font-family: Arial, Helvetica, sans-serif;
|
||||||
|
color: #898989;
|
||||||
|
top: 4px;
|
||||||
|
right: 11px;
|
||||||
|
text-align: right;
|
||||||
|
margin: 0;
|
||||||
|
padding: 0;
|
||||||
|
height: 11px;
|
||||||
|
}
|
||||||
|
.colorpicker_hex {
|
||||||
|
position: absolute;
|
||||||
|
width: 72px;
|
||||||
|
height: 22px;
|
||||||
|
background: url(../images/colorpicker_hex.png) top;
|
||||||
|
left: 212px;
|
||||||
|
top: 142px;
|
||||||
|
}
|
||||||
|
.colorpicker_hex input {
|
||||||
|
right: 6px;
|
||||||
|
}
|
||||||
|
.colorpicker_field {
|
||||||
|
height: 22px;
|
||||||
|
width: 62px;
|
||||||
|
background-position: top;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
.colorpicker_field span {
|
||||||
|
position: absolute;
|
||||||
|
width: 12px;
|
||||||
|
height: 22px;
|
||||||
|
overflow: hidden;
|
||||||
|
top: 0;
|
||||||
|
right: 0;
|
||||||
|
cursor: n-resize;
|
||||||
|
}
|
||||||
|
.colorpicker_rgb_r {
|
||||||
|
background-image: url(../images/colorpicker_rgb_r.png);
|
||||||
|
top: 52px;
|
||||||
|
left: 212px;
|
||||||
|
}
|
||||||
|
.colorpicker_rgb_g {
|
||||||
|
background-image: url(../images/colorpicker_rgb_g.png);
|
||||||
|
top: 82px;
|
||||||
|
left: 212px;
|
||||||
|
}
|
||||||
|
.colorpicker_rgb_b {
|
||||||
|
background-image: url(../images/colorpicker_rgb_b.png);
|
||||||
|
top: 112px;
|
||||||
|
left: 212px;
|
||||||
|
}
|
||||||
|
.colorpicker_hsb_h {
|
||||||
|
background-image: url(../images/colorpicker_hsb_h.png);
|
||||||
|
top: 52px;
|
||||||
|
left: 282px;
|
||||||
|
}
|
||||||
|
.colorpicker_hsb_s {
|
||||||
|
background-image: url(../images/colorpicker_hsb_s.png);
|
||||||
|
top: 82px;
|
||||||
|
left: 282px;
|
||||||
|
}
|
||||||
|
.colorpicker_hsb_b {
|
||||||
|
background-image: url(../images/colorpicker_hsb_b.png);
|
||||||
|
top: 112px;
|
||||||
|
left: 282px;
|
||||||
|
}
|
||||||
|
.colorpicker_submit {
|
||||||
|
position: absolute;
|
||||||
|
width: 22px;
|
||||||
|
height: 22px;
|
||||||
|
background: url(../images/colorpicker_submit.png) top;
|
||||||
|
left: 322px;
|
||||||
|
top: 142px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.colorpicker_focus {
|
||||||
|
background-position: center;
|
||||||
|
}
|
||||||
|
.colorpicker_hex.colorpicker_focus {
|
||||||
|
background-position: bottom;
|
||||||
|
}
|
||||||
|
.colorpicker_submit.colorpicker_focus {
|
||||||
|
background-position: bottom;
|
||||||
|
}
|
||||||
|
.colorpicker_slider {
|
||||||
|
background-position: bottom;
|
||||||
|
}
|
218
studio/button-editor/css/layout.css
vendored
Normal file
218
studio/button-editor/css/layout.css
vendored
Normal file
@ -0,0 +1,218 @@
|
|||||||
|
body,div,dl,dt,dd,ul,ol,li,h1,h2,h3,h4,h5,h6,pre,form,fieldset,input,textarea,p,blockquote,th,td {
|
||||||
|
margin:0;
|
||||||
|
padding:0;
|
||||||
|
}
|
||||||
|
table {
|
||||||
|
border-collapse:collapse;
|
||||||
|
border-spacing:0;
|
||||||
|
}
|
||||||
|
fieldset,img {
|
||||||
|
border:0;
|
||||||
|
}
|
||||||
|
address,caption,cite,code,dfn,em,strong,th,var {
|
||||||
|
font-style:normal;
|
||||||
|
font-weight:normal;
|
||||||
|
}
|
||||||
|
ol,ul {
|
||||||
|
list-style:none;
|
||||||
|
}
|
||||||
|
caption,th {
|
||||||
|
text-align:left;
|
||||||
|
}
|
||||||
|
h1,h2,h3,h4,h5,h6 {
|
||||||
|
font-size:100%;
|
||||||
|
font-weight:normal;
|
||||||
|
}
|
||||||
|
q:before,q:after {
|
||||||
|
content:'';
|
||||||
|
}
|
||||||
|
abbr,acronym { border:0;
|
||||||
|
}
|
||||||
|
html, body {
|
||||||
|
background-color: #fff;
|
||||||
|
font-family: Arial, Helvetica, sans-serif;
|
||||||
|
font-size: 12px;
|
||||||
|
line-height: 18px;
|
||||||
|
color: #52697E;
|
||||||
|
}
|
||||||
|
body {
|
||||||
|
text-align: center;
|
||||||
|
overflow: auto;
|
||||||
|
}
|
||||||
|
.wrapper {
|
||||||
|
width: 700px;
|
||||||
|
margin: 0 auto;
|
||||||
|
text-align: left;
|
||||||
|
}
|
||||||
|
h1 {
|
||||||
|
font-size: 21px;
|
||||||
|
height: 47px;
|
||||||
|
line-height: 47px;
|
||||||
|
text-transform: uppercase;
|
||||||
|
}
|
||||||
|
.navigationTabs {
|
||||||
|
height: 23px;
|
||||||
|
line-height: 23px;
|
||||||
|
border-bottom: 1px solid #ccc;
|
||||||
|
}
|
||||||
|
.navigationTabs li {
|
||||||
|
float: left;
|
||||||
|
height: 23px;
|
||||||
|
line-height: 23px;
|
||||||
|
padding-right: 3px;
|
||||||
|
}
|
||||||
|
.navigationTabs li a{
|
||||||
|
float: left;
|
||||||
|
dispaly: block;
|
||||||
|
height: 23px;
|
||||||
|
line-height: 23px;
|
||||||
|
padding: 0 10px;
|
||||||
|
overflow: hidden;
|
||||||
|
color: #52697E;
|
||||||
|
background-color: #eee;
|
||||||
|
position: relative;
|
||||||
|
text-decoration: none;
|
||||||
|
}
|
||||||
|
.navigationTabs li a:hover {
|
||||||
|
background-color: #f0f0f0;
|
||||||
|
}
|
||||||
|
.navigationTabs li a.active {
|
||||||
|
background-color: #fff;
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-bottom: 0px solid;
|
||||||
|
}
|
||||||
|
.tabsContent {
|
||||||
|
border: 1px solid #ccc;
|
||||||
|
border-top: 0px solid;
|
||||||
|
width: 698px;
|
||||||
|
overflow: hidden;
|
||||||
|
}
|
||||||
|
.tab {
|
||||||
|
padding: 16px;
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
.tab h2 {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 16px;
|
||||||
|
}
|
||||||
|
.tab h3 {
|
||||||
|
font-weight: bold;
|
||||||
|
font-size: 14px;
|
||||||
|
margin-top: 20px;
|
||||||
|
}
|
||||||
|
.tab p {
|
||||||
|
margin-top: 16px;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
.tab ul {
|
||||||
|
margin-top: 16px;
|
||||||
|
list-style: disc;
|
||||||
|
}
|
||||||
|
.tab li {
|
||||||
|
margin: 10px 0 0 35px;
|
||||||
|
}
|
||||||
|
.tab a {
|
||||||
|
color: #8FB0CF;
|
||||||
|
}
|
||||||
|
.tab strong {
|
||||||
|
font-weight: bold;
|
||||||
|
}
|
||||||
|
.tab pre {
|
||||||
|
font-size: 11px;
|
||||||
|
margin-top: 20px;
|
||||||
|
width: 668px;
|
||||||
|
overflow: auto;
|
||||||
|
clear: both;
|
||||||
|
}
|
||||||
|
.tab table {
|
||||||
|
width: 100%;
|
||||||
|
}
|
||||||
|
.tab table td {
|
||||||
|
padding: 6px 10px 6px 0;
|
||||||
|
vertical-align: top;
|
||||||
|
}
|
||||||
|
.tab dt {
|
||||||
|
margin-top: 16px;
|
||||||
|
}
|
||||||
|
|
||||||
|
#colorSelector {
|
||||||
|
position: relative;
|
||||||
|
width: 36px;
|
||||||
|
height: 36px;
|
||||||
|
background: url(../images/select.png);
|
||||||
|
}
|
||||||
|
#colorSelector div {
|
||||||
|
position: absolute;
|
||||||
|
top: 3px;
|
||||||
|
left: 3px;
|
||||||
|
width: 30px;
|
||||||
|
height: 30px;
|
||||||
|
background: url(../images/select.png) center;
|
||||||
|
}
|
||||||
|
#colorSelector2 {
|
||||||
|
position: absolute;
|
||||||
|
top: 0;
|
||||||
|
left: 0;
|
||||||
|
width: 36px;
|
||||||
|
height: 36px;
|
||||||
|
background: url(../images/select2.png);
|
||||||
|
}
|
||||||
|
#colorSelector2 div {
|
||||||
|
position: absolute;
|
||||||
|
top: 4px;
|
||||||
|
left: 4px;
|
||||||
|
width: 28px;
|
||||||
|
height: 28px;
|
||||||
|
background: url(../images/select2.png) center;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 {
|
||||||
|
top: 32px;
|
||||||
|
left: 0;
|
||||||
|
width: 356px;
|
||||||
|
height: 0;
|
||||||
|
overflow: hidden;
|
||||||
|
position: absolute;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker {
|
||||||
|
background-image: url(../images/custom_background.png);
|
||||||
|
position: absolute;
|
||||||
|
bottom: 0;
|
||||||
|
left: 0;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_hue div {
|
||||||
|
background-image: url(../images/custom_indic.gif);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_hex {
|
||||||
|
background-image: url(../images/custom_hex.png);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_rgb_r {
|
||||||
|
background-image: url(../images/custom_rgb_r.png);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_rgb_g {
|
||||||
|
background-image: url(../images/custom_rgb_g.png);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_rgb_b {
|
||||||
|
background-image: url(../images/custom_rgb_b.png);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_hsb_s {
|
||||||
|
background-image: url(../images/custom_hsb_s.png);
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_hsb_h {
|
||||||
|
background-image: url(../images/custom_hsb_h.png);
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_hsb_b {
|
||||||
|
background-image: url(../images/custom_hsb_b.png);
|
||||||
|
display: none;
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker_submit {
|
||||||
|
background-image: url(../images/custom_submit.png);
|
||||||
|
}
|
||||||
|
#colorpickerHolder2 .colorpicker input {
|
||||||
|
color: #778398;
|
||||||
|
}
|
||||||
|
#customWidget {
|
||||||
|
position: relative;
|
||||||
|
height: 36px;
|
||||||
|
}
|
BIN
studio/button-editor/images/blank.gif
Normal file
BIN
studio/button-editor/images/blank.gif
Normal file
Binary file not shown.
After Width: | Height: | Size: 49 B |
1001
studio/button-editor/js/colorpicker.js
vendored
1001
studio/button-editor/js/colorpicker.js
vendored
File diff suppressed because it is too large
Load Diff
28
studio/button-editor/js/eye.js
vendored
Normal file
28
studio/button-editor/js/eye.js
vendored
Normal file
@ -0,0 +1,28 @@
|
|||||||
|
(function($){
|
||||||
|
var EYE = window.EYE = function() {
|
||||||
|
var _registered = {
|
||||||
|
init: []
|
||||||
|
};
|
||||||
|
return {
|
||||||
|
init: function() {
|
||||||
|
$.each(_registered.init, function(nr, fn){
|
||||||
|
fn.call();
|
||||||
|
});
|
||||||
|
},
|
||||||
|
extend: function(prop) {
|
||||||
|
for (var i in prop) {
|
||||||
|
if (prop[i] != undefined) {
|
||||||
|
this[i] = prop[i];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
},
|
||||||
|
register: function(fn, type) {
|
||||||
|
if (!_registered[type]) {
|
||||||
|
_registered[type] = [];
|
||||||
|
}
|
||||||
|
_registered[type].push(fn);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
}();
|
||||||
|
$(EYE.init);
|
||||||
|
})(jQuery);
|
4365
studio/button-editor/js/jquery.js
vendored
Normal file
4365
studio/button-editor/js/jquery.js
vendored
Normal file
File diff suppressed because it is too large
Load Diff
67
studio/button-editor/js/layout.js
vendored
Normal file
67
studio/button-editor/js/layout.js
vendored
Normal file
@ -0,0 +1,67 @@
|
|||||||
|
(function($){
|
||||||
|
var initLayout = function() {
|
||||||
|
var hash = window.location.hash.replace('#', '');
|
||||||
|
var currentTab = $('ul.navigationTabs a')
|
||||||
|
.bind('click', showTab)
|
||||||
|
.filter('a[rel=' + hash + ']');
|
||||||
|
if (currentTab.size() == 0) {
|
||||||
|
currentTab = $('ul.navigationTabs a:first');
|
||||||
|
}
|
||||||
|
showTab.apply(currentTab.get(0));
|
||||||
|
$('#colorpickerHolder').ColorPicker({flat: true});
|
||||||
|
$('#colorpickerHolder2').ColorPicker({
|
||||||
|
flat: true,
|
||||||
|
color: '#00ff00',
|
||||||
|
onSubmit: function(hsb, hex, rgb) {
|
||||||
|
$('#colorSelector2 div').css('backgroundColor', '#' + hex);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
$('#colorpickerHolder2>div').css('position', 'absolute');
|
||||||
|
var widt = false;
|
||||||
|
$('#colorSelector2').bind('click', function() {
|
||||||
|
$('#colorpickerHolder2').stop().animate({height: widt ? 0 : 173}, 500);
|
||||||
|
widt = !widt;
|
||||||
|
});
|
||||||
|
$('#colorpickerField1, #colorpickerField2, #colorpickerField3').ColorPicker({
|
||||||
|
onSubmit: function(hsb, hex, rgb, el) {
|
||||||
|
$(el).val(hex);
|
||||||
|
$(el).ColorPickerHide();
|
||||||
|
},
|
||||||
|
onBeforeShow: function () {
|
||||||
|
$(this).ColorPickerSetColor(this.value);
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.bind('keyup', function(){
|
||||||
|
$(this).ColorPickerSetColor(this.value);
|
||||||
|
});
|
||||||
|
$('#colorSelector').ColorPicker({
|
||||||
|
color: '#0000ff',
|
||||||
|
onShow: function (colpkr) {
|
||||||
|
$(colpkr).fadeIn(500);
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
onHide: function (colpkr) {
|
||||||
|
$(colpkr).fadeOut(500);
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
onChange: function (hsb, hex, rgb) {
|
||||||
|
$('#colorSelector div').css('backgroundColor', '#' + hex);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
};
|
||||||
|
|
||||||
|
var showTab = function(e) {
|
||||||
|
var tabIndex = $('ul.navigationTabs a')
|
||||||
|
.removeClass('active')
|
||||||
|
.index(this);
|
||||||
|
$(this)
|
||||||
|
.addClass('active')
|
||||||
|
.blur();
|
||||||
|
$('div.tab')
|
||||||
|
.hide()
|
||||||
|
.eq(tabIndex)
|
||||||
|
.show();
|
||||||
|
};
|
||||||
|
|
||||||
|
EYE.register(initLayout, 'init');
|
||||||
|
})(jQuery)
|
246
studio/button-editor/js/utils.js
vendored
Normal file
246
studio/button-editor/js/utils.js
vendored
Normal file
@ -0,0 +1,246 @@
|
|||||||
|
(function($) {
|
||||||
|
EYE.extend({
|
||||||
|
getPosition : function(e, forceIt)
|
||||||
|
{
|
||||||
|
var x = 0;
|
||||||
|
var y = 0;
|
||||||
|
var es = e.style;
|
||||||
|
var restoreStyles = false;
|
||||||
|
if (forceIt && jQuery.curCSS(e,'display') == 'none') {
|
||||||
|
var oldVisibility = es.visibility;
|
||||||
|
var oldPosition = es.position;
|
||||||
|
restoreStyles = true;
|
||||||
|
es.visibility = 'hidden';
|
||||||
|
es.display = 'block';
|
||||||
|
es.position = 'absolute';
|
||||||
|
}
|
||||||
|
var el = e;
|
||||||
|
if (el.getBoundingClientRect) { // IE
|
||||||
|
var box = el.getBoundingClientRect();
|
||||||
|
x = box.left + Math.max(document.documentElement.scrollLeft, document.body.scrollLeft) - 2;
|
||||||
|
y = box.top + Math.max(document.documentElement.scrollTop, document.body.scrollTop) - 2;
|
||||||
|
} else {
|
||||||
|
x = el.offsetLeft;
|
||||||
|
y = el.offsetTop;
|
||||||
|
el = el.offsetParent;
|
||||||
|
if (e != el) {
|
||||||
|
while (el) {
|
||||||
|
x += el.offsetLeft;
|
||||||
|
y += el.offsetTop;
|
||||||
|
el = el.offsetParent;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (jQuery.browser.safari && jQuery.curCSS(e, 'position') == 'absolute' ) {
|
||||||
|
x -= document.body.offsetLeft;
|
||||||
|
y -= document.body.offsetTop;
|
||||||
|
}
|
||||||
|
el = e.parentNode;
|
||||||
|
while (el && el.tagName.toUpperCase() != 'BODY' && el.tagName.toUpperCase() != 'HTML')
|
||||||
|
{
|
||||||
|
if (jQuery.curCSS(el, 'display') != 'inline') {
|
||||||
|
x -= el.scrollLeft;
|
||||||
|
y -= el.scrollTop;
|
||||||
|
}
|
||||||
|
el = el.parentNode;
|
||||||
|
}
|
||||||
|
}
|
||||||
|
if (restoreStyles == true) {
|
||||||
|
es.display = 'none';
|
||||||
|
es.position = oldPosition;
|
||||||
|
es.visibility = oldVisibility;
|
||||||
|
}
|
||||||
|
return {x:x, y:y};
|
||||||
|
},
|
||||||
|
getSize : function(e)
|
||||||
|
{
|
||||||
|
var w = parseInt(jQuery.curCSS(e,'width'), 10);
|
||||||
|
var h = parseInt(jQuery.curCSS(e,'height'), 10);
|
||||||
|
var wb = 0;
|
||||||
|
var hb = 0;
|
||||||
|
if (jQuery.curCSS(e, 'display') != 'none') {
|
||||||
|
wb = e.offsetWidth;
|
||||||
|
hb = e.offsetHeight;
|
||||||
|
} else {
|
||||||
|
var es = e.style;
|
||||||
|
var oldVisibility = es.visibility;
|
||||||
|
var oldPosition = es.position;
|
||||||
|
es.visibility = 'hidden';
|
||||||
|
es.display = 'block';
|
||||||
|
es.position = 'absolute';
|
||||||
|
wb = e.offsetWidth;
|
||||||
|
hb = e.offsetHeight;
|
||||||
|
es.display = 'none';
|
||||||
|
es.position = oldPosition;
|
||||||
|
es.visibility = oldVisibility;
|
||||||
|
}
|
||||||
|
return {w:w, h:h, wb:wb, hb:hb};
|
||||||
|
},
|
||||||
|
getClient : function(e)
|
||||||
|
{
|
||||||
|
var h, w;
|
||||||
|
if (e) {
|
||||||
|
w = e.clientWidth;
|
||||||
|
h = e.clientHeight;
|
||||||
|
} else {
|
||||||
|
var de = document.documentElement;
|
||||||
|
w = window.innerWidth || self.innerWidth || (de&&de.clientWidth) || document.body.clientWidth;
|
||||||
|
h = window.innerHeight || self.innerHeight || (de&&de.clientHeight) || document.body.clientHeight;
|
||||||
|
}
|
||||||
|
return {w:w,h:h};
|
||||||
|
},
|
||||||
|
getScroll : function (e)
|
||||||
|
{
|
||||||
|
var t=0, l=0, w=0, h=0, iw=0, ih=0;
|
||||||
|
if (e && e.nodeName.toLowerCase() != 'body') {
|
||||||
|
t = e.scrollTop;
|
||||||
|
l = e.scrollLeft;
|
||||||
|
w = e.scrollWidth;
|
||||||
|
h = e.scrollHeight;
|
||||||
|
} else {
|
||||||
|
if (document.documentElement) {
|
||||||
|
t = document.documentElement.scrollTop;
|
||||||
|
l = document.documentElement.scrollLeft;
|
||||||
|
w = document.documentElement.scrollWidth;
|
||||||
|
h = document.documentElement.scrollHeight;
|
||||||
|
} else if (document.body) {
|
||||||
|
t = document.body.scrollTop;
|
||||||
|
l = document.body.scrollLeft;
|
||||||
|
w = document.body.scrollWidth;
|
||||||
|
h = document.body.scrollHeight;
|
||||||
|
}
|
||||||
|
if (typeof pageYOffset != 'undefined') {
|
||||||
|
t = pageYOffset;
|
||||||
|
l = pageXOffset;
|
||||||
|
}
|
||||||
|
iw = self.innerWidth||document.documentElement.clientWidth||document.body.clientWidth||0;
|
||||||
|
ih = self.innerHeight||document.documentElement.clientHeight||document.body.clientHeight||0;
|
||||||
|
}
|
||||||
|
return { t: t, l: l, w: w, h: h, iw: iw, ih: ih };
|
||||||
|
},
|
||||||
|
getMargins : function(e, toInteger)
|
||||||
|
{
|
||||||
|
var t = jQuery.curCSS(e,'marginTop') || '';
|
||||||
|
var r = jQuery.curCSS(e,'marginRight') || '';
|
||||||
|
var b = jQuery.curCSS(e,'marginBottom') || '';
|
||||||
|
var l = jQuery.curCSS(e,'marginLeft') || '';
|
||||||
|
if (toInteger)
|
||||||
|
return {
|
||||||
|
t: parseInt(t, 10)||0,
|
||||||
|
r: parseInt(r, 10)||0,
|
||||||
|
b: parseInt(b, 10)||0,
|
||||||
|
l: parseInt(l, 10)
|
||||||
|
};
|
||||||
|
else
|
||||||
|
return {t: t, r: r, b: b, l: l};
|
||||||
|
},
|
||||||
|
getPadding : function(e, toInteger)
|
||||||
|
{
|
||||||
|
var t = jQuery.curCSS(e,'paddingTop') || '';
|
||||||
|
var r = jQuery.curCSS(e,'paddingRight') || '';
|
||||||
|
var b = jQuery.curCSS(e,'paddingBottom') || '';
|
||||||
|
var l = jQuery.curCSS(e,'paddingLeft') || '';
|
||||||
|
if (toInteger)
|
||||||
|
return {
|
||||||
|
t: parseInt(t, 10)||0,
|
||||||
|
r: parseInt(r, 10)||0,
|
||||||
|
b: parseInt(b, 10)||0,
|
||||||
|
l: parseInt(l, 10)
|
||||||
|
};
|
||||||
|
else
|
||||||
|
return {t: t, r: r, b: b, l: l};
|
||||||
|
},
|
||||||
|
getBorder : function(e, toInteger)
|
||||||
|
{
|
||||||
|
var t = jQuery.curCSS(e,'borderTopWidth') || '';
|
||||||
|
var r = jQuery.curCSS(e,'borderRightWidth') || '';
|
||||||
|
var b = jQuery.curCSS(e,'borderBottomWidth') || '';
|
||||||
|
var l = jQuery.curCSS(e,'borderLeftWidth') || '';
|
||||||
|
if (toInteger)
|
||||||
|
return {
|
||||||
|
t: parseInt(t, 10)||0,
|
||||||
|
r: parseInt(r, 10)||0,
|
||||||
|
b: parseInt(b, 10)||0,
|
||||||
|
l: parseInt(l, 10)||0
|
||||||
|
};
|
||||||
|
else
|
||||||
|
return {t: t, r: r, b: b, l: l};
|
||||||
|
},
|
||||||
|
traverseDOM : function(nodeEl, func)
|
||||||
|
{
|
||||||
|
func(nodeEl);
|
||||||
|
nodeEl = nodeEl.firstChild;
|
||||||
|
while(nodeEl){
|
||||||
|
EYE.traverseDOM(nodeEl, func);
|
||||||
|
nodeEl = nodeEl.nextSibling;
|
||||||
|
}
|
||||||
|
},
|
||||||
|
getInnerWidth : function(el, scroll) {
|
||||||
|
var offsetW = el.offsetWidth;
|
||||||
|
return scroll ? Math.max(el.scrollWidth,offsetW) - offsetW + el.clientWidth:el.clientWidth;
|
||||||
|
},
|
||||||
|
getInnerHeight : function(el, scroll) {
|
||||||
|
var offsetH = el.offsetHeight;
|
||||||
|
return scroll ? Math.max(el.scrollHeight,offsetH) - offsetH + el.clientHeight:el.clientHeight;
|
||||||
|
},
|
||||||
|
getExtraWidth : function(el) {
|
||||||
|
if($.boxModel)
|
||||||
|
return (parseInt($.curCSS(el, 'paddingLeft'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'paddingRight'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'borderLeftWidth'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'borderRightWidth'))||0);
|
||||||
|
return 0;
|
||||||
|
},
|
||||||
|
getExtraHeight : function(el) {
|
||||||
|
if($.boxModel)
|
||||||
|
return (parseInt($.curCSS(el, 'paddingTop'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'paddingBottom'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'borderTopWidth'))||0)
|
||||||
|
+ (parseInt($.curCSS(el, 'borderBottomWidth'))||0);
|
||||||
|
return 0;
|
||||||
|
},
|
||||||
|
isChildOf: function(parentEl, el, container) {
|
||||||
|
if (parentEl == el) {
|
||||||
|
return true;
|
||||||
|
}
|
||||||
|
if (!el || !el.nodeType || el.nodeType != 1) {
|
||||||
|
return false;
|
||||||
|
}
|
||||||
|
if (parentEl.contains && !$.browser.safari) {
|
||||||
|
return parentEl.contains(el);
|
||||||
|
}
|
||||||
|
if ( parentEl.compareDocumentPosition ) {
|
||||||
|
return !!(parentEl.compareDocumentPosition(el) & 16);
|
||||||
|
}
|
||||||
|
var prEl = el.parentNode;
|
||||||
|
while(prEl && prEl != container) {
|
||||||
|
if (prEl == parentEl)
|
||||||
|
return true;
|
||||||
|
prEl = prEl.parentNode;
|
||||||
|
}
|
||||||
|
return false;
|
||||||
|
},
|
||||||
|
centerEl : function(el, axis)
|
||||||
|
{
|
||||||
|
var clientScroll = EYE.getScroll();
|
||||||
|
var size = EYE.getSize(el);
|
||||||
|
if (!axis || axis == 'vertically')
|
||||||
|
$(el).css(
|
||||||
|
{
|
||||||
|
top: clientScroll.t + ((Math.min(clientScroll.h,clientScroll.ih) - size.hb)/2) + 'px'
|
||||||
|
}
|
||||||
|
);
|
||||||
|
if (!axis || axis == 'horizontally')
|
||||||
|
$(el).css(
|
||||||
|
{
|
||||||
|
left: clientScroll.l + ((Math.min(clientScroll.w,clientScroll.iw) - size.wb)/2) + 'px'
|
||||||
|
}
|
||||||
|
);
|
||||||
|
}
|
||||||
|
});
|
||||||
|
if (!$.easing.easeout) {
|
||||||
|
$.easing.easeout = function(p, n, firstNum, delta, duration) {
|
||||||
|
return -delta * ((n=n/duration-1)*n*n*n - 1) + firstNum;
|
||||||
|
};
|
||||||
|
}
|
||||||
|
|
||||||
|
})(jQuery);
|
Loading…
x
Reference in New Issue
Block a user