[TWIG][CSS] Complete HTML refactoring, now using details element instead of a checkbox trick per panel. Using a "grid" akin to IBM's Carbon design guidelines.

This commit is contained in:
Eliseu Amaro 2021-07-20 13:18:57 +01:00 committed by Diogo Peralta Cordeiro
parent 681f001f4e
commit b7b69b549e
Signed by: diogo
GPG Key ID: 18D2D35001FBFAB0
20 changed files with 230 additions and 2969 deletions

View File

@ -1,27 +1,31 @@
:root {
/* fonts */
/* FONTS */
--display-font: 'Manrope-ExtraBold', sans-serif;
--main-font: 'Inter', sans-serif;
/* font and margin sizes */
--unit-size-h: calc(100vh / 9);
--unit-size-w: calc(100vw / 9);
/* UNITS
* unit size - every element should be a multiplier of this
* main size - used for headers and icons
* medium size - same as above, except that the element in question is contained in something else
* small size - used in common text, borders
*/
--unit-size: 0.5rem;
--main-size: 1.5rem;
--medium-size: 1.125rem;
--small-size: 1rem;
/* colours and shadows */
--fg: #eceff4;
--accent: #81a1c1;
--accent-low: #81a1c160;
--bg-trans1: rgba(46, 52, 64, 0.42);
--bg-trans2: rgba(46, 52, 64, 0.21);
--bg1: #2e3440;
--bg2: #3b4252;
--bg3: #434c5e;
--bg4: #4c566a;
--bg5: #d8dee9;
--shadow: 0px 0px 20px 0px rgba(46,52,64,0.95);
--black: #040506;
--bg1: #383E51;
--bg2: #434A60;
--bg3: #5C6684;
--white: #EEDFD4;
--accent-blue: #8E8DBE;
--accent-red: #FF6666;
--accent-green: #2EC4B6;
--shadow: 0px 0px 16px 0px #383E51;
}
/* TYPOGRAPHY */
@ -67,27 +71,6 @@ p {
text-transform: none;
}
/* DEFAULTS */
body,
html {
height: 100%;
width: auto;
color: var(--fg);
/* BLENDING BANDING IN FIREFOX */
/* basically emulating screen blending with just "images" */
background-image: linear-gradient(var(--bg1) 10%, var(--bg4) 80%),
url();
background-blend-mode: multiply;
background-attachment: fixed;
filter: invert();
}
hr {
margin: 0;
color: var(--accent-low);
}
ul {
text-decoration: none;
margin: 0;
@ -103,89 +86,73 @@ li {
a:link {
text-decoration: none;
outline: 0;
color: var(--fg);
color: var(--bg3);
}
a:visited {
outline: 0;
color: var(--fg);
color: var(--bg3);
margin: 0;
padding: 0;
}
a:hover {
color: var(--fg);
color: var(--accent-blue);
transition: all 0.8s ease;
}
a:focus {
color: var(--fg);
color: var(--accent-blue);
transition: all 0.8s ease;
}
/* HEADER */
#header {
position: fixed;
top: 0;
left: 0;
right: 0;
height: 100vh;
/* ALLOW MAIN CONTENT POINTER EVENTS */
pointer-events: none;
}
#top {
display: flex;
flex-direction: column;
flex-wrap: nowrap;
/* DEFAULTS */
body,
html {
height: 100%;
width: auto;
color: var(--white);
/* PARENT HAS NO POINTER EVENTS */
pointer-events: all;
/* BLENDING BANDING IN FIREFOX */
/* basically emulating screen blending with just "images" */
background-color: var(--bg1);
background-image: radial-gradient(ellipse at bottom, var(--bg1), transparent),
url();
background-blend-mode: multiply;
background-attachment: fixed;
}
.icon-menu {
display: none;
width: var(--main-size);
height: var(--main-size);
stroke: currentColor;
fill: currentColor;
#header {
display: flex;
justify-content: center;
position: fixed;
pointer-events: none;
width: 100%;
height: calc(5 * var(--unit-size));
padding: var(--small-size);
background: repeating-linear-gradient(var(--bg2), var(--bg1)),
url();
background-blend-mode: multiply;
box-shadow: var(--shadow);
}
#instance {
order: 1;
font-size: var(--main-size);
display: flex;
justify-content: center;
height: calc(var(--unit-size-h) / 2);
width: 100%;
padding: 0;
box-sizing: border-box;
background-color: var(--bg1);
color: var(--fg);
-webkit-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.10);
-moz-box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.10);
box-shadow: 0px 0px 20px 0px rgba(0,0,0,0.10);
}
#instance a {
font-family: var(--display-font);
font-size: var(--main-size);
display: inline-flex;
flex-wrap: nowrap;
align-items: center;
align-self: center;
justify-content: center;
height: 100%;
width: 100%;
}
#instance a {
display: flex;
color: var(--white);
font-size: var(--main-size);
}
.icon-logo {
margin-right: 5px;
stroke-width: 0;
stroke: currentColor;
fill: var(--fg);
vertical-align: middle;
margin-right: var(--small-size);
fill: var(--white);
}
#panels {
order: 2;
display: flex;
.navigation {
padding-top: calc(2 * var(--small-size) + var(--main-size));
}

View File

