import { App, Widget, Hyprland, Utils, Variable } from '../../imports.js';
const { Box, EventBox, Overlay } = Widget;

import { RoundedCorner } from '../screen-corners.js';
import Gesture           from './gesture.js';

const Revealed = Variable(true);
const Hovering = Variable(false);
const wStyle = 'background: rgba(0, 0, 0, 0.5);';


Hyprland.connect('changed', () => {
    Revealed.value = Hyprland.getWorkspace(Hyprland.active.workspace.id)
        .hasfullscreen;
});
Hyprland.connect('fullscreen', (_, fullscreen) => Revealed.value = fullscreen);

export default props => Overlay({
    overlays: [
        RoundedCorner('topleft',  { className: 'corner' }),
        RoundedCorner('topright', { className: 'corner' }),
    ],

    child: Box({
        style: 'min-height: 1px',
        hexpand: true,
        vertical: true,
        children: [
            Widget.Revealer({
                transition: 'slide_down',
                setup: self => self.revealChild = true,

                properties: [['timeouts', []]],
                connections: [[Revealed, self => {
                    const Bar = App.getWindow('bar');
                    Bar.setStyle(Revealed.value ? '' : wStyle);

                    const BgGradient = App.getWindow('bg-gradient');
                    BgGradient.visible = !Revealed.value;

                    if (Revealed.value) {
                        Utils.timeout(2000, () => {
                            if (Revealed.value)
                                self.revealChild = false;
                        });
                    }
                    else {
                        self.revealChild = true;
                    }
                }]],

                child: Gesture({
                    onHover: () => Hovering.value = true,
                    onHoverLost: self => {
                        Hovering.value = false;
                        if (Revealed.value) {
                            Utils.timeout(2000, () => {
                                if (!Hovering.value) {
                                    self.get_parent().get_parent().children[1].revealChild = true;
                                    self.get_parent().revealChild = false;
                                }
                            });
                        }
                    },
                    ...props,
                }),
            }),

            Widget.Revealer({
                connections: [[Revealed, self => {
                    if (Revealed.value) {
                        Utils.timeout(2000, () => {
                            if (Revealed.value)
                                self.revealChild = true;
                        });
                    }
                    else {
                        self.revealChild = false;
                    }
                }]],
                child: EventBox({
                    onHover: self => {
                        Hovering.value = true;
                        self.get_parent().get_parent().children[0].revealChild = true;
                        self.get_parent().revealChild = false;
                    },
                    child: Box({
                        style: 'min-height: 50px;',
                    }),
                }),
            }),
        ],
    }),
});