@vizel/core 0.0.1-alpha.5 → 1.0.0

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
Files changed (75) hide show
  1. package/dist/components.css +1 -1
  2. package/dist/components.css.map +1 -1
  3. package/dist/index.d.ts +230 -15
  4. package/dist/index.js +78 -75
  5. package/dist/index10.js +1 -1
  6. package/dist/index11.js +4 -4
  7. package/dist/index14.js +1 -1
  8. package/dist/index15.js +134 -127
  9. package/dist/index17.js +2 -2
  10. package/dist/index18.js +1 -1
  11. package/dist/index19.js +86 -86
  12. package/dist/index20.js +2 -2
  13. package/dist/index21.js +2 -2
  14. package/dist/index22.js +16 -13
  15. package/dist/index24.js +164 -11
  16. package/dist/index25.js +12 -53
  17. package/dist/index26.js +49 -136
  18. package/dist/index27.js +132 -59
  19. package/dist/index28.js +66 -32
  20. package/dist/index29.js +35 -21
  21. package/dist/index3.js +91 -90
  22. package/dist/index30.js +23 -9
  23. package/dist/index31.js +9 -147
  24. package/dist/index32.js +138 -256
  25. package/dist/index33.js +258 -85
  26. package/dist/index34.js +84 -55
  27. package/dist/index35.js +64 -4
  28. package/dist/index36.js +4 -123
  29. package/dist/index37.js +111 -315
  30. package/dist/index38.js +321 -481
  31. package/dist/index39.js +12 -47
  32. package/dist/index4.js +1 -1
  33. package/dist/index40.js +463 -655
  34. package/dist/index41.js +48 -4
  35. package/dist/index42.js +694 -4
  36. package/dist/index43.js +4 -238
  37. package/dist/index44.js +4 -82
  38. package/dist/index45.js +237 -16
  39. package/dist/index46.js +81 -57
  40. package/dist/index47.js +17 -15
  41. package/dist/index48.js +57 -285
  42. package/dist/index49.js +15 -202
  43. package/dist/index5.js +78 -68
  44. package/dist/index50.js +281 -1497
  45. package/dist/index51.js +202 -5
  46. package/dist/index52.js +1408 -1467
  47. package/dist/index53.js +5 -723
  48. package/dist/index54.js +1109 -81
  49. package/dist/index55.js +703 -226
  50. package/dist/index56.js +84 -3
  51. package/dist/index57.js +219 -1205
  52. package/dist/index58.js +3 -734
  53. package/dist/index59.js +1232 -21
  54. package/dist/index6.js +1 -1
  55. package/dist/index60.js +734 -10
  56. package/dist/index61.js +21 -7
  57. package/dist/index62.js +10 -8
  58. package/dist/index63.js +6 -13
  59. package/dist/index64.js +7 -18
  60. package/dist/index65.js +12 -23
  61. package/dist/index66.js +17 -53
  62. package/dist/index67.js +23 -1059
  63. package/dist/index68.js +54 -90
  64. package/dist/index69.js +1061 -98
  65. package/dist/index7.js +108 -96
  66. package/dist/index70.js +98 -4
  67. package/dist/index71.js +93 -0
  68. package/dist/index72.js +6 -0
  69. package/dist/index8.js +1 -1
  70. package/dist/index9.js +75 -65
  71. package/dist/mathematics.css +1 -0
  72. package/dist/mathematics.css.map +1 -0
  73. package/dist/styles.css +1 -1
  74. package/dist/styles.css.map +1 -1
  75. package/package.json +90 -52
