@hmcts/media-viewer 4.1.2 → 4.1.3-redactions-rc1

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 (26) hide show
  1. package/esm2022/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.mjs +5 -4
  2. package/esm2022/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.mjs +4 -2
  3. package/esm2022/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.mjs +4 -3
  4. package/esm2022/lib/annotations/comment-set/comment/comment.component.mjs +3 -2
  5. package/esm2022/lib/annotations/comment-set/comment-set-render.service.mjs +3 -2
  6. package/esm2022/lib/media-viewer.component.mjs +3 -2
  7. package/esm2022/lib/shared/util/helpers/html-templates.helper.mjs +12 -1
  8. package/esm2022/lib/store/reducers/document.reducer.mjs +35 -6
  9. package/esm2022/lib/toolbar/main-toolbar/main-toolbar.component.mjs +4 -3
  10. package/esm2022/lib/toolbar/redaction-search-bar/redaction-search-bar.component.mjs +3 -2
  11. package/esm2022/lib/viewers/pdf-viewer/side-bar/side-bar.component.mjs +4 -2
  12. package/fesm2022/hmcts-media-viewer.mjs +80 -36
  13. package/fesm2022/hmcts-media-viewer.mjs.map +1 -1
  14. package/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.d.ts.map +1 -1
  15. package/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.d.ts.map +1 -1
  16. package/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.d.ts.map +1 -1
  17. package/lib/annotations/comment-set/comment/comment.component.d.ts.map +1 -1
  18. package/lib/annotations/comment-set/comment-set-render.service.d.ts.map +1 -1
  19. package/lib/media-viewer.component.d.ts.map +1 -1
  20. package/lib/shared/util/helpers/html-templates.helper.d.ts +1 -0
  21. package/lib/shared/util/helpers/html-templates.helper.d.ts.map +1 -1
  22. package/lib/store/reducers/document.reducer.d.ts.map +1 -1
  23. package/lib/toolbar/main-toolbar/main-toolbar.component.d.ts.map +1 -1
  24. package/lib/toolbar/redaction-search-bar/redaction-search-bar.component.d.ts.map +1 -1
  25. package/lib/viewers/pdf-viewer/side-bar/side-bar.component.d.ts.map +1 -1
  26. package/package.json +1 -1
@@ -31,7 +31,9 @@ export class SideBarComponent {
31
31
  this.sidebarOpen = toggle;
32
32
  }));
33
33
  this.subscriptions.push(this.store.pipe(select(bookmarksSelectors.getScrollTop)).subscribe(scrollTopValue => {
34
- this.sidebarDiv.nativeElement.scrollTop = scrollTopValue;
34
+ if (this.sidebarDiv?.nativeElement) {
35
+ this.sidebarDiv.nativeElement.scrollTop = scrollTopValue;
36
+ }
35
37
  }));
36
38
  }
37
39
  ngOnChanges(changes) {
@@ -94,4 +96,4 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
94
96
  type: ViewChild,
95
97
  args: ['sidebar']
96
98
  }] } });
