department-of-veterans-affairs/vets-website

View on GitHub
src/applications/letters/sass/letters.scss

Summary

Maintainability
Test Coverage
@import "~@department-of-veterans-affairs/formation/sass/shared-variables";
@import "~@department-of-veterans-affairs/css-library/dist/stylesheets/modules/m-form-process";
@import "../../../platform/forms/sass/m-schemaform";

@mixin schemaform-padding {
  // query borrowed from _m-schemaform.scss
  @media(max-width: 40.063em) {
    padding-right: 1.25rem - 0.5859375rem;
  }
}

// When AddressSection mounts, it calls focusElement('#content')
// The function needs to set a tabindex so it can focus on the element
// This triggers the [tabindex]:focus rule in USWDS which gives a golden outline
// We don't want that outline around #content
#content[tabindex]:focus {
    outline: none;
}

.letters {
  h5 {
    padding-top: 1.5em;
  }

  .form-process-total {
    padding-left: 4px;
  }

  .feature {
    margin-top: 1em;
    min-height: 0;

    &.help-desk {
      margin-top: 2em;

      h2 {
        margin-top: .5em;
      }
    }
  }

  .usa-alert {
    .address-block h5 {
      margin-top: 0.3125rem;
    }
  }

  .address-block {
    background-color: var(--vads-color-base-lightest);
    padding: 1em;

    h5 {
      color: var(--vads-color-primary-dark);
      padding: 0;

      &:focus {
        outline: none;
      }
    }

    button {
      margin-top: 2em;

      &.va-modal-close {
        margin-top: 0.15625rem;
      }

      &.address-help-btn {
        background-color: transparent;
        color: var(--vads-color-primary-dark);
        display: block;
        font-weight: normal;
        margin: 1em 0;
        outline: none;
        padding: 0;
        text-align: left;
        text-decoration: underline;
      }

      &.edit-address {
        margin-top: 1em;
      }
    }
  }

  .va-introtext {
    @include schemaform-padding;
  }

  .progress-bar-segmented {
    @include schemaform-padding;
    padding-right: 1.25rem;
  }

  .letters-address {
    text-transform: capitalize;
  }

  .accordion-header > button {
    min-height: 3.75rem;
    padding-bottom: 0.9375rem;
    padding-top: 0.9375rem;
  }

  .download-button {
    margin: 1.5em 0 1em;

    > button {
      &:disabled {
        background-color: var(--vads-color-base-lighter);
        color: var(--vads-color-black);
      }
    }
  }

  .service-info {
    text-transform: capitalize;
  }

  table > tbody > tr {
    vertical-align: middle;

    th {
      input,
      label {
        cursor: pointer;
      }

      label {
        // The USWDS label controlling the checkbox enforces an 8px margin-bottom
        // We are adding an equivalent top margin so that vertical-align works
        // correctly without using !important to over-ride margin-bottom
        margin-top: 8px;
        text-align: center;
      }
    }

    td > label {
      cursor: pointer;
      margin: 0;
    }
  }

  th {
    [scope="row"] {
      padding-bottom: 0;
      padding-top: 0;
    }
  }

  .form-expanding-group {
    margin-left: initial;
    margin-top: 1.5em;
  }

  .form-expanding-group-open {
    border-left: 0;
    padding-left: initial;
  }
}

#records-not-found {
  h2 {
    margin-top: 2em;
  }

  hr {
    border-color: var(--vads-color-primary);
    margin-bottom: 0;
    margin-top: 0;
  }

  .letters-phone-nowrap {
    white-space: nowrap;
  }
}

// --- Copied from _m-schemaform.css --- //

// This probably belongs somewhere else

.usa-alert, .usa-input-error, .nav-header > h4, .nav-header {
  &:focus {
    outline: none;
  }
}

label + div {
  select, input:not([type="radio"]) {
    margin-top: 0.5em;
  }
}

// Copied from .schemaform-chapter-progress
.section-content {
  padding-left: 1.25rem;
  padding-right: 1.25rem;
  margin-bottom: 1.5em;
  @media (max-width: 40.063em) {
    padding-left: 1.25rem - 0.5859375rem;
    padding-right: 1.25rem - 0.5859375rem;
  }
  > h4 {
    padding-bottom: 0 !important;
  }
}

// --- End copy from _m-schemaform.css --- //

.va-profile-wrapper .va-modal-inner {
  max-height: 100%;
  overflow-y: auto;
}