markmap-toolbar
Advanced tools
Comparing version 0.15.5 to 0.15.6-alpha.4
@@ -1,307 +0,293 @@ | ||
/*! markmap-toolbar v0.15.5 | MIT License */ | ||
(function (global, factory) { | ||
typeof exports === 'object' && typeof module !== 'undefined' ? factory(exports) : | ||
typeof define === 'function' && define.amd ? define(['exports'], factory) : | ||
(global = typeof globalThis !== 'undefined' ? globalThis : global || self, factory(global.markmap = global.markmap || {})); | ||
})(this, (function (exports) { 'use strict'; | ||
function _extends() { | ||
_extends = Object.assign ? Object.assign.bind() : function (target) { | ||
for (var i = 1; i < arguments.length; i++) { | ||
var source = arguments[i]; | ||
for (var key in source) { | ||
if (Object.prototype.hasOwnProperty.call(source, key)) { | ||
target[key] = source[key]; | ||
} | ||
} | ||
} | ||
return target; | ||
(function(exports) { | ||
"use strict"; | ||
/*! @gera2ld/jsx-dom v2.2.2 | ISC License */ | ||
const VTYPE_ELEMENT = 1; | ||
const VTYPE_FUNCTION = 2; | ||
const SVG_NS = "http://www.w3.org/2000/svg"; | ||
const XLINK_NS = "http://www.w3.org/1999/xlink"; | ||
const NS_ATTRS = { | ||
show: XLINK_NS, | ||
actuate: XLINK_NS, | ||
href: XLINK_NS | ||
}; | ||
return _extends.apply(this, arguments); | ||
} | ||
/*! @gera2ld/jsx-dom v2.2.2 | ISC License */ | ||
const VTYPE_ELEMENT = 1; | ||
const VTYPE_FUNCTION = 2; | ||
const SVG_NS = 'http://www.w3.org/2000/svg'; | ||
const XLINK_NS = 'http://www.w3.org/1999/xlink'; | ||
const NS_ATTRS = { | ||
show: XLINK_NS, | ||
actuate: XLINK_NS, | ||
href: XLINK_NS | ||
}; | ||
const isLeaf = c => typeof c === 'string' || typeof c === 'number'; | ||
const isElement = c => (c == null ? void 0 : c.vtype) === VTYPE_ELEMENT; | ||
const isRenderFunction = c => (c == null ? void 0 : c.vtype) === VTYPE_FUNCTION; | ||
function jsx(type, props) { | ||
let vtype; | ||
if (typeof type === 'string') vtype = VTYPE_ELEMENT;else if (typeof type === 'function') vtype = VTYPE_FUNCTION;else throw new Error('Invalid VNode type'); | ||
return { | ||
vtype, | ||
type, | ||
props | ||
const isLeaf = (c) => typeof c === "string" || typeof c === "number"; | ||
const isElement = (c) => (c == null ? void 0 : c.vtype) === VTYPE_ELEMENT; | ||
const isRenderFunction = (c) => (c == null ? void 0 : c.vtype) === VTYPE_FUNCTION; | ||
function jsx(type, props) { | ||
let vtype; | ||
if (typeof type === "string") | ||
vtype = VTYPE_ELEMENT; | ||
else if (typeof type === "function") | ||
vtype = VTYPE_FUNCTION; | ||
else | ||
throw new Error("Invalid VNode type"); | ||
return { | ||
vtype, | ||
type, | ||
props | ||
}; | ||
} | ||
const jsxs = jsx; | ||
function Fragment(props) { | ||
return props.children; | ||
} | ||
const DEFAULT_ENV = { | ||
isSvg: false | ||
}; | ||
} | ||
const jsxs = jsx; | ||
function Fragment(props) { | ||
return props.children; | ||
} | ||
const DEFAULT_ENV = { | ||
isSvg: false | ||
}; | ||
function insertDom(parent, nodes) { | ||
if (!Array.isArray(nodes)) nodes = [nodes]; | ||
nodes = nodes.filter(Boolean); | ||
if (nodes.length) parent.append(...nodes); | ||
} | ||
function mountAttributes(domElement, props, env) { | ||
for (const key in props) { | ||
if (key === 'key' || key === 'children' || key === 'ref') continue; | ||
if (key === 'dangerouslySetInnerHTML') { | ||
domElement.innerHTML = props[key].__html; | ||
} else if (key === 'innerHTML' || key === 'textContent' || key === 'innerText' || key === 'value' && ['textarea', 'select'].includes(domElement.tagName)) { | ||
const value = props[key]; | ||
if (value != null) domElement[key] = value; | ||
} else if (key.startsWith('on')) { | ||
domElement[key.toLowerCase()] = props[key]; | ||
} else { | ||
setDOMAttribute(domElement, key, props[key], env.isSvg); | ||
function insertDom(parent, nodes) { | ||
if (!Array.isArray(nodes)) | ||
nodes = [nodes]; | ||
nodes = nodes.filter(Boolean); | ||
if (nodes.length) | ||
parent.append(...nodes); | ||
} | ||
function mountAttributes(domElement, props, env) { | ||
for (const key in props) { | ||
if (key === "key" || key === "children" || key === "ref") | ||
continue; | ||
if (key === "dangerouslySetInnerHTML") { | ||
domElement.innerHTML = props[key].__html; | ||
} else if (key === "innerHTML" || key === "textContent" || key === "innerText" || key === "value" && ["textarea", "select"].includes(domElement.tagName)) { | ||
const value = props[key]; | ||
if (value != null) | ||
domElement[key] = value; | ||
} else if (key.startsWith("on")) { | ||
domElement[key.toLowerCase()] = props[key]; | ||
} else { | ||
setDOMAttribute(domElement, key, props[key], env.isSvg); | ||
} | ||
} | ||
} | ||
} | ||
const attrMap = { | ||
className: 'class', | ||
labelFor: 'for' | ||
}; | ||
function setDOMAttribute(el, attr, value, isSVG) { | ||
attr = attrMap[attr] || attr; | ||
if (value === true) { | ||
el.setAttribute(attr, ''); | ||
} else if (value === false) { | ||
el.removeAttribute(attr); | ||
} else { | ||
const namespace = isSVG ? NS_ATTRS[attr] : undefined; | ||
if (namespace !== undefined) { | ||
el.setAttributeNS(namespace, attr, value); | ||
const attrMap = { | ||
className: "class", | ||
labelFor: "for" | ||
}; | ||
function setDOMAttribute(el, attr, value, isSVG) { | ||
attr = attrMap[attr] || attr; | ||
if (value === true) { | ||
el.setAttribute(attr, ""); | ||
} else if (value === false) { | ||
el.removeAttribute(attr); | ||
} else { | ||
el.setAttribute(attr, value); | ||
const namespace = isSVG ? NS_ATTRS[attr] : void 0; | ||
if (namespace !== void 0) { | ||
el.setAttributeNS(namespace, attr, value); | ||
} else { | ||
el.setAttribute(attr, value); | ||
} | ||
} | ||
} | ||
} | ||
function flatten(arr) { | ||
return arr.reduce((prev, item) => prev.concat(item), []); | ||
} | ||
function mountChildren(children, env) { | ||
return Array.isArray(children) ? flatten(children.map(child => mountChildren(child, env))) : mount(children, env); | ||
} | ||
function mount(vnode, env = DEFAULT_ENV) { | ||
if (vnode == null || typeof vnode === 'boolean') { | ||
return null; | ||
function flatten(arr) { | ||
return arr.reduce((prev, item) => prev.concat(item), []); | ||
} | ||
if (vnode instanceof Node) { | ||
return vnode; | ||
function mountChildren(children, env) { | ||
return Array.isArray(children) ? flatten(children.map((child) => mountChildren(child, env))) : mount(children, env); | ||
} | ||
if (isRenderFunction(vnode)) { | ||
const { | ||
type, | ||
props | ||
} = vnode; | ||
if (type === Fragment) { | ||
const node = document.createDocumentFragment(); | ||
if (props.children) { | ||
const children = mountChildren(props.children, env); | ||
insertDom(node, children); | ||
function mount(vnode, env = DEFAULT_ENV) { | ||
if (vnode == null || typeof vnode === "boolean") { | ||
return null; | ||
} | ||
if (vnode instanceof Node) { | ||
return vnode; | ||
} | ||
if (isRenderFunction(vnode)) { | ||
const { | ||
type, | ||
props | ||
} = vnode; | ||
if (type === Fragment) { | ||
const node = document.createDocumentFragment(); | ||
if (props.children) { | ||
const children = mountChildren(props.children, env); | ||
insertDom(node, children); | ||
} | ||
return node; | ||
} | ||
return node; | ||
const childVNode = type(props); | ||
return mount(childVNode, env); | ||
} | ||
const childVNode = type(props); | ||
return mount(childVNode, env); | ||
} | ||
if (isLeaf(vnode)) { | ||
return document.createTextNode(`${vnode}`); | ||
} | ||
if (isElement(vnode)) { | ||
let node; | ||
const { | ||
type, | ||
props | ||
} = vnode; | ||
if (!env.isSvg && type === 'svg') { | ||
env = Object.assign({}, env, { | ||
isSvg: true | ||
}); | ||
if (isLeaf(vnode)) { | ||
return document.createTextNode(`${vnode}`); | ||
} | ||
if (!env.isSvg) { | ||
node = document.createElement(type); | ||
} else { | ||
node = document.createElementNS(SVG_NS, type); | ||
} | ||
mountAttributes(node, props, env); | ||
if (props.children) { | ||
let childEnv = env; | ||
if (env.isSvg && type === 'foreignObject') { | ||
childEnv = Object.assign({}, childEnv, { | ||
isSvg: false | ||
if (isElement(vnode)) { | ||
let node; | ||
const { | ||
type, | ||
props | ||
} = vnode; | ||
if (!env.isSvg && type === "svg") { | ||
env = Object.assign({}, env, { | ||
isSvg: true | ||
}); | ||
} | ||
const children = mountChildren(props.children, childEnv); | ||
if (children != null) insertDom(node, children); | ||
if (!env.isSvg) { | ||
node = document.createElement(type); | ||
} else { | ||
node = document.createElementNS(SVG_NS, type); | ||
} | ||
mountAttributes(node, props, env); | ||
if (props.children) { | ||
let childEnv = env; | ||
if (env.isSvg && type === "foreignObject") { | ||
childEnv = Object.assign({}, childEnv, { | ||
isSvg: false | ||
}); | ||
} | ||
const children = mountChildren(props.children, childEnv); | ||
if (children != null) | ||
insertDom(node, children); | ||
} | ||
const { | ||
ref | ||
} = props; | ||
if (typeof ref === "function") | ||
ref(node); | ||
return node; | ||
} | ||
const { | ||
ref | ||
} = props; | ||
if (typeof ref === 'function') ref(node); | ||
return node; | ||
throw new Error("mount: Invalid Vnode!"); | ||
} | ||
throw new Error('mount: Invalid Vnode!'); | ||
} | ||
/** | ||
* Mount vdom as real DOM nodes. | ||
*/ | ||
function mountDom(vnode) { | ||
return mount(vnode); | ||
} | ||
const clsToolbarItem = 'mm-toolbar-item'; | ||
const clsActive = 'active'; | ||
function renderBrand() { | ||
return jsxs("a", { | ||
className: "mm-toolbar-brand", | ||
href: "https://markmap.js.org/", | ||
children: [jsx("img", { | ||
alt: "markmap", | ||
src: "" | ||
}), jsx("span", { | ||
children: "markmap" | ||
})] | ||
}); | ||
} | ||
function renderItem({ | ||
title, | ||
content, | ||
onClick | ||
}) { | ||
return jsx("div", { | ||
className: clsToolbarItem, | ||
title: title, | ||
onClick: onClick, | ||
children: content | ||
}); | ||
} | ||
let promise; | ||
function safeCaller(fn) { | ||
return async (...args) => { | ||
if (promise) return; | ||
promise = fn(...args); | ||
try { | ||
await promise; | ||
} finally { | ||
promise = undefined; | ||
} | ||
}; | ||
} | ||
class Toolbar { | ||
static create(mm) { | ||
const toolbar = new Toolbar(); | ||
toolbar.attach(mm); | ||
return toolbar; | ||
function mountDom(vnode) { | ||
return mount(vnode); | ||
} | ||
static icon(path, attrs = {}) { | ||
attrs = _extends({ | ||
stroke: 'none', | ||
fill: 'currentColor', | ||
'fill-rule': 'evenodd' | ||
}, attrs); | ||
return jsx("svg", { | ||
width: "20", | ||
height: "20", | ||
viewBox: "0 0 20 20", | ||
children: jsx("path", _extends({}, attrs, { | ||
d: path | ||
})) | ||
}); | ||
const clsToolbarItem = "mm-toolbar-item"; | ||
const clsActive = "active"; | ||
function renderBrand() { | ||
return /* @__PURE__ */ jsxs("a", { className: "mm-toolbar-brand", href: "https://markmap.js.org/", children: [ | ||
/* @__PURE__ */ jsx( | ||
"img", | ||
{ | ||
alt: "markmap", | ||
src: "" | ||
} | ||
), | ||
/* @__PURE__ */ jsx("span", { children: "markmap" }) | ||
] }); | ||
} | ||
constructor() { | ||
this.showBrand = true; | ||
this.registry = {}; | ||
this.el = mountDom(jsx("div", { | ||
className: "mm-toolbar" | ||
})); | ||
this.items = [...Toolbar.defaultItems]; | ||
this.register({ | ||
id: 'zoomIn', | ||
title: 'Zoom in', | ||
content: Toolbar.icon('M9 5v4h-4v2h4v4h2v-4h4v-2h-4v-4z'), | ||
onClick: this.getHandler(mm => mm.rescale(1.25)) | ||
}); | ||
this.register({ | ||
id: 'zoomOut', | ||
title: 'Zoom out', | ||
content: Toolbar.icon('M5 9h10v2h-10z'), | ||
onClick: this.getHandler(mm => mm.rescale(0.8)) | ||
}); | ||
this.register({ | ||
id: 'fit', | ||
title: 'Fit window size', | ||
content: Toolbar.icon('M4 7h2v-2h2v4h-4zM4 13h2v2h2v-4h-4zM16 7h-2v-2h-2v4h4zM16 13h-2v2h-2v-4h4z'), | ||
onClick: this.getHandler(mm => mm.fit()) | ||
}); | ||
this.register({ | ||
id: 'recurse', | ||
title: 'Toggle recursively', | ||
content: Toolbar.icon('M16 4h-12v12h12v-8h-8v4h2v-2h4v4h-8v-8h10z'), | ||
onClick: e => { | ||
var _this$markmap; | ||
const button = e.target.closest(`.${clsToolbarItem}`); | ||
const active = button == null ? void 0 : button.classList.toggle(clsActive); | ||
(_this$markmap = this.markmap) == null || _this$markmap.setOptions({ | ||
toggleRecursively: active | ||
}); | ||
function renderItem({ title, content, onClick }) { | ||
return /* @__PURE__ */ jsx("div", { className: clsToolbarItem, title, onClick, children: content }); | ||
} | ||
let promise; | ||
function safeCaller(fn) { | ||
return async (...args) => { | ||
if (promise) | ||
return; | ||
promise = fn(...args); | ||
try { | ||
await promise; | ||
} finally { | ||
promise = void 0; | ||
} | ||
}); | ||
this.render(); | ||
} | ||
setBrand(show) { | ||
this.showBrand = show; | ||
return this.render(); | ||
} | ||
register(data) { | ||
this.registry[data.id] = data; | ||
} | ||
getHandler(handle) { | ||
handle = safeCaller(handle); | ||
return () => { | ||
if (this.markmap) handle(this.markmap); | ||
}; | ||
} | ||
setItems(items) { | ||
this.items = [...items]; | ||
return this.render(); | ||
} | ||
attach(mm) { | ||
this.markmap = mm; | ||
} | ||
render() { | ||
const items = this.items.map(item => { | ||
if (typeof item === 'string') { | ||
const data = this.registry[item]; | ||
if (!data) console.warn(`[markmap-toolbar] ${item} not found`); | ||
return data; | ||
const _Toolbar = class _Toolbar { | ||
constructor() { | ||
this.showBrand = true; | ||
this.registry = {}; | ||
this.el = mountDom(/* @__PURE__ */ jsx("div", { className: "mm-toolbar" })); | ||
this.items = [..._Toolbar.defaultItems]; | ||
this.register({ | ||
id: "zoomIn", | ||
title: "Zoom in", | ||
content: _Toolbar.icon("M9 5v4h-4v2h4v4h2v-4h4v-2h-4v-4z"), | ||
onClick: this.getHandler((mm) => mm.rescale(1.25)) | ||
}); | ||
this.register({ | ||
id: "zoomOut", | ||
title: "Zoom out", | ||
content: _Toolbar.icon("M5 9h10v2h-10z"), | ||
onClick: this.getHandler((mm) => mm.rescale(0.8)) | ||
}); | ||
this.register({ | ||
id: "fit", | ||
title: "Fit window size", | ||
content: _Toolbar.icon( | ||
"M4 7h2v-2h2v4h-4zM4 13h2v2h2v-4h-4zM16 7h-2v-2h-2v4h4zM16 13h-2v2h-2v-4h4z" | ||
), | ||
onClick: this.getHandler((mm) => mm.fit()) | ||
}); | ||
this.register({ | ||
id: "recurse", | ||
title: "Toggle recursively", | ||
content: _Toolbar.icon("M16 4h-12v12h12v-8h-8v4h2v-2h4v4h-8v-8h10z"), | ||
onClick: (e) => { | ||
var _a; | ||
const button = e.target.closest( | ||
`.${clsToolbarItem}` | ||
); | ||
const active = button == null ? void 0 : button.classList.toggle(clsActive); | ||
(_a = this.markmap) == null ? void 0 : _a.setOptions({ | ||
toggleRecursively: active | ||
}); | ||
} | ||
}); | ||
this.render(); | ||
} | ||
static create(mm) { | ||
const toolbar = new _Toolbar(); | ||
toolbar.attach(mm); | ||
return toolbar; | ||
} | ||
static icon(path, attrs = {}) { | ||
attrs = { | ||
stroke: "none", | ||
fill: "currentColor", | ||
"fill-rule": "evenodd", | ||
...attrs | ||
}; | ||
return /* @__PURE__ */ jsx("svg", { width: "20", height: "20", viewBox: "0 0 20 20", children: /* @__PURE__ */ jsx("path", { ...attrs, d: path }) }); | ||
} | ||
setBrand(show) { | ||
this.showBrand = show; | ||
return this.render(); | ||
} | ||
register(data) { | ||
this.registry[data.id] = data; | ||
} | ||
getHandler(handle) { | ||
handle = safeCaller(handle); | ||
return () => { | ||
if (this.markmap) | ||
handle(this.markmap); | ||
}; | ||
} | ||
setItems(items) { | ||
this.items = [...items]; | ||
return this.render(); | ||
} | ||
attach(mm) { | ||
this.markmap = mm; | ||
} | ||
render() { | ||
const items = this.items.map((item) => { | ||
if (typeof item === "string") { | ||
const data = this.registry[item]; | ||
if (!data) | ||
console.warn(`[markmap-toolbar] ${item} not found`); | ||
return data; | ||
} | ||
return item; | ||
}).filter(Boolean); | ||
while (this.el.firstChild) { | ||
this.el.firstChild.remove(); | ||
} | ||
return item; | ||
}).filter(Boolean); | ||
while (this.el.firstChild) { | ||
this.el.firstChild.remove(); | ||
this.el.append( | ||
mountDom( | ||
/* @__PURE__ */ jsxs(Fragment, { children: [ | ||
this.showBrand && renderBrand(), | ||
items.map(renderItem) | ||
] }) | ||
) | ||
); | ||
return this.el; | ||
} | ||
this.el.append(mountDom(jsxs(Fragment, { | ||
children: [this.showBrand && renderBrand(), items.map(renderItem)] | ||
}))); | ||
return this.el; | ||
} | ||
} | ||
Toolbar.defaultItems = ['zoomIn', 'zoomOut', 'fit', 'recurse']; | ||
exports.Toolbar = Toolbar; | ||
})); | ||
}; | ||
_Toolbar.defaultItems = [ | ||
"zoomIn", | ||
"zoomOut", | ||
"fit", | ||
"recurse" | ||
]; | ||
let Toolbar = _Toolbar; | ||
exports.Toolbar = Toolbar; | ||
Object.defineProperty(exports, Symbol.toStringTag, { value: "Module" }); | ||
})(this.markmap = this.markmap || {}); |
{ | ||
"name": "markmap-toolbar", | ||
"version": "0.15.5", | ||
"version": "0.15.6-alpha.4+4734119", | ||
"description": "Extensible toolbar for markmap", | ||
@@ -8,6 +8,5 @@ "author": "Gerald <gera2ld@live.com>", | ||
"scripts": { | ||
"dev": "rollup -wc rollup.conf.js", | ||
"clean": "del-cli dist types", | ||
"clean": "del-cli dist", | ||
"build:types": "tsc", | ||
"build:js": "rollup -c rollup.conf.js" | ||
"build:js": "vite build && TARGET=es vite build --emptyOutDir=false" | ||
}, | ||
@@ -19,4 +18,3 @@ "main": "dist/index.js", | ||
"files": [ | ||
"dist", | ||
"types" | ||
"dist" | ||
], | ||
@@ -35,3 +33,3 @@ "publishConfig": { | ||
}, | ||
"typings": "types/index.d.ts", | ||
"typings": "dist/index.d.ts", | ||
"peerDependencies": { | ||
@@ -42,3 +40,3 @@ "markmap-common": "*" | ||
"markmap-common": "0.15.5", | ||
"markmap-view": "0.15.5" | ||
"markmap-view": "0.15.6-alpha.4+4734119" | ||
}, | ||
@@ -49,3 +47,3 @@ "dependencies": { | ||
}, | ||
"gitHead": "f7bda12b219cba3833dec1dae1daad14c3b53db6" | ||
"gitHead": "473411985496abcc20a546978438614c48ec56cf" | ||
} |
Sorry, the diff of this file is not supported yet
Sorry, the diff of this file is not supported yet
Manifest confusion
Supply chain riskThis package has inconsistent metadata. This could be malicious or caused by an error when publishing the package.
Found 1 instance in 1 package
25078
656
1