Merge branch 'master' into update_node_matrix
This commit is contained in:
		
						commit
						50a96ce340
					
				| @ -504,9 +504,17 @@ describe('Mainnet', () => { | ||||
| 
 | ||||
|     describe('RBF transactions', () => { | ||||
|       it('shows RBF transactions properly (mobile)', () => { | ||||
|         cy.intercept('/api/v1/tx/21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f/cached', { | ||||
|           fixture: 'mainnet_tx_cached.json' | ||||
|         }).as('cached_tx'); | ||||
| 
 | ||||
|         cy.intercept('/api/v1/tx/f81a08699b62b2070ad8fe0f2a076f8bea0386a2fdcd8124caee42cbc564a0d5/rbf', { | ||||
|           fixture: 'mainnet_rbf_new.json' | ||||
|         }).as('rbf'); | ||||
| 
 | ||||
|         cy.viewport('iphone-xr'); | ||||
|         cy.mockMempoolSocket(); | ||||
|         cy.visit('/tx/f81a08699b62b2070ad8fe0f2a076f8bea0386a2fdcd8124caee42cbc564a0d5'); | ||||
|         cy.visit('/tx/21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f'); | ||||
| 
 | ||||
|         cy.waitForSkeletonGone(); | ||||
| 
 | ||||
| @ -524,22 +532,30 @@ describe('Mainnet', () => { | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         cy.get('.alert-mempool').should('be.visible'); | ||||
|         cy.get('.alert-mempool').invoke('css', 'width').then((alertWidth) => { | ||||
|         cy.get('.alert').should('be.visible'); | ||||
|         cy.get('.alert').invoke('css', 'width').then((alertWidth) => { | ||||
|           cy.get('.container-xl > :nth-child(3)').invoke('css', 'width').should('equal', alertWidth); | ||||
|         }); | ||||
| 
 | ||||
|         cy.get('.btn-success').then(getRectangle).then((rectA) => { | ||||
|           cy.get('.alert-mempool').then(getRectangle).then((rectB) => { | ||||
|         cy.get('.btn-danger').then(getRectangle).then((rectA) => { | ||||
|           cy.get('.alert').then(getRectangle).then((rectB) => { | ||||
|             expect(areOverlapping(rectA, rectB), 'Confirmations box and RBF alert are overlapping').to.be.false; | ||||
|           }); | ||||
|         }); | ||||
|       }); | ||||
| 
 | ||||
|       it('shows RBF transactions properly (desktop)', () => { | ||||
|         cy.intercept('/api/v1/tx/21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f/cached', { | ||||
|           fixture: 'mainnet_tx_cached.json' | ||||
|         }).as('cached_tx'); | ||||
| 
 | ||||
|         cy.intercept('/api/v1/tx/f81a08699b62b2070ad8fe0f2a076f8bea0386a2fdcd8124caee42cbc564a0d5/rbf', { | ||||
|           fixture: 'mainnet_rbf_new.json' | ||||
|         }).as('rbf'); | ||||
| 
 | ||||
|         cy.viewport('macbook-16'); | ||||
|         cy.mockMempoolSocket(); | ||||
|         cy.visit('/tx/f81a08699b62b2070ad8fe0f2a076f8bea0386a2fdcd8124caee42cbc564a0d5'); | ||||
|         cy.visit('/tx/21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f'); | ||||
| 
 | ||||
|         cy.waitForSkeletonGone(); | ||||
| 
 | ||||
| @ -557,17 +573,17 @@ describe('Mainnet', () => { | ||||
|           } | ||||
|         }); | ||||
| 
 | ||||
|         cy.get('.alert-mempool').should('be.visible'); | ||||
|         cy.get('.alert').should('be.visible'); | ||||
| 
 | ||||
|         const alertLocator = '.alert-mempool'; | ||||
|         const alertLocator = '.alert'; | ||||
|         const tableLocator = '.container-xl > :nth-child(3)'; | ||||
| 
 | ||||
|         cy.get(tableLocator).invoke('css', 'width').then((firstWidth) => { | ||||
|           cy.get(alertLocator).invoke('css', 'width').should('equal', firstWidth); | ||||
|         }); | ||||
| 
 | ||||
|         cy.get('.btn-success').then(getRectangle).then((rectA) => { | ||||
|           cy.get('.alert-mempool').then(getRectangle).then((rectB) => { | ||||
|         cy.get('.btn-danger').then(getRectangle).then((rectA) => { | ||||
|           cy.get('.alert').then(getRectangle).then((rectB) => { | ||||
|             expect(areOverlapping(rectA, rectB), 'Confirmations box and RBF alert are overlapping').to.be.false; | ||||
|           }); | ||||
|         }); | ||||
|  | ||||
| @ -1,52 +1,4 @@ | ||||
| { | ||||
|   "rbfTransaction": { | ||||
|     "txid": "8913ec7ba0ede285dbd120e46f6d61a28f2903c10814a6f6c4f97d0edf3e1f46", | ||||
|     "version": 2, | ||||
|     "locktime": 632699, | ||||
|     "vin": [ | ||||
|       { | ||||
|         "txid": "02238126a63ea2669c5f378012180ef8b54402a949316f9b2f1352c51730a086", | ||||
|         "vout": 0, | ||||
|         "prevout": { | ||||
|           "scriptpubkey": "a914f8e495456956c833e5e8c69b9a9dc041aa14c72f87", | ||||
|           "scriptpubkey_asm": "OP_HASH160 OP_PUSHBYTES_20 f8e495456956c833e5e8c69b9a9dc041aa14c72f OP_EQUAL", | ||||
|           "scriptpubkey_type": "p2sh", | ||||
|           "scriptpubkey_address": "3QP3LMD8veT5GtWV83Nosif2Bhr73857VB", | ||||
|           "value": 25000000 | ||||
|         }, | ||||
|         "scriptsig": "22002043288fbbc0fc5efa86c229dbb7d88ab78d57957c65b5d5ceaece70838976ad1b", | ||||
|         "scriptsig_asm": "OP_PUSHBYTES_34 002043288fbbc0fc5efa86c229dbb7d88ab78d57957c65b5d5ceaece70838976ad1b", | ||||
|         "witness": [ | ||||
|           "", | ||||
|           "3044022009e2d3a8e645f65bc89c8492cd9c08e6fb02609fd402214884a754a1970145340220575bb325429def59f3a3f1e22d9740a3feecbe97438ff3bb5796b2c46b3c477f01", | ||||
|           "3044022039c34372882da8fc1c1243bd72b5e7e5e6870301ef56bdebb87bc647fb50f9b5022071a704ee77d742f78b10e45be675d4c45a5f31e884139e75c975144fde70e41701", | ||||
|           "522102346eb7133f11e0dc279bc592d5ac948a91676372a6144c9ae2085625d7fbf70421021b9508a458f9d59be4eb8cc87ad582c3b494106fb1d4ec22801569be0700eb7b52ae" | ||||
|         ], | ||||
|         "is_coinbase": false, | ||||
|         "sequence": 4294967293, | ||||
|         "inner_redeemscript_asm": "OP_0 OP_PUSHBYTES_32 43288fbbc0fc5efa86c229dbb7d88ab78d57957c65b5d5ceaece70838976ad1b", | ||||
|         "inner_witnessscript_asm": "OP_PUSHNUM_2 OP_PUSHBYTES_33 02346eb7133f11e0dc279bc592d5ac948a91676372a6144c9ae2085625d7fbf704 OP_PUSHBYTES_33 021b9508a458f9d59be4eb8cc87ad582c3b494106fb1d4ec22801569be0700eb7b OP_PUSHNUM_2 OP_CHECKMULTISIG" | ||||
|       } | ||||
|     ], | ||||
|     "vout": [ | ||||
|       { | ||||
|         "scriptpubkey": "a914fd4e5e59dd5cf2dc48eaedf1a2a1650ca1ce9d7f87", | ||||
|         "scriptpubkey_asm": "OP_HASH160 OP_PUSHBYTES_20 fd4e5e59dd5cf2dc48eaedf1a2a1650ca1ce9d7f OP_EQUAL", | ||||
|         "scriptpubkey_type": "p2sh", | ||||
|         "scriptpubkey_address": "3QnNmDhZS7toHA7bhhbTPBdtpLJoeecq5c", | ||||
|         "value": 13986350 | ||||
|       }, | ||||
|       { | ||||
|         "scriptpubkey": "76a914edc93d0446deec1c2d514f3a490f050096e74e0e88ac", | ||||
|         "scriptpubkey_asm": "OP_DUP OP_HASH160 OP_PUSHBYTES_20 edc93d0446deec1c2d514f3a490f050096e74e0e OP_EQUALVERIFY OP_CHECKSIG", | ||||
|         "scriptpubkey_type": "p2pkh", | ||||
|         "scriptpubkey_address": "1NgJDkTUqJxxCAAZrrsC87kWag5kphrRtM", | ||||
|         "value": 11000000 | ||||
|       } | ||||
|     ], | ||||
|     "size": 372, | ||||
|     "weight": 828, | ||||
|     "fee": 1.5, | ||||
|     "status": { "confirmed": false } | ||||
|   } | ||||
| } | ||||
| "txReplaced": { | ||||
|   "txid": "8913ec7ba0ede285dbd120e46f6d61a28f2903c10814a6f6c4f97d0edf3e1f46" | ||||
| }} | ||||
							
								
								
									
										31
									
								
								frontend/cypress/fixtures/mainnet_rbf_new.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										31
									
								
								frontend/cypress/fixtures/mainnet_rbf_new.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,31 @@ | ||||
| { | ||||
|   "replacements": { | ||||
|     "tx": { | ||||
|       "txid": "f22735aaa8eb84bcae3e7705f78609c6f5f0cd7dfc34ae03094e61f2dab0cc64", | ||||
|       "fee": 13843, | ||||
|       "vsize": 109.25, | ||||
|       "value": 253003805, | ||||
|       "rate": 36.04666732302845, | ||||
|       "rbf": true | ||||
|     }, | ||||
|     "time": 1683865345, | ||||
|     "fullRbf": false, | ||||
|     "replaces": [ | ||||
|       { | ||||
|         "tx": { | ||||
|           "txid": "21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f", | ||||
|           "fee": 8794, | ||||
|           "vsize": 109.25, | ||||
|           "value": 253008854, | ||||
|           "rate": 35.05247612484001, | ||||
|           "rbf": true | ||||
|         }, | ||||
|         "time": 1683864993, | ||||
|         "interval": 352, | ||||
|         "fullRbf": false, | ||||
|         "replaces": [] | ||||
|       } | ||||
|     ] | ||||
|   }, | ||||
|   "replaces": null | ||||
| } | ||||
							
								
								
									
										60
									
								
								frontend/cypress/fixtures/mainnet_tx_cached.json
									
									
									
									
									
										Normal file
									
								
							
							
						
						
									
										60
									
								
								frontend/cypress/fixtures/mainnet_tx_cached.json
									
									
									
									
									
										Normal file
									
								
							| @ -0,0 +1,60 @@ | ||||
| { | ||||
|   "vsize": 109, | ||||
|   "feePerVsize": 80.49427917620137, | ||||
|   "effectiveFeePerVsize": 35.05247612484001, | ||||
|   "txid": "21518a98d1aa9df524865d2f88c578499f524eb1d0c4d3e70312ab863508692f", | ||||
|   "version": 2, | ||||
|   "locktime": 0, | ||||
|   "vin": [ | ||||
|     { | ||||
|       "txid": "1e3bd5c634781a6ba8bb3d3385b14739bf38cad5332d5fbc5c0ab775e54b9aef", | ||||
|       "vout": 144, | ||||
|       "prevout": { | ||||
|         "scriptpubkey": "0014d98654186b90d95da7e31a30929f5b5b6a0af250", | ||||
|         "scriptpubkey_asm": "OP_0 OP_PUSHBYTES_20 d98654186b90d95da7e31a30929f5b5b6a0af250", | ||||
|         "scriptpubkey_type": "v0_p2wpkh", | ||||
|         "scriptpubkey_address": "bc1qmxr9gxrtjrv4mflrrgcf986mtd4q4ujss432tk", | ||||
|         "value": 253017648 | ||||
|       }, | ||||
|       "scriptsig": "", | ||||
|       "scriptsig_asm": "", | ||||
|       "witness": [ | ||||
|         "30440220448e8f58fcdea87c1969d58438b49da5b43712380bc4c68b02d22cf6b164907302207b2ed660f1a5b3b74f712961ffb3f3a7d1ac6e48b269ea6ff15df985042211f301", | ||||
|         "02e39a1f3583e382cec1a1fab6a3f5950b6403c953fada58d809127a497f502ebe" | ||||
|       ], | ||||
|       "is_coinbase": false, | ||||
|       "sequence": 4294967293 | ||||
|     } | ||||
|   ], | ||||
|   "vout": [ | ||||
|     { | ||||
|       "scriptpubkey": "0014edb5167da7e97c73d7931eb2130ac3e34e6845a9", | ||||
|       "scriptpubkey_asm": "OP_0 OP_PUSHBYTES_20 edb5167da7e97c73d7931eb2130ac3e34e6845a9", | ||||
|       "scriptpubkey_type": "v0_p2wpkh", | ||||
|       "scriptpubkey_address": "bc1qak63vld8a97884unr6epxzkrud8xs3dfdqswy2", | ||||
|       "value": 253008854 | ||||
|     } | ||||
|   ], | ||||
|   "size": 191, | ||||
|   "weight": 437, | ||||
|   "fee": 8794, | ||||
|   "status": { | ||||
|     "confirmed": false | ||||
|   }, | ||||
|   "firstSeen": 1683864993, | ||||
|   "uid": 298353, | ||||
|   "position": { | ||||
|     "block": 0, | ||||
|     "vsize": 886207.5 | ||||
|   }, | ||||
|   "cpfpChecked": true, | ||||
|   "ancestors": [ | ||||
|     { | ||||
|       "txid": "1e3bd5c634781a6ba8bb3d3385b14739bf38cad5332d5fbc5c0ab775e54b9aef", | ||||
|       "fee": 169220, | ||||
|       "weight": 19877 | ||||
|     } | ||||
|   ], | ||||
|   "descendants": [], | ||||
|   "bestDescendant": null | ||||
| } | ||||
| @ -1,11 +1,6 @@ | ||||
| .pagination-container { | ||||
|   float: none; | ||||
|   margin-bottom: 200px; | ||||
|   @media(min-width: 400px){ | ||||
|     float: right; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| .container-xl { | ||||
|     padding-bottom: 110px; | ||||
| } | ||||
| @ -36,7 +36,7 @@ | ||||
|           <h5 class="card-title">US Dollar - BTC/USD</h5> | ||||
|           <div class="chart-container"> | ||||
|             <ng-container *ngIf="hlocData$ | async as hlocData; else loadingSpinner"> | ||||
|               <app-lightweight-charts [height]="300" [data]="hlocData.hloc" [volumeData]="hlocData.volume" [precision]="2"></app-lightweight-charts>       | ||||
|               <app-lightweight-charts [height]="300" [data]="hlocData.hloc" [volumeData]="hlocData.volume" [precision]="2"></app-lightweight-charts> | ||||
|             </ng-container> | ||||
|           </div> | ||||
|         </div> | ||||
| @ -84,7 +84,7 @@ | ||||
|                     </ng-template> | ||||
|                   </td> | ||||
|                   <td>{{ ticker.volume?.num_trades ? ticker.volume?.num_trades : 0 }}</td> | ||||
|                 </tr>  | ||||
|                 </tr> | ||||
|               </tbody> | ||||
|             </table> | ||||
|           </div> | ||||
| @ -105,9 +105,6 @@ | ||||
|   </ng-container> | ||||
|   </div> | ||||
| 
 | ||||
|   <app-language-selector></app-language-selector> | ||||
| 
 | ||||
|   <app-global-footer></app-global-footer> | ||||
| </div> | ||||
| 
 | ||||
| <ng-template #loadingTmpl> | ||||
| @ -124,4 +121,4 @@ | ||||
| 
 | ||||
| <ng-template #loading> | ||||
|   <div class="skeleton-loader shorter"></div> | ||||
| </ng-template> | ||||
| </ng-template> | ||||
|  | ||||
| @ -393,27 +393,6 @@ | ||||
| 
 | ||||
|   <div class="footer-links"> | ||||
|     <a href="/3rdpartylicenses.txt">Third-party Licenses</a> | ||||
|     <div class="social-icons"> | ||||
|       <a target="_blank" href="https://github.com/mempool/mempool"> | ||||
|         <svg aria-hidden="true" focusable="false" data-prefix="fab" data-icon="github" class="svg-inline--fa fa-github fa-w-16 fa-2x" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 496 512"><path fill="currentColor" d="M165.9 397.4c0 2-2.3 3.6-5.2 3.6-3.3.3-5.6-1.3-5.6-3.6 0-2 2.3-3.6 5.2-3.6 3-.3 5.6 1.3 5.6 3.6zm-31.1-4.5c-.7 2 1.3 4.3 4.3 4.9 2.6 1 5.6 0 6.2-2s-1.3-4.3-4.3-5.2c-2.6-.7-5.5.3-6.2 2.3zm44.2-1.7c-2.9.7-4.9 2.6-4.6 4.9.3 2 2.9 3.3 5.9 2.6 2.9-.7 4.9-2.6 4.6-4.6-.3-1.9-3-3.2-5.9-2.9zM244.8 8C106.1 8 0 113.3 0 252c0 110.9 69.8 205.8 169.5 239.2 12.8 2.3 17.3-5.6 17.3-12.1 0-6.2-.3-40.4-.3-61.4 0 0-70 15-84.7-29.8 0 0-11.4-29.1-27.8-36.6 0 0-22.9-15.7 1.6-15.4 0 0 24.9 2 38.6 25.8 21.9 38.6 58.6 27.5 72.9 20.9 2.3-16 8.8-27.1 16-33.7-55.9-6.2-112.3-14.3-112.3-110.5 0-27.5 7.6-41.3 23.6-58.9-2.6-6.5-11.1-33.3 2.6-67.9 20.9-6.5 69 27 69 27 20-5.6 41.5-8.5 62.8-8.5s42.8 2.9 62.8 8.5c0 0 48.1-33.6 69-27 13.7 34.7 5.2 61.4 2.6 67.9 16 17.7 25.8 31.5 25.8 58.9 0 96.5-58.9 104.2-114.8 110.5 9.2 7.9 17 22.9 17 46.4 0 33.7-.3 75.4-.3 83.6 0 6.5 4.6 14.4 17.3 12.1C428.2 457.8 496 362.9 496 252 496 113.3 383.5 8 244.8 8zM97.2 352.9c-1.3 1-1 3.3.7 5.2 1.6 1.6 3.9 2.3 5.2 1 1.3-1 1-3.3-.7-5.2-1.6-1.6-3.9-2.3-5.2-1zm-10.8-8.1c-.7 1.3.3 2.9 2.3 3.9 1.6 1 3.6.7 4.3-.7.7-1.3-.3-2.9-2.3-3.9-2-.6-3.6-.3-4.3.7zm32.4 35.6c-1.6 1.3-1 4.3 1.3 6.2 2.3 2.3 5.2 2.6 6.5 1 1.3-1.3.7-4.3-1.3-6.2-2.2-2.3-5.2-2.6-6.5-1zm-11.4-14.7c-1.6 1-1.6 3.6 0 5.9 1.6 2.3 4.3 3.3 5.6 2.3 1.6-1.3 1.6-3.9 0-6.2-1.4-2.3-4-3.3-5.6-2z"></path></svg> | ||||
|       </a> | ||||
|       <a target="_blank" href="https://twitter.com/mempool"> | ||||
|         <svg aria-hidden="true" focusable="false" data-prefix="fab" data-icon="twitter" class="svg-inline--fa fa-twitter fa-w-16 fa-2x" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentColor" d="M459.37 151.716c.325 4.548.325 9.097.325 13.645 0 138.72-105.583 298.558-298.558 298.558-59.452 0-114.68-17.219-161.137-47.106 8.447.974 16.568 1.299 25.34 1.299 49.055 0 94.213-16.568 130.274-44.832-46.132-.975-84.792-31.188-98.112-72.772 6.498.974 12.995 1.624 19.818 1.624 9.421 0 18.843-1.3 27.614-3.573-48.081-9.747-84.143-51.98-84.143-102.985v-1.299c13.969 7.797 30.214 12.67 47.431 13.319-28.264-18.843-46.781-51.005-46.781-87.391 0-19.492 5.197-37.36 14.294-52.954 51.655 63.675 129.3 105.258 216.365 109.807-1.624-7.797-2.599-15.918-2.599-24.04 0-57.828 46.782-104.934 104.934-104.934 30.213 0 57.502 12.67 76.67 33.137 23.715-4.548 46.456-13.32 66.599-25.34-7.798 24.366-24.366 44.833-46.132 57.827 21.117-2.273 41.584-8.122 60.426-16.243-14.292 20.791-32.161 39.308-52.628 54.253z"></path></svg> | ||||
|       </a> | ||||
|       <a target="_blank" href="https://matrix.to/#/#mempool:bitcoin.kyoto"> | ||||
|         <svg aria-hidden="true" focusable="false" data-prefix="fab" data-icon="matrix" class="svg-inline--fa fa-matrix fa-w-16 fa-2x" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 1536 1792"><path fill="currentColor" d="M40.467 163.152v1465.696H145.92V1664H0V128h145.92v35.152zm450.757 464.64v74.14h2.069c19.79-28.356 43.717-50.215 71.483-65.575 27.765-15.656 59.963-23.336 96-23.336 34.56 0 66.165 6.795 94.818 20.086 28.652 13.293 50.216 37.22 65.28 70.893 16.246-23.926 38.4-45.194 66.166-63.507 27.766-18.314 60.848-27.472 98.954-27.472 28.948 0 55.828 3.545 80.64 10.635 24.812 7.088 45.785 18.314 63.508 33.968 17.722 15.656 31.31 35.742 41.354 60.85 9.747 25.107 14.768 55.236 14.768 90.683v366.573h-150.35V865.28c0-18.314-.59-35.741-2.068-51.987-1.476-16.247-5.316-30.426-11.52-42.24-6.499-12.112-15.656-21.563-28.062-28.653-12.405-7.088-29.242-10.634-50.214-10.634-21.268 0-38.4 4.135-51.397 12.112-12.997 8.27-23.336 18.608-30.72 31.901-7.386 12.997-12.407 27.765-14.77 44.602-2.363 16.542-3.84 33.379-3.84 50.216v305.133H692.971v-307.2c0-16.247-.294-32.197-1.18-48.149-.591-15.95-3.84-30.424-9.157-44.011-5.317-13.293-14.178-24.223-26.585-32.197-12.406-7.976-30.425-12.112-54.646-12.112-7.088 0-16.542 1.478-28.062 4.726-11.52 3.25-23.04 9.157-33.968 18.02-10.93 8.86-20.383 21.563-28.063 38.103-7.68 16.543-11.52 38.4-11.52 65.28v317.834H349.44V627.792zm1004.309 1001.056V163.152H1390.08V128H1536v1536h-145.92v-35.152z"/></svg> | ||||
|       </a> | ||||
|       <a target="_blank" href="https://youtube.com/@mempool"> | ||||
|         <svg aria-hidden="true" focusable="false" data-prefix="fab" data-icon="youtube" class="svg-inline--fa fa-youtube fa-w-16 fa-2x" role="img" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 512 512"><path fill="currentColor" d="M549.655 124.083c-6.281-23.65-24.787-42.276-48.284-48.597C458.781 64 288 64 288 64S117.22 64 74.629 75.486c-23.497 6.322-42.003 24.947-48.284 48.597-11.412 42.867-11.412 132.305-11.412 132.305s0 89.438 11.412 132.305c6.281 23.65 24.787 41.5 48.284 47.821C117.22 448 288 448 288 448s170.78 0 213.371-11.486c23.497-6.321 42.003-24.171 48.284-47.821 11.412-42.867 11.412-132.305 11.412-132.305s0-89.438-11.412-132.305zm-317.51 213.508V175.185l142.739 81.205-142.739 81.201z"/></svg> | ||||
|       </a> | ||||
|       <a target="_blank" href="https://bitcointv.com/c/mempool/videos" class="bitcointv"> | ||||
|         <svg xmlns="http://www.w3.org/2000/svg" focusable="false" viewBox="0 0 440 440"><path d="M225.57,2.08l-.69-.45a4.22,4.22,0,0,0-5.72,1.23L182.33,46.09a4,4,0,0,0,.88,5.81l9.38,6.38L173.48,97.49a4.22,4.22,0,0,0,2.45,4.19s3.55.7,4.53-1l41.92-40.56a3.62,3.62,0,0,0-1.51-5.1l-10.55-6.12L227.44,6.79A4.26,4.26,0,0,0,225.57,2.08Z" fill="currentColor"></path><path d="M118.52,401.83c-62.51,0-113.37-51-113.37-113.67V214.68C5.15,152,56,101,118.52,101H342.08a24.82,24.82,0,0,1,24.76,24.83V377a24.81,24.81,0,0,1-24.76,24.82Z"></path><path d="M342.08,105.18a20.65,20.65,0,0,1,20.61,20.66V377a20.66,20.66,0,0,1-20.61,20.66H118.52C58.3,397.67,9.31,348.55,9.31,288.16V214.68c0-60.38,49-109.5,109.21-109.5H342.08m0-8.34H118.52C53.62,96.84,1,149.6,1,214.68v73.48C1,353.24,53.62,406,118.52,406H342.08A29,29,0,0,0,371,377V125.84a29,29,0,0,0-28.92-29Z" fill="currentColor"></path><path fill="currentColor" d="M344.69,346.23A25.84,25.84,0,1,0,335,369.87l-10.22-10.2a11.69,11.69,0,1,1,4.77-5.12l10.31,10.28A25.84,25.84,0,0,0,344.69,346.23Z"></path><path fill="currentColor" d="M315.82,257.61a25.67,25.67,0,0,0-12.53,5.22L315,274.49a9.58,9.58,0,0,1,2.11-.73A9.72,9.72,0,1,1,309.4,283a9.4,9.4,0,0,1,.75-3.41L298.4,267.84a25.77,25.77,0,1,0,17.42-10.23Z"></path><path fill="currentColor" d="M313,214a7.76,7.76,0,1,1,1.41,10.91,7.62,7.62,0,0,1-2.19-2.69l-18.67-.14a25.94,25.94,0,1,0,.05-7l18.64.14A7.4,7.4,0,0,1,313,214Z"></path><path fill="currentColor" d="M341.2,144.08h-6.32c-1.67,0-3.61,1.87-3.61,4.29s1.94,4.29,3.61,4.29h6.32c1.67,0,3.61-1.87,3.61-4.29S342.87,144.08,341.2,144.08Z"></path><path fill="currentColor" d="M301.75,144.08h-6.44c-1.67,0-3.61,1.87-3.61,4.29s1.94,4.29,3.61,4.29h6.44c1.67,0,3.61-1.87,3.61-4.29S303.42,144.08,301.75,144.08Z"></path><path fill="currentColor" d="M321.77,144.08h-7c-1.67,0-3.62,1.87-3.62,4.29s1.95,4.29,3.62,4.29h7c1.67,0,3.62-1.87,3.62-4.29S323.44,144.08,321.77,144.08Z"></path><ellipse fill="currentColor" cx="295.97" cy="127.61" rx="4.27" ry="4.29"></ellipse><path fill="currentColor" d="M340.54,131.9a4.29,4.29,0,1,0-4.27-4.29A4.28,4.28,0,0,0,340.54,131.9Z"></path><path fill="currentColor" d="M318.26,131.9a4.29,4.29,0,1,0-4.27-4.29A4.29,4.29,0,0,0,318.26,131.9Z"></path><ellipse fill="currentColor" cx="295.97" cy="169.13" rx="4.27" ry="4.29"></ellipse><path fill="currentColor" d="M340.54,164.84a4.3,4.3,0,1,0,4.27,4.29A4.29,4.29,0,0,0,340.54,164.84Z"></path><path fill="currentColor" d="M318.26,164.84a4.3,4.3,0,1,0,4.28,4.29A4.29,4.29,0,0,0,318.26,164.84Z"></path><path d="M108.62,256.87c8.36-1,7.68-7.76,3.14-17-3.64-7.4-9.74-16.39-15.75-25.36-14.23-21.23-27.69-42.23-5.35-41.07,19.55,1,42.9,18.63,68.22,36.74,31.1,22.24,65.16,45.21,98.81,39.11a151.19,151.19,0,0,1,20-2.37V221a92,92,0,0,0-91.91-92.16H124.33A92,92,0,0,0,32.42,221v17.59c17.71,3.81,31,9.94,43.8,14.15C86.6,256.16,96.69,258.31,108.62,256.87Z"></path><path d="M273.37,310.79c-35-15.26-76.67-32.1-104-23.59-3.15,1-5,2.3-6,3.85-3.35,5.31,4.67,13.57,14.89,22.17,7.17,6,15.36,12.21,21.44,17.64,11.47,10.26,15.35,17.84-9.89,16.62-29.75-1.44-49.18-13.75-71.18-24l-.29-.14a165.84,165.84,0,0,0-22.93-8.91c-15.74-4.67-34.22-6.79-58.51-3.28A91.93,91.93,0,0,0,124.33,375h61.45A92,92,0,0,0,273.37,310.79Z"></path><path fill="currentColor" d="M257.69,249.31C224,255.41,190,232.44,158.88,210.2c-25.32-18.11-48.67-35.72-68.22-36.74C68.32,172.3,81.78,193.3,96,214.53c6,9,12.11,18,15.75,25.36,4.54,9.22,5.22,16-3.14,17-11.93,1.44-22-.71-32.4-4.13-12.8-4.21-26.09-10.34-43.8-14.15v44.26c0,1.26.14,2.48.19,3.72a91.8,91.8,0,0,0,2.9,19.62c.43,1.67.84,3.34,1.37,5,24.29-3.51,42.77-1.39,58.51,3.28a165.84,165.84,0,0,1,22.93,8.91c.39-.12.76-.26,1.14-.39l-.85.53c22,10.25,41.43,22.56,71.18,24,25.24,1.22,21.36-6.36,9.89-16.62-6.08-5.43-14.27-11.61-21.44-17.64-10.22-8.6-18.24-16.86-14.89-22.17,1-1.55,2.87-2.87,6-3.85,27.33-8.51,69,8.33,104,23.59.32-1,.56-2.05.84-3.07a92.33,92.33,0,0,0,3.48-24.87V246.94A151.19,151.19,0,0,0,257.69,249.31Z"></path><path fill="currentColor" d="M192,137a78,78,0,0,1,77.78,78v73.91a78,78,0,0,1-77.78,78H118.51a78,78,0,0,1-77.78-78V215a78,78,0,0,1,77.78-78H192m0-8.33H118.51A86.21,86.21,0,0,0,32.42,215v73.91a86.21,86.21,0,0,0,86.09,86.33H192a86.21,86.21,0,0,0,86.09-86.33V215A86.21,86.21,0,0,0,192,128.64Z"></path></svg> | ||||
|       </a> | ||||
|     </div> | ||||
|   </div> | ||||
| 
 | ||||
|   <div class="footer-version" *ngIf="officialMempoolSpace"> | ||||
|     {{ (backendInfo$ | async)?.hostname }} (v{{ (backendInfo$ | async )?.version }}) [<a href="https://github.com/mempool/mempool/commit/{{ (backendInfo$ | async )?.gitCommit | slice:0:8 }}">{{ (backendInfo$ | async )?.gitCommit | slice:0:8 }}</a>] | ||||
|   </div> | ||||
| 
 | ||||
|   <br> | ||||
|  | ||||
| @ -82,6 +82,10 @@ | ||||
| 
 | ||||
| <br /> | ||||
| 
 | ||||
| <router-outlet></router-outlet> | ||||
| <main> | ||||
|   <router-outlet></router-outlet> | ||||
| </main> | ||||
| 
 | ||||
| <app-global-footer *ngIf="footerVisible"></app-global-footer> | ||||
| 
 | ||||
| <br> | ||||
|  | ||||
| @ -17,6 +17,12 @@ li.nav-item { | ||||
|   padding-right: 10px; | ||||
| } | ||||
| 
 | ||||
| @media (max-width: 992px) { | ||||
|   footer > .container-fluid { | ||||
|     padding-bottom: 35px; | ||||
|   } | ||||
| } | ||||
| 
 | ||||
| @media (min-width: 992px) { | ||||
|   .navbar { | ||||
|     padding: 0rem 2rem; | ||||
|  | ||||
| @ -17,6 +17,7 @@ export class BisqMasterPageComponent implements OnInit { | ||||
|   isMobile = window.innerWidth <= 767.98; | ||||
|   urlLanguage: string; | ||||
|   networkPaths: { [network: string]: string }; | ||||
|   footerVisible = true; | ||||
| 
 | ||||
|   constructor( | ||||
|     private stateService: StateService, | ||||
| @ -31,6 +32,11 @@ export class BisqMasterPageComponent implements OnInit { | ||||
|     this.urlLanguage = this.languageService.getLanguageForUrl(); | ||||
|     this.navigationService.subnetPaths.subscribe((paths) => { | ||||
|       this.networkPaths = paths; | ||||
|       if (paths.mainnet.indexOf('docs') > -1) { | ||||
|         this.footerVisible = false; | ||||
|       } else { | ||||
|         this.footerVisible = true; | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|  | ||||
| @ -44,7 +44,7 @@ | ||||
|     </ng-container> | ||||
|   </a> | ||||
| 
 | ||||
|   <div ngbDropdown (window:resize)="onResize($event)" class="dropdown-container" *ngIf="env.TESTNET_ENABLED || env.SIGNET_ENABLED || env.LIQUID_ENABLED || env.BISQ_ENABLED || env.LIQUID_TESTNET_ENABLED"> | ||||
|   <div ngbDropdown (window:resize)="onResize()" class="dropdown-container" *ngIf="env.TESTNET_ENABLED || env.SIGNET_ENABLED || env.LIQUID_ENABLED || env.BISQ_ENABLED || env.LIQUID_TESTNET_ENABLED"> | ||||
|     <button ngbDropdownToggle type="button" class="btn btn-secondary dropdown-toggle-split" aria-haspopup="true"> | ||||
|       <app-svg-images [name]="network.val === '' ? 'liquid' : network.val" width="22" height="22" viewBox="0 0 125 125" style="width: 30px; height: 30px; margin-right: 5px;"></app-svg-images> | ||||
|     </button> | ||||
| @ -92,10 +92,10 @@ | ||||
| 
 | ||||
| <app-testnet-alert *ngIf="network.val === 'liquidtestnet'"></app-testnet-alert> | ||||
| 
 | ||||
| <br /> | ||||
| <main> | ||||
|   <router-outlet></router-outlet> | ||||
| </main> | ||||
| 
 | ||||
| <router-outlet></router-outlet> | ||||
| 
 | ||||
| <app-global-footer></app-global-footer> | ||||
| <app-global-footer *ngIf="footerVisible"></app-global-footer> | ||||
| 
 | ||||
| </ng-container> | ||||
| @ -19,6 +19,7 @@ export class LiquidMasterPageComponent implements OnInit { | ||||
|   network$: Observable<string>; | ||||
|   urlLanguage: string; | ||||
|   networkPaths: { [network: string]: string }; | ||||
|   footerVisible = true; | ||||
| 
 | ||||
|   constructor( | ||||
|     private stateService: StateService, | ||||
| @ -27,13 +28,18 @@ export class LiquidMasterPageComponent implements OnInit { | ||||
|     private navigationService: NavigationService, | ||||
|   ) { } | ||||
| 
 | ||||
|   ngOnInit() { | ||||
|   ngOnInit(): void { | ||||
|     this.env = this.stateService.env; | ||||
|     this.connectionState$ = this.stateService.connectionState$; | ||||
|     this.network$ = merge(of(''), this.stateService.networkChanged$); | ||||
|     this.urlLanguage = this.languageService.getLanguageForUrl(); | ||||
|     this.navigationService.subnetPaths.subscribe((paths) => { | ||||
|       this.networkPaths = paths; | ||||
|       if (paths.liquid.indexOf('docs') > -1) { | ||||
|         this.footerVisible = false; | ||||
|       } else { | ||||
|         this.footerVisible = true; | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
| @ -41,7 +47,7 @@ export class LiquidMasterPageComponent implements OnInit { | ||||
|     this.navCollapsed = !this.navCollapsed; | ||||
|   } | ||||
| 
 | ||||
|   onResize(event: any) { | ||||
|   onResize(): void { | ||||
|     this.isMobile = window.innerWidth <= 767.98; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -17,7 +17,7 @@ | ||||
|     </ng-container> | ||||
|   </a> | ||||
| 
 | ||||
|   <div (window:resize)="onResize($event)" ngbDropdown class="dropdown-container" *ngIf="env.TESTNET_ENABLED || env.SIGNET_ENABLED || env.LIQUID_ENABLED || env.BISQ_ENABLED || env.LIQUID_TESTNET_ENABLED"> | ||||
|   <div (window:resize)="onResize()" ngbDropdown class="dropdown-container" *ngIf="env.TESTNET_ENABLED || env.SIGNET_ENABLED || env.LIQUID_ENABLED || env.BISQ_ENABLED || env.LIQUID_TESTNET_ENABLED"> | ||||
|     <button ngbDropdownToggle type="button" class="btn btn-secondary dropdown-toggle-split" aria-haspopup="true"> | ||||
|       <app-svg-images [name]="network.val === '' ? 'bitcoin' : network.val" width="20" height="20" viewBox="0 0 65 65" style="width: 30px; height: 30px; margin-right: 5px;"></app-svg-images> | ||||
|     </button> | ||||
| @ -64,9 +64,9 @@ | ||||
| 
 | ||||
| <app-testnet-alert *ngIf="network.val === 'testnet' || network.val === 'signet'"></app-testnet-alert> | ||||
| 
 | ||||
| <main style="margin-top: 24px;"> | ||||
| <main> | ||||
|   <router-outlet></router-outlet> | ||||
| </main> | ||||
| 
 | ||||
| <app-global-footer></app-global-footer> | ||||
| <app-global-footer *ngIf="footerVisible"></app-global-footer> | ||||
| </ng-container> | ||||
|  | ||||
| @ -20,6 +20,8 @@ export class MasterPageComponent implements OnInit { | ||||
|   urlLanguage: string; | ||||
|   subdomain = ''; | ||||
|   networkPaths: { [network: string]: string }; | ||||
|   networkPaths$: Observable<Record<string, string>>; | ||||
|   footerVisible = true; | ||||
| 
 | ||||
|   constructor( | ||||
|     public stateService: StateService, | ||||
| @ -28,7 +30,7 @@ export class MasterPageComponent implements OnInit { | ||||
|     private navigationService: NavigationService, | ||||
|   ) { } | ||||
| 
 | ||||
|   ngOnInit() { | ||||
|   ngOnInit(): void { | ||||
|     this.env = this.stateService.env; | ||||
|     this.connectionState$ = this.stateService.connectionState$; | ||||
|     this.network$ = merge(of(''), this.stateService.networkChanged$); | ||||
| @ -36,6 +38,11 @@ export class MasterPageComponent implements OnInit { | ||||
|     this.subdomain = this.enterpriseService.getSubdomain(); | ||||
|     this.navigationService.subnetPaths.subscribe((paths) => { | ||||
|       this.networkPaths = paths; | ||||
|       if (paths.mainnet.indexOf('docs') > -1) { | ||||
|         this.footerVisible = false; | ||||
|       } else { | ||||
|         this.footerVisible = true; | ||||
|       } | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
| @ -43,7 +50,7 @@ export class MasterPageComponent implements OnInit { | ||||
|     this.navCollapsed = !this.navCollapsed; | ||||
|   } | ||||
| 
 | ||||
|   onResize(event: any) { | ||||
|   onResize(): void { | ||||
|     this.isMobile = window.innerWidth <= 767.98; | ||||
|   } | ||||
| } | ||||
|  | ||||
| @ -11,6 +11,15 @@ export class TimeComponent implements OnInit, OnChanges, OnDestroy { | ||||
|   interval: number; | ||||
|   text: string; | ||||
|   units: string[] = ['year', 'month', 'week', 'day', 'hour', 'minute', 'second']; | ||||
|   precisionThresholds = { | ||||
|     year: 100, | ||||
|     month: 18, | ||||
|     week: 12, | ||||
|     day: 31, | ||||
|     hour: 48, | ||||
|     minute: 90, | ||||
|     second: 90 | ||||
|   }; | ||||
|   intervals = {}; | ||||
| 
 | ||||
|   @Input() time: number; | ||||
| @ -85,8 +94,12 @@ export class TimeComponent implements OnInit, OnChanges, OnDestroy { | ||||
| 
 | ||||
|     let counter: number; | ||||
|     for (const [index, unit] of this.units.entries()) { | ||||
|       const precisionUnit = this.units[Math.min(this.units.length - 1), index + this.precision]; | ||||
|       let precisionUnit = this.units[Math.min(this.units.length - 1, index + this.precision)]; | ||||
|       counter = Math.floor(seconds / this.intervals[unit]); | ||||
|       const precisionCounter = Math.floor(seconds / this.intervals[precisionUnit]); | ||||
|       if (precisionCounter > this.precisionThresholds[precisionUnit]) { | ||||
|         precisionUnit = unit; | ||||
|       } | ||||
|       if (counter > 0) { | ||||
|         let rounded = Math.round(seconds / this.intervals[precisionUnit]); | ||||
|         if (this.fractionDigits) { | ||||
|  | ||||
| @ -1,29 +1,31 @@ | ||||
| <footer *ngIf="networkPaths$ | async as networkPaths"> | ||||
| <footer> | ||||
|     <div class="container-fluid"> | ||||
|     <div class="row main"> | ||||
|       <div class="col-sm-4 branding"> | ||||
|         <h5>The Mempool Open Source Project™</h5> | ||||
|         <p>Explore the full Bitcoin ecosystem.</p> | ||||
|       <div class="offset-lg-1 col-lg-4 col align-self-center branding"> | ||||
|         <h5 i18n="about.about-the-project">The Mempool Open Source Project</h5> | ||||
|         <p i18="@@7deec1c1520f06170e1f8e8ddfbe4532312f638f">Explore the full Bitcoin ecosystem</p> | ||||
|         <div class="selector"> | ||||
|           <app-language-selector></app-language-selector> | ||||
|         </div> | ||||
|         <div class="selector"> | ||||
|           <app-fiat-selector></app-fiat-selector> | ||||
|         </div> | ||||
|         <a class="cta btn btn-purple sponsor" [routerLink]="['/signup' | relativeUrl]">Sign In / Sign Up</a> | ||||
|         <a *ngIf="officialMempoolSpace" class="cta btn btn-purple sponsor" [routerLink]="['/signup' | relativeUrl]">Support the Project</a> | ||||
|         <p *ngIf="officialMempoolSpace && env.BASE_MODULE === 'mempool'" class="cta-secondary"><a [routerLink]="['/signin' | relativeUrl]" i18n="shared.broadcast-transaction|Broadcast Transaction">Sign In</a></p> | ||||
|         <p class="cta-secondary"><a [routerLink]="['/tx/push' | relativeUrl]" i18n="shared.broadcast-transaction|Broadcast Transaction">Broadcast Transaction</a></p> | ||||
|         <p class="cta-secondary"><a [routerLink]="['/lightning/group/the-mempool-open-source-project' | relativeUrl]">Connect to Mempool Nodes</a></p> | ||||
|         <p *ngIf="officialMempoolSpace && env.LIGHTNING" class="cta-secondary"><a [routerLink]="['/lightning/group/the-mempool-open-source-project' | relativeUrl]" i18n="footer.connect-to-our-nodes">Connect to our Nodes</a></p> | ||||
|         <p><a [routerLink]="['/about' | relativeUrl]">About the Project</a></p> | ||||
|       </div> | ||||
|       <div class="col-sm-8 links"> | ||||
|       <div class="col-lg-6 col-md-10 offset-md-1 links outer"> | ||||
|         <div class="row"> | ||||
|           <div class="col-sm-4"> | ||||
|           <div class="col-lg-6"> | ||||
|             <p class="category">Explore</p> | ||||
|             <p><a [routerLink]="['/mining' | relativeUrl]">Mining Dashboard</a></p> | ||||
|             <p><a [routerLink]="['/lightning' | relativeUrl]">Lightning Dashboard</a></p> | ||||
|             <p><a [routerLink]="['/blocks' | relativeUrl]">Recent Blocks</a></p> | ||||
|             <p><a [routerLink]="['/rbf' | relativeUrl]">Recent RBF Transactions</a></p> | ||||
|             <p><a [routerLink]="['/docs/api' | relativeUrl]">API Documentation</a></p> | ||||
|           </div> | ||||
|           <div class="col-sm-4 links"> | ||||
|           <div class="col-lg-6 links"> | ||||
|             <p class="category">Learn</p> | ||||
|             <p><a [routerLink]="['/docs/faq']" fragment="what-is-a-mempool">What is a mempool?</a></p> | ||||
|             <p><a [routerLink]="['/docs/faq']" fragment="what-is-a-block-explorer">What is a block explorer?</a></p> | ||||
| @ -31,7 +33,7 @@ | ||||
|             <p><a [routerLink]="['/docs/faq']" fragment="why-is-transaction-stuck-in-mempool">Why isn't my transaction confirming?</a></p> | ||||
|             <p><a [routerLink]="['/docs/faq' | relativeUrl]">More FAQs ›</a></p> | ||||
|           </div> | ||||
|           <div class="col-sm-4 links"> | ||||
|           <!--<div class="col-lg-4 links"> | ||||
|             <p class="category">Connect</p> | ||||
|             <p><a href="https://github.com/mempool" target="_blank">GitHub</a></p> | ||||
|             <p><a href="https://twitter.com/mempool" target="_blank">Twitter</a></p> | ||||
| @ -39,23 +41,18 @@ | ||||
|             <p><a href="https://youtube.com/@mempool" target="_blank">YouTube</a></p> | ||||
|             <p><a href="https://bitcointv.com/c/mempool/videos" target="_blank">BitcoinTV</a></p> | ||||
|             <p><a href="https://mempool.chat" target="_blank">Matrix</a></p> | ||||
|           </div> | ||||
|           </div>--> | ||||
|         </div> | ||||
|         <div class="row"> | ||||
|           <div class="col-sm-4 links"> | ||||
|             <p class="category">Resources</p> | ||||
|             <p><a [routerLink]="['/docs/faq' | relativeUrl]">FAQs</a></p> | ||||
|             <p><a [routerLink]="['/docs/api' | relativeUrl]">API Documentation</a></p> | ||||
|             <p><a [routerLink]="['/about' | relativeUrl]">About the Project</a></p> | ||||
|           </div> | ||||
|           <div class="col-sm-4 links"> | ||||
|           <div class="col-lg-6 links"> | ||||
|             <p class="category">More Networks</p> | ||||
|             <p><a [routerLink]="['/testnet' | relativeUrl]">Testnet Block Explorer</a></p> | ||||
|             <p><a [routerLink]="['/signet' | relativeUrl]">Signet Block Explorer</a></p> | ||||
|             <p><a href="https://liquid.network">Liquid Block Explorer</a></p> | ||||
|             <p><a href="https://bisq.network">Bisq Block Explorer</a></p> | ||||
|             <p *ngIf="currentNetwork !== '' && currentNetwork !== 'mainnet'"><a [href]="networkLink('mainnet')">Mainnet Explorer</a></p> | ||||
|             <p *ngIf="currentNetwork !== 'testnet'"><a [href]="networkLink('testnet')">Testnet Explorer</a></p> | ||||
|             <p *ngIf="currentNetwork !== 'signet'"><a [href]="networkLink('signet')">Signet Explorer</a></p> | ||||
|             <p *ngIf="currentNetwork !== 'liquid' && currentNetwork !== 'liquidtestnet'"><a [href]="networkLink('liquid')">Liquid Explorer</a></p> | ||||
|             <p *ngIf="currentNetwork !== 'bisq'"><a [href]="networkLink('bisq')">Bisq Explorer</a></p> | ||||
|           </div> | ||||
|           <div class="col-sm-4 links"> | ||||
|           <div class="col-lg-6 links"> | ||||
|             <p class="category">Legal</p> | ||||
|             <p><a [routerLink]="['/terms-of-service']" i18n="shared.terms-of-service|Terms of Service">Terms of Service</a></p> | ||||
|             <p><a [routerLink]="['/privacy-policy']" i18n="shared.privacy-policy|Privacy Policy">Privacy Policy</a></p> | ||||
| @ -64,10 +61,20 @@ | ||||
|         </div> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="row social-links"> | ||||
|       <div class="col-sm-12"> | ||||
|         <a href="https://github.com/mempool" target="_blank"><svg fill="#fff" role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>GitHub</title><path d="M12 .297c-6.63 0-12 5.373-12 12 0 5.303 3.438 9.8 8.205 11.385.6.113.82-.258.82-.577 0-.285-.01-1.04-.015-2.04-3.338.724-4.042-1.61-4.042-1.61C4.422 18.07 3.633 17.7 3.633 17.7c-1.087-.744.084-.729.084-.729 1.205.084 1.838 1.236 1.838 1.236 1.07 1.835 2.809 1.305 3.495.998.108-.776.417-1.305.76-1.605-2.665-.3-5.466-1.332-5.466-5.93 0-1.31.465-2.38 1.235-3.22-.135-.303-.54-1.523.105-3.176 0 0 1.005-.322 3.3 1.23.96-.267 1.98-.399 3-.405 1.02.006 2.04.138 3 .405 2.28-1.552 3.285-1.23 3.285-1.23.645 1.653.24 2.873.12 3.176.765.84 1.23 1.91 1.23 3.22 0 4.61-2.805 5.625-5.475 5.92.42.36.81 1.096.81 2.22 0 1.606-.015 2.896-.015 3.286 0 .315.21.69.825.57C20.565 22.092 24 17.592 24 12.297c0-6.627-5.373-12-12-12"/></svg></a> | ||||
|         <a href="https://twitter.com/mempool" target="_blank"><svg fill="#fff" role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>Twitter</title><path d="M23.953 4.57a10 10 0 01-2.825.775 4.958 4.958 0 002.163-2.723c-.951.555-2.005.959-3.127 1.184a4.92 4.92 0 00-8.384 4.482C7.69 8.095 4.067 6.13 1.64 3.162a4.822 4.822 0 00-.666 2.475c0 1.71.87 3.213 2.188 4.096a4.904 4.904 0 01-2.228-.616v.06a4.923 4.923 0 003.946 4.827 4.996 4.996 0 01-2.212.085 4.936 4.936 0 004.604 3.417 9.867 9.867 0 01-6.102 2.105c-.39 0-.779-.023-1.17-.067a13.995 13.995 0 007.557 2.209c9.053 0 13.998-7.496 13.998-13.985 0-.21 0-.42-.015-.63A9.935 9.935 0 0024 4.59z"/></svg></a> | ||||
|         <a href="nostr:npub18d4r6wanxkyrdfjdrjqzj2ukua5cas669ew2g5w7lf4a8te7awzqey6lt3" target="_blank"><svg fill="#fff" data-name="Layer 1" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 875 875"><path d="M684.72 485.57c.22 12.59-11.93 51.47-38.67 81.3-26.74 29.83-56.02 20.85-58.42 20.16s-3.09-4.46-7.89-3.77-9.6 6.17-18.86 7.2-17.49 1.71-26.06-1.37c-4.46.69-5.14.71-7.2 2.24s-17.83 10.79-21.6 11.47c0 7.2-1.37 44.57 0 55.89s3.77 25.71 7.54 36 2.74 10.63 7.54 9.94 13.37.34 15.77 4.11c2.4 3.77 1.37 6.51 5.49 8.23s60.69 17.14 99.43 19.2c26.74.69 42.86 2.74 52.12 19.54 1.37 7.89 7.54 13.03 11.31 14.06s8.23 2.06 12 5.83 1.03 8.23 5.49 11.66c4.46 3.43 14.74 8.57 25.37 13.71 10.63 5.14 15.09 13.37 15.77 16.11s1.71 10.97 1.71 10.97-8.91 0-10.97-2.06-2.74-5.83-2.74-5.83-6.17 1.03-7.54 3.43.69 2.74-7.89.69-11.66-3.77-18.17-8.57c-6.51-4.8-16.46-17.14-25.03-16.8 4.11 8.23 5.83 8.23 10.63 10.97s8.23 5.83 8.23 5.83l-7.2 4.46s-4.46 2.06-14.74-.69-11.66-4.46-12.69-10.63 0-9.26-2.74-14.4-4.11-15.77-22.29-21.26c-18.17-5.49-66.52-21.26-100.12-24.69s-22.63-2.74-28.11-1.37-15.77 4.46-26.4-1.37c-10.63-5.83-16.8-13.71-17.49-20.23s-1.71-10.97 0-19.2 3.43-19.89 1.71-26.74-14.06-55.89-19.89-64.12c-13.03 1.03-50.74-.69-50.74-.69s-2.4-.69-17.49 5.83-36.48 13.76-46.77 19.93-14.4 9.7-16.12 13.13c.12 3-1.23 7.72-2.79 9.06s-12.48 2.42-12.48 2.42-5.85 5.86-8.25 9.97c-6.86 9.6-55.2 125.14-66.52 149.83-13.54 32.57-9.77 27.43-37.71 27.43s-8.06.3-8.06.3-12.34 5.88-16.8 5.88-18.86-2.4-26.4 0-16.46 9.26-23.31 10.29-4.95-1.34-8.38-3.74c-4-.21-14.27-.12-14.27-.12s1.74-6.51 7.91-10.88c8.23-5.83 25.37-16.11 34.63-21.26s17.49-7.89 23.31-9.26 18.51-6.17 30.51-9.94 19.54-8.23 29.83-31.54 50.4-111.43 51.43-116.23c.63-2.96 3.73-6.48 4.8-15.09.66-5.35-2.49-13.04 1.71-22.63 10.97-25.03 21.6-20.23 26.4-20.23s17.14.34 26.4-1.37 15.43-2.74 24.69-7.89 11.31-8.91 11.31-8.91l-19.89-3.43s-18.51.69-25.03-4.46-15.43-15.77-15.43-15.77l-7.54-7.2 1.03 8.57s-5.14-8.91-6.51-10.29-8.57-6.51-11.31-11.31-7.54-25.03-7.54-25.03l-6.17 13.03-1.71-18.86-5.14 7.2-2.74-16.11-4.8 8.23-3.43-14.4-5.83 4.46-2.4-10.29-5.83-3.43s-14.06-9.26-16.46-9.6-4.46 3.43-4.46 3.43l1.37 12-12.2-6.27-7-11.9s2.36 4.01-9.62 7.53c-20.55 0-21.89-2.28-24.93-3.94-1.31-6.56-5.57-10.11-5.57-10.11h-20.57l-.34-6.86-7.89 3.09.69-10.29h-14.06l1.03-11.31h-8.91s3.09-9.26 25.71-22.97 25.03-16.46 46.29-17.14c21.26-.69 32.91 2.74 46.29 8.23s38.74 13.71 43.89 17.49c11.31-9.94 28.46-19.89 34.29-19.89 1.03-2.4 6.19-12.33 17.96-17.6 35.31-15.81 108.13-34 131.53-35.54 31.2-2.06 7.89-1.37 39.09 2.06 31.2 3.43 54.17 7.54 69.6 12.69 12.58 4.19 25.03 9.6 34.29 2.06 4.33-1.81 11.81-1.34 17.83-5.14 30.69-25.09 34.72-32.35 43.63-41.95s20.14-24.91 22.54-45.14 4.46-58.29-10.63-88.12-28.8-45.26-34.63-69.26c-5.83-24-8.23-61.03-6.17-73.03 2.06-12 5.14-22.29 6.86-30.51s9.94-14.74 19.89-16.46c9.94-1.71 17.83 1.37 22.29 4.8 4.46 3.43 11.65 6.28 13.37 10.29.34 1.71-1.37 6.51 8.23 8.23 9.6 1.71 16.05 4.16 16.05 4.16s15.64 4.29 3.11 7.73c-12.69 2.06-20.52-.71-24.29 1.69s-7.21 10.08-9.61 11.1-7.2.34-12 4.11-9.6 6.86-12.69 14.4-5.49 15.77-3.43 26.74 8.57 31.54 14.4 43.2c5.83 11.66 20.23 40.8 24.34 47.66s15.77 29.49 16.8 53.83 1.03 44.23 0 54.86-10.84 51.65-35.53 85.94c-8.16 14.14-23.21 31.9-24.67 35.03-1.45 3.13-3.02 4.88-1.61 7.65 4.62 9.05 12.87 22.13 14.71 29.22 2.29 6.64 6.99 16.13 7.22 28.72Z" style="stroke:#000;stroke-miterlimit:10;stroke-width:6px"/></svg></a> | ||||
|         <a href="https://youtube.com/@mempool" target="_blank"><svg fill="#fff" role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>YouTube</title><path d="M23.498 6.186a3.016 3.016 0 0 0-2.122-2.136C19.505 3.545 12 3.545 12 3.545s-7.505 0-9.377.505A3.017 3.017 0 0 0 .502 6.186C0 8.07 0 12 0 12s0 3.93.502 5.814a3.016 3.016 0 0 0 2.122 2.136c1.871.505 9.376.505 9.376.505s7.505 0 9.377-.505a3.015 3.015 0 0 0 2.122-2.136C24 15.93 24 12 24 12s0-3.93-.502-5.814zM9.545 15.568V8.432L15.818 12l-6.273 3.568z"/></svg></a> | ||||
|         <a href="https://bitcointv.com/c/mempool/videos" target="_blank"><svg _ngcontent-serverApp-c90="" xmlns="http://www.w3.org/2000/svg" focusable="false" viewBox="0 0 440 440"><path _ngcontent-serverApp-c90="" d="M225.57,2.08l-.69-.45a4.22,4.22,0,0,0-5.72,1.23L182.33,46.09a4,4,0,0,0,.88,5.81l9.38,6.38L173.48,97.49a4.22,4.22,0,0,0,2.45,4.19s3.55.7,4.53-1l41.92-40.56a3.62,3.62,0,0,0-1.51-5.1l-10.55-6.12L227.44,6.79A4.26,4.26,0,0,0,225.57,2.08Z" fill="#fff"></path><path _ngcontent-serverApp-c90="" d="M118.52,401.83c-62.51,0-113.37-51-113.37-113.67V214.68C5.15,152,56,101,118.52,101H342.08a24.82,24.82,0,0,1,24.76,24.83V377a24.81,24.81,0,0,1-24.76,24.82Z"></path><path _ngcontent-serverApp-c90="" d="M342.08,105.18a20.65,20.65,0,0,1,20.61,20.66V377a20.66,20.66,0,0,1-20.61,20.66H118.52C58.3,397.67,9.31,348.55,9.31,288.16V214.68c0-60.38,49-109.5,109.21-109.5H342.08m0-8.34H118.52C53.62,96.84,1,149.6,1,214.68v73.48C1,353.24,53.62,406,118.52,406H342.08A29,29,0,0,0,371,377V125.84a29,29,0,0,0-28.92-29Z" fill="#fff"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M344.69,346.23A25.84,25.84,0,1,0,335,369.87l-10.22-10.2a11.69,11.69,0,1,1,4.77-5.12l10.31,10.28A25.84,25.84,0,0,0,344.69,346.23Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M315.82,257.61a25.67,25.67,0,0,0-12.53,5.22L315,274.49a9.58,9.58,0,0,1,2.11-.73A9.72,9.72,0,1,1,309.4,283a9.4,9.4,0,0,1,.75-3.41L298.4,267.84a25.77,25.77,0,1,0,17.42-10.23Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M313,214a7.76,7.76,0,1,1,1.41,10.91,7.62,7.62,0,0,1-2.19-2.69l-18.67-.14a25.94,25.94,0,1,0,.05-7l18.64.14A7.4,7.4,0,0,1,313,214Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M341.2,144.08h-6.32c-1.67,0-3.61,1.87-3.61,4.29s1.94,4.29,3.61,4.29h6.32c1.67,0,3.61-1.87,3.61-4.29S342.87,144.08,341.2,144.08Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M301.75,144.08h-6.44c-1.67,0-3.61,1.87-3.61,4.29s1.94,4.29,3.61,4.29h6.44c1.67,0,3.61-1.87,3.61-4.29S303.42,144.08,301.75,144.08Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M321.77,144.08h-7c-1.67,0-3.62,1.87-3.62,4.29s1.95,4.29,3.62,4.29h7c1.67,0,3.62-1.87,3.62-4.29S323.44,144.08,321.77,144.08Z"></path><ellipse _ngcontent-serverApp-c90="" fill="#fff" cx="295.97" cy="127.61" rx="4.27" ry="4.29"></ellipse><path _ngcontent-serverApp-c90="" fill="#fff" d="M340.54,131.9a4.29,4.29,0,1,0-4.27-4.29A4.28,4.28,0,0,0,340.54,131.9Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M318.26,131.9a4.29,4.29,0,1,0-4.27-4.29A4.29,4.29,0,0,0,318.26,131.9Z"></path><ellipse _ngcontent-serverApp-c90="" fill="#fff" cx="295.97" cy="169.13" rx="4.27" ry="4.29"></ellipse><path _ngcontent-serverApp-c90="" fill="#fff" d="M340.54,164.84a4.3,4.3,0,1,0,4.27,4.29A4.29,4.29,0,0,0,340.54,164.84Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M318.26,164.84a4.3,4.3,0,1,0,4.28,4.29A4.29,4.29,0,0,0,318.26,164.84Z"></path><path _ngcontent-serverApp-c90="" d="M108.62,256.87c8.36-1,7.68-7.76,3.14-17-3.64-7.4-9.74-16.39-15.75-25.36-14.23-21.23-27.69-42.23-5.35-41.07,19.55,1,42.9,18.63,68.22,36.74,31.1,22.24,65.16,45.21,98.81,39.11a151.19,151.19,0,0,1,20-2.37V221a92,92,0,0,0-91.91-92.16H124.33A92,92,0,0,0,32.42,221v17.59c17.71,3.81,31,9.94,43.8,14.15C86.6,256.16,96.69,258.31,108.62,256.87Z"></path><path _ngcontent-serverApp-c90="" d="M273.37,310.79c-35-15.26-76.67-32.1-104-23.59-3.15,1-5,2.3-6,3.85-3.35,5.31,4.67,13.57,14.89,22.17,7.17,6,15.36,12.21,21.44,17.64,11.47,10.26,15.35,17.84-9.89,16.62-29.75-1.44-49.18-13.75-71.18-24l-.29-.14a165.84,165.84,0,0,0-22.93-8.91c-15.74-4.67-34.22-6.79-58.51-3.28A91.93,91.93,0,0,0,124.33,375h61.45A92,92,0,0,0,273.37,310.79Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M257.69,249.31C224,255.41,190,232.44,158.88,210.2c-25.32-18.11-48.67-35.72-68.22-36.74C68.32,172.3,81.78,193.3,96,214.53c6,9,12.11,18,15.75,25.36,4.54,9.22,5.22,16-3.14,17-11.93,1.44-22-.71-32.4-4.13-12.8-4.21-26.09-10.34-43.8-14.15v44.26c0,1.26.14,2.48.19,3.72a91.8,91.8,0,0,0,2.9,19.62c.43,1.67.84,3.34,1.37,5,24.29-3.51,42.77-1.39,58.51,3.28a165.84,165.84,0,0,1,22.93,8.91c.39-.12.76-.26,1.14-.39l-.85.53c22,10.25,41.43,22.56,71.18,24,25.24,1.22,21.36-6.36,9.89-16.62-6.08-5.43-14.27-11.61-21.44-17.64-10.22-8.6-18.24-16.86-14.89-22.17,1-1.55,2.87-2.87,6-3.85,27.33-8.51,69,8.33,104,23.59.32-1,.56-2.05.84-3.07a92.33,92.33,0,0,0,3.48-24.87V246.94A151.19,151.19,0,0,0,257.69,249.31Z"></path><path _ngcontent-serverApp-c90="" fill="#fff" d="M192,137a78,78,0,0,1,77.78,78v73.91a78,78,0,0,1-77.78,78H118.51a78,78,0,0,1-77.78-78V215a78,78,0,0,1,77.78-78H192m0-8.33H118.51A86.21,86.21,0,0,0,32.42,215v73.91a86.21,86.21,0,0,0,86.09,86.33H192a86.21,86.21,0,0,0,86.09-86.33V215A86.21,86.21,0,0,0,192,128.64Z"></path></svg></a> | ||||
|         <a href="https://mempool.chat" target="_blank"><svg fill="#fff" role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>Matrix</title><path d="M.632.55v22.9H2.28V24H0V0h2.28v.55zm7.043 7.26v1.157h.033c.309-.443.683-.784 1.117-1.024.433-.245.936-.365 1.5-.365.54 0 1.033.107 1.481.314.448.208.785.582 1.02 1.108.254-.374.6-.706 1.034-.992.434-.287.95-.43 1.546-.43.453 0 .872.056 1.26.167.388.11.716.286.993.53.276.245.489.559.646.951.152.392.23.863.23 1.417v5.728h-2.349V11.52c0-.286-.01-.559-.032-.812a1.755 1.755 0 0 0-.18-.66 1.106 1.106 0 0 0-.438-.448c-.194-.11-.457-.166-.785-.166-.332 0-.6.064-.803.189a1.38 1.38 0 0 0-.48.499 1.946 1.946 0 0 0-.231.696 5.56 5.56 0 0 0-.06.785v4.768h-2.35v-4.8c0-.254-.004-.503-.018-.752a2.074 2.074 0 0 0-.143-.688 1.052 1.052 0 0 0-.415-.503c-.194-.125-.476-.19-.854-.19-.111 0-.259.024-.439.074-.18.051-.36.143-.53.282-.171.138-.319.337-.439.595-.12.259-.18.6-.18 1.02v4.966H5.46V7.81zm15.693 15.64V.55H21.72V0H24v24h-2.28v-.55z"/></svg></a> | ||||
|       </div> | ||||
|     </div> | ||||
|     <div class="row version"> | ||||
|       <div class="col-sm-12"> | ||||
|         <p *ngIf="officialMempoolSpace">{{ (backendInfo$ | async)?.hostname }} (v{{ (backendInfo$ | async )?.version }}) [<a target="_blank" href="https://github.com/mempool/mempool/commit/{{ (backendInfo$ | async )?.gitCommit | slice:0:8 }}">{{ (backendInfo$ | async )?.gitCommit | slice:0:8 }}</a>]</p> | ||||
|          | ||||
| 
 | ||||
|         <p *ngIf="!officialMempoolSpace">v{{ packetJsonVersion }} [<a target="_blank" href="https://github.com/mempool/mempool/commit/{{ frontendGitCommitHash }}">{{ frontendGitCommitHash }}</a>]</p> | ||||
| 
 | ||||
|       </div> | ||||
|  | ||||
| @ -13,6 +13,8 @@ footer p { | ||||
| 
 | ||||
| footer .row.main { | ||||
|   padding: 40px 0; | ||||
|   max-width: 1200px; | ||||
|   margin: 0 auto; | ||||
| } | ||||
| 
 | ||||
| footer .row.main .branding { | ||||
| @ -29,13 +31,18 @@ footer .row.main .branding button.account { | ||||
| } | ||||
| 
 | ||||
| footer .row.main .branding .cta { | ||||
|   margin: 50px auto 45px auto; | ||||
|   margin: 20px auto 25px auto; | ||||
| } | ||||
| 
 | ||||
| footer .row.main .branding .cta-secondary { | ||||
| 
 | ||||
| } | ||||
| 
 | ||||
| footer .row.main .links.outer { | ||||
|   padding-left: 24px; | ||||
|   padding-top: 10px; | ||||
| } | ||||
| 
 | ||||
| footer .row.main .links > div:first-child { | ||||
|   margin-bottom: 20px; | ||||
| } | ||||
| @ -53,18 +60,47 @@ footer .selector { | ||||
|   margin: 20px 0; | ||||
| } | ||||
| 
 | ||||
| footer .row.version .col-sm-12 { | ||||
| footer .row.social-links { | ||||
|   text-align: center; | ||||
|   margin-bottom: 24px; | ||||
| } | ||||
| 
 | ||||
| footer .row.social-links a { | ||||
|   margin: 0 14px; | ||||
| } | ||||
| 
 | ||||
| footer .row.social-links svg { | ||||
|   width: 20px; | ||||
| } | ||||
| 
 | ||||
| footer .row.version { | ||||
|   padding: 20px !important; | ||||
|   background-color: #11131f; | ||||
| } | ||||
| 
 | ||||
| footer .row.version .col-sm-12 p { | ||||
| footer .row.version p { | ||||
|   margin-bottom: 0; | ||||
|   text-align: center; | ||||
|   font-size: 12px; | ||||
|   color: rgba(255, 255, 255, 0.4); | ||||
| } | ||||
| 
 | ||||
| footer .row.version .col-sm-12 p a { | ||||
| footer .row.version p a { | ||||
|   color: #09a3ba; | ||||
| } | ||||
| 
 | ||||
| @media (max-width: 992px) { | ||||
| 
 | ||||
|   footer .row.main .links.outer { | ||||
|     text-align: center; | ||||
|   } | ||||
| 
 | ||||
|   footer .row.main .links.outer > .row { | ||||
|     margin-top: 20px; | ||||
|   } | ||||
| 
 | ||||
|   footer .row.main .links.outer > .row > div:first-child { | ||||
|     margin-bottom: 20px; | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -1,8 +1,10 @@ | ||||
| import { ChangeDetectionStrategy, Component, OnInit } from '@angular/core'; | ||||
| import { Observable } from 'rxjs'; | ||||
| import { NavigationService } from '../../../services/navigation.service'; | ||||
| import { Observable, merge, of, Subject } from 'rxjs'; | ||||
| import { tap, takeUntil } from 'rxjs/operators'; | ||||
| import { Env, StateService } from '../../../services/state.service'; | ||||
| import { IBackendInfo } from '../../../interfaces/websocket.interface'; | ||||
| import { LanguageService } from '../../../services/language.service'; | ||||
| import { NavigationService } from '../../../services/navigation.service'; | ||||
| 
 | ||||
| @Component({ | ||||
|   selector: 'app-global-footer', | ||||
| @ -11,23 +13,56 @@ import { IBackendInfo } from '../../../interfaces/websocket.interface'; | ||||
|   changeDetection: ChangeDetectionStrategy.OnPush, | ||||
| }) | ||||
| export class GlobalFooterComponent implements OnInit { | ||||
|   private destroy$: Subject<any> = new Subject<any>(); | ||||
|   env: Env; | ||||
|   networkPaths: { [network: string]: string }; | ||||
|   officialMempoolSpace = this.stateService.env.OFFICIAL_MEMPOOL_SPACE; | ||||
|   networkPaths$: Observable<Record<string, string>>; | ||||
|   backendInfo$: Observable<IBackendInfo>; | ||||
|   frontendGitCommitHash = this.stateService.env.GIT_COMMIT_HASH; | ||||
|   packetJsonVersion = this.stateService.env.PACKAGE_JSON_VERSION; | ||||
|   urlLanguage: string; | ||||
|   network$: Observable<string>; | ||||
|   networkPaths: { [network: string]: string }; | ||||
|   currentNetwork = ''; | ||||
| 
 | ||||
|   constructor( | ||||
|     public stateService: StateService, | ||||
|     private languageService: LanguageService, | ||||
|     private navigationService: NavigationService, | ||||
|   ) {} | ||||
| 
 | ||||
|   ngOnInit(): void { | ||||
|     this.env = this.stateService.env; | ||||
|     this.networkPaths$ = this.navigationService.subnetPaths; | ||||
|     this.backendInfo$ = this.stateService.backendInfo$; | ||||
|     this.urlLanguage = this.languageService.getLanguageForUrl(); | ||||
|     this.navigationService.subnetPaths.subscribe((paths) => { | ||||
|       this.networkPaths = paths; | ||||
|     }); | ||||
|     this.network$ = merge(of(''), this.stateService.networkChanged$).pipe( | ||||
|       tap((network: string) => { | ||||
|         return network; | ||||
|       }) | ||||
|     ); | ||||
|     this.network$.pipe(takeUntil(this.destroy$)).subscribe((network) => { | ||||
|       this.currentNetwork = network; | ||||
|     }); | ||||
|   } | ||||
| 
 | ||||
|   ngOnDestroy(): void { | ||||
|     this.destroy$.next(true); | ||||
|     this.destroy$.complete(); | ||||
|   } | ||||
| 
 | ||||
|   networkLink(network) { | ||||
|     const thisNetwork = network || 'mainnet'; | ||||
|     if( network === '' || network === 'mainnet' || network === 'testnet' || network === 'signet' ) { | ||||
|       return (this.env.BASE_MODULE === 'mempool' ? '' : this.env.MEMPOOL_WEBSITE_URL + this.urlLanguage) + this.networkPaths[thisNetwork] || '/'; | ||||
|     } | ||||
|     if( network === 'liquid' || network === 'liquidtestnet' ) { | ||||
|       return (this.env.BASE_MODULE === 'liquid' ? '' : this.env.LIQUID_WEBSITE_URL + this.urlLanguage) + this.networkPaths[thisNetwork] || '/'; | ||||
|     } | ||||
|     if( network === 'bisq' ) { | ||||
|       return (this.env.BASE_MODULE === 'bisq' ? '' : this.env.BISQ_WEBSITE_URL + this.urlLanguage) + this.networkPaths[thisNetwork] || '/'; | ||||
|     } | ||||
|   } | ||||
| 
 | ||||
| } | ||||
|  | ||||
| @ -62,6 +62,10 @@ body { | ||||
|   position: relative; | ||||
| } | ||||
| 
 | ||||
| main { | ||||
|   margin-top: 24px; | ||||
| } | ||||
| 
 | ||||
| .full-height { | ||||
|   @media (max-width: 767.98px) { | ||||
|     min-height: 100vh; | ||||
| @ -1143,7 +1147,7 @@ th { | ||||
|   display: none; | ||||
| } | ||||
| 
 | ||||
| app-master-page, app-liquid-master-page { | ||||
| app-master-page, app-liquid-master-page, app-bisq-master-page { | ||||
|   display: flex; | ||||
|   flex-direction: column; | ||||
|   min-height: 100vh; | ||||
| @ -1155,4 +1159,4 @@ app-master-page, app-liquid-master-page { | ||||
| 
 | ||||
| app-global-footer { | ||||
|   margin-top: auto; | ||||
| } | ||||
| } | ||||
|  | ||||
		Loading…
	
	
			
			x
			
			
		
	
		Reference in New Issue
	
	Block a user