@ -1,258 +0,0 @@
:root {
/* fonts */
--main-font: 'Montserrat', sans-serif;
--main-font: 'Open Sans', sans-serif;
/* font and margin sizes */
--main-size: 1.15em;
--medium-size: 0.7em;
--small-size: 0.65em;
--unit-size: 1em;
--side-margin: 5em;
--nav-size: 15em;
/* colours and shadows */
--fg: #eceff4;
--accent: #81a1c1;
--accent-low: #81a1c160;
--bg1: #2e3440;
--bg2: #3b4252;
--bg3: #434c5e;
--bg4: #4c566a;
--bg5: #d8dee9;
--shadow: 0px 0px 20px 0px rgba(46,52,64,0.95);
}
/* DEFAULTS */
body,
html {
background: var(--bg1);
background-attachment: fixed;
background-size: cover;
color: var(--fg);
font-family: var(--main-font);
font-size: var(--main-size);
margin: 0;
padding: 0;
}
ul {
text-decoration: none;
margin: 0;
padding: 0;
list-style: none;
}
li {
margin: 0;
padding: 0;
}
a:link {
text-decoration: none;
outline: 0;
color: var(--fg);
margin: 0;
padding: 0;
}
a:visited {
outline: 0;
color: var(--fg);
margin: 0;
padding: 0;
}
a:hover {
color: var(--fg);
transition: all 0.8s ease;
}
a:focus {
color: var(--fg);
transition: all 0.8s ease;
}
b {
font-family: var(--main-font);
font-weight: 800;
}
/* HEADER */
#header {
position: fixed;
top: 0;
left: 0;
right: 0;
background-color: var(--accent);
padding: var(--main-size);
height: var(--main-size);
}
#top {
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
width: 100%;
}
.icon-menu {
position: relative;
display: flex;
align-items: center;
width: var(--unit-size);
height: var(--unit-size);
cursor: pointer;
transition: all .5s ease-in-out;
}
.icon-menu label {
width: var(--unit-size);
height: 3px;
border-radius: 3px;
background: var(--bg1);
transition: all .5s ease-in-out;
}
.icon-menu label::before,
.icon-menu label::after {
content: '';
position: absolute;
width: var(--unit-size);
height: 3px;
border-radius: 3px;
background: var(--bg1);
transition: all .5s ease-in-out;
}
.icon-menu label::before {
transform: translateY(-6px);
}
.icon-menu label::after {
transform: translateY(6px);
}
#toggle:checked+div label{
width: 0;
}
#toggle:checked+div label::before {
transform: rotate(45deg);
}
#toggle:checked+div label::after {
transform: rotate(-45deg);
}
#instance {
order: 2;
}
#instance b {
margin: 0;
padding: 0;
vertical-align: middle;
margin-left: calc(0.2 * var(--unit-size));
color: var(--bg1);
}
.icon-logo {
margin: 0;
padding: 0;
display: inline-block;
width: var(--unit-size);
height: var(--unit-size);
stroke-width: 0;
stroke: currentColor;
fill: var(--bg1);
vertical-align: middle;
}
#left-panel {
order: 1;
}
/* left panel z-index fix */
.form {
position: relative;
z-index: 0;
}
#header {
z-index: 1;
}
/* styling radio buttons and checkboxes */
.content input[type="checkbox"] + label::before {
content: '';
position: relative;
display: inline-block;
margin-right: 5px;
width: var(--medium-size);
height: var(--medium-size);
background: var(--fg);
border-radius: 10%
}
.content input[type="checkbox"]:checked + label::before {
background: var(--accent);
border-radius: 10%;
background-image: url(); background-position: center;
background-repeat: no-repeat;
background-size: 80%;
}
.content input[type="checkbox"]:focus + label::before,
.content input[type="checkbox"]:hover + label::before{
border-radius: 10%;
box-shadow: 0 0 8px var(--accent);
}
.content input[type="checkbox"] {
height: 1px;
width: 1px;
overflow: hidden;
}
.content input[type="radio"] + label::before {
content: '';
position: relative;
display: inline-block;
margin-right: 5px;
width: var(--medium-size);
height: var(--medium-size);
background: var(--fg);
border-radius: 50%
}
.content input[type="radio"]:checked + label::before {
background: var(--accent);
border-radius: 50%;
background-image: url();
background-position: center;
background-repeat: no-repeat;
background-size: 50%;
fill: #2e3440;
}
.content input[type="radio"]:focus + label::before,
.content input[type="radio"]:hover + label::before{
border-radius: 50%;
box-shadow: 0 0 8px var(--accent);
}
.content input[type="radio"] {
position: absolute;
height: 1px;
width: 1px;
overflow: hidden;
clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
clip: rect(1px, 1px, 1px, 1px);
}
.create-notice button[type=submit] {
background: var(--bg1);
padding: 0.3em 1em;
color: var(--fg);
border-style: solid;
border-color: var(--accent);
border-radius: var(--small-size);
border-width: 2px;
font-family: 'Montserrat', sans-serif;
font-size: var(--small-size);
font-weight: 700;
}
.create-notice button[type=submit]:focus,
.create-notice button[type=submit]:hover {
border-radius: var(--small-size);
box-shadow: 0 0 8px var(--accent);
}
.avatar {
border-radius: 50%;
}

View File

@ -1,258 +0,0 @@
:root {
/* fonts */
--main-font: 'Montserrat', sans-serif;
--main-font: 'Open Sans', sans-serif;
/* font and margin sizes */
--main-size: 1.2em;
--medium-size: 0.7em;
--small-size: 0.65em;
--unit-size: 1em;
--side-margin: 2em;
--nav-size: 100%;
/* colours and shadows */
--fg: #eceff4;
--accent: #81a1c1;
--bg1: #2e3440;
--bg2: #3b4252;
--bg3: #434c5e;
--bg4: #4c566a;
--bg5: #d8dee9;
--shadow: 0px 0px 40px 0px rgba(46,52,64,0.95);
}
/* DEFAULTS */
body,
html {
background: var(--bg1);
background-attachment: fixed;
background-size: cover;
color: var(--fg);
font-family: var(--main-font);
font-size: var(--main-size);
margin: 0;
padding: 0;
}
ul {
text-decoration: none;
margin: 0;
padding: 0;
list-style: none;
}
li {
margin: 0;
padding: 0;
}
a:link {
text-decoration: none;
outline: 0;
color: var(--fg);
margin: 0;
padding: 0;
}
a:visited {
outline: 0;
color: var(--fg);
margin: 0;
padding: 0;
}
a:hover {
color: var(--fg);
transition: all 0.8s ease;
}
a:focus {
color: var(--fg);
transition: all 0.8s ease;
}
b {
font-family: var(--main-font);
font-weight: 800;
}
/* HEADER */
#header {
position: fixed;
top: 0;
left: 0;
right: 0;
background-color: var(--accent);
padding: var(--main-size);
height: var(--main-size);
}
#top {
display: flex;
justify-content: space-between;
align-items: center;
flex-wrap: wrap;
width: 100%;
}
.icon-menu {
position: relative;
display: flex;
align-items: center;
width: var(--unit-size);
height: var(--unit-size);
cursor: pointer;
transition: all .5s ease-in-out;
}
.icon-menu label {
width: var(--unit-size);
height: 3px;
border-radius: 3px;
background: var(--bg1);
transition: all .5s ease-in-out;
}
.icon-menu label::before,
.icon-menu label::after {
content: '';
position: absolute;
width: var(--unit-size);
height: 3px;
border-radius: 3px;
background: var(--bg1);
transition: all .5s ease-in-out;
}
.icon-menu label::before {
transform: translateY(-6px);
}
.icon-menu label::after {
transform: translateY(6px);
}
#toggle:checked+div label{
width: 0;
}
#toggle:checked+div label::before {
transform: rotate(45deg);
}
#toggle:checked+div label::after {
transform: rotate(-45deg);
}
#instance {
order: 2;
}
#instance b {
margin: 0;
padding: 0;
vertical-align: middle;
margin-left: calc(0.2 * var(--unit-size));
color: var(--bg1);
}
.icon-logo {
margin: 0;
padding: 0;
display: inline-block;
width: var(--unit-size);
height: var(--unit-size);
stroke-width: 0;
stroke: currentColor;
fill: var(--bg1);
vertical-align: middle;
}
#left-panel {
order: 1;
}
/* left panel z-index fix */
.form {
position: relative;
z-index: 0;
}
#header {
z-index: 1;
}
/* styling radio buttons and checkboxes */
.content input[type="checkbox"] + label::before {
content: '';
position: relative;
display: inline-block;
margin-right: 5px;
width: var(--unit-size);
height: var(--unit-size);
background: var(--fg);
border-radius: 10%
}
.content input[type="checkbox"]:checked + label::before {
background: var(--accent);
border-radius: 10%;
background-image: url();
background-position: center;
background-repeat: no-repeat;
background-size: 80%;
}
.content input[type="checkbox"]:focus + label::before,
.content input[type="checkbox"]:hover + label::before{
border-radius: 10%;
box-shadow: 0 0 8px var(--accent);
}
.content input[type="checkbox"] {
height: 1px;
width: 1px;
overflow: hidden;
}
.content input[type="radio"] + label::before {
content: '';
position: relative;
display: inline-block;
margin-right: 5px;
width: var(--unit-size);
height: var(--unit-size);
background: var(--fg);
border-radius: 50%
}
.content input[type="radio"]:checked + label::before {
background: var(--accent);
border-radius: 50%;
background-image: url();
background-position: center;
background-repeat: no-repeat;
background-size: 50%;
fill: #2e3440;
}
.content input[type="radio"]:focus + label::before,
.content input[type="radio"]:hover + label::before{
border-radius: 50%;
box-shadow: 0 0 8px var(--accent);
}
.content input[type="radio"] {
position: absolute;
height: 1px;
width: 1px;
overflow: hidden;
clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
clip: rect(1px, 1px, 1px, 1px);
}
.create-notice button[type=submit] {
background: var(--bg1);
padding: 0.6em 1.3em;
color: var(--fg);
border-style: solid;
border-color: var(--accent);
border-radius: var(--unit-size);
border-width: 2px;
font-family: 'Montserrat', sans-serif;
font-size: var(--small-size);
font-weight: 700;
}
.create-notice button[type=submit]:focus,
.create-notice button[type=submit]:hover {
border-radius: var(--small-size);
box-shadow: 0 0 8px var(--accent);
}
.avatar {
border-radius: 50%;
}

