From 1ea8050d9003240f173b8ef8c7c1d09ea2355ce3 Mon Sep 17 00:00:00 2001 From: Jeremy Smartt Date: Fri, 13 Jul 2018 13:27:54 -0700 Subject: [PATCH] feat(breadcrumbs): initial implementation *experimental* (#1183) * feat(breadcrumbs): Initial scaffolding for breadcrumbs * feat(breadcrumbs): Checkpoint checkin with breadcrumbs showing up * feat(breadcrumbs): code cleanup and adding graying out to last element * feat(breadcrumbs): Adding themes to experimental area. Using scss to style breadcrumbs * add to demo * feat(breadcrumbs): Responsive Breadcrumbs, removes the left-most crumb as the window shrinks * Adding sandbox area with routes to test-beds * Using ngAfterContentChecked lifecycle method * Adding title to demo * Update documentation Readme with usage * Moving tab-select into separate demo directory * Unit Tests for Breadcrumbs * Unit Tests for Breadcrumbs * chore(breadcrumbs): Update code from code review * fix(breadcrumb): Fix unit test * chore(breadcrumbs): Use Subscription.EMPTY to avoid needing null checks * chore(breadcrumbs): remove console.log * chore(): updates on README Showcase get/set methods as properties since thats how they are used * chore(breadcrumbs): remove media usage from breadcrumbs to reduce noise * fix(breadcrumbs): stop click event on the breadcrumb separator this is done because the navigation or event shouldnt be triggered in that scenario --- .../experimental/breadcrumbs/README.md | 89 ++++++++++ .../breadcrumb/_breadcrumb-theme.scss | 11 ++ .../breadcrumb/breadcrumb.component.html | 8 + .../breadcrumb/breadcrumb.component.scss | 22 +++ .../breadcrumb/breadcrumb.component.spec.ts | 0 .../breadcrumb/breadcrumb.component.ts | 72 +++++++++ .../breadcrumbs/breadcrumbs.component.html | 3 + .../breadcrumbs/breadcrumbs.component.scss | 5 + .../breadcrumbs/breadcrumbs.component.spec.ts | 106 ++++++++++++ .../breadcrumbs/breadcrumbs.component.ts | 152 ++++++++++++++++++ .../breadcrumbs/breadcrumbs.module.ts | 24 +++ .../experimental/breadcrumbs/index.ts | 1 + .../experimental/breadcrumbs/package.json | 7 + .../experimental/breadcrumbs/public-api.ts | 2 + src/platform/experimental/public-api.ts | 1 + .../experimental/theming/_all-theme.scss | 6 + src/test-bed/main/main.component.html | 10 ++ src/test-bed/main/main.component.scss | 0 src/test-bed/main/main.component.ts | 15 ++ .../breadcrumbs/breadcrumbs.component.html | 33 ++++ .../breadcrumbs/breadcrumbs.component.scss | 0 .../breadcrumbs/breadcrumbs.component.ts | 10 ++ .../tab-select/tab-select.component.html | 70 ++++++++ .../tab-select/tab-select.component.scss | 0 .../tab-select/tab-select.component.ts | 13 ++ src/test-bed/test-bed.module.ts | 24 ++- src/test-bed/test-bed.routes.ts | 28 ++++ src/test-bed/test-bed/test-bed.component.html | 71 +------- src/test-bed/test-bed/test-bed.component.ts | 3 - src/theme.scss | 2 + 30 files changed, 712 insertions(+), 76 deletions(-) create mode 100644 src/platform/experimental/breadcrumbs/README.md create mode 100644 src/platform/experimental/breadcrumbs/breadcrumb/_breadcrumb-theme.scss create mode 100644 src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.html create mode 100644 src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.scss create mode 100644 src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.spec.ts create mode 100644 src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.ts create mode 100644 src/platform/experimental/breadcrumbs/breadcrumbs.component.html create mode 100644 src/platform/experimental/breadcrumbs/breadcrumbs.component.scss create mode 100644 src/platform/experimental/breadcrumbs/breadcrumbs.component.spec.ts create mode 100644 src/platform/experimental/breadcrumbs/breadcrumbs.component.ts create mode 100644 src/platform/experimental/breadcrumbs/breadcrumbs.module.ts create mode 100644 src/platform/experimental/breadcrumbs/index.ts create mode 100644 src/platform/experimental/breadcrumbs/package.json create mode 100644 src/platform/experimental/breadcrumbs/public-api.ts create mode 100644 src/platform/experimental/theming/_all-theme.scss create mode 100644 src/test-bed/main/main.component.html create mode 100644 src/test-bed/main/main.component.scss create mode 100644 src/test-bed/main/main.component.ts create mode 100644 src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.html create mode 100644 src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.scss create mode 100644 src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.ts create mode 100644 src/test-bed/sandbox/tab-select/tab-select.component.html create mode 100644 src/test-bed/sandbox/tab-select/tab-select.component.scss create mode 100644 src/test-bed/sandbox/tab-select/tab-select.component.ts create mode 100644 src/test-bed/test-bed.routes.ts diff --git a/src/platform/experimental/breadcrumbs/README.md b/src/platform/experimental/breadcrumbs/README.md new file mode 100644 index 0000000000..87d6e6e481 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/README.md @@ -0,0 +1,89 @@ +# td-breadcrumbs (experimental) + +`td-breadcrumbs` element generates breadcrumbs for navigation. Handles Responsive by removing breadcrumbs from the beginning of the list as allowable space decreases. + +## API Summary + +#### Inputs + ++ separatorIcon?: string + + Sets the icon url shown between breadcrumbs. Defaults to right chevron. + +#### Methods + ++ count: number + + The total count of individual breadcrumbs (read only) + +#### Attributes + ++ hiddenBreadcrumbs: TdBreadcrumbComponent[] + + Array of currently hidden breadcrumbs (responsive) + +# td-breadcrumb + +`td-breadcrumb` element generates an individual breadcrumb component. + +## API Summary + +#### Methods + ++ displayCrumb: boolean + + Whether to display the individual breadcrumb or not ++ width: number + + The current width of the individual breadcrumb (read only) + +## Setup + +Import the [CovalentBreadcrumbsModule] in your NgModule: + +```typescript +import { CovalentBreadcrumbsModule } from '@covalent/experimental/breadcrumbs'; +@NgModule({ + imports: [ + CovalentBreadcrumbsModule, + ... + ], + ... +}) +export class MyModule {} +``` + +## Usage + +Basic Example: + +```html + + Home + Layouts + Layouts2 + Layouts3 + Manage List + +``` + +Example with all inputs/outputs: + +```html + + Home + Layouts + Layouts2 + Layouts3 + Manage List + + +
+ Total Breadcrumbs Count: {{breadcrumbs.count}} +
+
+ Hidden Breadcrumbs Count (shrink window to see): {{breadcrumbs.hiddenBreadcrumbs.length}} +
+ +
+

Breadcrumb Number: {{index}}

+

Breadcrumb Width: {{breadcrumb?.width}}

+ +
+
+``` diff --git a/src/platform/experimental/breadcrumbs/breadcrumb/_breadcrumb-theme.scss b/src/platform/experimental/breadcrumbs/breadcrumb/_breadcrumb-theme.scss new file mode 100644 index 0000000000..aad32dcdfa --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumb/_breadcrumb-theme.scss @@ -0,0 +1,11 @@ + +@mixin td-breadcrumb-theme($theme) { + $foreground: map-get($theme, foreground); + + td-breadcrumb { + &:last-of-type { + color: mat-color($foreground, disabled); + cursor: default; + } + } +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.html b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.html new file mode 100644 index 0000000000..a047a6281b --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.html @@ -0,0 +1,8 @@ + + + + {{separatorIcon}} + + diff --git a/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.scss b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.scss new file mode 100644 index 0000000000..870e9a32a0 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.scss @@ -0,0 +1,22 @@ +:host { + .td-breadcrumb { + height: 48px; + box-sizing: border-box; + flex-direction: row; + align-items: center; + align-content: center; + max-width: 100%; + justify-content: flex-end; + ::ng-deep > * { + margin: 0 10px; + } + } + mat-icon.material-icons.mat-icon { + display: inline-flex; + vertical-align: middle; + } + &.mat-button { + min-width: 0; + padding: 0; + } +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.spec.ts b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.spec.ts new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.ts b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.ts new file mode 100644 index 0000000000..32d6f3b01d --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumb/breadcrumb.component.ts @@ -0,0 +1,72 @@ +import { + Component, + ElementRef, + Renderer2, + HostBinding, + AfterViewInit, + ChangeDetectionStrategy, + ChangeDetectorRef, +} from '@angular/core'; + +@Component({ + selector: 'td-breadcrumb, a[td-breadcrumb]', + styleUrls: ['./breadcrumb.component.scss'], + templateUrl: './breadcrumb.component.html', + changeDetection: ChangeDetectionStrategy.OnPush, +}) +export class TdBreadcrumbComponent implements AfterViewInit { + + private _displayCrumb: boolean = true; + private _width: number = 0; + // Sets the icon url shown between breadcrumbs. Defaults to right chevron + separatorIcon: string = 'navigate_next'; + // Should show the right chevron or not before the label + _displayIcon: boolean = true; + + get displayCrumb(): boolean { + return this._displayCrumb; + } + + /** + * Whether to display the crumb or not + */ + set displayCrumb(shouldDisplay: boolean) { + this._displayCrumb = shouldDisplay; + this._changeDetectorRef.markForCheck(); + } + + /** + * Width of the DOM element of the crumb + */ + get width(): number { + return this._width; + } + + // Set the display to none on the component, just in case the end user is hiding + // and showing them instead of the component doing itself for reasons like responsive + @HostBinding('style.display') + private get displayBinding(): string { + return this._displayCrumb ? undefined : 'none'; + } + + constructor(private _elementRef: ElementRef, + private _renderer: Renderer2, + private _changeDetectorRef: ChangeDetectorRef) { + this._renderer.addClass(this._elementRef.nativeElement, 'mat-button'); + } + + ngAfterViewInit(): void { + // set the width from the actual rendered DOM element + this._width = (this._elementRef.nativeElement).getBoundingClientRect().width; + this._changeDetectorRef.markForCheck(); + } + + /** + * Stop click propagation when clicking on icon + */ + _handleIconClick(event: Event): void { + event.stopPropagation(); + event.preventDefault(); + } + +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumbs.component.html b/src/platform/experimental/breadcrumbs/breadcrumbs.component.html new file mode 100644 index 0000000000..699cfff156 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumbs.component.html @@ -0,0 +1,3 @@ +
+ +
diff --git a/src/platform/experimental/breadcrumbs/breadcrumbs.component.scss b/src/platform/experimental/breadcrumbs/breadcrumbs.component.scss new file mode 100644 index 0000000000..a5d60692ac --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumbs.component.scss @@ -0,0 +1,5 @@ +:host { + .td-breadcrumbs { + white-space: nowrap; + } +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumbs.component.spec.ts b/src/platform/experimental/breadcrumbs/breadcrumbs.component.spec.ts new file mode 100644 index 0000000000..1ba51d63f3 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumbs.component.spec.ts @@ -0,0 +1,106 @@ +import { + TestBed, + inject, + async, + ComponentFixture, +} from '@angular/core/testing'; +import { RouterTestingModule } from '@angular/router/testing'; +import { + Component, + DebugElement, +} from '@angular/core'; +import { NoopAnimationsModule } from '@angular/platform-browser/animations'; +import { By } from '@angular/platform-browser'; +import { + CovalentBreadcrumbsModule, +} from './public-api'; +import { + TdBreadcrumbsComponent, +} from './breadcrumbs.component'; + +@Component({ + selector: 'fake', + template: `
fake
`, +}) +export class FakeComponent { +} + +describe('Component: Breadcrumbs', () => { + + beforeEach(async(() => { + TestBed.configureTestingModule({ + declarations: [ + TdBreadcrumbsTestComponent, + FakeComponent, + ], + imports: [ + NoopAnimationsModule, + RouterTestingModule.withRoutes([ + { path: '', component: FakeComponent }, + { path: 'layouts', component: FakeComponent }, + { path: 'layouts2', component: FakeComponent }, + { path: 'layouts3', component: FakeComponent }, + ]), + CovalentBreadcrumbsModule, + ], + }); + TestBed.compileComponents(); + })); + + it('should render 5 Breadcrumbs', + async(inject([], () => { + let fixture: ComponentFixture = TestBed.createComponent(TdBreadcrumbsTestComponent); + fixture.detectChanges(); + fixture.whenStable().then(() => { + let breadcrumbs: TdBreadcrumbsComponent = fixture.debugElement.query(By.directive(TdBreadcrumbsComponent)).componentInstance; + expect(breadcrumbs.count).toBe(5); + }); + }), + )); + + it('should change the separatorIcon', + async(inject([], () => { + let fixture: ComponentFixture = TestBed.createComponent(TdBreadcrumbsTestComponent); + let component: TdBreadcrumbsTestComponent = fixture.debugElement.componentInstance; + component.separatorIcon = 'flight_land'; + fixture.detectChanges(); + fixture.whenStable().then(() => { + expect(fixture.debugElement.queryAll(By.css('.td-breadcrumb'))[1].nativeElement.innerHTML.indexOf('flight_land')).toBeGreaterThan(-1); + }); + }), + )); + + it('should resize window and hide breadcrumbs', + async(inject([], () => { + let fixture: ComponentFixture = TestBed.createComponent(TdBreadcrumbsTestComponent); + fixture.detectChanges(); + fixture.whenStable().then(() => { + fixture.debugElement.query(By.directive(TdBreadcrumbsComponent)).nativeElement.parentElement.style.width = '300px'; + window.dispatchEvent(new Event('resize')); + fixture.detectChanges(); + fixture.whenStable().then(() => { + let breadcrumbs: TdBreadcrumbsComponent = fixture.debugElement.query(By.directive(TdBreadcrumbsComponent)).componentInstance; + expect(breadcrumbs.hiddenBreadcrumbs.length).toBe(2); + }); + }); + }), + )); +}); + +@Component({ + selector: 'td-breadcrumbs-test', + template: ` +
+ + Home + Layouts + Layouts2 + Layouts3 + Manage List + +
+ `, +}) +class TdBreadcrumbsTestComponent { + separatorIcon: string = 'motorcycle'; +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumbs.component.ts b/src/platform/experimental/breadcrumbs/breadcrumbs.component.ts new file mode 100644 index 0000000000..123a58a040 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumbs.component.ts @@ -0,0 +1,152 @@ +import { + Component, + ContentChildren, + QueryList, + OnInit, + OnDestroy, + ChangeDetectionStrategy, + AfterContentInit, + DoCheck, + ChangeDetectorRef, + ElementRef, + Input, +} from '@angular/core'; + +import { + Subscription, + Subject, +} from 'rxjs'; +import { + debounceTime, + distinctUntilChanged, +} from 'rxjs/operators'; +import { fromEvent } from 'rxjs/observable/fromEvent'; +import { merge } from 'rxjs/observable/merge'; + +import { TdBreadcrumbComponent } from './breadcrumb/breadcrumb.component'; + +@Component({ + selector: 'td-breadcrumbs', + styleUrls: ['./breadcrumbs.component.scss'], + templateUrl: './breadcrumbs.component.html', + changeDetection: ChangeDetectionStrategy.OnPush, +}) +export class TdBreadcrumbsComponent implements OnInit, DoCheck, AfterContentInit, OnDestroy { + + private _resizeSubscription: Subscription = Subscription.EMPTY; + private _widthSubject: Subject = new Subject(); + private _resizing: boolean = false; + + // all the sub components, which are the individual breadcrumbs + @ContentChildren(TdBreadcrumbComponent) _breadcrumbs: QueryList; + // the list of hidden breadcrumbs not shown right now (responsive) + hiddenBreadcrumbs: TdBreadcrumbComponent[] = new Array(); + + /** + * Sets the icon url shown between breadcrumbs. Defaults to right chevron. + */ + @Input('separatorIcon') separatorIcon: string = 'navigate_next'; + + constructor(private _elementRef: ElementRef, private _changeDetectorRef: ChangeDetectorRef) { } + + ngOnInit(): void { + this._resizeSubscription = merge( + fromEvent(window, 'resize').pipe( + debounceTime(10), + ), + this._widthSubject.asObservable().pipe( + distinctUntilChanged(), + ), + ).subscribe(() => { + if (!this._resizing) { + this._resizing = true; + setTimeout(() => { + this.displayWidthAvailableCrumbs(); + this._resizing = false; + this._changeDetectorRef.markForCheck(); + }, 100); + } + }); + } + + ngDoCheck(): void { + if (this._elementRef && this._elementRef.nativeElement) { + this._widthSubject.next(this.nativeElementWidth); + } + } + + ngAfterContentInit(): void { + this.setCrumbIcons(); + this._changeDetectorRef.markForCheck(); + } + + ngOnDestroy(): void { + this._resizeSubscription.unsubscribe(); + } + + /* + * Current width of the element container + */ + get nativeElementWidth(): number { + return (this._elementRef.nativeElement).getBoundingClientRect().width; + } + + /** + * The total count of individual breadcrumbs + */ + get count(): number { + return this._breadcrumbs ? this._breadcrumbs.length : 0; + } + + /** + * Set the crumb icon separators + */ + private setCrumbIcons(): void { + let breadcrumbArray: TdBreadcrumbComponent[] = this._breadcrumbs.toArray(); + if (breadcrumbArray.length > 0) { + // don't show the icon on the last breadcrumb + breadcrumbArray[breadcrumbArray.length - 1]._displayIcon = false; + } + breadcrumbArray.forEach((breadcrumb: TdBreadcrumbComponent) => { + breadcrumb.separatorIcon = this.separatorIcon; + }); + } + + private displayWidthAvailableCrumbs(): void { + let curTotCrumbWidth: number = 0; + let crumbsArray: TdBreadcrumbComponent[] = this._breadcrumbs.toArray(); + // calculate the current width of the shown breadcrumbs + for (let i: number = this.hiddenBreadcrumbs.length; i < crumbsArray.length; i++) { + curTotCrumbWidth += crumbsArray[i].width; + } + // hide the first bread crumb if window size is smaller than all the crumb sizes + if (this.nativeElementWidth < curTotCrumbWidth) { + crumbsArray[this.hiddenBreadcrumbs.length].displayCrumb = false; + this.hiddenBreadcrumbs.push(crumbsArray[this.hiddenBreadcrumbs.length]); + this.displayWidthAvailableCrumbs(); + } else { + // loop over all the hidden crumbs and see if adding them back in will + // fit in the current window size + let totalHidden: number = this.hiddenBreadcrumbs.length - 1; + for (let i: number = totalHidden; i >= 0; i--) { + let hiddenCrumbWidth: number = crumbsArray[i].width; + if ((curTotCrumbWidth + hiddenCrumbWidth) < this.nativeElementWidth) { + crumbsArray[i].displayCrumb = true; + crumbsArray[i + 1]._displayIcon = true; + this.hiddenBreadcrumbs.pop(); + // recalculate the total width based on adding back in a crumb + let newTotCrumbWidth: number = 0; + for (let j: number = this.hiddenBreadcrumbs.length; j < crumbsArray.length; j++) { + newTotCrumbWidth += crumbsArray[j].width; + } + curTotCrumbWidth = newTotCrumbWidth; + } else if (i === totalHidden) { + // need to break out of loop here because the first in the hidden + // list can't fit in current window size + break; + } + } + } + } + +} diff --git a/src/platform/experimental/breadcrumbs/breadcrumbs.module.ts b/src/platform/experimental/breadcrumbs/breadcrumbs.module.ts new file mode 100644 index 0000000000..39d73f8b06 --- /dev/null +++ b/src/platform/experimental/breadcrumbs/breadcrumbs.module.ts @@ -0,0 +1,24 @@ +import { NgModule } from '@angular/core'; +import { CommonModule } from '@angular/common'; +import { MatIconModule } from '@angular/material/icon'; + +import { TdBreadcrumbsComponent } from './breadcrumbs.component'; +import { TdBreadcrumbComponent } from './breadcrumb/breadcrumb.component'; + +@NgModule({ + imports: [ + CommonModule, + MatIconModule, + ], + declarations: [ + TdBreadcrumbsComponent, + TdBreadcrumbComponent, + ], + exports: [ + TdBreadcrumbsComponent, + TdBreadcrumbComponent, + ], +}) +export class CovalentBreadcrumbsModule { + +} diff --git a/src/platform/experimental/breadcrumbs/index.ts b/src/platform/experimental/breadcrumbs/index.ts new file mode 100644 index 0000000000..7e1a213e3e --- /dev/null +++ b/src/platform/experimental/breadcrumbs/index.ts @@ -0,0 +1 @@ +export * from './public-api'; diff --git a/src/platform/experimental/breadcrumbs/package.json b/src/platform/experimental/breadcrumbs/package.json new file mode 100644 index 0000000000..dedb72ce9c --- /dev/null +++ b/src/platform/experimental/breadcrumbs/package.json @@ -0,0 +1,7 @@ +{ + "ngPackage": { + "lib": { + "entryFile": "index.ts" + } + } +} diff --git a/src/platform/experimental/breadcrumbs/public-api.ts b/src/platform/experimental/breadcrumbs/public-api.ts new file mode 100644 index 0000000000..fe571da45b --- /dev/null +++ b/src/platform/experimental/breadcrumbs/public-api.ts @@ -0,0 +1,2 @@ +export * from './breadcrumbs.module'; +export * from './breadcrumbs.component'; diff --git a/src/platform/experimental/public-api.ts b/src/platform/experimental/public-api.ts index 1012583450..b53d64cff2 100644 --- a/src/platform/experimental/public-api.ts +++ b/src/platform/experimental/public-api.ts @@ -1,2 +1,3 @@ export * from './template-rename-me-experiment-module/index'; +export * from './breadcrumbs/index'; export * from './tab-select/index'; diff --git a/src/platform/experimental/theming/_all-theme.scss b/src/platform/experimental/theming/_all-theme.scss new file mode 100644 index 0000000000..0546bc1409 --- /dev/null +++ b/src/platform/experimental/theming/_all-theme.scss @@ -0,0 +1,6 @@ +@import '../breadcrumbs/breadcrumb/breadcrumb-theme'; + +// Create a theme. +@mixin experimental-theme($theme, $config: null) { + @include td-breadcrumb-theme($theme); +} diff --git a/src/test-bed/main/main.component.html b/src/test-bed/main/main.component.html new file mode 100644 index 0000000000..3da35dd5f8 --- /dev/null +++ b/src/test-bed/main/main.component.html @@ -0,0 +1,10 @@ +

Test Bed

+ +

Sandbox Links:

+ + + \ No newline at end of file diff --git a/src/test-bed/main/main.component.scss b/src/test-bed/main/main.component.scss new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/test-bed/main/main.component.ts b/src/test-bed/main/main.component.ts new file mode 100644 index 0000000000..071074d134 --- /dev/null +++ b/src/test-bed/main/main.component.ts @@ -0,0 +1,15 @@ +/* + * Copyright (C) 2016-2018 by Teradata Corporation. All rights reserved. + * TERADATA CORPORATION CONFIDENTIAL AND TRADE SECRET + */ + +import { Component } from '@angular/core'; + +@Component({ + selector: 'testbed-main', + templateUrl: './main.component.html', + styleUrls: ['./main.component.scss'], +}) +export class MainComponent { + +} diff --git a/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.html b/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.html new file mode 100644 index 0000000000..0fa8001947 --- /dev/null +++ b/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.html @@ -0,0 +1,33 @@ +
+

Breadcrumbs

+

Basic Breadcrumbs

+ + Home + Layouts + Layouts2 + Layouts3 + Manage List + + +

Breadcrumbs with all inputs/outputs

+ + Home + Layouts + Layouts2 + Layouts3 + Manage List + +
+ Total Breadcrumbs Count: {{breadcrumbs.count}} +
+
+ Hidden Breadcrumbs Count (shrink window to see): {{breadcrumbs.hiddenBreadcrumbs.length}} +
+ +
+

Breadcrumb Index: {{index}}

+

Breadcrumb Width: {{breadcrumb?.width}}

+ +
+
+
\ No newline at end of file diff --git a/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.scss b/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.scss new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.ts b/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.ts new file mode 100644 index 0000000000..21e923b846 --- /dev/null +++ b/src/test-bed/sandbox/breadcrumbs/breadcrumbs.component.ts @@ -0,0 +1,10 @@ +import { Component } from '@angular/core'; + +@Component({ + selector: 'breadcrumbs-demo', + styleUrls: [ './breadcrumbs.component.scss' ], + templateUrl: './breadcrumbs.component.html', +}) +export class BreadcrumbDemoComponent { + +} diff --git a/src/test-bed/sandbox/tab-select/tab-select.component.html b/src/test-bed/sandbox/tab-select/tab-select.component.html new file mode 100644 index 0000000000..a931d46a32 --- /dev/null +++ b/src/test-bed/sandbox/tab-select/tab-select.component.html @@ -0,0 +1,70 @@ +
+

Tab Select

+

Default with accent color with a disabled tab

+ + + MY LABEL + + + MY LABEL 2 + + + MY LABEL 3 + + +

value: {{tabSelect.value}}

+ +

Value usage with primary backgroundColor

+ + + MY LABEL + + + MY LABEL 2 + + + MY LABEL 3 + + +

value: {{value}}

+ +

Forms Usage

+ + + MY LABEL + + + MY LABEL 2 + + + MY LABEL 3 + + +

value: {{formValue}}

+ +

Disabled tabs

+ + + MY LABEL + + + MY LABEL 2 + + + MY LABEL 3 + + + +

Stretched and disabled ripple on tabs

+ + + MY LABEL + + + MY LABEL 2 + + + MY LABEL 3 + + +
\ No newline at end of file diff --git a/src/test-bed/sandbox/tab-select/tab-select.component.scss b/src/test-bed/sandbox/tab-select/tab-select.component.scss new file mode 100644 index 0000000000..e69de29bb2 diff --git a/src/test-bed/sandbox/tab-select/tab-select.component.ts b/src/test-bed/sandbox/tab-select/tab-select.component.ts new file mode 100644 index 0000000000..1eceb7f807 --- /dev/null +++ b/src/test-bed/sandbox/tab-select/tab-select.component.ts @@ -0,0 +1,13 @@ +import { Component } from '@angular/core'; + +@Component({ + selector: 'tab-select-demo', + styleUrls: [ './tab-select.component.scss' ], + templateUrl: './tab-select.component.html', +}) +export class TabSelectDemoComponent { + + value: string = 'test3'; + formValue: string = 'test2'; + +} diff --git a/src/test-bed/test-bed.module.ts b/src/test-bed/test-bed.module.ts index b046320ed1..3ae043d744 100644 --- a/src/test-bed/test-bed.module.ts +++ b/src/test-bed/test-bed.module.ts @@ -3,19 +3,37 @@ import { CommonModule } from '@angular/common'; import { FormsModule } from '@angular/forms'; import { BrowserModule } from '@angular/platform-browser'; import { BrowserAnimationsModule } from '@angular/platform-browser/animations'; +import { MatDividerModule } from '@angular/material/divider'; -import { TestBedComponent } from './test-bed/test-bed.component'; - +import { CovalentBreadcrumbsModule } from '../platform/experimental/breadcrumbs/breadcrumbs.module'; import { CovalentTabSelectModule } from '../platform/experimental/tab-select'; +import { TestBedComponent } from './test-bed/test-bed.component'; +import { MainComponent } from './main/main.component'; +import { BreadcrumbDemoComponent } from './sandbox/breadcrumbs/breadcrumbs.component'; +import { TabSelectDemoComponent } from './sandbox/tab-select/tab-select.component'; +import { appRoutes, appRoutingProviders } from './test-bed.routes'; + @NgModule({ - declarations: [TestBedComponent], + declarations: [ + TestBedComponent, + BreadcrumbDemoComponent, + TabSelectDemoComponent, + MainComponent, + ], imports: [ BrowserModule, CommonModule, BrowserAnimationsModule, FormsModule, + MatDividerModule, + appRoutes, /** Experimental Modules */ + CovalentBreadcrumbsModule, + CovalentTabSelectModule, + ], // modules needed to run this module + providers: [ + appRoutingProviders, CovalentTabSelectModule, ], bootstrap: [TestBedComponent], diff --git a/src/test-bed/test-bed.routes.ts b/src/test-bed/test-bed.routes.ts new file mode 100644 index 0000000000..e21469470e --- /dev/null +++ b/src/test-bed/test-bed.routes.ts @@ -0,0 +1,28 @@ +import { Routes, RouterModule } from '@angular/router'; + +import { BreadcrumbDemoComponent } from './sandbox/breadcrumbs/breadcrumbs.component'; +import { TabSelectDemoComponent } from './sandbox/tab-select/tab-select.component'; +import { MainComponent } from './main/main.component'; + +const routes: Routes = [ + { + component: MainComponent, + path: '', + }, + { + component: BreadcrumbDemoComponent, + path: 'breadcrumbs', + }, + { + component: TabSelectDemoComponent, + path: 'tabselect', + }, +]; + +export const appRoutingProviders: any[] = [ + +]; + +export const appRoutes: any = RouterModule.forRoot(routes, { + useHash: true, +}); diff --git a/src/test-bed/test-bed/test-bed.component.html b/src/test-bed/test-bed/test-bed.component.html index a931d46a32..0680b43f9c 100644 --- a/src/test-bed/test-bed/test-bed.component.html +++ b/src/test-bed/test-bed/test-bed.component.html @@ -1,70 +1 @@ -
-

Tab Select

-

Default with accent color with a disabled tab

- - - MY LABEL - - - MY LABEL 2 - - - MY LABEL 3 - - -

value: {{tabSelect.value}}

- -

Value usage with primary backgroundColor

- - - MY LABEL - - - MY LABEL 2 - - - MY LABEL 3 - - -

value: {{value}}

- -

Forms Usage

- - - MY LABEL - - - MY LABEL 2 - - - MY LABEL 3 - - -

value: {{formValue}}

- -

Disabled tabs

- - - MY LABEL - - - MY LABEL 2 - - - MY LABEL 3 - - - -

Stretched and disabled ripple on tabs

- - - MY LABEL - - - MY LABEL 2 - - - MY LABEL 3 - - -
\ No newline at end of file + diff --git a/src/test-bed/test-bed/test-bed.component.ts b/src/test-bed/test-bed/test-bed.component.ts index 03792bfc5f..c79d0c5d59 100644 --- a/src/test-bed/test-bed/test-bed.component.ts +++ b/src/test-bed/test-bed/test-bed.component.ts @@ -7,7 +7,4 @@ import { Component } from '@angular/core'; }) export class TestBedComponent { - value: string = 'test3'; - formValue: string = 'test2'; - } diff --git a/src/theme.scss b/src/theme.scss index ee6a713f00..5e7824749a 100644 --- a/src/theme.scss +++ b/src/theme.scss @@ -1,5 +1,6 @@ @import '~@angular/material/theming'; @import './platform/core/theming/all-theme'; +@import './platform/experimental/theming/all-theme'; @import './platform/markdown/markdown-theme'; @import './platform/highlight/highlight-theme'; // Plus imports for other components in your app. @@ -86,6 +87,7 @@ $theme: mat-light-theme($primary, $accent, $warn); // that you are using. @include angular-material-theme($theme); @include covalent-theme($theme); +@include experimental-theme($theme); @include covalent-markdown-theme($theme); @include covalent-highlight-theme(); // OR @import '~highlight.js/styles/vs.css';