ngx-bimplus-components 0.0.84-draggable-1 → 0.0.84-draggable-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.
@@ -30,7 +30,7 @@ export class BimplusFloatingBarHideObjectsComponent extends BimplusLocalizedWidg
30
30
  this.focusSelectorId = 'hide-menu-id';
31
31
  this.layoutManagerService = layoutManagerService;
32
32
  }
33
- ngOnInit() {
33
+ ngAfterViewInit() {
34
34
  // Subscribe to the observable
35
35
  this.layoutManagerService.registerObject(this.element, this.componentId, '.floating-panel.visible', true, DEFAULT_POSITION_LEFT, DEFAULT_POSITION_TOP);
36
36
  }
@@ -56,4 +56,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
56
56
  }], items: [{
57
57
  type: Input
58
58
  }] } });
59
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-floating-bar-hide-objects.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-hide-objects/bimplus-floating-bar-hide-objects.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-hide-objects/bimplus-floating-bar-hide-objects.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAwC,MAAM,eAAe,CAAC;AAChI,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,+BAA+B,EAAE,MAAM,kEAAkE,CAAA;AAClH,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,kCAAkC,EAAE,MAAM,wEAAwE,CAAC;AAC5H,OAAO,EAAE,wCAAwC,EAAE,MAAM,sFAAsF,CAAC;AAChJ,OAAO,EAAE,qCAAqC,EAAE,MAAM,gFAAgF,CAAC;;;;;AAKvI,MAAM,qBAAqB,GAAE,GAAG,CAAC;AACjC,MAAM,oBAAoB,GAAE,GAAG,CAAC;AAiBhC,MAAM,OAAO,sCAAuC,SAAQ,+BAA+B;IAiBzF,YAAY,gBAAkC,EAC5C,oBAA0C,EAClC,OAAmB,EACnB,GAAsB,EACtB,qBAA2C;QAErD,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAJd,YAAO,GAAP,OAAO,CAAY;QACnB,QAAG,GAAH,GAAG,CAAmB;QACtB,0BAAqB,GAArB,qBAAqB,CAAsB;QAnB3C,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5C,WAAM,GAAY,IAAI,CAAC;QACvB,cAAS,GAAY,IAAI,CAAC;QACnC,6CAA6C;QACpC,UAAK,GAA2B,EAAE,CAAC;QAEpC,mBAAc,GAAY,KAAK,CAAC;QAIxC,gBAAW,GAAG,iBAAiB,CAAA;QAC/B,SAAI,GAAG,mBAAmB,CAAC;QAC3B,UAAK,GAAW,EAAE,CAAC,CAAC,+BAA+B;QACnD,oBAAe,GAAW,cAAc,CAAC;QASzC,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;IACjD,CAAC;IAGD,QAAQ;QACN,8BAA8B;QAC9B,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,IAAI,EAAC,qBAAqB,EAAC,oBAAoB,CAAC,CAAC;IACpJ,CAAC;+GA/BU,sCAAsC;mGAAtC,sCAAsC,uMALtC,CAAC,gBAAgB,CAAC,iDCzB/B,gsCAqCA,yykBDnBI,YAAY,+BACZ,2BAA2B,2KAC3B,kCAAkC,kHAClC,wCAAwC,8JACxC,qCAAqC,sIACrC,eAAe;;4FAON,sCAAsC;kBAhBlD,SAAS;+BACE,uCAAuC,cACrC,IAAI,WACP;wBACP,YAAY;wBACZ,2BAA2B;wBAC3B,kCAAkC;wBAClC,wCAAwC;wBACxC,qCAAqC;wBACrC,eAAe;qBAChB,aACU,CAAC,gBAAgB,CAAC,iBAGd,iBAAiB,CAAC,SAAS;qNAIhC,aAAa;sBAAtB,MAAM;gBACE,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,KAAK;sBAAb,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewEncapsulation,ElementRef, ChangeDetectorRef, OnInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateService, TranslateModule } from '@ngx-translate/core';\r\nimport { BimplusLocalizedWidgetComponent } from \"./../bimplus-localized-widget/bimplus-localized-widget.component\"\r\nimport { BimplusFloatingBarComponent } from '../bimplus-floating-bar/bimplus-floating-bar.component';\r\nimport { BimplusFloatingBarDraggerComponent } from '../bimplus-floating-bar-dragger/bimplus-floating-bar-dragger.component';\r\nimport { BimplusFloatingBarHeaderContentComponent } from '../bimplus-floating-bar-header-content/bimplus-floating-bar-header-content.component';\r\nimport { BimplusFloatingBarHeaderLogoComponent } from '../bimplus-floating-bar-header-logo/bimplus-floating-bar-header-logo.component';\r\nimport { FloatingBarItem } from '../bimplus-floating-bar/bimplus-floating-bar.interface';\r\nimport { LayoutManagerService } from '../../services/layout-manager.service';\r\nimport { ResizeObserverService } from '../../services/resize-observer.service';\r\n\r\nconst DEFAULT_POSITION_LEFT =355;\r\nconst DEFAULT_POSITION_TOP =355;\r\n@Component({\r\n  selector: 'lib-bimplus-floating-bar-hide-objects',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    BimplusFloatingBarComponent,\r\n    BimplusFloatingBarDraggerComponent,\r\n    BimplusFloatingBarHeaderContentComponent,\r\n    BimplusFloatingBarHeaderLogoComponent,\r\n    TranslateModule,\r\n  ],\r\n  providers: [TranslateService],\r\n  templateUrl: './bimplus-floating-bar-hide-objects.component.html',\r\n  styleUrl: './bimplus-floating-bar-hide-objects.component.less',\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\nexport class BimplusFloatingBarHideObjectsComponent extends BimplusLocalizedWidgetComponent implements OnInit {\r\n  \r\n  @Output() actionClicked = new EventEmitter<string>();\r\n  @Input() noBody: boolean = true;  \r\n  @Input() isFocused: boolean = true;\r\n  // Items for the header content sub component\r\n  @Input() items: Array<FloatingBarItem> = [];\r\n\r\n  private hasViewChecked: boolean = false;\r\n  protected layoutManagerService: LayoutManagerService;\r\n\r\n\r\n  componentId = 'hide-menu-fp-id'\r\n  icon = 'ui-icon-hide-menu';\r\n  title: string = \"\"; // no tooltip info on Logo icon\r\n  focusSelectorId: string = 'hide-menu-id';\r\n\r\n  constructor(translateService: TranslateService,\r\n    layoutManagerService: LayoutManagerService,\r\n    private element: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private resizeObserverService:ResizeObserverService\r\n     ){    \r\n  super(translateService);\r\n  this.layoutManagerService = layoutManagerService;\r\n  }\r\n  \r\n  \r\n  ngOnInit():void{\r\n    // Subscribe to the observable\r\n    this.layoutManagerService.registerObject(this.element,this.componentId,'.floating-panel.visible',true,DEFAULT_POSITION_LEFT,DEFAULT_POSITION_TOP);    \r\n  }  \r\n}\r\n","<lib-bimplus-floating-bar\r\n  id=\"hide-menu-fp-id\"\r\n  [id] = \"componentId\"\r\n  class=\"hide-menu\"\r\n  [noBody]=\"noBody\"\r\n  [isFocused]=\"isFocused\"\r\n  [resizeEnabled]=\"false\"\r\n  [focusSelector]=\"focusSelectorId\"\r\n  [isVisible]=\"true\"\r\n  [selectedLanguage]=\"selectedLanguage\"\r\n  [localizedStrings]=\"localizedStrings\"  \r\n>\r\n  <lib-bimplus-floating-bar-header-logo\r\n    class=\"floating-bar-header-logo\"\r\n    [parentId] = \"componentId\"\r\n    [icon]=\"icon\"\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-logo>\r\n\r\n  <lib-bimplus-floating-bar-header-content\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    [parentId] = \"componentId\"\r\n    class=\"floating-bar-header-content\"\r\n    [items]=\"items\"    \r\n    (actionClicked)=\"actionClicked.emit($event)\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-content>\r\n\r\n  <lib-bimplus-floating-bar-dragger\r\n    class=\"floating-bar-dragger\"    \r\n    [parentId] = \"componentId\"\r\n  >\r\n  </lib-bimplus-floating-bar-dragger>\r\n</lib-bimplus-floating-bar>\r\n"]}
59
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-floating-bar-hide-objects.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-hide-objects/bimplus-floating-bar-hide-objects.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-hide-objects/bimplus-floating-bar-hide-objects.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAA+C,MAAM,eAAe,CAAC;AACvI,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AACxE,OAAO,EAAE,+BAA+B,EAAE,MAAM,kEAAkE,CAAA;AAClH,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,kCAAkC,EAAE,MAAM,wEAAwE,CAAC;AAC5H,OAAO,EAAE,wCAAwC,EAAE,MAAM,sFAAsF,CAAC;AAChJ,OAAO,EAAE,qCAAqC,EAAE,MAAM,gFAAgF,CAAC;;;;;AAKvI,MAAM,qBAAqB,GAAE,GAAG,CAAC;AACjC,MAAM,oBAAoB,GAAE,GAAG,CAAC;AAiBhC,MAAM,OAAO,sCAAuC,SAAQ,+BAA+B;IAiBzF,YAAY,gBAAkC,EAC5C,oBAA0C,EAClC,OAAmB,EACnB,GAAsB,EACtB,qBAA2C;QAErD,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAJd,YAAO,GAAP,OAAO,CAAY;QACnB,QAAG,GAAH,GAAG,CAAmB;QACtB,0BAAqB,GAArB,qBAAqB,CAAsB;QAnB3C,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAC5C,WAAM,GAAY,IAAI,CAAC;QACvB,cAAS,GAAY,IAAI,CAAC;QACnC,6CAA6C;QACpC,UAAK,GAA2B,EAAE,CAAC;QAEpC,mBAAc,GAAY,KAAK,CAAC;QAIxC,gBAAW,GAAG,iBAAiB,CAAA;QAC/B,SAAI,GAAG,mBAAmB,CAAC;QAC3B,UAAK,GAAW,EAAE,CAAC,CAAC,+BAA+B;QACnD,oBAAe,GAAW,cAAc,CAAC;QASzC,IAAI,CAAC,oBAAoB,GAAG,oBAAoB,CAAC;IACjD,CAAC;IAGD,eAAe;QACb,8BAA8B;QAC9B,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,IAAI,EAAC,qBAAqB,EAAC,oBAAoB,CAAC,CAAC;IACpJ,CAAC;+GA/BU,sCAAsC;mGAAtC,sCAAsC,uMALtC,CAAC,gBAAgB,CAAC,iDCzB/B,gsCAqCA,yykBDnBI,YAAY,+BACZ,2BAA2B,2KAC3B,kCAAkC,kHAClC,wCAAwC,8JACxC,qCAAqC,sIACrC,eAAe;;4FAON,sCAAsC;kBAhBlD,SAAS;+BACE,uCAAuC,cACrC,IAAI,WACP;wBACP,YAAY;wBACZ,2BAA2B;wBAC3B,kCAAkC;wBAClC,wCAAwC;wBACxC,qCAAqC;wBACrC,eAAe;qBAChB,aACU,CAAC,gBAAgB,CAAC,iBAGd,iBAAiB,CAAC,SAAS;qNAIhC,aAAa;sBAAtB,MAAM;gBACE,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAEG,KAAK;sBAAb,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewEncapsulation,ElementRef, ChangeDetectorRef, AfterViewInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateService, TranslateModule } from '@ngx-translate/core';\r\nimport { BimplusLocalizedWidgetComponent } from \"./../bimplus-localized-widget/bimplus-localized-widget.component\"\r\nimport { BimplusFloatingBarComponent } from '../bimplus-floating-bar/bimplus-floating-bar.component';\r\nimport { BimplusFloatingBarDraggerComponent } from '../bimplus-floating-bar-dragger/bimplus-floating-bar-dragger.component';\r\nimport { BimplusFloatingBarHeaderContentComponent } from '../bimplus-floating-bar-header-content/bimplus-floating-bar-header-content.component';\r\nimport { BimplusFloatingBarHeaderLogoComponent } from '../bimplus-floating-bar-header-logo/bimplus-floating-bar-header-logo.component';\r\nimport { FloatingBarItem } from '../bimplus-floating-bar/bimplus-floating-bar.interface';\r\nimport { LayoutManagerService } from '../../services/layout-manager.service';\r\nimport { ResizeObserverService } from '../../services/resize-observer.service';\r\n\r\nconst DEFAULT_POSITION_LEFT =355;\r\nconst DEFAULT_POSITION_TOP =355;\r\n@Component({\r\n  selector: 'lib-bimplus-floating-bar-hide-objects',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    BimplusFloatingBarComponent,\r\n    BimplusFloatingBarDraggerComponent,\r\n    BimplusFloatingBarHeaderContentComponent,\r\n    BimplusFloatingBarHeaderLogoComponent,\r\n    TranslateModule,\r\n  ],\r\n  providers: [TranslateService],\r\n  templateUrl: './bimplus-floating-bar-hide-objects.component.html',\r\n  styleUrl: './bimplus-floating-bar-hide-objects.component.less',\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\nexport class BimplusFloatingBarHideObjectsComponent extends BimplusLocalizedWidgetComponent implements AfterViewInit {\r\n  \r\n  @Output() actionClicked = new EventEmitter<string>();\r\n  @Input() noBody: boolean = true;  \r\n  @Input() isFocused: boolean = true;\r\n  // Items for the header content sub component\r\n  @Input() items: Array<FloatingBarItem> = [];\r\n\r\n  private hasViewChecked: boolean = false;\r\n  protected layoutManagerService: LayoutManagerService;\r\n\r\n\r\n  componentId = 'hide-menu-fp-id'\r\n  icon = 'ui-icon-hide-menu';\r\n  title: string = \"\"; // no tooltip info on Logo icon\r\n  focusSelectorId: string = 'hide-menu-id';\r\n\r\n  constructor(translateService: TranslateService,\r\n    layoutManagerService: LayoutManagerService,\r\n    private element: ElementRef,\r\n    private cdr: ChangeDetectorRef,\r\n    private resizeObserverService:ResizeObserverService\r\n     ){    \r\n  super(translateService);\r\n  this.layoutManagerService = layoutManagerService;\r\n  }\r\n  \r\n  \r\n  ngAfterViewInit(){\r\n    // Subscribe to the observable\r\n    this.layoutManagerService.registerObject(this.element,this.componentId,'.floating-panel.visible',true,DEFAULT_POSITION_LEFT,DEFAULT_POSITION_TOP);    \r\n  }    \r\n}\r\n","<lib-bimplus-floating-bar\r\n  id=\"hide-menu-fp-id\"\r\n  [id] = \"componentId\"\r\n  class=\"hide-menu\"\r\n  [noBody]=\"noBody\"\r\n  [isFocused]=\"isFocused\"\r\n  [resizeEnabled]=\"false\"\r\n  [focusSelector]=\"focusSelectorId\"\r\n  [isVisible]=\"true\"\r\n  [selectedLanguage]=\"selectedLanguage\"\r\n  [localizedStrings]=\"localizedStrings\"  \r\n>\r\n  <lib-bimplus-floating-bar-header-logo\r\n    class=\"floating-bar-header-logo\"\r\n    [parentId] = \"componentId\"\r\n    [icon]=\"icon\"\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-logo>\r\n\r\n  <lib-bimplus-floating-bar-header-content\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    [parentId] = \"componentId\"\r\n    class=\"floating-bar-header-content\"\r\n    [items]=\"items\"    \r\n    (actionClicked)=\"actionClicked.emit($event)\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-content>\r\n\r\n  <lib-bimplus-floating-bar-dragger\r\n    class=\"floating-bar-dragger\"    \r\n    [parentId] = \"componentId\"\r\n  >\r\n  </lib-bimplus-floating-bar-dragger>\r\n</lib-bimplus-floating-bar>\r\n"]}
@@ -28,7 +28,7 @@ export class BimplusFloatingBarIsolationObjectsComponent extends BimplusLocalize
28
28
  this.focusSelectorId = 'isolation-menu-id';
