@use "../utils";

// =========
// codemirror
// =========
.cm-editor {
  width: 100%;
  height: 100%;
  outline: none !important;
}

// =========
// gd-main
// =========
.gd-main {
  width: 100%;
  height: 100%;
  position: relative;
  overflow: hidden;
  background-color: var(--gd-exercise-bg-color);
}

// =========
// gd-splash
// =========
.gd-splash {
  width: 100vw;
  height: 100vh;
  background-color: var(--gd-exercise-bg-color);
}

// =========
// gd-layout
// =========
.gd-layout {
  width: 100%;
  height: 100%;
  overflow: hidden;

  display: grid;
  grid-template-areas: "footer footer";
  grid-template-columns: 1fr 1fr;
  grid-template-rows: 1fr;

  &--with-code-and-player {
    @extend .gd-layout;

    grid-template-areas:
      "code player"
      "footer footer";
    grid-template-columns: 1fr 1fr;
    grid-template-rows: 3fr minmax(200px, 1fr);

    @include utils.is-collapsed {
      grid-template-areas:
        "collapsed-menu"
        "active"
        "footer";
      grid-template-columns: auto;
      grid-template-rows: min-content 3fr minmax(200px, 1fr);
    }
  }

  &--with-code-only {
    @extend .gd-layout--with-code-and-player;

    grid-template-areas:
      "code code"
      "footer footer";

    @include utils.is-collapsed {
      grid-template-areas:
        "collapsed-menu"
        "active"
        "footer";
      grid-template-columns: auto;
      grid-template-rows: min-content 3fr minmax(200px, 1fr);
    }
  }

  &--with-player-only {
    @extend .gd-layout--with-code-and-player;

    grid-template-areas:
      "player player"
      "footer footer";

    @include utils.is-collapsed {
      grid-template-areas:
        "collapsed-menu"
        "active"
        "footer";
      grid-template-columns: auto;
      grid-template-rows: min-content 3fr minmax(200px, 1fr);
    }
  }
}

.gd-collapsed-menu {
  grid-area: collapsed-menu;
  padding-bottom: 0;

  .gd-menu {
    @include utils.is-not-collapsed {
      display: none;
    }
  }

  .layout-tabs {
    width: 100%;
    height: 100%;
    overflow-x: auto;
    overflow-y: hidden;

    display: none;

    @include utils.is-collapsed {
      display: block;

      &.container {
        padding-bottom: 0;
        margin-bottom: 0;
      }
    }
  }

  @include utils.is-not-collapsed {
    display: none;
  }
}

// =========
// gd-player
// =========
.gd-player {
  grid-area: player;

  display: grid;
  grid-template-areas:
    "menu"
    "player-container";
  grid-template-columns: auto;
  grid-template-rows: auto 1fr;

  @include utils.is-collapsed {
    padding-top: 0;

    &.active {
      grid-area: active;
    }

    &:not(.active) {
      // ==== This is a hack ====
      // We cannot hide the player, as it will stop rendering
      // the game and Godot will start to panic.
      // So, the solution is to move the game outside of the view,
      // but the browser will still render the canvas.
      position: absolute;
      left: -99999px;
    }
  }
}

.gd-player-container {
  grid-area: player-container;
  position: relative;
}

.gd-player-loading {
  position: absolute;
  width: 100%;
  height: 100%;
  background-color: var(--gd-exercise-bg-color-inactive);
  z-index: 1;

  display: flex;
  justify-content: center;
  align-items: center;
}

.gd-player-loading-progress {
  width: 80%;
  height: 2em;
  padding: 0.25em;
  background-color: var(--gd-exercise-bg-color);
}

.gd-player-loading-progress-bar {
  width: 100%;
  height: 100%;
  background-color: var(--gd-exercise-bg-color-inactive);

  transform-origin: 0 50%;
  transform: scaleX(calc(var(--download-current) / var(--download-total)));
}

.gd-player-menu {
  grid-area: menu;
}

