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.name + '

' + '

' + 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 = '' + + 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 + '.
Please try again later', timeout: 5000 @@ -183,7 +183,7 @@ if (data.status && data.status === 'ok') set_follow_state(data.follow); else { app.alert({ - type: 'error', + type: 'danger', alert_id: 'topic_follow', title: 'Please Log In', message: 'Please register or log in in order to subscribe to this topic', @@ -246,9 +246,8 @@ }); $('.post-container').on('click', '.favourite', function() { - var ids = this.id.replace('favs_', '').split('_'), - pid = ids[0], - uid = ids[1]; + var pid = $(this).parents('li').attr('data-pid'); + var uid = $(this).parents('li').attr('data-uid'); var element = $(this).find('i'); if(element.attr('class') == 'icon-star-empty') { @@ -260,9 +259,8 @@ }); $('.post-container').delegate('.edit', 'click', function(e) { - var pid = ($(this).attr('id') || $(this.parentNode).attr('id')).split('_')[1]; - - var main = $(this).parents('.main-post'); + var pid = $(this).parents('li').attr('data-pid'), + main = $(this).parents('.main-post'); require(['composer'], function(cmp) { cmp.push(null, null, pid); @@ -270,10 +268,10 @@ }); $('.post-container').delegate('.delete', 'click', function(e) { - var pid = ($(this).attr('id') || $(this.parentNode).attr('id')).split('_')[1], - postEl = $(document.querySelector('#post-container li[data-pid="' + pid + '"]')), - deleteAction = !postEl.hasClass('deleted') ? true : false, - confirmDel = confirm((deleteAction ? 'Delete' : 'Restore') + ' this post?'); + var pid = $(this).parents('li').attr('data-pid'), + postEl = $(document.querySelector('#post-container li[data-pid="' + pid + '"]')), + deleteAction = !postEl.hasClass('deleted') ? true : false, + confirmDel = confirm((deleteAction ? 'Delete' : 'Restore') + ' this post?'); if (confirmDel) { deleteAction ? @@ -282,18 +280,17 @@ } }); - $('.post-container').delegate('.chat', 'click', function(e) { - - var username = $(this).parents('li').attr('data-username'); - var touid = $(this).parents('li').attr('data-uid'); + $('.topic-buttons').delegate('.chat', 'click', function(e) { + var username = $(this).parents('li.row').attr('data-username'); + var touid = $(this).parents('li.row').attr('data-uid'); if(username === app.username || !app.username) return; require(['chat'], function(chat) { var chatModal = chat.createModalIfDoesntExist(username, touid); - chatModal.show(); - chat.bringModalToTop(chatModal); + chatModal.modal(); + chat.bringModalToTop(chatModal); // I don't think this is necessary }); }); @@ -602,4 +599,60 @@ deleteEl.addClass('none'); } } + + + + var postAuthorImage, postAuthorInfo, pagination; + var postcount = templates.get('postcount'); + + function updateHeader() { + jQuery('.post-author-info').css('bottom', '0px'); + postAuthorImage = postAuthorImage || document.getElementById('post-author-image'); + postAuthorInfo = postAuthorInfo || document.getElementById('post-author-info'); + pagination = pagination || document.getElementById('pagination'); + + pagination.style.display = 'block'; + + var windowHeight = jQuery(window).height(); + var scrollTop = jQuery(window).scrollTop(); + var scrollBottom = scrollTop + windowHeight; + + if (scrollTop < 50) { + postAuthorImage.src = (jQuery('.main-avatar img').attr('src')); + postAuthorInfo.innerHTML = 'Posted by ' + jQuery('.main-post').attr('data-username') + ', ' + jQuery('.main-post').find('.relativeTimeAgo').html(); + pagination.innerHTML = '0 / ' + postcount; + return; + } + + + var count = 0; + + jQuery('.sub-posts').each(function() { + count++; + this.postnumber = count; + + + var el = jQuery(this); + var elTop = el.offset().top; + var height = Math.floor(el.height()); + var elBottom = elTop + (height < 300 ? height : 300); + + var inView = ((elBottom >= scrollTop) && (elTop <= scrollBottom) + && (elBottom <= scrollBottom) && (elTop >= scrollTop)); + + + if (inView) { + pagination.innerHTML = this.postnumber + ' / ' + postcount; + postAuthorImage.src = (jQuery(this).find('.profile-image-block img').attr('src')); + postAuthorInfo.innerHTML = 'Posted by ' + jQuery(this).attr('data-username') + ', ' + jQuery(this).find('.relativeTimeAgo').html(); + } + }); + + if(scrollTop + windowHeight == jQuery(document).height()) { + pagination.innerHTML = postcount + ' / ' + postcount; + } + } + + window.onscroll = updateHeader; + window.onload = updateHeader; })(); \ No newline at end of file diff --git a/public/src/forum/users.js b/public/src/forum/users.js index 0cba6d649b..2592b800fa 100644 --- a/public/src/forum/users.js +++ b/public/src/forum/users.js @@ -8,6 +8,8 @@ parts = url.split('/'), active = parts[parts.length-1]; + var lastSearch = null; + app.addCommasToNumbers(); jQuery('.nav-pills li').removeClass('active'); @@ -27,22 +29,30 @@ timeoutId = setTimeout(function() { var username = $('#search-user').val(); - jQuery('.icon-spinner').removeClass('none'); - socket.emit('api:admin.user.search', username); + if (username == '') { + jQuery('#user-notfound-notify').html(''); + jQuery('#user-notfound-notify').parent().removeClass('btn-warning label-warning btn-success label-success'); + return; + } + + if (lastSearch === username) return; + lastSearch = username; + + jQuery('#user-notfound-notify').html(''); + + setTimeout(function() { + socket.emit('api:admin.user.search', username); + }, 500); //replace this with global throttling function/constant + }, 250); }); socket.removeAllListeners('api:admin.user.search'); socket.on('api:admin.user.search', function(data) { - - jQuery('.icon-spinner').addClass('none'); - if(data === null) { - $('#user-notfound-notify').html('You need to be logged in to search!') - .show() - .addClass('label-important') - .removeClass('label-success'); + $('#user-notfound-notify').html('You need to be logged in to search!'); + $('#user-notfound-notify').parent().addClass('btn-warning label-warning'); return; } @@ -55,16 +65,12 @@ if(data && data.length === 0) { - $('#user-notfound-notify').html('User not found!') - .show() - .addClass('label-important') - .removeClass('label-success'); + $('#user-notfound-notify').html('User not found!'); + $('#user-notfound-notify').parent().addClass('btn-warning label-warning'); } else { - $('#user-notfound-notify').html(data.length + ' user'+(data.length>1?'s':'') + ' found!') - .show() - .addClass('label-success') - .removeClass('label-important'); + $('#user-notfound-notify').html(data.length + ' user'+(data.length>1?'s':'') + ' found!'); + $('#user-notfound-notify').parent().addClass('btn-success label-success'); } }); diff --git a/public/src/modules/composer.js b/public/src/modules/composer.js index 47b8b72223..1e9e46a885 100644 --- a/public/src/modules/composer.js +++ b/public/src/modules/composer.js @@ -8,7 +8,7 @@ define(['taskbar'], function(taskbar) { }; function createImageLabel(img, postImages) { - var imageLabel = $('
'+ img.name +'
'); + var imageLabel = $('
'+ img.name +'
'); var closeButton = $(''); closeButton.on('click', function(e) { @@ -30,9 +30,9 @@ define(['taskbar'], function(taskbar) { imagelist = $('.post-window .imagelist'), uuid = dropDiv.parents('[data-uuid]').attr('data-uuid'), posts = composer.posts[uuid]; - + $(reader).on('loadend', function(e) { - var bin = this.result; + var bin = this.result; bin = bin.split(',')[1]; var img = { @@ -47,13 +47,13 @@ define(['taskbar'], function(taskbar) { imagelist.append(imageLabel); dropDiv.hide(); }); - + reader.readAsDataURL(file); } function initializeFileReader() { jQuery.event.props.push( "dataTransfer" ); - + var draggingDocument = false; if(window.FileReader) { @@ -77,12 +77,12 @@ define(['taskbar'], function(taskbar) { drop.off('dragleave'); }); }); - + function cancel(e) { e.preventDefault(); return false; } - + drop.on('dragover', cancel); drop.on('dragenter', cancel); @@ -96,7 +96,7 @@ define(['taskbar'], function(taskbar) { for (var i=0; i' + '
' + '
' + @@ -125,7 +125,7 @@ define(['taskbar'], function(taskbar) { '
Drag and Drop Images Here
'+ '
' + '
' + - '' + + '' + '' + '' + '
' + @@ -157,7 +157,7 @@ define(['taskbar'], function(taskbar) { composer.load(uuid); } else { app.alert({ - type: 'error', + type: 'danger', timeout: 5000, alert_id: 'post_error', title: 'Please Log In to Post', @@ -284,7 +284,7 @@ define(['taskbar'], function(taskbar) { composer.reposition(post_uuid); composer.active = post_uuid; - + composer.postContainer.setAttribute('data-uuid', post_uuid); if (parseInt(post_data.tid) > 0) { titleEl.value = 'Replying to: ' + post_data.title; @@ -312,7 +312,7 @@ define(['taskbar'], function(taskbar) { } composer.reposition = function(post_uuid) { - var postWindowEl = composer.postContainer.querySelector('.span5'), + var postWindowEl = composer.postContainer.querySelector('.col-md-5'), taskbarBtn = document.querySelector('#taskbar [data-uuid="' + post_uuid + '"]'), btnRect = taskbarBtn.getBoundingClientRect(), taskbarRect = document.getElementById('taskbar').getBoundingClientRect(), @@ -330,13 +330,13 @@ define(['taskbar'], function(taskbar) { var postData = composer.posts[post_uuid], titleEl = composer.postContainer.querySelector('input'), bodyEl = composer.postContainer.querySelector('textarea'); - + titleEl.value = titleEl.value.trim(); bodyEl.value = bodyEl.value.trim(); - + if (titleEl.value.length < config.minimumTitleLength) { return app.alert({ - type: 'error', + type: 'danger', timeout: 2000, title: 'Title too short', message: "Please enter a longer title. At least " + config.minimumTitleLength+ " characters.", @@ -346,7 +346,7 @@ define(['taskbar'], function(taskbar) { if (bodyEl.value.length < config.minimumPostLength) { return app.alert({ - type: 'error', + type: 'danger', timeout: 2000, title: 'Content too short', message: "Please enter a longer post. At least " + config.minimumPostLength + " characters.", diff --git a/public/src/modules/mobileMenu.js b/public/src/modules/mobileMenu.js index 115a0c750a..e1479dd03b 100644 --- a/public/src/modules/mobileMenu.js +++ b/public/src/modules/mobileMenu.js @@ -99,10 +99,11 @@ define(function() { mobileMenu.init = function() { + return; // disabling until this can be pluginified. overlay = overlay || document.getElementById('mobile-menu-overlay'); menuBtn = menuBtn || document.getElementById('mobile-menu-btn'); postBtn = postBtn || document.getElementById('mobile-post-btn'); - + menuBtn.onclick = function() { animateIcons(); } @@ -111,7 +112,7 @@ define(function() { displayCategories(); mobileMenu.onNavigate(); }); - + } return { diff --git a/public/src/utils.js b/public/src/utils.js index 790fc9754c..50323b7327 100644 --- a/public/src/utils.js +++ b/public/src/utils.js @@ -1,5 +1,5 @@ (function (module) { - + var utils, fs; try { @@ -39,15 +39,15 @@ }); }); }, - + relativeTime: function(timestamp, min) { var now = +new Date(), difference = now - Math.floor(parseFloat(timestamp)); difference = Math.floor(difference / 1000); - + if (difference < 60) return difference + (min ? 's' : ' second') + (difference !== 1 && !min ? 's' : ''); - + difference = Math.floor(difference / 60); if (difference < 60) return difference + (min ? 'm' : ' minute') + (difference !== 1 && !min ? 's' : ''); @@ -63,7 +63,7 @@ difference = Math.floor(difference / 12); return difference + (min ? 'y' : ' year') + (difference !== 1 && !min ? 's' : ''); }, - + //http://dense13.com/blog/2009/05/03/converting-string-to-slug-javascript/ slugify: function(str) { str = str.replace(/^\s+|\s+$/g, ''); // trim @@ -93,7 +93,7 @@ isUserNameValid: function(name) { return (name && name !== "" && (/^[a-zA-Z0-9 _-]+$/.test(name))); }, - + isPasswordValid: function(password) { return password && password.indexOf(' ') === -1; }, @@ -132,10 +132,12 @@ a.href = document.location; url = a.pathname.slice(1); } + var notificationIcon; socket.emit('api:meta.buildTitle', url, function(title, numNotifications) { document.title = (numNotifications > 0 ? '(' + numNotifications + ') ' : '') + title; - if (numNotifications > 0) document.querySelector('.notifications a i').className = 'icon-circle active'; + notificationIcon = notificationIcon || document.querySelector('.notifications a i'); + if (numNotifications > 0 && notificationIcon) notificationIcon.className = 'icon-circle active'; }); jQuery.getJSON(RELATIVE_PATH + '/api/unread/total', function(data) { @@ -169,16 +171,16 @@ if (!String.prototype.ltrim) { String.prototype.ltrim=function(){return this.replace(/^\s+/,'');}; } - + if (!String.prototype.rtrim) { - String.prototype.rtrim=function(){return this.replace(/\s+$/,'');}; + String.prototype.rtrim=function(){return this.replace(/\s+$/,'');}; } - + if (!String.prototype.fulltrim) { - String.prototype.fulltrim=function(){return this.replace(/(?:(?:^|\n)\s+|\s+(?:$|\n))/g,'').replace(/\s+/g,' ');}; + String.prototype.fulltrim=function(){return this.replace(/(?:(?:^|\n)\s+|\s+(?:$|\n))/g,'').replace(/\s+/g,' ');}; } - + if ('undefined' !== typeof window) { window.utils = module.exports; } diff --git a/public/templates/403.tpl b/public/templates/403.tpl index 4cbd7e91dc..62b460deb3 100644 --- a/public/templates/403.tpl +++ b/public/templates/403.tpl @@ -1,4 +1,4 @@ -
+
Access Denied

You seem to have stumbled upon a page that you do not have access to. Perhaps you should try logging in?

\ No newline at end of file diff --git a/public/templates/404.tpl b/public/templates/404.tpl index f3a998992e..1825280f6f 100644 --- a/public/templates/404.tpl +++ b/public/templates/404.tpl @@ -1,4 +1,4 @@ -
+
Not found

You seem to have stumbled upon a page that does not exist. Return to the home page

\ No newline at end of file diff --git a/public/templates/account.tpl b/public/templates/account.tpl index 9a661ce22c..16e87313c6 100644 --- a/public/templates/account.tpl +++ b/public/templates/account.tpl @@ -1,5 +1,5 @@ -
+