* Move some inline styles to CSS files * Move default_account_display_name span to fix useless tags with duplicate id * Change handling of public pages spoiler text from inline CSS to dataset attribute * Use the `dir` HTML attribute instead of inline CSS * Move status action bar inline CSS to CSS file * Hide logo resources from CSS file, not inline CSS Fixes #11601 * Move translation prompt styling from inline CSS to CSS file * Move “invited by” styling on registration form from inline to CSS file * Use the progress tag to display poll results in JS fallback * Fix poll results JS-less fallback when the user has voted for an option * Change account public page “moved” notice to use img tags instead of inline CSS * Move OTP hint inline CSS to SCSS file * Hide JS-less fallback vote progressbars from accessibility tools Co-authored-by: Eugen Rochko <eugen@zeonfederated.com>
		
			
				
	
	
		
			247 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
			
		
		
	
	
			247 lines
		
	
	
	
		
			4.4 KiB
		
	
	
	
		
			SCSS
		
	
	
	
	
	
| @function hex-color($color) {
 | |
|   @if type-of($color) == 'color' {
 | |
|     $color: str-slice(ie-hex-str($color), 4);
 | |
|   }
 | |
| 
 | |
|   @return '%23' + unquote($color);
 | |
| }
 | |
| 
 | |
| body {
 | |
|   font-family: $font-sans-serif, sans-serif;
 | |
|   background: darken($ui-base-color, 7%);
 | |
|   font-size: 13px;
 | |
|   line-height: 18px;
 | |
|   font-weight: 400;
 | |
|   color: $primary-text-color;
 | |
|   text-rendering: optimizelegibility;
 | |
|   font-feature-settings: "kern";
 | |
|   text-size-adjust: none;
 | |
|   -webkit-tap-highlight-color: rgba(0, 0, 0, 0);
 | |
|   -webkit-tap-highlight-color: transparent;
 | |
| 
 | |
|   &.system-font {
 | |
|     // system-ui => standard property (Chrome/Android WebView 56+, Opera 43+, Safari 11+)
 | |
|     // -apple-system => Safari <11 specific
 | |
|     // BlinkMacSystemFont => Chrome <56 on macOS specific
 | |
|     // Segoe UI => Windows 7/8/10
 | |
|     // Oxygen => KDE
 | |
|     // Ubuntu => Unity/Ubuntu
 | |
|     // Cantarell => GNOME
 | |
|     // Fira Sans => Firefox OS
 | |
|     // Droid Sans => Older Androids (<4.0)
 | |
|     // Helvetica Neue => Older macOS <10.11
 | |
|     // $font-sans-serif => web-font (Roboto) fallback and newer Androids (>=4.0)
 | |
|     font-family: system-ui, -apple-system, BlinkMacSystemFont, "Segoe UI", "Oxygen", "Ubuntu", "Cantarell", "Fira Sans", "Droid Sans", "Helvetica Neue", $font-sans-serif, sans-serif;
 | |
|   }
 | |
| 
 | |
|   &.app-body {
 | |
|     padding: 0;
 | |
| 
 | |
|     &.layout-single-column {
 | |
|       height: auto;
 | |
|       min-height: 100vh;
 | |
|       overflow-y: scroll;
 | |
|     }
 | |
| 
 | |
|     &.layout-multiple-columns {
 | |
|       position: absolute;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|     }
 | |
| 
 | |
|     &.with-modals--active {
 | |
|       overflow-y: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.lighter {
 | |
|     background: $ui-base-color;
 | |
|   }
 | |
| 
 | |
|   &.with-modals {
 | |
|     overflow-x: hidden;
 | |
|     overflow-y: scroll;
 | |
| 
 | |
|     &--active {
 | |
|       overflow-y: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.player {
 | |
|     text-align: center;
 | |
|   }
 | |
| 
 | |
|   &.embed {
 | |
|     background: lighten($ui-base-color, 4%);
 | |
|     margin: 0;
 | |
|     padding-bottom: 0;
 | |
| 
 | |
|     .container {
 | |
|       position: absolute;
 | |
|       width: 100%;
 | |
|       height: 100%;
 | |
|       overflow: hidden;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &.admin {
 | |
|     background: darken($ui-base-color, 4%);
 | |
|     padding: 0;
 | |
|   }
 | |
| 
 | |
|   &.error {
 | |
|     position: absolute;
 | |
|     text-align: center;
 | |
|     color: $darker-text-color;
 | |
|     background: $ui-base-color;
 | |
|     width: 100%;
 | |
|     height: 100%;
 | |
|     padding: 0;
 | |
|     display: flex;
 | |
|     justify-content: center;
 | |
|     align-items: center;
 | |
| 
 | |
|     .dialog {
 | |
|       vertical-align: middle;
 | |
|       margin: 20px;
 | |
| 
 | |
|       &__illustration {
 | |
|         img {
 | |
|           display: block;
 | |
|           max-width: 470px;
 | |
|           width: 100%;
 | |
|           height: auto;
 | |
|           margin-top: -120px;
 | |
|         }
 | |
|       }
 | |
| 
 | |
|       h1 {
 | |
|         font-size: 20px;
 | |
|         line-height: 28px;
 | |
|         font-weight: 400;
 | |
|       }
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| button {
 | |
|   font-family: inherit;
 | |
|   cursor: pointer;
 | |
| 
 | |
|   &:focus {
 | |
|     outline: none;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .app-holder {
 | |
|   &,
 | |
|   & > div,
 | |
|   & > noscript {
 | |
|     display: flex;
 | |
|     width: 100%;
 | |
|     align-items: center;
 | |
|     justify-content: center;
 | |
|     outline: 0 !important;
 | |
|   }
 | |
| 
 | |
|   & > noscript {
 | |
|     height: 100vh;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .layout-single-column .app-holder {
 | |
|   &,
 | |
|   & > div {
 | |
|     min-height: 100vh;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .layout-multiple-columns .app-holder {
 | |
|   &,
 | |
|   & > div {
 | |
|     height: 100%;
 | |
|   }
 | |
| }
 | |
| 
 | |
| .error-boundary,
 | |
| .app-holder noscript {
 | |
|   flex-direction: column;
 | |
|   font-size: 16px;
 | |
|   font-weight: 400;
 | |
|   line-height: 1.7;
 | |
|   color: lighten($error-red, 4%);
 | |
|   text-align: center;
 | |
| 
 | |
|   & > div {
 | |
|     max-width: 500px;
 | |
|   }
 | |
| 
 | |
|   p {
 | |
|     margin-bottom: .85em;
 | |
| 
 | |
|     &:last-child {
 | |
|       margin-bottom: 0;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   a {
 | |
|     color: $highlight-text-color;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       text-decoration: none;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   &__footer {
 | |
|     color: $dark-text-color;
 | |
|     font-size: 13px;
 | |
| 
 | |
|     a {
 | |
|       color: $dark-text-color;
 | |
|     }
 | |
|   }
 | |
| 
 | |
|   button {
 | |
|     display: inline;
 | |
|     border: 0;
 | |
|     background: transparent;
 | |
|     color: $dark-text-color;
 | |
|     font: inherit;
 | |
|     padding: 0;
 | |
|     margin: 0;
 | |
|     line-height: inherit;
 | |
|     cursor: pointer;
 | |
|     outline: 0;
 | |
|     transition: color 300ms linear;
 | |
|     text-decoration: underline;
 | |
| 
 | |
|     &:hover,
 | |
|     &:focus,
 | |
|     &:active {
 | |
|       text-decoration: none;
 | |
|     }
 | |
| 
 | |
|     &.copied {
 | |
|       color: $valid-value-color;
 | |
|       transition: none;
 | |
|     }
 | |
|   }
 | |
| }
 | |
| 
 | |
| .logo-resources {
 | |
|   display: none;
 | |
| }
 | |
| 
 | |
| // NoScript adds a __ns__pop2top class to the full ancestry of blocked elements,
 | |
| // to set the z-index to a high value, which messes with modals and dropdowns.
 | |
| // Blocked elements can in theory only be media and frames/embeds, so they
 | |
| // should only appear in statuses, under divs and articles.
 | |
| body,
 | |
| div,
 | |
| article {
 | |
|   .__ns__pop2top {
 | |
|     z-index: unset !important;
 | |
|   }
 | |
| }
 |