/*

Copyright 2008-2015 Clipperz Srl

This file is part of Clipperz, the online password manager.
For further information about its features and functionalities please
refer to http://www.clipperz.com.

* Clipperz is free software: you can redistribute it and/or modify it 
  under the terms of the GNU Affero General Public License as published 
  by the Free Software Foundation, either version 3 of the License, or 
  (at your option) any later version.

* Clipperz is distributed in the hope that it will be useful, but 
  WITHOUT ANY WARRANTY; without even the implied warranty of 
  MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
  See the GNU Affero General Public License for more details.

* You should have received a copy of the GNU Affero General Public
  License along with Clipperz. If not, see http://www.gnu.org/licenses/.

*/

@mixin border-radius ($radius) {
	-webkit-border-radius: $radius;
	   -moz-border-radius: $radius;
	        border-radius: $radius;
}

@mixin radial-gradient ($inner-color, $outer-color) {
	background-image:     -ms-radial-gradient(center, circle farthest-corner, $inner-color 0%, $outer-color 100%);		/* IE10 */ 
	background-image:    -moz-radial-gradient(center, circle farthest-corner, $inner-color 0%, $outer-color 100%);		/* Mozilla Firefox */ 
	background-image:      -o-radial-gradient(center, circle farthest-corner, $inner-color 0%, $outer-color 100%);		/* Opera */ 
	background-image: -webkit-radial-gradient(center, circle farthest-corner, $inner-color 0%, $outer-color 100%);		/* Webkit (Chrome 11+) */ 
	background-image:         radial-gradient(center, circle farthest-corner, $inner-color 0%, $outer-color 100%);		/* Proposed W3C Markup */ 
	background-image:        -webkit-gradient(radial, center center, 0, center center, 495, color-stop(0, $inner-color), color-stop(1, $outer-color));	/* Webkit (Safari/Chrome 10) */ 
}

@mixin font-feature-settings ($foo, $bar) {
	-webkit-font-feature-settings:$foo 1, $bar 1;
//	-moz-font-feature-settings:$foo = 1, $bar = 1;
	-moz-font-feature-settings:$foo 1, $bar 1;
	-ms-font-feature-settings:$foo 1, $bar 1;
	-o-font-feature-settings:$foo 1, $bar 1;
	font-feature-settings:$foo 1, $bar 1;
}

@mixin icon-font () {
	font-family: 'clipperz-icons';
	@include font-feature-settings("liga", "dlig");
	-webkit-font-smoothing: antialiased;
	text-rendering:optimizeLegibility;
}

@mixin password-font () {
	font-family: 'clipperz-password';
	-webkit-font-smoothing: antialiased;
	text-rendering:optimizeLegibility;
}

@mixin animation ($animation, $duration, $timing-function:linear, $iteration-count:1, $fill-mode:none) {
	-webkit-animation-name: $animation;
	-webkit-animation-duration: $duration;
	-webkit-animation-timing-function: $timing-function;
	-webkit-animation-iteration-count: $iteration-count;
	-webkit-animation-fill-mode: $fill-mode;

	-moz-animation-name: $animation;
	-moz-animation-duration: $duration;
	-moz-animation-timing-function: $timing-function;
	-moz-animation-iteration-count: $iteration-count;
	-moz-animation-fill-mode: $fill-mode;

	-ms-animation-name: $animation;
	-ms-animation-duration: $duration;
	-ms-animation-timing-function: $timing-function;
	-ms-animation-iteration-count: $iteration-count;
	-ms-animation-fill-mode: $fill-mode;

	-o-animation-name: $animation;
	-o-animation-duration: $duration;
	-o-animation-timing-function: $timing-function;
	-o-animation-iteration-count: $iteration-count;
	-o-animation-fill-mode: $fill-mode;

	animation-name: $animation;
	animation-duration: $duration;
	animation-timing-function: $timing-function;
	animation-iteration-count: $iteration-count;
	animation-fill-mode: $fill-mode;
}

@mixin transition ($item, $time, $function) {
	-webkit-transition: $item $time $function;
	   -moz-transition: $item $time $function;
	     -o-transition: $item $time $function;
	    -ms-transition: $item $time $function;
	        transition: $item $time $function;
}

@mixin transform ($rotateAngle, $translateX, $translateY) {
	-webkit-transform: rotate(  $rotateAngle) translate($translateX, $translateY);
	   -moz-transform: rotate(  $rotateAngle) translate($translateX, $translateY);
	    -ms-transform: rotate(  $rotateAngle) translate($translateX, $translateY);
	     -o-transform: rotate(  $rotateAngle) translate($translateX, $translateY);
	        transform: rotate(  $rotateAngle) translate($translateX, $translateY);
}

