@hmcts/media-viewer 4.2.0 → 4.2.4-exui-3994-f
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/.editorconfig +13 -0
- package/.eslintrc.json +54 -0
- package/.github/renovate.json +6 -0
- package/.github/workflows/npmpublish.yml +97 -0
- package/.github/workflows/pr-bot.yml +78 -0
- package/.nvmrc +2 -0
- package/.pa11yci +13 -0
- package/.pa11yci2 +17 -0
- package/.sessions/UUcTPnIAu1CxfK2Rl2DMK3QG4rpsONbj.json +1 -0
- package/.sessions/kEJWiY8Nu48owLiw0RtFL_Pk-Ht4-IpT.json +1 -0
- package/.sessions/oosQwb2r9llN9uU1_rncDuYMR_fEPGHd.json +1 -0
- package/.vscode/settings.json +22 -0
- package/.yarn/releases/yarn-4.5.0.cjs +925 -0
- package/.yarnrc.yml +13 -0
- package/Dockerfile +19 -0
- package/Jenkinsfile_CNP +131 -0
- package/Jenkinsfile_nightly +119 -0
- package/Makefile +3 -0
- package/angular.json +205 -0
- package/api/annotation-stubs.js +41 -0
- package/api/config.ts +63 -0
- package/api/health.ts +14 -0
- package/api/logger.ts +3 -0
- package/api/security/idam-client.ts +100 -0
- package/api/security/service-auth-provider-client.ts +46 -0
- package/api/security/token-repository.ts +50 -0
- package/api/server.ts +95 -0
- package/api/tsconfig.json +18 -0
- package/audit.json +178 -0
- package/catalog-info.yaml +18 -0
- package/charts/em-media-viewer/.helmignore +22 -0
- package/charts/em-media-viewer/Chart.yaml +10 -0
- package/charts/em-media-viewer/templates/NOTES.txt +8 -0
- package/charts/em-media-viewer/values.aat.template.yaml +4 -0
- package/charts/em-media-viewer/values.preview.template.yaml +4 -0
- package/charts/em-media-viewer/values.yaml +23 -0
- package/config/dependency-check-suppressions.xml +27 -0
- package/docker-compose.yml +12 -0
- package/e2e/ci.protractor.conf.js +50 -0
- package/e2e/cucumber.conf.js +2 -0
- package/e2e/local.protractor.conf.js +45 -0
- package/e2e/protractor.conf.js +65 -0
- package/e2e/reports.js +15 -0
- package/e2e/saucelabs.conf.js +91 -0
- package/e2e/src/app.e2e-spec.ts +16 -0
- package/e2e/src/common/constants.js +18 -0
- package/e2e/src/features/bookmarks.feature +31 -0
- package/e2e/src/features/comments.panel.feature +35 -0
- package/e2e/src/features/custom.toolbar.feature +87 -0
- package/e2e/src/features/download.feature +11 -0
- package/e2e/src/features/image.viewer.annotations.feature +24 -0
- package/e2e/src/features/multimedia.audio.feature +22 -0
- package/e2e/src/features/multimedia.feature +24 -0
- package/e2e/src/features/navigation.feature +33 -0
- package/e2e/src/features/outline.feature +28 -0
- package/e2e/src/features/pdf.viewer.annotations.feature +57 -0
- package/e2e/src/features/pdf.viewer.redactions.feature +45 -0
- package/e2e/src/features/print.download.feature +11 -0
- package/e2e/src/features/rotate.feature +30 -0
- package/e2e/src/features/search.feature +38 -0
- package/e2e/src/features/zoom.feature +16 -0
- package/e2e/src/pages/app.po.ts +381 -0
- package/e2e/src/pages/comment.po.ts +44 -0
- package/e2e/src/pages/commentspanel.po.ts +129 -0
- package/e2e/src/pages/download.po.ts +23 -0
- package/e2e/src/pages/multimedia.po.ts +14 -0
- package/e2e/src/pages/navigate.po.ts +40 -0
- package/e2e/src/pages/outline.po.ts +62 -0
- package/e2e/src/pages/print.po.ts +30 -0
- package/e2e/src/pages/redact.po.ts +107 -0
- package/e2e/src/pages/rotate.po.ts +49 -0
- package/e2e/src/pages/search.po.ts +91 -0
- package/e2e/src/pages/toolbar.po.ts +50 -0
- package/e2e/src/pages/zoom.po.ts +24 -0
- package/e2e/src/scenarios/comment.e2e-spec.ts +30 -0
- package/e2e/src/scenarios/download.e2e-spec.ts +44 -0
- package/e2e/src/scenarios/navigate.e2e-spec.ts +24 -0
- package/e2e/src/scenarios/print.e2e-spec.ts +37 -0
- package/e2e/src/scenarios/rotate.e2e-spec.ts +38 -0
- package/e2e/src/scenarios/search.e2e-spec.ts +43 -0
- package/e2e/src/scenarios/zoom.e2e-spec.ts +63 -0
- package/e2e/src/step_definitions/hooks.ts +21 -0
- package/e2e/src/step_definitions/media-viewer.ts +727 -0
- package/e2e/src/step_definitions/multimedia.ts +30 -0
- package/e2e/src/step_definitions/redact.ts +81 -0
- package/e2e/src/step_definitions/timeout.ts +2 -0
- package/e2e/src/utils/genericMethods.ts +39 -0
- package/e2e/supportedBrowsers.js +78 -0
- package/e2e/tsconfig.e2e.json +14 -0
- package/karma.conf.js +40 -0
- package/pa11y/pa11y-screenshots/home.png +0 -0
- package/package.json +203 -39
- package/projects/media-viewer/.eslintrc.json +46 -0
- package/projects/media-viewer/.yarn/releases/yarn-3.8.5.cjs +875 -0
- package/projects/media-viewer/.yarn/releases/yarn-4.5.0.cjs +925 -0
- package/projects/media-viewer/.yarnrc.yml +5 -0
- package/projects/media-viewer/css-bundle.ts +28 -0
- package/projects/media-viewer/karma.conf.js +52 -0
- package/projects/media-viewer/ng-package.json +15 -0
- package/projects/media-viewer/ng-package.prod.json +14 -0
- package/projects/media-viewer/package.json +43 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.html +16 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.spec.ts +366 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/box-highlight-create/box-highlight-create.component.ts +140 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.spec.ts +198 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.directive.ts +149 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.spec.ts +115 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-create/highlight-create/highlight-create.service.ts +104 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-set.component.html +12 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-set.component.spec.ts +168 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-set.component.ts +50 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-set.model.ts +7 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.html +26 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.spec.ts +219 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation-view.component.ts +88 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/annotation.model.ts +16 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.html +31 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.spec.ts +239 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.component.ts +135 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/annotation-view/rectangle/rectangle.model.ts +9 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.html +30 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.spec.ts +278 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/ctx-toolbar/ctx-toolbar.component.ts +127 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.html +36 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.spec.ts +232 -0
- package/projects/media-viewer/src/lib/annotations/annotation-set/metadata-layer/metadata-layer.component.ts +98 -0
- package/projects/media-viewer/src/lib/annotations/annotations.module.ts +99 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.component.html +75 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.component.spec.ts +315 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.component.ts +202 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.model.ts +13 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.service.spec.ts +107 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/comment.service.ts +57 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/text-highlight/text-highlight.directive.spec.ts +37 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/text-highlight/text-highlight.directive.ts +45 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/textarea-auto-expand/textarea-auto-expand.directive.spec.ts +48 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment/textarea-auto-expand/textarea-auto-expand.directive.ts +27 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-navigate/comments-navigate.component.html +13 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-navigate/comments-navigate.component.spec.ts +95 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-navigate/comments-navigate.component.ts +96 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-filter/comment-filter.component.html +102 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-filter/comment-filter.component.ts +71 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-search/comment-search.component.html +26 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-search/comment-search.component.ts +56 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-search/commet-search.component.spec.ts +102 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-set-header.component.html +58 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-set-header.component.spec.ts +80 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-header/comment-set-header.component.ts +73 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-render.service.spec.ts +85 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set-render.service.ts +59 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set.component.html +23 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set.component.spec.ts +375 -0
- package/projects/media-viewer/src/lib/annotations/comment-set/comment-set.component.ts +146 -0
- package/projects/media-viewer/src/lib/annotations/comments-summary/comments-summary.component.html +165 -0
- package/projects/media-viewer/src/lib/annotations/comments-summary/comments-summary.component.spec.ts +228 -0
- package/projects/media-viewer/src/lib/annotations/comments-summary/comments-summary.component.ts +123 -0
- package/projects/media-viewer/src/lib/annotations/comments-summary/comments-summary.model.ts +8 -0
- package/projects/media-viewer/src/lib/annotations/models/api-persisted.model.ts +11 -0
- package/projects/media-viewer/src/lib/annotations/models/event-select.model.ts +6 -0
- package/projects/media-viewer/src/lib/annotations/models/tags.model.ts +6 -0
- package/projects/media-viewer/src/lib/annotations/models/user.model.ts +7 -0
- package/projects/media-viewer/src/lib/annotations/pipes/date/date.pipe.spec.ts +19 -0
- package/projects/media-viewer/src/lib/annotations/pipes/date/date.pipe.ts +25 -0
- package/projects/media-viewer/src/lib/annotations/pipes/filter/filter.pipe.spec.ts +29 -0
- package/projects/media-viewer/src/lib/annotations/pipes/filter/filter.pipe.ts +30 -0
- package/projects/media-viewer/src/lib/annotations/pipes/unsnake/unsnake.pipe.spec.ts +15 -0
- package/projects/media-viewer/src/lib/annotations/pipes/unsnake/unsnake.pipe.ts +13 -0
- package/projects/media-viewer/src/lib/annotations/services/annotation-api/annotation-api.service.spec.ts +242 -0
- package/projects/media-viewer/src/lib/annotations/services/annotation-api/annotation-api.service.ts +77 -0
- package/projects/media-viewer/src/lib/annotations/services/bookmarks-api/bookmarks-api.service.spec.ts +82 -0
- package/projects/media-viewer/src/lib/annotations/services/bookmarks-api/bookmarks-api.service.ts +56 -0
- package/projects/media-viewer/src/lib/annotations/services/tags/tags.service.spec.ts +61 -0
- package/projects/media-viewer/src/lib/annotations/services/tags/tags.services.ts +44 -0
- package/projects/media-viewer/src/lib/annotations/tags/tags.component.html +34 -0
- package/projects/media-viewer/src/lib/annotations/tags/tags.component.spec.ts +47 -0
- package/projects/media-viewer/src/lib/annotations/tags/tags.component.ts +52 -0
- package/projects/media-viewer/src/lib/bookmark/components/bookmark-icons.component.html +19 -0
- package/projects/media-viewer/src/lib/bookmark/components/bookmark-icons.component.ts +27 -0
- package/projects/media-viewer/src/lib/icp/confirm-exit/confirm-action-dialog.component.html +16 -0
- package/projects/media-viewer/src/lib/icp/confirm-exit/confirm-action-dialog.component.spec.ts +124 -0
- package/projects/media-viewer/src/lib/icp/confirm-exit/confirm-action-dialog.component.ts +28 -0
- package/projects/media-viewer/src/lib/icp/icp-follower.service.spec.ts +80 -0
- package/projects/media-viewer/src/lib/icp/icp-follower.service.ts +69 -0
- package/projects/media-viewer/src/lib/icp/icp-presenter.service.spec.ts +119 -0
- package/projects/media-viewer/src/lib/icp/icp-presenter.service.ts +61 -0
- package/projects/media-viewer/src/lib/icp/icp-session-api.service.spec.ts +52 -0
- package/projects/media-viewer/src/lib/icp/icp-session-api.service.ts +26 -0
- package/projects/media-viewer/src/lib/icp/icp-update.service.spec.ts +176 -0
- package/projects/media-viewer/src/lib/icp/icp-update.service.ts +81 -0
- package/projects/media-viewer/src/lib/icp/icp.events.ts +13 -0
- package/projects/media-viewer/src/lib/icp/icp.interfaces.ts +26 -0
- package/projects/media-viewer/src/lib/icp/icp.service.spec.ts +226 -0
- package/projects/media-viewer/src/lib/icp/icp.service.ts +114 -0
- package/projects/media-viewer/src/lib/icp/participants-list/participants-list.component.html +18 -0
- package/projects/media-viewer/src/lib/icp/participants-list/participants-list.component.spec.ts +42 -0
- package/projects/media-viewer/src/lib/icp/participants-list/participants-list.component.ts +38 -0
- package/projects/media-viewer/src/lib/icp/socket.service.spec.ts +139 -0
- package/projects/media-viewer/src/lib/icp/socket.service.ts +138 -0
- package/projects/media-viewer/src/lib/media-viewer.component.html +105 -0
- package/projects/media-viewer/src/lib/media-viewer.component.spec.ts +384 -0
- package/projects/media-viewer/src/lib/media-viewer.component.ts +261 -0
- package/projects/media-viewer/src/lib/media-viewer.module.ts +91 -0
- package/projects/media-viewer/src/lib/print.service.spec.ts +59 -0
- package/projects/media-viewer/src/lib/print.service.ts +30 -0
- package/projects/media-viewer/src/lib/redaction/components/redaction.component.html +34 -0
- package/projects/media-viewer/src/lib/redaction/components/redaction.component.spec.ts +129 -0
- package/projects/media-viewer/src/lib/redaction/components/redaction.component.ts +106 -0
- package/projects/media-viewer/src/lib/redaction/services/redaction-api.service.spec.ts +91 -0
- package/projects/media-viewer/src/lib/redaction/services/redaction-api.service.ts +65 -0
- package/projects/media-viewer/src/lib/redaction/services/redaction.model.ts +12 -0
- package/projects/media-viewer/src/lib/shared/directives/tooltip-dismiss.directive.spec.ts +65 -0
- package/projects/media-viewer/src/lib/shared/directives/tooltip-dismiss.directive.ts +24 -0
- package/projects/media-viewer/src/lib/shared/gov-uk-date/gov-uk-date.component.html +95 -0
- package/projects/media-viewer/src/lib/shared/gov-uk-date/gov-uk-date.component.ts +17 -0
- package/projects/media-viewer/src/lib/shared/gov-uk-error-message/gov-uk-error-message.component.ts +21 -0
- package/projects/media-viewer/src/lib/shared/gov-uk-fieldset/gov-uk-fieldset.component.ts +39 -0
- package/projects/media-viewer/src/lib/shared/gov-uk-label/gov-uk-label.component.ts +28 -0
- package/projects/media-viewer/src/lib/shared/shared.module.ts +34 -0
- package/projects/media-viewer/src/lib/shared/util/helpers/html-templates.helper.spec.ts +38 -0
- package/projects/media-viewer/src/lib/shared/util/helpers/html-templates.helper.ts +29 -0
- package/projects/media-viewer/src/lib/shared/util/services/number.helper.service.spec.ts +47 -0
- package/projects/media-viewer/src/lib/shared/util/services/number.helper.service.ts +21 -0
- package/projects/media-viewer/src/lib/store/actions/annotation.actions.spec.ts +134 -0
- package/projects/media-viewer/src/lib/store/actions/annotation.actions.ts +129 -0
- package/projects/media-viewer/src/lib/store/actions/bookmark.actions.spec.ts +110 -0
- package/projects/media-viewer/src/lib/store/actions/bookmark.actions.ts +107 -0
- package/projects/media-viewer/src/lib/store/actions/document.actions.spec.ts +47 -0
- package/projects/media-viewer/src/lib/store/actions/document.actions.ts +96 -0
- package/projects/media-viewer/src/lib/store/actions/icp.actions.spec.ts +121 -0
- package/projects/media-viewer/src/lib/store/actions/icp.actions.ts +61 -0
- package/projects/media-viewer/src/lib/store/actions/index.ts +0 -0
- package/projects/media-viewer/src/lib/store/actions/redaction.actions.ts +132 -0
- package/projects/media-viewer/src/lib/store/actions/tag.actions.ts +25 -0
- package/projects/media-viewer/src/lib/store/bookmarks-store-utils.spec.ts +34 -0
- package/projects/media-viewer/src/lib/store/bookmarks-store-utils.ts +54 -0
- package/projects/media-viewer/src/lib/store/effects/annotation.effects.spec.ts +91 -0
- package/projects/media-viewer/src/lib/store/effects/annotation.effects.ts +76 -0
- package/projects/media-viewer/src/lib/store/effects/bookmarks.effects.spec.ts +145 -0
- package/projects/media-viewer/src/lib/store/effects/bookmarks.effects.ts +93 -0
- package/projects/media-viewer/src/lib/store/effects/document.effects.spec.ts +93 -0
- package/projects/media-viewer/src/lib/store/effects/document.effects.ts +63 -0
- package/projects/media-viewer/src/lib/store/effects/icp.effects.spec.ts +84 -0
- package/projects/media-viewer/src/lib/store/effects/icp.effects.ts +40 -0
- package/projects/media-viewer/src/lib/store/effects/index.ts +7 -0
- package/projects/media-viewer/src/lib/store/effects/redaction.effects.spec.ts +175 -0
- package/projects/media-viewer/src/lib/store/effects/redaction.effects.ts +111 -0
- package/projects/media-viewer/src/lib/store/models/bookmarks.interface.ts +32 -0
- package/projects/media-viewer/src/lib/store/models/filters.interface.ts +5 -0
- package/projects/media-viewer/src/lib/store/reducers/annotations.reducer.spec.ts +153 -0
- package/projects/media-viewer/src/lib/store/reducers/annotations.reducer.ts +246 -0
- package/projects/media-viewer/src/lib/store/reducers/bookmarks.reducer.spec.ts +141 -0
- package/projects/media-viewer/src/lib/store/reducers/bookmarks.reducer.ts +150 -0
- package/projects/media-viewer/src/lib/store/reducers/document.reducer.spec.ts +119 -0
- package/projects/media-viewer/src/lib/store/reducers/document.reducer.ts +205 -0
- package/projects/media-viewer/src/lib/store/reducers/icp.reducer.spec.ts +70 -0
- package/projects/media-viewer/src/lib/store/reducers/icp.reducer.ts +66 -0
- package/projects/media-viewer/src/lib/store/reducers/redaction.reducer.spec.ts +86 -0
- package/projects/media-viewer/src/lib/store/reducers/redaction.reducer.ts +143 -0
- package/projects/media-viewer/src/lib/store/reducers/reducers.ts +35 -0
- package/projects/media-viewer/src/lib/store/reducers/tags.reducer.ts +120 -0
- package/projects/media-viewer/src/lib/store/selectors/annotation.selectors.spec.ts +290 -0
- package/projects/media-viewer/src/lib/store/selectors/annotation.selectors.ts +151 -0
- package/projects/media-viewer/src/lib/store/selectors/bookmark.selectors.spec.ts +63 -0
- package/projects/media-viewer/src/lib/store/selectors/bookmark.selectors.ts +73 -0
- package/projects/media-viewer/src/lib/store/selectors/document.selectors.spec.ts +53 -0
- package/projects/media-viewer/src/lib/store/selectors/document.selectors.ts +49 -0
- package/projects/media-viewer/src/lib/store/selectors/icp.selectors.spec.ts +140 -0
- package/projects/media-viewer/src/lib/store/selectors/icp.selectors.ts +44 -0
- package/projects/media-viewer/src/lib/store/selectors/index.ts +0 -0
- package/projects/media-viewer/src/lib/store/selectors/redaction.selectors.ts +57 -0
- package/projects/media-viewer/src/lib/store/selectors/tag.selectors.spec.ts +185 -0
- package/projects/media-viewer/src/lib/store/selectors/tag.selectors.ts +38 -0
- package/projects/media-viewer/src/lib/store/store-utils.spec.ts +127 -0
- package/projects/media-viewer/src/lib/store/store-utils.ts +152 -0
- package/projects/media-viewer/src/lib/toolbar/highlight-toolbar/highlight-toolbar.component.html +56 -0
- package/projects/media-viewer/src/lib/toolbar/highlight-toolbar/highlight-toolbar.component.scss +0 -0
- package/projects/media-viewer/src/lib/toolbar/highlight-toolbar/highlight-toolbar.component.spec.ts +127 -0
- package/projects/media-viewer/src/lib/toolbar/highlight-toolbar/highlight-toolbar.component.ts +53 -0
- package/projects/media-viewer/src/lib/toolbar/icp-event.service.ts +45 -0
- package/projects/media-viewer/src/lib/toolbar/icp-toolbar/icp-toolbar.component.html +47 -0
- package/projects/media-viewer/src/lib/toolbar/icp-toolbar/icp-toolbar.component.spec.ts +70 -0
- package/projects/media-viewer/src/lib/toolbar/icp-toolbar/icp-toolbar.component.ts +51 -0
- package/projects/media-viewer/src/lib/toolbar/main-toolbar/main-toolbar.component.html +428 -0
- package/projects/media-viewer/src/lib/toolbar/main-toolbar/main-toolbar.component.spec.ts +298 -0
- package/projects/media-viewer/src/lib/toolbar/main-toolbar/main-toolbar.component.ts +239 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-search-bar/redaction-search-bar.component.html +76 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-search-bar/redaction-search-bar.component.scss +15 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-search-bar/redaction-search-bar.component.spec.ts +291 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-search-bar/redaction-search-bar.component.ts +289 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-search-bar/redaction-search.model.ts +13 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-toolbar/redaction-toolbar.component.html +118 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-toolbar/redaction-toolbar.component.spec.ts +126 -0
- package/projects/media-viewer/src/lib/toolbar/redaction-toolbar/redaction-toolbar.component.ts +77 -0
- package/projects/media-viewer/src/lib/toolbar/search-bar/search-bar.component.html +157 -0
- package/projects/media-viewer/src/lib/toolbar/search-bar/search-bar.component.spec.ts +191 -0
- package/projects/media-viewer/src/lib/toolbar/search-bar/search-bar.component.ts +119 -0
- package/projects/media-viewer/src/lib/toolbar/toolbar-button-visibility.service.spec.ts +39 -0
- package/projects/media-viewer/src/lib/toolbar/toolbar-button-visibility.service.ts +94 -0
- package/projects/media-viewer/src/lib/toolbar/toolbar-event.service.spec.ts +203 -0
- package/projects/media-viewer/src/lib/toolbar/toolbar-event.service.ts +227 -0
- package/projects/media-viewer/src/lib/toolbar/toolbar.module.ts +47 -0
- package/projects/media-viewer/src/lib/toolbar/tooltip-dismiss.directive.ts +0 -0
- package/projects/media-viewer/src/lib/viewers/convertible-content-viewer/convertible-content-viewer.component.html +12 -0
- package/projects/media-viewer/src/lib/viewers/convertible-content-viewer/convertible-content-viewer.component.spec.ts +97 -0
- package/projects/media-viewer/src/lib/viewers/convertible-content-viewer/convertible-content-viewer.component.ts +83 -0
- package/projects/media-viewer/src/lib/viewers/convertible-content-viewer/document-conversion-api.service.spec.ts +28 -0
- package/projects/media-viewer/src/lib/viewers/convertible-content-viewer/document-conversion-api.service.ts +22 -0
- package/projects/media-viewer/src/lib/viewers/grab-n-drag.directive.spec.ts +62 -0
- package/projects/media-viewer/src/lib/viewers/grab-n-drag.directive.ts +49 -0
- package/projects/media-viewer/src/lib/viewers/image-viewer/image-viewer.component.html +63 -0
- package/projects/media-viewer/src/lib/viewers/image-viewer/image-viewer.component.spec.ts +213 -0
- package/projects/media-viewer/src/lib/viewers/image-viewer/image-viewer.component.ts +202 -0
- package/projects/media-viewer/src/lib/viewers/multimedia-player/multimedia-player.component.html +53 -0
- package/projects/media-viewer/src/lib/viewers/multimedia-player/multimedia-player.component.spec.ts +77 -0
- package/projects/media-viewer/src/lib/viewers/multimedia-player/multimedia-player.component.ts +71 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-js/pdf-js-wrapper.provider.spec.ts +25 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-js/pdf-js-wrapper.provider.ts +57 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-js/pdf-js-wrapper.spec.ts +376 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-js/pdf-js-wrapper.ts +322 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-viewer.component.html +88 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-viewer.component.spec.ts +461 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/pdf-viewer.component.ts +312 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.html +108 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.spec.ts +416 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.component.ts +446 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/bookmarks/bookmarks.interfaces.ts +16 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/outline-item/outline-item.component.html +32 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/outline-item/outline-item.component.spec.ts +94 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/outline-item/outline-item.component.ts +48 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/outline-item/outline.model.ts +13 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.html +66 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.spec.ts +126 -0
- package/projects/media-viewer/src/lib/viewers/pdf-viewer/side-bar/side-bar.component.ts +106 -0
- package/projects/media-viewer/src/lib/viewers/rotation-persist/rotation-api.service.spec.ts +41 -0
- package/projects/media-viewer/src/lib/viewers/rotation-persist/rotation-api.service.ts +32 -0
- package/projects/media-viewer/src/lib/viewers/rotation-persist/rotation-persist.directive.spec.ts +55 -0
- package/projects/media-viewer/src/lib/viewers/rotation-persist/rotation-persist.directive.ts +70 -0
- package/projects/media-viewer/src/lib/viewers/rotation-persist/rotation.model.ts +4 -0
- package/projects/media-viewer/src/lib/viewers/unsupported-viewer/unsupported-viewer.component.html +11 -0
- package/projects/media-viewer/src/lib/viewers/unsupported-viewer/unsupported-viewer.component.spec.ts +54 -0
- package/projects/media-viewer/src/lib/viewers/unsupported-viewer/unsupported-viewer.component.ts +56 -0
- package/projects/media-viewer/src/lib/viewers/viewer-event.service.spec.ts +39 -0
- package/projects/media-viewer/src/lib/viewers/viewer-event.service.ts +41 -0
- package/projects/media-viewer/src/lib/viewers/viewer-exception.model.ts +20 -0
- package/projects/media-viewer/src/lib/viewers/viewer-util.service.spec.ts +40 -0
- package/projects/media-viewer/src/lib/viewers/viewer-util.service.ts +15 -0
- package/projects/media-viewer/src/public_api.ts +33 -0
- package/projects/media-viewer/src/test.ts +18 -0
- package/projects/media-viewer/tsconfig.lib.json +35 -0
- package/projects/media-viewer/tsconfig.lib.prod.json +7 -0
- package/projects/media-viewer/tsconfig.spec.json +18 -0
- package/projects/media-viewer/tslint.json +17 -0
- package/projects/media-viewer/yarn.lock +291 -0
- package/proxy.config.js +45 -0
- package/sonar-project.properties +33 -0
- package/src/app/app.component.html +5 -0
- package/src/app/app.component.scss +87 -0
- package/src/app/app.component.spec.ts +31 -0
- package/src/app/app.component.ts +14 -0
- package/src/app/app.module.ts +46 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/custom-toolbar.component.html +79 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/custom-toolbar.component.ts +66 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/custom-toolbar.module.ts +20 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/search-bar/search-bar.component.css +12 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/search-bar/search-bar.component.html +50 -0
- package/src/app/media-viewer-wrapper/custom-toolbar/search-bar/search-bar.component.ts +84 -0
- package/src/app/media-viewer-wrapper/media-viewer-wrapper.component.html +226 -0
- package/src/app/media-viewer-wrapper/media-viewer-wrapper.component.ts +120 -0
- package/src/app/media-viewer-wrapper/toolbar-toggles/toggle/toggle.component.html +13 -0
- package/src/app/media-viewer-wrapper/toolbar-toggles/toggle/toggle.component.ts +12 -0
- package/src/app/media-viewer-wrapper/toolbar-toggles/toolbar-toggles.component.html +151 -0
- package/src/app/media-viewer-wrapper/toolbar-toggles/toolbar-toggles.component.scss +62 -0
- package/src/app/media-viewer-wrapper/toolbar-toggles/toolbar-toggles.component.ts +31 -0
- package/src/app/routing.module.ts +45 -0
- package/src/assets/annotation-set.json +152 -0
- package/src/assets/documents/image/69fb7313-5338-42c4-b94d-0ceb3b6ed18b +0 -0
- package/src/assets/documents/pdf/04666097-eb32-4b2b-9bec-8e9ce8057560 +0 -0
- package/src/assets/example.jpg +0 -0
- package/src/assets/example.pdf +0 -0
- package/src/assets/example2.pdf +0 -0
- package/src/assets/example3.pdf +0 -0
- package/src/assets/mock-data/image-annotation-set.ts +90 -0
- package/src/assets/mock-data/pdf-annotation-set.ts +122 -0
- package/src/assets/multimedia/audio_test.aac +0 -0
- package/src/assets/multimedia/audio_test.m4a +0 -0
- package/src/assets/multimedia/audio_test.mp3 +0 -0
- package/src/assets/multimedia/audio_test.ogg +0 -0
- package/src/assets/multimedia/audio_test.wav +0 -0
- package/src/assets/multimedia/audio_test.wma +0 -0
- package/src/assets/multimedia/clapping.mp3 +0 -0
- package/src/assets/multimedia/movie.mp4 +0 -0
- package/src/assets/multimedia/movie.ogv +0 -0
- package/src/assets/multimedia/video_test.avi +0 -0
- package/src/assets/multimedia/video_test.mov +0 -0
- package/src/assets/multimedia/video_test.mpg +0 -0
- package/src/assets/multimedia/video_test.webm +0 -0
- package/src/assets/multimedia/video_test.wmv +0 -0
- package/src/assets/unsupported.txt +1 -0
- package/src/browserslist +11 -0
- package/src/environments/environment.prod.ts +3 -0
- package/src/environments/environment.ts +3 -0
- package/src/favicon.ico +0 -0
- package/src/index.html +13 -0
- package/src/karma.conf.js +40 -0
- package/src/main.ts +6 -0
- package/src/polyfills.ts +73 -0
- package/src/test.ts +16 -0
- package/src/tsconfig.app.json +16 -0
- package/src/tsconfig.spec.json +12 -0
- package/src/tslint.json +17 -0
- package/test/config.js +23 -0
- package/test/crossbrowser/supportedBrowsers.js +65 -0
- package/test/end-to-end/codecept.conf.js +85 -0
- package/test/end-to-end/codecept.smoke.conf.js +85 -0
- package/test/end-to-end/data/ThankYou.doc +0 -0
- package/test/end-to-end/data/ccd-case-basic-data.json +81 -0
- package/test/end-to-end/data/commonConfig.json +119 -0
- package/test/end-to-end/data/example.pdf +0 -0
- package/test/end-to-end/data/nicemelody.mp3 +0 -0
- package/test/end-to-end/data/quote.jpg +0 -0
- package/test/end-to-end/helpers/JSWait.js +97 -0
- package/test/end-to-end/helpers/PuppeteerHelper.js +39 -0
- package/test/end-to-end/helpers/SauceLabsReportingHelper.js +24 -0
- package/test/end-to-end/helpers/WebDriverHelper.js +45 -0
- package/test/end-to-end/helpers/ccdDataStoreApi.js +73 -0
- package/test/end-to-end/helpers/idamApi.js +44 -0
- package/test/end-to-end/helpers/mvCaseHelper.js +365 -0
- package/test/end-to-end/helpers/s2sHelper.js +30 -0
- package/test/end-to-end/mvFeatures/annotationsAndComments.js +83 -0
- package/test/end-to-end/mvFeatures/bookMarks.js +54 -0
- package/test/end-to-end/mvFeatures/createCCDCase.js +14 -0
- package/test/end-to-end/mvFeatures/dmStoreScenarios.js +26 -0
- package/test/end-to-end/mvFeatures/imageViewerAnnotationsAndComments.js +32 -0
- package/test/end-to-end/mvFeatures/indexAndOutline.js +25 -0
- package/test/end-to-end/mvFeatures/multiMedia.js +17 -0
- package/test/end-to-end/mvFeatures/printAndDownload.js +17 -0
- package/test/end-to-end/mvFeatures/redact.js +89 -0
- package/test/end-to-end/mvFeatures/rotate.js +17 -0
- package/test/end-to-end/mvFeatures/search.js +35 -0
- package/test/end-to-end/mvFeatures/smokeTest.js +21 -0
- package/test/end-to-end/mvFeatures/zoomAndnavigation.js +30 -0
- package/test/end-to-end/pages/annotationsAndComments/addCommentAndRotate.js +13 -0
- package/test/end-to-end/pages/annotationsAndComments/addComments.js +17 -0
- package/test/end-to-end/pages/annotationsAndComments/addMultipleComments.js +14 -0
- package/test/end-to-end/pages/annotationsAndComments/annotateFromSearch.js +22 -0
- package/test/end-to-end/pages/annotationsAndComments/clickCommentsPanel.js +17 -0
- package/test/end-to-end/pages/annotationsAndComments/collateComments.js +14 -0
- package/test/end-to-end/pages/annotationsAndComments/collateCommentsNotBlank.js +23 -0
- package/test/end-to-end/pages/annotationsAndComments/commentsSearch.js +19 -0
- package/test/end-to-end/pages/annotationsAndComments/deleteAllExistingComments.js +20 -0
- package/test/end-to-end/pages/annotationsAndComments/deleteAllExistingNonTextualHighlights.js +16 -0
- package/test/end-to-end/pages/annotationsAndComments/deleteAllExistingTextHighlights.js +23 -0
- package/test/end-to-end/pages/annotationsAndComments/deleteComments.js +26 -0
- package/test/end-to-end/pages/annotationsAndComments/highlightOnImage.js +35 -0
- package/test/end-to-end/pages/annotationsAndComments/highlightPdfText.js +32 -0
- package/test/end-to-end/pages/annotationsAndComments/nonTextualHighlightAndComment.js +12 -0
- package/test/end-to-end/pages/annotationsAndComments/openHighlightToolbar.js +7 -0
- package/test/end-to-end/pages/annotationsAndComments/updateComment.js +19 -0
- package/test/end-to-end/pages/annotationsAndComments/updateNonTextualComments.js +27 -0
- package/test/end-to-end/pages/bookMarks/add30Bookmarks.js +16 -0
- package/test/end-to-end/pages/bookMarks/addAnEmptyBookMarks.js +15 -0
- package/test/end-to-end/pages/bookMarks/addNamedBookmark.js +17 -0
- package/test/end-to-end/pages/bookMarks/bookmarkBoxBlank.js +11 -0
- package/test/end-to-end/pages/bookMarks/clearBookmarkss.js +14 -0
- package/test/end-to-end/pages/bookMarks/createBookmarks.js +30 -0
- package/test/end-to-end/pages/bookMarks/customOrderBookmarks.js +18 -0
- package/test/end-to-end/pages/bookMarks/deleteBookMark.js +14 -0
- package/test/end-to-end/pages/bookMarks/openBookmarksPanel.js +20 -0
- package/test/end-to-end/pages/bookMarks/reorderBookmarks.js +9 -0
- package/test/end-to-end/pages/bookMarks/sortBookmarks.js +44 -0
- package/test/end-to-end/pages/bookMarks/updateBookMark.js +22 -0
- package/test/end-to-end/pages/common/constants.js +47 -0
- package/test/end-to-end/pages/dmStore/uploadImageJpeg.js +13 -0
- package/test/end-to-end/pages/dmStore/uploadPdfDocument.js +14 -0
- package/test/end-to-end/pages/dmStore/uploadWordDocument.js +14 -0
- package/test/end-to-end/pages/idam/signIn.js +18 -0
- package/test/end-to-end/pages/imageViewer/openImage.js +11 -0
- package/test/end-to-end/pages/indexAndOutline/loadDocumentAndCheckSuccessLoad.js +18 -0
- package/test/end-to-end/pages/indexAndOutline/navigateIndexBundleDocument.js +29 -0
- package/test/end-to-end/pages/indexAndOutline/navigateIndexNestedDocument.js +40 -0
- package/test/end-to-end/pages/multiMedia/multiMediaAudio.js +9 -0
- package/test/end-to-end/pages/navigationMV/pdfViewerNavigation.js +23 -0
- package/test/end-to-end/pages/nextStep/nextStep.js +11 -0
- package/test/end-to-end/pages/openCaseDocsInMv/openCaseDocsInMV.js +16 -0
- package/test/end-to-end/pages/printAndDownload/mvDownload.js +16 -0
- package/test/end-to-end/pages/printAndDownload/mvPrint.js +16 -0
- package/test/end-to-end/pages/redact/CreateRedactionsUsingDrawboxAndRedactText.js +19 -0
- package/test/end-to-end/pages/redact/clearAllRedactions.js +12 -0
- package/test/end-to-end/pages/redact/clickRedactAllButton.js +18 -0
- package/test/end-to-end/pages/redact/clickRedactMenu.js +17 -0
- package/test/end-to-end/pages/redact/clickRedactSearchButton.js +10 -0
- package/test/end-to-end/pages/redact/clickSearchFrom.js +17 -0
- package/test/end-to-end/pages/redact/markContentForRedaction.js +15 -0
- package/test/end-to-end/pages/redact/previewAllRedactions.js +13 -0
- package/test/end-to-end/pages/redact/redactContentUsingRedactText.js +12 -0
- package/test/end-to-end/pages/redact/redactFillSearchInput.js +10 -0
- package/test/end-to-end/pages/redact/redactFirstPage.js +16 -0
- package/test/end-to-end/pages/redact/redactMultiplePages.js +21 -0
- package/test/end-to-end/pages/redact/redactSearchAndRedactAll.js +15 -0
- package/test/end-to-end/pages/redact/redactText.js +21 -0
- package/test/end-to-end/pages/redact/redactTextAndThenRemoveRedaction.js +19 -0
- package/test/end-to-end/pages/redact/redactionsPreview.js +14 -0
- package/test/end-to-end/pages/redact/saveAllRedactions.js +13 -0
- package/test/end-to-end/pages/redact/verifyWhetherTheRedactionAreVisibleOrNot.js +10 -0
- package/test/end-to-end/pages/rotate/pdfAndImageRotation.js +10 -0
- package/test/end-to-end/pages/search/contentSearch.js +10 -0
- package/test/end-to-end/pages/search/enterShouldJumpViewerToNextSearchResults.js +16 -0
- package/test/end-to-end/pages/search/searchResultsNavigationUsingNextAndPrevious.js +16 -0
- package/test/end-to-end/pages/steps.js +79 -0
- package/test/end-to-end/pages/zoom/pdfViewerZoom.js +10 -0
- package/test/end-to-end/saucelabs.conf.js +131 -0
- package/test/mocks/data/mock-annotation-set.ts +173 -0
- package/test/mocks/data/mock-annotations.ts +39 -0
- package/test/mocks/data/mock-comments.ts +27 -0
- package/tsconfig.json +38 -0
- package/tsconfig.spec.json +17 -0
- package/tslint.json +120 -0
- package/version +4 -0
- package/yarn-audit-known-issues +13 -0
- package/assets/build/pdf.min.mjs +0 -21
- package/assets/build/pdf.mjs +0 -21576
- package/assets/build/pdf.mjs.map +0 -1
- package/assets/build/pdf.sandbox.min.mjs +0 -21
- package/assets/build/pdf.sandbox.mjs +0 -242
- package/assets/build/pdf.sandbox.mjs.map +0 -1
- package/assets/build/pdf.worker.min.mjs +0 -21
- package/assets/build/pdf.worker.mjs +0 -56979
- package/assets/build/pdf.worker.mjs.map +0 -1
- package/fesm2022/hmcts-media-viewer.mjs +0 -7539
- package/fesm2022/hmcts-media-viewer.mjs.map +0 -1
- package/index.d.ts +0 -2318
- package/index.d.ts.map +0 -1
- /package/{assets → projects/media-viewer/src/assets}/all.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/annotation-set.ts +0 -0
- /package/{assets → projects/media-viewer/src/assets}/fonts/bold-a2452cb66f-v1.woff2 +0 -0
- /package/{assets → projects/media-viewer/src/assets}/fonts/bold-f38c792ac2-v1.woff +0 -0
- /package/{assets → projects/media-viewer/src/assets}/fonts/light-f38ad40456-v1.woff2 +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/annotate-highlight.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/annotation-note.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/arrow-down.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/arrow-up.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/bookmark-here.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/bookmark-rename.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/bookmark-save.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/clear-all.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/download-button.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-next-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-next-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-next.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-next@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-previous-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-previous-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-previous.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/findbarButton-previous@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/grab.cur +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/grab_n_drag.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/grabbing.cur +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-bookmarks-custom.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-bookmarks-position.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-comments.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-hide.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-items.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-rotate-left.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-rotate.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-casefile-view.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-document-comments.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-document-items.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-draw-box.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-draw-redact-box-alt.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-filter.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-highlight.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-page.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-preview-off.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-preview.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-redact.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-sort-down.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-sort-up.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-tag-remove-cross.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/icon-unmark-all.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/loading-small.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/loading-small@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/lock_48px.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/marker-pen.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/more.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/present.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/printer.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/search-minus.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/search-plus.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/search.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-documentProperties.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-documentProperties@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-firstPage.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-firstPage@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-handGrab.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-handTool.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-handTool@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-lastPage.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-lastPage@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-rotateCcw.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-rotateCcw@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-rotateCw.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-rotateCw@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-saveRotation.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollHorizontal.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollHorizontal@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollVertical.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollVertical@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollWrapped.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-scrollWrapped@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-selectTool.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-selectTool@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadEven.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadEven@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadNone.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadNone@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadOdd.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/secondaryToolbarButton-spreadOdd@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toggleButton-draw.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toggleButton-draw@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-addBookmark.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-addBookmark@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-bookmark.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-bookmark@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-bookmarkDark.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-download.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-download@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-highlight.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-highlight@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-menuArrows.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-menuArrows@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-openFile.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-openFile@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageDown-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageDown-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageDown.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageDown@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageUp-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageUp-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageUp.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-pageUp@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-presentationMode.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-presentationMode@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-print.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-print@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-search.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-search@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-searchComments.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-secondaryToolbarToggle-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-secondaryToolbarToggle-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-secondaryToolbarToggle.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-secondaryToolbarToggle@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-sidebarToggle-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-sidebarToggle-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-sidebarToggle.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-sidebarToggle@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewAttachments.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewAttachments@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewOutline-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewOutline-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewOutline.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewOutline@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewThumbnail.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-viewThumbnail@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-zoomIn.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-zoomIn@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-zoomOut.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/toolbarButton-zoomOut@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-collapsed-rtl.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-collapsed-rtl@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-collapsed.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-collapsed@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-expanded.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/treeitem-expanded@2x.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/images/viewer-rotate.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_add.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_add.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_disclaimer.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_disclaimer.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_done.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_done.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_spinner.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_spinner.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_warning.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/altText_warning.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-check.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-check.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-comment.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-comment.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-help.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-help.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-insert.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-insert.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-key.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-key.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-newparagraph.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-newparagraph.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-noicon.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-noicon.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-note.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-note.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-paperclip.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-paperclip.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-paragraph.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-paragraph.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-pushpin.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/annotation-pushpin.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorFreeHighlight.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorFreeHighlight.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorFreeText.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorFreeText.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorInk.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorInk.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorTextHighlight.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/cursor-editorTextHighlight.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/editor-toolbar-delete.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/editor-toolbar-delete.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/loading-icon.gif +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/loading-icon.gif:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/messageBar_closingButton.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/messageBar_closingButton.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/messageBar_warning.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/messageBar_warning.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/shadow.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/texture.png +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/toolbarButton-editorHighlight.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/toolbarButton-editorHighlight.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/toolbarButton-menuArrow.svg +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/images/toolbarButton-menuArrow.svg:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/pdf_viewer.css +0 -0
- /package/{assets → projects/media-viewer/src/assets}/pdfjs/pdf_viewer.css:Zone.Identifier +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/angular-tree-component.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/annotation-set.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/bookmarks.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/box-highlight.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment-filter.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment-search.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment-set-header.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment-set-panel.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment-set-toggle.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comment.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/comments-summary-dialog.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/confirm-action-dialog.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/document.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/image-viewer.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/media-viewer.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/outline-attachment.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/participants-list.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/pdf-viewer.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/popup-toolbar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/rectangle.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/redaction.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/settings.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/tabs.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/tags.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/buttons.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/debugging.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/dialog-overlay.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/field-label.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/icp-buttons.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/icp-toolbar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/loading-bar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/main-toolbar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/main.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/media.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/redaction-toolbar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/search-bar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/side-bar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/sub-toolbar.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/text-selection.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/toolbar/thumbnail.scss +0 -0
- /package/{assets → projects/media-viewer/src/assets}/sass/tooltip.scss +0 -0
|
@@ -0,0 +1,239 @@
|
|
|
1
|
+
import { ComponentFixture, TestBed} from '@angular/core/testing';
|
|
2
|
+
import { CUSTOM_ELEMENTS_SCHEMA, DebugElement } from '@angular/core';
|
|
3
|
+
import { RectangleComponent } from './rectangle.component';
|
|
4
|
+
import { FormsModule } from '@angular/forms';
|
|
5
|
+
import { MutableDivModule } from 'mutable-div';
|
|
6
|
+
import { By } from '@angular/platform-browser';
|
|
7
|
+
import { HighlightCreateService } from '../../annotation-create/highlight-create/highlight-create.service';
|
|
8
|
+
import { StoreModule } from '@ngrx/store';
|
|
9
|
+
import { reducers } from '../../../../store/reducers/reducers';
|
|
10
|
+
|
|
11
|
+
describe('RectangleComponent', () => {
|
|
12
|
+
let component: RectangleComponent;
|
|
13
|
+
let fixture: ComponentFixture<RectangleComponent>;
|
|
14
|
+
let rectangleEl: DebugElement;
|
|
15
|
+
let nativeElement;
|
|
16
|
+
let mockRectangle;
|
|
17
|
+
|
|
18
|
+
beforeEach(() => {
|
|
19
|
+
mockRectangle = {
|
|
20
|
+
id: '16d5c513-15f9-4c39-8102-88bdb85d8831',
|
|
21
|
+
createdBy: 'ea6d959c-b6c9-48af-89c2-6f7bd796524d',
|
|
22
|
+
createdByDetails: {
|
|
23
|
+
'forename': 'Linus',
|
|
24
|
+
'surname': 'Norton',
|
|
25
|
+
'email': 'linus.norton@hmcts.net'
|
|
26
|
+
},
|
|
27
|
+
createdDate: '2018-05-28T08:48:33.206Z',
|
|
28
|
+
lastModifiedBy: 'ea6d959c-b6c9-48af-89c2-6f7bd796524d',
|
|
29
|
+
lastModifiedByDetails: {
|
|
30
|
+
'forename': 'Jeroen',
|
|
31
|
+
'surname': 'Rijks',
|
|
32
|
+
'email': 'jeroen.rijks@hmcts.net'
|
|
33
|
+
},
|
|
34
|
+
lastModifiedDate: '2019-05-28T08:48:33.206Z',
|
|
35
|
+
annotationId: '123annotationId',
|
|
36
|
+
height: 100,
|
|
37
|
+
width: 50,
|
|
38
|
+
x: 5,
|
|
39
|
+
y: 10,
|
|
40
|
+
};
|
|
41
|
+
});
|
|
42
|
+
|
|
43
|
+
beforeEach(() => {
|
|
44
|
+
return TestBed.configureTestingModule({
|
|
45
|
+
declarations: [RectangleComponent],
|
|
46
|
+
imports: [
|
|
47
|
+
FormsModule,
|
|
48
|
+
MutableDivModule,
|
|
49
|
+
StoreModule.forFeature('media-viewer', reducers),
|
|
50
|
+
StoreModule.forRoot({})
|
|
51
|
+
],
|
|
52
|
+
providers: [HighlightCreateService],
|
|
53
|
+
schemas: [CUSTOM_ELEMENTS_SCHEMA, ]
|
|
54
|
+
})
|
|
55
|
+
.compileComponents();
|
|
56
|
+
});
|
|
57
|
+
|
|
58
|
+
beforeEach(() => {
|
|
59
|
+
fixture = TestBed.createComponent(RectangleComponent);
|
|
60
|
+
component = fixture.componentInstance;
|
|
61
|
+
component.annoRect = mockRectangle;
|
|
62
|
+
component.pageHeight = 800;
|
|
63
|
+
component.pageWidth = 400;
|
|
64
|
+
component.zoom = 1;
|
|
65
|
+
component.rotate = 0;
|
|
66
|
+
component.editable = true;
|
|
67
|
+
component.selected = false;
|
|
68
|
+
component.enableGrabNDrag = false;
|
|
69
|
+
nativeElement = fixture.debugElement.nativeElement;
|
|
70
|
+
fixture.detectChanges();
|
|
71
|
+
rectangleEl = fixture.debugElement.query(By.css('.rectangle'));
|
|
72
|
+
fixture.detectChanges();
|
|
73
|
+
});
|
|
74
|
+
|
|
75
|
+
it('should be created', () => {
|
|
76
|
+
expect(component).toBeTruthy();
|
|
77
|
+
});
|
|
78
|
+
|
|
79
|
+
it('should set dimentions on annoRect input with 0.5 zoom', () => {
|
|
80
|
+
component.zoom = 0.5;
|
|
81
|
+
component.annoRect = mockRectangle;
|
|
82
|
+
|
|
83
|
+
expect(component.height).toBe(50);
|
|
84
|
+
expect(component.width).toBe(25);
|
|
85
|
+
expect(component.top).toBe(5);
|
|
86
|
+
expect(component.left).toBe(2.5);
|
|
87
|
+
});
|
|
88
|
+
|
|
89
|
+
it('should maitain dimensions when rotation is zero', () => {
|
|
90
|
+
component.zoom = 0.5;
|
|
91
|
+
component.annoRect = mockRectangle;
|
|
92
|
+
component.adjustForRotation(0);
|
|
93
|
+
|
|
94
|
+
expect(component.height).toBe(50);
|
|
95
|
+
expect(component.width).toBe(25);
|
|
96
|
+
expect(component.top).toBe(5);
|
|
97
|
+
expect(component.left).toBe(2.5);
|
|
98
|
+
});
|
|
99
|
+
|
|
100
|
+
it('should adjust dimensions when rotation is 90deg', () => {
|
|
101
|
+
component.zoom = 0.5;
|
|
102
|
+
component.annoRect = mockRectangle;
|
|
103
|
+
component.adjustForRotation(90);
|
|
104
|
+
|
|
105
|
+
expect(component.height).toBe(25);
|
|
106
|
+
expect(component.width).toBe(50);
|
|
107
|
+
expect(component.top).toBe(2.5);
|
|
108
|
+
expect(component.left).toBe(345);
|
|
109
|
+
});
|
|
110
|
+
|
|
111
|
+
it('should adjust dimensions when rotation is 180deg', () => {
|
|
112
|
+
component.zoom = 0.5;
|
|
113
|
+
component.annoRect = mockRectangle;
|
|
114
|
+
component.adjustForRotation(180);
|
|
115
|
+
|
|
116
|
+
expect(component.height).toBe(50);
|
|
117
|
+
expect(component.width).toBe(25);
|
|
118
|
+
expect(component.top).toBe(745);
|
|
119
|
+
expect(component.left).toBe(372.5);
|
|
120
|
+
});
|
|
121
|
+
|
|
122
|
+
it('should adjust dimensions when rotation is 270deg', () => {
|
|
123
|
+
component.zoom = 0.5;
|
|
124
|
+
component.annoRect = mockRectangle;
|
|
125
|
+
component.adjustForRotation(270);
|
|
126
|
+
|
|
127
|
+
expect(component.height).toBe(25);
|
|
128
|
+
expect(component.width).toBe(50);
|
|
129
|
+
expect(component.top).toBe(772.5);
|
|
130
|
+
expect(component.left).toBe(5);
|
|
131
|
+
});
|
|
132
|
+
|
|
133
|
+
it('should emit a click', () => {
|
|
134
|
+
spyOn(component.selectEvent, 'emit');
|
|
135
|
+
component.onClick();
|
|
136
|
+
|
|
137
|
+
expect(component.selectEvent.emit).toHaveBeenCalledTimes(1);
|
|
138
|
+
});
|
|
139
|
+
|
|
140
|
+
it('should update the rectangle if moved', () => {
|
|
141
|
+
const oldLeft = rectangleEl.nativeElement.offsetLeft;
|
|
142
|
+
const oldTop = rectangleEl.nativeElement.offsetTop;
|
|
143
|
+
|
|
144
|
+
const pointerDownEvent = createPointerEvent('pointerdown', 500, 500, 500, 500);
|
|
145
|
+
const pointerMoveEvent = createPointerEvent('pointermove', 750, 750, 900, 900);
|
|
146
|
+
const pointerUpEvent = createPointerEvent('pointerup', 750, 800, 750, 800);
|
|
147
|
+
|
|
148
|
+
rectangleEl.nativeElement.dispatchEvent(pointerDownEvent);
|
|
149
|
+
rectangleEl.nativeElement.dispatchEvent(pointerMoveEvent);
|
|
150
|
+
rectangleEl.nativeElement.dispatchEvent(pointerUpEvent);
|
|
151
|
+
|
|
152
|
+
fixture.detectChanges();
|
|
153
|
+
expect(rectangleEl.nativeElement.offsetLeft).not.toEqual(oldLeft);
|
|
154
|
+
expect(rectangleEl.nativeElement.offsetTop).not.toEqual(oldTop);
|
|
155
|
+
});
|
|
156
|
+
|
|
157
|
+
it('should update the rectangle if resized', () => {
|
|
158
|
+
const oldWidth = rectangleEl.nativeElement.offsetWidth;
|
|
159
|
+
const oldHeight = rectangleEl.nativeElement.offsetHeight;
|
|
160
|
+
|
|
161
|
+
const pointerDownEvent = createPointerEvent('pointerdown', 500, 500, 500, 500);
|
|
162
|
+
const pointerMoveEvent = createPointerEvent('pointermove', 750, 750, 900, 900);
|
|
163
|
+
const pointerUpEvent = createPointerEvent('pointerup', 750, 800, 750, 800);
|
|
164
|
+
|
|
165
|
+
rectangleEl.nativeElement.dispatchEvent(new Event('pointerdown'));
|
|
166
|
+
fixture.detectChanges();
|
|
167
|
+
const bottomRightHandle = document.querySelector('.BOTTOM-RIGHT');
|
|
168
|
+
bottomRightHandle.dispatchEvent(pointerDownEvent);
|
|
169
|
+
bottomRightHandle.dispatchEvent(pointerMoveEvent);
|
|
170
|
+
bottomRightHandle.dispatchEvent(pointerUpEvent);
|
|
171
|
+
|
|
172
|
+
fixture.detectChanges();
|
|
173
|
+
expect(rectangleEl.nativeElement.offsetWidth).not.toEqual(oldWidth);
|
|
174
|
+
expect(rectangleEl.nativeElement.offsetHeight).not.toEqual(oldHeight);
|
|
175
|
+
});
|
|
176
|
+
|
|
177
|
+
it('should not update the rectangle if the rectangle did not change', () => {
|
|
178
|
+
spyOn(component.updateEvent, 'emit');
|
|
179
|
+
component.left = rectangleEl.nativeElement.offsetLeft;
|
|
180
|
+
component.top = rectangleEl.nativeElement.offsetTop;
|
|
181
|
+
component.width = rectangleEl.nativeElement.offsetWidth;
|
|
182
|
+
component.height = rectangleEl.nativeElement.offsetHeight;
|
|
183
|
+
|
|
184
|
+
const pointerDownEvent = createPointerEvent('pointerdown', 500, 500, 500, 500);
|
|
185
|
+
const pointerMoveEvent = createPointerEvent('pointermove', 500, 500, 500, 500);
|
|
186
|
+
const pointerUpEvent = createPointerEvent('pointerup', 500, 500, 500, 500);
|
|
187
|
+
|
|
188
|
+
rectangleEl.nativeElement.dispatchEvent(pointerDownEvent);
|
|
189
|
+
rectangleEl.nativeElement.dispatchEvent(pointerMoveEvent);
|
|
190
|
+
rectangleEl.nativeElement.dispatchEvent(pointerUpEvent);
|
|
191
|
+
|
|
192
|
+
fixture.detectChanges();
|
|
193
|
+
expect(rectangleEl.nativeElement.offsetLeft).toEqual(component.left);
|
|
194
|
+
expect(rectangleEl.nativeElement.offsetTop).toEqual(component.top);
|
|
195
|
+
expect(rectangleEl.nativeElement.offsetWidth).toEqual(component.width);
|
|
196
|
+
expect(rectangleEl.nativeElement.offsetHeight).toEqual(component.height);
|
|
197
|
+
expect(component.updateEvent.emit).not.toHaveBeenCalled();
|
|
198
|
+
});
|
|
199
|
+
|
|
200
|
+
it('should compare 2 rectangles values and see if its the same', () => {
|
|
201
|
+
const rect = {
|
|
202
|
+
offsetLeft: 100,
|
|
203
|
+
offsetTop: 100,
|
|
204
|
+
offsetWidth: 100,
|
|
205
|
+
offsetHeight: 100
|
|
206
|
+
};
|
|
207
|
+
let hasRectChanged = component.hasRectangleChanged(rect);
|
|
208
|
+
expect(hasRectChanged).toEqual(true);
|
|
209
|
+
|
|
210
|
+
component.top = 100;
|
|
211
|
+
component.left = 100;
|
|
212
|
+
component.height = 100;
|
|
213
|
+
component.width = 100;
|
|
214
|
+
hasRectChanged = component.hasRectangleChanged(rect);
|
|
215
|
+
expect(hasRectChanged).toEqual(false);
|
|
216
|
+
});
|
|
217
|
+
|
|
218
|
+
function createPointerEvent(typeArg: string, screenX: number, screenY: number, clientX: number, clientY: number) {
|
|
219
|
+
const pointerEvent = document.createEvent('MouseEvents');
|
|
220
|
+
pointerEvent.initMouseEvent(
|
|
221
|
+
typeArg,
|
|
222
|
+
true,
|
|
223
|
+
true,
|
|
224
|
+
window,
|
|
225
|
+
1,
|
|
226
|
+
screenX,
|
|
227
|
+
screenY,
|
|
228
|
+
clientX,
|
|
229
|
+
clientY,
|
|
230
|
+
false,
|
|
231
|
+
false,
|
|
232
|
+
false,
|
|
233
|
+
false,
|
|
234
|
+
0,
|
|
235
|
+
null
|
|
236
|
+
);
|
|
237
|
+
return pointerEvent as PointerEvent;
|
|
238
|
+
}
|
|
239
|
+
});
|
|
@@ -0,0 +1,135 @@
|
|
|
1
|
+
import {
|
|
2
|
+
AfterViewInit,
|
|
3
|
+
Component,
|
|
4
|
+
ElementRef,
|
|
5
|
+
EventEmitter,
|
|
6
|
+
Input,
|
|
7
|
+
OnChanges,
|
|
8
|
+
OnDestroy,
|
|
9
|
+
Output,
|
|
10
|
+
SimpleChanges,
|
|
11
|
+
ViewChild
|
|
12
|
+
} from '@angular/core';
|
|
13
|
+
import { Rectangle } from './rectangle.model';
|
|
14
|
+
import { Subscription } from 'rxjs';
|
|
15
|
+
import { ToolbarEventService } from '../../../../toolbar/toolbar-event.service';
|
|
16
|
+
import { HighlightCreateService } from '../../annotation-create/highlight-create/highlight-create.service';
|
|
17
|
+
|
|
18
|
+
@Component({
|
|
19
|
+
selector: 'mv-anno-rectangle',
|
|
20
|
+
templateUrl: './rectangle.component.html',
|
|
21
|
+
standalone: false
|
|
22
|
+
})
|
|
23
|
+
export class RectangleComponent implements OnChanges, AfterViewInit, OnDestroy {
|
|
24
|
+
|
|
25
|
+
@Input() color: String;
|
|
26
|
+
@Input() zoom: number;
|
|
27
|
+
@Input() rotate: number;
|
|
28
|
+
@Input() editable: boolean;
|
|
29
|
+
@Input() pageHeight: number;
|
|
30
|
+
@Input() pageWidth: number;
|
|
31
|
+
|
|
32
|
+
@Output() selectEvent = new EventEmitter<Rectangle>();
|
|
33
|
+
@Output() updateEvent = new EventEmitter<Rectangle>();
|
|
34
|
+
|
|
35
|
+
@ViewChild('rectElement', {static: false}) viewRect: ElementRef;
|
|
36
|
+
|
|
37
|
+
private subscriptions: Subscription[] = [];
|
|
38
|
+
_selected: boolean;
|
|
39
|
+
enableGrabNDrag = false;
|
|
40
|
+
|
|
41
|
+
height: number;
|
|
42
|
+
width: number;
|
|
43
|
+
top: number;
|
|
44
|
+
left: number;
|
|
45
|
+
|
|
46
|
+
_annoRect: Rectangle;
|
|
47
|
+
@Input()
|
|
48
|
+
set annoRect(annoRect: Rectangle) {
|
|
49
|
+
this._annoRect = { ...annoRect };
|
|
50
|
+
this.height = +(annoRect.height * this.zoom).toFixed(2);
|
|
51
|
+
this.width = +(annoRect.width * this.zoom).toFixed(2);
|
|
52
|
+
this.left = +(annoRect.x * this.zoom).toFixed(2);
|
|
53
|
+
this.top = +(annoRect.y * this.zoom).toFixed(2);
|
|
54
|
+
}
|
|
55
|
+
|
|
56
|
+
get annoRect() {
|
|
57
|
+
return this._annoRect;
|
|
58
|
+
}
|
|
59
|
+
|
|
60
|
+
|
|
61
|
+
constructor(private readonly toolbarEvents: ToolbarEventService,
|
|
62
|
+
private readonly highlightService: HighlightCreateService) {}
|
|
63
|
+
|
|
64
|
+
ngOnChanges(changes: SimpleChanges) {
|
|
65
|
+
if (changes.rotate) {
|
|
66
|
+
this.adjustForRotation(this.rotate);
|
|
67
|
+
}
|
|
68
|
+
}
|
|
69
|
+
|
|
70
|
+
ngAfterViewInit() {
|
|
71
|
+
this.subscriptions.push(
|
|
72
|
+
this.toolbarEvents.grabNDrag.subscribe(grabNDrag => this.enableGrabNDrag = grabNDrag)
|
|
73
|
+
);
|
|
74
|
+
}
|
|
75
|
+
|
|
76
|
+
ngOnDestroy(): void {
|
|
77
|
+
this.subscriptions.filter(subscription => !subscription.closed)
|
|
78
|
+
.forEach(subscription => subscription.unsubscribe());
|
|
79
|
+
}
|
|
80
|
+
|
|
81
|
+
@Input()
|
|
82
|
+
set selected(selected: boolean) {
|
|
83
|
+
this._selected = selected;
|
|
84
|
+
if (this._selected && this.viewRect) {
|
|
85
|
+
this.viewRect.nativeElement.focus();
|
|
86
|
+
}
|
|
87
|
+
}
|
|
88
|
+
|
|
89
|
+
get selected() {
|
|
90
|
+
return this._selected;
|
|
91
|
+
}
|
|
92
|
+
|
|
93
|
+
onClick() {
|
|
94
|
+
this.selectEvent.emit(this.annoRect);
|
|
95
|
+
}
|
|
96
|
+
|
|
97
|
+
onUpdate(viewRect: any) {
|
|
98
|
+
const { offsetHeight, offsetWidth, offsetTop, offsetLeft } = viewRect;
|
|
99
|
+
if (this.hasRectangleChanged(viewRect)) {
|
|
100
|
+
let rectangle = this.highlightService
|
|
101
|
+
.applyRotation(this.pageHeight, this.pageWidth, offsetHeight, offsetWidth, offsetTop, offsetLeft, this.rotate, this.zoom);
|
|
102
|
+
rectangle = { ...this.annoRect, ...rectangle };
|
|
103
|
+
this.updateEvent.emit({ ...rectangle });
|
|
104
|
+
}
|
|
105
|
+
}
|
|
106
|
+
|
|
107
|
+
adjustForRotation(rotation: number) {
|
|
108
|
+
const { top, left, height, width } = this;
|
|
109
|
+
switch (rotation) {
|
|
110
|
+
case 90:
|
|
111
|
+
this.width = height;
|
|
112
|
+
this.height = width;
|
|
113
|
+
this.left = this.pageWidth - top - height;
|
|
114
|
+
this.top = left;
|
|
115
|
+
break;
|
|
116
|
+
case 180:
|
|
117
|
+
this.left = this.pageWidth - left - width;
|
|
118
|
+
this.top = this.pageHeight - top - height;
|
|
119
|
+
break;
|
|
120
|
+
case 270:
|
|
121
|
+
this.width = height;
|
|
122
|
+
this.height = width;
|
|
123
|
+
this.left = top;
|
|
124
|
+
this.top = this.pageHeight - left - width;
|
|
125
|
+
break;
|
|
126
|
+
}
|
|
127
|
+
}
|
|
128
|
+
|
|
129
|
+
hasRectangleChanged(viewRect): boolean {
|
|
130
|
+
return Math.round(this.left) !== viewRect.offsetLeft ||
|
|
131
|
+
Math.round(this.top) !== viewRect.offsetTop ||
|
|
132
|
+
Math.round(this.width) !== viewRect.offsetWidth ||
|
|
133
|
+
Math.round(this.height) !== viewRect.offsetHeight;
|
|
134
|
+
}
|
|
135
|
+
}
|
|
@@ -0,0 +1,30 @@
|
|
|
1
|
+
<div class="toolbar" *ngIf="rectangle"
|
|
2
|
+
[style.top.px]="top"
|
|
3
|
+
[style.left.px]="left">
|
|
4
|
+
<button *ngIf="canHighlight"
|
|
5
|
+
type="button" title="Highlight"
|
|
6
|
+
class="aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton aui__toolbar-button-highlight"
|
|
7
|
+
(mousedown)="createHighlight()">
|
|
8
|
+
<span>Highlight</span>
|
|
9
|
+
</button>
|
|
10
|
+
<button *ngIf="canDelete"
|
|
11
|
+
type="button" title="Delete"
|
|
12
|
+
class="aui__toolbar-button aui__toolbar-button--comments contextual-btn leftButton"
|
|
13
|
+
(mousedown)="deleteHighlight()">
|
|
14
|
+
<span>Remove</span>
|
|
15
|
+
</button>
|
|
16
|
+
<button *ngIf="canComment"
|
|
17
|
+
type="button" title="Comment"
|
|
18
|
+
class="aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-comment"
|
|
19
|
+
(mousedown)="addOrEditComment()">
|
|
20
|
+
<span>Comment</span></button>
|
|
21
|
+
<button *ngIf="canBookmark"
|
|
22
|
+
type="button" title="Bookmark"
|
|
23
|
+
class="aui__toolbar-button aui__toolbar-button--comments contextual-btn rightButton aui__toolbar-button-bookmark"
|
|
24
|
+
id="bookmarkButton"
|
|
25
|
+
(mousedown)="createBookmark()">
|
|
26
|
+
<span>Bookmark</span></button>
|
|
27
|
+
<div class="arrow-down">
|
|
28
|
+
<div class="inner-triangle"></div>
|
|
29
|
+
</div>
|
|
30
|
+
</div>
|
|
@@ -0,0 +1,278 @@
|
|
|
1
|
+
import { ComponentFixture, TestBed } from '@angular/core/testing';
|
|
2
|
+
import { CtxToolbarComponent } from './ctx-toolbar.component';
|
|
3
|
+
import { By } from '@angular/platform-browser';
|
|
4
|
+
import { EventEmitter } from '@angular/core';
|
|
5
|
+
|
|
6
|
+
describe('CtxToolbarComponent', () => {
|
|
7
|
+
let component: CtxToolbarComponent;
|
|
8
|
+
let fixture: ComponentFixture<CtxToolbarComponent>;
|
|
9
|
+
const mockRectangle = {
|
|
10
|
+
x: 100, y: 100, width: 100, height: 20,
|
|
11
|
+
id: '16d5c513-15f9-4c39-8102-88bdb85d8831',
|
|
12
|
+
annotationId: '4f3f9361-6d17-4689-81dd-5cb2e317b329',
|
|
13
|
+
createdDate: '2018-05-28T08:48:33.206Z',
|
|
14
|
+
createdBy: 'ea6d959c-b6c9-48af-89c2-6f7bd796524d',
|
|
15
|
+
createdByDetails: {
|
|
16
|
+
'forename': 'Linus',
|
|
17
|
+
'surname': 'Norton',
|
|
18
|
+
'email': 'linus.norton@hmcts.net'
|
|
19
|
+
},
|
|
20
|
+
lastModifiedDate: '2019-05-28T08:48:33.206Z',
|
|
21
|
+
lastModifiedBy: 'ea6d959c-b6c9-48af-89c2-6f7bd796524d',
|
|
22
|
+
lastModifiedByDetails: {
|
|
23
|
+
'forename': 'Jeroen',
|
|
24
|
+
'surname': 'Rijks',
|
|
25
|
+
'email': 'jeroen.rijks@hmcts.net'
|
|
26
|
+
},
|
|
27
|
+
};
|
|
28
|
+
|
|
29
|
+
beforeEach(() => {
|
|
30
|
+
TestBed.configureTestingModule({
|
|
31
|
+
declarations: [CtxToolbarComponent]
|
|
32
|
+
})
|
|
33
|
+
.compileComponents();
|
|
34
|
+
|
|
35
|
+
fixture = TestBed.createComponent(CtxToolbarComponent);
|
|
36
|
+
component = fixture.componentInstance;
|
|
37
|
+
component.rectangles = [mockRectangle];
|
|
38
|
+
component.zoom = 1;
|
|
39
|
+
component.ngOnChanges({ zoom: { previousValue: undefined, currentValue: 1, firstChange: true, isFirstChange: () => true }});
|
|
40
|
+
|
|
41
|
+
fixture.detectChanges();
|
|
42
|
+
});
|
|
43
|
+
|
|
44
|
+
afterEach(() => {
|
|
45
|
+
if (component.rectangle) {
|
|
46
|
+
component.rectangle.x = 100;
|
|
47
|
+
component.rectangle.y = 100;
|
|
48
|
+
}
|
|
49
|
+
});
|
|
50
|
+
|
|
51
|
+
it('should create', () => {
|
|
52
|
+
expect(component).toBeTruthy();
|
|
53
|
+
});
|
|
54
|
+
|
|
55
|
+
it('should set rectangle', () => {
|
|
56
|
+
const rectangles = [{ y: 10 }, { y: 20 }] as any;
|
|
57
|
+
component.rectangles = rectangles;
|
|
58
|
+
|
|
59
|
+
expect(component._rectangles).toEqual(rectangles);
|
|
60
|
+
expect(component.rectangle).toEqual({ y: 10 } as any);
|
|
61
|
+
});
|
|
62
|
+
|
|
63
|
+
it('should create highlight', function () {
|
|
64
|
+
spyOn(component.createHighlightEvent, 'emit');
|
|
65
|
+
component.rectangle = { id: 'rectId' } as any;
|
|
66
|
+
|
|
67
|
+
component.createHighlight();
|
|
68
|
+
|
|
69
|
+
expect(component.createHighlightEvent.emit).toHaveBeenCalled();
|
|
70
|
+
expect(component.rectangle).toBeUndefined();
|
|
71
|
+
});
|
|
72
|
+
|
|
73
|
+
it('should delete highlight', () => {
|
|
74
|
+
const mockDeleteEvent = new EventEmitter();
|
|
75
|
+
spyOn(mockDeleteEvent, 'emit');
|
|
76
|
+
component.canDelete = true;
|
|
77
|
+
fixture.detectChanges();
|
|
78
|
+
|
|
79
|
+
component.deleteHighlightEvent = mockDeleteEvent;
|
|
80
|
+
const deleteBtn = fixture.debugElement.query(By.css('button[title=Delete]'));
|
|
81
|
+
deleteBtn.triggerEventHandler('mousedown', {});
|
|
82
|
+
|
|
83
|
+
expect(mockDeleteEvent.emit).toHaveBeenCalledWith();
|
|
84
|
+
});
|
|
85
|
+
|
|
86
|
+
it('should create comment', () => {
|
|
87
|
+
const mockCommentEvent = new EventEmitter();
|
|
88
|
+
spyOn(mockCommentEvent, 'emit');
|
|
89
|
+
component.canComment = true;
|
|
90
|
+
fixture.detectChanges();
|
|
91
|
+
|
|
92
|
+
component.addOrEditCommentEvent = mockCommentEvent;
|
|
93
|
+
const commentBtn = fixture.debugElement.query(By.css('button[title=Comment]'));
|
|
94
|
+
commentBtn.triggerEventHandler('mousedown', {});
|
|
95
|
+
|
|
96
|
+
expect(mockCommentEvent.emit).toHaveBeenCalledWith();
|
|
97
|
+
});
|
|
98
|
+
|
|
99
|
+
it('adjust its position', () => {
|
|
100
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
101
|
+
expect(element.styles.left).toEqual('0px');
|
|
102
|
+
expect(element.styles.top).toEqual('30px');
|
|
103
|
+
});
|
|
104
|
+
|
|
105
|
+
it('rotate 90 should align to top and horizontally with highlight', () => {
|
|
106
|
+
component.rotate = 90;
|
|
107
|
+
fixture.detectChanges();
|
|
108
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
109
|
+
expect(element.styles.left).toEqual('0px');
|
|
110
|
+
expect(element.styles.top).toEqual('30px');
|
|
111
|
+
});
|
|
112
|
+
|
|
113
|
+
it('rotate 180 should align to left and horizontally with highlight (accounting for highlight dimensions)', () => {
|
|
114
|
+
component.rotate = 180;
|
|
115
|
+
fixture.detectChanges();
|
|
116
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
117
|
+
expect(element.styles.left).toEqual('0px');
|
|
118
|
+
expect(element.styles.top).toEqual('30px');
|
|
119
|
+
});
|
|
120
|
+
|
|
121
|
+
it('rotate 270 should align to bottom and horizontally with highlight (accounting for highlight dimensions)', () => {
|
|
122
|
+
component.rotate = 270;
|
|
123
|
+
fixture.detectChanges();
|
|
124
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
125
|
+
expect(element.styles.left).toEqual('0px');
|
|
126
|
+
expect(element.styles.top).toEqual('30px');
|
|
127
|
+
});
|
|
128
|
+
|
|
129
|
+
it('top should default to 30px when annotation is at the top of the page', () => {
|
|
130
|
+
component.rotate = 0;
|
|
131
|
+
component.rectangle.y = 0;
|
|
132
|
+
fixture.detectChanges();
|
|
133
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
134
|
+
expect(element.styles.top).toEqual('30px');
|
|
135
|
+
});
|
|
136
|
+
|
|
137
|
+
it('rotate 90 should set top to calculated value when pop-up is not at the edge of the page', () => {
|
|
138
|
+
component.rotate = 90;
|
|
139
|
+
component.rectangle.y = 200;
|
|
140
|
+
fixture.detectChanges();
|
|
141
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
142
|
+
expect(element.styles.top).toEqual('30px');
|
|
143
|
+
});
|
|
144
|
+
|
|
145
|
+
it('rotate 90 should align top to the height of the page when annotation is at far left of page', () => {
|
|
146
|
+
component.rotate = 90;
|
|
147
|
+
component.rectangle.y = 600;
|
|
148
|
+
component.pageHeight = 750;
|
|
149
|
+
fixture.detectChanges();
|
|
150
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
151
|
+
expect(element.styles.top).toEqual('30px');
|
|
152
|
+
});
|
|
153
|
+
|
|
154
|
+
it('rotate 270 should set top to calculated value when pop-up is not at the edge of the page', () => {
|
|
155
|
+
component.rotate = 270;
|
|
156
|
+
component.rectangle.y = 250;
|
|
157
|
+
fixture.detectChanges();
|
|
158
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
159
|
+
expect(element.styles.top).toEqual('30px');
|
|
160
|
+
});
|
|
161
|
+
|
|
162
|
+
it('rotate 270 should align top to 30px when annotation is at the far right of the page', () => {
|
|
163
|
+
component.rotate = 270;
|
|
164
|
+
component.rectangle.y = 900;
|
|
165
|
+
fixture.detectChanges();
|
|
166
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
167
|
+
expect(element.styles.top).toEqual('30px');
|
|
168
|
+
});
|
|
169
|
+
|
|
170
|
+
it('left should default to 0px when annotation is at the far left of the page', () => {
|
|
171
|
+
component.rotate = 0;
|
|
172
|
+
component.rectangle.x = 0;
|
|
173
|
+
fixture.detectChanges();
|
|
174
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
175
|
+
expect(element.styles.left).toEqual('0px');
|
|
176
|
+
});
|
|
177
|
+
|
|
178
|
+
it('left should default to 0px when annotation is at the far right of the page', () => {
|
|
179
|
+
component.rotate = 0;
|
|
180
|
+
component.rectangle.x = 600;
|
|
181
|
+
fixture.detectChanges();
|
|
182
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
183
|
+
expect(element.styles.left).toEqual('0px');
|
|
184
|
+
});
|
|
185
|
+
|
|
186
|
+
it('left should be set to calculated value when pop-up is not at the edge of the page', () => {
|
|
187
|
+
component.rotate = 0;
|
|
188
|
+
component.rectangle.x = 250;
|
|
189
|
+
fixture.detectChanges();
|
|
190
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
191
|
+
expect(element.styles.left).toEqual('0px');
|
|
192
|
+
});
|
|
193
|
+
|
|
194
|
+
it('rotate 180 should align left to width - defaultWidth when annotation is at the far left of the page', () => {
|
|
195
|
+
component.rotate = 180;
|
|
196
|
+
component.rectangle.x = 750;
|
|
197
|
+
component.pageWidth = 350;
|
|
198
|
+
fixture.detectChanges();
|
|
199
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
200
|
+
expect(element.styles.left).toEqual('0px');
|
|
201
|
+
});
|
|
202
|
+
|
|
203
|
+
it('rotate 180 should set left to calculated value when pop-up is not at the edge of the page', () => {
|
|
204
|
+
component.rotate = 180;
|
|
205
|
+
component.rectangle.x = 250;
|
|
206
|
+
|
|
207
|
+
fixture.detectChanges();
|
|
208
|
+
const element = fixture.debugElement.query(By.css('div'));
|
|
209
|
+
|
|
210
|
+
expect(element.styles.left).toEqual('0px');
|
|
211
|
+
});
|
|
212
|
+
|
|
213
|
+
describe('rectangles', () => {
|
|
214
|
+
it('should call setRectangle, popupTop and popupLeft when rectangles provided', () => {
|
|
215
|
+
spyOn(component, 'setRectangle').and.callThrough();
|
|
216
|
+
|
|
217
|
+
component.rectangles = [mockRectangle];
|
|
218
|
+
fixture.detectChanges();
|
|
219
|
+
|
|
220
|
+
expect(component.setRectangle).toHaveBeenCalled();
|
|
221
|
+
});
|
|
222
|
+
|
|
223
|
+
it('should not call setRectangle, popupTop and popupLeft when rectangles is not provided', () => {
|
|
224
|
+
spyOn(component, 'setRectangle').and.callThrough();
|
|
225
|
+
spyOn(component, 'popupTop').and.callThrough();
|
|
226
|
+
spyOn(component, 'popupLeft').and.callThrough();
|
|
227
|
+
|
|
228
|
+
component.rectangles = null;
|
|
229
|
+
fixture.detectChanges();
|
|
230
|
+
|
|
231
|
+
expect(component.setRectangle).not.toHaveBeenCalled();
|
|
232
|
+
expect(component.popupTop).not.toHaveBeenCalled();
|
|
233
|
+
expect(component.popupLeft).not.toHaveBeenCalled();
|
|
234
|
+
});
|
|
235
|
+
});
|
|
236
|
+
|
|
237
|
+
it('should emit an event when createBookmark called', () => {
|
|
238
|
+
component.rectangle = mockRectangle;
|
|
239
|
+
fixture.detectChanges();
|
|
240
|
+
|
|
241
|
+
spyOn(component.createBookmarkEvent, 'emit').and.callThrough();
|
|
242
|
+
component.createBookmark();
|
|
243
|
+
|
|
244
|
+
expect(component.createBookmarkEvent.emit).toHaveBeenCalledWith(mockRectangle);
|
|
245
|
+
expect(component.rectangle).toBeUndefined();
|
|
246
|
+
});
|
|
247
|
+
|
|
248
|
+
describe('setRectangle', () => {
|
|
249
|
+
beforeEach(() => {
|
|
250
|
+
component.pageWidth = 300;
|
|
251
|
+
component.pageHeight = 200;
|
|
252
|
+
});
|
|
253
|
+
|
|
254
|
+
[
|
|
255
|
+
{ rotate: 90, zoom: 1, rectangle: { x: 180, y: 100, width: 20, height: 100 } },
|
|
256
|
+
{ rotate: 90, zoom: 2, rectangle: { x: 30, y: 100, width: 20, height: 100 } },
|
|
257
|
+
{ rotate: 180, zoom: 1, rectangle: { x: 100, y: 80, width: 100, height: 20 } },
|
|
258
|
+
{ rotate: 180, zoom: 2, rectangle: { x: -50, y: -20, width: 100, height: 20 } },
|
|
259
|
+
{ rotate: 270, zoom: 1, rectangle: { x: 100, y: 0, width: 20, height: 100 } },
|
|
260
|
+
{ rotate: 270, zoom: 2, rectangle: { x: 100, y: -100, width: 20, height: 100 } }
|
|
261
|
+
]
|
|
262
|
+
.forEach((take: {rotate: number, zoom: number, rectangle: { x: number, y: number, width: number, height: number}}) => {
|
|
263
|
+
it(`should update the rectangle when rotate ${take.rotate}deg, zoom = ${take.zoom}`, () => {
|
|
264
|
+
component.rotate = take.rotate;
|
|
265
|
+
component.zoom = take.zoom;
|
|
266
|
+
fixture.detectChanges();
|
|
267
|
+
|
|
268
|
+
component.setRectangle();
|
|
269
|
+
|
|
270
|
+
expect(component.rectangle.x).toEqual(take.rectangle.x);
|
|
271
|
+
expect(component.rectangle.y).toEqual(take.rectangle.y);
|
|
272
|
+
expect(component.rectangle.width).toEqual(take.rectangle.width);
|
|
273
|
+
expect(component.rectangle.height).toEqual(take.rectangle.height);
|
|
274
|
+
});
|
|
275
|
+
}
|
|
276
|
+
);
|
|
277
|
+
});
|
|
278
|
+
});
|