discourse/app/assets/stylesheets/desktop/topic-post.scss

922 lines
16 KiB
SCSS
Raw Normal View History

2015-07-20 15:47:53 +08:00
.wrap {
max-width: $large-width;
2013-02-06 03:16:51 +08:00
}
.full-width {
margin-left: 0;
2013-02-06 03:16:51 +08:00
}
h1 .topic-statuses .topic-status i {
font-size: 0.857em;
vertical-align: middle;
}
.logo-small {
margin-right: 8px;
width: auto;
max-width: 80px;
height: auto;
max-height: 40px;
}
2013-02-06 03:16:51 +08:00
.topic-body {
padding: 0;
&:first-of-type {
border-top: none;
}
.reply-to-tab {
z-index: z("base") + 1;
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-medium, $secondary-medium);
}
.actions .fade-out {
.discourse-no-touch & {
opacity: 0.7;
transition: opacity 0.7s ease-in-out;
}
.discourse-touch & {
opacity: 1;
}
2013-02-06 03:16:51 +08:00
}
&:hover .actions .fade-out,
.selected .actions .fade-out {
opacity: 1;
2013-02-06 03:16:51 +08:00
}
}
section.post-menu-area {
position: relative;
2018-10-11 00:11:47 +08:00
padding-left: 11px;
}
2018-10-17 00:39:55 +08:00
.post-links-container {
margin-left: 11px;
}
nav.post-controls {
padding: 0;
.like-button {
display: inline-flex;
.like-count {
color: dark-light-choose($primary-low-mid, $secondary-high);
}
.widget-button {
background: none;
}
&:hover {
background: $primary-low;
.like-count {
color: $primary-medium;
&.d-hover {
color: $primary;
}
}
.d-hover {
background: none;
}
}
&:active {
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.4);
.widget-button {
box-shadow: none;
}
}
.like {
&:focus {
background: none;
}
}
.like-count {
font-size: $font-up-1;
margin-left: 0;
i.d-icon {
2018-04-25 01:39:03 +08:00
padding-left: 10px;
color: dark-light-choose($primary-low-mid, $secondary-high);
}
&.my-likes {
margin-right: -2px;
}
&.regular-likes {
margin-right: -12px;
}
}
.toggle-like {
padding: 8px 8px;
2018-04-03 00:17:50 +08:00
margin-left: 2px;
}
}
.highlight-action {
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-medium, $secondary-high);
}
a,
button {
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-low-mid, $secondary-high);
.d-icon {
opacity: 1;
}
margin-right: 2px;
display: inline-block;
}
a.toggle-likes {
padding: 8px 0;
margin-right: -3px;
2013-02-06 03:16:51 +08:00
}
span.badge-posts {
margin-right: 5px;
2014-12-23 19:09:17 +08:00
transition: all linear 0.15s;
2013-02-06 03:16:51 +08:00
}
.actions {
text-align: right;
float: right;
display: inline-block;
.more-actions {
display: none;
overflow: hidden;
}
}
.show-replies {
margin-left: -10px;
2015-06-30 07:25:53 +08:00
font-size: inherit;
span.badge-posts {
color: dark-light-choose($primary-medium, $secondary-high);
}
2014-03-23 05:39:47 +08:00
&:hover {
2017-06-12 10:20:14 +08:00
background: $primary-low;
span.badge-posts {
color: $primary;
}
2014-03-23 05:39:47 +08:00
}
i {
margin-left: 5px;
2018-01-13 06:27:38 +08:00
font-size: $font-down-1;
2013-02-06 03:16:51 +08:00
}
}
button.create {
margin-right: 0;
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-high, $secondary-low);
margin-left: 10px;
2013-02-06 03:16:51 +08:00
}
.create i {
margin-right: 5px;
2013-02-06 03:16:51 +08:00
}
button {
2018-01-13 06:27:38 +08:00
font-size: $font-up-1;
padding: 8px 10px;
vertical-align: top;
background: transparent;
border: none;
margin-left: 3px;
&.d-hover,
&:focus {
2017-06-12 10:20:14 +08:00
background: $primary-low;
color: $primary;
}
&:active {
box-shadow: inset 0 1px 3px rgba(0, 0, 0, 0.4);
}
&.hidden {
display: none;
}
&.admin {
position: relative;
}
&.delete.d-hover,
&.delete:focus {
background: $danger;
color: $secondary;
}
&.like.d-hover,
&.like:focus {
color: $love;
2017-06-12 10:20:14 +08:00
background: $love-low;
}
&.has-like {
color: $love;
}
&.has-like[disabled]:hover {
background: transparent;
}
&.has-like[disabled]:active {
box-shadow: none;
}
&.bookmark {
padding: 8px 11px;
&.bookmarked {
color: $tertiary;
}
}
}
2014-05-13 20:53:11 +08:00
.post-admin-menu {
display: inline-flex;
flex-direction: column;
box-sizing: border-box;
2014-05-13 20:53:11 +08:00
background-color: $secondary;
width: auto;
max-width: 320px;
2014-05-13 20:53:11 +08:00
padding: 10px;
2017-06-12 10:20:14 +08:00
border: 1px solid $primary-low;
2014-05-13 20:53:11 +08:00
position: absolute;
text-align: left;
bottom: -2px;
right: 15px;
z-index: z("dropdown");
2014-05-13 20:53:11 +08:00
h3 {
margin-top: 0;
color: $primary;
2018-01-13 06:27:38 +08:00
font-size: $font-0;
2014-05-13 20:53:11 +08:00
}
ul {
list-style: none;
margin: 10px 0 0 0;
}
li {
margin-bottom: 5px;
.d-icon {
2014-05-13 20:53:11 +08:00
width: 14px;
margin-right: 10px;
2014-05-13 20:53:11 +08:00
}
}
}
2014-04-30 10:13:16 +08:00
}
.embedded-posts {
h1,
h2,
h3 {
margin: 10px 0;
}
border: 1px solid $primary-low;
2014-07-10 23:40:31 +08:00
.topic-body {
box-sizing: border-box;
width: calc(100% - 70px); // [100% - .topic-avatar width]
// WARNING: overflow hide is required for quoted / embedded images
// which expect "normal" post width, but expansions are narrower
overflow: hidden;
} // this is covered by .topic-body .regular on a normal post
// but no such class structure exists for an embedded, expanded post
.cooked {
margin-top: 15px;
}
2014-07-10 23:40:31 +08:00
.topic-avatar {
padding-left: 25px;
padding-top: 15px;
2014-07-10 23:40:31 +08:00
}
.collapse-down,
.collapse-up {
2018-01-17 05:06:04 +08:00
position: absolute;
color: $primary-medium;
background: $secondary;
border: 1px solid $primary-low;
2018-01-17 05:06:04 +08:00
padding: 6px 9px 8px;
z-index: 99; // Needs to be higher than topic-avatar
&:hover {
background: $primary-low;
color: $primary;
}
} // bottom means "reply expansion" below a post
2014-04-30 10:13:16 +08:00
&.bottom {
border-top: none;
margin-bottom: 20px;
2018-10-17 00:39:55 +08:00
margin-left: 11px;
&.hidden {
display: block;
opacity: 0;
}
2013-02-06 03:16:51 +08:00
}
2014-07-10 23:40:31 +08:00
&.bottom {
.collapse-up {
2018-01-17 05:06:04 +08:00
transform: translate(-50%, -164%);
}
.row {
padding-bottom: 0.5em;
.topic-avatar,
.topic-body {
border-top: 1px solid $primary-low;
}
}
} // top means "in reply to expansion" above a post
&.top {
border-bottom: none;
.collapse-down {
transform: translate(-50%, 55%);
}
margin-left: 56px;
width: 699px;
.row {
border-bottom: none;
.topic-avatar,
.topic-body {
border-top: 1px solid $primary-low;
}
}
}
&.top.topic-body {
2016-01-27 09:03:18 +08:00
padding: 0;
}
.post-date {
color: dark-light-choose($primary-medium, $secondary-high);
}
.d-icon-arrow-up,
.d-icon-arrow-down {
margin-left: 5px;
}
.reply:first-of-type .row {
border-top: none;
}
2014-04-30 10:13:16 +08:00
.topic-meta-data {
position: relative;
}
.topic-meta-data h5 {
position: absolute;
z-index: z("base");
2018-01-13 06:27:38 +08:00
font-size: $font-down-1;
2014-04-30 10:13:16 +08:00
a {
font-weight: bold;
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-low-mid, $secondary-high);
2014-04-30 10:13:16 +08:00
}
}
.arrow {
color: dark-light-choose($primary-medium, $secondary-high);
}
2014-04-30 10:13:16 +08:00
}
2013-02-06 03:16:51 +08:00
.post-action {
.relative-date {
margin-left: 5px;
2013-02-06 03:16:51 +08:00
}
.avatar {
margin-right: 2px;
}
}
2013-09-04 23:53:00 +08:00
.topic-map {
2018-10-17 00:39:55 +08:00
margin: 20px 0 20px 11px;
.map {
.secondary {
text-align: center;
}
2013-02-06 03:16:51 +08:00
li {
float: left;
2014-07-23 04:30:32 +08:00
padding: 7px 10px;
2013-02-06 03:16:51 +08:00
&:last-of-type {
border-right: 0;
}
&:nth-child(3) {
text-align: center;
}
2013-02-06 03:16:51 +08:00
}
a,
.number {
2018-01-13 06:27:38 +08:00
line-height: $line-height-large;
2013-02-06 03:16:51 +08:00
}
.number,
i {
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-high, $secondary-low);
2018-01-13 06:27:38 +08:00
font-size: $font-up-2;
line-height: $line-height-medium;
2013-02-06 03:16:51 +08:00
}
.avatar a {
2013-02-06 03:16:51 +08:00
float: left;
}
2018-01-13 06:27:38 +08:00
.topic-map-post {
margin-top: 6px;
}
2013-02-06 03:16:51 +08:00
}
.avatars,
.links,
.information {
padding: 7px 10px 7px 10px;
color: $primary;
2013-02-06 03:16:51 +08:00
}
.buttons {
float: right;
.btn {
border: 0;
padding: 0 23px;
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-medium, $secondary-high);
background: blend-primary-secondary(5%);
2017-06-12 10:20:14 +08:00
border-left: 1px solid $primary-low;
2018-01-13 06:27:38 +08:00
border-top: 1px solid transparent;
2013-02-06 03:16:51 +08:00
&:hover {
color: $primary;
2017-06-12 10:20:14 +08:00
background: $primary-low;
2013-02-06 03:16:51 +08:00
}
&.collapsed {
padding-bottom: 1px;
2013-02-06 03:16:51 +08:00
}
2013-12-10 05:27:49 +08:00
.fa {
2013-02-06 03:16:51 +08:00
margin: 0;
2018-01-13 06:27:38 +08:00
font-size: $font-up-2;
2013-02-06 03:16:51 +08:00
line-height: 52px;
}
}
}
.link-summary .btn {
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-medium, $secondary-high);
background: blend-primary-secondary(5%);
width: 100%;
&:hover {
color: $primary;
background: dark-light-diff($primary, $secondary, 90%, -80%);
}
}
2013-02-06 03:16:51 +08:00
}
2017-08-16 01:17:15 +08:00
@mixin topic-footer-button {
margin-bottom: 5px;
margin-right: 10px;
}
#topic-footer-buttons {
padding: 10px 10px 0 0;
float: left;
p {
2018-01-13 06:27:38 +08:00
color: dark-light-choose($primary-medium, $secondary-medium);
}
.btn {
2017-08-16 01:17:15 +08:00
@include topic-footer-button;
.d-icon-bookmark.bookmarked {
color: $tertiary;
}
}
.bookmark.bookmarked .d-icon-bookmark {
color: $tertiary;
}
2017-08-16 01:17:15 +08:00
}
#topic-footer-button {
width: 757px;
}
#suggested-topics {
clear: left;
padding: 20px 0 15px 0;
table {
margin-top: 10px;
} // this forces category to take less space in suggested topics
// as the poster list is not present at all there.
th.category {
width: 150px;
}
}
#suggested-topics .topic-statuses .topic-status {
padding: 0;
i {
font-size: 1em;
}
}
span.post-count {
background: $primary;
color: $secondary;
opacity: 0.8;
}
2014-04-03 03:54:21 +08:00
button.expand-post {
margin-top: 10px;
}
.quote-button.visible {
display: block;
}
iframe {
max-width: 100%;
}
2014-12-09 04:39:36 +08:00
video {
max-height: 500px;
}
2014-12-25 18:19:06 +08:00
@-webkit-keyframes fadein {
from {
opacity: 0;
}
to {
opacity: 1;
}
2014-12-25 18:19:06 +08:00
}
@keyframes fadein {
from {
opacity: 0;
}
to {
opacity: 1;
}
}
.extra-info-wrapper {
overflow: hidden;
.badge-wrapper,
i,
.topic-link {
-webkit-animation: fadein 0.7s;
animation: fadein 0.7s;
2015-01-30 01:08:24 +08:00
}
.topic-statuses {
i {
color: $header_primary;
}
.d-icon-envelope {
color: $danger;
}
.d-icon-lock {
padding-top: 0.15em;
}
.unpinned {
color: $header_primary;
}
}
.topic-link {
color: $header_primary;
display: block;
white-space: nowrap;
overflow: hidden;
text-overflow: ellipsis;
}
.topic-header-extra {
margin: 0 0 0 5px;
}
}
2014-10-07 06:32:38 +08:00
/* default docked header CSS for all topics, including those without categories */
.extra-info {
h1 {
margin: 5px 0 0 0;
2018-01-13 06:27:38 +08:00
font-size: $font-up-3;
line-height: $line-height-large;
width: 100%;
}
.topic-statuses {
margin-top: -2px;
}
}
2013-02-06 03:16:51 +08:00
2014-10-07 06:32:38 +08:00
/* override docked header CSS for topics with categories */
.extra-info.two-rows {
2014-10-07 06:32:38 +08:00
h1 {
2018-01-13 06:27:38 +08:00
line-height: $line-height-medium;
margin: 0;
2018-02-03 08:33:00 +08:00
width: 100%;
2014-10-07 06:32:38 +08:00
}
}
2018-06-19 02:10:48 +08:00
.open > .dropdown-menu {
display: block;
}
.btn-group {
2013-02-06 03:16:51 +08:00
position: relative;
}
.dropdown-toggle {
float: left;
position: relative;
}
2014-05-07 11:53:04 +08:00
.deleted {
.topic-body {
2018-06-19 02:10:48 +08:00
background-color: dark-light-diff(
rgba($danger, 0.7),
$secondary,
50%,
-60%
);
}
}
#share-link {
width: 365px;
margin-left: -4px;
}
.post-select {
float: right;
margin-right: 20px;
margin-top: -20px;
}
.deleted-user-avatar {
2018-01-13 06:27:38 +08:00
font-size: $font-up-6;
}
.info-line {
margin: 10px 0;
color: $primary;
}
2014-06-30 15:58:27 +08:00
/* solo quotes */
2014-06-30 15:58:27 +08:00
blockquote {
2014-06-30 18:03:54 +08:00
/* leave browser defaults for top and bottom here */
margin-left: 0;
margin-right: 0;
padding: 12px;
}
2014-06-30 15:58:27 +08:00
/* quotes with attribution */
2014-06-30 15:58:27 +08:00
.quote {
2018-06-19 02:10:48 +08:00
& > blockquote {
.onebox-result {
2018-08-04 05:43:07 +08:00
background-color: $primary-very-low;
}
}
aside {
.quote,
.title,
blockquote,
.onebox,
.onebox-result {
2018-08-04 05:43:07 +08:00
background: $primary-very-low;
2017-06-12 10:20:14 +08:00
border-left: 5px solid $primary-low;
}
2018-06-19 02:10:48 +08:00
aside.quote > blockquote,
aside.quote > .title {
border-left: 0;
}
}
}
// variables are used to calculate the width of .gap
$topic-body-width: 690px;
$topic-body-width-padding: 11px;
$topic-avatar-width: 45px;
.topic-body {
2018-10-08 23:55:54 +08:00
width: calc(#{$topic-body-width} + (#{$topic-body-width-padding} * 2));
float: left;
position: relative;
z-index: z("base");
2017-06-12 10:20:14 +08:00
border-top: 1px solid $primary-low;
padding: 12px 0 0 0;
.topic-meta-data,
.cooked {
padding: 0 $topic-body-width-padding 0.25em $topic-body-width-padding;
}
}
.topic-avatar {
2017-06-12 10:20:14 +08:00
border-top: 1px solid $primary-low;
padding-top: 15px;
width: $topic-avatar-width;
float: left;
z-index: z("base") + 1;
}
2015-06-29 16:14:54 +08:00
.gap {
2018-06-19 02:10:48 +08:00
width: calc(
#{$topic-avatar-width} + #{$topic-body-width} + 2 * #{$topic-body-width-padding}
);
2015-06-29 16:14:54 +08:00
}
/* hide the reply border above the time gap notices */
2018-06-19 02:10:48 +08:00
.time-gap + .topic-post .topic-body,
.time-gap + .topic-post .topic-avatar {
border-top: none;
}
2018-06-19 02:10:48 +08:00
.time-gap + .topic-post .embedded-posts.top {
border-bottom: 1px solid $primary-low;
2018-03-30 05:32:56 +08:00
}
2013-10-22 04:54:53 +08:00
.posts-wrapper {
position: relative;
-webkit-font-smoothing: subpixel-antialiased;
}
.dropdown {
position: relative;
}
.caret {
display: inline-block;
width: 0;
height: 0;
vertical-align: middle;
border-top: 4px solid $primary;
border-right: 4px solid transparent;
border-left: 4px solid transparent;
content: "";
margin-left: 5px;
}
.dropdown-menu {
position: absolute;
bottom: 115%;
left: 0;
z-index: z("dropdown");
display: none;
float: left;
width: 550px;
margin: 1px 0 0;
list-style: none;
background-color: $secondary;
2017-06-12 10:20:14 +08:00
border: 1px solid $primary-low;
box-shadow: shadow("dropdown");
background-clip: padding-box;
span {
2018-01-13 06:27:38 +08:00
font-size: $font-down-1;
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-medium, $secondary-medium);
}
span.title {
font-weight: bold;
display: block;
2018-01-13 06:27:38 +08:00
font-size: $font-0;
color: $primary;
}
}
.dropdown-menu a {
display: block;
2014-06-28 07:42:43 +08:00
padding: 9px;
clear: both;
font-weight: normal;
2018-01-13 06:27:38 +08:00
line-height: $line-height-medium;
color: $primary;
transition: all linear 0.15s;
2018-06-19 02:10:48 +08:00
& > div {
margin-left: 26px;
}
}
2018-06-19 02:10:48 +08:00
.dropdown-menu li > a:hover,
.dropdown-menu .active > a,
.dropdown-menu .active > a:hover {
2014-06-28 07:42:43 +08:00
color: $primary;
text-decoration: none;
2017-06-12 10:20:14 +08:00
background-color: $highlight-medium;
}
2018-06-19 02:10:48 +08:00
.dropdown-menu .disabled > a,
.dropdown-menu .disabled > a:hover {
text-decoration: none;
color: $primary;
2017-06-12 10:20:14 +08:00
background-color: $tertiary-low;
cursor: default;
}
.dropdown-menu .icon {
margin-top: 3px;
float: left;
2018-01-13 06:27:38 +08:00
font-size: $font-up-2;
}
2018-06-19 02:10:48 +08:00
.open > .dropdown-menu {
display: block;
clear: both;
}
.selected-posts {
width: 200px;
position: fixed;
z-index: z("dropdown");
2018-07-21 04:37:43 +08:00
box-shadow: shadow("card");
padding: 0.714em;
margin-bottom: 5px;
right: 10px;
2018-07-13 04:38:51 +08:00
@include breakpoint(extra-large, min-width) {
right: auto;
margin-left: 330px;
left: 50%;
}
button {
2018-07-21 04:37:43 +08:00
width: 100%;
margin: 4px auto;
display: inline-block;
text-align: left;
}
&.hidden {
display: none;
}
.controls {
margin-top: 10px;
}
p {
2018-01-13 06:27:38 +08:00
font-size: $font-down-1;
margin: 0 0 10px 0;
}
p.cancel {
margin: 10px 0 0 0;
}
h3 {
2018-01-13 06:27:38 +08:00
font-size: $font-up-4;
color: $primary;
margin-bottom: 5px;
i {
margin-right: 7px;
}
}
}
2013-10-23 15:52:15 +08:00
a.attachment:before {
display: inline-block;
margin-right: 4px;
font-family: "FontAwesome";
content: "\f019";
}
.private_message .gutter,
.deleted-topic .gutter,
.read_restricted .gutter {
position: relative;
}
.deleted-topic .gutter:before {
display: block;
position: absolute;
left: 767px;
color: rgba($primary-low, 0.8);
font: 6.429em/1 FontAwesome;
content: "\f014";
z-index: z("base");
}
2013-10-30 21:11:05 +08:00
.topic-meta-data {
align-items: center;
.names {
display: flex;
align-items: center;
}
&:after {
visibility: hidden;
display: block;
font-size: 0;
content: " ";
clear: both;
height: 0;
}
.post-info {
a {
color: dark-light-choose($primary-medium, $secondary-medium);
}
a.wiki {
color: $wiki;
}
}
}
2015-07-10 12:48:44 +08:00
.who-liked {
margin-top: 20px;
margin-bottom: 0;
2015-07-10 12:48:44 +08:00
width: 100%;
text-align: right;
}
span.highlighted {
2017-06-12 10:20:14 +08:00
background-color: $tertiary-low;
2014-05-14 16:05:24 +08:00
}
.username.new-user a {
2017-10-11 04:07:46 +08:00
color: dark-light-choose($primary-low-mid, $secondary-high);
2014-05-14 16:05:24 +08:00
}
.read-state {
2014-06-03 10:32:33 +08:00
position: absolute;
2018-09-06 01:19:36 +08:00
// We use absolute positioning here because we want it to display in the padding
align-self: center;
color: $tertiary-medium;
right: 0;
font-size: 0.571em;
}
.read-state.read {
opacity: 0;
2014-12-23 19:09:17 +08:00
transition: opacity ease-out 1s;
}
2015-09-02 07:49:45 +08:00
.signup-cta {
width: $topic-body-width;
}
/* Tablet (portrait) ----------- */
@media all and (max-width: 775px) {
.gutter {
display: none;
}
2014-07-10 23:40:31 +08:00
.topic-avatar {
width: 45px;
2014-07-10 23:40:31 +08:00
}
.topic-post .reply-to-tab {
right: 15%;
}
2014-07-10 23:40:31 +08:00
.topic-body {
box-sizing: border-box;
width: calc(100% - 47px); //100% - [width of .topic-avatar + 2px]
}
2014-07-10 23:40:31 +08:00
.embedded-posts {
// top means "in reply to expansion" above a post
&.top {
width: calc(100% - 56px); // [100% - margin-left]
2014-07-10 23:40:31 +08:00
}
}
}