@import "../../../style/mixin.less";

@keyframes fade-scale-on {

    0% {
        opacity: 0; transform: scale(.5); }

    100% {
        opacity: 1; transform: scale(1); }
}

@keyframes fade-scale-off {

    0% {
        opacity: 1; transform: scale(1); }

    100% {
        opacity: 0; transform: scale(.5); }
}

.@{prefix}-fade-scale-enter-active {
    animation: fade-scale-on cubic-bezier(.2, 1.23, .25, 1) forwards;
    animation-duration: var(--builtin-transition-fade-scale-enter-duration, .45s);
}

.@{prefix}-fade-scale-exit-active {
    animation: fade-scale-off cubic-bezier(.48, .04, .52, .96) forwards;
    animation-duration: var(--builtin-transition-fade-scale-exit-duration, .15s);
}

.@{prefix}-dialog {

    &-mask,
    &-container {
        position: fixed;
        top: 0;
        left: 0;
        width: 100%;
        height: 100%;
    }

    &-mask {
        z-index: @full-screen-z-index;
        .use-var(background, dialog-mask-background);
    }

    &-container {
        display: flex;
        align-items: center;
        justify-content: center;
        z-index: @full-screen-z-index + 1;
        pointer-events: none;
    }

    &-content {
        position: relative;
        .use-var(width, dialog-content-width);
        pointer-events: visible;

        &.android {
            .use-var(width, dialog-content-android-width);
        }
    }

    &-container.pre-mount &-content,
    &-container[class*="-exit-done"] &-content {
        pointer-events: none;
    }

    &-part {
        .use-var(background, dialog-content-background);

        &.android {

            &:first-of-type {
                .use-var(border-top-left-radius, dialog-content-android-border-radius);
                .use-var(border-top-right-radius, dialog-content-android-border-radius);
            }

            &:last-of-type {
                .use-var(border-bottom-left-radius, dialog-content-android-border-radius);
                .use-var(border-bottom-right-radius, dialog-content-android-border-radius);
            }
        }

        &.ios {

            &:first-of-type {
                .use-var(border-top-left-radius, dialog-content-border-radius);
                .use-var(border-top-right-radius, dialog-content-border-radius);
            }

            &:last-of-type {
                .use-var(border-bottom-left-radius, dialog-content-border-radius);
                .use-var(border-bottom-right-radius, dialog-content-border-radius);
            }
        }
    }

    &-header {
        position: relative;

        &.ios {
            text-align: center;
            .use-var(padding-top, dialog-ios-vertical-padding);
            .use-var(padding-left, dialog-ios-horizontal-padding);
            .use-var(padding-right, dialog-ios-horizontal-padding);
            .use-var(font-size, dialog-header-ios-font-size);
            .use-var(line-height, dialog-header-ios-line-height);
            .text-medium();

            &.only-title {
                .use-var(padding-bottom, dialog-ios-vertical-padding);
            }
        }

        &.android {
            .use-var(color, dialog-header-android-color);
        }
    }

    &-body {

        &.ios {
            .use-var(padding-top, dialog-ios-header-body-gutter);
            .use-var(padding-left, dialog-ios-horizontal-padding);
            .use-var(padding-right, dialog-ios-horizontal-padding);
            .use-var(padding-bottom, dialog-ios-vertical-padding);
            .use-var(color, dialog-body-ios-color);
            .use-var(font-size, dialog-body-ios-font-size);
            .use-var(line-height, dialog-body-ios-line-height);

            &.sub-title {
                .use-var(padding-top, dialog-ios-vertical-padding);
            }
        }

        &.android {
            .use-var(padding-top, dialog-android-header-body-gutter);
            .use-var(padding-left, dialog-android-horizontal-padding);
            .use-var(padding-right, dialog-android-horizontal-padding);
            .use-var(color, dialog-body-android-color);
            .use-var(font-size, dialog-body-android-font-size);
            .use-var(line-height, dialog-body-android-line-height);
        }
    }

    &-header,
    &-body {

        &.left {
            .set-value-with-rtl(text-align, left);
        }

        &.center {
            text-align: center;
        }

        &.right {
            .set-value-with-rtl(text-align, right);
        }
    }

    &-header,
    &-body.sub-title {

        &.android {
            .use-var(padding-top, dialog-android-vertical-padding);
            .use-var(padding-left, dialog-android-horizontal-padding);
            .use-var(padding-right, dialog-android-horizontal-padding);
            .use-var(font-size, dialog-header-android-font-size);
            .use-var(line-height, dialog-header-android-line-height);
        }

        &.ios {
            .use-var(color, dialog-header-ios-color);
        }
    }

    &-footer {
        display: flex;
        align-items: center;

        &.android {
            .use-var(padding-left, dialog-android-horizontal-padding);
            .use-var(padding-right, dialog-android-horizontal-padding);
            .use-var(padding-top, dialog-android-body-footer-gutter);
            .use-var(padding-bottom, dialog-android-vertical-padding);
            justify-content: flex-end;
            .set-value-with-rtl(text-align, right);

            .dialog-footer-button {
                .use-var(color, dialog-footer-android-color);
                .use-var(font-size, dialog-footer-android-font-size);
                .use-var(line-height, dialog-footer-android-line-height);

                &:not(:last-child) {
                    .use-var-with-rtl(margin-right, dialog-footer-android-button-gutter);
                }
            }
        }

        &.ios {
            overflow: hidden;

            .dialog-footer-button {
                display: flex;
                justify-content: center;
                align-items: center;
                .use-var(height, dialog-footer-ios-height);
                .use-var(font-size, dialog-footer-ios-font-size);
                .use-var(color, dialog-footer-ios-color);
            }

            &:not(.collapsed):not(.type-button) {
                .onepx-border-var(top, line-color);

                .dialog-footer-button {
                    flex: 1;

                    &:not(:last-child) {
                        .onepx-border-var(right, line-color);

                        [dir='rtl'] & {
                            .onepx-border-var(left, line-color);
                            &::after {
                                display: none;
                            }
                        }
                    }
                }
            }

            &.collapsed {
                flex-direction: column;

                .dialog-footer-button {
                    width: 100%;
                    .onepx-border-var(top, line-color);
                }
            }

            &.type-button {
                flex-direction: column;
                .use-var(padding-left, dialog-ios-horizontal-padding);
                .use-var(padding-right, dialog-ios-horizontal-padding);
                .use-var(padding-bottom, dialog-ios-vertical-padding);

                .dialog-footer-button {
                    width: 100%;
                    .use-var(border-radius, dialog-button-footer-border-radius);
                    .use-var(height, dialog-button-footer-height);

                    &:first-child {
                        .use-var(color, dialog-button-footer-primary-color);
                        .use-var(background, dialog-button-footer-primary-background);
                    }

                    &:not(:first-child) {
                        .use-var(color, dialog-button-footer-color);
                        .use-var(margin-top, dialog-button-footer-gutter);
                    }

                    &:last-child {
                        .rem(margin-bottom, -7);
                    }
                }
            }
        }
    }
}

