src/app/components/repo-list/repo-list.template.html
<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>