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组件的更多相关文章

  1. 【angular5 项目积累总结】项目公共样式

    main.css @font-face { font-family: 'wf_segoe-ui_normal'; src: local('Segoe UI'),url('../fonts/segoe- ...

  2. 【angular5项目积累总结】优秀组件以及应用实例

    1.手机端 图片预览组件 组件:sideshow 效果图:(预览图全屏 且可以左右移动)                  code: <div class="row ui-app-s ...

  3. 【angular5项目积累总结】avatar组件

    View Code import { Component, HostListener, ElementRef } from '@angular/core'; import { Adal4Service ...

  4. 【angular5项目积累总结】breadcrumb面包屑组件

    view code <div class="fxs-breadcrumb-wrapper" aria-label="Navigation history" ...

  5. 【angular5项目积累总结】遇到的一些问题以及解决办法

    1.项目中字符串特别是\r\n,替换成br之后,在页面换行无法生效? 答:绑定元素 innerHTML. <div class="panel-body" [innerHTML ...

  6. 【angular5项目积累总结】消息订阅服务

    code import { Injectable } from '@angular/core'; import { Subject } from 'rxjs/Subject'; @Injectable ...

  7. 【angular5项目积累总结】文件上传

    <div class="form-group row"> <label class="col-sm-2 col-form-label"> ...

  8. 【angular5项目积累总结】侧栏菜单 navmenu

    View Code import { Component, OnInit } from '@angular/core'; import { HttpClient } from '@angular/co ...

  9. 【angular5项目积累总结】结合adal4实现http拦截器(token)

    import { Injectable } from '@angular/core'; import { HttpEvent, HttpInterceptor, HttpHandler, HttpRe ...

随机推荐

  1. ajax +LoadLayer插件实现访问页面跳转loading..

    布局页:第一步进行扩展ajax$(function () { $.ajax2 = function (options) {//遮罩 Mask();//jquery 原生ajax $.ajax(opti ...

  2. Ceph 基础知识和基础架构认识

    1  Ceph基础介绍 Ceph是一个可靠地.自动重均衡.自动恢复的分布式存储系统,根据场景划分可以将Ceph分为三大块,分别是对象存储.块设备存储和文件系统服务.在虚拟化领域里,比较常用到的是Cep ...

  3. 【OCP题库-12c】最新CUUG OCP 071考试题库(70题)

    70.(31-2)choose the best answer: View the Exhibit and examine the structure of the Book table. The B ...

  4. “全栈2019”Java多线程第十四章:线程与堆栈详解

    难度 初级 学习时间 10分钟 适合人群 零基础 开发语言 Java 开发环境 JDK v11 IntelliJ IDEA v2018.3 文章原文链接 "全栈2019"Java多 ...

  5. springboot 配置webservice接口

    导入依赖的jar <!-- webservice cxf --> <dependency> <groupId>org.apache.cxf</groupId& ...

  6. leetcode 198 打家劫舍 Python 动态规划

    打家劫舍 你是一个专业的小偷,计划偷窃沿街的房屋.每间房内都藏有一定的现金,影响你偷窃的唯一制约因素就是相邻的房屋装有相互连通的防盗系统,如果两间相邻的房屋在同一晚上被小偷闯入,系统会自动报警. 给定 ...

  7. 【ASP.NET Core MVC 入门须知】Net Core和Net Framework 的区别

     1.简单介绍 从上面图中我们可以看到.net  主要分为三个部分 .net FrameWork,.net Core ,Xamarin XAMARIN  主要用来构建APP的主要用的是C#语言 .NE ...

  8. leetcode-482-License Key Formatting

    题目描述: You are given a license key represented as a string S which consists only alphanumeric charact ...

  9. C#-WebForm-Request、Response、QueryString

    知识点: Request - 获取请求对象 专门用来接传递过来的值 Request["key"](李献策lxc) 1.获取地址栏传递过来的值 get 2.获取表单传递过来的参数值 ...

  10. Vue.js 动态挂载子组件

    直接来实例 父组件 <template> <div> <div :is="sub.content" :ref="sub.name" ...