View File

@ -1,85 +0,0 @@
.content {
display: flex;
flex-wrap: wrap;
margin-top: calc(3 * var(--main-size));
justify-content: center;
align-items: center;
margin-left: 0;
margin-right: 0;
height: 100%;
}
.faq-nav {
order: 1;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
width: 100%;
background-color: #2A323B;
padding: var(--medium-size);
font-size: var(--medium-size);
font-family: var(--head-font);
box-shadow: 0 0 60px -20px rgba(0, 0, 0, 0.75);
}
.faq-nav ul {
display: flex;
align-items: stretch;
justify-content: space-evenly;
width: 100%;
margin-left: var(--side-margin);
margin-right: var(--side-margin);
padding: 0;
}
.faq-nav li {
display: block;
flex: 0 1 auto;
list-style-type: none;
font-weight: 700;
font-size: var(--medium-size);
}
.active {
color: #F6F6F6 !important;
font-weight: 700;
}
.faq-nav a {
color: #91B9D0;
}
.faq-nav a:hover {
color: #F6F6F6;
transition: all 0.8s ease;
}
.faq-nav a:focus {
color: #F6F6F6;
transition: all 0.8s ease;
}
.markd {
order: 2;
background-color: #00000050;
font-size: var(--small-size);
padding: var(--unit-size) calc(3 * var(--unit-size)) calc(3 * var(--unit-size));
border-radius: var(--unit-size);
margin-top: calc(2 * var(--unit-size));
margin-right: var(--side-margin);
margin-left: var(--side-margin);
box-shadow: 0 0 60px -20px rgba(0, 0, 0, 0.75);
}
.markd h2 {
margin-top: var(--unit-size);
}
.markd p {
margin-top: var(--unit-size);
margin-left: calc(0.5 * var(--unit-size));
}
.markd ul {
list-style-type: disc;
margin-left: calc(2 * var(--unit-size));
margin-top: var(--unit-size);
}

View File

@ -1,85 +0,0 @@
.content {
display: flex;
flex-wrap: wrap;
margin-top: calc(3 * var(--main-size));
justify-content: center;
align-items: center;
margin-left: 0;
margin-right: 0;
box-shadow: 0 0 60px -20px rgba(0, 0, 0, 0.75);
height: 100%;
}
.faq-nav {
order: 1;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
width: 100%;
background-color: #2A323B;
padding: var(--medium-size);
font-size: var(--medium-size);
font-family: var(--head-font);
}
.faq-nav ul {
display: flex;
align-items: stretch;
justify-content: space-evenly;
width: 100%;
margin-left: 0;
margin-right: 0;
padding: 0;
}
.faq-nav li {
display: block;
flex: 0 1 auto;
list-style-type: none;
font-weight: 700;
font-size: var(--medium-size);
}
.active {
color: #F6F6F6 !important;
font-weight: 700;
}
.faq-nav a {
color: #91B9D0;
}
.faq-nav a:hover {
color: #F6F6F6;
transition: all 0.8s ease;
}
.faq-nav a:focus {
color: #F6F6F6;
transition: all 0.8s ease;
}
.markd {
order: 2;
background-color: #00000050;
font-size: var(--small-size);
padding: var(--unit-size) calc(3 * var(--unit-size)) calc(3 * var(--unit-size));
border-radius: var(--unit-size);
margin-top: calc(2 * var(--unit-size));
margin-right: 1%;
margin-left: 1%;
box-shadow: 0 0 60px -20px rgba(0, 0, 0, 0.75);
}
.markd h2 {
margin-top: var(--unit-size);
}
.markd p {
margin-top: var(--unit-size);
margin-left: calc(0.5 * var(--unit-size));
}
.markd ul {
list-style-type: disc;
margin-left: calc(2 * var(--unit-size));
margin-top: var(--unit-size);
}

View File

@ -1,44 +1,13 @@
.icon-avatar {
border-radius: 50%;
width: var(--main-size);
}
.icon-left {
position: fixed;
top: 0;
left: 0;
padding: calc(3 * var(--unit-size));
/* left panel z-index fix */
.form {
position: relative;
z-index: 0;
}
#header {
z-index: 1;
}
width: var(--main-size);
height: auto;
/* CHECKBOX TRICK */
.icon-menu label {
opacity: 0;
cursor: pointer
}
#toggle {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle:checked+.navbar {
display: block;
left: 0;
top: 0;
transition: 0.3s ease;
}
#left-panel {
display: flex;
flex-direction: column;
left: 0;
width: calc(2 * var(--unit-size-w));
padding: var(--small-size);
box-sizing: border-box;
font-size: var(--medium-size);
background-image: linear-gradient(var(--bg1), transparent);
fill: var(--white);
stroke-width: 0;
vertical-align: middle;
}

