import Cookies from 'js-cookie';

require('./bootstrap');

$(() => {
    if (Cookies.get('agechecked')) {
        $('body').removeClass('tis-need-agecheck');
    } else {
        $('#ageCheckModal')
            .modal({backdrop: 'static'})
            .on('hide.bs.modal', function () {
                $('body').removeClass('tis-need-agecheck');
                Cookies.set('agechecked', '1', {expires: 365});
            });
    }

    if (navigator.serviceWorker) {
        navigator.serviceWorker.register('/sw.js');
    }
    $('[data-toggle="tooltip"]').tooltip();
    $('.alert').alert();
    $('.tis-page-selector').pageSelector();

    $('.link-card').linkCard();
    const $deleteCheckinModal = $('#deleteCheckinModal').deleteCheckinModal();
    $(document).on('click', '[data-target="#deleteCheckinModal"]', function (event) {
        event.preventDefault();
        $deleteCheckinModal.modal('show', this);
    });

    $(document).on('click', '[data-href]', function (event) {
        location.href = $(this).data('href');
    });

    $(document).on('click', '.like-button', function (event) {
        event.preventDefault();

        const $this = $(this);
        const targetId = $this.data('id');
        const isLiked = $this.data('liked');

        if (isLiked) {
            const callback = (data) => {
                $this.data('liked', false);
                $this.find('.oi-heart').removeClass('text-danger');

                const count = data.ejaculation ? data.ejaculation.likes_count : 0;
                $this.find('.like-count').text(count ? count : '');
            };

            $.ajax({
                url: '/api/likes/' + encodeURIComponent(targetId),
                method: 'delete',
                type: 'json'
            })
                .then(callback)
                .catch(function (xhr) {
                    if (xhr.status === 404) {
                        callback(JSON.parse(xhr.responseText));
                        return;
                    }

                    console.error(xhr);
                    alert('いいねを解除できませんでした。');
                });
        } else {
            const callback = (data) => {
                $this.data('liked', true);
                $this.find('.oi-heart').addClass('text-danger');

                const count = data.ejaculation ? data.ejaculation.likes_count : 0;
                $this.find('.like-count').text(count ? count : '');
            };

            $.ajax({
                url: '/api/likes',
                method: 'post',
                type: 'json',
                data: {
                    id: targetId
                }
            })
                .then(callback)
                .catch(function (xhr) {
                    if (xhr.status === 409) {
                        callback(JSON.parse(xhr.responseText));
                        return;
                    }

                    console.error(xhr);
                    alert('いいねできませんでした。');
                });
        }
    });
});