ngx-joyride
Version:
An Angular Tour (Joyride) library built entirely in Angular, without using any heavy external dependencies like Bootstrap or JQuery. From now on you can easily guide your users through your site showing them all the sections and features.
118 lines • 15.8 kB
JavaScript
import { Injectable } from '@angular/core';
import { of, Observable } from 'rxjs';
import * as i0 from "@angular/core";
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.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: JoyrideOptionsService, deps: [], target: i0.ɵɵFactoryTarget.Injectable });
JoyrideOptionsService.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: JoyrideOptionsService });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "13.1.1", ngImport: i0, type: 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';\nimport {\n    JoyrideOptions,\n    CustomTexts,\n    ICustomTexts\n} from '../models/joyride-options.class';\nimport { of, Observable } from 'rxjs';\n\nexport const DEFAULT_THEME_COLOR = '#3b5560';\nexport const STEP_DEFAULT_POSITION = 'bottom';\nexport const DEFAULT_TIMEOUT_BETWEEN_STEPS = 1;\n\nexport class ObservableCustomTexts implements ICustomTexts {\n    prev: Observable<string>;\n    next: Observable<string>;\n    done: Observable<string>;\n    close: Observable<string>;\n}\nexport const DEFAULT_TEXTS: ObservableCustomTexts = {\n    prev: of('prev'),\n    next: of('next'),\n    done: of('done'),\n    close: of(null)\n};\n\nexport interface IJoyrideOptionsService {\n    setOptions(options: JoyrideOptions): void;\n    getBackdropColor(): string;\n    getThemeColor(): string;\n    getStepDefaultPosition();\n    getStepsOrder(): string[];\n    getFirstStep(): string;\n    getWaitingTime(): number;\n    areLogsEnabled(): boolean;\n    isCounterVisible(): boolean;\n    isPrevButtonVisible(): boolean;\n    getCustomTexts(): ObservableCustomTexts;\n}\n\n@Injectable()\nexport class JoyrideOptionsService implements IJoyrideOptionsService {\n    private themeColor: string = DEFAULT_THEME_COLOR;\n    private stepDefaultPosition: string = STEP_DEFAULT_POSITION;\n    private logsEnabled = false;\n    private showCounter = true;\n    private showPrevButton = true;\n    private stepsOrder: string[] = [];\n    private firstStep: string;\n    private waitingTime: number;\n    private customTexts: ObservableCustomTexts;\n\n    setOptions(options: JoyrideOptions) {\n        this.stepsOrder = options.steps;\n        this.stepDefaultPosition = options.stepDefaultPosition\n            ? options.stepDefaultPosition\n            : this.stepDefaultPosition;\n        this.logsEnabled =\n            typeof options.logsEnabled !== 'undefined'\n                ? options.logsEnabled\n                : this.logsEnabled;\n        this.showCounter =\n            typeof options.showCounter !== 'undefined'\n                ? options.showCounter\n                : this.showCounter;\n        this.showPrevButton =\n            typeof options.showPrevButton !== 'undefined'\n                ? options.showPrevButton\n                : this.showPrevButton;\n        this.themeColor = options.themeColor\n            ? options.themeColor\n            : this.themeColor;\n        this.firstStep = options.startWith;\n        this.waitingTime =\n            typeof options.waitingTime !== 'undefined'\n                ? options.waitingTime\n                : DEFAULT_TIMEOUT_BETWEEN_STEPS;\n        typeof options.customTexts !== 'undefined'\n            ? this.setCustomText(options.customTexts)\n            : this.setCustomText(DEFAULT_TEXTS);\n    }\n\n    getBackdropColor() {\n        return this.hexToRgb(this.themeColor);\n    }\n\n    getThemeColor() {\n        return this.themeColor;\n    }\n\n    getStepDefaultPosition() {\n        return this.stepDefaultPosition;\n    }\n\n    getStepsOrder() {\n        return this.stepsOrder;\n    }\n\n    getFirstStep() {\n        return this.firstStep;\n    }\n\n    getWaitingTime() {\n        return this.waitingTime;\n    }\n\n    areLogsEnabled() {\n        return this.logsEnabled;\n    }\n\n    isCounterVisible() {\n        return this.showCounter;\n    }\n\n    isPrevButtonVisible() {\n        return this.showPrevButton;\n    }\n\n    getCustomTexts(): ObservableCustomTexts {\n        return this.customTexts;\n    }\n\n    private setCustomText(texts: CustomTexts) {\n        let prev: string | Observable<string>;\n        let next: string | Observable<string>;\n        let done;\n        let close;\n        prev = texts.prev ? texts.prev : DEFAULT_TEXTS.prev;\n        next = texts.next ? texts.next : DEFAULT_TEXTS.next;\n        done = texts.done ? texts.done : DEFAULT_TEXTS.done;\n        close = texts.close ? texts.close : DEFAULT_TEXTS.close;\n        this.customTexts = {\n            prev: this.toObservable(prev),\n            next: this.toObservable(next),\n            done: this.toObservable(done),\n            close: this.toObservable(close)\n        } as ObservableCustomTexts;\n    }\n\n    private toObservable(value: string | Observable<string>) {\n        return value instanceof Observable ? value : of(value);\n    }\n\n    private hexToRgb(hex: any): string {\n        const shorthandRegex = /^#?([a-f\\d])([a-f\\d])([a-f\\d])$/i;\n        hex = hex.replace(shorthandRegex, (m: any, r: any, g: any, b: any) => {\n            return r + r + g + g + b + b;\n        });\n\n        const result = /^#?([a-f\\d]{2})([a-f\\d]{2})([a-f\\d]{2})$/i.exec(hex);\n        return result\n            ? `${parseInt(result[1], 16)}, ${parseInt(\n                  result[2],\n                  16\n              )}, ${parseInt(result[3], 16)}`\n            : null;\n    }\n}\n"]}