import { Credentials } from '../../../shared/models/credentials.model';
import { HostService } from './services/host.service';
+Frontend components
+~~~~~~~~~~~~~~~~~~~
+
+There are several components that can be reused on different pages.
+This components are declared on the components module:
+`src/pybind/mgr/dashboard/frontend/src/app/shared/components`.
+
+Helper
+......
+
+This component should be used to provide additional information to the user.
+
+Example:
+
+.. code:: html
+
+ <cd-helper>
+ Some <strong>helper</strong> html text
+ </cd-helper>
Backend Development
-------------------
import { NgModule } from '@angular/core';
import { ChartsModule } from 'ng2-charts/ng2-charts';
-import { AlertModule } from 'ngx-bootstrap';
+import { AlertModule, PopoverModule } from 'ngx-bootstrap';
+import { HelperComponent } from './helper/helper.component';
import { SparklineComponent } from './sparkline/sparkline.component';
import { ViewCacheComponent } from './view-cache/view-cache.component';
imports: [
CommonModule,
AlertModule.forRoot(),
+ PopoverModule.forRoot(),
ChartsModule
],
declarations: [
ViewCacheComponent,
- SparklineComponent
+ SparklineComponent,
+ HelperComponent
],
providers: [],
exports: [
ViewCacheComponent,
- SparklineComponent
+ SparklineComponent,
+ HelperComponent
]
})
export class ComponentsModule { }
--- /dev/null
+<ng-template #popoverTpl>
+ <div [innerHtml]="html"></div>
+ <ng-content></ng-content>
+</ng-template>
+<i class="fa fa-question-circle"
+ aria-hidden="true"
+ [popover]="popoverTpl"
+ placement="bottom"
+ container="body"
+ [outsideClick]="true">
+</i>
--- /dev/null
+@import '../../../../defaults';
+
+i {
+ color: $oa-color-blue;
+ cursor: pointer;
+}
--- /dev/null
+import { async, ComponentFixture, TestBed } from '@angular/core/testing';
+
+import { PopoverModule } from 'ngx-bootstrap';
+
+import { HelperComponent } from './helper.component';
+
+describe('HelperComponent', () => {
+ let component: HelperComponent;
+ let fixture: ComponentFixture<HelperComponent>;
+
+ beforeEach(async(() => {
+ TestBed.configureTestingModule({
+ imports: [ PopoverModule.forRoot() ],
+ declarations: [ HelperComponent ]
+ })
+ .compileComponents();
+ }));
+
+ beforeEach(() => {
+ fixture = TestBed.createComponent(HelperComponent);
+ component = fixture.componentInstance;
+ fixture.detectChanges();
+ });
+
+ it('should create', () => {
+ expect(component).toBeTruthy();
+ });
+});
--- /dev/null
+import { Component, Input } from '@angular/core';
+
+@Component({
+ selector: 'cd-helper',
+ templateUrl: './helper.component.html',
+ styleUrls: ['./helper.component.scss']
+})
+export class HelperComponent {
+
+ @Input() html: any;
+
+ constructor() { }
+
+}
color: #d04437;
}
-/* oa-helper */
-oa-helper i {
- color: $oa-color-blue;
- cursor: pointer;
-}
-
.page-footer {
font-size: 12px;
color: #777;