ngx-histaff-alpha 4.3.0 → 4.3.2

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
@@ -0,0 +1,40 @@
1
+ import { Injectable, inject } from '@angular/core';
2
+ import { AppConfigService } from '../services/app-config.service';
3
+ import * as i0 from "@angular/core";
4
+ import * as i1 from "../services/app-config.service";
5
+ export class AppTypeInterceptor {
6
+ constructor(appConfigService) {
7
+ this.appConfigService = appConfigService;
8
+ }
9
+ intercept(req, next) {
10
+ const appType = this.appConfigService.APP_TYPE;
11
+ if (appType === undefined) {
12
+ return next.handle(req);
13
+ }
14
+ const cloneReq = req.clone({
15
+ headers: req.headers.set('App-Type', appType)
16
+ });
17
+ return next.handle(cloneReq);
18
+ }
19
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: AppTypeInterceptor, deps: [{ token: i1.AppConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); }
20
+ static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: AppTypeInterceptor, providedIn: 'root' }); }
21
+ }
22
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: AppTypeInterceptor, decorators: [{
23
+ type: Injectable,
24
+ args: [{
25
+ providedIn: 'root'
26
+ }]
27
+ }], ctorParameters: () => [{ type: i1.AppConfigService }] });
28
+ // Fn style
29
+ export function appTypeInterceptor(req, next) {
30
+ const appConfigService = inject(AppConfigService);
31
+ const appType = appConfigService.APP_TYPE;
32
+ if (appType === undefined) {
33
+ return next(req);
34
+ }
35
+ const cloneReq = req.clone({
36
+ headers: req.headers.set('App-Type', appType)
37
+ });
38
+ return next(cloneReq);
39
+ }
40
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiYXBwLXR5cGUtaW50ZXJjZXB0b3IuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9odHRwLWludGVyY2VwdG9ycy9hcHAtdHlwZS1pbnRlcmNlcHRvci50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsVUFBVSxFQUFFLE1BQU0sRUFBRSxNQUFNLGVBQWUsQ0FBQztBQVFuRCxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxnQ0FBZ0MsQ0FBQzs7O0FBS2xFLE1BQU0sT0FBTyxrQkFBa0I7SUFFM0IsWUFDWSxnQkFBa0M7UUFBbEMscUJBQWdCLEdBQWhCLGdCQUFnQixDQUFrQjtJQUMxQyxDQUFDO0lBRUwsU0FBUyxDQUFDLEdBQXFCLEVBQUUsSUFBaUI7UUFFOUMsTUFBTSxPQUFPLEdBQUcsSUFBSSxDQUFDLGdCQUFnQixDQUFDLFFBQVEsQ0FBQztRQUUvQyxJQUFJLE9BQU8sS0FBSyxTQUFTLEVBQUU7WUFDdkIsT0FBTyxJQUFJLENBQUMsTUFBTSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1NBQzNCO1FBRUQsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztZQUN2QixPQUFPLEVBQUUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQztTQUNoRCxDQUFDLENBQUM7UUFFSCxPQUFPLElBQUksQ0FBQyxNQUFNLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDakMsQ0FBQzs4R0FuQlEsa0JBQWtCO2tIQUFsQixrQkFBa0IsY0FGZixNQUFNOzsyRkFFVCxrQkFBa0I7a0JBSDlCLFVBQVU7bUJBQUM7b0JBQ1IsVUFBVSxFQUFFLE1BQU07aUJBQ3JCOztBQXVCRCxXQUFXO0FBQ1gsTUFBTSxVQUFVLGtCQUFrQixDQUFDLEdBQXFCLEVBQUUsSUFBbUI7SUFFekUsTUFBTSxnQkFBZ0IsR0FBRyxNQUFNLENBQUMsZ0JBQWdCLENBQUMsQ0FBQztJQUVsRCxNQUFNLE9BQU8sR0FBRyxnQkFBZ0IsQ0FBQyxRQUFRLENBQUM7SUFFMUMsSUFBSSxPQUFPLEtBQUssU0FBUyxFQUFFO1FBQ3ZCLE9BQU8sSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO0tBQ3BCO0lBRUQsTUFBTSxRQUFRLEdBQUcsR0FBRyxDQUFDLEtBQUssQ0FBQztRQUN2QixPQUFPLEVBQUUsR0FBRyxDQUFDLE9BQU8sQ0FBQyxHQUFHLENBQUMsVUFBVSxFQUFFLE9BQU8sQ0FBQztLQUNoRCxDQUFDLENBQUM7SUFFSCxPQUFPLElBQUksQ0FBQyxRQUFRLENBQUMsQ0FBQztBQUMxQixDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgSW5qZWN0YWJsZSwgaW5qZWN0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XHJcbmltcG9ydCB7XHJcbiAgICBIdHRwSW50ZXJjZXB0b3IsIEh0dHBIYW5kbGVyLCBIdHRwUmVxdWVzdCxcclxuICAgIEh0dHBIYW5kbGVyRm4sXHJcbiAgICBIdHRwRXZlbnRcclxufSBmcm9tICdAYW5ndWxhci9jb21tb24vaHR0cCc7XHJcblxyXG5pbXBvcnQgeyBPYnNlcnZhYmxlIH0gZnJvbSAncnhqcyc7XHJcbmltcG9ydCB7IEFwcENvbmZpZ1NlcnZpY2UgfSBmcm9tICcuLi9zZXJ2aWNlcy9hcHAtY29uZmlnLnNlcnZpY2UnO1xyXG5cclxuQEluamVjdGFibGUoe1xyXG4gICAgcHJvdmlkZWRJbjogJ3Jvb3QnXHJcbn0pXHJcbmV4cG9ydCBjbGFzcyBBcHBUeXBlSW50ZXJjZXB0b3IgaW1wbGVtZW50cyBIdHRwSW50ZXJjZXB0b3Ige1xyXG5cclxuICAgIGNvbnN0cnVjdG9yKFxyXG4gICAgICAgIHByaXZhdGUgYXBwQ29uZmlnU2VydmljZTogQXBwQ29uZmlnU2VydmljZVxyXG4gICAgKSB7IH1cclxuXHJcbiAgICBpbnRlcmNlcHQocmVxOiBIdHRwUmVxdWVzdDxhbnk+LCBuZXh0OiBIdHRwSGFuZGxlcikge1xyXG5cclxuICAgICAgICBjb25zdCBhcHBUeXBlID0gdGhpcy5hcHBDb25maWdTZXJ2aWNlLkFQUF9UWVBFO1xyXG5cclxuICAgICAgICBpZiAoYXBwVHlwZSA9PT0gdW5kZWZpbmVkKSB7XHJcbiAgICAgICAgICAgIHJldHVybiBuZXh0LmhhbmRsZShyZXEpO1xyXG4gICAgICAgIH1cclxuXHJcbiAgICAgICAgY29uc3QgY2xvbmVSZXEgPSByZXEuY2xvbmUoe1xyXG4gICAgICAgICAgICBoZWFkZXJzOiByZXEuaGVhZGVycy5zZXQoJ0FwcC1UeXBlJywgYXBwVHlwZSlcclxuICAgICAgICB9KTtcclxuXHJcbiAgICAgICAgcmV0dXJuIG5leHQuaGFuZGxlKGNsb25lUmVxKTtcclxuICAgIH1cclxufVxyXG5cclxuLy8gRm4gc3R5bGVcclxuZXhwb3J0IGZ1bmN0aW9uIGFwcFR5cGVJbnRlcmNlcHRvcihyZXE6IEh0dHBSZXF1ZXN0PGFueT4sIG5leHQ6IEh0dHBIYW5kbGVyRm4pOiBPYnNlcnZhYmxlPEh0dHBFdmVudDx1bmtub3duPj4ge1xyXG5cclxuICAgIGNvbnN0IGFwcENvbmZpZ1NlcnZpY2UgPSBpbmplY3QoQXBwQ29uZmlnU2VydmljZSk7XHJcblxyXG4gICAgY29uc3QgYXBwVHlwZSA9IGFwcENvbmZpZ1NlcnZpY2UuQVBQX1RZUEU7XHJcblxyXG4gICAgaWYgKGFwcFR5cGUgPT09IHVuZGVmaW5lZCkge1xyXG4gICAgICAgIHJldHVybiBuZXh0KHJlcSk7XHJcbiAgICB9XHJcblxyXG4gICAgY29uc3QgY2xvbmVSZXEgPSByZXEuY2xvbmUoe1xyXG4gICAgICAgIGhlYWRlcnM6IHJlcS5oZWFkZXJzLnNldCgnQXBwLVR5cGUnLCBhcHBUeXBlKVxyXG4gICAgfSk7XHJcblxyXG4gICAgcmV0dXJuIG5leHQoY2xvbmVSZXEpO1xyXG59Il19
@@ -9,8 +9,10 @@ import { ResponseInterceptor, responseInterceptor } from './response-interceptor
9
9
  import { TimeZoneInterceptor, timeZoneInterceptor } from './time-zone-interceptor';
