AugurProject/augur-ui

View on GitHub
src/modules/modal/components/common/common.styles.less

Summary

Maintainability
Test Coverage
@import (reference) "~assets/styles/shared";

.ModalView {
  background-color: @color-modal-veil;
  height: 100vh;
  position: fixed;
  top: 0;
  width: 100vw;
  z-index: @mask-modal;
}

.ModalView__content {
  align-items: center;
  display: flex;
  flex-direction: column;
  height: 100%;
  justify-content: center;
  width: 100%;

  & > section {
    align-items: center;
    color: @color-white;
    display: flex;
    flex-direction: column;
  }
}

.ModalContainer {
  background-color: @color-white;
  border-radius: 0.32rem;
  color: @color-almostblack;
  max-width: 35rem;
  padding: 1.5rem 0;
  position: relative;
  text-align: center;
  width: 100%;

  > * {
    width: 100%;
  }

  form.ModalTightForm > h1,
  h1 {
    color: @color-almostblack;
    font-size: @font-size-somewhat-large;
    font-weight: 500;
    line-height: 1.75rem;
    margin: 0.5rem 0 1.5rem;
    text-align: center;
  }

  form.ModalTightForm > label {
    color: @color-almostblack;
    font-size: @font-size-medium;
    font-weight: 600;
    line-height: @font-size-large;
    margin: 0 7rem 0.5rem;
    text-align: left;
    width: auto;
  }

  form.ModalTightForm > p,
  > p {
    color: @color-almostblack;
    font-size: @font-size-small;
    line-height: @font-size-large;
    margin: 0;
    padding: 0 4rem;

    &:last-of-type {
      margin-bottom: 1.5rem;
    }

    > button {
      text-decoration: underline;
    }
  }

  form.ModalTightForm > p.Error,
  > p.Error {
    color: @color-red;
  }

  form.ModalTightForm > p.Error {
    margin: 0 7rem 1.5rem;
    padding: 0;
  }

  form.ModalTightForm > div {
    font-size: @font-size-medium;
    line-height: @font-size-normal;
    margin: 0 7rem 1.5rem;
    width: auto;

    > input {
      font-size: @font-size-medium;
      line-height: @font-size-normal;
      padding: @font-size-small @font-size-normal;
    }

    > input::placeholder {
      color: @color-input-border-no-focus;
    }
  }

  form.ModalTightForm > div.ErrorField {
    margin-bottom: 0.5rem;
  }

  form.ModalTightForm > div:last-of-type {
    margin: 0.5rem 0 0;
  }
}

.ModalForm {
  background-color: @color-white;
  color: @color-almostblack;
  max-width: 35rem;
  text-align: left;
  width: 100%;

  > * {
    color: @color-almostblack;
    width: 100%;
  }

  h1 {
    color: @color-almostblack;
    font-size: @font-size-somewhat-large;
    font-weight: 500;
    line-height: 1.75rem;
    margin: 0.5rem 0 1.5rem;
    text-align: center;
  }

  p.Error {
    margin: 0 4rem 1.5rem;
  }

  label {
    color: @color-almostblack;
    font-size: @font-size-medium;
    font-weight: 600;
    line-height: @font-size-large;
    margin: 0 4rem 0.5rem;
    text-align: left;
    text-transform: capitalize;
    width: auto;
  }

  div {
    font-size: @font-size-medium;
    line-height: @font-size-normal;
    margin: 0 4rem 1.5rem;
    width: auto;

    > input {
      font-size: @font-size-medium;
      line-height: @font-size-normal;
      padding: @font-size-small @font-size-normal;
    }

    > input::placeholder {
      color: @color-input-border-no-focus;
    }
  }

  div:last-of-type {
    margin: 0.5rem 0 0;
  }
}

.TightModalContainer {
  background-color: @color-white;
  border-radius: 0.32rem;
  color: @color-almostblack;
  max-width: 20rem;
  padding: 1.5rem 0;
  position: relative;
  text-align: center;
  width: 100%;

  > * {
    width: 100%;
  }

  h1 {
    color: @color-almostblack;
    font-size: @font-size-somewhat-large;
    font-weight: 500;
    line-height: 1.75rem;
    margin: 0.5rem 0 1.5rem;
    text-align: center;
  }

  h2 {
    color: @color-almostblack;
    font-size: @font-size-normal;
    font-weight: 500;
    line-height: @font-size-large;
    margin: 1.5rem 0 0;
    padding: 0 1.5rem;
    text-align: left;
  }

  h3 {
    color: @color-almostblack;
    font-size: @font-size-small;
    font-weight: 400;
    line-height: @font-size-large;
    margin: 0 0 1rem;
    padding: 0 1.5rem;
    text-align: left;
  }

  > div {
    width: 17rem;
  }

  div.ActionButtons {
    width: 100%;
  }
}

