1. LayoutService: Delete isDashboard. 2. Navbar: fix a bug with class add and remove. 3. Role-users: Add new search-input. 4. Modal make title h5
This commit is contained in:
parent
8205f303a7
commit
510f4c56ba
|
@ -35,11 +35,6 @@ export class LayoutService {
|
||||||
*/
|
*/
|
||||||
private isSmallScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
|
private isSmallScreenSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(false);
|
||||||
|
|
||||||
/**
|
|
||||||
* Add isDashboard: false on data of route config, if page is for a stakeholder but not for dashboard.
|
|
||||||
*/
|
|
||||||
private isDashboardSubject: BehaviorSubject<boolean> = new BehaviorSubject<boolean>(true);
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Add activeMenuItem: string on data of route config, if page should activate a specific MenuItem and route url does not match.
|
* Add activeMenuItem: string on data of route config, if page should activate a specific MenuItem and route url does not match.
|
||||||
*/
|
*/
|
||||||
|
@ -90,12 +85,6 @@ export class LayoutService {
|
||||||
} else {
|
} else {
|
||||||
this.setSmallScreen(false);
|
this.setSmallScreen(false);
|
||||||
}
|
}
|
||||||
if (data['isDashboard'] !== undefined &&
|
|
||||||
data['isDashboard'] === false) {
|
|
||||||
this.setDashboard(false);
|
|
||||||
} else {
|
|
||||||
this.setDashboard(true);
|
|
||||||
}
|
|
||||||
if (data['activeMenuItem'] !== undefined &&
|
if (data['activeMenuItem'] !== undefined &&
|
||||||
data['activeMenuItem'] !== null) {
|
data['activeMenuItem'] !== null) {
|
||||||
this.setActiveMenuItem(data['activeMenuItem']);
|
this.setActiveMenuItem(data['activeMenuItem']);
|
||||||
|
@ -147,14 +136,6 @@ export class LayoutService {
|
||||||
this.isFrontPageSubject.next(value);
|
this.isFrontPageSubject.next(value);
|
||||||
}
|
}
|
||||||
|
|
||||||
get isDashboard(): Observable<boolean> {
|
|
||||||
return this.isDashboardSubject.asObservable();
|
|
||||||
}
|
|
||||||
|
|
||||||
setDashboard(value: boolean) {
|
|
||||||
this.isDashboardSubject.next(value);
|
|
||||||
}
|
|
||||||
|
|
||||||
get isSmallScreen(): boolean {
|
get isSmallScreen(): boolean {
|
||||||
return this.isSmallScreenSubject.getValue();
|
return this.isSmallScreenSubject.getValue();
|
||||||
}
|
}
|
||||||
|
|
|
@ -1,6 +1,6 @@
|
||||||
<aside id="sidebar_main">
|
<aside id="sidebar_main">
|
||||||
<div id="sidebar_content">
|
<div id="sidebar_content">
|
||||||
<div *ngIf="items.length > 0" class="menu_section uk-margin-xlarge-top">
|
<div *ngIf="items.length > 0" class="menu_section uk-margin-xlarge-top" style="min-height: 30vh">
|
||||||
<div *ngIf="items[activeIndex]" class="active" [style]="'--index: ' + activeIndex + '; --size: ' + (items[activeIndex].icon?'40px':0)"></div>
|
<div *ngIf="items[activeIndex]" class="active" [style]="'--index: ' + activeIndex + '; --size: ' + (items[activeIndex].icon?'40px':0)"></div>
|
||||||
<ul class="uk-list uk-nav-parent-icon" uk-nav>
|
<ul class="uk-list uk-nav-parent-icon" uk-nav>
|
||||||
<ng-template ngFor [ngForOf]="items" let-item let-i="index">
|
<ng-template ngFor [ngForOf]="items" let-item let-i="index">
|
||||||
|
@ -12,7 +12,7 @@
|
||||||
[queryParams]=item.params [queryParamsHandling]="queryParamsHandling">
|
[queryParams]=item.params [queryParamsHandling]="queryParamsHandling">
|
||||||
<div class="uk-flex uk-flex-middle uk-flex-center">
|
<div class="uk-flex uk-flex-middle uk-flex-center">
|
||||||
<div *ngIf="item.icon" class="uk-width-auto">
|
<div *ngIf="item.icon" class="uk-width-auto">
|
||||||
<icon class="menu-icon" [svg]="item.icon" [flex]="true"></icon>
|
<icon class="menu-icon" [customClass]="item.icon.class" [name]="item.icon.name" [svg]="item.icon.svg" [flex]="true"></icon>
|
||||||
</div>
|
</div>
|
||||||
<span *ngIf="open || !item.icon" [class.uk-text-small]="!open" class="uk-width-expand uk-text-truncate uk-margin-small-left">{{item.title}}</span>
|
<span *ngIf="open || !item.icon" [class.uk-text-small]="!open" class="uk-width-expand uk-text-truncate uk-margin-small-left">{{item.title}}</span>
|
||||||
</div>
|
</div>
|
||||||
|
@ -22,15 +22,17 @@
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<ng-template [ngIf]="specialMenuItem">
|
<ng-template [ngIf]="specialMenuItem">
|
||||||
<div class="special_section uk-margin-large-top">
|
<div class="menu_section uk-margin-large-top">
|
||||||
<ul class="uk-list">
|
<ul class="uk-list">
|
||||||
<li [class.uk-active]="isTheActiveUrl(specialMenuItem.route)">
|
<li [class.uk-active]="isTheActiveUrl(specialMenuItem.route)">
|
||||||
<a [routerLink]="specialMenuItem.route" [queryParams]="specialMenuItem.params"
|
<a [routerLink]="specialMenuItem.route" [queryParams]="specialMenuItem.params"
|
||||||
[queryParamsHandling]="queryParamsHandling" class="uk-flex uk-flex-center uk-flex-middle uk-flex-wrap">
|
[queryParamsHandling]="queryParamsHandling">
|
||||||
<span [class.uk-display-block]="!open" [innerHTML]="satinizeHTML(specialMenuItem.icon)"></span>
|
<div class="uk-flex uk-flex-middle uk-flex-center">
|
||||||
<span [ngClass]="specialMenuItem.customClass" class="uk-text-center"
|
<div *ngIf="specialMenuItem.icon" class="uk-width-auto">
|
||||||
[class.uk-margin-small-left]="open" [class.uk-margin-small-top]="!open"
|
<icon class="menu-icon" [customClass]="specialMenuItem.icon.class" [name]="specialMenuItem.icon.name" [svg]="specialMenuItem.icon.svg" [flex]="true"></icon>
|
||||||
[class.uk-text-small]="!open">{{specialMenuItem.title}}</span>
|
</div>
|
||||||
|
<span *ngIf="open || !specialMenuItem.icon" [class.uk-text-small]="!open" class="uk-width-expand uk-text-truncate uk-margin-small-left">{{specialMenuItem.title}}</span>
|
||||||
|
</div>
|
||||||
</a>
|
</a>
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
|
|
|
@ -6,7 +6,7 @@
|
||||||
<div *ngIf="loadActive || loadPending" class="uk-position-center">
|
<div *ngIf="loadActive || loadPending" class="uk-position-center">
|
||||||
<loading></loading>
|
<loading></loading>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-grid uk-margin-medium-bottom" uk-grid>
|
<div class="uk-grid uk-margin-medium-bottom uk-margin-top" uk-grid>
|
||||||
<div class="uk-flex uk-flex-left@m uk-flex-center uk-width-expand">
|
<div class="uk-flex uk-flex-left@m uk-flex-center uk-width-expand">
|
||||||
<ul class="uk-subnav uk-subnav-pill">
|
<ul class="uk-subnav uk-subnav-pill">
|
||||||
<li [class.uk-active]="showCurrent" (click)="showCurrent = true">
|
<li [class.uk-active]="showCurrent" (click)="showCurrent = true">
|
||||||
|
@ -17,13 +17,12 @@
|
||||||
</li>
|
</li>
|
||||||
</ul>
|
</ul>
|
||||||
</div>
|
</div>
|
||||||
<div [class.uk-invisible]="loadActive || loadPending"
|
<div class="uk-width-expand@m uk-width-1-1 uk-grid uk-flex-middle uk-flex-right@m uk-flex-center uk-margin-remove-left" uk-grid>
|
||||||
class="uk-width-auto@m uk-width-1-1 uk-grid uk-flex-middle uk-flex-right@m uk-flex-center uk-margin-remove-left" uk-grid>
|
<div *ngIf="showCurrent" [disabled]="loadActive" search-input class="uk-width-expand@l uk-width-1-1"
|
||||||
<div *ngIf="showCurrent" search-input [control]="filterForm.get('active')" [showSearch]="false" [placeholder]="'Search ' + role + 's'"
|
[searchControl]="filterForm.get('active')" [expandable]="true" [placeholder]="'Search ' + role + 's'" searchInputClass="outer">
|
||||||
[bordered]="true" colorClass="uk-text-secondary">
|
|
||||||
</div>
|
</div>
|
||||||
<div *ngIf="!showCurrent" search-input [control]="filterForm.get('active')" [showSearch]="false" [placeholder]="'Search invitations'"
|
<div *ngIf="!showCurrent" [disabled]="loadPending" search-input class="uk-width-expand@l uk-width-1-1"
|
||||||
[bordered]="true" colorClass="uk-text-secondary">
|
[searchControl]="filterForm.get('pending')" [expandable]="true" [placeholder]="'Search invitations'" searchInputClass="outer">
|
||||||
</div>
|
</div>
|
||||||
<div>
|
<div>
|
||||||
<button *ngIf="exists" class="uk-button uk-button-default uk-text-primary uk-flex uk-flex-middle" [attr.uk-tooltip]="inviteDisableMessage"
|
<button *ngIf="exists" class="uk-button uk-button-default uk-text-primary uk-flex uk-flex-middle" [attr.uk-tooltip]="inviteDisableMessage"
|
||||||
|
|
|
@ -1,3 +1,9 @@
|
||||||
|
export interface Icon {
|
||||||
|
name?: string,
|
||||||
|
svg?: string,
|
||||||
|
class?: string
|
||||||
|
}
|
||||||
|
|
||||||
export class MenuItem {
|
export class MenuItem {
|
||||||
_id: string = ""; // for root menu in order to close the dropdown when clicked
|
_id: string = ""; // for root menu in order to close the dropdown when clicked
|
||||||
title: string = "";
|
title: string = "";
|
||||||
|
@ -11,12 +17,12 @@ export class MenuItem {
|
||||||
params: any = {};
|
params: any = {};
|
||||||
fragment: string;
|
fragment: string;
|
||||||
items: MenuItem[] = [];
|
items: MenuItem[] = [];
|
||||||
icon: string;
|
icon: Icon;
|
||||||
open: boolean;
|
open: boolean;
|
||||||
customClass: string = null;
|
customClass: string = null;
|
||||||
isFeatured: boolean;
|
isFeatured: boolean;
|
||||||
|
|
||||||
constructor(id: string, title: string, url: string, route: string, needsAuthorization: boolean, entitiesRequired: string[], routeRequired: string[], params, icon=null, fragment = null, customClass = null, routeActive = null) {
|
constructor(id: string, title: string, url: string, route: string, needsAuthorization: boolean, entitiesRequired: string[], routeRequired: string[], params, icon: Icon = null, fragment = null, customClass = null, routeActive = null) {
|
||||||
this._id = id;
|
this._id = id;
|
||||||
this.title = title;
|
this.title = title;
|
||||||
this.url = url;
|
this.url = url;
|
||||||
|
|
|
@ -276,7 +276,7 @@
|
||||||
</ng-container>
|
</ng-container>
|
||||||
</a>
|
</a>
|
||||||
<a *ngIf="header.url" [href]="header.url" [class.uk-padding-remove]="!isHeaderLeft"
|
<a *ngIf="header.url" [href]="header.url" [class.uk-padding-remove]="!isHeaderLeft"
|
||||||
class="uk-logo uk-navbar-item uk-text-center uk-text-bold" [class..uk-margin-medium-left]="!mobile">
|
class="uk-logo uk-navbar-item uk-text-center uk-text-bold" [class.uk-margin-medium-left]="!mobile">
|
||||||
<img *ngIf="(mobile && header.logoSmallUrl) || (!mobile && header.logoUrl)"
|
<img *ngIf="(mobile && header.logoSmallUrl) || (!mobile && header.logoUrl)"
|
||||||
[src]="!mobile?header.logoUrl:header.logoSmallUrl"
|
[src]="!mobile?header.logoUrl:header.logoSmallUrl"
|
||||||
[alt]="header.title">
|
[alt]="header.title">
|
||||||
|
|
|
@ -16,6 +16,7 @@ import {InputComponent} from "../input/input.component";
|
||||||
@Component({
|
@Component({
|
||||||
selector: '[search-input]',
|
selector: '[search-input]',
|
||||||
template: `
|
template: `
|
||||||
|
<div *ngIf="searchControl || value" class="uk-flex uk-flex-right uk-width-1-1">
|
||||||
<div #searchInput class="search-input" [class.collapsed]="hidden" [ngClass]="searchInputClass">
|
<div #searchInput class="search-input" [class.collapsed]="hidden" [ngClass]="searchInputClass">
|
||||||
<div class="uk-flex uk-flex-middle">
|
<div class="uk-flex uk-flex-middle">
|
||||||
<div class="uk-width-expand">
|
<div class="uk-width-expand">
|
||||||
|
@ -34,6 +35,7 @@ import {InputComponent} from "../input/input.component";
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
</div>
|
||||||
`
|
`
|
||||||
})
|
})
|
||||||
export class SearchInputComponent implements OnInit {
|
export class SearchInputComponent implements OnInit {
|
||||||
|
@ -53,7 +55,7 @@ export class SearchInputComponent implements OnInit {
|
||||||
|
|
||||||
@HostListener('document:click', ['$event'])
|
@HostListener('document:click', ['$event'])
|
||||||
click(event) {
|
click(event) {
|
||||||
if(event.isTrusted && this.expandable) {
|
if(event.isTrusted && this.expandable && !this.disabled) {
|
||||||
this.expand(this.searchInput && this.searchInput.nativeElement.contains(event.target));
|
this.expand(this.searchInput && this.searchInput.nativeElement.contains(event.target));
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
@ -71,12 +73,14 @@ export class SearchInputComponent implements OnInit {
|
||||||
}
|
}
|
||||||
|
|
||||||
public search(event) {
|
public search(event) {
|
||||||
|
if(!this.disabled) {
|
||||||
if (this.expandable) {
|
if (this.expandable) {
|
||||||
this.expand(!this.expanded);
|
this.expand(!this.expanded);
|
||||||
event.stopPropagation();
|
event.stopPropagation();
|
||||||
}
|
}
|
||||||
this.searchEmitter.emit();
|
this.searchEmitter.emit();
|
||||||
}
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public reset() {
|
public reset() {
|
||||||
this.searchControl.setValue('');
|
this.searchControl.setValue('');
|
||||||
|
|
|
@ -10,17 +10,19 @@ declare var UIkit: any;
|
||||||
<div class="uk-modal-dialog uk-modal-body uk-animation-fast uk-margin-medium-bottom uk-text-left"
|
<div class="uk-modal-dialog uk-modal-body uk-animation-fast uk-margin-medium-bottom uk-text-left"
|
||||||
[ngClass]="classBody">
|
[ngClass]="classBody">
|
||||||
<div [ngClass]="classTitle" class="uk-modal-title" [hidden]=!alertHeader>
|
<div [ngClass]="classTitle" class="uk-modal-title" [hidden]=!alertHeader>
|
||||||
<button class="uk-modal-close-default uk-float-right" (click)='cancel()' uk-close></button>
|
<button class="uk-close uk-icon uk-modal-close-default uk-float-right" (click)='cancel()'>
|
||||||
<h4 class="modal-title">{{alertTitle}}</h4>
|
<icon name="close" ratio="1.5"></icon>
|
||||||
|
</button>
|
||||||
|
<h5>{{alertTitle}}</h5>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-margin">
|
<div class="uk-margin">
|
||||||
<div *ngIf="message" [hidden]=!alertMessage [innerHTML]="message | safeHtml"></div>
|
<div *ngIf="message" [hidden]=!alertMessage [innerHTML]="message | safeHtml"></div>
|
||||||
<ng-content></ng-content>
|
<ng-content></ng-content>
|
||||||
</div>
|
</div>
|
||||||
<div class="uk-grid uk-flex uk-flex-middle">
|
<div class="uk-grid uk-flex uk-flex-middle">
|
||||||
<label *ngIf="choice" class="uk-width-1-2 checkbox">
|
<label *ngIf="choice" class="uk-width-1-2">
|
||||||
<input type="checkbox" [(ngModel)]="select">
|
<input type="checkbox" [(ngModel)]="select">
|
||||||
<span class="uk-margin-small-left" style="font-weight: normal;">Don't show this message again</span>
|
<span class="uk-margin-small-left">Don't show this message again</span>
|
||||||
</label>
|
</label>
|
||||||
<div [ngClass]="(choice)?'uk-width-1-2':'uk-width-1-1'">
|
<div [ngClass]="(choice)?'uk-width-1-2':'uk-width-1-1'">
|
||||||
<div *ngIf="alertFooter" class="uk-flex-right uk-grid uk-grid-small" uk-grid>
|
<div *ngIf="alertFooter" class="uk-flex-right uk-grid uk-grid-small" uk-grid>
|
||||||
|
|
|
@ -5,9 +5,10 @@ import { FormsModule } from '@angular/forms';
|
||||||
import {AlertModal} from './alert';
|
import {AlertModal} from './alert';
|
||||||
import {ModalModule} from './modal.module';
|
import {ModalModule} from './modal.module';
|
||||||
import {SafeHtmlPipeModule} from "../pipes/safeHTMLPipe.module";
|
import {SafeHtmlPipeModule} from "../pipes/safeHTMLPipe.module";
|
||||||
|
import {IconsModule} from "../icons/icons.module";
|
||||||
|
|
||||||
@NgModule({
|
@NgModule({
|
||||||
imports: [CommonModule, FormsModule, ModalModule, SafeHtmlPipeModule],
|
imports: [CommonModule, FormsModule, ModalModule, SafeHtmlPipeModule, IconsModule],
|
||||||
declarations: [
|
declarations: [
|
||||||
AlertModal
|
AlertModal
|
||||||
],
|
],
|
||||||
|
|
Loading…
Reference in New Issue