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.
- package/esm2022/lib/app/http-interceptors/app-type-interceptor.mjs +40 -0
- package/esm2022/lib/app/http-interceptors/index.mjs +4 -2
- package/esm2022/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.mjs +63 -73
- package/esm2022/lib/app/libraries/core-table/core-table.component.mjs +3 -3
- package/esm2022/lib/app/libraries/navigator/navigator/navigator.component.mjs +6 -6
- package/esm2022/lib/app/services/sys-menu.service.mjs +5 -5
- package/fesm2022/ngx-histaff-alpha.mjs +109 -81
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/http-interceptors/app-type-interceptor.d.ts +12 -0
- package/lib/app/http-interceptors/index.d.ts +6 -1
- package/lib/app/libraries/core-orgchartflex/core-orgchartflex/core-orgchartflex.component.d.ts +27 -22
- package/lib/app/services/sys-menu.service.d.ts +2 -2
- package/package.json +1 -1
|
@@ -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,
|
|
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 {
|
|
2
|
-
import { Component, EventEmitter,
|
|
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.
|
|
8
|
-
this.
|
|
9
|
-
this.
|
|
10
|
-
this.
|
|
11
|
-
this.
|
|
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.
|
|
13
|
+
this.$mouseDown.set(false);
|
|
15
14
|
}
|
|
16
15
|
moveEvent(e) {
|
|
17
16
|
e.preventDefault();
|
|
18
|
-
if (!this
|
|
17
|
+
if (!this.$mouseDown()) {
|
|
19
18
|
return;
|
|
20
19
|
}
|
|
21
|
-
const x = e.pageX - this
|
|
22
|
-
const scrollX = x - this
|
|
23
|
-
this
|
|
24
|
-
const y = e.pageY - this
|
|
25
|
-
const scrollY = y - this
|
|
26
|
-
this
|
|
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
|
|
31
|
-
this
|
|
32
|
-
|
|
33
|
-
|
|
34
|
-
|
|
35
|
-
|
|
36
|
-
|
|
37
|
-
|
|
38
|
-
|
|
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.
|
|
60
|
-
this
|
|
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.
|
|
64
|
-
this
|
|
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.
|
|
68
|
-
this
|
|
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: "
|
|
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
|
-
|
|
77
|
-
|
|
78
|
-
|
|
79
|
-
|
|
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":"AAAA,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAiB,SAAS,EAAc,YAAY,EAAE,KAAK,EAAqB,MAAM,EAA8B,SAAS,EAAE,MAAM,eAAe,CAAC;;;AAW5J,MAAM,OAAO,yBAAyB;IAsBpC,aAAa,CAAC,CAAM,EAAE,IAAS;QAC7B,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC;QACtB,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC;QAC9D,IAAI,CAAC,UAAU,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC;QACxD,IAAI,CAAC,MAAM,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,SAAS,CAAC;QAC7D,IAAI,CAAC,SAAS,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,SAAS,CAAC;IACxD,CAAC;IAED,YAAY,CAAC,CAAM,EAAE,IAAS;QAC5B,IAAI,CAAC,SAAS,GAAG,KAAK,CAAC;IACzB,CAAC;IAED,SAAS,CAAC,CAAM;QACd,CAAC,CAAC,cAAc,EAAE,CAAC;QACnB,IAAI,CAAC,IAAI,CAAC,SAAS,EAAE;YACnB,OAAO;SACR;QACD,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,UAAU,CAAC;QAC1D,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;QAChC,IAAI,CAAC,MAAO,CAAC,aAAa,CAAC,UAAU,GAAG,IAAI,CAAC,UAAU,GAAG,OAAO,CAAC;QAClE,MAAM,CAAC,GAAG,CAAC,CAAC,KAAK,GAAG,IAAI,CAAC,MAAM,EAAE,aAAa,CAAC,SAAS,CAAC;QACzD,MAAM,OAAO,GAAG,CAAC,GAAG,IAAI,CAAC,MAAM,CAAC;QAChC,IAAI,CAAC,MAAO,CAAC,aAAa,CAAC,SAAS,GAAG,IAAI,CAAC,SAAS,GAAG,OAAO,CAAC;IAElE,CAAC;IAED;QAxCU,wBAAmB,GAAG,IAAI,YAAY,EAAE,CAAC;QAMnD,cAAS,GAAG,KAAK,CAAC;QAMlB,UAAK,GAAW,CAAC,CAAC;IA4BF,CAAC;IAEjB,WAAW,CAAC,OAAsB;QAChC,IAAI,OAAO,CAAC,OAAO,CAAC,IAAI,OAAO,CAAC,QAAQ,CAAC,EAAE;YACzC,IAAI,CAAC,gBAAgB,EAAE,CAAC;SACzB;IACH,CAAC;IAED,QAAQ;IACR,CAAC;IAED,gBAAgB;QACd,MAAM,KAAK,GAAG,IAAI,CAAC,SAAS,EAAE,aAAa,CAAC,KAAK,CAAC;QAClD,IAAI,CAAC,CAAC,CAAC,KAAK;YAAE,OAAO;QACrB,IAAI,CAAC,CAAC,IAAI,CAAC,KAAK;YAAE,KAAK,CAAC,WAAW,CAAC,SAAS,EAAE,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,CAAA;QACjE,IAAI,CAAC,CAAC,IAAI,CAAC,MAAM;YAAE,KAAK,CAAC,WAAW,CAAC,UAAU,EAAE,IAAI,CAAC,MAAM,GAAG,IAAI,CAAC,CAAA;IACtE,CAAC;IAED,eAAe;QACb,UAAU,CAAC,GAAG,EAAE;YACd,IAAI,CAAC,gBAAgB,EAAE,CAAC;YACxB,IAAI,CAAC,mBAAmB,CAAC,IAAI,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QAC/C,CAAC,CAAC,CAAA;IACJ,CAAC;IAED,YAAY,CAAC,CAAM;QACjB,CAAC,CAAC,aAAa,GAAG,CAAC,CAAC,CAAC,CAAC,CAAC,aAAa,CAAA;IACtC,CAAC;IAED,MAAM;QACJ,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;IAClF,CAAC;IAED,OAAO;QACL,IAAI,CAAC,KAAK,GAAG,IAAI,CAAC,KAAK,GAAG,GAAG,CAAC;QAC9B,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;IAClF,CAAC;IAED,QAAQ;QACN,IAAI,CAAC,KAAK,GAAG,CAAC,CAAC;QACf,IAAI,CAAC,SAAS,CAAC,aAAa,CAAC,KAAK,CAAC,WAAW,CAAC,oBAAoB,EAAE,IAAI,CAAC,KAAK,CAAC,CAAA;IAClF,CAAC;8GA1FU,yBAAyB;kGAAzB,yBAAyB,qkBCZtC,0yEA4CM,i6FDrCF,YAAY;;2FAKH,yBAAyB;kBATrC,SAAS;+BACE,mBAAmB,cACjB,IAAI,WACP;wBACP,YAAY;qBACb;wDAMQ,IAAI;sBAAZ,KAAK;gBACG,YAAY;sBAApB,KAAK;gBACG,WAAW;sBAAnB,KAAK;gBACG,aAAa;sBAArB,KAAK;gBACG,KAAK;sBAAb,KAAK;gBACG,MAAM;sBAAd,KAAK;gBACI,mBAAmB;sBAA5B,MAAM;gBAEiB,SAAS;sBAAhC,SAAS;uBAAC,WAAW;gBACD,MAAM;sBAA1B,SAAS;uBAAC,QAAQ;gBACK,SAAS;sBAAhC,SAAS;uBAAC,WAAW","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>"]}
|