diff --git a/public/css/account.less b/public/css/account.less
new file mode 100644
index 0000000000..0867d35720
--- /dev/null
+++ b/public/css/account.less
@@ -0,0 +1,86 @@
+
+.account {
+ .topic-row {
+ width: 100%;
+ }
+}
+
+.favourites {
+ .topic-row {
+ width: 100%;
+ margin-bottom: 10px;
+ }
+}
+
+
+.account-username-box{
+ border-bottom:1px solid #e3e3e3;
+ margin-bottom:10px;
+}
+
+.account-sub-links a{
+ margin-left:10px;
+}
+
+
+.account-block {
+ div {
+ padding-bottom:10px;
+ }
+}
+
+.account-picture-block{
+ display:inline-block;
+ vertical-align:top;
+}
+
+.account-online-status {
+ .icon-circle-blank {
+ color:red;
+ }
+ .icon-circle {
+ color:green;
+ }
+}
+
+.user-profile-picture {
+ width:128px;
+}
+
+.user-picture-label {
+ font-size:20px;
+}
+
+.account-bio-block{
+ display:inline-block;
+ vertical-align:top;
+}
+
+.account-bio-label{
+ display:inline-block;
+ width:100px;
+}
+
+
+.account-username{
+ font-size:20px;
+ font-weight:bold;
+}
+
+
+
+.user-recent-posts {
+ div {
+ color: #333;
+ margin-bottom: 10px;
+ .pointer;
+ overflow:hidden;
+ p {
+ color: #333;
+ }
+ }
+
+ span {
+ padding-top: 10px;
+ }
+}
diff --git a/public/css/admin.less b/public/css/admin.less
index 9cb477f08e..a3b4616261 100644
--- a/public/css/admin.less
+++ b/public/css/admin.less
@@ -13,41 +13,29 @@
}
.admin-categories {
+ margin-top: 20px;
form {
margin: 0 0 0px;
}
- input {
- height: 20px;
- padding: 5px;
- margin-left: 10px;
+ input, select {
width: 150px;
- border: 0;
- border-radius: 5px;
- margin-top: -8px;
}
-
+
.category_description {
width: 300px;
}
- select {
- border: 0;
- margin-left: 10px;
- padding: 5px;
- margin-top: -8px;
- }
-
- button {
- margin-top: -7px;
- }
-
.icon{
width: 30px;
height: 30px;
text-align: center;
- line-height: 35px;
+ line-height: 40px;
display: inline-block;
+ margin: 0 5px 0 5px;
+ i {
+ vertical-align: -20%;
+ }
}
}
@@ -119,11 +107,11 @@
.icon-container {
.row {
margin: 0;
- .span3 {
+ .col-md-3 {
width: 20px;
height: 20px;
margin: 1px;
- cursor: pointer;
+ .pointer;
line-height: 20px;
text-align: center;
@@ -154,4 +142,18 @@
}
}
}
+}
+
+
+
+#admin-redis-info {
+ span {
+ display:inline-block;
+ width:220px;
+ }
+}
+
+.fa-icons .col-md-3 {
+ padding-left: 0;
+ padding-right: 0;
}
\ No newline at end of file
diff --git a/public/css/category.less b/public/css/category.less
index 4df36256c1..6894a99253 100644
--- a/public/css/category.less
+++ b/public/css/category.less
@@ -4,11 +4,14 @@
margin-bottom: 50px;
}
+ > .col-md-12 {
+ padding-right: 30px;
+ }
+
a {
li {
list-style: none;
//border-bottom: 1px solid #eee;
- margin-bottom: 10px;
padding-bottom: 10px;
&.deleted {
@@ -23,7 +26,7 @@
}
ul {
- margin-left: 0;
+ margin-left: -25px;
}
.thread-rating {
@@ -38,7 +41,7 @@
}
- @media (max-width: 1200px)
+ @media (max-width: 1200px)
{
margin-left: -1px;
}
@@ -48,9 +51,14 @@
}
.topic-row {
+
+ &.col-md-12 {
+ margin-right: 11px;
+ }
+
border-radius: 5px;
- padding-left: 20px;
- border: 1px solid rgba(0, 0, 0, 0.2);
+ padding: 5px 5px 5px 20px;
+ border: 1px solid rgba(0, 0, 0, 0.15);
small {
vertical-align: 2px;
@@ -81,18 +89,10 @@
margin-right: 6px;
}
- @media (max-width: 979px)
- {
- width: 100%;
- }
+
}
}
- @media (max-width: 979px)
- {
- width: 100%;
- margin-left: 0px;
- }
}
@@ -107,9 +107,8 @@
height: 50px;
line-height: 16px;
margin-left: 1px;
- padding: 5px;
+ padding: 2px 5px 5px 20px;
border-left: 1px solid #bbb;
- padding-left: 20px;
img {
display: block;
@@ -150,7 +149,7 @@
li {
clear: both;
- line-height: 16px;
+ line-height: 17px;
margin-bottom: 1em;
&:last-child {
@@ -163,18 +162,17 @@
}
p {
display: block;
- padding-left:5px;
- padding-top: 2px;
+ padding-left: 8px;
overflow: hidden;
- height: 32px;
- margin-bottom: 0.5em;
+ height: 35px;
+ margin-bottom: 0;
}
span {
font-size: 12px;
display: block;
overflow: hidden;
height: 16px;
- padding-left:5px;
+ padding-left: 8px;
color: #666;
}
}
@@ -184,6 +182,8 @@
.sidebar-block {
+ display: block;
+
.block-header {
padding: 8px;
padding-left: 13px;
@@ -198,7 +198,7 @@
}
.block-content {
padding: 10px;
- .img-polaroid {
+ .img-rounded {
width: 20%;
height: auto;
max-width: 48px;
@@ -209,7 +209,7 @@
padding: 0;
margin-bottom: 20px;
- .img-polaroid {
+ .img-rounded {
margin-top: 2px;
}
diff --git a/public/css/header.less b/public/css/header.less
new file mode 100644
index 0000000000..055de41461
--- /dev/null
+++ b/public/css/header.less
@@ -0,0 +1,130 @@
+
+#user_label { //belongs in header.less
+ img {
+ border: 1px solid #454;
+ margin-right: 8px;
+ margin-top: -2px;
+ float: left;
+ width:24px;
+ height:24px;
+ }
+
+ span {
+ font-size: 14px;
+ font-weight: 400;
+ color: #ded;
+ }
+}
+
+
+
+#pagination {
+ position: absolute;
+ background: rgb(34, 34, 34);
+ right: 0px;
+ top: 50px;
+ color: white;
+ padding: 10px;
+ padding-bottom: 5px;
+ padding-top: 5px;
+ font-size: 15px;
+ display: none;
+}
+
+
+.taskbar {
+ display: none;
+ -moz-opacity: 0.5;
+ opacity: 0.5;
+ margin-top: 0;
+ -webkit-transition: opacity 250ms ease-in;
+ -moz-transition: opacity 250ms ease-in;
+ -ms-transition: opacity 250ms ease-in;
+ -o-transition: opacity 250ms ease-in;
+ transition: opacity 250ms ease-in;
+
+ &[data-active="1"] {
+ display: block;
+ }
+
+ &:hover {
+ -moz-opacity: 1;
+ opacity: 1;
+ }
+
+ li {
+ float: left;
+
+ a > span {
+ .inline-block;
+ max-width: 200px;
+ text-overflow: ellipsis;
+ white-space: nowrap;
+ overflow: hidden;
+ }
+
+ img {
+ max-width: 24px;
+ max-height: 24px;
+ margin-right: 1em;
+ }
+
+ &.pulse {
+ -webkit-animation: pulsate 2500ms linear;
+ -webkit-animation-iteration-count: infinite;
+ }
+
+ @-webkit-keyframes pulsate {
+ 0% { background: none; }
+ 50% { background: #e5e5e5; }
+ 100% { background: none; }
+ }
+ }
+}
+
+#notif-list {
+ li {
+ font-size: 12px;
+ width: 300px;
+ text-align: left;
+
+ a {
+ white-space: normal;
+ }
+
+ &.unread {
+ background: #eceff5;
+ }
+ }
+}
+
+
+
+.dropdown-toggle {
+ i {
+ font-size: 12px;
+
+ @-webkit-keyframes glow
+ {
+ from {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
+ 50% {text-shadow: 0 0 10px #aaf, 0 0 10px #aaf, 0 0 10px #aaf;}
+ to {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
+ }
+ @keyframes glow
+ {
+ from {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
+ 50% {text-shadow: 0 0 10px #aaf, 0 0 10px #aaf, 0 0 10px #aaf;}
+ to {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
+ }
+
+
+ &.active {
+ color: #558;
+
+ text-shadow: 0 0 1em #aaf, 0 0 1em #aaf, 0 0 1em #aaf;
+ -webkit-animation:glow 1.5s infinite linear;
+ animation:glow 1.5s infinite linear;
+ }
+
+ }
+}
diff --git a/public/css/home.less b/public/css/home.less
new file mode 100644
index 0000000000..4ebc7335bf
--- /dev/null
+++ b/public/css/home.less
@@ -0,0 +1,169 @@
+
+.categories {
+ h4 {
+ font-weight: 700;
+ text-align: left;
+ /*color: #555;*/ // NOTE: color for cat/topic header links should be grey in the default theme when we get around to it.
+ white-space: nowrap;
+ overflow: hidden;
+ text-overflow: ellipsis;
+ }
+ a {
+ text-decoration: none;
+ border: 0;
+ }
+ .icon {
+ width: 100%;
+ height: 110px;
+ text-align: center;
+ border-radius: 0px;
+ margin: 0;
+ padding-top:25px;
+ .pointer;
+ margin-bottom: 20px;
+ border-radius: 5px;
+ overflow:hidden;
+ }
+
+}
+
+.category-purple {
+ @color: #ab1290;
+ background: @color;
+ color: white;
+
+ &:hover {
+ background: lighten(@color, 10%);
+ }
+}
+
+.category-darkblue {
+ @color: #004C66;
+ background: @color;
+ color: white;
+
+ &:hover {
+ background: lighten(@color, 10%);
+ }
+}
+
+.category-blue {
+ @color: #0059B2;
+ background: @color;
+ color: white;
+
+ &:hover {
+ background: lighten(@color, 10%);
+ }
+}
+
+.category-darkgreen {
+ @color: #004000;
+ background: @color;
+ color: white;
+
+ &:hover {
+ background: lighten(@color, 10%);
+ }
+}
+
+.category-orange {
+ @color: #FF7A4D;
+ color: white;
+ background: @color;
+
+ &:hover {
+ background: lighten(@color, 10%);
+ }
+}
+
+
+.category-box {
+ height:90px;
+
+ .post-preview {
+ padding-left:10px;
+ padding-right:10px;
+ text-align:left;
+ img {
+ width:60px;
+ height:60px;
+ padding-right:5px;
+ }
+
+ p {
+ overflow: hidden;
+ text-overflow:ellipsis;
+ height:60px;
+ }
+ }
+}
+
+@-webkit-keyframes scroll-2 /* Safari and Chrome */
+{
+ 0% {top: 0px;}
+ 25% {top: -90px;}
+ 50% {top: -180px;}
+ 75% {top: -270px;}
+ 100% {top: -360px;}
+}
+
+@keyframes scroll-2
+{
+ 0% {top: 0px;}
+ 25% {top: -90px;}
+ 50% {top: -180px;}
+ 75% {top: -270px;}
+ 100% {top: -360px;}
+}
+
+@-webkit-keyframes scroll-1 /* Safari and Chrome */
+{
+ 0% {top: 0px;}
+ 33% {top: -90px;}
+ 66% {top: -180px;}
+ 100% {top: -270px;}
+}
+
+@keyframes scroll-1
+{
+ 0% {top: 0px;}
+ 33% {top: -90px;}
+ 66% {top: -180px;}
+ 100% {top: -270px;}
+}
+
+@-webkit-keyframes scroll-0 /* Safari and Chrome */
+{
+ 0% {top: 0px;}
+ 50% {top: -90px;}
+ 100% {top: -180px;}
+}
+
+@keyframes scroll-0
+{
+ 0% {top: 0px;}
+ 50% {top: -90px;}
+ 100% {top: -180px;}
+}
+
+.category-slider-2:hover {
+ position:relative;
+
+ -webkit-animation: scroll-2 10s ease 0.5s infinite normal;
+ animation: scroll-2 10s ease 0.5s infinite normal;/* Safari and Chrome: */
+}
+
+.category-slider-1:hover {
+ position:relative;
+
+ -webkit-animation: scroll-1 8s ease 0.5s infinite normal;
+ animation: scroll-1 8s ease 0.5s infinite normal;/* Safari and Chrome: */
+}
+
+.category-slider-0:hover {
+ position:relative;
+
+ -webkit-animation: scroll-0 6s ease 0.5s infinite normal;
+ animation: scroll-0 6s ease 0.5s infinite normal;/* Safari and Chrome: */
+}
diff --git a/public/css/nodebb.less b/public/css/nodebb.less
index 78c464f8b4..2977bdfe56 100644
--- a/public/css/nodebb.less
+++ b/public/css/nodebb.less
@@ -2,4 +2,11 @@
@import "topic";
@import "category";
-@import "noscript";
\ No newline at end of file
+@import "noscript";
+@import "home";
+@import "header";
+@import "account";
+@import "search";
+@import "unread";
+@import "admin";
+@import "users";
\ No newline at end of file
diff --git a/public/css/search.less b/public/css/search.less
new file mode 100644
index 0000000000..9f553a8bc4
--- /dev/null
+++ b/public/css/search.less
@@ -0,0 +1,18 @@
+
+.search-result-post {
+ width: 100%;
+ line-height: 16px;
+ padding: 5px;
+ overflow:hidden;
+ img {
+ display: block;
+ float: left;
+ width:48px;
+ height:48px;
+ margin-right:10px;
+ }
+}
+
+.category.search #topics-container {
+ margin-left: -38px;
+}
\ No newline at end of file
diff --git a/public/css/style.less b/public/css/style.less
index 961d0e00ce..d3697fdb95 100644
--- a/public/css/style.less
+++ b/public/css/style.less
@@ -7,10 +7,10 @@ html {
body {
/*background: #fdfdfd;*/ // port to default theme when it is implemented.
-webkit-transition: margin-bottom 250ms ease;
- -moz-transition: margin-bottom 250ms ease;
- -ms-transition: margin-bottom 250ms ease;
- -o-transition: margin-bottom 250ms ease;
- transition: margin-bottom 250ms ease;
+ -moz-transition: margin-bottom 250ms ease;
+ -ms-transition: margin-bottom 250ms ease;
+ -o-transition: margin-bottom 250ms ease;
+ transition: margin-bottom 250ms ease;
&.composing {
margin-bottom: 350px;
@@ -23,6 +23,7 @@ body {
@media (max-width: 979px)
{
+ padding-top: 70px;
padding-bottom: 50px;
}
}
@@ -38,13 +39,19 @@ button, a {
.block, .show {
display: block;
}
-.badge {
- vertical-align: 17%;
+
+.bold {
+ font-weight: bold;
}
-.nav .badge {
- vertical-align: 2%;
+
+a:hover, .btn-link:hover, .btn-link:active, .btn-link:focus {
+ text-decoration:none;
}
+
+
+
+
#alert_window {
position: fixed;
right: 20px;
@@ -54,8 +61,7 @@ button, a {
}
.toaster-alert {
-
- cursor: pointer;
+ .pointer;
}
footer.footer {
@@ -67,77 +73,6 @@ footer.footer {
}
}
-#post_window {
- width: 100%;
- position: fixed;
- height: 350px;
- left: 0px;
- bottom: 0px;
- background: white;
- z-index: 1500;
-
- input {
- width: 100%;
- height: 30px;
- padding: 5px;
- }
-
- textarea {
- width: 100%;
- background: #222;
- height: 220px;
- resize: none;
- border-radius: 0;
- border: 1px solid #111;
- font-size: 16px;
- color: #bebebe;
- outline: 0;
-
- &:focus {
- outline: 0;
- border:none !important;
- box-shadow:none !important;
- }
- }
-
- .post-title-container {
- opacity: 0.8;
- height: 50px;
- }
-
- .post-content-container {
- opacity: 0.8;
- background: #000;
- width: 100%;
- height: 300px;
- }
-}
-
-
-
-#user_label { //belongs in header.less
- img {
- border: 1px solid #454;
- margin-right: 8px;
- margin-top: -2px;
- float: left;
- width:24px;
- height:24px;
- }
-
- span {
- font-size: 14px;
- font-weight: 400;
- color: #ded;
- }
-}
-
-#reply_title {
- font-size: 17px;
- padding-top: 14px;
- font-weight: 600;
-}
-
.alt-logins {
margin: 0 0 0 1em;
padding: 0;
@@ -155,10 +90,10 @@ footer.footer {
i {
-webkit-transition: color 100ms linear;
- -moz-transition: color 100ms linear;
- -ms-transition: color 100ms linear;
- -o-transition: color 100ms linear;
- transition: color 100ms linear;
+ -moz-transition: color 100ms linear;
+ -ms-transition: color 100ms linear;
+ -o-transition: color 100ms linear;
+ transition: color 100ms linear;
&.icon-twitter-sign:hover {
color: #4099FF;
@@ -175,208 +110,14 @@ footer.footer {
}
}
-
-#thread_active_users {
- float: right;
- color: rgb(153,153,153);
-
- strong {
- color: rgb(100,100,100);
- font-weight: 600;
- cursor: pointer;
- }
-}
-
-.account-username-box{
- border-bottom:1px solid #e3e3e3;
- margin-bottom:10px;
-}
-
-.account-sub-links a{
- margin-left:10px;
-}
-
-.account-username{
- font-size:20px;
- font-weight:bold;
-}
-
-.bold {
- font-weight: bold;
-}
-
-.account-block {
- div {
- padding-bottom:10px;
- }
-}
-
-.account-picture-block{
- display:inline-block;
- vertical-align:top;
-}
-
-.account-online-status {
- .icon-circle-blank {
- color:red;
- }
- .icon-circle {
- color:green;
- }
-}
-
-.user-profile-picture {
- width:128px;
-}
-
-.user-picture-label {
- font-size:20px;
-}
-
-.account-bio-block{
- display:inline-block;
- vertical-align:top;
-}
-
-.account-bio-label{
- display:inline-block;
- width:100px;
-}
-
-.user-recent-posts {
- div {
- color: #333;
- margin-bottom: 10px;
- cursor: pointer;
- overflow:hidden;
- p {
- color: #333;
- }
- }
- span {
- padding-top: 10px;
- }
-}
-
-.category-icon {
- width: 100%;
- height: 90px;
- text-align: center;
- border-radius: 0px;
- margin: 0;
- padding-top:25px;
- cursor: pointer;
- margin-bottom: 20px;
- border-radius: 5px;
- overflow:hidden;
-}
-.category-row h4 {
- font-weight: 700;
- text-align: left;
- /*color: #555;*/ // NOTE: color for cat/topic header links should be grey in the default theme when we get around to it.
- white-space: nowrap;
- overflow: hidden;
- text-overflow: ellipsis;
-}
-.category-row a {
- text-decoration: none;
- border: 0;
-}
-
-.category-purple {
- @color: #ab1290;
- background: @color;
- color: white;
-
- &:hover {
- background: lighten(@color, 10%);
- }
-}
-
-.category-darkblue {
- @color: #004C66;
- background: @color;
- color: white;
-
- &:hover {
- background: lighten(@color, 10%);
- }
-}
-
-.category-blue {
- @color: #0059B2;
- background: @color;
- color: white;
-
- &:hover {
- background: lighten(@color, 10%);
- }
-}
-
-.category-darkgreen {
- @color: #004000;
- background: @color;
- color: white;
-
- &:hover {
- background: lighten(@color, 10%);
- }
-}
-.category-orange {
- @color: #FF7A4D;
- color: white;
- background: @color;
-
- &:hover {
- background: lighten(@color, 10%);
- }
-}
-
-.category-list {
- li {
- .inline-block;
- .pointer;
- padding: 0.5em 0;
- text-align: center;
- margin: 0.5em;
- -webkit-border-radius: 5px;
- -moz-border-radius: 5px;
- border-radius: 5px;
- padding: 0.5em;
- }
-}
-
-.hero-unit {
+.jumbotron {
+ // goes into theme
background: #56BCDA;
color: white;
padding: 30px;
word-wrap: break-word;
}
-.users-box{
- display: inline-block;
- margin-top: 20px;
- text-align: center;
- vertical-align: top;
- max-width: 104px;
- white-space: nowrap;
- text-overflow: ellipsis;
- overflow: hidden;
-
- img {
- width:80px;
- height:80px;
- }
-
- a {
- margin:5px;
- }
-}
-
-a:hover, .btn-link:hover, .btn-link:active, .btn-link:focus {
- text-decoration:none;
-}
-
.formatting-bar {
.no-select;
@@ -395,159 +136,27 @@ a:hover, .btn-link:hover, .btn-link:active, .btn-link:focus {
}
}
-body .navbar .nodebb-inline-block {
- display:inline-block;
-}
-
#right-menu{
float:right;
}
-#admin-redis-info {
- span {
- display:inline-block;
- width:220px;
- }
-}
-
-.post-signature {
- color: #666;
- font-size: 12px;
- border-top: 1px solid #ddd;
- display: inline-block;
-
- img {
- max-width:200px;
- max-height:60px;
- }
-}
-
-.username-field {
- .icon-circle {
- font-size: 12px;
- color: green;
- margin-right:3px;
- }
- .icon-circle-blank {
- font-size: 12px;
- color: red;
- margin-right:3px;
- }
-}
-
#chat-content {
- width:95%;
height:200px;
resize:none;
}
-#chat-message-input {
- width:95%;
-}
-
#content{
- padding-bottom:20px;
-}
-
-
-.dropdown-toggle {
- i {
- font-size: 12px;
-
- @-webkit-keyframes glow
- {
- from {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
- 50% {text-shadow: 0 0 10px #aaf, 0 0 10px #aaf, 0 0 10px #aaf;}
- to {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
- }
- @keyframes glow
- {
- from {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
- 50% {text-shadow: 0 0 10px #aaf, 0 0 10px #aaf, 0 0 10px #aaf;}
- to {text-shadow: 0 0 5px #aaf, 0 0 5px #aaf, 0 0 5px #aaf;}
- }
-
-
- &.active {
- color: #558;
-
- text-shadow: 0 0 1em #aaf, 0 0 1em #aaf, 0 0 1em #aaf;
- -webkit-animation:glow 1.5s infinite linear;
- animation:glow 1.5s infinite linear;
- }
-
- }
-}
-
-#notif-list {
- li {
- font-size: 12px;
- width: 300px;
- text-align: left;
-
- a {
- white-space: normal;
- }
-
- &.unread {
- background: #eceff5;
- }
- }
+ padding-bottom:20px;
}
-.taskbar {
- display: none;
- -moz-opacity: 0.5;
- opacity: 0.5;
- margin-top: 0;
- -webkit-transition: opacity 250ms ease-in;
- -moz-transition: opacity 250ms ease-in;
- -ms-transition: opacity 250ms ease-in;
- -o-transition: opacity 250ms ease-in;
- transition: opacity 250ms ease-in;
-
- &[data-active="1"] {
- display: block;
- }
-
- &:hover {
- -moz-opacity: 1;
- opacity: 1;
- }
-
- li {
- a > span {
- .inline-block;
- max-width: 200px;
- text-overflow: ellipsis;
- white-space: nowrap;
- overflow: hidden;
- }
-
- img {
- max-width: 24px;
- max-height: 24px;
- margin-right: 1em;
- }
-
- &.pulse {
- -webkit-animation: pulsate 2500ms linear;
- -webkit-animation-iteration-count: infinite;
- }
-
- @-webkit-keyframes pulsate {
- 0% { background: none; }
- 50% { background: #e5e5e5; }
- 100% { background: none; }
- }
- }
-}
+/* START: post-window needs to go in its own plugin area */
.post-window {
position: fixed;
display: none;
height: 350px;
visibility: hidden;
+ width: 100%;
> div {
position: absolute;
@@ -645,245 +254,29 @@ body .navbar .nodebb-inline-block {
}
}
}
+/* END: post-window needs to go in its own plugin area */
-#mobile-menu {
- position: fixed;
- bottom: 0px;
- height: 50px;
- background: #333;
- width: 100%;
- left: 0px;
-}
-
-#mobile-menu, #mobile-menu-overlay {
- z-index: 999;
- @media (min-width: 979px)
- {
+//START: FIXES FOR BS3, may need to remove these when we get out of the RC releases
+@media (max-width: 979px) {
+ .hidden-mobile {
+ // BS2/3's hidden-xs does not support inline-block, so here it is for now.
display: none !important;
}
}
-
-.btn-none,
-.btn-none:active,
-.btn-none[disabled] {
- background-color: transparent;
- background-image: none;
- -webkit-box-shadow: none;
- -moz-box-shadow: none;
- box-shadow: none;
+.container > .navbar-header, .container > .navbar-collapse {
+ padding-right: 0;
+ margin-right: -11px;
}
-.btn-none {
- cursor: pointer;
- border-color: transparent;
- -webkit-border-radius: 0;
- -moz-border-radius: 0;
- border-radius: 0;
-}
-
-.btn-none:hover,
-.btn-none:focus {
- text-decoration: none;
- background-color: transparent;
-}
-
-.btn-none[disabled]:hover,
-.btn-none[disabled]:focus {
- text-decoration: none;
-}
-
-.btn-none {
- .icon-white {
- color: white;
- }
-}
-
-#mobile-menu {
- button {
- color: #eee;
- padding: 10px;
- text-shadow: none;
- -webkit-tap-highlight-color: rgba(0,0,0,0);
- }
-}
-
-#mobile-menu-overlay {
-
- background: rgba(0, 0, 0, 0.85);
- position: fixed;
- top: 0px;
- left: 0px;
- height: 100%;
- width: 100%;
- //margin-top: 50px;
- padding-top: 20px;
- opacity: 0;
-
- -webkit-transition: opacity 150ms ease;
- -moz-transition: opacity 150ms ease;
- -ms-transition: opacity 150ms ease;
- -o-transition: opacity 150ms ease;
- transition: opacity 150ms ease;
- z-index: -1;
- &.menu-visible {
- z-index: 99;
- opacity: 1;
- }
-
- .mobile-menu-icon {
- color: white;
- width: 20%;
- min-width: 85px;
- height: auto;
- text-align: center;
- padding: 10px;
- display: inline-block;
- cursor: pointer;
- -webkit-tap-highlight-color: rgba(0,0,0,0);
-
- -webkit-transition: margin-top 250ms ease;
- -moz-transition: margin-top 250ms ease;
- -ms-transition: margin-top 250ms ease;
- -o-transition: margin-top 250ms ease;
- transition: margin-top 250ms ease;
-
- margin-top: 20%;
-
-
- &.menu-visible {
- margin-top: 0%;
- }
-
- i {
- width: 100%;
- }
-
- }
-}
-
-#mobile-sidebar {
- height: 100%;
- position: absolute;
- left: 100%;
- top: 0px;
- overflow: hidden;
- margin-top: 60px;
-}
-
-.category-box {
- height:90px;
-
- .post-preview {
- padding-left:10px;
- padding-right:10px;
- text-align:left;
- img {
- width:60px;
- height:60px;
- padding-right:5px;
- }
-
- p {
- overflow: hidden;
- text-overflow:ellipsis;
- height:60px;
- }
- }
-}
-
-#mark-allread-btn {
- margin-bottom:15px;
-}
-
-@-webkit-keyframes scroll-2 /* Safari and Chrome */
-{
- 0% {top: 0px;}
- 25% {top: -90px;}
- 50% {top: -180px;}
- 75% {top: -270px;}
- 100% {top: -360px;}
-}
-
-@keyframes scroll-2
-{
- 0% {top: 0px;}
- 25% {top: -90px;}
- 50% {top: -180px;}
- 75% {top: -270px;}
- 100% {top: -360px;}
-}
-
-@-webkit-keyframes scroll-1 /* Safari and Chrome */
-{
- 0% {top: 0px;}
- 33% {top: -90px;}
- 66% {top: -180px;}
- 100% {top: -270px;}
-}
-
-@keyframes scroll-1
-{
- 0% {top: 0px;}
- 33% {top: -90px;}
- 66% {top: -180px;}
- 100% {top: -270px;}
-}
-
-@-webkit-keyframes scroll-0 /* Safari and Chrome */
-{
- 0% {top: 0px;}
- 50% {top: -90px;}
- 100% {top: -180px;}
-}
-
-@keyframes scroll-0
-{
- 0% {top: 0px;}
- 50% {top: -90px;}
- 100% {top: -180px;}
-}
-
-.category-slider-2:hover {
- position:relative;
-
- -webkit-animation: scroll-2 10s ease 0.5s infinite normal;
- animation: scroll-2 10s ease 0.5s infinite normal;/* Safari and Chrome: */
-}
-
-.category-slider-1:hover {
- position:relative;
-
- -webkit-animation: scroll-1 8s ease 0.5s infinite normal;
- animation: scroll-1 8s ease 0.5s infinite normal;/* Safari and Chrome: */
-}
-
-.category-slider-0:hover {
- position:relative;
-
- -webkit-animation: scroll-0 6s ease 0.5s infinite normal;
- animation: scroll-0 6s ease 0.5s infinite normal;/* Safari and Chrome: */
+.badge {
+ vertical-align: 17%;
}
-.form-search {
- float: left;
- margin-top: 5px;
- margin-bottom: 5px;
+.modal {
+ overflow-y: hidden;
}
-.search-result-post {
- width: 100%;
- line-height: 16px;
- padding: 5px;
- overflow:hidden;
- img {
- display: block;
- float: left;
- width:48px;
- height:48px;
- padding-right:10px;
- }
-
-}
\ No newline at end of file
+//END: FIXES FOR BS3, may need to remove these when we get out of the RC releases
\ No newline at end of file
diff --git a/public/css/topic.less b/public/css/topic.less
index ed3621d4f2..87664861cc 100644
--- a/public/css/topic.less
+++ b/public/css/topic.less
@@ -1,21 +1,11 @@
-.post-container {
+.topic {
list-style-type: none;
padding: 0;
margin: 0;
clear: both;
- .profile-image-block {
- display: inline-block;
- text-align: center;
- font-size: 12px;
-
- .stats {
- clear: both;
- }
- }
-
- li {
+ li.row {
padding-bottom: 15px;
&.deleted {
@@ -31,8 +21,19 @@
}
}
+ .chat {
+ display: block;
+ padding: 3px 20px;
+ clear: both;
+ .pointer;
+ }
+ .chat:hover, .chat:focus {
+ color: white;
+ background-color: rgb(66, 139, 202);
+ }
+
.profile-block, .post-block {
- position:relative;
+ position: relative;
border: 1px solid rgba(0, 0, 0, 0.06);
border-radius: 5px;
padding: 10px;
@@ -42,29 +43,33 @@
}
}
+ .post-signature {
+ color: #666;
+ font-size: 12px;
+ border-top: 1px solid #ddd;
+ display: inline-block;
+
+ img {
+ max-width:200px;
+ max-height:60px;
+ }
+
+ margin-left: 5px;
+ }
+
.profile-block {
background: rgba(0, 0, 0, 0.02);
- margin-right: -11px;
- margin-left: -11px;
- margin-bottom: -11px;
- margin-top: 15px;
+ margin: 15px -11px -11px -11px;
border-radius: 0 0 5px 5px;
font-size: 10px;
- line-height: 18px;
- padding: 5px;
- padding-left: 10px;
-
- img.hidden-desktop {
- max-width: 10px;
- max-height: 10px;
- padding-top: 5px;
- margin-right: 5px;
-
- }
+ line-height: 15px;
+ padding: 5px 8px 5px 5px;
+ color: #777;
}
+
.post-content {
min-height: 50px;
- padding: 2px 5px 0 5px;
+ padding: 10px 5px 0 5px;
word-wrap: break-word;
}
@@ -74,50 +79,28 @@
.post-block {
.post-buttons {
- font-size: 12px;
- float: right;
- margin-right: 5px;
-
- button, a {
- display: inline-block;
- padding: 0px 15px;
- border: none;
- border-left: 1px solid rgba(0, 0, 0, 0.06);
- cursor: pointer;
- background: none;
- font-size: 12px;
- height: 20px;
-
- &:last-child {
- padding-right: 5px;
- }
+ background: rgba(0, 0, 0, 0.02);
+ border: 1px solid rgba(0, 0, 0, 0.06);
+ margin: -5px 0 0 0;
+ padding: 8px 0 0 23px;
+
+ button.show {
+ display: inline-block !important;
}
- .icon-star {
- //theme this to make it yellow eventually
+ @media (max-width: 767px) {
+ padding-left: 9px;
}
}
}
-
-
&.deleted {
-moz-opacity: 0.30;
opacity: 0.30;
}
- /*http://stackoverflow.com/questions/11037517/bootstrap-making-responsive-changes-to-layout*/
- @media (max-width: 979px) {
-
-
- .span12-tablet {
- width: 100% !important;
- margin-left:0px;
- *width: 100% !important;
- }
- }
@media (min-width: 979px) {
- .speech-bubble:after
+ .speech-bubble:after
{
content: "";
position: absolute;
@@ -125,13 +108,13 @@
left: -7px;
border-style: solid;
border-width: 7px 7px 7px 0;
- border-color: transparent #FFFFFF;
+ border-color: transparent rgb(250,250,250);
display: block;
width: 0;
z-index: 1;
}
- .speech-bubble:before
+ .speech-bubble:before
{
content: "";
position: absolute;
@@ -146,6 +129,28 @@
}
}
+ .sub-posts {
+ .post-tools {
+ margin-right: 9px;
+ }
+ .post-content {
+ margin-left: 10px;
+ }
+ .post-signature {
+ margin-left: 15px;
+ }
+ .img-thumbnail {
+ padding: 2px;
+ border-radius: 0;
+ margin-left: 16px;
+ }
+ .post-buttons {
+ margin: -11px -10px 0 -10px;
+ border: 0;
+ border-bottom: 1px solid rgba(0, 0, 0, 0.06);
+ }
+ }
+
.main-post {
h3 {
margin: 0;
@@ -153,11 +158,8 @@
.topic-title {
width: auto;
overflow: hidden;
- margin: 0;
- padding: 0;
- padding-top: 5px;
- margin-bottom: -5px;
- padding-bottom: 5px;
+ margin: 0 0 -5px 0;
+ padding: 0 0 5px 0
}
}
@@ -165,62 +167,149 @@
color: white;
position: relative;
float: left;
- margin-right: 25px;
- margin-bottom: 0px;
+ margin: 0 10px 0 0;
padding-bottom: 0px;
text-align: center;
- width:80px;
-
- @media (max-width: 767px) {
+ width:100px;
+
+ @media (max-width: 767px) {
display: none;
}
}
- .main-avatar:hover .hover-overlay {
- opacity: 0.75;
- }
-
- .hover-overlay {
- margin: 5px;
- position: absolute;
- bottom: 0px;
- height: 35px;
- padding-top: 2px;
- width: 80px;
- font-size: 13px;
- line-height: 16px;
- background: #000;
- opacity: 0;
- transition: opacity 0.3s;
+ .img-thumbnail {
+ padding: 2px;
+ border-radius: 0;
}
.post-content {
min-height: 80px;
}
+
hr {
- margin-top: 0;
- margin-right: 10px;
- margin-bottom: 0;
+ margin: 0 10px 0 0;
}
+
.post-block {
.post-buttons {
- div {
- border: 0;
+ button.show {
+ display: inline-block!important;
}
+
}
}
+
.favourite {
- cursor: pointer;
+ .pointer;
}
.btn {
display: inline-block;
}
- .topic-buttons {
- margin-top: 8px;
+ .topic-buttons { //main-post version is called post-buttons, needs to be consolidated.
+ background: rgba(0, 0, 0, 0.02);
+ border: 1px solid rgba(0, 0, 0, 0.06);
+ margin: 0 -11px 0 92px;
+ padding: 10px;
+ border-right: 0;
+
+ @media (max-width: 767px) {
+ margin-left: -11px;
+ border-left: 0;
+ }
+
+ button.show {
+ display: inline-block!important;
+ }
+ }
+
+ }
+
+ .topic-main-buttons {
+ @media (max-width: 767px) {
+ margin-bottom: 0px;
}
+ }
+ @media (max-width: 475px) {
+ .post-tools {
+ display: none;
+ }
+ .favourite-text {
+ display: none;
+ }
}
}
+.post-author-info {
+ display: none;
+ @media (max-width: 767px) {
+ display: block;
+ position: fixed;
+ width: 100%;
+ margin-left: -15px;
+ bottom: -50px;
+ height: 50px;
+ background: rgba(0,0,0,0.8);
+ -webkit-transition: bottom 150ms linear;
+ -moz-transition: bottom 150ms linear;
+ -ms-transition: bottom 150ms linear;
+ -o-transition: bottom 150ms linear;
+ transition: bottom 150ms linear;
+ }
+
+ img {
+ padding: 5px;
+ }
+
+ h4 {
+ color: white;
+ margin: 16px 0 0 -35px;
+ font-weight: 300;
+ font-size: 16px;
+ }
+}
+
+
+
+.category-list {
+ li {
+ .inline-block;
+ .pointer;
+ padding: 0.5em 0;
+ text-align: center;
+ margin: 0.5em;
+ -webkit-border-radius: 5px;
+ -moz-border-radius: 5px;
+ border-radius: 5px;
+ padding: 0.5em;
+ }
+}
+
+
+.username-field {
+ .icon-circle {
+ font-size: 12px;
+ color: green;
+ margin-right:3px;
+ }
+ .icon-circle-blank {
+ font-size: 12px;
+ color: red;
+ margin-right:3px;
+ }
+}
+
+
+
+#thread_active_users {
+ float: right;
+ color: rgb(153,153,153);
+
+ strong {
+ color: rgb(100,100,100);
+ font-weight: 600;
+ .pointer;
+ }
+}
\ No newline at end of file
diff --git a/public/css/unread.less b/public/css/unread.less
new file mode 100644
index 0000000000..754fbf84ab
--- /dev/null
+++ b/public/css/unread.less
@@ -0,0 +1,4 @@
+
+#mark-allread-btn {
+ margin-bottom:15px;
+}
\ No newline at end of file
diff --git a/public/css/users.less b/public/css/users.less
new file mode 100644
index 0000000000..5f6b486ee4
--- /dev/null
+++ b/public/css/users.less
@@ -0,0 +1,23 @@
+
+#users-container {
+ padding: 0;
+}
+.users-box{
+ display: inline-block;
+ margin-top: 20px;
+ text-align: center;
+ vertical-align: top;
+ max-width: 104px;
+ white-space: nowrap;
+ text-overflow: ellipsis;
+ overflow: hidden;
+
+ img {
+ width:80px;
+ height:80px;
+ }
+
+ a {
+ margin:5px;
+ }
+}
diff --git a/public/src/ajaxify.js b/public/src/ajaxify.js
index a18fe6abce..370894927b 100644
--- a/public/src/ajaxify.js
+++ b/public/src/ajaxify.js
@@ -25,11 +25,19 @@ var ajaxify = {};
if (event !== null && event.state && event.state.url !== undefined) ajaxify.go(event.state.url, null, null, true);
};
+ var pagination;
+
ajaxify.go = function(url, callback, template, quiet) {
+ // start: the following should be set like so: ajaxify.onchange(function(){}); where the code actually belongs
$(window).off('scroll');
- // leave room and join global
app.enter_room('global');
+ pagination = pagination || document.getElementById('pagination');
+ if (pagination) pagination.style.display = 'none';
+ window.onscroll = null;
+ // end
+
+
var url = url.replace(/\/$/, "");
var hash = window.location.hash;
diff --git a/public/src/app.js b/public/src/app.js
index 27b8bc50a7..11341a9c78 100644
--- a/public/src/app.js
+++ b/public/src/app.js
@@ -72,13 +72,13 @@ var socket,
alert_id: 'connection_alert',
title: 'Reconnecting',
message: 'You have disconnected from NodeBB, we will try to reconnect you.
',
- type: 'notify',
+ type: 'warning',
timeout: 5000
});
});
socket.on('api:user.get_online_users', function(users) {
- jQuery('.username-field').each(function() {
+ jQuery('a.username-field').each(function() {
if (this.processed === true)
return;
@@ -93,6 +93,22 @@ var socket,
el.prepend('');
}
+ el.processed = true;
+ });
+ jQuery('button .username-field').each(function() {
+ //DRY FAIL
+ if (this.processed === true)
+ return;
+
+ var el = jQuery(this),
+ uid = el.parents('li').attr('data-uid');
+
+ if (uid && jQuery.inArray(uid, users) !== -1) {
+ el.parent().addClass('btn-success');
+ } else {
+ el.parent().addClass('btn-danger');
+ }
+
el.processed = true;
});
});
@@ -145,7 +161,7 @@ var socket,
if(alert.length > 0) {
alert.find('strong').html(params.title);
alert.find('p').html(params.message);
- alert.attr('class', "alert toaster-alert " + ((params.type=='warning') ? '' : "alert-" + params.type));
+ alert.attr('class', "alert toaster-alert " + "alert-" + params.type);
clearTimeout(alert.attr('timeoutId'));
startTimeout(alert, params.timeout);
@@ -159,7 +175,7 @@ var socket,
p.innerHTML = params.message;
strong.innerHTML = params.title;
- div.className = "alert toaster-alert " + ((params.type=='warning') ? '' : "alert-" + params.type);
+ div.className = "alert toaster-alert " + "alert-" + params.type;
div.setAttribute('id', alert_id);
div.appendChild(button);
@@ -211,7 +227,7 @@ var socket,
app.alert({
title: 'Error',
message: message,
- type: 'error',
+ type: 'danger',
timeout: timeout
});
}
@@ -376,8 +392,6 @@ var socket,
}
jQuery('document').ready(function() {
- addTouchEvents();
-
$('#search-form').on('submit', function() {
var input = $(this).find('input');
ajaxify.go("search/"+input.val(), null, "search");
@@ -391,56 +405,4 @@ var socket,
loadConfig();
- function addTouchEvents() {
- return; // later.
-
-
- // click simulation just for testing/sanity purposes.
-
- var el = jQuery("#content"),
- sidebar = jQuery('#mobile-sidebar'),
- width = el.width();
-
- function onTouchMove(ev) {
- var coordinates = window.event ? window.event.touches[0] : ev.touches[0];
-
- el.css({
- marginLeft: -parseInt(width - coordinates.pageX) + 'px',
- paddingRight: parseInt(width - coordinates.pageX) + 'px'});
-
- sidebar.css({
- marginLeft: -parseInt(width - coordinates.pageX) + 'px',
- width: parseInt(width - coordinates.pageX) + 'px'
- });
- }
-
- function onMouseMove(ev) {
- ev.touches = [{pageX: ev.pageX, pageY: ev.pageY}];
- onTouchMove(ev);
- }
-
- function onTouchEnd() {
- el.css({
- marginLeft: '0px',
- paddingRight: '0px'
- });
-
- sidebar.css({
- marginLeft: '0px',
- width: '0px'
- });
- }
-
- el.on('touchmove', onTouchMove);
- el.on('mousedown', function() {
- el.on('mousemove', onMouseMove);
- });
-
- el.on('touchend', onTouchEnd);
- el.on('mouseup', function() {
- el.off('mousemove');
- onTouchEnd();
- });
-
- }
}());
diff --git a/public/src/forum/accountedit.js b/public/src/forum/accountedit.js
index ab0d1a6cba..0946362c53 100644
--- a/public/src/forum/accountedit.js
+++ b/public/src/forum/accountedit.js
@@ -4,52 +4,53 @@ var gravatarPicture = templates.get('gravatarpicture');
var uploadedPicture = templates.get('uploadedpicture');
$(document).ready(function() {
-
+
$('#uploadForm').submit(function() {
status('uploading the file ...');
-
+
$('#upload-progress-bar').css('width', '0%');
$('#upload-progress-box').show();
-
+ $('#upload-progress-box').removeClass('hide');
+
if(!$('#userPhotoInput').val()) {
error('select an image to upload!');
- return false;
+ return false;
}
-
+
$(this).find('#imageUploadCsrf').val($('#csrf_token').val());
-
+
$(this).ajaxSubmit({
-
+
error: function(xhr) {
error('Error: ' + xhr.status);
},
-
+
uploadProgress : function(event, position, total, percent) {
$('#upload-progress-bar').css('width', percent+'%');
},
-
-
+
+
success: function(response) {
if(response.error) {
error(response.error);
return;
}
-
+
var imageUrlOnServer = response.path;
-
+
$('#user-current-picture').attr('src', imageUrlOnServer);
$('#user-uploaded-picture').attr('src', imageUrlOnServer);
-
- uploadedPicture = imageUrlOnServer;
-
+
+ uploadedPicture = imageUrlOnServer;
+
setTimeout(function() {
hideAlerts();
$('#upload-picture-modal').modal('hide');
}, 750);
-
+
socket.emit('api:updateHeader', { fields: ['username', 'picture', 'userslug'] });
success('File uploaded successfully!');
}
@@ -57,45 +58,45 @@ $(document).ready(function() {
return false;
});
-
+
function hideAlerts() {
$('#alert-status').hide();
$('#alert-success').hide();
$('#alert-error').hide();
$('#upload-progress-box').hide();
}
-
+
function status(message) {
hideAlerts();
$('#alert-status').text(message).show();
}
-
+
function success(message) {
hideAlerts();
$('#alert-success').text(message).show();
}
-
+
function error(message) {
hideAlerts();
$('#alert-error').text(message).show();
}
-
- function changeUserPicture(type) {
+
+ function changeUserPicture(type) {
var userData = {
type: type
};
-
+
socket.emit('api:user.changePicture', userData, function(success) {
if(!success) {
app.alertError('There was an error changing picture!');
}
});
}
-
+
var selectedImageType = '';
-
+
$('#submitBtn').on('click',function(){
-
+
var userData = {
uid:$('#inputUID').val(),
email:$('#inputEmail').val(),
@@ -116,14 +117,14 @@ $(document).ready(function() {
if(data.gravatarpicture) {
$('#user-gravatar-picture').attr('src', data.gravatarpicture);
gravatarPicture = data.gravatarpicture;
- }
+ }
} else {
app.alertError('There was an error updating your profile!');
}
});
return false;
});
-
+
function updateImages() {
var currentPicture = $('#user-current-picture').attr('src');
@@ -140,73 +141,75 @@ $(document).ready(function() {
}
else
$('#uploaded-box').hide();
-
-
+
+
if(currentPicture == gravatarPicture)
$('#gravatar-box .icon-ok').show();
else
$('#gravatar-box .icon-ok').hide();
-
+
if(currentPicture == uploadedPicture)
$('#uploaded-box .icon-ok').show();
else
$('#uploaded-box .icon-ok').hide();
}
-
-
+
+
$('#changePictureBtn').on('click', function() {
selectedImageType = '';
updateImages();
-
+
$('#change-picture-modal').modal('show');
-
+ $('#change-picture-modal').removeClass('hide');
+
return false;
});
-
+
$('#gravatar-box').on('click', function(){
$('#gravatar-box .icon-ok').show();
$('#uploaded-box .icon-ok').hide();
selectedImageType = 'gravatar';
});
-
+
$('#uploaded-box').on('click', function(){
$('#gravatar-box .icon-ok').hide();
$('#uploaded-box .icon-ok').show();
selectedImageType = 'uploaded';
});
-
+
$('#savePictureChangesBtn').on('click', function() {
$('#change-picture-modal').modal('hide');
if(selectedImageType) {
changeUserPicture(selectedImageType);
-
+
if(selectedImageType == 'gravatar')
- $('#user-current-picture').attr('src', gravatarPicture);
+ $('#user-current-picture').attr('src', gravatarPicture);
else if(selectedImageType == 'uploaded')
- $('#user-current-picture').attr('src', uploadedPicture);
+ $('#user-current-picture').attr('src', uploadedPicture);
}
-
+
});
-
+
$('#upload-picture-modal').on('hide', function() {
$('#userPhotoInput').val('');
});
-
+
$('#uploadPictureBtn').on('click', function(){
-
+
$('#change-picture-modal').modal('hide');
$('#upload-picture-modal').modal('show');
+ $('#upload-picture-modal').removeClass('hide');
hideAlerts();
-
+
return false;
});
-
+
$('#pictureUploadSubmitBtn').on('click', function() {
$('#uploadForm').submit();
});
-
+
(function handlePasswordChange() {
var currentPassword = $('#inputCurrentPassword');
var password_notify = $('#password-notify');
@@ -221,22 +224,22 @@ $(document).ready(function() {
passwordvalid = utils.isPasswordValid(password.val());
if (password.val().length < 6) {
password_notify.html('Password too short');
- password_notify.attr('class', 'label label-important');
+ password_notify.attr('class', 'label label-danger');
} else if(!passwordvalid) {
password_notify.html('Invalid password');
- password_notify.attr('class', 'label label-important');
+ password_notify.attr('class', 'label label-danger');
} else {
password_notify.html('OK!');
password_notify.attr('class', 'label label-success');
}
-
+
onPasswordConfirmChanged();
}
function onPasswordConfirmChanged() {
if(password.val() !== password_confirm.val()) {
password_confirm_notify.html('Passwords must match!');
- password_confirm_notify.attr('class', 'label label-important');
+ password_confirm_notify.attr('class', 'label label-danger');
passwordsmatch = false;
} else {
password_confirm_notify.html('OK!');
@@ -249,10 +252,10 @@ $(document).ready(function() {
password_confirm.on('keyup', onPasswordConfirmChanged);
$('#changePasswordBtn').on('click', function() {
-
+
if(passwordvalid && passwordsmatch && currentPassword.val()) {
socket.emit('api:user.changePassword', {'currentPassword': currentPassword.val(),'newPassword': password.val() }, function(data) {
-
+
currentPassword.val('');
password.val('');
password_confirm.val('');
@@ -260,18 +263,18 @@ $(document).ready(function() {
password_confirm_notify.html('');
passwordsmatch = false;
passwordvalid = false;
-
+
if(data.err) {
app.alertError(data.err);
return;
}
-
+
app.alertSuccess('Your password is updated!');
-
+
});
}
return false;
});
-
+
}());
});
\ No newline at end of file
diff --git a/public/src/forum/admin/categories.js b/public/src/forum/admin/categories.js
index b7f77c8dbb..959dabfcfa 100644
--- a/public/src/forum/admin/categories.js
+++ b/public/src/forum/admin/categories.js
@@ -29,10 +29,12 @@ function select_icon(el) {
}
});
- jQuery('.bootbox .span3').on('click', function() {
- jQuery('.bootbox .selected').removeClass('selected');
- jQuery(this).addClass('selected');
- });
+ setTimeout(function() { //bootbox was rewritten for BS3 and I had to add this timeout for the previous code to work. TODO: to look into
+ jQuery('.bootbox .col-md-3').on('click', function() {
+ jQuery('.bootbox .selected').removeClass('selected');
+ jQuery(this).addClass('selected');
+ });
+ }, 500);
}
@@ -46,7 +48,7 @@ jQuery('.blockclass').each(function() {
});
-//DRY Failure. this needs to go into an ajaxify onready style fn. Currently is copy pasted into every single function so after ACP is off the ground fix asap
+//DRY Failure. this needs to go into an ajaxify onready style fn. Currently is copy pasted into every single function so after ACP is off the ground fix asap
(function() {
jQuery('document').ready(function() {
var url = window.location.href,
@@ -99,5 +101,5 @@ jQuery('.blockclass').each(function() {
});
});
-
+
}());
\ No newline at end of file
diff --git a/public/src/forum/admin/footer.js b/public/src/forum/admin/footer.js
index 2ed60171c4..9fc84c7325 100644
--- a/public/src/forum/admin/footer.js
+++ b/public/src/forum/admin/footer.js
@@ -2,9 +2,9 @@
var nodebb_admin = (function(nodebb_admin) {
-
+
nodebb_admin.config = undefined;
-
+
nodebb_admin.prepare = function() {
// Come back in 500ms if the config isn't ready yet
if (nodebb_admin.config === undefined) {
@@ -67,10 +67,10 @@ var nodebb_admin = (function(nodebb_admin) {
}
});
}
-
+
nodebb_admin.remove = function(key) {
- socket.emit('api:config.remove', key);
- }
+ socket.emit('api:config.remove', key);
+ }
jQuery('document').ready(function() {
@@ -93,7 +93,7 @@ var nodebb_admin = (function(nodebb_admin) {
socket.once('api:config.get', function(config) {
nodebb_admin.config = config;
});
-
+
socket.emit('api:config.get');
socket.on('api:config.set', function(data) {
@@ -111,12 +111,12 @@ var nodebb_admin = (function(nodebb_admin) {
timeout: 2500,
title: 'Changes Not Saved',
message: 'NodeBB encountered a problem saving your changes',
- type: 'error'
+ type: 'danger'
});
}
});
-
+
return nodebb_admin;
-
+
}(nodebb_admin || {}));
diff --git a/public/src/forum/admin/plugins.js b/public/src/forum/admin/plugins.js
index 07907b14e0..a913cc9fe9 100644
--- a/public/src/forum/admin/plugins.js
+++ b/public/src/forum/admin/plugins.js
@@ -21,7 +21,7 @@ var nodebb_admin = nodebb_admin || {};
alert_id: 'plugin_toggled_' + status.id,
title: 'Plugin Enabled',
message: 'You may need to restart NodeBB in order for these changes to be reflected.',
- type: 'notify',
+ type: 'warning',
timeout: 5000
})
});
diff --git a/public/src/forum/admin/themes.js b/public/src/forum/admin/themes.js
index 762924cd4f..95881fec63 100644
--- a/public/src/forum/admin/themes.js
+++ b/public/src/forum/admin/themes.js
@@ -18,7 +18,7 @@ var nodebb_admin = (function(nodebb_admin) {
'
' + theme.description + '
' + @@ -29,11 +29,11 @@ var nodebb_admin = (function(nodebb_admin) { themeContainer.innerHTML = ''; themeContainer.appendChild(themeFrag); } - + nodebb_admin.themes = themes; - + return nodebb_admin; - + }(nodebb_admin || {})); diff --git a/public/src/forum/admin/users.js b/public/src/forum/admin/users.js index 3cc4f1fb12..76473647c6 100644 --- a/public/src/forum/admin/users.js +++ b/public/src/forum/admin/users.js @@ -91,7 +91,9 @@ if(!isAdmin) { bootbox.confirm('Do you really want to delete "' + parent.attr('data-username') +'"?', function(confirm) { - socket.emit('api:admin.user.deleteUser', uid); + if (confirm) { + socket.emit('api:admin.user.deleteUser', uid); + } }); } @@ -112,9 +114,11 @@ parent.attr('data-banned', 0); } else { bootbox.confirm('Do you really want to ban "' + parent.attr('data-username') +'"?', function(confirm) { - socket.emit('api:admin.user.banUser', uid); - banBtn.addClass('btn-warning'); - parent.attr('data-banned', 1); + if (confirm) { + socket.emit('api:admin.user.banUser', uid); + banBtn.addClass('btn-warning'); + parent.attr('data-banned', 1); + } }); } } @@ -172,14 +176,14 @@ if(data && data.length === 0) { $('#user-notfound-notify').html('User not found!') .show() - .addClass('label-important') + .addClass('label-danger') .removeClass('label-success'); } else { $('#user-notfound-notify').html(data.length + ' user'+(data.length>1?'s':'') + ' found!') .show() .addClass('label-success') - .removeClass('label-important'); + .removeClass('label-danger'); } initUsers(); diff --git a/public/src/forum/category.js b/public/src/forum/category.js index 569d46958e..70e8937701 100644 --- a/public/src/forum/category.js +++ b/public/src/forum/category.js @@ -83,12 +83,12 @@ li.setAttribute('data-pid', posts[i].pid); - li.innerHTML = '' + - '' + posts[i].username + ': ' + posts[i].content + + posts[i].content + '
' + - 'posted ' + utils.relativeTime(posts[i].timestamp) + ' ago' + + '' + posts[i].username + ' - ' + utils.relativeTime(posts[i].timestamp) + ' ago' + ''; frag.appendChild(li.cloneNode(true)); diff --git a/public/src/forum/footer.js b/public/src/forum/footer.js index eba06ee4cf..c892b300eb 100644 --- a/public/src/forum/footer.js +++ b/public/src/forum/footer.js @@ -152,7 +152,7 @@ alert_id: 'new_notif', title: 'New notification', message: 'You have unread notifications.', - type: 'notify', + type: 'warning', timeout: 2000 }); utils.refreshTitle(); diff --git a/public/src/forum/register.js b/public/src/forum/register.js index 62d4b32fef..89ee708e5a 100644 --- a/public/src/forum/register.js +++ b/public/src/forum/register.js @@ -7,26 +7,31 @@ username_notify = $('#username-notify'), email_notify = $('#email-notify'), password_notify = $('#password-notify'), - password_confirm_notify = $('#password-confirm-notify'), - validationError = false; + password_confirm_notify = $('#password-confirm-notify'), + validationError = false, + successIcon = ''; function showError(element, msg) { element.html(msg); - element.attr('class', 'alert alert-error'); + element.parent() + .removeClass('alert-success') + .addClass('alert-danger'); element.show(); validationError = true; } - + function showSuccess(element, msg) { element.html(msg); - element.attr('class', 'alert alert-success'); + element.parent() + .removeClass('alert-danger') + .addClass('alert-success'); element.show(); } function validateEmail() { if(!emailEl.val()) { validationError = true; - email_notify.hide(); + //email_notify.hide(); return; } @@ -44,9 +49,9 @@ function validateUsername() { if(!username.val()) { validationError = true; - username_notify.hide(); + //username_notify.hide(); return; - } + } if(username.val().length < config.minimumUsernameLength) { showError(username_notify, 'Username too short!'); @@ -59,17 +64,20 @@ } } + username.on('keyup', function() { + jQuery('#yourUsername').html(this.value.length > 0 ? this.value : 'username'); + }); username.on('blur', function() { validateUsername(); }); - + function validatePassword() { if(!password.val()){ validationError = true; - password_notify.hide(); + //password_notify.hide(); return; } - + if (password.val().length < config.minimumPasswordLength) { showError(password_notify, 'Password too short!'); } else if(password.val().length > config.maximumPasswordLength) { @@ -77,31 +85,31 @@ } else if(!utils.isPasswordValid(password.val())) { showError(password_notify, 'Invalid password!'); } else { - showSuccess(password_notify, 'OK!'); + showSuccess(password_notify, successIcon); } - + if(password.val() !== password_confirm.val() && password_confirm.val() !== '') { showError(password_confirm_notify, 'Passwords must match!'); } } - + $(password).on('blur', function() { validatePassword(); }); - + function validatePasswordConfirm() { if(!password.val() || password_notify.hasClass('alert-error')) { - password_confirm_notify.hide(); + //password_confirm_notify.hide(); return; } - + if(password.val() !== password_confirm.val()) { showError(password_confirm_notify, 'Passwords must match!'); } else { - showSuccess(password_confirm_notify, 'OK!'); + showSuccess(password_confirm_notify, successIcon); } } - + $(password_confirm).on('blur', function() { validatePasswordConfirm(); }); @@ -112,15 +120,15 @@ if (data.exists === true) { showError(username_notify, 'Username already taken!'); } else { - showSuccess(username_notify, 'OK!'); + showSuccess(username_notify, successIcon); } }); - + socket.on('user.email.exists', function(data) { if (data.exists === true) { showError(email_notify, 'Email address already taken!'); } else { - showSuccess(email_notify, 'OK!'); + showSuccess(email_notify, successIcon); } }); @@ -131,7 +139,7 @@ function validateForm() { validationError = false; - + validateEmail(); validateUsername(); validatePassword(); @@ -139,9 +147,9 @@ return validationError; } - + register.on('click', function(e) { if (validateForm()) e.preventDefault(); }); - -}()); + +}()); \ No newline at end of file diff --git a/public/src/forum/topic.js b/public/src/forum/topic.js index 2edf4659e6..0b39c690de 100644 --- a/public/src/forum/topic.js +++ b/public/src/forum/topic.js @@ -124,7 +124,7 @@ } else { app.alert({ 'alert_id': 'thread_move', - type: 'error', + type: 'danger', title: 'Unable to Move Topic', message: 'This topic could not be moved to ' + targetCatLabel + '.