Merge remote-tracking branches 'cybre/feature_hotlink_twitter_mentions', 'cybre/feature_longer_bios' and 'cybre/theme_light' into scalybiz
This commit is contained in:
		
						commit
						a960b023a9
					
				
					 12 changed files with 1114 additions and 17 deletions
				
			
		
							
								
								
									
										
											BIN
										
									
								
								app/javascript/images/background-cybre-light.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/javascript/images/background-cybre-light.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 223 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/javascript/images/header-cybre-alt.jpg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/javascript/images/header-cybre-alt.jpg
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 786 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/javascript/images/header-cybre-colour.jpg
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/javascript/images/header-cybre-colour.jpg
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 9.9 KiB | 
							
								
								
									
										
											BIN
										
									
								
								app/javascript/images/logo-cybre-light.png
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										
											BIN
										
									
								
								app/javascript/images/logo-cybre-light.png
									
										
									
									
									
										Normal file
									
								
							
										
											Binary file not shown.
										
									
								
							| After Width: | Height: | Size: 149 KiB | 
|  | @ -17,6 +17,12 @@ window.addEventListener('message', e => { | |||
|       id: data.id, | ||||
|       height: document.getElementsByTagName('html')[0].scrollHeight, | ||||
|     }, '*'); | ||||
| 
 | ||||
|     if (document.fonts && document.fonts.ready) { | ||||
|       document.fonts.ready.then(sizeBioText); | ||||
|     } else { | ||||
|       sizeBioText(); | ||||
|     } | ||||
|   }); | ||||
| }); | ||||
| 
 | ||||
|  | @ -91,6 +97,17 @@ function main() { | |||
|       detailedStatuses[0].scrollIntoView(); | ||||
|       history.replace(location.pathname, { ...location.state, scrolledToDetailedStatus: true }); | ||||
|     } | ||||
| 
 | ||||
|     [].forEach.call(document.querySelectorAll('[data-component="Card"]'), (content) => { | ||||
|       const props = JSON.parse(content.getAttribute('data-props')); | ||||
|       ReactDOM.render(<CardContainer locale={locale} {...props} />, content); | ||||
|     }); | ||||
| 
 | ||||