10
10
  import { CachingInterceptor, cachingInterceptor } from './caching-interceptor';
11
11
  import { LangInterceptor, langInterceptor } from './lang-interceptor';
12
+ import { AppTypeInterceptor, appTypeInterceptor } from './app-type-interceptor';
12
13
  /** Http interceptor providers in outside-in order */
13
14
  export const httpInterceptorProviders = [
15
+ { provide: HTTP_INTERCEPTORS, useClass: AppTypeInterceptor, multi: true },
14
16
  { provide: HTTP_INTERCEPTORS, useClass: BaseUrlInterceptor, multi: true },
15
17
  { provide: HTTP_INTERCEPTORS, useClass: LoggingInterceptor, multi: true },
16
18
  { provide: HTTP_INTERCEPTORS, useClass: AuthInterceptor, multi: true },
@@ -21,5 +23,5 @@ export const httpInterceptorProviders = [
21
23
  { provide: HTTP_INTERCEPTORS, useClass: CachingInterceptor, multi: true },
22
24
  { provide: HTTP_INTERCEPTORS, useClass: LangInterceptor, multi: true },
23
25
  ];
24
- export { InterceptorSkipHeader, baseUrlInterceptor, authInterceptor, graphInterceptor, tokenInterceptor, responseInterceptor, timeZoneInterceptor, cachingInterceptor, langInterceptor };
25
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9odHRwLWludGVyY2VwdG9ycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtQ0FBbUM7QUFDbkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLHFCQUFxQixFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN0RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNsRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNuRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMvRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBRXJFLHFEQUFxRDtBQUNyRCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRztJQUN0QyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN6RSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN6RSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdEUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdkUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdkUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDMUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDMUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDekUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0NBQ3ZFLENBQUM7QUFFRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogXCJCYXJyZWxcIiBvZiBIdHRwIEludGVyY2VwdG9ycyAqL1xyXG5pbXBvcnQgeyBIVFRQX0lOVEVSQ0VQVE9SUyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuXHJcbmltcG9ydCB7IEJhc2VVcmxJbnRlcmNlcHRvciwgSW50ZXJjZXB0b3JTa2lwSGVhZGVyLCBiYXNlVXJsSW50ZXJjZXB0b3IgfSBmcm9tICcuL2Jhc2UtdXJsLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgTG9nZ2luZ0ludGVyY2VwdG9yIH0gZnJvbSAnLi9sb2dnaW5nLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgQXV0aEludGVyY2VwdG9yLCBhdXRoSW50ZXJjZXB0b3IgfSBmcm9tICcuL2F1dGgtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBHcmFwaEludGVyY2VwdG9yLCBncmFwaEludGVyY2VwdG9yIH0gZnJvbSAnLi9ncmFwaC1pbnRlcmNlcHRvcic7XHJcbmltcG9ydCB7IFRva2VuSW50ZXJjZXB0b3IsIHRva2VuSW50ZXJjZXB0b3IgfSBmcm9tICcuL3Rva2VuLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgUmVzcG9uc2VJbnRlcmNlcHRvciwgcmVzcG9uc2VJbnRlcmNlcHRvciB9IGZyb20gJy4vcmVzcG9uc2UtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBUaW1lWm9uZUludGVyY2VwdG9yLCB0aW1lWm9uZUludGVyY2VwdG9yIH0gZnJvbSAnLi90aW1lLXpvbmUtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBDYWNoaW5nSW50ZXJjZXB0b3IsIGNhY2hpbmdJbnRlcmNlcHRvciB9IGZyb20gJy4vY2FjaGluZy1pbnRlcmNlcHRvcic7XHJcbmltcG9ydCB7IExhbmdJbnRlcmNlcHRvciwgbGFuZ0ludGVyY2VwdG9yIH0gZnJvbSAnLi9sYW5nLWludGVyY2VwdG9yJ1xyXG5cclxuLyoqIEh0dHAgaW50ZXJjZXB0b3IgcHJvdmlkZXJzIGluIG91dHNpZGUtaW4gb3JkZXIgKi9cclxuZXhwb3J0IGNvbnN0IGh0dHBJbnRlcmNlcHRvclByb3ZpZGVycyA9IFtcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogQmFzZVVybEludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBMb2dnaW5nSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBIVFRQX0lOVEVSQ0VQVE9SUywgdXNlQ2xhc3M6IEF1dGhJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogR3JhcGhJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogVG9rZW5JbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogUmVzcG9uc2VJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogVGltZVpvbmVJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogQ2FjaGluZ0ludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBMYW5nSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlIH0sXHJcbl07XHJcblxyXG5leHBvcnQgeyBJbnRlcmNlcHRvclNraXBIZWFkZXIsIGJhc2VVcmxJbnRlcmNlcHRvciwgYXV0aEludGVyY2VwdG9yLCBncmFwaEludGVyY2VwdG9yLCB0b2tlbkludGVyY2VwdG9yLCByZXNwb25zZUludGVyY2VwdG9yLCB0aW1lWm9uZUludGVyY2VwdG9yLCBjYWNoaW5nSW50ZXJjZXB0b3IsIGxhbmdJbnRlcmNlcHRvciB9OyJdfQ==
26
+ export { InterceptorSkipHeader, appTypeInterceptor, baseUrlInterceptor, authInterceptor, graphInterceptor, tokenInterceptor, responseInterceptor, timeZoneInterceptor, cachingInterceptor, langInterceptor };
27
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiaW5kZXguanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9uZ3gtaGlzdGFmZi1hbHBoYS9zcmMvbGliL2FwcC9odHRwLWludGVyY2VwdG9ycy9pbmRleC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxtQ0FBbUM7QUFDbkMsT0FBTyxFQUFFLGlCQUFpQixFQUFFLE1BQU0sc0JBQXNCLENBQUM7QUFFekQsT0FBTyxFQUFFLGtCQUFrQixFQUFFLHFCQUFxQixFQUFFLGtCQUFrQixFQUFFLE1BQU0sd0JBQXdCLENBQUM7QUFDdkcsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sdUJBQXVCLENBQUM7QUFDM0QsT0FBTyxFQUFFLGVBQWUsRUFBRSxlQUFlLEVBQUUsTUFBTSxvQkFBb0IsQ0FBQztBQUN0RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RSxPQUFPLEVBQUUsZ0JBQWdCLEVBQUUsZ0JBQWdCLEVBQUUsTUFBTSxxQkFBcUIsQ0FBQztBQUN6RSxPQUFPLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx3QkFBd0IsQ0FBQztBQUNsRixPQUFPLEVBQUUsbUJBQW1CLEVBQUUsbUJBQW1CLEVBQUUsTUFBTSx5QkFBeUIsQ0FBQztBQUNuRixPQUFPLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSx1QkFBdUIsQ0FBQztBQUMvRSxPQUFPLEVBQUUsZUFBZSxFQUFFLGVBQWUsRUFBRSxNQUFNLG9CQUFvQixDQUFBO0FBQ3JFLE9BQU8sRUFBRSxrQkFBa0IsRUFBRSxrQkFBa0IsRUFBRSxNQUFNLHdCQUF3QixDQUFDO0FBRWhGLHFEQUFxRDtBQUNyRCxNQUFNLENBQUMsTUFBTSx3QkFBd0IsR0FBRztJQUN0QyxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN6RSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN6RSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsa0JBQWtCLEVBQUUsS0FBSyxFQUFFLElBQUksRUFBRTtJQUN6RSxFQUFFLE9BQU8sRUFBRSxpQkFBaUIsRUFBRSxRQUFRLEVBQUUsZUFBZSxFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdEUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdkUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGdCQUFnQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDdkUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDMUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLG1CQUFtQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDMUUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGtCQUFrQixFQUFFLEtBQUssRUFBRSxJQUFJLEVBQUU7SUFDekUsRUFBRSxPQUFPLEVBQUUsaUJBQWlCLEVBQUUsUUFBUSxFQUFFLGVBQWUsRUFBRSxLQUFLLEVBQUUsSUFBSSxFQUFFO0NBQ3ZFLENBQUM7QUFFRixPQUFPLEVBQUUscUJBQXFCLEVBQUUsa0JBQWtCLEVBQUUsa0JBQWtCLEVBQUUsZUFBZSxFQUFFLGdCQUFnQixFQUFFLGdCQUFnQixFQUFFLG1CQUFtQixFQUFFLG1CQUFtQixFQUFFLGtCQUFrQixFQUFFLGVBQWUsRUFBRSxDQUFDIiwic291cmNlc0NvbnRlbnQiOlsiLyogXCJCYXJyZWxcIiBvZiBIdHRwIEludGVyY2VwdG9ycyAqL1xyXG5pbXBvcnQgeyBIVFRQX0lOVEVSQ0VQVE9SUyB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbi9odHRwJztcclxuXHJcbmltcG9ydCB7IEJhc2VVcmxJbnRlcmNlcHRvciwgSW50ZXJjZXB0b3JTa2lwSGVhZGVyLCBiYXNlVXJsSW50ZXJjZXB0b3IgfSBmcm9tICcuL2Jhc2UtdXJsLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgTG9nZ2luZ0ludGVyY2VwdG9yIH0gZnJvbSAnLi9sb2dnaW5nLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgQXV0aEludGVyY2VwdG9yLCBhdXRoSW50ZXJjZXB0b3IgfSBmcm9tICcuL2F1dGgtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBHcmFwaEludGVyY2VwdG9yLCBncmFwaEludGVyY2VwdG9yIH0gZnJvbSAnLi9ncmFwaC1pbnRlcmNlcHRvcic7XHJcbmltcG9ydCB7IFRva2VuSW50ZXJjZXB0b3IsIHRva2VuSW50ZXJjZXB0b3IgfSBmcm9tICcuL3Rva2VuLWludGVyY2VwdG9yJztcclxuaW1wb3J0IHsgUmVzcG9uc2VJbnRlcmNlcHRvciwgcmVzcG9uc2VJbnRlcmNlcHRvciB9IGZyb20gJy4vcmVzcG9uc2UtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBUaW1lWm9uZUludGVyY2VwdG9yLCB0aW1lWm9uZUludGVyY2VwdG9yIH0gZnJvbSAnLi90aW1lLXpvbmUtaW50ZXJjZXB0b3InO1xyXG5pbXBvcnQgeyBDYWNoaW5nSW50ZXJjZXB0b3IsIGNhY2hpbmdJbnRlcmNlcHRvciB9IGZyb20gJy4vY2FjaGluZy1pbnRlcmNlcHRvcic7XHJcbmltcG9ydCB7IExhbmdJbnRlcmNlcHRvciwgbGFuZ0ludGVyY2VwdG9yIH0gZnJvbSAnLi9sYW5nLWludGVyY2VwdG9yJ1xyXG5pbXBvcnQgeyBBcHBUeXBlSW50ZXJjZXB0b3IsIGFwcFR5cGVJbnRlcmNlcHRvciB9IGZyb20gJy4vYXBwLXR5cGUtaW50ZXJjZXB0b3InO1xyXG5cclxuLyoqIEh0dHAgaW50ZXJjZXB0b3IgcHJvdmlkZXJzIGluIG91dHNpZGUtaW4gb3JkZXIgKi9cclxuZXhwb3J0IGNvbnN0IGh0dHBJbnRlcmNlcHRvclByb3ZpZGVycyA9IFtcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogQXBwVHlwZUludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBCYXNlVXJsSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBIVFRQX0lOVEVSQ0VQVE9SUywgdXNlQ2xhc3M6IExvZ2dpbmdJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuICB7IHByb3ZpZGU6IEhUVFBfSU5URVJDRVBUT1JTLCB1c2VDbGFzczogQXV0aEludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBHcmFwaEludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBUb2tlbkludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBSZXNwb25zZUludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBUaW1lWm9uZUludGVyY2VwdG9yLCBtdWx0aTogdHJ1ZSB9LFxyXG4gIHsgcHJvdmlkZTogSFRUUF9JTlRFUkNFUFRPUlMsIHVzZUNsYXNzOiBDYWNoaW5nSW50ZXJjZXB0b3IsIG11bHRpOiB0cnVlIH0sXHJcbiAgeyBwcm92aWRlOiBIVFRQX0lOVEVSQ0VQVE9SUywgdXNlQ2xhc3M6IExhbmdJbnRlcmNlcHRvciwgbXVsdGk6IHRydWUgfSxcclxuXTtcclxuXHJcbmV4cG9ydCB7IEludGVyY2VwdG9yU2tpcEhlYWRlciwgYXBwVHlwZUludGVyY2VwdG9yLCBiYXNlVXJsSW50ZXJjZXB0b3IsIGF1dGhJbnRlcmNlcHRvciwgZ3JhcGhJbnRlcmNlcHRvciwgdG9rZW5JbnRlcmNlcHRvciwgcmVzcG9uc2VJbnRlcmNlcHRvciwgdGltZVpvbmVJbnRlcmNlcHRvciwgY2FjaGluZ0ludGVyY2VwdG9yLCBsYW5nSW50ZXJjZXB0b3IgfTsiXX0=
@@ -1,102 +1,92 @@
1
- import { CommonModule } from '@angular/common';
2
- import { Component, EventEmitter, Input, Output, ViewChild } from '@angular/core';
1
+ import { NgStyle, NgTemplateOutlet } from '@angular/common';
2
+ import { ChangeDetectionStrategy, ChangeDetectorRef, Component, EventEmitter, inject, input, Output, signal, viewChild } from '@angular/core';
3
3
  import * as i0 from "@angular/core";
4
- import * as i1 from "@angular/common";
5
4
  export class CoreOrgchartflexComponent {
6
5
  startDragging(e, flag) {
7
- this.mouseDown = true;
8
- this.startX = e.pageX - this.parent?.nativeElement.offsetLeft;
9
- this.scrollLeft = this.parent?.nativeElement.scrollLeft;
10
- this.startY = e.pageY - this.parent?.nativeElement.offsetTop;
11
- this.scrollTop = this.parent?.nativeElement.scrollTop;
6
+ this.$mouseDown.set(true);
7
+ this.$startX.set(e.pageX - this.$parent()?.nativeElement.offsetLeft);
8
+ this.$scrollLeft.set(this.$parent()?.nativeElement.scrollLeft);
9
+ this.$startY.set(e.pageY - this.$parent()?.nativeElement.offsetTop);
10
+ this.$scrollTop.set(this.$parent()?.nativeElement.scrollTop);
12
11
  }
13
12
  stopDragging(e, flag) {
14
- this.mouseDown = false;
13
+ this.$mouseDown.set(false);
15
14
  }
16
15
  moveEvent(e) {
17
16
  e.preventDefault();
18
- if (!this.mouseDown) {
17
+ if (!this.$mouseDown()) {
19
18
  return;
20
19
  }
21
- const x = e.pageX - this.parent?.nativeElement.offsetLeft;
22
- const scrollX = x - this.startX;
23
- this.parent.nativeElement.scrollLeft = this.scrollLeft - scrollX;
24
- const y = e.pageY - this.parent?.nativeElement.offsetTop;
25
- const scrollY = y - this.startY;
26
- this.parent.nativeElement.scrollTop = this.scrollTop - scrollY;
20
+ const x = e.pageX - this.$parent()?.nativeElement.offsetLeft;
21
+ const scrollX = x - this.$startX();
22
+ this.$parent().nativeElement.scrollLeft = this.$scrollLeft() - scrollX;
23
+ const y = e.pageY - this.$parent()?.nativeElement.offsetTop;
24
+ const scrollY = y - this.$startY();
25
+ this.$parent().nativeElement.scrollTop = this.$scrollTop() - scrollY;
27
26
  }
28
27
  constructor() {
28
+ this.$data = input.required();
29
+ this.$itemTemplate = input.required();
30
+ this.$compactMode = input();
31
+ this.$showDissolved = input();
32
+ this.$width = input();
33
+ this.$height = input();
34
+ this.$connectionColor = input();
35
+ this.$connectionSize = input(); // in pixel
36
+ this.$fromChildrenToTopLine = input(); // in pixel
37
+ this.$fromParentToChildrenTopLine = input(); // in pixel
38
+ this.$childrenHorizontalMargin = input(); // in pixel
39
+ this.$childrenBorderSize = input(); // in pixel
40
+ this.$childrenBorderColor = input(); // in pixel
29
41
  this.onPrintAreaRendered = new EventEmitter();
30
- this.mouseDown = false;
31
- this.scale = 1;
32
- }
33
- ngOnChanges(changes) {
34
- if (changes['width'] || changes['height']) {
35
- this.setGeometricRect();
36
- }
37
- }
38
- ngOnInit() {
39
- }
40
- setGeometricRect() {
41
- const style = this.container?.nativeElement.style;
42
- if (!!!style)
43
- return;
44
- if (!!this.width)
45
- style.setProperty('--width', this.width + 'px');
46
- if (!!this.height)
47
- style.setProperty('--height', this.height + 'px');
48
- }
49
- ngAfterViewInit() {
50
- setTimeout(() => {
51
- this.setGeometricRect();
52
- this.onPrintAreaRendered.emit(this.printArea);
53
- });
42
+ this.$container = viewChild('container');
43
+ this.$parent = viewChild('parent');
44
+ this.$printArea = viewChild('printArea');
45
+ this.$mouseDown = signal(false);
46
+ this.$startX = signal(undefined);
47
+ this.$scrollLeft = signal(undefined);
48
+ this.$startY = signal(undefined);
49
+ this.$scrollTop = signal(undefined);
50
+ this.$scale = signal(1);
51
+ this.cdr = inject(ChangeDetectorRef);
54
52
  }
55
53
  toggleExpand(e) {
56
54
  e.tree$Expanded = !!!e.tree$Expanded;
57
55
  }
58
56
  zoonIn() {
59
- this.scale = this.scale * 1.1;
60
- this.container.nativeElement.style.setProperty('--print-area-scale', this.scale);
57
+ this.$scale.set(this.$scale() * 1.1);
58
+ this.$container().nativeElement.style.setProperty('--print-area-scale', this.$scale());
61
59
  }
62
60
  zoonOut() {
63
- this.scale = this.scale / 1.1;
64
- this.container.nativeElement.style.setProperty('--print-area-scale', this.scale);
61
+ this.$scale.set(this.$scale() / 1.1);
62
+ this.$container().nativeElement.style.setProperty('--print-area-scale', this.$scale());
65
63
  }
66
64
  zoonFeat() {
67
- this.scale = 1;
68
- this.container.nativeElement.style.setProperty('--print-area-scale', this.scale);
65
+ this.$scale.set(1);
66
+ this.$container().nativeElement.style.setProperty('--print-area-scale', this.$scale());
67
+ }
68
+ ngAfterViewInit() {
69
+ setTimeout(() => {
70
+ var style = this.$container()?.nativeElement.style;
71
+ style.setProperty('--connection-color', this.$connectionColor());
72
+ style.setProperty('--connection-size', this.$connectionSize() + 'px');
73
+ style.setProperty('--from-children-to-top-line', this.$fromChildrenToTopLine() + 'px');
74
+ style.setProperty('--from-parent-to-children-top-line', this.$fromParentToChildrenTopLine() + 'px');
75
+ style.setProperty('--children-horizontal-margin', this.$childrenHorizontalMargin() + 'px');
76
+ style.setProperty('--children-border-size', this.$childrenBorderSize() + 'px');
77
+ style.setProperty('--children-border-color', this.$childrenBorderColor());
78
+ });
69
79
  }
70
80
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreOrgchartflexComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
71
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "17.2.3", type: CoreOrgchartflexComponent, isStandalone: true, selector: "core-orgchartflex", inputs: { data: "data", itemTemplate: "itemTemplate", compactMode: "compactMode", showDissolved: "showDissolved", width: "width", height: "height" }, outputs: { onPrintAreaRendered: "onPrintAreaRendered" }, viewQueries: [{ propertyName: "container", first: true, predicate: ["container"], descendants: true }, { propertyName: "parent", first: true, predicate: ["parent"], descendants: true }, { propertyName: "printArea", first: true, predicate: ["printArea"], descendants: true }], usesOnChanges: true, ngImport: i0, template: "<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: mouseDown ? 'all-scroll' : 'unset'}\">\r\n\r\n <div class=\"zoom-control p-absolute\">\r\n <div class=\"p-relative d-flex d-flex-start\">\r\n <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"print-area\" #printArea>\r\n\r\n <ul class=\"tree\" *ngFor=\"let root of data\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n </ul>\r\n\r\n </div>\r\n\r\n <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n <li *ngIf=\"(!showDissolved && !!isActive) || (!!showDissolved)\">\r\n <span *ngIf=\"!!compactMode\" (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\">\r\n {{ title }}\r\n </span>\r\n\r\n <!-- When passing item template and compactMode=false-->\r\n <span *ngIf=\"!!!compactMode && !!itemTemplate\" (click)=\"toggleExpand(context)\" class=\"pointer\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: context } \"></ng-container>\r\n </span>\r\n <!-- ------------------------- -->\r\n\r\n <ul *ngIf=\"!!expanded && !!children.length \">\r\n <ng-container *ngFor=\"let child of children\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n </ng-container>\r\n </ul>\r\n </li>\r\n </ng-template>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-orgchartflex-container{--width: 100px;--height: 100px;--link-color: cadetblue;--print-area-scale: 1}@keyframes fadeIn{0%{transform:scale(0)}to{transform:scale(1)}}.core-orgchartflex-container *{animation:fadeIn .5s ease-in-out}.core-orgchartflex-container .scroll-container{display:block;width:var(--width);height:var(--height);overflow-x:auto}.core-orgchartflex-container .scroll-container .zoom-control{top:var(--size-layout-block-cell-spacing);right:var(--size-layout-block-cell-spacing);z-index:3}.core-orgchartflex-container .scroll-container .zoom-control i{font-size:16px;color:#848484}.core-orgchartflex-container .scroll-container .print-area{transform:scale(var(--print-area-scale));transition:.5s linear;width:6000px!important;height:3000px!important}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul,.core-orgchartflex-container .scroll-container .tree li{list-style:none;margin:0;padding:0;position:relative}.core-orgchartflex-container .scroll-container .tree{margin:0 0 1em;text-align:center}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul{display:table}.core-orgchartflex-container .scroll-container .tree ul{width:100%}.core-orgchartflex-container .scroll-container .tree li{display:table-cell;padding:.5em 0;vertical-align:top!important}.core-orgchartflex-container .scroll-container .tree li:before{outline:solid 1px #666;content:\"\";left:0;position:absolute;right:0;top:0}.core-orgchartflex-container .scroll-container .tree li:first-child:before{left:50%}.core-orgchartflex-container .scroll-container .tree li:last-child:before{right:50%}.core-orgchartflex-container .scroll-container .tree code,.core-orgchartflex-container .scroll-container .tree span{border:solid .1em lightgrey;display:inline-block;margin:0 .2em .5em;padding:.2em .5em;position:relative}.core-orgchartflex-container .scroll-container .tree span.compact{max-width:75px}.core-orgchartflex-container .scroll-container .tree ul:before,.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{outline:solid 1px #666;content:\"\";height:.5em;left:50%;position:absolute}.core-orgchartflex-container .scroll-container .tree ul:before{top:-.5em}.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{top:-.55em}.core-orgchartflex-container .scroll-container .tree>li{margin-top:0}.core-orgchartflex-container .scroll-container .tree>li:before,.core-orgchartflex-container .scroll-container .tree>li:after,.core-orgchartflex-container .scroll-container .tree>li>code:before,.core-orgchartflex-container .scroll-container .tree>li>span:before{outline:none}.core-orgchartflex-container .scroll-container a{text-decoration:unset;color:var(--link-color)!important}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] }); }
81
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "17.2.3", type: CoreOrgchartflexComponent, isStandalone: true, selector: "core-orgchartflex", inputs: { $data: { classPropertyName: "$data", publicName: "$data", isSignal: true, isRequired: true, transformFunction: null }, $itemTemplate: { classPropertyName: "$itemTemplate", publicName: "$itemTemplate", isSignal: true, isRequired: true, transformFunction: null }, $compactMode: { classPropertyName: "$compactMode", publicName: "$compactMode", isSignal: true, isRequired: false, transformFunction: null }, $showDissolved: { classPropertyName: "$showDissolved", publicName: "$showDissolved", isSignal: true, isRequired: false, transformFunction: null }, $width: { classPropertyName: "$width", publicName: "$width", isSignal: true, isRequired: false, transformFunction: null }, $height: { classPropertyName: "$height", publicName: "$height", isSignal: true, isRequired: false, transformFunction: null }, $connectionColor: { classPropertyName: "$connectionColor", publicName: "$connectionColor", isSignal: true, isRequired: false, transformFunction: null }, $connectionSize: { classPropertyName: "$connectionSize", publicName: "$connectionSize", isSignal: true, isRequired: false, transformFunction: null }, $fromChildrenToTopLine: { classPropertyName: "$fromChildrenToTopLine", publicName: "$fromChildrenToTopLine", isSignal: true, isRequired: false, transformFunction: null }, $fromParentToChildrenTopLine: { classPropertyName: "$fromParentToChildrenTopLine", publicName: "$fromParentToChildrenTopLine", isSignal: true, isRequired: false, transformFunction: null }, $childrenHorizontalMargin: { classPropertyName: "$childrenHorizontalMargin", publicName: "$childrenHorizontalMargin", isSignal: true, isRequired: false, transformFunction: null }, $childrenBorderSize: { classPropertyName: "$childrenBorderSize", publicName: "$childrenBorderSize", isSignal: true, isRequired: false, transformFunction: null }, $childrenBorderColor: { classPropertyName: "$childrenBorderColor", publicName: "$childrenBorderColor", isSignal: true, isRequired: false, transformFunction: null } }, outputs: { onPrintAreaRendered: "onPrintAreaRendered" }, viewQueries: [{ propertyName: "$container", first: true, predicate: ["container"], descendants: true, isSignal: true }, { propertyName: "$parent", first: true, predicate: ["parent"], descendants: true, isSignal: true }, { propertyName: "$printArea", first: true, predicate: ["printArea"], descendants: true, isSignal: true }], ngImport: i0, template: "<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: $mouseDown() ? 'all-scroll' : 'unset', width: $width() + 'px', height: $height() + 'px' }\">\r\n\r\n <div class=\"zoom-control p-absolute\">\r\n <div class=\"p-relative d-flex d-flex-start\">\r\n <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"print-area\" #printArea>\r\n\r\n @for (root of $data(); track $index) {\r\n <ul class=\"tree\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n </ul>\r\n }\r\n\r\n </div>\r\n\r\n <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n @if ((!$showDissolved() && !!isActive) || (!!$showDissolved())) {\r\n <li>\r\n @if ($compactMode()) {\r\n <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\" [class.expanded]=\"expanded\">\r\n {{ title }}\r\n </span>\r\n }\r\n \r\n <!-- When passing item template and compactMode=false-->\r\n @if (!$compactMode() && !!$itemTemplate()) {\r\n <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.expanded]=\"expanded\">\r\n <ng-container *ngTemplateOutlet=\"$itemTemplate(); context: { item: context } \"></ng-container>\r\n </span>\r\n }\r\n <!-- ------------------------- -->\r\n \r\n @if (!!expanded && !!children.length) {\r\n <ul>\r\n @for (child of children; track $index) {\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n }\r\n </ul>\r\n }\r\n </li>\r\n }\r\n </ng-template>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-orgchartflex-container{--width: 100px;--height: 100px;--link-color: cadetblue;--print-area-scale: 1;--connection-color: gray;--connection-size: 1px;--from-children-to-top-line: 100px;--from-parent-to-children-top-line: 100px;--children-horizontal-margin: 5px;--children-border-size: 1px;--children-border-color: gray}@keyframes fadeIn{0%{transform:scale(0)}to{transform:scale(1)}}.core-orgchartflex-container *{animation:fadeIn .5s ease-in-out}.core-orgchartflex-container .scroll-container{display:block;width:var(--width);height:var(--height);overflow-x:auto}.core-orgchartflex-container .scroll-container .zoom-control{top:var(--size-layout-block-cell-spacing);right:var(--size-layout-block-cell-spacing);z-index:3}.core-orgchartflex-container .scroll-container .zoom-control i{font-size:16px;color:#848484}.core-orgchartflex-container .scroll-container .print-area{transform:scale(var(--print-area-scale));transition:.5s linear;width:6000px!important;height:3000px!important}.core-orgchartflex-container .scroll-container .tree *{box-sizing:border-box}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul,.core-orgchartflex-container .scroll-container .tree li{list-style:none;margin:0;padding:0;position:relative}.core-orgchartflex-container .scroll-container .tree{margin:0 0 1em;text-align:center}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul{display:table}.core-orgchartflex-container .scroll-container .tree ul{width:100%}.core-orgchartflex-container .scroll-container .tree li{display:table-cell;padding:var(--from-children-to-top-line) 0;vertical-align:top!important}.core-orgchartflex-container .scroll-container .tree li:before{outline:solid calc(var(--connection-size) / 2) var(--connection-color);content:\"\";left:0;position:absolute;right:0;top:0}.core-orgchartflex-container .scroll-container .tree li:first-child:before{left:50%}.core-orgchartflex-container .scroll-container .tree li:last-child:before{right:50%}.core-orgchartflex-container .scroll-container .tree code,.core-orgchartflex-container .scroll-container .tree span{border:solid var(--children-border-size) var(--children-border-color);display:inline-block;margin:0 var(--children-horizontal-margin) var(--from-parent-to-children-top-line);position:relative}.core-orgchartflex-container .scroll-container .tree span.compact{max-width:75px}.core-orgchartflex-container .scroll-container .tree ul:before,.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{outline:solid calc(var(--connection-size) / 2) var(--connection-color);content:\"\";height:calc(var(--from-children-to-top-line) - var(--connection-size));left:50%;position:absolute}.core-orgchartflex-container .scroll-container .tree ul:before{top:calc(var(--from-parent-to-children-top-line) * -1 + var(--connection-size) / 2);height:calc(var(--from-parent-to-children-top-line) - var(--connection-size) * 1.5 + 1px)}.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{top:calc(var(--from-children-to-top-line) * -1 + var(--connection-size) / 2 - var(--children-border-size))}.core-orgchartflex-container .scroll-container .tree>li{margin-top:0}.core-orgchartflex-container .scroll-container .tree>li:before,.core-orgchartflex-container .scroll-container .tree>li:after,.core-orgchartflex-container .scroll-container .tree>li>code:before,.core-orgchartflex-container .scroll-container .tree>li>span:before{outline:none}.core-orgchartflex-container .scroll-container a{text-decoration:unset;color:var(--link-color)!important}\n"], dependencies: [{ kind: "directive", type: NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }, { kind: "directive", type: NgTemplateOutlet, selector: "[ngTemplateOutlet]", inputs: ["ngTemplateOutletContext", "ngTemplateOutlet", "ngTemplateOutletInjector"] }], changeDetection: i0.ChangeDetectionStrategy.OnPush }); }
72
82
  }
