summaryrefslogtreecommitdiff
path: root/maintenance/jsduck/eg-iframe.html
blob: fca839d99ba51aa625e58fb6ef523c8d5d1243f8 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
<!DOCTYPE html>
<html>
<head>
	<meta charset="utf-8">
	<title>MediaWiki Code Example</title>
	<script>
		/**
		 * Basic log console for the example iframe in documentation pages.
		 */
		var log = ( function () {
			var pre;
			return function () {
				var str, i, len, line;
				if ( !pre ) {
					pre = document.createElement( 'pre' );
					pre.className = 'mw-jsduck-log';
					( document.body || document.documentElement ).appendChild( pre );
				}
				str = [];
				for ( i = 0, len = arguments.length; i < len; i++ ) {
					str.push( String( arguments[ i ] ) );
				}
				line = document.createElement( 'div' );
				line.className = 'mw-jsduck-log-line';
				line.appendChild(
						document.createTextNode( str.join( ' , ' ) + '\n' )
				);
				pre.appendChild( line );
			};
		}() );

		window.onerror = function ( error, filePath, linerNr ) {
			log( error + '\n' + filePath + ':' + linerNr  );
		};
	</script>
	<script src="modules/src/startup.js"></script>
	<script>
		function startUp() {
			mw.config = new mw.Map();
		}
	</script>
	<script src="modules/lib/jquery/jquery.js"></script>
	<script src="modules/src/mediawiki/mediawiki.js"></script>
	<script src="modules/src/mediawiki/mediawiki.errorLogger.js"></script>
	<script src="modules/src/mediawiki/mediawiki.startUp.js"></script>
	<style>
		.mw-jsduck-log {
			position: relative;
			min-height: 3em;
			margin-top: 2em;
			background: #f7f7f7;
			border: 1px solid #e4e4e4;
		}

		.mw-jsduck-log::after {
			position: absolute;
			bottom: 100%;
			right: -1px;
			padding: 0.5em;
			background: #fff;
			border: 1px solid #e4e4e4;
			border-bottom: 0;
			border-radius: 0.5em 0.5em 0 0;
			font: normal 0.5em sans-serif;
			content: 'console';
		}

		.mw-jsduck-log-line {
			padding: 0.2em 0.5em;
			white-space: pre-wrap;
		}

		.mw-jsduck-log-line:nth-child(odd) {
			background: #fff;
		}
	</style>
</head>
<body>
<script>
	if ( window.mw ) {
		mw.log = log;
	}

	window.onerror = function ( error, filePath, linerNr ) {
		log( filePath + ':' + linerNr  );
	};

	/**
	 * Method called by jsduck to execute the example code.
	 */
	function loadInlineExample( code, options, callback ) {
		try {
			eval( code );
			callback && callback( true );
		} catch ( e ) {
			log( 'Uncaught ' + e );
			callback && callback( false, e );
			throw e;
		}
	}
</script>
</body>
</html>