Merge pull request #1457 from mempool/nymkappa/feature/address-list-collapse
Pool addresses collapse - Cleanup mobile layout
This commit is contained in:
		
						commit
						0965140bd5
					
				| @ -9,44 +9,104 @@ | |||||||
| 
 | 
 | ||||||
|     <div class="box"> |     <div class="box"> | ||||||
|       <div class="row"> |       <div class="row"> | ||||||
|  | 
 | ||||||
|         <div class="col-lg-9"> |         <div class="col-lg-9"> | ||||||
|           <table class="table table-borderless table-striped" style="table-layout: fixed;"> |           <table class="table table-borderless table-striped" style="table-layout: fixed;"> | ||||||
|             <tbody> |             <tbody> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Tags</td> |               <!-- Regexes desktop --> | ||||||
|                 <td class="text-truncate" *ngIf="poolStats.pool.regexes.length else nodata"> |               <tr *ngIf="!isMobile()"> | ||||||
|                   <div class="scrollable"> |                 <td class="label" i18n="mining.tags">Tags</td> | ||||||
|  |                 <td *ngIf="poolStats.pool.regexes.length else nodata"> | ||||||
|  |                   {{ poolStats.pool.regexes }} | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|  |               <!-- Regexes mobile --> | ||||||
|  |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan=2> | ||||||
|  |                   <span i18n="mining.tags" class="label">Tags</span> | ||||||
|  |                   <div *ngIf="poolStats.pool.regexes.length else nodata" class="overflow-auto"> | ||||||
|                     {{ poolStats.pool.regexes }} |                     {{ poolStats.pool.regexes }} | ||||||
|                   </div> |                   </div> | ||||||
|                 </td> |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Addresses</td> |               <!-- Addresses desktop --> | ||||||
|                 <td class="text-truncate" *ngIf="poolStats.pool.addresses.length else nodata"> |               <tr *ngIf="!isMobile()"> | ||||||
|                   <div class="scrollable"> |                 <td class="label" i18n="mining.addresses">Addresses</td> | ||||||
|                     <a *ngFor="let address of poolStats.pool.addresses" |                 <td *ngIf="poolStats.pool.addresses.length else nodata" style="padding-bottom: 0;"> | ||||||
|  |                   <a [routerLink]="['/address' | relativeUrl, poolStats.pool.addresses[0]]" class="first-address"> | ||||||
|  |                     {{ poolStats.pool.addresses[0] }} | ||||||
|  |                   </a> | ||||||
|  |                   <button *ngIf="poolStats.pool.addresses.length >= 2" style="transform: translateY(-3px);" | ||||||
|  |                     type="button" class="btn btn-outline-info btn-sm float-right" (click)="collapse.toggle()" | ||||||
|  |                     [attr.aria-expanded]="!gfg" aria-controls="collapseExample"> | ||||||
|  |                     <span i18n="show-all">Show all</span> ({{ poolStats.pool.addresses.length }}) | ||||||
|  |                   </button> | ||||||
|  |                   <div #collapse="ngbCollapse" [(ngbCollapse)]="gfg"> | ||||||
|  |                     <a *ngFor="let address of poolStats.pool.addresses | slice: 1" | ||||||
|                       [routerLink]="['/address' | relativeUrl, address]">{{ |                       [routerLink]="['/address' | relativeUrl, address]">{{ | ||||||
|                       address }}<br></a> |                       address }}<br></a> | ||||||
|                   </div> |                   </div> | ||||||
|                 </td> |                 </td> | ||||||
|                 <ng-template #nodata> |               </tr> | ||||||
|                   <td class="right-mobile">~</td> | 
 | ||||||
