Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

markmap-toolbar

Package Overview
Dependencies
Maintainers
1
Versions
86
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

markmap-toolbar - npm Package Compare versions

Comparing version 0.15.5 to 0.15.6-alpha.4

dist/index.d.ts

554

dist/index.js

@@ -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

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc