This commit is contained in:
syuilo
2017-10-30 17:30:32 +09:00
parent 9aed3d21c9
commit 77528f022d
8 changed files with 149 additions and 12 deletions

View File

@@ -0,0 +1,29 @@
/**
* Module dependencies
*/
import $ from 'cafy';
import Thread from '../../../models/bbs-thread';
import serialize from '../../../serializers/bbs-thread';
/**
* Create a thread
*
* @param {any} params
* @param {any} user
* @return {Promise<any>}
*/
module.exports = async (params, user) => new Promise(async (res, rej) => {
// Get 'title' parameter
const [title, titleErr] = $(params.title).string().range(1, 100).$;
if (titleErr) return rej('invalid title param');
// Create a thread
const thread = await Thread.insert({
created_at: new Date(),
user_id: user._id,
title: title
});
// Response
res(await serialize(thread));
});

View File

@@ -0,0 +1,13 @@
import * as mongo from 'mongodb';
import db from '../../db/mongodb';
const collection = db.get('bbs_threads');
export default collection as any; // fuck type definition
export type IBbsThread = {
_id: mongo.ObjectID;
created_at: Date;
title: string;
user_id: mongo.ObjectID;
};

View File

@@ -0,0 +1,44 @@
/**
* Module dependencies
*/
import * as mongo from 'mongodb';
import deepcopy = require('deepcopy');
import { IUser } from '../models/user';
import { default as Thread, IBbsThread } from '../models/bbs-thread';
/**
* Serialize a thread
*
* @param thread target
* @param me? serializee
* @return response
*/
export default (
thread: string | mongo.ObjectID | IBbsThread,
me?: string | mongo.ObjectID | IUser
) => new Promise<any>(async (resolve, reject) => {
let _thread: any;
// Populate the thread if 'thread' is ID
if (mongo.ObjectID.prototype.isPrototypeOf(thread)) {
_thread = await Thread.findOne({
_id: thread
});
} else if (typeof thread === 'string') {
_thread = await Thread.findOne({
_id: new mongo.ObjectID(thread)
});
} else {
_thread = deepcopy(thread);
}
// Rename _id to id
_thread.id = _thread._id;
delete _thread._id;
// Remove needless properties
delete _thread.user_id;
resolve(_thread);
});

View File

@@ -61,6 +61,7 @@ require('./pages/user.tag');
require('./pages/post.tag');
require('./pages/search.tag');
require('./pages/not-found.tag');
require('./pages/bbs.tag');
require('./autocomplete-suggestion.tag');
require('./progress-dialog.tag');
require('./user-preview.tag');

View File

@@ -0,0 +1,30 @@
<mk-bbs-page>
<mk-ui ref="ui">
<main>
<h1>%i18n:desktop.tags.mk-bbs-page.title%</h1>
<button onclick={ parent.new }>%i18n:desktop.tags.mk-bbs-page.new%</button>
</main>
</mk-ui>
<style>
:scope
display block
</style>
<script>
this.mixin('api');
this.on('mount', () => {
document.title = '%i18n:desktop.tags.mk-bbs-page.title%';
});
this.new = () => {
const title = window.prompt('%i18n:desktop.tags.mk-bbs-page.thread-title%');
this.api('bbs/threads/create', {
title: title
}).then(thread => {
location.href = '/bbs/' + thread.id;
});
};
</script>
</mk-bbs-page>

View File

@@ -319,18 +319,26 @@
</mk-ui-header-notifications>
<mk-ui-header-nav>
<ul if={ SIGNIN }>
<li class="home { active: page == 'home' }">
<a href={ CONFIG.url }>
<i class="fa fa-home"></i>
<p>%i18n:desktop.tags.mk-ui-header-nav.home%</p>
</a>
</li>
<li class="messaging">
<a onclick={ messaging }>
<i class="fa fa-comments"></i>
<p>%i18n:desktop.tags.mk-ui-header-nav.messaging%</p>
<i class="fa fa-circle" if={ hasUnreadMessagingMessages }></i>
<ul>
<virtual if={ SIGNIN }>
<li class="home { active: page == 'home' }">
<a href={ CONFIG.url }>
<i class="fa fa-home"></i>
<p>%i18n:desktop.tags.mk-ui-header-nav.home%</p>
</a>
</li>
<li class="messaging">
<a onclick={ messaging }>
<i class="fa fa-comments"></i>
<p>%i18n:desktop.tags.mk-ui-header-nav.messaging%</p>
<i class="fa fa-circle" if={ hasUnreadMessagingMessages }></i>
</a>
</li>
</virtual>
<li class="bbs">
<a href={ CONFIG.url + '/bbs' }>
<i class="fa fa-coffee"></i>
<p>%i18n:desktop.tags.mk-ui-header-nav.bbs%</p>
</a>
</li>
<li class="info">