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

:root,
:host {
  --xzx-uploader-size: 80px;
  --xzx-uploader-icon-size: 24px;
  --xzx-uploader-icon-color: var(--xzx-text-gray-3);
  --xzx-uploader-text-color: var(--xzx-text-gray-2);
  --xzx-uploader-text-font-size: var(--xzx-text-sm);
  --xzx-uploader-upload-background: var(--xzx-gray-1);
  --xzx-uploader-upload-active-color: var(--xzx-color-primary-focus);
  --xzx-uploader-delete-color: var(--xzx-text-white-1);
  --xzx-uploader-delete-icon-size: 20px;
  --xzx-uploader-delete-background: var(--xzx-text-gray-3);
  --xzx-uploader-file-background: var(--xzx-color-white);
  --xzx-uploader-file-icon-size: 20px;
  --xzx-uploader-file-icon-color: var(--xzx-gray-7);
  --xzx-uploader-file-name-padding: 0 var(--xzx-padding-base);
  --xzx-uploader-file-name-margin-top: var(--xzx-padding-xs);
  --xzx-uploader-file-name-font-size: var(--xzx-text-sm);
  --xzx-uploader-file-name-text-color: var(--xzx-gray-7);
  --xzx-uploader-mask-text-color: var(--xzx-text-white-1);
  --xzx-uploader-mask-background: rgba(50, 50, 51, 0.88);
  --xzx-uploader-mask-icon-size: 22px;
  --xzx-uploader-mask-message-font-size: var(--xzx-text-sm);
  --xzx-uploader-mask-message-line-height: var(--xzx-text-lh-xs);
  --xzx-uploader-loading-icon-size: 22px;
  --xzx-uploader-loading-icon-color: var(--xzx-text-white-1);
  --xzx-uploader-disabled-opacity: var(--xzx-disabled-opacity);
  --xzx-uploader-border-radius: var(--xzx-br-base);
}

@include b(upload) {
  border-radius: 13px;
  position: relative;
  display: inline-block;

  &__wrapper {
    display: flex;
    flex-wrap: wrap;

    &--disabled {
      opacity: var(--xzx-uploader-disabled-opacity);
    }
  }

  &__input {
    position: absolute;
    top: 0;
    left: 0;
    width: 100%;
    height: 100%;
    overflow: hidden; // to clip file-upload-button
    cursor: pointer;
    opacity: 0;

    &-wrapper {
      position: relative;
    }

    &:disabled {
      cursor: not-allowed;
    }
  }

  &__upload {
    position: relative;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    box-sizing: border-box;
    width: var(--xzx-uploader-size);
    height: var(--xzx-uploader-size);
    margin: 0 var(--xzx-padding-xs) var(--xzx-padding-md) 0;
    background: var(--xzx-uploader-upload-background);
    border-radius: var(--xzx-uploader-border-radius);

    &:active {
      background-color: var(--xzx-uploader-upload-active-color);
    }

    &--readonly:active {
      background-color: var(--xzx-uploader-upload-background);
    }

    &-icon {
      color: var(--xzx-uploader-icon-color);
      font-size: var(--xzx-uploader-icon-size);
    }

    &-text {
      margin-top: var(--xzx-padding-xs);
      color: var(--xzx-uploader-text-color);
      font-size: var(--xzx-uploader-text-font-size);
    }
  }

  &__preview {
    position: relative;
    margin: 0 var(--xzx-padding-xs) var(--xzx-padding-md) 0;
    cursor: pointer;

    &-image {
      display: block;
      width: var(--xzx-uploader-size);
      height: var(--xzx-uploader-size);
      overflow: hidden;
      border-radius: var(--xzx-uploader-border-radius);
    }

    &-delete {
      position: absolute;
      top: 0;
      right: 0;

      &--shadow {
        width: var(--xzx-uploader-delete-icon-size);
        height: var(--xzx-uploader-delete-icon-size);
        background: var(--xzx-uploader-delete-background);
        border-radius: 0 var(--xzx-uploader-border-radius) 0
          var(--xzx-uploader-border-radius);
        display: flex;
        justify-content: center;
        align-items: center;
        padding: 2px;
        box-sizing: border-box;
      }

      &-icon {
        color: var(--xzx-uploader-delete-color);
        font-size: 0.8em;
      }
    }

    &-cover {
      position: absolute;
      top: 0;
      right: 0;
      bottom: 0;
      left: 0;
    }
  }

  &__mask {
    position: absolute;
    top: 0;
    right: 0;
    bottom: 0;
    left: 0;
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    color: var(--xzx-uploader-mask-text-color);
    background: var(--xzx-uploader-mask-background);
    border-radius: var(--xzx-uploader-border-radius);

    &-icon {
      font-size: var(--xzx-uploader-mask-icon-size);
    }

    &-message {
      margin-top: 6px;
      padding: 0 var(--xzx-padding-base);
      font-size: var(--xzx-uploader-mask-message-font-size);
      line-height: var(--xzx-uploader-mask-message-line-height);
    }
  }

  &__loading {
    width: var(--xzx-uploader-loading-icon-size);
    height: var(--xzx-uploader-loading-icon-size);
    color: var(--xzx-uploader-loading-icon-color);
  }

  &__file {
    display: flex;
    flex-direction: column;
    align-items: center;
    justify-content: center;
    width: var(--xzx-uploader-size);
    height: var(--xzx-uploader-size);
    background: var(--xzx-uploader-file-background);

    &-icon {
      color: var(--xzx-uploader-file-icon-color);
      font-size: var(--xzx-uploader-file-icon-size);
    }

    &-name {
      box-sizing: border-box;
      width: 100%;
      margin-top: var(--xzx-uploader-file-name-margin-top);
      padding: var(--xzx-uploader-file-name-padding);
      color: var(--xzx-uploader-file-name-text-color);
      font-size: var(--xzx-uploader-file-name-font-size);
      text-align: center;
    }
  }
}