@mixin transform3d ($tx, $ty, $tz) {
	-webkit-transform: translate3d($tx, $ty, $tz);
	        transform: translate3d($tx, $ty, $tz);
}

@mixin transition-duration ($duration) {
	-webkit-transition-duration: $duration;
	        transition-duration: $duration;
}


@mixin animation-delay ($delay) {
	-webkit-animation-delay: $delay;
	   -moz-animation-delay: $delay;
	    -ms-animation-delay: $delay;
	     -o-animation-delay: $delay;
	        animation-delay: $delay;
}

@mixin box-shadow ($xOffset, $yOffset, $size, $color) {
	-webkit-box-shadow: $xOffset $yOffset $size $color;	
	   -moz-box-shadow: $xOffset $yOffset $size $color;	
	    -ms-box-shadow: $xOffset $yOffset $size $color;	
	     -o-box-shadow: $xOffset $yOffset $size $color;	
	        box-shadow: $xOffset $yOffset $size $color;	
}

@mixin keyframes ($name) {
	@-webkit-keyframes #{$name} {
		@content; 
	}
	@-moz-keyframes #{$name} {
		@content;
	}
	@-ms-keyframes #{$name} {
		@content;
	}
	@keyframes #{$name} {
		@content;
	} 
}

@mixin mask () {
	.mask {
		position: absolute;
		top: 0;
		left: 0;
		width: 100%;
		height: 100%;
		z-index: 10;
		background-color: rgba(0, 0, 0, 0.5);
	}
}

@include keyframes(spin) {
	0% { @include transform(0deg, 0, 0); }
	100% { @include transform(359deg, 0, 0); }
}

@mixin user-select($value) {
	//	http://css-tricks.com/almanac/properties/u/user-select/
	//	none | text | all | element
	-webkit-user-select: $value;	/* Chrome all / Safari all */
	-moz-user-select: $value;		/* Firefox all */
	-ms-user-select: $value;		/* IE 10+ */

	/* No support for these yet, use at own risk */
	-o-user-select: $value;
	user-select: $value;
}

@mixin overflow-auto () {
	overflow: auto;
	-webkit-overflow-scrolling: touch;
}

@mixin chromeFix () {
	-webkit-transform: translate3d(0,0,0);
}

@mixin placeholder {
	&::-webkit-input-placeholder {@content}
	&:-moz-placeholder           {@content}
	&::-moz-placeholder          {@content}
	&:-ms-input-placeholder      {@content}  
}

@mixin cursor-grab () {
	cursor: grab;
	cursor: -moz-grab;
	cursor: -webkit-grab;
}

@mixin cursor-grabbing () {
	cursor: grabbing;
	cursor: -moz-grabbing;
	cursor: -webkit-grabbing;
}

@mixin dotted-background () {
	//	http://codepen.io/aleprieto/pen/nAmIy
	background-image: -webkit-repeating-radial-gradient(center center, rgba(0,0,0,.2), rgba(0,0,0,.2) 1px, transparent 1px, transparent 100%);
	background-image: -moz-repeating-radial-gradient(center center, rgba(0,0,0,.2), rgba(0,0,0,.2) 1px, transparent 1px, transparent 100%);
	background-image: -ms-repeating-radial-gradient(center center, rgba(0,0,0,.2), rgba(0,0,0,.2) 1px, transparent 1px, transparent 100%);
	background-image: repeating-radial-gradient(center center, rgba(0,0,0,.2), rgba(0,0,0,.2) 1px, transparent 1px, transparent 100%);
	-webkit-background-size: 3px 3px;
	-moz-background-size: 3px 3px;
	background-size: 3px 3px;
}

@mixin fixHeighHack ($offsetHeight /*, $padding*/) {
/*
	#mainPanel {
		&.extra-wide {
			.subpanel {
				&.cardContent {
					height: calc(100% - #{$offsetHeight});
				}
			}
		}

		&.wide {
				.cardContent {
					height: calc(100% - #{$offsetHeight});
				}
		}
	}

	div.cardContent {
		div.cardListColumn.column {
			&.addCard {
				height: calc(100% + #{$offsetHeight});
			}

			div.cardList {
//				height: calc(100% - #{$padding} - #{$offsetHeight});
				height: calc(100% - #{$offsetHeight});
			}
		}
	}
*/
}

@mixin userSelectNone () {
	-moz-user-select: -moz-none;
	-khtml-user-select: none;
	-webkit-user-select: none;
	-ms-user-select: none;
	user-select: none;
}