Make theme directory and Rename application.scss (#5336)
* Rename application.scss * Move to 'default' directory * Follow review Move directory, and Rename "mastodon". * Revert rename * undo removal of newline
This commit is contained in:
		
							
								
								
									
										12
									
								
								app/javascript/styles/mastodon/_mixins.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										12
									
								
								app/javascript/styles/mastodon/_mixins.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,12 @@ | ||||
| @mixin avatar-radius() { | ||||
|   border-radius: 4px; | ||||
|   background: transparent no-repeat; | ||||
|   background-position: 50%; | ||||
|   background-clip: padding-box; | ||||
| } | ||||
|  | ||||
| @mixin avatar-size($size:48px) { | ||||
|   width: $size; | ||||
|   height: $size; | ||||
|   background-size: $size $size; | ||||
| } | ||||
							
								
								
									
										824
									
								
								app/javascript/styles/mastodon/about.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										824
									
								
								app/javascript/styles/mastodon/about.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,824 @@ | ||||
| .landing-page { | ||||
|   p, | ||||
|   li { | ||||
|     font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|     font-size: 16px; | ||||
|     font-weight: 400; | ||||
|     font-size: 16px; | ||||
|     line-height: 30px; | ||||
|     margin-bottom: 12px; | ||||
|     color: $ui-primary-color; | ||||
|  | ||||
|     a { | ||||
|       color: $ui-highlight-color; | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   em { | ||||
|     display: inline; | ||||
|     margin: 0; | ||||
|     padding: 0; | ||||
|     font-weight: 500; | ||||
|     background: transparent; | ||||
|     font-family: inherit; | ||||
|     font-size: inherit; | ||||
|     line-height: inherit; | ||||
|     color: lighten($ui-primary-color, 10%); | ||||
|   } | ||||
|  | ||||
|   h1 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 26px; | ||||
|     line-height: 30px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|  | ||||
|     small { | ||||
|       font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|       display: block; | ||||
|       font-size: 18px; | ||||
|       font-weight: 400; | ||||
|       color: $ui-base-lighter-color; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   h2 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 22px; | ||||
|     line-height: 26px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   h3 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 18px; | ||||
|     line-height: 24px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   h4 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 16px; | ||||
|     line-height: 24px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   h5 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 14px; | ||||
|     line-height: 24px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   h6 { | ||||
|     font-family: 'mastodon-font-display', sans-serif; | ||||
|     font-size: 12px; | ||||
|     line-height: 24px; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   ul, | ||||
|   ol { | ||||
|     margin-left: 20px; | ||||
|  | ||||
|     &[type='a'] { | ||||
|       list-style-type: lower-alpha; | ||||
|     } | ||||
|  | ||||
|     &[type='i'] { | ||||
|       list-style-type: lower-roman; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   ul { | ||||
|     list-style: disc; | ||||
|   } | ||||
|  | ||||
|   ol { | ||||
|     list-style: decimal; | ||||
|   } | ||||
|  | ||||
|   li > ol, | ||||
|   li > ul { | ||||
|     margin-top: 6px; | ||||
|   } | ||||
|  | ||||
|   hr { | ||||
|     border-color: rgba($ui-base-lighter-color, .6); | ||||
|   } | ||||
|  | ||||
|   .container { | ||||
|     width: 100%; | ||||
|     box-sizing: border-box; | ||||
|     max-width: 800px; | ||||
|     margin: 0 auto; | ||||
|     word-wrap: break-word; | ||||
|   } | ||||
|  | ||||
|   .header-wrapper { | ||||
|     padding-top: 15px; | ||||
|     background: $ui-base-color; | ||||
|     background: linear-gradient(150deg, lighten($ui-base-color, 8%), $ui-base-color); | ||||
|     position: relative; | ||||
|  | ||||
|     &.compact { | ||||
|       background: $ui-base-color; | ||||
|       padding-bottom: 15px; | ||||
|  | ||||
|       .hero .heading { | ||||
|         padding-bottom: 20px; | ||||
|         font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|         font-size: 16px; | ||||
|         font-weight: 400; | ||||
|         font-size: 16px; | ||||
|         line-height: 30px; | ||||
|         color: $ui-primary-color; | ||||
|  | ||||
|         a { | ||||
|           color: $ui-highlight-color; | ||||
|           text-decoration: underline; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .mascot-container { | ||||
|       max-width: 800px; | ||||
|       margin: 0 auto; | ||||
|       position: absolute; | ||||
|       top: 0; | ||||
|       left: 0; | ||||
|       right: 0; | ||||
|       height: 100%; | ||||
|     } | ||||
|  | ||||
|     .mascot { | ||||
|       position: absolute; | ||||
|       bottom: -14px; | ||||
|       width: auto; | ||||
|       height: auto; | ||||
|       left: 60px; | ||||
|       z-index: 3; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .header { | ||||
|     line-height: 30px; | ||||
|     overflow: hidden; | ||||
|  | ||||
|     .container { | ||||
|       display: flex; | ||||
|       justify-content: space-between; | ||||
|     } | ||||
|  | ||||
|     .links { | ||||
|       position: relative; | ||||
|       z-index: 4; | ||||
|  | ||||
|       a { | ||||
|         display: flex; | ||||
|         justify-content: center; | ||||
|         align-items: center; | ||||
|         color: $ui-primary-color; | ||||
|         text-decoration: none; | ||||
|         padding: 12px 16px; | ||||
|         line-height: 32px; | ||||
|         font-family: 'mastodon-font-display', sans-serif; | ||||
|         font-weight: 500; | ||||
|         font-size: 14px; | ||||
|  | ||||
|         &:hover { | ||||
|           color: $ui-secondary-color; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       .brand { | ||||
|         a { | ||||
|           padding-left: 0; | ||||
|           padding-right: 0; | ||||
|           color: $white; | ||||
|         } | ||||
|  | ||||
|         img { | ||||
|           height: 32px; | ||||
|           position: relative; | ||||
|           top: 4px; | ||||
|           left: -10px; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       ul { | ||||
|         list-style: none; | ||||
|         margin: 0; | ||||
|  | ||||
|         li { | ||||
|           display: inline-block; | ||||
|           vertical-align: bottom; | ||||
|           margin: 0; | ||||
|  | ||||
|           &:first-child a { | ||||
|             padding-left: 0; | ||||
|           } | ||||
|  | ||||
|           &:last-child a { | ||||
|             padding-right: 0; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .hero { | ||||
|       margin-top: 50px; | ||||
|       align-items: center; | ||||
|       position: relative; | ||||
|  | ||||
|       .floats { | ||||
|         position: absolute; | ||||
|         width: 100%; | ||||
|         height: 100%; | ||||
|         top: 0; | ||||
|         left: 0; | ||||
|  | ||||
|         div { | ||||
|           position: absolute; | ||||
|           transition: all 0.1s linear; | ||||
|           animation-name: floating; | ||||
|           animation-iteration-count: infinite; | ||||
|           animation-direction: alternate; | ||||
|           animation-timing-function: ease-in-out; | ||||
|           z-index: 2; | ||||
|         } | ||||
|  | ||||
|         .float-1 { | ||||
|           width: 324px; | ||||
|           height: 170px; | ||||
|           right: -120px; | ||||
|           bottom: 0; | ||||
|           animation-duration: 3s; | ||||
|           background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 447.1875 234.375" height="170" width="324"><path fill="#{hex-color($ui-base-lighter-color)}" d="M21.69 233.366c-6.45-1.268-13.347-5.63-16.704-10.564-10.705-15.734-1.513-37.724 18.632-44.57l4.8-1.632.173-17.753c.146-14.77.515-19.063 2.2-25.55 6.736-25.944 24.46-46.032 47.766-54.137 11.913-4.143 19.558-5.366 34.178-5.47l13.828-.096V71.12c0-4.755 2.853-17.457 5.238-23.327 8.588-21.137 26.735-35.957 52.153-42.593 23.248-6.07 50.153-6.415 71.863-.923 11.14 2.82 25.686 9.957 33.857 16.615 19.335 15.756 31.82 41.05 35.183 71.275.59 5.305.672 5.435 3.11 4.926 11.833-2.474 30.4-3.132 40.065-1.42 24.388 4.32 40.568 19.076 47.214 43.058 2.16 7.8 3.953 23.894 3.59 32.237l-.24 5.498 5.156 1.317c6.392 1.633 14.55 7.098 18.003 12.062 1.435 2.062 3.305 6.597 4.156 10.078 1.428 5.84 1.43 6.8.04 12.44-1.807 7.318-5.672 13.252-10.872 16.694-8.508 5.63 3.756 5.33-211.916 5.216-108.56-.056-199.22-.464-201.47-.906z"/></svg>'); | ||||
|         } | ||||
|  | ||||
|         .float-2 { | ||||
|           width: 241px; | ||||
|           height: 100px; | ||||
|           right: 210px; | ||||
|           bottom: 0; | ||||
|           animation-duration: 3.5s; | ||||
|           animation-delay: 0.2s; | ||||
|           background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 536.25 222.1875" height="100" width="241"><path fill="#{hex-color($ui-base-lighter-color)}" d="M42.626 221.23c-14.104-1.174-26.442-5.133-32.825-10.534-4.194-3.548-7.684-10.66-8.868-18.075-1.934-12.102.633-22.265 7.528-29.81 7.61-8.328 19.998-12.76 39.855-14.257l8.47-.638-2.08-6.223c-4.826-14.422-6.357-24.813-6.37-43.255-.012-14.923.28-18.513 2.1-25.724 2.283-9.048 8.483-23.034 13.345-30.1 14.76-21.45 43.505-38.425 70.535-41.65 30.628-3.655 64.47 12.073 89.668 41.673l5.955 6.995 2.765-4.174c1.52-2.296 5.74-6.93 9.376-10.295 18.382-17.02 43.436-20.676 73.352-10.705 12.158 4.052 21.315 9.53 29.64 17.733 12.752 12.562 18.16 25.718 18.19 44.26l.02 10.98 2.312-3.01c15.64-20.365 42.29-20.485 62.438-.28 3.644 3.653 7.558 8.593 8.697 10.976 4.895 10.24 5.932 25.688 2.486 37.046-.76 2.507-1.388 4.816-1.393 5.13-.006.316 6.845.87 15.224 1.234 53.06 2.297 76.356 12.98 81.817 37.526 3.554 15.973-3.71 28.604-19.566 34.02-4.554 1.555-17.922 1.655-234.517 1.757-126.327.06-233.497-.21-238.154-.597z"/></svg>'); | ||||
|         } | ||||
|  | ||||
|         .float-3 { | ||||
|           width: 267px; | ||||
|           height: 140px; | ||||
|           right: 110px; | ||||
|           top: -30px; | ||||
|           animation-duration: 4s; | ||||
|           animation-delay: 0.5s; | ||||
|           background-image: url('data:image/svg+xml;utf8,<svg xmlns="http://www.w3.org/2000/svg" viewBox="0 0 388.125 202.5" height="140" width="267"><path fill="#{hex-color($ui-base-lighter-color)}" d="M181.37 201.458c-17.184-1.81-36.762-8.944-49.523-18.05l-5.774-4.12-8.074 2.63c-11.468 3.738-21.382 4.962-35.815 4.422-14.79-.554-24.577-2.845-36.716-8.594-15.483-7.332-28.498-19.98-35.985-34.968C2.44 128.675-.94 108.435.9 91.356c3.362-31.234 18.197-53.698 43.63-66.074 12.803-6.23 22.384-8.55 37.655-9.122 14.433-.54 24.347.684 35.814 4.42l8.073 2.633 5.635-4.01c24.81-17.656 60.007-23.332 92.914-14.985 10.11 2.565 25.498 9.62 33.102 15.178l5.068 3.704 7.632-2.564c10.89-3.66 21.086-4.916 35.516-4.376 45.816 1.716 76.422 30.03 81.285 75.196 1.84 17.08-1.54 37.32-8.585 51.422-7.487 14.99-20.502 27.636-35.984 34.968-12.14 5.75-21.926 8.04-36.716 8.593-14.43.54-24.626-.716-35.516-4.376l-7.632-2.564-5.068 3.704c-12.844 9.387-32.714 16.488-51.545 18.42-10.607 1.09-13.916 1.08-24.81-.066z"/></svg>'); | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       .heading { | ||||
|         position: relative; | ||||
|         z-index: 4; | ||||
|         padding-bottom: 150px; | ||||
|       } | ||||
|  | ||||
|       .simple_form, | ||||
|       .closed-registrations-message { | ||||
|         background: darken($ui-base-color, 4%); | ||||
|         width: 280px; | ||||
|         padding: 15px 20px; | ||||
|         border-radius: 4px 4px 0 0; | ||||
|         line-height: initial; | ||||
|         position: relative; | ||||
|         z-index: 4; | ||||
|  | ||||
|         .actions { | ||||
|           margin-bottom: 0; | ||||
|  | ||||
|           button, | ||||
|           .button, | ||||
|           .block-button { | ||||
|             margin-bottom: 0; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       .closed-registrations-message { | ||||
|         min-height: 330px; | ||||
|         display: flex; | ||||
|         flex-direction: column; | ||||
|         justify-content: space-between; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .about-short { | ||||
|     background: darken($ui-base-color, 4%); | ||||
|     padding: 50px 0 30px; | ||||
|     font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|     font-size: 16px; | ||||
|     font-weight: 400; | ||||
|     font-size: 16px; | ||||
|     line-height: 30px; | ||||
|     color: $ui-primary-color; | ||||
|  | ||||
|     a { | ||||
|       color: $ui-highlight-color; | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .information-board { | ||||
|     background: darken($ui-base-color, 4%); | ||||
|     padding: 20px 0; | ||||
|  | ||||
|     .container { | ||||
|       position: relative; | ||||
|       padding-right: 280px + 15px; | ||||
|     } | ||||
|  | ||||
|     .information-board-sections { | ||||
|       display: flex; | ||||
|       justify-content: space-between; | ||||
|       flex-wrap: wrap; | ||||
|     } | ||||
|  | ||||
|     .section { | ||||
|       flex: 1 0 0; | ||||
|       font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|       font-size: 16px; | ||||
|       line-height: 28px; | ||||
|       color: $primary-text-color; | ||||
|       text-align: right; | ||||
|       padding: 10px 15px; | ||||
|  | ||||
|       span, | ||||
|       strong { | ||||
|         display: block; | ||||
|       } | ||||
|  | ||||
|       span { | ||||
|         &:last-child { | ||||
|           color: $ui-secondary-color; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       strong { | ||||
|         font-weight: 500; | ||||
|         font-size: 32px; | ||||
|         line-height: 48px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .panel { | ||||
|       position: absolute; | ||||
|       width: 280px; | ||||
|       box-sizing: border-box; | ||||
|       background: darken($ui-base-color, 8%); | ||||
|       padding: 20px; | ||||
|       padding-top: 10px; | ||||
|       border-radius: 4px 4px 0 0; | ||||
|       right: 0; | ||||
|       bottom: -40px; | ||||
|  | ||||
|       .panel-header { | ||||
|         font-family: 'mastodon-font-display', sans-serif; | ||||
|         font-size: 14px; | ||||
|         line-height: 24px; | ||||
|         font-weight: 500; | ||||
|         color: $ui-primary-color; | ||||
|         padding-bottom: 5px; | ||||
|         margin-bottom: 15px; | ||||
|         border-bottom: 1px solid lighten($ui-base-color, 4%); | ||||
|         text-overflow: ellipsis; | ||||
|         white-space: nowrap; | ||||
|         overflow: hidden; | ||||
|  | ||||
|         a, | ||||
|         span { | ||||
|           font-weight: 400; | ||||
|           color: darken($ui-primary-color, 10%); | ||||
|         } | ||||
|  | ||||
|         a { | ||||
|           text-decoration: none; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .owner { | ||||
|       text-align: center; | ||||
|  | ||||
|       .avatar { | ||||
|         width: 80px; | ||||
|         height: 80px; | ||||
|         margin: 0 auto; | ||||
|         margin-bottom: 15px; | ||||
|  | ||||
|         img { | ||||
|           display: block; | ||||
|           width: 80px; | ||||
|           height: 80px; | ||||
|           border-radius: 48px; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       .name { | ||||
|         font-size: 14px; | ||||
|  | ||||
|         a { | ||||
|           display: block; | ||||
|           color: $primary-text-color; | ||||
|           text-decoration: none; | ||||
|  | ||||
|           &:hover { | ||||
|             .display_name { | ||||
|               text-decoration: underline; | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|  | ||||
|         .username { | ||||
|           display: block; | ||||
|           color: $ui-primary-color; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .features { | ||||
|     padding: 50px 0; | ||||
|  | ||||
|     .container { | ||||
|       display: flex; | ||||
|     } | ||||
|  | ||||
|     #mastodon-timeline { | ||||
|       display: flex; | ||||
|       -webkit-overflow-scrolling: touch; | ||||
|       -ms-overflow-style: -ms-autohiding-scrollbar; | ||||
|       font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|       font-size: 13px; | ||||
|       line-height: 18px; | ||||
|       font-weight: 400; | ||||
|       color: $primary-text-color; | ||||
|       width: 330px; | ||||
|       margin-right: 30px; | ||||
|       flex: 0 0 auto; | ||||
|       background: $ui-base-color; | ||||
|       overflow: hidden; | ||||
|       border-radius: 4px; | ||||
|       box-shadow: 0 0 6px rgba($black, 0.1); | ||||
|  | ||||
|       .column-header { | ||||
|         color: inherit; | ||||
|         font-family: inherit; | ||||
|         font-size: 16px; | ||||
|         line-height: inherit; | ||||
|         font-weight: inherit; | ||||
|         margin: 0; | ||||
|         padding: 15px; | ||||
|       } | ||||
|  | ||||
|       .column { | ||||
|         padding: 0; | ||||
|         border-radius: 4px; | ||||
|         overflow: hidden; | ||||
|       } | ||||
|  | ||||
|       .scrollable { | ||||
|         height: 400px; | ||||
|       } | ||||
|  | ||||
|       p { | ||||
|         font-size: inherit; | ||||
|         line-height: inherit; | ||||
|         font-weight: inherit; | ||||
|         color: $primary-text-color; | ||||
|         margin-bottom: 20px; | ||||
|  | ||||
|         &:last-child { | ||||
|           margin-bottom: 0; | ||||
|         } | ||||
|  | ||||
|         a { | ||||
|           color: $ui-secondary-color; | ||||
|           text-decoration: none; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .about-mastodon { | ||||
|       max-width: 675px; | ||||
|  | ||||
|       p { | ||||
|         margin-bottom: 20px; | ||||
|       } | ||||
|  | ||||
|       .features-list { | ||||
|         margin-top: 20px; | ||||
|  | ||||
|         .features-list__row { | ||||
|           display: flex; | ||||
|           padding: 10px 0; | ||||
|           justify-content: space-between; | ||||
|  | ||||
|           &:first-child { | ||||
|             padding-top: 0; | ||||
|           } | ||||
|  | ||||
|           .visual { | ||||
|             flex: 0 0 auto; | ||||
|             display: flex; | ||||
|             align-items: center; | ||||
|             margin-left: 15px; | ||||
|  | ||||
|             .fa { | ||||
|               display: block; | ||||
|               color: $ui-primary-color; | ||||
|               font-size: 48px; | ||||
|             } | ||||
|           } | ||||
|  | ||||
|           .text { | ||||
|             font-size: 16px; | ||||
|             line-height: 30px; | ||||
|             color: $ui-primary-color; | ||||
|  | ||||
|             h6 { | ||||
|               font-size: inherit; | ||||
|               line-height: inherit; | ||||
|               margin-bottom: 0; | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .extended-description { | ||||
|     padding: 50px 0; | ||||
|     font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|     font-size: 16px; | ||||
|     font-weight: 400; | ||||
|     font-size: 16px; | ||||
|     line-height: 30px; | ||||
|     color: $ui-primary-color; | ||||
|  | ||||
|     a { | ||||
|       color: $ui-highlight-color; | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .footer-links { | ||||
|     padding-bottom: 50px; | ||||
|     text-align: right; | ||||
|     color: $ui-base-lighter-color; | ||||
|  | ||||
|     p { | ||||
|       font-size: 14px; | ||||
|     } | ||||
|  | ||||
|     a { | ||||
|       color: inherit; | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 840px) { | ||||
|     .container { | ||||
|       padding: 0 20px; | ||||
|     } | ||||
|  | ||||
|     .information-board { | ||||
|  | ||||
|       .container { | ||||
|         padding-right: 20px; | ||||
|       } | ||||
|  | ||||
|       .section { | ||||
|         text-align: center; | ||||
|       } | ||||
|  | ||||
|       .panel { | ||||
|         position: static; | ||||
|         margin-top: 20px; | ||||
|         width: 100%; | ||||
|         border-radius: 4px; | ||||
|  | ||||
|         .panel-header { | ||||
|           text-align: center; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .header-wrapper .mascot { | ||||
|       left: 20px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 689px) { | ||||
|     .header-wrapper .mascot { | ||||
|       display: none; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 675px) { | ||||
|     .header-wrapper { | ||||
|       padding-top: 0; | ||||
|  | ||||
|       &.compact { | ||||
|         padding-bottom: 0; | ||||
|       } | ||||
|  | ||||
|       &.compact .hero .heading { | ||||
|         text-align: initial; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .header .container, | ||||
|     .features .container { | ||||
|       display: block; | ||||
|     } | ||||
|  | ||||
|     .header { | ||||
|  | ||||
|       .links { | ||||
|         padding-top: 15px; | ||||
|         background: darken($ui-base-color, 4%); | ||||
|  | ||||
|         a { | ||||
|           padding: 12px 8px; | ||||
|         } | ||||
|  | ||||
|         .nav { | ||||
|           display: flex; | ||||
|           flex-flow: row wrap; | ||||
|           justify-content: space-around; | ||||
|         } | ||||
|  | ||||
|         .brand img { | ||||
|           left: 0; | ||||
|           top: 0; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       .hero { | ||||
|         margin-top: 30px; | ||||
|         padding: 0; | ||||
|  | ||||
|         .floats { | ||||
|           display: none; | ||||
|         } | ||||
|  | ||||
|         .heading { | ||||
|           padding: 30px 20px; | ||||
|           text-align: center; | ||||
|         } | ||||
|  | ||||
|         .simple_form, | ||||
|         .closed-registrations-message { | ||||
|           background: darken($ui-base-color, 8%); | ||||
|           width: 100%; | ||||
|           border-radius: 0; | ||||
|           box-sizing: border-box; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .features #mastodon-timeline { | ||||
|       height: 70vh; | ||||
|       width: 100%; | ||||
|       margin-bottom: 50px; | ||||
|  | ||||
|       .column { | ||||
|         width: 100%; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .cta { | ||||
|     margin: 20px; | ||||
|   } | ||||
|  | ||||
|   &.tag-page { | ||||
|     .features { | ||||
|       padding: 30px 0; | ||||
|  | ||||
|       .container { | ||||
|         max-width: 820px; | ||||
|  | ||||
|         #mastodon-timeline { | ||||
|           margin-right: 0; | ||||
|           border-top-right-radius: 0; | ||||
|         } | ||||
|  | ||||
|         .about-mastodon { | ||||
|           .about-hashtag { | ||||
|             background: darken($ui-base-color, 4%); | ||||
|             padding: 0 20px 20px 30px; | ||||
|             border-radius: 0 5px 5px 0; | ||||
|  | ||||
|             .brand { | ||||
|               padding-top: 20px; | ||||
|               margin-bottom: 20px; | ||||
|  | ||||
|               img { | ||||
|                 height: 48px; | ||||
|                 width: auto; | ||||
|               } | ||||
|             } | ||||
|  | ||||
|             p { | ||||
|               strong { | ||||
|                 color: $ui-secondary-color; | ||||
|                 font-weight: 700; | ||||
|               } | ||||
|             } | ||||
|  | ||||
|             .cta { | ||||
|               margin: 0; | ||||
|  | ||||
|               .button { | ||||
|                 margin-right: 4px; | ||||
|               } | ||||
|             } | ||||
|           } | ||||
|  | ||||
|           .features-list { | ||||
|             margin-left: 30px; | ||||
|             margin-right: 10px; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     @media screen and (max-width: 675px) { | ||||
|       .features { | ||||
|         padding: 10px 0; | ||||
|  | ||||
|         .container { | ||||
|           display: flex; | ||||
|           flex-direction: column; | ||||
|  | ||||
|           #mastodon-timeline { | ||||
|             order: 2; | ||||
|             flex: 0 0 auto; | ||||
|             height: 60vh; | ||||
|             margin-bottom: 20px; | ||||
|             border-top-right-radius: 4px; | ||||
|           } | ||||
|  | ||||
|           .about-mastodon { | ||||
|             order: 1; | ||||
|             flex: 0 0 auto; | ||||
|             max-width: 100%; | ||||
|  | ||||
|             .about-hashtag { | ||||
|               background: unset; | ||||
|               padding: 0; | ||||
|               border-radius: 0; | ||||
|  | ||||
|               .cta { | ||||
|                 margin: 20px 0; | ||||
|               } | ||||
|             } | ||||
|  | ||||
|             .features-list { | ||||
|               display: none; | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| @keyframes floating { | ||||
|   from { | ||||
|     transform: translate(0, 0); | ||||
|   } | ||||
|  | ||||
|   65% { | ||||
|     transform: translate(0, 4px); | ||||
|   } | ||||
|  | ||||
|   to { | ||||
|     transform: translate(0, -0); | ||||
|   } | ||||
| } | ||||
							
								
								
									
										537
									
								
								app/javascript/styles/mastodon/accounts.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										537
									
								
								app/javascript/styles/mastodon/accounts.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,537 @@ | ||||
| .card { | ||||
|   background-color: lighten($ui-base-color, 4%); | ||||
|   background-size: cover; | ||||
|   background-position: center; | ||||
|   border-radius: 4px 4px 0 0; | ||||
|   box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|   overflow: hidden; | ||||
|   position: relative; | ||||
|   display: flex; | ||||
|  | ||||
|   &::after { | ||||
|     background: rgba(darken($ui-base-color, 8%), 0.5); | ||||
|     display: block; | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     left: 0; | ||||
|     top: 0; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     z-index: 1; | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 740px) { | ||||
|     border-radius: 0; | ||||
|     box-shadow: none; | ||||
|   } | ||||
|  | ||||
|   .card__illustration { | ||||
|     padding: 60px 0; | ||||
|     position: relative; | ||||
|     flex: 1 1 auto; | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
|   } | ||||
|  | ||||
|   .card__bio { | ||||
|     max-width: 260px; | ||||
|     flex: 1 1 auto; | ||||
|     display: flex; | ||||
|     flex-direction: column; | ||||
|     justify-content: space-between; | ||||
|     background: rgba(darken($ui-base-color, 8%), 0.8); | ||||
|     position: relative; | ||||
|     z-index: 2; | ||||
|   } | ||||
|  | ||||
|   &.compact { | ||||
|     padding: 30px 0; | ||||
|     border-radius: 4px; | ||||
|  | ||||
|     .avatar { | ||||
|       margin-bottom: 0; | ||||
|  | ||||
|       img { | ||||
|         object-fit: cover; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .name { | ||||
|     display: block; | ||||
|     font-size: 20px; | ||||
|     line-height: 18px * 1.5; | ||||
|     color: $primary-text-color; | ||||
|     padding: 10px 15px; | ||||
|     padding-bottom: 0; | ||||
|     font-weight: 500; | ||||
|     position: relative; | ||||
|     z-index: 2; | ||||
|     margin-bottom: 30px; | ||||
|     overflow: hidden; | ||||
|     text-overflow: ellipsis; | ||||
|  | ||||
|     small { | ||||
|       display: block; | ||||
|       font-size: 14px; | ||||
|       color: $ui-highlight-color; | ||||
|       font-weight: 400; | ||||
|       overflow: hidden; | ||||
|       text-overflow: ellipsis; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .avatar { | ||||
|     width: 120px; | ||||
|     margin: 0 auto; | ||||
|     position: relative; | ||||
|     z-index: 2; | ||||
|  | ||||
|     img { | ||||
|       width: 120px; | ||||
|       height: 120px; | ||||
|       display: block; | ||||
|       border-radius: 120px; | ||||
|       box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .controls { | ||||
|     position: absolute; | ||||
|     top: 15px; | ||||
|     left: 15px; | ||||
|     z-index: 2; | ||||
|  | ||||
|     .icon-button { | ||||
|       color: rgba($white, 0.8); | ||||
|       text-decoration: none; | ||||
|       font-size: 13px; | ||||
|       line-height: 13px; | ||||
|       font-weight: 500; | ||||
|  | ||||
|       .fa { | ||||
|         font-weight: 400; | ||||
|         margin-right: 5px; | ||||
|       } | ||||
|  | ||||
|       &:hover, | ||||
|       &:active, | ||||
|       &:focus { | ||||
|         color: $white; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .roles { | ||||
|     margin-bottom: 30px; | ||||
|     padding: 0 15px; | ||||
|   } | ||||
|  | ||||
|   .details-counters { | ||||
|     margin-top: 30px; | ||||
|     display: flex; | ||||
|     flex-direction: row; | ||||
|     width: 100%; | ||||
|   } | ||||
|  | ||||
|   .counter { | ||||
|     width: 33.3%; | ||||
|     box-sizing: border-box; | ||||
|     flex: 0 0 auto; | ||||
|     color: $ui-primary-color; | ||||
|     padding: 5px 10px 0; | ||||
|     margin-bottom: 10px; | ||||
|     border-right: 1px solid lighten($ui-base-color, 4%); | ||||
|     cursor: default; | ||||
|     text-align: center; | ||||
|     position: relative; | ||||
|  | ||||
|     a { | ||||
|       display: block; | ||||
|     } | ||||
|  | ||||
|     &:last-child { | ||||
|       border-right: 0; | ||||
|     } | ||||
|  | ||||
|     &::after { | ||||
|       display: block; | ||||
|       content: ""; | ||||
|       position: absolute; | ||||
|       bottom: -10px; | ||||
|       left: 0; | ||||
|       width: 100%; | ||||
|       border-bottom: 4px solid $ui-primary-color; | ||||
|       opacity: 0.5; | ||||
|       transition: all 400ms ease; | ||||
|     } | ||||
|  | ||||
|     &.active { | ||||
|       &::after { | ||||
|         border-bottom: 4px solid $ui-highlight-color; | ||||
|         opacity: 1; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     &:hover { | ||||
|       &::after { | ||||
|         opacity: 1; | ||||
|         transition-duration: 100ms; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     a { | ||||
|       text-decoration: none; | ||||
|       color: inherit; | ||||
|     } | ||||
|  | ||||
|     .counter-label { | ||||
|       font-size: 12px; | ||||
|       display: block; | ||||
|       margin-bottom: 5px; | ||||
|     } | ||||
|  | ||||
|     .counter-number { | ||||
|       font-weight: 500; | ||||
|       font-size: 18px; | ||||
|       color: $primary-text-color; | ||||
|       font-family: 'mastodon-font-display', sans-serif; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .bio { | ||||
|     font-size: 14px; | ||||
|     line-height: 18px; | ||||
|     padding: 0 15px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 480px) { | ||||
|     display: block; | ||||
|  | ||||
|     .card__bio { | ||||
|       max-width: none; | ||||
|     } | ||||
|  | ||||
|     .name, | ||||
|     .roles { | ||||
|       text-align: center; | ||||
|       margin-bottom: 15px; | ||||
|     } | ||||
|  | ||||
|     .bio { | ||||
|       margin-bottom: 15px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .pagination { | ||||
|   padding: 30px 0; | ||||
|   text-align: center; | ||||
|   overflow: hidden; | ||||
|  | ||||
|   a, | ||||
|   .current, | ||||
|   .next, | ||||
|   .prev, | ||||
|   .page, | ||||
|   .gap { | ||||
|     font-size: 14px; | ||||
|     color: $primary-text-color; | ||||
|     font-weight: 500; | ||||
|     display: inline-block; | ||||
|     padding: 6px 10px; | ||||
|     text-decoration: none; | ||||
|   } | ||||
|  | ||||
|   .current { | ||||
|     background: $simple-background-color; | ||||
|     border-radius: 100px; | ||||
|     color: $ui-base-color; | ||||
|     cursor: default; | ||||
|     margin: 0 10px; | ||||
|   } | ||||
|  | ||||
|   .gap { | ||||
|     cursor: default; | ||||
|   } | ||||
|  | ||||
|   .prev, | ||||
|   .next { | ||||
|     text-transform: uppercase; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   .prev { | ||||
|     float: left; | ||||
|     padding-left: 0; | ||||
|  | ||||
|     .fa { | ||||
|       display: inline-block; | ||||
|       margin-right: 5px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .next { | ||||
|     float: right; | ||||
|     padding-right: 0; | ||||
|  | ||||
|     .fa { | ||||
|       display: inline-block; | ||||
|       margin-left: 5px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .disabled { | ||||
|     cursor: default; | ||||
|     color: lighten($ui-base-color, 10%); | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 700px) { | ||||
|     padding: 30px 20px; | ||||
|  | ||||
|     .page { | ||||
|       display: none; | ||||
|     } | ||||
|  | ||||
|     .next, | ||||
|     .prev { | ||||
|       display: inline-block; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .accounts-grid { | ||||
|   box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|   background: darken($simple-background-color, 8%); | ||||
|   border-radius: 0 0 4px 4px; | ||||
|   padding: 20px 5px; | ||||
|   padding-bottom: 10px; | ||||
|   overflow: hidden; | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   z-index: 2; | ||||
|   position: relative; | ||||
|  | ||||
|   @media screen and (max-width: 740px) { | ||||
|     border-radius: 0; | ||||
|     box-shadow: none; | ||||
|   } | ||||
|  | ||||
|   .account-grid-card { | ||||
|     box-sizing: border-box; | ||||
|     width: 335px; | ||||
|     background: $simple-background-color; | ||||
|     border-radius: 4px; | ||||
|     color: $ui-base-color; | ||||
|     margin: 0 5px 10px; | ||||
|     position: relative; | ||||
|  | ||||
|     @media screen and (max-width: 740px) { | ||||
|       width: calc(100% - 10px); | ||||
|     } | ||||
|  | ||||
|     .account-grid-card__header { | ||||
|       overflow: hidden; | ||||
|       height: 100px; | ||||
|       border-radius: 4px 4px 0 0; | ||||
|       background-color: lighten($ui-base-color, 4%); | ||||
|       background-size: cover; | ||||
|       background-position: center; | ||||
|       position: relative; | ||||
|  | ||||
|       &::after { | ||||
|         background: rgba(darken($ui-base-color, 8%), 0.5); | ||||
|         display: block; | ||||
|         content: ""; | ||||
|         position: absolute; | ||||
|         left: 0; | ||||
|         top: 0; | ||||
|         width: 100%; | ||||
|         height: 100%; | ||||
|         z-index: 1; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .account-grid-card__avatar { | ||||
|       box-sizing: border-box; | ||||
|       padding: 15px; | ||||
|       position: absolute; | ||||
|       z-index: 2; | ||||
|       top: 100px - (40px + 2px); | ||||
|       left: -2px; | ||||
|     } | ||||
|  | ||||
|     .avatar { | ||||
|       width: 80px; | ||||
|       height: 80px; | ||||
|  | ||||
|       img { | ||||
|         display: block; | ||||
|         width: 80px; | ||||
|         height: 80px; | ||||
|         border-radius: 80px; | ||||
|         border: 2px solid $simple-background-color; | ||||
|         background: $simple-background-color; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .name { | ||||
|       padding: 15px; | ||||
|       padding-top: 10px; | ||||
|       padding-left: 15px + 80px + 15px; | ||||
|  | ||||
|       a { | ||||
|         display: block; | ||||
|         color: $ui-base-color; | ||||
|         text-decoration: none; | ||||
|         text-overflow: ellipsis; | ||||
|         overflow: hidden; | ||||
|         font-weight: 500; | ||||
|  | ||||
|         &:hover { | ||||
|           .display_name { | ||||
|             text-decoration: underline; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .display_name { | ||||
|       font-size: 16px; | ||||
|       display: block; | ||||
|       text-overflow: ellipsis; | ||||
|       overflow: hidden; | ||||
|     } | ||||
|  | ||||
|     .username { | ||||
|       color: lighten($ui-base-color, 34%); | ||||
|       font-size: 14px; | ||||
|       font-weight: 400; | ||||
|     } | ||||
|  | ||||
|     .note { | ||||
|       padding: 10px 15px; | ||||
|       padding-top: 15px; | ||||
|       box-sizing: border-box; | ||||
|       color: lighten($ui-base-color, 26%); | ||||
|       word-wrap: break-word; | ||||
|       min-height: 80px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .nothing-here { | ||||
|   width: 100%; | ||||
|   display: block; | ||||
|   color: $ui-primary-color; | ||||
|   font-size: 14px; | ||||
|   font-weight: 500; | ||||
|   text-align: center; | ||||
|   padding: 60px 0; | ||||
|   padding-top: 55px; | ||||
|   cursor: default; | ||||
| } | ||||
|  | ||||
| .account-card { | ||||
|   padding: 14px 10px; | ||||
|   background: $simple-background-color; | ||||
|   border-radius: 4px; | ||||
|   text-align: left; | ||||
|   box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|  | ||||
|   .detailed-status__display-name { | ||||
|     display: block; | ||||
|     overflow: hidden; | ||||
|     margin-bottom: 15px; | ||||
|  | ||||
|     &:last-child { | ||||
|       margin-bottom: 0; | ||||
|     } | ||||
|  | ||||
|     & > div { | ||||
|       float: left; | ||||
|       margin-right: 10px; | ||||
|       width: 48px; | ||||
|       height: 48px; | ||||
|     } | ||||
|  | ||||
|     .avatar { | ||||
|       display: block; | ||||
|       border-radius: 4px; | ||||
|     } | ||||
|  | ||||
|     .display-name { | ||||
|       display: block; | ||||
|       max-width: 100%; | ||||
|       overflow: hidden; | ||||
|       white-space: nowrap; | ||||
|       text-overflow: ellipsis; | ||||
|       cursor: default; | ||||
|  | ||||
|       strong { | ||||
|         font-weight: 500; | ||||
|         color: $ui-base-color; | ||||
|       } | ||||
|  | ||||
|       span { | ||||
|         font-size: 14px; | ||||
|         color: $ui-primary-color; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     &:hover { | ||||
|       .display-name { | ||||
|         strong { | ||||
|           text-decoration: none; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .account__header__content { | ||||
|     font-size: 14px; | ||||
|     color: $ui-base-color; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .activity-stream-tabs { | ||||
|   background: $simple-background-color; | ||||
|   border-bottom: 1px solid $ui-secondary-color; | ||||
|   position: relative; | ||||
|   z-index: 2; | ||||
|  | ||||
|   a { | ||||
|     display: inline-block; | ||||
|     padding: 15px; | ||||
|     text-decoration: none; | ||||
|     color: $ui-highlight-color; | ||||
|     text-transform: uppercase; | ||||
|     font-weight: 500; | ||||
|  | ||||
|     &:hover, | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       color: lighten($ui-highlight-color, 8%); | ||||
|     } | ||||
|  | ||||
|     &.active { | ||||
|       color: $ui-base-color; | ||||
|       cursor: default; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .account-role { | ||||
|   display: inline-block; | ||||
|   padding: 4px 6px; | ||||
|   cursor: default; | ||||
|   border-radius: 3px; | ||||
|   font-size: 12px; | ||||
|   line-height: 12px; | ||||
|   font-weight: 500; | ||||
|   color: $success-green; | ||||
|   background-color: rgba($success-green, 0.1); | ||||
|   border: 1px solid rgba($success-green, 0.5); | ||||
| } | ||||
							
								
								
									
										349
									
								
								app/javascript/styles/mastodon/admin.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										349
									
								
								app/javascript/styles/mastodon/admin.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,349 @@ | ||||
| .admin-wrapper { | ||||
|   display: flex; | ||||
|   justify-content: center; | ||||
|   height: 100%; | ||||
|  | ||||
|   .sidebar-wrapper { | ||||
|     flex: 1; | ||||
|     height: 100%; | ||||
|     background: $ui-base-color; | ||||
|     display: flex; | ||||
|     justify-content: flex-end; | ||||
|   } | ||||
|  | ||||
|   .sidebar { | ||||
|     width: 240px; | ||||
|     height: 100%; | ||||
|     padding: 0; | ||||
|     overflow-y: auto; | ||||
|  | ||||
|     .logo { | ||||
|       display: block; | ||||
|       margin: 40px auto; | ||||
|       width: 100px; | ||||
|       height: 100px; | ||||
|     } | ||||
|  | ||||
|     ul { | ||||
|       list-style: none; | ||||
|       border-radius: 4px 0 0 4px; | ||||
|       overflow: hidden; | ||||
|       margin-bottom: 20px; | ||||
|  | ||||
|       a { | ||||
|         display: block; | ||||
|         padding: 15px; | ||||
|         color: rgba($primary-text-color, 0.7); | ||||
|         text-decoration: none; | ||||
|         transition: all 200ms linear; | ||||
|         border-radius: 4px 0 0 4px; | ||||
|  | ||||
|         i.fa { | ||||
|           margin-right: 5px; | ||||
|         } | ||||
|  | ||||
|         &:hover { | ||||
|           color: $primary-text-color; | ||||
|           background-color: darken($ui-base-color, 5%); | ||||
|           transition: all 100ms linear; | ||||
|         } | ||||
|  | ||||
|         &.selected { | ||||
|           background: darken($ui-base-color, 2%); | ||||
|           border-radius: 4px 0 0; | ||||
|         } | ||||
|       } | ||||
|  | ||||
|       ul { | ||||
|         background: darken($ui-base-color, 4%); | ||||
|         border-radius: 0 0 0 4px; | ||||
|         margin: 0; | ||||
|  | ||||
|         a { | ||||
|           border: 0; | ||||
|           padding: 15px 35px; | ||||
|  | ||||
|           &.selected { | ||||
|             color: $primary-text-color; | ||||
|             background-color: $ui-highlight-color; | ||||
|             border-bottom: 0; | ||||
|             border-radius: 0; | ||||
|  | ||||
|             &:hover { | ||||
|               background-color: lighten($ui-highlight-color, 5%); | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .content-wrapper { | ||||
|     flex: 2; | ||||
|     overflow: auto; | ||||
|   } | ||||
|  | ||||
|   .content { | ||||
|     max-width: 700px; | ||||
|     padding: 20px 15px; | ||||
|     padding-top: 60px; | ||||
|     padding-left: 25px; | ||||
|  | ||||
|     h2 { | ||||
|       color: $ui-secondary-color; | ||||
|       font-size: 24px; | ||||
|       line-height: 28px; | ||||
|       font-weight: 400; | ||||
|       margin-bottom: 40px; | ||||
|     } | ||||
|  | ||||
|     h3 { | ||||
|       color: $ui-secondary-color; | ||||
|       font-size: 20px; | ||||
|       line-height: 28px; | ||||
|       font-weight: 400; | ||||
|       margin-bottom: 30px; | ||||
|     } | ||||
|  | ||||
|     h6 { | ||||
|       font-size: 16px; | ||||
|       color: $ui-secondary-color; | ||||
|       line-height: 28px; | ||||
|       font-weight: 400; | ||||
|     } | ||||
|  | ||||
|     & > p { | ||||
|       font-size: 14px; | ||||
|       line-height: 18px; | ||||
|       color: $ui-secondary-color; | ||||
|       margin-bottom: 20px; | ||||
|  | ||||
|       strong { | ||||
|         color: $primary-text-color; | ||||
|         font-weight: 500; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     hr { | ||||
|       margin: 20px 0; | ||||
|       border: 0; | ||||
|       background: transparent; | ||||
|       border-bottom: 1px solid $ui-base-color; | ||||
|     } | ||||
|  | ||||
|     .muted-hint { | ||||
|       color: $ui-primary-color; | ||||
|  | ||||
|       a { | ||||
|         color: $ui-highlight-color; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .positive-hint { | ||||
|       color: $valid-value-color; | ||||
|       font-weight: 500; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .simple_form { | ||||
|     max-width: 400px; | ||||
|  | ||||
|     &.edit_user, | ||||
|     &.new_form_admin_settings, | ||||
|     &.new_form_two_factor_confirmation, | ||||
|     &.new_form_delete_confirmation, | ||||
|     &.new_import, | ||||
|     &.new_domain_block, | ||||
|     &.edit_domain_block { | ||||
|       max-width: none; | ||||
|     } | ||||
|  | ||||
|     .form_two_factor_confirmation_code, | ||||
|     .form_delete_confirmation_password { | ||||
|       max-width: 400px; | ||||
|     } | ||||
|  | ||||
|     .actions { | ||||
|       max-width: 400px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 600px) { | ||||
|     display: block; | ||||
|     overflow-y: auto; | ||||
|     -webkit-overflow-scrolling: touch; | ||||
|  | ||||
|     .sidebar-wrapper, | ||||
|     .content-wrapper { | ||||
|       flex: 0 0 auto; | ||||
|       height: auto; | ||||
|       overflow: initial; | ||||
|     } | ||||
|  | ||||
|     .sidebar { | ||||
|       width: 100%; | ||||
|       padding: 10px 0; | ||||
|       height: auto; | ||||
|  | ||||
|       .logo { | ||||
|         margin: 20px auto; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .content { | ||||
|       padding-top: 20px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .filters { | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|  | ||||
|   .filter-subset { | ||||
|     flex: 0 0 auto; | ||||
|     margin: 0 40px 10px 0; | ||||
|  | ||||
|     &:last-child { | ||||
|       margin-bottom: 20px; | ||||
|     } | ||||
|  | ||||
|     ul { | ||||
|       margin-top: 5px; | ||||
|       list-style: none; | ||||
|  | ||||
|       li { | ||||
|         display: inline-block; | ||||
|         margin-right: 5px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     strong { | ||||
|       font-weight: 500; | ||||
|       text-transform: uppercase; | ||||
|       font-size: 12px; | ||||
|     } | ||||
|  | ||||
|     a { | ||||
|       display: inline-block; | ||||
|       color: rgba($primary-text-color, 0.7); | ||||
|       text-decoration: none; | ||||
|       text-transform: uppercase; | ||||
|       font-size: 12px; | ||||
|       font-weight: 500; | ||||
|       border-bottom: 2px solid $ui-base-color; | ||||
|  | ||||
|       &:hover { | ||||
|         color: $primary-text-color; | ||||
|         border-bottom: 2px solid lighten($ui-base-color, 5%); | ||||
|       } | ||||
|  | ||||
|       &.selected { | ||||
|         color: $ui-highlight-color; | ||||
|         border-bottom: 2px solid $ui-highlight-color; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .report-accounts { | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
|  | ||||
| .report-accounts__item { | ||||
|   display: flex; | ||||
|   flex: 250px; | ||||
|   flex-direction: column; | ||||
|   margin: 0 5px; | ||||
|  | ||||
|   & > strong { | ||||
|     display: block; | ||||
|     margin: 0 0 10px -5px; | ||||
|     font-weight: 500; | ||||
|     font-size: 14px; | ||||
|     line-height: 18px; | ||||
|     color: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   .account-card { | ||||
|     flex: 1 1 auto; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .report-status, | ||||
| .account-status { | ||||
|   display: flex; | ||||
|   margin-bottom: 10px; | ||||
|  | ||||
|   .activity-stream { | ||||
|     flex: 2 0 0; | ||||
|     margin-right: 20px; | ||||
|     max-width: calc(100% - 60px); | ||||
|  | ||||
|     .entry { | ||||
|       border-radius: 4px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .report-status__actions, | ||||
| .account-status__actions { | ||||
|   flex: 0 0 auto; | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|  | ||||
|   .icon-button { | ||||
|     font-size: 24px; | ||||
|     width: 24px; | ||||
|     text-align: center; | ||||
|     margin-bottom: 10px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .batch-form-box { | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   margin-bottom: 5px; | ||||
|  | ||||
|   #form_status_batch_action { | ||||
|     margin: 0 5px 5px 0; | ||||
|     font-size: 14px; | ||||
|   } | ||||
|  | ||||
|   input.button { | ||||
|     margin: 0 5px 5px 0; | ||||
|   } | ||||
|  | ||||
|   .media-spoiler-toggle-buttons { | ||||
|     margin-left: auto; | ||||
|  | ||||
|     .button { | ||||
|       overflow: visible; | ||||
|       margin: 0 0 5px 5px; | ||||
|       float: right; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .batch-checkbox, | ||||
| .batch-checkbox-all { | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|   margin-right: 5px; | ||||
| } | ||||
|  | ||||
| .back-link { | ||||
|   margin-bottom: 10px; | ||||
|   font-size: 14px; | ||||
|  | ||||
|   a { | ||||
|     color: $classic-highlight-color; | ||||
|     text-decoration: none; | ||||
|  | ||||
|     &:hover { | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										122
									
								
								app/javascript/styles/mastodon/basics.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										122
									
								
								app/javascript/styles/mastodon/basics.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,122 @@ | ||||
| body { | ||||
|   font-family: 'mastodon-font-sans-serif', sans-serif; | ||||
|   background: $ui-base-color; | ||||
|   background-size: cover; | ||||
|   background-attachment: fixed; | ||||
|   font-size: 13px; | ||||
|   line-height: 18px; | ||||
|   font-weight: 400; | ||||
|   color: $primary-text-color; | ||||
|   padding-bottom: 20px; | ||||
|   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 | ||||
|     // mastodon-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", mastodon-font-sans-serif, sans-serif; | ||||
|   } | ||||
|  | ||||
|   &.app-body { | ||||
|     position: absolute; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     padding: 0; | ||||
|     background: $ui-base-color; | ||||
|   } | ||||
|  | ||||
|   &.about-body { | ||||
|     background: darken($ui-base-color, 8%); | ||||
|     padding-bottom: 0; | ||||
|   } | ||||
|  | ||||
|   &.tag-body { | ||||
|     background: darken($ui-base-color, 8%); | ||||
|     padding-bottom: 0; | ||||
|   } | ||||
|  | ||||
|   &.embed { | ||||
|     background: transparent; | ||||
|     margin: 0; | ||||
|     padding-bottom: 0; | ||||
|  | ||||
|     .container { | ||||
|       position: absolute; | ||||
|       width: 100%; | ||||
|       height: 100%; | ||||
|       overflow: hidden; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   &.admin { | ||||
|     background: darken($ui-base-color, 4%); | ||||
|     position: fixed; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     padding: 0; | ||||
|   } | ||||
|  | ||||
|   &.error { | ||||
|     position: absolute; | ||||
|     text-align: center; | ||||
|     color: $ui-primary-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; | ||||
|  | ||||
|       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 { | ||||
|     display: flex; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     align-items: center; | ||||
|     justify-content: center; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										18
									
								
								app/javascript/styles/mastodon/boost.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										18
									
								
								app/javascript/styles/mastodon/boost.scss
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because one or more lines are too long
											
										
									
								
							
							
								
								
									
										34
									
								
								app/javascript/styles/mastodon/compact_header.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										34
									
								
								app/javascript/styles/mastodon/compact_header.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,34 @@ | ||||
| .compact-header { | ||||
|   h1 { | ||||
|     font-size: 24px; | ||||
|     line-height: 28px; | ||||
|     color: $ui-primary-color; | ||||
|     font-weight: 500; | ||||
|     margin-bottom: 20px; | ||||
|     padding: 0 10px; | ||||
|     word-wrap: break-word; | ||||
|  | ||||
|     @media screen and (max-width: 740px) { | ||||
|       text-align: center; | ||||
|       padding: 20px 10px 0; | ||||
|     } | ||||
|  | ||||
|     a { | ||||
|       color: inherit; | ||||
|       text-decoration: none; | ||||
|     } | ||||
|  | ||||
|     small { | ||||
|       font-weight: 400; | ||||
|       color: $ui-secondary-color; | ||||
|     } | ||||
|  | ||||
|     img { | ||||
|       display: inline-block; | ||||
|       margin-bottom: -5px; | ||||
|       margin-right: 15px; | ||||
|       width: 36px; | ||||
|       height: 36px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										4339
									
								
								app/javascript/styles/mastodon/components.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										4339
									
								
								app/javascript/styles/mastodon/components.scss
									
									
									
									
									
										Normal file
									
								
							
										
											
												File diff suppressed because it is too large
												Load Diff
											
										
									
								
							
							
								
								
									
										116
									
								
								app/javascript/styles/mastodon/containers.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										116
									
								
								app/javascript/styles/mastodon/containers.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,116 @@ | ||||
| .container { | ||||
|   width: 700px; | ||||
|   margin: 0 auto; | ||||
|   margin-top: 40px; | ||||
|  | ||||
|   @media screen and (max-width: 740px) { | ||||
|     width: 100%; | ||||
|     margin: 0; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .logo-container { | ||||
|   margin: 100px auto; | ||||
|   margin-bottom: 50px; | ||||
|  | ||||
|   @media screen and (max-width: 400px) { | ||||
|     margin: 30px auto; | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
|  | ||||
|   h1 { | ||||
|     display: flex; | ||||
|     justify-content: center; | ||||
|     align-items: center; | ||||
|  | ||||
|     img { | ||||
|       height: 42px; | ||||
|       margin-right: 10px; | ||||
|     } | ||||
|  | ||||
|     a { | ||||
|       display: flex; | ||||
|       justify-content: center; | ||||
|       align-items: center; | ||||
|       color: $primary-text-color; | ||||
|       text-decoration: none; | ||||
|       outline: 0; | ||||
|       padding: 12px 16px; | ||||
|       line-height: 32px; | ||||
|       font-family: 'mastodon-font-display', sans-serif; | ||||
|       font-weight: 500; | ||||
|       font-size: 14px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .compose-standalone { | ||||
|   .compose-form { | ||||
|     width: 400px; | ||||
|     margin: 0 auto; | ||||
|     padding: 20px 0; | ||||
|     margin-top: 40px; | ||||
|     box-sizing: border-box; | ||||
|  | ||||
|     @media screen and (max-width: 400px) { | ||||
|       width: 100%; | ||||
|       margin-top: 0; | ||||
|       padding: 20px; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .account-header { | ||||
|   width: 400px; | ||||
|   margin: 0 auto; | ||||
|   display: flex; | ||||
|   font-size: 13px; | ||||
|   line-height: 18px; | ||||
|   box-sizing: border-box; | ||||
|   padding: 20px 0; | ||||
|   padding-bottom: 0; | ||||
|   margin-bottom: -30px; | ||||
|   margin-top: 40px; | ||||
|  | ||||
|   @media screen and (max-width: 440px) { | ||||
|     width: 100%; | ||||
|     margin: 0; | ||||
|     margin-bottom: 10px; | ||||
|     padding: 20px; | ||||
|     padding-bottom: 0; | ||||
|   } | ||||
|  | ||||
|   .avatar { | ||||
|     width: 40px; | ||||
|     height: 40px; | ||||
|     margin-right: 8px; | ||||
|  | ||||
|     img { | ||||
|       width: 100%; | ||||
|       height: 100%; | ||||
|       display: block; | ||||
|       margin: 0; | ||||
|       border-radius: 4px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .name { | ||||
|     flex: 1 1 auto; | ||||
|     color: $ui-secondary-color; | ||||
|     width: calc(100% - 88px); | ||||
|  | ||||
|     .username { | ||||
|       display: block; | ||||
|       font-weight: 500; | ||||
|       text-overflow: ellipsis; | ||||
|       overflow: hidden; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .logout-link { | ||||
|     display: block; | ||||
|     font-size: 32px; | ||||
|     line-height: 40px; | ||||
|     margin-left: 8px; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										199
									
								
								app/javascript/styles/mastodon/emoji_picker.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										199
									
								
								app/javascript/styles/mastodon/emoji_picker.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,199 @@ | ||||
| .emoji-mart { | ||||
|   &, | ||||
|   * { | ||||
|     box-sizing: border-box; | ||||
|     line-height: 1.15; | ||||
|   } | ||||
|  | ||||
|   font-size: 13px; | ||||
|   display: inline-block; | ||||
|   color: $ui-base-color; | ||||
|  | ||||
|   .emoji-mart-emoji { | ||||
|     padding: 6px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-bar { | ||||
|   border: 0 solid darken($ui-secondary-color, 8%); | ||||
|  | ||||
|   &:first-child { | ||||
|     border-bottom-width: 1px; | ||||
|     border-top-left-radius: 5px; | ||||
|     border-top-right-radius: 5px; | ||||
|     background: $ui-secondary-color; | ||||
|   } | ||||
|  | ||||
|   &:last-child { | ||||
|     border-top-width: 1px; | ||||
|     border-bottom-left-radius: 5px; | ||||
|     border-bottom-right-radius: 5px; | ||||
|     display: none; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-anchors { | ||||
|   display: flex; | ||||
|   justify-content: space-between; | ||||
|   padding: 0 6px; | ||||
|   color: $ui-primary-color; | ||||
|   line-height: 0; | ||||
| } | ||||
|  | ||||
| .emoji-mart-anchor { | ||||
|   position: relative; | ||||
|   flex: 1; | ||||
|   text-align: center; | ||||
|   padding: 12px 4px; | ||||
|   overflow: hidden; | ||||
|   transition: color .1s ease-out; | ||||
|   cursor: pointer; | ||||
|  | ||||
|   &:hover { | ||||
|     color: darken($ui-primary-color, 4%); | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-anchor-selected { | ||||
|   color: darken($ui-highlight-color, 3%); | ||||
|  | ||||
|   &:hover { | ||||
|     color: darken($ui-highlight-color, 3%); | ||||
|   } | ||||
|  | ||||
|   .emoji-mart-anchor-bar { | ||||
|     bottom: 0; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-anchor-bar { | ||||
|   position: absolute; | ||||
|   bottom: -3px; | ||||
|   left: 0; | ||||
|   width: 100%; | ||||
|   height: 3px; | ||||
|   background-color: darken($ui-highlight-color, 3%); | ||||
| } | ||||
|  | ||||
| .emoji-mart-anchors { | ||||
|   i { | ||||
|     display: inline-block; | ||||
|     width: 100%; | ||||
|     max-width: 22px; | ||||
|   } | ||||
|  | ||||
|   svg { | ||||
|     fill: currentColor; | ||||
|     max-height: 18px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-scroll { | ||||
|   overflow-y: scroll; | ||||
|   height: 270px; | ||||
|   max-height: 35vh; | ||||
|   padding: 0 6px 6px; | ||||
|   background: $simple-background-color; | ||||
|   will-change: transform; | ||||
| } | ||||
|  | ||||
| .emoji-mart-search { | ||||
|   padding: 10px; | ||||
|   padding-right: 45px; | ||||
|   background: $simple-background-color; | ||||
|  | ||||
|   input { | ||||
|     font-size: 14px; | ||||
|     font-weight: 400; | ||||
|     padding: 7px 9px; | ||||
|     font-family: inherit; | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     background: rgba($ui-secondary-color, 0.3); | ||||
|     color: $ui-primary-color; | ||||
|     border: 1px solid $ui-secondary-color; | ||||
|     border-radius: 4px; | ||||
|  | ||||
|     &::-moz-focus-inner { | ||||
|       border: 0; | ||||
|     } | ||||
|  | ||||
|     &::-moz-focus-inner, | ||||
|     &:focus, | ||||
|     &:active { | ||||
|       outline: 0 !important; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-category .emoji-mart-emoji { | ||||
|   cursor: pointer; | ||||
|  | ||||
|   span { | ||||
|     z-index: 1; | ||||
|     position: relative; | ||||
|     text-align: center; | ||||
|   } | ||||
|  | ||||
|   &:hover::before { | ||||
|     z-index: 0; | ||||
|     content: ""; | ||||
|     position: absolute; | ||||
|     top: 0; | ||||
|     left: 0; | ||||
|     width: 100%; | ||||
|     height: 100%; | ||||
|     background-color: rgba($ui-secondary-color, 0.7); | ||||
|     border-radius: 100%; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-category-label { | ||||
|   z-index: 2; | ||||
|   position: relative; | ||||
|   position: -webkit-sticky; | ||||
|   position: sticky; | ||||
|   top: 0; | ||||
|  | ||||
|   span { | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     font-weight: 500; | ||||
|     padding: 5px 6px; | ||||
|     background: $simple-background-color; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-emoji { | ||||
|   position: relative; | ||||
|   display: inline-block; | ||||
|   font-size: 0; | ||||
|  | ||||
|   span { | ||||
|     width: 22px; | ||||
|     height: 22px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-no-results { | ||||
|   font-size: 14px; | ||||
|   text-align: center; | ||||
|   padding-top: 70px; | ||||
|   color: $ui-primary-color; | ||||
|  | ||||
|   .emoji-mart-category-label { | ||||
|     display: none; | ||||
|   } | ||||
|  | ||||
|   .emoji-mart-no-results-label { | ||||
|     margin-top: .2em; | ||||
|   } | ||||
|  | ||||
|   .emoji-mart-emoji:hover::before { | ||||
|     content: none; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .emoji-mart-preview { | ||||
|   display: none; | ||||
| } | ||||
							
								
								
									
										30
									
								
								app/javascript/styles/mastodon/footer.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										30
									
								
								app/javascript/styles/mastodon/footer.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,30 @@ | ||||
| .footer { | ||||
|   text-align: center; | ||||
|   margin-top: 30px; | ||||
|   font-size: 12px; | ||||
|   color: darken($ui-secondary-color, 25%); | ||||
|  | ||||
|   .domain { | ||||
|     font-weight: 500; | ||||
|  | ||||
|     a { | ||||
|       color: inherit; | ||||
|       text-decoration: none; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .powered-by, | ||||
|   .single-user-login { | ||||
|     font-weight: 400; | ||||
|  | ||||
|     a { | ||||
|       color: inherit; | ||||
|       text-decoration: underline; | ||||
|       font-weight: 500; | ||||
|  | ||||
|       &:hover { | ||||
|         text-decoration: none; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										540
									
								
								app/javascript/styles/mastodon/forms.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										540
									
								
								app/javascript/styles/mastodon/forms.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,540 @@ | ||||
| code { | ||||
|   font-family: 'mastodon-font-monospace', monospace; | ||||
|   font-weight: 400; | ||||
| } | ||||
|  | ||||
| .form-container { | ||||
|   max-width: 400px; | ||||
|   padding: 20px; | ||||
|   margin: 0 auto; | ||||
| } | ||||
|  | ||||
| .simple_form { | ||||
|   .input { | ||||
|     margin-bottom: 15px; | ||||
|     overflow: hidden; | ||||
|   } | ||||
|  | ||||
|   span.hint { | ||||
|     display: block; | ||||
|     color: $ui-primary-color; | ||||
|     font-size: 12px; | ||||
|     margin-top: 4px; | ||||
|   } | ||||
|  | ||||
|   h4 { | ||||
|     text-transform: uppercase; | ||||
|     font-size: 13px; | ||||
|     font-weight: 500; | ||||
|     color: $ui-primary-color; | ||||
|     padding-bottom: 8px; | ||||
|     margin-bottom: 8px; | ||||
|     border-bottom: 1px solid lighten($ui-base-color, 8%); | ||||
|   } | ||||
|  | ||||
|   p.hint { | ||||
|     margin-bottom: 15px; | ||||
|     color: $ui-primary-color; | ||||
|  | ||||
|     &.subtle-hint { | ||||
|       text-align: center; | ||||
|       font-size: 12px; | ||||
|       line-height: 18px; | ||||
|       margin-top: 15px; | ||||
|       margin-bottom: 0; | ||||
|       color: $ui-primary-color; | ||||
|  | ||||
|       a { | ||||
|         color: $ui-highlight-color; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .card { | ||||
|     margin-bottom: 15px; | ||||
|   } | ||||
|  | ||||
|   strong { | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   .label_input { | ||||
|     display: flex; | ||||
|  | ||||
|     label { | ||||
|       flex: 0 0 auto; | ||||
|     } | ||||
|  | ||||
|     input { | ||||
|       flex: 1 1 auto; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .input.with_label { | ||||
|     padding: 15px 0; | ||||
|     margin-bottom: 0; | ||||
|  | ||||
|     .label_input { | ||||
|       flex-wrap: wrap; | ||||
|       align-items: flex-start; | ||||
|     } | ||||
|  | ||||
|     &.select .label_input { | ||||
|       align-items: initial; | ||||
|     } | ||||
|  | ||||
|     .label_input > label { | ||||
|       font-family: inherit; | ||||
|       font-size: 16px; | ||||
|       color: $primary-text-color; | ||||
|       display: block; | ||||
|       padding-top: 5px; | ||||
|       margin-bottom: 5px; | ||||
|       flex: 1; | ||||
|       min-width: 150px; | ||||
|       word-wrap: break-word; | ||||
|  | ||||
|       &.select { | ||||
|         flex: 0; | ||||
|       } | ||||
|  | ||||
|       & ~ * { | ||||
|         margin-left: 10px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     ul { | ||||
|       flex: 390px; | ||||
|     } | ||||
|  | ||||
|     &.boolean { | ||||
|       padding: initial; | ||||
|       margin-bottom: initial; | ||||
|  | ||||
|       .label_input > label { | ||||
|         font-family: inherit; | ||||
|         font-size: 14px; | ||||
|         color: $primary-text-color; | ||||
|         display: block; | ||||
|         width: auto; | ||||
|       } | ||||
|  | ||||
|       label.checkbox { | ||||
|         position: relative; | ||||
|         padding-left: 25px; | ||||
|         flex: 1 1 auto; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .input.with_block_label { | ||||
|     & > label { | ||||
|       font-family: inherit; | ||||
|       font-size: 16px; | ||||
|       color: $primary-text-color; | ||||
|       display: block; | ||||
|       padding-top: 5px; | ||||
|     } | ||||
|  | ||||
|     .hint { | ||||
|       margin-bottom: 15px; | ||||
|     } | ||||
|  | ||||
|     li { | ||||
|       float: left; | ||||
|       width: 50%; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .fields-group { | ||||
|     margin-bottom: 25px; | ||||
|   } | ||||
|  | ||||
|   .input.radio_buttons .radio label { | ||||
|     margin-bottom: 5px; | ||||
|     font-family: inherit; | ||||
|     font-size: 14px; | ||||
|     color: $primary-text-color; | ||||
|     display: block; | ||||
|     width: auto; | ||||
|   } | ||||
|  | ||||
|   .input.boolean { | ||||
|     margin-bottom: 5px; | ||||
|  | ||||
|     label { | ||||
|       font-family: inherit; | ||||
|       font-size: 14px; | ||||
|       color: $primary-text-color; | ||||
|       display: block; | ||||
|       width: auto; | ||||
|     } | ||||
|  | ||||
|     label.checkbox { | ||||
|       position: relative; | ||||
|       padding-left: 25px; | ||||
|       flex: 1 1 auto; | ||||
|     } | ||||
|  | ||||
|     input[type=checkbox] { | ||||
|       position: absolute; | ||||
|       left: 0; | ||||
|       top: 5px; | ||||
|       margin: 0; | ||||
|     } | ||||
|  | ||||
|     .hint { | ||||
|       padding-left: 25px; | ||||
|       margin-left: 0; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .check_boxes { | ||||
|     .checkbox { | ||||
|       label { | ||||
|         font-family: inherit; | ||||
|         font-size: 14px; | ||||
|         color: $primary-text-color; | ||||
|         display: block; | ||||
|         width: auto; | ||||
|         position: relative; | ||||
|         padding-top: 5px; | ||||
|         padding-left: 25px; | ||||
|         flex: 1 1 auto; | ||||
|       } | ||||
|  | ||||
|       input[type=checkbox] { | ||||
|         position: absolute; | ||||
|         left: 0; | ||||
|         top: 5px; | ||||
|         margin: 0; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   input[type=text], | ||||
|   input[type=number], | ||||
|   input[type=email], | ||||
|   input[type=password], | ||||
|   textarea { | ||||
|     background: transparent; | ||||
|     box-sizing: border-box; | ||||
|     border: 0; | ||||
|     border-bottom: 2px solid $ui-primary-color; | ||||
|     border-radius: 2px 2px 0 0; | ||||
|     padding: 7px 4px; | ||||
|     font-size: 16px; | ||||
|     color: $primary-text-color; | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     outline: 0; | ||||
|     font-family: inherit; | ||||
|     resize: vertical; | ||||
|  | ||||
|     &:invalid { | ||||
|       box-shadow: none; | ||||
|     } | ||||
|  | ||||
|     &:focus:invalid { | ||||
|       border-bottom-color: $error-value-color; | ||||
|     } | ||||
|  | ||||
|     &:required:valid { | ||||
|       border-bottom-color: $valid-value-color; | ||||
|     } | ||||
|  | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       border-bottom-color: $ui-highlight-color; | ||||
|       background: rgba($base-overlay-background, 0.1); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .input.field_with_errors { | ||||
|     label { | ||||
|       color: $error-value-color; | ||||
|     } | ||||
|  | ||||
|     input[type=text], | ||||
|     input[type=email], | ||||
|     input[type=password] { | ||||
|       border-bottom-color: $error-value-color; | ||||
|     } | ||||
|  | ||||
|     .error { | ||||
|       display: block; | ||||
|       font-weight: 500; | ||||
|       color: $error-value-color; | ||||
|       margin-top: 4px; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .actions { | ||||
|     margin-top: 30px; | ||||
|     display: flex; | ||||
|   } | ||||
|  | ||||
|   button, | ||||
|   .button, | ||||
|   .block-button { | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     border: 0; | ||||
|     border-radius: 4px; | ||||
|     background: $ui-highlight-color; | ||||
|     color: $primary-text-color; | ||||
|     font-size: 18px; | ||||
|     line-height: inherit; | ||||
|     height: auto; | ||||
|     padding: 10px; | ||||
|     text-transform: uppercase; | ||||
|     text-decoration: none; | ||||
|     text-align: center; | ||||
|     box-sizing: border-box; | ||||
|     cursor: pointer; | ||||
|     font-weight: 500; | ||||
|     outline: 0; | ||||
|     margin-bottom: 10px; | ||||
|     margin-right: 10px; | ||||
|  | ||||
|     &:last-child { | ||||
|       margin-right: 0; | ||||
|     } | ||||
|  | ||||
|     &:hover { | ||||
|       background-color: lighten($ui-highlight-color, 5%); | ||||
|     } | ||||
|  | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       background-color: darken($ui-highlight-color, 5%); | ||||
|     } | ||||
|  | ||||
|     &.negative { | ||||
|       background: $error-value-color; | ||||
|  | ||||
|       &:hover { | ||||
|         background-color: lighten($error-value-color, 5%); | ||||
|       } | ||||
|  | ||||
|       &:active, | ||||
|       &:focus { | ||||
|         background-color: darken($error-value-color, 5%); | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   select { | ||||
|     font-size: 16px; | ||||
|     max-height: 29px; | ||||
|   } | ||||
|  | ||||
|   .input-with-append { | ||||
|     position: relative; | ||||
|  | ||||
|     .input input { | ||||
|       padding-right: 127px; | ||||
|     } | ||||
|  | ||||
|     .append { | ||||
|       position: absolute; | ||||
|       right: 0; | ||||
|       top: 0; | ||||
|       padding: 7px 4px; | ||||
|       padding-bottom: 9px; | ||||
|       font-size: 16px; | ||||
|       color: $ui-base-lighter-color; | ||||
|       font-family: inherit; | ||||
|       pointer-events: none; | ||||
|       cursor: default; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .flash-message { | ||||
|   background: lighten($ui-base-color, 8%); | ||||
|   color: $ui-primary-color; | ||||
|   border-radius: 4px; | ||||
|   padding: 15px 10px; | ||||
|   margin-bottom: 30px; | ||||
|   box-shadow: 0 0 5px rgba($base-shadow-color, 0.2); | ||||
|   text-align: center; | ||||
|  | ||||
|   p { | ||||
|     margin-bottom: 15px; | ||||
|   } | ||||
|  | ||||
|   .oauth-code { | ||||
|     color: $ui-secondary-color; | ||||
|     outline: 0; | ||||
|     box-sizing: border-box; | ||||
|     display: block; | ||||
|     width: 100%; | ||||
|     border: none; | ||||
|     padding: 10px; | ||||
|     font-family: 'mastodon-font-monospace', monospace; | ||||
|     background: $ui-base-color; | ||||
|     color: $ui-primary-color; | ||||
|     font-size: 14px; | ||||
|     margin: 0; | ||||
|  | ||||
|     &::-moz-focus-inner { | ||||
|       border: 0; | ||||
|     } | ||||
|  | ||||
|     &::-moz-focus-inner, | ||||
|     &:focus, | ||||
|     &:active { | ||||
|       outline: 0 !important; | ||||
|     } | ||||
|  | ||||
|     &:focus { | ||||
|       background: lighten($ui-base-color, 4%); | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   strong { | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 740px) and (min-width: 441px) { | ||||
|     margin-top: 40px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .form-footer { | ||||
|   margin-top: 30px; | ||||
|   text-align: center; | ||||
|  | ||||
|   a { | ||||
|     color: $ui-primary-color; | ||||
|     text-decoration: none; | ||||
|  | ||||
|     &:hover { | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .oauth-prompt, | ||||
| .follow-prompt { | ||||
|   margin-bottom: 30px; | ||||
|   text-align: center; | ||||
|   color: $ui-primary-color; | ||||
|  | ||||
|   h2 { | ||||
|     font-size: 16px; | ||||
|     margin-bottom: 30px; | ||||
|   } | ||||
|  | ||||
|   strong { | ||||
|     color: $ui-secondary-color; | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 740px) and (min-width: 441px) { | ||||
|     margin-top: 40px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .qr-wrapper { | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   align-items: flex-start; | ||||
| } | ||||
|  | ||||
| .qr-code { | ||||
|   flex: 0 0 auto; | ||||
|   background: $simple-background-color; | ||||
|   padding: 4px; | ||||
|   margin: 0 10px 20px 0; | ||||
|   box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|   display: inline-block; | ||||
|  | ||||
|   svg { | ||||
|     display: block; | ||||
|     margin: 0; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .qr-alternative { | ||||
|   margin-bottom: 20px; | ||||
|   color: $ui-secondary-color; | ||||
|   flex: 150px; | ||||
|  | ||||
|   samp { | ||||
|     display: block; | ||||
|     font-size: 14px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .table-form { | ||||
|   p { | ||||
|     margin-bottom: 15px; | ||||
|  | ||||
|     strong { | ||||
|       font-weight: 500; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .simple_form, | ||||
| .table-form { | ||||
|   .warning { | ||||
|     box-sizing: border-box; | ||||
|     background: rgba($error-value-color, 0.5); | ||||
|     color: $primary-text-color; | ||||
|     text-shadow: 1px 1px 0 rgba($base-shadow-color, 0.3); | ||||
|     box-shadow: 0 2px 6px rgba($base-shadow-color, 0.4); | ||||
|     border-radius: 4px; | ||||
|     padding: 10px; | ||||
|     margin-bottom: 15px; | ||||
|  | ||||
|     a { | ||||
|       color: $primary-text-color; | ||||
|       text-decoration: underline; | ||||
|  | ||||
|       &:hover, | ||||
|       &:focus, | ||||
|       &:active { | ||||
|         text-decoration: none; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     strong { | ||||
|       font-weight: 600; | ||||
|       display: block; | ||||
|       margin-bottom: 5px; | ||||
|  | ||||
|       .fa { | ||||
|         font-weight: 400; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .action-pagination { | ||||
|   display: flex; | ||||
|   flex-wrap: wrap; | ||||
|   align-items: center; | ||||
|  | ||||
|   .actions, | ||||
|   .pagination { | ||||
|     flex: 1 1 auto; | ||||
|   } | ||||
|  | ||||
|   .actions { | ||||
|     padding: 30px 0; | ||||
|     padding-right: 20px; | ||||
|     flex: 0 0 auto; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .post-follow-actions { | ||||
|   text-align: center; | ||||
|   color: $ui-primary-color; | ||||
|  | ||||
|   div { | ||||
|     margin-bottom: 4px; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										31
									
								
								app/javascript/styles/mastodon/landing_strip.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								app/javascript/styles/mastodon/landing_strip.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,31 @@ | ||||
| .landing-strip { | ||||
|   background: rgba(darken($ui-base-color, 7%), 0.8); | ||||
|   color: $ui-primary-color; | ||||
|   font-weight: 400; | ||||
|   padding: 14px; | ||||
|   border-radius: 4px; | ||||
|   margin-bottom: 20px; | ||||
|   display: flex; | ||||
|   align-items: center; | ||||
|  | ||||
|   strong, | ||||
|   a { | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   a { | ||||
|     color: inherit; | ||||
|     text-decoration: underline; | ||||
|   } | ||||
|  | ||||
|   .logo { | ||||
|     width: 30px; | ||||
|     height: 30px; | ||||
|     flex: 0 0 auto; | ||||
|     margin-right: 15px; | ||||
|   } | ||||
|  | ||||
|   @media screen and (max-width: 740px) { | ||||
|     margin-bottom: 0; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										19
									
								
								app/javascript/styles/mastodon/lists.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										19
									
								
								app/javascript/styles/mastodon/lists.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,19 @@ | ||||
| .no-list { | ||||
|   list-style: none; | ||||
|  | ||||
|   li { | ||||
|     display: inline-block; | ||||
|     margin: 0 5px; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .recovery-codes { | ||||
|   list-style: none; | ||||
|   margin: 0 auto; | ||||
|  | ||||
|   li { | ||||
|     font-size: 125%; | ||||
|     line-height: 1.5; | ||||
|     letter-spacing: 1px; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										91
									
								
								app/javascript/styles/mastodon/reset.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										91
									
								
								app/javascript/styles/mastodon/reset.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,91 @@ | ||||
| /* http://meyerweb.com/eric/tools/css/reset/ | ||||
|    v2.0 | 20110126 | ||||
|    License: none (public domain) | ||||
| */ | ||||
|  | ||||
| html, body, div, span, applet, object, iframe, | ||||
| h1, h2, h3, h4, h5, h6, p, blockquote, pre, | ||||
| a, abbr, acronym, address, big, cite, code, | ||||
| del, dfn, em, img, ins, kbd, q, s, samp, | ||||
| small, strike, strong, sub, sup, tt, var, | ||||
| b, u, i, center, | ||||
| dl, dt, dd, ol, ul, li, | ||||
| fieldset, form, label, legend, | ||||
| table, caption, tbody, tfoot, thead, tr, th, td, | ||||
| article, aside, canvas, details, embed, | ||||
| figure, figcaption, footer, header, hgroup, | ||||
| menu, nav, output, ruby, section, summary, | ||||
| time, mark, audio, video { | ||||
|   margin: 0; | ||||
|   padding: 0; | ||||
|   border: 0; | ||||
|   font-size: 100%; | ||||
|   font: inherit; | ||||
|   vertical-align: baseline; | ||||
| } | ||||
|  | ||||
| /* HTML5 display-role reset for older browsers */ | ||||
| article, aside, details, figcaption, figure, | ||||
| footer, header, hgroup, menu, nav, section { | ||||
|   display: block; | ||||
| } | ||||
|  | ||||
| body { | ||||
|   line-height: 1; | ||||
| } | ||||
|  | ||||
| ol, ul { | ||||
|   list-style: none; | ||||
| } | ||||
|  | ||||
| blockquote, q { | ||||
|   quotes: none; | ||||
| } | ||||
|  | ||||
| blockquote:before, blockquote:after, | ||||
| q:before, q:after { | ||||
|   content: ''; | ||||
|   content: none; | ||||
| } | ||||
|  | ||||
| table { | ||||
|   border-collapse: collapse; | ||||
|   border-spacing: 0; | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar { | ||||
|   width: 8px; | ||||
|   height: 8px; | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-thumb { | ||||
|   background: lighten($ui-base-color, 4%); | ||||
|   border: 0px none $base-border-color; | ||||
|   border-radius: 50px; | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-thumb:hover { | ||||
|   background: lighten($ui-base-color, 6%); | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-thumb:active { | ||||
|   background: lighten($ui-base-color, 4%); | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-track { | ||||
|   border: 0px none $base-border-color; | ||||
|   border-radius: 0; | ||||
|   background: rgba($base-overlay-background, 0.1); | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-track:hover { | ||||
|   background: $ui-base-color; | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-track:active { | ||||
|   background: $ui-base-color; | ||||
| } | ||||
|  | ||||
| ::-webkit-scrollbar-corner { | ||||
|   background: transparent; | ||||
| } | ||||
							
								
								
									
										254
									
								
								app/javascript/styles/mastodon/rtl.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										254
									
								
								app/javascript/styles/mastodon/rtl.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,254 @@ | ||||
| body.rtl { | ||||
|   direction: rtl; | ||||
|  | ||||
|   .column-link__icon, | ||||
|   .column-header__icon { | ||||
|     margin-right: 0; | ||||
|     margin-left: 5px; | ||||
|   } | ||||
|  | ||||
|   .character-counter__wrapper { | ||||
|     margin-right: 8px; | ||||
|     margin-left: 16px; | ||||
|   } | ||||
|  | ||||
|   .navigation-bar__profile { | ||||
|     margin-left: 0; | ||||
|     margin-right: 8px; | ||||
|   } | ||||
|  | ||||
|   .search__input { | ||||
|     padding-right: 10px; | ||||
|     padding-left: 30px; | ||||
|   } | ||||
|  | ||||
|   .search__icon .fa { | ||||
|     right: auto; | ||||
|     left: 10px; | ||||
|   } | ||||
|  | ||||
|   .column-header__buttons { | ||||
|     left: 0; | ||||
|     right: auto; | ||||
|   } | ||||
|  | ||||
|   .column-header__back-button { | ||||
|     padding-left: 5px; | ||||
|     padding-right: 0; | ||||
|   } | ||||
|  | ||||
|   .column-header__setting-arrows { | ||||
|     float: left; | ||||
|   } | ||||
|  | ||||
|   .compose-form__modifiers { | ||||
|     border-radius: 0 0 0 4px; | ||||
|   } | ||||
|  | ||||
|   .setting-toggle { | ||||
|     margin-left: 0; | ||||
|     margin-right: 8px; | ||||
|   } | ||||
|  | ||||
|   .setting-meta__label { | ||||
|     float: left; | ||||
|   } | ||||
|  | ||||
|   .status__avatar { | ||||
|     left: auto; | ||||
|     right: 10px; | ||||
|   } | ||||
|  | ||||
|   .status, | ||||
|   .activity-stream .status.light { | ||||
|     padding-left: 10px; | ||||
|     padding-right: 68px; | ||||
|   } | ||||
|  | ||||
|   .status__info .status__display-name, | ||||
|   .activity-stream .status.light .status__display-name { | ||||
|     padding-left: 25px; | ||||
|     padding-right: 0; | ||||
|   } | ||||
|  | ||||
|   .activity-stream .pre-header { | ||||
|     padding-right: 68px; | ||||
|     padding-left: 0; | ||||
|   } | ||||
|  | ||||
|   .status__prepend { | ||||
|     margin-left: 0; | ||||
|     margin-right: 68px; | ||||
|   } | ||||
|  | ||||
|   .status__prepend-icon-wrapper { | ||||
|     left: auto; | ||||
|     right: -26px; | ||||
|   } | ||||
|  | ||||
|   .activity-stream .pre-header .pre-header__icon { | ||||
|     left: auto; | ||||
|     right: 42px; | ||||
|   } | ||||
|  | ||||
|   .account__avatar-overlay-overlay { | ||||
|     right: auto; | ||||
|     left: 0; | ||||
|   } | ||||
|  | ||||
|   .column-back-button--slim-button { | ||||
|     right: auto; | ||||
|     left: 0; | ||||
|   } | ||||
|  | ||||
|   .status__relative-time, | ||||
|   .activity-stream .status.light .status__header .status__meta { | ||||
|     float: left; | ||||
|   } | ||||
|  | ||||
|   .activity-stream .detailed-status.light .detailed-status__display-name > div { | ||||
|     float: right; | ||||
|     margin-right: 0; | ||||
|     margin-left: 10px; | ||||
|   } | ||||
|  | ||||
|   .activity-stream .detailed-status.light .detailed-status__meta span > span { | ||||
|     margin-left: 0; | ||||
|     margin-right: 6px; | ||||
|   } | ||||
|  | ||||
|   .status__action-bar-button { | ||||
|     float: right; | ||||
|     margin-right: 0; | ||||
|     margin-left: 18px; | ||||
|   } | ||||
|  | ||||
|   .status__action-bar-dropdown { | ||||
|     float: right; | ||||
|   } | ||||
|  | ||||
|   .privacy-dropdown__dropdown { | ||||
|     margin-left: 0; | ||||
|     margin-right: 40px; | ||||
|   } | ||||
|  | ||||
|   .privacy-dropdown__option__icon { | ||||
|     margin-left: 10px; | ||||
|     margin-right: 0; | ||||
|   } | ||||
|  | ||||
|   .detailed-status__display-avatar { | ||||
|     margin-right: 0; | ||||
|     margin-left: 10px; | ||||
|     float: right; | ||||
|   } | ||||
|  | ||||
|   .detailed-status__favorites, | ||||
|   .detailed-status__reblogs { | ||||
|     margin-left: 0; | ||||
|     margin-right: 6px; | ||||
|   } | ||||
|  | ||||
|   .fa-ul { | ||||
|     margin-left: 0; | ||||
|     margin-left: 2.14285714em; | ||||
|   } | ||||
|  | ||||
|   .fa-li { | ||||
|     left: auto; | ||||
|     right: -2.14285714em; | ||||
|   } | ||||
|  | ||||
|   .admin-wrapper .sidebar ul a i.fa, | ||||
|   a.table-action-link i.fa { | ||||
|     margin-right: 0; | ||||
|     margin-left: 5px; | ||||
|   } | ||||
|  | ||||
|   .simple_form .check_boxes .checkbox label, | ||||
|   .simple_form .input.with_label.boolean label.checkbox { | ||||
|     padding-left: 0; | ||||
|     padding-right: 25px; | ||||
|   } | ||||
|  | ||||
|   .simple_form .check_boxes .checkbox input[type="checkbox"], | ||||
|   .simple_form .input.boolean input[type="checkbox"] { | ||||
|     left: auto; | ||||
|     right: 0; | ||||
|   } | ||||
|  | ||||
|   .simple_form .input-with-append .input input { | ||||
|     padding-left: 127px; | ||||
|     padding-right: 0; | ||||
|   } | ||||
|  | ||||
|   .simple_form .input-with-append .append { | ||||
|     right: auto; | ||||
|     left: 0; | ||||
|   } | ||||
|  | ||||
|   .table th, | ||||
|   .table td { | ||||
|     text-align: right; | ||||
|   } | ||||
|  | ||||
|   .filters .filter-subset { | ||||
|     margin-right: 0; | ||||
|     margin-left: 45px; | ||||
|   } | ||||
|  | ||||
|   .landing-page .header-wrapper .mascot { | ||||
|     right: 60px; | ||||
|     left: auto; | ||||
|   } | ||||
|  | ||||
|   .landing-page .header .hero .floats .float-1 { | ||||
|     left: -120px; | ||||
|     right: auto; | ||||
|   } | ||||
|  | ||||
|   .landing-page .header .hero .floats .float-2 { | ||||
|     left: 210px; | ||||
|     right: auto; | ||||
|   } | ||||
|  | ||||
|   .landing-page .header .hero .floats .float-3 { | ||||
|     left: 110px; | ||||
|     right: auto; | ||||
|   } | ||||
|  | ||||
|   .landing-page .header .links .brand img { | ||||
|     left: 0; | ||||
|   } | ||||
|  | ||||
|   .landing-page .fa-external-link { | ||||
|     padding-right: 5px; | ||||
|     padding-left: 0 !important; | ||||
|   } | ||||
|  | ||||
|   .landing-page .features #mastodon-timeline { | ||||
|     margin-right: 0; | ||||
|     margin-left: 30px; | ||||
|   } | ||||
|  | ||||
|   @media screen and (min-width: 631px) { | ||||
|     .column, | ||||
|     .drawer { | ||||
|       padding-left: 5px; | ||||
|       padding-right: 5px; | ||||
|  | ||||
|       &:first-child { | ||||
|         padding-left: 5px; | ||||
|         padding-right: 10px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .columns-area > div { | ||||
|       .column, | ||||
|       .drawer { | ||||
|         padding-left: 5px; | ||||
|         padding-right: 5px; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										339
									
								
								app/javascript/styles/mastodon/stream_entries.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										339
									
								
								app/javascript/styles/mastodon/stream_entries.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,339 @@ | ||||
| .activity-stream { | ||||
|   clear: both; | ||||
|   box-shadow: 0 0 15px rgba($base-shadow-color, 0.2); | ||||
|  | ||||
|   .entry { | ||||
|     background: $simple-background-color; | ||||
|  | ||||
|     .detailed-status.light, | ||||
|     .status.light { | ||||
|       border-bottom: 1px solid $ui-secondary-color; | ||||
|       animation: none; | ||||
|     } | ||||
|  | ||||
|     &:last-child { | ||||
|       &, | ||||
|       .detailed-status.light, | ||||
|       .status.light { | ||||
|         border-bottom: 0; | ||||
|         border-radius: 0 0 4px 4px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     &:first-child { | ||||
|       &, | ||||
|       .detailed-status.light, | ||||
|       .status.light { | ||||
|         border-radius: 4px 4px 0 0; | ||||
|       } | ||||
|  | ||||
|       &:last-child { | ||||
|         &, | ||||
|         .detailed-status.light, | ||||
|         .status.light { | ||||
|           border-radius: 4px; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     @media screen and (max-width: 740px) { | ||||
|       &, | ||||
|       .detailed-status.light, | ||||
|       .status.light { | ||||
|         border-radius: 0 !important; | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   &.with-header { | ||||
|     .entry { | ||||
|       &:first-child { | ||||
|         &, | ||||
|         .detailed-status.light, | ||||
|         .status.light { | ||||
|           border-radius: 0; | ||||
|         } | ||||
|  | ||||
|         &:last-child { | ||||
|           &, | ||||
|           .detailed-status.light, | ||||
|           .status.light { | ||||
|             border-radius: 0 0 4px 4px; | ||||
|           } | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .status.light { | ||||
|     padding: 14px 14px 14px (48px + 14px * 2); | ||||
|     position: relative; | ||||
|     min-height: 48px; | ||||
|     cursor: default; | ||||
|  | ||||
|     .status__header { | ||||
|       font-size: 15px; | ||||
|  | ||||
|       .status__meta { | ||||
|         float: right; | ||||
|         font-size: 14px; | ||||
|  | ||||
|         .status__relative-time { | ||||
|           color: $ui-primary-color; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .status__display-name { | ||||
|       display: block; | ||||
|       max-width: 100%; | ||||
|       padding-right: 25px; | ||||
|       color: $ui-base-color; | ||||
|     } | ||||
|  | ||||
|     .status__avatar { | ||||
|       position: absolute; | ||||
|       left: 14px; | ||||
|       top: 14px; | ||||
|       width: 48px; | ||||
|       height: 48px; | ||||
|  | ||||
|       & > div { | ||||
|         width: 48px; | ||||
|         height: 48px; | ||||
|       } | ||||
|  | ||||
|       img { | ||||
|         display: block; | ||||
|         border-radius: 4px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .display-name { | ||||
|       display: block; | ||||
|       max-width: 100%; | ||||
|       overflow: hidden; | ||||
|       white-space: nowrap; | ||||
|       text-overflow: ellipsis; | ||||
|  | ||||
|       strong { | ||||
|         font-weight: 500; | ||||
|         color: $ui-base-color; | ||||
|       } | ||||
|  | ||||
|       span { | ||||
|         font-size: 14px; | ||||
|         color: $ui-primary-color; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .status__content { | ||||
|       color: $ui-base-color; | ||||
|  | ||||
|       a { | ||||
|         color: $ui-highlight-color; | ||||
|       } | ||||
|  | ||||
|       a.status__content__spoiler-link { | ||||
|         color: $primary-text-color; | ||||
|         background: $ui-primary-color; | ||||
|  | ||||
|         &:hover { | ||||
|           background: lighten($ui-primary-color, 8%); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .detailed-status.light { | ||||
|     padding: 14px; | ||||
|     background: $simple-background-color; | ||||
|     cursor: default; | ||||
|  | ||||
|     .detailed-status__display-name { | ||||
|       display: block; | ||||
|       overflow: hidden; | ||||
|       margin-bottom: 15px; | ||||
|  | ||||
|       & > div { | ||||
|         float: left; | ||||
|         margin-right: 10px; | ||||
|       } | ||||
|  | ||||
|       .display-name { | ||||
|         display: block; | ||||
|         max-width: 100%; | ||||
|         overflow: hidden; | ||||
|         white-space: nowrap; | ||||
|         text-overflow: ellipsis; | ||||
|  | ||||
|         strong { | ||||
|           font-weight: 500; | ||||
|           color: $ui-base-color; | ||||
|         } | ||||
|  | ||||
|         span { | ||||
|           font-size: 14px; | ||||
|           color: $ui-primary-color; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .avatar { | ||||
|       width: 48px; | ||||
|       height: 48px; | ||||
|  | ||||
|       img { | ||||
|         display: block; | ||||
|         border-radius: 4px; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .status__content { | ||||
|       color: $ui-base-color; | ||||
|  | ||||
|       a { | ||||
|         color: $ui-highlight-color; | ||||
|       } | ||||
|  | ||||
|       a.status__content__spoiler-link { | ||||
|         color: $primary-text-color; | ||||
|         background: $ui-primary-color; | ||||
|  | ||||
|         &:hover { | ||||
|           background: lighten($ui-primary-color, 8%); | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .detailed-status__meta { | ||||
|       margin-top: 15px; | ||||
|       color: $ui-primary-color; | ||||
|       font-size: 14px; | ||||
|       line-height: 18px; | ||||
|  | ||||
|       a { | ||||
|         color: inherit; | ||||
|       } | ||||
|  | ||||
|       span > span { | ||||
|         font-weight: 500; | ||||
|         font-size: 12px; | ||||
|         margin-left: 6px; | ||||
|         display: inline-block; | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .status-card { | ||||
|       border-color: lighten($ui-secondary-color, 4%); | ||||
|       color: darken($ui-primary-color, 4%); | ||||
|  | ||||
|       &:hover { | ||||
|         background: lighten($ui-secondary-color, 4%); | ||||
|       } | ||||
|     } | ||||
|  | ||||
|     .status-card__title, | ||||
|     .status-card__description { | ||||
|       color: $ui-base-color; | ||||
|     } | ||||
|  | ||||
|     .status-card__image { | ||||
|       background: $ui-secondary-color; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .media-spoiler { | ||||
|     background: $ui-primary-color; | ||||
|     color: $white; | ||||
|     transition: all 100ms linear; | ||||
|  | ||||
|     &:hover, | ||||
|     &:active, | ||||
|     &:focus { | ||||
|       background: darken($ui-primary-color, 5%); | ||||
|       color: unset; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .pre-header { | ||||
|     padding: 14px 0; | ||||
|     padding-left: (48px + 14px * 2); | ||||
|     padding-bottom: 0; | ||||
|     margin-bottom: -4px; | ||||
|     color: $ui-primary-color; | ||||
|     font-size: 14px; | ||||
|     position: relative; | ||||
|  | ||||
|     .pre-header__icon { | ||||
|       position: absolute; | ||||
|       left: (48px + 14px * 2 - 30px); | ||||
|     } | ||||
|  | ||||
|     .status__display-name.muted strong { | ||||
|       color: $ui-primary-color; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   .open-in-web-link { | ||||
|     text-decoration: none; | ||||
|  | ||||
|     &:hover { | ||||
|       text-decoration: underline; | ||||
|     } | ||||
|   } | ||||
| } | ||||
|  | ||||
| .embed { | ||||
|   .activity-stream { | ||||
|     box-shadow: none; | ||||
|  | ||||
|     .entry { | ||||
|  | ||||
|       .detailed-status.light { | ||||
|         display: flex; | ||||
|         flex-wrap: wrap; | ||||
|         justify-content: space-between; | ||||
|         align-items: flex-start; | ||||
|  | ||||
|         .detailed-status__display-name { | ||||
|           flex: 1; | ||||
|           margin: 0 5px 15px 0; | ||||
|         } | ||||
|  | ||||
|         .button.button-secondary.logo-button { | ||||
|           flex: 0 auto; | ||||
|           font-size: 14px; | ||||
|  | ||||
|           svg { | ||||
|             width: 20px; | ||||
|             height: auto; | ||||
|             vertical-align: middle; | ||||
|             margin-right: 5px; | ||||
|  | ||||
|             path:first-child { | ||||
|               fill: $ui-primary-color; | ||||
|             } | ||||
|  | ||||
|             path:last-child { | ||||
|               fill: $simple-background-color; | ||||
|             } | ||||
|           } | ||||
|  | ||||
|           &:active, | ||||
|           &:focus, | ||||
|           &:hover { | ||||
|             svg path:first-child { | ||||
|               fill: lighten($ui-primary-color, 4%); | ||||
|             } | ||||
|           } | ||||
|         } | ||||
|  | ||||
|         .status__content, | ||||
|         .detailed-status__meta { | ||||
|           flex: 100%; | ||||
|         } | ||||
|       } | ||||
|     } | ||||
|   } | ||||
| } | ||||
							
								
								
									
										76
									
								
								app/javascript/styles/mastodon/tables.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										76
									
								
								app/javascript/styles/mastodon/tables.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,76 @@ | ||||
| .table { | ||||
|   width: 100%; | ||||
|   max-width: 100%; | ||||
|   border-spacing: 0; | ||||
|   border-collapse: collapse; | ||||
|  | ||||
|   th, | ||||
|   td { | ||||
|     padding: 8px; | ||||
|     line-height: 18px; | ||||
|     vertical-align: top; | ||||
|     border-top: 1px solid $ui-base-color; | ||||
|     text-align: left; | ||||
|   } | ||||
|  | ||||
|   & > thead > tr > th { | ||||
|     vertical-align: bottom; | ||||
|     border-bottom: 2px solid $ui-base-color; | ||||
|     border-top: 0; | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   & > tbody > tr > th { | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   & > tbody > tr:nth-child(odd) > td, | ||||
|   & > tbody > tr:nth-child(odd) > th { | ||||
|     background: $ui-base-color; | ||||
|   } | ||||
|  | ||||
|   a { | ||||
|     color: $ui-highlight-color; | ||||
|     text-decoration: underline; | ||||
|  | ||||
|     &:hover { | ||||
|       text-decoration: none; | ||||
|     } | ||||
|   } | ||||
|  | ||||
|   strong { | ||||
|     font-weight: 500; | ||||
|   } | ||||
|  | ||||
|   &.inline-table > tbody > tr:nth-child(odd) > td, | ||||
|   &.inline-table > tbody > tr:nth-child(odd) > th { | ||||
|     background: transparent; | ||||
|   } | ||||
| } | ||||
|  | ||||
| .table-wrapper { | ||||
|   overflow: auto; | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
|  | ||||
| samp { | ||||
|   font-family: 'mastodon-font-monospace', monospace; | ||||
| } | ||||
|  | ||||
| a.table-action-link { | ||||
|   text-decoration: none; | ||||
|   display: inline-block; | ||||
|   margin-right: 5px; | ||||
|   padding: 0 10px; | ||||
|   color: rgba($primary-text-color, 0.7); | ||||
|   font-weight: 500; | ||||
|  | ||||
|   &:hover { | ||||
|     color: $primary-text-color; | ||||
|   } | ||||
|  | ||||
|   i.fa { | ||||
|     font-weight: 400; | ||||
|     margin-right: 5px; | ||||
|   } | ||||
| } | ||||
							
								
								
									
										29
									
								
								app/javascript/styles/mastodon/variables.scss
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										29
									
								
								app/javascript/styles/mastodon/variables.scss
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,29 @@ | ||||
| // Commonly used web colors | ||||
| $black: #000000;            // Black | ||||
| $white: #ffffff;            // White | ||||
| $success-green: #79bd9a;    // Padua | ||||
| $error-red: #df405a;        // Cerise | ||||
| $warning-red: #ff5050;      // Sunset Orange | ||||
| $gold-star: #ca8f04;        // Dark Goldenrod | ||||
|  | ||||
| // Values from the classic Mastodon UI | ||||
| $classic-base-color: #282c37;         // Midnight Express | ||||
| $classic-primary-color: #9baec8;      // Echo Blue | ||||
| $classic-secondary-color: #d9e1e8;    // Pattens Blue | ||||
| $classic-highlight-color: #2b90d9;    // Summer Sky | ||||
|  | ||||
| // Variables for defaults in UI | ||||
| $base-shadow-color: $black !default; | ||||
| $base-overlay-background: $black !default; | ||||
| $base-border-color: $white !default; | ||||
| $simple-background-color: $white !default; | ||||
| $primary-text-color: $white !default; | ||||
| $valid-value-color: $success-green !default; | ||||
| $error-value-color: $error-red !default; | ||||
|  | ||||
| // Tell UI to use selected colors | ||||
| $ui-base-color: $classic-base-color !default;                  // Darkest | ||||
| $ui-base-lighter-color: lighten($ui-base-color, 26%) !default; // Lighter darkest | ||||
| $ui-primary-color: $classic-primary-color !default;            // Lighter | ||||
| $ui-secondary-color: $classic-secondary-color !default;        // Lightest | ||||
| $ui-highlight-color: $classic-highlight-color !default;        // Vibrant | ||||
		Reference in New Issue
	
	Block a user