File

src/app/app.component.ts

Implements

OnInit

Metadata

changeDetection ChangeDetectionStrategy.OnPush
selector app-root
styleUrls ./app.component.scss
templateUrl ./app.component.html

Index

Properties
Methods
HostListeners

Constructor

constructor(authService: AuthService, transactionService: TransactionService, loggingService: LoggingService, errorDialogService: ErrorDialogService, swUpdate: SwUpdate)
Parameters :
Name Type Optional
authService AuthService No
transactionService TransactionService No
loggingService LoggingService No
errorDialogService ErrorDialogService No
swUpdate SwUpdate No

HostListeners

window:cic_convert
Arguments : '$event'
window:cic_convert(event: CustomEvent)
window:cic_transfer
Arguments : '$event'
window:cic_transfer(event: CustomEvent)

Methods

ngOnInit
ngOnInit()
Returns : void
onResize
onResize(e)
Parameters :
Name Optional
e No
Returns : void

Properties

mediaQuery
Type : MediaQueryList
Default value : window.matchMedia('(max-width: 768px)')
readyState
Type : number
Default value : 0
readyStateTarget
Type : number
Default value : 3
title
Type : string
Default value : 'CICADA'
import { ChangeDetectionStrategy, Component, HostListener, OnInit } from '@angular/core';
import {
  AuthService,
  ErrorDialogService,
  LoggingService,
  TransactionService,
} from '@app/_services';
import { catchError } from 'rxjs/operators';
import { SwUpdate } from '@angular/service-worker';

@Component({
  selector: 'app-root',
  templateUrl: './app.component.html',
  styleUrls: ['./app.component.scss'],
  changeDetection: ChangeDetectionStrategy.OnPush,
})
export class AppComponent implements OnInit {
  title = 'CICADA';
  readyStateTarget: number = 3;
  readyState: number = 0;
  mediaQuery: MediaQueryList = window.matchMedia('(max-width: 768px)');

  constructor(
    private authService: AuthService,
    private transactionService: TransactionService,
    private loggingService: LoggingService,
    private errorDialogService: ErrorDialogService,
    private swUpdate: SwUpdate
  ) {
    (async () => {
      try {
        await this.authService.init();
        // this.authService.getPublicKeys()
        //   .pipe(catchError(async (error) => {
        //     this.loggingService.sendErrorLevelMessage('Unable to load trusted public keys.', this, {error});
        //     this.errorDialogService.openDialog({message: 'Trusted keys endpoint can\'t be reached. Please try again later.'});
        // })).subscribe(this.authService.mutableKeyStore.importPublicKey);
        const publicKeys = await this.authService.getPublicKeys();
        await this.authService.mutableKeyStore.importPublicKey(publicKeys);
      } catch (error) {
        this.errorDialogService.openDialog({
          message: 'Trusted keys endpoint cannot be reached. Please try again later.',
        });
        // TODO do something to halt user progress...show a sad cicada page 🦗?
      }
    })();
    this.mediaQuery.addEventListener('change', this.onResize);
    this.onResize(this.mediaQuery);
  }

  ngOnInit(): void {
    if (!this.swUpdate.isEnabled) {
      this.swUpdate.available.subscribe(() => {
        if (confirm('New Version available. Load New Version?')) {
          window.location.reload();
        }
      });
    }
  }

  // Load resize
  onResize(e): void {
    const sidebar: HTMLElement = document.getElementById('sidebar');
    const content: HTMLElement = document.getElementById('content');
    const sidebarCollapse: HTMLElement = document.getElementById('sidebarCollapse');
    if (sidebarCollapse?.classList.contains('active')) {
      sidebarCollapse?.classList.remove('active');
    }
    if (e.matches) {
      if (!sidebar?.classList.contains('active')) {
        sidebar?.classList.add('active');
      }
      if (!content?.classList.contains('active')) {
        content?.classList.add('active');
      }
    } else {
      if (sidebar?.classList.contains('active')) {
        sidebar?.classList.remove('active');
      }
      if (content?.classList.contains('active')) {
        content?.classList.remove('active');
      }
    }
  }

  @HostListener('window:cic_transfer', ['$event'])
  async cicTransfer(event: CustomEvent): Promise<void> {
    const transaction: any = event.detail.tx;
    await this.transactionService.setTransaction(transaction, 100);
  }

  @HostListener('window:cic_convert', ['$event'])
  async cicConvert(event: CustomEvent): Promise<void> {
    const conversion: any = event.detail.tx;
    await this.transactionService.setConversion(conversion, 100);
  }
}
<app-network-status></app-network-status>
<router-outlet (activate)="onResize(mediaQuery)"></router-outlet>

./app.component.scss

Legend
Html element
Component
Html element with directive

result-matching ""

    No results matching ""