View File

@ -1,122 +0,0 @@
.navbar {
display: flex;
flex-direction: column;
width: var(--nav-size);
height: calc(100vh - (3 * var(--unit-size)));
position: fixed;
background-color: var(--bg1);
margin-top: calc(3 * var(--main-size));
margin-left: -1px;
border: solid 1px var(--accent-low);
}
.navbar {
left: -100%;
top: 0;
transition: 0.3s ease;
}
/* left navigation */
.navbar .left-nav {
flex: 1;
overflow-y: auto;
}
.navbar .left-nav > a {
display: block;
color: var(--accent);
font-size: var(--medium-size);
margin-bottom: var(--unit-size);
margin-left: var(--unit-size);
}
.navbar .left-nav > a:nth-child(1) {
margin-top: var(--unit-size);
}
.navbar .left-nav > a:last-child {
margin-bottom: 0;
}
.navbar .left-nav > a:hover,
.navbar .left-nav > a:focus {
color: var(--fg);
transition: all 0.8s ease;
}
/* footer static pages links */
.navbar .footer {
display: flex;
flex-wrap: wrap;
flex-direction: row;
justify-content: space-evenly;
font-size: var(--medium-size);
padding: var(--unit-size);
margin-bottom: var(--unit-size);
}
.navbar .footer a {
margin-right: var(--unit-size);
color: var(--accent);
font-size: var(--medium-size);
}
/* checkbox trick */
.icon-menu label {
display: block;
cursor: pointer
}
#toggle {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle:checked~.navbar {
display: flex;
left: 0;
top: 0;
transition: 0.3s ease;
}
input.larger {
width: calc(1.5 * var(--main-size));
height: calc(1.5 * var(--main-size));
}
/* profile stats */
.profile {
display: flex;
flex-wrap: wrap;
background-color: var(--bg2);
padding: var(--unit-size);
font-size: var(--small-size);
margin-bottom: var(--unit-size);
vertical-align: middle;
}
.icon-avatar {
order: 1;
height: calc(5 * var(--unit-size));
width: calc(5 * var(--unit-size));
margin-right: var(--small-size);
border-radius: 50%;
}
.info {
order: 2;
}
.info #nick {
order: 1;
margin-bottom: var(--small-size);
}
.info .tags {
order: 2;
margin-bottom: var(--small-size);
}
.info .stats {
order: 3;
}
.info .stats span:last-child {
margin-left: var(--small-size);
}
.info .tags i {
color: var(--accent);
}
.info .tags i:first-child {
margin-left: 0 !important;
}
.info .tags i:last-child {
margin-left: var(--small-size);
}

View File

@ -1,122 +0,0 @@
.navbar {
display: flex;
flex-direction: column;
width: var(--nav-size);
height: calc(100vh - (3 * var(--unit-size)));
position: fixed;
background-color: var(--bg1);
margin-top: calc(3 * var(--main-size));
margin-left: -2px;
border: solid 1px var(--accent-low);
}
.navbar {
left: -100%;
top: 0;
transition: 0.3s ease;
}
/* left navigation */
.navbar .left-nav {
flex: 1;
overflow-y: auto;
}
.navbar .left-nav > a {
display: block;
color: var(--accent);
font-size: calc(1.2 * var(--medium-size));
margin-bottom: var(--unit-size);
margin-left: var(--unit-size);
}
.navbar .left-nav > a:nth-child(1) {
margin-top: var(--unit-size);
}
.navbar .left-nav > a:last-child {
margin-bottom: 0;
}
.navbar .left-nav > a:hover,
.navbar .left-nav > a:focus {
color: var(--fg);
transition: all 0.8s ease;
}
/* footer static pages links */
.navbar .footer {
display: flex;
flex-wrap: wrap;
flex-direction: row;
justify-content: space-evenly;
font-size: var(--medium-size);
padding: var(--unit-size);
margin-bottom: var(--unit-size);
}
.navbar .footer a {
margin-right: var(--unit-size);
color: var(--accent);
font-size: var(--medium-size);
}
/* checkbox trick */
.icon-menu label {
display: block;
cursor: pointer
}
#toggle {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle:checked~.navbar {
display: flex;
left: 0;
top: 0;
transition: 0.3s ease;
}
input.larger {
width: calc(1.5 * var(--main-size));
height: calc(1.5 * var(--main-size));
}
/* profile stats */
.profile {
display: flex;
flex-wrap: wrap;
background-color: var(--bg2);
padding: var(--unit-size);
font-size: var(--medium-size);
margin-bottom: var(--unit-size);
vertical-align: middle;
}
.icon-avatar {
order: 1;
height: calc(5 * var(--unit-size));
width: calc(5 * var(--unit-size));
margin-right: var(--small-size);
border-radius: 50%;
}
.info {
order: 2;
}
.info #nick {
order: 1;
margin-bottom: var(--small-size);
}
.info .tags {
order: 2;
margin-bottom: var(--small-size);
}
.info .stats {
order: 3;
}
.info .stats span:last-child {
margin-left: var(--small-size);
}
.info .tags i {
color: var(--accent);
}
.info .tags i:first-child {
margin-left: 0 !important;
}
.info .tags i:last-child {
margin-left: var(--small-size);
}

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

File diff suppressed because one or more lines are too long

View File

@ -1,78 +1,13 @@
#right-panel {
display: flex;
flex-direction: column;
.icon-right {
position: fixed;
top: 0;
right: 0;
padding: calc(3 * var(--unit-size));
width: calc(2 * var(--unit-size-w));
padding: var(--small-size);
box-sizing: border-box;
font-size: var(--medium-size);
background-image: linear-gradient(var(--bg1), transparent);
}
.icon-attach {
width: var(--main-size);
height: var(--main-size);
font-size: var(--medium-size);
fill: var(--fg);
cursor: pointer;
}
height: auto;
#replyform {
margin: var(--small-size);
}
#replyform div {
display: inline-flex;
justify-content: flex-start;
width: 100%;
box-sizing: border-box;
}
#replyform div textarea {
width: 100%;
}
/* UNTOGGLED */
.arrow {
border: solid var(--fg);
border-width: 0 3px 3px 0;
display: none;
padding: 0.3em;
}
.right {
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
#right-container {
right: 0;
top: 0;
transition: 0.3s ease;
}
.arrow label {
display: block;
cursor: pointer;
}
#toggle-right {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle-right:not(:checked)+.arrow {
transform: rotate(135deg);
transition: 0.3s ease;
}
/* TOGGLED */
#toggle-right:checked~#right-container {
display: flex;
right: 0;
top: 0;
transition: 0.3s ease;
}
#toggle-right:checked+.arrow {
transform: rotate(-45deg);
transition: 0.3s ease;
}
fill: var(--white);
stroke-width: 0;
vertical-align: middle;
}

