| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237238239240241242243244245246247248249250251252253254255256257258259260261262263264265266267268269270271272273274275276277278279280281282283284285286287288289290291292293294295296297298299300301302303304305306307308309310311312313314315316317318319320321322323324325326327328329330331332333334335336337338339340341342343344345346347348349350351352353354355356357358359360361362363364365366367368369370371372373374375376377378379380381382383384385386387388389390391392393394395396397398399400401402403404405406407408409410411412413414415416417418419420421422423424425426427428429430431432433434435436437438439440441442443444445446447448449450451452453454455456457458459460461462463464465466467468469470471472473474475476477478479480481482483484485486487488489490491492493494495496497498499500501502503504505506507508509510511512513514515516517518519520521522523524525526527528529530531532533534535536537538539540541542543544545546547548549550551552553554555556557558559560561562563564565566567568569570571572573574575576577578579580581582583584585586587588589 | @import '../../style/themes/index';@import '../../style/mixins/index';@upload-prefix-cls: ~'@{ant-prefix}-upload';@upload-item: ~'@{ant-prefix}-upload-list-item';@upload-picture-card-size: 104px;@upload-picture-card-border-style: @border-style-base;.@{upload-prefix-cls} {  .reset-component();  outline: 0;  p {    margin: 0;  }  &-btn {    display: block;    width: 100%;    outline: none;  }  input[type='file'] {    cursor: pointer;  }  &&-select {    display: inline-block;  }  &&-disabled {    cursor: not-allowed;  }  &&-select-picture-card {    width: @upload-picture-card-size;    height: @upload-picture-card-size;    margin-right: 8px;    margin-bottom: 8px;    text-align: center;    vertical-align: top;    background-color: @background-color-light;    border: @border-width-base dashed @border-color-base;    border-radius: @border-radius-base;    cursor: pointer;    transition: border-color 0.3s;    > .@{upload-prefix-cls} {      display: flex;      align-items: center;      justify-content: center;      height: 100%;      text-align: center;    }    &:hover {      border-color: @primary-color;      .@{upload-prefix-cls}-disabled& {        border-color: @border-color-base;      }    }  }  &&-drag {    position: relative;    width: 100%;    height: 100%;    text-align: center;    background: @background-color-light;    border: @border-width-base dashed @border-color-base;    border-radius: @border-radius-base;    cursor: pointer;    transition: border-color 0.3s;    .@{upload-prefix-cls} {      padding: @padding-md 0;    }    &.@{upload-prefix-cls}-drag-hover:not(.@{upload-prefix-cls}-disabled) {      border-color: @primary-7;    }    &.@{upload-prefix-cls}-disabled {      cursor: not-allowed;    }    .@{upload-prefix-cls}-btn {      display: table;      height: 100%;    }    .@{upload-prefix-cls}-drag-container {      display: table-cell;      vertical-align: middle;    }    &:not(.@{upload-prefix-cls}-disabled):hover {      border-color: @primary-5;    }    p.@{upload-prefix-cls}-drag-icon {      .@{iconfont-css-prefix} {        color: @primary-5;        font-size: 48px;      }      margin-bottom: 20px;    }    p.@{upload-prefix-cls}-text {      margin: 0 0 4px;      color: @heading-color;      font-size: @font-size-lg;    }    p.@{upload-prefix-cls}-hint {      color: @text-color-secondary;      font-size: @font-size-base;    }    .@{iconfont-css-prefix}-plus {      color: @disabled-color;      font-size: 30px;      transition: all 0.3s;      &:hover {        color: @text-color-secondary;      }    }    &:hover .@{iconfont-css-prefix}-plus {      color: @text-color-secondary;    }  }  &-picture-card-wrapper {    .clearfix();    display: inline-block;    width: 100%;  }}.@{upload-prefix-cls}-list {  .reset-component();  .clearfix();  line-height: @line-height-base;  // ============================ Item ============================  &-item {    position: relative;    height: @line-height-base * @font-size-base;    margin-top: @margin-xs;    font-size: @font-size-base;    &-name {      display: inline-block;      width: 100%;      padding-left: @font-size-base + 8px;      overflow: hidden;      line-height: @line-height-base;      white-space: nowrap;      text-overflow: ellipsis;    }    &-card-actions {      position: absolute;      right: 0;      &-btn {        opacity: 0;      }      &-btn.@{ant-prefix}-btn-sm {        height: 20px;        line-height: 1;      }      &.picture {        top: 22px;        line-height: 0;      }      &-btn:focus,      &.picture &-btn {        opacity: 1;      }      .@{iconfont-css-prefix} {        color: @upload-actions-color;      }    }    &-info {      height: 100%;      padding: 0 4px;      transition: background-color 0.3s;      > span {        display: block;        width: 100%;        height: 100%;      }      .@{iconfont-css-prefix}-loading,      .@{upload-prefix-cls}-text-icon {        .@{iconfont-css-prefix} {          position: absolute;          top: (@font-size-base / 2) - 2px;          color: @text-color-secondary;          font-size: @font-size-base;        }      }    }    .@{iconfont-css-prefix}-close {      position: absolute;      top: 6px;      right: 4px;      color: @text-color-secondary;      font-size: 10px;      line-height: 0;      cursor: pointer;      opacity: 0;      transition: all 0.3s;      &:hover {        color: @text-color;      }    }    &:hover &-info {      background-color: @item-hover-bg;    }    &:hover .@{iconfont-css-prefix}-close {      opacity: 1;    }    &:hover &-card-actions-btn {      opacity: 1;    }    &-error,    &-error .@{upload-prefix-cls}-text-icon > .@{iconfont-css-prefix},    &-error &-name {      color: @error-color;    }    &-error &-card-actions {      .@{iconfont-css-prefix} {        color: @error-color;      }      &-btn {        opacity: 1;      }    }    &-progress {      position: absolute;      bottom: -12px;      width: 100%;      padding-left: @font-size-base + 12px;      font-size: @font-size-base;      line-height: 0;    }  }  // =================== Picture & Picture Card ===================  &-picture,  &-picture-card {    .@{upload-item} {      position: relative;      height: 66px;      padding: @padding-xs;      border: @border-width-base @upload-picture-card-border-style @border-color-base;      border-radius: @border-radius-base;      &:hover {        background: transparent;      }      &-error {        border-color: @error-color;      }    }    .@{upload-item}-info {      padding: 0;    }    .@{upload-item}:hover .@{upload-item}-info {      background: transparent;    }    .@{upload-item}-uploading {      border-style: dashed;    }    .@{upload-item}-thumbnail {      width: 48px;      height: 48px;      line-height: 60px;      text-align: center;      opacity: 0.8;      .@{iconfont-css-prefix} {        font-size: 26px;      }    }    // Adjust the color of the error icon : https://github.com/ant-design/ant-design/pull/24160    .@{upload-item}-error .@{upload-item}-thumbnail {      .@{iconfont-css-prefix} {        svg path {          &[fill='#e6f7ff'] {            fill: @error-color-deprecated-bg;          }          &[fill='#1890ff'] {            fill: @error-color;          }        }      }    }    .@{upload-item}-icon {      position: absolute;      top: 50%;      left: 50%;      font-size: 26px;      transform: translate(-50%, -50%);      .@{iconfont-css-prefix} {        font-size: 26px;      }    }    .@{upload-item}-image {      max-width: 100%;    }    .@{upload-item}-thumbnail img {      display: block;      width: 48px;      height: 48px;      overflow: hidden;    }    .@{upload-item}-name {      display: inline-block;      box-sizing: border-box;      max-width: 100%;      margin: 0 0 0 8px;      padding-right: 8px;      padding-left: 48px;      overflow: hidden;      line-height: 44px;      white-space: nowrap;      text-overflow: ellipsis;      transition: all 0.3s;    }    .@{upload-item}-uploading .@{upload-item}-name {      margin-bottom: 12px;    }    .@{upload-item}-progress {      bottom: 14px;      width: ~'calc(100% - 24px)';      margin-top: 0;      padding-left: 56px;    }    .@{iconfont-css-prefix}-close {      position: absolute;      top: 8px;      right: 8px;      line-height: 1;      opacity: 1;    }  }  // ======================== Picture Card ========================  &-picture-card {    &-container {      display: inline-block;      width: @upload-picture-card-size;      height: @upload-picture-card-size;      margin: 0 @margin-xs @margin-xs 0;      vertical-align: top;    }    &.@{upload-prefix-cls}-list::after {      display: none;    }    .@{upload-item} {      height: 100%;      margin: 0;    }    .@{upload-item}-info {      position: relative;      height: 100%;      overflow: hidden;      &::before {        position: absolute;        z-index: 1;        width: 100%;        height: 100%;        background-color: fade(@black, 50%);        opacity: 0;        transition: all 0.3s;        content: ' ';      }    }    .@{upload-item}:hover .@{upload-item}-info::before {      opacity: 1;    }    .@{upload-item}-actions {      position: absolute;      top: 50%;      left: 50%;      z-index: 10;      white-space: nowrap;      transform: translate(-50%, -50%);      opacity: 0;      transition: all 0.3s;      .@{iconfont-css-prefix}-eye,      .@{iconfont-css-prefix}-download,      .@{iconfont-css-prefix}-delete {        z-index: 10;        width: 16px;        margin: 0 4px;        color: @text-color-dark;        font-size: 16px;        cursor: pointer;        transition: all 0.3s;        &:hover {          color: @text-color-inverse;        }      }    }    .@{upload-item}-info:hover + .@{upload-item}-actions,    .@{upload-item}-actions:hover {      opacity: 1;    }    .@{upload-item}-thumbnail,    .@{upload-item}-thumbnail img {      position: static;      display: block;      width: 100%;      height: 100%;      object-fit: contain;    }    .@{upload-item}-name {      display: none;      margin: 8px 0 0;      padding: 0;      line-height: @line-height-base;      text-align: center;    }    .@{upload-item}-file + .@{upload-item}-name {      position: absolute;      bottom: 10px;      display: block;    }    .@{upload-item}-uploading {      &.@{upload-item} {        background-color: @background-color-light;      }      .@{upload-item}-info {        height: auto;        &::before,        .@{iconfont-css-prefix}-eye,        .@{iconfont-css-prefix}-delete {          display: none;        }      }    }    .@{upload-item}-progress {      bottom: 32px;      width: calc(100% - 14px);      padding-left: 0;    }  }  // ======================= Picture & Text =======================  &-text,  &-picture {    &-container {      transition: opacity @animation-duration-slow, height @animation-duration-slow;      &::before {        display: table;        width: 0;        height: 0;        content: '';      }      // Don't know why span here, just stretch it      .@{upload-prefix-cls}-span {        display: block;        flex: auto;      }    }    // text & picture no need this additional element.    // But it used for picture-card, let's keep it.    .@{upload-prefix-cls}-span {      display: flex;      align-items: center;      > * {        flex: none;      }    }    .@{upload-item}-name {      flex: auto;      margin: 0;      padding: 0 @padding-xs;    }    .@{upload-item}-card-actions {      position: static;    }  }  // ============================ Text ============================  &-text {    .@{upload-prefix-cls}-text-icon {      .@{iconfont-css-prefix} {        position: static;      }    }  }  // =========================== Motion ===========================  .@{upload-prefix-cls}-animate-inline-appear,  .@{upload-prefix-cls}-animate-inline-enter,  .@{upload-prefix-cls}-animate-inline-leave {    animation-duration: @animation-duration-slow;    animation-fill-mode: @ease-in-out-circ;  }  .@{upload-prefix-cls}-animate-inline-appear,  .@{upload-prefix-cls}-animate-inline-enter {    animation-name: uploadAnimateInlineIn;  }  .@{upload-prefix-cls}-animate-inline-leave {    animation-name: uploadAnimateInlineOut;  }}@keyframes uploadAnimateInlineIn {  from {    width: 0;    height: 0;    margin: 0;    padding: 0;    opacity: 0;  }}@keyframes uploadAnimateInlineOut {  to {    width: 0;    height: 0;    margin: 0;    padding: 0;    opacity: 0;  }}@import './rtl';
 |