2015-03-22 23:15:45 +01:00
|
|
|
/*
|
|
|
|
|
2018-11-25 17:31:43 +01:00
|
|
|
Copyright 2008-2018 Clipperz Srl
|
2015-03-22 23:15:45 +01:00
|
|
|
|
|
|
|
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/.
|
|
|
|
|
|
|
|
*/
|
|
|
|
|
2013-10-02 09:59:30 +02:00
|
|
|
@mixin border-radius ($radius) {
|
|
|
|
-webkit-border-radius: $radius;
|
2014-07-28 18:07:48 +02:00
|
|
|
-moz-border-radius: $radius;
|
|
|
|
border-radius: $radius;
|
2013-10-02 09:59:30 +02:00
|
|
|
}
|
|
|
|
|
2014-07-28 18:07:48 +02:00
|
|
|
@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) {
|
2015-02-13 08:57:00 +01:00
|
|
|
-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;
|
2013-10-02 09:59:30 +02:00
|
|
|
}
|
|
|
|
|
2014-07-28 18:07:48 +02:00
|
|
|
@mixin icon-font () {
|
2013-10-02 09:59:30 +02:00
|
|
|
font-family: 'clipperz-icons';
|
|
|
|
@include font-feature-settings("liga", "dlig");
|
|
|
|
-webkit-font-smoothing: antialiased;
|
|
|
|
text-rendering:optimizeLegibility;
|
|
|
|
}
|
|
|
|
|
2014-07-28 18:07:48 +02:00
|
|
|
@mixin password-font () {
|
2013-10-02 09:59:30 +02:00
|
|
|
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;
|
2014-07-28 18:07:48 +02:00
|
|
|
-moz-transition: $item $time $function;
|
|
|
|
-o-transition: $item $time $function;
|
|
|
|
-ms-transition: $item $time $function;
|
|
|
|
transition: $item $time $function;
|
2013-10-02 09:59:30 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@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);
|
|
|
|
}
|
|
|
|
|
2014-07-28 18:07:48 +02:00
|
|
|
@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;
|
|
|
|
}
|
|
|
|
|
2013-10-02 09:59:30 +02:00
|
|
|
|
|
|
|
@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;
|
|
|
|
}
|
|
|
|
|
2014-07-28 18:07:48 +02:00
|
|
|
@mixin keyframes ($name) {
|
2013-10-02 09:59:30 +02:00
|
|
|
@-webkit-keyframes #{$name} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
@-moz-keyframes #{$name} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
@-ms-keyframes #{$name} {
|
|
|
|
@content;
|
|
|
|
}
|
|
|
|
@keyframes #{$name} {
|
|
|
|
@content;
|
|
|
|
}
|
2014-07-28 18:07:48 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
@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); }
|
|
|
|
}
|
2014-10-12 14:48:34 +02:00
|
|
|
|
|
|
|
@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;
|
|
|
|
}
|
|
|
|
|
2015-04-20 18:02:37 +02:00
|
|
|
@mixin overflow-auto () {
|
|
|
|
overflow: auto;
|
2014-10-12 14:48:34 +02:00
|
|
|
-webkit-overflow-scrolling: touch;
|
|
|
|
}
|
2015-01-04 16:53:08 +01:00
|
|
|
|
2015-07-20 10:27:28 +02:00
|
|
|
@mixin chromeFix () {
|
|
|
|
-webkit-transform: translate3d(0,0,0);
|
|
|
|
}
|
|
|
|
|
2015-02-13 16:44:18 +01:00
|
|
|
@mixin placeholder {
|
|
|
|
&::-webkit-input-placeholder {@content}
|
|
|
|
&:-moz-placeholder {@content}
|
|
|
|
&::-moz-placeholder {@content}
|
|
|
|
&:-ms-input-placeholder {@content}
|
2015-03-09 15:32:36 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
@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;
|
|
|
|
}
|
2015-07-22 08:42:55 +02:00
|
|
|
|
2015-08-18 17:29:29 +02:00
|
|
|
@mixin fixHeighHack ($offsetHeight /*, $padding*/) {
|
|
|
|
/*
|
|
|
|
#mainPanel {
|
|
|
|
&.extra-wide {
|
|
|
|
.subpanel {
|
|
|
|
&.cardContent {
|
|
|
|
height: calc(100% - #{$offsetHeight});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
&.wide {
|
|
|
|
.cardContent {
|
|
|
|
height: calc(100% - #{$offsetHeight});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2015-07-22 08:42:55 +02:00
|
|
|
|
2015-08-18 17:29:29 +02:00
|
|
|
div.cardContent {
|
|
|
|
div.cardListColumn.column {
|
|
|
|
&.addCard {
|
|
|
|
height: calc(100% + #{$offsetHeight});
|
|
|
|
}
|
|
|
|
|
|
|
|
div.cardList {
|
|
|
|
// height: calc(100% - #{$padding} - #{$offsetHeight});
|
|
|
|
height: calc(100% - #{$offsetHeight});
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
*/
|
|
|
|
}
|
2015-11-23 16:10:44 +01:00
|
|
|
|
|
|
|
@mixin userSelectNone () {
|
|
|
|
-moz-user-select: -moz-none;
|
|
|
|
-khtml-user-select: none;
|
|
|
|
-webkit-user-select: none;
|
|
|
|
-ms-user-select: none;
|
|
|
|
user-select: none;
|
|
|
|
}
|