diff --git a/src/app/fuse-fake-db/faq.ts b/src/app/fuse-fake-db/faq.ts new file mode 100644 index 00000000..be28a980 --- /dev/null +++ b/src/app/fuse-fake-db/faq.ts @@ -0,0 +1,61 @@ +export class FaqFakeDb +{ + public static data = [ + { + 'question': 'Proident tempor est nulla irure ad est?', + 'answer': 'Id nulla nulla proident deserunt deserunt proident in quis. Cillum reprehenderit labore id anim laborum.' + }, + { + 'question': 'Ullamco duis commodo sint ad aliqua aute?', + 'answer': 'Sunt laborum enim nostrud ea fugiat cillum mollit aliqua exercitation ad elit.' + }, + { + 'question': 'Eiusmod non occaecat pariatur Lorem in ex?', + 'answer': 'Nostrud anim mollit incididunt qui qui sit commodo duis. Anim amet irure aliquip duis nostrud sit quis fugiat ullamco non dolor labore. Lorem sunt voluptate laboris culpa proident. Aute eiusmod aliqua exercitation irure exercitation qui laboris mollit occaecat eu occaecat fugiat.' + }, + { + 'question': 'Lorem magna cillum consequat consequat mollit?', + 'answer': 'Velit ipsum proident ea incididunt et. Consectetur eiusmod laborum voluptate duis occaecat ullamco sint enim proident.' + }, + { + 'question': 'Quis irure cupidatat ad consequat reprehenderit excepteur?', + 'answer': 'Esse nisi mollit aliquip mollit aute consequat adipisicing. Do excepteur dolore proident cupidatat pariatur irure consequat incididunt.' + }, + { + 'question': 'Officia voluptate tempor ut mollit ea cillum?', + 'answer': 'Deserunt veniam reprehenderit do elit magna ut.' + }, + { + 'question': 'Sunt fugiat officia nisi minim sunt duis?', + 'answer': 'Eiusmod eiusmod sint aliquip exercitation cillum. Magna nulla officia ex consectetur ea ad excepteur in qui.' + }, + { + 'question': 'Non cupidatat enim quis aliquip minim laborum?', + 'answer': 'Qui cillum eiusmod nostrud sunt dolore velit nostrud labore voluptate ad dolore. Eu Lorem anim pariatur aliqua. Ullamco ut dolor velit esse occaecat dolore eu cillum commodo qui. Nulla dolor consequat voluptate magna ut commodo magna consectetur non aute proident.' + }, + { + 'question': 'Dolor ex occaecat magna labore laboris qui?', + 'answer': 'Incididunt qui excepteur eiusmod elit cillum occaecat voluptate cillum nostrud. Dolor ullamco ullamco eiusmod do sunt adipisicing pariatur. In esse esse labore id reprehenderit sint do. Pariatur culpa dolor tempor qui excepteur duis do anim minim ipsum.' + }, + { + 'question': 'Nisi et ullamco minim ea proident tempor?', + 'answer': 'Dolor veniam dolor cillum Lorem magna nisi in occaecat nulla dolor ea eiusmod.' + }, + { + 'question': 'Amet sunt et quis amet commodo quis?', + 'answer': 'Nulla dolore consequat aliqua sint consequat elit qui occaecat et.' + }, + { + 'question': 'Ut eiusmod ex ea eiusmod culpa incididunt?', + 'answer': 'Fugiat non incididunt officia ex incididunt occaecat. Voluptate nostrud culpa aliquip mollit incididunt non dolore.' + }, + { + 'question': 'Proident reprehenderit laboris pariatur ut et nisi?', + 'answer': 'Reprehenderit proident ut ad cillum quis velit quis aliqua ut aliquip tempor ullamco.' + }, + { + 'question': 'Aliqua aliquip aliquip aliquip et exercitation aute?', + 'answer': 'Adipisicing Lorem tempor ex anim. Labore tempor laboris nostrud dolore voluptate ullamco. Fugiat ex deserunt anim minim esse velit laboris aute ea duis incididunt. Elit irure id Lorem incididunt laborum aliquip consectetur est irure sunt. Ut labore anim nisi aliqua tempor laborum nulla cillum. Duis irure consequat cillum magna cillum eiusmod ut. Et exercitation voluptate quis deserunt elit quis dolor deserunt ex ex esse ex.' + } + ]; +} diff --git a/src/app/fuse-fake-db/fuse-fake-db.service.ts b/src/app/fuse-fake-db/fuse-fake-db.service.ts index 4f9bbec1..84a2c09c 100644 --- a/src/app/fuse-fake-db/fuse-fake-db.service.ts +++ b/src/app/fuse-fake-db/fuse-fake-db.service.ts @@ -13,6 +13,7 @@ import { QuickPanelFakeDb } from './quick-panel'; import { IconsFakeDb } from './icons'; import { ProjectsDashboardDb } from './projects-dashboard'; import { ScrumboardFakeDb } from './scrumboard'; +import { FaqFakeDb } from './faq'; export class FuseFakeDbService implements InMemoryDbService { @@ -44,7 +45,8 @@ export class FuseFakeDbService implements InMemoryDbService 'icons' : IconsFakeDb.icons, 'projects-dashboard-projects': ProjectsDashboardDb.projects, 'projects-dashboard-widgets' : ProjectsDashboardDb.widgets, - 'scrumboard-boards' : ScrumboardFakeDb.boards + 'scrumboard-boards' : ScrumboardFakeDb.boards, + 'faq' : FaqFakeDb.data }; } } diff --git a/src/app/main/content/pages/faq/faq.component.html b/src/app/main/content/pages/faq/faq.component.html new file mode 100644 index 00000000..eea80bd4 --- /dev/null +++ b/src/app/main/content/pages/faq/faq.component.html @@ -0,0 +1,38 @@ +
+ + +
+ +
+

