Welcome to mirror list, hosted at ThFree Co, Russian Federation.

github.com/twbs/bootstrap.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorPuru Vijay <47742487+PuruVJ@users.noreply.github.com>2022-03-09 18:32:58 +0300
committerGitHub <noreply@github.com>2022-03-09 18:32:58 +0300
commit645f95584551409660fcd9b990fc24caa0327df5 (patch)
tree7c2e06398708c563cecd43c5b9df2d01188093fc
parent7e5a8016ba557641ee93b38aed4482a1360b64af (diff)
docs: add a StackBlitz "Try It" button in code examples (#35644)
Co-authored-by: GeoSot <geo.sotis@gmail.com> Co-authored-by: XhmikosR <xhmikosr@gmail.com>
-rw-r--r--site/assets/js/application.js27
-rw-r--r--site/assets/scss/_clipboard-js.scss11
-rw-r--r--site/layouts/partials/scripts.html45
-rw-r--r--site/layouts/shortcodes/example.html3
4 files changed, 74 insertions, 12 deletions
diff --git a/site/assets/js/application.js b/site/assets/js/application.js
index b267bfb6f2..1719ed9f2a 100644
--- a/site/assets/js/application.js
+++ b/site/assets/js/application.js
@@ -125,17 +125,24 @@
element.insertAdjacentHTML('beforebegin', btnHtml)
})
- document.querySelectorAll('.btn-clipboard')
- .forEach(function (btn) {
- var tooltipBtn = new bootstrap.Tooltip(btn, { title: btnTitle })
-
- btn.addEventListener('mouseleave', function () {
- // Explicitly hide tooltip, since after clicking it remains
- // focused (as it's a button), so tooltip would otherwise
- // remain visible until focus is moved away
- tooltipBtn.hide()
- })
+ /**
+ *
+ * @param {HTMLButtonElement} btn
+ * @param {string} title
+ */
+ function snippetButtonTooltip(btn, title) {
+ var tooltipBtn = new bootstrap.Tooltip(btn, { title: title })
+
+ btn.addEventListener('mouseleave', function () {
+ // Explicitly hide tooltip, since after clicking it remains
+ // focused (as it's a button), so tooltip would otherwise
+ // remain visible until focus is moved away
+ tooltipBtn.hide()
})
+ }
+
+ snippetButtonTooltip(document.querySelector('.btn-clipboard'), 'Copy to clipboard')
+ snippetButtonTooltip(document.querySelector('.btn-edit'), 'Edit on Stackblitz')
var clipboard = new ClipboardJS('.btn-clipboard', {
target: function (trigger) {
diff --git a/site/assets/scss/_clipboard-js.scss b/site/assets/scss/_clipboard-js.scss
index 83b9a8b9e5..b2b0854dc4 100644
--- a/site/assets/scss/_clipboard-js.scss
+++ b/site/assets/scss/_clipboard-js.scss
@@ -2,7 +2,8 @@
//
// JS-based `Copy` buttons for code snippets.
-.bd-clipboard {
+.bd-clipboard,
+.bd-edit {
position: relative;
display: none;
float: right;
@@ -16,7 +17,8 @@
}
}
-.btn-clipboard {
+.btn-clipboard,
+.btn-edit {
position: absolute;
top: .65rem;
right: .65rem;
@@ -25,6 +27,7 @@
padding: .25rem .5rem;
@include font-size(.65em);
color: $primary;
+ white-space: nowrap;
background-color: $white;
border: 1px solid;
@include border-radius();
@@ -35,3 +38,7 @@
background-color: $primary;
}
}
+
+.btn-edit {
+ right: 3.65rem;
+}
diff --git a/site/layouts/partials/scripts.html b/site/layouts/partials/scripts.html
index d25add3ff4..0724a39ee1 100644
--- a/site/layouts/partials/scripts.html
+++ b/site/layouts/partials/scripts.html
@@ -6,6 +6,7 @@
{{ if eq .Page.Layout "docs" -}}
<script src="https://cdn.jsdelivr.net/npm/docsearch.js@2/dist/cdn/docsearch.min.js"></script>
+<script src="https://cdn.jsdelivr.net/npm/@stackblitz/sdk@1/bundles/sdk.umd.js"></script>
{{- end }}
{{- $vendor := resources.Match "js/vendor/*.js" -}}
@@ -18,3 +19,47 @@
{{- end }}
<script src="{{ $docsJs.Permalink | relURL }}"></script>
+
+{{ if eq .Page.Layout "docs" -}}
+<script>
+ // Open in StackBlitz logic
+ document.querySelectorAll('.btn-edit')
+ .forEach(function (btn) {
+ btn.addEventListener('click', function (event) {
+ var htmlSnippet = event.target.closest('.bd-content').querySelector('.bd-example').innerHTML
+
+ StackBlitzSDK.openBootstrapSnippet(htmlSnippet)
+ })
+ })
+
+ StackBlitzSDK.openBootstrapSnippet = function(snippet) {
+ var project = {
+ files: {
+ 'index.html': `<!doctype html>
+<html lang="en">
+ <head>
+ <meta charset="utf-8">
+ <meta name="viewport" content="width=device-width, initial-scale=1">
+ <link href="{{ .Site.Params.cdn.css }}" rel="stylesheet">
+ <title>Bootstrap Example</title>
+ </head>
+ <body>
+
+ <!-- Example Code -->
+${snippet.replace(/^/gm, ' ')}
+ <!-- End Example Code -->
+
+ <${'script'} src="{{ .Site.Params.cdn.js_bundle }}"></${'script'}>
+ </body>
+</html>`
+ },
+ title: 'Bootstrap Example',
+ description: 'Official example from ' + window.location.href,
+ template: 'html',
+ tags: ['bootstrap']
+ }
+
+ StackBlitzSDK.openProject(project, { openFile: 'index.html' })
+ }
+</script>
+{{- end }}
diff --git a/site/layouts/shortcodes/example.html b/site/layouts/shortcodes/example.html
index 0592adc6b5..a808c2589a 100644
--- a/site/layouts/shortcodes/example.html
+++ b/site/layouts/shortcodes/example.html
@@ -22,6 +22,9 @@
{{- end -}}
{{- if eq $show_markup true -}}
+ <div class="bd-edit">
+ <button type="button" class="btn-edit text-nowrap" title="Try it on StackBlitz">Try it</button>
+ </div>
{{- $content := replaceRE `<svg class="bd-placeholder-img(?:-lg)?(?: *?bd-placeholder-img-lg)? ?(.*?)".*?<\/svg>\n` `<img src="..." class="$1" alt="...">` $input -}}
{{- $content = replaceRE ` (class=" *?")` "" $content -}}
{{- highlight (trim $content "\n") $lang "" -}}