UNPKG

ngx-joyride

Version:

[![npm version](https://badge.fury.io/js/ngx-joyride.svg)](https://badge.fury.io/js/ngx-joyride) [![Build Status](https://travis-ci.org/tnicola/ngx-joyride.svg?branch=master)](https://travis-ci.org/tnicola/ngx-joyride) [![codecov](https://codecov.io/gh/

115 lines 15.8 kB
import { Injectable } from '@angular/core'; import { of, Observable } from 'rxjs'; export const DEFAULT_THEME_COLOR = '#3b5560'; export const STEP_DEFAULT_POSITION = 'bottom'; export const DEFAULT_TIMEOUT_BETWEEN_STEPS = 1; export class ObservableCustomTexts { } export const DEFAULT_TEXTS = { prev: of('prev'), next: of('next'), done: of('done'), close: of(null) }; export class JoyrideOptionsService { constructor() { this.themeColor = DEFAULT_THEME_COLOR; this.stepDefaultPosition = STEP_DEFAULT_POSITION; this.logsEnabled = false; this.showCounter = true; this.showPrevButton = true; this.stepsOrder = []; } setOptions(options) { this.stepsOrder = options.steps; this.stepDefaultPosition = options.stepDefaultPosition ? options.stepDefaultPosition : this.stepDefaultPosition; this.logsEnabled = typeof options.logsEnabled !== 'undefined' ? options.logsEnabled : this.logsEnabled; this.showCounter = typeof options.showCounter !== 'undefined' ? options.showCounter : this.showCounter; this.showPrevButton = typeof options.showPrevButton !== 'undefined' ? options.showPrevButton : this.showPrevButton; this.themeColor = options.themeColor ? options.themeColor : this.themeColor; this.firstStep = options.startWith; this.waitingTime = typeof options.waitingTime !== 'undefined' ? options.waitingTime : DEFAULT_TIMEOUT_BETWEEN_STEPS; typeof options.customTexts !== 'undefined' ? this.setCustomText(options.customTexts) : this.setCustomText(DEFAULT_TEXTS); } getBackdropColor() { return this.hexToRgb(this.themeColor); } getThemeColor() { return this.themeColor; } getStepDefaultPosition() { return this.stepDefaultPosition; } getStepsOrder() { return this.stepsOrder; } getFirstStep() { return this.firstStep; } getWaitingTime() { return this.waitingTime; } areLogsEnabled() { return this.logsEnabled; } isCounterVisible() { return this.showCounter; } isPrevButtonVisible() { return this.showPrevButton; } getCustomTexts() { return this.customTexts; } setCustomText(texts) { let prev; let next; let done; let close; prev = texts.prev ? texts.prev : DEFAULT_TEXTS.prev; next = texts.next ? texts.next : DEFAULT_TEXTS.next; done = texts.done ? texts.done : DEFAULT_TEXTS.done; close = texts.close ? texts.close : DEFAULT_TEXTS.close; this.customTexts = { prev: this.toObservable(prev), next: this.toObservable(next), done: this.toObservable(done), close: this.toObservable(close) }; } toObservable(value) { return value instanceof Observable ? value : of(value); } hexToRgb(hex) { const shorthandRegex = /^#?([a-f\d])([a-f\d])([a-f\d])$/i; hex = hex.replace(shorthandRegex, (m, r, g, b) => { return r + r + g + g + b + b; }); const result = /^#?([a-f\d]{2})([a-f\d]{2})([a-f\d]{2})$/i.exec(hex); return result ? `${parseInt(result[1], 16)}, ${parseInt(result[2], 16)}, ${parseInt(result[3], 16)}` : null; } } JoyrideOptionsService.decorators = [ { type: Injectable } ]; //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"joyride-options.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-joyride/src/lib/services/joyride-options.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { Injectable } from '@angular/core';\r\nimport {\r\n    JoyrideOptions,\r\n    CustomTexts,\r\n    ICustomTexts\r\n} from '../models/joyride-options.class';\r\nimport { of, Observable } from 'rxjs';\r\n\r\nexport const DEFAULT_THEME_COLOR = '#3b5560';\r\nexport const STEP_DEFAULT_POSITION = 'bottom';\r\nexport const DEFAULT_TIMEOUT_BETWEEN_STEPS = 1;\r\n\r\nexport class ObservableCustomTexts implements ICustomTexts {\r\n    prev: Observable<string>;\r\n    next: Observable<string>;\r\n    done: Observable<string>;\r\n    close: Observable<string>;\r\n}\r\nexport const DEFAULT_TEXTS: ObservableCustomTexts = {\r\n    prev: of('prev'),\r\n    next: of('next'),\r\n    done: of('done'),\r\n    close: of(null)\r\n};\r\n\r\nexport interface IJoyrideOptionsService {\r\n    setOptions(options: JoyrideOptions): void;\r\n    getBackdropColor(): string;\r\n    getThemeColor(): string;\r\n    getStepDefaultPosition();\r\n    getStepsOrder(): string[];\r\n    getFirstStep(): string;\r\n    getWaitingTime(): number;\r\n    areLogsEnabled(): boolean;\r\n    isCounterVisible(): boolean;\r\n    isPrevButtonVisible(): boolean;\r\n    getCustomTexts(): ObservableCustomTexts;\r\n}\r\n\r\n@Injectable()\r\nexport class JoyrideOptionsService implements IJoyrideOptionsService {\r\n    private themeColor: string = DEFAULT_THEME_COLOR;\r\n    private stepDefaultPosition: string = STEP_DEFAULT_POSITION;\r\n    private logsEnabled = false;\r\n    private showCounter = true;\r\n    private showPrevButton = true;\r\n    private stepsOrder: string[] = [];\r\n    private firstStep: string;\r\n    private waitingTime: number;\r\n    private customTexts: ObservableCustomTexts;\r\n\r\n    setOptions(options: JoyrideOptions) {\r\n        this.stepsOrder = options.steps;\r\n        this.stepDefaultPosition = options.stepDefaultPosition\r\n            ? options.stepDefaultPosition\r\n            : this.stepDefaultPosition;\r\n        this.logsEnabled =\r\n            typeof options.logsEnabled !== 'undefined'\r\n                ? options.logsEnabled\r\n                : this.logsEnabled;\r\n        this.showCounter =\r\n            typeof options.showCounter !== 'undefined'\r\n                ? options.showCounter\r\n                : this.showCounter;\r\n        this.showPrevButton =\r\n            typeof options.showPrevButton !== 'undefined'\r\n                ? options.showPrevButton\r\n                : this.showPrevButton;\r\n        this.themeColor = options.themeColor\r\n            ? options.themeColor\r\n            : this.themeColor;\r\n        this.firstStep = options.startWith;\r\n        this.waitingTime =\r\n            typeof options.waitingTime !== 'undefined'\r\n                ? options.waitingTime\r\n                : DEFAULT_TIMEOUT_BETWEEN_STEPS;\r\n        typeof options.customTexts !== 'undefined'\r\n            ? this.setCustomText(options.customTexts)\r\n            : this.setCustomText(DEFAULT_TEXTS);\r\n    }\r\n\r\n    getBackdropColor() {\r\n        return this.hexToRgb(this.themeColor);\r\n    }\r\n\r\n    getThemeColor() {\r\n        return this.themeColor;\r\n    }\r\n\r\n    getStepDefaultPosition() {\r\n        return this.stepDefaultPosition;\r\n    }\r\n\r\n    getStepsOrder() {\r\n        return this.stepsOrder;\r\n    }\r\n\r\n    getFirstStep() {\r\n        return this.firstStep;\r\n    }\r\n\r\n    getWaitingTime() {\r\n        return this.waitingTime;\r\n    }\r\n\r\n    areLogsEnabled() {\r\n        return this.logsEnabled;\r\n    }\r\n\r\n    isCounterVisible() {\r\n        return this.showCounter;\r\n    }\r\n\r\n    isPrevButtonVisible() {\r\n        return this.showPrevButton;\r\n    }\r\n\r\n    getCustomTexts(): ObservableCustomTexts {\r\n        return this.customTexts;\r\n    }\r\n\r\n    private setCustomText(texts: CustomTexts) {\r\n        let prev: string | Observable<string>;\r\n        let next: string | Observable<string>;\r\n        let done;\r\n        let close;\r\n        prev = texts.prev ? texts.prev : DEFAULT_TEXTS.prev;\r\n        next = texts.next ? texts.next : DEFAULT_TEXTS.next;\r\n        done = texts.done ? texts.done : DEFAULT_TEXTS.done;\r\n        close = texts.close ? texts.close : DEFAULT_TEXTS.close;\r\n        this.customTexts = {\r\n            prev: this.toObservable(prev),\r\n            next: this.toObservable(next),\r\n            done: this.toObservable(done),\r\n            close: this.toObservable(close)\r\n        } as ObservableCustomTexts;\r\n    }\r\n\r\n    private toObservable(value: string | Observable<string>) {\r\n        return value instanceof Observable ? value : of(value);\r\n    }\r\n\r\n    private hexToRgb(hex: any): string {\r\n        const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\r\n        hex = hex.replace(shorthandRegex, (m: any, r: any, g: any, b: any) => {\r\n            return r + r + g + g + b + b;\r\n        });\r\n\r\n        const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\r\n        return result\r\n            ? `${parseInt(result[1], 16)}, ${parseInt(\r\n                  result[2],\r\n                  16\r\n              )}, ${parseInt(result[3], 16)}`\r\n            : null;\r\n    }\r\n}\r\n"]}