@rosoftlab/core 1.0.0-alpha-4 → 1.0.0-alpha-6

Sign up to get free protection for your applications and to get access to all the features.
package/lib/index.d.ts CHANGED
@@ -3,8 +3,6 @@ export * from './decorators/attribute.decorator';
3
3
  export * from './decorators/base-datastore-config.decorator';
4
4
  export * from './decorators/base-model-config.decorator';
5
5
  export * from './decorators/custom.type.decorator';
6
- export * from './directives/translated-content.directive';
7
- export * from './directives/translated-element.directive';
8
6
  export * from './interceptors';
9
7
  export * from './interfaces/attribute-decorator-options.interface';
10
8
  export * from './interfaces/datastore-config.interface';
@@ -1,21 +1,7 @@
1
1
  import { Observable } from 'rxjs';
2
- import * as i0 from "@angular/core";
3
- /**
4
- * Async modal dialog service
5
- * DialogService makes this app easier to test by faking this service.
6
- * TODO: better modal implementation that doesn't use window.confirm
7
- */
8
- export declare class DialogService {
9
- /**
10
- * Ask user to confirm an action. `message` explains the action and choices.
11
- * Returns observable resolving to `true`=confirm or `false`=cancel
12
- */
13
- constructor();
2
+ export interface DialogService {
14
3
  confirm(message?: string, text?: string, confirmButtonText?: string, cancelButtonText?: string): Observable<boolean>;
15
4
  showSaveMessage(message?: string, title?: string): Observable<boolean>;
16
5
  showRegisteredMessage(message?: string, title?: string): Observable<boolean>;
17
6
  showErrorMessage(e: any, message?: string): Observable<boolean>;
18
- getTextTranslation(translationKey: string): string;
19
- static ɵfac: i0.ɵɵFactoryDeclaration<DialogService, never>;
20
- static ɵprov: i0.ɵɵInjectableDeclaration<DialogService>;
21
7
  }
package/package.json CHANGED
@@ -1,18 +1,15 @@
1
1
  {
2
2
  "name": "@rosoftlab/core",
3
- "version": "1.0.0-alpha-4",
3
+ "version": "1.0.0-alpha-6",
4
4
  "peerDependencies": {
5
- "@angular/common": "^16.2.1",
6
- "@angular/core": "^16.2.1",
5
+ "@angular/common": "^16.2.10",
6
+ "@angular/core": "^16.2.10",
7
7
  "fast-json-patch": "^3.1.1",
8
8
  "date-fns": "^2.30.0",
9
- "@types/qs": "^6.9.7",
9
+ "@types/qs": "^6.9.9",
10
10
  "@ngx-translate/core": "^15.0.0",
11
- "@tinymce/tinymce-angular": "^7.0.0",
12
- "tinymce": "^6.4.2",
13
11
  "json-logic-js": "^2.0.2",
14
- "sweetalert2": "^11.7.5",
15
- "@angular/cdk": "^16.2.1"
12
+ "@angular/cdk": "^16.2.9"
16
13
  },
17
14
  "dependencies": {
18
15
  "tslib": "^2.3.1"
@@ -1,97 +0,0 @@
1
- import { ChangeDetectorRef, ContentChildren, Directive, Input, QueryList, Renderer2, ViewContainerRef } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
3
- import { BehaviorSubject, combineLatest, merge } from 'rxjs';
4
- import { map, switchMap } from 'rxjs/operators';
5
- import { TranslatedElementDirective } from './translated-element.directive';
6
- import * as i0 from "@angular/core";
7
- import * as i1 from "@ngx-translate/core";
8
- const TOKEN_START_DEMARC = '{{';
9
- const TOKEN_END_DEMARC = '}}';
10
- // adapted from @kasperlauge's solution in https://github.com/ngx-translate/core/issues/223
11
- export class TranslatedContentDirective {
12
- constructor(viewRef, renderer, translateService, changeDetectorRef) {
13
- this.viewRef = viewRef;
14
- this.renderer = renderer;
15
- this.translateService = translateService;
16
- this.changeDetectorRef = changeDetectorRef;
17
- this.subs = [];
18
- }
19
- ngOnInit() {
20
- this.rawTranslation = merge(this.translateService.get(this.translationKey), this.translateService.onLangChange.asObservable().pipe(switchMap(() => this.translateService.get(this.translationKey))));
21
- }
22
- ngAfterContentInit() {
23
- // QueryList.changes doesn't re-emit after its initial value, which we have by now
24
- // BehaviorSubjects re-emit their initial value on subscription, so we get what we need by merging
25
- // the BehaviorSubject and the QueryList.changes observable
26
- const elementsSubject = new BehaviorSubject(this.elements.toArray());
27
- const elementsChanges = merge(elementsSubject, this.elements.changes);
28
- this.translationData = combineLatest(this.rawTranslation, elementsChanges)
29
- .pipe(map(([rawTranslation]) => {
30
- return {
31
- elements: this.elements.toArray(),
32
- rawTranslation,
33
- };
34
- }));
35
- this.subs.push(this.translationData.subscribe(this.render.bind(this)));
36
- }
37
- render(translationData) {
38
- if (!translationData.rawTranslation || translationData.rawTranslation === this.translationKey) {
39
- throw new Error(`No resource matching the key '${this.translationKey}'`);
40
- }
41
- while (this.viewRef.element.nativeElement.firstChild) {
42
- this.renderer.removeChild(this.viewRef.element.nativeElement, this.viewRef.element.nativeElement.firstChild);
43
- }
44
- let lastTokenEnd = 0;
45
- while (lastTokenEnd < translationData.rawTranslation.length) {
46
- const tokenStartDemarc = translationData.rawTranslation.indexOf(TOKEN_START_DEMARC, lastTokenEnd);
47
- if (tokenStartDemarc < 0) {
48
- break;
49
- }
50
- const tokenStart = tokenStartDemarc + TOKEN_START_DEMARC.length;
51
- const tokenEnd = translationData.rawTranslation.indexOf(TOKEN_END_DEMARC, tokenStart);
52
- if (tokenEnd < 0) {
53
- throw new Error(`Encountered unterminated token in translation string '${this.translationKey}'`);
54
- }
55
- const tokenEndDemarc = tokenEnd + TOKEN_END_DEMARC.length;
56
- const precedingText = translationData.rawTranslation.substring(lastTokenEnd, tokenStartDemarc);
57
- const precedingTextElement = this.renderer.createText(precedingText);
58
- this.renderer.appendChild(this.viewRef.element.nativeElement, precedingTextElement);
59
- const elementKey = translationData.rawTranslation.substring(tokenStart, tokenEnd);
60
- const embeddedElementTemplate = translationData.elements.find(element => element.elementKey === elementKey);
61
- if (embeddedElementTemplate) {
62
- const embeddedElementView = embeddedElementTemplate.viewRef.createEmbeddedView(embeddedElementTemplate.templateRef);
63
- this.renderer.appendChild(this.viewRef.element.nativeElement, embeddedElementView.rootNodes[0]);
64
- }
65
- else {
66
- const missingTokenText = translationData.rawTranslation.substring(tokenStartDemarc, tokenEndDemarc);
67
- const missingTokenElement = this.renderer.createText(missingTokenText);
68
- this.renderer.appendChild(this.viewRef.element.nativeElement, missingTokenElement);
69
- }
70
- lastTokenEnd = tokenEndDemarc;
71
- }
72
- const trailingText = translationData.rawTranslation.substring(lastTokenEnd);
73
- const trailingTextElement = this.renderer.createText(trailingText);
74
- this.renderer.appendChild(this.viewRef.element.nativeElement, trailingTextElement);
75
- // in case the rendering happens outside of a change detection event, this ensures that any translations in the
76
- // embedded elements are rendered
77
- this.changeDetectorRef.detectChanges();
78
- }
79
- ngOnDestroy() {
80
- this.subs.forEach(sub => sub.unsubscribe());
81
- }
82
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: TranslatedContentDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.Renderer2 }, { token: i1.TranslateService }, { token: i0.ChangeDetectorRef }], target: i0.ɵɵFactoryTarget.Directive }); }
83
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: TranslatedContentDirective, selector: "[appTranslatedContent]", inputs: { translationKey: ["appTranslatedContent", "translationKey"] }, queries: [{ propertyName: "elements", predicate: TranslatedElementDirective }], ngImport: i0 }); }
84
- }
85
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: TranslatedContentDirective, decorators: [{
86
- type: Directive,
87
- args: [{
88
- selector: '[appTranslatedContent]',
89
- }]
90
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.Renderer2 }, { type: i1.TranslateService }, { type: i0.ChangeDetectorRef }]; }, propDecorators: { translationKey: [{
91
- type: Input,
92
- args: ['appTranslatedContent']
93
- }], elements: [{
94
- type: ContentChildren,
95
- args: [TranslatedElementDirective]
96
- }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"translated-content.directive.js","sourceRoot":"","sources":["../../../../../../projects/rosoftlab/core/src/lib/directives/translated-content.directive.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n  AfterContentInit, ChangeDetectorRef, ContentChildren, Directive,\n  Input, OnDestroy, OnInit, QueryList, Renderer2, ViewContainerRef\n} from '@angular/core';\nimport { TranslateService } from '@ngx-translate/core';\nimport { BehaviorSubject, combineLatest, merge, Observable, Subscription } from 'rxjs';\nimport { map, switchMap } from 'rxjs/operators';\nimport { TranslatedElementDirective } from './translated-element.directive';\n\ninterface TranslationData {\n  elements: TranslatedElementDirective[];\n  rawTranslation: string;\n}\n\nconst TOKEN_START_DEMARC = '{{';\nconst TOKEN_END_DEMARC = '}}';\n\n// adapted from @kasperlauge's solution in https://github.com/ngx-translate/core/issues/223\n@Directive({\n  selector: '[appTranslatedContent]',\n})\nexport class TranslatedContentDirective implements OnInit, OnDestroy, AfterContentInit {\n\n  @Input('appTranslatedContent') translationKey: string;\n\n  @ContentChildren(TranslatedElementDirective)\n  private elements: QueryList<TranslatedElementDirective>;\n\n  private subs: Subscription[] = [];\n  private rawTranslation: Observable<string>;\n  private translationData: Observable<TranslationData>;\n\n  constructor(\n    private viewRef: ViewContainerRef,\n    private renderer: Renderer2,\n    private translateService: TranslateService,\n    private changeDetectorRef: ChangeDetectorRef,\n  ) { }\n\n  public ngOnInit(): void {\n    this.rawTranslation = merge(\n      this.translateService.get(this.translationKey),\n      this.translateService.onLangChange.asObservable().pipe(switchMap(() => this.translateService.get(this.translationKey)))\n    );\n  }\n\n\n  public ngAfterContentInit(): void {\n    // QueryList.changes doesn't re-emit after its initial value, which we have by now\n    // BehaviorSubjects re-emit their initial value on subscription, so we get what we need by merging\n    // the BehaviorSubject and the QueryList.changes observable\n    const elementsSubject = new BehaviorSubject(this.elements.toArray());\n    const elementsChanges = merge(elementsSubject, this.elements.changes);\n\n    this.translationData = combineLatest(this.rawTranslation, elementsChanges)\n      .pipe(\n        map(([rawTranslation]) => {\n          return {\n            elements: this.elements.toArray(),\n            rawTranslation,\n          };\n        })\n      );\n\n    this.subs.push(this.translationData.subscribe(this.render.bind(this)));\n  }\n\n  private render(translationData: TranslationData): void {\n\n    if (!translationData.rawTranslation || translationData.rawTranslation === this.translationKey) {\n      throw new Error(`No resource matching the key '${this.translationKey}'`);\n    }\n\n    while (this.viewRef.element.nativeElement.firstChild) {\n      this.renderer.removeChild(this.viewRef.element.nativeElement, this.viewRef.element.nativeElement.firstChild);\n    }\n\n    let lastTokenEnd = 0;\n    while (lastTokenEnd < translationData.rawTranslation.length) {\n      const tokenStartDemarc = translationData.rawTranslation.indexOf(TOKEN_START_DEMARC, lastTokenEnd);\n      if (tokenStartDemarc < 0) {\n        break;\n      }\n      const tokenStart = tokenStartDemarc + TOKEN_START_DEMARC.length;\n      const tokenEnd = translationData.rawTranslation.indexOf(TOKEN_END_DEMARC, tokenStart);\n      if (tokenEnd < 0) {\n        throw new Error(`Encountered unterminated token in translation string '${this.translationKey}'`);\n      }\n      const tokenEndDemarc = tokenEnd + TOKEN_END_DEMARC.length;\n\n      const precedingText = translationData.rawTranslation.substring(lastTokenEnd, tokenStartDemarc);\n      const precedingTextElement = this.renderer.createText(precedingText);\n      this.renderer.appendChild(this.viewRef.element.nativeElement, precedingTextElement);\n\n      const elementKey = translationData.rawTranslation.substring(tokenStart, tokenEnd);\n      const embeddedElementTemplate = translationData.elements.find(element => element.elementKey === elementKey);\n      if (embeddedElementTemplate) {\n        const embeddedElementView = embeddedElementTemplate.viewRef.createEmbeddedView(embeddedElementTemplate.templateRef);\n        this.renderer.appendChild(this.viewRef.element.nativeElement, embeddedElementView.rootNodes[0]);\n      } else {\n        const missingTokenText = translationData.rawTranslation.substring(tokenStartDemarc, tokenEndDemarc);\n        const missingTokenElement = this.renderer.createText(missingTokenText);\n        this.renderer.appendChild(this.viewRef.element.nativeElement, missingTokenElement);\n      }\n\n      lastTokenEnd = tokenEndDemarc;\n    }\n\n    const trailingText = translationData.rawTranslation.substring(lastTokenEnd);\n    const trailingTextElement = this.renderer.createText(trailingText);\n\n    this.renderer.appendChild(this.viewRef.element.nativeElement, trailingTextElement);\n\n    // in case the rendering happens outside of a change detection event, this ensures that any translations in the\n    // embedded elements are rendered\n    this.changeDetectorRef.detectChanges();\n\n  }\n\n  public ngOnDestroy(): void {\n    this.subs.forEach(sub => sub.unsubscribe());\n  }\n}"]}
@@ -1,20 +0,0 @@
1
- import { Directive, Input, TemplateRef, ViewContainerRef } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export class TranslatedElementDirective {
4
- constructor(viewRef, templateRef) {
5
- this.viewRef = viewRef;
6
- this.templateRef = templateRef;
7
- }
8
- static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: TranslatedElementDirective, deps: [{ token: i0.ViewContainerRef }, { token: i0.TemplateRef }], target: i0.ɵɵFactoryTarget.Directive }); }
9
- static { this.ɵdir = i0.ɵɵngDeclareDirective({ minVersion: "14.0.0", version: "16.2.1", type: TranslatedElementDirective, selector: "[translatedElement]", inputs: { elementKey: ["translatedElement", "elementKey"] }, ngImport: i0 }); }
10
- }
11
- i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "16.2.1", ngImport: i0, type: TranslatedElementDirective, decorators: [{
12
- type: Directive,
13
- args: [{
14
- selector: '[translatedElement]',
15
- }]
16
- }], ctorParameters: function () { return [{ type: i0.ViewContainerRef }, { type: i0.TemplateRef }]; }, propDecorators: { elementKey: [{
17
- type: Input,
18
- args: ['translatedElement']
19
- }] } });
20
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidHJhbnNsYXRlZC1lbGVtZW50LmRpcmVjdGl2ZS5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL3Jvc29mdGxhYi9jb3JlL3NyYy9saWIvZGlyZWN0aXZlcy90cmFuc2xhdGVkLWVsZW1lbnQuZGlyZWN0aXZlLnRzIl0sIm5hbWVzIjpbXSwibWFwcGluZ3MiOiJBQUNBLE9BQU8sRUFBRSxTQUFTLEVBQUUsS0FBSyxFQUFFLFdBQVcsRUFBRSxnQkFBZ0IsRUFBRSxNQUFNLGVBQWUsQ0FBQzs7QUFLaEYsTUFBTSxPQUFPLDBCQUEwQjtJQUtyQyxZQUNrQixPQUF5QixFQUN6QixXQUE2QjtRQUQ3QixZQUFPLEdBQVAsT0FBTyxDQUFrQjtRQUN6QixnQkFBVyxHQUFYLFdBQVcsQ0FBa0I7SUFDNUMsQ0FBQzs4R0FSTywwQkFBMEI7a0dBQTFCLDBCQUEwQjs7MkZBQTFCLDBCQUEwQjtrQkFIdEMsU0FBUzttQkFBQztvQkFDVCxRQUFRLEVBQUUscUJBQXFCO2lCQUNoQztpSUFJUSxVQUFVO3NCQURoQixLQUFLO3VCQUFDLG1CQUFtQiIsInNvdXJjZXNDb250ZW50IjpbIlxuaW1wb3J0IHsgRGlyZWN0aXZlLCBJbnB1dCwgVGVtcGxhdGVSZWYsIFZpZXdDb250YWluZXJSZWYgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcblxuQERpcmVjdGl2ZSh7XG4gIHNlbGVjdG9yOiAnW3RyYW5zbGF0ZWRFbGVtZW50XScsXG59KVxuZXhwb3J0IGNsYXNzIFRyYW5zbGF0ZWRFbGVtZW50RGlyZWN0aXZlIHtcblxuICBASW5wdXQoJ3RyYW5zbGF0ZWRFbGVtZW50JylcbiAgcHVibGljIGVsZW1lbnRLZXk6IHN0cmluZztcblxuICBjb25zdHJ1Y3RvcihcbiAgICBwdWJsaWMgcmVhZG9ubHkgdmlld1JlZjogVmlld0NvbnRhaW5lclJlZixcbiAgICBwdWJsaWMgcmVhZG9ubHkgdGVtcGxhdGVSZWY6IFRlbXBsYXRlUmVmPGFueT4sXG4gICkge31cbn0iXX0=
@@ -1,21 +0,0 @@
1
- import { AfterContentInit, ChangeDetectorRef, OnDestroy, OnInit, Renderer2, ViewContainerRef } from '@angular/core';
2
- import { TranslateService } from '@ngx-translate/core';
3
- import * as i0 from "@angular/core";
4
- export declare class TranslatedContentDirective implements OnInit, OnDestroy, AfterContentInit {
5
- private viewRef;
6
- private renderer;
7
- private translateService;
8
- private changeDetectorRef;
9
- translationKey: string;
10
- private elements;
11
- private subs;
12
- private rawTranslation;
13
- private translationData;
14
- constructor(viewRef: ViewContainerRef, renderer: Renderer2, translateService: TranslateService, changeDetectorRef: ChangeDetectorRef);
15
- ngOnInit(): void;
16
- ngAfterContentInit(): void;
17
- private render;
18
- ngOnDestroy(): void;
19
- static ɵfac: i0.ɵɵFactoryDeclaration<TranslatedContentDirective, never>;
20
- static ɵdir: i0.ɵɵDirectiveDeclaration<TranslatedContentDirective, "[appTranslatedContent]", never, { "translationKey": { "alias": "appTranslatedContent"; "required": false; }; }, {}, ["elements"], never, false, never>;
21
- }
@@ -1,10 +0,0 @@
1
- import { TemplateRef, ViewContainerRef } from '@angular/core';
2
- import * as i0 from "@angular/core";
3
- export declare class TranslatedElementDirective {
4
- readonly viewRef: ViewContainerRef;
5
- readonly templateRef: TemplateRef<any>;
6
- elementKey: string;
7
- constructor(viewRef: ViewContainerRef, templateRef: TemplateRef<any>);
8
- static ɵfac: i0.ɵɵFactoryDeclaration<TranslatedElementDirective, never>;
9
- static ɵdir: i0.ɵɵDirectiveDeclaration<TranslatedElementDirective, "[translatedElement]", never, { "elementKey": { "alias": "translatedElement"; "required": false; }; }, {}, never, never, false, never>;
10
- }