[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 Hugo Sales
parent ee3ed5f096
commit 3812a2d04d
Signed by: someonewithpc
GPG Key ID: 7D0C7EAFC9D835A0
20 changed files with 230 additions and 2969 deletions

View File

@ -1,27 +1,31 @@
:root { :root {
/* fonts */ /* FONTS */
--display-font: 'Manrope-ExtraBold', sans-serif; --display-font: 'Manrope-ExtraBold', sans-serif;
--main-font: 'Inter', sans-serif; --main-font: 'Inter', sans-serif;
/* font and margin sizes */ /* UNITS
--unit-size-h: calc(100vh / 9); * unit size - every element should be a multiplier of this
--unit-size-w: calc(100vw / 9); * 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; --main-size: 1.5rem;
--medium-size: 1.125rem; --medium-size: 1.125rem;
--small-size: 1rem; --small-size: 1rem;
/* colours and shadows */ /* colours and shadows */
--fg: #eceff4; --black: #040506;
--accent: #81a1c1; --bg1: #383E51;
--accent-low: #81a1c160; --bg2: #434A60;
--bg-trans1: rgba(46, 52, 64, 0.42); --bg3: #5C6684;
--bg-trans2: rgba(46, 52, 64, 0.21); --white: #EEDFD4;
--bg1: #2e3440;
--bg2: #3b4252; --accent-blue: #8E8DBE;
--bg3: #434c5e; --accent-red: #FF6666;
--bg4: #4c566a; --accent-green: #2EC4B6;
--bg5: #d8dee9;
--shadow: 0px 0px 20px 0px rgba(46,52,64,0.95); --shadow: 0px 0px 16px 0px #383E51;
} }
/* TYPOGRAPHY */ /* TYPOGRAPHY */
@ -67,27 +71,6 @@ p {
text-transform: none; 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 { ul {
text-decoration: none; text-decoration: none;
margin: 0; margin: 0;
@ -103,89 +86,73 @@ li {
a:link { a:link {
text-decoration: none; text-decoration: none;
outline: 0; outline: 0;
color: var(--fg); color: var(--bg3);
} }
a:visited { a:visited {
outline: 0; outline: 0;
color: var(--fg); color: var(--bg3);
margin: 0; margin: 0;
padding: 0; padding: 0;
} }
a:hover { a:hover {
color: var(--fg); color: var(--accent-blue);
transition: all 0.8s ease; transition: all 0.8s ease;
} }
a:focus { a:focus {
color: var(--fg); color: var(--accent-blue);
transition: all 0.8s ease; transition: all 0.8s ease;
} }
/* HEADER */ /* DEFAULTS */
#header { body,
position: fixed; html {
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;
height: 100%; height: 100%;
width: auto;
color: var(--white);
/* PARENT HAS NO POINTER EVENTS */ /* BLENDING BANDING IN FIREFOX */
pointer-events: all; /* 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 { #header {
display: none; display: flex;
width: var(--main-size); justify-content: center;
height: var(--main-size); position: fixed;
stroke: currentColor; pointer-events: none;
fill: currentColor;
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 { #instance {
order: 1;
font-size: var(--main-size);
display: flex; 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-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 { .icon-logo {
margin-right: 5px; margin-right: var(--small-size);
stroke-width: 0; fill: var(--white);
stroke: currentColor;
fill: var(--fg);
vertical-align: middle;
} }
#panels { .navigation {
order: 2; padding-top: calc(2 * var(--small-size) + var(--main-size));
display: flex;
} }

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 { .icon-left {
border-radius: 50%; position: fixed;
width: var(--main-size); top: 0;
} left: 0;
padding: calc(3 * var(--unit-size));
/* left panel z-index fix */ width: var(--main-size);
.form { height: auto;
position: relative;
z-index: 0;
}
#header {
z-index: 1;
}
/* CHECKBOX TRICK */ fill: var(--white);
.icon-menu label { stroke-width: 0;
opacity: 0; vertical-align: middle;
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);
} }

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 { .icon-right {
display: flex;
flex-direction: column;
position: fixed; position: fixed;
top: 0;
right: 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); width: var(--main-size);
height: var(--main-size); height: auto;
font-size: var(--medium-size);
fill: var(--fg);
cursor: pointer;
}
#replyform { fill: var(--white);
margin: var(--small-size); stroke-width: 0;
} vertical-align: middle;
#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;
}

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

View File

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

View File

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

View File

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