framework7
Version:
Full featured mobile HTML framework for building iOS & Android apps
282 lines (276 loc) • 5.83 kB
text/less
// RTL, LTR
.ltr(@ruleset) {
& when not (@rtl) {
@ruleset();
}
}
.rtl(@ruleset) {
& when (@rtl) {
@ruleset();
}
}
.if-ios-theme(@ruleset) {
& when (@includeIosTheme) {
@ruleset();
}
}
.if-md-theme(@ruleset) {
& when (@includeMdTheme) {
@ruleset();
}
}
.if-dark-theme(@ruleset) {
& when(@includeDarkTheme) {
@ruleset();
}
}
.ios-vars(@ruleset) {
& when (@includeIosTheme) {
.ios {
@ruleset();
}
}
}
.md-vars(@ruleset) {
& when (@includeMdTheme) {
.md {
@ruleset();
}
}
}
.md-color-vars(@ruleset) {
& when (@includeMdTheme) {
.md,
.md .dark,
.md [class*='color-'] {
@ruleset();
}
}
}
.dark-vars(@ruleset) {
& when (@includeDarkTheme) {
.dark,
&.dark {
@ruleset();
}
}
}
.light-vars(@ruleset) {
& when (@includeLightTheme) {
& {
@ruleset();
}
}
}
// Scrollable
.scrollable() {
overflow: auto;
-webkit-overflow-scrolling: touch;
}
.not-scrollable() {
overflow: hidden;
-webkit-overflow-scrolling: auto;
}
// Disabled
.disabled() {
opacity: 0.55;
pointer-events: none;
}
// Modal Backdrops
.modal-backdrop() {
position: absolute;
left: 0;
top: 0;
width: 100%;
height: 100%;
background: rgba(0, 0, 0, 0.4);
z-index: 13000;
visibility: hidden;
opacity: 0;
transition-duration: 400ms;
&.not-animated {
transition-duration: 0ms;
}
&.backdrop-in {
visibility: visible;
opacity: 1;
}
}
// Hairlines
.hairline-pseudo(@color, @top, @right, @bottom, @left) {
content: '';
position: absolute;
background-color: @color;
display: block;
z-index: 15;
top: @top;
right: @right;
bottom: @bottom;
left: @left;
}
.hairline(@position, @color) when (@position = top) {
&:before {
.hairline-pseudo(@color, 0, auto, auto, 0);
height: 1px;
width: 100%;
transform-origin: 50% 0%;
transform: scaleY(calc(1 / var(--f7-device-pixel-ratio)));
}
}
.hairline(@position, @color) when (@position = left) {
&:before {
.hairline-pseudo(@color, 0, auto, auto, 0);
width: 1px;
height: 100%;
transform-origin: 0% 50%;
transform: scaleX(calc(1 / var(--f7-device-pixel-ratio)));
}
}
.hairline(@position, @color) when (@position = bottom) {
&:after {
.hairline-pseudo(@color, auto, auto, 0, 0);
height: 1px;
width: 100%;
transform-origin: 50% 100%;
transform: scaleY(calc(1 / var(--f7-device-pixel-ratio)));
}
}
.hairline(@position, @color) when (@position = right) {
&:after {
.hairline-pseudo(@color, 0, 0, auto, auto);
width: 1px;
height: 100%;
transform-origin: 100% 50%;
transform: scaleX(calc(1 / var(--f7-device-pixel-ratio)));
}
}
.hairline-remove-top-bottom() {
&:before,
&:after {
display: none ;
}
}
// For right and bottom
.hairline-remove(@position) when not (@position = left) and not (@position = top) {
&:after {
display: none ;
}
}
// For left and top
.hairline-remove(@position) when not (@position = right) and not (@position = bottom) {
&:before {
display: none ;
}
}
// For right and bottom
.hairline-color(@position, @color) when not (@position = left) and not (@position = top) {
&:after {
background-color: @color;
}
}
// For left and top
.hairline-color(@position, @color) when not (@position = right) and not (@position = bottom) {
&:before {
background-color: @color;
}
}
// MD Active Active Links Highlights
.link-highlight() {
&:before {
content: '';
width: 152%;
height: 152%;
left: -26%;
top: -26%;
position: absolute;
background-image: radial-gradient(
circle at center,
var(--f7-link-highlight-color) 66%,
rgba(255, 255, 255, 0) 66%
);
background-repeat: no-repeat;
background-position: center;
background-size: 100% 100%;
opacity: 0;
pointer-events: none;
transition-duration: 300ms;
transition-property: opacity;
}
&.icon-only:before,
&.ripple-inset:before,
&.searchbar-disable-button:before,
&.input-clear-button:before,
&.notification-close-button:before {
width: 100%;
height: 100%;
left: 0;
top: 0;
background-image: radial-gradient(
circle at center,
var(--f7-link-highlight-color) 71%,
rgba(255, 255, 255, 0) 71%
);
}
&.active-state:before {
opacity: 1;
transition-duration: 150ms;
}
}
// MD Bars Shadow
.core-icons-font() {
font-family: 'framework7-core-icons';
font-weight: normal;
font-style: normal;
line-height: 1;
letter-spacing: normal;
text-transform: none;
white-space: nowrap;
word-wrap: normal;
direction: ltr;
-webkit-font-smoothing: antialiased;
text-rendering: optimizeLegibility;
-moz-osx-font-smoothing: grayscale;
font-feature-settings: 'liga';
text-align: center;
display: block;
width: 100%;
height: 100%;
font-size: 20px;
}
.ios-translucent-bars(@color) {
.ios-translucent-bars & {
@supports (backdrop-filter: blur(20px)) {
background-color: rgba(@color, var(--f7-bars-translucent-opacity));
backdrop-filter: saturate(180%) blur(var(--f7-bars-translucent-blur));
}
}
}
.ios-translucent-modals(@color) {
.ios-translucent-modals & {
@supports (backdrop-filter: blur(20px)) {
background-color: rgba(@color, 0.8);
backdrop-filter: saturate(180%) blur(20px);
}
}
}
.no-scrollbar() {
scrollbar-width: none;
scrollbar-color: transparent;
&::-webkit-scrollbar {
appearance: none;
width: 0px;
display: none;
opacity: 0;
background: transparent;
}
&::-webkit-scrollbar-track {
box-shadow: none;
background: transparent;
}
&::-webkit-scrollbar-thumb {
background-color: transparent;
outline: none;
border-radius: 9999px;
position: relative;
}
}