73
83
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImport: i0, type: CoreOrgchartflexComponent, decorators: [{
74
84
  type: Component,
75
- args: [{ selector: 'core-orgchartflex', standalone: true, imports: [
76
- CommonModule
77
- ], template: "<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: mouseDown ? 'all-scroll' : 'unset'}\">\r\n\r\n <div class=\"zoom-control p-absolute\">\r\n <div class=\"p-relative d-flex d-flex-start\">\r\n <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"print-area\" #printArea>\r\n\r\n <ul class=\"tree\" *ngFor=\"let root of data\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n </ul>\r\n\r\n </div>\r\n\r\n <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n <li *ngIf=\"(!showDissolved && !!isActive) || (!!showDissolved)\">\r\n <span *ngIf=\"!!compactMode\" (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\">\r\n {{ title }}\r\n </span>\r\n\r\n <!-- When passing item template and compactMode=false-->\r\n <span *ngIf=\"!!!compactMode && !!itemTemplate\" (click)=\"toggleExpand(context)\" class=\"pointer\">\r\n <ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: context } \"></ng-container>\r\n </span>\r\n <!-- ------------------------- -->\r\n\r\n <ul *ngIf=\"!!expanded && !!children.length \">\r\n <ng-container *ngFor=\"let child of children\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n </ng-container>\r\n </ul>\r\n </li>\r\n </ng-template>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-orgchartflex-container{--width: 100px;--height: 100px;--link-color: cadetblue;--print-area-scale: 1}@keyframes fadeIn{0%{transform:scale(0)}to{transform:scale(1)}}.core-orgchartflex-container *{animation:fadeIn .5s ease-in-out}.core-orgchartflex-container .scroll-container{display:block;width:var(--width);height:var(--height);overflow-x:auto}.core-orgchartflex-container .scroll-container .zoom-control{top:var(--size-layout-block-cell-spacing);right:var(--size-layout-block-cell-spacing);z-index:3}.core-orgchartflex-container .scroll-container .zoom-control i{font-size:16px;color:#848484}.core-orgchartflex-container .scroll-container .print-area{transform:scale(var(--print-area-scale));transition:.5s linear;width:6000px!important;height:3000px!important}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul,.core-orgchartflex-container .scroll-container .tree li{list-style:none;margin:0;padding:0;position:relative}.core-orgchartflex-container .scroll-container .tree{margin:0 0 1em;text-align:center}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul{display:table}.core-orgchartflex-container .scroll-container .tree ul{width:100%}.core-orgchartflex-container .scroll-container .tree li{display:table-cell;padding:.5em 0;vertical-align:top!important}.core-orgchartflex-container .scroll-container .tree li:before{outline:solid 1px #666;content:\"\";left:0;position:absolute;right:0;top:0}.core-orgchartflex-container .scroll-container .tree li:first-child:before{left:50%}.core-orgchartflex-container .scroll-container .tree li:last-child:before{right:50%}.core-orgchartflex-container .scroll-container .tree code,.core-orgchartflex-container .scroll-container .tree span{border:solid .1em lightgrey;display:inline-block;margin:0 .2em .5em;padding:.2em .5em;position:relative}.core-orgchartflex-container .scroll-container .tree span.compact{max-width:75px}.core-orgchartflex-container .scroll-container .tree ul:before,.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{outline:solid 1px #666;content:\"\";height:.5em;left:50%;position:absolute}.core-orgchartflex-container .scroll-container .tree ul:before{top:-.5em}.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{top:-.55em}.core-orgchartflex-container .scroll-container .tree>li{margin-top:0}.core-orgchartflex-container .scroll-container .tree>li:before,.core-orgchartflex-container .scroll-container .tree>li:after,.core-orgchartflex-container .scroll-container .tree>li>code:before,.core-orgchartflex-container .scroll-container .tree>li>span:before{outline:none}.core-orgchartflex-container .scroll-container a{text-decoration:unset;color:var(--link-color)!important}\n"] }]
78
- }], ctorParameters: () => [], propDecorators: { data: [{
79
- type: Input
80
- }], itemTemplate: [{
81
- type: Input
82
- }], compactMode: [{
83
- type: Input
84
- }], showDissolved: [{
85
- type: Input
86
- }], width: [{
87
- type: Input
88
- }], height: [{
89
- type: Input
90
- }], onPrintAreaRendered: [{
85
+ args: [{ selector: 'core-orgchartflex', standalone: true, changeDetection: ChangeDetectionStrategy.OnPush, imports: [
86
+ NgStyle,
87
+ NgTemplateOutlet,
88
+ ], template: "<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: $mouseDown() ? 'all-scroll' : 'unset', width: $width() + 'px', height: $height() + 'px' }\">\r\n\r\n <div class=\"zoom-control p-absolute\">\r\n <div class=\"p-relative d-flex d-flex-start\">\r\n <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n </div>\r\n </div>\r\n\r\n <div class=\"print-area\" #printArea>\r\n\r\n @for (root of $data(); track $index) {\r\n <ul class=\"tree\">\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n </ul>\r\n }\r\n\r\n </div>\r\n\r\n <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n @if ((!$showDissolved() && !!isActive) || (!!$showDissolved())) {\r\n <li>\r\n @if ($compactMode()) {\r\n <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\" [class.expanded]=\"expanded\">\r\n {{ title }}\r\n </span>\r\n }\r\n \r\n <!-- When passing item template and compactMode=false-->\r\n @if (!$compactMode() && !!$itemTemplate()) {\r\n <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.expanded]=\"expanded\">\r\n <ng-container *ngTemplateOutlet=\"$itemTemplate(); context: { item: context } \"></ng-container>\r\n </span>\r\n }\r\n <!-- ------------------------- -->\r\n \r\n @if (!!expanded && !!children.length) {\r\n <ul>\r\n @for (child of children; track $index) {\r\n <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n }\r\n </ul>\r\n }\r\n </li>\r\n }\r\n </ng-template>\r\n\r\n </div>\r\n\r\n</div>", styles: [".core-orgchartflex-container{--width: 100px;--height: 100px;--link-color: cadetblue;--print-area-scale: 1;--connection-color: gray;--connection-size: 1px;--from-children-to-top-line: 100px;--from-parent-to-children-top-line: 100px;--children-horizontal-margin: 5px;--children-border-size: 1px;--children-border-color: gray}@keyframes fadeIn{0%{transform:scale(0)}to{transform:scale(1)}}.core-orgchartflex-container *{animation:fadeIn .5s ease-in-out}.core-orgchartflex-container .scroll-container{display:block;width:var(--width);height:var(--height);overflow-x:auto}.core-orgchartflex-container .scroll-container .zoom-control{top:var(--size-layout-block-cell-spacing);right:var(--size-layout-block-cell-spacing);z-index:3}.core-orgchartflex-container .scroll-container .zoom-control i{font-size:16px;color:#848484}.core-orgchartflex-container .scroll-container .print-area{transform:scale(var(--print-area-scale));transition:.5s linear;width:6000px!important;height:3000px!important}.core-orgchartflex-container .scroll-container .tree *{box-sizing:border-box}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul,.core-orgchartflex-container .scroll-container .tree li{list-style:none;margin:0;padding:0;position:relative}.core-orgchartflex-container .scroll-container .tree{margin:0 0 1em;text-align:center}.core-orgchartflex-container .scroll-container .tree,.core-orgchartflex-container .scroll-container .tree ul{display:table}.core-orgchartflex-container .scroll-container .tree ul{width:100%}.core-orgchartflex-container .scroll-container .tree li{display:table-cell;padding:var(--from-children-to-top-line) 0;vertical-align:top!important}.core-orgchartflex-container .scroll-container .tree li:before{outline:solid calc(var(--connection-size) / 2) var(--connection-color);content:\"\";left:0;position:absolute;right:0;top:0}.core-orgchartflex-container .scroll-container .tree li:first-child:before{left:50%}.core-orgchartflex-container .scroll-container .tree li:last-child:before{right:50%}.core-orgchartflex-container .scroll-container .tree code,.core-orgchartflex-container .scroll-container .tree span{border:solid var(--children-border-size) var(--children-border-color);display:inline-block;margin:0 var(--children-horizontal-margin) var(--from-parent-to-children-top-line);position:relative}.core-orgchartflex-container .scroll-container .tree span.compact{max-width:75px}.core-orgchartflex-container .scroll-container .tree ul:before,.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{outline:solid calc(var(--connection-size) / 2) var(--connection-color);content:\"\";height:calc(var(--from-children-to-top-line) - var(--connection-size));left:50%;position:absolute}.core-orgchartflex-container .scroll-container .tree ul:before{top:calc(var(--from-parent-to-children-top-line) * -1 + var(--connection-size) / 2);height:calc(var(--from-parent-to-children-top-line) - var(--connection-size) * 1.5 + 1px)}.core-orgchartflex-container .scroll-container .tree code:before,.core-orgchartflex-container .scroll-container .tree span:before{top:calc(var(--from-children-to-top-line) * -1 + var(--connection-size) / 2 - var(--children-border-size))}.core-orgchartflex-container .scroll-container .tree>li{margin-top:0}.core-orgchartflex-container .scroll-container .tree>li:before,.core-orgchartflex-container .scroll-container .tree>li:after,.core-orgchartflex-container .scroll-container .tree>li>code:before,.core-orgchartflex-container .scroll-container .tree>li>span:before{outline:none}.core-orgchartflex-container .scroll-container a{text-decoration:unset;color:var(--link-color)!important}\n"] }]
89
+ }], ctorParameters: () => [], propDecorators: { onPrintAreaRendered: [{
91
90
  type: Output
92
- }], container: [{
93
- type: ViewChild,
94
- args: ['container']
95
- }], parent: [{
96
- type: ViewChild,
97
- args: ['parent']
98
- }], printArea: [{
99
- type: ViewChild,
100
- args: ['printArea']
101
91
  }] } });
