UNPKG

markdown-it-image-loading

Version:
38 lines (27 loc) 13.4 kB
'use strict'; const defaultLoadingImg = ""; const defaultOptions = { loadingSrc: defaultLoadingImg, loadingWidth: 30, loadingHeight: 30, minWidth: 100, minHeight: 100, bgColor: '' } module.exports = function loading(md, options) { md.use(require('markdown-it-attrs')) var defaultImageRenderer = md.renderer.rules.image; md.renderer.rules.image = function (tokens, idx, imageOptions, env, self) { let opts = {} const token = tokens[idx] const attrs = token.attrs || [] const attrObj = {} attrs.forEach(v => { attrObj[v[0]] = v[1] }) opts = Object.assign({ ...defaultOptions }, options, attrObj) const style = `min-width: ${opts.minWidth}px;min-height: ${opts.minHeight}px;background:url(${opts.loadingSrc}) no-repeat center;background-size: ${opts.loadingWidth}px ${opts.loadingHeight}px;background-color:${opts.bgColor}` token.attrSet('style', style); return defaultImageRenderer(tokens, idx, imageOptions, env, self); }; };