Files
doneit-web/src/app/shared/header/header.page.ts
T

156 lines
3.9 KiB
TypeScript
Raw Normal View History

2020-12-10 11:22:06 +01:00
import { Component, OnInit } from '@angular/core';
2021-03-02 18:53:37 +01:00
import { AnimationController, ModalController } from '@ionic/angular';
2021-01-07 10:54:11 +01:00
import { SearchPage } from 'src/app/pages/search/search.page';
2021-03-01 15:45:30 +01:00
import { Router } from '@angular/router';
2021-05-27 16:21:04 +01:00
import { ProfileComponent } from '../headers/header-no-search/profile/profile.page';
import { AuthService } from 'src/app/services/auth.service';
import { User } from 'src/app/models/user.model';
2021-07-29 15:59:03 +01:00
import { ProfilePage } from 'src/app/modals/profile/profile.page';
2020-12-10 11:22:06 +01:00
@Component({
selector: 'app-header',
templateUrl: './header.page.html',
styleUrls: ['./header.page.scss'],
})
export class HeaderPage implements OnInit {
2021-03-05 14:54:10 +01:00
searchSubject: string = '';
2021-04-23 14:30:18 +01:00
showSearch=false;
loggeduser: User;
2021-07-30 14:11:19 +01:00
hideSearchBtn:boolean = false;
2021-07-29 15:59:03 +01:00
2021-03-02 18:53:37 +01:00
constructor(
2021-05-18 14:37:43 +01:00
private router: Router,
private modalController: ModalController,
private animationController: AnimationController,
2021-05-18 14:37:43 +01:00
authService: AuthService
) {
this.loggeduser = authService.ValidatedUser;
2021-05-18 14:37:43 +01:00
router.events.subscribe((val) => {
this.showSearch=false;
//this.modalController.dismiss();
});
2021-02-01 17:00:01 +01:00
}
2020-12-10 11:22:06 +01:00
ngOnInit() {
2021-07-30 14:11:19 +01:00
this.hideSearch();
}
hideSearch(){
2021-07-30 16:06:58 +01:00
if(this.router.url == '/home/events' || this.router.url == '/home/chat'){
2021-07-30 14:11:19 +01:00
this.hideSearchBtn = true;
}
2020-12-10 11:22:06 +01:00
}
2021-03-02 14:46:38 +01:00
locationPathname(): string {
return window.location.pathname
}
2021-01-07 10:54:11 +01:00
async openSearch() {
2021-04-08 19:25:59 +01:00
let classs, showSearchInput, type;
2021-04-23 14:30:18 +01:00
if(window.innerWidth < 1366) {
classs = 'modal modal-width-100'
showSearchInput = true
2021-04-23 14:30:18 +01:00
} else {
2021-06-24 11:08:17 +01:00
classs = 'modal modal-desktop desktop-search'
showSearchInput = false
}
2021-08-10 13:22:33 +01:00
if(window.location.pathname.startsWith('/home/agenda')) {
type = "Agenda"
2021-08-10 13:22:33 +01:00
} else if (window.location.pathname.startsWith('/home/gabinete-digital')) {
type = "AccoesPresidenciais & ArquivoDespachoElect"
2021-08-10 13:22:33 +01:00
} else if (window.location.pathname.startsWith('/home/publications')) {
type = "AccoesPresidenciais"
2021-04-23 14:30:18 +01:00
}
2021-01-07 10:54:11 +01:00
const modal = await this.modalController.create({
component: SearchPage,
2021-04-23 14:30:18 +01:00
cssClass: classs,
2021-01-07 10:54:11 +01:00
componentProps: {
2021-07-26 11:34:46 +01:00
type: type,
showSearchInput: showSearchInput,
select: false
2021-01-07 10:54:11 +01:00
}
});
return await modal.present();
}
2021-03-01 15:45:30 +01:00
changeRoute(path){
this.router.navigateByUrl(path)
}
2021-03-02 18:53:37 +01:00
async openProfile() {
const enterAnimation = (baseEl: any) => {
const backdropAnimation = this.animationController.create()
.addElement(baseEl.querySelector('ion-backdrop')!)
.fromTo('opacity', '0.01', 'var(--backdrop-opacity)');
const wrapperAnimation = this.animationController.create()
.addElement(baseEl.querySelector('.modal-wrapper')!)
.keyframes([
{ offset: 0, opacity: '1', right: '-100%' },
{ offset: 1, opacity: '1', right: '0px' }
]);
return this.animationController.create()
.addElement(baseEl)
.easing('ease-out')
.duration(500)
.addAnimation([backdropAnimation, wrapperAnimation]);
}
const leaveAnimation = (baseEl: any) => {
return enterAnimation(baseEl).direction('reverse');
}
2021-07-29 15:59:03 +01:00
2021-03-02 18:53:37 +01:00
const modal = await this.modalController.create({
enterAnimation,
leaveAnimation,
2021-07-29 15:59:03 +01:00
component: ProfilePage,
2021-03-11 10:31:46 +01:00
cssClass: 'model profile-modal search-submodal',
2021-03-02 18:53:37 +01:00
componentProps: {
}
});
return await modal.present();
}
2021-03-02 19:00:55 +01:00
2021-03-05 14:54:10 +01:00
async dynamicSearch(){
window['dynamicSearch'](this.searchSubject)
}
2021-03-02 19:00:55 +01:00
2021-03-05 14:54:10 +01:00
async closeSearch(){
2021-03-11 10:31:46 +01:00
this.modalController.dismiss()
2021-03-05 14:54:10 +01:00
}
/**
* @description set empty value to searchSubject
*/
clearSearchInput(){
this.searchSubject = "";
window['dynamicSearch'](this.searchSubject)
}
2021-07-30 22:12:50 +01:00
async basicSearch() {
2021-03-05 14:54:10 +01:00
window['searchTriger']()
}
2021-08-06 12:19:38 +01:00
profileLabel(text) {
if (text == 'MDGPR') {
return 'MD'
} else if (text == 'PR') {
return text
} else {
return 'UN'
}
}
2021-07-29 15:59:03 +01:00
}