ngx-bimplus-components 0.0.155-28793-1 → 0.0.155-29322-1

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.
Files changed (30) hide show
  1. package/assets/images/default/progress-spinner.svg +1 -0
  2. package/esm2022/lib/components/bimplus-attachments/components/bimplus-attachment-item/bimplus-attachment-item.component.mjs +3 -3
  3. package/esm2022/lib/components/bimplus-link-tooltip-message/bimplus-link-tooltip-message.component.mjs +105 -0
  4. package/esm2022/lib/components/bimplus-link-tooltip-message/tooltipMessageSettings.mjs +2 -0
  5. package/esm2022/lib/components/bimplus-object-comments-list/bimplus-object-comments-list.component.mjs +22 -8
  6. package/esm2022/lib/components/bimplus-status-bar/bimplus-status-bar.component.mjs +35 -0
  7. package/esm2022/lib/components/bimplus-status-bar/bimplus-status-bar.service.mjs +35 -0
  8. package/esm2022/lib/components/bimplus-status-bar/statusBar.mjs +2 -0
  9. package/esm2022/lib/components/bimplus-tabs-switcher/components/bimplus-tab/bimplus-tab.component.mjs +3 -3
  10. package/esm2022/lib/components/object-preview/object-preview.component.mjs +42 -14
  11. package/esm2022/lib/components/object-properties/object-properties.component.mjs +9 -6
  12. package/esm2022/lib/components/object-properties/object-properties.service.mjs +26 -0
  13. package/esm2022/lib/components/object-properties-header/object-properties-header.component.mjs +29 -5
  14. package/esm2022/lib/components/object-properties-header/object-properties-header.interface.mjs +1 -1
  15. package/esm2022/public-api.mjs +5 -1
  16. package/fesm2022/ngx-bimplus-components.mjs +289 -33
  17. package/fesm2022/ngx-bimplus-components.mjs.map +1 -1
  18. package/lib/components/bimplus-link-tooltip-message/bimplus-link-tooltip-message.component.d.ts +29 -0
  19. package/lib/components/bimplus-link-tooltip-message/tooltipMessageSettings.d.ts +22 -0
  20. package/lib/components/bimplus-object-comments-list/bimplus-object-comments-list.component.d.ts +7 -3
  21. package/lib/components/bimplus-status-bar/bimplus-status-bar.component.d.ts +14 -0
  22. package/lib/components/bimplus-status-bar/bimplus-status-bar.service.d.ts +14 -0
  23. package/lib/components/bimplus-status-bar/statusBar.d.ts +4 -0
  24. package/lib/components/object-preview/object-preview.component.d.ts +6 -3
  25. package/lib/components/object-properties/object-properties.component.d.ts +3 -1
  26. package/lib/components/object-properties/object-properties.service.d.ts +12 -0
  27. package/lib/components/object-properties-header/object-properties-header.component.d.ts +6 -2
  28. package/lib/components/object-properties-header/object-properties-header.interface.d.ts +10 -0
  29. package/package.json +3 -3
  30. package/public-api.d.ts +4 -0
