diff --git a/media/js/wiki.js b/media/js/wiki.js index 0fdc417b0d4..694ebdbffcc 100644 --- a/media/js/wiki.js +++ b/media/js/wiki.js @@ -847,5 +847,70 @@ if($('details').length){ initDetailsTags(); } + + function create_jsfiddle(title, htmlCode, cssCode, jsCode) { + var $form = $('
'); + $form.find('input[name=html]').val(htmlCode); + $form.find('input[name=css]').val(cssCode); + $form.find('input[name=js]').val(jsCode); + $form.find('input[name=title]').val(title); + $form.submit(); + } + + function create_codepen(title, htmlCode, cssCode, jsCode) { + var $form = $(''); + var data = {'title': title, 'html': htmlCode, 'css': cssCode, 'js': jsCode}; + $form.find('input[name=data]').val(JSON.stringify(data)); + $form.submit(); + } + + function create_sample(sampleCodeHost, title, htmlCode, cssCode, jsCode) { + if(sampleCodeHost == 'jsfiddle') { + create_jsfiddle(title, htmlCode, cssCode, jsCode); + } else if(sampleCodeHost == 'codepen') { + create_codepen(title, htmlCode, cssCode, jsCode); + } + } + + $('#wikiArticle').on('click', 'button.open-in-host', function(){ + var $button = $(this); + var section = $button.attr('data-section'); + var sampleCodeHost = $button.attr('data-host'); + + + // disable the button, till we open the fiddle + if($button.attr('disabled')) return; + + // track the click and sample code host + mdn.analytics.trackEvent({ + category: 'Samples', + action: 'open-' + sampleCodeHost, + label: section + }); + + $button.attr('disabled', '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_sample(sampleCodeHost, title, htmlCode, cssCode, jsCode); + + $button.removeAttr('disabled'); + }); + }); })(window, document, jQuery); diff --git a/media/stylus/base/elements/forms.styl b/media/stylus/base/elements/forms.styl index 623848d5037..6fc5c5eda2f 100644 --- a/media/stylus/base/elements/forms.styl +++ b/media/stylus/base/elements/forms.styl @@ -114,3 +114,7 @@ label { text-decoration: none; } } + +.open-in-host + .open-in-host { + bidi-style(margin-left, ($grid-spacing / 2), margin-right, 0); +} \ No newline at end of file diff --git a/media/stylus/components/wiki/fiddle-buttons.styl b/media/stylus/components/wiki/fiddle-buttons.styl new file mode 100644 index 00000000000..e69de29bb2d