2018-03-06 10:54:56 -06:00
|
|
|
<template>
|
2018-08-03 01:59:24 -05:00
|
|
|
<div class="vchtoekanapleubgzioubdtmlkribzfd">
|
2018-03-06 20:40:40 -06:00
|
|
|
<div v-if="game">
|
2018-03-08 02:57:57 -06:00
|
|
|
<x-gameroom :game="game"/>
|
2018-03-06 20:40:40 -06:00
|
|
|
</div>
|
2018-03-07 02:48:32 -06:00
|
|
|
<div class="matching" v-else-if="matching">
|
2018-08-01 19:52:47 -05:00
|
|
|
<h1>{{ '%i18n:@matching.waiting-for%'.split('{}')[0] }}<b>{{ matching | userName }}</b>{{ '%i18n:@matching.waiting-for%'.split('{}')[1] }}<mk-ellipsis/></h1>
|
2018-03-07 02:48:32 -06:00
|
|
|
<div class="cancel">
|
2018-08-02 10:36:29 -05:00
|
|
|
<form-button round @click="cancel">%i18n:@matching.cancel%</form-button>
|
2018-03-07 02:48:32 -06:00
|
|
|
</div>
|
2018-03-06 10:54:56 -06:00
|
|
|
</div>
|
2018-03-07 02:48:32 -06:00
|
|
|
<div class="index" v-else>
|
2018-08-03 07:30:44 -05:00
|
|
|
<x-index @go="onGo" @matching="onMatching"/>
|
2018-03-06 10:54:56 -06:00
|
|
|
</div>
|
|
|
|
</div>
|
|
|
|
</template>
|
|
|
|
|
|
|
|
<script lang="ts">
|
|
|
|
import Vue from 'vue';
|
2018-06-16 18:10:54 -05:00
|
|
|
import XGameroom from './reversi.gameroom.vue';
|
2018-08-03 07:30:44 -05:00
|
|
|
import XIndex from './reversi.index.vue';
|
2018-03-06 20:40:40 -06:00
|
|
|
|
2018-03-06 10:54:56 -06:00
|
|
|
export default Vue.extend({
|
2018-03-06 20:40:40 -06:00
|
|
|
components: {
|
2018-08-03 07:30:44 -05:00
|
|
|
XGameroom,
|
|
|
|
XIndex
|
2018-03-06 20:40:40 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-09 10:48:16 -06:00
|
|
|
props: ['initGame'],
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-06 20:40:40 -06:00
|
|
|
data() {
|
|
|
|
return {
|
|
|
|
game: null,
|
2018-03-07 02:48:32 -06:00
|
|
|
matching: null,
|
2018-03-06 20:40:40 -06:00
|
|
|
connection: null,
|
2018-03-11 04:08:26 -05:00
|
|
|
connectionId: null,
|
|
|
|
pingClock: null
|
2018-03-06 20:40:40 -06:00
|
|
|
};
|
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-09 10:48:16 -06:00
|
|
|
watch: {
|
|
|
|
game(g) {
|
|
|
|
this.$emit('gamed', g);
|
|
|
|
}
|
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-09 10:48:16 -06:00
|
|
|
created() {
|
|
|
|
if (this.initGame) {
|
|
|
|
this.game = this.initGame;
|
|
|
|
}
|
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-06 20:40:40 -06:00
|
|
|
mounted() {
|
2018-07-26 14:01:12 -05:00
|
|
|
if (this.$store.getters.isSignedIn) {
|
|
|
|
this.connection = (this as any).os.streams.reversiStream.getConnection();
|
|
|
|
this.connectionId = (this as any).os.streams.reversiStream.use();
|
2018-03-06 20:40:40 -06:00
|
|
|
|
2018-07-26 14:01:12 -05:00
|
|
|
this.connection.on('matched', this.onMatched);
|
|
|
|
|
|
|
|
this.pingClock = setInterval(() => {
|
|
|
|
if (this.matching) {
|
|
|
|
this.connection.send({
|
|
|
|
type: 'ping',
|
|
|
|
id: this.matching.id
|
|
|
|
});
|
|
|
|
}
|
|
|
|
}, 3000);
|
|
|
|
}
|
2018-03-06 20:40:40 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-06 20:40:40 -06:00
|
|
|
beforeDestroy() {
|
2018-07-26 14:01:12 -05:00
|
|
|
if (this.connection) {
|
|
|
|
this.connection.off('matched', this.onMatched);
|
|
|
|
(this as any).os.streams.reversiStream.dispose(this.connectionId);
|
2018-03-11 04:08:26 -05:00
|
|
|
|
2018-07-26 14:01:12 -05:00
|
|
|
clearInterval(this.pingClock);
|
|
|
|
}
|
2018-03-06 20:40:40 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-06 20:40:40 -06:00
|
|
|
methods: {
|
2018-08-03 07:30:44 -05:00
|
|
|
onGo(game) {
|
|
|
|
this.matching = null;
|
|
|
|
this.game = game;
|
2018-03-09 03:29:27 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-08-03 07:30:44 -05:00
|
|
|
onMatching(user) {
|
|
|
|
this.matching = user;
|
2018-03-06 20:40:40 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-07 02:48:32 -06:00
|
|
|
cancel() {
|
|
|
|
this.matching = null;
|
2018-07-07 05:01:33 -05:00
|
|
|
(this as any).api('games/reversi/match/cancel');
|
2018-03-07 02:48:32 -06:00
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-07 02:48:32 -06:00
|
|
|
accept(invitation) {
|
2018-07-07 05:01:33 -05:00
|
|
|
(this as any).api('games/reversi/match', {
|
2018-03-29 00:48:47 -05:00
|
|
|
userId: invitation.parent.id
|
2018-03-07 02:48:32 -06:00
|
|
|
}).then(game => {
|
|
|
|
if (game) {
|
2018-03-11 04:08:26 -05:00
|
|
|
this.matching = null;
|
2018-03-07 02:48:32 -06:00
|
|
|
this.game = game;
|
|
|
|
}
|
|
|
|
});
|
|
|
|
},
|
2018-07-26 14:01:12 -05:00
|
|
|
|
2018-03-06 20:40:40 -06:00
|
|
|
onMatched(game) {
|
2018-03-11 04:08:26 -05:00
|
|
|
this.matching = null;
|
2018-03-06 20:40:40 -06:00
|
|
|
this.game = game;
|
2018-03-06 10:54:56 -06:00
|
|
|
}
|
|
|
|
}
|
|
|
|
});
|
|
|
|
</script>
|
|
|
|
|
2018-03-07 02:48:32 -06:00
|
|
|
<style lang="stylus" scoped>
|
|
|
|
@import '~const.styl'
|
|
|
|
|
2018-08-03 01:59:24 -05:00
|
|
|
root(isDark)
|
|
|
|
color isDark ? #fff : #677f84
|
|
|
|
background isDark ? #191b22 : #fff
|
2018-03-07 02:48:32 -06:00
|
|
|
|
|
|
|
> .matching
|
|
|
|
> h1
|
|
|
|
margin 0
|
|
|
|
padding 24px
|
|
|
|
font-size 20px
|
|
|
|
text-align center
|
|
|
|
font-weight normal
|
|
|
|
|
|
|
|
> .cancel
|
|
|
|
margin 0 auto
|
|
|
|
padding 24px 0 0 0
|
|
|
|
max-width 200px
|
|
|
|
text-align center
|
|
|
|
border-top dashed 1px #c4cdd4
|
|
|
|
|
2018-08-03 01:59:24 -05:00
|
|
|
.vchtoekanapleubgzioubdtmlkribzfd[data-darkmode]
|
|
|
|
root(true)
|
|
|
|
|
|
|
|
.vchtoekanapleubgzioubdtmlkribzfd:not([data-darkmode])
|
|
|
|
root(false)
|
|
|
|
|
2018-03-07 02:48:32 -06:00
|
|
|
</style>
|