29
29
  this.componentId = 'isolation-menu-fp-id';
30
30
  }
31
- ngOnInit() {
31
+ ngAfterViewInit() {
32
32
  this.layoutManagerService.registerObject(this.element, this.componentId, '.floating-panel.visible', true, DEFAULT_POSITION_LEFT, DEFAULT_POSITION_TOP);
33
33
  }
34
34
  ngAfterViewChecked() {
@@ -62,4 +62,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
62
62
  }], items: [{
63
63
  type: Input
64
64
  }] } });
65
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-floating-bar-isolation-objects.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-isolation-objects/bimplus-floating-bar-isolation-objects.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-isolation-objects/bimplus-floating-bar-isolation-objects.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAA2D,MAAM,eAAe,CAAC;AACnJ,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAExE,OAAO,EAAE,+BAA+B,EAAE,MAAM,kEAAkE,CAAA;AAClH,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,kCAAkC,EAAE,MAAM,wEAAwE,CAAC;AAC5H,OAAO,EAAE,wCAAwC,EAAE,MAAM,sFAAsF,CAAC;AAChJ,OAAO,EAAE,qCAAqC,EAAE,MAAM,gFAAgF,CAAC;;;;AAIvI,MAAM,qBAAqB,GAAE,GAAG,CAAC;AACjC,MAAM,oBAAoB,GAAG,GAAG,CAAC;AAmBjC,MAAM,OAAO,2CAA4C,SAAQ,+BAA+B;IAC9F,YAAY,gBAAkC,EAC1B,oBAA0C,EAC1C,OAAmB,EACnB,GAAsB;QACxC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAHN,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,YAAO,GAAP,OAAO,CAAY;QACnB,QAAG,GAAH,GAAG,CAAmB;QAIlC,mBAAc,GAAY,KAAK,CAAC;QAG9B,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAE5C,WAAM,GAAY,IAAI,CAAC;QACvB,cAAS,GAAY,IAAI,CAAC;QAEnC,6CAA6C;QACpC,UAAK,GAA2B,EAAE,CAAC;QAE5C,SAAI,GAAG,wBAAwB,CAAC;QAChC,UAAK,GAAW,EAAE,CAAC,CAAC,+BAA+B;QACnD,oBAAe,GAAW,mBAAmB,CAAC;QAC9C,gBAAW,GAAG,sBAAsB,CAAC;IAfrC,CAAC;IAgBD,QAAQ;QACN,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,IAAI,EAAC,qBAAqB,EAAC,oBAAoB,CAAE,CAAC;IACrJ,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC,6CAA6C;YACzE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,+BAA+B;YACzD,UAAU,CAAC,GAAE,EAAE;gBACb,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,SAAS,EAAC,CAAC,EAAC,CAAC,EAAC,IAAI,CAAC,CAAC;YACzG,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;+GAnCU,2CAA2C;mGAA3C,2CAA2C,4MAN3C,CAAC,gBAAgB,CAAC,iDC1B/B,ssCAqCA,yykBDlBI,YAAY,+BACZ,2BAA2B,2KAC3B,kCAAkC,kHAClC,wCAAwC,8JACxC,qCAAqC,sIACrC,eAAe;;4FAQN,2CAA2C;kBAjBvD,SAAS;+BACE,4CAA4C,cAC1C,IAAI,WACP;wBACP,YAAY;wBACZ,2BAA2B;wBAC3B,kCAAkC;wBAClC,wCAAwC;wBACxC,qCAAqC;wBACrC,eAAe;qBAChB,aACU,CAAC,gBAAgB,CAAC,iBAGd,iBAAiB,CAAC,SAAS;iLAchC,aAAa;sBAAtB,MAAM;gBAEE,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAGG,KAAK;sBAAb,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewEncapsulation ,ElementRef, AfterViewChecked, ChangeDetectorRef, OnInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateService, TranslateModule } from '@ngx-translate/core';\r\n\r\nimport { BimplusLocalizedWidgetComponent } from \"./../bimplus-localized-widget/bimplus-localized-widget.component\"\r\nimport { BimplusFloatingBarComponent } from '../bimplus-floating-bar/bimplus-floating-bar.component';\r\nimport { BimplusFloatingBarDraggerComponent } from '../bimplus-floating-bar-dragger/bimplus-floating-bar-dragger.component';\r\nimport { BimplusFloatingBarHeaderContentComponent } from '../bimplus-floating-bar-header-content/bimplus-floating-bar-header-content.component';\r\nimport { BimplusFloatingBarHeaderLogoComponent } from '../bimplus-floating-bar-header-logo/bimplus-floating-bar-header-logo.component';\r\nimport { FloatingBarItem } from '../bimplus-floating-bar/bimplus-floating-bar.interface';\r\nimport { LayoutManagerService} from '../../services/layout-manager.service';\r\n\r\nconst DEFAULT_POSITION_LEFT =355;\r\nconst DEFAULT_POSITION_TOP = 320;\r\n\r\n@Component({\r\n  selector: 'lib-bimplus-floating-bar-isolation-objects',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    BimplusFloatingBarComponent,\r\n    BimplusFloatingBarDraggerComponent,\r\n    BimplusFloatingBarHeaderContentComponent,\r\n    BimplusFloatingBarHeaderLogoComponent,\r\n    TranslateModule,\r\n  ],\r\n  providers: [TranslateService],\r\n  templateUrl: './bimplus-floating-bar-isolation-objects.component.html',\r\n  styleUrl: './bimplus-floating-bar-isolation-objects.component.less',\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class BimplusFloatingBarIsolationObjectsComponent extends BimplusLocalizedWidgetComponent implements OnInit, AfterViewChecked{\r\n  constructor(translateService: TranslateService, \r\n              private layoutManagerService: LayoutManagerService,\r\n              private element: ElementRef,\r\n              private cdr: ChangeDetectorRef){    \r\n    super(translateService);    \r\n    \r\n  }\r\n  private hasViewChecked: boolean = false;\r\n\r\n  \r\n  @Output() actionClicked = new EventEmitter<string>();\r\n\r\n  @Input() noBody: boolean = true;\r\n  @Input() isFocused: boolean = true;\r\n\r\n  // Items for the header content sub component\r\n  @Input() items: Array<FloatingBarItem> = [];\r\n\r\n  icon = 'ui-icon-isolation-menu';\r\n  title: string = \"\"; // no tooltip info on Logo icon\r\n  focusSelectorId: string = 'isolation-menu-id';\r\n  componentId = 'isolation-menu-fp-id';\r\n  ngOnInit():void{\r\n    this.layoutManagerService.registerObject(this.element,this.componentId,'.floating-panel.visible',true,DEFAULT_POSITION_LEFT,DEFAULT_POSITION_TOP,);\r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (!this.hasViewChecked) {\r\n      this.hasViewChecked = true; // Set the flag to prevent repeated execution\r\n      this.cdr.detectChanges(); // Trigger change detection    \r\n      setTimeout(()=>{\r\n        this.layoutManagerService.checkPosition(this.componentId,'.floating-panel.visible',undefined,0,0,true);        \r\n      });\r\n    }\r\n  }\r\n}\r\n","<lib-bimplus-floating-bar\r\n  id=\"isolation-menu-fp-id\"\r\n  [id] = \"componentId\"\r\n  class=\"isolation-menu\"\r\n  [noBody]=\"noBody\"\r\n  [isFocused]=\"isFocused\"\r\n  [resizeEnabled]=\"false\"\r\n  [focusSelector]=\"focusSelectorId\"\r\n  [isVisible]=\"true\"\r\n  [selectedLanguage]=\"selectedLanguage\"\r\n  [localizedStrings]=\"localizedStrings\"\r\n>\r\n  <lib-bimplus-floating-bar-header-logo\r\n    class=\"floating-bar-header-logo\"\r\n    [parentId] = \"componentId\"\r\n    [icon]=\"icon\"\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    >\r\n  </lib-bimplus-floating-bar-header-logo>\r\n\r\n  <lib-bimplus-floating-bar-header-content\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    [parentId] = \"componentId\"    \r\n    class=\"floating-bar-header-content\"\r\n    [items]=\"items\"\r\n    (actionClicked)=\"actionClicked.emit($event)\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-content>\r\n\r\n  <lib-bimplus-floating-bar-dragger\r\n    class=\"floating-bar-dragger\"\r\n    [parentId] = \"componentId\"\r\n  >\r\n  </lib-bimplus-floating-bar-dragger>\r\n</lib-bimplus-floating-bar>\r\n"]}
65
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-floating-bar-isolation-objects.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-isolation-objects/bimplus-floating-bar-isolation-objects.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-floating-bar-isolation-objects/bimplus-floating-bar-isolation-objects.component.html"],"names":[],"mappings":"AAAA,OAAO,EAAE,SAAS,EAAE,YAAY,EAAE,KAAK,EAAE,MAAM,EAAE,iBAAiB,EAAkE,MAAM,eAAe,CAAC;AAC1J,OAAO,EAAE,YAAY,EAAE,MAAM,iBAAiB,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,eAAe,EAAE,MAAM,qBAAqB,CAAC;AAExE,OAAO,EAAE,+BAA+B,EAAE,MAAM,kEAAkE,CAAA;AAClH,OAAO,EAAE,2BAA2B,EAAE,MAAM,wDAAwD,CAAC;AACrG,OAAO,EAAE,kCAAkC,EAAE,MAAM,wEAAwE,CAAC;AAC5H,OAAO,EAAE,wCAAwC,EAAE,MAAM,sFAAsF,CAAC;AAChJ,OAAO,EAAE,qCAAqC,EAAE,MAAM,gFAAgF,CAAC;;;;AAIvI,MAAM,qBAAqB,GAAE,GAAG,CAAC;AACjC,MAAM,oBAAoB,GAAG,GAAG,CAAC;AAmBjC,MAAM,OAAO,2CAA4C,SAAQ,+BAA+B;IAC9F,YAAY,gBAAkC,EAC1B,oBAA0C,EAC1C,OAAmB,EACnB,GAAsB;QACxC,KAAK,CAAC,gBAAgB,CAAC,CAAC;QAHN,yBAAoB,GAApB,oBAAoB,CAAsB;QAC1C,YAAO,GAAP,OAAO,CAAY;QACnB,QAAG,GAAH,GAAG,CAAmB;QAIlC,mBAAc,GAAY,KAAK,CAAC;QAG9B,kBAAa,GAAG,IAAI,YAAY,EAAU,CAAC;QAE5C,WAAM,GAAY,IAAI,CAAC;QACvB,cAAS,GAAY,IAAI,CAAC;QAEnC,6CAA6C;QACpC,UAAK,GAA2B,EAAE,CAAC;QAE5C,SAAI,GAAG,wBAAwB,CAAC;QAChC,UAAK,GAAW,EAAE,CAAC,CAAC,+BAA+B;QACnD,oBAAe,GAAW,mBAAmB,CAAC;QAC9C,gBAAW,GAAG,sBAAsB,CAAC;IAfrC,CAAC;IAiBD,eAAe;QACb,IAAI,CAAC,oBAAoB,CAAC,cAAc,CAAC,IAAI,CAAC,OAAO,EAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,IAAI,EAAC,qBAAqB,EAAC,oBAAoB,CAAE,CAAC;IACrJ,CAAC;IAED,kBAAkB;QAChB,IAAI,CAAC,IAAI,CAAC,cAAc,EAAE,CAAC;YACzB,IAAI,CAAC,cAAc,GAAG,IAAI,CAAC,CAAC,6CAA6C;YACzE,IAAI,CAAC,GAAG,CAAC,aAAa,EAAE,CAAC,CAAC,+BAA+B;YACzD,UAAU,CAAC,GAAE,EAAE;gBACb,IAAI,CAAC,oBAAoB,CAAC,aAAa,CAAC,IAAI,CAAC,WAAW,EAAC,yBAAyB,EAAC,SAAS,EAAC,CAAC,EAAC,CAAC,EAAC,IAAI,CAAC,CAAC;YACzG,CAAC,CAAC,CAAC;QACL,CAAC;IACH,CAAC;+GApCU,2CAA2C;mGAA3C,2CAA2C,4MAN3C,CAAC,gBAAgB,CAAC,iDC1B/B,ssCAqCA,yykBDlBI,YAAY,+BACZ,2BAA2B,2KAC3B,kCAAkC,kHAClC,wCAAwC,8JACxC,qCAAqC,sIACrC,eAAe;;4FAQN,2CAA2C;kBAjBvD,SAAS;+BACE,4CAA4C,cAC1C,IAAI,WACP;wBACP,YAAY;wBACZ,2BAA2B;wBAC3B,kCAAkC;wBAClC,wCAAwC;wBACxC,qCAAqC;wBACrC,eAAe;qBAChB,aACU,CAAC,gBAAgB,CAAC,iBAGd,iBAAiB,CAAC,SAAS;iLAchC,aAAa;sBAAtB,MAAM;gBAEE,MAAM;sBAAd,KAAK;gBACG,SAAS;sBAAjB,KAAK;gBAGG,KAAK;sBAAb,KAAK","sourcesContent":["import { Component, EventEmitter, Input, Output, ViewEncapsulation ,ElementRef, AfterViewChecked, ChangeDetectorRef, AfterViewInit } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { TranslateService, TranslateModule } from '@ngx-translate/core';\r\n\r\nimport { BimplusLocalizedWidgetComponent } from \"./../bimplus-localized-widget/bimplus-localized-widget.component\"\r\nimport { BimplusFloatingBarComponent } from '../bimplus-floating-bar/bimplus-floating-bar.component';\r\nimport { BimplusFloatingBarDraggerComponent } from '../bimplus-floating-bar-dragger/bimplus-floating-bar-dragger.component';\r\nimport { BimplusFloatingBarHeaderContentComponent } from '../bimplus-floating-bar-header-content/bimplus-floating-bar-header-content.component';\r\nimport { BimplusFloatingBarHeaderLogoComponent } from '../bimplus-floating-bar-header-logo/bimplus-floating-bar-header-logo.component';\r\nimport { FloatingBarItem } from '../bimplus-floating-bar/bimplus-floating-bar.interface';\r\nimport { LayoutManagerService} from '../../services/layout-manager.service';\r\n\r\nconst DEFAULT_POSITION_LEFT =355;\r\nconst DEFAULT_POSITION_TOP = 320;\r\n\r\n@Component({\r\n  selector: 'lib-bimplus-floating-bar-isolation-objects',\r\n  standalone: true,\r\n  imports: [\r\n    CommonModule,\r\n    BimplusFloatingBarComponent,\r\n    BimplusFloatingBarDraggerComponent,\r\n    BimplusFloatingBarHeaderContentComponent,\r\n    BimplusFloatingBarHeaderLogoComponent,\r\n    TranslateModule,\r\n  ],\r\n  providers: [TranslateService],\r\n  templateUrl: './bimplus-floating-bar-isolation-objects.component.html',\r\n  styleUrl: './bimplus-floating-bar-isolation-objects.component.less',\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\n\r\nexport class BimplusFloatingBarIsolationObjectsComponent extends BimplusLocalizedWidgetComponent implements AfterViewInit, AfterViewChecked{\r\n  constructor(translateService: TranslateService, \r\n              private layoutManagerService: LayoutManagerService,\r\n              private element: ElementRef,\r\n              private cdr: ChangeDetectorRef){    \r\n    super(translateService);    \r\n    \r\n  }\r\n  private hasViewChecked: boolean = false;\r\n\r\n  \r\n  @Output() actionClicked = new EventEmitter<string>();\r\n\r\n  @Input() noBody: boolean = true;\r\n  @Input() isFocused: boolean = true;\r\n\r\n  // Items for the header content sub component\r\n  @Input() items: Array<FloatingBarItem> = [];\r\n\r\n  icon = 'ui-icon-isolation-menu';\r\n  title: string = \"\"; // no tooltip info on Logo icon\r\n  focusSelectorId: string = 'isolation-menu-id';\r\n  componentId = 'isolation-menu-fp-id';\r\n  \r\n  ngAfterViewInit(){\r\n    this.layoutManagerService.registerObject(this.element,this.componentId,'.floating-panel.visible',true,DEFAULT_POSITION_LEFT,DEFAULT_POSITION_TOP,);    \r\n  }\r\n\r\n  ngAfterViewChecked() {\r\n    if (!this.hasViewChecked) {\r\n      this.hasViewChecked = true; // Set the flag to prevent repeated execution\r\n      this.cdr.detectChanges(); // Trigger change detection    \r\n      setTimeout(()=>{\r\n        this.layoutManagerService.checkPosition(this.componentId,'.floating-panel.visible',undefined,0,0,true);        \r\n      });\r\n    }\r\n  }\r\n}\r\n","<lib-bimplus-floating-bar\r\n  id=\"isolation-menu-fp-id\"\r\n  [id] = \"componentId\"\r\n  class=\"isolation-menu\"\r\n  [noBody]=\"noBody\"\r\n  [isFocused]=\"isFocused\"\r\n  [resizeEnabled]=\"false\"\r\n  [focusSelector]=\"focusSelectorId\"\r\n  [isVisible]=\"true\"\r\n  [selectedLanguage]=\"selectedLanguage\"\r\n  [localizedStrings]=\"localizedStrings\"\r\n>\r\n  <lib-bimplus-floating-bar-header-logo\r\n    class=\"floating-bar-header-logo\"\r\n    [parentId] = \"componentId\"\r\n    [icon]=\"icon\"\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    >\r\n  </lib-bimplus-floating-bar-header-logo>\r\n\r\n  <lib-bimplus-floating-bar-header-content\r\n    [selectedLanguage]=\"selectedLanguage\"\r\n    [localizedStrings]=\"localizedStrings\"\r\n    [parentId] = \"componentId\"    \r\n    class=\"floating-bar-header-content\"\r\n    [items]=\"items\"\r\n    (actionClicked)=\"actionClicked.emit($event)\"\r\n  >\r\n  </lib-bimplus-floating-bar-header-content>\r\n\r\n  <lib-bimplus-floating-bar-dragger\r\n    class=\"floating-bar-dragger\"\r\n    [parentId] = \"componentId\"\r\n  >\r\n  </lib-bimplus-floating-bar-dragger>\r\n</lib-bimplus-floating-bar>\r\n"]}
@@ -71,17 +71,18 @@ export class LayoutManagerService {
71
71
  if (!config) {
72
72
  return;
73
73
  }
74
- const element = this._getDomElement(obj, '');
75
- if (!element) {
74
+ const parentElement = this._getDomParentElement(obj);
75
+ const internalElement = this._getDomInternalElement(obj, '');
76
+ if (!parentElement || !internalElement) {
76
77
  return;
77
78
  }
78
- element.style.left = (config.left) + 'px';
79
- element.style.top = (config.top) + 'px';
79
+ parentElement.style.left = (config.left) + 'px';
80
+ parentElement.style.top = (config.top) + 'px';
80
81
  if (config.width && config.width > 0) {
81
- element.style.width = config.width + 'px';
82
+ internalElement.style.width = config.width + 'px';
82
83
  }
83
84
  if (config.height && config.height > 0) {
84
- element.style.height = config.height + 'px';
85
+ internalElement.style.height = config.height + 'px';
85
86
  }
86
87
  this.checkPosition(obj.id, "", undefined, 0, 0, true);
87
88
  }
@@ -135,18 +136,31 @@ export class LayoutManagerService {
135
136
  config[objId] = newItem;
136
137
  this.localStorageService.setObject(this.CONFIG, config);
137
138
  }
138
- _getDomElement(item, selector) {
139
+ _getDomParentElement(item) {
140
+ const element = item.element?.nativeElement; //?.shadowRoot || item.element?.nativeElement;
141
+ if (!element) {
142
+ console.error('_getDomParentElement: missing element');
143
+ return null;
144
+ }
145
+ return element;
146
+ }
147
+ _getDomInternalElement(item, selector) {
139
148
  const element = item.element?.nativeElement?.shadowRoot || item.element?.nativeElement;
140
149
  if (!element) {
141
- console.error('_getDomElement: missing element');
150
+ console.error('_getDomInternalElement: missing element');
142
151
  return null;
143
152
  }
144
153
  const mySelector = selector && selector?.length > 0 ? selector : item.selector;
145
- return mySelector ? element.querySelector(mySelector) : element;
154
+ const retval = mySelector ? element.querySelector(mySelector) : element;
155
+ if (!retval) {
156
+ console.error(`_getDomInternalElement: selection of element ${element} failed with selector ${mySelector}`);
157
+ }
158
+ return retval;
146
159
  }
147
160
  _getElementRect(item, selector, parentRectangle) {
148
- const selectedObj = this._getDomElement(item, selector);
161
+ const selectedObj = this._getDomInternalElement(item, selector);
149
162
  if (!selectedObj) {
163
+ console.error('_getElementRect: missing selected object');
150
164
  return null;
151
165
  }
152
166
  const parentRect = parentRectangle || this.resizeObserverService.getParentAppRect();
@@ -155,6 +169,9 @@ export class LayoutManagerService {
155
169
  return null;
156
170
  }
157
171
  const elementRect = selectedObj.getBoundingClientRect();
172
+ if (!elementRect) {
173
+ console.error('_getElementRect: missing bounding rect');
174
+ }
158
175
  return elementRect;
159
176
  }
160
177
  // checks whether element or element with additional selection of subelement is placed within the give rectangle
@@ -170,11 +187,11 @@ export class LayoutManagerService {
170
187
  const parentRect = parentRectangle || this.resizeObserverService.getParentAppRect();
171
188
  const elementRect = this._getElementRect(e1, selector, parentRect);
172
189
  if (!elementRect) {
173
- console.error('checkPosition: missing element');
190
+ console.error('checkPosition: missing elementRect');
174
191
  return { deltaX: 0, deltaY: 0 };
175
192
  }
176
193
  if (!elementRect?.width || !elementRect?.height) {
177
- console.error('checkPosition:missing element rect');
194
+ console.error('checkPosition:element rect empty ');
178
195
  return { deltaX: 0, deltaY: 0 };
179
196
  }
180
197
  let checkBoundaries = true;
@@ -201,7 +218,7 @@ export class LayoutManagerService {
201
218
  this._translateRectangle(elementDOMRect, deltaX, deltaY);
202
219
  }
203
220
  }
204
- const selectedElement = this._getDomElement(e1, ''); //e1.element.nativeElement;
221
+ const selectedElement = this._getDomParentElement(e1);
205
222
  if (!selectedElement) {
206
223
  return;
207
224
  }
@@ -312,7 +329,7 @@ export class LayoutManagerService {
312
329
  if (!item) {
313
330
  return;
314
331
  }
315
- const element = this._getDomElement(item, '');
332
+ const element = this._getDomParentElement(item);
316
333
  if (!element) {
317
334
  return;
318
335
  }
@@ -331,4 +348,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "17.3.10", ngImpo
331
348
  providedIn: 'root'
332
349
  }]
333
350
  }], ctorParameters: () => [{ type: i1.ResizeObserverService }, { type: i2.LocalStorageService }] });