.Error {
  color: @color-red;
  display: flex;
  padding: 0;

  > svg {
    height: 1rem;
    line-height: 1rem;
    margin-right: 0.3rem;
    width: 1rem;
  }
}

div.ErrorField,
div.ErrorField:focus-within,
div.ErrorField:focus {
  .border(true, @border-all, @color-red, @border-width-2);

  margin-bottom: 0.5rem;
}

.Warning {
  color: @color-almostblack;
  font-size: @font-size-medium;
  line-height: @font-size-normal;
  margin: 0 0 1.5rem;
  padding: 0 1.5rem;

  > svg {
    height: 1rem;
    line-height: 1rem;
    width: 1rem;
  }
}

.Loading {
  display: flex;
  flex-flow: row nowrap;
  margin: 0.5rem 0;
  max-width: 35rem;
  padding: 0;

  > div {
    display: flex;
    margin: auto;
  }
}

.Receipt {
  background-color: @color-offwhite;
  color: @color-almostblack;
  list-style: none;
  margin: 0 2rem 1.5rem;
  padding: 1rem 0;

  > li {
    align-items: baseline;
    display: flex;
    flex-flow: row nowrap;
    font-size: @font-size-medium;
    line-height: @font-size-normal;
    padding: 0.5rem 0;

    > label {
      color: @color-almostblack;
      flex: 1;
      font-weight: 600;
      margin: 0 1rem 0 auto;
      text-align: right;
    }

    > span:first-of-type {
      color: @color-almostblack;
      flex: 3;
      margin: 0 auto 0 0;
      text-align: left;

      > span {
        font-size: @font-size-extra-small;
        margin-left: 0.25rem;
      }
    }
  }
}

.Description {
  color: @color-almostblack;
  font-size: @font-size-small;
  line-height: @font-size-large;
  margin: 0 0 1.5rem;
  padding: 0 4rem;
}

.ModalTable {
  border-left: 1px solid @color-lightergray;
  border-top: 1px solid @color-lightergray;
  color: @color-almostblack;
  display: flex;
  flex-flow: column;
  margin: 0 0 1.5rem;
}

.ModalTableRow {
  border-bottom: 1px solid @color-lightergray;
  display: flex;
  flex: 1;
  flex-flow: row;

  &:hover {
    background-color: @color-lightpurple;
    color: @color-white;
  }
}

.ModalTableRow__header {
  background-color: @color-offwhite;
  font-size: @font-size-medium;
  line-height: @font-size-normal;

  &:hover {
    background-color: @color-offwhite;
    color: @color-almostblack;
  }
}

.ModalTableColumn {
  border-right: 1px solid @color-lightergray;
  flex: 1;
  font-size: @font-size-small;
  line-height: @font-size-medium;
  padding: 0.25rem 0 0.25rem 1rem;
  text-align: left;
}

.ActionButtons {
  border-top: 1px solid #d8d8d8;
  display: flex;
  flex-flow: row nowrap;
  margin-top: 0.5rem;
  max-width: 35rem;
  padding: 1.5rem 0 0;

  > button {
    line-height: 0;
    min-width: 7rem;
  }
}

.ActionButtons__button {
  margin-right: 1rem;

  &:first-of-type {
    margin-left: auto;
  }

  &:only-of-type {
    margin: auto;
  }

  &:last-of-type {
    margin-right: auto;
  }

  &.disabled {
    pointer-events: none;
  }
}

.ActionButtons__button-gray {
  &:extend(.button--gray all);

  &.disabled {
    &:extend(.button--grey-disabled);
  }
}

.ActionButtons__button-offWhite {
  &:extend(.button--offWhite all);

  &.disabled {
    &:extend(.button--offWhite--disabled);
  }
}

.ActionButtons__button-purple {
  &:extend(.button--purple all);

  &.disabled {
    &:extend(.button--purple--disabled);
  }
}

.ModalDisclaimer {
  background-color: @color-white;
  border-radius: 0.32rem;
  color: @color-almostblack;
  flex-flow: row nowrap;
  max-width: 35rem;
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
  padding: 1.5rem 0;
  position: relative;
  text-align: center;
  width: 100%;

  > * {
    width: 100%;
  }

  h1 {
    color: @color-almostblack;
    font-size: @font-size-somewhat-large;
    font-weight: 500;
    line-height: 1.75rem;
    margin: 0.5rem 0 1.5rem;
  }
}