View File

@ -1,64 +0,0 @@
/* RIGHT PANEL */
#right-panel {
order: 3;
}
.arrow {
border: solid var(--bg1);
border-width: 0 3px 3px 0;
display: inline-block;
padding: 0.3em;
}
.right {
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
#right-container {
display: flex;
flex-direction: column;
width: var(--nav-size);
height: calc(100vh - (3 * var(--unit-size)));
position: fixed;
background-color: var(--bg1);
margin-top: calc(3 * var(--main-size));
border: solid 1px var(--accent-low);
}
input.larger {
width: var(--main-size);
height: calc( 2 * var(--main-size));
}
/* untoggled */
#right-container {
right: -100%;
top: 0;
transition: 0.3s ease;
}
.arrow label {
display: block;
cursor: pointer
}
#toggle-right {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle-right:not(:checked)+.arrow {
transform: rotate(135deg);
transition: 0.3s ease;
}
/* toggled */
#toggle-right:checked~#right-container {
display: flex;
right: 0;
top: 0;
transition: 0.3s ease;
}
#toggle-right:checked+.arrow {
transform: rotate(-45deg);
transition: 0.3s ease;
}

View File

@ -1,64 +0,0 @@
/* RIGHT PANEL */
#right-panel {
order: 3;
}
.arrow {
border: solid var(--bg1);
border-width: 0 3px 3px 0;
display: inline-block;
padding: 0.3em;
}
.right {
transform: rotate(135deg);
-webkit-transform: rotate(135deg);
}
#right-container {
display: flex;
flex-direction: column;
width: var(--nav-size);
height: calc(100vh - (3 * var(--unit-size)));
position: fixed;
background-color: var(--bg1);
margin-top: calc(3 * var(--main-size));
border: solid 1px var(--accent-low);
}
input.larger {
width: var(--main-size);
height: calc( 2 * var(--main-size));
}
/* untoggled */
#right-container {
right: -100%;
top: 0;
transition: 0.3s ease;
}
.arrow label {
display: block;
cursor: pointer
}
#toggle-right {
position: absolute;
z-index: 2;
cursor: pointer;
opacity: 0;
}
#toggle-right:not(:checked)+.arrow {
transform: rotate(135deg);
transition: 0.3s ease;
}
/* toggled */
#toggle-right:checked~#right-container {
display: flex;
right: 0;
top: 0;
transition: 0.3s ease;
}
#toggle-right:checked+.arrow {
transform: rotate(-45deg);
transition: 0.3s ease;
}

View File

@ -1,281 +0,0 @@
.content {
display: flex;
flex-wrap: wrap;
margin-top: calc(4 * var(--main-size));
justify-content: center;
align-items: center;
margin-left: 0;
margin-right: 0;
margin-bottom: var(--unit-size);
}
.main {
width: 100%;
margin-left: var(--unit-size);
margin-right: var(--unit-size);
box-shadow: var(--shadow);
border-radius: var(--small-size);
border: solid 2px var(--accent-low);
background-color: var(--bg3);
}
.set-nav {
order: 1;
display: flex;
justify-content: space-evenly;
flex-wrap: wrap;
flex: 1;
background-color: var(--bg1);
padding: var(--medium-size);
font-family: var(--head-font);
border-radius: var(--small-size) var(--small-size) 0 0;
}
.set-nav ul {
display: flex;
align-items: stretch;
justify-content: space-around;
width: 100%;
margin-left: var(--side-margin);
margin-right: var(--side-margin);
padding: 0;
}
.set-nav li {
display: block;
flex: 0 1 auto;
list-style-type: none;
font-weight: 700;
font-size: var(--medium-size);
}
.set-nav a {
color: var(--accent);
}
.set-nav a:hover {
color: var(--fg);
transition: all 0.8s ease;
}
.active {
color: var(--fg) !important;
font-weight: 700;
}
.secondary {
display: flex;
flex-wrap: wrap;
background-color: var(--bg3);
margin: var(--unit-size);
border: solid 2px var(--accent-low);
border-radius: var(--small-size);
box-shadow: var(--shadow);
}
.form {
order: 3;
padding: calc(2*var(--unit-size));
height: 100%;
width: 100%;
box-shadow: var(--shadow);
border-radius: 0 0 var(--small-size) var(--small-size);
}
.form-single {
order: 2;
padding: calc(2*var(--unit-size));
height: 100%;
width: 100%;
border-radius: var(--small-size);
}
.form label,
.form-single label {
font-size: var(--medium-size);
}
/* FORMS ------------------------------*/
.form label {
display: inline-block;
font-family: 'Montserrat', sans-serif;
font-weight: 700;
width: 100%;
}
.form input[type=text] {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
background-color: var(--bg2);
box-shadow: var(--shadow);
border: solid 2px var(--accent-low);
padding: calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
.form input[type=checkbox] {
float: right;
}
#save_bio {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
height: calc(10 * var(--unit-size));
box-shadow: var(--shadow);
background-color: var(--bg2);
border: solid 2px var(--accent-low);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
word-wrap: break-word;
resize: vertical;
}
#save_phone_number {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
background-color: var(--bg2);
border: solid 2px var(--accent-low);
box-shadow: var(--shadow);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
#save_language{
margin-top: calc(var(--unit-size) * 0.5);
background-color: var(--bg2);
border: solid 2px var(--accent-low);
box-shadow: var(--shadow);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
select {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background-image: url("../../icons/drop.svg");
background-size: var(--main-size);
background-position: 95% 50%;
background-repeat: no-repeat;
}
.help-text {
font-size: var(--medium-size);
font-style: italic;
color: var(--fg);
margin-bottom: var(--unit-size);
}
.form-single input[type=checkbox] {
margin-left: var(--unit-size);
}
/* JS Cropping */
#img-cropped {
display: block;
max-width: 100%;
}
#img-container {
margin: var(--main-size) auto;
max-width: 80%;
}
.cropper-view-box,
.cropper-face {
border-radius: 50%;
}
/* NOTIFICATIONS TABS */
/* visual feedback */
ul input[type=radio] + label {
color: var(--accent);
}
ul input[type=radio]:checked + label {
color: var(--fg);
}
ul input[type=radio]:focus + label {
color: var(--fg);
}
/* show/hide each tab */
ul input[type=radio]:not(:checked) + label + div {
display: none;
}
ul input[type=radio]:checked + label + div {
display: flex;
}
/* hide radio buttons */
input[type=radio] {
position: absolute;
z-index: 1;
height: 1px;
width: 1px;
overflow: hidden;
clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
clip: rect(1px, 1px, 1px, 1px);
}
#form-tabs {
order: 2;
width: 100%;
font-size: var(--medium-size);
}
#form-tabs ul {
display: flex;
flex-wrap: wrap;
border-radius: 0 0 var(--unit-size) var(--unit-size);
background-color: var(--bg1);
justify-content: space-evenly;
width: 100%;
}
#form-tabs ul label {
order: 1;
flex: 0;
}
#tabs {
padding: var(--medium-size);
text-transform: capitalize;
}
#form-tabs ul .form {
order: 2;
padding: calc(2*var(--unit-size));
background-color: var(--bg3) !important;
height: 100%;
margin-left: 0;
margin-right: 0;
margin-top: 0;
box-shadow: none;
border-radius: 0 0 var(--unit-size) var(--unit-size);
font-size: var(--unit-size);
}
#form-tabs ul .form form{
width: 100%;
}
#form-tabs ul .form form div label {
margin-bottom: calc(var(--unit-size) * 0.5);
}
.secondary button[type=submit] {
background: var(--bg1);
padding: 0.6em 1.2em;
color: var(--fg);
border-style: solid;
border-color: var(--accent);
border-radius: var(--unit-size);
border-width: 2px;
font-family: 'Montserrat', sans-serif;
font-weight: 700;
}
.secondary button[type=submit]:focus,
.secondary button[type=submit]:hover {
border-radius: var(--unit-size);
box-shadow: 0 0 8px var(--accent);
}