97
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.ts","../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, HostListener, Input, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewChild } from '@angular/core';\nimport { Outline } from './outline-item/outline.model';\nimport { Observable, Subscription } from 'rxjs';\nimport { select, Store } from '@ngrx/store';\nimport * as bookmarksSelectors from '../../../store/selectors/bookmark.selectors';\nimport { BookmarkNode } from '../../../store/models/bookmarks.interface';\nimport { CreateBookmark, LoadBookmarks } from '../../../store/actions/bookmark.actions';\nimport { take } from 'rxjs/operators';\nimport { v4 as uuid } from 'uuid';\nimport { ViewerEventService } from '../../viewer-event.service';\nimport { BookmarksState } from '../../../store/reducers/bookmarks.reducer';\nimport { ToolbarEventService } from '../../../toolbar/toolbar-event.service';\nimport { BookmarksComponent } from './bookmarks/bookmarks.component';\n\n@Component({\n  selector: 'mv-side-bar',\n  templateUrl: './side-bar.component.html'\n})\nexport class SideBarComponent implements OnInit, OnChanges, OnDestroy {\n\n  @Input() annotationsEnabled: boolean;\n  @Input() outline: Outline;\n  @Input() url: string;\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Input() currentPageNumber: number;\n\n  @ViewChild(BookmarksComponent)\n  bookmarks: BookmarksComponent;\n  treeChanged: boolean = false;\n  selectedView = 'outline';\n  bookmarkNodes$: Observable<BookmarkNode[]>;\n  scrollTop: any;\n  sidebarOpen: any;\n\n  private subscriptions: Subscription[] = [];\n  @ViewChild('sidebar') sidebarDiv;\n\n  constructor(private viewerEvents: ViewerEventService,\n    private store: Store<BookmarksState>,\n    private readonly toolbarEvents: ToolbarEventService,\n  ) { }\n\n  ngOnInit(): void {\n    this.bookmarkNodes$ = this.store.pipe(select(bookmarksSelectors.getBookmarkNodes));\n    this.subscriptions.push(this.store.pipe(select(bookmarksSelectors.getEditableBookmark))\n      .subscribe(editable => this.selectedView = editable ? 'bookmarks' : this.selectedView));\n    this.subscriptions.push(\n      this.toolbarEvents.sidebarOutlineView.subscribe(toggle => {\n        this.selectedView = toggle ? 'outline' : 'bookmarks';\n      }),\n      this.toolbarEvents.sidebarOpen.subscribe(toggle => {\n        this.sidebarOpen = toggle;\n      })\n    );\n    this.subscriptions.push(this.store.pipe(select(bookmarksSelectors.getScrollTop)).subscribe(scrollTopValue => {\n      this.sidebarDiv.nativeElement.scrollTop = scrollTopValue;\n    }));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.url && this.url) {\n      this.store.dispatch(new LoadBookmarks());\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscriptions.length > 0) {\n      this.subscriptions.forEach(subscription => subscription.unsubscribe());\n    }\n  }\n\n  public onScroll(event: any): void {\n    if (!this.treeChanged) {\n      this.scrollTop = event.srcElement.scrollTop;\n    }\n    this.treeChanged = false;\n  }\n\n  goToDestination(destination: any[]) {\n    this.viewerEvents.goToDestination(destination);\n  }\n\n  hasTreeChanged(value: boolean) {\n    this.treeChanged = value;\n  }\n\n  toggleSidebarView(sidebarView: string) {\n    this.selectedView = sidebarView;\n  }\n\n  isViewedItem(current: Outline, next: Outline): boolean {\n    if (current.pageNumber === this.currentPageNumber) {\n      return true;\n    }\n    return next === undefined ? current.pageNumber <= this.currentPageNumber :\n      current.pageNumber <= this.currentPageNumber && (next.pageNumber > this.currentPageNumber);\n  }\n\n  findEndPage(next: Outline): number {\n    return next === undefined ? Number.MAX_SAFE_INTEGER : next.pageNumber;\n  }\n}\n","<div id=\"toolbarSidebar\">\n  <div\n    *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n    class=\"splitToolbarButton toggled\"\n  >\n    <button\n      id=\"sortBookmarkPosition\"\n      class=\"splitToolbarButton left bookmark__sort__position\"\n      (click)=\"bookmarks.sort(bookmarks.positionSort)\"\n      title=\"Order by place in document\"\n      aria-pressed=\"true\"\n    ></button>\n    <button\n      id=\"sortBookmarkCustom\"\n      class=\"splitToolbarButton left bookmark__sort__custom\"\n      (click)=\"bookmarks.sort(bookmarks.customSort)\"\n      title=\"Order manually\"\n      aria-pressed=\"true\"\n    ></button>\n  </div>\n  <div class=\"splitToolbarButtonSeparator\"></div>\n  <div\n    *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n    class=\"splitToolbarButton right\"\n  >\n    <button\n      id=\"addBookmark\"\n      class=\"toolbarButton addBookmark\"\n      (click)=\"bookmarks.onAddBookmarkClick()\"\n      title=\"Add bookmark\"\n      tabindex=\"3\"\n      data-l10n-id=\"addBookmark\"\n    >\n      <span data-l10n-id=\"addBookmark_label\">{{\n        \"Add bookmark\" | rpxTranslate\n      }}</span>\n    </button>\n  </div>\n</div>\n<div #sidebar id=\"sidebarContent\" cdkScrollable (scroll)=\"onScroll($event)\" [hidden]=\"!sidebarOpen\">\n  <div id=\"outlineView\" class=\"outlineWithDeepNesting\">\n    <div class=\"outlineItem\" *ngIf=\"selectedView === 'outline'\">\n      <mv-outline-item\n        *ngFor=\"let outlineItem of outline; index as i\"\n        [outline]=\"outlineItem\"\n        [currentPageNumber]=\"currentPageNumber\"\n        [isCurrentSection]=\"isViewedItem(outlineItem, outline[i + 1])\"\n        [endPage]=\"findEndPage(outline[i + 1])\"\n        (navigationEvent)=\"goToDestination($event)\"\n      ></mv-outline-item>\n    </div>\n    <div\n      *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n      id=\"bookmarkContainer\"\n    >\n      <mv-bookmarks\n        [bookmarkNodes]=\"bookmarkNodes$ | async\"\n        [zoom]=\"zoom\"\n        [rotate]=\"rotate\"\n        [parentScrollTop]=\"scrollTop\"\n        (goToDestination)=\"goToDestination($event)\"\n        (treeHasChanged)=\"hasTreeChanged($event)\"\n      ></mv-bookmarks>\n    </div>\n  </div>\n</div>\n"]}
99
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"side-bar.component.js","sourceRoot":"","sources":["../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.ts","../../../../../../../projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.html"],"names":[],"mappings":"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","sourcesContent":["import { AfterViewInit, Component, ElementRef, HostListener, Input, OnChanges, OnDestroy, OnInit, SimpleChanges, ViewChild } from '@angular/core';\nimport { Outline } from './outline-item/outline.model';\nimport { Observable, Subscription } from 'rxjs';\nimport { select, Store } from '@ngrx/store';\nimport * as bookmarksSelectors from '../../../store/selectors/bookmark.selectors';\nimport { BookmarkNode } from '../../../store/models/bookmarks.interface';\nimport { CreateBookmark, LoadBookmarks } from '../../../store/actions/bookmark.actions';\nimport { take } from 'rxjs/operators';\nimport { v4 as uuid } from 'uuid';\nimport { ViewerEventService } from '../../viewer-event.service';\nimport { BookmarksState } from '../../../store/reducers/bookmarks.reducer';\nimport { ToolbarEventService } from '../../../toolbar/toolbar-event.service';\nimport { BookmarksComponent } from './bookmarks/bookmarks.component';\n\n@Component({\n  selector: 'mv-side-bar',\n  templateUrl: './side-bar.component.html'\n})\nexport class SideBarComponent implements OnInit, OnChanges, OnDestroy {\n\n  @Input() annotationsEnabled: boolean;\n  @Input() outline: Outline;\n  @Input() url: string;\n  @Input() zoom: number;\n  @Input() rotate: number;\n  @Input() currentPageNumber: number;\n\n  @ViewChild(BookmarksComponent)\n  bookmarks: BookmarksComponent;\n  treeChanged: boolean = false;\n  selectedView = 'outline';\n  bookmarkNodes$: Observable<BookmarkNode[]>;\n  scrollTop: any;\n  sidebarOpen: any;\n\n  private subscriptions: Subscription[] = [];\n  @ViewChild('sidebar') sidebarDiv;\n\n  constructor(private viewerEvents: ViewerEventService,\n    private store: Store<BookmarksState>,\n    private readonly toolbarEvents: ToolbarEventService,\n  ) { }\n\n  ngOnInit(): void {\n    this.bookmarkNodes$ = this.store.pipe(select(bookmarksSelectors.getBookmarkNodes));\n    this.subscriptions.push(this.store.pipe(select(bookmarksSelectors.getEditableBookmark))\n      .subscribe(editable => this.selectedView = editable ? 'bookmarks' : this.selectedView));\n    this.subscriptions.push(\n      this.toolbarEvents.sidebarOutlineView.subscribe(toggle => {\n        this.selectedView = toggle ? 'outline' : 'bookmarks';\n      }),\n      this.toolbarEvents.sidebarOpen.subscribe(toggle => {\n        this.sidebarOpen = toggle;\n      })\n    );\n    this.subscriptions.push(this.store.pipe(select(bookmarksSelectors.getScrollTop)).subscribe(scrollTopValue => {\n      if (this.sidebarDiv?.nativeElement) {\n        this.sidebarDiv.nativeElement.scrollTop = scrollTopValue\n      }\n    }));\n  }\n\n  ngOnChanges(changes: SimpleChanges): void {\n    if (changes.url && this.url) {\n      this.store.dispatch(new LoadBookmarks());\n    }\n  }\n\n  ngOnDestroy(): void {\n    if (this.subscriptions.length > 0) {\n      this.subscriptions.forEach(subscription => subscription.unsubscribe());\n    }\n  }\n\n  public onScroll(event: any): void {\n    if (!this.treeChanged) {\n      this.scrollTop = event.srcElement.scrollTop;\n    }\n    this.treeChanged = false;\n  }\n\n  goToDestination(destination: any[]) {\n    this.viewerEvents.goToDestination(destination);\n  }\n\n  hasTreeChanged(value: boolean) {\n    this.treeChanged = value;\n  }\n\n  toggleSidebarView(sidebarView: string) {\n    this.selectedView = sidebarView;\n  }\n\n  isViewedItem(current: Outline, next: Outline): boolean {\n    if (current.pageNumber === this.currentPageNumber) {\n      return true;\n    }\n    return next === undefined ? current.pageNumber <= this.currentPageNumber :\n      current.pageNumber <= this.currentPageNumber && (next.pageNumber > this.currentPageNumber);\n  }\n\n  findEndPage(next: Outline): number {\n    return next === undefined ? Number.MAX_SAFE_INTEGER : next.pageNumber;\n  }\n}\n","<div id=\"toolbarSidebar\">\n  <div\n    *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n    class=\"splitToolbarButton toggled\"\n  >\n    <button\n      id=\"sortBookmarkPosition\"\n      class=\"splitToolbarButton left bookmark__sort__position\"\n      (click)=\"bookmarks.sort(bookmarks.positionSort)\"\n      title=\"Order by place in document\"\n      aria-pressed=\"true\"\n    ></button>\n    <button\n      id=\"sortBookmarkCustom\"\n      class=\"splitToolbarButton left bookmark__sort__custom\"\n      (click)=\"bookmarks.sort(bookmarks.customSort)\"\n      title=\"Order manually\"\n      aria-pressed=\"true\"\n    ></button>\n  </div>\n  <div class=\"splitToolbarButtonSeparator\"></div>\n  <div\n    *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n    class=\"splitToolbarButton right\"\n  >\n    <button\n      id=\"addBookmark\"\n      class=\"toolbarButton addBookmark\"\n      (click)=\"bookmarks.onAddBookmarkClick()\"\n      title=\"Add bookmark\"\n      tabindex=\"3\"\n      data-l10n-id=\"addBookmark\"\n    >\n      <span data-l10n-id=\"addBookmark_label\">{{\n        \"Add bookmark\" | rpxTranslate\n      }}</span>\n    </button>\n  </div>\n</div>\n<div #sidebar id=\"sidebarContent\" cdkScrollable (scroll)=\"onScroll($event)\" [hidden]=\"!sidebarOpen\">\n  <div id=\"outlineView\" class=\"outlineWithDeepNesting\">\n    <div class=\"outlineItem\" *ngIf=\"selectedView === 'outline'\">\n      <mv-outline-item\n        *ngFor=\"let outlineItem of outline; index as i\"\n        [outline]=\"outlineItem\"\n        [currentPageNumber]=\"currentPageNumber\"\n        [isCurrentSection]=\"isViewedItem(outlineItem, outline[i + 1])\"\n        [endPage]=\"findEndPage(outline[i + 1])\"\n        (navigationEvent)=\"goToDestination($event)\"\n      ></mv-outline-item>\n    </div>\n    <div\n      *ngIf=\"annotationsEnabled && selectedView === 'bookmarks'\"\n      id=\"bookmarkContainer\"\n    >\n      <mv-bookmarks\n        [bookmarkNodes]=\"bookmarkNodes$ | async\"\n        [zoom]=\"zoom\"\n        [rotate]=\"rotate\"\n        [parentScrollTop]=\"scrollTop\"\n        (goToDestination)=\"goToDestination($event)\"\n        (treeHasChanged)=\"hasTreeChanged($event)\"\n      ></mv-bookmarks>\n    </div>\n  </div>\n</div>\n"]}
@@ -304,19 +304,48 @@ function docReducer(state = initialDocumentState, action) {
304
304
  let pageHeight;
305
305
  let pageWidth;
306
306
  let hasDifferentPageSize = state.hasDifferentPageSize;
307
+ // we store the first page, as this has been rendered we can use this to get the rounding value
308
+ const pageNumberInput = document.getElementById('pageNumber');
309
+ const pageIndex = pageNumberInput ? parseInt(pageNumberInput.value, 10) : 0;
310
+ console.log('pageIndex', pageIndex);
311
+ const loadedPage = payload[pageIndex] && payload[pageIndex].div && payload[pageIndex].div['attributes'] && payload[pageIndex].div['attributes'].style
312
+ ? payload[pageIndex].div['attributes'].style.value
313
+ : '';
307
314
  payload.forEach(page => {
315
+ const sizingValue = page.div && page.div['attributes'] && page.div['attributes'].style
316
+ ? page.div['attributes'].style.value
317
+ : '';
318
+ const widthMatch = sizingValue.match(/width:\s*round\(down,\s*var\(--scale-factor\)\s*\*\s*([\d.]+)px,.*var\(--scale-round-x, ([\d.]+)px\)\)/);
319
+ const heightMatch = sizingValue.match(/height:\s*round\(down,\s*var\(--scale-factor\)\s*\*\s*([\d.]+)px,.*var\(--scale-round-y, ([\d.]+)px\)\)/);
320
+ const scaleRoundXMatch = loadedPage.match(/--scale-round-x:\s*([\d.]+)px/);
321
+ const scaleRoundYMatch = loadedPage.match(/--scale-round-y:\s*([\d.]+)px/);
322
+ const scaleFactor = page.viewportScale ?? 1;
323
+ const scaleRoundX = scaleRoundXMatch ? parseFloat(scaleRoundXMatch[1]) : 1;
324
+ const scaleRoundY = scaleRoundYMatch ? parseFloat(scaleRoundYMatch[1]) : 1;
325
+ const baseWidth = widthMatch ? parseFloat(widthMatch[1]) : undefined;
326
+ const baseHeight = heightMatch ? parseFloat(heightMatch[1]) : undefined;
327
+ function roundDown(value, step) {
328
+ return Math.floor(value / step) * step;
329
+ }
330
+ const computedWidth = baseWidth !== undefined
331
+ ? roundDown(scaleFactor * baseWidth, scaleRoundX)
332
+ : page.div['clientWidth'];
333
+ const computedHeight = baseHeight !== undefined
334
+ ? roundDown(scaleFactor * baseHeight, scaleRoundY)
335
+ : page.div['clientHeight'];
336
+ console.log(computedHeight, computedWidth);
308
337
  if (!hasDifferentPageSize && pageHeight && pageWidth &&
309
- (pageHeight !== page.div['clientHeight'] || pageWidth !== page.div['clientWidth'])) {
338
+ (pageHeight !== computedHeight || pageWidth !== computedWidth)) {
310
339
  hasDifferentPageSize = true;
311
340
  }
312
341
  else {
313
- pageHeight = page.div['clientHeight'];
314
- pageWidth = page.div['clientWidth'];
342
+ pageHeight = computedHeight;
343
+ pageWidth = computedWidth;
315
344
  }
316
345
  const styles = {
317
346
  left: page.div['offsetLeft'],
318
- height: page.div['clientHeight'],
319
- width: page.div['clientWidth']
347
+ height: computedHeight,
348
+ width: computedWidth
320
349
  };
321
350
  const scaleRotation = {
322
351
  scale: page.scale,
@@ -2511,6 +2540,35 @@ const defaultUnsupportedOptions = {
2511
2540
  showPrint: true
2512
2541
  };
2513
2542
 
2543
+ /**
2544
+ * Helper Class
2545
+ * Used for dynamic templates manipulation
2546
+ * */
2547
+ class HtmlTemplatesHelper {
2548
+ static setDescribedBy(errorMessage, config) {
2549
+ if (!errorMessage) {
2550
+ return config.hint ? `${config.id}-hint` : null;
2551
+ }
2552
+ else if (errorMessage && errorMessage.isInvalid) {
2553
+ return config.hint ? `${config.id}-hint ${config.id}-error` : `${config.id}-error`;
2554
+ }
2555
+ else {
2556
+ return config.hint ? `${config.id}-hint` : null;
2557
+ }
2558
+ }
2559
+ static getAdjustedBoundingRect(element, log = true) {
2560
+ const viewportX = window.visualViewport.offsetLeft;
2561
+ const viewportY = window.visualViewport.offsetTop;
2562
+ const viewportScale = window.visualViewport.scale;
2563
+ const viewportPageX = window.visualViewport.pageLeft;
2564
+ const viewportPageY = window.visualViewport.pageTop;
2565
+ if (log && viewportX || viewportY || (viewportScale != 1) || viewportPageX || viewportPageY) {
2566
+ console.log(`Element: ${element.id} Viewport X: ${viewportX}, Y: ${viewportY}, Scale: ${viewportScale}, PageX: ${viewportPageX}, PageY: ${viewportPageY}`);
2567
+ }
2568
+ return element.getBoundingClientRect();
2569
+ }
2570
+ }
2571
+
2514
2572
  const getTagsRootState = createSelector(getMVState, (state) => state.tags);
2515
2573
  const getTagEntities = createSelector(getTagsRootState, getTagNameEnt);
2516
2574
  const getTagFilters = createSelector(getTagsRootState, getFilters);
@@ -2872,7 +2930,7 @@ class RedactionSearchBarComponent {
2872
2930
  const range = selection.getRangeAt(0).cloneRange();
2873
2931
  const clientRects = range.getClientRects();
2874
2932
  if (clientRects) {
2875
- const parentRect = selectedHighLightedElements[0].parentElement.parentElement.getBoundingClientRect();
2933
+ const parentRect = HtmlTemplatesHelper.getAdjustedBoundingRect(selectedHighLightedElements[0]?.parentElement?.parentElement);
2876
2934
  const selectionRectangles = [];
2877
2935
  for (let i = 0; i < clientRects.length; i++) {
2878
2936
  const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);
@@ -2998,7 +3056,7 @@ class CommentSetRenderService {
2998
3056
  }
2999
3057
  }
3000
3058
  height(element) {
3001
- return element.form.nativeElement.getBoundingClientRect().height;
3059
+ return HtmlTemplatesHelper.getAdjustedBoundingRect(element.form.nativeElement)?.height | 0;
3002
3060
  }
3003
3061
  difference(a, b) { return Math.abs(a - b); }
3004
3062
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentSetRenderService, deps: [], target: i0.ɵɵFactoryTarget.Injectable }); }
@@ -3314,7 +3372,7 @@ class CommentComponent {
3314
3372
  return this.totalPrevPagesHeight + (this.rectTop * this.zoom);
3315
3373
  }
3316
3374
  get height() {
3317
- return this.form.nativeElement.getBoundingClientRect().height / this.zoom;
3375
+ return HtmlTemplatesHelper.getAdjustedBoundingRect(this.form.nativeElement).height / this.zoom;
3318
3376
  }
3319
3377
  /** @nocollapse */ static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.13", ngImport: i0, type: CommentComponent, deps: [{ token: i1.Store }, { token: CommentService }, { token: TagsServices }], target: i0.ɵɵFactoryTarget.Component }); }
3320
3378
  /** @nocollapse */ static { this.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.13", type: CommentComponent, selector: "mv-anno-comment", inputs: { rotate: "rotate", zoom: "zoom", index: "index", page: "page", comment: "comment", annotation: "annotation" }, outputs: { commentClick: "commentClick", renderComments: "renderComments", delete: "delete", updated: "updated", changes: "changes" }, viewQueries: [{ propertyName: "form", first: true, predicate: ["form"], descendants: true }, { propertyName: "editableComment", first: true, predicate: ["editableComment"], descendants: true }], ngImport: i0, template: "<div\n #form\n (click)=\"onCommentClick()\"\n class=\"aui-comment\"\n [ngClass]=\"{ stylestoggle: (marginToComment$ | async) }\"\n [style.top.px]=\"commentTop\"\n [style.zIndex]=\"selected ? 100 : 0\"\n>\n <div id=\"detailsWrapper {{ index }}\" class=\"aui-comment__header\">\n <span *ngIf=\"author && !editor\" class=\"aui-comment__author\">\n {{ author.forename }} {{ author.surname }}\n </span>\n <span *ngIf=\"editor\" class=\"aui-comment__author\">\n {{ editor.forename }} {{ editor.surname }}\n </span>\n <time [hidden]=\"!selected && !this.editable\" class=\"aui-comment__meta\">\n {{ lastUpdate | momentDate : \"d MMMM y h:mm a\" }}\n </time>\n </div>\n <mv-tags\n [tagItems]=\"tagItems\"\n [userId]=\"createdBy\"\n [editable]=\"editable\"\n [annoId]=\"_comment.annotationId\"\n >\n </mv-tags>\n <textarea\n *ngIf=\"selected && editable\"\n #editableComment\n mvTextAreaAutoExpand\n type=\"text\"\n required\n name=\"content\"\n [maxlength]=\"CHAR_LIMIT\"\n class=\"aui-comment__content form-control mimic-focus edit-mode expanded\"\n [ngModel]=\"fullComment\"\n (ngModelChange)=\"fullComment = $event; reRenderComments(); onCommentChange($event)\"\n aria-label=\"comment\"\n >\n </textarea>\n <p\n *ngIf=\"!editable\"\n mvTextHighlight\n class=\"commentText\"\n [textToHighlight]=\"searchString\"\n >\n {{ fullComment }}\n </p>\n <div\n *ngIf=\"\n selected ||\n this.editable ||\n (!fullComment.length && tagItems && !tagItems.length)\n \"\n class=\"aui-comment__footer commentBtns\"\n >\n <button\n class=\"govuk-button\"\n type=\"button\"\n role=\"button\"\n (click)=\"editOrSave()\"\n >\n {{ !editable ? (\"Edit\" | rpxTranslate) : (\"Save\" | rpxTranslate) }}\n </button>\n <button\n type=\"button\"\n role=\"button\"\n class=\"govuk-button govuk-button--secondary\"\n (click)=\"deleteOrCancel()\"\n >\n {{ !editable ? (\"Delete\" | rpxTranslate) : (\"Cancel\" | rpxTranslate) }}\n </button>\n </div>\n <span class=\"aui-comment__private\">{{ \"private\" | rpxTranslate }}</span>\n</div>\n", dependencies: [{ kind: "directive", type: i5.NgClass, selector: "[ngClass]", inputs: ["class", "ngClass"] }, { kind: "directive", type: i5.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i2.DefaultValueAccessor, selector: "input:not([type=checkbox])[formControlName],textarea[formControlName],input:not([type=checkbox])[formControl],textarea[formControl],input:not([type=checkbox])[ngModel],textarea[ngModel],[ngDefaultControl]" }, { kind: "directive", type: i2.NgControlStatus, selector: "[formControlName],[ngModel],[formControl]" }, { kind: "directive", type: i2.RequiredValidator, selector: ":not([type=checkbox])[required][formControlName],:not([type=checkbox])[required][formControl],:not([type=checkbox])[required][ngModel]", inputs: ["required"] }, { kind: "directive", type: i2.MaxLengthValidator, selector: "[maxlength][formControlName],[maxlength][formControl],[maxlength][ngModel]", inputs: ["maxlength"] }, { kind: "directive", type: i2.NgModel, selector: "[ngModel]:not([formControlName]):not([formControl])", inputs: ["name", "disabled", "ngModel", "ngModelOptions"], outputs: ["ngModelChange"], exportAs: ["ngModel"] }, { kind: "directive", type: TextHighlightDirective, selector: "[mvTextHighlight]", inputs: ["textToHighlight"] }, { kind: "directive", type: TextareaAutoExpandDirective, selector: "[mvTextAreaAutoExpand]" }, { kind: "component", type: TagsComponent, selector: "mv-tags", inputs: ["tagItems", "userId", "editable", "annoId"] }, { kind: "pipe", type: i5.AsyncPipe, name: "async" }, { kind: "pipe", type: i5$1.RpxTranslatePipe, name: "rpxTranslate" }, { kind: "pipe", type: MomentDatePipe, name: "momentDate" }] }); }
@@ -3807,7 +3865,7 @@ class BoxHighlightCreateComponent {
3807
3865
  this.highlightPage();
3808
3866
  return;
3809
3867
  }
3810
- const rect = event.target.getBoundingClientRect(), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
3868
+ const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
3811
3869
  console.log(`initHighlight: rect=${JSON.stringify(rect)}, clientX=${event.clientX}, clientY=${event.clientY}, offsetX=${offsetX}, offsetY=${offsetY}`);
3812
3870
  this.position = 'absolute';
3813
3871
  this.backgroundColor = 'yellow';
@@ -3832,8 +3890,7 @@ class BoxHighlightCreateComponent {
3832
3890
  }
3833
3891
  }
3834
3892
  updateHighlight(event) {
3835
- const rect = event.target.getBoundingClientRect(), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
3836
- console.log(`updateHighlight: rect=${JSON.stringify(rect)}, clientX=${event.clientX}, clientY=${event.clientY}, offsetX=${offsetX}, offsetY=${offsetY}`);
3893
+ const rect = HtmlTemplatesHelper.getAdjustedBoundingRect(event.target, false), offsetX = event.clientX - rect.left, offsetY = event.clientY - rect.top;
3837
3894
  if (this.drawStartX > 0 && this.drawStartY > 0) {
3838
3895
  this.height = Math.abs(offsetY - this.drawStartY);
3839
3896
  this.width = Math.abs(offsetX - this.drawStartX);
@@ -3846,6 +3903,7 @@ class BoxHighlightCreateComponent {
3846
3903
  let rectangle = this.highlightService
3847
3904
  .applyRotation(this.pageHeight, this.pageWidth, this.height, this.width, this.top, this.left, this.rotate, this.zoom);
3848
3905
  rectangle = { id: v4(), ...rectangle };
3906
+ console.log(`createHighlight: rectangle=${JSON.stringify(rectangle)}`);
3849
3907
  this.saveSelection.emit({ rectangles: [rectangle], page: this.page });
3850
3908
  this.resetHighlight();
3851
3909
  }
@@ -4035,10 +4093,11 @@ class CtxToolbarComponent {
4035
4093
  addOrEditComment() {
4036
4094
  this.addOrEditCommentEvent.emit();
4037
4095
  setTimeout(() => {
4096
+ // This hack to wait until the element is rendered seems to be unreliable,
4038
4097
  if (!location.hash) {
4039
- document.getElementById('viewerContainer').scrollBy(0, 1);
4098
+ document.getElementById('viewerContainer')?.scrollBy(0, 1);
4040
4099
  }
4041
- }, 10);
4100
+ }, 20);
4042
4101
  }
4043
4102
  createBookmark() {
4044
4103
  this.createBookmarkEvent.emit(this.rectangle);
@@ -4740,7 +4799,9 @@ class SideBarComponent {
4740
4799
  this.sidebarOpen = toggle;
4741
4800
  }));
4742
4801
  this.subscriptions.push(this.store.pipe(select(getScrollTop)).subscribe(scrollTopValue => {
4743
- this.sidebarDiv.nativeElement.scrollTop = scrollTopValue;
4802
+ if (this.sidebarDiv?.nativeElement) {
4803
+ this.sidebarDiv.nativeElement.scrollTop = scrollTopValue;
4804
+ }
4744
4805
  }));
4745
4806
  }
4746
4807
  ngOnChanges(changes) {
@@ -4917,7 +4978,8 @@ class HighlightCreateDirective {
4917
4978
  const range = selection.getRangeAt(0).cloneRange();
4918
4979
  const clientRects = range.getClientRects();
4919
4980
  if (clientRects) {
4920
- const parentRect = localElement.closest(".textLayer").getBoundingClientRect();
4981
+ const parentRect = HtmlTemplatesHelper
4982
+ .getAdjustedBoundingRect(localElement.closest(".textLayer"));
4921
4983
  const selectionRectangles = [];
4922
4984
  for (let i = 0; i < clientRects.length; i++) {
4923
4985
  const selectionRectangle = this.createTextRectangle(clientRects[i], parentRect);
@@ -5756,8 +5818,8 @@ class MainToolbarComponent {
5756
5818
  }
5757
5819
  }
5758
5820
  ngAfterViewInit() {
5759
- Array.from(this.mvToolbarMain.nativeElement.children).forEach(button => {
5760
- this.allButtonsWidth += button.getBoundingClientRect().width;
5821
+ Array.from(this.mvToolbarMain.nativeElement.children).forEach((button) => {
5822
+ this.allButtonsWidth += HtmlTemplatesHelper.getAdjustedBoundingRect(button).width;
5761
5823
  this.widthRequiredForBtn[button.id] = this.allButtonsWidth;
5762
5824
  });
5763
5825
  this.cdr.detectChanges();
@@ -6058,24 +6120,6 @@ i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.13", ngImpo
6058
6120
  type: Input
6059
6121
  }] } });
6060
6122
 
6061
- /**
6062
- * Helper Class
6063
- * Used for dynamic templates manipulation
6064
- * */
6065
- class HtmlTemplatesHelper {
6066
- static setDescribedBy(errorMessage, config) {
6067
- if (!errorMessage) {
6068
- return config.hint ? `${config.id}-hint` : null;
6069
- }
6070
- else if (errorMessage && errorMessage.isInvalid) {
6071
- return config.hint ? `${config.id}-hint ${config.id}-error` : `${config.id}-error`;
6072
- }
6073
- else {
6074
- return config.hint ? `${config.id}-hint` : null;
6075
- }
6076
- }
6077
- }
6078
-
6079
6123
  /*
6080
6124
  * Gov Uk Fieldset Component
6081
6125
  * Used to wrap group fieldset elements
@@ -6558,7 +6602,7 @@ class MediaViewerComponent {
6558
6602
  return;
6559
6603
  }
6560
6604
  if (!this.height) {
6561
- const compOffsetTop = this.elRef.nativeElement.getBoundingClientRect().top;
6605
+ const compOffsetTop = HtmlTemplatesHelper.getAdjustedBoundingRect(this.elRef.nativeElement).top;
6562
6606
  const viewerOffsetTop = this.viewerRef.nativeElement.offsetTop;
6563
6607
  const offset = compOffsetTop + viewerOffsetTop;
6564
6608
  if (this.prevOffset !== offset) {