<template>
    <div id="match-report" :class="{'match-report': true, minimized: isMinimized}" v-if="(haveScores(characterMatch.you) || haveScores(characterMatch.them))">
        <a class="minimize-btn" @click.prevent="toggleMinimize()"><i :class="{fa: true, 'fa-plus': isMinimized, 'fa-minus': !isMinimized}"></i></a>

        <div class="scores you">
            <h3>
                <img :src="avatarUrl(characterMatch.you.you.name)" class="thumbnail"/>
                {{characterMatch.you.you.name}}
            </h3>

            <ul>
                <li v-for="score in getScores(characterMatch.you)" v-if="shouldShowScore(score)" :class="getScoreClass(score)" v-html="score.description"></li>
            </ul>
        </div>

        <div class="vs">
            vs.
        </div>

        <div class="scores them">
            <h3>
                <img :src="avatarUrl(characterMatch.them.you.name)" class="thumbnail" />
                {{characterMatch.them.you.name}}
            </h3>

            <ul>
                <li v-for="score in getScores(characterMatch.them)" v-if="shouldShowScore(score)" :class="getScoreClass(score)" v-html="score.description"></li>
            </ul>
        </div>
    </div>
</template>

<script lang="ts">
    import { Component, Prop, Watch } from '@f-list/vue-ts';
    import * as _ from 'lodash';
    import Vue from 'vue';
    import * as Utils from '../utils';
    import { MatchReport, MatchResult, Score, Scoring } from '../../learn/matcher';

    export interface CssClassMap {
        [key: string]: boolean;
    }


    @Component
    export default class MatchReportView extends Vue {
        @Prop({required: true})
        readonly characterMatch!: MatchReport;

        @Prop({required: true})
        readonly minimized = false;

        readonly avatarUrl = Utils.avatarURL;

        isMinimized = false;

        @Watch('minimized')
        onMinimizedChange(): void {
            this.isMinimized = this.minimized;
        }

        getScoreClass(score: Score): CssClassMap {
            const classes: CssClassMap = {};

            classes[score.getRecommendedClass()] = true;
            classes['match-score'] = true;

            return classes;
        }

        haveScores(result: MatchResult): boolean {
            return !_.every(
                result.scores,
                (s: Score) => (s.score === Scoring.NEUTRAL)
            );
        }

        shouldShowScore(score: Score): boolean {
            return (score.score !== Scoring.NEUTRAL);
        }

        getScores(result: MatchResult): Score[] {
            return _.map(result.scores, (s: Score) => (s));
        }

        toggleMinimize(): void {
            this.isMinimized = !this.isMinimized;
        }
    }

</script>