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, |       id: data.id, | ||||||
|       height: document.getElementsByTagName('html')[0].scrollHeight, |       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(); |       detailedStatuses[0].scrollIntoView(); | ||||||
|       history.replace(location.pathname, { ...location.state, scrolledToDetailedStatus: true }); |       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 }) => { |   delegate(document, '.webapp-btn', 'click', ({ target, button }) => { | ||||||
|  | @ -142,13 +159,7 @@ function main() { | ||||||
|     } |     } | ||||||
|   }); |   }); | ||||||
| 
 | 
 | ||||||
|   delegate(document, '#account_note', 'input', ({ target }) => { |   delegate(document, '#account_note', 'input', sizeBioText); | ||||||
|     const noteCounter = document.querySelector('.note-counter'); |  | ||||||
| 
 |  | ||||||
|     if (noteCounter) { |  | ||||||
|       noteCounter.textContent = 160 - length(target.value); |  | ||||||
|     } |  | ||||||
|   }); |  | ||||||
| 
 | 
 | ||||||
|   delegate(document, '#account_avatar', 'change', ({ target }) => { |   delegate(document, '#account_avatar', 'change', ({ target }) => { | ||||||
|     const avatar = document.querySelector('.card .avatar img'); |     const avatar = document.querySelector('.card .avatar img'); | ||||||
|  | @ -175,6 +186,20 @@ function main() { | ||||||
|       lock.style.display = 'none'; |       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 => { | 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 UniqueUsernameValidator, if: -> { local? && will_save_change_to_username? } | ||||||
|   validates_with UnreservedUsernameValidator, 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 :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? } |   validates :fields, length: { maximum: 4 }, if: -> { local? && will_save_change_to_fields? } | ||||||
| 
 | 
 | ||||||
|   # Timelines |   # Timelines | ||||||
|  | @ -266,10 +267,8 @@ class Account < ApplicationRecord | ||||||
|   def save_with_optional_media! |   def save_with_optional_media! | ||||||
|     save! |     save! | ||||||
|   rescue ActiveRecord::RecordInvalid |   rescue ActiveRecord::RecordInvalid | ||||||
|     self.avatar              = nil |     self.avatar = nil if errors[:avatar].present? | ||||||
|     self.header              = nil |     self.header = nil if errors[:header].present? | ||||||
|     self[:avatar_remote_url] = '' |  | ||||||
|     self[:header_remote_url] = '' |  | ||||||
|     save! |     save! | ||||||
|   end |   end | ||||||
| 
 | 
 | ||||||
|  | @ -293,6 +292,10 @@ class Account < ApplicationRecord | ||||||
|     shared_inbox_url.presence || inbox_url |     shared_inbox_url.presence || inbox_url | ||||||
|   end |   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 |   class Field < ActiveModelSerializers::Model | ||||||
|     attributes :name, :value, :account, :errors |     attributes :name, :value, :account, :errors | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -6,7 +6,7 @@ | ||||||
| 
 | 
 | ||||||
|   .fields-group |   .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 :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 |   = render 'application/card', account: @account | ||||||
| 
 | 
 | ||||||
|  |  | ||||||
|  | @ -1,3 +1,4 @@ | ||||||
| default: styles/application.scss | default: styles/application.scss | ||||||
| contrast: styles/contrast.scss | contrast: styles/contrast.scss | ||||||
| mastodon-light: styles/mastodon-light.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) |         expect(account).to model_have_error_on_field(:display_name) | ||||||
|       end |       end | ||||||
| 
 | 
 | ||||||
|       it 'is invalid if the note is longer than 160 characters' do |       it 'is invalid if the note is longer than 413 characters' do | ||||||
|         account = Fabricate.build(:account, note: Faker::Lorem.characters(161)) |         account = Fabricate.build(:account, note: Faker::Lorem.characters(414)) | ||||||
|         account.valid? |         account.valid? | ||||||
|         expect(account).to model_have_error_on_field(:note) |         expect(account).to model_have_error_on_field(:note) | ||||||
|       end |       end | ||||||
|  | @ -636,8 +636,8 @@ RSpec.describe Account, type: :model do | ||||||
|         expect(account).not_to model_have_error_on_field(:display_name) |         expect(account).not_to model_have_error_on_field(:display_name) | ||||||
|       end |       end | ||||||
| 
 | 
 | ||||||
|       it 'is valid even if the note is longer than 160 characters' do |       it 'is valid even if the note is longer than 413 characters' do | ||||||
|         account = Fabricate.build(:account, domain: 'domain', note: Faker::Lorem.characters(161)) |         account = Fabricate.build(:account, domain: 'domain', note: Faker::Lorem.characters(414)) | ||||||
|         account.valid? |         account.valid? | ||||||
|         expect(account).not_to model_have_error_on_field(:note) |         expect(account).not_to model_have_error_on_field(:note) | ||||||
|       end |       end | ||||||
|  |  | ||||||
		Loading…
	
	Add table
		
		Reference in a new issue