.ModalDisclaimer__TextBox {
  background-color: @color-offwhite;
  margin: 0 2rem 1.5rem;
  max-height: 25rem;
  max-width: 35rem;
  overflow: auto;
  -webkit-overflow-scrolling: touch;
  padding: 0.5rem 2rem;
  text-align: left;
  width: auto;

  > p {
    color: @color-almostblack;
    font-size: @font-size-medium;
    line-height: @font-size-somewhat-large;
    margin: 0 0 1.5rem;
  }
}

.ModalDisclaimer__helperText {
  display: flex;
  flex-flow: row nowrap;
  margin-bottom: 1rem;

  > label {
    align-items: center;
    color: @color-almostblack;
    display: flex;
    font-size: @font-size-medium;
    font-weight: normal;
    line-height: @font-size-normal;
    margin: 0 5rem 0 4rem;
    text-align: left;
    text-transform: none;
    width: 100%;
  }
}

.ModalDisclaimer__checkbox {
  display: flex;
  flex-flow: row nowrap;
  margin-bottom: 1rem;

  > label {
    align-items: center;
    color: @color-almostblack;
    display: flex;
    font-size: @font-size-medium;
    font-weight: bold;
    line-height: @font-size-normal;
    margin: 0 4rem;
    text-transform: none;
    width: 100%;

    > div {
      margin-right: 2rem;
    }
  }
}

.ModalDisclaimer__ActionButtons {
  border-top: 1px solid #d8d8d8;
  display: flex;
  flex-flow: column;
  justify-content: space-between;
  max-width: 35rem;
  padding: 0 2rem;

  > label {
    align-items: flex-end;
    color: @color-almostblack;
    display: flex;
    margin: 1.5rem 0;

    > input {
      height: 1rem;
      margin-left: 1rem;
      width: 1rem;
    }
  }

  > button {
    &:extend(.button--purple all);

    margin: 0 auto;

    &.disabled {
      &:extend(.button--purple--disabled);

      pointer-events: none;
    }
  }
}

.ModalMarketReview,
.ModalMarketsV2Alert {
  background-color: @color-white;
  border-radius: 0.32rem;
  color: @color-almostblack;
  flex-flow: row nowrap;
  max-width: 35rem;
  -webkit-overflow-scrolling: touch;
  overflow-y: auto;
  padding: 1.5rem 0;
  position: relative;
  text-align: center;
  width: 100%;

  h1 {
    color: @color-almostblack;
    font-size: 1.375rem;
    font-weight: bold;
    margin: 0 0 0.25rem;
    text-align: center;
  }
}

.ModalMarketReview__Header {
  color: @color-almostblack;
  font-size: 0.875rem;
  font-weight: normal;
  padding: 0 2rem 1rem;
  text-align: left;

  > p:first-of-type {
    > span {
      font-weight: bold;
    }
  }
}

.ModalMarketReview__ReadMore {
  color: @color-almostblack;
  cursor: pointer;
  font-weight: bold;
}

.ModalMarketReview__TextBox,
.ModalMarketsV2Alert__Markets {
  background-color: @color-offwhite;
  color: @color-almostblack;
  margin: 0 2rem 1.5rem;
  overflow-wrap: break-word;
  padding: 1.5rem 2rem;
  text-align: left;
  width: 89%;

  > div {
    > p {
      font-size: 0.875rem;
      font-weight: bold;
      margin: 0 0 0.25rem;
      text-transform: uppercase;
    }

    font-size: 0.875rem;
    font-weight: normal;
    margin: 0 0 1rem;
  }
}

.ModalMarketReview__checkbox {
  display: flex;
  flex-flow: row nowrap;
  margin-bottom: 1.5rem;
  width: 100%;

  > label {
    align-items: center;
    color: @color-darkpurple;
    display: flex;
    font-size: 0.875rem;
    font-weight: bold;
    margin: 0 2rem;
    text-transform: none;
    user-select: none;

    > div {
      margin-right: 2rem;
    }
  }

  &:active,
  &:focus {
    outline: none;
  }
}

