UNPKG

@pi0/framework7

Version:

Full featured mobile HTML framework for building iOS & Android apps

395 lines (387 loc) 9.89 kB
// Colors Loop .color-theme-loop(@ruleset) when (length( @colors ) >= 1) { @length: length( @colors ) ; .looper( 1 ) ; .looper( @index ) when ( @index <= @length ) and (length(extract( @colors, @index )) = 2) { @pairTheme: extract( @colors, @index ); @colorThemeName: extract( @pairTheme, 1 ) ; @colorThemeValue: extract( @pairTheme, 2 ) ; @ruleset(); .looper( @index + 1 ) ; } } .color-loop(@ruleset) when (length( @colors ) >= 1) { @length: length( @colors ) ; .looper( 1 ) ; .looper( @index ) when ( @index <= @length ) and (length(extract( @colors, @index )) = 2) { @pair: extract( @colors, @index ); @colorName: extract( @pair, 1 ) ; @colorValue: extract( @pair, 2 ) ; @ruleset(); .looper( @index + 1 ) ; } } // RTL, LTR .ltr(@ruleset) { & when not (@rtl) { @ruleset(); } } .rtl(@ruleset) { & when (@rtl) { @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; will-change: opacity; contain: strict; &.not-animated { transition-duration: 0ms; } &.backdrop-in { visibility: visible; opacity: 1; } } // No Hairlines .no-hairlines() { &.no-hairlines, &.no-hairlines ul, .md &.no-hairlines-md, .md &.no-hairlines-md ul, .ios &.no-hairlines-ios, .ios &.no-hairlines-ios ul { .hairline-remove(top); .hairline-remove(bottom); } &.no-hairline-top, &.no-hairline-top ul, .md &.no-hairline-top-md, .md &.no-hairline-top-md ul, .ios &.no-hairline-top-ios, .ios &.no-hairline-top-ios ul { .hairline-remove(top); } &.no-hairline-bottom, &.no-hairline-bottom ul, .md &.no-hairline-bottom-md, .md &.no-hairline-bottom-md ul, .ios &.no-hairline-bottom-ios, .ios &.no-hairline-bottom-ios ul { .hairline-remove(bottom); } } .no-hairlines-between() { &.no-hairlines-between, .md &.no-hairlines-between-md, .ios &.no-hairlines-between-ios { .item-inner, .list-button, .item-divider, .list-group-title, .list-group-title { .hairline-remove(bottom); } } } // 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%; html.device-pixel-ratio-2 & { transform: scaleY(0.5); } html.device-pixel-ratio-3 & { transform: scaleY(0.33); } } } .hairline-root(@selector, @position, @color) when (@position = top) { @selectorEscaped: e(@selector); @{selectorEscaped}:before { .hairline-pseudo(@color, 0, auto, auto, 0); height: 1px; width: 100%; transform-origin: 50% 0%; } &.device-pixel-ratio-2 @{selectorEscaped}:before { transform: scaleY(0.5); } &.device-pixel-ratio-3 @{selectorEscaped}:before { transform: scaleY(0.33); } } .hairline(@position, @color) when (@position = left) { &:before { .hairline-pseudo(@color, 0, auto, auto, 0); width: 1px; height: 100%; transform-origin: 0% 50%; html.device-pixel-ratio-2 & { transform: scaleX(0.5); } html.device-pixel-ratio-3 & { transform: scaleX(0.33); } } } .hairline-root(@selector, @position, @color) when (@position = left) { @selectorEscaped: e(@selector); @{selectorEscaped}:before { .hairline-pseudo(@color, 0, auto, auto, 0); width: 1px; height: 100%; transform-origin: 0% 50%; } &.device-pixel-ratio-2 @{selectorEscaped}:before { transform: scaleX(0.5); } &.device-pixel-ratio-3 @{selectorEscaped}:before { transform: scaleX(0.33); } } .hairline(@position, @color) when (@position = bottom) { &:after { .hairline-pseudo(@color, auto, auto, 0, 0); height: 1px; width: 100%; transform-origin: 50% 100%; html.device-pixel-ratio-2 & { transform: scaleY(0.5); } html.device-pixel-ratio-3 & { transform: scaleY(0.33); } } } .hairline-root(@selector, @position, @color) when (@position = bottom) { @selectorEscaped: e(@selector); @{selectorEscaped}:after { .hairline-pseudo(@color, auto, auto, 0, 0); height: 1px; width: 100%; transform-origin: 50% 100%; } &.device-pixel-ratio-2 @{selectorEscaped}:after { transform: scaleY(0.5); } &.device-pixel-ratio-3 @{selectorEscaped}:after { transform: scaleY(0.33); } } .hairline(@position, @color) when (@position = right) { &:after { .hairline-pseudo(@color, 0, 0, auto, auto); width: 1px; height: 100%; transform-origin: 100% 50%; html.device-pixel-ratio-2 & { transform: scaleX(0.5); } html.device-pixel-ratio-3 & { transform: scaleX(0.33); } } } .hairline-root(@selector, @position, @color) when (@position = right) { @selectorEscaped: e(@selector); @{selectorEscaped}:after { .hairline-pseudo(@color, 0, 0, auto, auto); width: 1px; height: 100%; transform-origin: 100% 50%; } &.device-pixel-ratio-2 @{selectorEscaped}:after { transform: scaleX(0.5); } &.device-pixel-ratio-3 @{selectorEscaped}:after { transform: scaleX(0.33); } } // For right and bottom .hairline-remove(@position) when not (@position = left) and not (@position = top) { &:after { display: none !important; } } // For left and top .hairline-remove(@position) when not (@position = right) and not (@position = bottom) { &:before { display: none !important; } } // 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; } } // SVG BG .svg-background(@svg) { @url: `encodeURIComponent(@{svg})`; background-image: url("data:image/svg+xml;charset=utf-8,@{url}"); } // MD Active Active Links Highlights .md-link-highlight(@color:rgba(255,255,255,0.15)) { &:before { content: ''; width: 152%; height: 152%; position: absolute; left: -26%; top: -26%; background-image: -webkit-radial-gradient(center, circle cover, @color 66%, rgba(red(@color),green(@color),blue(@color),0) 66%); background-image: radial-gradient(circle at center, @color 66%, rgba(red(@color),green(@color),blue(@color),0) 66%); background-repeat: no-repeat; background-position: center; background-size: 100% 100%; opacity: 0; pointer-events: none; transition-duration: 600ms; } &.active-state:before { opacity: 1; transition-duration: 150ms; } } .md-link-highlight-color(@color) { &:before { background-image: -webkit-radial-gradient(center, circle cover, @color 66%, rgba(red(@color),green(@color),blue(@color),0) 66%); background-image: radial-gradient(circle at center, @color 66%, rgba(red(@color),green(@color),blue(@color),0) 66%); } } // MD Button .md-button() { color:@themeColor; border-radius: 2px; line-height: 36px; height: 36px; text-transform: uppercase; min-width: 64px; padding: 0 8px; border: none; transition-duration: 300ms; transform: translate3d(0,0,0); &.active-state { background: rgba(0,0,0,0.1); } &.button-fill, &.button-active, &.tab-link-active { background-color: @themeColor; color: #fff; &.active-state { background: darken(@themeColor, 8%); } } &.button-big { height: 48px; line-height: 48px; border-radius: 3px; } &.button-round { border-radius: 36px; } i.icon + span, span:not(.ripple-wave) + span, span:not(.ripple-wave) + i.icon, i.icon + i.icon { margin-left: 8px; } // Raised (with shadow) buttons &.button-raised { box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24); &.active-state { box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23); } } } // MD Shadows .md-depth(@level:1) { & when (@level = 1) { box-shadow: 0 1px 3px rgba(0,0,0,0.12), 0 1px 2px rgba(0,0,0,0.24); } & when (@level = 2) { box-shadow: 0 3px 6px rgba(0,0,0,0.16), 0 3px 6px rgba(0,0,0,0.23); } & when (@level = 3) { box-shadow: 0 10px 20px rgba(0,0,0,0.19), 0 6px 6px rgba(0,0,0,0.23); } & when (@level = 4) { box-shadow: 0 14px 28px rgba(0,0,0,0.25), 0 10px 10px rgba(0,0,0,0.22); } & when (@level = 5) { box-shadow: 0 19px 38px rgba(0,0,0,0.30), 0 15px 12px rgba(0,0,0,0.22); } } // MD Bars Shadow .md-bar-shadow-remove() { &:after { display: none; } } .md-bar-shadow-to-bottom() { &:after { content: ''; position: absolute; right: 0; width: 100%; top: 100%; bottom: auto; height: 10px; pointer-events: none; background: linear-gradient(to bottom, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.1) 40%, rgba(0,0,0,0.05) 50%, rgba(0,0,0,0) 80%, rgba(0,0,0,0) 100% ); } } .md-bar-shadow-to-top() { &:after { content: ''; position: absolute; right: 0; width: 100%; bottom: 100%; height: 10px; top: auto; pointer-events: none; background: linear-gradient(to top, rgba(0,0,0,0.3) 0%, rgba(0,0,0,0.1) 40%, rgba(0,0,0,0.05) 50%, rgba(0,0,0,0) 80%, rgba(0,0,0,0) 100% ); } } .md-bar-no-shadow() { &:after { display: none; } }