@authsignal/browser 0.0.19 → 0.0.20

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/dist/index.js CHANGED
@@ -498,36 +498,2798 @@ if (typeof document !== 'undefined') {
498
498
  }
499
499
  }
500
500
 
501
+ /*
502
+ * File: iframeResizer.js
503
+ * Desc: Force iframes to size to content.
504
+ * Requires: iframeResizer.contentWindow.js to be loaded into the target frame.
505
+ * Doc: https://github.com/davidjbradshaw/iframe-resizer
506
+ * Author: David J. Bradshaw - dave@bradshaw.net
507
+ * Contributor: Jure Mav - jure.mav@gmail.com
508
+ * Contributor: Reed Dadoune - reed@dadoune.com
509
+ */
510
+ (function (undefined$1) {
511
+ if (typeof window === 'undefined') return // don't run for server side render
512
+
513
+ var count = 0,
514
+ logEnabled = false,
515
+ hiddenCheckEnabled = false,
516
+ msgHeader = 'message',
517
+ msgHeaderLen = msgHeader.length,
518
+ msgId = '[iFrameSizer]', // Must match iframe msg ID
519
+ msgIdLen = msgId.length,
520
+ pagePosition = null,
521
+ requestAnimationFrame = window.requestAnimationFrame,
522
+ resetRequiredMethods = Object.freeze({
523
+ max: 1,
524
+ scroll: 1,
525
+ bodyScroll: 1,
526
+ documentElementScroll: 1
527
+ }),
528
+ settings = {},
529
+ timer = null,
530
+ defaults = Object.freeze({
531
+ autoResize: true,
532
+ bodyBackground: null,
533
+ bodyMargin: null,
534
+ bodyMarginV1: 8,
535
+ bodyPadding: null,
536
+ checkOrigin: true,
537
+ inPageLinks: false,
538
+ enablePublicMethods: true,
539
+ heightCalculationMethod: 'bodyOffset',
540
+ id: 'iFrameResizer',
541
+ interval: 32,
542
+ log: false,
543
+ maxHeight: Infinity,
544
+ maxWidth: Infinity,
545
+ minHeight: 0,
546
+ minWidth: 0,
547
+ mouseEvents: true,
548
+ resizeFrom: 'parent',
549
+ scrolling: false,
550
+ sizeHeight: true,
551
+ sizeWidth: false,
552
+ warningTimeout: 5000,
553
+ tolerance: 0,
554
+ widthCalculationMethod: 'scroll',
555
+ onClose: function () {
556
+ return true
557
+ },
558
+ onClosed: function () {},
559
+ onInit: function () {},
560
+ onMessage: function () {
561
+ warn('onMessage function not defined');
562
+ },
563
+ onMouseEnter: function () {},
564
+ onMouseLeave: function () {},
565
+ onResized: function () {},
566
+ onScroll: function () {
567
+ return true
568
+ }
569
+ });
570
+
571
+ function getMutationObserver() {
572
+ return (
573
+ window.MutationObserver ||
574
+ window.WebKitMutationObserver ||
575
+ window.MozMutationObserver
576
+ )
577
+ }
578
+
579
+ function addEventListener(el, evt, func) {
580
+ el.addEventListener(evt, func, false);
581
+ }
582
+
583
+ function removeEventListener(el, evt, func) {
584
+ el.removeEventListener(evt, func, false);
585
+ }
586
+
587
+ function setupRequestAnimationFrame() {
588
+ var vendors = ['moz', 'webkit', 'o', 'ms'];
589
+ var x;
590
+
591
+ // Remove vendor prefixing if prefixed and break early if not
592
+ for (x = 0; x < vendors.length && !requestAnimationFrame; x += 1) {
593
+ requestAnimationFrame = window[vendors[x] + 'RequestAnimationFrame'];
594
+ }
595
+
596
+ if (requestAnimationFrame) {
597
+ // Firefox extension content-scripts have a globalThis object that is not the same as window.
598
+ // Binding `requestAnimationFrame` to window allows the function to work and prevents errors
599
+ // being thrown when run in that context, and should be a no-op in every other context.
600
+ requestAnimationFrame = requestAnimationFrame.bind(window);
601
+ } else {
602
+ log('setup', 'RequestAnimationFrame not supported');
603
+ }
604
+ }
605
+
606
+ function getMyID(iframeId) {
607
+ var retStr = 'Host page: ' + iframeId;
608
+
609
+ if (window.top !== window.self) {
610
+ retStr =
611
+ window.parentIFrame && window.parentIFrame.getId
612
+ ? window.parentIFrame.getId() + ': ' + iframeId
613
+ : 'Nested host page: ' + iframeId;
614
+ }
615
+
616
+ return retStr
617
+ }
618
+
619
+ function formatLogHeader(iframeId) {
620
+ return msgId + '[' + getMyID(iframeId) + ']'
621
+ }
622
+
623
+ function isLogEnabled(iframeId) {
624
+ return settings[iframeId] ? settings[iframeId].log : logEnabled
625
+ }
626
+
627
+ function log(iframeId, msg) {
628
+ output('log', iframeId, msg, isLogEnabled(iframeId));
629
+ }
630
+
631
+ function info(iframeId, msg) {
632
+ output('info', iframeId, msg, isLogEnabled(iframeId));
633
+ }
634
+
635
+ function warn(iframeId, msg) {
636
+ output('warn', iframeId, msg, true);
637
+ }
638
+
639
+ function output(type, iframeId, msg, enabled) {
640
+ if (true === enabled && 'object' === typeof window.console) {
641
+ // eslint-disable-next-line no-console
642
+ console[type](formatLogHeader(iframeId), msg);
643
+ }
644
+ }
645
+
646
+ function iFrameListener(event) {
647
+ function resizeIFrame() {
648
+ function resize() {
649
+ setSize(messageData);
650
+ setPagePosition(iframeId);
651
+ on('onResized', messageData);
652
+ }
653
+
654
+ ensureInRange('Height');
655
+ ensureInRange('Width');
656
+
657
+ syncResize(resize, messageData, 'init');
658
+ }
659
+
660
+ function processMsg() {
661
+ var data = msg.slice(msgIdLen).split(':');
662
+ var height = data[1] ? parseInt(data[1], 10) : 0;
663
+ var iframe = settings[data[0]] && settings[data[0]].iframe;
664
+ var compStyle = getComputedStyle(iframe);
665
+
666
+ return {
667
+ iframe: iframe,
668
+ id: data[0],
669
+ height: height + getPaddingEnds(compStyle) + getBorderEnds(compStyle),
670
+ width: data[2],
671
+ type: data[3]
672
+ }
673
+ }
674
+
675
+ function getPaddingEnds(compStyle) {
676
+ if (compStyle.boxSizing !== 'border-box') {
677
+ return 0
678
+ }
679
+ var top = compStyle.paddingTop ? parseInt(compStyle.paddingTop, 10) : 0;
680
+ var bot = compStyle.paddingBottom
681
+ ? parseInt(compStyle.paddingBottom, 10)
682
+ : 0;
683
+ return top + bot
684
+ }
685
+
686
+ function getBorderEnds(compStyle) {
687
+ if (compStyle.boxSizing !== 'border-box') {
688
+ return 0
689
+ }
690
+ var top = compStyle.borderTopWidth
691
+ ? parseInt(compStyle.borderTopWidth, 10)
692
+ : 0;
693
+ var bot = compStyle.borderBottomWidth
694
+ ? parseInt(compStyle.borderBottomWidth, 10)
695
+ : 0;
696
+ return top + bot
697
+ }
698
+
699
+ function ensureInRange(Dimension) {
700
+ var max = Number(settings[iframeId]['max' + Dimension]),
701
+ min = Number(settings[iframeId]['min' + Dimension]),
702
+ dimension = Dimension.toLowerCase(),
703
+ size = Number(messageData[dimension]);
704
+
705
+ log(iframeId, 'Checking ' + dimension + ' is in range ' + min + '-' + max);
706
+
707
+ if (size < min) {
708
+ size = min;
709
+ log(iframeId, 'Set ' + dimension + ' to min value');
710
+ }
711
+
712
+ if (size > max) {
713
+ size = max;
714
+ log(iframeId, 'Set ' + dimension + ' to max value');
715
+ }
716
+
717
+ messageData[dimension] = '' + size;
718
+ }
719
+
720
+ function isMessageFromIFrame() {
721
+ function checkAllowedOrigin() {
722
+ function checkList() {
723
+ var i = 0,
724
+ retCode = false;
725
+
726
+ log(
727
+ iframeId,
728
+ 'Checking connection is from allowed list of origins: ' +
729
+ checkOrigin
730
+ );
731
+
732
+ for (; i < checkOrigin.length; i++) {
733
+ if (checkOrigin[i] === origin) {
734
+ retCode = true;
735
+ break
736
+ }
737
+ }
738
+ return retCode
739
+ }
740
+
741
+ function checkSingle() {
742
+ var remoteHost = settings[iframeId] && settings[iframeId].remoteHost;
743
+ log(iframeId, 'Checking connection is from: ' + remoteHost);
744
+ return origin === remoteHost
745
+ }
746
+
747
+ return checkOrigin.constructor === Array ? checkList() : checkSingle()
748
+ }
749
+
750
+ var origin = event.origin,
751
+ checkOrigin = settings[iframeId] && settings[iframeId].checkOrigin;
752
+
753
+ if (checkOrigin && '' + origin !== 'null' && !checkAllowedOrigin()) {
754
+ throw new Error(
755
+ 'Unexpected message received from: ' +
756
+ origin +
757
+ ' for ' +
758
+ messageData.iframe.id +
759
+ '. Message was: ' +
760
+ event.data +
761
+ '. This error can be disabled by setting the checkOrigin: false option or by providing of array of trusted domains.'
762
+ )
763
+ }
764
+
765
+ return true
766
+ }
767
+
768
+ function isMessageForUs() {
769
+ return (
770
+ msgId === ('' + msg).slice(0, msgIdLen) &&
771
+ msg.slice(msgIdLen).split(':')[0] in settings
772
+ ) // ''+Protects against non-string msg
773
+ }
774
+
775
+ function isMessageFromMetaParent() {
776
+ // Test if this message is from a parent above us. This is an ugly test, however, updating
777
+ // the message format would break backwards compatibility.
778
+ var retCode = messageData.type in { true: 1, false: 1, undefined: 1 };
779
+
780
+ if (retCode) {
781
+ log(iframeId, 'Ignoring init message from meta parent page');
782
+ }
783
+
784
+ return retCode
785
+ }
786
+
787
+ function getMsgBody(offset) {
788
+ return msg.slice(msg.indexOf(':') + msgHeaderLen + offset)
789
+ }
790
+
791
+ function forwardMsgFromIFrame(msgBody) {
792
+ log(
793
+ iframeId,
794
+ 'onMessage passed: {iframe: ' +
795
+ messageData.iframe.id +
796
+ ', message: ' +
797
+ msgBody +
798
+ '}'
799
+ );
800
+
801
+ on('onMessage', {
802
+ iframe: messageData.iframe,
803
+ message: JSON.parse(msgBody)
804
+ });
805
+
806
+ log(iframeId, '--');
807
+ }
808
+
809
+ function getPageInfo() {
810
+ var bodyPosition = document.body.getBoundingClientRect(),
811
+ iFramePosition = messageData.iframe.getBoundingClientRect();
812
+
813
+ return JSON.stringify({
814
+ iframeHeight: iFramePosition.height,
815
+ iframeWidth: iFramePosition.width,
816
+ clientHeight: Math.max(
817
+ document.documentElement.clientHeight,
818
+ window.innerHeight || 0
819
+ ),
820
+ clientWidth: Math.max(
821
+ document.documentElement.clientWidth,
822
+ window.innerWidth || 0
823
+ ),
824
+ offsetTop: parseInt(iFramePosition.top - bodyPosition.top, 10),
825
+ offsetLeft: parseInt(iFramePosition.left - bodyPosition.left, 10),
826
+ scrollTop: window.pageYOffset,
827
+ scrollLeft: window.pageXOffset,
828
+ documentHeight: document.documentElement.clientHeight,
829
+ documentWidth: document.documentElement.clientWidth,
830
+ windowHeight: window.innerHeight,
831
+ windowWidth: window.innerWidth
832
+ })
833
+ }
834
+
835
+ function sendPageInfoToIframe(iframe, iframeId) {
836
+ function debouncedTrigger() {
837
+ trigger('Send Page Info', 'pageInfo:' + getPageInfo(), iframe, iframeId);
838
+ }
839
+ debounceFrameEvents(debouncedTrigger, 32, iframeId);
840
+ }
841
+
842
+ function startPageInfoMonitor() {
843
+ function setListener(type, func) {
844
+ function sendPageInfo() {
845
+ if (settings[id]) {
846
+ sendPageInfoToIframe(settings[id].iframe, id);
847
+ } else {
848
+ stop();
849
+ }
850
+ }
851
+ ['scroll', 'resize'].forEach(function (evt) {
852
+ log(id, type + evt + ' listener for sendPageInfo');
853
+ func(window, evt, sendPageInfo);
854
+ });
855
+ }
856
+
857
+ function stop() {
858
+ setListener('Remove ', removeEventListener);
859
+ }
860
+
861
+ function start() {
862
+ setListener('Add ', addEventListener);
863
+ }
864
+
865
+ var id = iframeId; // Create locally scoped copy of iFrame ID
866
+
867
+ start();
868
+
869
+ if (settings[id]) {
870
+ settings[id].stopPageInfo = stop;
871
+ }
872
+ }
873
+
874
+ function stopPageInfoMonitor() {
875
+ if (settings[iframeId] && settings[iframeId].stopPageInfo) {
876
+ settings[iframeId].stopPageInfo();
877
+ delete settings[iframeId].stopPageInfo;
878
+ }
879
+ }
880
+
881
+ function checkIFrameExists() {
882
+ var retBool = true;
883
+
884
+ if (null === messageData.iframe) {
885
+ warn(iframeId, 'IFrame (' + messageData.id + ') not found');
886
+ retBool = false;
887
+ }
888
+ return retBool
889
+ }
890
+
891
+ function getElementPosition(target) {
892
+ var iFramePosition = target.getBoundingClientRect();
893
+
894
+ getPagePosition(iframeId);
895
+
896
+ return {
897
+ x: Math.floor(Number(iFramePosition.left) + Number(pagePosition.x)),
898
+ y: Math.floor(Number(iFramePosition.top) + Number(pagePosition.y))
899
+ }
900
+ }
901
+
902
+ function scrollRequestFromChild(addOffset) {
903
+ /* istanbul ignore next */ // Not testable in Karma
904
+ function reposition() {
905
+ pagePosition = newPosition;
906
+ scrollTo();
907
+ log(iframeId, '--');
908
+ }
909
+
910
+ function calcOffset() {
911
+ return {
912
+ x: Number(messageData.width) + offset.x,
913
+ y: Number(messageData.height) + offset.y
914
+ }
915
+ }
916
+
917
+ function scrollParent() {
918
+ if (window.parentIFrame) {
919
+ window.parentIFrame['scrollTo' + (addOffset ? 'Offset' : '')](
920
+ newPosition.x,
921
+ newPosition.y
922
+ );
923
+ } else {
924
+ warn(
925
+ iframeId,
926
+ 'Unable to scroll to requested position, window.parentIFrame not found'
927
+ );
928
+ }
929
+ }
930
+
931
+ var offset = addOffset
932
+ ? getElementPosition(messageData.iframe)
933
+ : { x: 0, y: 0 },
934
+ newPosition = calcOffset();
935
+
936
+ log(
937
+ iframeId,
938
+ 'Reposition requested from iFrame (offset x:' +
939
+ offset.x +
940
+ ' y:' +
941
+ offset.y +
942
+ ')'
943
+ );
944
+
945
+ if (window.top === window.self) {
946
+ reposition();
947
+ } else {
948
+ scrollParent();
949
+ }
950
+ }
951
+
952
+ function scrollTo() {
953
+ if (false === on('onScroll', pagePosition)) {
954
+ unsetPagePosition();
955
+ } else {
956
+ setPagePosition(iframeId);
957
+ }
958
+ }
959
+
960
+ function findTarget(location) {
961
+ function jumpToTarget() {
962
+ var jumpPosition = getElementPosition(target);
963
+
964
+ log(
965
+ iframeId,
966
+ 'Moving to in page link (#' +
967
+ hash +
968
+ ') at x: ' +
969
+ jumpPosition.x +
970
+ ' y: ' +
971
+ jumpPosition.y
972
+ );
973
+ pagePosition = {
974
+ x: jumpPosition.x,
975
+ y: jumpPosition.y
976
+ };
977
+
978
+ scrollTo();
979
+ log(iframeId, '--');
980
+ }
981
+
982
+ function jumpToParent() {
983
+ if (window.parentIFrame) {
984
+ window.parentIFrame.moveToAnchor(hash);
985
+ } else {
986
+ log(
987
+ iframeId,
988
+ 'In page link #' +
989
+ hash +
990
+ ' not found and window.parentIFrame not found'
991
+ );
992
+ }
993
+ }
994
+
995
+ var hash = location.split('#')[1] || '',
996
+ hashData = decodeURIComponent(hash),
997
+ target =
998
+ document.getElementById(hashData) ||
999
+ document.getElementsByName(hashData)[0];
1000
+
1001
+ if (target) {
1002
+ jumpToTarget();
1003
+ } else if (window.top === window.self) {
1004
+ log(iframeId, 'In page link #' + hash + ' not found');
1005
+ } else {
1006
+ jumpToParent();
1007
+ }
1008
+ }
1009
+
1010
+ function onMouse(event) {
1011
+ var mousePos = {};
1012
+
1013
+ if (Number(messageData.width) === 0 && Number(messageData.height) === 0) {
1014
+ var data = getMsgBody(9).split(':');
1015
+ mousePos = {
1016
+ x: data[1],
1017
+ y: data[0]
1018
+ };
1019
+ } else {
1020
+ mousePos = {
1021
+ x: messageData.width,
1022
+ y: messageData.height
1023
+ };
1024
+ }
1025
+
1026
+ on(event, {
1027
+ iframe: messageData.iframe,
1028
+ screenX: Number(mousePos.x),
1029
+ screenY: Number(mousePos.y),
1030
+ type: messageData.type
1031
+ });
1032
+ }
1033
+
1034
+ function on(funcName, val) {
1035
+ return chkEvent(iframeId, funcName, val)
1036
+ }
1037
+
1038
+ function actionMsg() {
1039
+ if (settings[iframeId] && settings[iframeId].firstRun) firstRun();
1040
+
1041
+ switch (messageData.type) {
1042
+ case 'close': {
1043
+ closeIFrame(messageData.iframe);
1044
+ break
1045
+ }
1046
+
1047
+ case 'message': {
1048
+ forwardMsgFromIFrame(getMsgBody(6));
1049
+ break
1050
+ }
1051
+
1052
+ case 'mouseenter': {
1053
+ onMouse('onMouseEnter');
1054
+ break
1055
+ }
1056
+
1057
+ case 'mouseleave': {
1058
+ onMouse('onMouseLeave');
1059
+ break
1060
+ }
1061
+
1062
+ case 'autoResize': {
1063
+ settings[iframeId].autoResize = JSON.parse(getMsgBody(9));
1064
+ break
1065
+ }
1066
+
1067
+ case 'scrollTo': {
1068
+ scrollRequestFromChild(false);
1069
+ break
1070
+ }
1071
+
1072
+ case 'scrollToOffset': {
1073
+ scrollRequestFromChild(true);
1074
+ break
1075
+ }
1076
+
1077
+ case 'pageInfo': {
1078
+ sendPageInfoToIframe(
1079
+ settings[iframeId] && settings[iframeId].iframe,
1080
+ iframeId
1081
+ );
1082
+ startPageInfoMonitor();
1083
+ break
1084
+ }
1085
+
1086
+ case 'pageInfoStop': {
1087
+ stopPageInfoMonitor();
1088
+ break
1089
+ }
1090
+
1091
+ case 'inPageLink': {
1092
+ findTarget(getMsgBody(9));
1093
+ break
1094
+ }
1095
+
1096
+ case 'reset': {
1097
+ resetIFrame(messageData);
1098
+ break
1099
+ }
1100
+
1101
+ case 'init': {
1102
+ resizeIFrame();
1103
+ on('onInit', messageData.iframe);
1104
+ break
1105
+ }
1106
+
1107
+ default: {
1108
+ if (
1109
+ Number(messageData.width) === 0 &&
1110
+ Number(messageData.height) === 0
1111
+ ) {
1112
+ warn(
1113
+ 'Unsupported message received (' +
1114
+ messageData.type +
1115
+ '), this is likely due to the iframe containing a later ' +
1116
+ 'version of iframe-resizer than the parent page'
1117
+ );
1118
+ } else {
1119
+ resizeIFrame();
1120
+ }
1121
+ }
1122
+ }
1123
+ }
1124
+
1125
+ function hasSettings(iframeId) {
1126
+ var retBool = true;
1127
+
1128
+ if (!settings[iframeId]) {
1129
+ retBool = false;
1130
+ warn(
1131
+ messageData.type +
1132
+ ' No settings for ' +
1133
+ iframeId +
1134
+ '. Message was: ' +
1135
+ msg
1136
+ );
1137
+ }
1138
+
1139
+ return retBool
1140
+ }
1141
+
1142
+ function iFrameReadyMsgReceived() {
1143
+ // eslint-disable-next-line no-restricted-syntax, guard-for-in
1144
+ for (var iframeId in settings) {
1145
+ trigger(
1146
+ 'iFrame requested init',
1147
+ createOutgoingMsg(iframeId),
1148
+ settings[iframeId].iframe,
1149
+ iframeId
1150
+ );
1151
+ }
1152
+ }
1153
+
1154
+ function firstRun() {
1155
+ if (settings[iframeId]) {
1156
+ settings[iframeId].firstRun = false;
1157
+ }
1158
+ }
1159
+
1160
+ var msg = event.data,
1161
+ messageData = {},
1162
+ iframeId = null;
1163
+
1164
+ if ('[iFrameResizerChild]Ready' === msg) {
1165
+ iFrameReadyMsgReceived();
1166
+ } else if (isMessageForUs()) {
1167
+ messageData = processMsg();
1168
+ iframeId = messageData.id;
1169
+ if (settings[iframeId]) {
1170
+ settings[iframeId].loaded = true;
1171
+ }
1172
+
1173
+ if (!isMessageFromMetaParent() && hasSettings(iframeId)) {
1174
+ log(iframeId, 'Received: ' + msg);
1175
+
1176
+ if (checkIFrameExists() && isMessageFromIFrame()) {
1177
+ actionMsg();
1178
+ }
1179
+ }
1180
+ } else {
1181
+ info(iframeId, 'Ignored: ' + msg);
1182
+ }
1183
+ }
1184
+
1185
+ function chkEvent(iframeId, funcName, val) {
1186
+ var func = null,
1187
+ retVal = null;
1188
+
1189
+ if (settings[iframeId]) {
1190
+ func = settings[iframeId][funcName];
1191
+
1192
+ if ('function' === typeof func) {
1193
+ retVal = func(val);
1194
+ } else {
1195
+ throw new TypeError(
1196
+ funcName + ' on iFrame[' + iframeId + '] is not a function'
1197
+ )
1198
+ }
1199
+ }
1200
+
1201
+ return retVal
1202
+ }
1203
+
1204
+ function removeIframeListeners(iframe) {
1205
+ var iframeId = iframe.id;
1206
+ delete settings[iframeId];
1207
+ }
1208
+
1209
+ function closeIFrame(iframe) {
1210
+ var iframeId = iframe.id;
1211
+ if (chkEvent(iframeId, 'onClose', iframeId) === false) {
1212
+ log(iframeId, 'Close iframe cancelled by onClose event');
1213
+ return
1214
+ }
1215
+ log(iframeId, 'Removing iFrame: ' + iframeId);
1216
+
1217
+ try {
1218
+ // Catch race condition error with React
1219
+ if (iframe.parentNode) {
1220
+ iframe.parentNode.removeChild(iframe);
1221
+ }
1222
+ } catch (error) {
1223
+ warn(error);
1224
+ }
1225
+
1226
+ chkEvent(iframeId, 'onClosed', iframeId);
1227
+ log(iframeId, '--');
1228
+ removeIframeListeners(iframe);
1229
+ }
1230
+
1231
+ function getPagePosition(iframeId) {
1232
+ if (null === pagePosition) {
1233
+ pagePosition = {
1234
+ x:
1235
+ window.pageXOffset === undefined$1
1236
+ ? document.documentElement.scrollLeft
1237
+ : window.pageXOffset,
1238
+ y:
1239
+ window.pageYOffset === undefined$1
1240
+ ? document.documentElement.scrollTop
1241
+ : window.pageYOffset
1242
+ };
1243
+ log(
1244
+ iframeId,
1245
+ 'Get page position: ' + pagePosition.x + ',' + pagePosition.y
1246
+ );
1247
+ }
1248
+ }
1249
+
1250
+ function setPagePosition(iframeId) {
1251
+ if (null !== pagePosition) {
1252
+ window.scrollTo(pagePosition.x, pagePosition.y);
1253
+ log(
1254
+ iframeId,
1255
+ 'Set page position: ' + pagePosition.x + ',' + pagePosition.y
1256
+ );
1257
+ unsetPagePosition();
1258
+ }
1259
+ }
1260
+
1261
+ function unsetPagePosition() {
1262
+ pagePosition = null;
1263
+ }
1264
+
1265
+ function resetIFrame(messageData) {
1266
+ function reset() {
1267
+ setSize(messageData);
1268
+ trigger('reset', 'reset', messageData.iframe, messageData.id);
1269
+ }
1270
+
1271
+ log(
1272
+ messageData.id,
1273
+ 'Size reset requested by ' +
1274
+ ('init' === messageData.type ? 'host page' : 'iFrame')
1275
+ );
1276
+ getPagePosition(messageData.id);
1277
+ syncResize(reset, messageData, 'reset');
1278
+ }
1279
+
1280
+ function setSize(messageData) {
1281
+ function setDimension(dimension) {
1282
+ if (!messageData.id) {
1283
+ log('undefined', 'messageData id not set');
1284
+ return
1285
+ }
1286
+ messageData.iframe.style[dimension] = messageData[dimension] + 'px';
1287
+ log(
1288
+ messageData.id,
1289
+ 'IFrame (' +
1290
+ iframeId +
1291
+ ') ' +
1292
+ dimension +
1293
+ ' set to ' +
1294
+ messageData[dimension] +
1295
+ 'px'
1296
+ );
1297
+ }
1298
+
1299
+ function chkZero(dimension) {
1300
+ // FireFox sets dimension of hidden iFrames to zero.
1301
+ // So if we detect that set up an event to check for
1302
+ // when iFrame becomes visible.
1303
+
1304
+ /* istanbul ignore next */ // Not testable in PhantomJS
1305
+ if (!hiddenCheckEnabled && '0' === messageData[dimension]) {
1306
+ hiddenCheckEnabled = true;
1307
+ log(iframeId, 'Hidden iFrame detected, creating visibility listener');
1308
+ fixHiddenIFrames();
1309
+ }
1310
+ }
1311
+
1312
+ function processDimension(dimension) {
1313
+ setDimension(dimension);
1314
+ chkZero(dimension);
1315
+ }
1316
+
1317
+ var iframeId = messageData.iframe.id;
1318
+
1319
+ if (settings[iframeId]) {
1320
+ if (settings[iframeId].sizeHeight) {
1321
+ processDimension('height');
1322
+ }
1323
+ if (settings[iframeId].sizeWidth) {
1324
+ processDimension('width');
1325
+ }
1326
+ }
1327
+ }
1328
+
1329
+ function syncResize(func, messageData, doNotSync) {
1330
+ /* istanbul ignore if */ // Not testable in PhantomJS
1331
+ if (
1332
+ doNotSync !== messageData.type &&
1333
+ requestAnimationFrame &&
1334
+ // including check for jasmine because had trouble getting spy to work in unit test using requestAnimationFrame
1335
+ !window.jasmine
1336
+ ) {
1337
+ log(messageData.id, 'Requesting animation frame');
1338
+ requestAnimationFrame(func);
1339
+ } else {
1340
+ func();
1341
+ }
1342
+ }
1343
+
1344
+ function trigger(calleeMsg, msg, iframe, id, noResponseWarning) {
1345
+ function postMessageToIFrame() {
1346
+ var target = settings[id] && settings[id].targetOrigin;
1347
+ log(
1348
+ id,
1349
+ '[' +
1350
+ calleeMsg +
1351
+ '] Sending msg to iframe[' +
1352
+ id +
1353
+ '] (' +
1354
+ msg +
1355
+ ') targetOrigin: ' +
1356
+ target
1357
+ );
1358
+ iframe.contentWindow.postMessage(msgId + msg, target);
1359
+ }
1360
+
1361
+ function iFrameNotFound() {
1362
+ warn(id, '[' + calleeMsg + '] IFrame(' + id + ') not found');
1363
+ }
1364
+
1365
+ function chkAndSend() {
1366
+ if (
1367
+ iframe &&
1368
+ 'contentWindow' in iframe &&
1369
+ null !== iframe.contentWindow
1370
+ ) {
1371
+ // Null test for PhantomJS
1372
+ postMessageToIFrame();
1373
+ } else {
1374
+ iFrameNotFound();
1375
+ }
1376
+ }
1377
+
1378
+ function warnOnNoResponse() {
1379
+ function warning() {
1380
+ if (settings[id] && !settings[id].loaded && !errorShown) {
1381
+ errorShown = true;
1382
+ warn(
1383
+ id,
1384
+ 'IFrame has not responded within ' +
1385
+ settings[id].warningTimeout / 1000 +
1386
+ ' seconds. Check iFrameResizer.contentWindow.js has been loaded in iFrame. This message can be ignored if everything is working, or you can set the warningTimeout option to a higher value or zero to suppress this warning.'
1387
+ );
1388
+ }
1389
+ }
1390
+
1391
+ if (
1392
+ !!noResponseWarning &&
1393
+ settings[id] &&
1394
+ !!settings[id].warningTimeout
1395
+ ) {
1396
+ settings[id].msgTimeout = setTimeout(
1397
+ warning,
1398
+ settings[id].warningTimeout
1399
+ );
1400
+ }
1401
+ }
1402
+
1403
+ var errorShown = false;
1404
+
1405
+ id = id || iframe.id;
1406
+
1407
+ if (settings[id]) {
1408
+ chkAndSend();
1409
+ warnOnNoResponse();
1410
+ }
1411
+ }
1412
+
1413
+ function createOutgoingMsg(iframeId) {
1414
+ return (
1415
+ iframeId +
1416
+ ':' +
1417
+ settings[iframeId].bodyMarginV1 +
1418
+ ':' +
1419
+ settings[iframeId].sizeWidth +
1420
+ ':' +
1421
+ settings[iframeId].log +
1422
+ ':' +
1423
+ settings[iframeId].interval +
1424
+ ':' +
1425
+ settings[iframeId].enablePublicMethods +
1426
+ ':' +
1427
+ settings[iframeId].autoResize +
1428
+ ':' +
1429
+ settings[iframeId].bodyMargin +
1430
+ ':' +
1431
+ settings[iframeId].heightCalculationMethod +
1432
+ ':' +
1433
+ settings[iframeId].bodyBackground +
1434
+ ':' +
1435
+ settings[iframeId].bodyPadding +
1436
+ ':' +
1437
+ settings[iframeId].tolerance +
1438
+ ':' +
1439
+ settings[iframeId].inPageLinks +
1440
+ ':' +
1441
+ settings[iframeId].resizeFrom +
1442
+ ':' +
1443
+ settings[iframeId].widthCalculationMethod +
1444
+ ':' +
1445
+ settings[iframeId].mouseEvents
1446
+ )
1447
+ }
1448
+
1449
+ function isNumber(value) {
1450
+ return typeof value === 'number'
1451
+ }
1452
+
1453
+ function setupIFrame(iframe, options) {
1454
+ function setLimits() {
1455
+ function addStyle(style) {
1456
+ var styleValue = settings[iframeId][style];
1457
+ if (Infinity !== styleValue && 0 !== styleValue) {
1458
+ iframe.style[style] = isNumber(styleValue)
1459
+ ? styleValue + 'px'
1460
+ : styleValue;
1461
+ log(iframeId, 'Set ' + style + ' = ' + iframe.style[style]);
1462
+ }
1463
+ }
1464
+
1465
+ function chkMinMax(dimension) {
1466
+ if (
1467
+ settings[iframeId]['min' + dimension] >
1468
+ settings[iframeId]['max' + dimension]
1469
+ ) {
1470
+ throw new Error(
1471
+ 'Value for min' +
1472
+ dimension +
1473
+ ' can not be greater than max' +
1474
+ dimension
1475
+ )
1476
+ }
1477
+ }
1478
+
1479
+ chkMinMax('Height');
1480
+ chkMinMax('Width');
1481
+
1482
+ addStyle('maxHeight');
1483
+ addStyle('minHeight');
1484
+ addStyle('maxWidth');
1485
+ addStyle('minWidth');
1486
+ }
1487
+
1488
+ function newId() {
1489
+ var id = (options && options.id) || defaults.id + count++;
1490
+ if (null !== document.getElementById(id)) {
1491
+ id += count++;
1492
+ }
1493
+ return id
1494
+ }
1495
+
1496
+ function ensureHasId(iframeId) {
1497
+ if (typeof iframeId !== 'string') {
1498
+ throw new TypeError('Invaild id for iFrame. Expected String')
1499
+ }
1500
+
1501
+ if ('' === iframeId) {
1502
+ // eslint-disable-next-line no-multi-assign
1503
+ iframe.id = iframeId = newId();
1504
+ logEnabled = (options || {}).log;
1505
+ log(
1506
+ iframeId,
1507
+ 'Added missing iframe ID: ' + iframeId + ' (' + iframe.src + ')'
1508
+ );
1509
+ }
1510
+
1511
+ return iframeId
1512
+ }
1513
+
1514
+ function setScrolling() {
1515
+ log(
1516
+ iframeId,
1517
+ 'IFrame scrolling ' +
1518
+ (settings[iframeId] && settings[iframeId].scrolling
1519
+ ? 'enabled'
1520
+ : 'disabled') +
1521
+ ' for ' +
1522
+ iframeId
1523
+ );
1524
+ iframe.style.overflow =
1525
+ false === (settings[iframeId] && settings[iframeId].scrolling)
1526
+ ? 'hidden'
1527
+ : 'auto';
1528
+ switch (settings[iframeId] && settings[iframeId].scrolling) {
1529
+ case 'omit': {
1530
+ break
1531
+ }
1532
+
1533
+ case true: {
1534
+ iframe.scrolling = 'yes';
1535
+ break
1536
+ }
1537
+
1538
+ case false: {
1539
+ iframe.scrolling = 'no';
1540
+ break
1541
+ }
1542
+
1543
+ default: {
1544
+ iframe.scrolling = settings[iframeId]
1545
+ ? settings[iframeId].scrolling
1546
+ : 'no';
1547
+ }
1548
+ }
1549
+ }
1550
+
1551
+ // The V1 iFrame script expects an int, where as in V2 expects a CSS
1552
+ // string value such as '1px 3em', so if we have an int for V2, set V1=V2
1553
+ // and then convert V2 to a string PX value.
1554
+ function setupBodyMarginValues() {
1555
+ if (
1556
+ 'number' ===
1557
+ typeof (settings[iframeId] && settings[iframeId].bodyMargin) ||
1558
+ '0' === (settings[iframeId] && settings[iframeId].bodyMargin)
1559
+ ) {
1560
+ settings[iframeId].bodyMarginV1 = settings[iframeId].bodyMargin;
1561
+ settings[iframeId].bodyMargin =
1562
+ '' + settings[iframeId].bodyMargin + 'px';
1563
+ }
1564
+ }
1565
+
1566
+ function checkReset() {
1567
+ // Reduce scope of firstRun to function, because IE8's JS execution
1568
+ // context stack is borked and this value gets externally
1569
+ // changed midway through running this function!!!
1570
+ var firstRun = settings[iframeId] && settings[iframeId].firstRun,
1571
+ resetRequertMethod =
1572
+ settings[iframeId] &&
1573
+ settings[iframeId].heightCalculationMethod in resetRequiredMethods;
1574
+
1575
+ if (!firstRun && resetRequertMethod) {
1576
+ resetIFrame({ iframe: iframe, height: 0, width: 0, type: 'init' });
1577
+ }
1578
+ }
1579
+
1580
+ function setupIFrameObject() {
1581
+ if (settings[iframeId]) {
1582
+ settings[iframeId].iframe.iFrameResizer = {
1583
+ close: closeIFrame.bind(null, settings[iframeId].iframe),
1584
+
1585
+ removeListeners: removeIframeListeners.bind(
1586
+ null,
1587
+ settings[iframeId].iframe
1588
+ ),
1589
+
1590
+ resize: trigger.bind(
1591
+ null,
1592
+ 'Window resize',
1593
+ 'resize',
1594
+ settings[iframeId].iframe
1595
+ ),
1596
+
1597
+ moveToAnchor: function (anchor) {
1598
+ trigger(
1599
+ 'Move to anchor',
1600
+ 'moveToAnchor:' + anchor,
1601
+ settings[iframeId].iframe,
1602
+ iframeId
1603
+ );
1604
+ },
1605
+
1606
+ sendMessage: function (message) {
1607
+ message = JSON.stringify(message);
1608
+ trigger(
1609
+ 'Send Message',
1610
+ 'message:' + message,
1611
+ settings[iframeId].iframe,
1612
+ iframeId
1613
+ );
1614
+ }
1615
+ };
1616
+ }
1617
+ }
1618
+
1619
+ // We have to call trigger twice, as we can not be sure if all
1620
+ // iframes have completed loading when this code runs. The
1621
+ // event listener also catches the page changing in the iFrame.
1622
+ function init(msg) {
1623
+ function iFrameLoaded() {
1624
+ trigger('iFrame.onload', msg, iframe, undefined$1, true);
1625
+ checkReset();
1626
+ }
1627
+
1628
+ function createDestroyObserver(MutationObserver) {
1629
+ if (!iframe.parentNode) {
1630
+ return
1631
+ }
1632
+
1633
+ var destroyObserver = new MutationObserver(function (mutations) {
1634
+ mutations.forEach(function (mutation) {
1635
+ var removedNodes = Array.prototype.slice.call(mutation.removedNodes); // Transform NodeList into an Array
1636
+ removedNodes.forEach(function (removedNode) {
1637
+ if (removedNode === iframe) {
1638
+ closeIFrame(iframe);
1639
+ }
1640
+ });
1641
+ });
1642
+ });
1643
+ destroyObserver.observe(iframe.parentNode, {
1644
+ childList: true
1645
+ });
1646
+ }
1647
+
1648
+ var MutationObserver = getMutationObserver();
1649
+ if (MutationObserver) {
1650
+ createDestroyObserver(MutationObserver);
1651
+ }
1652
+
1653
+ addEventListener(iframe, 'load', iFrameLoaded);
1654
+ trigger('init', msg, iframe, undefined$1, true);
1655
+ }
1656
+
1657
+ function checkOptions(options) {
1658
+ if ('object' !== typeof options) {
1659
+ throw new TypeError('Options is not an object')
1660
+ }
1661
+ }
1662
+
1663
+ function copyOptions(options) {
1664
+ // eslint-disable-next-line no-restricted-syntax
1665
+ for (var option in defaults) {
1666
+ if (Object.prototype.hasOwnProperty.call(defaults, option)) {
1667
+ settings[iframeId][option] = Object.prototype.hasOwnProperty.call(
1668
+ options,
1669
+ option
1670
+ )
1671
+ ? options[option]
1672
+ : defaults[option];
1673
+ }
1674
+ }
1675
+ }
1676
+
1677
+ function getTargetOrigin(remoteHost) {
1678
+ return '' === remoteHost ||
1679
+ null !== remoteHost.match(/^(about:blank|javascript:|file:\/\/)/)
1680
+ ? '*'
1681
+ : remoteHost
1682
+ }
1683
+
1684
+ function depricate(key) {
1685
+ var splitName = key.split('Callback');
1686
+
1687
+ if (splitName.length === 2) {
1688
+ var name =
1689
+ 'on' + splitName[0].charAt(0).toUpperCase() + splitName[0].slice(1);
1690
+ this[name] = this[key];
1691
+ delete this[key];
1692
+ warn(
1693
+ iframeId,
1694
+ "Deprecated: '" +
1695
+ key +
1696
+ "' has been renamed '" +
1697
+ name +
1698
+ "'. The old method will be removed in the next major version."
1699
+ );
1700
+ }
1701
+ }
1702
+
1703
+ function processOptions(options) {
1704
+ options = options || {};
1705
+
1706
+ settings[iframeId] = Object.create(null); // Protect against prototype attacks
1707
+ settings[iframeId].iframe = iframe;
1708
+ settings[iframeId].firstRun = true;
1709
+ settings[iframeId].remoteHost =
1710
+ iframe.src && iframe.src.split('/').slice(0, 3).join('/');
1711
+
1712
+ checkOptions(options);
1713
+ Object.keys(options).forEach(depricate, options);
1714
+ copyOptions(options);
1715
+
1716
+ if (settings[iframeId]) {
1717
+ settings[iframeId].targetOrigin =
1718
+ true === settings[iframeId].checkOrigin
1719
+ ? getTargetOrigin(settings[iframeId].remoteHost)
1720
+ : '*';
1721
+ }
1722
+ }
1723
+
1724
+ function beenHere() {
1725
+ return iframeId in settings && 'iFrameResizer' in iframe
1726
+ }
1727
+
1728
+ var iframeId = ensureHasId(iframe.id);
1729
+
1730
+ if (beenHere()) {
1731
+ warn(iframeId, 'Ignored iFrame, already setup.');
1732
+ } else {
1733
+ processOptions(options);
1734
+ setScrolling();
1735
+ setLimits();
1736
+ setupBodyMarginValues();
1737
+ init(createOutgoingMsg(iframeId));
1738
+ setupIFrameObject();
1739
+ }
1740
+ }
1741
+
1742
+ function debouce(fn, time) {
1743
+ if (null === timer) {
1744
+ timer = setTimeout(function () {
1745
+ timer = null;
1746
+ fn();
1747
+ }, time);
1748
+ }
1749
+ }
1750
+
1751
+ var frameTimer = {};
1752
+ function debounceFrameEvents(fn, time, frameId) {
1753
+ if (!frameTimer[frameId]) {
1754
+ frameTimer[frameId] = setTimeout(function () {
1755
+ frameTimer[frameId] = null;
1756
+ fn();
1757
+ }, time);
1758
+ }
1759
+ }
1760
+
1761
+ // Not testable in PhantomJS
1762
+ /* istanbul ignore next */
1763
+
1764
+ function fixHiddenIFrames() {
1765
+ function checkIFrames() {
1766
+ function checkIFrame(settingId) {
1767
+ function chkDimension(dimension) {
1768
+ return (
1769
+ '0px' ===
1770
+ (settings[settingId] && settings[settingId].iframe.style[dimension])
1771
+ )
1772
+ }
1773
+
1774
+ function isVisible(el) {
1775
+ return null !== el.offsetParent
1776
+ }
1777
+
1778
+ if (
1779
+ settings[settingId] &&
1780
+ isVisible(settings[settingId].iframe) &&
1781
+ (chkDimension('height') || chkDimension('width'))
1782
+ ) {
1783
+ trigger(
1784
+ 'Visibility change',
1785
+ 'resize',
1786
+ settings[settingId].iframe,
1787
+ settingId
1788
+ );
1789
+ }
1790
+ }
1791
+
1792
+ Object.keys(settings).forEach(function (key) {
1793
+ checkIFrame(key);
1794
+ });
1795
+ }
1796
+
1797
+ function mutationObserved(mutations) {
1798
+ log(
1799
+ 'window',
1800
+ 'Mutation observed: ' + mutations[0].target + ' ' + mutations[0].type
1801
+ );
1802
+ debouce(checkIFrames, 16);
1803
+ }
1804
+
1805
+ function createMutationObserver() {
1806
+ var target = document.querySelector('body'),
1807
+ config = {
1808
+ attributes: true,
1809
+ attributeOldValue: false,
1810
+ characterData: true,
1811
+ characterDataOldValue: false,
1812
+ childList: true,
1813
+ subtree: true
1814
+ },
1815
+ observer = new MutationObserver(mutationObserved);
1816
+
1817
+ observer.observe(target, config);
1818
+ }
1819
+
1820
+ var MutationObserver = getMutationObserver();
1821
+ if (MutationObserver) {
1822
+ createMutationObserver();
1823
+ }
1824
+ }
1825
+
1826
+ function resizeIFrames(event) {
1827
+ function resize() {
1828
+ sendTriggerMsg('Window ' + event, 'resize');
1829
+ }
1830
+
1831
+ log('window', 'Trigger event: ' + event);
1832
+ debouce(resize, 16);
1833
+ }
1834
+
1835
+ // Not testable in PhantomJS
1836
+ /* istanbul ignore next */
1837
+ function tabVisible() {
1838
+ function resize() {
1839
+ sendTriggerMsg('Tab Visible', 'resize');
1840
+ }
1841
+
1842
+ if ('hidden' !== document.visibilityState) {
1843
+ log('document', 'Trigger event: Visibility change');
1844
+ debouce(resize, 16);
1845
+ }
1846
+ }
1847
+
1848
+ function sendTriggerMsg(eventName, event) {
1849
+ function isIFrameResizeEnabled(iframeId) {
1850
+ return (
1851
+ settings[iframeId] &&
1852
+ 'parent' === settings[iframeId].resizeFrom &&
1853
+ settings[iframeId].autoResize &&
1854
+ !settings[iframeId].firstRun
1855
+ )
1856
+ }
1857
+
1858
+ Object.keys(settings).forEach(function (iframeId) {
1859
+ if (isIFrameResizeEnabled(iframeId)) {
1860
+ trigger(eventName, event, settings[iframeId].iframe, iframeId);
1861
+ }
1862
+ });
1863
+ }
1864
+
1865
+ function setupEventListeners() {
1866
+ addEventListener(window, 'message', iFrameListener);
1867
+
1868
+ addEventListener(window, 'resize', function () {
1869
+ resizeIFrames('resize');
1870
+ });
1871
+
1872
+ addEventListener(document, 'visibilitychange', tabVisible);
1873
+
1874
+ addEventListener(document, '-webkit-visibilitychange', tabVisible);
1875
+ }
1876
+
1877
+ function factory() {
1878
+ function init(options, element) {
1879
+ function chkType() {
1880
+ if (!element.tagName) {
1881
+ throw new TypeError('Object is not a valid DOM element')
1882
+ } else if ('IFRAME' !== element.tagName.toUpperCase()) {
1883
+ throw new TypeError(
1884
+ 'Expected <IFRAME> tag, found <' + element.tagName + '>'
1885
+ )
1886
+ }
1887
+ }
1888
+
1889
+ if (element) {
1890
+ chkType();
1891
+ setupIFrame(element, options);
1892
+ iFrames.push(element);
1893
+ }
1894
+ }
1895
+
1896
+ function warnDeprecatedOptions(options) {
1897
+ if (options && options.enablePublicMethods) {
1898
+ warn(
1899
+ 'enablePublicMethods option has been removed, public methods are now always available in the iFrame'
1900
+ );
1901
+ }
1902
+ }
1903
+
1904
+ var iFrames;
1905
+
1906
+ setupRequestAnimationFrame();
1907
+ setupEventListeners();
1908
+
1909
+ return function iFrameResizeF(options, target) {
1910
+ iFrames = []; // Only return iFrames past in on this call
1911
+
1912
+ warnDeprecatedOptions(options);
1913
+
1914
+ switch (typeof target) {
1915
+ case 'undefined':
1916
+ case 'string': {
1917
+ Array.prototype.forEach.call(
1918
+ document.querySelectorAll(target || 'iframe'),
1919
+ init.bind(undefined$1, options)
1920
+ );
1921
+ break
1922
+ }
1923
+
1924
+ case 'object': {
1925
+ init(options, target);
1926
+ break
1927
+ }
1928
+
1929
+ default: {
1930
+ throw new TypeError('Unexpected data type (' + typeof target + ')')
1931
+ }
1932
+ }
1933
+
1934
+ return iFrames
1935
+ }
1936
+ }
1937
+
1938
+ function createJQueryPublicMethod($) {
1939
+ if (!$.fn) {
1940
+ info('', 'Unable to bind to jQuery, it is not fully loaded.');
1941
+ } else if (!$.fn.iFrameResize) {
1942
+ $.fn.iFrameResize = function $iFrameResizeF(options) {
1943
+ function init(index, element) {
1944
+ setupIFrame(element, options);
1945
+ }
1946
+
1947
+ return this.filter('iframe').each(init).end()
1948
+ };
1949
+ }
1950
+ }
1951
+
1952
+ if (window.jQuery !== undefined$1) {
1953
+ createJQueryPublicMethod(window.jQuery);
1954
+ }
1955
+
1956
+ if (typeof define === 'function' && define.amd) {
1957
+ define([], factory);
1958
+ } else if (typeof module === 'object' && typeof module.exports === 'object') {
1959
+ // Node for browserfy
1960
+ module.exports = factory();
1961
+ }
1962
+ window.iFrameResize = window.iFrameResize || factory();
1963
+ })();
1964
+
1965
+ /*
1966
+ * File: iframeResizer.contentWindow.js
1967
+ * Desc: Include this file in any page being loaded into an iframe
1968
+ * to force the iframe to resize to the content size.
1969
+ * Requires: iframeResizer.js on host page.
1970
+ * Doc: https://github.com/davidjbradshaw/iframe-resizer
1971
+ * Author: David J. Bradshaw - dave@bradshaw.net
1972
+ *
1973
+ */
1974
+ (function (undefined$1) {
1975
+ if (typeof window === 'undefined') return // don't run for server side render
1976
+
1977
+ var autoResize = true,
1978
+ base = 10,
1979
+ bodyBackground = '',
1980
+ bodyMargin = 0,
1981
+ bodyMarginStr = '',
1982
+ bodyObserver = null,
1983
+ bodyPadding = '',
1984
+ calculateWidth = false,
1985
+ doubleEventList = { resize: 1, click: 1 },
1986
+ eventCancelTimer = 128,
1987
+ firstRun = true,
1988
+ height = 1,
1989
+ heightCalcModeDefault = 'bodyOffset',
1990
+ heightCalcMode = heightCalcModeDefault,
1991
+ initLock = true,
1992
+ initMsg = '',
1993
+ inPageLinks = {},
1994
+ interval = 32,
1995
+ intervalTimer = null,
1996
+ logging = false,
1997
+ mouseEvents = false,
1998
+ msgID = '[iFrameSizer]', // Must match host page msg ID
1999
+ msgIdLen = msgID.length,
2000
+ myID = '',
2001
+ resetRequiredMethods = {
2002
+ max: 1,
2003
+ min: 1,
2004
+ bodyScroll: 1,
2005
+ documentElementScroll: 1
2006
+ },
2007
+ resizeFrom = 'child',
2008
+ target = window.parent,
2009
+ targetOriginDefault = '*',
2010
+ tolerance = 0,
2011
+ triggerLocked = false,
2012
+ triggerLockedTimer = null,
2013
+ throttledTimer = 16,
2014
+ width = 1,
2015
+ widthCalcModeDefault = 'scroll',
2016
+ widthCalcMode = widthCalcModeDefault,
2017
+ win = window,
2018
+ onMessage = function () {
2019
+ warn('onMessage function not defined');
2020
+ },
2021
+ onReady = function () {},
2022
+ onPageInfo = function () {},
2023
+ customCalcMethods = {
2024
+ height: function () {
2025
+ warn('Custom height calculation function not defined');
2026
+ return document.documentElement.offsetHeight
2027
+ },
2028
+ width: function () {
2029
+ warn('Custom width calculation function not defined');
2030
+ return document.body.scrollWidth
2031
+ }
2032
+ },
2033
+ eventHandlersByName = {},
2034
+ passiveSupported = false;
2035
+
2036
+ function noop() {}
2037
+
2038
+ try {
2039
+ var options = Object.create(
2040
+ {},
2041
+ {
2042
+ passive: {
2043
+ // eslint-disable-next-line getter-return
2044
+ get: function () {
2045
+ passiveSupported = true;
2046
+ }
2047
+ }
2048
+ }
2049
+ );
2050
+ window.addEventListener('test', noop, options);
2051
+ window.removeEventListener('test', noop, options);
2052
+ } catch (error) {
2053
+ /* */
2054
+ }
2055
+
2056
+ function addEventListener(el, evt, func, options) {
2057
+ el.addEventListener(evt, func, passiveSupported ? options || {} : false);
2058
+ }
2059
+
2060
+ function removeEventListener(el, evt, func) {
2061
+ el.removeEventListener(evt, func, false);
2062
+ }
2063
+
2064
+ function capitalizeFirstLetter(string) {
2065
+ return string.charAt(0).toUpperCase() + string.slice(1)
2066
+ }
2067
+
2068
+ // Based on underscore.js
2069
+ function throttle(func) {
2070
+ var context,
2071
+ args,
2072
+ result,
2073
+ timeout = null,
2074
+ previous = 0,
2075
+ later = function () {
2076
+ previous = Date.now();
2077
+ timeout = null;
2078
+ result = func.apply(context, args);
2079
+ if (!timeout) {
2080
+ // eslint-disable-next-line no-multi-assign
2081
+ context = args = null;
2082
+ }
2083
+ };
2084
+
2085
+ return function () {
2086
+ var now = Date.now();
2087
+
2088
+ if (!previous) {
2089
+ previous = now;
2090
+ }
2091
+
2092
+ var remaining = throttledTimer - (now - previous);
2093
+
2094
+ context = this;
2095
+ args = arguments;
2096
+
2097
+ if (remaining <= 0 || remaining > throttledTimer) {
2098
+ if (timeout) {
2099
+ clearTimeout(timeout);
2100
+ timeout = null;
2101
+ }
2102
+
2103
+ previous = now;
2104
+ result = func.apply(context, args);
2105
+
2106
+ if (!timeout) {
2107
+ // eslint-disable-next-line no-multi-assign
2108
+ context = args = null;
2109
+ }
2110
+ } else if (!timeout) {
2111
+ timeout = setTimeout(later, remaining);
2112
+ }
2113
+
2114
+ return result
2115
+ }
2116
+ }
2117
+
2118
+ function formatLogMsg(msg) {
2119
+ return msgID + '[' + myID + '] ' + msg
2120
+ }
2121
+
2122
+ function log(msg) {
2123
+ if (logging && 'object' === typeof window.console) {
2124
+ // eslint-disable-next-line no-console
2125
+ console.log(formatLogMsg(msg));
2126
+ }
2127
+ }
2128
+
2129
+ function warn(msg) {
2130
+ if ('object' === typeof window.console) {
2131
+ // eslint-disable-next-line no-console
2132
+ console.warn(formatLogMsg(msg));
2133
+ }
2134
+ }
2135
+
2136
+ function init() {
2137
+ readDataFromParent();
2138
+ log('Initialising iFrame (' + window.location.href + ')');
2139
+ readDataFromPage();
2140
+ setMargin();
2141
+ setBodyStyle('background', bodyBackground);
2142
+ setBodyStyle('padding', bodyPadding);
2143
+ injectClearFixIntoBodyElement();
2144
+ checkHeightMode();
2145
+ checkWidthMode();
2146
+ stopInfiniteResizingOfIFrame();
2147
+ setupPublicMethods();
2148
+ setupMouseEvents();
2149
+ startEventListeners();
2150
+ inPageLinks = setupInPageLinks();
2151
+ sendSize('init', 'Init message from host page');
2152
+ onReady();
2153
+ }
2154
+
2155
+ function readDataFromParent() {
2156
+ function strBool(str) {
2157
+ return 'true' === str
2158
+ }
2159
+
2160
+ var data = initMsg.slice(msgIdLen).split(':');
2161
+
2162
+ myID = data[0];
2163
+ bodyMargin = undefined$1 === data[1] ? bodyMargin : Number(data[1]); // For V1 compatibility
2164
+ calculateWidth = undefined$1 === data[2] ? calculateWidth : strBool(data[2]);
2165
+ logging = undefined$1 === data[3] ? logging : strBool(data[3]);
2166
+ interval = undefined$1 === data[4] ? interval : Number(data[4]);
2167
+ autoResize = undefined$1 === data[6] ? autoResize : strBool(data[6]);
2168
+ bodyMarginStr = data[7];
2169
+ heightCalcMode = undefined$1 === data[8] ? heightCalcMode : data[8];
2170
+ bodyBackground = data[9];
2171
+ bodyPadding = data[10];
2172
+ tolerance = undefined$1 === data[11] ? tolerance : Number(data[11]);
2173
+ inPageLinks.enable = undefined$1 === data[12] ? false : strBool(data[12]);
2174
+ resizeFrom = undefined$1 === data[13] ? resizeFrom : data[13];
2175
+ widthCalcMode = undefined$1 === data[14] ? widthCalcMode : data[14];
2176
+ mouseEvents = undefined$1 === data[15] ? mouseEvents : strBool(data[15]);
2177
+ }
2178
+
2179
+ function depricate(key) {
2180
+ var splitName = key.split('Callback');
2181
+
2182
+ if (splitName.length === 2) {
2183
+ var name =
2184
+ 'on' + splitName[0].charAt(0).toUpperCase() + splitName[0].slice(1);
2185
+ this[name] = this[key];
2186
+ delete this[key];
2187
+ warn(
2188
+ "Deprecated: '" +
2189
+ key +
2190
+ "' has been renamed '" +
2191
+ name +
2192
+ "'. The old method will be removed in the next major version."
2193
+ );
2194
+ }
2195
+ }
2196
+
2197
+ function readDataFromPage() {
2198
+ function readData() {
2199
+ var data = window.iFrameResizer;
2200
+
2201
+ log('Reading data from page: ' + JSON.stringify(data));
2202
+ Object.keys(data).forEach(depricate, data);
2203
+
2204
+ onMessage = 'onMessage' in data ? data.onMessage : onMessage;
2205
+ onReady = 'onReady' in data ? data.onReady : onReady;
2206
+ targetOriginDefault =
2207
+ 'targetOrigin' in data ? data.targetOrigin : targetOriginDefault;
2208
+ heightCalcMode =
2209
+ 'heightCalculationMethod' in data
2210
+ ? data.heightCalculationMethod
2211
+ : heightCalcMode;
2212
+ widthCalcMode =
2213
+ 'widthCalculationMethod' in data
2214
+ ? data.widthCalculationMethod
2215
+ : widthCalcMode;
2216
+ }
2217
+
2218
+ function setupCustomCalcMethods(calcMode, calcFunc) {
2219
+ if ('function' === typeof calcMode) {
2220
+ log('Setup custom ' + calcFunc + 'CalcMethod');
2221
+ customCalcMethods[calcFunc] = calcMode;
2222
+ calcMode = 'custom';
2223
+ }
2224
+
2225
+ return calcMode
2226
+ }
2227
+
2228
+ if (
2229
+ 'iFrameResizer' in window &&
2230
+ Object === window.iFrameResizer.constructor
2231
+ ) {
2232
+ readData();
2233
+ heightCalcMode = setupCustomCalcMethods(heightCalcMode, 'height');
2234
+ widthCalcMode = setupCustomCalcMethods(widthCalcMode, 'width');
2235
+ }
2236
+
2237
+ log('TargetOrigin for parent set to: ' + targetOriginDefault);
2238
+ }
2239
+
2240
+ function chkCSS(attr, value) {
2241
+ if (-1 !== value.indexOf('-')) {
2242
+ warn('Negative CSS value ignored for ' + attr);
2243
+ value = '';
2244
+ }
2245
+ return value
2246
+ }
2247
+
2248
+ function setBodyStyle(attr, value) {
2249
+ if (undefined$1 !== value && '' !== value && 'null' !== value) {
2250
+ document.body.style[attr] = value;
2251
+ log('Body ' + attr + ' set to "' + value + '"');
2252
+ }
2253
+ }
2254
+
2255
+ function setMargin() {
2256
+ // If called via V1 script, convert bodyMargin from int to str
2257
+ if (undefined$1 === bodyMarginStr) {
2258
+ bodyMarginStr = bodyMargin + 'px';
2259
+ }
2260
+
2261
+ setBodyStyle('margin', chkCSS('margin', bodyMarginStr));
2262
+ }
2263
+
2264
+ function stopInfiniteResizingOfIFrame() {
2265
+ document.documentElement.style.height = '';
2266
+ document.body.style.height = '';
2267
+ log('HTML & body height set to "auto"');
2268
+ }
2269
+
2270
+ function manageTriggerEvent(options) {
2271
+ var listener = {
2272
+ add: function (eventName) {
2273
+ function handleEvent() {
2274
+ sendSize(options.eventName, options.eventType);
2275
+ }
2276
+
2277
+ eventHandlersByName[eventName] = handleEvent;
2278
+
2279
+ addEventListener(window, eventName, handleEvent, { passive: true });
2280
+ },
2281
+ remove: function (eventName) {
2282
+ var handleEvent = eventHandlersByName[eventName];
2283
+ delete eventHandlersByName[eventName];
2284
+
2285
+ removeEventListener(window, eventName, handleEvent);
2286
+ }
2287
+ };
2288
+
2289
+ if (options.eventNames && Array.prototype.map) {
2290
+ options.eventName = options.eventNames[0];
2291
+ options.eventNames.map(listener[options.method]);
2292
+ } else {
2293
+ listener[options.method](options.eventName);
2294
+ }
2295
+
2296
+ log(
2297
+ capitalizeFirstLetter(options.method) +
2298
+ ' event listener: ' +
2299
+ options.eventType
2300
+ );
2301
+ }
2302
+
2303
+ function manageEventListeners(method) {
2304
+ manageTriggerEvent({
2305
+ method: method,
2306
+ eventType: 'Animation Start',
2307
+ eventNames: ['animationstart', 'webkitAnimationStart']
2308
+ });
2309
+ manageTriggerEvent({
2310
+ method: method,
2311
+ eventType: 'Animation Iteration',
2312
+ eventNames: ['animationiteration', 'webkitAnimationIteration']
2313
+ });
2314
+ manageTriggerEvent({
2315
+ method: method,
2316
+ eventType: 'Animation End',
2317
+ eventNames: ['animationend', 'webkitAnimationEnd']
2318
+ });
2319
+ manageTriggerEvent({
2320
+ method: method,
2321
+ eventType: 'Input',
2322
+ eventName: 'input'
2323
+ });
2324
+ manageTriggerEvent({
2325
+ method: method,
2326
+ eventType: 'Mouse Up',
2327
+ eventName: 'mouseup'
2328
+ });
2329
+ manageTriggerEvent({
2330
+ method: method,
2331
+ eventType: 'Mouse Down',
2332
+ eventName: 'mousedown'
2333
+ });
2334
+ manageTriggerEvent({
2335
+ method: method,
2336
+ eventType: 'Orientation Change',
2337
+ eventName: 'orientationchange'
2338
+ });
2339
+ manageTriggerEvent({
2340
+ method: method,
2341
+ eventType: 'Print',
2342
+ eventNames: ['afterprint', 'beforeprint']
2343
+ });
2344
+ manageTriggerEvent({
2345
+ method: method,
2346
+ eventType: 'Ready State Change',
2347
+ eventName: 'readystatechange'
2348
+ });
2349
+ manageTriggerEvent({
2350
+ method: method,
2351
+ eventType: 'Touch Start',
2352
+ eventName: 'touchstart'
2353
+ });
2354
+ manageTriggerEvent({
2355
+ method: method,
2356
+ eventType: 'Touch End',
2357
+ eventName: 'touchend'
2358
+ });
2359
+ manageTriggerEvent({
2360
+ method: method,
2361
+ eventType: 'Touch Cancel',
2362
+ eventName: 'touchcancel'
2363
+ });
2364
+ manageTriggerEvent({
2365
+ method: method,
2366
+ eventType: 'Transition Start',
2367
+ eventNames: [
2368
+ 'transitionstart',
2369
+ 'webkitTransitionStart',
2370
+ 'MSTransitionStart',
2371
+ 'oTransitionStart',
2372
+ 'otransitionstart'
2373
+ ]
2374
+ });
2375
+ manageTriggerEvent({
2376
+ method: method,
2377
+ eventType: 'Transition Iteration',
2378
+ eventNames: [
2379
+ 'transitioniteration',
2380
+ 'webkitTransitionIteration',
2381
+ 'MSTransitionIteration',
2382
+ 'oTransitionIteration',
2383
+ 'otransitioniteration'
2384
+ ]
2385
+ });
2386
+ manageTriggerEvent({
2387
+ method: method,
2388
+ eventType: 'Transition End',
2389
+ eventNames: [
2390
+ 'transitionend',
2391
+ 'webkitTransitionEnd',
2392
+ 'MSTransitionEnd',
2393
+ 'oTransitionEnd',
2394
+ 'otransitionend'
2395
+ ]
2396
+ });
2397
+ if ('child' === resizeFrom) {
2398
+ manageTriggerEvent({
2399
+ method: method,
2400
+ eventType: 'IFrame Resized',
2401
+ eventName: 'resize'
2402
+ });
2403
+ }
2404
+ }
2405
+
2406
+ function checkCalcMode(calcMode, calcModeDefault, modes, type) {
2407
+ if (calcModeDefault !== calcMode) {
2408
+ if (!(calcMode in modes)) {
2409
+ warn(
2410
+ calcMode + ' is not a valid option for ' + type + 'CalculationMethod.'
2411
+ );
2412
+ calcMode = calcModeDefault;
2413
+ }
2414
+ log(type + ' calculation method set to "' + calcMode + '"');
2415
+ }
2416
+
2417
+ return calcMode
2418
+ }
2419
+
2420
+ function checkHeightMode() {
2421
+ heightCalcMode = checkCalcMode(
2422
+ heightCalcMode,
2423
+ heightCalcModeDefault,
2424
+ getHeight,
2425
+ 'height'
2426
+ );
2427
+ }
2428
+
2429
+ function checkWidthMode() {
2430
+ widthCalcMode = checkCalcMode(
2431
+ widthCalcMode,
2432
+ widthCalcModeDefault,
2433
+ getWidth,
2434
+ 'width'
2435
+ );
2436
+ }
2437
+
2438
+ function startEventListeners() {
2439
+ if (true === autoResize) {
2440
+ manageEventListeners('add');
2441
+ setupMutationObserver();
2442
+ } else {
2443
+ log('Auto Resize disabled');
2444
+ }
2445
+ }
2446
+
2447
+ // function stopMsgsToParent() {
2448
+ // log('Disable outgoing messages')
2449
+ // sendPermit = false
2450
+ // }
2451
+
2452
+ // function removeMsgListener() {
2453
+ // log('Remove event listener: Message')
2454
+ // removeEventListener(window, 'message', receiver)
2455
+ // }
2456
+
2457
+ function disconnectMutationObserver() {
2458
+ if (null !== bodyObserver) {
2459
+ /* istanbul ignore next */ // Not testable in PhantonJS
2460
+ bodyObserver.disconnect();
2461
+ }
2462
+ }
2463
+
2464
+ function stopEventListeners() {
2465
+ manageEventListeners('remove');
2466
+ disconnectMutationObserver();
2467
+ clearInterval(intervalTimer);
2468
+ }
2469
+
2470
+ // function teardown() {
2471
+ // stopMsgsToParent()
2472
+ // removeMsgListener()
2473
+ // if (true === autoResize) stopEventListeners()
2474
+ // }
2475
+
2476
+ function injectClearFixIntoBodyElement() {
2477
+ var clearFix = document.createElement('div');
2478
+ clearFix.style.clear = 'both';
2479
+ // Guard against the following having been globally redefined in CSS.
2480
+ clearFix.style.display = 'block';
2481
+ clearFix.style.height = '0';
2482
+ document.body.appendChild(clearFix);
2483
+ }
2484
+
2485
+ function setupInPageLinks() {
2486
+ function getPagePosition() {
2487
+ return {
2488
+ x:
2489
+ window.pageXOffset === undefined$1
2490
+ ? document.documentElement.scrollLeft
2491
+ : window.pageXOffset,
2492
+ y:
2493
+ window.pageYOffset === undefined$1
2494
+ ? document.documentElement.scrollTop
2495
+ : window.pageYOffset
2496
+ }
2497
+ }
2498
+
2499
+ function getElementPosition(el) {
2500
+ var elPosition = el.getBoundingClientRect(),
2501
+ pagePosition = getPagePosition();
2502
+
2503
+ return {
2504
+ x: parseInt(elPosition.left, 10) + parseInt(pagePosition.x, 10),
2505
+ y: parseInt(elPosition.top, 10) + parseInt(pagePosition.y, 10)
2506
+ }
2507
+ }
2508
+
2509
+ function findTarget(location) {
2510
+ function jumpToTarget(target) {
2511
+ var jumpPosition = getElementPosition(target);
2512
+
2513
+ log(
2514
+ 'Moving to in page link (#' +
2515
+ hash +
2516
+ ') at x: ' +
2517
+ jumpPosition.x +
2518
+ ' y: ' +
2519
+ jumpPosition.y
2520
+ );
2521
+ sendMsg(jumpPosition.y, jumpPosition.x, 'scrollToOffset'); // X&Y reversed at sendMsg uses height/width
2522
+ }
2523
+
2524
+ var hash = location.split('#')[1] || location, // Remove # if present
2525
+ hashData = decodeURIComponent(hash),
2526
+ target =
2527
+ document.getElementById(hashData) ||
2528
+ document.getElementsByName(hashData)[0];
2529
+
2530
+ if (undefined$1 === target) {
2531
+ log(
2532
+ 'In page link (#' +
2533
+ hash +
2534
+ ') not found in iFrame, so sending to parent'
2535
+ );
2536
+ sendMsg(0, 0, 'inPageLink', '#' + hash);
2537
+ } else {
2538
+ jumpToTarget(target);
2539
+ }
2540
+ }
2541
+
2542
+ function checkLocationHash() {
2543
+ var hash = window.location.hash;
2544
+ var href = window.location.href;
2545
+
2546
+ if ('' !== hash && '#' !== hash) {
2547
+ findTarget(href);
2548
+ }
2549
+ }
2550
+
2551
+ function bindAnchors() {
2552
+ function setupLink(el) {
2553
+ function linkClicked(e) {
2554
+ e.preventDefault();
2555
+
2556
+ /* jshint validthis:true */
2557
+ findTarget(this.getAttribute('href'));
2558
+ }
2559
+
2560
+ if ('#' !== el.getAttribute('href')) {
2561
+ addEventListener(el, 'click', linkClicked);
2562
+ }
2563
+ }
2564
+
2565
+ Array.prototype.forEach.call(
2566
+ document.querySelectorAll('a[href^="#"]'),
2567
+ setupLink
2568
+ );
2569
+ }
2570
+
2571
+ function bindLocationHash() {
2572
+ addEventListener(window, 'hashchange', checkLocationHash);
2573
+ }
2574
+
2575
+ function initCheck() {
2576
+ // Check if page loaded with location hash after init resize
2577
+ setTimeout(checkLocationHash, eventCancelTimer);
2578
+ }
2579
+
2580
+ function enableInPageLinks() {
2581
+ /* istanbul ignore else */ // Not testable in phantonJS
2582
+ if (Array.prototype.forEach && document.querySelectorAll) {
2583
+ log('Setting up location.hash handlers');
2584
+ bindAnchors();
2585
+ bindLocationHash();
2586
+ initCheck();
2587
+ } else {
2588
+ warn(
2589
+ 'In page linking not fully supported in this browser! (See README.md for IE8 workaround)'
2590
+ );
2591
+ }
2592
+ }
2593
+
2594
+ if (inPageLinks.enable) {
2595
+ enableInPageLinks();
2596
+ } else {
2597
+ log('In page linking not enabled');
2598
+ }
2599
+
2600
+ return {
2601
+ findTarget: findTarget
2602
+ }
2603
+ }
2604
+
2605
+ function setupMouseEvents() {
2606
+ if (mouseEvents !== true) return
2607
+
2608
+ function sendMouse(e) {
2609
+ sendMsg(0, 0, e.type, e.screenY + ':' + e.screenX);
2610
+ }
2611
+
2612
+ function addMouseListener(evt, name) {
2613
+ log('Add event listener: ' + name);
2614
+ addEventListener(window.document, evt, sendMouse);
2615
+ }
2616
+
2617
+ addMouseListener('mouseenter', 'Mouse Enter');
2618
+ addMouseListener('mouseleave', 'Mouse Leave');
2619
+ }
2620
+
2621
+ function setupPublicMethods() {
2622
+ log('Enable public methods');
2623
+
2624
+ win.parentIFrame = {
2625
+ autoResize: function autoResizeF(resize) {
2626
+ if (true === resize && false === autoResize) {
2627
+ autoResize = true;
2628
+ startEventListeners();
2629
+ } else if (false === resize && true === autoResize) {
2630
+ autoResize = false;
2631
+ stopEventListeners();
2632
+ }
2633
+ sendMsg(0, 0, 'autoResize', JSON.stringify(autoResize));
2634
+ return autoResize
2635
+ },
2636
+
2637
+ close: function closeF() {
2638
+ sendMsg(0, 0, 'close');
2639
+ // teardown()
2640
+ },
2641
+
2642
+ getId: function getIdF() {
2643
+ return myID
2644
+ },
2645
+
2646
+ getPageInfo: function getPageInfoF(callback) {
2647
+ if ('function' === typeof callback) {
2648
+ onPageInfo = callback;
2649
+ sendMsg(0, 0, 'pageInfo');
2650
+ } else {
2651
+ onPageInfo = function () {};
2652
+ sendMsg(0, 0, 'pageInfoStop');
2653
+ }
2654
+ },
2655
+
2656
+ moveToAnchor: function moveToAnchorF(hash) {
2657
+ inPageLinks.findTarget(hash);
2658
+ },
2659
+
2660
+ reset: function resetF() {
2661
+ resetIFrame('parentIFrame.reset');
2662
+ },
2663
+
2664
+ scrollTo: function scrollToF(x, y) {
2665
+ sendMsg(y, x, 'scrollTo'); // X&Y reversed at sendMsg uses height/width
2666
+ },
2667
+
2668
+ scrollToOffset: function scrollToF(x, y) {
2669
+ sendMsg(y, x, 'scrollToOffset'); // X&Y reversed at sendMsg uses height/width
2670
+ },
2671
+
2672
+ sendMessage: function sendMessageF(msg, targetOrigin) {
2673
+ sendMsg(0, 0, 'message', JSON.stringify(msg), targetOrigin);
2674
+ },
2675
+
2676
+ setHeightCalculationMethod: function setHeightCalculationMethodF(
2677
+ heightCalculationMethod
2678
+ ) {
2679
+ heightCalcMode = heightCalculationMethod;
2680
+ checkHeightMode();
2681
+ },
2682
+
2683
+ setWidthCalculationMethod: function setWidthCalculationMethodF(
2684
+ widthCalculationMethod
2685
+ ) {
2686
+ widthCalcMode = widthCalculationMethod;
2687
+ checkWidthMode();
2688
+ },
2689
+
2690
+ setTargetOrigin: function setTargetOriginF(targetOrigin) {
2691
+ log('Set targetOrigin: ' + targetOrigin);
2692
+ targetOriginDefault = targetOrigin;
2693
+ },
2694
+
2695
+ size: function sizeF(customHeight, customWidth) {
2696
+ var valString =
2697
+ '' + (customHeight || '') + (customWidth ? ',' + customWidth : '');
2698
+ sendSize(
2699
+ 'size',
2700
+ 'parentIFrame.size(' + valString + ')',
2701
+ customHeight,
2702
+ customWidth
2703
+ );
2704
+ }
2705
+ };
2706
+ }
2707
+
2708
+ function initInterval() {
2709
+ if (0 !== interval) {
2710
+ log('setInterval: ' + interval + 'ms');
2711
+ intervalTimer = setInterval(function () {
2712
+ sendSize('interval', 'setInterval: ' + interval);
2713
+ }, Math.abs(interval));
2714
+ }
2715
+ }
2716
+
2717
+ // Not testable in PhantomJS
2718
+ /* istanbul ignore next */
2719
+ function setupBodyMutationObserver() {
2720
+ function addImageLoadListners(mutation) {
2721
+ function addImageLoadListener(element) {
2722
+ if (false === element.complete) {
2723
+ log('Attach listeners to ' + element.src);
2724
+ element.addEventListener('load', imageLoaded, false);
2725
+ element.addEventListener('error', imageError, false);
2726
+ elements.push(element);
2727
+ }
2728
+ }
2729
+
2730
+ if (mutation.type === 'attributes' && mutation.attributeName === 'src') {
2731
+ addImageLoadListener(mutation.target);
2732
+ } else if (mutation.type === 'childList') {
2733
+ Array.prototype.forEach.call(
2734
+ mutation.target.querySelectorAll('img'),
2735
+ addImageLoadListener
2736
+ );
2737
+ }
2738
+ }
2739
+
2740
+ function removeFromArray(element) {
2741
+ elements.splice(elements.indexOf(element), 1);
2742
+ }
2743
+
2744
+ function removeImageLoadListener(element) {
2745
+ log('Remove listeners from ' + element.src);
2746
+ element.removeEventListener('load', imageLoaded, false);
2747
+ element.removeEventListener('error', imageError, false);
2748
+ removeFromArray(element);
2749
+ }
2750
+
2751
+ function imageEventTriggered(event, type, typeDesc) {
2752
+ removeImageLoadListener(event.target);
2753
+ sendSize(type, typeDesc + ': ' + event.target.src);
2754
+ }
2755
+
2756
+ function imageLoaded(event) {
2757
+ imageEventTriggered(event, 'imageLoad', 'Image loaded');
2758
+ }
2759
+
2760
+ function imageError(event) {
2761
+ imageEventTriggered(event, 'imageLoadFailed', 'Image load failed');
2762
+ }
2763
+
2764
+ function mutationObserved(mutations) {
2765
+ sendSize(
2766
+ 'mutationObserver',
2767
+ 'mutationObserver: ' + mutations[0].target + ' ' + mutations[0].type
2768
+ );
2769
+
2770
+ // Deal with WebKit / Blink asyncing image loading when tags are injected into the page
2771
+ mutations.forEach(addImageLoadListners);
2772
+ }
2773
+
2774
+ function createMutationObserver() {
2775
+ var target = document.querySelector('body'),
2776
+ config = {
2777
+ attributes: true,
2778
+ attributeOldValue: false,
2779
+ characterData: true,
2780
+ characterDataOldValue: false,
2781
+ childList: true,
2782
+ subtree: true
2783
+ };
2784
+
2785
+ observer = new MutationObserver(mutationObserved);
2786
+
2787
+ log('Create body MutationObserver');
2788
+ observer.observe(target, config);
2789
+
2790
+ return observer
2791
+ }
2792
+
2793
+ var elements = [],
2794
+ MutationObserver =
2795
+ window.MutationObserver || window.WebKitMutationObserver,
2796
+ observer = createMutationObserver();
2797
+
2798
+ return {
2799
+ disconnect: function () {
2800
+ if ('disconnect' in observer) {
2801
+ log('Disconnect body MutationObserver');
2802
+ observer.disconnect();
2803
+ elements.forEach(removeImageLoadListener);
2804
+ }
2805
+ }
2806
+ }
2807
+ }
2808
+
2809
+ function setupMutationObserver() {
2810
+ var forceIntervalTimer = 0 > interval;
2811
+
2812
+ // Not testable in PhantomJS
2813
+ /* istanbul ignore if */ if (
2814
+ window.MutationObserver ||
2815
+ window.WebKitMutationObserver
2816
+ ) {
2817
+ if (forceIntervalTimer) {
2818
+ initInterval();
2819
+ } else {
2820
+ bodyObserver = setupBodyMutationObserver();
2821
+ }
2822
+ } else {
2823
+ log('MutationObserver not supported in this browser!');
2824
+ initInterval();
2825
+ }
2826
+ }
2827
+
2828
+ // document.documentElement.offsetHeight is not reliable, so
2829
+ // we have to jump through hoops to get a better value.
2830
+ function getComputedStyle(prop, el) {
2831
+ var retVal = 0;
2832
+ el = el || document.body; // Not testable in phantonJS
2833
+
2834
+ retVal = document.defaultView.getComputedStyle(el, null);
2835
+ retVal = null === retVal ? 0 : retVal[prop];
2836
+
2837
+ return parseInt(retVal, base)
2838
+ }
2839
+
2840
+ function chkEventThottle(timer) {
2841
+ if (timer > throttledTimer / 2) {
2842
+ throttledTimer = 2 * timer;
2843
+ log('Event throttle increased to ' + throttledTimer + 'ms');
2844
+ }
2845
+ }
2846
+
2847
+ // Idea from https://github.com/guardian/iframe-messenger
2848
+ function getMaxElement(side, elements) {
2849
+ var elementsLength = elements.length,
2850
+ elVal = 0,
2851
+ maxVal = 0,
2852
+ Side = capitalizeFirstLetter(side),
2853
+ timer = Date.now();
2854
+
2855
+ for (var i = 0; i < elementsLength; i++) {
2856
+ elVal =
2857
+ elements[i].getBoundingClientRect()[side] +
2858
+ getComputedStyle('margin' + Side, elements[i]);
2859
+ if (elVal > maxVal) {
2860
+ maxVal = elVal;
2861
+ }
2862
+ }
2863
+
2864
+ timer = Date.now() - timer;
2865
+
2866
+ log('Parsed ' + elementsLength + ' HTML elements');
2867
+ log('Element position calculated in ' + timer + 'ms');
2868
+
2869
+ chkEventThottle(timer);
2870
+
2871
+ return maxVal
2872
+ }
2873
+
2874
+ function getAllMeasurements(dimensions) {
2875
+ return [
2876
+ dimensions.bodyOffset(),
2877
+ dimensions.bodyScroll(),
2878
+ dimensions.documentElementOffset(),
2879
+ dimensions.documentElementScroll()
2880
+ ]
2881
+ }
2882
+
2883
+ function getTaggedElements(side, tag) {
2884
+ function noTaggedElementsFound() {
2885
+ warn('No tagged elements (' + tag + ') found on page');
2886
+ return document.querySelectorAll('body *')
2887
+ }
2888
+
2889
+ var elements = document.querySelectorAll('[' + tag + ']');
2890
+
2891
+ if (elements.length === 0) noTaggedElementsFound();
2892
+
2893
+ return getMaxElement(side, elements)
2894
+ }
2895
+
2896
+ function getAllElements() {
2897
+ return document.querySelectorAll('body *')
2898
+ }
2899
+
2900
+ var getHeight = {
2901
+ bodyOffset: function getBodyOffsetHeight() {
2902
+ return (
2903
+ document.body.offsetHeight +
2904
+ getComputedStyle('marginTop') +
2905
+ getComputedStyle('marginBottom')
2906
+ )
2907
+ },
2908
+
2909
+ offset: function () {
2910
+ return getHeight.bodyOffset() // Backwards compatibility
2911
+ },
2912
+
2913
+ bodyScroll: function getBodyScrollHeight() {
2914
+ return document.body.scrollHeight
2915
+ },
2916
+
2917
+ custom: function getCustomWidth() {
2918
+ return customCalcMethods.height()
2919
+ },
2920
+
2921
+ documentElementOffset: function getDEOffsetHeight() {
2922
+ return document.documentElement.offsetHeight
2923
+ },
2924
+
2925
+ documentElementScroll: function getDEScrollHeight() {
2926
+ return document.documentElement.scrollHeight
2927
+ },
2928
+
2929
+ max: function getMaxHeight() {
2930
+ return Math.max.apply(null, getAllMeasurements(getHeight))
2931
+ },
2932
+
2933
+ min: function getMinHeight() {
2934
+ return Math.min.apply(null, getAllMeasurements(getHeight))
2935
+ },
2936
+
2937
+ grow: function growHeight() {
2938
+ return getHeight.max() // Run max without the forced downsizing
2939
+ },
2940
+
2941
+ lowestElement: function getBestHeight() {
2942
+ return Math.max(
2943
+ getHeight.bodyOffset() || getHeight.documentElementOffset(),
2944
+ getMaxElement('bottom', getAllElements())
2945
+ )
2946
+ },
2947
+
2948
+ taggedElement: function getTaggedElementsHeight() {
2949
+ return getTaggedElements('bottom', 'data-iframe-height')
2950
+ }
2951
+ },
2952
+ getWidth = {
2953
+ bodyScroll: function getBodyScrollWidth() {
2954
+ return document.body.scrollWidth
2955
+ },
2956
+
2957
+ bodyOffset: function getBodyOffsetWidth() {
2958
+ return document.body.offsetWidth
2959
+ },
2960
+
2961
+ custom: function getCustomWidth() {
2962
+ return customCalcMethods.width()
2963
+ },
2964
+
2965
+ documentElementScroll: function getDEScrollWidth() {
2966
+ return document.documentElement.scrollWidth
2967
+ },
2968
+
2969
+ documentElementOffset: function getDEOffsetWidth() {
2970
+ return document.documentElement.offsetWidth
2971
+ },
2972
+
2973
+ scroll: function getMaxWidth() {
2974
+ return Math.max(getWidth.bodyScroll(), getWidth.documentElementScroll())
2975
+ },
2976
+
2977
+ max: function getMaxWidth() {
2978
+ return Math.max.apply(null, getAllMeasurements(getWidth))
2979
+ },
2980
+
2981
+ min: function getMinWidth() {
2982
+ return Math.min.apply(null, getAllMeasurements(getWidth))
2983
+ },
2984
+
2985
+ rightMostElement: function rightMostElement() {
2986
+ return getMaxElement('right', getAllElements())
2987
+ },
2988
+
2989
+ taggedElement: function getTaggedElementsWidth() {
2990
+ return getTaggedElements('right', 'data-iframe-width')
2991
+ }
2992
+ };
2993
+
2994
+ function sizeIFrame(
2995
+ triggerEvent,
2996
+ triggerEventDesc,
2997
+ customHeight,
2998
+ customWidth
2999
+ ) {
3000
+ function resizeIFrame() {
3001
+ height = currentHeight;
3002
+ width = currentWidth;
3003
+
3004
+ sendMsg(height, width, triggerEvent);
3005
+ }
3006
+
3007
+ function isSizeChangeDetected() {
3008
+ function checkTolarance(a, b) {
3009
+ var retVal = Math.abs(a - b) <= tolerance;
3010
+ return !retVal
3011
+ }
3012
+
3013
+ currentHeight =
3014
+ undefined$1 === customHeight ? getHeight[heightCalcMode]() : customHeight;
3015
+ currentWidth =
3016
+ undefined$1 === customWidth ? getWidth[widthCalcMode]() : customWidth;
3017
+
3018
+ return (
3019
+ checkTolarance(height, currentHeight) ||
3020
+ (calculateWidth && checkTolarance(width, currentWidth))
3021
+ )
3022
+ }
3023
+
3024
+ function isForceResizableEvent() {
3025
+ return !(triggerEvent in { init: 1, interval: 1, size: 1 })
3026
+ }
3027
+
3028
+ function isForceResizableCalcMode() {
3029
+ return (
3030
+ heightCalcMode in resetRequiredMethods ||
3031
+ (calculateWidth && widthCalcMode in resetRequiredMethods)
3032
+ )
3033
+ }
3034
+
3035
+ function logIgnored() {
3036
+ log('No change in size detected');
3037
+ }
3038
+
3039
+ function checkDownSizing() {
3040
+ if (isForceResizableEvent() && isForceResizableCalcMode()) {
3041
+ resetIFrame(triggerEventDesc);
3042
+ } else if (!(triggerEvent in { interval: 1 })) {
3043
+ logIgnored();
3044
+ }
3045
+ }
3046
+
3047
+ var currentHeight, currentWidth;
3048
+
3049
+ if (isSizeChangeDetected() || 'init' === triggerEvent) {
3050
+ lockTrigger();
3051
+ resizeIFrame();
3052
+ } else {
3053
+ checkDownSizing();
3054
+ }
3055
+ }
3056
+
3057
+ var sizeIFrameThrottled = throttle(sizeIFrame);
3058
+
3059
+ function sendSize(triggerEvent, triggerEventDesc, customHeight, customWidth) {
3060
+ function recordTrigger() {
3061
+ if (!(triggerEvent in { reset: 1, resetPage: 1, init: 1 })) {
3062
+ log('Trigger event: ' + triggerEventDesc);
3063
+ }
3064
+ }
3065
+
3066
+ function isDoubleFiredEvent() {
3067
+ return triggerLocked && triggerEvent in doubleEventList
3068
+ }
3069
+
3070
+ if (isDoubleFiredEvent()) {
3071
+ log('Trigger event cancelled: ' + triggerEvent);
3072
+ } else {
3073
+ recordTrigger();
3074
+ if (triggerEvent === 'init') {
3075
+ sizeIFrame(triggerEvent, triggerEventDesc, customHeight, customWidth);
3076
+ } else {
3077
+ sizeIFrameThrottled(
3078
+ triggerEvent,
3079
+ triggerEventDesc,
3080
+ customHeight,
3081
+ customWidth
3082
+ );
3083
+ }
3084
+ }
3085
+ }
3086
+
3087
+ function lockTrigger() {
3088
+ if (!triggerLocked) {
3089
+ triggerLocked = true;
3090
+ log('Trigger event lock on');
3091
+ }
3092
+ clearTimeout(triggerLockedTimer);
3093
+ triggerLockedTimer = setTimeout(function () {
3094
+ triggerLocked = false;
3095
+ log('Trigger event lock off');
3096
+ log('--');
3097
+ }, eventCancelTimer);
3098
+ }
3099
+
3100
+ function triggerReset(triggerEvent) {
3101
+ height = getHeight[heightCalcMode]();
3102
+ width = getWidth[widthCalcMode]();
3103
+
3104
+ sendMsg(height, width, triggerEvent);
3105
+ }
3106
+
3107
+ function resetIFrame(triggerEventDesc) {
3108
+ var hcm = heightCalcMode;
3109
+ heightCalcMode = heightCalcModeDefault;
3110
+
3111
+ log('Reset trigger event: ' + triggerEventDesc);
3112
+ lockTrigger();
3113
+ triggerReset('reset');
3114
+
3115
+ heightCalcMode = hcm;
3116
+ }
3117
+
3118
+ function sendMsg(height, width, triggerEvent, msg, targetOrigin) {
3119
+ function setTargetOrigin() {
3120
+ if (undefined$1 === targetOrigin) {
3121
+ targetOrigin = targetOriginDefault;
3122
+ } else {
3123
+ log('Message targetOrigin: ' + targetOrigin);
3124
+ }
3125
+ }
3126
+
3127
+ function sendToParent() {
3128
+ var size = height + ':' + width,
3129
+ message =
3130
+ myID +
3131
+ ':' +
3132
+ size +
3133
+ ':' +
3134
+ triggerEvent +
3135
+ (undefined$1 === msg ? '' : ':' + msg);
3136
+
3137
+ log('Sending message to host page (' + message + ')');
3138
+ target.postMessage(msgID + message, targetOrigin);
3139
+ }
3140
+
3141
+ {
3142
+ setTargetOrigin();
3143
+ sendToParent();
3144
+ }
3145
+ }
3146
+
3147
+ function receiver(event) {
3148
+ var processRequestFromParent = {
3149
+ init: function initFromParent() {
3150
+ initMsg = event.data;
3151
+ target = event.source;
3152
+
3153
+ init();
3154
+ firstRun = false;
3155
+ setTimeout(function () {
3156
+ initLock = false;
3157
+ }, eventCancelTimer);
3158
+ },
3159
+
3160
+ reset: function resetFromParent() {
3161
+ if (initLock) {
3162
+ log('Page reset ignored by init');
3163
+ } else {
3164
+ log('Page size reset by host page');
3165
+ triggerReset('resetPage');
3166
+ }
3167
+ },
3168
+
3169
+ resize: function resizeFromParent() {
3170
+ sendSize('resizeParent', 'Parent window requested size check');
3171
+ },
3172
+
3173
+ moveToAnchor: function moveToAnchorF() {
3174
+ inPageLinks.findTarget(getData());
3175
+ },
3176
+ inPageLink: function inPageLinkF() {
3177
+ this.moveToAnchor();
3178
+ }, // Backward compatibility
3179
+
3180
+ pageInfo: function pageInfoFromParent() {
3181
+ var msgBody = getData();
3182
+ log('PageInfoFromParent called from parent: ' + msgBody);
3183
+ onPageInfo(JSON.parse(msgBody));
3184
+ log(' --');
3185
+ },
3186
+
3187
+ message: function messageFromParent() {
3188
+ var msgBody = getData();
3189
+
3190
+ log('onMessage called from parent: ' + msgBody);
3191
+ // eslint-disable-next-line sonarjs/no-extra-arguments
3192
+ onMessage(JSON.parse(msgBody));
3193
+ log(' --');
3194
+ }
3195
+ };
3196
+
3197
+ function isMessageForUs() {
3198
+ return msgID === ('' + event.data).slice(0, msgIdLen) // ''+ Protects against non-string messages
3199
+ }
3200
+
3201
+ function getMessageType() {
3202
+ return event.data.split(']')[1].split(':')[0]
3203
+ }
3204
+
3205
+ function getData() {
3206
+ return event.data.slice(event.data.indexOf(':') + 1)
3207
+ }
3208
+
3209
+ function isMiddleTier() {
3210
+ return (
3211
+ (!(typeof module !== 'undefined' && module.exports) &&
3212
+ 'iFrameResize' in window) ||
3213
+ (window.jQuery !== undefined$1 &&
3214
+ 'iFrameResize' in window.jQuery.prototype)
3215
+ )
3216
+ }
3217
+
3218
+ function isInitMsg() {
3219
+ // Test if this message is from a child below us. This is an ugly test, however, updating
3220
+ // the message format would break backwards compatibility.
3221
+ return event.data.split(':')[2] in { true: 1, false: 1 }
3222
+ }
3223
+
3224
+ function callFromParent() {
3225
+ var messageType = getMessageType();
3226
+
3227
+ if (messageType in processRequestFromParent) {
3228
+ processRequestFromParent[messageType]();
3229
+ } else if (!isMiddleTier() && !isInitMsg()) {
3230
+ warn('Unexpected message (' + event.data + ')');
3231
+ }
3232
+ }
3233
+
3234
+ function processMessage() {
3235
+ if (false === firstRun) {
3236
+ callFromParent();
3237
+ } else if (isInitMsg()) {
3238
+ processRequestFromParent.init();
3239
+ } else {
3240
+ log(
3241
+ 'Ignored message of type "' +
3242
+ getMessageType() +
3243
+ '". Received before initialization.'
3244
+ );
3245
+ }
3246
+ }
3247
+
3248
+ if (isMessageForUs()) {
3249
+ processMessage();
3250
+ }
3251
+ }
3252
+
3253
+ // Normally the parent kicks things off when it detects the iFrame has loaded.
3254
+ // If this script is async-loaded, then tell parent page to retry init.
3255
+ function chkLateLoaded() {
3256
+ if ('loading' !== document.readyState) {
3257
+ window.parent.postMessage('[iFrameResizerChild]Ready', '*');
3258
+ }
3259
+ }
3260
+
3261
+ addEventListener(window, 'message', receiver);
3262
+ addEventListener(window, 'readystatechange', chkLateLoaded);
3263
+ chkLateLoaded();
3264
+
3265
+
3266
+ })();
3267
+
501
3268
  var CONTAINER_ID = "__authsignal-popup-container";