We're here to help

+

Frequently asked questions

+
+ + + +
+ + + +
+ + + + + + + help_outline + {{faq.question}} + + + {{faq.answer}} + + +
+ + +
diff --git a/src/app/main/content/pages/faq/faq.component.scss b/src/app/main/content/pages/faq/faq.component.scss new file mode 100644 index 00000000..131f21d7 --- /dev/null +++ b/src/app/main/content/pages/faq/faq.component.scss @@ -0,0 +1,71 @@ +@import "../../../../core/scss/fuse"; + +:host { + + .header { + height: 360px; + background: #1A237E; + background: linear-gradient(to right, #0E2A3B 0%, #34306B 100%); + + @include media-breakpoint('xs') { + height: 240px; + padding: 16px; + } + + .hero-text { + margin-bottom: 32px; + + @include media-breakpoint-down('xs') { + } + + h1 { + color: white; + font-size: 48px; + font-weight: 300; + letter-spacing: 0.01em; + text-align: center; + margin-top: 0; + margin-bottom: 16px; + + @include media-breakpoint-down('xs') { + font-size: 24px; + } + } + + h3 { + color: rgba(255, 255, 255, 0.75); + max-width: 480px; + text-align: center; + font-weight: 300; + letter-spacing: 0.03em; + margin: 0; + + @include media-breakpoint-down('xs') { + font-size: 14px; + } + } + } + + .search { + width: 100%; + max-width: 640px; + height: 56px; + line-height: 56px; + padding: 18px; + + input { + height: 56px; + padding-left: 16px; + color: rgba(0, 0, 0, 0.54); + border: none; + outline: none; + } + } + } + + .content { + max-width: 960px; + width: 100%; + margin: 0 auto; + } +} diff --git a/src/app/main/content/pages/faq/faq.component.ts b/src/app/main/content/pages/faq/faq.component.ts new file mode 100644 index 00000000..a16121d6 --- /dev/null +++ b/src/app/main/content/pages/faq/faq.component.ts @@ -0,0 +1,56 @@ +import { Component, OnInit } from '@angular/core'; +import { FormControl } from '@angular/forms'; +import { Subscription } from 'rxjs/Subscription'; +import { FaqService } from './faq.service'; +import { FuseUtils } from '../../../../core/fuseUtils'; + +@Component({ + selector : 'fuse-faq', + templateUrl: './faq.component.html', + styleUrls : ['./faq.component.scss'] +}) +export class FuseFaqComponent implements OnInit +{ + faqs: any; + faqsFiltered: any; + step = 0; + searchInput; + onFaqsChanged: Subscription; + + constructor(private faqService: FaqService) + { + this.searchInput = new FormControl(''); + } + + ngOnInit() + { + this.onFaqsChanged = + this.faqService.onFaqsChanged + .subscribe(response => { + this.faqs = response; + this.faqsFiltered = response; + }); + + this.searchInput.valueChanges + .debounceTime(300) + .distinctUntilChanged() + .subscribe(searchText => { + this.faqsFiltered = FuseUtils.filterArrayByString(this.faqs, searchText); + }); + } + + setStep(index: number) + { + this.step = index; + } + + nextStep() + { + this.step++; + } + + prevStep() + { + this.step--; + } +} diff --git a/src/app/main/content/pages/faq/faq.module.ts b/src/app/main/content/pages/faq/faq.module.ts new file mode 100644 index 00000000..b4aa1970 --- /dev/null +++ b/src/app/main/content/pages/faq/faq.module.ts @@ -0,0 +1,31 @@ +import { NgModule } from '@angular/core'; +import { SharedModule } from '../../../../core/modules/shared.module'; +import { RouterModule } from '@angular/router'; +import { FuseFaqComponent } from './faq.component'; +import { FaqService } from './faq.service'; + +const routes = [ + { + path : 'pages/faq', + component: FuseFaqComponent, + resolve : { + search: FaqService + } + } +]; + +@NgModule({ + declarations: [ + FuseFaqComponent + ], + imports : [ + SharedModule, + RouterModule.forChild(routes) + ], + providers : [ + FaqService + ] +}) +export class FaqModule +{ +} diff --git a/src/app/main/content/pages/faq/faq.service.ts b/src/app/main/content/pages/faq/faq.service.ts new file mode 100644 index 00000000..3accb335 --- /dev/null +++ b/src/app/main/content/pages/faq/faq.service.ts @@ -0,0 +1,53 @@ +import { Injectable } from '@angular/core'; +import { ActivatedRouteSnapshot, Resolve, RouterStateSnapshot } from '@angular/router'; +import { Observable } from 'rxjs/Observable'; +import { HttpClient } from '@angular/common/http'; +import { BehaviorSubject } from 'rxjs/BehaviorSubject'; + +@Injectable() +export class FaqService implements Resolve +{ + faqs: any; + + onFaqsChanged: BehaviorSubject = new BehaviorSubject({}); + + constructor(private http: HttpClient) + { + } + + /** + * Resolve + * @param {ActivatedRouteSnapshot} route + * @param {RouterStateSnapshot} state + * @returns {Observable | Promise | any} + */ + resolve(route: ActivatedRouteSnapshot, state: RouterStateSnapshot): Observable | Promise | any + { + return new Promise((resolve, reject) => { + Promise.all([ + this.getFaqs() + ]).then( + () => { + resolve(); + }, + reject + ); + }); + } + + /** + * Get faqs + */ + getFaqs(): Promise + { + return new Promise((resolve, reject) => { + + this.http.get('api/faq') + .subscribe((response: any) => { + this.faqs = response; + this.onFaqsChanged.next(this.faqs); + resolve(this.faqs); + }, reject); + }); + } +} diff --git a/src/app/main/content/pages/pages.module.ts b/src/app/main/content/pages/pages.module.ts index f7ebb757..f22a58e9 100644 --- a/src/app/main/content/pages/pages.module.ts +++ b/src/app/main/content/pages/pages.module.ts @@ -19,6 +19,7 @@ import { MaintenanceModule } from './maintenance/maintenence.module'; import { PricingModule } from './pricing/pricing.module'; import { ProfileModule } from './profile/profile.module'; import { SearchModule } from './search/search.module'; +import { FaqModule } from './faq/faq.module'; @NgModule({ imports: [ @@ -55,7 +56,10 @@ import { SearchModule } from './search/search.module'; ProfileModule, // Search - SearchModule + SearchModule, + + // Faq + FaqModule ] }) export class PagesModule diff --git a/src/app/navigation.model.ts b/src/app/navigation.model.ts index e801539d..ed9f8b9b 100644 --- a/src/app/navigation.model.ts +++ b/src/app/navigation.model.ts @@ -222,6 +222,12 @@ export class NavigationModel 'type' : 'item', 'icon' : 'search', 'url' : '/pages/search' + }, + { + 'title': 'Faq', + 'type' : 'item', + 'icon' : 'help', + 'url' : '/pages/faq' } ] },