View File

@ -1,266 +0,0 @@
.content {
display: flex;
flex-wrap: wrap;
margin-top: calc(3 * var(--main-size) + 2%);
justify-content: center;
align-items: center;
margin-left: 0;
margin-right: 0;
margin-bottom: var(--unit-size);
}
.main {
width: 100%;
margin-left: 1%;
margin-right: 1%;
box-shadow: var(--shadow);
border-radius: var(--small-size);
border: solid 2px var(--accent-low);
background-color: var(--bg3);
}
.set-nav {
order: 1;
display: flex;
justify-content: space-between;
flex-wrap: wrap;
flex: 1;
background-color: var(--bg1);
padding: var(--medium-size);
font-family: var(--head-font);
border-radius: var(--small-size) var(--small-size) 0 0;
}
.set-nav ul {
display: flex;
align-items: stretch;
justify-content: space-around;
width: 100%;
margin-left: var(--side-margin);
margin-right: var(--side-margin);
padding: 0;
}
.set-nav li {
display: block;
flex: 0 1 auto;
list-style-type: none;
font-weight: 700;
font-size: var(--medium-size);
}
.set-nav a {
color: var(--accent);
}
.set-nav a:hover {
color: var(--fg);
transition: all 0.8s ease;
}
.active {
color: var(--fg) !important;
font-weight: 700;
}
.secondary {
display: flex;
flex-wrap: wrap;
background-color: var(--bg3);
margin: 2%;
border: solid 2px var(--accent-low);
border-radius: var(--small-size);
box-shadow: var(--shadow);
}
.form {
order: 3;
padding: var(--unit-size);
height: 100%;
width: 100%;
box-shadow: var(--shadow);
border-radius: 0 0 var(--small-size) var(--small-size);
}
.form-single {
order: 2;
padding: var(--unit-size);
height: 100%;
width: 100%;
border-radius: var(--small-size);
}
.form label,
.form-single label {
font-size: var(--medium-size);
}
/* FORMS ------------------------------*/
.form label,
.form-single label {
display: inline-block;
font-family: 'Montserrat', sans-serif;
font-weight: 700;
font-size: var(--medium-size);
width: 100%;
}
.form input[type=text],
.form-single input[type=text] {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
box-shadow: var(--shadow);
background-color: var(--bg2);
border: solid 2px var(--accent-low);
padding: calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
.form input[type=checkbox] {
float: right;
}
#save_bio {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
height: calc(10 * var(--unit-size));
background-color: var(--bg2);
border: solid 2px var(--accent-low);
box-shadow: var(--shadow);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
word-wrap: break-word;
resize: vertical;
}
#save_phone_number {
margin-top: calc(var(--unit-size) * 0.5);
width: calc(100% - var(--unit-size));
background-color: var(--bg2);
border: solid 2px var(--accent-low);
box-shadow: var(--shadow);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
#save_language{
margin-top: calc(var(--unit-size) * 0.5);
background-color: var(--bg2);
border: solid 2px var(--accent-low);
box-shadow: var(--shadow);
padding: calc(var(--unit-size) * 0.5) calc(var(--unit-size) * 0.5);
color: var(--fg);
border-radius: calc(var(--unit-size) * 0.5);
font-size: var(--medium-size);
}
select {
-webkit-appearance: none;
-moz-appearance: none;
appearance: none;
background-image: url("../../icons/drop.svg");
background-size: var(--main-size);
background-position: 95% 50%;
background-repeat: no-repeat;
}
.help-text {
font-size: var(--medium-size);
font-style: italic;
color: var(--fg);
margin-bottom: var(--unit-size);
}
.form-single input[type=checkbox] {
margin-left: var(--unit-size);
}
/* JS Cropping */
#img-cropped {
display: block;
max-width: 100%;
}
#img-container {
margin: var(--main-size) auto;
max-width: 80%;
}
.cropper-view-box,
.cropper-face {
border-radius: 50%;
}
/* NOTIFICATIONS TABS */
/* visual feedback */
ul input[type=radio] + label {
color: var(--accent);
}
ul input[type=radio]:checked + label {
color: var(--fg);
}
ul input[type=radio]:focus + label {
color: var(--fg);
}
/* show/hide each tab */
ul input[type=radio]:not(:checked) + label + div {
display: none;
}
ul input[type=radio]:checked + label + div {
display: flex;
}
/* hide radio buttons */
input[type=radio] {
position: absolute;
z-index: 1;
height: 1px;
width: 1px;
overflow: hidden;
clip: rect(1px 1px 1px 1px); /* IE6, IE7 */
clip: rect(1px, 1px, 1px, 1px);
}
#form-tabs {
order: 2;
width: 100%;
font-size: var(--medium-size);
}
#form-tabs ul {
display: flex;
flex-wrap: wrap;
border-radius: 0 0 var(--unit-size) var(--unit-size);
background-color: var(--bg1);
justify-content: space-evenly;
width: 100%;
}
#form-tabs ul label {
order: 1;
flex: 0;
}
#tabs {
padding: var(--medium-size);
text-transform: capitalize;
}
#form-tabs ul .form {
order: 2;
padding: var(--unit-size);
background-color: var(--bg3) !important;
height: 100%;
margin-left: 0;
margin-right: 0;
margin-top: 0;
box-shadow: none;
border-radius: 0 0 var(--unit-size) var(--unit-size);
font-size: var(--unit-size);
}
#form-tabs ul .form form{
width: 100%;
}
#form-tabs ul .form form div label {
margin-bottom: calc(var(--unit-size) * 0.5);
}

