ngx-histaff-alpha 3.2.2 → 3.2.3
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/libraries/core-org-param/core-org-param.component.mjs +16 -18
- package/fesm2022/ngx-histaff-alpha.mjs +15 -17
- package/fesm2022/ngx-histaff-alpha.mjs.map +1 -1
- package/lib/app/libraries/core-org-param/core-org-param.component.d.ts +2 -0
- package/lib/app/libraries/core-table/core-table.component.d.ts +1 -1
- package/package.json +1 -1
|
@@ -19,6 +19,7 @@ export class CoreOrgParamComponent extends CoreFormControlBaseComponent {
|
|
|
19
19
|
this.organizationService = organizationService;
|
|
20
20
|
this.accessorMode = EnumCoreOrgTreeaAccessorMode.ACTIVATED_INHERITANCE;
|
|
21
21
|
this.pendingIds = [];
|
|
22
|
+
this.subscriptions = [];
|
|
22
23
|
this.seekerService.sourceSpaceHeight$.subscribe(x => {
|
|
23
24
|
this.sourceSpaceHeight = x;
|
|
24
25
|
this.sourceContainerHeight = this.showPageHeader ? x - this.layoutService.corePageHeaderHeight - 68 : x - 68;
|
|
@@ -28,27 +29,24 @@ export class CoreOrgParamComponent extends CoreFormControlBaseComponent {
|
|
|
28
29
|
ngAfterViewInit() {
|
|
29
30
|
setTimeout(() => {
|
|
30
31
|
this.writeValue(this.organizationService.status$.value.activeKeys.map(x => Number(x)));
|
|
32
|
+
this.subscriptions.push(this.organizationService.status$.subscribe(x => {
|
|
33
|
+
if (!!x.selectedKey) {
|
|
34
|
+
const filteredLinearData = this.organizationService.linerData$.value.filter(i => i.id === Number(x.selectedKey));
|
|
35
|
+
if (!!filteredLinearData.length) {
|
|
36
|
+
this.valueToShow = filteredLinearData[0].tree$Title;
|
|
37
|
+
}
|
|
38
|
+
else {
|
|
39
|
+
this.valueToShow = '';
|
|
40
|
+
}
|
|
41
|
+
}
|
|
42
|
+
else {
|
|
43
|
+
this.valueToShow = '';
|
|
44
|
+
}
|
|
45
|
+
}));
|
|
31
46
|
});
|
|
32
47
|
}
|
|
33
48
|
writeValue(obj) {
|
|
34
49
|
this.value = obj;
|
|
35
|
-
const filteredLinearData = this.organizationService.linerData$.value
|
|
36
|
-
.filter(x => obj?.includes(x.id));
|
|
37
|
-
if (!filteredLinearData.length) {
|
|
38
|
-
this.valueToShow = '';
|
|
39
|
-
}
|
|
40
|
-
else {
|
|
41
|
-
try {
|
|
42
|
-
const tryFindTheShortedPath = filteredLinearData
|
|
43
|
-
.reduce((shortest, current) => {
|
|
44
|
-
return current.tree$Path.length < shortest.tree$Path.length ? current : shortest;
|
|
45
|
-
}, filteredLinearData[0]);
|
|
46
|
-
this.valueToShow = tryFindTheShortedPath.tree$Title;
|
|
47
|
-
}
|
|
48
|
-
catch {
|
|
49
|
-
this.valueToShow = "";
|
|
50
|
-
}
|
|
51
|
-
}
|
|
52
50
|
}
|
|
53
51
|
onCancel() {
|
|
54
52
|
this.sourceOpen = false;
|
|
@@ -106,4 +104,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.2.3", ngImpor
|
|
|
106
104
|
},
|
|
107
105
|
], template: "<div #container class=\"core-org-param-container\">\r\n <div class=\"input-wrapper\">\r\n <label #shownText type=\"text\" class=\"text form-control pointer\" (click)=\"onClickSeek()\">\r\n <span [appTooltip]=\"valueToShow\">{{ valueToShow }}</span>\r\n </label>\r\n </div>\r\n <div class=\"seeker-icon-wrapper\" (click)=\"onClickSeek()\">\r\n <div class=\"flex-wrapper\">\r\n <i class=\"feather-search\"></i>\r\n </div>\r\n </div>\r\n\r\n @if (!!sourceOpen) {\r\n <div class=\"modal-container\">\r\n <div class=\"modal-content-root\" [ngStyle]=\"{ padding: '0px' }\">\r\n\r\n <div class=\"source-space\" [ngStyle]=\"{\r\n height: sourceSpaceHeight + 'px',\r\n overflow: 'hidden',\r\n boxSizing: 'border-box',\r\n }\">\r\n <div class=\"source-container\" [ngStyle]=\"{\r\n height: sourceContainerHeight + 'px',\r\n paddingTop: '0px',\r\n paddingBottom: '0px'\r\n }\">\r\n <i class=\"close-icon feather-x d-block\" (click)=\"onCancel()\"></i>\r\n\r\n <core-org-unit-seeker [accessorMode]=\"accessorMode\" [height]=\"childComponentHeight\" (itemClick)=\"onItemClick($event)\" (itemDoubleClick)=\"onItemDoubleClick($event)\" (idsChange)=\"onIdsChange($event)\"\r\n [height]=\"childComponentHeight\"></core-org-unit-seeker>\r\n\r\n </div>\r\n\r\n <div class=\"footer\">\r\n <div class=\"d-flex-end\">\r\n @if (!!pendingIds.length) {\r\n <button class=\"btn btn-primary\" type=\"button\" (click)=\"onSelect()\">{{\r\n 'UI_CORE_CONFIRM_DIALOG_BUTTON_SELECT' | translate: lang }}</button>\r\n }\r\n <button class=\"btn btn-secondary\" type=\"button\" (click)=\"onCancel()\">{{\r\n 'UI_CORE_CONFIRM_DIALOG_BUTTON_CANCEL' | translate: lang }}</button>\r\n </div>\r\n </div>\r\n\r\n </div>\r\n\r\n </div>\r\n </div>\r\n }\r\n\r\n</div>", styles: [".core-org-param-container{display:block;position:relative;background-color:#fff}.core-org-param-container>.seeker-icon-wrapper{display:block;position:absolute;background-color:#e9e9e9;right:3px;top:3px;width:29px;height:29px;border-radius:.275rem;cursor:pointer}.core-org-param-container>.seeker-icon-wrapper>.flex-wrapper{width:29px;height:29px;display:flex;align-items:center;justify-content:center}.core-org-param-container>.seeker-icon-wrapper>.flex-wrapper>i.close-icon{color:#848484;font-size:20px}.core-org-param-container .input-wrapper{height:var(--size-form-control-height)}.core-org-param-container .input-wrapper label.text span{display:block;height:calc(var(--size-form-control-height) - 12px);line-height:calc(var(--size-form-control-height) - 12px);width:calc(100% - var(--size-form-control-height));overflow:hidden;white-space:nowrap;text-overflow:ellipsis;color:inherit}.core-org-param-container .input-wrapper .clear-icon-wrapper{display:none;position:absolute;background-color:transparent;right:28px;top:3px;width:29px;height:29px;border-radius:.275rem;cursor:pointer}.core-org-param-container .input-wrapper .clear-icon-wrapper>.flex-wrapper{width:29px;height:29px;display:flex;align-items:center;justify-content:center}.core-org-param-container .input-wrapper .clear-icon-wrapper>.flex-wrapper>i{color:#848484;font-size:20px}.core-org-param-container .input-wrapper:hover>.clear-icon-wrapper{display:block}.core-org-param-container>.seeker-icon-wrapper.multi-mode{position:relative;width:35px;height:35px}.core-org-param-container>.seeker-icon-wrapper.multi-mode>.flex-wrapper{width:35px;height:35px}.core-org-param-container .source-container{display:block;background-color:#fff;padding:var(--size-layout-block-cell-spacing);max-width:1200px;border-radius:10px}.core-org-param-container .source-container i.close-icon{font-size:20px;cursor:pointer;position:absolute;right:15px;top:15px}.core-org-param-container .source-container.d-none{display:none}.core-org-param-container .source-container>caption{display:block;width:100%}.core-org-param-container .source-container:has(~.footer){border-bottom-left-radius:0!important;border-bottom-right-radius:0!important}.core-org-param-container .footer{background-color:var(--color-bg-main);border-bottom-left-radius:10px;border-bottom-right-radius:10px;padding:var(--size-layout-block-cell-spacing);position:absolute;bottom:0;left:0;width:100%}.core-org-param-container .footer button:first-child{margin-right:var(--size-layout-block-cell-spacing)}.core-org-param-container .core-tabbe-wrapper{margin-top:5px}\n"] }]
|
|
108
106
|
}], ctorParameters: () => [{ type: i1.SeekerService }, { type: i2.LayoutService }, { type: i3.OrganizationService }] });
|
|
109
|
-
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-org-param.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-org-param/core-org-param.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-org-param/core-org-param.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, AfterViewInit } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { CoreOrgUnitSeekerComponent } from '../core-org-unit-seeker/core-org-unit-seeker/core-org-unit-seeker.component';\r\nimport { NgStyle } from '@angular/common';\r\nimport { CorePageHeaderComponent } from '../core-page-header/core-page-header/core-page-header.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { EnumCoreOrgTreeaAccessorMode } from '../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { SeekerService } from '../core-form-control-seeker/seeker.service';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { OrganizationService } from '../../services/organization.service';\r\nimport { IOrgTreeItem } from '../core-org-tree/core-org-tree/IOrgTreeItem';\r\n\r\n@Component({\r\n  selector: 'core-org-param',\r\n  standalone: true,\r\n  imports: [\r\n    NgStyle,\r\n    FormsModule,\r\n    CorePageHeaderComponent,\r\n    CoreOrgUnitSeekerComponent,\r\n    TranslatePipe,\r\n    TooltipDirective\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreOrgParamComponent\r\n    },\r\n  ],\r\n  templateUrl: './core-org-param.component.html',\r\n  styleUrl: './core-org-param.component.scss'\r\n})\r\nexport class CoreOrgParamComponent extends CoreFormControlBaseComponent implements AfterViewInit {\r\n\r\n  override value!: number[];\r\n  lang!: string;\r\n  sourceOpen!: boolean;\r\n  sourceContainerHeight!: number;\r\n  childComponentHeight!: number;\r\n  sourceSpaceHeight!: number;\r\n  valueToShow!: string;\r\n  accessorMode = EnumCoreOrgTreeaAccessorMode.ACTIVATED_INHERITANCE\r\n  pendingIds: number[] = [];\r\n  showPageHeader!: boolean;\r\n  ids!: number[];\r\n\r\n  constructor(\r\n    private seekerService: SeekerService,\r\n    private layoutService: LayoutService,\r\n    private organizationService: OrganizationService\r\n  ) {\r\n    super()\r\n    this.seekerService.sourceSpaceHeight$.subscribe(x => {\r\n      this.sourceSpaceHeight = x;\r\n      this.sourceContainerHeight = this.showPageHeader ? x - this.layoutService.corePageHeaderHeight - 68 : x - 68;\r\n      this.childComponentHeight = this.sourceContainerHeight;\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.writeValue(this.organizationService.status$.value.activeKeys.map(x => Number(x)))\r\n    })\r\n  }\r\n\r\n  override writeValue(obj: number[]): void {\r\n    this.value = obj;\r\n\r\n    const filteredLinearData = this.organizationService.linerData$.value\r\n      .filter(x => obj?.includes(x.id));\r\n\r\n    if (!filteredLinearData.length) {\r\n      this.valueToShow = '';\r\n    } else {\r\n      try {\r\n        const tryFindTheShortedPath = filteredLinearData\r\n          .reduce((shortest: IOrgTreeItem, current: IOrgTreeItem) => {\r\n            return current.tree$Path.length < shortest.tree$Path.length ? current : shortest;\r\n          }, filteredLinearData[0]);\r\n        this.valueToShow = tryFindTheShortedPath.tree$Title\r\n      } catch {\r\n        this.valueToShow = \"\";\r\n      }\r\n    }\r\n  }\r\n\r\n  onCancel(): void {\r\n    this.sourceOpen = false;\r\n  }\r\n\r\n  onClickSeek(): void {\r\n    this.sourceOpen = true;\r\n  }\r\n\r\n  onSelect(): void {\r\n    if (!!this.pendingIds.length) {\r\n      this.pendingIds = [];\r\n      this.sourceOpen = false;\r\n    }\r\n  }\r\n\r\n  onItemDoubleClick(e: any) {\r\n    this.onSelect();\r\n  }\r\n\r\n  onIdsChange(e: number[]) {\r\n    this.writeValue(e);\r\n    console.log(\"CoreOrgParamComponent onIdsChange: \", e)\r\n    this.onChange(e);\r\n    this.pendingIds = e;\r\n  }\r\n\r\n  onItemClick(e: any) {\r\n    if (e.name) this.valueToShow = e['name']\r\n  }\r\n\r\n  onClickClear(): void {\r\n    this.valueToShow = ''\r\n    this.value = [];\r\n    this.onChange([]);\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-org-param-container\">\r\n    <div class=\"input-wrapper\">\r\n        <label #shownText type=\"text\" class=\"text form-control pointer\" (click)=\"onClickSeek()\">\r\n            <span [appTooltip]=\"valueToShow\">{{ valueToShow }}</span>\r\n        </label>\r\n    </div>\r\n    <div class=\"seeker-icon-wrapper\" (click)=\"onClickSeek()\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-search\"></i>\r\n        </div>\r\n    </div>\r\n\r\n    @if (!!sourceOpen) {\r\n    <div class=\"modal-container\">\r\n        <div class=\"modal-content-root\" [ngStyle]=\"{ padding: '0px' }\">\r\n\r\n            <div class=\"source-space\" [ngStyle]=\"{\r\n                height: sourceSpaceHeight + 'px',\r\n                overflow: 'hidden',\r\n                boxSizing: 'border-box',\r\n            }\">\r\n                <div class=\"source-container\" [ngStyle]=\"{\r\n                    height: sourceContainerHeight + 'px',\r\n                    paddingTop: '0px',\r\n                    paddingBottom: '0px'\r\n                }\">\r\n                    <i class=\"close-icon feather-x d-block\" (click)=\"onCancel()\"></i>\r\n\r\n                    <core-org-unit-seeker [accessorMode]=\"accessorMode\" [height]=\"childComponentHeight\" (itemClick)=\"onItemClick($event)\" (itemDoubleClick)=\"onItemDoubleClick($event)\" (idsChange)=\"onIdsChange($event)\"\r\n                        [height]=\"childComponentHeight\"></core-org-unit-seeker>\r\n\r\n                </div>\r\n\r\n                <div class=\"footer\">\r\n                    <div class=\"d-flex-end\">\r\n                        @if (!!pendingIds.length) {\r\n                        <button class=\"btn btn-primary\" type=\"button\" (click)=\"onSelect()\">{{\r\n                            'UI_CORE_CONFIRM_DIALOG_BUTTON_SELECT' | translate: lang }}</button>\r\n                        }\r\n                        <button class=\"btn btn-secondary\" type=\"button\" (click)=\"onCancel()\">{{\r\n                            'UI_CORE_CONFIRM_DIALOG_BUTTON_CANCEL' | translate: lang }}</button>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n    }\r\n\r\n</div>"]}
|
|
107
|
+
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"core-org-param.component.js","sourceRoot":"","sources":["../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-org-param/core-org-param.component.ts","../../../../../../../projects/ngx-histaff-alpha/src/lib/app/libraries/core-org-param/core-org-param.component.html"],"names":[],"mappings":"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","sourcesContent":["import { Component, AfterViewInit } from '@angular/core';\r\nimport { CoreFormControlBaseComponent } from '../core-form-control-base/core-form-control-base.component';\r\nimport { TranslatePipe } from '../../app-pipes/translate.pipe';\r\nimport { CoreOrgUnitSeekerComponent } from '../core-org-unit-seeker/core-org-unit-seeker/core-org-unit-seeker.component';\r\nimport { NgStyle } from '@angular/common';\r\nimport { CorePageHeaderComponent } from '../core-page-header/core-page-header/core-page-header.component';\r\nimport { TooltipDirective } from '../tooltip/tooltip.directive';\r\nimport { FormsModule, NG_VALUE_ACCESSOR } from '@angular/forms';\r\nimport { EnumCoreOrgTreeaAccessorMode } from '../core-org-tree/core-org-tree/core-org-tree.component';\r\nimport { SeekerService } from '../core-form-control-seeker/seeker.service';\r\nimport { LayoutService } from '../../services/layout.service';\r\nimport { OrganizationService } from '../../services/organization.service';\r\nimport { IOrgTreeItem } from '../core-org-tree/core-org-tree/IOrgTreeItem';\r\nimport { Subscription } from 'rxjs';\r\n\r\n@Component({\r\n  selector: 'core-org-param',\r\n  standalone: true,\r\n  imports: [\r\n    NgStyle,\r\n    FormsModule,\r\n    CorePageHeaderComponent,\r\n    CoreOrgUnitSeekerComponent,\r\n    TranslatePipe,\r\n    TooltipDirective\r\n  ],\r\n  providers: [\r\n    {\r\n      provide: NG_VALUE_ACCESSOR,\r\n      multi: true,\r\n      useExisting: CoreOrgParamComponent\r\n    },\r\n  ],\r\n  templateUrl: './core-org-param.component.html',\r\n  styleUrl: './core-org-param.component.scss'\r\n})\r\nexport class CoreOrgParamComponent extends CoreFormControlBaseComponent implements AfterViewInit {\r\n\r\n  override value!: number[];\r\n  lang!: string;\r\n  sourceOpen!: boolean;\r\n  sourceContainerHeight!: number;\r\n  childComponentHeight!: number;\r\n  sourceSpaceHeight!: number;\r\n  valueToShow!: string;\r\n  accessorMode = EnumCoreOrgTreeaAccessorMode.ACTIVATED_INHERITANCE\r\n  pendingIds: number[] = [];\r\n  showPageHeader!: boolean;\r\n  ids!: number[];\r\n  subscriptions: Subscription[] = [];\r\n\r\n  constructor(\r\n    private seekerService: SeekerService,\r\n    private layoutService: LayoutService,\r\n    private organizationService: OrganizationService\r\n  ) {\r\n    super()\r\n    this.seekerService.sourceSpaceHeight$.subscribe(x => {\r\n      this.sourceSpaceHeight = x;\r\n      this.sourceContainerHeight = this.showPageHeader ? x - this.layoutService.corePageHeaderHeight - 68 : x - 68;\r\n      this.childComponentHeight = this.sourceContainerHeight;\r\n    });\r\n  }\r\n\r\n  ngAfterViewInit(): void {\r\n    setTimeout(() => {\r\n      this.writeValue(this.organizationService.status$.value.activeKeys.map(x => Number(x)))\r\n\r\n      this.subscriptions.push(\r\n        this.organizationService.status$.subscribe(x => {\r\n          if (!!x.selectedKey) {\r\n            const filteredLinearData = this.organizationService.linerData$.value.filter(i => i.id === Number(x.selectedKey));\r\n            if (!!filteredLinearData.length) {\r\n              this.valueToShow = filteredLinearData[0].tree$Title\r\n            } else {\r\n              this.valueToShow = ''  \r\n            }\r\n          } else {\r\n            this.valueToShow = ''\r\n          }\r\n        })\r\n      )\r\n\r\n    })\r\n  }\r\n\r\n  override writeValue(obj: number[]): void {\r\n    this.value = obj;\r\n  }\r\n\r\n  onCancel(): void {\r\n    this.sourceOpen = false;\r\n  }\r\n\r\n  onClickSeek(): void {\r\n    this.sourceOpen = true;\r\n  }\r\n\r\n  onSelect(): void {\r\n    if (!!this.pendingIds.length) {\r\n      this.pendingIds = [];\r\n      this.sourceOpen = false;\r\n    }\r\n  }\r\n\r\n  onItemDoubleClick(e: any) {\r\n    this.onSelect();\r\n  }\r\n\r\n  onIdsChange(e: number[]) {\r\n    this.writeValue(e);\r\n    console.log(\"CoreOrgParamComponent onIdsChange: \", e)\r\n    this.onChange(e);\r\n    this.pendingIds = e;\r\n  }\r\n\r\n  onItemClick(e: any) {\r\n    if (e.name) this.valueToShow = e['name']\r\n  }\r\n\r\n  onClickClear(): void {\r\n    this.valueToShow = ''\r\n    this.value = [];\r\n    this.onChange([]);\r\n  }\r\n\r\n}\r\n","<div #container class=\"core-org-param-container\">\r\n    <div class=\"input-wrapper\">\r\n        <label #shownText type=\"text\" class=\"text form-control pointer\" (click)=\"onClickSeek()\">\r\n            <span [appTooltip]=\"valueToShow\">{{ valueToShow }}</span>\r\n        </label>\r\n    </div>\r\n    <div class=\"seeker-icon-wrapper\" (click)=\"onClickSeek()\">\r\n        <div class=\"flex-wrapper\">\r\n            <i class=\"feather-search\"></i>\r\n        </div>\r\n    </div>\r\n\r\n    @if (!!sourceOpen) {\r\n    <div class=\"modal-container\">\r\n        <div class=\"modal-content-root\" [ngStyle]=\"{ padding: '0px' }\">\r\n\r\n            <div class=\"source-space\" [ngStyle]=\"{\r\n                height: sourceSpaceHeight + 'px',\r\n                overflow: 'hidden',\r\n                boxSizing: 'border-box',\r\n            }\">\r\n                <div class=\"source-container\" [ngStyle]=\"{\r\n                    height: sourceContainerHeight + 'px',\r\n                    paddingTop: '0px',\r\n                    paddingBottom: '0px'\r\n                }\">\r\n                    <i class=\"close-icon feather-x d-block\" (click)=\"onCancel()\"></i>\r\n\r\n                    <core-org-unit-seeker [accessorMode]=\"accessorMode\" [height]=\"childComponentHeight\" (itemClick)=\"onItemClick($event)\" (itemDoubleClick)=\"onItemDoubleClick($event)\" (idsChange)=\"onIdsChange($event)\"\r\n                        [height]=\"childComponentHeight\"></core-org-unit-seeker>\r\n\r\n                </div>\r\n\r\n                <div class=\"footer\">\r\n                    <div class=\"d-flex-end\">\r\n                        @if (!!pendingIds.length) {\r\n                        <button class=\"btn btn-primary\" type=\"button\" (click)=\"onSelect()\">{{\r\n                            'UI_CORE_CONFIRM_DIALOG_BUTTON_SELECT' | translate: lang }}</button>\r\n                        }\r\n                        <button class=\"btn btn-secondary\" type=\"button\" (click)=\"onCancel()\">{{\r\n                            'UI_CORE_CONFIRM_DIALOG_BUTTON_CANCEL' | translate: lang }}</button>\r\n                    </div>\r\n                </div>\r\n\r\n            </div>\r\n\r\n        </div>\r\n    </div>\r\n    }\r\n\r\n</div>"]}
|
|
@@ -8022,6 +8022,7 @@ class CoreOrgParamComponent extends CoreFormControlBaseComponent {
|
|
|
8022
8022
|
this.organizationService = organizationService;
|
|
8023
8023
|
this.accessorMode = EnumCoreOrgTreeaAccessorMode.ACTIVATED_INHERITANCE;
|
|
8024
8024
|
this.pendingIds = [];
|
|
8025
|
+
this.subscriptions = [];
|
|
8025
8026
|
this.seekerService.sourceSpaceHeight$.subscribe(x => {
|
|
8026
8027
|
this.sourceSpaceHeight = x;
|
|
8027
8028
|
this.sourceContainerHeight = this.showPageHeader ? x - this.layoutService.corePageHeaderHeight - 68 : x - 68;
|
|
@@ -8031,27 +8032,24 @@ class CoreOrgParamComponent extends CoreFormControlBaseComponent {
|
|
|
8031
8032
|
ngAfterViewInit() {
|
|
8032
8033
|
setTimeout(() => {
|
|
8033
8034
|
this.writeValue(this.organizationService.status$.value.activeKeys.map(x => Number(x)));
|
|
8035
|
+
this.subscriptions.push(this.organizationService.status$.subscribe(x => {
|
|
8036
|
+
if (!!x.selectedKey) {
|
|
8037
|
+
const filteredLinearData = this.organizationService.linerData$.value.filter(i => i.id === Number(x.selectedKey));
|
|
8038
|
+
if (!!filteredLinearData.length) {
|
|
8039
|
+
this.valueToShow = filteredLinearData[0].tree$Title;
|
|
8040
|
+
}
|
|
8041
|
+
else {
|
|
8042
|
+
this.valueToShow = '';
|
|
8043
|
+
}
|
|
8044
|
+
}
|
|
8045
|
+
else {
|
|
8046
|
+
this.valueToShow = '';
|
|
8047
|
+
}
|
|
8048
|
+
}));
|
|
8034
8049
|
});
|
|
8035
8050
|
}
|
|
8036
8051
|
writeValue(obj) {
|
|
8037
8052
|
this.value = obj;
|
|
8038
|
-
const filteredLinearData = this.organizationService.linerData$.value
|
|
8039
|
-
.filter(x => obj?.includes(x.id));
|
|
8040
|
-
if (!filteredLinearData.length) {
|
|
8041
|
-
this.valueToShow = '';
|
|
8042
|
-
}
|
|
8043
|
-
else {
|
|
8044
|
-
try {
|
|
8045
|
-
const tryFindTheShortedPath = filteredLinearData
|
|
8046
|
-
.reduce((shortest, current) => {
|
|
8047
|
-
return current.tree$Path.length < shortest.tree$Path.length ? current : shortest;
|
|
8048
|
-
}, filteredLinearData[0]);
|
|
8049
|
-
this.valueToShow = tryFindTheShortedPath.tree$Title;
|
|
8050
|
-
}
|
|
8051
|
-
catch {
|
|
8052
|
-
this.valueToShow = "";
|
|
8053
|
-
}
|
|
8054
|
-
}
|
|
8055
8053
|
}
|
|
8056
8054
|
onCancel() {
|
|
8057
8055
|
this.sourceOpen = false;
|