/***************************************************
 *                                                 *
 *               Arco Theme Style                  *
 *                                                 *
 ***************************************************/
& when (@use-dark-mode = 1) {
    
  .process-bg-color-with-config,
  .process-custom-icon-bg-color-with-config {
    @{arco-dark-mode-selector} & {
      .use-var(color, dark-steps-process-with-config-item-icon-color);
      .use-var(color, dark-steps-process-with-config-item-icon-color);
    }
  }
  .wait-custom-icon-bg-color-with-config {
    @{arco-dark-mode-selector} & {
      .use-var(background, dark-steps-wait-icon-num-background);
      .use-var(color, dark-sub-info-font-color);
      .use-var(background, dark-steps-wait-icon-num-background);
      .use-var(color, dark-sub-info-font-color);
    }
  }
  .@{prefix}-dialog {
    &-part {
      @{arco-dark-mode-selector} & {
        .use-var(background, dark-dialog-content-background);
      }
    }
    &-header {
      &.android {
        @{arco-dark-mode-selector} & {
          .use-var(color, dark-dialog-header-android-color);
        }
      }
    }
    &-body {
      &.ios {
        @{arco-dark-mode-selector} & {
          .use-var(color, dark-dialog-body-ios-color);
        }
      }
      &.android {
        @{arco-dark-mode-selector} & {
          .use-var(color, dark-dialog-body-android-color);
        }
      }
    }
    &-header,
    &-body.sub-title {
      &.ios {
        @{arco-dark-mode-selector} & {
          .use-var(color, dark-dialog-header-ios-color);
        }
      }
    }
    &-footer {
      &.ios {
        .dialog-footer-button {
          @{arco-dark-mode-selector} & {
            .use-var(color, dark-dialog-footer-ios-color);
          }
        }
        &:not(.collapsed):not(.type-button) {
          @{arco-dark-mode-selector} & {
            .onepx-border-var(top, dark-line-color);
          }
          .dialog-footer-button {
            &:not(:last-child) {
              @{arco-dark-mode-selector} & {
                .onepx-border-var(right, dark-line-color);
              }
              [dir='rtl'] & {
                @{arco-dark-mode-selector} & {
                  .onepx-border-var(left, dark-line-color);
                }
              }
            }
          }
        }
        &.collapsed {
          .dialog-footer-button {
            @{arco-dark-mode-selector} & {
              .onepx-border-var(top, dark-line-color);
            }
          }
        }
        &.type-button {
          .dialog-footer-button {
            &:first-child {
              @{arco-dark-mode-selector} & {
                .use-var(color, dark-dialog-button-footer-primary-color);
                .use-var(background, dark-dialog-button-footer-primary-background);
              }
            }
            &:not(:first-child) {
              @{arco-dark-mode-selector} & {
                .use-var(color, dark-dialog-button-footer-color);
              }
            }
          }
        }
      }
    }
  }
}
/********************* End *************************/