@@ -0,0 +1 @@
1
+ <svg class="lds-spinner" width="200" height="200" xmlns="http://www.w3.org/2000/svg" viewBox="0 0 100 100" preserveAspectRatio="xMidYMid" style="background:0 0"><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.9166666666666666s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(30 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.8333333333333334s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(60 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.75s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(90 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.6666666666666666s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(120 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5833333333333334s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(150 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.5s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(180 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.4166666666666667s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(210 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.3333333333333333s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(240 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.25s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(270 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.16666666666666666s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(300 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="-0.08333333333333333s" repeatCount="indefinite"/></rect><rect x="47" y="17.5" rx="9.4" ry="3.5" width="6" height="25" fill="#fff" transform="rotate(330 50 50)"><animate attributeName="opacity" values="1;0" keyTimes="0;1" dur="1s" begin="0s" repeatCount="indefinite"/></rect></svg>
@@ -66,11 +66,11 @@ export class BimplusAttachmentItemComponent {
66
66
  this.intersectionObserver = new IntersectionObserver(callback, options);
67
67
  }
68
68
  static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusAttachmentItemComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
69
- static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: BimplusAttachmentItemComponent, isStandalone: true, selector: "lib-bimplus-attachment-item", inputs: { closeIconTemplate: "closeIconTemplate", attachment: "attachment", parentWidth: "parentWidth" }, outputs: { deleteAttachment: "deleteAttachment", getAttachment: "getAttachment" }, viewQueries: [{ propertyName: "attachmentSizeRef", first: true, predicate: ["attachmentSizeRef"], descendants: true }, { propertyName: "attachmentNameRef", first: true, predicate: ["attachmentNameRef"], descendants: true }], ngImport: i0, template: "<div class=\"bim-attachment-item\">\r\n <div\r\n data-test=\"bim-attachment\"\r\n (click)=\"getAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n title=\"{{ attachment.fileName }}\"\r\n class=\"bim-attachment-name\"\r\n [style.width.px]=\"nameInfoLineWidth()\"\r\n >\r\n <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n @if (nameIsfullyVisible() && !hideSize) {\r\n <span class=\"bim-attachment-size\">{{\r\n attachment.size | bitConverter\r\n }}</span>\r\n }\r\n </div>\r\n @if(!nameIsfullyVisible() && !hideSize) {\r\n <span>{{ type }} </span>\r\n <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n {{ attachment.size | bitConverter }}\r\n </div>\r\n }\r\n @if (!config?.hideDeleteAttachmentButton) {\r\n <span\r\n data-test=\"delete-attachment-btn\"\r\n class=\"bim-attachment-delete-button\"\r\n title=\"{{ '_Delete attachment' | translate }}\"\r\n (click)=\"deleteAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n >\r\n <span class=\"icon\">\u2715\uFE0E</span>\r\n </span>\r\n }\r\n</div>\r\n", styles: [".bim-attachment-item{border-bottom:var(--bim-attachment-item-border-bottom, .1rem solid var(--bim-attachment-item-border-bottom-color, #B8BBBF));line-height:2.5rem;display:flex;align-items:center;justify-content:space-between;color:#46494d;padding-left:var(--bim-attachment-item-padding-left, 2.6rem);background-image:var(--bim-attachment-item-background-image, url(data:image/png;base64,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));background-repeat:no-repeat;background-size:1.8rem;background-position:var(--bim-attachment-item-background-position, .8rem center)}.bim-attachment-item .bim-attachment-name{padding-left:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bim-attachment-item .bim-attachment-size{padding-left:.5rem;white-space:nowrap;margin-right:.4rem}.bim-attachment-item .bim-attachment-delete-button{width:30px;cursor:pointer;margin-left:auto}.bim-attachment-item .bim-attachment-delete-button .icon{font-weight:var(--bim-attachment-delete-button-icon-font-weight, normal);color:var(--bim-attachment-delete-button-icon-color, #B8BBBF)}.bim-attachment-item .bim-attachment-delete-button .icon:hover{color:#46494d}\n"], dependencies: [{ kind: "pipe", type: BitConverterPipe, name: "bitConverter" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
69
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "17.0.0", version: "18.2.12", type: BimplusAttachmentItemComponent, isStandalone: true, selector: "lib-bimplus-attachment-item", inputs: { closeIconTemplate: "closeIconTemplate", attachment: "attachment", parentWidth: "parentWidth" }, outputs: { deleteAttachment: "deleteAttachment", getAttachment: "getAttachment" }, viewQueries: [{ propertyName: "attachmentSizeRef", first: true, predicate: ["attachmentSizeRef"], descendants: true }, { propertyName: "attachmentNameRef", first: true, predicate: ["attachmentNameRef"], descendants: true }], ngImport: i0, template: "<div class=\"bim-attachment-item\">\r\n <div\r\n data-test=\"bim-attachment\"\r\n (click)=\"getAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n title=\"{{ attachment.fileName }}\"\r\n class=\"bim-attachment-name\"\r\n [style.width.px]=\"nameInfoLineWidth()\"\r\n >\r\n <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n @if (nameIsfullyVisible() && !hideSize) {\r\n <span class=\"bim-attachment-size\">{{\r\n attachment.size | bitConverter\r\n }}</span>\r\n }\r\n </div>\r\n @if(!nameIsfullyVisible() && !hideSize) {\r\n <span>{{ type }} </span>\r\n <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n {{ attachment.size | bitConverter }}\r\n </div>\r\n }\r\n @if (!config?.hideDeleteAttachmentButton) {\r\n <span\r\n data-test=\"delete-attachment-btn\"\r\n class=\"bim-attachment-delete-button\"\r\n title=\"{{ '_Delete attachment' | translate }}\"\r\n (click)=\"deleteAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n >\r\n <span class=\"icon\">\u2715\uFE0E</span>\r\n </span>\r\n }\r\n</div>\r\n", styles: [".bim-attachment-item{border-bottom:var(--bim-attachment-item-border-bottom, .1rem solid var(--bim-attachment-item-border-bottom-color, #B8BBBF));line-height:2.5rem;display:flex;align-items:center;justify-content:space-between;color:#46494d;padding-left:var(--bim-attachment-item-padding-left, 2.6rem);background-image:var(--bim-attachment-item-background-image, url(data:image/png;base64,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));background-size:var(--bim-attachment-item-background-size, auto);background-repeat:no-repeat;background-position:var(--bim-attachment-item-background-position, .8rem center)}.bim-attachment-item .bim-attachment-name{padding-left:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bim-attachment-item .bim-attachment-size{padding-left:.5rem;white-space:nowrap;margin-right:.4rem}.bim-attachment-item .bim-attachment-delete-button{width:30px;cursor:pointer;margin-left:auto}.bim-attachment-item .bim-attachment-delete-button .icon{font-weight:var(--bim-attachment-delete-button-icon-font-weight, normal);color:var(--bim-attachment-delete-button-icon-color, #B8BBBF)}.bim-attachment-item .bim-attachment-delete-button .icon:hover{color:#46494d}\n"], dependencies: [{ kind: "pipe", type: BitConverterPipe, name: "bitConverter" }, { kind: "ngmodule", type: TranslateModule }, { kind: "pipe", type: i1.TranslatePipe, name: "translate" }] }); }
70
70
  }
71
71
  i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusAttachmentItemComponent, decorators: [{
72
72
  type: Component,
73
- args: [{ selector: 'lib-bimplus-attachment-item', standalone: true, imports: [BitConverterPipe, TranslateModule], template: "<div class=\"bim-attachment-item\">\r\n <div\r\n data-test=\"bim-attachment\"\r\n (click)=\"getAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n title=\"{{ attachment.fileName }}\"\r\n class=\"bim-attachment-name\"\r\n [style.width.px]=\"nameInfoLineWidth()\"\r\n >\r\n <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n @if (nameIsfullyVisible() && !hideSize) {\r\n <span class=\"bim-attachment-size\">{{\r\n attachment.size | bitConverter\r\n }}</span>\r\n }\r\n </div>\r\n @if(!nameIsfullyVisible() && !hideSize) {\r\n <span>{{ type }} </span>\r\n <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n {{ attachment.size | bitConverter }}\r\n </div>\r\n }\r\n @if (!config?.hideDeleteAttachmentButton) {\r\n <span\r\n data-test=\"delete-attachment-btn\"\r\n class=\"bim-attachment-delete-button\"\r\n title=\"{{ '_Delete attachment' | translate }}\"\r\n (click)=\"deleteAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n >\r\n <span class=\"icon\">\u2715\uFE0E</span>\r\n </span>\r\n }\r\n</div>\r\n", styles: [".bim-attachment-item{border-bottom:var(--bim-attachment-item-border-bottom, .1rem solid var(--bim-attachment-item-border-bottom-color, #B8BBBF));line-height:2.5rem;display:flex;align-items:center;justify-content:space-between;color:#46494d;padding-left:var(--bim-attachment-item-padding-left, 2.6rem);background-image:var(--bim-attachment-item-background-image, url(data:image/png;base64,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));background-repeat:no-repeat;background-size:1.8rem;background-position:var(--bim-attachment-item-background-position, .8rem center)}.bim-attachment-item .bim-attachment-name{padding-left:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bim-attachment-item .bim-attachment-size{padding-left:.5rem;white-space:nowrap;margin-right:.4rem}.bim-attachment-item .bim-attachment-delete-button{width:30px;cursor:pointer;margin-left:auto}.bim-attachment-item .bim-attachment-delete-button .icon{font-weight:var(--bim-attachment-delete-button-icon-font-weight, normal);color:var(--bim-attachment-delete-button-icon-color, #B8BBBF)}.bim-attachment-item .bim-attachment-delete-button .icon:hover{color:#46494d}\n"] }]
73
+ args: [{ selector: 'lib-bimplus-attachment-item', standalone: true, imports: [BitConverterPipe, TranslateModule], template: "<div class=\"bim-attachment-item\">\r\n <div\r\n data-test=\"bim-attachment\"\r\n (click)=\"getAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n title=\"{{ attachment.fileName }}\"\r\n class=\"bim-attachment-name\"\r\n [style.width.px]=\"nameInfoLineWidth()\"\r\n >\r\n <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n @if (nameIsfullyVisible() && !hideSize) {\r\n <span class=\"bim-attachment-size\">{{\r\n attachment.size | bitConverter\r\n }}</span>\r\n }\r\n </div>\r\n @if(!nameIsfullyVisible() && !hideSize) {\r\n <span>{{ type }} </span>\r\n <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n {{ attachment.size | bitConverter }}\r\n </div>\r\n }\r\n @if (!config?.hideDeleteAttachmentButton) {\r\n <span\r\n data-test=\"delete-attachment-btn\"\r\n class=\"bim-attachment-delete-button\"\r\n title=\"{{ '_Delete attachment' | translate }}\"\r\n (click)=\"deleteAttachment.emit(attachment)\"\r\n (keypress)=\"$event.preventDefault()\"\r\n >\r\n <span class=\"icon\">\u2715\uFE0E</span>\r\n </span>\r\n }\r\n</div>\r\n", styles: [".bim-attachment-item{border-bottom:var(--bim-attachment-item-border-bottom, .1rem solid var(--bim-attachment-item-border-bottom-color, #B8BBBF));line-height:2.5rem;display:flex;align-items:center;justify-content:space-between;color:#46494d;padding-left:var(--bim-attachment-item-padding-left, 2.6rem);background-image:var(--bim-attachment-item-background-image, url(data:image/png;base64,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));background-size:var(--bim-attachment-item-background-size, auto);background-repeat:no-repeat;background-position:var(--bim-attachment-item-background-position, .8rem center)}.bim-attachment-item .bim-attachment-name{padding-left:1rem;overflow:hidden;text-overflow:ellipsis;white-space:nowrap}.bim-attachment-item .bim-attachment-size{padding-left:.5rem;white-space:nowrap;margin-right:.4rem}.bim-attachment-item .bim-attachment-delete-button{width:30px;cursor:pointer;margin-left:auto}.bim-attachment-item .bim-attachment-delete-button .icon{font-weight:var(--bim-attachment-delete-button-icon-font-weight, normal);color:var(--bim-attachment-delete-button-icon-color, #B8BBBF)}.bim-attachment-item .bim-attachment-delete-button .icon:hover{color:#46494d}\n"] }]
74
74
  }], propDecorators: { closeIconTemplate: [{
75
75
  type: Input
76
76
  }], attachmentSizeRef: [{
@@ -89,4 +89,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImpo
89
89
  }], getAttachment: [{
90
90
  type: Output
91
91
  }] } });
92
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-attachment-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-attachments/components/bimplus-attachment-item/bimplus-attachment-item.component.ts","../../../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-attachments/components/bimplus-attachment-item/bimplus-attachment-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  computed,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  signal,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { BitConverterPipe } from '../../../../pipes/bit-converter.pipe';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport {\r\n  Attachment,\r\n  BIMPLUS_ATTACHMENTS_CONFIG,\r\n} from '../../bimplus-attachments.interface';\r\n\r\nconst BIM_ATTACHMENT_DELETE_BUTTON_WIDTH = 30;\r\nconst BIM_ATTACHMENT_ITEM_PADDING_LEFT = 28;\r\n\r\n@Component({\r\n  selector: 'lib-bimplus-attachment-item',\r\n  standalone: true,\r\n  imports: [BitConverterPipe, TranslateModule],\r\n  templateUrl: './bimplus-attachment-item.component.html',\r\n  styleUrl: './bimplus-attachment-item.component.less',\r\n})\r\nexport class BimplusAttachmentItemComponent\r\n  implements AfterViewInit, OnDestroy\r\n{\r\n  @Input() closeIconTemplate?: TemplateRef<unknown>;\r\n  @ViewChild('attachmentSizeRef') attachmentSizeRef?: ElementRef<HTMLElement>;\r\n  @ViewChild('attachmentNameRef') attachmentNameRef!: ElementRef<HTMLElement>;\r\n  @Input({ required: true }) attachment!: Attachment;\r\n  @Input() set parentWidth(value: number | undefined) {\r\n    if (!value) {\r\n      return;\r\n    }\r\n\r\n    this.parentWidthSignal.set(value);\r\n  }\r\n  @Output() deleteAttachment = new EventEmitter<Attachment>();\r\n  @Output() getAttachment = new EventEmitter<Attachment>();\r\n\r\n  get type(): string {\r\n    return `.${this.attachment.fileName.split('.').at(-1)}`;\r\n  }\r\n\r\n  private intersectionObserver?: IntersectionObserver;\r\n  /** Parent element width. */\r\n  private readonly parentWidthSignal = signal<number | undefined>(undefined);\r\n  /** Attachment size text width. */\r\n  private readonly attachmentSizeWidth = signal<number>(0);\r\n  /** Wheter name is fully visible or not based on parent width. */\r\n  protected readonly nameIsfullyVisible = signal<boolean>(false);\r\n\r\n  protected readonly config = inject(BIMPLUS_ATTACHMENTS_CONFIG, {\r\n    optional: true,\r\n  });\r\n\r\n  /** Attribute to indicate if show/hide size of File. */\r\n  protected readonly hideSize = !!this.config?.hideAttachmentSize;\r\n\r\n  /** Width size of file name line. */\r\n  protected readonly nameInfoLineWidth = computed<number>(() => {\r\n    const parentWidth = this.parentWidthSignal();\r\n    const attachmentSizeWidth = this.attachmentSizeWidth();\r\n    const nameIsfullyVisible = this.nameIsfullyVisible();\r\n\r\n    if (!parentWidth) {\r\n      return 0;\r\n    }\r\n\r\n    if (nameIsfullyVisible) {\r\n      return parentWidth - BIM_ATTACHMENT_DELETE_BUTTON_WIDTH;\r\n    }\r\n\r\n    return (\r\n      parentWidth -\r\n      attachmentSizeWidth -\r\n      (BIM_ATTACHMENT_DELETE_BUTTON_WIDTH + BIM_ATTACHMENT_ITEM_PADDING_LEFT)\r\n    );\r\n  });\r\n\r\n  public ngAfterViewInit(): void {\r\n    if (this.attachmentSizeRef) {\r\n      this.attachmentSizeWidth.set(\r\n        +this.attachmentSizeRef.nativeElement.clientWidth\r\n      );\r\n      this.createIntersectionObserver();\r\n      this.intersectionObserver!.observe(this.attachmentNameRef.nativeElement);\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.intersectionObserver?.unobserve(this.attachmentNameRef.nativeElement);\r\n  }\r\n\r\n  private createIntersectionObserver(): void {\r\n    const options: IntersectionObserverInit = {\r\n      root: null,\r\n      rootMargin: '0px',\r\n      threshold: 1.0,\r\n    };\r\n    const callback: IntersectionObserverCallback = (entries) =>\r\n      entries.forEach(({ intersectionRatio }) =>\r\n        this.nameIsfullyVisible.set(intersectionRatio === 1)\r\n      );\r\n\r\n    this.intersectionObserver = new IntersectionObserver(callback, options);\r\n  }\r\n}\r\n","<div class=\"bim-attachment-item\">\r\n  <div\r\n    data-test=\"bim-attachment\"\r\n    (click)=\"getAttachment.emit(attachment)\"\r\n    (keypress)=\"$event.preventDefault()\"\r\n    title=\"{{ attachment.fileName }}\"\r\n    class=\"bim-attachment-name\"\r\n    [style.width.px]=\"nameInfoLineWidth()\"\r\n  >\r\n    <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n    @if (nameIsfullyVisible() && !hideSize) {\r\n    <span class=\"bim-attachment-size\">{{\r\n      attachment.size | bitConverter\r\n    }}</span>\r\n    }\r\n  </div>\r\n  @if(!nameIsfullyVisible() && !hideSize) {\r\n    <span>{{ type }} </span>\r\n    <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n      {{ attachment.size | bitConverter }}\r\n    </div>\r\n  }\r\n  @if (!config?.hideDeleteAttachmentButton) {\r\n    <span\r\n      data-test=\"delete-attachment-btn\"\r\n      class=\"bim-attachment-delete-button\"\r\n      title=\"{{ '_Delete attachment' | translate }}\"\r\n      (click)=\"deleteAttachment.emit(attachment)\"\r\n      (keypress)=\"$event.preventDefault()\"\r\n    >\r\n      <span class=\"icon\">✕︎</span>\r\n    </span>\r\n  }\r\n</div>\r\n"]}
92
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-attachment-item.component.js","sourceRoot":"","sources":["../../../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-attachments/components/bimplus-attachment-item/bimplus-attachment-item.component.ts","../../../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-attachments/components/bimplus-attachment-item/bimplus-attachment-item.component.html"],"names":[],"mappings":"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","sourcesContent":["import {\r\n  AfterViewInit,\r\n  Component,\r\n  computed,\r\n  ElementRef,\r\n  EventEmitter,\r\n  inject,\r\n  Input,\r\n  OnDestroy,\r\n  Output,\r\n  signal,\r\n  TemplateRef,\r\n  ViewChild,\r\n} from '@angular/core';\r\nimport { BitConverterPipe } from '../../../../pipes/bit-converter.pipe';\r\nimport { TranslateModule } from '@ngx-translate/core';\r\nimport {\r\n  Attachment,\r\n  BIMPLUS_ATTACHMENTS_CONFIG,\r\n} from '../../bimplus-attachments.interface';\r\n\r\nconst BIM_ATTACHMENT_DELETE_BUTTON_WIDTH = 30;\r\nconst BIM_ATTACHMENT_ITEM_PADDING_LEFT = 28;\r\n\r\n@Component({\r\n  selector: 'lib-bimplus-attachment-item',\r\n  standalone: true,\r\n  imports: [BitConverterPipe, TranslateModule],\r\n  templateUrl: './bimplus-attachment-item.component.html',\r\n  styleUrl: './bimplus-attachment-item.component.less',\r\n})\r\nexport class BimplusAttachmentItemComponent\r\n  implements AfterViewInit, OnDestroy\r\n{\r\n  @Input() closeIconTemplate?: TemplateRef<unknown>;\r\n  @ViewChild('attachmentSizeRef') attachmentSizeRef?: ElementRef<HTMLElement>;\r\n  @ViewChild('attachmentNameRef') attachmentNameRef!: ElementRef<HTMLElement>;\r\n  @Input({ required: true }) attachment!: Attachment;\r\n  @Input() set parentWidth(value: number | undefined) {\r\n    if (!value) {\r\n      return;\r\n    }\r\n\r\n    this.parentWidthSignal.set(value);\r\n  }\r\n  @Output() deleteAttachment = new EventEmitter<Attachment>();\r\n  @Output() getAttachment = new EventEmitter<Attachment>();\r\n\r\n  get type(): string {\r\n    return `.${this.attachment.fileName.split('.').at(-1)}`;\r\n  }\r\n\r\n  private intersectionObserver?: IntersectionObserver;\r\n  /** Parent element width. */\r\n  private readonly parentWidthSignal = signal<number | undefined>(undefined);\r\n  /** Attachment size text width. */\r\n  private readonly attachmentSizeWidth = signal<number>(0);\r\n  /** Wheter name is fully visible or not based on parent width. */\r\n  protected readonly nameIsfullyVisible = signal<boolean>(false);\r\n\r\n  protected readonly config = inject(BIMPLUS_ATTACHMENTS_CONFIG, {\r\n    optional: true,\r\n  });\r\n\r\n  /** Attribute to indicate if show/hide size of File. */\r\n  protected readonly hideSize = !!this.config?.hideAttachmentSize;\r\n\r\n  /** Width size of file name line. */\r\n  protected readonly nameInfoLineWidth = computed<number>(() => {\r\n    const parentWidth = this.parentWidthSignal();\r\n    const attachmentSizeWidth = this.attachmentSizeWidth();\r\n    const nameIsfullyVisible = this.nameIsfullyVisible();\r\n\r\n    if (!parentWidth) {\r\n      return 0;\r\n    }\r\n\r\n    if (nameIsfullyVisible) {\r\n      return parentWidth - BIM_ATTACHMENT_DELETE_BUTTON_WIDTH;\r\n    }\r\n\r\n    return (\r\n      parentWidth -\r\n      attachmentSizeWidth -\r\n      (BIM_ATTACHMENT_DELETE_BUTTON_WIDTH + BIM_ATTACHMENT_ITEM_PADDING_LEFT)\r\n    );\r\n  });\r\n\r\n  public ngAfterViewInit(): void {\r\n    if (this.attachmentSizeRef) {\r\n      this.attachmentSizeWidth.set(\r\n        +this.attachmentSizeRef.nativeElement.clientWidth\r\n      );\r\n      this.createIntersectionObserver();\r\n      this.intersectionObserver!.observe(this.attachmentNameRef.nativeElement);\r\n    }\r\n  }\r\n\r\n  public ngOnDestroy(): void {\r\n    this.intersectionObserver?.unobserve(this.attachmentNameRef.nativeElement);\r\n  }\r\n\r\n  private createIntersectionObserver(): void {\r\n    const options: IntersectionObserverInit = {\r\n      root: null,\r\n      rootMargin: '0px',\r\n      threshold: 1.0,\r\n    };\r\n    const callback: IntersectionObserverCallback = (entries) =>\r\n      entries.forEach(({ intersectionRatio }) =>\r\n        this.nameIsfullyVisible.set(intersectionRatio === 1)\r\n      );\r\n\r\n    this.intersectionObserver = new IntersectionObserver(callback, options);\r\n  }\r\n}\r\n","<div class=\"bim-attachment-item\">\r\n  <div\r\n    data-test=\"bim-attachment\"\r\n    (click)=\"getAttachment.emit(attachment)\"\r\n    (keypress)=\"$event.preventDefault()\"\r\n    title=\"{{ attachment.fileName }}\"\r\n    class=\"bim-attachment-name\"\r\n    [style.width.px]=\"nameInfoLineWidth()\"\r\n  >\r\n    <span #attachmentNameRef>{{ attachment.fileName }}</span>\r\n    @if (nameIsfullyVisible() && !hideSize) {\r\n    <span class=\"bim-attachment-size\">{{\r\n      attachment.size | bitConverter\r\n    }}</span>\r\n    }\r\n  </div>\r\n  @if(!nameIsfullyVisible() && !hideSize) {\r\n    <span>{{ type }} </span>\r\n    <div #attachmentSizeRef class=\"bim-attachment-size\">\r\n      {{ attachment.size | bitConverter }}\r\n    </div>\r\n  }\r\n  @if (!config?.hideDeleteAttachmentButton) {\r\n    <span\r\n      data-test=\"delete-attachment-btn\"\r\n      class=\"bim-attachment-delete-button\"\r\n      title=\"{{ '_Delete attachment' | translate }}\"\r\n      (click)=\"deleteAttachment.emit(attachment)\"\r\n      (keypress)=\"$event.preventDefault()\"\r\n    >\r\n      <span class=\"icon\">✕︎</span>\r\n    </span>\r\n  }\r\n</div>\r\n"]}
@@ -0,0 +1,105 @@
1
+ import { Component, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';
2
+ import * as i0 from "@angular/core";
3
+ export class BimplusLinkTooltipMessageComponent {
4
+ get link() {
5
+ return this._link;
6
+ }
7
+ set link(value) {
8
+ this._link = value;
9
+ }
10
+ get titleHeader() {
11
+ return this._titleHeader;
12
+ }
13
+ set titleHeader(value) {
14
+ this._titleHeader = value;
15
+ }
16
+ get enableCopyPressKeys() {
17
+ return this._enableCopyPressKeys;
18
+ }
19
+ set enableCopyPressKeys(value) {
20
+ this._enableCopyPressKeys = value;
21
+ }
22
+ get options() {
23
+ return this._options;
24
+ }
25
+ set options(value) {
26
+ this._options = value;
27
+ }
28
+ constructor() {
29
+ this.iconCode = '&#10005;&#xFE0E;';
30
+ this._enableCopyPressKeys = true;
31
+ this._titleHeader = '';
32
+ this._link = '';
33
+ }
34
+ ngAfterViewInit() {
35
+ this.selectText(this.messageLink.nativeElement);
36
+ this.setStyleSettingsVariables();
37
+ }
38
+ selectText(node) {
39
+ if (window.getSelection) {
40
+ const selection = window.getSelection();
41
+ const range = document.createRange();
42
+ range.selectNodeContents(node);
43
+ selection?.removeAllRanges();
44
+ selection?.addRange(range);
45
+ }
46
+ else {
47
+ console.log("Could not select text in node: Unsupported browser.");
48
+ }
49
+ }
50
+ setStyleSettingsVariables() {
51
+ const linkTooltipMessage = this.linkTooltipMessage.nativeElement;
52
+ const linkContent = this.linkContent.nativeElement;
53
+ linkTooltipMessage.className += ' ' + this.options.triangleArrowPositionClass;
54
+ linkContent.style.setProperty('--bc', this.options.backgroundColor);
55
+ linkContent.style.position = this.options.position.position;
56
+ linkContent.style.top = this.options.position.top;
57
+ linkContent.style.right = this.options.position.right;
58
+ linkContent.style.maxWidth = this.options.maxWidth;
59
+ linkContent.style.minWidth = this.options.minWidth;
60
+ linkContent.style.borderRadius = this.options.borderRadius;
61
+ linkContent.style.filter = this.options.filter || 'none';
62
+ linkTooltipMessage.style.setProperty('--triangle-position', this.options.triangleData.position);
63
+ linkTooltipMessage.style.setProperty('--triangle-height', this.options.triangleData.height);
64
+ linkTooltipMessage.style.setProperty('--triangle-side', this.options.triangleData.side);
65
+ linkTooltipMessage.style.setProperty('--bc', this.options.backgroundColor);
66
+ linkTooltipMessage.style.setProperty('--c', this.options.color);
67
+ }
68
+ close() {
69
+ this.options.actionClose();
70
+ }
71
+ onKeyPress() {
72
+ if (this.messageLink && this.enableCopyPressKeys) {
73
+ navigator.clipboard.writeText(this.messageLink.nativeElement.innerText).catch((err) => {
74
+ console.error("Could not copy text in node.", err);
75
+ });
76
+ }
77
+ }
78
+ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusLinkTooltipMessageComponent, deps: [], target: i0.ɵɵFactoryTarget.Component }); }
79
+ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.12", type: BimplusLinkTooltipMessageComponent, isStandalone: true, selector: "lib-bimplus-link-tooltip-message", inputs: { link: "link", titleHeader: "titleHeader", enableCopyPressKeys: "enableCopyPressKeys", options: "options" }, host: { listeners: { "window:keydown.control.c": "onKeyPress($event)" } }, viewQueries: [{ propertyName: "messageLink", first: true, predicate: ["messageLink"], descendants: true }, { propertyName: "linkTooltipMessage", first: true, predicate: ["linkTooltipMessage"], descendants: true }, { propertyName: "linkContent", first: true, predicate: ["linkContent"], descendants: true }], ngImport: i0, template: "<div class=\"link-content\" #linkContent>\r\n <div\r\n class=\"link-tooltip-message\"\r\n #linkTooltipMessage\r\n (click)=\"close()\"\r\n (keydown)=\"close()\">\r\n <div class=\"header\">\r\n <span class=\"title\">{{titleHeader}}</span>\r\n <span\r\n class='tooltip-cross-icon close'\r\n [innerHTML]=\"iconCode\">\r\n </span>\r\n </div>\r\n <div class=\"content\">\r\n <div\r\n class=\"link\"\r\n #messageLink\r\n [innerHTML]=\"link\">\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<div\r\n class=\"link-tooltip-message-overlay\"\r\n (click)=\"close();\"\r\n (keydown)=\"close()\">\r\n</div>", styles: [".link-content{--bc: var(--popup-window-content-background-color);display:flex;max-width:40rem;min-width:5rem;top:8rem;right:9.4rem;position:absolute;z-index:3;background:var(--bc)}.link-content .link-tooltip-message{--x: 0%;--y: 0%;--xw: 100%;--yh: 100%;--triangle-position: 2.5rem;--triangle-height: 1.7rem;--triangle-side: 3.7rem;--p: var(--triangle-position);--th: var(--triangle-height);--ts: var(--triangle-side);--c: var(--ui-text-1-color);color:var(--c);font-size:18px;max-width:40rem;min-width:5rem;text-align:center;background:var(--bc);padding:0rem .5rem .5rem;cursor:default}.link-content .link-tooltip-message.right-arrow{clip-path:polygon(var(--xw) var(--yh),var(--x) var(--yh),var(--x) var(--y),var(--xw) var(--y),var(--xw) max(var(--y),var(--p) - var(--ts)/2),calc(var(--xw) + var(--th)) var(--p),var(--xw) min(var(--yh),var(--p) + var(--ts)/2));box-shadow:1px -1px 0 var(--ts) var(--bc);-moz-box-shadow:1px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:1px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.left-arrow{clip-path:polygon(var(--x) var(--yh),var(--xw) var(--yh),var(--xw) var(--y),var(--x) var(--y),var(--x) max(var(--y),var(--p) - var(--ts)/2),calc(-1*var(--th)) var(--p),var(--x) min(var(--yh),var(--p) + var(--ts)/2));box-shadow:-1px -1px 0 var(--ts) var(--bc);-moz-box-shadow:-1px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:-1px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.top-arrow{clip-path:polygon(var(--x) var(--y),var(--x) var(--yh),var(--xw) var(--yh),var(--xw) var(--y),min(var(--xw),var(--p) + var(--ts)/2) var(--y),var(--p) calc(-1*var(--th)),max(var(--x),var(--p) - var(--ts)/2) var(--y));box-shadow:0 -1px 0 var(--ts) var(--bc);-moz-box-shadow:0px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:0px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.bottom-arrow{clip-path:polygon(var(--x) var(--yh),var(--x) var(--y),var(--xw) var(--y),var(--xw) var(--yh),min(var(--xw),var(--p) + var(--ts)/2) var(--yh),var(--p) calc(var(--yh) + var(--th)),max(var(--x),var(--p) - var(--ts)/2) var(--yh));box-shadow:0 1px 0 var(--ts) var(--bc);-moz-box-shadow:0px 1px 0px var(--ts) var(--bc);-webkit-box-shadow:0px 1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message div,.link-content .link-tooltip-message span{-webkit-tap-highlight-color:transparent}.link-content .link-tooltip-message .header{display:inline-flex;justify-content:space-around;align-items:center;width:100%;font:400 1.28rem Source Sans Pro,Helvetica,Arial,tahoma,sans-serif!important;font-size:1.28rem!important;font-weight:700}.link-content .link-tooltip-message .header .title{margin-right:auto;font-weight:700}.link-content .link-tooltip-message .header .close{font-size:2.1rem;line-height:1;color:#000;text-shadow:0 1px 0 var(--popup-window-content-background-color);opacity:.2;float:right;padding-right:.3rem}.link-content .link-tooltip-message .header .close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.5}.link-content .link-tooltip-message .content{font:400 1.28rem Source Sans Pro,Helvetica,Arial,tahoma,sans-serif!important;font-size:1.28rem!important;color:var(--ui-text-1-color);-webkit-user-select:text;user-select:text}.link-content .link-tooltip-message .content .link{text-align:left}.link-tooltip-message-overlay{height:100%;width:100%;position:fixed;z-index:2;left:0;top:0;overflow-x:hidden;background-color:transparent}\n"], encapsulation: i0.ViewEncapsulation.ShadowDom }); }
80
+ }
81
+ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.12", ngImport: i0, type: BimplusLinkTooltipMessageComponent, decorators: [{
82
+ type: Component,
83
+ args: [{ selector: 'lib-bimplus-link-tooltip-message', standalone: true, encapsulation: ViewEncapsulation.ShadowDom, template: "<div class=\"link-content\" #linkContent>\r\n <div\r\n class=\"link-tooltip-message\"\r\n #linkTooltipMessage\r\n (click)=\"close()\"\r\n (keydown)=\"close()\">\r\n <div class=\"header\">\r\n <span class=\"title\">{{titleHeader}}</span>\r\n <span\r\n class='tooltip-cross-icon close'\r\n [innerHTML]=\"iconCode\">\r\n </span>\r\n </div>\r\n <div class=\"content\">\r\n <div\r\n class=\"link\"\r\n #messageLink\r\n [innerHTML]=\"link\">\r\n </div>\r\n </div>\r\n </div>\r\n</div>\r\n<div\r\n class=\"link-tooltip-message-overlay\"\r\n (click)=\"close();\"\r\n (keydown)=\"close()\">\r\n</div>", styles: [".link-content{--bc: var(--popup-window-content-background-color);display:flex;max-width:40rem;min-width:5rem;top:8rem;right:9.4rem;position:absolute;z-index:3;background:var(--bc)}.link-content .link-tooltip-message{--x: 0%;--y: 0%;--xw: 100%;--yh: 100%;--triangle-position: 2.5rem;--triangle-height: 1.7rem;--triangle-side: 3.7rem;--p: var(--triangle-position);--th: var(--triangle-height);--ts: var(--triangle-side);--c: var(--ui-text-1-color);color:var(--c);font-size:18px;max-width:40rem;min-width:5rem;text-align:center;background:var(--bc);padding:0rem .5rem .5rem;cursor:default}.link-content .link-tooltip-message.right-arrow{clip-path:polygon(var(--xw) var(--yh),var(--x) var(--yh),var(--x) var(--y),var(--xw) var(--y),var(--xw) max(var(--y),var(--p) - var(--ts)/2),calc(var(--xw) + var(--th)) var(--p),var(--xw) min(var(--yh),var(--p) + var(--ts)/2));box-shadow:1px -1px 0 var(--ts) var(--bc);-moz-box-shadow:1px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:1px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.left-arrow{clip-path:polygon(var(--x) var(--yh),var(--xw) var(--yh),var(--xw) var(--y),var(--x) var(--y),var(--x) max(var(--y),var(--p) - var(--ts)/2),calc(-1*var(--th)) var(--p),var(--x) min(var(--yh),var(--p) + var(--ts)/2));box-shadow:-1px -1px 0 var(--ts) var(--bc);-moz-box-shadow:-1px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:-1px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.top-arrow{clip-path:polygon(var(--x) var(--y),var(--x) var(--yh),var(--xw) var(--yh),var(--xw) var(--y),min(var(--xw),var(--p) + var(--ts)/2) var(--y),var(--p) calc(-1*var(--th)),max(var(--x),var(--p) - var(--ts)/2) var(--y));box-shadow:0 -1px 0 var(--ts) var(--bc);-moz-box-shadow:0px -1px 0px var(--ts) var(--bc);-webkit-box-shadow:0px -1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message.bottom-arrow{clip-path:polygon(var(--x) var(--yh),var(--x) var(--y),var(--xw) var(--y),var(--xw) var(--yh),min(var(--xw),var(--p) + var(--ts)/2) var(--yh),var(--p) calc(var(--yh) + var(--th)),max(var(--x),var(--p) - var(--ts)/2) var(--yh));box-shadow:0 1px 0 var(--ts) var(--bc);-moz-box-shadow:0px 1px 0px var(--ts) var(--bc);-webkit-box-shadow:0px 1px 0px var(--ts) var(--bc)}.link-content .link-tooltip-message div,.link-content .link-tooltip-message span{-webkit-tap-highlight-color:transparent}.link-content .link-tooltip-message .header{display:inline-flex;justify-content:space-around;align-items:center;width:100%;font:400 1.28rem Source Sans Pro,Helvetica,Arial,tahoma,sans-serif!important;font-size:1.28rem!important;font-weight:700}.link-content .link-tooltip-message .header .title{margin-right:auto;font-weight:700}.link-content .link-tooltip-message .header .close{font-size:2.1rem;line-height:1;color:#000;text-shadow:0 1px 0 var(--popup-window-content-background-color);opacity:.2;float:right;padding-right:.3rem}.link-content .link-tooltip-message .header .close:hover{color:#000;text-decoration:none;cursor:pointer;opacity:.5}.link-content .link-tooltip-message .content{font:400 1.28rem Source Sans Pro,Helvetica,Arial,tahoma,sans-serif!important;font-size:1.28rem!important;color:var(--ui-text-1-color);-webkit-user-select:text;user-select:text}.link-content .link-tooltip-message .content .link{text-align:left}.link-tooltip-message-overlay{height:100%;width:100%;position:fixed;z-index:2;left:0;top:0;overflow-x:hidden;background-color:transparent}\n"] }]
84
+ }], ctorParameters: () => [], propDecorators: { messageLink: [{
85
+ type: ViewChild,
86
+ args: ['messageLink']
87
+ }], linkTooltipMessage: [{
88
+ type: ViewChild,
89
+ args: ['linkTooltipMessage']
90
+ }], linkContent: [{
91
+ type: ViewChild,
92
+ args: ['linkContent']
93
+ }], link: [{
94
+ type: Input
95
+ }], titleHeader: [{
96
+ type: Input
97
+ }], enableCopyPressKeys: [{
98
+ type: Input
99
+ }], options: [{
100
+ type: Input
101
+ }], onKeyPress: [{
102
+ type: HostListener,
103
+ args: ['window:keydown.control.c', ['$event']]
104
+ }] } });
105
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"bimplus-link-tooltip-message.component.js","sourceRoot":"","sources":["../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-link-tooltip-message/bimplus-link-tooltip-message.component.ts","../../../../../../projects/ngx-bimplus-components/src/lib/components/bimplus-link-tooltip-message/bimplus-link-tooltip-message.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, HostListener, Input, ViewChild, ViewEncapsulation } from '@angular/core';\r\nimport { LinkTooltipMessageOptions } from './tooltipMessageSettings';\r\n\r\n@Component({\r\n  selector: 'lib-bimplus-link-tooltip-message',\r\n  templateUrl: './bimplus-link-tooltip-message.component.html',\r\n  styleUrls: ['./bimplus-link-tooltip-message.component.less'],\r\n  standalone: true,\r\n  encapsulation: ViewEncapsulation.ShadowDom\r\n})\r\nexport class BimplusLinkTooltipMessageComponent implements AfterViewInit {\r\n\r\n  @ViewChild('messageLink') messageLink!: ElementRef<HTMLElement>;\r\n  @ViewChild('linkTooltipMessage') linkTooltipMessage!: ElementRef<HTMLElement>;\r\n  @ViewChild('linkContent') linkContent!: ElementRef<HTMLElement>;\r\n\r\n  iconCode = '&#10005;&#xFE0E;';\r\n\r\n  private _options!: LinkTooltipMessageOptions;\r\n  private _enableCopyPressKeys = true;\r\n  private _titleHeader = '';\r\n  private _link = '';\r\n\r\n  @Input()\r\n  get link(): string {\r\n    return this._link;\r\n  }\r\n  set link(value: string) {\r\n    this._link = value;\r\n  }\r\n\r\n  @Input()\r\n  get titleHeader(): string {\r\n    return this._titleHeader;\r\n  }\r\n  set titleHeader(value: string) {\r\n    this._titleHeader = value;\r\n  }\r\n\r\n  @Input()\r\n  get enableCopyPressKeys(): boolean {\r\n    return this._enableCopyPressKeys;\r\n  }\r\n  set enableCopyPressKeys(value: boolean) {\r\n    this._enableCopyPressKeys = value;\r\n  }\r\n\r\n  @Input()\r\n  get options(): LinkTooltipMessageOptions {\r\n    return this._options;\r\n  }\r\n  set options(value: LinkTooltipMessageOptions) {\r\n    this._options = value;\r\n  }\r\n\r\n  constructor() { }\r\n\r\n  ngAfterViewInit(): void {\r\n    this.selectText(this.messageLink.nativeElement);\r\n    this.setStyleSettingsVariables();\r\n  }\r\n\r\n  selectText(node: HTMLElement) {\r\n    if (window.getSelection) {\r\n      const selection = window.getSelection();\r\n      const range = document.createRange();\r\n      range.selectNodeContents(node);\r\n      selection?.removeAllRanges();\r\n      selection?.addRange(range);\r\n    } else {\r\n      console.log(\"Could not select text in node: Unsupported browser.\");\r\n    }\r\n  }\r\n\r\n  setStyleSettingsVariables() {\r\n    const linkTooltipMessage = this.linkTooltipMessage.nativeElement;\r\n    const linkContent = this.linkContent.nativeElement;\r\n\r\n    linkTooltipMessage.className += ' ' + this.options.triangleArrowPositionClass;\r\n    linkContent.style.setProperty('--bc', this.options.backgroundColor);\r\n\r\n    linkContent.style.position = this.options.position.position;\r\n    linkContent.style.top = this.options.position.top;\r\n    linkContent.style.right = this.options.position.right;\r\n    linkContent.style.maxWidth = this.options.maxWidth;\r\n    linkContent.style.minWidth = this.options.minWidth;\r\n    linkContent.style.borderRadius = this.options.borderRadius;\r\n    linkContent.style.filter = this.options.filter || 'none';\r\n\r\n    linkTooltipMessage.style.setProperty('--triangle-position', this.options.triangleData.position);\r\n    linkTooltipMessage.style.setProperty('--triangle-height', this.options.triangleData.height);\r\n    linkTooltipMessage.style.setProperty('--triangle-side', this.options.triangleData.side);\r\n    linkTooltipMessage.style.setProperty('--bc', this.options.backgroundColor);\r\n    linkTooltipMessage.style.setProperty('--c', this.options.color);\r\n  }\r\n\r\n  close() {\r\n    this.options.actionClose();\r\n  }\r\n\r\n  @HostListener('window:keydown.control.c', ['$event'])\r\n  onKeyPress() {\r\n    if (this.messageLink && this.enableCopyPressKeys) {\r\n      navigator.clipboard.writeText(this.messageLink.nativeElement.innerText).catch((err) => {\r\n        console.error(\"Could not copy text in node.\", err);\r\n      });\r\n    }\r\n  }\r\n}","<div class=\"link-content\" #linkContent>\r\n  <div\r\n    class=\"link-tooltip-message\"\r\n    #linkTooltipMessage\r\n    (click)=\"close()\"\r\n    (keydown)=\"close()\">\r\n    <div class=\"header\">\r\n      <span class=\"title\">{{titleHeader}}</span>\r\n      <span\r\n        class='tooltip-cross-icon close'\r\n        [innerHTML]=\"iconCode\">\r\n      </span>\r\n    </div>\r\n    <div class=\"content\">\r\n      <div\r\n        class=\"link\"\r\n        #messageLink\r\n        [innerHTML]=\"link\">\r\n      </div>\r\n    </div>\r\n  </div>\r\n</div>\r\n<div\r\n  class=\"link-tooltip-message-overlay\"\r\n  (click)=\"close();\"\r\n  (keydown)=\"close()\">\r\n</div>"]}
@@ -0,0 +1,2 @@
1
+ export {};
2
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidG9vbHRpcE1lc3NhZ2VTZXR0aW5ncy5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL25neC1iaW1wbHVzLWNvbXBvbmVudHMvc3JjL2xpYi9jb21wb25lbnRzL2JpbXBsdXMtbGluay10b29sdGlwLW1lc3NhZ2UvdG9vbHRpcE1lc3NhZ2VTZXR0aW5ncy50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiIiwic291cmNlc0NvbnRlbnQiOlsiZXhwb3J0IGludGVyZmFjZSBQb3NpdGlvbk9mTWVzc2FnZSB7XHJcbiAgcG9zaXRpb246IHN0cmluZztcclxuICB0b3A6IHN0cmluZztcclxuICByaWdodDogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIFRyaWFuZ2xlU2V0dGluZ3Mge1xyXG4gIHBvc2l0aW9uOiBzdHJpbmc7XHJcbiAgaGVpZ2h0OiBzdHJpbmc7XHJcbiAgc2lkZTogc3RyaW5nO1xyXG59XHJcblxyXG5leHBvcnQgaW50ZXJmYWNlIExpbmtUb29sdGlwTWVzc2FnZU9wdGlvbnMge1xyXG4gIHBvc2l0aW9uOiBQb3NpdGlvbk9mTWVzc2FnZTtcclxuICB0cmlhbmdsZURhdGE6IFRyaWFuZ2xlU2V0dGluZ3M7XHJcbiAgdHJpYW5nbGVBcnJvd1Bvc2l0aW9uQ2xhc3M6IHN0cmluZztcclxuICBib3JkZXJSYWRpdXM6IHN0cmluZztcclxuICBiYWNrZ3JvdW5kQ29sb3I6IHN0cmluZztcclxuICBjb2xvcjogc3RyaW5nO1xyXG4gIG1heFdpZHRoOiBzdHJpbmc7XHJcbiAgbWluV2lkdGg6IHN0cmluZztcclxuICBhY3Rpb25DbG9zZTogKCkgPT4gdm9pZDtcclxuICBmaWx0ZXI6IHN0cmluZztcclxufVxyXG4iXX0=