presidential-innovation-fellows/code-gov-web

View on GitHub
src/app/components/repo-list/repo-list.template.html

Summary

Maintainability
Test Coverage
<div class="loading-dialog" *ngIf="results === null">
  <p>Loading Results...</p>
  <img alt="United States of America Flag" width="44" height="30" src=""
  />
</div>

<div *ngIf="results !== null" class="repo-list">
  <div *ngIf="hasRepos()" class="repos-container">
    <ul class="repos-list repos-list--infinite-scrolled"
        infinite-scroll
        [infiniteScrollDistance]="500"
        [infiniteScrollThrottle]="500"
        (scrolled)="onScroll()">
      <li *ngFor="let result of loadedResults" class="repo">
        <div *ngIf="result.agency;then repoListItem else agencyListItem"></div>
        <ng-template #repoListItem>
          <repo-list-item [repo]="result"></repo-list-item>
        </ng-template>
        <ng-template #agencyListItem>
          <agency-list-item [agency]="result"></agency-list-item>
        </ng-template>
      </li>
    </ul>
    <ul class="repos-list repos-list--paged">
      <li *ngFor="let result of results | paginate: { itemsPerPage: pageSize, currentPage: currentPage }" class="repo">
        <div *ngIf="result.agency;then repoListItem else agencyListItem"></div>
        <ng-template #repoListItem>
          <repo-list-item [repo]="result"></repo-list-item>
        </ng-template>
        <ng-template #agencyListItem>
          <agency-list-item [agency]="result"></agency-list-item>
        </ng-template>
      </li>
    </ul>
    <pagination-template #p="paginationApi" (pageChange)="onPageChange($event)">
        <nav role="navigation" aria-label="Pagination Navigation" tabindex="0">
          <ul class="ngx-pagination">
              <div class="repo-list-summary-wrapper" tabindex="0">
                  <p *ngIf="results.length === 0" class="repo-list-summary">No results found.</p>
                  <p *ngIf="results.length > 0" class="repo-list-summary">Results <strong>{{ getMinPageIndex() }}-{{ getMaxPageIndex() }}</strong> of <strong>{{ results.length }}</strong></p>
              </div>
              <li class="pagination-previous" [class.disabled]="p.isFirstPage()" tabindex="0">
              <span *ngIf="p.isFirstPage()" aria-label="Previous"><i class="icon icon-angle-circled-left"></i> Prev</span>
              <a *ngIf="!p.isFirstPage()" (click)="p.previous()"><i class="icon icon-angle-circled-up"></i> Prev</a>
              </li>

              <li *ngFor="let page of p.pages; let isFirst = first" class="page" [class.current]="p.getCurrent() === page.value" [class.first]="isFirst" tabindex="0">
              <a (click)="p.setCurrent(page.value)" *ngIf="p.getCurrent() !== page.value" attr.aria-label="Go to page {{ page.label }}">
                  {{ page.label }}
              </a>
              <span *ngIf="p.getCurrent() === page.value" attr.aria-label="Current Page {{ page.label }}" aria-current="true">
                  {{ page.label }}
              </span>
              </li>

              <li class="pagination-next" [class.disabled]="p.isLastPage()" tabindex="0">
              <span *ngIf="p.isLastPage()">Next <i class="icon icon-angle-circled-right"></i></span>
              <a *ngIf="!p.isLastPage()" (click)="p.next()">Next <i class="icon icon-angle-circled-right"></i></a>
              </li>
         </ul>
        </nav>
      </pagination-template>
  </div>

  <div *ngIf="!hasRepos()" class="no-repos">
    <h4>
      No repositories found.
    </h4>
  </div>
</div>