|     if (document.fonts && document.fonts.ready) { | ||||
|       document.fonts.ready.then(sizeBioText); | ||||
|     } else { | ||||
|       sizeBioText(); | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   delegate(document, '.webapp-btn', 'click', ({ target, button }) => { | ||||
|  | @ -142,13 +159,7 @@ function main() { | |||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   delegate(document, '#account_note', 'input', ({ target }) => { | ||||
|     const noteCounter = document.querySelector('.note-counter'); | ||||
| 
 | ||||
|     if (noteCounter) { | ||||
|       noteCounter.textContent = 160 - length(target.value); | ||||
|     } | ||||
|   }); | ||||
|   delegate(document, '#account_note', 'input', sizeBioText); | ||||
| 
 | ||||
|   delegate(document, '#account_avatar', 'change', ({ target }) => { | ||||
|     const avatar = document.querySelector('.card .avatar img'); | ||||
|  | @ -175,6 +186,20 @@ function main() { | |||
|       lock.style.display = 'none'; | ||||
|     } | ||||
|   }); | ||||
| 
 | ||||
|   function sizeBioText() { | ||||
|     const noteCounter = document.querySelector('.note-counter'); | ||||
|     const bioTextArea = document.querySelector('#account_note'); | ||||
| 
 | ||||
|     if (noteCounter) { | ||||
|       noteCounter.textContent = 413 - length(bioTextArea.value); | ||||
|     } | ||||
| 
 | ||||
|     if (bioTextArea) { | ||||
|       bioTextArea.style.height = 'auto'; | ||||
|       bioTextArea.style.height = (bioTextArea.scrollHeight+3) + 'px'; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| loadPolyfills().then(main).catch(error => { | ||||
|  |  | |||
							
								
								
									
										63
									
								
								app/javascript/styles/cybre-base.scss
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										63
									
								
								app/javascript/styles/cybre-base.scss
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,63 @@ | |||
| 
 | ||||
| @import 'application'; | ||||
| 
 | ||||
| /* Allow columns to grow wider as the screen gets  | ||||
|  * wider, but don't ever let them get more than | ||||
|  * 400px (some people have a bunch of columns!) */ | ||||
| @media screen and (min-width: 1300px) { | ||||
|   .column { | ||||
|     flex-grow: 1 !important; | ||||
|     max-width: 400px; | ||||
|   } | ||||
| 
 | ||||
|   .drawer { | ||||
|     width: 17%; /* Not part of the flex fun */ | ||||
|     max-width: 400px; | ||||
|     min-width: 330px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* Cap the column height at 100vh (fixed an old | ||||
|  * bug someone encountered in safari, but which | ||||
|  * I've seen resurface from time to time) */ | ||||
| .column { | ||||
|   max-height:100vh; | ||||
| } | ||||
| 
 | ||||
| /* Don't show outline around statuses if we're in  | ||||
|  * mouse or touch mode (rather than keyboard) */ | ||||
| [data-whatinput="mouse"], [data-whatinput="touch"] { | ||||
|   .status__content:focus, .status:focus, | ||||
|   .status__wrapper:focus, .status__content__text:focus { | ||||
|     outline: none; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* Show a little arrowey thing after the time in a | ||||
|  * status to signal that you can click it to see | ||||
|  * a detailed view */ | ||||
| .status time:after, | ||||
| .detailed-status__datetime span:after { | ||||
|   font: normal normal normal 14px/1 FontAwesome; | ||||
|   content: "\00a0\00a0\f08e"; | ||||
| } | ||||
| 
 | ||||
| /* Don't display the elephant mascot (we have our | ||||
|  * own, thanks) */ | ||||
| .drawer__inner__mastodon { | ||||
|   display: none; | ||||
| } | ||||
| 
 | ||||
| /* Let the compose area/drawer be short, but | ||||
|  * expand if necessary */ | ||||
| .drawer .drawer__inner { | ||||
|   overflow: visible; | ||||
|   height:inherit; | ||||
|   background-image: none; | ||||
| } | ||||
| .drawer__pager { | ||||
|   overflow-y:auto; | ||||
| } | ||||
| 
 | ||||
| @import 'fullwidth-media'; | ||||
| 
 | ||||
							
								
								
									
										957
									
								
								app/javascript/styles/cybre-light.scss
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										957
									
								
								app/javascript/styles/cybre-light.scss
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,957 @@ | |||
| $ui-base-color: #f7e8ed; // "darkest" | ||||
| $ui-base-alt: #f9f2f5; | ||||
| $ui-base-lighter-color: darken($ui-base-color, 40%); // Lighter darkest | ||||
| $ui-secondary-color: #ead0d6; // "lightest" | ||||
| $ui-primary-color: #bf5677; // "lighter" | ||||
| $ui-highlight-color: #bf5677; // "vibrant" | ||||
| $primary-text-color: #382b32; | ||||
| $secondary-text-color: #382b32; | ||||
| 
 | ||||
| $header-color: $ui-primary-color; | ||||
| $header-text-color: #fff; | ||||
| $icon-button-inactive-color: lighten(desaturate($ui-base-lighter-color, 20%), 20%); | ||||
| $action-button-color: $icon-button-inactive-color; | ||||
| 
 | ||||
| $about-page-text: $primary-text-color; | ||||
| 
 | ||||
| @import 'application'; | ||||
| 
 | ||||
| 
 | ||||
| $gold-star: #dd9d08; | ||||
| 
 | ||||
| /* cybre-specific additions */ | ||||
| 
 | ||||
| .column .static-content.getting-started { | ||||
|   background-image: url('../images/logo-cybre-light.png'); | ||||
|   background-size:auto 50%; | ||||
|   background-position: 50% 75%; | ||||
|   background-repeat:no-repeat; | ||||
| } | ||||
| 
 | ||||
| .ui, body { | ||||
|   background: $ui-base-color url('../images/background-cybre-light.png'); | ||||
| } | ||||
| 
 | ||||
| .drawer__inner__mastodon { | ||||
|   display: none; | ||||
| } | ||||
| 
 | ||||
| .landing-page .header-wrapper { | ||||
|     background-image:url('../images/header-cybre-alt.jpg'); | ||||
|     background-size:cover; | ||||
|     background-position:50% 50%; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .header { | ||||
|     background-image:url('../images/header-cybre-colour.jpg'); | ||||
|     background-repeat: repeat-x; | ||||
|     background-size:contain; | ||||
|     height:45vh; | ||||
|     width: 100%; | ||||
|     position:absolute; | ||||
|     z-index: 1; | ||||
|     text-align:center; | ||||
| 
 | ||||
|     display: unset!important; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .header img { | ||||
|     margin: auto; | ||||
|     max-height:45vh; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .landing-page.alternative .grid { | ||||
|     position: relative; | ||||
|     z-index:2; | ||||
|     margin-top:15vh; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .landing-page__hero img { | ||||
|     visibility: hidden; | ||||
|     max-height:170px; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .landing-page__forms { | ||||
|     height:auto; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .column-1 { | ||||
|     display:flex; | ||||
|     align-items:flex-end; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .column { | ||||
|     max-height:initial; | ||||
| } | ||||
| 
 | ||||
| .landing-page.alternative .row__mascot { | ||||
|     .floats { | ||||
|         position:absolute; | ||||
|         img { | ||||
|             width:100%; | ||||
|             height:100%; | ||||
|         } | ||||
|         transition: all 0.1s linear; | ||||
|         animation-name: floating; | ||||
|         animation-iteration-count: infinite; | ||||
|         animation-direction: alternate; | ||||
|         animation-timing-function: ease-in-out; | ||||
|     } | ||||
| 
 | ||||
|     .float-1 { | ||||
|         width:50px; | ||||
|         height:50px; | ||||
|         bottom:60px; | ||||
|         left:110px; | ||||
|         animation-duration: 3s; | ||||
|     } | ||||
| 
 | ||||
|     .float-2 { | ||||
|         width:130px; | ||||
|         height:130px; | ||||
|         left:85px; | ||||
|         bottom: -60px; | ||||
|         animation-duration: 3.5s; | ||||
|         animation-delay: 0.2s; | ||||
|     } | ||||
| 
 | ||||
|     .float-3 { | ||||
|         width:100px; | ||||
|         height:100px; | ||||
|         right: 50; | ||||
|         top: -10px; | ||||
|         animation-duration: 4s; | ||||
|         animation-delay: 0.5s; | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| /* about.scss */ | ||||
| 
 | ||||
| .landing-page { | ||||
|   h1 { | ||||
|     color: $about-page-text; | ||||
|     small { | ||||
|       color: lighten($about-page-text, 10%); | ||||
|     } | ||||
|   } | ||||
|   p, li { | ||||
|     color: $about-page-text; | ||||
|   } | ||||
| 
 | ||||
|   .header-wrapper { | ||||
|     padding-top:0px; | ||||
| 
 | ||||
|     background-size:cover; | ||||
|     background-position:50% 55%; | ||||
|   } | ||||
| 
 | ||||
|   .header-wrapper { | ||||
|     .mascot { | ||||
|         width:500px; | ||||
|         bottom:-52px; | ||||
|         left:-120px; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   .container.links { | ||||
|      background-color: $ui-base-color; | ||||
|      border-top: 5px solid $ui-primary-color; | ||||
|      width:100%; | ||||
|      max-width:100%; | ||||
|      padding:0px calc(50% - 400px); | ||||
| 
 | ||||
|      a { | ||||
|         &:hover { | ||||
|           color: lighten($ui-primary-color, 10%); | ||||
|         } | ||||
|      } | ||||
|   } | ||||
| 
 | ||||
|   .container.hero { | ||||
|       .floats { | ||||
|           display:none; | ||||
|       } | ||||
| 
 | ||||
|       .closed-registrations-message, form { | ||||
|           border-top: 50px solid #5f4770; | ||||
|           -webkit-box-shadow: 0 0 6px rgba(0,0,0,.1); | ||||
|           box-shadow: 0 0 6px rgba(0,0,0,.1); | ||||
| 
 | ||||
|           &:before { | ||||
|               font-size: 16px; | ||||
|               font-family:inherit; | ||||
|               line-height:inherit; | ||||
|               font-weight:normal; | ||||
|               color:white; | ||||
|               position:absolute; | ||||
|               top:-35px; | ||||
|           } | ||||
|       } | ||||
| 
 | ||||
|       .closed-registrations-message:before { | ||||
|           content: "Registrations closed"; | ||||
|       } | ||||
| 
 | ||||
|       form:before { | ||||
|           content: "Register now"; | ||||
|       } | ||||
|   } | ||||
| 
 | ||||
|   #mastodon-timeline { | ||||
|     .column-header { | ||||
|       color:white; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .features-list__row { | ||||
|   .text { | ||||
|     color: $about-page-text; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .information-board { | ||||
|   .panel { | ||||
|     .panel-header { | ||||
|       color: $primary-text-color; | ||||
|       border-bottom: 1px solid lighten($ui-secondary-color, 4%); | ||||
| 
 | ||||
|       a, | ||||
|       span { | ||||
|         font-weight: 400; | ||||
|         color: lighten($ui-primary-color, 4%); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* components.scss */ | ||||
| 
 | ||||
| .onboarding-modal__page { | ||||
|   p { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .column-header { | ||||
|   background: $header-color; | ||||
|   color: $header-text-color; | ||||
|   border-top-left-radius: 3px; | ||||
|   border-top-right-radius: 3px; | ||||
|   box-shadow: 0px 0px 3px rgba(0,0,0,0.3); | ||||
| } | ||||
| 
 | ||||
| .column-header__button { | ||||
|   background: $header-color; | ||||
|   color: $header-text-color; | ||||
|   border-top-right-radius: 3px; | ||||
| 
 | ||||
|   &:hover { | ||||
|     color: darken($ui-base-color, 10%); | ||||
|   } | ||||
| 
 | ||||
|   &.active { | ||||
|     color: $primary-text-color; | ||||
|     background: darken($ui-base-color, 5%); | ||||
| 
 | ||||
|     &:hover { | ||||
|       background: darken($ui-base-color, 5%); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| // selectivity -- needs to override .column-header > button | ||||
| .column-header .column-header__back-button { | ||||
|   background: $header-color; | ||||
|   color:$header-text-color; | ||||
| } | ||||
| 
 | ||||
| .column-back-button { | ||||
|   background: $header-color; | ||||
|   color:$header-text-color; | ||||
| } | ||||
| 
 | ||||
| .column-header__collapsible-inner { | ||||
|   background: darken($ui-base-alt, 2%); | ||||
| } | ||||
| 
 | ||||
| .empty-column-indicator, | ||||
| .error-column { | ||||
|   color: darken($ui-base-lighter-color, 15%); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .compose-form { | ||||
|   .autosuggest-textarea__textarea, | ||||
|   .spoiler-input__input { | ||||
|     color: $primary-text-color; | ||||
|     border: 1px solid $ui-primary-color; | ||||
|   } | ||||
| 
 | ||||
|   .autosuggest-textarea__textarea { | ||||
|     border-bottom-width:0px; | ||||
|   } | ||||
|   .compose-form__modifiers { | ||||
|     border: 1px solid $ui-primary-color; | ||||
|     border-top-width:0px; | ||||
|   } | ||||
| 
 | ||||
|   .compose-form__buttons button.active:last-child { | ||||
|     border-radius:3px; | ||||
|     background: $ui-base-color; | ||||
|     color: $ui-primary-color; | ||||
|   } | ||||
|   .compose-form__buttons-wrapper { | ||||
|     background-color:$ui-primary-color; | ||||
|   } | ||||
| 
 | ||||
|   .icon-button.inverted { | ||||
|     color:white; | ||||
| 
 | ||||
|     &:hover { | ||||
|       color:$ui-secondary-color; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| button.icon-button { | ||||
|   &.disabled { | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .icon-button { | ||||
|   &.inverted { | ||||
|     color: darken($ui-base-lighter-color, 10%); | ||||
|   } | ||||
| 
 | ||||
|   &.overlayed { | ||||
|     background: rgba($base-overlay-background, 0.2); | ||||
|     color: rgba($white, 0.7); | ||||
| 
 | ||||
|     &:hover { | ||||
|       background: rgba($base-overlay-background, 0.4); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   &.disabled { | ||||
|     color: desaturate($icon-button-inactive-color, 5%); | ||||
| 
 | ||||
|     &:hover, | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       color: desaturate($icon-button-inactive-color, 5%); | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   color: $icon-button-inactive-color; | ||||
| 
 | ||||
|   &:hover, | ||||
|   &:active, | ||||
|   &:focus { | ||||
|     color: darken($icon-button-inactive-color, 5%); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .icon-button.star-icon, | ||||
| .icon-button.star-icon:active { | ||||
|   background:transparent; | ||||
|   border:none; | ||||
| } | ||||
| 
 | ||||
| .icon-button.star-icon.active { | ||||
|   color: $gold-star; | ||||
|   &:active,  &:hover, &:focus { | ||||
|     color: $gold-star; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .text-icon-button { | ||||
|   color: $white; | ||||
|   &.active { | ||||
|     background: $ui-base-color; | ||||
|     color: $ui-primary-color; | ||||
|   } | ||||
|   &:focus, &:hover { | ||||
|     color: darken($ui-base-color, 3%); | ||||
|   } | ||||
| } | ||||
| .status.status-direct { | ||||
|   background: darken($ui-base-alt, 5%); | ||||
|   .icon-button.disabled { | ||||
|     color: lighten($ui-base-lighter-color, 10%); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .account__header, .account-card { | ||||
|   & > div { | ||||
|     background: rgba(lighten($ui-base-color, 4%), 0.6); | ||||
|   } | ||||
| 
 | ||||
|   .account__header__content { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| 
 | ||||
|   .detailed-status__display-name .display-name strong { | ||||
|     color: $ui-highlight-color; | ||||
|   } | ||||
| 
 | ||||
|   .icon-button { | ||||
|     &, &:hover { | ||||
|       color:desaturate($ui-base-lighter-color, 20%); | ||||
|     } | ||||
|     &.active { | ||||
|       &, &:hover { | ||||
|         color:$ui-base-lighter-color; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .account__section-headline a { | ||||
|   &.active { | ||||
|     color: $primary-text-color; | ||||
| 
 | ||||
|     &::after { | ||||
|       border-bottom-color: $ui-base-alt; | ||||
|     } | ||||
| 
 | ||||
|     &::after { | ||||
|       border-bottom-color: $ui-base-alt; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .privacy-dropdown.active .privacy-dropdown__value.active .icon-button { | ||||
|     color: $ui-primary-color; | ||||
| } | ||||
| 
 | ||||
| .privacy-dropdown__option { | ||||
|   color: $primary-text-color; | ||||
| 
 | ||||
|   strong { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| 
 | ||||
|   &:hover, | ||||
|   &.active { | ||||
|     color: $white; | ||||
| 
 | ||||
|     .privacy-dropdown__option__content { | ||||
|       color: $white; | ||||
| 
 | ||||
|       strong { | ||||
|         color: $white; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .emoji-picker-dropdown__menu { | ||||
|   .emoji-search-wrapper { | ||||
|     border-color: darken($ui-base-color, 10%); | ||||
|   } | ||||
|   .emoji-search { | ||||
|     background: darken($ui-base-color, 5%); | ||||
|     border-color: darken($ui-base-color, 10%); | ||||
|   } | ||||
|   .emoji-mart { | ||||
|     color: $ui-primary-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .search-popout { | ||||
|   background: $ui-base-color; | ||||
|   color: $ui-primary-color; | ||||
| 
 | ||||
|   h4 { | ||||
|     color: $ui-primary-color; | ||||
|   } | ||||
| 
 | ||||
|   em { | ||||
|     color: $ui-highlight-color; | ||||
|   } | ||||
| } | ||||
| .search__icon .fa.active { | ||||
|   opacity:1.0; | ||||
| } | ||||
| .search-results__hashtag { | ||||
|   color: darken($ui-primary-color, 10%); | ||||
|   &:hover { | ||||
|     color: lighten($ui-primary-color, 5%); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .static-content { | ||||
|     /*color: $primary-text-color;*/ | ||||
| } | ||||
| 
 | ||||
| #Getting-started { | ||||
|   background: $ui-primary-color; | ||||
|   border-bottom:0px; | ||||
|   color:white; | ||||
| } | ||||
| 
 | ||||
| .getting-started { | ||||
|   p { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| 
 | ||||
|   a { | ||||
|     color: darken($ui-base-lighter-color, 10%); | ||||
|   } | ||||
| } | ||||
| .getting-started__wrapper { | ||||
|   flex: 0 0.5 auto; | ||||
| } | ||||
| 
 | ||||
| .getting-started { | ||||
|   .column-link { | ||||
|     background: lighten($ui-primary-color, 5%); | ||||
|     color:$white; | ||||
|     &:hover { | ||||
|       background: lighten($ui-primary-color, 10%); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| .column-link__badge { | ||||
|   background: saturate(darken($ui-primary-color, 5%), 5%); | ||||
| } | ||||
| .column-subheading { | ||||
|   background: darken($ui-primary-color, 5%); | ||||
|   color:$white; | ||||
| } | ||||
| 
 | ||||
| .media-spoiler, | ||||
| .video-player__spoiler.active { | ||||
|   color: $white; | ||||
|   &:hover { | ||||
|     color: darken($white, 5%); | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .status { | ||||
|   border-bottom: 1px solid $ui-secondary-color; | ||||
| } | ||||
| 
 | ||||
| .status__relative-time, .status__display-name { | ||||
|   color: darken($ui-base-color, 40%); | ||||
| } | ||||
| 
 | ||||
| .status__content { | ||||
|   .status__content__spoiler-link { | ||||
|     background: $ui-base-lighter-color; | ||||
| 
 | ||||
|     &:hover { | ||||
|       background: lighten($ui-base-lighter-color, 5%); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .muted .status__content p { | ||||
|   color: $icon-button-inactive-color; | ||||
| } | ||||
| 
 | ||||
| .dropdown-menu__item { | ||||
|   & > a { | ||||
|     color: $primary-text-color; | ||||
|     &:hover, &:active, &:focus { | ||||
|       color: $white; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .dropdown--active .dropdown__content { | ||||
|   & > ul { | ||||
|     background: $ui-base-color; | ||||
|     box-shadow: 0 0 5px rgba($base-shadow-color, 0.2); | ||||
|     & > li > a { | ||||
|       background: $ui-base-color; | ||||
|       color: $primary-text-color; | ||||
| 
 | ||||
|       &:hover { | ||||
|         background: $ui-highlight-color; | ||||
|         color: $ui-base-color; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .boost-modal, | ||||
| .confirmation-modal, | ||||
| .report-modal, | ||||
| .actions-modal, | ||||
| .mute-modal | ||||
| { | ||||
|   color: $primary-text-color; | ||||
| } | ||||
| .boost-modal__action-bar, | ||||
| .confirmation-modal__action-bar, | ||||
| .mute-modal__action-bar, | ||||
| .report-modal__action-bar, | ||||
| .mute-modal__action-bar  { | ||||
|   & > div { | ||||
|     color: $ui-primary-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .actions-modal | ||||
| { | ||||
|   ul { | ||||
|     li:not(:empty) { | ||||
|       a { | ||||
|         color: $primary-text-color; | ||||
|         button { | ||||
| 
 | ||||
|         } | ||||
|         &.active, &:hover, &:active, &:focus { | ||||
|           color: $white; | ||||
|           button { | ||||
|             color: $white; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .react-toggle-track { | ||||
|   background-color: $icon-button-inactive-color; | ||||
| } | ||||
| 
 | ||||
| .report-modal__comment .setting-text { | ||||
|   color: $primary-text-color; | ||||
|   border-bottom-color: lighten($ui-primary-color, 10%); | ||||
|   &:focus, &:active { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .status.light { | ||||
|   .status__content { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
|   .display-name strong { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .reply-indicator__content a { | ||||
|   color: lighten($ui-highlight-color, 30%); | ||||
| } | ||||
| 
 | ||||
| .status__content | ||||
| { | ||||
|   a { | ||||
|     color: $ui-highlight-color; | ||||
| 
 | ||||
|     &:hover { | ||||
|       .fa { | ||||
|         color: darken($ui-base-color, 40%); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .detailed-status__display-name { | ||||
|   color: $ui-base-lighter-color; | ||||
| } | ||||
| 
 | ||||
| .drawer .drawer__inner { | ||||
|   overflow: visible; | ||||
|   height:inherit; | ||||
|   background:$ui-base-alt; | ||||
| } | ||||
| 
 | ||||
| .search__icon .fa { | ||||
|   color: $ui-highlight-color; | ||||
| } | ||||
| 
 | ||||
| .drawer__pager { | ||||
|   overflow-y:auto; | ||||
| } | ||||
| 
 | ||||
| .drawer .drawer__header { | ||||
|   background: $ui-base-color; | ||||
|   border-radius:3px; | ||||
| } | ||||
| 
 | ||||
| .onboarding-modal__page h1 { | ||||
|   background-color: darken($ui-primary-color, 5%); | ||||
| } | ||||
| 
 | ||||
| /* forms.scss */ | ||||
| .block-button, .button, button { | ||||
|   background-color: $ui-primary-color; | ||||
|   color: $white; | ||||
| 
 | ||||
|   &.button-alternative { | ||||
|     color: $ui-base-color; | ||||
|   } | ||||
| 
 | ||||
|   &.logo-button { | ||||
|     color: $white; | ||||
|     svg path:first-child { | ||||
|       fill: $white; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .simple_form { | ||||
|   p.hint { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
| 
 | ||||
|   .block-button, .button, button { | ||||
|     background-color: $ui-primary-color; | ||||
|     color: $white; | ||||
| 
 | ||||
|     &:hover { | ||||
|       background-color: lighten($ui-primary-color, 5%); | ||||
|     } | ||||
| 
 | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       background-color: darken($ui-primary-color, 5%); | ||||
|     } | ||||
| 
 | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* admin.scss */ | ||||
| 
 | ||||
| .table > thead > tr > th { | ||||
|   border-bottom-color:  $ui-secondary-color; | ||||
| } | ||||
| 
 | ||||
| .simple_form h4 { | ||||
|   border-bottom: 1px solid $ui-highlight-color; | ||||
| } | ||||
| 
 | ||||
| .admin-wrapper { | ||||
|   .content { | ||||
|     h2, p.hint, h4, h6 { | ||||
|       color: $primary-text-color; | ||||
|     } | ||||
| 
 | ||||
|     .muted-hint { | ||||
|       color: $primary-text-color; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
|   .sidebar { | ||||
|     .logo { | ||||
|       -webkit-filter: invert(100%); | ||||
|       filter: invert(100%); | ||||
|     } | ||||
| 
 | ||||
|     ul { | ||||
|       ul { | ||||
|         a { | ||||
|           &.selected { | ||||
|             background-color: $ui-primary-color; | ||||
|             color: $white; | ||||
| 
 | ||||
|             &:hover { | ||||
|               background-color: lighten($ui-primary-color, 10%); | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .pagination .current { | ||||
|   color: $ui-primary-color; | ||||
| } | ||||
| 
 | ||||
| .report-accounts__item > strong { | ||||
|   color: $primary-text-color; | ||||
| } | ||||
| 
 | ||||
| .admin-wrapper .content {  | ||||
|   & > p { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
|   hr { | ||||
|     border-color: $ui-highlight-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* accounts.scss */ | ||||
| .card { | ||||
|   .name { | ||||
|     color: $white; | ||||
|   } | ||||
| 
 | ||||
|   .counter { | ||||
|     .counter-number { | ||||
|       color: $white; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* stream_entries.scss */ | ||||
| .activity-stream { | ||||
|   .entry { | ||||
|   } | ||||
|   .status.light { | ||||
|     .display-name { | ||||
|       strong { | ||||
|         color: $primary-text-color; | ||||
|       } | ||||
|     } | ||||
|     .status__content { | ||||
|       color: $primary-text-color; | ||||
|     } | ||||
|   } | ||||
|   .detailed-status.light { | ||||
|     .detailed-status__display-name { | ||||
|       .display-name { | ||||
|         strong { | ||||
|           color: $primary-text-color; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|     .status__content { | ||||
|       color: $primary-text-color; | ||||
|     } | ||||
|     .status-card, | ||||
|     .status-card__title, | ||||
|     .status-card__description { | ||||
|       color: $primary-text-color; | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* accounts.scss */ | ||||
| .card { | ||||
|   .name { | ||||
|     color: darken($ui-primary-color, 15%); | ||||
|   } | ||||
|   .counter { | ||||
|     .counter-number { | ||||
|       color: darken($ui-primary-color, 15%); | ||||
|     } | ||||
|     border-color: $ui-primary-color; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .activity-stream-tabs { | ||||
|   a { | ||||
|     color: lighten($ui-primary-color, 10%); | ||||
|     &.active { | ||||
|       color: darken($ui-primary-color, 10%); | ||||
|     } | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| /* uncategorized */ | ||||
| 
 | ||||
| @media screen and (min-width: 1300px) { | ||||
|   .column { | ||||
|     flex-grow: 1 !important; | ||||
|     max-width: 400px; | ||||
|   } | ||||
| 
 | ||||
|   .drawer { | ||||
|     width: 17%; | ||||
|     max-width: 400px; | ||||
|     min-width: 330px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .status time:after, | ||||
| .detailed-status__datetime span:after { | ||||
|   font: normal normal normal 14px/1 FontAwesome; | ||||
|   content: "\00a0\00a0\f08e"; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .column { | ||||
|   max-height:100vh; | ||||
|   & > .scrollable { | ||||
|     background-color: $ui-base-alt; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .empty-column-indicator, .error-column { | ||||
|   background-color: $ui-base-alt; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .media-gallery, | ||||
| .video-player { | ||||
|   max-height:30vh; | ||||
|   height:30vh !important; | ||||
|   position:relative; | ||||
|   margin-top:20px; | ||||
|   margin-left:-68px; | ||||
|   width: calc(100% + 80px) !important; | ||||
|   max-width: calc(100% + 80px); | ||||
| } | ||||
| 
 | ||||
| .detailed-status .media-gallery, | ||||
| .detailed-status .video-player { | ||||
|   margin-left:-10px; | ||||
|   width: calc(100% + 22px); | ||||
|   max-width: calc(100% + 22px); | ||||
| } | ||||
| 
 | ||||
| .video-player video { | ||||
|   transform: unset; | ||||
|   top: unset; | ||||
| } | ||||
| 
 | ||||
| .detailed-status .media-spoiler, | ||||
| .status .media-spoiler { | ||||
|   height:100% !important; | ||||
|   vertical-align:middle; | ||||
| } | ||||
| 
 | ||||
| .actions .button.button-alternative { | ||||
|     background: $ui-highlight-color; | ||||
|     color: $white; | ||||
| 
 | ||||
|     &:active, | ||||
|     &:focus, | ||||
|     &:hover { | ||||
|       background-color: lighten($ui-highlight-color, 4%); | ||||
|     } | ||||
| } | ||||
| 
 | ||||
| .public-layout .header { | ||||
|   background: $ui-highlight-color; | ||||
|   color: $white; | ||||
| } | ||||
| 
 | ||||
| .public-layout .public-account-header__tabs__name h1 { | ||||
|   color: $white; | ||||
|   small { | ||||
|     color: $white; | ||||
|   } | ||||
| } | ||||
| .public-layout .header .brand:hover,  | ||||
| .public-layout .header .brand:focus,  | ||||
| .public-layout .header .brand:active { | ||||
|   background: lighten($ui-highlight-color, 5%); | ||||
| } | ||||
| 
 | ||||
| .public-layout .container:last-child { | ||||
|   background:$ui-highlight-color; | ||||
|   padding-left: 100px; | ||||
|   padding-right: 100px; | ||||
|   border-radius: 4px; | ||||
|   h4 { | ||||
|     color: white; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .modal-layout, .modal-layout__mastodon > * { | ||||
|   background: none; | ||||
| } | ||||
| 
 | ||||
| .dashboard__widgets a:not(.name-tag) { | ||||
|   color: $primary-text-color; | ||||
| } | ||||
							
								
								
									
										48
									
								
								app/javascript/styles/fullwidth-media.scss
									
										
									
									
									
										Normal file
									
								
							
							
						
						
									
										48
									
								
								app/javascript/styles/fullwidth-media.scss
									
										
									
									
									
										Normal file
									
								
							|  | @ -0,0 +1,48 @@ | |||
| 
 | ||||
| /* So we can position things absolute to it*/ | ||||
| .status__content { | ||||
|   position:relative; | ||||
| } | ||||
| 
 | ||||
| /* Use 30% of the viewport height always*/ | ||||
| .detailed-status > .media-spoiler, | ||||
| .status > .media-spoiler, | ||||
| .video-player, | ||||
| .media-gallery { | ||||
|   max-height:30vh; | ||||
|   height:30vh !important; | ||||
|   position:relative; | ||||
|   margin-top:20px; | ||||
|   margin-left:-68px; | ||||
|   width: calc(100% + 80px); | ||||
| } | ||||
| 
 | ||||
| /* Unset max-width for spoilers and the video | ||||
|  * player */ | ||||
| .detailed-status > .media-spoiler, | ||||
| .status > .media-spoiler, | ||||
| .video-player { | ||||
|   max-width: none; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .detailed-status .media-spoiler, | ||||
| .status .media-spoiler { | ||||
|   height:30vh !important; | ||||
|   vertical-align:middle; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| .status__video-player-video { | ||||
|   transform:unset; | ||||
|   top:unset; | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
| /* Adjust offset and width for detail view */ | ||||
| .detailed-status .media-gallery { | ||||
|   margin-left:-10px; | ||||
|   width: calc(100% + 22px); | ||||
| } | ||||
| 
 | ||||
| 
 | ||||
|  | @ -75,7 +75,8 @@ class Account < ApplicationRecord | |||
|   validates_with UniqueUsernameValidator, if: -> { local? && will_save_change_to_username? } | ||||
|   validates_with UnreservedUsernameValidator, if: -> { local? && will_save_change_to_username? } | ||||
|   validates :display_name, length: { maximum: 30 }, if: -> { local? && will_save_change_to_display_name? } | ||||
|   validates :note, length: { maximum: 160 }, if: -> { local? && will_save_change_to_note? } | ||||
|   validates :note, length: { maximum: 413 }, if: -> { local? && will_save_change_to_note? } | ||||
|   validate :note_has_eight_newlines?, if: -> { local? && will_save_change_to_note? } | ||||
|   validates :fields, length: { maximum: 4 }, if: -> { local? && will_save_change_to_fields? } | ||||
| 
 | ||||
|   # Timelines | ||||
|  | @ -266,10 +267,8 @@ class Account < ApplicationRecord | |||
|   def save_with_optional_media! | ||||
|     save! | ||||
|   rescue ActiveRecord::RecordInvalid | ||||
|     self.avatar              = nil | ||||
|     self.header              = nil | ||||
|     self[:avatar_remote_url] = '' | ||||
|     self[:header_remote_url] = '' | ||||
|     self.avatar = nil if errors[:avatar].present? | ||||
|     self.header = nil if errors[:header].present? | ||||
|     save! | ||||
|   end | ||||
| 
 | ||||
|  | @ -293,6 +292,10 @@ class Account < ApplicationRecord | |||
|     shared_inbox_url.presence || inbox_url | ||||
|   end | ||||
| 
 | ||||
|   def note_has_eight_newlines? | ||||
|     errors.add(:note, 'Bio can\'t have more then 8 newlines') unless note.count("\n") <= 8 | ||||
|   end | ||||
| 
 | ||||
|   class Field < ActiveModelSerializers::Model | ||||
|     attributes :name, :value, :account, :errors | ||||
| 
 | ||||
|  |  | |||
|  | @ -6,7 +6,7 @@ | |||
| 
 | ||||
|   .fields-group | ||||
|     = f.input :display_name, placeholder: t('simple_form.labels.defaults.display_name'), hint: t('simple_form.hints.defaults.display_name', count: 30 - @account.display_name.size).html_safe | ||||
|     = f.input :note, placeholder: t('simple_form.labels.defaults.note'), hint: t('simple_form.hints.defaults.note', count: 160 - @account.note.size).html_safe | ||||
|     = f.input :note, placeholder: t('simple_form.labels.defaults.note'), hint: t('simple_form.hints.defaults.note', count: 413 - @account.note.size).html_safe | ||||
| 
 | ||||
|   = render 'application/card', account: @account | ||||
| 
 | ||||
|  |  | |||
|  | @ -1,3 +1,4 @@ | |||
| default: styles/application.scss | ||||
| contrast: styles/contrast.scss | ||||
| mastodon-light: styles/mastodon-light.scss | ||||
| light: styles/cybre-light.scss | ||||
|  |  | |||
|  | @ -596,8 +596,8 @@ RSpec.describe Account, type: :model do | |||
|         expect(account).to model_have_error_on_field(:display_name) | ||||
|       end | ||||
| 
 | ||||
|       it 'is invalid if the note is longer than 160 characters' do | ||||
|         account = Fabricate.build(:account, note: Faker::Lorem.characters(161)) | ||||
|       it 'is invalid if the note is longer than 413 characters' do | ||||
|         account = Fabricate.build(:account, note: Faker::Lorem.characters(414)) | ||||
|         account.valid? | ||||
|         expect(account).to model_have_error_on_field(:note) | ||||
|       end | ||||
|  | @ -636,8 +636,8 @@ RSpec.describe Account, type: :model do | |||
|         expect(account).not_to model_have_error_on_field(:display_name) | ||||
|       end | ||||
| 
 | ||||
|       it 'is valid even if the note is longer than 160 characters' do | ||||
|         account = Fabricate.build(:account, domain: 'domain', note: Faker::Lorem.characters(161)) | ||||
|       it 'is valid even if the note is longer than 413 characters' do | ||||
|         account = Fabricate.build(:account, domain: 'domain', note: Faker::Lorem.characters(414)) | ||||
|         account.valid? | ||||
|         expect(account).not_to model_have_error_on_field(:note) | ||||
|       end | ||||
|  |  | |||
		Loading…
	
	Add table
		
		Reference in a new issue