From 46ac4c3fd2db9384e7be5b6a8949bf0ada2e1e92 Mon Sep 17 00:00:00 2001 From: "qingwei.li" Date: Wed, 20 Sep 2017 08:57:19 +0800 Subject: [PATCH] feat(plugin): add codesponsor plugin --- docs/index.html | 2 + src/core/util/dom.js | 5 ++ src/plugins/codesponsor.js | 86 +++++++++++++++++++++++++++++++++ src/plugins/search/component.js | 4 +- src/themes/basic/_layout.css | 3 +- 5 files changed, 97 insertions(+), 3 deletions(-) create mode 100644 src/plugins/codesponsor.js diff --git a/docs/index.html b/docs/index.html index 657a0487a..55dc8e6e6 100644 --- a/docs/index.html +++ b/docs/index.html @@ -34,6 +34,7 @@ mergeNavbar: true, maxLevel: 4, subMaxLevel: 2, + codesponsor: '7c9Ms7xRs-j_y_8abU03DA', ga: 'UA-106147152-1', name: 'docsify', search: { @@ -68,6 +69,7 @@ + diff --git a/src/core/util/dom.js b/src/core/util/dom.js index f554c2d57..4fa60beef 100644 --- a/src/core/util/dom.js +++ b/src/core/util/dom.js @@ -81,3 +81,8 @@ export function off (el, type, handler) { export function toggleClass (el, type, val) { el && el.classList[val ? type : 'toggle'](val || type) } + +export function style (content) { + appendTo(head, create('style', content)) +} + diff --git a/src/plugins/codesponsor.js b/src/plugins/codesponsor.js new file mode 100644 index 000000000..df20015c4 --- /dev/null +++ b/src/plugins/codesponsor.js @@ -0,0 +1,86 @@ +const DEFAULT_OPTIONS = { + theme: 'light', + image: 'show' +} + +function tpl (id, options) { + const qs = [] + + for (let key in options) { + qs.push(`${key}=${options[key]}`) + } + + const div = Docsify.dom.create('div') + + Docsify.dom.toggleClass(div, 'codesponsor') + div.innerHTML = `` + + return div +} + +function appIframe (id, opts) { + const html = tpl(id, opts) + + Docsify.dom.before(Docsify.dom.find('section.content'), html) +} + +function appendStyle () { + Docsify.dom.style(` + .codesponsor { + position: relative; + float: right; + right: 10px; + top: 10px; + } + + @media screen and (min-width: 1300px) { + body.sticky .codesponsor { + position: fixed; + } + + .codesponsor { + position: absolute; + bottom: 10px; + top: auto; + float: none; + } + } + `) +} + +const install = function (hook, vm) { + let config = vm.config.codesponsor + let id + + if (typeof config === 'string') { + id = config + config = {} + } else { + id = config.id + } + + const opts = Docsify.util.merge(DEFAULT_OPTIONS, config) + + if (!id) { + throw Error('codesponsor plugin need id') + } + + if (Docsify.util.isMobile) { + return + } + + // Append style + hook.ready(() => { + appendStyle() + appIframe(id, opts) + }) +} + +window.$docsify.plugins = [].concat(install, window.$docsify.plugins) diff --git a/src/plugins/search/component.js b/src/plugins/search/component.js index f629a0ab2..aab0c502b 100644 --- a/src/plugins/search/component.js +++ b/src/plugins/search/component.js @@ -64,8 +64,8 @@ function style () { .search p.empty { text-align: center; }` - const style = Docsify.dom.create('style', code) - Docsify.dom.appendTo(Docsify.dom.head, style) + + Docsify.dom.style(code) } function tpl (opts, defaultValue = '') { diff --git a/src/themes/basic/_layout.css b/src/themes/basic/_layout.css index d56e41dc0..222249a03 100644 --- a/src/themes/basic/_layout.css +++ b/src/themes/basic/_layout.css @@ -325,7 +325,7 @@ body.sticky { /* main content */ .content { - padding-top: 20px; + padding-top: 60px; position: absolute 0 0 0 $sidebar-width; transition: left 250ms ease; } @@ -471,6 +471,7 @@ body.close { left: 0; max-width: 100vw; position: static; + padding-top: 20px; transition: transform 250ms ease; }