.gd-player-player {
  position: absolute;
  width: 100%;
  height: 100%;
  overflow: hidden;

  .canvas {
    width: 100%;
    height: 100%;
    border-radius: var(--gd-exercise-app-border-radius);
  }
}

// =======
// gd-code
// =======
.gd-code {
  grid-area: code;
  overflow: hidden;

  display: grid;
  grid-template-areas:
    "files"
    "code"
    "menu";
  grid-template-columns: auto;
  grid-template-rows:
    auto
    1fr
    auto;

  @include utils.is-collapsed {
    padding-top: 0;

    grid-template-areas:
      "code"
      "menu";
    grid-template-rows:
      1fr
      auto;

    &.active {
      grid-area: active;
    }

    &:not(.active) {
      position: absolute;
      visibility: hidden;
    }

    &.container {
      padding-top: 0;
      margin-top: 0;
    }
  }

  width: 100%;
  height: 100%;
}

.gd-code-files {
  grid-area: files;
  overflow-y: auto;
}

.gd-code-code {
  grid-area: code;
  display: flex;
  // height: 100%;
  overflow: auto;
}

.gd-code-menu {
  grid-area: menu;
  padding-top: var(--gd-exercise-app-padding-dimensions);

  display: grid;
  grid-template-areas: "revert . save";
  grid-template-columns: auto 1fr auto;

  &-button {
    display: flex;
    position: relative;
    align-items: center;
    justify-content: center;
    gap: var(--gd-exercise-app-padding-dimensions);
    font-family: var(--gd-exercise-font-family);
    font-size: var(--gd-exercise-app-button-font-size);
    border-radius: var(--gd-exercise-app-border-radius);
    border: none;
    padding: var(--gd-exercise-app-padding-dimensions);
    color: var(--gd-exercise-text-color);
    background-color: transparent;
    cursor: pointer;

    .material-symbols-outlined {
      position: relative;
      margin-top: -2em;
      top: 1em;
    }

    :disabled {
      cursor: normal;
    }

    &--save {
      grid-area: save;
    }

    &--revert {
      grid-area: revert;
    }

    &--cta {
      color: var(--gd-exercise-button-cta-text-color);
      font-weight: var(--gd-exercise-button-cta-font-weight);
      background-color: var(--gd-exercise-button-cta-bg-color);
      box-shadow: var(--gd-exercise-button-cta-box-shadow);
      text-transform: var(--gd-exercise-button-cta-text-transform);

      &:disabled {
        background-color: var(--gd-exercise-button-cta-bg-color-disabled);
        box-shadow: var(--gd-exercise-button-cta-box-shadow-disabled);
        cursor: default;
      }

      &:enabled:active {
        top: var(--gd-exercise-button-cta-pseudo-height);
        box-shadow: none;
      }
    }
  }
}

// ================
// gd-layout-footer
// ================

.gd-layout-footer {
  grid-area: footer;
  width: 100%;
  height: 100%;
  overflow: hidden;

  display: grid;
  grid-template-areas: "console";
  grid-template-columns: auto;
  grid-template-areas: auto;

  &--has-test {
    @extend .gd-layout-footer;

    display: grid;
    grid-template-areas: "test console";
    grid-template-columns: 1fr 1fr;
    grid-template-areas: auto;

    .gd-test {
      display: block;
    }
  }
}

// ==========
// gd-console
// ==========
.gd-console {
  grid-area: console;
  overflow: hidden;

  display: grid;
  grid-template-areas:
    "console-tab"
    "console";
  grid-template-columns: auto;
  grid-template-rows: min-content auto;
}

.gd-console-tab {
  grid-area: console-tab;
}

.gd-console-console {
  grid-area: console;
  overflow: hidden;
}

// =======
// gd-test
// =======
.gd-test {
  display: none;

  grid-area: test;
  overflow: hidden;

  grid-template-areas:
    "test-tab"
    "test";
}

.gd-test-tab {
  grid-area: test-tab;
}

.gd-test-test {
  grid-area: test;
}