View File

@ -5,24 +5,21 @@
<meta charset="UTF-8">
<meta name="viewport" content="width=device-width, initial-scale=1">
{% endblock %}
<title>
{% block title %}{% endblock %}
</title>
{% block stylesheets %}
<link rel='stylesheet' type='text/css' href="{{ asset('assets/fonts/inter/inter.css') }}">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/fonts/manrope/manrope.css') }}">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/base.css') }}"
media="screen and (min-width: 1300px)">
{# <link rel='stylesheet' type='text/css' href="{{ asset('assets/css/base_mid.css') }}"#}
{# media="screen and (max-width: 1300px)">#}
{# <link rel='stylesheet' type='text/css' href="{{ asset('assets/css/base_small.css') }}"#}
{# media="screen and (max-width: 750px)">#}
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/base.css') }}">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/reset.css') }}">
{% for stylesheet in show_stylesheets() %}
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/' ~ stylesheet) }}">
{% endfor %}
{% endblock %}
{% for arr in handle_event('ShowHeadElements', app.request) %}
{# Only one element, but has dynamic value, can't access it directly #}
{% for type, element in arr %}
@ -32,31 +29,29 @@
</head>
<body>
<div class="container">
{% block header %}
<div id='header'>
<div id='top'>
<nav id='instance'>
<a href="{{ path('main_public') }}">
{{ icon('logo', 'icon icon-logo') | raw }}
<h1> {{ config('site', 'name') }} </h1>
</a>
</nav>
<div id="panels">
{% block leftpanel %}
{% endblock leftpanel %}
{% block rightpanel %}
{% endblock rightpanel %}
</div>
</div>
</div>
<div id='header'>
<nav id='instance'>
<a href="{{ path('main_public') }}">
{{ icon('logo', 'icon icon-logo') | raw }}
<h1> {{ config('site', 'name') }} </h1>
</a>
</nav>
</div>
{% endblock header %}
{% block nav %}{% endblock %}
{% block body %}{% endblock %}
{% block javascripts %}{% endblock javascripts %}
</div>
<div class="container">
{% block leftpanel %}
{% endblock leftpanel %}
{% block rightpanel %}
{% endblock rightpanel %}
{% block nav %}{% endblock %}
{% block body %}{% endblock %}
{% block javascripts %}{% endblock javascripts %}
</div>
</body>
</html>

View File

@ -8,12 +8,7 @@
{% block stylesheets %}
{{ parent() }}
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/network/public.css') }}"
media="screen and (min-width: 1300px)">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/network/public_mid.css') }}"
media="screen and (max-width: 1300px)">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/network/public_small.css') }}"
media="screen and (max-width: 750px)">
<link rel='stylesheet' type='text/css' href="{{ asset('assets/css/network/public.css') }}">
{% endblock %}
{% block header %}
@ -27,7 +22,7 @@
{% block body %}
<div class="content">
<div class="main">
<div class="navigation">
<nav class='main-nav'>
<ul>
<li>
@ -62,19 +57,20 @@
{% endif %}
</ul>
</nav>
</div>
<div class="timeline">
<div class="notes">
{% if notes is defined and notes is not empty %}
{% for conversation in notes %}
{% include '/note/view.html.twig' with {'note': conversation['note'], 'have_user': have_user, 'replies': conversation['replies']} only %}
{% endfor %}
{% else %}
<h1>{% trans %}No notes here.{% endtrans %}</h1>
{% endif %}
</div>
<div class="timeline">
<div class="notes">
{% if notes is defined and notes is not empty %}
{% for conversation in notes %}
{% include '/note/view.html.twig' with {'note': conversation['note'], 'have_user': have_user, 'replies': conversation['replies']} only %}
{% endfor %}
{% else %}
<div id="empty-notes"><h1>{% trans %}No notes here.{% endtrans %}</h1></div>
{% endif %}
</div>
</div>
</div>
{% endblock body %}

View File

@ -1,74 +1,70 @@
{% if app.user %}
<div id='left-panel'>
<input type="checkbox" id="toggle" class="larger" autofocus>
<div class="icon-menu">
<label for="toggle" id='menu' tabindex="0"></label>
</div>
<div class='navbar'>
<div class="left-nav">
<div class='profile'>
{% for extra in profile_extras %}
{% include '/'~ extra.name ~ '/view.html.twig' with {'vars': extra.vars} only %}
<details>
<summary>{{ icon('menu', 'icon icon-left') | raw }}</summary>
{% if app.user %}
<div id='left-panel'>
<div class='navbar'>
<div class="left-nav">
<div class='profile'>
{% for extra in profile_extras %}
{% include '/'~ extra.name ~ '/view.html.twig' with {'vars': extra.vars} only %}
{% endfor %}
<a href="{{ path('settings_avatar') }}">
<img src='{{ user_avatar }}' alt="Your avatar." class="icon icon-avatar">
</a>
<a href="{{ path('settings_personal_info') }}">
<div class="info">
<b id="nick">{{ user_nickname }}</b>
<div class="tags">
{% if user_tags %}
{% for tag in user_tags %}
<a href='#'><i> #{{ tag }} </i></a>
{% endfor %}
{% else %}
<i> {{ '(No tags)' | trans }} </i>
{% endif %}
</div>
<div class="stats">
<span> <b> {{ user_followers }} </b> {{ 'Followers' | trans }} </span>
<span> <b> {{ user_followed }} </b> {{ 'Followed' | trans }} </span>
</div>
</div>
</a>
</div>
<a href='#'>Messages</a>
<a href="{{ path("replies", {'nickname' : user_nickname}) }}"
class='hover-effect {{ active("replies") }}'>Replies</a>
{% for link in handle_event('InsertLeftPanelLink', user_nickname) %}
{{ link | raw }}
{% endfor %}
<a href="{{ path('settings_avatar') }}">
<img src='{{ user_avatar }}' alt="Your avatar." class="icon icon-avatar">
</a>
<a href="{{ path('settings_personal_info') }}">
<div class="info">
<b id="nick">{{ user_nickname }}</b>
<div class="tags">
{% if user_tags %}
{% for tag in user_tags %}
<a href='#'><i> #{{ tag }} </i></a>
{% endfor %}
{% else %}
<i> {{ '(No tags)' | trans }} </i>
{% endif %}
</div>
<div class="stats">
<span> <b> {{ user_followers }} </b> {{ 'Followers' | trans }} </span>
<span> <b> {{ user_followed }} </b> {{ 'Followed' | trans }} </span>
</div>
</div>
</a>
<a href="{{ path('settings_personal_info') }}"
class='hover-effect {{ active('settings_') }}'>Settings</a>
<a href='{{ path('logout') }}'>Logout</a>
</div>
<div class="footer">
<a href="{{ path('doc_faq') }}" class='hover-effect {{ active('doc_faq') }}'>FAQ</a>
<a href="{{ path('doc_tos') }}" class='hover-effect {{ active('doc_tos') }}'>TOS</a>
<a href="{{ path('doc_privacy') }}" class='hover-effect {{ active('doc_privacy') }}'>Privacy</a>
<a href="{{ path('doc_source') }}" class='hover-effect {{ active('doc_source') }}'>Source</a>
<a href="{{ path('doc_version') }}" class='hover-effect {{ active('doc_version') }}'>Version</a>
</div>
<a href='#'>Messages</a>
<a href="{{ path("replies", {'nickname' : user_nickname}) }}"
class='hover-effect {{ active("replies") }}'>Replies</a>
{% for link in handle_event('InsertLeftPanelLink', user_nickname) %}
{{ link | raw }}
{% endfor %}
<a href="{{ path('settings_personal_info') }}"
class='hover-effect {{ active('settings_') }}'>Settings</a>
<a href='{{ path('logout') }}'>Logout</a>
</div>
<div class="footer">
<a href="{{ path('doc_faq') }}" class='hover-effect {{ active('doc_faq') }}'>FAQ</a>
<a href="{{ path('doc_tos') }}" class='hover-effect {{ active('doc_tos') }}'>TOS</a>
<a href="{{ path('doc_privacy') }}" class='hover-effect {{ active('doc_privacy') }}'>Privacy</a>
<a href="{{ path('doc_source') }}" class='hover-effect {{ active('doc_source') }}'>Source</a>
<a href="{{ path('doc_version') }}" class='hover-effect {{ active('doc_version') }}'>Version</a>
</div>
</div>
</div>
{% else %}
<div id='left-panel'>
<input type="checkbox" id="toggle">
<div class="icon-menu">
<label for="toggle" id='menu'></label>
</div>
<div class='navbar'>
<div class="left-nav">
<a href="{{ path('login') }}" class='hover-effect {{ active('login') }}'>Login</a>
<a href="{{ path('register') }}">Register</a>
</div>
<div class="footer">
<a href="{{ path('doc_faq') }}" class='hover-effect {{ active('doc_faq') }}'>FAQ</a>
<a href="{{ path('doc_tos') }}" class='hover-effect {{ active('doc_tos') }}'>TOS</a>
<a href="{{ path('doc_privacy') }}" class='hover-effect {{ active('doc_privacy') }}'>Privacy</a>
<a href="{{ path('doc_source') }}" class='hover-effect {{ active('doc_source') }}'>Source</a>
<a href="{{ path('doc_version') }}" class='hover-effect {{ active('doc_version') }}'>Version</a>
{% else %}
<div id='left-panel'>
<div class='navbar'>
<div class="left-nav">
<a href="{{ path('login') }}" class='hover-effect {{ active('login') }}'>Login</a>
<a href="{{ path('register') }}">Register</a>
</div>
<div class="footer">
<a href="{{ path('doc_faq') }}" class='hover-effect {{ active('doc_faq') }}'>FAQ</a>
<a href="{{ path('doc_tos') }}" class='hover-effect {{ active('doc_tos') }}'>TOS</a>
<a href="{{ path('doc_privacy') }}" class='hover-effect {{ active('doc_privacy') }}'>Privacy</a>
<a href="{{ path('doc_source') }}" class='hover-effect {{ active('doc_source') }}'>Source</a>
<a href="{{ path('doc_version') }}" class='hover-effect {{ active('doc_version') }}'>Version</a>
</div>
</div>
</div>
</div>
{% endif %}
{% endif %}
</details>

View File

@ -1,61 +1,60 @@
<div id="right-panel">
<input type="checkbox" id="toggle-right" class="larger">
<div class="arrow right">
<label for="toggle-right" id='right-panel'></label>
</div>
<div id='right-container'>
{% if post_form is defined %}
{{ form_start(post_form) }}
<div class="create-notice">
<div class="target">
<div class="target-top">
{{ form_label(post_form.to) }}
</div>
<div class="target-bot">
{{ form_widget(post_form.to) }}
</div>
</div>
<div class="create-right">
<div class="create-top-right">
<div class="scope">
{{ form_row(post_form.visibility) }}
<details>
<summary>{{ icon('menu', 'icon icon-right') | raw }}</summary>
<div id="right-panel">
<div id='right-container'>
{% if post_form is defined %}
{{ form_start(post_form) }}
<div class="create-notice">
<div class="target">
<div class="target-top">
{{ form_label(post_form.to) }}
</div>
<div class="tabs">
{% for tab in tabs %}
<a href={{ path(tab['href']) }}>{{ tab['title'] }}</a>
{% endfor %}
<div class="target-bot">
{{ form_widget(post_form.to) }}
</div>
</div>
<div class="input-wrapper">
<div class="content-input">
{{ form_row(post_form.content) }}
<div class="create-right">
<div class="create-top-right">
<div class="scope">
{{ form_row(post_form.visibility) }}
</div>
<div class="tabs">
{% for tab in tabs %}
<a href={{ path(tab['href']) }}>{{ tab['title'] }}</a>
{% endfor %}
</div>
</div>
</div>
<div class="notice-options">
<div class="attachments">
{{ form_widget(post_form.attachments) }}
<label for="{{ post_form.attachments.vars.id }}">
{{ icon('attach', 'icon icon-attach') | raw }}
</label>
<div class="input-wrapper">
<div class="content-input">
{{ form_row(post_form.content) }}
</div>
</div>
<div class="post">
{{ form_row(post_form.post) }}
<div class="notice-options">
<div class="attachments">
{{ form_widget(post_form.attachments) }}
<label for="{{ post_form.attachments.vars.id }}">
{{ icon('attach', 'icon icon-attach') | raw }}
</label>
</div>
<div class="post">
{{ form_row(post_form.post) }}
</div>
</div>
</div>
</div>
</div>
{{ form_end(post_form) }}
{% endif %}
{{ form_end(post_form) }}
{% endif %}
{% set current_path = app.request.get('_route') %}
{% if right_panel_vars is defined %}
{% for block in handle_event('AppendRightPanelBlock', {'path': current_path, 'vars': right_panel_vars}) %}
{{ block | raw }}
{% endfor %}
{% else %}
{% for block in handle_event('AppendRightPanelBlock', {'path': current_path}) %}
{{ block | raw }}
{% endfor %}
{% endif %}
{% set current_path = app.request.get('_route') %}
{% if right_panel_vars is defined %}
{% for block in handle_event('AppendRightPanelBlock', {'path': current_path, 'vars': right_panel_vars}) %}
{{ block | raw }}
{% endfor %}
{% else %}
{% for block in handle_event('AppendRightPanelBlock', {'path': current_path}) %}
{{ block | raw }}
{% endfor %}
{% endif %}
</div>
</div>
</div>
</details>