@alauda-fe/common
Version:
Alauda frontend team common codes.
78 lines • 11.6 kB
JavaScript
import { DialogService } from '@alauda/ui';
import { Location } from '@angular/common';
import { Injectable } from '@angular/core';
import { NavigationEnd, Router } from '@angular/router';
import { Subject, filter, takeUntil, from, map } from 'rxjs';
import { TranslateService } from '../../translate/public-api';
import { CURR_ESCAPE_DEACTIVATE_GUARD, ESCAPE_DEACTIVATE_GUARD, } from '../guards/intercept-deactivate.guard';
import { skipError } from '../utils/operators';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
import * as i2 from "@angular/router";
import * as i3 from "@alauda/ui";
import * as i4 from "../../translate/public-api";
export class InterceptDeactivateService {
constructor(location, router, dialog, translate) {
this.location = location;
this.router = router;
this.dialog = dialog;
this.translate = translate;
this.destroy$$ = new Subject();
this.router.events
.pipe(filter(ev => ev instanceof NavigationEnd), takeUntil(this.destroy$$))
.subscribe(() => {
const url = new URL(this.location.path(true), window.location.href);
if (url.hash === '#' + ESCAPE_DEACTIVATE_GUARD ||
url.hash === '#' + CURR_ESCAPE_DEACTIVATE_GUARD) {
this.location.replaceState(url.pathname, url.search.slice(1));
}
});
}
ngOnDestroy() {
this.destroy$$.next();
this.destroy$$.complete();
}
intercept({ title, content, context, errorFallback, } = {}) {
return from(this.dialog.confirm({
title: this.translate.get(title || 'intercept_deactivate_title', context),
content: this.translate.get(content || 'intercept_deactivate_content', context),
confirmText: this.translate.get('confirm'),
cancelText: this.translate.get('cancel'),
})).pipe(map(() => true), skipError(errorFallback));
}
async back(escape) {
if (escape) {
await this.escape();
}
this.location.back();
}
async forward(escape) {
if (escape) {
await this.escape();
}
this.location.forward();
}
searchParamsToQueryParams(searchParams) {
const queryParams = {};
searchParams.forEach((_value, key) => {
const values = searchParams.getAll(key);
queryParams[key] = values.length <= 1 ? values[0] : values;
});
return queryParams;
}
async escape() {
const url = new URL(this.location.path(), location.href);
await this.router.navigate([url.pathname], {
replaceUrl: true,
fragment: CURR_ESCAPE_DEACTIVATE_GUARD,
queryParams: this.searchParamsToQueryParams(url.searchParams),
});
}
static { this.ɵfac = function InterceptDeactivateService_Factory(t) { return new (t || InterceptDeactivateService)(i0.ɵɵinject(i1.Location), i0.ɵɵinject(i2.Router), i0.ɵɵinject(i3.DialogService), i0.ɵɵinject(i4.TranslateService)); }; }
static { this.ɵprov = /*@__PURE__*/ i0.ɵɵdefineInjectable({ token: InterceptDeactivateService, factory: InterceptDeactivateService.ɵfac, providedIn: 'root' }); }
}
(() => { (typeof ngDevMode === "undefined" || ngDevMode) && i0.ɵsetClassMetadata(InterceptDeactivateService, [{
type: Injectable,
args: [{ providedIn: 'root' }]
}], () => [{ type: i1.Location }, { type: i2.Router }, { type: i3.DialogService }, { type: i4.TranslateService }], null); })();
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"intercept-deactivate.service.js","sourceRoot":"","sources":["../../../../../../libs/common/src/core/services/intercept-deactivate.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { DialogService } from '@alauda/ui';\nimport { Location } from '@angular/common';\nimport { Injectable, OnDestroy } from '@angular/core';\nimport { NavigationEnd, Router } from '@angular/router';\nimport { Subject, filter, takeUntil, from, map } from 'rxjs';\n\nimport { TranslateService, TemplateData } from '../../translate/public-api';\nimport {\n  CURR_ESCAPE_DEACTIVATE_GUARD,\n  ESCAPE_DEACTIVATE_GUARD,\n} from '../guards/intercept-deactivate.guard';\nimport { skipError } from '../utils/operators';\n\n@Injectable({ providedIn: 'root' })\nexport class InterceptDeactivateService implements OnDestroy {\n  destroy$$ = new Subject<void>();\n\n  constructor(\n    private readonly location: Location,\n    private readonly router: Router,\n    private readonly dialog: DialogService,\n    private readonly translate: TranslateService,\n  ) {\n    this.router.events\n      .pipe(\n        filter(ev => ev instanceof NavigationEnd),\n        takeUntil(this.destroy$$),\n      )\n      .subscribe(() => {\n        const url = new URL(this.location.path(true), window.location.href);\n        if (\n          url.hash === '#' + ESCAPE_DEACTIVATE_GUARD ||\n          url.hash === '#' + CURR_ESCAPE_DEACTIVATE_GUARD\n        ) {\n          this.location.replaceState(url.pathname, url.search.slice(1));\n        }\n      });\n  }\n\n  ngOnDestroy(): void {\n    this.destroy$$.next();\n    this.destroy$$.complete();\n  }\n\n  intercept({\n    title,\n    content,\n    context,\n    errorFallback,\n  }: {\n    title?: string;\n    content?: string;\n    context?: TemplateData;\n    errorFallback?: boolean;\n  } = {}) {\n    return from(\n      this.dialog.confirm({\n        title: this.translate.get(\n          title || 'intercept_deactivate_title',\n          context,\n        ),\n        content: this.translate.get(\n          content || 'intercept_deactivate_content',\n          context,\n        ),\n        confirmText: this.translate.get('confirm'),\n        cancelText: this.translate.get('cancel'),\n      }),\n    ).pipe(\n      map(() => true),\n      skipError(errorFallback),\n    );\n  }\n\n  async back(escape?: boolean) {\n    if (escape) {\n      await this.escape();\n    }\n\n    this.location.back();\n  }\n\n  async forward(escape?: boolean) {\n    if (escape) {\n      await this.escape();\n    }\n\n    this.location.forward();\n  }\n\n  searchParamsToQueryParams(searchParams: URLSearchParams) {\n    const queryParams: Record<string, string | string[]> = {};\n    searchParams.forEach((_value, key) => {\n      const values = searchParams.getAll(key);\n      queryParams[key] = values.length <= 1 ? values[0] : values;\n    });\n    return queryParams;\n  }\n\n  async escape() {\n    const url = new URL(this.location.path(), location.href);\n\n    await this.router.navigate([url.pathname], {\n      replaceUrl: true,\n      fragment: CURR_ESCAPE_DEACTIVATE_GUARD,\n      queryParams: this.searchParamsToQueryParams(url.searchParams),\n    });\n  }\n}\n"]}