diff --git a/media/js/wiki.js b/media/js/wiki.js index 0fdc417b0d4..186be4e053f 100644 --- a/media/js/wiki.js +++ b/media/js/wiki.js @@ -847,5 +847,53 @@ if($('details').length){ initDetailsTags(); } + + function create_fiddle(title, htmlCode, cssCode, jsCode) { + var $form = $('
' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '' + + '
'); + $form.find('#html').val(htmlCode); + $form.find('#css').val(cssCode); + $form.find('#js').val(jsCode); + $form.submit(); + } + + $('a.open-in-jsfiddle').on('click', function(e){ + // don't change hash on page + e.stopPropagation(); + e.preventDefault(); + var $button = $(this); + var isDisabled = $button.attr('data-disabled'); + var section = $button.attr('href').substring(1); + mdn.analytics.trackEvent({ + category: 'Samples', + action: 'Open-JSFiddle', + label: section + }); + // disable the button, till we open the fiddle + if(isDisabled == "true") return; + $button.attr('data-disabled', true); + $button.addClass('disabled'); + var sampleUrl = window.location.href.split('#')[0] + '?section=' + section + '&raw=1'; + $.get(sampleUrl).then(function(sample) { + var $sample = $('
').append(sample); + var htmlCode = $sample.find('.brush\\:.html').text(); + var cssCode = $sample.find('.brush\\:.css').text(); + var jsCode = $sample.find('.brush\\:.js').text(); + var title = section.replace('_', ' '); + create_fiddle(title, htmlCode, cssCode, jsCode); + $button.attr('data-disabled', false); + $button.removeClass('disabled'); + }); + }); })(window, document, jQuery);