@use 'mixins/mixins' as *;
@use 'mixins/var' as *;
@use 'common/var' as *;

:root,
:host {
  --xzx-dialog-width: 320px;
  --xzx-dialog-small-screen-width: 90%;
  --xzx-dialog-font-size: var(--xzx-text-md);
  --xzx-dialog-transition: var(--xzx-duration-base);
  --xzx-dialog-radius: var(--xzx-br-lg);
  --xzx-dialog-background: var(--xzx-background-2);
  --xzx-dialog-header-font-weight: var(--xzx-font-bold);
  --xzx-dialog-header-line-height: var(--xzx-text-lh-md);
  --xzx-dialog-header-padding-top: 24px;
  --xzx-dialog-header-isolated-padding: var(--xzx-padding-lg) 0;
  --xzx-dialog-message-padding: var(--xzx-padding-lg);
  --xzx-dialog-message-font-size: var(--xzx-text-base);
  --xzx-dialog-message-line-height: 24px;
  --xzx-dialog-message-max-height: 60vh;
  --xzx-dialog-has-title-message-text-color: var(--xzx-text-gray-2);
  --xzx-dialog-has-title-message-padding-top: var(--xzx-padding-xs);
  --xzx-dialog-button-height: 56px;
  --xzx-dialog-round-button-height: 36px;
  --xzx-dialog-confirm-button-text-color: var(--xzx-color-primary);
  --xzx-dialog-type-icon-size: 72px;
}

@include b(dialog) {
  top: 45%;
  width: var(--xzx-dialog-width);
  overflow: hidden;
  font-size: var(--xzx-dialog-font-size);
  background: var(--xzx-dialog-background);
  border-radius: var(--xzx-dialog-radius);
  backface-visibility: hidden; // avoid blurry text after scale animation
  transition: var(--xzx-dialog-transition);
  transition-property: transform, opacity;

  @media (max-width: 321px) {
    width: var(--xzx-dialog-small-screen-width);
  }

  &__header {
    color: var(--xzx-text-color);
    padding-top: var(--xzx-dialog-header-padding-top);
    font-weight: var(--xzx-dialog-header-font-weight);
    line-height: var(--xzx-dialog-header-line-height);
    text-align: center;

    &--isolated {
      padding: var(--xzx-dialog-header-isolated-padding);
    }
  }

  &__content {
    &--isolated {
      display: flex;
      align-items: center;
      min-height: 104px;
    }
  }

  &__message {
    color: var(--xzx-text-color);
    flex: 1;
    max-height: var(--xzx-dialog-message-max-height);
    padding: 24px var(--xzx-dialog-message-padding);
    overflow-y: auto;
    font-size: var(--xzx-dialog-message-font-size);
    line-height: var(--xzx-dialog-message-line-height);

    // allow newline character
    white-space: pre-wrap;
    text-align: center;
    word-wrap: break-word;
    -webkit-overflow-scrolling: touch;

    &--has-title {
      padding-top: var(--xzx-dialog-has-title-message-padding-top);
      color: var(--xzx-dialog-has-title-message-text-color);
    }

    &--left {
      text-align: left;
    }

    &--right {
      text-align: right;
    }

    &--justify {
      text-align: justify;
    }
  }

  &__footer {
    overflow: hidden;
    user-select: none;
    padding: 0 var(--xzx-padding-lg) var(--xzx-padding-lg) var(--xzx-padding-lg);
  }

  &__footer-text {
    overflow: hidden;
    user-select: none;
    padding: 0;

    .xzx-button:first-child,
    .xzx-button:last-child {
      margin: 0;
    }
  }

  &__icon-type {
    display: flex;
    align-items: center;
    justify-content: center;
    width: 100%;
    flex-shrink: 0;
    font-size: var(--xzx-dialog-type-icon-size);
    padding-bottom: var(--xzx-padding-lg);
  }

  &__confirm,
  &__cancel {
    height: var(--xzx-dialog-button-height);
    margin: 0;
    border: 0;
    border-radius: 0;
  }

  &__confirm {
    &,
    &:active {
      color: var(--xzx-dialog-confirm-button-text-color);
    }
  }

  &--round-button {
    .xzx-dialog__footer {
      position: relative;
      height: auto;
      padding: var(--xzx-padding-xs) var(--xzx-padding-lg) var(--xzx-padding-md);
    }

    .xzx-dialog__message {
      padding-bottom: var(--xzx-padding-md);
      color: var(--xzx-text-color);
    }

    .xzx-dialog__confirm,
    .xzx-dialog__cancel {
      height: var(--xzx-dialog-round-button-height);
    }

    .xzx-dialog__confirm {
      color: var(--xzx-white);
    }

    .xzx-action-bar-button {
      &--first {
        border-top-left-radius: var(--xzx-radius-max);
        border-bottom-left-radius: var(--xzx-radius-max);
      }

      &--last {
        border-top-right-radius: var(--xzx-radius-max);
        border-bottom-right-radius: var(--xzx-radius-max);
      }
    }
  }

  &-bounce-enter-from {
    transform: translate3d(0, -50%, 0) scale(0.7);
    opacity: 0;
  }

  &-bounce-leave-active {
    transform: translate3d(0, -50%, 0) scale(0.9);
    opacity: 0;
  }
}