502
3269
  var CONTENT_ID = "__authsignal-popup-content";
503
3270
  var OVERLAY_ID = "__authsignal-popup-overlay";
504
3271
  var STYLE_ID = "__authsignal-popup-style";
505
- var DEFAULT_WIDTH = "576px";
506
- var DEFAULT_HEIGHT = "600px";
3272
+ var IFRAME_ID = "__authsignal-popup-iframe";
3273
+ var DEFAULT_WIDTH = "385px";
507
3274
  var PopupHandler = /** @class */ (function () {
508
3275
  function PopupHandler(_a) {
509
- var width = _a.width, height = _a.height;
3276
+ var width = _a.width;
510
3277
  this.popup = null;
3278
+ this.isHeightAutoResized = true;
511
3279
  if (document.querySelector("#".concat(CONTAINER_ID))) {
512
3280
  throw new Error("Multiple instances of Authsignal popup is not supported.");
513
3281
  }
514
- this.create({ width: width, height: height });
3282
+ this.create({ width: width });
515
3283
  }
516
3284
  PopupHandler.prototype.create = function (_a) {
517
3285
  var _this = this;
518
- var _b = _a.width, width = _b === void 0 ? DEFAULT_WIDTH : _b, _c = _a.height, height = _c === void 0 ? DEFAULT_HEIGHT : _c;
3286
+ var _b = _a.width, width = _b === void 0 ? DEFAULT_WIDTH : _b;
519
3287
  var isWidthValidCSSValue = CSS.supports("width", width);
520
- var isHeightValidCSSValue = CSS.supports("height", height);
521
3288
  var popupWidth = width;
522
- var popupHeight = height;
523
3289
  if (!isWidthValidCSSValue) {
524
3290
  console.warn("Invalid CSS value for `popupOptions.width`. Using default value instead.");
525
3291
  popupWidth = DEFAULT_WIDTH;
526
3292
  }
527
- if (!isHeightValidCSSValue) {
528
- console.warn("Invalid CSS value for `popupOptions.height`. Using default value instead.");
529
- popupHeight = DEFAULT_HEIGHT;
530
- }
531
3293
  // Create dialog container
532
3294
  var container = document.createElement("div");
533
3295
  container.setAttribute("id", CONTAINER_ID);
@@ -543,7 +3305,7 @@ var PopupHandler = /** @class */ (function () {
543
3305
  // Create CSS for dialog
544
3306
  var style = document.createElement("style");
545
3307
  style.setAttribute("id", STYLE_ID);
546
- style.textContent = "\n #".concat(CONTAINER_ID, ",\n #").concat(OVERLAY_ID, " {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n }\n\n #").concat(CONTAINER_ID, " {\n z-index: 2147483647;\n display: flex;\n }\n\n #").concat(CONTAINER_ID, "[aria-hidden='true'] {\n display: none;\n }\n\n #").concat(OVERLAY_ID, " {\n background-color: rgba(43, 46, 56, 0.9);\n }\n\n #").concat(CONTENT_ID, " {\n margin: auto;\n z-index: 2147483647;\n position: relative;\n background-color: transparent;\n height: ").concat(popupHeight, ";\n width: ").concat(popupWidth, ";\n border-radius: 8px;\n }\n\n #").concat(CONTENT_ID, " iframe {\n width: 100%;\n height: 100%;\n border-radius: inherit;\n }\n ");
3308
+ style.textContent = "\n @keyframes fade-in {\n from {\n opacity: 0;\n }\n }\n \n @keyframes slide-up {\n from {\n transform: translateY(10%);\n }\n }\n\n #".concat(CONTAINER_ID, ",\n #").concat(OVERLAY_ID, " {\n position: fixed;\n top: 0;\n right: 0;\n bottom: 0;\n left: 0;\n }\n\n #").concat(CONTAINER_ID, " {\n z-index: 2147483647;\n display: flex;\n }\n\n #").concat(CONTAINER_ID, "[aria-hidden='true'] {\n display: none;\n }\n\n #").concat(OVERLAY_ID, " {\n background-color: rgba(0, 0, 0, 0.18);\n animation: fade-in 200ms both;\n }\n\n #").concat(CONTENT_ID, " {\n margin: auto;\n z-index: 2147483647;\n position: relative;\n background-color: transparent;\n border-radius: 8px;\n width: ").concat(popupWidth, ";\n animation: fade-in 400ms 200ms both, slide-up 400ms 200ms both;\n }\n\n #").concat(CONTENT_ID, " iframe {\n width: 1px;\n min-width: 100%;\n border-radius: inherit;\n max-height: 65vh;\n }\n\n @media (prefers-reduced-motion: reduce) {\n #").concat(OVERLAY_ID, ",\n #").concat(CONTENT_ID, " {\n animation: none;\n }\n }\n ");
547
3309
  // Attach the created elements
548
3310
  document.head.insertAdjacentElement("beforeend", style);
549
3311
  container.appendChild(overlay);
@@ -563,11 +3325,13 @@ var PopupHandler = /** @class */ (function () {
563
3325
  }
564
3326
  };
565
3327
  PopupHandler.prototype.show = function (_a) {
3328
+ var _this = this;
566
3329
  var url = _a.url;
567
3330
  if (!this.popup) {
568
3331
  throw new Error("Popup is not initialized");
569
3332
  }
570
3333
  var iframe = document.createElement("iframe");
3334
+ iframe.setAttribute("id", IFRAME_ID);
571
3335
  iframe.setAttribute("name", "authsignal");
572
3336
  iframe.setAttribute("title", "Authsignal multi-factor authentication");
573
3337
  iframe.setAttribute("src", url);
@@ -577,7 +3341,15 @@ var PopupHandler = /** @class */ (function () {
577
3341
  if (dialogContent) {
578
3342
  dialogContent.appendChild(iframe);
579
3343
  }
580
- this.popup.show();
3344
+ // @ts-expect-error can't get typescript import to behave nicely, this works though
3345
+ iFrameResize({
3346
+ checkOrigin: false,
3347
+ scrolling: true,
3348
+ onInit: function () {
3349
+ var _a;
3350
+ (_a = _this.popup) === null || _a === void 0 ? void 0 : _a.show();
3351
+ }
3352
+ }, iframe);
581
3353
  };
582
3354
  PopupHandler.prototype.close = function () {
583
3355
  if (!this.popup) {
@@ -628,7 +3400,7 @@ var Authsignal = /** @class */ (function () {
628
3400
  }
629
3401
  else {
630
3402
  var popupOptions = options.popupOptions;
631
- var Popup_1 = new PopupHandler({ width: popupOptions === null || popupOptions === void 0 ? void 0 : popupOptions.width, height: popupOptions === null || popupOptions === void 0 ? void 0 : popupOptions.height });
3403
+ var Popup_1 = new PopupHandler({ width: popupOptions === null || popupOptions === void 0 ? void 0 : popupOptions.width });
632
3404
  var popupUrl = "".concat(url, "&mode=popup");
633
3405
  Popup_1.show({ url: popupUrl });
634
3406
  return new Promise(function (resolve) {