|                 </ng-template> |               <!-- Addresses mobile --> | ||||||
|  |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan=2> | ||||||
|  |                   <span class="label" i18n="mining.addresses">Addresses</span> | ||||||
|  |                   <div *ngIf="poolStats.pool.addresses.length else nodatamobile"> | ||||||
|  |                     <button *ngIf="poolStats.pool.addresses.length >= 2" type="button" | ||||||
|  |                       class="btn btn-outline-info btn-sm float-right small-button" (click)="collapse.toggle()" | ||||||
|  |                       [attr.aria-expanded]="!gfg" aria-controls="collapseExample"> | ||||||
|  |                       <span i18n="show-all">Show all</span> ({{ poolStats.pool.addresses.length }}) | ||||||
|  |                     </button> | ||||||
|  |                     <a [routerLink]="['/address' | relativeUrl, poolStats.pool.addresses[0]]"> | ||||||
|  |                       {{ poolStats.pool.addresses[0] | shortenString: 40 }} | ||||||
|  |                     </a> | ||||||
|  |                     <div #collapse="ngbCollapse" [(ngbCollapse)]="gfg" style="width: 100%"> | ||||||
|  |                       <a *ngFor="let address of poolStats.pool.addresses | slice: 1" | ||||||
|  |                         [routerLink]="['/address' | relativeUrl, address]">{{ | ||||||
|  |                         address | shortenString: 40 }}<br></a> | ||||||
|  |                     </div> | ||||||
|  |                   </div> | ||||||
|  |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
|             </tbody> |             </tbody> | ||||||
|           </table> |           </table> | ||||||
|         </div> |         </div> | ||||||
|  | 
 | ||||||
|         <div class="col-lg-3"> |         <div class="col-lg-3"> | ||||||
|           <table class="table table-borderless table-striped"> |           <table class="table table-borderless table-striped"> | ||||||
|             <tbody> |             <tbody> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Mined Blocks</td> |               <!-- Mined blocks desktop --> | ||||||
|  |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.mined-blocks">Mined Blocks</td> | ||||||
|                 <td class="data">{{ formatNumber(poolStats.blockCount, this.locale, '1.0-0') }}</td> |                 <td class="data">{{ formatNumber(poolStats.blockCount, this.locale, '1.0-0') }}</td> | ||||||
|               </tr> |               </tr> | ||||||
|               <tr> |               <!-- Mined blocks desktop --> | ||||||
|                 <td class="label">Empty Blocks</td> |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan=2> | ||||||
|  |                   <span class="label" i18n="mining.mined-blocks">Mined Blocks</span> | ||||||
|  |                   <div>{{ formatNumber(poolStats.blockCount, this.locale, '1.0-0') }}</div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|  |               <!-- Empty blocks desktop --> | ||||||
|  |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.empty-blocks">Empty Blocks</td> | ||||||
|                 <td class="data">{{ formatNumber(poolStats.emptyBlocks, this.locale, '1.0-0') }}</td> |                 <td class="data">{{ formatNumber(poolStats.emptyBlocks, this.locale, '1.0-0') }}</td> | ||||||
|               </tr> |               </tr> | ||||||
|  |               <!-- Empty blocks mobile --> | ||||||
|  |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan="2"> | ||||||
|  |                   <span class="label" i18n="mining.empty-blocks">Blocks</span> | ||||||
|  |                   <div>{{ formatNumber(poolStats.emptyBlocks, this.locale, '1.0-0') }}</div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|             </tbody> |             </tbody> | ||||||
|           </table> |           </table> | ||||||
|         </div> |         </div> | ||||||
| @ -54,14 +114,20 @@ | |||||||
|     </div> |     </div> | ||||||
|   </div> |   </div> | ||||||
| 
 | 
 | ||||||
|  |   <ng-template #nodata> | ||||||
|  |     <td>~</td> | ||||||
|  |   </ng-template> | ||||||
|  |   <ng-template #nodatamobile> | ||||||
|  |     <div>~</div> | ||||||
|  |   </ng-template> | ||||||
|  | 
 | ||||||
|   <div class="chart" echarts [initOpts]="chartInitOptions" [options]="chartOptions"></div> |   <div class="chart" echarts [initOpts]="chartInitOptions" [options]="chartOptions"></div> | ||||||
|   <div class="text-center loadingGraphs" *ngIf="isLoading"> |   <div class="text-center loadingGraphs" *ngIf="isLoading"> | ||||||
|     <div class="spinner-border text-light"></div> |     <div class="spinner-border text-light"></div> | ||||||
|   </div> |   </div> | ||||||
| 
 | 
 | ||||||
