C:/GoDev/src/TCSTK-Angular/projects/tibco-tcstk/tc-core-lib/src/lib/components/tibco-cloud-splash-screen/tibco-cloud-splash-screen.component.ts
Splash Screen
<tc-tibco-cloud-splash-screen></tc-tibco-cloud-splash-screen>
selector | tc-tibco-cloud-splash-screen |
styleUrls | tibco-cloud-splash-screen.component.css |
templateUrl | tibco-cloud-splash-screen.component.html |
Properties |
|
Inputs |
Outputs |
Accessors |
constructor()
|
Shows Application Overview like Configured |
actionButtons | |
Type : ActionButtonConfig[]
|
|
Buttons configuration with text and route to go. |
backGroundImage | |
Type : string
|
|
Splash Configured Background Image URL to a SVG, PNG or Jpeg |
highlights | |
Type : LandingPageItemConfig[]
|
|
Bullet Point Item Configuration with Icon's and Text |
subTitle | |
Type : string
|
|
Splash Sub-Title |
title | |
Type : string
|
|
Splash Screen main Title |
topMargin | |
Type : string
|
|
getStartedEvent | |
Type : EventEmitter<RouteAction>
|
|
~event getStartedEvent : Get Started Clicked ~payload string : emits that user clicked get started button on cloud splash screen |
getStartedClick |
Default value : () => {...}
|
Get Started Click to open the Application |
Public topMargin |
Type : string
|
Default value : '0px'
|
Space above the highlight panel. Default is 0px |
TopMargin | ||||||
setTopMargin(topMargin: string)
|
||||||
Parameters :
Returns :
void
|
import { Component, Input, OnInit, Output, EventEmitter } from '@angular/core';
import { TcCoreCommonFunctions } from '../../common/tc-core-common-functions';
import { Location } from '@angular/common';
import { LandingPageItemConfig, ActionButtonConfig } from '../../models/tc-general-landing-page-config';
import { RouteAction } from '../../models/tc-routing-actions';
/**
* Splash Screen
*
*@example <tc-tibco-cloud-splash-screen></tc-tibco-cloud-splash-screen>
*/
@Component({
selector: 'tc-tibco-cloud-splash-screen',
templateUrl: 'tibco-cloud-splash-screen.component.html',
styleUrls: ['tibco-cloud-splash-screen.component.css'],
})
export class TibcoCloudSplashScreenComponent implements OnInit {
/**
* Splash Screen main Title
*/
@Input() title: string;
/**
* Splash Sub-Title
*/
@Input() subTitle: string;
/**
* Splash Configured Background Image URL to a SVG, PNG or Jpeg
*/
@Input() backGroundImage: string;
/**
* Space above the highlight panel. Default is 0px
*/
public topMargin: string = '0px';
@Input('topMargin') set TopMargin(topMargin: string) {
if (topMargin){
this.topMargin = topMargin;
}
}
/**
* Bullet Point Item Configuration with Icon's and Text
*/
@Input() highlights: LandingPageItemConfig[];
/**
* Buttons configuration with text and route to go.
*/
@Input() actionButtons: ActionButtonConfig[];
/**
* ~event getStartedEvent : Get Started Clicked
* ~payload string : emits that user clicked get started button on cloud splash screen
*/
@Output() getStartedEvent: EventEmitter<RouteAction> = new EventEmitter<RouteAction>();
/**
* Shows Application Overview like Configured
*/
constructor() {
}
/**
* @ignore
*/
ngOnInit(): void {
console.log(this);
}
/**
* Get Started Click to open the Application
*/
getStartedClick = (route: string): void => {
this.getStartedEvent.emit(new RouteAction('buttonClicked', route));
}
}
<div class="tcs-splash-content" fxFill fxLayout="column" fxFill>
<div fxFill [ngClass]="backGroundImage ? 'custom-splash-bg' : 'default-splash-bg'" [ngStyle]="backGroundImage ? {'background-repeat': 'round', 'background-color': '#FFF', 'background-image': 'url(' + backGroundImage + ')'} : ''">
<div class="text-center" id="initscreen">
<div class="splash-heading-pane">
<div ngClass.lt-md="splash-welcome-small" ngClass.gt-sm="splash-welcome-large" class="splash-welcome">
{{title}}</div>
<div ngClass.lt-md="splash-welcome-message-small" ngClass.gt-sm="splash-welcome-message-large"
class="splash-welcome-message">
<span>{{subTitle}}</span>
</div>
</div>
<div fxLayout="column" fxLayoutAlign="start center" [ngStyle]="{'margin-top': topMargin}">
<div class="splash-modal" ngClass.lt-md="splash-modal-small" ngClass.gt-sm="splash-modal-large">
<table class="splash-highlightstable">
<tbody fxLayout="column" fxLayoutGap="30px">
<tr *ngFor="let highlight of highlights" fxLayoutAlign="start center" fxLayoutGap="30px"
fxLayout="row">
<td>
<div class="splash-oval" ngStyle.gt-sm="height: 86px; width: 86px;" fxLayout="row"
fxLayoutAlign="center center">
<mat-icon ngStyle.gt-sm="height: 50px; width: 50px;" class="splash-svg"
ngStyle.lt-md="padding: 2px;" [svgIcon]="highlight.iconURL"></mat-icon>
</div>
</td>
<td fxLayout="column" fxLayoutAlign="space-around start">
<span class="splash-highlight-item-title">{{highlight.title}}</span>
<span class="splash-highlight-item-content">{{highlight.content}}</span>
</td>
</tr>
</tbody>
</table>
<div fxLayoutGap="10px">
<button *ngFor="let actionButton of actionButtons" (click)="getStartedClick(actionButton.route)" cdkFocusInitial class="splash-get-started-button" mat-button>{{actionButton.text}}</button>
</div>
</div>
</div>
</div>
</div>
</div>
tibco-cloud-splash-screen.component.css
/*
@font-face {
font-family: Source Sans Pro;
src: url(/assets/fonts/tibco_fonts_Source_Sans_Pro_Source Sans Pro-Regular.ttf);
}
@font-face {
font-family: Source Sans ProBold;
src: url(/assets/fonts/tibco_fonts_Source_Sans_Pro_Source Sans Pro-Bold.ttf);
}*/
.splash-welcome {
font-family: Source Sans Pro;
font-weight: 300;
font-style: normal;
font-stretch: normal;
line-height: normal;
letter-spacing: 0.3px;
text-align: center;
color: #ffffff;
text-shadow: 0 2px 8px rgba(6, 46, 121, 0.5);
}
.splash-welcome-large {
font-family: Source Sans Pro;
font-size: 48px;
margin-top: 88px;
}
.splash-welcome-small {
font-family: Source Sans Pro;
font-size: 22px;
margin-top: 5px;
}
.splash-welcome-message {
font-family: Source Sans Pro;
font-weight: normal;
font-style: normal;
font-stretch: normal;
line-height: normal;
letter-spacing: 0.1px;
text-align: center;
color: #ffffff;
text-shadow: 0 2px 8px rgba(6, 46, 121, 0.5);
}
.splash-welcome-message-large {
font-size: 20px;
margin-top: 19px;
margin-bottom: 32px;
}
.splash-welcome-message-small {
font-size: 15px;
margin-top: 19px;
margin-bottom: 32px;
}
.splash-heading-pane {
margin-left: 10px;
margin-right: 10px;
}
.splash-modal {
margin: auto;
max-width: 676px;
}
.splash-modal-large {
border-radius: 10px;
box-shadow: 10px 10px 20px 0 rgba(33, 33, 33, 0.04);
background-color: #ffffff;
}
.splash-modal-small {
box-shadow: 10px 10px 20px 0 rgba(33, 33, 33, 0.04);
background-color: #ffffff;
width: 100%;
}
.splash-oval {
/* border: solid 3px #349bed; */
/* background-color: #349bed; */
border: solid 3px #c8d4e8;
border-radius: 43px;
align-content: center;
background-position: center;
background-repeat: no-repeat;
}
.splash-oval mat-icon {
}
.tcs-splash-content {
overflow: auto;
}
.splash-svg {
}
.splash-modal-small .splash-highlightstable {
border-spacing: 25px;
}
.splash-highlightstable {
border: 0;
padding-top: 3px;
padding-bottom: 0px;
border-spacing: 45px;
text-align: left;
border-collapse: separate;
}
.splash-get-started-button {
width: 117px;
height: 40px;
border-radius: 3px;
background-color: #349bed;
border: solid 1px #349bed;
margin-bottom: 58px;
font-family: Source Sans Pro;
font-size: 16px;
font-weight: 600;
font-style: normal;
font-stretch: normal;
line-height: normal;
letter-spacing: 0.3px;
text-align: center;
color: #ffffff;
}
.splash-get-started-button:hover{
border: solid 1px #74bee4;
background-color: #74bee4;
}
.splash-highlight-item-title {
font-family: Source Sans Pro;
font-size: 16px;
font-weight: bold;
font-style: normal;
font-stretch: normal;
line-height: 1.25;
letter-spacing: 0.1px;
color: #062e79;
}
.splash-modal-small .splash-highlight-item-content {
font-size: 14px;
}
.splash-highlight-item-content {
font-family: Source Sans Pro;
font-size: 16px;
font-weight: normal;
font-style: normal;
font-stretch: normal;
line-height: 1.25;
letter-spacing: 0.1px;
color: #062e79;
padding-top: 12px;
}
.default-splash-bg {
background: url("") no-repeat;
background-size: 100%;
}
.custom-splash-bg {
}