mediasfu-angular 1.0.1 → 2.0.0
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/README.md +871 -769
- package/dist/README.md +870 -769
- package/dist/fesm2022/mediasfu-angular.mjs +13241 -3372
- package/dist/fesm2022/mediasfu-angular.mjs.map +1 -1
- package/dist/lib/@types/types.d.ts +22 -1
- package/dist/lib/components/background-components/background-modal/background-modal.component.d.ts +36 -0
- package/dist/lib/components/breakout-components/breakout-rooms-modal.component.d.ts +51 -0
- package/dist/lib/components/breakout-components/edit-room-modal/edit-room-modal.component.d.ts +48 -0
- package/dist/lib/components/co-host-components/co-host-modal/co-host-modal.component.d.ts +62 -0
- package/dist/lib/components/display-components/alert-component/alert.component.component.d.ts +24 -18
- package/dist/lib/components/display-components/audio-card/audio-card.component.d.ts +59 -0
- package/dist/lib/components/display-components/audio-grid/audio-grid.component.d.ts +20 -0
- package/dist/lib/components/display-components/card-video-display/card-video-display.component.d.ts +35 -0
- package/dist/lib/components/display-components/control-buttons-alt-component/control-buttons-alt-component.component.d.ts +38 -0
- package/dist/lib/components/display-components/control-buttons-component-touch/control-buttons-component-touch.component.d.ts +24 -40
- package/dist/lib/components/display-components/control-widgets/menu-participants-widget.component.d.ts +21 -0
- package/dist/lib/components/display-components/control-widgets/menu-record-widget.component.d.ts +22 -0
- package/dist/lib/components/display-components/control-widgets/menu-widget.component.d.ts +23 -0
- package/dist/lib/components/display-components/control-widgets/message-widget.component.d.ts +23 -0
- package/dist/lib/components/display-components/control-widgets/record-timer-widget.component.d.ts +15 -0
- package/dist/lib/components/display-components/control-widgets/screenshare-widget.component.d.ts +27 -0
- package/dist/lib/components/display-components/flexible-grid/flexible-grid.component.d.ts +27 -18
- package/dist/lib/components/display-components/flexible-video/flexible-video.component.d.ts +30 -45
- package/dist/lib/components/display-components/loading-modal/loading-modal.component.d.ts +19 -17
- package/dist/lib/components/display-components/main-aspect-component/main-aspect-component.component.d.ts +32 -24
- package/dist/lib/components/display-components/main-container-component/main-container-component.component.d.ts +28 -16
- package/dist/lib/components/display-components/main-grid-component/main-grid-component.component.d.ts +28 -14
- package/dist/lib/components/display-components/main-screen-component/main-screen-component.component.d.ts +43 -22
- package/dist/lib/components/display-components/meeting-progress-timer/meeting-progress-timer.component.d.ts +25 -30
- package/dist/lib/components/display-components/mini-audio/mini-audio.component.d.ts +55 -62
- package/dist/lib/components/display-components/mini-card/mini-card.component.d.ts +19 -23
- package/dist/lib/components/display-components/mini-card-audio/mini-card-audio.component.d.ts +39 -39
- package/dist/lib/components/display-components/other-grid-component/other-grid-component.component.d.ts +28 -13
- package/dist/lib/components/display-components/pagination/pagination.component.d.ts +29 -23
- package/dist/lib/components/display-components/sub-aspect-component/sub-aspect-component.component.d.ts +18 -24
- package/dist/lib/components/display-components/video-card/video-card.component.d.ts +62 -0
- package/dist/lib/components/display-settings-components/display-settings-modal.component.d.ts +28 -17
- package/dist/lib/components/event-settings-components/event-settings-modal/event-settings-modal.component.d.ts +47 -38
- package/dist/lib/components/exit-components/confirm-exit-modal/confirm-exit-modal.component.d.ts +35 -22
- package/dist/lib/components/media-settings-components/media-settings-modal/media-settings-modal.component.d.ts +35 -24
- package/dist/lib/components/mediasfu-components/mediasfu-broadcast.component.d.ts +258 -117
- package/dist/lib/components/mediasfu-components/mediasfu-chat.component.d.ts +254 -117
- package/dist/lib/components/mediasfu-components/mediasfu-conference.component.d.ts +312 -162
- package/dist/lib/components/mediasfu-components/mediasfu-generic.component.d.ts +312 -162
- package/dist/lib/components/mediasfu-components/mediasfu-webinar.component.d.ts +310 -162
- package/dist/lib/components/menu-components/custom-buttons/custom-buttons.component.d.ts +49 -51
- package/dist/lib/components/menu-components/meeting-id-component/meeting-id-component.component.d.ts +6 -1
- package/dist/lib/components/menu-components/meeting-passcode-component/meeting-passcode-component.component.d.ts +5 -0
- package/dist/lib/components/menu-components/menu-modal/menu-modal.component.d.ts +27 -29
- package/dist/lib/components/menu-components/share-buttons-component/share-buttons-component.component.d.ts +20 -15
- package/dist/lib/components/message-components/message-panel/message-panel.component.d.ts +24 -0
- package/dist/lib/components/message-components/messages-modal/messages-modal.component.d.ts +34 -0
- package/dist/lib/components/misc-components/confirm-here-modal/confirm-here-modal.component.d.ts +20 -35
- package/dist/lib/components/misc-components/pre-join-page/pre-join-page.component.d.ts +79 -66
- package/dist/lib/components/misc-components/share-event-modal/share-event-modal.component.d.ts +19 -1
- package/dist/lib/components/misc-components/welcome-page/welcome-page.component.d.ts +15 -0
- package/dist/lib/components/participants-components/participant-list/participant-list.component.d.ts +19 -0
- package/dist/lib/components/participants-components/participant-list-item/participant-list-item.component.d.ts +19 -0
- package/dist/lib/components/participants-components/participant-list-others/participant-list-others.component.d.ts +17 -0
- package/dist/lib/components/participants-components/participant-list-others-item/participant-list-others-item.component.d.ts +17 -0
- package/dist/lib/components/participants-components/participants-modal/participants-modal.component.d.ts +24 -0
- package/dist/lib/components/polls-components/poll-modal/poll-modal.component.d.ts +27 -0
- package/dist/lib/components/recording-components/advanced-panel-component/advanced-panel-components.component.d.ts +15 -0
- package/dist/lib/components/recording-components/recording-modal/recording-modal.component.d.ts +12 -0
- package/dist/lib/components/recording-components/standard-panel-component/standard-panel-component.component.d.ts +5 -0
- package/dist/lib/components/requests-components/render-request-component/render-request-component.component.d.ts +22 -0
- package/dist/lib/components/requests-components/requests-modal/requests-modal.component.d.ts +17 -0
- package/dist/lib/components/screenboard-components/screenboard/screenboard.component.d.ts +10 -0
- package/dist/lib/components/screenboard-components/screenboard-modal/screenboard-modal.component.d.ts +11 -0
- package/dist/lib/components/waiting-components/waiting-room-modal.component.d.ts +59 -0
- package/dist/lib/components/whiteboard-components/configure-whiteboard-modal/configure-whiteboard-modal.component.d.ts +21 -0
- package/dist/lib/components/whiteboard-components/whiteboard/whiteboard.component.d.ts +49 -0
- package/dist/lib/consumers/add-videos-grid.service.d.ts +49 -0
- package/dist/lib/consumers/auto-adjust.service.d.ts +26 -0
- package/dist/lib/consumers/calculate-rows-and-columns.service.d.ts +18 -0
- package/dist/lib/consumers/change-vids.service.d.ts +131 -66
- package/dist/lib/consumers/check-grid.service.d.ts +32 -18
- package/dist/lib/consumers/check-permission.service.d.ts +25 -0
- package/dist/lib/consumers/check-screen-share.service.d.ts +35 -0
- package/dist/lib/consumers/close-and-resize.service.d.ts +102 -0
- package/dist/lib/consumers/compare-active-names.service.d.ts +31 -0
- package/dist/lib/consumers/compare-screen-states.service.d.ts +35 -0
- package/dist/lib/consumers/connect-ips.service.d.ts +42 -0
- package/dist/lib/consumers/connect-local-ips.service.d.ts +81 -0
- package/dist/lib/consumers/connect-recv-transport.service.d.ts +33 -0
- package/dist/lib/consumers/connect-send-transport-audio.service.d.ts +81 -11
- package/dist/lib/consumers/connect-send-transport-screen.service.d.ts +96 -15
- package/dist/lib/consumers/connect-send-transport-video.service.d.ts +101 -11
- package/dist/lib/consumers/connect-send-transport.service.d.ts +59 -1
- package/dist/lib/consumers/consumer-resume.service.d.ts +36 -0
- package/dist/lib/consumers/control-media.service.d.ts +45 -0
- package/dist/lib/consumers/create-send-transport.service.d.ts +149 -13
- package/dist/lib/consumers/disconnect-send-transport-audio.service.d.ts +100 -13
- package/dist/lib/consumers/disconnect-send-transport-screen.service.d.ts +75 -2
- package/dist/lib/consumers/disconnect-send-transport-video.service.d.ts +99 -17
- package/dist/lib/consumers/disp-streams.service.d.ts +92 -0
- package/dist/lib/consumers/generate-page-content.service.d.ts +47 -0
- package/dist/lib/consumers/get-estimate.service.d.ts +50 -0
- package/dist/lib/consumers/get-piped-producers-alt.service.d.ts +38 -1
- package/dist/lib/consumers/get-producers-piped.service.d.ts +33 -0
- package/dist/lib/consumers/get-videos.service.d.ts +33 -0
- package/dist/lib/consumers/mix-streams.service.d.ts +22 -0
- package/dist/lib/consumers/on-screen-changes.service.d.ts +40 -0
- package/dist/lib/consumers/prepopulate-user-media.service.d.ts +99 -0
- package/dist/lib/consumers/process-consumer-transports-audio.service.d.ts +29 -0
- package/dist/lib/consumers/process-consumer-transports.service.d.ts +37 -0
- package/dist/lib/consumers/re-port.service.d.ts +48 -0
- package/dist/lib/consumers/re-update-inter.service.d.ts +82 -0
- package/dist/lib/consumers/readjust.service.d.ts +50 -0
- package/dist/lib/consumers/receive-all-piped-transports.service.d.ts +36 -1
- package/dist/lib/consumers/receive-room-messages.service.d.ts +27 -0
- package/dist/lib/consumers/reorder-streams.service.d.ts +58 -0
- package/dist/lib/consumers/request-screen-share.service.d.ts +34 -0
- package/dist/lib/consumers/resume-pause-audio-streams.service.d.ts +51 -0
- package/dist/lib/consumers/resume-pause-streams.service.d.ts +33 -0
- package/dist/lib/consumers/resume-send-transport-audio.service.d.ts +76 -7
- package/dist/lib/consumers/signal-new-consumer-transport.service.d.ts +37 -37
- package/dist/lib/consumers/socket-receive-methods/join-consume-room.service.d.ts +33 -0
- package/dist/lib/consumers/socket-receive-methods/new-pipe-producer.service.d.ts +39 -0
- package/dist/lib/consumers/socket-receive-methods/producer-closed.service.d.ts +27 -0
- package/dist/lib/consumers/start-share-screen.service.d.ts +40 -0
- package/dist/lib/consumers/stop-share-screen.service.d.ts +55 -0
- package/dist/lib/consumers/stream-success-audio-switch.service.d.ts +148 -11
- package/dist/lib/consumers/stream-success-audio.service.d.ts +61 -0
- package/dist/lib/consumers/stream-success-screen.service.d.ts +50 -0
- package/dist/lib/consumers/stream-success-video.service.d.ts +58 -0
- package/dist/lib/consumers/switch-user-audio.service.d.ts +33 -0
- package/dist/lib/consumers/switch-user-video-alt.service.d.ts +32 -0
- package/dist/lib/consumers/switch-user-video.service.d.ts +47 -0
- package/dist/lib/consumers/trigger.service.d.ts +41 -0
- package/dist/lib/consumers/update-mini-cards-grid.service.d.ts +54 -0
- package/dist/lib/consumers/update-participant-audio-decibels.service.d.ts +45 -0
- package/dist/lib/methods/background-methods/launch-background.service.d.ts +25 -0
- package/dist/lib/methods/breakout-room-methods/breakout-room-updated.service.d.ts +71 -0
- package/dist/lib/methods/breakout-room-methods/launch-breakout-rooms.service.d.ts +24 -0
- package/dist/lib/methods/co-host-methods/launch-co-host.service.d.ts +24 -0
- package/dist/lib/methods/co-host-methods/modify-co-host-settings.service.d.ts +44 -0
- package/dist/lib/methods/display-settings-methods/launch-display-settings.service.d.ts +22 -0
- package/dist/lib/methods/display-settings-methods/modify-display-settings.service.d.ts +75 -0
- package/dist/lib/methods/exit-methods/confirm-exit.service.d.ts +29 -1
- package/dist/lib/methods/exit-methods/launch-confirm-exit.service.d.ts +20 -0
- package/dist/lib/methods/media-settings-methods/launch-media-settings.service.d.ts +35 -0
- package/dist/lib/methods/menu-methods/launch-menu-modal.service.d.ts +22 -0
- package/dist/lib/methods/message-methods/launch-messages.service.d.ts +22 -0
- package/dist/lib/methods/message-methods/send-message.service.d.ts +49 -0
- package/dist/lib/methods/participants-methods/launch-participants.service.d.ts +24 -0
- package/dist/lib/methods/participants-methods/message-participants.service.d.ts +46 -0
- package/dist/lib/methods/participants-methods/mute-participants.service.d.ts +39 -0
- package/dist/lib/methods/participants-methods/remove-participants.service.d.ts +45 -0
- package/dist/lib/methods/polls-methods/handle-create-poll.service.d.ts +38 -0
- package/dist/lib/methods/polls-methods/handle-end-poll.service.d.ts +32 -0
- package/dist/lib/methods/polls-methods/handle-vote-poll.service.d.ts +34 -0
- package/dist/lib/methods/polls-methods/launch-poll.service.d.ts +20 -0
- package/dist/lib/methods/polls-methods/poll-updated.service.d.ts +31 -0
- package/dist/lib/methods/recording-methods/check-pause-state.service.d.ts +24 -0
- package/dist/lib/methods/recording-methods/check-resume-state.service.d.ts +22 -0
- package/dist/lib/methods/recording-methods/confirm-recording.service.d.ts +63 -0
- package/dist/lib/methods/recording-methods/launch-recording.service.d.ts +43 -0
- package/dist/lib/methods/recording-methods/record-pause-timer.service.d.ts +27 -0
- package/dist/lib/methods/recording-methods/record-resume-timer.service.d.ts +44 -0
- package/dist/lib/methods/recording-methods/record-start-timer.service.d.ts +45 -0
- package/dist/lib/methods/recording-methods/record-update-timer.service.d.ts +32 -0
- package/dist/lib/methods/recording-methods/start-recording.service.d.ts +53 -0
- package/dist/lib/methods/recording-methods/stop-recording.service.d.ts +42 -1
- package/dist/lib/methods/recording-methods/update-recording.service.d.ts +51 -0
- package/dist/lib/methods/requests-methods/launch-requests.service.d.ts +25 -0
- package/dist/lib/methods/requests-methods/respond-to-requests.service.d.ts +39 -0
- package/dist/lib/methods/settings-methods/launch-settings.service.d.ts +25 -0
- package/dist/lib/methods/settings-methods/modify-settings.service.d.ts +42 -0
- package/dist/lib/methods/stream-methods/click-audio.service.d.ts +100 -0
- package/dist/lib/methods/stream-methods/click-chat.service.d.ts +31 -0
- package/dist/lib/methods/stream-methods/click-screen-share.service.d.ts +68 -0
- package/dist/lib/methods/stream-methods/click-video.service.d.ts +88 -0
- package/dist/lib/methods/stream-methods/switch-audio.service.d.ts +47 -0
- package/dist/lib/methods/stream-methods/switch-video-alt.service.d.ts +50 -0
- package/dist/lib/methods/stream-methods/switch-video.service.d.ts +56 -0
- package/dist/lib/methods/utils/check-limits-and-make-request.service.d.ts +23 -0
- package/dist/lib/methods/utils/create-response-join-room.util.d.ts +33 -0
- package/dist/lib/methods/utils/create-room-on-media-sfu.service.d.ts +25 -0
- package/dist/lib/methods/utils/format-number.service.d.ts +26 -14
- package/dist/lib/methods/utils/generate-random-messages.service.d.ts +33 -0
- package/dist/lib/methods/utils/generate-random-participants.service.d.ts +27 -0
- package/dist/lib/methods/utils/generate-random-polls.service.d.ts +26 -0
- package/dist/lib/methods/utils/generate-random-request-list.service.d.ts +36 -0
- package/dist/lib/methods/utils/generate-random-waiting-room-list.service.d.ts +21 -0
- package/dist/lib/methods/utils/get-modal-position.util.d.ts +13 -3
- package/dist/lib/methods/utils/get-overlay-position.util.d.ts +13 -3
- package/dist/lib/methods/utils/initial-values.util.d.ts +6 -0
- package/dist/lib/methods/utils/join-room-on-media-sfu.service.d.ts +52 -0
- package/dist/lib/methods/utils/meeting-timer/start-meeting-progress-timer.service.d.ts +37 -0
- package/dist/lib/methods/utils/mini-audio-player/mini-audio-player.component.d.ts +55 -0
- package/dist/lib/methods/utils/producer/a-params.service.d.ts +37 -0
- package/dist/lib/methods/utils/producer/h-params.service.d.ts +50 -0
- package/dist/lib/methods/utils/producer/screen-params.service.d.ts +37 -0
- package/dist/lib/methods/utils/producer/v-params.service.d.ts +50 -0
- package/dist/lib/methods/utils/producer/video-capture-constraints.service.d.ts +46 -0
- package/dist/lib/methods/utils/sleep.util.d.ts +9 -3
- package/dist/lib/methods/utils/sound-player.service.d.ts +21 -0
- package/dist/lib/methods/utils/validate-alphanumeric.service.d.ts +16 -0
- package/dist/lib/methods/waiting-methods/launch-waiting.service.d.ts +18 -0
- package/dist/lib/methods/waiting-methods/respond-to-waiting.service.d.ts +29 -0
- package/dist/lib/methods/whiteboard-methods/capture-canvas-stream.service.d.ts +46 -0
- package/dist/lib/methods/whiteboard-methods/launch-configure-whiteboard.service.d.ts +20 -0
- package/dist/lib/producer-client/producer-client-emits/create-device-client.service.d.ts +23 -0
- package/dist/lib/producer-client/producer-client-emits/join-room-client.service.d.ts +31 -0
- package/dist/lib/producer-client/producer-client-emits/update-room-parameters-client.service.d.ts +44 -0
- package/dist/lib/producers/producer-emits/join-con-room.service.d.ts +38 -0
- package/dist/lib/producers/producer-emits/join-local-room.service.d.ts +125 -0
- package/dist/lib/producers/producer-emits/join-room.service.d.ts +38 -0
- package/dist/lib/producers/socket-receive-methods/all-members-rest.service.d.ts +80 -2
- package/dist/lib/producers/socket-receive-methods/all-members.service.d.ts +78 -2
- package/dist/lib/producers/socket-receive-methods/all-waiting-room-members.service.d.ts +27 -0
- package/dist/lib/producers/socket-receive-methods/ban-participant.service.d.ts +36 -0
- package/dist/lib/producers/socket-receive-methods/control-media-host.service.d.ts +37 -0
- package/dist/lib/producers/socket-receive-methods/disconnect-user-self.service.d.ts +29 -1
- package/dist/lib/producers/socket-receive-methods/disconnect.service.d.ts +26 -0
- package/dist/lib/producers/socket-receive-methods/get-domains.service.d.ts +24 -9
- package/dist/lib/producers/socket-receive-methods/host-request-response.service.d.ts +31 -48
- package/dist/lib/producers/socket-receive-methods/meeting-ended.service.d.ts +29 -0
- package/dist/lib/producers/socket-receive-methods/meeting-still-there.service.d.ts +23 -0
- package/dist/lib/producers/socket-receive-methods/meeting-time-remaining.service.d.ts +27 -0
- package/dist/lib/producers/socket-receive-methods/participant-requested.service.d.ts +31 -0
- package/dist/lib/producers/socket-receive-methods/person-joined.service.d.ts +25 -0
- package/dist/lib/producers/socket-receive-methods/producer-media-closed.service.d.ts +61 -0
- package/dist/lib/producers/socket-receive-methods/producer-media-paused.service.d.ts +62 -0
- package/dist/lib/producers/socket-receive-methods/producer-media-resumed.service.d.ts +45 -0
- package/dist/lib/producers/socket-receive-methods/re-initiate-recording.service.d.ts +29 -0
- package/dist/lib/producers/socket-receive-methods/receive-message.service.d.ts +38 -0
- package/dist/lib/producers/socket-receive-methods/recording-notice.service.d.ts +38 -0
- package/dist/lib/producers/socket-receive-methods/room-record-params.service.d.ts +62 -0
- package/dist/lib/producers/socket-receive-methods/screen-producer-id.service.d.ts +41 -0
- package/dist/lib/producers/socket-receive-methods/start-records.service.d.ts +25 -0
- package/dist/lib/producers/socket-receive-methods/stopped-recording.service.d.ts +25 -0
- package/dist/lib/producers/socket-receive-methods/time-left-recording.service.d.ts +21 -0
- package/dist/lib/producers/socket-receive-methods/update-consuming-domains.service.d.ts +42 -0
- package/dist/lib/producers/socket-receive-methods/update-media-settings.service.d.ts +30 -0
- package/dist/lib/producers/socket-receive-methods/updated-co-host.service.d.ts +40 -0
- package/dist/lib/producers/socket-receive-methods/user-waiting.service.d.ts +14 -40
- package/dist/lib/sockets/socket-manager.service.d.ts +130 -0
- package/dist/public-api.d.ts +11 -1
- package/package.json +17 -20
- package/dist/esm2022/lib/@types/types.mjs +0 -2
- package/dist/esm2022/lib/components/background-components/background-modal/background-modal.component.mjs +0 -763
- package/dist/esm2022/lib/components/breakout-components/breakout-rooms-modal.component.mjs +0 -316
- package/dist/esm2022/lib/components/breakout-components/edit-room-modal/edit-room-modal.component.mjs +0 -95
- package/dist/esm2022/lib/components/breakout-components/room-list/room-list.component.mjs +0 -40
- package/dist/esm2022/lib/components/co-host-components/co-host-modal/co-host-modal.component.mjs +0 -246
- package/dist/esm2022/lib/components/display-components/alert-component/alert.component.component.mjs +0 -73
- package/dist/esm2022/lib/components/display-components/audio-card/audio-card.component.mjs +0 -297
- package/dist/esm2022/lib/components/display-components/audio-grid/audio-grid.component.mjs +0 -60
- package/dist/esm2022/lib/components/display-components/card-video-display/card-video-display.component.mjs +0 -94
- package/dist/esm2022/lib/components/display-components/control-buttons-alt-component/control-buttons-alt-component.component.mjs +0 -100
- package/dist/esm2022/lib/components/display-components/control-buttons-component/control-buttons-component.component.mjs +0 -231
- package/dist/esm2022/lib/components/display-components/control-buttons-component-touch/control-buttons-component-touch.component.mjs +0 -298
- package/dist/esm2022/lib/components/display-components/control-widgets/menu-participants-widget.component.mjs +0 -61
- package/dist/esm2022/lib/components/display-components/control-widgets/menu-record-widget.component.mjs +0 -43
- package/dist/esm2022/lib/components/display-components/control-widgets/menu-widget.component.mjs +0 -114
- package/dist/esm2022/lib/components/display-components/control-widgets/message-widget.component.mjs +0 -114
- package/dist/esm2022/lib/components/display-components/control-widgets/record-timer-widget.component.mjs +0 -36
- package/dist/esm2022/lib/components/display-components/control-widgets/screenshare-widget.component.mjs +0 -74
- package/dist/esm2022/lib/components/display-components/flexible-grid/flexible-grid.component.mjs +0 -142
- package/dist/esm2022/lib/components/display-components/flexible-video/flexible-video.component.mjs +0 -265
- package/dist/esm2022/lib/components/display-components/loading-modal/loading-modal.component.mjs +0 -100
- package/dist/esm2022/lib/components/display-components/main-aspect-component/main-aspect-component.component.mjs +0 -132
- package/dist/esm2022/lib/components/display-components/main-container-component/main-container-component.component.mjs +0 -119
- package/dist/esm2022/lib/components/display-components/main-grid-component/main-grid-component.component.mjs +0 -106
- package/dist/esm2022/lib/components/display-components/main-screen-component/main-screen-component.component.mjs +0 -180
- package/dist/esm2022/lib/components/display-components/meeting-progress-timer/meeting-progress-timer.component.mjs +0 -120
- package/dist/esm2022/lib/components/display-components/mini-audio/mini-audio.component.mjs +0 -326
- package/dist/esm2022/lib/components/display-components/mini-card/mini-card.component.mjs +0 -165
- package/dist/esm2022/lib/components/display-components/mini-card-audio/mini-card-audio.component.mjs +0 -230
- package/dist/esm2022/lib/components/display-components/other-grid-component/other-grid-component.component.mjs +0 -111
- package/dist/esm2022/lib/components/display-components/pagination/pagination.component.mjs +0 -328
- package/dist/esm2022/lib/components/display-components/sub-aspect-component/sub-aspect-component.component.mjs +0 -118
- package/dist/esm2022/lib/components/display-components/video-card/video-card.component.mjs +0 -330
- package/dist/esm2022/lib/components/display-settings-components/display-settings-modal.component.mjs +0 -95
- package/dist/esm2022/lib/components/event-settings-components/event-settings-modal/event-settings-modal.component.mjs +0 -190
- package/dist/esm2022/lib/components/exit-components/confirm-exit-modal/confirm-exit-modal.component.mjs +0 -119
- package/dist/esm2022/lib/components/media-settings-components/media-settings-modal/media-settings-modal.component.mjs +0 -209
- package/dist/esm2022/lib/components/mediasfu-components/mediasfu-broadcast.component.mjs +0 -4189
- package/dist/esm2022/lib/components/mediasfu-components/mediasfu-chat.component.mjs +0 -3705
- package/dist/esm2022/lib/components/mediasfu-components/mediasfu-conference.component.mjs +0 -5024
- package/dist/esm2022/lib/components/mediasfu-components/mediasfu-generic.component.mjs +0 -5333
- package/dist/esm2022/lib/components/mediasfu-components/mediasfu-webinar.component.mjs +0 -5023
- package/dist/esm2022/lib/components/menu-components/custom-buttons/custom-buttons.component.mjs +0 -85
- package/dist/esm2022/lib/components/menu-components/meeting-id-component/meeting-id-component.component.mjs +0 -22
- package/dist/esm2022/lib/components/menu-components/meeting-passcode-component/meeting-passcode-component.component.mjs +0 -22
- package/dist/esm2022/lib/components/menu-components/menu-modal/menu-modal.component.mjs +0 -132
- package/dist/esm2022/lib/components/menu-components/share-buttons-component/share-buttons-component.component.mjs +0 -104
- package/dist/esm2022/lib/components/message-components/message-panel/message-panel.component.mjs +0 -204
- package/dist/esm2022/lib/components/message-components/messages-modal/messages-modal.component.mjs +0 -243
- package/dist/esm2022/lib/components/misc-components/confirm-here-modal/confirm-here-modal.component.mjs +0 -147
- package/dist/esm2022/lib/components/misc-components/pre-join-page/pre-join-page.component.mjs +0 -335
- package/dist/esm2022/lib/components/misc-components/share-event-modal/share-event-modal.component.mjs +0 -113
- package/dist/esm2022/lib/components/misc-components/welcome-page/welcome-page.component.mjs +0 -226
- package/dist/esm2022/lib/components/participants-components/participant-list/participant-list.component.mjs +0 -63
- package/dist/esm2022/lib/components/participants-components/participant-list-item/participant-list-item.component.mjs +0 -120
- package/dist/esm2022/lib/components/participants-components/participant-list-others/participant-list-others.component.mjs +0 -23
- package/dist/esm2022/lib/components/participants-components/participant-list-others-item/participant-list-others-item.component.mjs +0 -43
- package/dist/esm2022/lib/components/participants-components/participants-modal/participants-modal.component.mjs +0 -100
- package/dist/esm2022/lib/components/polls-components/poll-modal/poll-modal.component.mjs +0 -174
- package/dist/esm2022/lib/components/recording-components/advanced-panel-component/advanced-panel-components.component.mjs +0 -77
- package/dist/esm2022/lib/components/recording-components/recording-modal/recording-modal.component.mjs +0 -121
- package/dist/esm2022/lib/components/recording-components/standard-panel-component/standard-panel-component.component.mjs +0 -85
- package/dist/esm2022/lib/components/requests-components/render-request-component/render-request-component.component.mjs +0 -59
- package/dist/esm2022/lib/components/requests-components/requests-modal/requests-modal.component.mjs +0 -130
- package/dist/esm2022/lib/components/screenboard-components/screenboard/screenboard.component.mjs +0 -617
- package/dist/esm2022/lib/components/screenboard-components/screenboard-modal/screenboard-modal.component.mjs +0 -380
- package/dist/esm2022/lib/components/waiting-components/waiting-room-modal.component.mjs +0 -142
- package/dist/esm2022/lib/components/whiteboard-components/configure-whiteboard-modal/configure-whiteboard-modal.component.mjs +0 -265
- package/dist/esm2022/lib/components/whiteboard-components/whiteboard/whiteboard.component.mjs +0 -1784
- package/dist/esm2022/lib/consumers/add-videos-grid.service.mjs +0 -296
- package/dist/esm2022/lib/consumers/auto-adjust.service.mjs +0 -83
- package/dist/esm2022/lib/consumers/calculate-rows-and-columns.service.mjs +0 -42
- package/dist/esm2022/lib/consumers/change-vids.service.mjs +0 -486
- package/dist/esm2022/lib/consumers/check-grid.service.mjs +0 -79
- package/dist/esm2022/lib/consumers/check-permission.service.mjs +0 -80
- package/dist/esm2022/lib/consumers/check-screen-share.service.mjs +0 -71
- package/dist/esm2022/lib/consumers/close-and-resize.service.mjs +0 -229
- package/dist/esm2022/lib/consumers/compare-active-names.service.mjs +0 -75
- package/dist/esm2022/lib/consumers/compare-screen-states.service.mjs +0 -63
- package/dist/esm2022/lib/consumers/connect-ips.service.mjs +0 -112
- package/dist/esm2022/lib/consumers/connect-recv-transport.service.mjs +0 -113
- package/dist/esm2022/lib/consumers/connect-send-transport-audio.service.mjs +0 -46
- package/dist/esm2022/lib/consumers/connect-send-transport-screen.service.mjs +0 -62
- package/dist/esm2022/lib/consumers/connect-send-transport-video.service.mjs +0 -55
- package/dist/esm2022/lib/consumers/connect-send-transport.service.mjs +0 -86
- package/dist/esm2022/lib/consumers/consumer-resume.service.mjs +0 -332
- package/dist/esm2022/lib/consumers/control-media.service.mjs +0 -68
- package/dist/esm2022/lib/consumers/create-send-transport.service.mjs +0 -126
- package/dist/esm2022/lib/consumers/disconnect-send-transport-audio.service.mjs +0 -58
- package/dist/esm2022/lib/consumers/disconnect-send-transport-screen.service.mjs +0 -45
- package/dist/esm2022/lib/consumers/disconnect-send-transport-video.service.mjs +0 -56
- package/dist/esm2022/lib/consumers/disp-streams.service.mjs +0 -421
- package/dist/esm2022/lib/consumers/generate-page-content.service.mjs +0 -59
- package/dist/esm2022/lib/consumers/get-estimate.service.mjs +0 -70
- package/dist/esm2022/lib/consumers/get-piped-producers-alt.service.mjs +0 -49
- package/dist/esm2022/lib/consumers/get-producers-piped.service.mjs +0 -46
- package/dist/esm2022/lib/consumers/get-videos.service.mjs +0 -58
- package/dist/esm2022/lib/consumers/mix-streams.service.mjs +0 -73
- package/dist/esm2022/lib/consumers/on-screen-changes.service.mjs +0 -63
- package/dist/esm2022/lib/consumers/prepopulate-user-media.service.mjs +0 -442
- package/dist/esm2022/lib/consumers/process-consumer-transports-audio.service.mjs +0 -72
- package/dist/esm2022/lib/consumers/process-consumer-transports.service.mjs +0 -91
- package/dist/esm2022/lib/consumers/re-port.service.mjs +0 -66
- package/dist/esm2022/lib/consumers/re-update-inter.service.mjs +0 -157
- package/dist/esm2022/lib/consumers/readjust.service.mjs +0 -123
- package/dist/esm2022/lib/consumers/receive-all-piped-transports.service.mjs +0 -56
- package/dist/esm2022/lib/consumers/receive-room-messages.service.mjs +0 -42
- package/dist/esm2022/lib/consumers/reorder-streams.service.mjs +0 -181
- package/dist/esm2022/lib/consumers/request-screen-share.service.mjs +0 -67
- package/dist/esm2022/lib/consumers/resume-pause-audio-streams.service.mjs +0 -99
- package/dist/esm2022/lib/consumers/resume-pause-streams.service.mjs +0 -70
- package/dist/esm2022/lib/consumers/resume-send-transport-audio.service.mjs +0 -55
- package/dist/esm2022/lib/consumers/signal-new-consumer-transport.service.mjs +0 -136
- package/dist/esm2022/lib/consumers/socket-receive-methods/join-consume-room.service.mjs +0 -63
- package/dist/esm2022/lib/consumers/socket-receive-methods/new-pipe-producer.service.mjs +0 -61
- package/dist/esm2022/lib/consumers/socket-receive-methods/producer-closed.service.mjs +0 -51
- package/dist/esm2022/lib/consumers/start-share-screen.service.mjs +0 -80
- package/dist/esm2022/lib/consumers/stop-share-screen.service.mjs +0 -120
- package/dist/esm2022/lib/consumers/stream-success-audio-switch.service.mjs +0 -132
- package/dist/esm2022/lib/consumers/stream-success-audio.service.mjs +0 -149
- package/dist/esm2022/lib/consumers/stream-success-screen.service.mjs +0 -143
- package/dist/esm2022/lib/consumers/stream-success-video.service.mjs +0 -202
- package/dist/esm2022/lib/consumers/switch-user-audio.service.mjs +0 -87
- package/dist/esm2022/lib/consumers/switch-user-video-alt.service.mjs +0 -228
- package/dist/esm2022/lib/consumers/switch-user-video.service.mjs +0 -125
- package/dist/esm2022/lib/consumers/trigger.service.mjs +0 -172
- package/dist/esm2022/lib/consumers/update-mini-cards-grid.service.mjs +0 -81
- package/dist/esm2022/lib/consumers/update-participant-audio-decibels.service.mjs +0 -39
- package/dist/esm2022/lib/methods/background-methods/launch-background.service.mjs +0 -23
- package/dist/esm2022/lib/methods/breakout-room-methods/breakout-room-updated.service.mjs +0 -112
- package/dist/esm2022/lib/methods/breakout-room-methods/launch-breakout-rooms.service.mjs +0 -22
- package/dist/esm2022/lib/methods/co-host-methods/launch-co-host.service.mjs +0 -22
- package/dist/esm2022/lib/methods/co-host-methods/modify-co-host-settings.service.mjs +0 -60
- package/dist/esm2022/lib/methods/display-settings-methods/launch-display-settings.service.mjs +0 -24
- package/dist/esm2022/lib/methods/display-settings-methods/modify-display-settings.service.mjs +0 -119
- package/dist/esm2022/lib/methods/exit-methods/confirm-exit.service.mjs +0 -28
- package/dist/esm2022/lib/methods/exit-methods/launch-confirm-exit.service.mjs +0 -22
- package/dist/esm2022/lib/methods/media-settings-methods/launch-media-settings.service.mjs +0 -50
- package/dist/esm2022/lib/methods/menu-methods/launch-menu-modal.service.mjs +0 -22
- package/dist/esm2022/lib/methods/message-methods/launch-messages.service.mjs +0 -23
- package/dist/esm2022/lib/methods/message-methods/send-message.service.mjs +0 -94
- package/dist/esm2022/lib/methods/participants-methods/launch-participants.service.mjs +0 -23
- package/dist/esm2022/lib/methods/participants-methods/message-participants.service.mjs +0 -52
- package/dist/esm2022/lib/methods/participants-methods/mute-participants.service.mjs +0 -57
- package/dist/esm2022/lib/methods/participants-methods/remove-participants.service.mjs +0 -62
- package/dist/esm2022/lib/methods/polls-methods/handle-create-poll.service.mjs +0 -37
- package/dist/esm2022/lib/methods/polls-methods/handle-end-poll.service.mjs +0 -40
- package/dist/esm2022/lib/methods/polls-methods/handle-vote-poll.service.mjs +0 -49
- package/dist/esm2022/lib/methods/polls-methods/launch-poll.service.mjs +0 -23
- package/dist/esm2022/lib/methods/polls-methods/poll-updated.service.mjs +0 -64
- package/dist/esm2022/lib/methods/recording-methods/check-pause-state.service.mjs +0 -45
- package/dist/esm2022/lib/methods/recording-methods/check-resume-state.service.mjs +0 -34
- package/dist/esm2022/lib/methods/recording-methods/confirm-recording.service.mjs +0 -215
- package/dist/esm2022/lib/methods/recording-methods/launch-recording.service.mjs +0 -82
- package/dist/esm2022/lib/methods/recording-methods/record-pause-timer.service.mjs +0 -40
- package/dist/esm2022/lib/methods/recording-methods/record-resume-timer.service.mjs +0 -86
- package/dist/esm2022/lib/methods/recording-methods/record-start-timer.service.mjs +0 -89
- package/dist/esm2022/lib/methods/recording-methods/record-update-timer.service.mjs +0 -48
- package/dist/esm2022/lib/methods/recording-methods/start-recording.service.mjs +0 -147
- package/dist/esm2022/lib/methods/recording-methods/stop-recording.service.mjs +0 -74
- package/dist/esm2022/lib/methods/recording-methods/update-recording.service.mjs +0 -224
- package/dist/esm2022/lib/methods/requests-methods/launch-requests.service.mjs +0 -26
- package/dist/esm2022/lib/methods/requests-methods/respond-to-requests.service.mjs +0 -45
- package/dist/esm2022/lib/methods/settings-methods/launch-settings.service.mjs +0 -26
- package/dist/esm2022/lib/methods/settings-methods/modify-settings.service.mjs +0 -67
- package/dist/esm2022/lib/methods/stream-methods/click-audio.service.mjs +0 -178
- package/dist/esm2022/lib/methods/stream-methods/click-chat.service.mjs +0 -44
- package/dist/esm2022/lib/methods/stream-methods/click-screen-share.service.mjs +0 -110
- package/dist/esm2022/lib/methods/stream-methods/click-video.service.mjs +0 -183
- package/dist/esm2022/lib/methods/stream-methods/switch-audio.service.mjs +0 -33
- package/dist/esm2022/lib/methods/stream-methods/switch-video-alt.service.mjs +0 -66
- package/dist/esm2022/lib/methods/stream-methods/switch-video.service.mjs +0 -76
- package/dist/esm2022/lib/methods/utils/format-number.service.mjs +0 -45
- package/dist/esm2022/lib/methods/utils/generate-random-messages.service.mjs +0 -87
- package/dist/esm2022/lib/methods/utils/generate-random-participants.service.mjs +0 -99
- package/dist/esm2022/lib/methods/utils/generate-random-polls.service.mjs +0 -52
- package/dist/esm2022/lib/methods/utils/generate-random-request-list.service.mjs +0 -54
- package/dist/esm2022/lib/methods/utils/generate-random-waiting-room-list.service.mjs +0 -38
- package/dist/esm2022/lib/methods/utils/get-modal-position.util.mjs +0 -22
- package/dist/esm2022/lib/methods/utils/get-overlay-position.util.mjs +0 -21
- package/dist/esm2022/lib/methods/utils/initial-values.util.mjs +0 -379
- package/dist/esm2022/lib/methods/utils/meeting-timer/start-meeting-progress-timer.service.mjs +0 -59
- package/dist/esm2022/lib/methods/utils/mini-audio-player/mini-audio-player.component.mjs +0 -260
- package/dist/esm2022/lib/methods/utils/producer/a-params.service.mjs +0 -21
- package/dist/esm2022/lib/methods/utils/producer/h-params.service.mjs +0 -37
- package/dist/esm2022/lib/methods/utils/producer/screen-params.service.mjs +0 -24
- package/dist/esm2022/lib/methods/utils/producer/v-params.service.mjs +0 -37
- package/dist/esm2022/lib/methods/utils/producer/video-capture-constraints.service.mjs +0 -38
- package/dist/esm2022/lib/methods/utils/sleep.util.mjs +0 -11
- package/dist/esm2022/lib/methods/utils/sound-player.service.mjs +0 -42
- package/dist/esm2022/lib/methods/utils/validate-alphanumeric.service.mjs +0 -33
- package/dist/esm2022/lib/methods/waiting-methods/launch-waiting.service.mjs +0 -23
- package/dist/esm2022/lib/methods/waiting-methods/respond-to-waiting.service.mjs +0 -40
- package/dist/esm2022/lib/methods/whiteboard-methods/capture-canvas-stream.service.mjs +0 -69
- package/dist/esm2022/lib/methods/whiteboard-methods/launch-configure-whiteboard.service.mjs +0 -24
- package/dist/esm2022/lib/producer-client/producer-client-emits/create-device-client.service.mjs +0 -51
- package/dist/esm2022/lib/producer-client/producer-client-emits/join-room-client.service.mjs +0 -65
- package/dist/esm2022/lib/producer-client/producer-client-emits/update-room-parameters-client.service.mjs +0 -232
- package/dist/esm2022/lib/producers/producer-emits/join-con-room.service.mjs +0 -114
- package/dist/esm2022/lib/producers/producer-emits/join-room.service.mjs +0 -114
- package/dist/esm2022/lib/producers/socket-receive-methods/all-members-rest.service.mjs +0 -155
- package/dist/esm2022/lib/producers/socket-receive-methods/all-members.service.mjs +0 -147
- package/dist/esm2022/lib/producers/socket-receive-methods/all-waiting-room-members.service.mjs +0 -30
- package/dist/esm2022/lib/producers/socket-receive-methods/ban-participant.service.mjs +0 -40
- package/dist/esm2022/lib/producers/socket-receive-methods/control-media-host.service.mjs +0 -146
- package/dist/esm2022/lib/producers/socket-receive-methods/disconnect-user-self.service.mjs +0 -26
- package/dist/esm2022/lib/producers/socket-receive-methods/disconnect.service.mjs +0 -38
- package/dist/esm2022/lib/producers/socket-receive-methods/get-domains.service.mjs +0 -63
- package/dist/esm2022/lib/producers/socket-receive-methods/host-request-response.service.mjs +0 -167
- package/dist/esm2022/lib/producers/socket-receive-methods/meeting-ended.service.mjs +0 -44
- package/dist/esm2022/lib/producers/socket-receive-methods/meeting-still-there.service.mjs +0 -24
- package/dist/esm2022/lib/producers/socket-receive-methods/meeting-time-remaining.service.mjs +0 -36
- package/dist/esm2022/lib/producers/socket-receive-methods/participant-requested.service.mjs +0 -32
- package/dist/esm2022/lib/producers/socket-receive-methods/person-joined.service.mjs +0 -29
- package/dist/esm2022/lib/producers/socket-receive-methods/producer-media-closed.service.mjs +0 -68
- package/dist/esm2022/lib/producers/socket-receive-methods/producer-media-paused.service.mjs +0 -90
- package/dist/esm2022/lib/producers/socket-receive-methods/producer-media-resumed.service.mjs +0 -54
- package/dist/esm2022/lib/producers/socket-receive-methods/re-initiate-recording.service.mjs +0 -38
- package/dist/esm2022/lib/producers/socket-receive-methods/receive-message.service.mjs +0 -96
- package/dist/esm2022/lib/producers/socket-receive-methods/recording-notice.service.mjs +0 -195
- package/dist/esm2022/lib/producers/socket-receive-methods/room-record-params.service.mjs +0 -59
- package/dist/esm2022/lib/producers/socket-receive-methods/screen-producer-id.service.mjs +0 -45
- package/dist/esm2022/lib/producers/socket-receive-methods/start-records.service.mjs +0 -35
- package/dist/esm2022/lib/producers/socket-receive-methods/stopped-recording.service.mjs +0 -37
- package/dist/esm2022/lib/producers/socket-receive-methods/time-left-recording.service.mjs +0 -36
- package/dist/esm2022/lib/producers/socket-receive-methods/update-consuming-domains.service.mjs +0 -63
- package/dist/esm2022/lib/producers/socket-receive-methods/update-media-settings.service.mjs +0 -36
- package/dist/esm2022/lib/producers/socket-receive-methods/updated-co-host.service.mjs +0 -56
- package/dist/esm2022/lib/producers/socket-receive-methods/user-waiting.service.mjs +0 -78
- package/dist/esm2022/lib/sockets/socket-manager.service.mjs +0 -73
- package/dist/esm2022/mediasfu-angular.mjs +0 -5
- package/dist/esm2022/public-api.mjs +0 -187
package/dist/esm2022/lib/components/display-components/flexible-video/flexible-video.component.mjs
DELETED
|
@@ -1,265 +0,0 @@
|
|
|
1
|
-
import { Component, Input, Injector } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
/**
|
|
6
|
-
* Component for displaying a flexible video grid.
|
|
7
|
-
*
|
|
8
|
-
* @component
|
|
9
|
-
* @selector app-flexible-video
|
|
10
|
-
* @standalone true
|
|
11
|
-
* @imports CommonModule
|
|
12
|
-
*
|
|
13
|
-
* @template
|
|
14
|
-
* <div>
|
|
15
|
-
* <!-- Dynamic styles and layout for video grid -->
|
|
16
|
-
* <div *ngFor="let rowComponents of grid; let rowIndex = index">
|
|
17
|
-
* <div *ngFor="let component of rowComponents; let colIndex = index">
|
|
18
|
-
* <ng-container *ngComponentOutlet="component.component; injector: createInjector(component.inputs)"></ng-container>
|
|
19
|
-
* </div>
|
|
20
|
-
* </div>
|
|
21
|
-
* <div *ngIf="Screenboard && Screenboard.component">
|
|
22
|
-
* <ng-container *ngComponentOutlet="Screenboard.component; injector: createInjector(Screenboard.inputs)"></ng-container>
|
|
23
|
-
* </div>
|
|
24
|
-
* </div>
|
|
25
|
-
*
|
|
26
|
-
* @class FlexibleVideo
|
|
27
|
-
* @implements OnInit, OnChanges
|
|
28
|
-
*
|
|
29
|
-
* @property {number} customWidth - Custom width for the video grid.
|
|
30
|
-
* @property {number} customHeight - Custom height for the video grid.
|
|
31
|
-
* @property {number} rows - Number of rows in the video grid.
|
|
32
|
-
* @property {number} columns - Number of columns in the video grid.
|
|
33
|
-
* @property {Array<{ component: ComponentType<any>, inputs: any }>} componentsToRender - Components to render in the grid.
|
|
34
|
-
* @property {boolean} showAspect - Flag to show or hide the aspect ratio.
|
|
35
|
-
* @property {string} [backgroundColor='transparent'] - Background color for the video grid.
|
|
36
|
-
* @property {{ component: ComponentType<any>, inputs: any }} [Screenboard] - Screenboard component to overlay on the grid.
|
|
37
|
-
* @property {boolean} [annotateScreenStream=false] - Flag to annotate the screen stream.
|
|
38
|
-
* @property {MediaStream} [localStreamScreen] - Local media stream for the screen.
|
|
39
|
-
*
|
|
40
|
-
* @property {number} key - Key for tracking changes.
|
|
41
|
-
* @property {number} cardWidth - Width of each card in the grid.
|
|
42
|
-
* @property {number} cardHeight - Height of each card in the grid.
|
|
43
|
-
* @property {number} cardTop - Top position of each card in the grid.
|
|
44
|
-
* @property {number} cardLeft - Left position of each card in the grid.
|
|
45
|
-
* @property {number} canvasLeft - Left position of the canvas.
|
|
46
|
-
* @property {any[][]} grid - Grid structure for the components.
|
|
47
|
-
*
|
|
48
|
-
* @constructor
|
|
49
|
-
* @param {Injector} injector - Angular injector for dependency injection.
|
|
50
|
-
*
|
|
51
|
-
* @method ngOnInit - Lifecycle hook that is called after data-bound properties are initialized.
|
|
52
|
-
* @method ngOnChanges - Lifecycle hook that is called when any data-bound property changes.
|
|
53
|
-
* @method generateGrid - Generates the grid structure based on rows and columns.
|
|
54
|
-
* @method createInjector - Creates an injector for the given inputs.
|
|
55
|
-
* @param {any} inputs - Inputs for the component.
|
|
56
|
-
* @returns {Injector} - The created injector.
|
|
57
|
-
*/
|
|
58
|
-
export class FlexibleVideo {
|
|
59
|
-
injector;
|
|
60
|
-
customWidth = 0;
|
|
61
|
-
customHeight = 0;
|
|
62
|
-
rows = 0;
|
|
63
|
-
columns = 0;
|
|
64
|
-
componentsToRender = [];
|
|
65
|
-
showAspect = false;
|
|
66
|
-
backgroundColor = 'transparent';
|
|
67
|
-
Screenboard;
|
|
68
|
-
annotateScreenStream = false;
|
|
69
|
-
localStreamScreen;
|
|
70
|
-
key = 0;
|
|
71
|
-
cardWidth = 0;
|
|
72
|
-
cardHeight = 0;
|
|
73
|
-
cardTop = 0;
|
|
74
|
-
cardLeft = 0;
|
|
75
|
-
canvasLeft = 0;
|
|
76
|
-
grid = [];
|
|
77
|
-
injectorCache = new WeakMap();
|
|
78
|
-
constructor(injector) {
|
|
79
|
-
this.injector = injector;
|
|
80
|
-
}
|
|
81
|
-
ngOnInit() {
|
|
82
|
-
if (this.showAspect) {
|
|
83
|
-
this.generateGrid();
|
|
84
|
-
}
|
|
85
|
-
}
|
|
86
|
-
ngOnChanges(changes) {
|
|
87
|
-
if (changes['columns'] ||
|
|
88
|
-
changes['rows'] ||
|
|
89
|
-
changes['componentsToRender'] ||
|
|
90
|
-
changes['customWidth'] ||
|
|
91
|
-
changes['customHeight']) {
|
|
92
|
-
if (this.showAspect) {
|
|
93
|
-
this.key++;
|
|
94
|
-
this.generateGrid();
|
|
95
|
-
}
|
|
96
|
-
}
|
|
97
|
-
if (this.annotateScreenStream && this.localStreamScreen) {
|
|
98
|
-
const videoHeight = this.localStreamScreen.getVideoTracks()[0].getSettings().height || 0;
|
|
99
|
-
const videoWidth = this.localStreamScreen.getVideoTracks()[0].getSettings().width || 0;
|
|
100
|
-
this.cardWidth = videoWidth;
|
|
101
|
-
this.cardHeight = videoHeight;
|
|
102
|
-
this.cardTop = Math.floor((this.customHeight - videoHeight) / 2);
|
|
103
|
-
this.cardLeft = Math.floor((this.customWidth - videoWidth) / 2);
|
|
104
|
-
this.canvasLeft = this.cardLeft < 0 ? this.cardLeft : 0;
|
|
105
|
-
}
|
|
106
|
-
else {
|
|
107
|
-
this.cardWidth = this.customWidth;
|
|
108
|
-
this.cardHeight = this.customHeight;
|
|
109
|
-
this.cardTop = 0;
|
|
110
|
-
this.cardLeft = 0;
|
|
111
|
-
this.canvasLeft = 0;
|
|
112
|
-
}
|
|
113
|
-
}
|
|
114
|
-
generateGrid() {
|
|
115
|
-
this.grid = [];
|
|
116
|
-
for (let row = 0; row < this.rows; row++) {
|
|
117
|
-
const rowComponents = [];
|
|
118
|
-
for (let col = 0; col < this.columns; col++) {
|
|
119
|
-
const index = row * this.columns + col;
|
|
120
|
-
const component = this.componentsToRender[index];
|
|
121
|
-
rowComponents.push(component);
|
|
122
|
-
}
|
|
123
|
-
this.grid.push(rowComponents);
|
|
124
|
-
}
|
|
125
|
-
}
|
|
126
|
-
createInjector(inputs) {
|
|
127
|
-
if (!this.injectorCache.has(inputs)) {
|
|
128
|
-
const injector = Injector.create({
|
|
129
|
-
providers: Object.keys(inputs).map((key) => ({ provide: key, useValue: inputs[key] })),
|
|
130
|
-
parent: this.injector,
|
|
131
|
-
});
|
|
132
|
-
this.injectorCache.set(inputs, injector);
|
|
133
|
-
}
|
|
134
|
-
// eslint-disable-next-line @typescript-eslint/no-non-null-assertion
|
|
135
|
-
return this.injectorCache.get(inputs);
|
|
136
|
-
}
|
|
137
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FlexibleVideo, deps: [{ token: i0.Injector }], target: i0.ɵɵFactoryTarget.Component });
|
|
138
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: FlexibleVideo, isStandalone: true, selector: "app-flexible-video", inputs: { customWidth: "customWidth", customHeight: "customHeight", rows: "rows", columns: "columns", componentsToRender: "componentsToRender", showAspect: "showAspect", backgroundColor: "backgroundColor", Screenboard: "Screenboard", annotateScreenStream: "annotateScreenStream", localStreamScreen: "localStreamScreen" }, usesOnChanges: true, ngImport: i0, template: `
|
|
139
|
-
<div
|
|
140
|
-
style="padding: 0; flex: 1; margin: 0; position: relative; display: {{
|
|
141
|
-
showAspect ? 'flex' : 'none'
|
|
142
|
-
}};
|
|
143
|
-
max-width: {{ customWidth }}px; overflow-x: hidden; overflow-y: auto; left: {{
|
|
144
|
-
cardLeft > 0 ? cardLeft : 0
|
|
145
|
-
}}px;"
|
|
146
|
-
>
|
|
147
|
-
<div
|
|
148
|
-
*ngFor="let rowComponents of grid; let rowIndex = index"
|
|
149
|
-
style="display: flex; flex-direction: row;"
|
|
150
|
-
>
|
|
151
|
-
<div
|
|
152
|
-
*ngFor="let component of rowComponents; let colIndex = index"
|
|
153
|
-
[ngStyle]="{
|
|
154
|
-
flex: 1,
|
|
155
|
-
width: cardWidth + 'px',
|
|
156
|
-
height: cardHeight + 'px',
|
|
157
|
-
backgroundColor: backgroundColor,
|
|
158
|
-
margin: '1px',
|
|
159
|
-
padding: 0,
|
|
160
|
-
borderRadius: '0px',
|
|
161
|
-
left: cardLeft + 'px'
|
|
162
|
-
}"
|
|
163
|
-
>
|
|
164
|
-
<ng-container
|
|
165
|
-
*ngComponentOutlet="component.component; injector: createInjector(component.inputs)"
|
|
166
|
-
></ng-container>
|
|
167
|
-
</div>
|
|
168
|
-
</div>
|
|
169
|
-
<div
|
|
170
|
-
*ngIf="Screenboard && Screenboard.component"
|
|
171
|
-
[ngStyle]="{
|
|
172
|
-
position: 'absolute',
|
|
173
|
-
top: '0',
|
|
174
|
-
left: canvasLeft + 'px',
|
|
175
|
-
width: cardWidth + 'px',
|
|
176
|
-
height: cardHeight + 'px',
|
|
177
|
-
backgroundColor: 'rgba(0, 0, 0, 0.005)',
|
|
178
|
-
zIndex: '2'
|
|
179
|
-
}"
|
|
180
|
-
>
|
|
181
|
-
<ng-container
|
|
182
|
-
*ngComponentOutlet="Screenboard.component; injector: createInjector(Screenboard.inputs)"
|
|
183
|
-
></ng-container>
|
|
184
|
-
</div>
|
|
185
|
-
</div>
|
|
186
|
-
`, isInline: true, dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgComponentOutlet, selector: "[ngComponentOutlet]", inputs: ["ngComponentOutlet", "ngComponentOutletInputs", "ngComponentOutletInjector", "ngComponentOutletContent", "ngComponentOutletNgModule", "ngComponentOutletNgModuleFactory"] }, { kind: "directive", type: i1.NgForOf, selector: "[ngFor][ngForOf]", inputs: ["ngForOf", "ngForTrackBy", "ngForTemplate"] }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
187
|
-
}
|
|
188
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: FlexibleVideo, decorators: [{
|
|
189
|
-
type: Component,
|
|
190
|
-
args: [{
|
|
191
|
-
selector: 'app-flexible-video',
|
|
192
|
-
standalone: true,
|
|
193
|
-
imports: [CommonModule],
|
|
194
|
-
template: `
|
|
195
|
-
<div
|
|
196
|
-
style="padding: 0; flex: 1; margin: 0; position: relative; display: {{
|
|
197
|
-
showAspect ? 'flex' : 'none'
|
|
198
|
-
}};
|
|
199
|
-
max-width: {{ customWidth }}px; overflow-x: hidden; overflow-y: auto; left: {{
|
|
200
|
-
cardLeft > 0 ? cardLeft : 0
|
|
201
|
-
}}px;"
|
|
202
|
-
>
|
|
203
|
-
<div
|
|
204
|
-
*ngFor="let rowComponents of grid; let rowIndex = index"
|
|
205
|
-
style="display: flex; flex-direction: row;"
|
|
206
|
-
>
|
|
207
|
-
<div
|
|
208
|
-
*ngFor="let component of rowComponents; let colIndex = index"
|
|
209
|
-
[ngStyle]="{
|
|
210
|
-
flex: 1,
|
|
211
|
-
width: cardWidth + 'px',
|
|
212
|
-
height: cardHeight + 'px',
|
|
213
|
-
backgroundColor: backgroundColor,
|
|
214
|
-
margin: '1px',
|
|
215
|
-
padding: 0,
|
|
216
|
-
borderRadius: '0px',
|
|
217
|
-
left: cardLeft + 'px'
|
|
218
|
-
}"
|
|
219
|
-
>
|
|
220
|
-
<ng-container
|
|
221
|
-
*ngComponentOutlet="component.component; injector: createInjector(component.inputs)"
|
|
222
|
-
></ng-container>
|
|
223
|
-
</div>
|
|
224
|
-
</div>
|
|
225
|
-
<div
|
|
226
|
-
*ngIf="Screenboard && Screenboard.component"
|
|
227
|
-
[ngStyle]="{
|
|
228
|
-
position: 'absolute',
|
|
229
|
-
top: '0',
|
|
230
|
-
left: canvasLeft + 'px',
|
|
231
|
-
width: cardWidth + 'px',
|
|
232
|
-
height: cardHeight + 'px',
|
|
233
|
-
backgroundColor: 'rgba(0, 0, 0, 0.005)',
|
|
234
|
-
zIndex: '2'
|
|
235
|
-
}"
|
|
236
|
-
>
|
|
237
|
-
<ng-container
|
|
238
|
-
*ngComponentOutlet="Screenboard.component; injector: createInjector(Screenboard.inputs)"
|
|
239
|
-
></ng-container>
|
|
240
|
-
</div>
|
|
241
|
-
</div>
|
|
242
|
-
`,
|
|
243
|
-
}]
|
|
244
|
-
}], ctorParameters: () => [{ type: i0.Injector }], propDecorators: { customWidth: [{
|
|
245
|
-
type: Input
|
|
246
|
-
}], customHeight: [{
|
|
247
|
-
type: Input
|
|
248
|
-
}], rows: [{
|
|
249
|
-
type: Input
|
|
250
|
-
}], columns: [{
|
|
251
|
-
type: Input
|
|
252
|
-
}], componentsToRender: [{
|
|
253
|
-
type: Input
|
|
254
|
-
}], showAspect: [{
|
|
255
|
-
type: Input
|
|
256
|
-
}], backgroundColor: [{
|
|
257
|
-
type: Input
|
|
258
|
-
}], Screenboard: [{
|
|
259
|
-
type: Input
|
|
260
|
-
}], annotateScreenStream: [{
|
|
261
|
-
type: Input
|
|
262
|
-
}], localStreamScreen: [{
|
|
263
|
-
type: Input
|
|
264
|
-
}] } });
|
|
265
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiZmxleGlibGUtdmlkZW8uY29tcG9uZW50LmpzIiwic291cmNlUm9vdCI6IiIsInNvdXJjZXMiOlsiLi4vLi4vLi4vLi4vLi4vLi4vLi4vcHJvamVjdHMvbWVkaWFzZnUtYW5ndWxhci9zcmMvbGliL2NvbXBvbmVudHMvZGlzcGxheS1jb21wb25lbnRzL2ZsZXhpYmxlLXZpZGVvL2ZsZXhpYmxlLXZpZGVvLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBb0MsUUFBUSxFQUFFLE1BQU0sZUFBZSxDQUFDO0FBQzdGLE9BQU8sRUFBRSxZQUFZLEVBQUUsTUFBTSxpQkFBaUIsQ0FBQzs7O0FBaUIvQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQW9ERztBQXVESCxNQUFNLE9BQU8sYUFBYTtJQXNCSjtJQXJCWCxXQUFXLEdBQUcsQ0FBQyxDQUFDO0lBQ2hCLFlBQVksR0FBRyxDQUFDLENBQUM7SUFDakIsSUFBSSxHQUFHLENBQUMsQ0FBQztJQUNULE9BQU8sR0FBRyxDQUFDLENBQUM7SUFDWixrQkFBa0IsR0FBMkIsRUFBRSxDQUFDO0lBQ2hELFVBQVUsR0FBRyxLQUFLLENBQUM7SUFDbkIsZUFBZSxHQUFZLGFBQWEsQ0FBQztJQUN6QyxXQUFXLENBQXdCO0lBQ25DLG9CQUFvQixHQUFhLEtBQUssQ0FBQztJQUN2QyxpQkFBaUIsQ0FBZTtJQUV6QyxHQUFHLEdBQUcsQ0FBQyxDQUFDO0lBQ1IsU0FBUyxHQUFHLENBQUMsQ0FBQztJQUNkLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFDZixPQUFPLEdBQUcsQ0FBQyxDQUFDO0lBQ1osUUFBUSxHQUFHLENBQUMsQ0FBQztJQUNiLFVBQVUsR0FBRyxDQUFDLENBQUM7SUFDZixJQUFJLEdBQVksRUFBRSxDQUFDO0lBRVgsYUFBYSxHQUFHLElBQUksT0FBTyxFQUFpQixDQUFDO0lBRXJELFlBQW9CLFFBQWtCO1FBQWxCLGFBQVEsR0FBUixRQUFRLENBQVU7SUFBRyxDQUFDO0lBRTFDLFFBQVE7UUFDTixJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztZQUNwQixJQUFJLENBQUMsWUFBWSxFQUFFLENBQUM7UUFDdEIsQ0FBQztJQUNILENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFDRSxPQUFPLENBQUMsU0FBUyxDQUFDO1lBQ2xCLE9BQU8sQ0FBQyxNQUFNLENBQUM7WUFDZixPQUFPLENBQUMsb0JBQW9CLENBQUM7WUFDN0IsT0FBTyxDQUFDLGFBQWEsQ0FBQztZQUN0QixPQUFPLENBQUMsY0FBYyxDQUFDLEVBQ3ZCLENBQUM7WUFDRCxJQUFJLElBQUksQ0FBQyxVQUFVLEVBQUUsQ0FBQztnQkFDcEIsSUFBSSxDQUFDLEdBQUcsRUFBRSxDQUFDO2dCQUNYLElBQUksQ0FBQyxZQUFZLEVBQUUsQ0FBQztZQUN0QixDQUFDO1FBQ0gsQ0FBQztRQUVELElBQUksSUFBSSxDQUFDLG9CQUFvQixJQUFJLElBQUksQ0FBQyxpQkFBaUIsRUFBRSxDQUFDO1lBQ3hELE1BQU0sV0FBVyxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxNQUFNLElBQUksQ0FBQyxDQUFDO1lBQ3pGLE1BQU0sVUFBVSxHQUFHLElBQUksQ0FBQyxpQkFBaUIsQ0FBQyxjQUFjLEVBQUUsQ0FBQyxDQUFDLENBQUMsQ0FBQyxXQUFXLEVBQUUsQ0FBQyxLQUFLLElBQUksQ0FBQyxDQUFDO1lBQ3ZGLElBQUksQ0FBQyxTQUFTLEdBQUcsVUFBVSxDQUFDO1lBQzVCLElBQUksQ0FBQyxVQUFVLEdBQUcsV0FBVyxDQUFDO1lBQzlCLElBQUksQ0FBQyxPQUFPLEdBQUcsSUFBSSxDQUFDLEtBQUssQ0FBQyxDQUFDLElBQUksQ0FBQyxZQUFZLEdBQUcsV0FBVyxDQUFDLEdBQUcsQ0FBQyxDQUFDLENBQUM7WUFDakUsSUFBSSxDQUFDLFFBQVEsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLENBQUMsSUFBSSxDQUFDLFdBQVcsR0FBRyxVQUFVLENBQUMsR0FBRyxDQUFDLENBQUMsQ0FBQztZQUNoRSxJQUFJLENBQUMsVUFBVSxHQUFHLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDLENBQUMsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLENBQUMsQ0FBQyxDQUFDLENBQUM7UUFDMUQsQ0FBQzthQUFNLENBQUM7WUFDTixJQUFJLENBQUMsU0FBUyxHQUFHLElBQUksQ0FBQyxXQUFXLENBQUM7WUFDbEMsSUFBSSxDQUFDLFVBQVUsR0FBRyxJQUFJLENBQUMsWUFBWSxDQUFDO1lBQ3BDLElBQUksQ0FBQyxPQUFPLEdBQUcsQ0FBQyxDQUFDO1lBQ2pCLElBQUksQ0FBQyxRQUFRLEdBQUcsQ0FBQyxDQUFDO1lBQ2xCLElBQUksQ0FBQyxVQUFVLEdBQUcsQ0FBQyxDQUFDO1FBQ3RCLENBQUM7SUFDSCxDQUFDO0lBRUQsWUFBWTtRQUNWLElBQUksQ0FBQyxJQUFJLEdBQUcsRUFBRSxDQUFDO1FBQ2YsS0FBSyxJQUFJLEdBQUcsR0FBRyxDQUFDLEVBQUUsR0FBRyxHQUFHLElBQUksQ0FBQyxJQUFJLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQztZQUN6QyxNQUFNLGFBQWEsR0FBRyxFQUFFLENBQUM7WUFDekIsS0FBSyxJQUFJLEdBQUcsR0FBRyxDQUFDLEVBQUUsR0FBRyxHQUFHLElBQUksQ0FBQyxPQUFPLEVBQUUsR0FBRyxFQUFFLEVBQUUsQ0FBQztnQkFDNUMsTUFBTSxLQUFLLEdBQUcsR0FBRyxHQUFHLElBQUksQ0FBQyxPQUFPLEdBQUcsR0FBRyxDQUFDO2dCQUN2QyxNQUFNLFNBQVMsR0FBRyxJQUFJLENBQUMsa0JBQWtCLENBQUMsS0FBSyxDQUFDLENBQUM7Z0JBQ2pELGFBQWEsQ0FBQyxJQUFJLENBQUMsU0FBUyxDQUFDLENBQUM7WUFDaEMsQ0FBQztZQUNELElBQUksQ0FBQyxJQUFJLENBQUMsSUFBSSxDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBQ2hDLENBQUM7SUFDSCxDQUFDO0lBRUQsY0FBYyxDQUFDLE1BQVc7UUFDeEIsSUFBSSxDQUFDLElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLE1BQU0sQ0FBQyxFQUFFLENBQUM7WUFDcEMsTUFBTSxRQUFRLEdBQUcsUUFBUSxDQUFDLE1BQU0sQ0FBQztnQkFDL0IsU0FBUyxFQUFFLE1BQU0sQ0FBQyxJQUFJLENBQUMsTUFBTSxDQUFDLENBQUMsR0FBRyxDQUFDLENBQUMsR0FBRyxFQUFFLEVBQUUsQ0FBQyxDQUFDLEVBQUUsT0FBTyxFQUFFLEdBQUcsRUFBRSxRQUFRLEVBQUUsTUFBTSxDQUFDLEdBQUcsQ0FBQyxFQUFFLENBQUMsQ0FBQztnQkFDdEYsTUFBTSxFQUFFLElBQUksQ0FBQyxRQUFRO2FBQ3RCLENBQUMsQ0FBQztZQUNILElBQUksQ0FBQyxhQUFhLENBQUMsR0FBRyxDQUFDLE1BQU0sRUFBRSxRQUFRLENBQUMsQ0FBQztRQUMzQyxDQUFDO1FBQ0Qsb0VBQW9FO1FBQ3BFLE9BQU8sSUFBSSxDQUFDLGFBQWEsQ0FBQyxHQUFHLENBQUMsTUFBTSxDQUFFLENBQUM7SUFDekMsQ0FBQzt1R0FwRlUsYUFBYTsyRkFBYixhQUFhLHFhQWxEZDs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBZ0RULDJEQWpEUyxZQUFZOzsyRkFtRFgsYUFBYTtrQkF0RHpCLFNBQVM7bUJBQUM7b0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtvQkFDOUIsVUFBVSxFQUFFLElBQUk7b0JBQ2hCLE9BQU8sRUFBRSxDQUFDLFlBQVksQ0FBQztvQkFDdkIsUUFBUSxFQUFFOzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7R0FnRFQ7aUJBQ0Y7NkVBRVUsV0FBVztzQkFBbkIsS0FBSztnQkFDRyxZQUFZO3NCQUFwQixLQUFLO2dCQUNHLElBQUk7c0JBQVosS0FBSztnQkFDRyxPQUFPO3NCQUFmLEtBQUs7Z0JBQ0csa0JBQWtCO3NCQUExQixLQUFLO2dCQUNHLFVBQVU7c0JBQWxCLEtBQUs7Z0JBQ0csZUFBZTtzQkFBdkIsS0FBSztnQkFDRyxXQUFXO3NCQUFuQixLQUFLO2dCQUNHLG9CQUFvQjtzQkFBNUIsS0FBSztnQkFDRyxpQkFBaUI7c0JBQXpCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0LCBPbkNoYW5nZXMsIE9uSW5pdCwgU2ltcGxlQ2hhbmdlcywgSW5qZWN0b3IgfSBmcm9tICdAYW5ndWxhci9jb3JlJztcbmltcG9ydCB7IENvbW1vbk1vZHVsZSB9IGZyb20gJ0Bhbmd1bGFyL2NvbW1vbic7XG5pbXBvcnQgeyBDdXN0b21NZWRpYUNvbXBvbmVudCB9IGZyb20gJy4uLy4uLy4uL0B0eXBlcy90eXBlcyc7XG5leHBvcnQgaW50ZXJmYWNlIEZsZXhpYmxlVmlkZW9PcHRpb25zIHtcbiAgY3VzdG9tV2lkdGg6IG51bWJlcjtcbiAgY3VzdG9tSGVpZ2h0OiBudW1iZXI7XG4gIHJvd3M6IG51bWJlcjtcbiAgY29sdW1uczogbnVtYmVyO1xuICBjb21wb25lbnRzVG9SZW5kZXI6IEN1c3RvbU1lZGlhQ29tcG9uZW50W107XG4gIHNob3dBc3BlY3Q/OiBib29sZWFuO1xuICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gIFNjcmVlbmJvYXJkPzogQ3VzdG9tTWVkaWFDb21wb25lbnQ7XG4gIGFubm90YXRlU2NyZWVuU3RyZWFtPzogYm9vbGVhbjtcbiAgbG9jYWxTdHJlYW1TY3JlZW46IE1lZGlhU3RyZWFtIHwgbnVsbDtcbn1cblxuZXhwb3J0IHR5cGUgRmxleGlibGVWaWRlb1R5cGUgPSAob3B0aW9uczogRmxleGlibGVWaWRlb09wdGlvbnMpID0+IEhUTUxFbGVtZW50O1xuXG4vKipcbiAqIENvbXBvbmVudCBmb3IgZGlzcGxheWluZyBhIGZsZXhpYmxlIHZpZGVvIGdyaWQuXG4gKlxuICogQGNvbXBvbmVudFxuICogQHNlbGVjdG9yIGFwcC1mbGV4aWJsZS12aWRlb1xuICogQHN0YW5kYWxvbmUgdHJ1ZVxuICogQGltcG9ydHMgQ29tbW9uTW9kdWxlXG4gKlxuICogQHRlbXBsYXRlXG4gKiA8ZGl2PlxuICogICA8IS0tIER5bmFtaWMgc3R5bGVzIGFuZCBsYXlvdXQgZm9yIHZpZGVvIGdyaWQgLS0+XG4gKiAgIDxkaXYgKm5nRm9yPVwibGV0IHJvd0NvbXBvbmVudHMgb2YgZ3JpZDsgbGV0IHJvd0luZGV4ID0gaW5kZXhcIj5cbiAqICAgICA8ZGl2ICpuZ0Zvcj1cImxldCBjb21wb25lbnQgb2Ygcm93Q29tcG9uZW50czsgbGV0IGNvbEluZGV4ID0gaW5kZXhcIj5cbiAqICAgICAgIDxuZy1jb250YWluZXIgKm5nQ29tcG9uZW50T3V0bGV0PVwiY29tcG9uZW50LmNvbXBvbmVudDsgaW5qZWN0b3I6IGNyZWF0ZUluamVjdG9yKGNvbXBvbmVudC5pbnB1dHMpXCI+PC9uZy1jb250YWluZXI+XG4gKiAgICAgPC9kaXY+XG4gKiAgIDwvZGl2PlxuICogICA8ZGl2ICpuZ0lmPVwiU2NyZWVuYm9hcmQgJiYgU2NyZWVuYm9hcmQuY29tcG9uZW50XCI+XG4gKiAgICAgPG5nLWNvbnRhaW5lciAqbmdDb21wb25lbnRPdXRsZXQ9XCJTY3JlZW5ib2FyZC5jb21wb25lbnQ7IGluamVjdG9yOiBjcmVhdGVJbmplY3RvcihTY3JlZW5ib2FyZC5pbnB1dHMpXCI+PC9uZy1jb250YWluZXI+XG4gKiAgIDwvZGl2PlxuICogPC9kaXY+XG4gKlxuICogQGNsYXNzIEZsZXhpYmxlVmlkZW9cbiAqIEBpbXBsZW1lbnRzIE9uSW5pdCwgT25DaGFuZ2VzXG4gKlxuICogQHByb3BlcnR5IHtudW1iZXJ9IGN1c3RvbVdpZHRoIC0gQ3VzdG9tIHdpZHRoIGZvciB0aGUgdmlkZW8gZ3JpZC5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBjdXN0b21IZWlnaHQgLSBDdXN0b20gaGVpZ2h0IGZvciB0aGUgdmlkZW8gZ3JpZC5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSByb3dzIC0gTnVtYmVyIG9mIHJvd3MgaW4gdGhlIHZpZGVvIGdyaWQuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY29sdW1ucyAtIE51bWJlciBvZiBjb2x1bW5zIGluIHRoZSB2aWRlbyBncmlkLlxuICogQHByb3BlcnR5IHtBcnJheTx7IGNvbXBvbmVudDogQ29tcG9uZW50VHlwZTxhbnk+LCBpbnB1dHM6IGFueSB9Pn0gY29tcG9uZW50c1RvUmVuZGVyIC0gQ29tcG9uZW50cyB0byByZW5kZXIgaW4gdGhlIGdyaWQuXG4gKiBAcHJvcGVydHkge2Jvb2xlYW59IHNob3dBc3BlY3QgLSBGbGFnIHRvIHNob3cgb3IgaGlkZSB0aGUgYXNwZWN0IHJhdGlvLlxuICogQHByb3BlcnR5IHtzdHJpbmd9IFtiYWNrZ3JvdW5kQ29sb3I9J3RyYW5zcGFyZW50J10gLSBCYWNrZ3JvdW5kIGNvbG9yIGZvciB0aGUgdmlkZW8gZ3JpZC5cbiAqIEBwcm9wZXJ0eSB7eyBjb21wb25lbnQ6IENvbXBvbmVudFR5cGU8YW55PiwgaW5wdXRzOiBhbnkgfX0gW1NjcmVlbmJvYXJkXSAtIFNjcmVlbmJvYXJkIGNvbXBvbmVudCB0byBvdmVybGF5IG9uIHRoZSBncmlkLlxuICogQHByb3BlcnR5IHtib29sZWFufSBbYW5ub3RhdGVTY3JlZW5TdHJlYW09ZmFsc2VdIC0gRmxhZyB0byBhbm5vdGF0ZSB0aGUgc2NyZWVuIHN0cmVhbS5cbiAqIEBwcm9wZXJ0eSB7TWVkaWFTdHJlYW19IFtsb2NhbFN0cmVhbVNjcmVlbl0gLSBMb2NhbCBtZWRpYSBzdHJlYW0gZm9yIHRoZSBzY3JlZW4uXG4gKlxuICogQHByb3BlcnR5IHtudW1iZXJ9IGtleSAtIEtleSBmb3IgdHJhY2tpbmcgY2hhbmdlcy5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBjYXJkV2lkdGggLSBXaWR0aCBvZiBlYWNoIGNhcmQgaW4gdGhlIGdyaWQuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY2FyZEhlaWdodCAtIEhlaWdodCBvZiBlYWNoIGNhcmQgaW4gdGhlIGdyaWQuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY2FyZFRvcCAtIFRvcCBwb3NpdGlvbiBvZiBlYWNoIGNhcmQgaW4gdGhlIGdyaWQuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY2FyZExlZnQgLSBMZWZ0IHBvc2l0aW9uIG9mIGVhY2ggY2FyZCBpbiB0aGUgZ3JpZC5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBjYW52YXNMZWZ0IC0gTGVmdCBwb3NpdGlvbiBvZiB0aGUgY2FudmFzLlxuICogQHByb3BlcnR5IHthbnlbXVtdfSBncmlkIC0gR3JpZCBzdHJ1Y3R1cmUgZm9yIHRoZSBjb21wb25lbnRzLlxuICpcbiAqIEBjb25zdHJ1Y3RvclxuICogQHBhcmFtIHtJbmplY3Rvcn0gaW5qZWN0b3IgLSBBbmd1bGFyIGluamVjdG9yIGZvciBkZXBlbmRlbmN5IGluamVjdGlvbi5cbiAqXG4gKiBAbWV0aG9kIG5nT25Jbml0IC0gTGlmZWN5Y2xlIGhvb2sgdGhhdCBpcyBjYWxsZWQgYWZ0ZXIgZGF0YS1ib3VuZCBwcm9wZXJ0aWVzIGFyZSBpbml0aWFsaXplZC5cbiAqIEBtZXRob2QgbmdPbkNoYW5nZXMgLSBMaWZlY3ljbGUgaG9vayB0aGF0IGlzIGNhbGxlZCB3aGVuIGFueSBkYXRhLWJvdW5kIHByb3BlcnR5IGNoYW5nZXMuXG4gKiBAbWV0aG9kIGdlbmVyYXRlR3JpZCAtIEdlbmVyYXRlcyB0aGUgZ3JpZCBzdHJ1Y3R1cmUgYmFzZWQgb24gcm93cyBhbmQgY29sdW1ucy5cbiAqIEBtZXRob2QgY3JlYXRlSW5qZWN0b3IgLSBDcmVhdGVzIGFuIGluamVjdG9yIGZvciB0aGUgZ2l2ZW4gaW5wdXRzLlxuICogQHBhcmFtIHthbnl9IGlucHV0cyAtIElucHV0cyBmb3IgdGhlIGNvbXBvbmVudC5cbiAqIEByZXR1cm5zIHtJbmplY3Rvcn0gLSBUaGUgY3JlYXRlZCBpbmplY3Rvci5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLWZsZXhpYmxlLXZpZGVvJyxcbiAgc3RhbmRhbG9uZTogdHJ1ZSxcbiAgaW1wb3J0czogW0NvbW1vbk1vZHVsZV0sXG4gIHRlbXBsYXRlOiBgXG4gICAgPGRpdlxuICAgICAgc3R5bGU9XCJwYWRkaW5nOiAwOyBmbGV4OiAxOyBtYXJnaW46IDA7IHBvc2l0aW9uOiByZWxhdGl2ZTsgZGlzcGxheToge3tcbiAgICAgICAgc2hvd0FzcGVjdCA/ICdmbGV4JyA6ICdub25lJ1xuICAgICAgfX07XG4gICAgICAgICAgICAgbWF4LXdpZHRoOiB7eyBjdXN0b21XaWR0aCB9fXB4OyBvdmVyZmxvdy14OiBoaWRkZW47IG92ZXJmbG93LXk6IGF1dG87IGxlZnQ6IHt7XG4gICAgICAgIGNhcmRMZWZ0ID4gMCA/IGNhcmRMZWZ0IDogMFxuICAgICAgfX1weDtcIlxuICAgID5cbiAgICAgIDxkaXZcbiAgICAgICAgKm5nRm9yPVwibGV0IHJvd0NvbXBvbmVudHMgb2YgZ3JpZDsgbGV0IHJvd0luZGV4ID0gaW5kZXhcIlxuICAgICAgICBzdHlsZT1cImRpc3BsYXk6IGZsZXg7IGZsZXgtZGlyZWN0aW9uOiByb3c7XCJcbiAgICAgID5cbiAgICAgICAgPGRpdlxuICAgICAgICAgICpuZ0Zvcj1cImxldCBjb21wb25lbnQgb2Ygcm93Q29tcG9uZW50czsgbGV0IGNvbEluZGV4ID0gaW5kZXhcIlxuICAgICAgICAgIFtuZ1N0eWxlXT1cIntcbiAgICAgICAgICAgIGZsZXg6IDEsXG4gICAgICAgICAgICB3aWR0aDogY2FyZFdpZHRoICsgJ3B4JyxcbiAgICAgICAgICAgIGhlaWdodDogY2FyZEhlaWdodCArICdweCcsXG4gICAgICAgICAgICBiYWNrZ3JvdW5kQ29sb3I6IGJhY2tncm91bmRDb2xvcixcbiAgICAgICAgICAgIG1hcmdpbjogJzFweCcsXG4gICAgICAgICAgICBwYWRkaW5nOiAwLFxuICAgICAgICAgICAgYm9yZGVyUmFkaXVzOiAnMHB4JyxcbiAgICAgICAgICAgIGxlZnQ6IGNhcmRMZWZ0ICsgJ3B4J1xuICAgICAgICAgIH1cIlxuICAgICAgICA+XG4gICAgICAgICAgPG5nLWNvbnRhaW5lclxuICAgICAgICAgICAgKm5nQ29tcG9uZW50T3V0bGV0PVwiY29tcG9uZW50LmNvbXBvbmVudDsgaW5qZWN0b3I6IGNyZWF0ZUluamVjdG9yKGNvbXBvbmVudC5pbnB1dHMpXCJcbiAgICAgICAgICA+PC9uZy1jb250YWluZXI+XG4gICAgICAgIDwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgICA8ZGl2XG4gICAgICAgICpuZ0lmPVwiU2NyZWVuYm9hcmQgJiYgU2NyZWVuYm9hcmQuY29tcG9uZW50XCJcbiAgICAgICAgW25nU3R5bGVdPVwie1xuICAgICAgICAgIHBvc2l0aW9uOiAnYWJzb2x1dGUnLFxuICAgICAgICAgIHRvcDogJzAnLFxuICAgICAgICAgIGxlZnQ6IGNhbnZhc0xlZnQgKyAncHgnLFxuICAgICAgICAgIHdpZHRoOiBjYXJkV2lkdGggKyAncHgnLFxuICAgICAgICAgIGhlaWdodDogY2FyZEhlaWdodCArICdweCcsXG4gICAgICAgICAgYmFja2dyb3VuZENvbG9yOiAncmdiYSgwLCAwLCAwLCAwLjAwNSknLFxuICAgICAgICAgIHpJbmRleDogJzInXG4gICAgICAgIH1cIlxuICAgICAgPlxuICAgICAgICA8bmctY29udGFpbmVyXG4gICAgICAgICAgKm5nQ29tcG9uZW50T3V0bGV0PVwiU2NyZWVuYm9hcmQuY29tcG9uZW50OyBpbmplY3RvcjogY3JlYXRlSW5qZWN0b3IoU2NyZWVuYm9hcmQuaW5wdXRzKVwiXG4gICAgICAgID48L25nLWNvbnRhaW5lcj5cbiAgICAgIDwvZGl2PlxuICAgIDwvZGl2PlxuICBgLFxufSlcbmV4cG9ydCBjbGFzcyBGbGV4aWJsZVZpZGVvIGltcGxlbWVudHMgT25Jbml0LCBPbkNoYW5nZXMge1xuICBASW5wdXQoKSBjdXN0b21XaWR0aCA9IDA7XG4gIEBJbnB1dCgpIGN1c3RvbUhlaWdodCA9IDA7XG4gIEBJbnB1dCgpIHJvd3MgPSAwO1xuICBASW5wdXQoKSBjb2x1bW5zID0gMDtcbiAgQElucHV0KCkgY29tcG9uZW50c1RvUmVuZGVyOiBDdXN0b21NZWRpYUNvbXBvbmVudFtdID0gW107XG4gIEBJbnB1dCgpIHNob3dBc3BlY3QgPSBmYWxzZTtcbiAgQElucHV0KCkgYmFja2dyb3VuZENvbG9yPzogc3RyaW5nID0gJ3RyYW5zcGFyZW50JztcbiAgQElucHV0KCkgU2NyZWVuYm9hcmQ/OiBDdXN0b21NZWRpYUNvbXBvbmVudDtcbiAgQElucHV0KCkgYW5ub3RhdGVTY3JlZW5TdHJlYW0/OiBib29sZWFuID0gZmFsc2U7XG4gIEBJbnB1dCgpIGxvY2FsU3RyZWFtU2NyZWVuPzogTWVkaWFTdHJlYW07XG5cbiAga2V5ID0gMDtcbiAgY2FyZFdpZHRoID0gMDtcbiAgY2FyZEhlaWdodCA9IDA7XG4gIGNhcmRUb3AgPSAwO1xuICBjYXJkTGVmdCA9IDA7XG4gIGNhbnZhc0xlZnQgPSAwO1xuICBncmlkOiBhbnlbXVtdID0gW107XG5cbiAgcHJpdmF0ZSBpbmplY3RvckNhY2hlID0gbmV3IFdlYWtNYXA8YW55LCBJbmplY3Rvcj4oKTtcblxuICBjb25zdHJ1Y3Rvcihwcml2YXRlIGluamVjdG9yOiBJbmplY3Rvcikge31cblxuICBuZ09uSW5pdCgpIHtcbiAgICBpZiAodGhpcy5zaG93QXNwZWN0KSB7XG4gICAgICB0aGlzLmdlbmVyYXRlR3JpZCgpO1xuICAgIH1cbiAgfVxuXG4gIG5nT25DaGFuZ2VzKGNoYW5nZXM6IFNpbXBsZUNoYW5nZXMpIHtcbiAgICBpZiAoXG4gICAgICBjaGFuZ2VzWydjb2x1bW5zJ10gfHxcbiAgICAgIGNoYW5nZXNbJ3Jvd3MnXSB8fFxuICAgICAgY2hhbmdlc1snY29tcG9uZW50c1RvUmVuZGVyJ10gfHxcbiAgICAgIGNoYW5nZXNbJ2N1c3RvbVdpZHRoJ10gfHxcbiAgICAgIGNoYW5nZXNbJ2N1c3RvbUhlaWdodCddXG4gICAgKSB7XG4gICAgICBpZiAodGhpcy5zaG93QXNwZWN0KSB7XG4gICAgICAgIHRoaXMua2V5Kys7XG4gICAgICAgIHRoaXMuZ2VuZXJhdGVHcmlkKCk7XG4gICAgICB9XG4gICAgfVxuXG4gICAgaWYgKHRoaXMuYW5ub3RhdGVTY3JlZW5TdHJlYW0gJiYgdGhpcy5sb2NhbFN0cmVhbVNjcmVlbikge1xuICAgICAgY29uc3QgdmlkZW9IZWlnaHQgPSB0aGlzLmxvY2FsU3RyZWFtU2NyZWVuLmdldFZpZGVvVHJhY2tzKClbMF0uZ2V0U2V0dGluZ3MoKS5oZWlnaHQgfHwgMDtcbiAgICAgIGNvbnN0IHZpZGVvV2lkdGggPSB0aGlzLmxvY2FsU3RyZWFtU2NyZWVuLmdldFZpZGVvVHJhY2tzKClbMF0uZ2V0U2V0dGluZ3MoKS53aWR0aCB8fCAwO1xuICAgICAgdGhpcy5jYXJkV2lkdGggPSB2aWRlb1dpZHRoO1xuICAgICAgdGhpcy5jYXJkSGVpZ2h0ID0gdmlkZW9IZWlnaHQ7XG4gICAgICB0aGlzLmNhcmRUb3AgPSBNYXRoLmZsb29yKCh0aGlzLmN1c3RvbUhlaWdodCAtIHZpZGVvSGVpZ2h0KSAvIDIpO1xuICAgICAgdGhpcy5jYXJkTGVmdCA9IE1hdGguZmxvb3IoKHRoaXMuY3VzdG9tV2lkdGggLSB2aWRlb1dpZHRoKSAvIDIpO1xuICAgICAgdGhpcy5jYW52YXNMZWZ0ID0gdGhpcy5jYXJkTGVmdCA8IDAgPyB0aGlzLmNhcmRMZWZ0IDogMDtcbiAgICB9IGVsc2Uge1xuICAgICAgdGhpcy5jYXJkV2lkdGggPSB0aGlzLmN1c3RvbVdpZHRoO1xuICAgICAgdGhpcy5jYXJkSGVpZ2h0ID0gdGhpcy5jdXN0b21IZWlnaHQ7XG4gICAgICB0aGlzLmNhcmRUb3AgPSAwO1xuICAgICAgdGhpcy5jYXJkTGVmdCA9IDA7XG4gICAgICB0aGlzLmNhbnZhc0xlZnQgPSAwO1xuICAgIH1cbiAgfVxuXG4gIGdlbmVyYXRlR3JpZCgpIHtcbiAgICB0aGlzLmdyaWQgPSBbXTtcbiAgICBmb3IgKGxldCByb3cgPSAwOyByb3cgPCB0aGlzLnJvd3M7IHJvdysrKSB7XG4gICAgICBjb25zdCByb3dDb21wb25lbnRzID0gW107XG4gICAgICBmb3IgKGxldCBjb2wgPSAwOyBjb2wgPCB0aGlzLmNvbHVtbnM7IGNvbCsrKSB7XG4gICAgICAgIGNvbnN0IGluZGV4ID0gcm93ICogdGhpcy5jb2x1bW5zICsgY29sO1xuICAgICAgICBjb25zdCBjb21wb25lbnQgPSB0aGlzLmNvbXBvbmVudHNUb1JlbmRlcltpbmRleF07XG4gICAgICAgIHJvd0NvbXBvbmVudHMucHVzaChjb21wb25lbnQpO1xuICAgICAgfVxuICAgICAgdGhpcy5ncmlkLnB1c2gocm93Q29tcG9uZW50cyk7XG4gICAgfVxuICB9XG5cbiAgY3JlYXRlSW5qZWN0b3IoaW5wdXRzOiBhbnkpIHtcbiAgICBpZiAoIXRoaXMuaW5qZWN0b3JDYWNoZS5oYXMoaW5wdXRzKSkge1xuICAgICAgY29uc3QgaW5qZWN0b3IgPSBJbmplY3Rvci5jcmVhdGUoe1xuICAgICAgICBwcm92aWRlcnM6IE9iamVjdC5rZXlzKGlucHV0cykubWFwKChrZXkpID0+ICh7IHByb3ZpZGU6IGtleSwgdXNlVmFsdWU6IGlucHV0c1trZXldIH0pKSxcbiAgICAgICAgcGFyZW50OiB0aGlzLmluamVjdG9yLFxuICAgICAgfSk7XG4gICAgICB0aGlzLmluamVjdG9yQ2FjaGUuc2V0KGlucHV0cywgaW5qZWN0b3IpO1xuICAgIH1cbiAgICAvLyBlc2xpbnQtZGlzYWJsZS1uZXh0LWxpbmUgQHR5cGVzY3JpcHQtZXNsaW50L25vLW5vbi1udWxsLWFzc2VydGlvblxuICAgIHJldHVybiB0aGlzLmluamVjdG9yQ2FjaGUuZ2V0KGlucHV0cykhO1xuICB9XG59XG4iXX0=
|
package/dist/esm2022/lib/components/display-components/loading-modal/loading-modal.component.mjs
DELETED
|
@@ -1,100 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
/**
|
|
6
|
-
* Component representing a loading modal.
|
|
7
|
-
*
|
|
8
|
-
* @selector app-loading-modal
|
|
9
|
-
* @standalone true
|
|
10
|
-
* @imports CommonModule
|
|
11
|
-
*
|
|
12
|
-
* @description
|
|
13
|
-
* This component displays a loading modal with a spinner and a loading text.
|
|
14
|
-
* It is designed to be displayed as an overlay with customizable background and text colors.
|
|
15
|
-
*
|
|
16
|
-
* @example
|
|
17
|
-
* <app-loading-modal [isVisible]="true" [backgroundColor]="'rgba(0, 0, 0, 0.5)'" [displayColor]="'white'"></app-loading-modal>
|
|
18
|
-
*
|
|
19
|
-
* @styles
|
|
20
|
-
* - .spinner: Styles for the loading spinner.
|
|
21
|
-
* - @keyframes spin: Keyframes for the spinner animation.
|
|
22
|
-
* - .modal-content: Styles for the modal content container.
|
|
23
|
-
* - .loading-text: Styles for the loading text.
|
|
24
|
-
*
|
|
25
|
-
* @inputs
|
|
26
|
-
* - `isVisible` (boolean): Determines if the modal is visible. Default is `false`.
|
|
27
|
-
* - `backgroundColor` (string): Background color of the modal. Default is `'rgba(0, 0, 0, 0.5)'`.
|
|
28
|
-
* - `displayColor` (string): Color of the loading text. Default is `'white'`.
|
|
29
|
-
*
|
|
30
|
-
* @properties
|
|
31
|
-
* - `modalContainerStyle` (object): Computed styles for the modal container.
|
|
32
|
-
* - `modalContentStyle` (object): Computed styles for the modal content.
|
|
33
|
-
* - `spinnerContainerStyle` (object): Computed styles for the spinner container.
|
|
34
|
-
* - `loadingTextStyle` (object): Computed styles for the loading text.
|
|
35
|
-
*/
|
|
36
|
-
export class LoadingModal {
|
|
37
|
-
isVisible = false;
|
|
38
|
-
backgroundColor = 'rgba(0, 0, 0, 0.5)';
|
|
39
|
-
displayColor = 'white';
|
|
40
|
-
get modalContainerStyle() {
|
|
41
|
-
return {
|
|
42
|
-
position: 'fixed',
|
|
43
|
-
top: '0',
|
|
44
|
-
left: '0',
|
|
45
|
-
width: '100%',
|
|
46
|
-
height: '100%',
|
|
47
|
-
backgroundColor: this.backgroundColor,
|
|
48
|
-
display: 'flex',
|
|
49
|
-
alignItems: 'center',
|
|
50
|
-
justifyContent: 'center',
|
|
51
|
-
zIndex: '999',
|
|
52
|
-
};
|
|
53
|
-
}
|
|
54
|
-
get modalContentStyle() {
|
|
55
|
-
return {
|
|
56
|
-
backgroundColor: this.backgroundColor,
|
|
57
|
-
borderRadius: '10px',
|
|
58
|
-
padding: '10px',
|
|
59
|
-
maxWidth: '200px',
|
|
60
|
-
textAlign: 'center',
|
|
61
|
-
};
|
|
62
|
-
}
|
|
63
|
-
get spinnerContainerStyle() {
|
|
64
|
-
return {
|
|
65
|
-
marginBottom: '20px',
|
|
66
|
-
};
|
|
67
|
-
}
|
|
68
|
-
get loadingTextStyle() {
|
|
69
|
-
return {
|
|
70
|
-
color: this.displayColor,
|
|
71
|
-
};
|
|
72
|
-
}
|
|
73
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: LoadingModal, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
74
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: LoadingModal, isStandalone: true, selector: "app-loading-modal", inputs: { isVisible: "isVisible", backgroundColor: "backgroundColor", displayColor: "displayColor" }, ngImport: i0, template: `
|
|
75
|
-
<div *ngIf="isVisible" [ngStyle]="modalContainerStyle">
|
|
76
|
-
<div [ngStyle]="modalContentStyle" class="modal-content">
|
|
77
|
-
<div class="spinner" [ngStyle]="spinnerContainerStyle"></div>
|
|
78
|
-
<div [ngStyle]="loadingTextStyle" class="loading-text">Loading...</div>
|
|
79
|
-
</div>
|
|
80
|
-
</div>
|
|
81
|
-
`, isInline: true, styles: [".spinner{border:12px solid #f3f3f3;border-top:12px solid black;border-radius:50%;width:50px;height:50px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-content{display:flex;flex-direction:column;align-items:center}.loading-text{margin-top:10px}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
82
|
-
}
|
|
83
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: LoadingModal, decorators: [{
|
|
84
|
-
type: Component,
|
|
85
|
-
args: [{ selector: 'app-loading-modal', standalone: true, imports: [CommonModule], template: `
|
|
86
|
-
<div *ngIf="isVisible" [ngStyle]="modalContainerStyle">
|
|
87
|
-
<div [ngStyle]="modalContentStyle" class="modal-content">
|
|
88
|
-
<div class="spinner" [ngStyle]="spinnerContainerStyle"></div>
|
|
89
|
-
<div [ngStyle]="loadingTextStyle" class="loading-text">Loading...</div>
|
|
90
|
-
</div>
|
|
91
|
-
</div>
|
|
92
|
-
`, styles: [".spinner{border:12px solid #f3f3f3;border-top:12px solid black;border-radius:50%;width:50px;height:50px;animation:spin 2s linear infinite}@keyframes spin{0%{transform:rotate(0)}to{transform:rotate(360deg)}}.modal-content{display:flex;flex-direction:column;align-items:center}.loading-text{margin-top:10px}\n"] }]
|
|
93
|
-
}], propDecorators: { isVisible: [{
|
|
94
|
-
type: Input
|
|
95
|
-
}], backgroundColor: [{
|
|
96
|
-
type: Input
|
|
97
|
-
}], displayColor: [{
|
|
98
|
-
type: Input
|
|
99
|
-
}] } });
|
|
100
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibG9hZGluZy1tb2RhbC5jb21wb25lbnQuanMiLCJzb3VyY2VSb290IjoiIiwic291cmNlcyI6WyIuLi8uLi8uLi8uLi8uLi8uLi8uLi9wcm9qZWN0cy9tZWRpYXNmdS1hbmd1bGFyL3NyYy9saWIvY29tcG9uZW50cy9kaXNwbGF5LWNvbXBvbmVudHMvbG9hZGluZy1tb2RhbC9sb2FkaW5nLW1vZGFsLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBRSxNQUFNLGVBQWUsQ0FBQztBQUNqRCxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0saUJBQWlCLENBQUM7OztBQVMvQzs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7O0dBOEJHO0FBMENILE1BQU0sT0FBTyxZQUFZO0lBQ2QsU0FBUyxHQUFHLEtBQUssQ0FBQztJQUNsQixlQUFlLEdBQVksb0JBQW9CLENBQUM7SUFDaEQsWUFBWSxHQUFZLE9BQU8sQ0FBQztJQUV6QyxJQUFJLG1CQUFtQjtRQUNyQixPQUFPO1lBQ0wsUUFBUSxFQUFFLE9BQU87WUFDakIsR0FBRyxFQUFFLEdBQUc7WUFDUixJQUFJLEVBQUUsR0FBRztZQUNULEtBQUssRUFBRSxNQUFNO1lBQ2IsTUFBTSxFQUFFLE1BQU07WUFDZCxlQUFlLEVBQUUsSUFBSSxDQUFDLGVBQWU7WUFDckMsT0FBTyxFQUFFLE1BQU07WUFDZixVQUFVLEVBQUUsUUFBUTtZQUNwQixjQUFjLEVBQUUsUUFBUTtZQUN4QixNQUFNLEVBQUUsS0FBSztTQUNkLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxpQkFBaUI7UUFDbkIsT0FBTztZQUNMLGVBQWUsRUFBRSxJQUFJLENBQUMsZUFBZTtZQUNyQyxZQUFZLEVBQUUsTUFBTTtZQUNwQixPQUFPLEVBQUUsTUFBTTtZQUNmLFFBQVEsRUFBRSxPQUFPO1lBQ2pCLFNBQVMsRUFBRSxRQUFRO1NBQ3BCLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxxQkFBcUI7UUFDdkIsT0FBTztZQUNMLFlBQVksRUFBRSxNQUFNO1NBQ3JCLENBQUM7SUFDSixDQUFDO0lBRUQsSUFBSSxnQkFBZ0I7UUFDbEIsT0FBTztZQUNMLEtBQUssRUFBRSxJQUFJLENBQUMsWUFBWTtTQUN6QixDQUFDO0lBQ0osQ0FBQzt1R0F4Q1UsWUFBWTsyRkFBWixZQUFZLG1MQXJDYjs7Ozs7OztHQU9ULDRYQVJTLFlBQVk7OzJGQXNDWCxZQUFZO2tCQXpDeEIsU0FBUzsrQkFDRSxtQkFBbUIsY0FDakIsSUFBSSxXQUNQLENBQUMsWUFBWSxDQUFDLFlBQ2I7Ozs7Ozs7R0FPVDs4QkErQlEsU0FBUztzQkFBakIsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQgeyBDb21wb25lbnQsIElucHV0IH0gZnJvbSAnQGFuZ3VsYXIvY29yZSc7XG5pbXBvcnQgeyBDb21tb25Nb2R1bGUgfSBmcm9tICdAYW5ndWxhci9jb21tb24nO1xuZXhwb3J0IGludGVyZmFjZSBMb2FkaW5nTW9kYWxPcHRpb25zIHtcbiAgaXNWaXNpYmxlOiBib29sZWFuO1xuICBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmc7XG4gIGRpc3BsYXlDb2xvcj86IHN0cmluZztcbn1cblxuZXhwb3J0IHR5cGUgTG9hZGluZ01vZGFsVHlwZSA9IChvcHRpb25zOiBMb2FkaW5nTW9kYWxPcHRpb25zKSA9PiBIVE1MRWxlbWVudDtcblxuLyoqXG4gKiBDb21wb25lbnQgcmVwcmVzZW50aW5nIGEgbG9hZGluZyBtb2RhbC5cbiAqXG4gKiBAc2VsZWN0b3IgYXBwLWxvYWRpbmctbW9kYWxcbiAqIEBzdGFuZGFsb25lIHRydWVcbiAqIEBpbXBvcnRzIENvbW1vbk1vZHVsZVxuICpcbiAqIEBkZXNjcmlwdGlvblxuICogVGhpcyBjb21wb25lbnQgZGlzcGxheXMgYSBsb2FkaW5nIG1vZGFsIHdpdGggYSBzcGlubmVyIGFuZCBhIGxvYWRpbmcgdGV4dC5cbiAqIEl0IGlzIGRlc2lnbmVkIHRvIGJlIGRpc3BsYXllZCBhcyBhbiBvdmVybGF5IHdpdGggY3VzdG9taXphYmxlIGJhY2tncm91bmQgYW5kIHRleHQgY29sb3JzLlxuICpcbiAqIEBleGFtcGxlXG4gKiA8YXBwLWxvYWRpbmctbW9kYWwgW2lzVmlzaWJsZV09XCJ0cnVlXCIgW2JhY2tncm91bmRDb2xvcl09XCIncmdiYSgwLCAwLCAwLCAwLjUpJ1wiIFtkaXNwbGF5Q29sb3JdPVwiJ3doaXRlJ1wiPjwvYXBwLWxvYWRpbmctbW9kYWw+XG4gKlxuICogQHN0eWxlc1xuICogLSAuc3Bpbm5lcjogU3R5bGVzIGZvciB0aGUgbG9hZGluZyBzcGlubmVyLlxuICogLSBAa2V5ZnJhbWVzIHNwaW46IEtleWZyYW1lcyBmb3IgdGhlIHNwaW5uZXIgYW5pbWF0aW9uLlxuICogLSAubW9kYWwtY29udGVudDogU3R5bGVzIGZvciB0aGUgbW9kYWwgY29udGVudCBjb250YWluZXIuXG4gKiAtIC5sb2FkaW5nLXRleHQ6IFN0eWxlcyBmb3IgdGhlIGxvYWRpbmcgdGV4dC5cbiAqXG4gKiBAaW5wdXRzXG4gKiAtIGBpc1Zpc2libGVgIChib29sZWFuKTogRGV0ZXJtaW5lcyBpZiB0aGUgbW9kYWwgaXMgdmlzaWJsZS4gRGVmYXVsdCBpcyBgZmFsc2VgLlxuICogLSBgYmFja2dyb3VuZENvbG9yYCAoc3RyaW5nKTogQmFja2dyb3VuZCBjb2xvciBvZiB0aGUgbW9kYWwuIERlZmF1bHQgaXMgYCdyZ2JhKDAsIDAsIDAsIDAuNSknYC5cbiAqIC0gYGRpc3BsYXlDb2xvcmAgKHN0cmluZyk6IENvbG9yIG9mIHRoZSBsb2FkaW5nIHRleHQuIERlZmF1bHQgaXMgYCd3aGl0ZSdgLlxuICpcbiAqIEBwcm9wZXJ0aWVzXG4gKiAtIGBtb2RhbENvbnRhaW5lclN0eWxlYCAob2JqZWN0KTogQ29tcHV0ZWQgc3R5bGVzIGZvciB0aGUgbW9kYWwgY29udGFpbmVyLlxuICogLSBgbW9kYWxDb250ZW50U3R5bGVgIChvYmplY3QpOiBDb21wdXRlZCBzdHlsZXMgZm9yIHRoZSBtb2RhbCBjb250ZW50LlxuICogLSBgc3Bpbm5lckNvbnRhaW5lclN0eWxlYCAob2JqZWN0KTogQ29tcHV0ZWQgc3R5bGVzIGZvciB0aGUgc3Bpbm5lciBjb250YWluZXIuXG4gKiAtIGBsb2FkaW5nVGV4dFN0eWxlYCAob2JqZWN0KTogQ29tcHV0ZWQgc3R5bGVzIGZvciB0aGUgbG9hZGluZyB0ZXh0LlxuICovXG5AQ29tcG9uZW50KHtcbiAgc2VsZWN0b3I6ICdhcHAtbG9hZGluZy1tb2RhbCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXYgKm5nSWY9XCJpc1Zpc2libGVcIiBbbmdTdHlsZV09XCJtb2RhbENvbnRhaW5lclN0eWxlXCI+XG4gICAgICA8ZGl2IFtuZ1N0eWxlXT1cIm1vZGFsQ29udGVudFN0eWxlXCIgY2xhc3M9XCJtb2RhbC1jb250ZW50XCI+XG4gICAgICAgIDxkaXYgY2xhc3M9XCJzcGlubmVyXCIgW25nU3R5bGVdPVwic3Bpbm5lckNvbnRhaW5lclN0eWxlXCI+PC9kaXY+XG4gICAgICAgIDxkaXYgW25nU3R5bGVdPVwibG9hZGluZ1RleHRTdHlsZVwiIGNsYXNzPVwibG9hZGluZy10ZXh0XCI+TG9hZGluZy4uLjwvZGl2PlxuICAgICAgPC9kaXY+XG4gICAgPC9kaXY+XG4gIGAsXG4gIHN0eWxlczogW1xuICAgIGBcbiAgICAgIC5zcGlubmVyIHtcbiAgICAgICAgYm9yZGVyOiAxMnB4IHNvbGlkICNmM2YzZjM7IC8qIExpZ2h0IGdyZXkgKi9cbiAgICAgICAgYm9yZGVyLXRvcDogMTJweCBzb2xpZCBibGFjazsgLyogQmxhY2sgKi9cbiAgICAgICAgYm9yZGVyLXJhZGl1czogNTAlO1xuICAgICAgICB3aWR0aDogNTBweDtcbiAgICAgICAgaGVpZ2h0OiA1MHB4O1xuICAgICAgICBhbmltYXRpb246IHNwaW4gMnMgbGluZWFyIGluZmluaXRlO1xuICAgICAgfVxuICAgICAgQGtleWZyYW1lcyBzcGluIHtcbiAgICAgICAgMCUge1xuICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDBkZWcpO1xuICAgICAgICB9XG4gICAgICAgIDEwMCUge1xuICAgICAgICAgIHRyYW5zZm9ybTogcm90YXRlKDM2MGRlZyk7XG4gICAgICAgIH1cbiAgICAgIH1cbiAgICAgIC5tb2RhbC1jb250ZW50IHtcbiAgICAgICAgZGlzcGxheTogZmxleDtcbiAgICAgICAgZmxleC1kaXJlY3Rpb246IGNvbHVtbjtcbiAgICAgICAgYWxpZ24taXRlbXM6IGNlbnRlcjtcbiAgICAgIH1cbiAgICAgIC5sb2FkaW5nLXRleHQge1xuICAgICAgICBtYXJnaW4tdG9wOiAxMHB4O1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIExvYWRpbmdNb2RhbCB7XG4gIEBJbnB1dCgpIGlzVmlzaWJsZSA9IGZhbHNlO1xuICBASW5wdXQoKSBiYWNrZ3JvdW5kQ29sb3I/OiBzdHJpbmcgPSAncmdiYSgwLCAwLCAwLCAwLjUpJztcbiAgQElucHV0KCkgZGlzcGxheUNvbG9yPzogc3RyaW5nID0gJ3doaXRlJztcblxuICBnZXQgbW9kYWxDb250YWluZXJTdHlsZSgpIHtcbiAgICByZXR1cm4ge1xuICAgICAgcG9zaXRpb246ICdmaXhlZCcsXG4gICAgICB0b3A6ICcwJyxcbiAgICAgIGxlZnQ6ICcwJyxcbiAgICAgIHdpZHRoOiAnMTAwJScsXG4gICAgICBoZWlnaHQ6ICcxMDAlJyxcbiAgICAgIGJhY2tncm91bmRDb2xvcjogdGhpcy5iYWNrZ3JvdW5kQ29sb3IsXG4gICAgICBkaXNwbGF5OiAnZmxleCcsXG4gICAgICBhbGlnbkl0ZW1zOiAnY2VudGVyJyxcbiAgICAgIGp1c3RpZnlDb250ZW50OiAnY2VudGVyJyxcbiAgICAgIHpJbmRleDogJzk5OScsXG4gICAgfTtcbiAgfVxuXG4gIGdldCBtb2RhbENvbnRlbnRTdHlsZSgpIHtcbiAgICByZXR1cm4ge1xuICAgICAgYmFja2dyb3VuZENvbG9yOiB0aGlzLmJhY2tncm91bmRDb2xvcixcbiAgICAgIGJvcmRlclJhZGl1czogJzEwcHgnLFxuICAgICAgcGFkZGluZzogJzEwcHgnLFxuICAgICAgbWF4V2lkdGg6ICcyMDBweCcsXG4gICAgICB0ZXh0QWxpZ246ICdjZW50ZXInLFxuICAgIH07XG4gIH1cblxuICBnZXQgc3Bpbm5lckNvbnRhaW5lclN0eWxlKCkge1xuICAgIHJldHVybiB7XG4gICAgICBtYXJnaW5Cb3R0b206ICcyMHB4JyxcbiAgICB9O1xuICB9XG5cbiAgZ2V0IGxvYWRpbmdUZXh0U3R5bGUoKSB7XG4gICAgcmV0dXJuIHtcbiAgICAgIGNvbG9yOiB0aGlzLmRpc3BsYXlDb2xvcixcbiAgICB9O1xuICB9XG59XG4iXX0=
|
|
@@ -1,132 +0,0 @@
|
|
|
1
|
-
import { Component, Input } from '@angular/core';
|
|
2
|
-
import { CommonModule } from '@angular/common';
|
|
3
|
-
import * as i0 from "@angular/core";
|
|
4
|
-
import * as i1 from "@angular/common";
|
|
5
|
-
/**
|
|
6
|
-
* MainAspectComponent is a standalone Angular component that adjusts its aspect ratio
|
|
7
|
-
* based on the window size and other input properties. It listens to window resize
|
|
8
|
-
* and orientation change events to dynamically update its styles.
|
|
9
|
-
*
|
|
10
|
-
* @selector app-main-aspect-component
|
|
11
|
-
* @standalone true
|
|
12
|
-
* @imports [CommonModule]
|
|
13
|
-
*
|
|
14
|
-
* @template
|
|
15
|
-
* ```html
|
|
16
|
-
* <div [ngStyle]="aspectStyles" [style.backgroundColor]="backgroundColor" class="aspect-container">
|
|
17
|
-
* <ng-content></ng-content>
|
|
18
|
-
* </div>
|
|
19
|
-
* ```
|
|
20
|
-
*
|
|
21
|
-
* @styles
|
|
22
|
-
* ```css
|
|
23
|
-
* .aspect-container {
|
|
24
|
-
* overflow: hidden;
|
|
25
|
-
* }
|
|
26
|
-
* ```
|
|
27
|
-
*
|
|
28
|
-
* @class MainAspectComponent
|
|
29
|
-
* @implements OnInit, OnDestroy, OnChanges
|
|
30
|
-
*
|
|
31
|
-
* @property {string} backgroundColor - The background color of the aspect container.
|
|
32
|
-
* @property {boolean} showControls - Flag to show or hide controls.
|
|
33
|
-
* @property {number} containerWidthFraction - Fraction of the window width for the container.
|
|
34
|
-
* @property {number} containerHeightFraction - Fraction of the window height for the container.
|
|
35
|
-
* @property {number} defaultFraction - Default fraction to adjust the height when controls are shown.
|
|
36
|
-
* @property {(isWideScreen: boolean) => void} updateIsWideScreen - Callback to update wide screen status.
|
|
37
|
-
* @property {(isMediumScreen: boolean) => void} updateIsMediumScreen - Callback to update medium screen status.
|
|
38
|
-
* @property {(isSmallScreen: boolean) => void} updateIsSmallScreen - Callback to update small screen status.
|
|
39
|
-
*
|
|
40
|
-
* @method ngOnInit - Lifecycle hook that is called after data-bound properties are initialized.
|
|
41
|
-
* @method ngOnChanges - Lifecycle hook that is called when any data-bound property changes.
|
|
42
|
-
* @method ngOnDestroy - Lifecycle hook that is called just before the component is destroyed.
|
|
43
|
-
* @method private updateAspectStyles - Updates the aspect styles based on the window size and input properties.
|
|
44
|
-
*/
|
|
45
|
-
export class MainAspectComponent {
|
|
46
|
-
backgroundColor = '';
|
|
47
|
-
showControls = true;
|
|
48
|
-
containerWidthFraction = 1;
|
|
49
|
-
containerHeightFraction = 1;
|
|
50
|
-
defaultFraction = 0.94;
|
|
51
|
-
updateIsWideScreen;
|
|
52
|
-
updateIsMediumScreen;
|
|
53
|
-
updateIsSmallScreen;
|
|
54
|
-
aspectStyles = {};
|
|
55
|
-
ngOnInit() {
|
|
56
|
-
this.updateAspectStyles();
|
|
57
|
-
window.addEventListener('resize', this.updateAspectStyles);
|
|
58
|
-
window.addEventListener('orientationchange', this.updateAspectStyles);
|
|
59
|
-
}
|
|
60
|
-
ngOnChanges(changes) {
|
|
61
|
-
if (changes['showControls'] ||
|
|
62
|
-
changes['containerWidthFraction'] ||
|
|
63
|
-
changes['containerHeightFraction'] ||
|
|
64
|
-
changes['defaultFraction']) {
|
|
65
|
-
this.updateAspectStyles();
|
|
66
|
-
}
|
|
67
|
-
}
|
|
68
|
-
ngOnDestroy() {
|
|
69
|
-
window.removeEventListener('resize', this.updateAspectStyles);
|
|
70
|
-
window.removeEventListener('orientationchange', this.updateAspectStyles);
|
|
71
|
-
}
|
|
72
|
-
updateAspectStyles = () => {
|
|
73
|
-
const windowHeight = window.innerHeight;
|
|
74
|
-
const windowWidth = window.innerWidth;
|
|
75
|
-
const parentWidth = Math.floor(this.containerWidthFraction * windowWidth);
|
|
76
|
-
const parentHeight = this.showControls
|
|
77
|
-
? Math.floor(this.containerHeightFraction * windowHeight * this.defaultFraction)
|
|
78
|
-
: Math.floor(this.containerHeightFraction * windowHeight);
|
|
79
|
-
let isWideScreen = parentWidth >= 768;
|
|
80
|
-
const isMediumScreen = parentWidth >= 576 && parentWidth < 768;
|
|
81
|
-
const isSmallScreen = parentWidth < 576;
|
|
82
|
-
if (!isWideScreen && parentWidth > 1.5 * parentHeight) {
|
|
83
|
-
isWideScreen = true;
|
|
84
|
-
}
|
|
85
|
-
this.updateIsWideScreen(isWideScreen);
|
|
86
|
-
this.updateIsMediumScreen(isMediumScreen);
|
|
87
|
-
this.updateIsSmallScreen(isSmallScreen);
|
|
88
|
-
this.aspectStyles = {
|
|
89
|
-
height: parentHeight + 'px',
|
|
90
|
-
width: parentWidth + 'px',
|
|
91
|
-
};
|
|
92
|
-
};
|
|
93
|
-
static ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MainAspectComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
|
|
94
|
-
static ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "18.2.8", type: MainAspectComponent, isStandalone: true, selector: "app-main-aspect-component", inputs: { backgroundColor: "backgroundColor", showControls: "showControls", containerWidthFraction: "containerWidthFraction", containerHeightFraction: "containerHeightFraction", defaultFraction: "defaultFraction", updateIsWideScreen: "updateIsWideScreen", updateIsMediumScreen: "updateIsMediumScreen", updateIsSmallScreen: "updateIsSmallScreen" }, usesOnChanges: true, ngImport: i0, template: `
|
|
95
|
-
<div
|
|
96
|
-
[ngStyle]="aspectStyles"
|
|
97
|
-
[style.backgroundColor]="backgroundColor"
|
|
98
|
-
class="aspect-container"
|
|
99
|
-
>
|
|
100
|
-
<ng-content></ng-content>
|
|
101
|
-
</div>
|
|
102
|
-
`, isInline: true, styles: [".aspect-container{overflow:hidden}\n"], dependencies: [{ kind: "ngmodule", type: CommonModule }, { kind: "directive", type: i1.NgStyle, selector: "[ngStyle]", inputs: ["ngStyle"] }] });
|
|
103
|
-
}
|
|
104
|
-
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.2.8", ngImport: i0, type: MainAspectComponent, decorators: [{
|
|
105
|
-
type: Component,
|
|
106
|
-
args: [{ selector: 'app-main-aspect-component', standalone: true, imports: [CommonModule], template: `
|
|
107
|
-
<div
|
|
108
|
-
[ngStyle]="aspectStyles"
|
|
109
|
-
[style.backgroundColor]="backgroundColor"
|
|
110
|
-
class="aspect-container"
|
|
111
|
-
>
|
|
112
|
-
<ng-content></ng-content>
|
|
113
|
-
</div>
|
|
114
|
-
`, styles: [".aspect-container{overflow:hidden}\n"] }]
|
|
115
|
-
}], propDecorators: { backgroundColor: [{
|
|
116
|
-
type: Input
|
|
117
|
-
}], showControls: [{
|
|
118
|
-
type: Input
|
|
119
|
-
}], containerWidthFraction: [{
|
|
120
|
-
type: Input
|
|
121
|
-
}], containerHeightFraction: [{
|
|
122
|
-
type: Input
|
|
123
|
-
}], defaultFraction: [{
|
|
124
|
-
type: Input
|
|
125
|
-
}], updateIsWideScreen: [{
|
|
126
|
-
type: Input
|
|
127
|
-
}], updateIsMediumScreen: [{
|
|
128
|
-
type: Input
|
|
129
|
-
}], updateIsSmallScreen: [{
|
|
130
|
-
type: Input
|
|
131
|
-
}] } });
|
|
132
|
-
//# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoibWFpbi1hc3BlY3QtY29tcG9uZW50LmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiIiLCJzb3VyY2VzIjpbIi4uLy4uLy4uLy4uLy4uLy4uLy4uL3Byb2plY3RzL21lZGlhc2Z1LWFuZ3VsYXIvc3JjL2xpYi9jb21wb25lbnRzL2Rpc3BsYXktY29tcG9uZW50cy9tYWluLWFzcGVjdC1jb21wb25lbnQvbWFpbi1hc3BlY3QtY29tcG9uZW50LmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiQUFBQSxPQUFPLEVBQUUsU0FBUyxFQUFFLEtBQUssRUFBK0MsTUFBTSxlQUFlLENBQUM7QUFDOUYsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLGlCQUFpQixDQUFDOzs7QUFlL0M7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7Ozs7OztHQXVDRztBQXNCSCxNQUFNLE9BQU8sbUJBQW1CO0lBQ3JCLGVBQWUsR0FBRyxFQUFFLENBQUM7SUFDckIsWUFBWSxHQUFHLElBQUksQ0FBQztJQUNwQixzQkFBc0IsR0FBRyxDQUFDLENBQUM7SUFDM0IsdUJBQXVCLEdBQUcsQ0FBQyxDQUFDO0lBQzVCLGVBQWUsR0FBRyxJQUFJLENBQUM7SUFDdkIsa0JBQWtCLENBQW1DO0lBQ3JELG9CQUFvQixDQUFxQztJQUN6RCxtQkFBbUIsQ0FBb0M7SUFFaEUsWUFBWSxHQUEyQixFQUFFLENBQUM7SUFFMUMsUUFBUTtRQUNOLElBQUksQ0FBQyxrQkFBa0IsRUFBRSxDQUFDO1FBRTFCLE1BQU0sQ0FBQyxnQkFBZ0IsQ0FBQyxRQUFRLEVBQUUsSUFBSSxDQUFDLGtCQUFrQixDQUFDLENBQUM7UUFDM0QsTUFBTSxDQUFDLGdCQUFnQixDQUFDLG1CQUFtQixFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO0lBQ3hFLENBQUM7SUFFRCxXQUFXLENBQUMsT0FBc0I7UUFDaEMsSUFDRSxPQUFPLENBQUMsY0FBYyxDQUFDO1lBQ3ZCLE9BQU8sQ0FBQyx3QkFBd0IsQ0FBQztZQUNqQyxPQUFPLENBQUMseUJBQXlCLENBQUM7WUFDbEMsT0FBTyxDQUFDLGlCQUFpQixDQUFDLEVBQzFCLENBQUM7WUFDRCxJQUFJLENBQUMsa0JBQWtCLEVBQUUsQ0FBQztRQUM1QixDQUFDO0lBQ0gsQ0FBQztJQUVELFdBQVc7UUFDVCxNQUFNLENBQUMsbUJBQW1CLENBQUMsUUFBUSxFQUFFLElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxDQUFDO1FBQzlELE1BQU0sQ0FBQyxtQkFBbUIsQ0FBQyxtQkFBbUIsRUFBRSxJQUFJLENBQUMsa0JBQWtCLENBQUMsQ0FBQztJQUMzRSxDQUFDO0lBRU8sa0JBQWtCLEdBQUcsR0FBRyxFQUFFO1FBQ2hDLE1BQU0sWUFBWSxHQUFHLE1BQU0sQ0FBQyxXQUFXLENBQUM7UUFDeEMsTUFBTSxXQUFXLEdBQUcsTUFBTSxDQUFDLFVBQVUsQ0FBQztRQUV0QyxNQUFNLFdBQVcsR0FBRyxJQUFJLENBQUMsS0FBSyxDQUFDLElBQUksQ0FBQyxzQkFBc0IsR0FBRyxXQUFXLENBQUMsQ0FBQztRQUMxRSxNQUFNLFlBQVksR0FBRyxJQUFJLENBQUMsWUFBWTtZQUNwQyxDQUFDLENBQUMsSUFBSSxDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsdUJBQXVCLEdBQUcsWUFBWSxHQUFHLElBQUksQ0FBQyxlQUFlLENBQUM7WUFDaEYsQ0FBQyxDQUFDLElBQUksQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLHVCQUF1QixHQUFHLFlBQVksQ0FBQyxDQUFDO1FBRTVELElBQUksWUFBWSxHQUFHLFdBQVcsSUFBSSxHQUFHLENBQUM7UUFDdEMsTUFBTSxjQUFjLEdBQUcsV0FBVyxJQUFJLEdBQUcsSUFBSSxXQUFXLEdBQUcsR0FBRyxDQUFDO1FBQy9ELE1BQU0sYUFBYSxHQUFHLFdBQVcsR0FBRyxHQUFHLENBQUM7UUFFeEMsSUFBSSxDQUFDLFlBQVksSUFBSSxXQUFXLEdBQUcsR0FBRyxHQUFHLFlBQVksRUFBRSxDQUFDO1lBQ3RELFlBQVksR0FBRyxJQUFJLENBQUM7UUFDdEIsQ0FBQztRQUVELElBQUksQ0FBQyxrQkFBa0IsQ0FBQyxZQUFZLENBQUMsQ0FBQztRQUN0QyxJQUFJLENBQUMsb0JBQW9CLENBQUMsY0FBYyxDQUFDLENBQUM7UUFDMUMsSUFBSSxDQUFDLG1CQUFtQixDQUFDLGFBQWEsQ0FBQyxDQUFDO1FBRXhDLElBQUksQ0FBQyxZQUFZLEdBQUc7WUFDbEIsTUFBTSxFQUFFLFlBQVksR0FBRyxJQUFJO1lBQzNCLEtBQUssRUFBRSxXQUFXLEdBQUcsSUFBSTtTQUMxQixDQUFDO0lBQ0osQ0FBQyxDQUFDO3VHQTVEUyxtQkFBbUI7MkZBQW5CLG1CQUFtQixzY0FqQnBCOzs7Ozs7OztHQVFULDZHQVRTLFlBQVk7OzJGQWtCWCxtQkFBbUI7a0JBckIvQixTQUFTOytCQUNFLDJCQUEyQixjQUN6QixJQUFJLFdBQ1AsQ0FBQyxZQUFZLENBQUMsWUFDYjs7Ozs7Ozs7R0FRVDs4QkFVUSxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLFlBQVk7c0JBQXBCLEtBQUs7Z0JBQ0csc0JBQXNCO3NCQUE5QixLQUFLO2dCQUNHLHVCQUF1QjtzQkFBL0IsS0FBSztnQkFDRyxlQUFlO3NCQUF2QixLQUFLO2dCQUNHLGtCQUFrQjtzQkFBMUIsS0FBSztnQkFDRyxvQkFBb0I7c0JBQTVCLEtBQUs7Z0JBQ0csbUJBQW1CO3NCQUEzQixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHsgQ29tcG9uZW50LCBJbnB1dCwgT25Jbml0LCBPbkRlc3Ryb3ksIE9uQ2hhbmdlcywgU2ltcGxlQ2hhbmdlcyB9IGZyb20gJ0Bhbmd1bGFyL2NvcmUnO1xuaW1wb3J0IHsgQ29tbW9uTW9kdWxlIH0gZnJvbSAnQGFuZ3VsYXIvY29tbW9uJztcblxuZXhwb3J0IGludGVyZmFjZSBNYWluQXNwZWN0Q29tcG9uZW50T3B0aW9ucyB7XG4gIGJhY2tncm91bmRDb2xvcj86IHN0cmluZztcbiAgc2hvd0NvbnRyb2xzPzogYm9vbGVhbjtcbiAgY29udGFpbmVyV2lkdGhGcmFjdGlvbj86IG51bWJlcjtcbiAgY29udGFpbmVySGVpZ2h0RnJhY3Rpb24/OiBudW1iZXI7XG4gIGRlZmF1bHRGcmFjdGlvbj86IG51bWJlcjtcbiAgdXBkYXRlSXNXaWRlU2NyZWVuOiAoaXNXaWRlU2NyZWVuOiBib29sZWFuKSA9PiB2b2lkO1xuICB1cGRhdGVJc01lZGl1bVNjcmVlbjogKGlzTWVkaXVtU2NyZWVuOiBib29sZWFuKSA9PiB2b2lkO1xuICB1cGRhdGVJc1NtYWxsU2NyZWVuOiAoaXNTbWFsbFNjcmVlbjogYm9vbGVhbikgPT4gdm9pZDtcbn1cblxuZXhwb3J0IHR5cGUgTWFpbkFzcGVjdENvbXBvbmVudFR5cGUgPSAob3B0aW9uczogTWFpbkFzcGVjdENvbXBvbmVudE9wdGlvbnMpID0+IEhUTUxFbGVtZW50O1xuXG4vKipcbiAqIE1haW5Bc3BlY3RDb21wb25lbnQgaXMgYSBzdGFuZGFsb25lIEFuZ3VsYXIgY29tcG9uZW50IHRoYXQgYWRqdXN0cyBpdHMgYXNwZWN0IHJhdGlvXG4gKiBiYXNlZCBvbiB0aGUgd2luZG93IHNpemUgYW5kIG90aGVyIGlucHV0IHByb3BlcnRpZXMuIEl0IGxpc3RlbnMgdG8gd2luZG93IHJlc2l6ZVxuICogYW5kIG9yaWVudGF0aW9uIGNoYW5nZSBldmVudHMgdG8gZHluYW1pY2FsbHkgdXBkYXRlIGl0cyBzdHlsZXMuXG4gKlxuICogQHNlbGVjdG9yIGFwcC1tYWluLWFzcGVjdC1jb21wb25lbnRcbiAqIEBzdGFuZGFsb25lIHRydWVcbiAqIEBpbXBvcnRzIFtDb21tb25Nb2R1bGVdXG4gKlxuICogQHRlbXBsYXRlXG4gKiBgYGBodG1sXG4gKiA8ZGl2IFtuZ1N0eWxlXT1cImFzcGVjdFN0eWxlc1wiIFtzdHlsZS5iYWNrZ3JvdW5kQ29sb3JdPVwiYmFja2dyb3VuZENvbG9yXCIgY2xhc3M9XCJhc3BlY3QtY29udGFpbmVyXCI+XG4gKiAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAqIDwvZGl2PlxuICogYGBgXG4gKlxuICogQHN0eWxlc1xuICogYGBgY3NzXG4gKiAuYXNwZWN0LWNvbnRhaW5lciB7XG4gKiAgIG92ZXJmbG93OiBoaWRkZW47XG4gKiB9XG4gKiBgYGBcbiAqXG4gKiBAY2xhc3MgTWFpbkFzcGVjdENvbXBvbmVudFxuICogQGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3ksIE9uQ2hhbmdlc1xuICpcbiAqIEBwcm9wZXJ0eSB7c3RyaW5nfSBiYWNrZ3JvdW5kQ29sb3IgLSBUaGUgYmFja2dyb3VuZCBjb2xvciBvZiB0aGUgYXNwZWN0IGNvbnRhaW5lci5cbiAqIEBwcm9wZXJ0eSB7Ym9vbGVhbn0gc2hvd0NvbnRyb2xzIC0gRmxhZyB0byBzaG93IG9yIGhpZGUgY29udHJvbHMuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY29udGFpbmVyV2lkdGhGcmFjdGlvbiAtIEZyYWN0aW9uIG9mIHRoZSB3aW5kb3cgd2lkdGggZm9yIHRoZSBjb250YWluZXIuXG4gKiBAcHJvcGVydHkge251bWJlcn0gY29udGFpbmVySGVpZ2h0RnJhY3Rpb24gLSBGcmFjdGlvbiBvZiB0aGUgd2luZG93IGhlaWdodCBmb3IgdGhlIGNvbnRhaW5lci5cbiAqIEBwcm9wZXJ0eSB7bnVtYmVyfSBkZWZhdWx0RnJhY3Rpb24gLSBEZWZhdWx0IGZyYWN0aW9uIHRvIGFkanVzdCB0aGUgaGVpZ2h0IHdoZW4gY29udHJvbHMgYXJlIHNob3duLlxuICogQHByb3BlcnR5IHsoaXNXaWRlU2NyZWVuOiBib29sZWFuKSA9PiB2b2lkfSB1cGRhdGVJc1dpZGVTY3JlZW4gLSBDYWxsYmFjayB0byB1cGRhdGUgd2lkZSBzY3JlZW4gc3RhdHVzLlxuICogQHByb3BlcnR5IHsoaXNNZWRpdW1TY3JlZW46IGJvb2xlYW4pID0+IHZvaWR9IHVwZGF0ZUlzTWVkaXVtU2NyZWVuIC0gQ2FsbGJhY2sgdG8gdXBkYXRlIG1lZGl1bSBzY3JlZW4gc3RhdHVzLlxuICogQHByb3BlcnR5IHsoaXNTbWFsbFNjcmVlbjogYm9vbGVhbikgPT4gdm9pZH0gdXBkYXRlSXNTbWFsbFNjcmVlbiAtIENhbGxiYWNrIHRvIHVwZGF0ZSBzbWFsbCBzY3JlZW4gc3RhdHVzLlxuICpcbiAqIEBtZXRob2QgbmdPbkluaXQgLSBMaWZlY3ljbGUgaG9vayB0aGF0IGlzIGNhbGxlZCBhZnRlciBkYXRhLWJvdW5kIHByb3BlcnRpZXMgYXJlIGluaXRpYWxpemVkLlxuICogQG1ldGhvZCBuZ09uQ2hhbmdlcyAtIExpZmVjeWNsZSBob29rIHRoYXQgaXMgY2FsbGVkIHdoZW4gYW55IGRhdGEtYm91bmQgcHJvcGVydHkgY2hhbmdlcy5cbiAqIEBtZXRob2QgbmdPbkRlc3Ryb3kgLSBMaWZlY3ljbGUgaG9vayB0aGF0IGlzIGNhbGxlZCBqdXN0IGJlZm9yZSB0aGUgY29tcG9uZW50IGlzIGRlc3Ryb3llZC5cbiAqIEBtZXRob2QgcHJpdmF0ZSB1cGRhdGVBc3BlY3RTdHlsZXMgLSBVcGRhdGVzIHRoZSBhc3BlY3Qgc3R5bGVzIGJhc2VkIG9uIHRoZSB3aW5kb3cgc2l6ZSBhbmQgaW5wdXQgcHJvcGVydGllcy5cbiAqL1xuQENvbXBvbmVudCh7XG4gIHNlbGVjdG9yOiAnYXBwLW1haW4tYXNwZWN0LWNvbXBvbmVudCcsXG4gIHN0YW5kYWxvbmU6IHRydWUsXG4gIGltcG9ydHM6IFtDb21tb25Nb2R1bGVdLFxuICB0ZW1wbGF0ZTogYFxuICAgIDxkaXZcbiAgICAgIFtuZ1N0eWxlXT1cImFzcGVjdFN0eWxlc1wiXG4gICAgICBbc3R5bGUuYmFja2dyb3VuZENvbG9yXT1cImJhY2tncm91bmRDb2xvclwiXG4gICAgICBjbGFzcz1cImFzcGVjdC1jb250YWluZXJcIlxuICAgID5cbiAgICAgIDxuZy1jb250ZW50PjwvbmctY29udGVudD5cbiAgICA8L2Rpdj5cbiAgYCxcbiAgc3R5bGVzOiBbXG4gICAgYFxuICAgICAgLmFzcGVjdC1jb250YWluZXIge1xuICAgICAgICBvdmVyZmxvdzogaGlkZGVuO1xuICAgICAgfVxuICAgIGAsXG4gIF0sXG59KVxuZXhwb3J0IGNsYXNzIE1haW5Bc3BlY3RDb21wb25lbnQgaW1wbGVtZW50cyBPbkluaXQsIE9uRGVzdHJveSwgT25DaGFuZ2VzIHtcbiAgQElucHV0KCkgYmFja2dyb3VuZENvbG9yID0gJyc7XG4gIEBJbnB1dCgpIHNob3dDb250cm9scyA9IHRydWU7XG4gIEBJbnB1dCgpIGNvbnRhaW5lcldpZHRoRnJhY3Rpb24gPSAxO1xuICBASW5wdXQoKSBjb250YWluZXJIZWlnaHRGcmFjdGlvbiA9IDE7XG4gIEBJbnB1dCgpIGRlZmF1bHRGcmFjdGlvbiA9IDAuOTQ7XG4gIEBJbnB1dCgpIHVwZGF0ZUlzV2lkZVNjcmVlbiE6IChpc1dpZGVTY3JlZW46IGJvb2xlYW4pID0+IHZvaWQ7XG4gIEBJbnB1dCgpIHVwZGF0ZUlzTWVkaXVtU2NyZWVuITogKGlzTWVkaXVtU2NyZWVuOiBib29sZWFuKSA9PiB2b2lkO1xuICBASW5wdXQoKSB1cGRhdGVJc1NtYWxsU2NyZWVuITogKGlzU21hbGxTY3JlZW46IGJvb2xlYW4pID0+IHZvaWQ7XG5cbiAgYXNwZWN0U3R5bGVzOiB7IFtrZXk6IHN0cmluZ106IGFueSB9ID0ge307XG5cbiAgbmdPbkluaXQoKSB7XG4gICAgdGhpcy51cGRhdGVBc3BlY3RTdHlsZXMoKTtcblxuICAgIHdpbmRvdy5hZGRFdmVudExpc3RlbmVyKCdyZXNpemUnLCB0aGlzLnVwZGF0ZUFzcGVjdFN0eWxlcyk7XG4gICAgd2luZG93LmFkZEV2ZW50TGlzdGVuZXIoJ29yaWVudGF0aW9uY2hhbmdlJywgdGhpcy51cGRhdGVBc3BlY3RTdHlsZXMpO1xuICB9XG5cbiAgbmdPbkNoYW5nZXMoY2hhbmdlczogU2ltcGxlQ2hhbmdlcykge1xuICAgIGlmIChcbiAgICAgIGNoYW5nZXNbJ3Nob3dDb250cm9scyddIHx8XG4gICAgICBjaGFuZ2VzWydjb250YWluZXJXaWR0aEZyYWN0aW9uJ10gfHxcbiAgICAgIGNoYW5nZXNbJ2NvbnRhaW5lckhlaWdodEZyYWN0aW9uJ10gfHxcbiAgICAgIGNoYW5nZXNbJ2RlZmF1bHRGcmFjdGlvbiddXG4gICAgKSB7XG4gICAgICB0aGlzLnVwZGF0ZUFzcGVjdFN0eWxlcygpO1xuICAgIH1cbiAgfVxuXG4gIG5nT25EZXN0cm95KCkge1xuICAgIHdpbmRvdy5yZW1vdmVFdmVudExpc3RlbmVyKCdyZXNpemUnLCB0aGlzLnVwZGF0ZUFzcGVjdFN0eWxlcyk7XG4gICAgd2luZG93LnJlbW92ZUV2ZW50TGlzdGVuZXIoJ29yaWVudGF0aW9uY2hhbmdlJywgdGhpcy51cGRhdGVBc3BlY3RTdHlsZXMpO1xuICB9XG5cbiAgcHJpdmF0ZSB1cGRhdGVBc3BlY3RTdHlsZXMgPSAoKSA9PiB7XG4gICAgY29uc3Qgd2luZG93SGVpZ2h0ID0gd2luZG93LmlubmVySGVpZ2h0O1xuICAgIGNvbnN0IHdpbmRvd1dpZHRoID0gd2luZG93LmlubmVyV2lkdGg7XG5cbiAgICBjb25zdCBwYXJlbnRXaWR0aCA9IE1hdGguZmxvb3IodGhpcy5jb250YWluZXJXaWR0aEZyYWN0aW9uICogd2luZG93V2lkdGgpO1xuICAgIGNvbnN0IHBhcmVudEhlaWdodCA9IHRoaXMuc2hvd0NvbnRyb2xzXG4gICAgICA/IE1hdGguZmxvb3IodGhpcy5jb250YWluZXJIZWlnaHRGcmFjdGlvbiAqIHdpbmRvd0hlaWdodCAqIHRoaXMuZGVmYXVsdEZyYWN0aW9uKVxuICAgICAgOiBNYXRoLmZsb29yKHRoaXMuY29udGFpbmVySGVpZ2h0RnJhY3Rpb24gKiB3aW5kb3dIZWlnaHQpO1xuXG4gICAgbGV0IGlzV2lkZVNjcmVlbiA9IHBhcmVudFdpZHRoID49IDc2ODtcbiAgICBjb25zdCBpc01lZGl1bVNjcmVlbiA9IHBhcmVudFdpZHRoID49IDU3NiAmJiBwYXJlbnRXaWR0aCA8IDc2ODtcbiAgICBjb25zdCBpc1NtYWxsU2NyZWVuID0gcGFyZW50V2lkdGggPCA1NzY7XG5cbiAgICBpZiAoIWlzV2lkZVNjcmVlbiAmJiBwYXJlbnRXaWR0aCA+IDEuNSAqIHBhcmVudEhlaWdodCkge1xuICAgICAgaXNXaWRlU2NyZWVuID0gdHJ1ZTtcbiAgICB9XG5cbiAgICB0aGlzLnVwZGF0ZUlzV2lkZVNjcmVlbihpc1dpZGVTY3JlZW4pO1xuICAgIHRoaXMudXBkYXRlSXNNZWRpdW1TY3JlZW4oaXNNZWRpdW1TY3JlZW4pO1xuICAgIHRoaXMudXBkYXRlSXNTbWFsbFNjcmVlbihpc1NtYWxsU2NyZWVuKTtcblxuICAgIHRoaXMuYXNwZWN0U3R5bGVzID0ge1xuICAgICAgaGVpZ2h0OiBwYXJlbnRIZWlnaHQgKyAncHgnLFxuICAgICAgd2lkdGg6IHBhcmVudFdpZHRoICsgJ3B4JyxcbiAgICB9O1xuICB9O1xufVxuIl19
|