.ModalMarketReview__ActionButtons {
  border-top: 1px solid #d8d8d8;
  display: flex;
  justify-content: center;
  padding: 1.5rem 2rem 0;
  width: 100%;

  > div:first-of-type {
    margin-right: 1rem;
  }

  > div:last-of-type button {
    padding: 1rem;
  }

  > div {
    border: 0;
    margin: 0;
    padding: 0;
  }
}

.ModalMarketsV2Alert {
  margin: 3rem 0;
  padding: 2.125rem 0 1.5rem;

  > h1 {
    color: @color-cuttoff-red;
    margin: 0;
  }

  @media @breakpoint-mobile {
    margin: 0;
  }
}

.ModalMarketsV2Alert__Header,
.ModalMarketsV2Alert__Warning {
  color: @color-almostblack;
  font-size: 0.875rem;
  font-weight: normal;
  padding: 0 2rem 1rem;
  text-align: left;

  a {
    text-decoration: underline;
  }

  > p {
    line-height: 18px;
    margin: 1rem 0;
  }

  > p:last-of-type {
    font-weight: bold;
    margin: 1rem 0 0;
  }
}

.ModalMarketsV2Alert__Warning {
  color: @color-cuttoff-red;
  padding: 0 2rem 1rem;

  > p {
    margin: 0;
  }
}

.ModalMarketsV2Alert__Markets {
  background-color: @color-offwhite;
  color: @color-almostblack;
  margin: 0 2rem;
  overflow: auto;
  overflow-wrap: break-word;
  padding: 1.5rem;
  text-align: left;
  text-decoration-line: underline;
  width: 89%;

  > div {
    font-size: 0.875rem;
    font-weight: normal;
    margin: 0 0 1rem;
  }

  > div:last-of-type {
    margin: 0;
  }
}

.ModalConfirm {
  > p {
    font-size: @font-size-medium;
    margin-bottom: 1.25rem;
    padding: 0 2rem;
    text-align: left;
  }

  > p:last-of-type {
    margin-bottom: 2.25rem;
  }
}

@media @breakpoint-mobile-small {
  .ModalView__content {
    padding: 1rem;
  }

  .ModalView__content--taller {
    justify-content: flex-start;
  }

  .ModalContainer > p,
  form.ModalTightForm > p {
    padding: 0 1.5rem;
  }

  .ModalForm {
    div,
    p,
    p.Error {
      margin: 0 1.5rem 1.5rem;
    }

    p.Error {
      padding: 0;
    }

    div.ErrorField {
      margin: 0 1.5rem 0.5rem;
    }

    div:last-of-type {
      margin: 0.5rem 0 0;
    }

    label {
      margin: 0 1.5rem 0.5rem;
    }
  }

  .ActionButtons {
    > button {
      min-width: 7rem;
    }
  }

  .ModalDisclaimer__TextBox {
    margin: 0 1rem 1rem;
    max-height: 20rem;
    padding: 0.5rem 1rem;
  }

  .ModalDisclaimer__helperText,
  .ModalDisclaimer__checkbox {
    > label {
      font-size: @font-size-small;
      line-height: @font-size-small;
      margin: 0 1.5rem;
    }
  }

  .ModalDisclaimer {
    > h1 {
      margin: 0 0 1rem;
    }
  }
}

@media @breakpoint-mobile-extra-small {
  .ModalDisclaimer__TextBox {
    margin: 0 1rem 1rem;
    max-height: 10rem;
  }

  .ModalDisclaimer {
    padding: 1rem 0;

    > h1 {
      margin: 0 0 1rem;
    }

    .ModalDisclaimer__helperText,
    .ModalDisclaimer__checkbox {
      > label {
        margin: 0 1rem;
      }
    }

    .ActionButtons {
      padding: 1rem 0 0;
    }
  }
}

@media @breakpoint-mobile-smaller-height,
  @breakpoint-mobile-extra-small-height {
  .ModalDisclaimer {
    max-height: 75vh;
    max-width: 90vw;
    padding: 0.5rem 0;

    > h1 {
      margin: 0 0 0.5rem;
    }

    .ActionButtons {
      margin: 0;
      max-width: 90vw;
      padding: 0.5rem 0 0;
    }
  }

  .ModalDisclaimer__TextBox {
    margin: 0 0.5rem 0.5rem;
    max-height: 6rem;
    max-width: none;
    padding: 0 0.5rem;
  }

  .ModalDisclaimer__helperText,
  .ModalDisclaimer__checkbox {
    margin-bottom: 0.5rem;

    > label {
      font-size: @font-size-small;
      line-height: @font-size-small;
      margin: 0 1rem;
    }
  }
}