Skip to content

Commit

Permalink
chore(release): release 15.0.0 (#302)
Browse files Browse the repository at this point in the history
Co-authored-by: huaweidevcloud <devcloudmobile@huawei.com>
  • Loading branch information
wangyaju and huaweidevcloud authored Feb 16, 2023
1 parent 94d3b7e commit dbc1ec8
Show file tree
Hide file tree
Showing 342 changed files with 5,221 additions and 2,646 deletions.
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ To see more in [devui.design](https://devui.design/home).

## Angular Support

Now supports Angular <font color=red>`^14.0.0`</font>
Now supports Angular <font color=red>`^15.0.0`</font>

## Getting Started

Expand Down
2 changes: 1 addition & 1 deletion README_zh_CN.md
Original file line number Diff line number Diff line change
Expand Up @@ -23,7 +23,7 @@ DevUI Design设计系统包含了DevUI规则、设计语言和最佳实践的资

## Angular版本

当前支持的angular版本<font color=red>`^14.0.0`</font>
当前支持的angular版本<font color=red>`^15.0.0`</font>

## 快速开始

Expand Down
288 changes: 288 additions & 0 deletions devui/accordion/accodion.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,288 @@
import { Component, DebugElement } from '@angular/core';
import { ComponentFixture, fakeAsync, TestBed, tick, waitForAsync } from '@angular/core/testing';
import { By } from '@angular/platform-browser';
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
import { Router } from '@angular/router';
import { RouterTestingModule } from '@angular/router/testing';
import { AccordionComponent } from './accordion.component';
import { AccordionModule } from './accordion.module';

@Component({
template: `
<d-accordion
[data]="menu"
class="menu"
[restrictOneOpen]="restrictOneOpen"
(itemClick)="itemClick($event)"
(menuToggle)="menuToggle($event)"
(activeItemChange)="activeItemChange($event)"
[accordionType]="accordionTypeEmbed ? 'embed' : 'normal'"
></d-accordion>
`,
})
class TestAccordionComponent {
restrictOneOpen = false;
accordionTypeEmbed = false;
menu = [
{
title: 'Content 1',
children: [{ title: 'Child Content 1' }, { title: 'Child Content 2' }, { title: 'Child Content ' }],
},
{
title: 'Content 2(This is a long sentence for option display.)',
children: [
{ title: 'Child Content 1 (This is a long sentence for option display.)' },
{ title: 'Child Content 2' },
{ title: 'Child Content 3' },
],
},
{
title: 'Content 3 (Default Open)',
open: true,
children: [
{ title: 'Child Content 1 (Disabled)', disabled: true },
{ title: 'Child Content 2 (Default Active)', active: true },
{ title: 'Child Content 3' },
],
},
{
title: 'Content 4 (No Child)',
children: [],
},
{
title: 'Content 5 (Disabled)',
disabled: true,
children: [],
},
{
title: 'Content 6 (Dynamic Content)',
needLoadChildren: true,
loading: false,
children: [],
},
];

menuToggle = jasmine.createSpy('menu toggled');

itemClick = jasmine.createSpy('item clicked');

activeItemChange = jasmine.createSpy('active item Changed');
}

@Component({
template: `
<d-accordion
[data]="menu"
class="menu"
[restrictOneOpen]="restrictOneOpen"
[accordionType]="accordionTypeEmbed ? 'embed' : 'normal'"
[itemTemplate]="itemTemplate"
[menuItemTemplate]="menuItemTemplate"
[loadingTemplate]="loadingTemplate"
></d-accordion>
<ng-template #itemTemplate let-item="item">
<div class="custom-item-template">
{{ item.title }}
</div>
<ng-template #menuItemTemplate let-item="item">
<div class="custom-menu-item-template">
{{ item.title }}
</div>
</ng-template>
<ng-template #loadingTemplate let-item="item">
<div class="custom-loading-template">Loading...</div>
</ng-template>
</ng-template>
`,
})
class TestAccordionTemplateComponent {
restrictOneOpen = false;
accordionTypeEmbed = false;
menu = [
{
title: 'Content 1',
children: [{ title: 'Child Content 1' }, { title: 'Child Content 2' }, { title: 'Child Content ' }],
},
{
title: 'Content 2(This is a long sentence for option display.)',
children: [
{ title: 'Child Content 1 (This is a long sentence for option display.)' },
{ title: 'Child Content 2' },
{ title: 'Child Content 3' },
],
},
{
title: 'Content 3 (Default Open)',
open: true,
children: [
{ title: 'Child Content 1 (Disabled)', disabled: true },
{ title: 'Child Content 2 (Default Active)', active: true },
{ title: 'Child Content 3' },
],
},
{
title: 'Content 4 (No Child)',
children: [],
},
{
title: 'Content 5 (Disabled)',
disabled: true,
children: [],
},
{
title: 'Content 6 (Dynamic Content)',
needLoadChildren: true,
loading: false,
children: [],
},
];
}

@Component({
template: ` <d-accordion [data]="menu" class="menu" [linkType]="'routerLink'"></d-accordion> `,
})
class TestAccordionLinkComponent {
constructor(private router: Router) {}
menu = [
{ title: 'Accordion', link: '/components/zh-cn/accordion', disabled: true },
{ title: 'Anchor', link: '/components/zh-cn/anchor?demo#basic' },
{ title: 'Button', link: '/components/zh-cn/button' },
];

get path() {
return this.router.url;
}
}

@Component({
template: ` <d-accordion [data]="menu" class="menu" [linkType]="'hrefLink'" [linkDefaultTarget]="'self'"></d-accordion> `,
})
class TestAccordionHrefLinkComponent {
menu = [
{ title: 'Accordion', link: '/components/zh-cn/accordion', disabled: true },
{ title: 'Anchor', link: '/components/zh-cn/anchor' },
{ title: 'Button', link: '/components/zh-cn/button' },
];
}

describe('Accordion', () => {
beforeEach(waitForAsync(() => {
TestBed.configureTestingModule({
imports: [AccordionModule, RouterTestingModule.withRoutes([]), BrowserAnimationsModule],
declarations: [TestAccordionComponent, TestAccordionLinkComponent, TestAccordionHrefLinkComponent, TestAccordionTemplateComponent],
}).compileComponents();
}));

describe('Accordion', () => {
let testComponent: TestAccordionComponent;
let accordionDebugElement: DebugElement;
let accordionNativeElement: HTMLElement;
let fixture: ComponentFixture<TestAccordionComponent>;
beforeEach(() => {
fixture = TestBed.createComponent(TestAccordionComponent);
testComponent = fixture.componentInstance;
accordionDebugElement = fixture.debugElement.query(By.directive(AccordionComponent));
accordionNativeElement = accordionDebugElement.nativeElement;
fixture.detectChanges();
});

describe('accordion default behavior', () => {
it('accordion demo has created successfully', () => {
expect(testComponent).toBeTruthy();
});

it('accordion item click', fakeAsync(() => {
const accordionItems = accordionNativeElement.querySelectorAll('.devui-accordion-item');
(accordionItems[0].querySelector('d-accordion-menu .devui-accordion-item-title') as HTMLElement).click();
fixture.detectChanges();
tick();
fixture.detectChanges();
expect(testComponent.menuToggle).toHaveBeenCalled();
expect(accordionItems[0].querySelector('.devui-accordion-item-title').classList).toContain('open');
}));

it('accordion item click', () => {
const accordionItems = accordionNativeElement.querySelectorAll('.devui-accordion-item');
(accordionItems[11].querySelector('d-accordion-item') as HTMLElement).click();
fixture.detectChanges();
expect(accordionItems[11].querySelector('.devui-accordion-item-title').classList).toContain('active');
expect(testComponent.itemClick).toHaveBeenCalled();
});
});
});

describe('Accordion Template', () => {
let testComponent: TestAccordionTemplateComponent;
let accordionDebugElement: DebugElement;
let accordionNativeElement: HTMLElement;
let fixture: ComponentFixture<TestAccordionTemplateComponent>;
beforeEach(() => {
fixture = TestBed.createComponent(TestAccordionTemplateComponent);
testComponent = fixture.componentInstance;
accordionDebugElement = fixture.debugElement.query(By.directive(AccordionComponent));
accordionNativeElement = accordionDebugElement.nativeElement;
fixture.detectChanges();
});

describe('accordion default behavior', () => {
it('accordion demo has created successfully', () => {
expect(testComponent).toBeTruthy();
});

it('accordion item custom template render correctly', () => {
const accordionItems = accordionNativeElement.querySelectorAll('.devui-accordion-item');
const customItem = accordionItems[0].querySelector('.custom-item-template');
expect(customItem).toBeTruthy();
});
});
});

describe('Accordion Link', () => {
let testComponent: TestAccordionLinkComponent;
let accordionDebugElement: DebugElement;
let accordionNativeElement: HTMLElement;
let fixture: ComponentFixture<TestAccordionLinkComponent>;
beforeEach(() => {
fixture = TestBed.createComponent(TestAccordionLinkComponent);
testComponent = fixture.componentInstance;
accordionDebugElement = fixture.debugElement.query(By.directive(AccordionComponent));
accordionNativeElement = accordionDebugElement.nativeElement;
fixture.detectChanges();
});

describe('accordion link default behavior', () => {
it('accordion link demo has created successfully', () => {
expect(testComponent).toBeTruthy();
});

it('accordion should be routerLink', () => {
const links = accordionNativeElement.querySelectorAll('d-accordion-item-routerlink');
expect(links.length).toEqual(testComponent.menu.length);
});
});
});
describe('Accordion HrefLink', () => {
let testComponent: TestAccordionHrefLinkComponent;
let accordionDebugElement: DebugElement;
let accordionNativeElement: HTMLElement;
let fixture: ComponentFixture<TestAccordionHrefLinkComponent>;
beforeEach(() => {
fixture = TestBed.createComponent(TestAccordionHrefLinkComponent);
testComponent = fixture.componentInstance;
accordionDebugElement = fixture.debugElement.query(By.directive(AccordionComponent));
accordionNativeElement = accordionDebugElement.nativeElement;
fixture.detectChanges();
});

describe('accordion link default behavior', () => {
it('accordion link demo has created successfully', () => {
expect(testComponent).toBeTruthy();
});

it('accordion should be href', () => {
const links = accordionNativeElement.querySelectorAll('d-accordion-item-hreflink');
expect(links.length).toEqual(testComponent.menu.length);
});
});
});
});
4 changes: 2 additions & 2 deletions devui/accordion/accordion.component.scss
Original file line number Diff line number Diff line change
Expand Up @@ -179,7 +179,7 @@
left: 10px;
width: 2px;
height: 40px;
background: $devui-dividing-line;
border-left: 2px solid $devui-dividing-line;
vertical-align: middle;

&.devui-parent-list {
Expand All @@ -192,7 +192,7 @@
display: block;
width: 2px;
height: 18px;
background-color: $devui-form-control-line-active;
border-left: 2px solid $devui-form-control-line-active;
position: absolute;
top: 11px;
left: 0;
Expand Down
4 changes: 2 additions & 2 deletions devui/alert/alert.spec.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@ import { AlertModule } from './alert.module';
@Component({
template: `
<d-alert [type]="type" [showIcon]= "showIcon" (closeEvent)="handleClose($event)" [cssClass]="cssClass">
<span>成功。devcloud一站式云端DevOps平台。</span>
<span>成功。消息提示成功。</span>
</d-alert>
`
})
Expand Down Expand Up @@ -58,7 +58,7 @@ describe('alert', () => {
});

it('Alert should have content', () => {
expect(alertElement.querySelector('.devui-alert').textContent).toBe('成功。devcloud一站式云端DevOps平台。');
expect(alertElement.querySelector('.devui-alert').textContent).toBe('成功。消息提示成功。');
});
});
describe('alert type', () => {
Expand Down
Loading

0 comments on commit dbc1ec8

Please sign in to comment.