From 1fd125f2840e980c2641b371ae6b9288194d15a5 Mon Sep 17 00:00:00 2001 From: sairaj mote Date: Sun, 30 Jan 2022 22:16:26 +0530 Subject: [PATCH] Adding article section traversal --- css/main.css | 128 +++++++++++++++++++++++---------- css/main.min.css | 2 +- css/main.scss | 125 +++++++++++++++++++++----------- index.html | 183 ++++++++++++++++++++++++++++++++++------------- 4 files changed, 306 insertions(+), 132 deletions(-) diff --git a/css/main.css b/css/main.css index 45e85da..276eea7 100644 --- a/css/main.css +++ b/css/main.css @@ -219,6 +219,10 @@ ul { display: flex; } +.flex-wrap { + flex-wrap: wrap; +} + .grid { display: grid; } @@ -448,6 +452,7 @@ details summary { -ms-user-select: none; user-select: none; cursor: pointer; + padding: 0.5rem 0; } details[open] > summary .down-arrow { transform: rotate(180deg); @@ -563,7 +568,8 @@ sm-copy { fill: var(--danger-color); } -main { +#main { + overflow-y: hidden; display: grid; height: 100%; grid-template-rows: auto 1fr; @@ -742,15 +748,41 @@ theme-toggle { } #article { - gap: 2rem 0; + display: flex; + padding: 1.5rem; + max-height: 100%; + overflow-y: auto; +} +#article main > section:last-of-type { padding-bottom: 6rem; } +#article_aside { + position: absolute; + left: 0; + top: 5rem; + padding: 1.5rem; +} + +#article_map_container { + margin-top: 1.5rem; + display: grid; + gap: 0.5rem; +} +#article_map_container button { + line-height: 1.3; + width: 100%; + padding: 0.5rem 0; + text-align: left; + font-weight: 500; + font-size: 0.9rem; + color: rgba(var(--text-color), 0.8); +} + .hero-section { display: grid; gap: 0.5rem; grid-template-columns: minmax(0, 1fr); - padding-top: 1.5rem; } #article_contributors { @@ -767,24 +799,19 @@ theme-toggle { padding: 0.3rem 0.5rem; } -#like_panel { +#action_panel { position: fixed; bottom: 0; - width: 100%; - padding: 1.5rem; - text-align: center; - justify-items: flex-start; + left: 0; + gap: 0.5rem; + align-items: center; } .up-vote { display: grid; - grid-template-columns: auto 1fr; position: relative; - padding: 0.8rem; - border-radius: 2rem; - background-color: var(--foreground-color); - box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1); - border: solid rgba(var(--text-color), 0.2) thin; + padding: 0.5rem; + border-radius: 0.3rem; } .up-vote > * { pointer-events: none; @@ -795,13 +822,6 @@ theme-toggle { .up-vote:active .icon { transform: scale(0.7); } -.up-vote.liked { - background-color: var(--like-color); - color: #fff; -} -.up-vote.liked .icon { - fill: #fff; -} .up-vote .expanding-heart, .up-vote .ring { grid-area: 1/1; @@ -809,8 +829,6 @@ theme-toggle { .up-vote .icon { grid-area: 1/1; fill: var(--like-color); - height: 1.5rem; - width: 1.5rem; transition: transform 0.2s; } @@ -866,7 +884,7 @@ theme-toggle { gap: 0.5rem; border-radius: 0.5rem; align-items: flex-start; - grid-template-columns: 1fr auto; + grid-template-columns: minmax(0, 1fr); } .request-card__title { grid-area: 2/1; @@ -876,6 +894,7 @@ theme-toggle { } .request-card .flex { grid-row: span 2; + margin-top: 0.5rem; } .request-card .publish-button { text-transform: uppercase; @@ -1018,6 +1037,17 @@ theme-toggle { width: 2.5rem; } + #action_panel { + width: -webkit-min-content; + width: -moz-min-content; + width: min-content; + padding: 0.5rem; + border-radius: 0.5rem; + background-color: var(--foreground-color); + margin: 1.5rem; + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); + } + .hide-on-mobile { display: none; } @@ -1098,7 +1128,41 @@ theme-toggle { } #article { - grid-template-columns: 1fr 60ch 1fr; + gap: 6vw; + padding: 0; + grid-template-columns: 16rem 1fr; + } + #article main { + width: 60ch; + padding: 1.5rem 0; + } + + #article_aside { + width: 20rem; + padding: 1.5rem 2rem; + display: flex; + flex-direction: column; + position: -webkit-sticky; + position: sticky; + top: 0; + height: 100%; + overflow-y: auto; + } + + #article_map_container { + margin-bottom: 3rem; + } + + #action_panel { + position: relative; + margin-top: auto; + } + + .request-card { + grid-template-columns: 1fr auto; + } + .request-card .flex { + margin-top: 0; } #preview_popup { @@ -1122,20 +1186,6 @@ theme-toggle { display: none; } } -@media screen and (min-width: 64rem) { - #like_panel { - margin: 1.5rem; - width: 18vw; - border-radius: 0.8rem; - border: solid thin rgba(var(--text-color), 0.2); - justify-content: flex-start; - justify-items: flex-start; - text-align: left; - } - #like_panel .up-vote { - box-shadow: none; - } -} @media (any-hover: hover) { ::-webkit-scrollbar { width: 0.5rem; diff --git a/css/main.min.css b/css/main.min.css index 02f6088..5b7cff2 100644 --- a/css/main.min.css +++ b/css/main.min.css @@ -1 +1 @@ -*{padding:0;margin:0;box-sizing:border-box;font-family:"Inter",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%;scroll-behavior:smooth}body{color:rgba(var(--text-color), 1);background:rgba(var(--background-color), 1)}body,body *{--accent-color: #256eff;--text-color: 36, 36, 36;--background-color: 248, 248, 248;--foreground-color: rgb(255, 255, 255);--danger-color: rgb(255, 75, 75);--green: #1cad59;--like-color: #e91e63;scrollbar-width:thin}body[data-theme=dark],body[data-theme=dark] *{--accent-color: #86afff;--text-color: 220, 220, 220;--background-color: 10, 10, 10;--foreground-color: rgb(24, 24, 24);--danger-color: rgb(255, 106, 106);--green: #00e676}body[data-theme=dark] sm-popup::part(popup){background-color:var(--foreground-color)}body[data-theme=dark] ::-webkit-calendar-picker-indicator{filter:invert(1)}p,strong{font-size:.9rem;max-width:70ch;line-height:1.7;color:rgba(var(--text-color), 0.8)}p:not(:last-of-type),strong:not(:last-of-type){margin-bottom:1.5rem}a{text-decoration:none}a:not([class]){color:var(--accent-color)}a:not([class]):focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}input[type=datetime-local]{width:100%;padding:.6rem .8rem;background-color:rgba(var(--text-color), 0.06);border:none;border-radius:.3rem;font-size:.9rem;color:inherit;font-family:inherit}input[type=datetime-local]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}button,.button{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:transparent;overflow:hidden;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;font-size:.9rem;font-weight:500}.button{white-space:nowrap;padding:.6rem .8rem;border-radius:.3rem;background-color:rgba(var(--text-color), 0.06);color:rgba(var(--text-color), 0.8);justify-content:center}.button--primary{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}.icon-only{padding:.5rem;border-radius:.3rem}button:disabled{opacity:.5}a:-webkit-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:-moz-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}sm-input,sm-textarea,tags-input{font-size:.9rem;--border-radius: 0.3rem}sm-button{--padding: 0.6rem 0.8rem}sm-button[variant=primary] .icon{fill:rgba(var(--background-color), 1)}sm-button[disabled] .icon{fill:rgba(var(--text-color), 0.6)}sm-button.uppercase{letter-spacing:.05em}sm-button.danger{--background: var(--danger-color);color:rgba(var(--background-color), 1)}ul{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.breakable{overflow-wrap:break-word;word-wrap:break-word;-ms-word-break:break-all;word-break:break-word;-ms-hyphens:auto;-webkit-hyphens:auto;hyphens:auto}.full-bleed{grid-column:1/-1}.h1{font-size:1.5rem}.h2{font-size:1.2rem}.h3{font-size:1rem}.h4{font-size:.9rem}.h5{font-size:.8rem}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.flex{display:flex}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-items:flex-start}.align-center{align-items:center}.text-center{text-align:center}.justify-start{justify-content:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.align-self-center{align-self:center}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none}.observe-empty-state:not(:empty)+.empty-state{display:none}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:currentColor}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.button__icon{height:1.2rem;width:1.2rem}.button__icon--left{margin-right:.5rem}.button__icon--right{margin-left:.5rem}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{font-weight:500;margin-bottom:.5rem}#confirmation_popup sm-button,#prompt_popup sm-button{margin:0}#confirmation_popup .flex,#prompt_popup .flex{padding:0;margin-top:1rem}#confirmation_popup .flex sm-button:first-of-type,#prompt_popup .flex sm-button:first-of-type{margin-right:.6rem;margin-left:auto}#prompt_message{margin-bottom:1.5rem}.popup__header{display:grid;gap:.5rem;width:100%;padding:0 1.5rem 0 .8rem;align-items:center;grid-template-columns:auto 1fr auto}.popup__header__close{padding:.5rem;cursor:pointer}.logo{position:absolute;color:inherit;display:grid;align-items:center;grid-template-columns:auto 1fr;gap:0 .2rem;justify-self:center}.logo h4{text-transform:capitalize;font-size:.9rem;letter-spacing:.03em}.logo .main-logo{height:1.4rem;width:1.4rem;fill:rgba(var(--text-color), 1);stroke:none}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-select,sm-option,strip-option{font-size:.9rem}sm-select{--max-height: 12rem}strip-select{--gap: 0}strip-option{font-weight:500;--border-radius: 0.3rem;--active-option-color: var(--accent-color)}sm-menu{--background: var(--foreground-color)}menu-option{font-size:.9rem}sm-copy{font-size:.9rem;--button-border-radius: 0.2rem}.warning{background-color:khaki;color:rgba(0,0,0,.7);padding:1rem;border-radius:.5rem;line-height:1.5}.page{height:100%}.page-layout,#preview_page{display:grid;grid-template-columns:1.5rem minmax(0, 1fr) 1.5rem}.page-layout>*,#preview_page>*{grid-column:2/3}#loading{display:grid;place-content:center;text-align:center}#loader_container{position:relative;height:3rem;overflow:hidden;margin-bottom:1.5rem}#loader_container::after{content:"";position:absolute;height:100%;width:100%;left:0;background:linear-gradient(rgba(var(--foreground-color), 1), transparent 20%, transparent 80%, rgba(var(--foreground-color), 1))}#loader{height:6rem;width:6rem;-webkit-animation:scroll infinite 1s cubic-bezier(0.075, 0.82, 0.165, 1);animation:scroll infinite 1s cubic-bezier(0.075, 0.82, 0.165, 1);fill:rgba(var(--text-color), 0.2)}@-webkit-keyframes scroll{to{transform:translateY(-3rem)}}@keyframes scroll{to{transform:translateY(-3rem)}}.label{font-size:.8rem;color:rgba(var(--text-color), 0.8);margin-bottom:.2rem}.icon--success{fill:var(--green)}.icon--failure,.icon--error{fill:var(--danger-color)}main{display:grid;height:100%;grid-template-rows:auto 1fr;grid-template-columns:minmax(0, 1fr)}#main_header{display:grid;gap:.5rem;padding:1rem;align-items:center;grid-column:1/-1;grid-template-columns:auto 1fr auto auto;background-color:rgba(var(--background-color), 1);z-index:2;border-bottom:thin solid rgba(var(--text-color), 0.1)}#expanding_search{position:absolute;display:grid;gap:.5rem;align-items:center;width:calc(100% - 2rem);z-index:1;background-color:rgba(var(--background-color), 1)}#expanding_search .icon-only{margin-right:.5rem}#search_suggestions{position:absolute;top:calc(100% + .5rem);background-color:var(--foreground-color);padding:.3rem;width:100%;border-radius:.3rem;box-shadow:0 .5rem 1.5rem rgba(0,0,0,.1)}.search-suggestion{font-size:.9rem;color:inherit;padding:1rem;border-radius:.3rem}#search_articles{--border-radius: 0.5em;width:100%}theme-toggle{margin-left:auto;padding:0 .5rem}#main_page{align-content:flex-start;display:grid;padding:1.5rem;gap:1.5rem;grid-template-columns:minmax(0, 1fr)}#news_categories_list{overflow-x:auto;gap:.5rem}.category{display:flex;flex-direction:column;padding:.8rem .5rem;color:inherit;font-size:.8rem;white-space:nowrap;flex-shrink:0;align-items:center;border-radius:.5rem;min-width:4rem;background-color:rgba(var(--text-color), 0.02)}.category .icon{transition:transform .3s}.category:hover .icon{transform:scale(1.3);fill:var(--accent-color)}.category span{margin-top:.5rem}#query_results_list,#written_article_list{margin:1rem 0;padding-bottom:2rem;gap:1.6rem}.article-card{gap:.3rem}.article-card a{color:inherit}.article-card .article-link{gap:.5rem}.article-card__title{line-height:1.4}.article-card__category{background-color:rgba(var(--text-color), 0.1);border-radius:.3rem;font-size:.8rem;padding:.3rem .6rem;font-weight:700;color:rgba(var(--text-color), 0.6) !important;justify-self:flex-start;text-transform:capitalize}.article-card .flex{font-size:.8rem}#trending_article_container{counter-reset:trending;margin-bottom:1.5rem}.trending-article{counter-increment:trending;grid-template-columns:auto 1fr;gap:.5rem 1.5rem}.trending-article::before{content:counter(trending);grid-column:1/2;grid-row:1/3;font-size:2.5em;font-weight:700;opacity:.3}#explore{padding-top:1.5rem}#writer{align-items:flex-start;align-content:flex-start;padding:1.5rem;gap:3rem}#writer sm-copy{font-size:.8rem}#writer_profile{display:flex;width:4rem;height:4rem;border-radius:2rem;background-color:var(--accent-color);justify-content:center}#writer_profile #writer_initials{align-self:center;font-weight:700;font-size:1.8rem;color:rgba(var(--background-color), 1);text-transform:uppercase}#article{gap:2rem 0;padding-bottom:6rem}.hero-section{display:grid;gap:.5rem;grid-template-columns:minmax(0, 1fr);padding-top:1.5rem}#article_contributors{flex-wrap:wrap;gap:.3rem;margin:.5rem 0 1rem 0}.contributor{color:inherit;font-size:.8rem;background-color:rgba(var(--text-color), 0.06);border-radius:.3rem;padding:.3rem .5rem}#like_panel{position:fixed;bottom:0;width:100%;padding:1.5rem;text-align:center;justify-items:flex-start}.up-vote{display:grid;grid-template-columns:auto 1fr;position:relative;padding:.8rem;border-radius:2rem;background-color:var(--foreground-color);box-shadow:0 .5rem 1rem rgba(0,0,0,.1);border:solid rgba(var(--text-color), 0.2) thin}.up-vote>*{pointer-events:none}.up-vote:active{transform:none}.up-vote:active .icon{transform:scale(0.7)}.up-vote.liked{background-color:var(--like-color);color:#fff}.up-vote.liked .icon{fill:#fff}.up-vote .expanding-heart,.up-vote .ring{grid-area:1/1}.up-vote .icon{grid-area:1/1;fill:var(--like-color);height:1.5rem;width:1.5rem;transition:transform .2s}.ring{border:.1rem solid var(--like-color);border-radius:50%;height:.5rem;width:.5rem;justify-self:center}.temp-count,#like_count{grid-area:1/2}.temp-count:not(:empty),#like_count:not(:empty){margin-left:.4rem}.floating-button{position:fixed;z-index:2;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);border-radius:2rem;bottom:0;right:0;margin:1.5rem;padding:1rem}#go_to_top{background-color:var(--foreground-color)}#dashboard{height:-webkit-max-content;height:-moz-max-content;height:max-content;padding:1.5rem 0;grid-template-rows:auto 1fr}#publishing_requests,#article_analytics{margin-top:2rem;align-content:flex-start}.request-card{display:grid;gap:.5rem;border-radius:.5rem;align-items:flex-start;grid-template-columns:1fr auto}.request-card__title{grid-area:2/1}.request-card__time{font-size:.8rem}.request-card .flex{grid-row:span 2}.request-card .publish-button{text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.article-row{align-items:center;gap:1rem;grid-template-columns:1fr auto auto}.article-row__published{font-size:.8rem}#preview_popup h1,#article h1{font-size:1.6rem;line-height:1.3}#preview_popup h3:not(:first-of-type),#article h3:not(:first-of-type){margin-top:2rem}#preview_popup h3,#article h3{margin-bottom:1rem}#preview_popup h3:not(:first-of-type),#article h3:not(:first-of-type){margin-top:1.5rem}#preview_popup p,#article p{font-family:"noto serif",serif;font-size:1rem;line-height:1.8}#preview_popup p>*,#article p>*{font-family:inherit}#preview_popup time,#preview_popup #reading_time,#article time,#article #reading_time{font-size:.8rem}#add_writer_button{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}#add_writer_button .icon{fill:rgba(var(--background-color), 1)}#writers_list{margin:1.5rem 0;grid-template-columns:repeat(auto-fill, minmax(20rem, 1fr));padding-bottom:3rem}.writer-card{display:grid;gap:1rem;padding:1rem;border-radius:.5rem;background-color:var(--foreground-color)}.writer-card .writer-profile{display:flex;align-items:center;justify-content:center;height:3rem;width:3rem;border-radius:2rem;background-color:var(--accent-color);text-align:center;font-size:100%;font-weight:700;text-transform:uppercase;color:var(--foreground-color)}.writer-card sm-copy{margin-top:-0.5rem;font-size:.8rem}#user_popup{overflow:hidden}#user_popup header{overflow:hidden;width:100%;position:relative;padding:1.5rem;color:#dcdcdc}#user_popup header h2{margin-top:2rem}#user_popup header .popup__header__close{margin-left:-0.5rem;background-color:rgba(0,0,0,.2);border-radius:2rem}#user_popup header .popup__header__close .icon{fill:#fff}#user_background{position:absolute;top:-1px;left:0;right:0;z-index:-1;transform:scale(-1);border-radius:0 0 .5rem .5rem}.hide{display:none !important}@media screen and (max-width: 40rem){button,.button{padding:.8rem}sm-button{--padding: 0.8rem}.writer-card .writer-profile{height:2.5rem;width:2.5rem}.hide-on-mobile{display:none}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}h1,.h1{font-size:2rem}.h2{font-size:1.8rem}.h3{font-size:1.3rem}.h4{font-size:1rem}.popup__header{grid-column:1/-1;padding:1rem 1.5rem 0 .8rem}#confirmation_popup{--width: 24rem}.page-layout{grid-template-columns:1fr 80vw 1fr}.hide-on-desktop{display:none}#main_header{padding:1rem 1.5rem}#main_page{padding:1rem 8vw;grid-template-rows:auto 1fr;grid-template-columns:2fr 1fr}#main_page__header{grid-area:1/1/2/-1}#expanding_search{margin:1rem 1.5rem;left:0;width:20rem}#writer{gap:1.5rem 6vw;padding:2rem 8vw;grid-template-columns:20rem 1fr}#writer>section:first-of-type{position:-webkit-sticky;position:sticky;top:1.5rem}#preview_popup h1,#article h1{font-size:2rem}#article{grid-template-columns:1fr 60ch 1fr}#preview_popup{--width: 60ch}#edit_article_meta_popup{--width: 48rem}#edit_article_meta_popup>section{grid-template-columns:1fr 1.5fr;align-items:flex-start}#user_popup{--width: 25rem}}@media screen and (max-width: 64rem){.hide-on-medium{display:none}}@media screen and (min-width: 64rem){#like_panel{margin:1.5rem;width:18vw;border-radius:.8rem;border:solid thin rgba(var(--text-color), 0.2);justify-content:flex-start;justify-items:flex-start;text-align:left}#like_panel .up-vote{box-shadow:none}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.interact,button:not(.button--primary){transition:background-color .3s}.interact:hover,button:not(.button--primary):hover{background-color:rgba(var(--text-color), 0.06)}.button--primary{transition:filter .3s}.button--primary:hover{filter:brightness(120%)}} \ No newline at end of file +*{padding:0;margin:0;box-sizing:border-box;font-family:"Inter",sans-serif}:root{font-size:clamp(1rem,1.2vmax,1.2rem)}html,body{height:100%;scroll-behavior:smooth}body{color:rgba(var(--text-color), 1);background:rgba(var(--background-color), 1)}body,body *{--accent-color: #256eff;--text-color: 36, 36, 36;--background-color: 248, 248, 248;--foreground-color: rgb(255, 255, 255);--danger-color: rgb(255, 75, 75);--green: #1cad59;--like-color: #e91e63;scrollbar-width:thin}body[data-theme=dark],body[data-theme=dark] *{--accent-color: #86afff;--text-color: 220, 220, 220;--background-color: 10, 10, 10;--foreground-color: rgb(24, 24, 24);--danger-color: rgb(255, 106, 106);--green: #00e676}body[data-theme=dark] sm-popup::part(popup){background-color:var(--foreground-color)}body[data-theme=dark] ::-webkit-calendar-picker-indicator{filter:invert(1)}p,strong{font-size:.9rem;max-width:70ch;line-height:1.7;color:rgba(var(--text-color), 0.8)}p:not(:last-of-type),strong:not(:last-of-type){margin-bottom:1.5rem}a{text-decoration:none}a:not([class]){color:var(--accent-color)}a:not([class]):focus-visible{box-shadow:0 0 0 .1rem rgba(var(--text-color), 1) inset}input[type=datetime-local]{width:100%;padding:.6rem .8rem;background-color:rgba(var(--text-color), 0.06);border:none;border-radius:.3rem;font-size:.9rem;color:inherit;font-family:inherit}input[type=datetime-local]:focus{outline:none;box-shadow:0 0 0 .1rem var(--accent-color)}button,.button{-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;position:relative;display:inline-flex;border:none;background-color:transparent;overflow:hidden;color:inherit;cursor:pointer;-webkit-tap-highlight-color:transparent;align-items:center;font-size:.9rem;font-weight:500}.button{white-space:nowrap;padding:.6rem .8rem;border-radius:.3rem;background-color:rgba(var(--text-color), 0.06);color:rgba(var(--text-color), 0.8);justify-content:center}.button--primary{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}.icon-only{padding:.5rem;border-radius:.3rem}button:disabled{opacity:.5}a:-webkit-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:-moz-any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}a:any-link:focus-visible{outline:rgba(var(--text-color), 1) .1rem solid}sm-input,sm-textarea,tags-input{font-size:.9rem;--border-radius: 0.3rem}sm-button{--padding: 0.6rem 0.8rem}sm-button[variant=primary] .icon{fill:rgba(var(--background-color), 1)}sm-button[disabled] .icon{fill:rgba(var(--text-color), 0.6)}sm-button.uppercase{letter-spacing:.05em}sm-button.danger{--background: var(--danger-color);color:rgba(var(--background-color), 1)}ul{list-style:none}.overflow-ellipsis{width:100%;overflow:hidden;white-space:nowrap;text-overflow:ellipsis}.breakable{overflow-wrap:break-word;word-wrap:break-word;-ms-word-break:break-all;word-break:break-word;-ms-hyphens:auto;-webkit-hyphens:auto;hyphens:auto}.full-bleed{grid-column:1/-1}.h1{font-size:1.5rem}.h2{font-size:1.2rem}.h3{font-size:1rem}.h4{font-size:.9rem}.h5{font-size:.8rem}.uppercase{text-transform:uppercase}.capitalize{text-transform:capitalize}.flex{display:flex}.flex-wrap{flex-wrap:wrap}.grid{display:grid}.flow-column{grid-auto-flow:column}.gap-0-5{gap:.5rem}.gap-1{gap:1rem}.gap-1-5{gap:1.5rem}.gap-2{gap:2rem}.gap-3{gap:3rem}.text-align-right{text-align:right}.align-start{align-items:flex-start}.align-center{align-items:center}.text-center{text-align:center}.justify-start{justify-content:start}.justify-center{justify-content:center}.justify-right{margin-left:auto}.align-self-center{align-self:center}.justify-self-center{justify-self:center}.justify-self-start{justify-self:start}.justify-self-end{justify-self:end}.direction-column{flex-direction:column}.space-between{justify-content:space-between}.w-100{width:100%}.ripple{height:8rem;width:8rem;position:absolute;border-radius:50%;transform:scale(0);background:radial-gradient(circle, rgba(var(--text-color), 0.3) 0%, rgba(0, 0, 0, 0) 50%);pointer-events:none}.interact{position:relative;overflow:hidden;cursor:pointer;-webkit-tap-highlight-color:transparent}.empty-state{display:grid;width:100%;padding:1.5rem 0}.observe-empty-state:empty{display:none}.observe-empty-state:not(:empty)+.empty-state{display:none}.bullet-point{display:flex;align-items:center;justify-content:center;margin:0 .8ch}.bullet-point::after{content:"";height:.4ch;width:.4ch;border-radius:.5em;background-color:currentColor}.icon{width:1.2rem;height:1.2rem;fill:rgba(var(--text-color), 0.8);flex-shrink:0}.button__icon{height:1.2rem;width:1.2rem}.button__icon--left{margin-right:.5rem}.button__icon--right{margin-left:.5rem}.icon-button{padding:.6rem;border-radius:.8rem;background-color:rgba(var(--text-color), 0.1);height:-webkit-max-content;height:-moz-max-content;height:max-content}.icon-button .icon{fill:var(--accent-color)}#confirmation_popup,#prompt_popup{flex-direction:column}#confirmation_popup h4,#prompt_popup h4{font-weight:500;margin-bottom:.5rem}#confirmation_popup sm-button,#prompt_popup sm-button{margin:0}#confirmation_popup .flex,#prompt_popup .flex{padding:0;margin-top:1rem}#confirmation_popup .flex sm-button:first-of-type,#prompt_popup .flex sm-button:first-of-type{margin-right:.6rem;margin-left:auto}#prompt_message{margin-bottom:1.5rem}.popup__header{display:grid;gap:.5rem;width:100%;padding:0 1.5rem 0 .8rem;align-items:center;grid-template-columns:auto 1fr auto}.popup__header__close{padding:.5rem;cursor:pointer}.logo{position:absolute;color:inherit;display:grid;align-items:center;grid-template-columns:auto 1fr;gap:0 .2rem;justify-self:center}.logo h4{text-transform:capitalize;font-size:.9rem;letter-spacing:.03em}.logo .main-logo{height:1.4rem;width:1.4rem;fill:rgba(var(--text-color), 1);stroke:none}details summary{display:flex;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none;cursor:pointer;padding:.5rem 0}details[open]>summary .down-arrow{transform:rotate(180deg)}sm-select,sm-option,strip-option{font-size:.9rem}sm-select{--max-height: 12rem}strip-select{--gap: 0}strip-option{font-weight:500;--border-radius: 0.3rem;--active-option-color: var(--accent-color)}sm-menu{--background: var(--foreground-color)}menu-option{font-size:.9rem}sm-copy{font-size:.9rem;--button-border-radius: 0.2rem}.warning{background-color:khaki;color:rgba(0,0,0,.7);padding:1rem;border-radius:.5rem;line-height:1.5}.page{height:100%}.page-layout,#preview_page{display:grid;grid-template-columns:1.5rem minmax(0, 1fr) 1.5rem}.page-layout>*,#preview_page>*{grid-column:2/3}#loading{display:grid;place-content:center;text-align:center}#loader_container{position:relative;height:3rem;overflow:hidden;margin-bottom:1.5rem}#loader_container::after{content:"";position:absolute;height:100%;width:100%;left:0;background:linear-gradient(rgba(var(--foreground-color), 1), transparent 20%, transparent 80%, rgba(var(--foreground-color), 1))}#loader{height:6rem;width:6rem;-webkit-animation:scroll infinite 1s cubic-bezier(0.075, 0.82, 0.165, 1);animation:scroll infinite 1s cubic-bezier(0.075, 0.82, 0.165, 1);fill:rgba(var(--text-color), 0.2)}@-webkit-keyframes scroll{to{transform:translateY(-3rem)}}@keyframes scroll{to{transform:translateY(-3rem)}}.label{font-size:.8rem;color:rgba(var(--text-color), 0.8);margin-bottom:.2rem}.icon--success{fill:var(--green)}.icon--failure,.icon--error{fill:var(--danger-color)}#main{overflow-y:hidden;display:grid;height:100%;grid-template-rows:auto 1fr;grid-template-columns:minmax(0, 1fr)}#main_header{display:grid;gap:.5rem;padding:1rem;align-items:center;grid-column:1/-1;grid-template-columns:auto 1fr auto auto;background-color:rgba(var(--background-color), 1);z-index:2;border-bottom:thin solid rgba(var(--text-color), 0.1)}#expanding_search{position:absolute;display:grid;gap:.5rem;align-items:center;width:calc(100% - 2rem);z-index:1;background-color:rgba(var(--background-color), 1)}#expanding_search .icon-only{margin-right:.5rem}#search_suggestions{position:absolute;top:calc(100% + .5rem);background-color:var(--foreground-color);padding:.3rem;width:100%;border-radius:.3rem;box-shadow:0 .5rem 1.5rem rgba(0,0,0,.1)}.search-suggestion{font-size:.9rem;color:inherit;padding:1rem;border-radius:.3rem}#search_articles{--border-radius: 0.5em;width:100%}theme-toggle{margin-left:auto;padding:0 .5rem}#main_page{align-content:flex-start;display:grid;padding:1.5rem;gap:1.5rem;grid-template-columns:minmax(0, 1fr)}#news_categories_list{overflow-x:auto;gap:.5rem}.category{display:flex;flex-direction:column;padding:.8rem .5rem;color:inherit;font-size:.8rem;white-space:nowrap;flex-shrink:0;align-items:center;border-radius:.5rem;min-width:4rem;background-color:rgba(var(--text-color), 0.02)}.category .icon{transition:transform .3s}.category:hover .icon{transform:scale(1.3);fill:var(--accent-color)}.category span{margin-top:.5rem}#query_results_list,#written_article_list{margin:1rem 0;padding-bottom:2rem;gap:1.6rem}.article-card{gap:.3rem}.article-card a{color:inherit}.article-card .article-link{gap:.5rem}.article-card__title{line-height:1.4}.article-card__category{background-color:rgba(var(--text-color), 0.1);border-radius:.3rem;font-size:.8rem;padding:.3rem .6rem;font-weight:700;color:rgba(var(--text-color), 0.6) !important;justify-self:flex-start;text-transform:capitalize}.article-card .flex{font-size:.8rem}#trending_article_container{counter-reset:trending;margin-bottom:1.5rem}.trending-article{counter-increment:trending;grid-template-columns:auto 1fr;gap:.5rem 1.5rem}.trending-article::before{content:counter(trending);grid-column:1/2;grid-row:1/3;font-size:2.5em;font-weight:700;opacity:.3}#explore{padding-top:1.5rem}#writer{align-items:flex-start;align-content:flex-start;padding:1.5rem;gap:3rem}#writer sm-copy{font-size:.8rem}#writer_profile{display:flex;width:4rem;height:4rem;border-radius:2rem;background-color:var(--accent-color);justify-content:center}#writer_profile #writer_initials{align-self:center;font-weight:700;font-size:1.8rem;color:rgba(var(--background-color), 1);text-transform:uppercase}#article{display:flex;padding:1.5rem;max-height:100%;overflow-y:auto}#article main>section:last-of-type{padding-bottom:6rem}#article_aside{position:absolute;left:0;top:5rem;padding:1.5rem}#article_map_container{margin-top:1.5rem;display:grid;gap:.5rem}#article_map_container button{line-height:1.3;width:100%;padding:.5rem 0;text-align:left;font-weight:500;font-size:.9rem;color:rgba(var(--text-color), 0.8)}.hero-section{display:grid;gap:.5rem;grid-template-columns:minmax(0, 1fr)}#article_contributors{flex-wrap:wrap;gap:.3rem;margin:.5rem 0 1rem 0}.contributor{color:inherit;font-size:.8rem;background-color:rgba(var(--text-color), 0.06);border-radius:.3rem;padding:.3rem .5rem}#action_panel{position:fixed;bottom:0;left:0;gap:.5rem;align-items:center}.up-vote{display:grid;position:relative;padding:.5rem;border-radius:.3rem}.up-vote>*{pointer-events:none}.up-vote:active{transform:none}.up-vote:active .icon{transform:scale(0.7)}.up-vote .expanding-heart,.up-vote .ring{grid-area:1/1}.up-vote .icon{grid-area:1/1;fill:var(--like-color);transition:transform .2s}.ring{border:.1rem solid var(--like-color);border-radius:50%;height:.5rem;width:.5rem;justify-self:center}.temp-count,#like_count{grid-area:1/2}.temp-count:not(:empty),#like_count:not(:empty){margin-left:.4rem}.floating-button{position:fixed;z-index:2;box-shadow:0 .5rem 1rem rgba(0,0,0,.2);border-radius:2rem;bottom:0;right:0;margin:1.5rem;padding:1rem}#go_to_top{background-color:var(--foreground-color)}#dashboard{height:-webkit-max-content;height:-moz-max-content;height:max-content;padding:1.5rem 0;grid-template-rows:auto 1fr}#publishing_requests,#article_analytics{margin-top:2rem;align-content:flex-start}.request-card{display:grid;gap:.5rem;border-radius:.5rem;align-items:flex-start;grid-template-columns:minmax(0, 1fr)}.request-card__title{grid-area:2/1}.request-card__time{font-size:.8rem}.request-card .flex{grid-row:span 2;margin-top:.5rem}.request-card .publish-button{text-transform:uppercase;letter-spacing:.05em;font-size:.8rem;font-weight:700}.article-row{align-items:center;gap:1rem;grid-template-columns:1fr auto auto}.article-row__published{font-size:.8rem}#preview_popup h1,#article h1{font-size:1.6rem;line-height:1.3}#preview_popup h3:not(:first-of-type),#article h3:not(:first-of-type){margin-top:2rem}#preview_popup h3,#article h3{margin-bottom:1rem}#preview_popup h3:not(:first-of-type),#article h3:not(:first-of-type){margin-top:1.5rem}#preview_popup p,#article p{font-family:"noto serif",serif;font-size:1rem;line-height:1.8}#preview_popup p>*,#article p>*{font-family:inherit}#preview_popup time,#preview_popup #reading_time,#article time,#article #reading_time{font-size:.8rem}#add_writer_button{background-color:var(--accent-color);color:rgba(var(--background-color), 1)}#add_writer_button .icon{fill:rgba(var(--background-color), 1)}#writers_list{margin:1.5rem 0;grid-template-columns:repeat(auto-fill, minmax(20rem, 1fr));padding-bottom:3rem}.writer-card{display:grid;gap:1rem;padding:1rem;border-radius:.5rem;background-color:var(--foreground-color)}.writer-card .writer-profile{display:flex;align-items:center;justify-content:center;height:3rem;width:3rem;border-radius:2rem;background-color:var(--accent-color);text-align:center;font-size:100%;font-weight:700;text-transform:uppercase;color:var(--foreground-color)}.writer-card sm-copy{margin-top:-0.5rem;font-size:.8rem}#user_popup{overflow:hidden}#user_popup header{overflow:hidden;width:100%;position:relative;padding:1.5rem;color:#dcdcdc}#user_popup header h2{margin-top:2rem}#user_popup header .popup__header__close{margin-left:-0.5rem;background-color:rgba(0,0,0,.2);border-radius:2rem}#user_popup header .popup__header__close .icon{fill:#fff}#user_background{position:absolute;top:-1px;left:0;right:0;z-index:-1;transform:scale(-1);border-radius:0 0 .5rem .5rem}.hide{display:none !important}@media screen and (max-width: 40rem){button,.button{padding:.8rem}sm-button{--padding: 0.8rem}.writer-card .writer-profile{height:2.5rem;width:2.5rem}#action_panel{width:-webkit-min-content;width:-moz-min-content;width:min-content;padding:.5rem;border-radius:.5rem;background-color:var(--foreground-color);margin:1.5rem;box-shadow:0 .5rem 1rem rgba(0,0,0,.2)}.hide-on-mobile{display:none}}@media screen and (min-width: 40rem){sm-popup{--width: 24rem}h1,.h1{font-size:2rem}.h2{font-size:1.8rem}.h3{font-size:1.3rem}.h4{font-size:1rem}.popup__header{grid-column:1/-1;padding:1rem 1.5rem 0 .8rem}#confirmation_popup{--width: 24rem}.page-layout{grid-template-columns:1fr 80vw 1fr}.hide-on-desktop{display:none}#main_header{padding:1rem 1.5rem}#main_page{padding:1rem 8vw;grid-template-rows:auto 1fr;grid-template-columns:2fr 1fr}#main_page__header{grid-area:1/1/2/-1}#expanding_search{margin:1rem 1.5rem;left:0;width:20rem}#writer{gap:1.5rem 6vw;padding:2rem 8vw;grid-template-columns:20rem 1fr}#writer>section:first-of-type{position:-webkit-sticky;position:sticky;top:1.5rem}#preview_popup h1,#article h1{font-size:2rem}#article{gap:6vw;padding:0;grid-template-columns:16rem 1fr}#article main{width:60ch;padding:1.5rem 0}#article_aside{width:20rem;padding:1.5rem 2rem;display:flex;flex-direction:column;position:-webkit-sticky;position:sticky;top:0;height:100%;overflow-y:auto}#article_map_container{margin-bottom:3rem}#action_panel{position:relative;margin-top:auto}.request-card{grid-template-columns:1fr auto}.request-card .flex{margin-top:0}#preview_popup{--width: 60ch}#edit_article_meta_popup{--width: 48rem}#edit_article_meta_popup>section{grid-template-columns:1fr 1.5fr;align-items:flex-start}#user_popup{--width: 25rem}}@media screen and (max-width: 64rem){.hide-on-medium{display:none}}@media(any-hover: hover){::-webkit-scrollbar{width:.5rem;height:.5rem}::-webkit-scrollbar-thumb{background:rgba(var(--text-color), 0.3);border-radius:1rem}::-webkit-scrollbar-thumb:hover{background:rgba(var(--text-color), 0.5)}.interact,button:not(.button--primary){transition:background-color .3s}.interact:hover,button:not(.button--primary):hover{background-color:rgba(var(--text-color), 0.06)}.button--primary{transition:filter .3s}.button--primary:hover{filter:brightness(120%)}} \ No newline at end of file diff --git a/css/main.scss b/css/main.scss index e4bca70..7be7650 100644 --- a/css/main.scss +++ b/css/main.scss @@ -212,6 +212,9 @@ ul { .flex { display: flex; } +.flex-wrap { + flex-wrap: wrap; +} .grid { display: grid; @@ -433,6 +436,7 @@ details { display: flex; user-select: none; cursor: pointer; + padding: 0.5rem 0; } &[open] > summary { @@ -534,7 +538,8 @@ sm-copy { fill: var(--danger-color); } -main { +#main { + overflow-y: hidden; display: grid; height: 100%; grid-template-rows: auto 1fr; @@ -706,15 +711,40 @@ theme-toggle { } #article { - gap: 2rem 0; - padding-bottom: 6rem; + display: flex; + padding: 1.5rem; + max-height: 100%; + overflow-y: auto; + main { + & > section:last-of-type { + padding-bottom: 6rem; + } + } +} +#article_aside { + position: absolute; + left: 0; + top: 5rem; + padding: 1.5rem; +} +#article_map_container { + margin-top: 1.5rem; + display: grid; + gap: 0.5rem; + button { + line-height: 1.3; + width: 100%; + padding: 0.5rem 0; + text-align: left; + font-weight: 500; + font-size: 0.9rem; + color: rgba(var(--text-color), 0.8); + } } - .hero-section { display: grid; gap: 0.5rem; grid-template-columns: minmax(0, 1fr); - padding-top: 1.5rem; } #article_contributors { flex-wrap: wrap; @@ -728,24 +758,18 @@ theme-toggle { border-radius: 0.3rem; padding: 0.3rem 0.5rem; } -#like_panel { +#action_panel { position: fixed; bottom: 0; - width: 100%; - padding: 1.5rem; - text-align: center; - justify-items: flex-start; + left: 0; + gap: 0.5rem; + align-items: center; } .up-vote { display: grid; - grid-template-columns: auto 1fr; position: relative; - padding: 0.8rem; - border-radius: 2rem; - background-color: var(--foreground-color); - -webkit-box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1); - box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.1); - border: solid rgba(var(--text-color), 0.2) thin; + padding: 0.5rem; + border-radius: 0.3rem; & > * { pointer-events: none; } @@ -759,14 +783,6 @@ theme-toggle { } } - &.liked { - background-color: var(--like-color); - color: #fff; - .icon { - fill: #fff; - } - } - .expanding-heart, .ring { grid-area: 1/1; @@ -774,8 +790,6 @@ theme-toggle { & .icon { grid-area: 1/1; fill: var(--like-color); - height: 1.5rem; - width: 1.5rem; -webkit-transition: -webkit-transform 0.2s; transition: -webkit-transform 0.2s; transition: transform 0.2s; @@ -831,7 +845,7 @@ theme-toggle { gap: 0.5rem; border-radius: 0.5rem; align-items: flex-start; - grid-template-columns: 1fr auto; + grid-template-columns: minmax(0, 1fr); &__title { grid-area: 2/1; } @@ -840,6 +854,7 @@ theme-toggle { } .flex { grid-row: span 2; + margin-top: 0.5rem; } .publish-button { text-transform: uppercase; @@ -976,6 +991,14 @@ theme-toggle { width: 2.5rem; } } + #action_panel { + width: min-content; + padding: 0.5rem; + border-radius: 0.5rem; + background-color: var(--foreground-color); + margin: 1.5rem; + box-shadow: 0 0.5rem 1rem rgba(0, 0, 0, 0.2); + } .hide-on-mobile { display: none; } @@ -1049,9 +1072,39 @@ theme-toggle { } } #article { - grid-template-columns: 1fr 60ch 1fr; + gap: 6vw; + padding: 0; + grid-template-columns: 16rem 1fr; + main { + width: 60ch; + padding: 1.5rem 0; + } + } + #article_aside { + width: 20rem; + padding: 1.5rem 2rem; + display: flex; + flex-direction: column; + position: sticky; + top: 0; + height: 100%; + overflow-y: auto; + } + #article_map_container { + margin-bottom: 3rem; } + #action_panel { + position: relative; + margin-top: auto; + } + + .request-card { + grid-template-columns: 1fr auto; + .flex { + margin-top: 0; + } + } #preview_popup { --width: 60ch; } @@ -1071,20 +1124,6 @@ theme-toggle { display: none; } } -@media screen and (min-width: 64rem) { - #like_panel { - margin: 1.5rem; - width: 18vw; - border-radius: 0.8rem; - border: solid thin rgba(var(--text-color), 0.2); - justify-content: flex-start; - justify-items: flex-start; - text-align: left; - .up-vote { - box-shadow: none; - } - } -} @media (any-hover: hover) { ::-webkit-scrollbar { width: 0.5rem; diff --git a/index.html b/index.html index ee77c69..c1a83e6 100644 --- a/index.html +++ b/index.html @@ -92,7 +92,7 @@

Loading RM Times

-
+
+
- -
-
-

Article by -

-
-
-
-

Like the article to support creators.

- -
+ +
+
+

+
+
+ +
+ +
+
+
+ +

In this article

+ + + + +
+
+
+
+

Article by -

+
+
+
+