【angular5项目积累总结】panel组件
view

code
panel.component.css
:host {
    display:flex;
    min-width:300px
}
panel.component.html
<header class="fxs-blade-header fxs-header fxs-blade-border fxs-trim-border fxs-trim fxs-blade-loaded">
<div class="fxs-blade-title-content">
<div class="fxs-blade-title">
<h2 class="fxs-blade-title-titleText msportalfx-tooltip-overflow" tabindex="-1">
{{headerTitle}}
</h2>
</div>
<div class="fxs-blade-actions" role="menubar" *ngIf="!disableAction">
<button type="button" role="menuitem" class="fxs-blade-collapser fxs-trim-svg fxs-trim-hover" title="Restore" (click)="minmize()" *ngIf="width=='100%'">
<svg height="100%" width="100%" aria-hidden="true" role="presentation" focusable="false">
<g xmlns="http://www.w3.org/2000/svg">
<path d="M 11 5 H 2 v 9 h 9 V 5 Z m -7 7 V 7 h 5 v 5 H 4 Z" />
<path d="M 8 6 V 3 h 5 v 5 h -3 v 2 h 5 V 1 H 6 v 5 h 2 Z" />
</g>
</svg>
</button>
<button type="button" role="menuitem" class="fxs-blade-pin fxs-trim-svg fxs-trim-hover" title="Maximize" (click)="maximize()" *ngIf="width!='100%'">
<svg height="100%" width="100%" role="presentation">
<g xmlns="http://www.w3.org/2000/svg">
<path d="M 1 2 v 12 h 14 V 2 H 1 Z m 2 10 V 6 h 10 v 6 H 3 Z" />
</g>
</svg>
</button>
<button type="button" role="menuitem" class="fxs-blade-close fxs-trim-svg" title="关闭" (click)="close()">
<svg height="100%" width="100%" role="presentation">
<g xmlns="http://www.w3.org/2000/svg">
<path d="M 14 3.3 L 12.7 2 L 8 6.7 L 3.3 2 L 2 3.3 L 6.7 8 L 2 12.7 L 3.3 14 L 8 9.3 l 4.7 4.7 l 1.3 -1.3 L 9.3 8 Z" />
</g>
</svg>
</button>
</div>
</div>
</header>
<div class="fxs-blade-content-container fxs-portal-text" [ngStyle]="{'height.px':height}">
<div class="fxs-blade-content-container-default fxs-blade-border fxs-portal-border fxs-bladecontent fxs-mode-locked fxs-blade-locked fx-rightClick fxs-bladestyle-default fxs-bladesize-small">
<div class="fxs-blade-commandBarContainer" *ngIf="menuItems.length>0">
<div class="fxs-commandBar-target fxs-portal-border fxs-portal-background fxs-portal-svg fxs-commandBar">
<ul class="fxs-commandBar-itemList" role="menubar" style="position: relative;">
<li class="fxs-commandBar-item fxs-portal-border fxs-portal-hover" *ngFor="let item of menuItems" (click)="item.event()" [title]="item.title">
<div class="fxs-commandBar-item-buttoncontainer">
<div class="fxs-commandBar-item-icon">
<svg height="100%" width="100%" role="presentation">
<use xmlns:xlink="http://www.w3.org/1999/xlink" [attr.xlink:href]="item.icon"></use>
</svg>
</div>
<div class="fxs-commandBar-item-text msportalfx-tooltip-overflow" preserveFragment="false">
{{item.title}}
</div>
</div>
</li>
</ul>
</div>
</div>
<ng-content></ng-content>
</div>
</div>
panel.component.ts
import { Component, Input, Output, EventEmitter } from '@angular/core';
@Component({
    selector: 'panel-component',
    templateUrl: './panel.component.html',
    styleUrls: ['./panel.component.css'],
    host: {
        'class': 'fxs-blade fxs-stacklayout-child fxs-blade-maximized fxs-blade-firstblade',
        '[class.whatever]': "{'fxs-blade-maximized': width=='100%'}",
        '[style.width]': 'width'
    }
})
export class PanelComponent {
    width: string;
    height: string;
    @Input()
    initWidth: string;
    @Input()
    headerTitle: string;
    @Input()
    menuItems: Array<{
        title: string,
        icon: string,
        event: string;
    }> = [];
    @Output()
    closeEvent: EventEmitter<any> = new EventEmitter();
    @Input()
    disableAction: boolean = false;
    constructor() {
    }
    ngOnInit() {
        var self = this;
        this.width = this.initWidth;
        this.height = (document.body.clientHeight - 85) + "";
        window.addEventListener("resize", function () {
            self.height = (document.body.clientHeight - 85) + "";
        });
    }
    maximize() {
        this.width = "100%";
    }
    minmize() {
        this.width = this.initWidth;
    }
    close() {
        this.closeEvent.emit();
    }
}
panel.component.module.ts
import { NgModule } from '@angular/core';
import { CommonModule } from '@angular/common';
import { PanelComponent } from './panel.component';
@NgModule({
    declarations: [
        PanelComponent,
    ],
    imports: [
        CommonModule,
    ],
    exports: [
        PanelComponent
    ]
})
export class PanelComponentModuleModule {
}
示例:
<div class="fxs-journey-target fxs-journey">
<div class="fxs-journey-layout fxs-stacklayout-horizontal fxs-stacklayout fxs-journey-withspacer">
<panel-component [menuItems]="menuItems" headerTitle="开发者中心" initWidth="600px" (closeEvent)="close()">
</panel-component>
</div>
</div>
import { Component } from '@angular/core';
import { Router } from '@angular/router';
@Component({
    selector: 'devCenter-page',
    templateUrl: './devCenter.html'
})
export class DevCenterPage {
  constructor(private router: Router) { }
    menuItems: any = [
        { title: "添加", icon: "#FxSymbol0-010", event: null },
    ]
    close() {
        this.router.navigate([''], {});
    }
}
【angular5项目积累总结】panel组件的更多相关文章
- 【angular5 项目积累总结】项目公共样式
		main.css @font-face { font-family: 'wf_segoe-ui_normal'; src: local('Segoe UI'),url('../fonts/segoe- ... 
- 【angular5项目积累总结】优秀组件以及应用实例
		1.手机端 图片预览组件 组件:sideshow 效果图:(预览图全屏 且可以左右移动) code: <div class="row ui-app-s ... 
- 【angular5项目积累总结】avatar组件
		View Code import { Component, HostListener, ElementRef } from '@angular/core'; import { Adal4Service ... 
- 【angular5项目积累总结】breadcrumb面包屑组件
		view code <div class="fxs-breadcrumb-wrapper" aria-label="Navigation history" ... 
- 【angular5项目积累总结】遇到的一些问题以及解决办法
		1.项目中字符串特别是\r\n,替换成br之后,在页面换行无法生效? 答:绑定元素 innerHTML. <div class="panel-body" [innerHTML ... 
- 【angular5项目积累总结】消息订阅服务
		code import { Injectable } from '@angular/core'; import { Subject } from 'rxjs/Subject'; @Injectable ... 
- 【angular5项目积累总结】文件上传
		<div class="form-group row"> <label class="col-sm-2 col-form-label"> ... 
- 【angular5项目积累总结】侧栏菜单 navmenu
		View Code import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/co ... 
- 【angular5项目积累总结】结合adal4实现http拦截器(token)
		import { Injectable } from '@angular/core'; import { HttpEvent, HttpInterceptor, HttpHandler, HttpRe ... 
随机推荐
- 解决ImageCropperComponent发布报错
			ng serve可以正常运行,npm run build 就会报错: ERROR in : Type ImageCropperComponent in -/node_modules/ng2-img-c ... 
- C++(指针和高级指针)-上篇
			[在指针中存储地址] int *pAge=nullptr; //将PAge声明为int指针,即用于存储int变量的地址 如果将指针初始化为0或者NUll,以后必须将变量的地址赋给它,如下例代码: ; ... 
- 了解什么是版本控制 & 用tortoiseSVN 建立本地版本库来管理自己的代码
			什么是版本控制 版本控制系统(Version Control System,简称VCS)广泛地应用于程序开发等领域,它可以协助你将某个指定的文件(甚至是一整个项目)返回至某个之前记录的状态,查看发生了 ... 
- 【12c OCP】CUUG OCP认证071考试原题解析(33)
			33.choose the best answer View the Exhibit and examine the structure of the ORDER_ITEMS table. Exami ... 
- Vue 框架   笔记
			1.兼容 2.性能优化 vuejs ******作者:尤雨溪 *** *******MVVM框架: M:model层 数据层 数据的增删改查 V:view视图层 类似于html的模板 vm:vie ... 
- Java 设计模式——单例模式
			Java有很多的设计模式,但是让我们一个个分析出来,可能就一脸蒙逼了,今天就和大家一块来分析一下Java中的一些常用的设计模式.今天先分析单例模式 单例模式的好处 举个例子:有一个类,里面有若干个公共 ... 
- 为IEnumerable类型添加Add方法
			IEnumerable类型原生是没有Add方法的,你可以用Contact方法去为它添加元素, 1 items = items.Concat(new[] { "foo" }); 也可 ... 
- jmeter ——JDBC Request中从数据库中读两个字段给接口取值
			前置条件数据库: 给接口传:tid和shopid这俩字段 直接从JDBC Request开始: Variable name:这里写入数据库连接池的名字(和JDBC Connection Configu ... 
- MySQL数据库管理
			好记性不如烂笔头 1.MySQL启动基本原理 /etc/init.d/mysqld 是一个shell启动脚本,启动后会调用mysqld_safe脚本,最后调用的是mysqld主程序启动mysql. 单 ... 
- Ubuntu下解决apt update时签名无效问题
			Ubuntu 18.04在执行apt-get update时出现一下报错: W: GPG 错误:http://repo.mysql.com/apt/ubuntu bionic InRelease: 下 ... 
