This commit is contained in:
syuilo 2018-03-09 18:29:27 +09:00
parent 910ccf1804
commit e82268db7e
7 changed files with 38 additions and 9 deletions

View file

@ -253,6 +253,11 @@ const endpoints: Endpoint[] = [
withCredential: true withCredential: true
}, },
{
name: 'othello/games/show',
withCredential: true
},
{ {
name: 'mute/create', name: 'mute/create',
withCredential: true, withCredential: true,

View file

@ -23,7 +23,7 @@ module.exports = (params, user) => new Promise(async (res, rej) => {
return rej('cannot set since_id and until_id'); return rej('cannot set since_id and until_id');
} }
const q = my ? { const q: any = my ? {
is_started: true, is_started: true,
$or: [{ $or: [{
user1_id: user._id user1_id: user._id
@ -34,7 +34,6 @@ module.exports = (params, user) => new Promise(async (res, rej) => {
is_started: true is_started: true
}; };
const sort = { const sort = {
_id: -1 _id: -1
}; };
@ -52,7 +51,8 @@ module.exports = (params, user) => new Promise(async (res, rej) => {
// Fetch games // Fetch games
const games = await Game.find(q, { const games = await Game.find(q, {
sort sort,
limit
}); });
// Reponse // Reponse

View file

@ -0,0 +1,16 @@
import $ from 'cafy';
import Game, { pack } from '../../../models/othello-game';
module.exports = (params, user) => new Promise(async (res, rej) => {
// Get 'game_id' parameter
const [gameId, gameIdErr] = $(params.game_id).id().$;
if (gameIdErr) return rej('invalid game_id param');
const game = await Game.findOne({ _id: gameId });
if (game == null) {
return rej('game not found');
}
res(await pack(game, user));
});

View file

@ -2,7 +2,6 @@ import * as mongo from 'mongodb';
import deepcopy = require('deepcopy'); import deepcopy = require('deepcopy');
import db from '../../db/mongodb'; import db from '../../db/mongodb';
import { IUser, pack as packUser } from './user'; import { IUser, pack as packUser } from './user';
import { Map } from '../../common/othello/maps';
const Game = db.get<IGame>('othello_games'); const Game = db.get<IGame>('othello_games');
export default Game; export default Game;
@ -79,6 +78,11 @@ export const pack = (
if (opts.detail === false) { if (opts.detail === false) {
delete _game.logs; delete _game.logs;
delete _game.settings.map; delete _game.settings.map;
} else {
// 互換性のため
if (_game.settings.map.hasOwnProperty('size')) {
_game.settings.map = _game.settings.map.data.match(new RegExp(`.{1,${_game.settings.map.size}}`, 'g'));
}
} }
// Populate user // Populate user

View file

@ -106,8 +106,6 @@ export default Vue.extend({
this.o.put(log.color, log.pos); this.o.put(log.color, log.pos);
}); });
console.log(this.o);
this.logs = this.game.logs; this.logs = this.game.logs;
this.logPos = this.logs.length; this.logPos = this.logs.length;
}, },

View file

@ -39,7 +39,7 @@
</section> </section>
<section v-if="myGames.length > 0"> <section v-if="myGames.length > 0">
<h2>自分の対局</h2> <h2>自分の対局</h2>
<div class="game" v-for="g in myGames" tabindex="-1" @click="game = g"> <div class="game" v-for="g in myGames" tabindex="-1" @click="go(g)">
<img :src="`${g.user1.avatar_url}?thumbnail&size=32`" alt=""> <img :src="`${g.user1.avatar_url}?thumbnail&size=32`" alt="">
<img :src="`${g.user2.avatar_url}?thumbnail&size=32`" alt=""> <img :src="`${g.user2.avatar_url}?thumbnail&size=32`" alt="">
<span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span> <span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span>
@ -48,7 +48,7 @@
</section> </section>
<section v-if="games.length > 0"> <section v-if="games.length > 0">
<h2>みんなの対局</h2> <h2>みんなの対局</h2>
<div class="game" v-for="g in games" tabindex="-1" @click="game = g"> <div class="game" v-for="g in games" tabindex="-1" @click="go(g)">
<img :src="`${g.user1.avatar_url}?thumbnail&size=32`" alt=""> <img :src="`${g.user1.avatar_url}?thumbnail&size=32`" alt="">
<img :src="`${g.user2.avatar_url}?thumbnail&size=32`" alt=""> <img :src="`${g.user2.avatar_url}?thumbnail&size=32`" alt="">
<span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span> <span><b>{{ g.user1.name }}</b> vs <b>{{ g.user2.name }}</b></span>
@ -108,6 +108,13 @@ export default Vue.extend({
(this as any).os.streams.othelloStream.dispose(this.connectionId); (this as any).os.streams.othelloStream.dispose(this.connectionId);
}, },
methods: { methods: {
go(game) {
(this as any).api('othello/games/show', {
game_id: game.id
}).then(game => {
this.game = game;
});
},
match() { match() {
(this as any).apis.input({ (this as any).apis.input({
title: 'ユーザー名を入力してください' title: 'ユーザー名を入力してください'

View file

@ -43,7 +43,6 @@ export default Vue.extend({
mounted() { mounted() {
if (this.default) this.text = this.default; if (this.default) this.text = this.default;
this.$nextTick(() => { this.$nextTick(() => {
console.log(this);
(this.$refs.text as any).focus(); (this.$refs.text as any).focus();
}); });
}, },