|   <table class="table table-borderless" [alwaysCallback]="true" infiniteScroll |   <table class="table table-borderless" [alwaysCallback]="true" infiniteScroll [infiniteScrollDistance]="1.5" | ||||||
|     [infiniteScrollDistance]="1.5" [infiniteScrollUpDistance]="1.5" [infiniteScrollThrottle]="50" |     [infiniteScrollUpDistance]="1.5" [infiniteScrollThrottle]="50" (scrolled)="loadMore()"> | ||||||
|     (scrolled)="loadMore()"> |  | ||||||
|     <thead> |     <thead> | ||||||
|       <th class="height" i18n="latest-blocks.height">Height</th> |       <th class="height" i18n="latest-blocks.height">Height</th> | ||||||
|       <th class="timestamp" i18n="latest-blocks.timestamp">Timestamp</th> |       <th class="timestamp" i18n="latest-blocks.timestamp">Timestamp</th> | ||||||
| @ -147,7 +213,9 @@ | |||||||
|   <div> |   <div> | ||||||
|     <div class="mb-3" style="display:flex; position: relative"> |     <div class="mb-3" style="display:flex; position: relative"> | ||||||
|       <div class="skeleton-loader mr-3" style="width: 50px; height: 50px"></div> |       <div class="skeleton-loader mr-3" style="width: 50px; height: 50px"></div> | ||||||
|       <h1 class="m-0 pt-1 pt-md-0"><div class="skeleton-loader" style="position: absolute; top: 32%; width: 150px; height: 20px"></div></h1> |       <h1 class="m-0 pt-1 pt-md-0"> | ||||||
|  |         <div class="skeleton-loader" style="position: absolute; top: 32%; width: 150px; height: 20px"></div> | ||||||
|  |       </h1> | ||||||
|     </div> |     </div> | ||||||
| 
 | 
 | ||||||
|     <div class="box"> |     <div class="box"> | ||||||
| @ -155,41 +223,88 @@ | |||||||
|         <div class="col-lg-9"> |         <div class="col-lg-9"> | ||||||
|           <table class="table table-borderless table-striped"> |           <table class="table table-borderless table-striped"> | ||||||
|             <tbody> |             <tbody> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Tags</td> |               <!-- Regexes desktop --> | ||||||
|                 <td class="text-truncate"> |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.tags">Tags</td> | ||||||
|  |                 <td> | ||||||
|                   <div class="skeleton-loader"></div> |                   <div class="skeleton-loader"></div> | ||||||
|                 </td> |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Addresses</td> |               <!-- Regexes mobile --> | ||||||
|                 <td class="text-truncate"> |               <tr *ngIf="isMobile()"> | ||||||
|                   <div class="scrollable"> |                 <td colspan=2> | ||||||
|  |                   <span class="label" i18n="mining.tags">Tags</span> | ||||||
|  |                   <div class="overflow-auto"> | ||||||
|                     <div class="skeleton-loader"></div> |                     <div class="skeleton-loader"></div> | ||||||
|                   </div> |                   </div> | ||||||
|                 </td> |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|  |               <!-- Addresses desktop --> | ||||||
|  |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.addresses">Addresses</td> | ||||||
|  |                 <td> | ||||||
|  |                   <div class="skeleton-loader"></div> | ||||||
|  |                 </td> | ||||||
|                 <ng-template #nodata> |                 <ng-template #nodata> | ||||||
|                   <td>~</td> |                   <td>~</td> | ||||||
|                 </ng-template> |                 </ng-template> | ||||||
|               </tr> |               </tr> | ||||||
|  | 
 | ||||||
|  |               <!-- Addresses mobile --> | ||||||
|  |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan=2> | ||||||
|  |                   <span class="label" i18n="mining.addresses">Addresses</span> | ||||||
|  |                   <div> | ||||||
|  |                     <div class="skeleton-loader"></div> | ||||||
|  |                   </div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|             </tbody> |             </tbody> | ||||||
|           </table> |           </table> | ||||||
|         </div> |         </div> | ||||||
|  | 
 | ||||||
|         <div class="col-lg-3"> |         <div class="col-lg-3"> | ||||||
|           <table class="table table-borderless table-striped" > |           <table class="table table-borderless table-striped"> | ||||||
|             <tbody> |             <tbody> | ||||||
|               <tr> | 
 | ||||||
