From bceeb4ba5a9ccdbe77aa050b4ebf340330aa02f7 Mon Sep 17 00:00:00 2001 From: OldHawk Date: Wed, 5 Jul 2017 17:01:59 +0800 Subject: [PATCH] feat(forums): load forums list data --- modules/core/client/app/trans-string-en.js | 5 +- modules/core/client/app/trans-string-zh.js | 5 +- .../admin/forums-admin.client.controller.js | 199 ++++++++++++++++++ .../controllers/forums.client.controller.js | 167 +-------------- modules/forums/client/less/forum.less | 62 ++++++ .../views/admin/configure.client.view.html | 6 +- .../client/views/index.client.view.html | 72 ++++++- .../controllers/forums.server.controller.js | 3 +- 8 files changed, 348 insertions(+), 171 deletions(-) create mode 100644 modules/forums/client/controllers/admin/forums-admin.client.controller.js diff --git a/modules/core/client/app/trans-string-en.js b/modules/core/client/app/trans-string-en.js index 6a2fcde1..b90f8049 100644 --- a/modules/core/client/app/trans-string-en.js +++ b/modules/core/client/app/trans-string-en.js @@ -653,7 +653,10 @@ MODERATORS: 'Moderators', DESC: 'Description', CATEGORY: 'Category', - READONLY: 'Only oper/admin can post new topic' + READONLY: 'Only oper/admin can post new topic', + TOPICS: 'Topics', + REPLIES: 'Replies', + LAST_REPLY: 'Last Reply' } }, diff --git a/modules/core/client/app/trans-string-zh.js b/modules/core/client/app/trans-string-zh.js index f5f9132e..5d21a56c 100644 --- a/modules/core/client/app/trans-string-zh.js +++ b/modules/core/client/app/trans-string-zh.js @@ -653,7 +653,10 @@ MODERATORS: '版主', DESC: '描述', CATEGORY: '分类', - READONLY: '只有管理员可以发起新话题' + READONLY: '只有管理员可以发起新话题', + TOPICS: '主题数', + REPLIES: '回贴数', + LAST_REPLY: '最近回复' } }, diff --git a/modules/forums/client/controllers/admin/forums-admin.client.controller.js b/modules/forums/client/controllers/admin/forums-admin.client.controller.js new file mode 100644 index 00000000..51d34e1e --- /dev/null +++ b/modules/forums/client/controllers/admin/forums-admin.client.controller.js @@ -0,0 +1,199 @@ +(function () { + 'use strict'; + + angular + .module('forums') + .controller('ForumsAdminController', ForumsAdminController); + + ForumsAdminController.$inject = ['$scope', '$state', '$translate', 'Authentication', 'MeanTorrentConfig', 'ForumsAdminService', 'SideOverlay', '$filter', 'NotifycationService', + 'marked', 'ModalConfirmService']; + + function ForumsAdminController($scope, $state, $translate, Authentication, MeanTorrentConfig, ForumsAdminService, SideOverlay, $filter, NotifycationService, + marked, ModalConfirmService) { + var vm = this; + vm.forumsConfig = MeanTorrentConfig.meanTorrentConfig.forumsConfig; + vm.user = Authentication.user; + + vm.addModeratorPopover = { + title: 'FORUMS.MODERATOR_TITLE', + templateUrl: 'add-moderator.html', + items: [] + }; + + /** + * init + */ + vm.init = function () { + ForumsAdminService.query({}, function (items) { + vm.forums = items; + console.log(items); + + angular.forEach(vm.forums, function (f) { + vm.addModeratorPopover.items.push(f._id, false); + }); + }); + }; + + /** + * popupCreateForum + * @param evt + */ + vm.popupCreateForum = function (evt) { + vm.forum = { + name: '', + desc: '', + category: 'discuss', + order: 0, + readOnly: false + }; + + vm.actionTitle = 'FORUMS.BTN_ADD_FORUM'; + vm.isEdit = false; + vm.categoryChanged(); + SideOverlay.open(evt, 'popupSlide'); + }; + /** + * popupEditForum + * @param evt + * @param f: forum + */ + vm.popupEditForum = function (evt, f) { + if (f) { + vm.forum = new ForumsAdminService(f); + vm.actionTitle = 'FORUMS.BTN_EDIT_FORUM'; + vm.isEdit = true; + SideOverlay.open(evt, 'popupSlide'); + } + }; + + /** + * + */ + vm.categoryChanged = function () { + vm.selectedForums = $filter('filter')(vm.forums, { + category: vm.forum.category + }); + + vm.forum.order = vm.selectedForums.length; + }; + + /** + * createNewForum + */ + vm.createNewForum = function () { + var f = new ForumsAdminService(vm.forum); + f.$save(function (res) { + NotifycationService.showSuccessNotify('FORUMS.ADD_SUCCESSFULLY'); + vm.forum = undefined; + SideOverlay.close(null, 'popupSlide'); + vm.init(); + }, function (res) { + NotifycationService.showErrorNotify(res.data.message, 'FORUMS.ADD_FAILED'); + }); + }; + + /** + * editForum + */ + vm.editForum = function () { + vm.forum.$update(function (res) { + NotifycationService.showSuccessNotify('FORUMS.EDIT_SUCCESSFULLY'); + vm.forum = undefined; + SideOverlay.close(null, 'popupSlide'); + vm.init(); + }, function (res) { + NotifycationService.showErrorNotify(res.data.message, 'FORUMS.EDIT_FAILED'); + }); + }; + + /** + * deleteForum + */ + vm.deleteForum = function () { + var modalOptions = { + closeButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_CANCEL'), + actionButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_OK'), + headerText: $translate.instant('FORUMS.DELETE_CONFIRM_HEADER_TEXT'), + bodyText: $translate.instant('FORUMS.DELETE_CONFIRM_BODY_TEXT') + }; + + ModalConfirmService.showModal({}, modalOptions) + .then(function (result) { + vm.forum.$remove(function (res) { + NotifycationService.showSuccessNotify('FORUMS.DELETE_SUCCESSFULLY'); + vm.forum = undefined; + SideOverlay.close(null, 'popupSlide'); + vm.init(); + }, function (res) { + NotifycationService.showErrorNotify(res.data.message, 'FORUMS.DELETE_FAILED'); + }); + }); + }; + + /** + * getForumDesc + * @param f: forum + * @returns {*} + */ + vm.getForumDesc = function (f) { + if (f) { + return marked(f.desc, {sanitize: true}); + } + }; + + /** + * addModerator + */ + vm.addModerator = function () { + ForumsAdminService.addModerator({ + _id: vm.forum._id, + _username: vm.addModeratorPopover.username + }, function (res) { + NotifycationService.showSuccessNotify('FORUMS.ADD_MODERATOR_SUCCESSFULLY'); + vm.addModeratorPopover.items[vm.forum._id] = false; + vm.init(); + }, function (res) { + NotifycationService.showErrorNotify(res.data.message, 'FORUMS.ADD_MODERATOR_FAILED'); + vm.addModeratorPopover.items[vm.forum._id] = false; + }); + }; + + /** + * addModeratorClicked + * @param f: forum + */ + vm.addModeratorClicked = function (f) { + vm.addModeratorPopover.username = undefined; + vm.addModeratorPopover.items[f._id] = true; + + vm.forum = f; + }; + + /** + * removeModeratorClicked + * @param f forum + * @param m moderator + */ + vm.removeModeratorClicked = function (f, m) { + var modalOptions = { + closeButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_CANCEL'), + actionButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_OK'), + headerText: $translate.instant('FORUMS.DELETE_CONFIRM_HEADER_TEXT'), + bodyText: $translate.instant('FORUMS.REMOVE_CONFIRM_BODY_TEXT') + }; + + ModalConfirmService.showModal({}, modalOptions) + .then(function (result) { + ForumsAdminService.removeModerator({ + _id: f._id, + _username: m.username + }, function (res) { + NotifycationService.showSuccessNotify('FORUMS.REMOVE_MODERATOR_SUCCESSFULLY'); + vm.init(); + }, function (res) { + NotifycationService.showErrorNotify(res.data.message, 'FORUMS.REMOVE_MODERATOR_FAILED'); + }); + }); + }; + } +}()); diff --git a/modules/forums/client/controllers/forums.client.controller.js b/modules/forums/client/controllers/forums.client.controller.js index 8f182fe3..f13d094a 100644 --- a/modules/forums/client/controllers/forums.client.controller.js +++ b/modules/forums/client/controllers/forums.client.controller.js @@ -5,131 +5,24 @@ .module('forums') .controller('ForumsController', ForumsController); - ForumsController.$inject = ['$scope', '$state', '$translate', 'Authentication', 'MeanTorrentConfig', 'ForumsAdminService', 'SideOverlay', '$filter', 'NotifycationService', + ForumsController.$inject = ['$scope', '$state', '$translate', 'Authentication', 'MeanTorrentConfig', 'ForumsService', 'SideOverlay', '$filter', 'NotifycationService', 'marked', 'ModalConfirmService']; - function ForumsController($scope, $state, $translate, Authentication, MeanTorrentConfig, ForumsAdminService, SideOverlay, $filter, NotifycationService, + function ForumsController($scope, $state, $translate, Authentication, MeanTorrentConfig, ForumsService, SideOverlay, $filter, NotifycationService, marked, ModalConfirmService) { var vm = this; vm.forumsConfig = MeanTorrentConfig.meanTorrentConfig.forumsConfig; vm.user = Authentication.user; - vm.addModeratorPopover = { - title: 'FORUMS.MODERATOR_TITLE', - templateUrl: 'add-moderator.html', - items: [] - }; - /** * init */ vm.init = function () { - ForumsAdminService.query({}, function (items) { + ForumsService.query({}, function (items) { vm.forums = items; - console.log(items); - - angular.forEach(vm.forums, function (f) { - vm.addModeratorPopover.items.push(f._id, false); - }); }); }; - /** - * popupCreateForum - * @param evt - */ - vm.popupCreateForum = function (evt) { - vm.forum = { - name: '', - desc: '', - category: 'discuss', - order: 0, - readOnly: false - }; - - vm.actionTitle = 'FORUMS.BTN_ADD_FORUM'; - vm.isEdit = false; - vm.categoryChanged(); - SideOverlay.open(evt, 'popupSlide'); - }; - /** - * popupEditForum - * @param evt - * @param f: forum - */ - vm.popupEditForum = function (evt, f) { - if (f) { - vm.forum = new ForumsAdminService(f); - vm.actionTitle = 'FORUMS.BTN_EDIT_FORUM'; - vm.isEdit = true; - SideOverlay.open(evt, 'popupSlide'); - } - }; - - /** - * - */ - vm.categoryChanged = function () { - vm.selectedForums = $filter('filter')(vm.forums, { - category: vm.forum.category - }); - - vm.forum.order = vm.selectedForums.length; - }; - - /** - * createNewForum - */ - vm.createNewForum = function () { - var f = new ForumsAdminService(vm.forum); - f.$save(function (res) { - NotifycationService.showSuccessNotify('FORUMS.ADD_SUCCESSFULLY'); - vm.forum = undefined; - SideOverlay.close(null, 'popupSlide'); - vm.init(); - }, function (res) { - NotifycationService.showErrorNotify(res.data.message, 'FORUMS.ADD_FAILED'); - }); - }; - - /** - * editForum - */ - vm.editForum = function () { - vm.forum.$update(function (res) { - NotifycationService.showSuccessNotify('FORUMS.EDIT_SUCCESSFULLY'); - vm.forum = undefined; - SideOverlay.close(null, 'popupSlide'); - vm.init(); - }, function (res) { - NotifycationService.showErrorNotify(res.data.message, 'FORUMS.EDIT_FAILED'); - }); - }; - - /** - * deleteForum - */ - vm.deleteForum = function () { - var modalOptions = { - closeButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_CANCEL'), - actionButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_OK'), - headerText: $translate.instant('FORUMS.DELETE_CONFIRM_HEADER_TEXT'), - bodyText: $translate.instant('FORUMS.DELETE_CONFIRM_BODY_TEXT') - }; - - ModalConfirmService.showModal({}, modalOptions) - .then(function (result) { - vm.forum.$remove(function (res) { - NotifycationService.showSuccessNotify('FORUMS.DELETE_SUCCESSFULLY'); - vm.forum = undefined; - SideOverlay.close(null, 'popupSlide'); - vm.init(); - }, function (res) { - NotifycationService.showErrorNotify(res.data.message, 'FORUMS.DELETE_FAILED'); - }); - }); - }; - /** * getForumDesc * @param f: forum @@ -141,59 +34,5 @@ } }; - /** - * addModerator - */ - vm.addModerator = function () { - ForumsAdminService.addModerator({ - _id: vm.forum._id, - _username: vm.addModeratorPopover.username - }, function (res) { - NotifycationService.showSuccessNotify('FORUMS.ADD_MODERATOR_SUCCESSFULLY'); - vm.addModeratorPopover.items[vm.forum._id] = false; - vm.init(); - }, function (res) { - NotifycationService.showErrorNotify(res.data.message, 'FORUMS.ADD_MODERATOR_FAILED'); - vm.addModeratorPopover.items[vm.forum._id] = false; - }); - }; - - /** - * addModeratorClicked - * @param f: forum - */ - vm.addModeratorClicked = function (f) { - vm.addModeratorPopover.username = undefined; - vm.addModeratorPopover.items[f._id] = true; - - vm.forum = f; - }; - - /** - * removeModeratorClicked - * @param f forum - * @param m moderator - */ - vm.removeModeratorClicked = function (f, m) { - var modalOptions = { - closeButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_CANCEL'), - actionButtonText: $translate.instant('FORUMS.DELETE_CONFIRM_OK'), - headerText: $translate.instant('FORUMS.DELETE_CONFIRM_HEADER_TEXT'), - bodyText: $translate.instant('FORUMS.REMOVE_CONFIRM_BODY_TEXT') - }; - - ModalConfirmService.showModal({}, modalOptions) - .then(function (result) { - ForumsAdminService.removeModerator({ - _id: f._id, - _username: m.username - }, function (res) { - NotifycationService.showSuccessNotify('FORUMS.REMOVE_MODERATOR_SUCCESSFULLY'); - vm.init(); - }, function (res) { - NotifycationService.showErrorNotify(res.data.message, 'FORUMS.REMOVE_MODERATOR_FAILED'); - }); - }); - }; } }()); diff --git a/modules/forums/client/less/forum.less b/modules/forums/client/less/forum.less index 2909192c..d8fd3ed6 100644 --- a/modules/forums/client/less/forum.less +++ b/modules/forums/client/less/forum.less @@ -25,10 +25,60 @@ } .forum-list { + .table-category { + border-radius: 6px; + } .forum-desc { word-break: break-all; color: #999; } + table { + border-spacing: 0; + border-collapse: inherit; + border: solid 3px @brand-primary; + thead { + background-color: @brand-primary; + border: solid 1px @brand-primary; + color: #efefef; + tr { + th { + border: solid 2px @brand-primary; + padding: 13px 10px; + } + } + } + tbody { + tr { + td { + border-top: none; + border-bottom: dotted 1px @brand-primary; + p { + margin-bottom: 5px; + &:last-child { + margin-bottom: 0; + } + } + .forum-icon { + float: left; + font-size: 25px; + color: #ff6600; + margin: 25px 10px; + } + .forum-info { + margin-left: 60px; + } + } + &:hover { + background-color: rgba(160, 196, 228, 0.15); + } + } + tr:last-child { + td { + border-bottom: none; + } + } + } + } } .add-moderator-popover { @@ -37,3 +87,15 @@ width: 250px; height: auto; } + +.pagetop { + background-image: url(); + background-color: #333; + background-attachment: fixed; + color: #e5e5e5; + .page-header { + margin-top: 30px; + margin-bottom: 30px; + border-bottom: none; + } +} diff --git a/modules/forums/client/views/admin/configure.client.view.html b/modules/forums/client/views/admin/configure.client.view.html index b62474fa..79392448 100644 --- a/modules/forums/client/views/admin/configure.client.view.html +++ b/modules/forums/client/views/admin/configure.client.view.html @@ -1,4 +1,4 @@ -
+
@@ -7,7 +7,7 @@
- {{ 'FORUMS.CATEGORY.'+cat.name | translate }} +

{{ 'FORUMS.CATEGORY.'+cat.name | translate }}

@@ -21,7 +21,7 @@ - +

{{f.name}} R [{{'FORUMS.LINK_EDIT' | translate}}] [ +
+
+
+
+ +
+
+ +
+
+
+ +
+ + +
+ + + + + + + + + + + + + + + + + +
{{'FORUMS.CATEGORY.'+cat.name | translate}}{{'FORUMS.FIELDS.TOPICS' | translate}}{{'FORUMS.FIELDS.REPLIES' | translate}}{{'FORUMS.FIELDS.LAST_REPLY' | translate}}
+ + +
+

{{f.name}} + R +

+ +

+ +

{{'FORUMS.FIELDS.MODERATORS' | translate}}: {{m.username}}

+
+
{{f.topicCount}}{{f.replyCount}} +
+
+
+
+
\ No newline at end of file diff --git a/modules/forums/server/controllers/forums.server.controller.js b/modules/forums/server/controllers/forums.server.controller.js index 45e67a49..6f319ad5 100644 --- a/modules/forums/server/controllers/forums.server.controller.js +++ b/modules/forums/server/controllers/forums.server.controller.js @@ -20,7 +20,8 @@ var path = require('path'), exports.list = function (req, res) { Forum.find() .sort('order -createdat') - .populate('lastTopic') + .populate('lastNewTopic') + .populate('lastReplyTopic') .populate('moderators', 'username displayName profileImageURL uploaded downloaded') .exec(function (err, forums) { if (err) {