<script setup>
    import systemService from '@/services/systemService'
    import { useNotifyStore } from '@/stores/notify'
    import { UseColorMode } from '@vueuse/components'

    const $2fauth = inject('2fauth')
    const notify = useNotifyStore()
    const returnTo = useStorage($2fauth.prefix + 'returnTo', 'accounts')

    const infos = ref()
    const listInfos = ref(null)

    const userPreferences = ref(false)
    const listUserPreferences = ref(null)

    const adminSettings = ref(false)
    const listAdminSettings = ref(null)

    const { copy } = useClipboard({ legacy: true })

    onMounted(() => {
        systemService.getSystemInfos().then(response => {
            infos.value = response.data.common

            if (response.data.admin_settings) {
                adminSettings.value = response.data.admin_settings
            }

            if (response.data.user_preferences) {
                userPreferences.value = response.data.user_preferences
            }
        })
    })

    function copyToClipboard(data) {
        copy(data)
        notify.info({ text: trans('commons.copied_to_clipboard') })
    }
</script>

<template>
    <ResponsiveWidthWrapper>
        <h1 class="title has-text-grey-dark">{{ $t('commons.about') }}</h1>
        <p class="block">
            <UseColorMode v-slot="{ mode }">
                <span :class="mode == 'dark' ? 'has-text-white':'has-text-black'"><span class="is-size-5">2FAuth</span> v{{ $2fauth.version }}</span>
            </UseColorMode>
            <br />
            {{ $t('commons.2fauth_teaser')}}
        </p>
        <img class="about-logo" src="logo.svg" alt="2FAuth logo" />
        <p class="block">
            ©Bubka <a class="is-size-7" href="https://github.com/Bubka/2FAuth/blob/master/LICENSE">AGPL-3.0 license</a>
        </p>
        <h2 class="title is-5 has-text-grey-light">
            {{ $t('commons.resources') }}
        </h2>
        <div class="buttons">
            <UseColorMode v-slot="{ mode }">
                <a class="button" :class="{'is-dark' : mode == 'dark'}" href="https://github.com/Bubka/2FAuth" target="_blank">
                    <span class="icon is-small">
                        <FontAwesomeIcon :icon="['fab', 'github-alt']" />
                    </span>
                    <span>Github</span>
                </a>
                <a class="button" :class="{'is-dark' : mode == 'dark'}" href="https://docs.2fauth.app/" target="_blank">
                    <span class="icon is-small">
                        <FontAwesomeIcon :icon="['fas', 'book']" />
                    </span>
                    <span>Docs</span>
                </a>
                <a class="button" :class="{'is-dark' : mode == 'dark'}" href="https://demo.2fauth.app/" target="_blank">
                    <span class="icon is-small">
                        <FontAwesomeIcon :icon="['fas', 'flask']" />
                    </span>
                    <span>Demo</span>
                </a>
                <a class="button" :class="{'is-dark' : mode == 'dark'}" href="https://docs.2fauth.app/resources/rapidoc.html" target="_blank">
                    <span class="icon is-small">
                        <FontAwesomeIcon :icon="['fas', 'code']" />
                    </span>
                    <span>API</span>
                </a>
            </UseColorMode>
        </div>
        <h2 class="title is-5 has-text-grey-light">
            {{ $t('commons.credits') }}
        </h2>
        <p class="block">
            <ul>
                <li>{{ $t('commons.made_with') }}&nbsp;<a href="https://docs.2fauth.app/credits/">Laravel, Bulma CSS, Vue.js and more</a></li>
                <li>{{ $t('commons.ui_icons_by') }}&nbsp;<a href="https://fontawesome.com/">Font Awesome</a>&nbsp;<a class="is-size-7" href="https://fontawesome.com/license/free">(CC BY 4.0, Fonts: SIL OFL 1.1, Code: MIT License)</a></li>
                <li>{{ $t('commons.logos_by') }}&nbsp;<a href="https://2fa.directory/">2FA Directory</a>&nbsp;<a class="is-size-7" href="https://github.com/2factorauth/twofactorauth/blob/master/LICENSE.md">(MIT License)</a></li>
            </ul>
        </p>
        <h2 class="title is-5 has-text-grey-light">
            {{ $t('commons.environment') }}
        </h2>
        <div class="about-debug box is-family-monospace is-size-7">
            <button id="btnCopyEnvVars" :aria-label="$t('commons.copy_to_clipboard')" class="button is-like-text is-pulled-right is-small is-text" @click.stop="copyToClipboard(listInfos.innerText)">
                <FontAwesomeIcon :icon="['fas', 'copy']" />
            </button>
            <ul ref="listInfos" id="listInfos">
                <li v-for="(value, key) in infos" :value="value" :key="key"><b>{{key}}</b>: {{value}}</li>
            </ul>
        </div>
        <h2 v-if="adminSettings" class="title is-5 has-text-grey-light">
            {{ $t('settings.admin_settings') }}
        </h2>
        <div v-if="adminSettings" class="about-debug box is-family-monospace is-size-7">
            <button id="btnCopyAdminSettings" :aria-label="$t('commons.copy_to_clipboard')" class="button is-like-text is-pulled-right is-small is-text" @click.stop="copyToClipboard(listAdminSettings.innerText)">
                <FontAwesomeIcon :icon="['fas', 'copy']" />
            </button>
            <ul ref="listAdminSettings" id="listAdminSettings">
                <li v-for="(value, setting) in adminSettings" :value="value" :key="setting"><b>{{setting}}</b>: {{value}}</li>
            </ul>
        </div>
        <h2 v-if="userPreferences" class="title is-5 has-text-grey-light">
            {{ $t('settings.user_preferences') }}
        </h2>
        <div v-if="userPreferences" class="about-debug box is-family-monospace is-size-7">
            <button id="btnCopyUserPreferences" :aria-label="$t('commons.copy_to_clipboard')" class="button is-like-text is-pulled-right is-small is-text" @click.stop="copyToClipboard(listUserPreferences.innerText)">
                <FontAwesomeIcon :icon="['fas', 'copy']" />
            </button>
            <ul ref="listUserPreferences" id="listUserPreferences">
                <li v-for="(value, preference) in userPreferences" :value="value" :key="preference"><b>{{preference}}</b>: {{value}}</li>
            </ul>
        </div>
        <!-- footer -->
        <VueFooter :showButtons="true">
            <!-- close button -->
            <p class="control">
                <UseColorMode v-slot="{ mode }">
                    <RouterLink
                        id="lnkBack"
                        :to="{ name: returnTo }"
                        :aria-label="$t('commons.close_the_x_page', {pagetitle: $route.meta.title})"
                        class="button is-rounded"
                        :class="{'is-dark' : mode == 'dark'}">
                        {{ $t('commons.back') }}
                    </RouterLink>
                </UseColorMode>
            </p>
        </VueFooter>
    </ResponsiveWidthWrapper>
</template>