File

src/components/popover-page/popover-page.tsx

Metadata

tag popover-page

Index

Properties
Methods

Methods

Async logout
logout()
Returns : any
openAll
openAll()
Returns : void
openProfile
openProfile()
Returns : void
render
render()
Returns : any
settings
settings()
Returns : void

Properties

closePopover
closePopover: EventEmitter
Type : EventEmitter
Decorators :
@Event()
el
el: Element
Type : Element
Decorators :
@Element()
popoverCtrl
popoverCtrl: HTMLIonPopoverControllerElement
Type : HTMLIonPopoverControllerElement
Decorators :
@Prop({connect: 'ion-popover-controller'})
import { Component, Element, Event, EventEmitter, Prop } from '@stencil/core';

declare var firebase: any;

@Component({
  tag: 'popover-page'
})
export class PopoverPage {

  @Prop({ connect: 'ion-popover-controller' }) popoverCtrl: HTMLIonPopoverControllerElement;

  @Event() closePopover: EventEmitter;

  @Element() el: Element;

  openProfile() {
    this.closePopover.emit();
    (document.querySelector('ion-nav') as HTMLIonNavElement).push('profile-page');

  }

  openAll() {
    this.closePopover.emit();
    (document.querySelector('ion-nav') as HTMLIonNavElement).push('users-page');
  }

  settings() {
    this.closePopover.emit();
    (document.querySelector('ion-nav') as HTMLIonNavElement).push('settings-page');
  }

  async logout() {
    console.log('here');
    this.closePopover.emit();
    await firebase.auth().signOut();
    // this.history.replace('/', {});
    (document.querySelector('ion-nav') as HTMLIonNavElement).setRoot('auth-page');
  }

  render() {
    return (
      <ion-list no-lines>
        <ion-item onClick={() => this.openProfile()}><ion-label>My Profile</ion-label></ion-item>
        <ion-item onClick={() => this.openAll()}><ion-label>All Users</ion-label></ion-item>
        <ion-item onClick={() => this.settings()}><ion-label>Settings</ion-label></ion-item>
        <ion-item onClick={() => this.logout()}><ion-label color='danger'>Logout</ion-label></ion-item>
      </ion-list>
    );
  }
}
Legend
Html element
Component
Html element with directive

result-matching ""

    No results matching ""