334
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-manager.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-bimplus-components/src/lib/services/layout-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef,Injectable } from '@angular/core';\r\nimport { ResizeObserverService } from './resize-observer.service';\r\nimport { LocalStorageService }   from './local-storage.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\n//import { ItemsList } from '@ng-select/ng-select/lib/items-list';\r\n//import { NotFoundError } from 'rxjs';\r\n\r\n\r\nexport interface LayoutManagerItem {\r\n  element:ElementRef;\r\n  id: string;\r\n  selector?:string;\r\n  isCollapsed:boolean;\r\n  rememberPosition?:boolean\r\n  left?: number;\r\n  top?:number;\r\n  width?:number;\r\n  height?:number;\r\n}\r\n\r\nexport interface LayoutManagerConfigItem {\r\n  id: string;\r\n  isCollapsed:boolean;  \r\n  left?: number;\r\n  top?:number;  \r\n  width?:number;\r\n  height?:number;\r\n}\r\n\r\n\r\ninterface LayoutManagerConfig {\r\n  [key:string]: LayoutManagerConfigItem\r\n}\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class LayoutManagerService {\r\n\r\n  registeredItems$: BehaviorSubject<LayoutManagerItem[]> = new BehaviorSubject<LayoutManagerItem[]>([])\r\n  constructor(private resizeObserverService:ResizeObserverService,\r\n              private localStorageService :LocalStorageService \r\n  ) { }\r\n  private registeredItems:LayoutManagerItem[] = [];\r\n  \r\n  get RegisteredItems(): LayoutManagerItem[] {\r\n    return this.registeredItems;\r\n  }\r\n  CONFIG:string = 'layoutManagerConfig';\r\n\r\n  \r\n/**--------------------------------------------------------------------------\r\n  * register object. object must have unique id or elementId\r\n  --------------------------------------------------------------------------*/\r\n  registerObject(obj:ElementRef, id:string, selector:string | undefined, rememberPosition:boolean,left:number = 100, top:number = 100,width:number = 0, height:number = 0) {\r\n    let foundIndex = -1;\r\n    if(this.registeredItems.some((item,index) => {\r\n        const retval = item.id === id;\r\n        if(retval){\r\n          foundIndex = index;\r\n        }\r\n        return retval;\r\n      })){\r\n      if(foundIndex >= 0){\r\n        this.registeredItems.splice(foundIndex,1);\r\n      }      \r\n    }\r\n    const newItem: LayoutManagerItem = { \r\n      element:obj,\r\n      id:id,\r\n      selector:selector,\r\n      rememberPosition:!!rememberPosition,\r\n      left:left,\r\n      top:top,\r\n      width:width,\r\n      height:height,\r\n      isCollapsed: false    \r\n     };\r\n\r\n    this.registeredItems.push(newItem);\r\n    this.registeredItems$.next(this.registeredItems);\r\n    this._initObject(newItem);\r\n  }\r\n  \r\n  _initObject(obj:LayoutManagerItem){\r\n    this._adjustObjectByConfig(obj);\r\n    this._adjustObjectByWindowSize(obj);\r\n    \r\n  }\r\n  /**--------------------------------------------------------------------------\r\n  * get object configuration\r\n  * return {left, top, width, heigth}\r\n  --------------------------------------------------------------------------*/\r\n  _getObjectConfig(obj:LayoutManagerItem):LayoutManagerConfigItem|null {\r\n    if(!obj){\r\n      return null;\r\n    }\r\n    const configValue = this.localStorageService.getItem(this.CONFIG);\r\n    const  config = configValue ? JSON.parse(configValue) : {};\r\n    const  objId = obj.id ;\r\n    let configObj = config[objId];\r\n    if(!configObj) {\r\n      configObj = {id:objId,left:obj.left,top:obj.top,width:obj.width,height:obj.height};        \r\n    }\r\n    return configObj;\r\n  }\r\n\r\n  _adjustObjectByConfig(obj:LayoutManagerItem){\r\n    const config:LayoutManagerConfigItem|null = this._getObjectConfig(obj);\r\n    if(!config){\r\n      return;      \r\n    }\r\n    const  element = this._getDomElement(obj,'');\r\n    if(!element){\r\n      return;\r\n    }\r\n    element.style.left = (config.left) + 'px';\r\n    element.style.top = (config.top) + 'px';\r\n    if(config.width && config.width > 0){\r\n      element.style.width = config.width + 'px';\r\n    }\r\n    if(config.height && config.height > 0){\r\n      element.style.height = config.height + 'px';\r\n    }\r\n    \r\n    this.checkPosition(obj.id,\"\",undefined,0,0,true);    \r\n  }\r\n\r\n  _adjustObjectByWindowSize(obj:LayoutManagerItem){\r\n    this.checkPosition(obj.id,\"\",undefined,0,0,true);  \r\n  }\r\n  \r\n  /**--------------------------------------------------------------------------\r\n  * returns object  registered in the layout manager \r\n  --------------------------------------------------------------------------*/\r\n  getItem(id: string ):LayoutManagerItem|null {   \r\n    let foundItem:LayoutManagerItem|null = null;\r\n    this.registeredItems.forEach(item =>{\r\n      if(item.id === id){\r\n        foundItem = item;\r\n      }\r\n    });\r\n    return foundItem;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * set object configuration\r\n  --------------------------------------------------------------------------*/\r\n  _setObjectConfig(obj:LayoutManagerItem, left:number,top:number,width:number,height:number) {\r\n    const objId = obj?.id ;\r\n    if (!objId) {\r\n      return;\r\n    }\r\n    let config = this.localStorageService.getObject(this.CONFIG) as LayoutManagerConfig;\r\n    //let config = configValue && JSON.parse(configValue) as LayoutManagerConfig;\r\n    if (!config) {\r\n      config = {};\r\n    }\r\n    if(obj?.isCollapsed){  // do not overtake collapsed size\r\n      if (!config[objId]) {        \r\n        config[objId] = obj;\r\n      }\r\n      config[objId].left = left;\r\n      config[objId].top  = top;\r\n      //config[objId].width = width;\r\n      //config[objId].height = height ;\r\n      this.localStorageService.setObject(this.CONFIG, config);\r\n      return;\r\n    }\r\n\r\n    const newItem :LayoutManagerConfigItem = {\r\n      id: objId,\r\n      isCollapsed: false,\r\n      left: left,\r\n      top: top,\r\n      width: width,\r\n      height: height\r\n    };\r\n    config[objId] = newItem;\r\n    this.localStorageService.setObject(this.CONFIG,config);\r\n  }\r\n  _getDomElement(item:LayoutManagerItem,selector:string | undefined ):HTMLElement|null {\r\n    const element:HTMLElement = item.element?.nativeElement?.shadowRoot || item.element?.nativeElement;    \r\n    if(!element){\r\n      console.error('_getDomElement: missing element');\r\n      return null;\r\n    }\r\n    const mySelector =selector && selector?.length > 0 ?selector:item.selector;   \r\n    return mySelector?element.querySelector(mySelector):element;\r\n  }\r\n\r\n  _getElementRect(item:LayoutManagerItem,selector:string | undefined ,parentRectangle:DOMRect |undefined ):DOMRect | null{\r\n    const selectedObj : HTMLElement|null = this._getDomElement(item,selector);\r\n    if(!selectedObj){\r\n      return null;\r\n    }\r\n\r\n    const parentRect:DOMRect =  parentRectangle ||  this.resizeObserverService.getParentAppRect();\r\n    if( !parentRect ||  parentRect?.width<=1 || parentRect?.height<=1 ) {\r\n      console.error('_getElementRect: missing parent rect');\r\n      return null;\r\n    }\r\n    const  elementRect:DOMRect|null = selectedObj.getBoundingClientRect();\r\n    return elementRect;\r\n  }\r\n\r\n  // checks whether element or element with additional selection of subelement is placed within the give rectangle\r\n  // if not then calculates the offset to be moved to fit in\r\n  checkPosition(id:string,selector:string,parentRectangle:DOMRect|undefined ,deltaX:number,deltaY:number,forceCheck:boolean = false){\r\n    if(!id){\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    const e1 = this.getItem(id);\r\n    if(!e1){\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    const parentRect:DOMRect =  parentRectangle ||  this.resizeObserverService.getParentAppRect();\r\n    const elementRect:DOMRect | null = this._getElementRect(e1,selector,parentRect);\r\n    if(!elementRect){\r\n      console.error('checkPosition: missing element');\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    \r\n    if(!elementRect?.width || !elementRect?.height){\r\n      console.error('checkPosition:missing element rect');\r\n      return {deltaX:0,deltaY:0};\r\n    } \r\n    let checkBoundaries = true;\r\n    if(this._isInsideRect(elementRect, parentRect) === false && !forceCheck) {\r\n      checkBoundaries = false;\r\n    }\r\n \r\n    // copy of real element rectangle to perform calculation over before set to the real element\r\n    const elementDOMRect = DOMRect.fromRect(elementRect);\r\n\r\n    //set the element rectangle by deltas\r\n    this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n\r\n    if(checkBoundaries) {\r\n      if(this._isInsideRect(elementDOMRect, parentRect) === false) {\r\n        const  newElementPos = this.getAlignedPosition(elementDOMRect, parentRect);\r\n        deltaX = newElementPos.x - elementRect.x;\r\n        deltaY = newElementPos.y - elementRect.y;\r\n        this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n      }\r\n    } else {\r\n      if (this._isInsideLeftTopRect(parentRect, elementDOMRect) === false) {\r\n        const newElementPos = this._getAlignedLeftTopPosition(elementDOMRect, parentRect);\r\n        deltaX = newElementPos.x - elementRect.x;\r\n        deltaY = newElementPos.y - elementRect.y;\r\n        this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n      }\r\n    }\r\n    const selectedElement = this._getDomElement(e1,'');//e1.element.nativeElement;\r\n    if(!selectedElement){\r\n      return;\r\n    }\r\n    const computedStyle = window.getComputedStyle(selectedElement);\r\n    const top = parseInt(computedStyle.top, 10);\r\n    const left = parseInt(computedStyle.left, 10);\r\n    selectedElement.style.top = (top + deltaY) + 'px';\r\n    selectedElement.style.left = (left + deltaX) + 'px';\r\n    return {deltaX,deltaY};\r\n  }\r\n  /**--------------------------------------------------------------------------\r\n  * find if rectangle 1 is inside rectangle 2\r\n  --------------------------------------------------------------------------*/\r\n  _isInsideRect(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return false;\r\n    }\r\n    return  r2.left <= r1.left  && r2.top <= r1.top && r2.right >= r1.right && r2.bottom >= r1.bottom;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * find if rectangles do not overlap the left and top sides\r\n  --------------------------------------------------------------------------*/\r\n  _isInsideLeftTopRect(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return false;\r\n    }\r\n    const  r1Inside = r2.left <= r1.left  && r2.top <= r1.top;\r\n    const  r2Inside = r1.left <= r2.left  && r1.top <= r2.top;\r\n    return r1Inside || r2Inside;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * get position of r1 aligned with the r2 sides\r\n  --------------------------------------------------------------------------*/\r\n  getAlignedPosition(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return {x:0,y:0};\r\n    }\r\n    const to = { x: r1.x, y: r1.y };\r\n    //align left or right sides. preferably left\r\n    if(r1.left < r2.left) {\r\n      to.x = r2.x;\r\n    } else if(r1.right > r2.right) {\r\n      to.x = r2.right - r1.width;\r\n    }\r\n    //align top or bottom. preferably top\r\n    if(r1.top < r2.top) {\r\n      to.y = r2.y;\r\n    } else if(r1.bottom > r2.bottom) {\r\n      to.y = r2.bottom - r1.height;\r\n    }\r\n    return to;\r\n  }\r\n  \r\n  /**--------------------------------------------------------------------------\r\n  * get position of r1 aligned with the r2 left, top sides\r\n  --------------------------------------------------------------------------*/\r\n  _getAlignedLeftTopPosition(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return  {x:0,y:0};\r\n    }\r\n\r\n    const  to = { x: r1.x, y: r1.y };\r\n    //align left\r\n    if(r1.left < r2.left) {\r\n      to.x = r2.x;\r\n    }\r\n    //align top\r\n    if(r1.top < r2.top) {\r\n      to.y = r2.y;\r\n    }\r\n    return to;\r\n  }\r\n\r\n   /**--------------------------------------------------------------------------\r\n  * translate rectangle by x, y\r\n  --------------------------------------------------------------------------*/\r\n  _translateRectangle(rect:DOMRect, translateX:number, translateY:number) {\r\n    if(!rect) {\r\n      return;\r\n    }\r\n    rect.x += translateX;\r\n    rect.y += translateY;\r\n    return rect;\r\n  }\r\n  \r\n  updateCollapsed(value:boolean, id:string = ''):void{    \r\n    const  foundItem = this.getItem(id);\r\n    if(!foundItem){\r\n      return;\r\n    }\r\n    foundItem.isCollapsed = value;\r\n    this.registeredItems$.next(this.registeredItems);\r\n    setTimeout(()=>{      \r\n      this.checkPosition(foundItem.id,\"\",undefined,0,0,true);      \r\n    });\r\n    let s1:string ='';\r\n    this.registeredItems.forEach((item)=>{\r\n      s1 = s1 + `${item.id}:<${item.isCollapsed?1:0}> `;\r\n    });\r\n  }  \r\n\r\n\r\n  handleDragEnd(id:string){//},left:number,top:number){\r\n    this.finalizeObjectChanges(id);\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * finalize object changes (position). object must be registered in the layout manager\r\n  * object: object to finalize  \r\n  --------------------------------------------------------------------------*/\r\n  finalizeObjectChanges(id:string):void {\r\n    const item:LayoutManagerItem|null  = this.getItem(id);\r\n    if(!item){\r\n      return;\r\n    }\r\n    const element = this._getDomElement(item,'');\r\n    if(!element){\r\n      return;\r\n    }\r\n    const computedStyle = window.getComputedStyle(element);  \r\n    const top = parseInt(computedStyle.top, 10);\r\n    const left = parseInt(computedStyle.left, 10);\r\n    \r\n    const elementRect = this._getElementRect(item,undefined,undefined);\r\n    this._setObjectConfig(item,left,top,\r\n                          elementRect && elementRect.width > 0 ? elementRect.width:0 ,\r\n                          elementRect && elementRect.height > 0 ? elementRect.height:0);\r\n  }\r\n}\r\n\r\n"]}
351
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"layout-manager.service.js","sourceRoot":"","sources":["../../../../../projects/ngx-bimplus-components/src/lib/services/layout-manager.service.ts"],"names":[],"mappings":"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","sourcesContent":["import { ElementRef,Injectable } from '@angular/core';\r\nimport { ResizeObserverService } from './resize-observer.service';\r\nimport { LocalStorageService }   from './local-storage.service';\r\nimport { BehaviorSubject } from 'rxjs';\r\n//import { ItemsList } from '@ng-select/ng-select/lib/items-list';\r\n//import { NotFoundError } from 'rxjs';\r\n\r\n\r\nexport interface LayoutManagerItem {\r\n  element:ElementRef;\r\n  id: string;\r\n  selector?:string;\r\n  isCollapsed:boolean;\r\n  rememberPosition?:boolean\r\n  left?: number;\r\n  top?:number;\r\n  width?:number;\r\n  height?:number;\r\n}\r\n\r\nexport interface LayoutManagerConfigItem {\r\n  id: string;\r\n  isCollapsed:boolean;  \r\n  left?: number;\r\n  top?:number;  \r\n  width?:number;\r\n  height?:number;\r\n}\r\n\r\n\r\ninterface LayoutManagerConfig {\r\n  [key:string]: LayoutManagerConfigItem\r\n}\r\n@Injectable({\r\n  providedIn: 'root'\r\n})\r\nexport class LayoutManagerService {\r\n\r\n  registeredItems$: BehaviorSubject<LayoutManagerItem[]> = new BehaviorSubject<LayoutManagerItem[]>([])\r\n  constructor(private resizeObserverService:ResizeObserverService,\r\n              private localStorageService :LocalStorageService \r\n  ) { }\r\n  private registeredItems:LayoutManagerItem[] = [];\r\n  \r\n  get RegisteredItems(): LayoutManagerItem[] {\r\n    return this.registeredItems;\r\n  }\r\n  CONFIG:string = 'layoutManagerConfig';\r\n\r\n  \r\n/**--------------------------------------------------------------------------\r\n  * register object. object must have unique id or elementId\r\n  --------------------------------------------------------------------------*/\r\n  registerObject(obj:ElementRef, id:string, selector:string | undefined, rememberPosition:boolean,left:number = 100, top:number = 100,width:number = 0, height:number = 0) {\r\n    let foundIndex = -1;\r\n    if(this.registeredItems.some((item,index) => {\r\n        const retval = item.id === id;\r\n        if(retval){\r\n          foundIndex = index;\r\n        }\r\n        return retval;\r\n      })){\r\n      if(foundIndex >= 0){\r\n        this.registeredItems.splice(foundIndex,1);\r\n      }      \r\n    }\r\n    const newItem: LayoutManagerItem = { \r\n      element:obj,\r\n      id:id,\r\n      selector:selector,\r\n      rememberPosition:!!rememberPosition,\r\n      left:left,\r\n      top:top,\r\n      width:width,\r\n      height:height,\r\n      isCollapsed: false    \r\n     };\r\n\r\n    this.registeredItems.push(newItem);\r\n    this.registeredItems$.next(this.registeredItems);\r\n    this._initObject(newItem);\r\n  }\r\n  \r\n  _initObject(obj:LayoutManagerItem){\r\n    this._adjustObjectByConfig(obj);\r\n    this._adjustObjectByWindowSize(obj);\r\n    \r\n  }\r\n  /**--------------------------------------------------------------------------\r\n  * get object configuration\r\n  * return {left, top, width, heigth}\r\n  --------------------------------------------------------------------------*/\r\n  _getObjectConfig(obj:LayoutManagerItem):LayoutManagerConfigItem|null {\r\n    if(!obj){\r\n      return null;\r\n    }\r\n    const configValue = this.localStorageService.getItem(this.CONFIG);\r\n    const  config = configValue ? JSON.parse(configValue) : {};\r\n    const  objId = obj.id ;\r\n    let configObj = config[objId];\r\n    if(!configObj) {\r\n      configObj = {id:objId,left:obj.left,top:obj.top,width:obj.width,height:obj.height};        \r\n    }\r\n    return configObj;\r\n  }\r\n\r\n  _adjustObjectByConfig(obj:LayoutManagerItem){\r\n    const config:LayoutManagerConfigItem|null = this._getObjectConfig(obj);\r\n    if(!config){\r\n      return;      \r\n    }\r\n    const  parentElement = this._getDomParentElement(obj);\r\n    const  internalElement = this._getDomInternalElement(obj,'');\r\n    if(!parentElement || !internalElement){\r\n      return;\r\n    }\r\n    parentElement.style.left = (config.left) + 'px';\r\n    parentElement.style.top = (config.top) + 'px';\r\n    if(config.width && config.width > 0){\r\n      internalElement.style.width = config.width + 'px';\r\n    }\r\n    if(config.height && config.height > 0){\r\n      internalElement.style.height = config.height + 'px';\r\n    }\r\n    \r\n    this.checkPosition(obj.id,\"\",undefined,0,0,true);    \r\n  }\r\n\r\n  _adjustObjectByWindowSize(obj:LayoutManagerItem){\r\n    this.checkPosition(obj.id,\"\",undefined,0,0,true);  \r\n  }\r\n  \r\n  /**--------------------------------------------------------------------------\r\n  * returns object  registered in the layout manager \r\n  --------------------------------------------------------------------------*/\r\n  getItem(id: string ):LayoutManagerItem|null {   \r\n    let foundItem:LayoutManagerItem|null = null;\r\n    this.registeredItems.forEach(item =>{\r\n      if(item.id === id){\r\n        foundItem = item;\r\n      }\r\n    });\r\n    return foundItem;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * set object configuration\r\n  --------------------------------------------------------------------------*/\r\n  _setObjectConfig(obj:LayoutManagerItem, left:number,top:number,width:number,height:number) {\r\n    const objId = obj?.id ;\r\n    if (!objId) {\r\n      return;\r\n    }\r\n    let config = this.localStorageService.getObject(this.CONFIG) as LayoutManagerConfig;\r\n    //let config = configValue && JSON.parse(configValue) as LayoutManagerConfig;\r\n    if (!config) {\r\n      config = {};\r\n    }\r\n    if(obj?.isCollapsed){  // do not overtake collapsed size\r\n      if (!config[objId]) {        \r\n        config[objId] = obj;\r\n      }\r\n      config[objId].left = left;\r\n      config[objId].top  = top;\r\n      //config[objId].width = width;\r\n      //config[objId].height = height ;\r\n      this.localStorageService.setObject(this.CONFIG, config);\r\n      return;\r\n    }\r\n\r\n    const newItem :LayoutManagerConfigItem = {\r\n      id: objId,\r\n      isCollapsed: false,\r\n      left: left,\r\n      top: top,\r\n      width: width,\r\n      height: height\r\n    };\r\n    config[objId] = newItem;\r\n    this.localStorageService.setObject(this.CONFIG,config);\r\n  }\r\n  _getDomParentElement(item:LayoutManagerItem ):HTMLElement|null {\r\n    const element:HTMLElement = item.element?.nativeElement;//?.shadowRoot || item.element?.nativeElement;    \r\n    if(!element){\r\n      console.error('_getDomParentElement: missing element');\r\n      return null;\r\n    }\r\n    return element;    \r\n  }\r\n\r\n  _getDomInternalElement(item:LayoutManagerItem,selector:string | undefined ):HTMLElement|null {\r\n    const element:HTMLElement = item.element?.nativeElement?.shadowRoot || item.element?.nativeElement;    \r\n    if(!element){\r\n      console.error('_getDomInternalElement: missing element');\r\n      return null;\r\n    }\r\n    const mySelector =selector && selector?.length > 0 ?selector:item.selector;   \r\n    const retval: HTMLElement|null= mySelector?element.querySelector(mySelector):element;\r\n    if(!retval){\r\n      console.error(`_getDomInternalElement: selection of element ${element}  failed with selector ${mySelector}`);\r\n    }\r\n    return retval;\r\n  }\r\n\r\n\r\n  _getElementRect(item:LayoutManagerItem,selector:string | undefined ,parentRectangle:DOMRect |undefined ):DOMRect | null{\r\n    const selectedObj : HTMLElement|null = this._getDomInternalElement(item,selector);\r\n    if(!selectedObj){\r\n      console.error('_getElementRect: missing selected object');\r\n      return null;\r\n    }\r\n\r\n    const parentRect:DOMRect =  parentRectangle ||  this.resizeObserverService.getParentAppRect();\r\n    if( !parentRect ||  parentRect?.width<=1 || parentRect?.height<=1 ) {\r\n      console.error('_getElementRect: missing parent rect');\r\n      return null;\r\n    }\r\n    const  elementRect:DOMRect|null = selectedObj.getBoundingClientRect();\r\n    if(!elementRect){\r\n      console.error('_getElementRect: missing bounding rect');\r\n    }\r\n    return elementRect;\r\n  }\r\n\r\n  // checks whether element or element with additional selection of subelement is placed within the give rectangle\r\n  // if not then calculates the offset to be moved to fit in\r\n  checkPosition(id:string,selector:string,parentRectangle:DOMRect|undefined ,deltaX:number,deltaY:number,forceCheck:boolean = false){\r\n    if(!id){\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    const e1 = this.getItem(id);\r\n    if(!e1){\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    const parentRect:DOMRect =  parentRectangle ||  this.resizeObserverService.getParentAppRect();\r\n    const elementRect:DOMRect | null = this._getElementRect(e1,selector,parentRect);\r\n    if(!elementRect){\r\n      console.error('checkPosition: missing elementRect');\r\n      return {deltaX:0,deltaY:0};\r\n    }\r\n    \r\n    if(!elementRect?.width || !elementRect?.height){\r\n      console.error('checkPosition:element rect empty ');\r\n      return {deltaX:0,deltaY:0};\r\n    } \r\n    let checkBoundaries = true;\r\n    if(this._isInsideRect(elementRect, parentRect) === false && !forceCheck) {\r\n      checkBoundaries = false;\r\n    }\r\n \r\n    // copy of real element rectangle to perform calculation over before set to the real element\r\n    const elementDOMRect = DOMRect.fromRect(elementRect);\r\n\r\n    //set the element rectangle by deltas\r\n    this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n\r\n    if(checkBoundaries) {\r\n      if(this._isInsideRect(elementDOMRect, parentRect) === false) {\r\n        const  newElementPos = this.getAlignedPosition(elementDOMRect, parentRect);\r\n        deltaX = newElementPos.x - elementRect.x;\r\n        deltaY = newElementPos.y - elementRect.y;\r\n        this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n      }\r\n    } else {\r\n      if (this._isInsideLeftTopRect(parentRect, elementDOMRect) === false) {\r\n        const newElementPos = this._getAlignedLeftTopPosition(elementDOMRect, parentRect);\r\n        deltaX = newElementPos.x - elementRect.x;\r\n        deltaY = newElementPos.y - elementRect.y;\r\n        this._translateRectangle(elementDOMRect, deltaX, deltaY);\r\n      }\r\n    }\r\n    const selectedElement = this._getDomParentElement(e1);\r\n    if(!selectedElement){\r\n      return;\r\n    }\r\n    const computedStyle = window.getComputedStyle(selectedElement);\r\n    const top = parseInt(computedStyle.top, 10);\r\n    const left = parseInt(computedStyle.left, 10);\r\n    selectedElement.style.top = (top + deltaY) + 'px';\r\n    selectedElement.style.left = (left + deltaX) + 'px';\r\n    return {deltaX,deltaY};\r\n  }\r\n  /**--------------------------------------------------------------------------\r\n  * find if rectangle 1 is inside rectangle 2\r\n  --------------------------------------------------------------------------*/\r\n  _isInsideRect(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return false;\r\n    }\r\n    return  r2.left <= r1.left  && r2.top <= r1.top && r2.right >= r1.right && r2.bottom >= r1.bottom;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * find if rectangles do not overlap the left and top sides\r\n  --------------------------------------------------------------------------*/\r\n  _isInsideLeftTopRect(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return false;\r\n    }\r\n    const  r1Inside = r2.left <= r1.left  && r2.top <= r1.top;\r\n    const  r2Inside = r1.left <= r2.left  && r1.top <= r2.top;\r\n    return r1Inside || r2Inside;\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * get position of r1 aligned with the r2 sides\r\n  --------------------------------------------------------------------------*/\r\n  getAlignedPosition(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return {x:0,y:0};\r\n    }\r\n    const to = { x: r1.x, y: r1.y };\r\n    //align left or right sides. preferably left\r\n    if(r1.left < r2.left) {\r\n      to.x = r2.x;\r\n    } else if(r1.right > r2.right) {\r\n      to.x = r2.right - r1.width;\r\n    }\r\n    //align top or bottom. preferably top\r\n    if(r1.top < r2.top) {\r\n      to.y = r2.y;\r\n    } else if(r1.bottom > r2.bottom) {\r\n      to.y = r2.bottom - r1.height;\r\n    }\r\n    return to;\r\n  }\r\n  \r\n  /**--------------------------------------------------------------------------\r\n  * get position of r1 aligned with the r2 left, top sides\r\n  --------------------------------------------------------------------------*/\r\n  _getAlignedLeftTopPosition(r1:DOMRect, r2:DOMRect) {\r\n    if(!r1 || !r2) {\r\n      return  {x:0,y:0};\r\n    }\r\n\r\n    const  to = { x: r1.x, y: r1.y };\r\n    //align left\r\n    if(r1.left < r2.left) {\r\n      to.x = r2.x;\r\n    }\r\n    //align top\r\n    if(r1.top < r2.top) {\r\n      to.y = r2.y;\r\n    }\r\n    return to;\r\n  }\r\n\r\n   /**--------------------------------------------------------------------------\r\n  * translate rectangle by x, y\r\n  --------------------------------------------------------------------------*/\r\n  _translateRectangle(rect:DOMRect, translateX:number, translateY:number) {\r\n    if(!rect) {\r\n      return;\r\n    }\r\n    rect.x += translateX;\r\n    rect.y += translateY;\r\n    return rect;\r\n  }\r\n  \r\n  updateCollapsed(value:boolean, id:string = ''):void{    \r\n    const  foundItem = this.getItem(id);\r\n    if(!foundItem){\r\n      return;\r\n    }\r\n    foundItem.isCollapsed = value;\r\n    this.registeredItems$.next(this.registeredItems);\r\n    setTimeout(()=>{      \r\n      this.checkPosition(foundItem.id,\"\",undefined,0,0,true);      \r\n    });\r\n    let s1:string ='';\r\n    this.registeredItems.forEach((item)=>{\r\n      s1 = s1 + `${item.id}:<${item.isCollapsed?1:0}> `;\r\n    });\r\n  }  \r\n\r\n\r\n  handleDragEnd(id:string){//},left:number,top:number){\r\n    this.finalizeObjectChanges(id);\r\n  }\r\n\r\n  /**--------------------------------------------------------------------------\r\n  * finalize object changes (position). object must be registered in the layout manager\r\n  * object: object to finalize  \r\n  --------------------------------------------------------------------------*/\r\n  finalizeObjectChanges(id:string):void {\r\n    const item:LayoutManagerItem|null  = this.getItem(id);\r\n    if(!item){\r\n      return;\r\n    }\r\n    const element = this._getDomParentElement(item);\r\n    if(!element){\r\n      return;\r\n    }\r\n    const computedStyle = window.getComputedStyle(element);  \r\n    const top = parseInt(computedStyle.top, 10);\r\n    const left = parseInt(computedStyle.left, 10);\r\n    \r\n    const elementRect = this._getElementRect(item,undefined,undefined);\r\n    this._setObjectConfig(item,left,top,\r\n                          elementRect && elementRect.width > 0 ? elementRect.width:0 ,\r\n                          elementRect && elementRect.height > 0 ? elementRect.height:0);\r\n  }\r\n}\r\n\r\n"]}
@@ -814,17 +814,18 @@ class LayoutManagerService {
814
814
  if (!config) {
815
815
  return;
816
816
  }
817
- const element = this._getDomElement(obj, '');
818
- if (!element) {
817
+ const parentElement = this._getDomParentElement(obj);
818
+ const internalElement = this._getDomInternalElement(obj, '');
819
+ if (!parentElement || !internalElement) {
819
820
  return;
820
821
  }
821
- element.style.left = (config.left) + 'px';
822
- element.style.top = (config.top) + 'px';
822
+ parentElement.style.left = (config.left) + 'px';
823
+ parentElement.style.top = (config.top) + 'px';
823
824
  if (config.width && config.width > 0) {
824
- element.style.width = config.width + 'px';
825
+ internalElement.style.width = config.width + 'px';
825
826
  }
826
827
  if (config.height && config.height > 0) {
827
- element.style.height = config.height + 'px';
828
+ internalElement.style.height = config.height + 'px';
828
829
  }
829
830
  this.checkPosition(obj.id, "", undefined, 0, 0, true);
830
831
  }
@@ -878,18 +879,31 @@ class LayoutManagerService {
878
879
  config[objId] = newItem;
879
880
  this.localStorageService.setObject(this.CONFIG, config);
880
881
  }
881
- _getDomElement(item, selector) {
882
+ _getDomParentElement(item) {
883
+ const element = item.element?.nativeElement; //?.shadowRoot || item.element?.nativeElement;
884
+ if (!element) {
885
+ console.error('_getDomParentElement: missing element');
886
+ return null;
887
+ }
888
+ return element;
889
+ }
890
+ _getDomInternalElement(item, selector) {
882
891
  const element = item.element?.nativeElement?.shadowRoot || item.element?.nativeElement;
883
892
  if (!element) {
884
- console.error('_getDomElement: missing element');
893
+ console.error('_getDomInternalElement: missing element');
885
894
  return null;
886
895
  }
887
896
  const mySelector = selector && selector?.length > 0 ? selector : item.selector;
888
- return mySelector ? element.querySelector(mySelector) : element;
897
+ const retval = mySelector ? element.querySelector(mySelector) : element;
898
+ if (!retval) {
899
+ console.error(`_getDomInternalElement: selection of element ${element} failed with selector ${mySelector}`);
900
+ }
901
+ return retval;
889
902
  }
890
903
  _getElementRect(item, selector, parentRectangle) {
891
- const selectedObj = this._getDomElement(item, selector);
904
+ const selectedObj = this._getDomInternalElement(item, selector);
892
905
  if (!selectedObj) {
906
+ console.error('_getElementRect: missing selected object');
893
907
  return null;
894
908
  }
895
909
  const parentRect = parentRectangle || this.resizeObserverService.getParentAppRect();
@@ -898,6 +912,9 @@ class LayoutManagerService {
898
912
  return null;
899
913
  }
900
914
  const elementRect = selectedObj.getBoundingClientRect();
915
+ if (!elementRect) {
916
+ console.error('_getElementRect: missing bounding rect');
917
+ }
901
918
  return elementRect;
902
919
  }
903
920
  // checks whether element or element with additional selection of subelement is placed within the give rectangle
@@ -913,11 +930,11 @@ class LayoutManagerService {
913
930
  const parentRect = parentRectangle || this.resizeObserverService.getParentAppRect();
914
931
  const elementRect = this._getElementRect(e1, selector, parentRect);
915
932
  if (!elementRect) {
916
- console.error('checkPosition: missing element');
933
+ console.error('checkPosition: missing elementRect');
917
934
  return { deltaX: 0, deltaY: 0 };
918
935
  }
919
936
  if (!elementRect?.width || !elementRect?.height) {
920
- console.error('checkPosition:missing element rect');
937
+ console.error('checkPosition:element rect empty ');
921
938
  return { deltaX: 0, deltaY: 0 };
922
939
  }
923
940
  let checkBoundaries = true;
@@ -944,7 +961,7 @@ class LayoutManagerService {
944
961
  this._translateRectangle(elementDOMRect, deltaX, deltaY);
945
962
  }
946
963
  }
947
- const selectedElement = this._getDomElement(e1, ''); //e1.element.nativeElement;
964
+ const selectedElement = this._getDomParentElement(e1);
948
965
  if (!selectedElement) {
949
966
  return;
950
967
  }
@@ -1055,7 +1072,7 @@ class LayoutManagerService {
1055
1072
  if (!item) {
1056
1073
  return;
1057
1074
  }
1058
- const element = this._getDomElement(item, '');
1075
+ const element = this._getDomParentElement(item);
1059
1076
  if (!element) {
1060
1077
  return;
1061
1078
  }
@@ -1603,7 +1620,7 @@ class BimplusFloatingBarHideObjectsComponent extends BimplusLocalizedWidgetCompo
1603
1620
  this.focusSelectorId = 'hide-menu-id';
1604
1621
  this.layoutManagerService = layoutManagerService;
1605
1622
  }
1606
- ngOnInit() {
1623
+ ngAfterViewInit() {
1607
1624
  // Subscribe to the observable
1608
1625
  this.layoutManagerService.registerObject(this.element, this.componentId, '.floating-panel.visible', true, DEFAULT_POSITION_LEFT$3, DEFAULT_POSITION_TOP$3);
1609
1626
  }
@@ -1649,7 +1666,7 @@ class BimplusFloatingBarIsolationObjectsComponent extends BimplusLocalizedWidget
1649
1666
  this.focusSelectorId = 'isolation-menu-id';
1650
1667
  this.componentId = 'isolation-menu-fp-id';
1651
1668
  }
1652
- ngOnInit() {
1669
+ ngAfterViewInit() {
1653
1670
  this.layoutManagerService.registerObject(this.element, this.componentId, '.floating-panel.visible', true, DEFAULT_POSITION_LEFT$2, DEFAULT_POSITION_TOP$2);
1654
1671
  }
1655
1672
  ngAfterViewChecked() {