102
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-orgchartflex.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.html"],"names":[],"mappings":"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","sourcesContent":["import { CommonModule } from '@angular/common';\r\nimport { AfterViewInit, Component, ElementRef, EventEmitter, Input, OnChanges, OnInit, Output, SimpleChanges, TemplateRef, ViewChild } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'core-orgchartflex',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule\r\n  ],\r\n  templateUrl: './core-orgchartflex.component.html',\r\n  styleUrls: ['./core-orgchartflex.component.scss']\r\n})\r\nexport class CoreOrgchartflexComponent implements OnChanges, OnInit, AfterViewInit {\r\n\r\n  @Input() data!: any[];\r\n  @Input() itemTemplate!: TemplateRef<any>;\r\n  @Input() compactMode!: boolean;\r\n  @Input() showDissolved!: boolean;\r\n  @Input() width!: number;\r\n  @Input() height!: number;\r\n  @Output() onPrintAreaRendered = new EventEmitter(); \r\n\r\n  @ViewChild('container') container!: ElementRef;\r\n  @ViewChild('parent') parent!: ElementRef;\r\n  @ViewChild('printArea') printArea!: ElementRef;\r\n\r\n  mouseDown = false;\r\n  startX: any;\r\n  scrollLeft: any;\r\n  startY: any;\r\n  scrollTop: any;\r\n\r\n  scale: number = 1;\r\n\r\n  startDragging(e: any, flag: any) {\r\n    this.mouseDown = true;\r\n    this.startX = e.pageX - this.parent?.nativeElement.offsetLeft;\r\n    this.scrollLeft = this.parent?.nativeElement.scrollLeft;\r\n    this.startY = e.pageY - this.parent?.nativeElement.offsetTop;\r\n    this.scrollTop = this.parent?.nativeElement.scrollTop;\r\n  }\r\n\r\n  stopDragging(e: any, flag: any) {\r\n    this.mouseDown = false;\r\n  }\r\n\r\n  moveEvent(e: any) {\r\n    e.preventDefault();\r\n    if (!this.mouseDown) {\r\n      return;\r\n    }\r\n    const x = e.pageX - this.parent?.nativeElement.offsetLeft;\r\n    const scrollX = x - this.startX;\r\n    this.parent!.nativeElement.scrollLeft = this.scrollLeft - scrollX;\r\n    const y = e.pageY - this.parent?.nativeElement.offsetTop;\r\n    const scrollY = y - this.startY;\r\n    this.parent!.nativeElement.scrollTop = this.scrollTop - scrollY;\r\n\r\n  }\r\n\r\n  constructor() { }\r\n\r\n  ngOnChanges(changes: SimpleChanges): void {\r\n    if (changes['width'] || changes['height']) {\r\n      this.setGeometricRect();\r\n    }\r\n  }\r\n\r\n  ngOnInit(): void {\r\n  }\r\n\r\n  setGeometricRect(): void {\r\n    const style = this.container?.nativeElement.style;\r\n    if (!!!style) return;\r\n    if (!!this.width) style.setProperty('--width', this.width + 'px')\r\n    if (!!this.height) style.setProperty('--height', this.height + 'px')\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.setGeometricRect();\r\n      this.onPrintAreaRendered.emit(this.printArea)\r\n    })\r\n  }\r\n\r\n  toggleExpand(e: any): void {\r\n    e.tree$Expanded = !!!e.tree$Expanded\r\n  }\r\n\r\n  zoonIn(): void {\r\n    this.scale = this.scale * 1.1;\r\n    this.container.nativeElement.style.setProperty('--print-area-scale', this.scale)\r\n  }\r\n\r\n  zoonOut(): void {\r\n    this.scale = this.scale / 1.1;\r\n    this.container.nativeElement.style.setProperty('--print-area-scale', this.scale)\r\n  }\r\n\r\n  zoonFeat(): void {\r\n    this.scale = 1;\r\n    this.container.nativeElement.style.setProperty('--print-area-scale', this.scale)\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n    (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n    <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: mouseDown ? 'all-scroll' : 'unset'}\">\r\n\r\n        <div class=\"zoom-control p-absolute\">\r\n            <div class=\"p-relative d-flex d-flex-start\">\r\n                <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n                <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n                <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"print-area\" #printArea>\r\n\r\n            <ul class=\"tree\" *ngFor=\"let root of data\">\r\n                <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n            </ul>\r\n\r\n        </div>\r\n\r\n        <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n            let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n            <li *ngIf=\"(!showDissolved && !!isActive) || (!!showDissolved)\">\r\n                <span *ngIf=\"!!compactMode\" (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\">\r\n                    {{ title }}\r\n                </span>\r\n\r\n                <!-- When passing item template and compactMode=false-->\r\n                <span *ngIf=\"!!!compactMode && !!itemTemplate\" (click)=\"toggleExpand(context)\" class=\"pointer\">\r\n                    <ng-container *ngTemplateOutlet=\"itemTemplate; context: { item: context } \"></ng-container>\r\n                </span>\r\n                <!-- -------------------------  -->\r\n\r\n                <ul *ngIf=\"!!expanded && !!children.length \">\r\n                    <ng-container *ngFor=\"let child of children\">\r\n                        <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n                    </ng-container>\r\n                </ul>\r\n            </li>\r\n        </ng-template>\r\n\r\n    </div>\r\n\r\n</div>"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-orgchartflex.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.ts","../../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.html"],"names":[],"mappings":"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","sourcesContent":["import { NgStyle, NgTemplateOutlet } from '@angular/common';\r\nimport { AfterViewInit, ChangeDetectionStrategy, ChangeDetectorRef, Component, ElementRef, EventEmitter, inject, input, Output, signal, TemplateRef, viewChild, WritableSignal } from '@angular/core';\r\n\r\n@Component({\r\n  selector: 'core-orgchartflex',\r\n  standalone: true,\r\n  changeDetection: ChangeDetectionStrategy.OnPush,\r\n  imports: [\r\n    NgStyle,\r\n    NgTemplateOutlet,\r\n  ],\r\n  templateUrl: './core-orgchartflex.component.html',\r\n  styleUrls: ['./core-orgchartflex.component.scss']\r\n})\r\nexport class CoreOrgchartflexComponent implements AfterViewInit {\r\n\r\n  $data = input.required<any[]>();\r\n  $itemTemplate = input.required<TemplateRef<any>>();\r\n  $compactMode = input<boolean>();\r\n  $showDissolved = input<boolean>();\r\n  $width = input<number>();\r\n  $height = input<number>();\r\n\r\n  $connectionColor = input<string>();\r\n  $connectionSize = input<number>(); // in pixel\r\n  $fromChildrenToTopLine = input<number>(); // in pixel\r\n  $fromParentToChildrenTopLine = input<number>(); // in pixel\r\n  $childrenHorizontalMargin = input<number>(); // in pixel\r\n  $childrenBorderSize = input<number>(); // in pixel\r\n  $childrenBorderColor = input<string>(); // in pixel\r\n\r\n  @Output() onPrintAreaRendered = new EventEmitter(); \r\n\r\n  $container = viewChild<ElementRef>('container');\r\n  $parent = viewChild<ElementRef>('parent');\r\n  $printArea = viewChild<ElementRef>('printArea');\r\n\r\n  $mouseDown = signal(false);\r\n  $startX: WritableSignal<any> = signal(undefined);\r\n  $scrollLeft: WritableSignal<any> = signal(undefined);\r\n  $startY: WritableSignal<any> = signal(undefined);\r\n  $scrollTop: WritableSignal<any> = signal(undefined);\r\n\r\n  $scale: WritableSignal<number> = signal(1);\r\n\r\n  cdr = inject(ChangeDetectorRef);\r\n\r\n  startDragging(e: any, flag: any) {\r\n    this.$mouseDown.set(true);\r\n    this.$startX.set(e.pageX - this.$parent()?.nativeElement.offsetLeft);\r\n    this.$scrollLeft.set(this.$parent()?.nativeElement.scrollLeft);\r\n    this.$startY.set(e.pageY - this.$parent()?.nativeElement.offsetTop);\r\n    this.$scrollTop.set(this.$parent()?.nativeElement.scrollTop);\r\n  }\r\n\r\n  stopDragging(e: any, flag: any) {\r\n    this.$mouseDown.set(false);\r\n  }\r\n\r\n  moveEvent(e: any) {\r\n    e.preventDefault();\r\n    if (!this.$mouseDown()) {\r\n      return;\r\n    }\r\n    const x = e.pageX - this.$parent()?.nativeElement.offsetLeft;\r\n    const scrollX = x - this.$startX();\r\n    this.$parent()!.nativeElement.scrollLeft = this.$scrollLeft() - scrollX;\r\n    const y = e.pageY - this.$parent()?.nativeElement.offsetTop;\r\n    const scrollY = y - this.$startY();\r\n    this.$parent()!.nativeElement.scrollTop = this.$scrollTop() - scrollY;\r\n\r\n  }\r\n\r\n  constructor() { }\r\n\r\n  toggleExpand(e: any): void {\r\n    e.tree$Expanded = !!!e.tree$Expanded\r\n  }\r\n\r\n  zoonIn(): void {\r\n    this.$scale.set(this.$scale() * 1.1);\r\n    this.$container()!.nativeElement.style.setProperty('--print-area-scale', this.$scale())\r\n  }\r\n\r\n  zoonOut(): void {\r\n    this.$scale.set(this.$scale() / 1.1);\r\n    this.$container()!.nativeElement.style.setProperty('--print-area-scale', this.$scale())\r\n  }\r\n\r\n  zoonFeat(): void {\r\n    this.$scale.set(1);\r\n    this.$container()!.nativeElement.style.setProperty('--print-area-scale', this.$scale())\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      var style = this.$container()?.nativeElement.style;\r\n      style.setProperty('--connection-color', this.$connectionColor())\r\n      style.setProperty('--connection-size', this.$connectionSize() + 'px')\r\n      style.setProperty('--from-children-to-top-line', this.$fromChildrenToTopLine() + 'px')\r\n      style.setProperty('--from-parent-to-children-top-line', this.$fromParentToChildrenTopLine() + 'px')\r\n      style.setProperty('--children-horizontal-margin', this.$childrenHorizontalMargin() + 'px')\r\n      style.setProperty('--children-border-size', this.$childrenBorderSize() + 'px')\r\n      style.setProperty('--children-border-color', this.$childrenBorderColor())\r\n    })\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-orgchartflex-container\" (mousedown)=\"startDragging($event, false)\"\r\n    (mouseup)=\"stopDragging($event, false)\" (mouseleave)=\"stopDragging($event, false)\" (mousemove)=\"moveEvent($event)\">\r\n\r\n    <div class=\"scroll-container\" #parent [ngStyle]=\"{ cursor: $mouseDown() ? 'all-scroll' : 'unset', width: $width() + 'px', height: $height() + 'px' }\">\r\n\r\n        <div class=\"zoom-control p-absolute\">\r\n            <div class=\"p-relative d-flex d-flex-start\">\r\n                <i class=\"feather-minus-circle pointer\" (click)=\"zoonOut()\"></i>\r\n                <i class=\"feather-plus-circle pointer\" (click)=\"zoonIn()\"></i>\r\n                <i class=\"feather-monitor pointer\" (click)=\"zoonFeat()\"></i>\r\n            </div>\r\n        </div>\r\n\r\n        <div class=\"print-area\" #printArea>\r\n\r\n            @for (root of $data(); track $index) {\r\n                <ul class=\"tree\">\r\n                    <ng-container *ngTemplateOutlet=\"item; context: { context: root}\"></ng-container>\r\n                </ul>\r\n            }\r\n\r\n        </div>\r\n\r\n        <ng-template #item let-context=\"context\" let-title=\"context.tree$Title\" let-expanded=\"context.tree$Expanded\"\r\n            let-children=\"context.tree$Children\" let-tier=\"context.tree$Tier\" let-isActive=\"context.isActive\">\r\n            @if ((!$showDissolved() && !!isActive) || (!!$showDissolved())) {\r\n                <li>\r\n                    @if ($compactMode()) {\r\n                        <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.compact]=\"tier !== 1\" [class.expanded]=\"expanded\">\r\n                            {{ title }}\r\n                        </span>\r\n                    }\r\n    \r\n                    <!-- When passing item template and compactMode=false-->\r\n                    @if (!$compactMode() && !!$itemTemplate()) {\r\n                        <span (click)=\"toggleExpand(context)\" class=\"pointer\" [class.expanded]=\"expanded\">\r\n                            <ng-container *ngTemplateOutlet=\"$itemTemplate(); context: { item: context } \"></ng-container>\r\n                        </span>\r\n                    }\r\n                    <!-- -------------------------  -->\r\n    \r\n                    @if (!!expanded && !!children.length) {\r\n                        <ul>\r\n                            @for (child of children; track $index) {\r\n                                <ng-container *ngTemplateOutlet=\"item; context: { context: child}\"></ng-container>\r\n                            }\r\n                        </ul>\r\n                    }\r\n                </li>\r\n            }\r\n        </ng-template>\r\n\r\n    </div>\r\n\r\n</div>"]}