This commit is contained in:
Ian Gilman 2010-06-25 16:10:52 -07:00
commit 611187d87b
3 changed files with 57 additions and 41 deletions

View File

@ -462,6 +462,11 @@ window.Group.prototype = iQ.extend(new Item(), new Subscribable(), {
return; return;
} }
rect.width = Math.max( 110, rect.width );
rect.height = Math.max( 125, rect.height);
var titleHeight = this.$titlebar.height(); var titleHeight = this.$titlebar.height();
// ___ Determine what has changed // ___ Determine what has changed

View File

@ -305,45 +305,60 @@ window.TabItem.prototype = iQ.extend(new Item(), {
$title.fadeIn();//.dequeue(); $title.fadeIn();//.dequeue();
} }
// TODO: This code is functional, but should probably be rewritten to // Usage
// break DRY less. I'm not really sure the best way to do that in // slide({60:0, 70:1}, 66);
// this case, though. I've leave it for a man with four hands. -- Aza // @60- return 0; at @70+ return 1; @65 return 0.5
function slider(bounds, val){
var keys = [];
for(var key in bounds){ keys.push(key); bounds[key] = parseFloat(bounds[key]); };
keys.sort(function(a,b){return a-b});
var min = keys[0], max = keys[1];
function slide(value){
if( value >= max ) return bounds[max];
if( value <= min ) return bounds[min];
var rise = bounds[max] - bounds[min];
var run = max-min;
var value = rise * (value-min)/run;
if( value >= bounds[max] ) return bounds[max];
if( value <= bounds[min] ) return bounds[min];
return value;
}
if( val == undefined ) return slide;
else return slide(val);
};
if(css.width && !this.inStack()) { if(css.width && !this.inStack()) {
$fav.css({top:4,left:4}); $fav.css({top:4,left:4});
if(css.width < 70) {
$fav.addClass("lessVisible"); var opacity = slider({70:1, 60:0}, css.width);
$close.show().css({opacity:opacity});
var opacity = (css.width-60)/10; if( opacity <= .1 ) $close.hide()
if( opacity > 0 ){
$close.show().css({opacity:opacity}); var pad = slider({70:6, 60:1}, css.width);
$fav.css({backgroundColor:"rgba(245,245,245," + opacity + ")"}) $fav.css({
} "padding-left": pad + "px",
else $close.hide(); "padding-right": pad + 2 + "px",
"padding-top": pad + "px",
} "padding-bottom": pad + "px",
else { "border-color": "rgba(0,0,0,"+ slider({70:.2, 60:.1}, css.width) +")",
$fav.removeClass("lessVisible").css({backgroundColor:"rgba(245,245,245,1)"}); });
$close.show();
}
} }
if(css.width && this.inStack()){ if(css.width && this.inStack()){
if(css.width < 90) { $fav.css({top:0, left:0});
$fav.addClass("lessVisible"); var opacity = slider({90:1, 70:0}, css.width);
var opacity = (css.width-80)/10; var pad = slider({90:6, 70:1}, css.width);
if( opacity > 0 ){ $fav.css({
$fav.css({backgroundColor:"rgba(245,245,245," + opacity + ")"}) "padding-left": pad + "px",
} "padding-right": pad + 2 + "px",
"padding-top": pad + "px",
} else { "padding-bottom": pad + "px",
$fav.removeClass("lessVisible").css({ "border-color": "rgba(0,0,0,"+ slider({90:.2, 70:.1}, css.width) +")",
backgroundColor:"rgba(245,245,245,1)", });
top: 0,
left: 0
});
}
} }
this._hasBeenDrawn = true; this._hasBeenDrawn = true;

View File

@ -71,7 +71,9 @@ body {
top: 4px; top: 4px;
left: 4px; left: 4px;
border-right: 1px solid rgba(0,0,0,0.2); border-right: 1px solid rgba(0,0,0,0.2);
border-bottom: 1px solid rgba(0,0,0,0.2); border-bottom: 1px solid rgba(0,0,0,0.2);
height: 17;
width: 17;
} }
.favicon img { .favicon img {
@ -80,12 +82,6 @@ body {
height: 16px; height: 16px;
} }
.lessVisible {
background-color: rgba(245,245,245, .2);
-moz-box-shadow: none;
border: none;
}
.close { .close {
position: absolute; position: absolute;