package/dist/index5.js CHANGED
@@ -1,28 +1,39 @@
1
- import H from "./index36.js";
2
- import { createLowlight as T, all as V } from "lowlight";
3
- import { renderVizelIcon as S } from "./index22.js";
4
- const w = T(V);
5
- function N() {
6
- return w.listLanguages().sort((t, p) => t.localeCompare(p)).map((t) => ({
1
+ import T from "./index37.js";
2
+ import { renderVizelIcon as I } from "./index22.js";
3
+ let C = null;
4
+ function E() {
5
+ return C ? C.listLanguages().sort((t, c) => t.localeCompare(c)).map((t) => ({
7
6
  id: t,
8
7
  // Capitalize first letter for display name
9
8
  name: t.charAt(0).toUpperCase() + t.slice(1)
10
- }));
9
+ })) : [];
11
10
  }
12
11
  function O() {
13
- return N().map((u) => u.id);
12
+ return E().map((r) => r.id);
14
13
  }
15
- function W(u) {
16
- const t = u.toLowerCase();
17
- return N().find((p) => p.id === t);
14
+ function P(r) {
15
+ const t = r.toLowerCase();
16
+ return E().find((c) => c.id === t);
18
17
  }
19
- function q(u = {}) {
18
+ async function S(r = "common") {
19
+ try {
20
+ const t = await import("lowlight"), c = r === "all" ? t.all : t.common;
21
+ return t.createLowlight(c);
22
+ } catch (t) {
23
+ throw new Error(
24
+ `[Vizel] Failed to load "lowlight". Please install it for code block syntax highlighting: npm install lowlight
25
+ Original error: ${t instanceof Error ? t.message : String(t)}`
26
+ );
27
+ }
28
+ }
29
+ async function q(r = {}) {
20
30
  const {
21
31
  defaultLanguage: t = "plaintext",
22
- lineNumbers: p = !1,
23
- lowlight: x = w
24
- } = u;
25
- return [H.extend({
32
+ lineNumbers: c = !1,
33
+ lowlight: x,
34
+ languages: M = "common"
35
+ } = r, k = x ?? await S(M);
36
+ return C = k, [T.extend({
26
37
  addAttributes() {
27
38
  return {
28
39
  ...this.parent?.(),
@@ -35,101 +46,100 @@ function q(u = {}) {
35
46
  })
36
47
  },
37
48
  lineNumbers: {
38
- default: p,
49
+ default: c,
39
50
  parseHTML: (n) => n.getAttribute("data-line-numbers") === "true",
40
51
  renderHTML: (n) => n.lineNumbers ? { "data-line-numbers": "true" } : {}
41
52
  }
42
53
  };
43
54
  },
44
55
  addNodeView() {
45
- return ({ node: n, getPos: f, editor: d }) => {
46
- const g = document.createElement("div");
47
- g.classList.add("vizel-code-block"), n.attrs.lineNumbers && g.classList.add("vizel-code-block-line-numbers");
48
- const o = document.createElement("div");
49
- o.classList.add("vizel-code-block-language-selector"), o.setAttribute("contenteditable", "false");
56
+ return ({ node: n, getPos: h, editor: g }) => {
57
+ const m = document.createElement("div");
58
+ m.classList.add("vizel-code-block"), n.attrs.lineNumbers && m.classList.add("vizel-code-block-line-numbers");
59
+ const u = document.createElement("div");
60
+ u.classList.add("vizel-code-block-language-selector"), u.setAttribute("contenteditable", "false");
50
61
  const l = document.createElement("input");
51
62
  l.type = "text", l.classList.add("vizel-code-block-language-input"), l.value = n.attrs.language || t, l.placeholder = "language";
52
- const k = `vizel-languages-${Math.random().toString(36).slice(2, 9)}`, v = document.createElement("datalist");
53
- v.id = k, l.setAttribute("list", k);
54
- for (const e of N()) {
63
+ const N = `vizel-languages-${Math.random().toString(36).slice(2, 9)}`, v = document.createElement("datalist");
64
+ v.id = N, l.setAttribute("list", N);
65
+ for (const e of E()) {
55
66
  const a = document.createElement("option");
56
67
  a.value = e.id, a.label = e.name, v.appendChild(a);
57
68
  }
58
- const C = () => {
59
- const e = typeof f == "function" ? f() : null;
69
+ const w = () => {
70
+ const e = typeof h == "function" ? h() : null;
60
71
  if (e != null) {
61
72
  const a = l.value.toLowerCase().trim() || t;
62
73
  l.value = a;
63
- const { tr: c } = d.state, i = d.state.doc.nodeAt(e);
64
- i && (c.setNodeMarkup(e, void 0, {
65
- ...i.attrs,
74
+ const { tr: d } = g.state, s = g.state.doc.nodeAt(e);
75
+ s && (d.setNodeMarkup(e, void 0, {
76
+ ...s.attrs,
66
77
  language: a
67
- }), d.view.dispatch(c));
78
+ }), g.view.dispatch(d));
68
79
  }
69
80
  };
70
- l.addEventListener("change", C), l.addEventListener("blur", C), l.addEventListener("keydown", (e) => {
71
- e.key === "Enter" && (e.preventDefault(), e.stopPropagation(), C(), l.blur());
81
+ l.addEventListener("change", w), l.addEventListener("blur", w), l.addEventListener("keydown", (e) => {
82
+ e.key === "Enter" && (e.preventDefault(), e.stopPropagation(), w(), l.blur());
72
83
  });
73
- const s = document.createElement("button");
74
- s.type = "button", s.classList.add("vizel-code-block-line-numbers-toggle"), s.innerHTML = S("listOrdered", { width: 16, height: 16 }), n.attrs.lineNumbers && s.classList.add("active"), s.title = n.attrs.lineNumbers ? "Hide line numbers" : "Show line numbers", o.appendChild(s), o.appendChild(l), o.appendChild(v);
75
- const L = document.createElement("div");
76
- L.classList.add("vizel-code-block-container");
77
- const r = document.createElement("div");
78
- r.classList.add("vizel-code-block-gutter"), r.setAttribute("contenteditable", "false"), r.setAttribute("aria-hidden", "true");
79
- const E = document.createElement("pre"), b = document.createElement("code");
80
- b.classList.add(`language-${n.attrs.language || t}`), E.appendChild(b), L.appendChild(r), L.appendChild(E), g.appendChild(o), g.appendChild(L);
81
- const z = () => {
84
+ const i = document.createElement("button");
85
+ i.type = "button", i.classList.add("vizel-code-block-line-numbers-toggle"), i.innerHTML = I("listOrdered", { width: 16, height: 16 }), n.attrs.lineNumbers && i.classList.add("active"), i.title = n.attrs.lineNumbers ? "Hide line numbers" : "Show line numbers", u.appendChild(i), u.appendChild(l), u.appendChild(v);
86
+ const f = document.createElement("div");
87
+ f.classList.add("vizel-code-block-container");
88
+ const o = document.createElement("div");
89
+ o.classList.add("vizel-code-block-gutter"), o.setAttribute("contenteditable", "false"), o.setAttribute("aria-hidden", "true");
90
+ const z = document.createElement("pre"), b = document.createElement("code");
91
+ b.classList.add(`language-${n.attrs.language || t}`), z.appendChild(b), f.appendChild(o), f.appendChild(z), m.appendChild(u), m.appendChild(f);
92
+ const y = () => {
82
93
  const e = b.textContent || "", a = e.split(`
83
- `), c = e.endsWith(`
94
+ `), d = e.endsWith(`
84
95
  `) && a.length > 1 ? a.length - 1 : Math.max(1, a.length);
85
- if (r.children.length !== c) {
86
- r.innerHTML = "";
87
- for (let i = 1; i <= c; i++) {
88
- const m = document.createElement("div");
89
- m.classList.add("vizel-code-block-line-number"), m.textContent = String(i), r.appendChild(m);
96
+ if (o.children.length !== d) {
97
+ o.replaceChildren();
98
+ for (let s = 1; s <= d; s++) {
99
+ const p = document.createElement("div");
100
+ p.classList.add("vizel-code-block-line-number"), p.textContent = String(s), o.appendChild(p);
90
101
  }
91
102
  }
92
103
  };
93
- n.attrs.lineNumbers && setTimeout(z, 0);
94
- let A = n.attrs.language, h = n.attrs.lineNumbers;
95
- s.addEventListener("click", (e) => {
104
+ n.attrs.lineNumbers && setTimeout(y, 0);
105
+ let A = n.attrs.language, L = n.attrs.lineNumbers;
106
+ i.addEventListener("click", (e) => {
96
107
  e.preventDefault(), e.stopPropagation();
97
- const a = typeof f == "function" ? f() : null;
108
+ const a = typeof h == "function" ? h() : null;
98
109
  if (a != null) {
99
- const c = !h, { tr: i } = d.state, m = d.state.doc.nodeAt(a);
100
- m && (i.setNodeMarkup(a, void 0, {
101
- ...m.attrs,
102
- lineNumbers: c
103
- }), d.view.dispatch(i));
110
+ const d = !L, { tr: s } = g.state, p = g.state.doc.nodeAt(a);
111
+ p && (s.setNodeMarkup(a, void 0, {
112
+ ...p.attrs,
113
+ lineNumbers: d
114
+ }), g.view.dispatch(s));
104
115
  }
105
116
  });
106
- const M = (e) => {
117
+ const V = (e) => {
107
118
  A = e, l.value = e || t, b.className = `language-${e || t}`;
108
- }, y = (e) => {
109
- h = e, g.classList.toggle("vizel-code-block-line-numbers", e), s.classList.toggle("active", e), s.title = e ? "Hide line numbers" : "Show line numbers";
119
+ }, H = (e) => {
120
+ L = e, m.classList.toggle("vizel-code-block-line-numbers", e), i.classList.toggle("active", e), i.title = e ? "Hide line numbers" : "Show line numbers";
110
121
  };
111
122
  return {
112
- dom: g,
123
+ dom: m,
113
124
  contentDOM: b,
114
125
  update(e) {
115
- return e.type.name !== "codeBlock" ? !1 : (e.attrs.language !== A && M(e.attrs.language), e.attrs.lineNumbers !== h && y(e.attrs.lineNumbers), h && setTimeout(z, 0), !0);
126
+ return e.type.name !== "codeBlock" ? !1 : (e.attrs.language !== A && V(e.attrs.language), e.attrs.lineNumbers !== L && H(e.attrs.lineNumbers), L && setTimeout(y, 0), !0);
116
127
  },
117
128
  ignoreMutation(e) {
118
- return r.contains(e.target) || o.contains(e.target);
129
+ return o.contains(e.target) || u.contains(e.target);
119
130
  }
120
131
  };
121
132
  };
122
133
  }
123
134
  }).configure({
124
- lowlight: x,
135
+ lowlight: k,
125
136
  defaultLanguage: t
126
137
  })];
127
138
  }
128
139
  export {
129
- H as CodeBlockLowlight,
140
+ T as CodeBlockLowlight,
130
141
  q as createVizelCodeBlockExtension,
131
- W as findVizelLanguage,
142
+ P as findVizelLanguage,
132
143
  O as getAllVizelLanguageIds,
133
- N as getVizelRegisteredLanguages,
134
- w as lowlight
144
+ E as getVizelRegisteredLanguages
135
145
  };