File

C:/GoDev/src/TCSTK-Angular/projects/tibco-tcstk/tc-core-lib/src/lib/components/tibco-cloud-splash-screen/tibco-cloud-splash-screen.component.ts

Description

Splash Screen

Implements

OnInit

Example

<tc-tibco-cloud-splash-screen></tc-tibco-cloud-splash-screen>

Metadata

selector tc-tibco-cloud-splash-screen
styleUrls tibco-cloud-splash-screen.component.css
templateUrl tibco-cloud-splash-screen.component.html

Index

Properties
Inputs
Outputs
Accessors

Constructor

constructor()

Shows Application Overview like Configured

Inputs

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

Outputs

getStartedEvent
Type : EventEmitter<RouteAction>

~event getStartedEvent : Get Started Clicked ~payload string : emits that user clicked get started button on cloud splash screen

Properties

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

Accessors

TopMargin
setTopMargin(topMargin: string)
Parameters :
Name Type Optional
topMargin string No
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 {

}
Legend
Html element
Component
Html element with directive

result-matching ""

    No results matching ""