From 28db1ce35779431c79dfcece2d853735212542a7 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Yi=C4=9Fit=20FINDIKLI?= Date: Thu, 10 Dec 2020 16:28:45 +0300 Subject: [PATCH] Fixed #9639 - Avatar Component --- src/app/components/avatar/avatar.ts | 50 ++ src/app/components/avatar/ng-package.json | 6 + src/app/components/avatar/public_api.ts | 1 + .../components/avatargroup/avatargroup.css | 8 + .../avatargroup/avatargroup.spec.ts | 23 + src/app/components/avatargroup/avatargroup.ts | 26 + .../components/avatargroup/ng-package.json | 6 + src/app/components/avatargroup/public_api.ts | 1 + .../avatar/avatardemo-routing.module.ts | 15 + .../components/avatar/avatardemo.html | 559 ++++++++++++++++++ .../components/avatar/avatardemo.module.ts | 31 + .../showcase/components/avatar/avatardemo.ts | 7 + 12 files changed, 733 insertions(+) create mode 100755 src/app/components/avatar/avatar.ts create mode 100644 src/app/components/avatar/ng-package.json create mode 100644 src/app/components/avatar/public_api.ts create mode 100755 src/app/components/avatargroup/avatargroup.css create mode 100755 src/app/components/avatargroup/avatargroup.spec.ts create mode 100755 src/app/components/avatargroup/avatargroup.ts create mode 100644 src/app/components/avatargroup/ng-package.json create mode 100644 src/app/components/avatargroup/public_api.ts create mode 100755 src/app/showcase/components/avatar/avatardemo-routing.module.ts create mode 100755 src/app/showcase/components/avatar/avatardemo.html create mode 100755 src/app/showcase/components/avatar/avatardemo.module.ts create mode 100755 src/app/showcase/components/avatar/avatardemo.ts diff --git a/src/app/components/avatar/avatar.ts b/src/app/components/avatar/avatar.ts new file mode 100755 index 00000000000..760b455868a --- /dev/null +++ b/src/app/components/avatar/avatar.ts @@ -0,0 +1,50 @@ +import { NgModule, Component, ChangeDetectionStrategy, ViewEncapsulation, Input } from '@angular/core'; +import { CommonModule } from '@angular/common'; + +@Component({ + selector: 'p-avatar', + template: ` +
+ + {{label}} + + +
+ `, + changeDetection: ChangeDetectionStrategy.OnPush, + encapsulation: ViewEncapsulation.None, + styleUrls: ['./avatar.css'] +}) +export class Avatar { + + @Input() label: string; + + @Input() icon: string; + + @Input() image: string; + + @Input() size: string = "normal"; + + @Input() shape: string = "square"; + + @Input() style: any; + + @Input() styleClass: string; + + containerClass() { + return { + 'p-avatar p-component': true, + 'p-avatar-image': this.image != null, + 'p-avatar-circle': this.shape === 'circle', + 'p-avatar-lg': this.size === 'large', + 'p-avatar-xl': this.size === 'xlarge' + }; + } +} + +@NgModule({ + imports: [CommonModule], + exports: [Avatar], + declarations: [Avatar] +}) +export class AvatarModule { } diff --git a/src/app/components/avatar/ng-package.json b/src/app/components/avatar/ng-package.json new file mode 100644 index 00000000000..ab5467eb7e4 --- /dev/null +++ b/src/app/components/avatar/ng-package.json @@ -0,0 +1,6 @@ +{ + "$schema": "ng-packagr/ng-package.schema.json", + "lib": { + "entryFile": "public_api.ts" + } + } \ No newline at end of file diff --git a/src/app/components/avatar/public_api.ts b/src/app/components/avatar/public_api.ts new file mode 100644 index 00000000000..867abf58a36 --- /dev/null +++ b/src/app/components/avatar/public_api.ts @@ -0,0 +1 @@ +export * from './avatar'; \ No newline at end of file diff --git a/src/app/components/avatargroup/avatargroup.css b/src/app/components/avatargroup/avatargroup.css new file mode 100755 index 00000000000..1b0f249a1c2 --- /dev/null +++ b/src/app/components/avatargroup/avatargroup.css @@ -0,0 +1,8 @@ +.p-avatar-group p-avatar + p-avatar { + margin-left: -1rem; +} + +.p-avatar-group { + display: flex; + align-items: center; +} \ No newline at end of file diff --git a/src/app/components/avatargroup/avatargroup.spec.ts b/src/app/components/avatargroup/avatargroup.spec.ts new file mode 100755 index 00000000000..611fad10a77 --- /dev/null +++ b/src/app/components/avatargroup/avatargroup.spec.ts @@ -0,0 +1,23 @@ +import { TestBed, ComponentFixture } from '@angular/core/testing'; +import { AvatarGroup } from './avatargroup'; +import { NoopAnimationsModule } from '@angular/platform-browser/animations'; + +describe('AvatarGroup', () => { + + let button: AvatarGroup; + let fixture: ComponentFixture; + + beforeEach(() => { + TestBed.configureTestingModule({ + imports: [ + NoopAnimationsModule + ], + declarations: [ + AvatarGroup + ] + }); + + fixture = TestBed.createComponent(AvatarGroup); + button = fixture.componentInstance; + }); +}); diff --git a/src/app/components/avatargroup/avatargroup.ts b/src/app/components/avatargroup/avatargroup.ts new file mode 100755 index 00000000000..2860fa4cce8 --- /dev/null +++ b/src/app/components/avatargroup/avatargroup.ts @@ -0,0 +1,26 @@ +import { NgModule, Component, ChangeDetectionStrategy, ViewEncapsulation, Input } from '@angular/core'; +import { CommonModule } from '@angular/common'; + +@Component({ + selector: 'p-avatarGroup', + template: ` +
+ +
+ `, + changeDetection: ChangeDetectionStrategy.OnPush, + encapsulation: ViewEncapsulation.None, + styleUrls: ['./avatargroup.css'] +}) +export class AvatarGroup { + + @Input() styleClass: string; + +} + +@NgModule({ + imports: [CommonModule], + exports: [AvatarGroup], + declarations: [AvatarGroup] +}) +export class AvatarGroupModule { } diff --git a/src/app/components/avatargroup/ng-package.json b/src/app/components/avatargroup/ng-package.json new file mode 100644 index 00000000000..ab5467eb7e4 --- /dev/null +++ b/src/app/components/avatargroup/ng-package.json @@ -0,0 +1,6 @@ +{ + "$schema": "ng-packagr/ng-package.schema.json", + "lib": { + "entryFile": "public_api.ts" + } + } \ No newline at end of file diff --git a/src/app/components/avatargroup/public_api.ts b/src/app/components/avatargroup/public_api.ts new file mode 100644 index 00000000000..2b4789a5151 --- /dev/null +++ b/src/app/components/avatargroup/public_api.ts @@ -0,0 +1 @@ +export * from './avatargroup'; \ No newline at end of file diff --git a/src/app/showcase/components/avatar/avatardemo-routing.module.ts b/src/app/showcase/components/avatar/avatardemo-routing.module.ts new file mode 100755 index 00000000000..8e59bbe3edc --- /dev/null +++ b/src/app/showcase/components/avatar/avatardemo-routing.module.ts @@ -0,0 +1,15 @@ +import {NgModule} from '@angular/core'; +import {RouterModule} from '@angular/router' +import {AvatarDemo} from './avatardemo'; + +@NgModule({ + imports: [ + RouterModule.forChild([ + {path:'',component: AvatarDemo} + ]) + ], + exports: [ + RouterModule + ] +}) +export class AvatarDemoRoutingModule {} diff --git a/src/app/showcase/components/avatar/avatardemo.html b/src/app/showcase/components/avatar/avatardemo.html new file mode 100755 index 00000000000..58d4f4196e3 --- /dev/null +++ b/src/app/showcase/components/avatar/avatardemo.html @@ -0,0 +1,559 @@ +
+
+

Avatar

+

Avatar represents people using icons, labels and images.

+
+
+ +
+
+
+
+
Label
+ + + +
+
+
+
+
Label - Circle
+ + + +
+
+
+
+
Label - Badge
+ +
+
+
+
+
+
+
Icon
+ + + +
+
+
+
+
Icon - Circle
+ + + +
+
+
+
+
Icon - Badge
+ +
+
+
+
+
+
+
Image
+ + + +
+
+
+
+
Avatar Group
+ + + + + + + + +
+
+
+
+
Image - Badge
+ +
+
+
+
+ +
+ + +
Import
+ +import {AccordionModule} from 'primeng/accordion'; + + +
Getting Started
+

Accordion element consists of one or more p-accordionTab elements. Title of the tab is defined using header attribute.

+ +<p-accordion> + <p-accordionTab header="Header 1"> + Content 1 + </p-accordionTab> + <p-accordionTab header="Header 2"> + Content 2 + </p-accordionTab> + <p-accordionTab header="Header 3"> + Content 3 + </p-accordionTab> +</p-accordion> + + +
Selected
+

Visibility of the content is specified with the selected property that supports one or two-way binding.

+ +<p-accordion> + <p-accordionTab header="Header 1" [selected]="true"> + Content 1 + </p-accordionTab> + <p-accordionTab header="Header 2"> + Content 2 + </p-accordionTab> + <p-accordionTab header="Header 3"> + Content 3 + </p-accordionTab> +</p-accordion> + + +
Multiple
+

By default only one tab at a time can be active, enabling multiple property changes this behavior to allow multiple + tabs be active at the same time.

+ +<p-accordion [multiple]="true"> + <p-accordionTab header="Header 1"> + Content 1 + </p-accordionTab> + <p-accordionTab header="Header 2"> + Content 2 + </p-accordionTab> + <p-accordionTab header="Header 3"> + Content 3 + </p-accordionTab> +</p-accordion> + + +
Disabled
+

A tab can be disabled by setting the disabled property to true.

+ + +<p-accordion> + <p-accordionTab header="Header 1" [disabled]="true"> + Content 1 + </p-accordionTab> + <p-accordionTab header="Header 2"> + Content 2 + </p-accordionTab> + <p-accordionTab header="Header 3"> + Content 3 + </p-accordionTab> +</p-accordion> + + +
Custom Content at Headers
+

Custom content can be placed at an accordion header with header template.

+ + +<p-accordionTab> + <ng-template pTemplate="header">Header Content</ng-template> + <ng-template pTemplate="content">Body Content</ng-template> +</p-accordionTab> + + +
Programmatic Control
+

Tabs can be controlled programmatically using the activeIndex property of the accordion in general or the selected property of p-accordionTab individually.

+ +<h5>Programmatic</h5> +<div class="p-py-3"> + <p-button [icon]="activeState[0] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(0)" styleClass="p-button-text" label="Toggle 1st"></p-button> + <p-button [icon]="activeState[1] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(1)" styleClass="p-button-text p-ml-2" label="Toggle 2st"></p-button> + <p-button [icon]="activeState[2] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(2)" styleClass="p-button-text p-ml-2" label="Toggle 3st"></p-button> +</div> + +<p-accordion> + <p-accordionTab header="Header I" [(selected)]="activeState[0]"> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation + ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. + Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> + </p-accordionTab> + <p-accordionTab header="Header II" [(selected)]="activeState[1]"> + <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi + architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione + voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.</p> + </p-accordionTab> + <p-accordionTab header="Header III" [(selected)]="activeState[2]"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> +</p-accordion> + + + +export class AccordionDemo { + + activeState: boolean[] = [true, false, false]; + + toggle(index: number) { + this.activeState[index] = !this.activeState[index]; + } +} + + +
Lazy Loading
+

Lazy loading helps initial load performance by only initializing the active tab, inactive tabs are not initialized until they get selected. A lazy + loaded accordionTab contents are cached by default so that upon reselection, they are not created again. You may use cache property on AccordionTab to + configure this behavior. A AccordionTab is specified as lazy when there is a ngTemplate with pTemplate="content" in it.

+ +<p-accordion> + <p-accordionTab header="Header 1"> + Content 1 + </p-accordionTab> + <p-accordionTab header="Header 2"> + <ng-template pTemplate="content"> + Complex Content to Lazy Load + </ng-template> + </p-accordionTab> + <p-accordionTab header="Header 3"> + <ng-template pTemplate="content"> + Complex Content to Lazy Load + </ng-template> + </p-accordionTab> +</p-accordion> + + + +export class AccordionDemo { + + index: number = 0; + + openNext() { + this.index = (this.index === 2) ? 0 : this.index + 1; + } + + openPrev() { + this.index = (this.index === 0) ? 2 : this.index - 1; + } +} + + +
Animation Configuration
+

Transition of the toggle animation can be customized using the transitionOptions property with a default value as 400ms cubic-bezier(0.86, 0, 0.07, 1), + example below disables the animation altogether.

+ +<p-accordionTab [transitionOptions]="'0ms'" header="Header 1"> + Content +</p-accordionTab> + +
Properties for Accordion
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeDefaultDescription
multiplebooleanfalseWhen enabled, multiple tabs can be activated at the same time.
stylestringnullInline style of the component.
styleClassstringfalseStyle class of the component.
activeIndexanynullIndex of the active tab or an array of indexes to change selected tab programmatically.
expandIconstringpi pi-fw pi-chevron-rightIcon of a collapsed tab.
collapseIconstringpi pi-fw pi-chevron-downIcon of an expanded tab.
+
+ +
Properties for AccordionTab
+
+ + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + + +
NameTypeDefaultDescription
headerstringnullTitle of the tab.
selectedbooleanfalseDefines if the tab is active.
disabledbooleanfalseDefines whether the tab can be selected.
transitionOptionsstring400ms cubic-bezier(0.86, 0, 0.07, 1)Transition options of the animation.
cachebooleantrueWhether a lazy loaded panel should avoid getting loaded again on reselection.
+
+ +
Events
+
+ + + + + + + + + + + + + + + + + + + + +
NameParametersDescription
onClose + event.originalEvent: Click object
+ event.index: Index of the tab +
Callback to invoke when an active tab is collapsed by clicking on the header.
onOpen + event.originalEvent: Click object
+ event.index: Index of the tab +
Callback to invoke when a tab gets expanded.
+
+ +<p-accordion (onOpen)="onTabOpen($event)"> + + + +onTabOpen(e) { + var index = e.index; +} + + +
Styling
+

Following is the list of structural style classes, for theming classes visit theming page.

+ +
+ + + + + + + + + + + + + + + + + + + + + +
NameElement
p-accordionContainer element
p-accordion-headerHeader of a tab.
p-accordion-contentContent of a tab.
+
+ +
Dependencies
+

None.

+ +
+ + + + View on GitHub + + + Edit in StackBlitz + + +<h5>Default</h5> +<p-accordion> + <p-accordionTab header="Header I" [selected]="true"> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation + ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. + Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> + </p-accordionTab> + <p-accordionTab header="Header II"> + <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi + architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione + voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.</p> + </p-accordionTab> + <p-accordionTab header="Header III"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> +</p-accordion> + +<h5>Multiple</h5> +<p-accordion [multiple]="true"> + <p-accordionTab header="Header I"> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation + ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. + Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> + </p-accordionTab> + <p-accordionTab header="Header II"> + <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi + architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione + voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.</p> + </p-accordionTab> + <p-accordionTab header="Header III"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> +</p-accordion> + +<h5>Programmatic</h5> +<div class="p-py-3"> + <p-button [icon]="activeState[0] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(0)" styleClass="p-button-text" label="Toggle 1st"></p-button> + <p-button [icon]="activeState[1] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(1)" styleClass="p-button-text p-ml-2" label="Toggle 2st"></p-button> + <p-button [icon]="activeState[2] ? 'pi pi-minus' : 'pi pi-plus'" (click)="toggle(2)" styleClass="p-button-text p-ml-2" label="Toggle 3st"></p-button> +</div> + +<p-accordion> + <p-accordionTab header="Header I" [(selected)]="activeState[0]"> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation + ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. + Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> + </p-accordionTab> + <p-accordionTab header="Header II" [(selected)]="activeState[1]"> + <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi + architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione + voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.</p> + </p-accordionTab> + <p-accordionTab header="Header III" [(selected)]="activeState[2]"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> +</p-accordion> + +<h5>Tab Change Event</h5> +<p-accordion (onClose)="onTabClose($event)" (onOpen)="onTabOpen($event)"> + <p-accordionTab header="Header I"> + <p>Lorem ipsum dolor sit amet, consectetur adipiscing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation + ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. + Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.</p> + </p-accordionTab> + <p-accordionTab header="Header II"> + <p>Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi + architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione + voluptatem sequi nesciunt. Consectetur, adipisci velit, sed quia non numquam eius modi.</p> + </p-accordionTab> + <p-accordionTab header="Header III"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> + <p-accordionTab header="Header IV" [disabled]="true"> + <p>At vero eos et accusamus et iusto odio dignissimos ducimus qui blanditiis praesentium voluptatum deleniti atque corrupti quos dolores et quas molestias excepturi sint occaecati + cupiditate non provident, similique sunt in culpa qui officia deserunt mollitia animi, id est laborum et dolorum fuga. Et harum quidem rerum facilis est et expedita distinctio. + Nam libero tempore, cum soluta nobis est eligendi optio cumque nihil impedit quo minus.</p> + </p-accordionTab> +</p-accordion> + + + +import {Component} from '@angular/core'; +import {MessageService} from 'primeng/api'; + +@Component({ + templateUrl: './accordiondemo.html', + providers: [MessageService], + styleUrls: ['./accordiondemo.scss'] +}) +export class AccordionDemo { + + activeState: boolean[] = [true, false, false]; + + constructor(private messageService: MessageService) {} + + onTabClose(event) { + this.messageService.add({severity:'info', summary:'Tab Closed', detail: 'Index: ' + event.index}) + } + + onTabOpen(event) { + this.messageService.add({severity:'info', summary:'Tab Expanded', detail: 'Index: ' + event.index}); + } + + toggle(index: number) { + this.activeState[index] = !this.activeState[index]; + } +} + + + + + + + +
+
diff --git a/src/app/showcase/components/avatar/avatardemo.module.ts b/src/app/showcase/components/avatar/avatardemo.module.ts new file mode 100755 index 00000000000..28a40141914 --- /dev/null +++ b/src/app/showcase/components/avatar/avatardemo.module.ts @@ -0,0 +1,31 @@ +import {NgModule} from '@angular/core'; +import {CommonModule} from '@angular/common'; +import {AvatarDemo} from './avatardemo'; +import {AvatarDemoRoutingModule} from './avatardemo-routing.module'; +import {AccordionModule} from 'primeng/accordion'; +import {ButtonModule} from 'primeng/button'; +import {TabViewModule} from 'primeng/tabview'; +import {ToastModule} from 'primeng/toast'; +import { AvatarModule } from 'primeng/avatar'; +import { AvatarGroupModule } from 'primeng/avatargroup'; +import { BadgeModule } from 'primeng/badge'; +import { AppCodeModule } from '../../app.code.component'; + +@NgModule({ + imports: [ + CommonModule, + AvatarDemoRoutingModule, + AccordionModule, + ButtonModule, + TabViewModule, + ToastModule, + AvatarModule, + AvatarGroupModule, + BadgeModule, + AppCodeModule + ], + declarations: [ + AvatarDemo + ] +}) +export class AvatarDemoModule {} diff --git a/src/app/showcase/components/avatar/avatardemo.ts b/src/app/showcase/components/avatar/avatardemo.ts new file mode 100755 index 00000000000..d754d1ef90e --- /dev/null +++ b/src/app/showcase/components/avatar/avatardemo.ts @@ -0,0 +1,7 @@ +import {Component} from '@angular/core'; + +@Component({ + templateUrl: './avatardemo.html' +}) +export class AvatarDemo { +} \ No newline at end of file