|                 <td class="label">Mined Blocks</td> |               <!-- Mined blocks desktop --> | ||||||
|                 <td class="text-truncate"> |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.mined-blocks">Mined Blocks</td> | ||||||
|  |                 <td class="data"> | ||||||
|                   <div class="skeleton-loader"></div> |                   <div class="skeleton-loader"></div> | ||||||
|                 </td> |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
|               <tr> |               <!-- Mined blocks desktop --> | ||||||
|                 <td class="label">Empty Blocks</td> |               <tr *ngIf="isMobile()"> | ||||||
|                 <td class="text-truncate"> |                 <td colspan=2> | ||||||
|  |                   <span class="label" i18n="mining.mined-blocks">Mined Blocks</span> | ||||||
|  |                   <div> | ||||||
|  |                     <div class="skeleton-loader"></div> | ||||||
|  |                   </div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|  |               <!-- Empty blocks desktop --> | ||||||
|  |               <tr *ngIf="!isMobile()"> | ||||||
|  |                 <td class="label" i18n="mining.empty-blocks">Empty Blocks</td> | ||||||
|  |                 <td class="data"> | ||||||
|                   <div class="skeleton-loader"></div> |                   <div class="skeleton-loader"></div> | ||||||
|                 </td> |                 </td> | ||||||
|               </tr> |               </tr> | ||||||
|  |               <!-- Empty blocks mobile --> | ||||||
|  |               <tr *ngIf="isMobile()"> | ||||||
|  |                 <td colspan="2"> | ||||||
|  |                   <span class="label" i18n="mining.empty-blocks">Blocks</span> | ||||||
|  |                   <div> | ||||||
|  |                     <div class="skeleton-loader"></div> | ||||||
|  |                   </div> | ||||||
|  |                 </td> | ||||||
|  |               </tr> | ||||||
|  | 
 | ||||||
|             </tbody> |             </tbody> | ||||||
|           </table> |           </table> | ||||||
|         </div> |         </div> | ||||||
|  | |||||||
| @ -45,13 +45,17 @@ div.scrollable { | |||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .label { | .label { | ||||||
|   width: 35%; |   width: 30%; | ||||||
|  |   @media (max-width: 767.98px) { | ||||||
|  |     font-weight: bold; | ||||||
|  |   } | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .data { | .data { | ||||||
|   text-align: left; |   text-align: right; | ||||||
|   padding-left: 25%; |   padding-left: 25%; | ||||||
|   @media (max-width: 991px) { |   @media (max-width: 992px) { | ||||||
|  |     text-align: left; | ||||||
|     padding-left: 12px; |     padding-left: 12px; | ||||||
|   } |   } | ||||||
|   @media (max-width: 450px) { |   @media (max-width: 450px) { | ||||||
| @ -132,12 +136,6 @@ div.scrollable { | |||||||
|   text-align: left; |   text-align: left; | ||||||
| } | } | ||||||
| 
 | 
 | ||||||
| .right-mobile { |  | ||||||
|   @media (max-width: 450px) { |  | ||||||
|     text-align: right; |  | ||||||
|   } |  | ||||||
| } |  | ||||||
| 
 |  | ||||||
| .skeleton-loader { | .skeleton-loader { | ||||||
|   max-width: 200px; |   max-width: 200px; | ||||||
| } | } | ||||||
| @ -151,3 +149,11 @@ div.scrollable { | |||||||
|     top: 600px; |     top: 600px; | ||||||
|   } |   } | ||||||
| } | } | ||||||
|  | 
 | ||||||
|  | .small-button { | ||||||
|  |   height: 20px; | ||||||
|  |   transform: translateY(-20px); | ||||||
|  |   font-size: 10px; | ||||||
|  |   padding-top: 0; | ||||||
|  |   padding-bottom: 0; | ||||||
|  | } | ||||||
| @ -19,6 +19,8 @@ export class PoolComponent implements OnInit { | |||||||
|   @Input() right: number | string = 45; |   @Input() right: number | string = 45; | ||||||
|   @Input() left: number | string = 75; |   @Input() left: number | string = 75; | ||||||
| 
 | 
 | ||||||
|  |   gfg = true; | ||||||
|  |    | ||||||
|   formatNumber = formatNumber; |   formatNumber = formatNumber; | ||||||
|   poolStats$: Observable<PoolStat>; |   poolStats$: Observable<PoolStat>; | ||||||
|   blocks$: Observable<BlockExtended[]>; |   blocks$: Observable<BlockExtended[]>; | ||||||
|  | |||||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user