@mark-sorcery/vue 0.4.3 → 0.6.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 (152) hide show
  1. package/README.md +10 -10
  2. package/dist/Blockquote-BYx2QlFv.cjs +1 -0
  3. package/dist/Blockquote-xx4inn22.js +1 -0
  4. package/dist/Bold-BiFH9EUs.js +1 -0
  5. package/dist/Bold-BoZIkk4l.cjs +1 -0
  6. package/dist/Code-CIuX53Su.js +1 -0
  7. package/dist/Code-CoQLSwBI.cjs +1 -0
  8. package/dist/CodeBlock-CBJUqIz7.js +2 -0
  9. package/dist/CodeBlock-NqAkDDFl.cjs +2 -0
  10. package/dist/Default-Dm6QzM55.cjs +1 -0
  11. package/dist/Default-Du5KpWO9.js +1 -0
  12. package/dist/Heading-BeD6JNR8.cjs +1 -0
  13. package/dist/Heading-Di0SzJmF.js +1 -0
  14. package/dist/HorizontalRule-BMcNqcX8.cjs +1 -0
  15. package/dist/HorizontalRule-DPKVMxXq.js +1 -0
  16. package/dist/Italic-BCSxulFP.cjs +1 -0
  17. package/dist/Italic-DxpVjZf8.js +1 -0
  18. package/dist/Link-CjW_-Hte.cjs +1 -0
  19. package/dist/Link-IdvG620t.js +1 -0
  20. package/dist/ListItem-B41dIF1i.cjs +1 -0
  21. package/dist/ListItem-lobxnDXx.js +1 -0
  22. package/dist/NodeList-CC_DnlOJ.cjs +1 -0
  23. package/dist/NodeList-Cnt9bUlC.js +1 -0
  24. package/dist/OrderedList-C8OQUxfM.js +1 -0
  25. package/dist/OrderedList-Dyky6G0n.cjs +1 -0
  26. package/dist/Paragraph-BYLoYhE4.cjs +1 -0
  27. package/dist/Paragraph-DFxhuzYm.js +1 -0
  28. package/dist/Strikethrough-BwUZSXgn.cjs +1 -0
  29. package/dist/Strikethrough-_EWGsunK.js +1 -0
  30. package/dist/Table-BHe4TZQf.cjs +1 -0
  31. package/dist/Table-CiG_ZrEU.js +1 -0
  32. package/dist/TableBody-l1bqR2BA.cjs +1 -0
  33. package/dist/TableBody-n-_2mkOQ.js +1 -0
  34. package/dist/TableData-D-Iwh5ZQ.js +1 -0
  35. package/dist/TableData-c1Rqbcu_.cjs +1 -0
  36. package/dist/TableHead-BgqaAdJ1.cjs +1 -0
  37. package/dist/TableHead-CuRy6BZG.js +1 -0
  38. package/dist/TableHeader-BK41oO7C.cjs +1 -0
  39. package/dist/TableHeader-CTBMqac9.js +1 -0
  40. package/dist/TableRow-30o6BXtx.cjs +1 -0
  41. package/dist/TableRow-BgoJ5-lh.js +1 -0
  42. package/dist/TaskListInput-BHl8y-3q.js +1 -0
  43. package/dist/TaskListInput-BdX4X7Za.cjs +1 -0
  44. package/dist/Text-CAMWUGdX.js +1 -0
  45. package/dist/Text-CtiSKNYX.cjs +1 -0
  46. package/dist/UnorderedList-BxYc45P8.cjs +1 -0
  47. package/dist/UnorderedList-C5D_qYHT.js +1 -0
  48. package/dist/elementPropertiesToProps-Rl89ZOmS.js +1 -0
  49. package/dist/elementPropertiesToProps-YEOuulPS.cjs +1 -0
  50. package/dist/index.cjs +1 -101
  51. package/dist/index.d.cts +39 -40
  52. package/dist/index.d.ts +39 -40
  53. package/dist/index.js +1 -91
  54. package/package.json +13 -12
  55. package/dist/Blockquote-BEanu_xk.js +0 -42
  56. package/dist/Blockquote-BEanu_xk.js.map +0 -1
  57. package/dist/Blockquote-qPDMwH1-.cjs +0 -42
  58. package/dist/Blockquote-qPDMwH1-.cjs.map +0 -1
  59. package/dist/Bold-BzZx1Tgn.js +0 -42
  60. package/dist/Bold-BzZx1Tgn.js.map +0 -1
  61. package/dist/Bold-C6ikWSEj.cjs +0 -42
  62. package/dist/Bold-C6ikWSEj.cjs.map +0 -1
  63. package/dist/Code-C03zpchV.cjs +0 -42
  64. package/dist/Code-C03zpchV.cjs.map +0 -1
  65. package/dist/Code-CCbWrPLf.js +0 -42
  66. package/dist/Code-CCbWrPLf.js.map +0 -1
  67. package/dist/CodeBlock-B6OiG87s.js +0 -46
  68. package/dist/CodeBlock-B6OiG87s.js.map +0 -1
  69. package/dist/CodeBlock-BQLdbP1J.cjs +0 -46
  70. package/dist/CodeBlock-BQLdbP1J.cjs.map +0 -1
  71. package/dist/Default-C18S5aUh.cjs +0 -17
  72. package/dist/Default-C18S5aUh.cjs.map +0 -1
  73. package/dist/Default-CM1nMlyi.js +0 -17
  74. package/dist/Default-CM1nMlyi.js.map +0 -1
  75. package/dist/Heading-BGeoKgwA.cjs +0 -52
  76. package/dist/Heading-BGeoKgwA.cjs.map +0 -1
  77. package/dist/Heading-CNP5Jwmy.js +0 -52
  78. package/dist/Heading-CNP5Jwmy.js.map +0 -1
  79. package/dist/HorizontalRule-Bbjd0a-j.cjs +0 -26
  80. package/dist/HorizontalRule-Bbjd0a-j.cjs.map +0 -1
  81. package/dist/HorizontalRule-rBfn0U9l.js +0 -26
  82. package/dist/HorizontalRule-rBfn0U9l.js.map +0 -1
  83. package/dist/Italic-BZQuXTDD.js +0 -42
  84. package/dist/Italic-BZQuXTDD.js.map +0 -1
  85. package/dist/Italic-CVr5Uv8e.cjs +0 -42
  86. package/dist/Italic-CVr5Uv8e.cjs.map +0 -1
  87. package/dist/Link-CR8Odrs_.js +0 -42
  88. package/dist/Link-CR8Odrs_.js.map +0 -1
  89. package/dist/Link-DrEnrVwi.cjs +0 -42
  90. package/dist/Link-DrEnrVwi.cjs.map +0 -1
  91. package/dist/ListItem-CxkythVa.js +0 -42
  92. package/dist/ListItem-CxkythVa.js.map +0 -1
  93. package/dist/ListItem-NBYDO8RP.cjs +0 -42
  94. package/dist/ListItem-NBYDO8RP.cjs.map +0 -1
  95. package/dist/NodeList-C6q-b84O.js +0 -137
  96. package/dist/NodeList-C6q-b84O.js.map +0 -1
  97. package/dist/NodeList-DWji6aQk.cjs +0 -160
  98. package/dist/NodeList-DWji6aQk.cjs.map +0 -1
  99. package/dist/OrderedList-CVOAGAnJ.cjs +0 -42
  100. package/dist/OrderedList-CVOAGAnJ.cjs.map +0 -1
  101. package/dist/OrderedList-DJ8NrHGb.js +0 -42
  102. package/dist/OrderedList-DJ8NrHGb.js.map +0 -1
  103. package/dist/Paragraph-BzBSasut.js +0 -42
  104. package/dist/Paragraph-BzBSasut.js.map +0 -1
  105. package/dist/Paragraph-DYZC2Knc.cjs +0 -42
  106. package/dist/Paragraph-DYZC2Knc.cjs.map +0 -1
  107. package/dist/Strikethrough-C6NlZlD4.cjs +0 -42
  108. package/dist/Strikethrough-C6NlZlD4.cjs.map +0 -1
  109. package/dist/Strikethrough-cBTzGuzF.js +0 -42
  110. package/dist/Strikethrough-cBTzGuzF.js.map +0 -1
  111. package/dist/Table-CdRPKCmK.cjs +0 -42
  112. package/dist/Table-CdRPKCmK.cjs.map +0 -1
  113. package/dist/Table-DTJYxLDp.js +0 -42
  114. package/dist/Table-DTJYxLDp.js.map +0 -1
  115. package/dist/TableBody-CC1wAoO1.cjs +0 -42
  116. package/dist/TableBody-CC1wAoO1.cjs.map +0 -1
  117. package/dist/TableBody-ZsZaxfGV.js +0 -42
  118. package/dist/TableBody-ZsZaxfGV.js.map +0 -1
  119. package/dist/TableData-DsP5mDkS.js +0 -42
  120. package/dist/TableData-DsP5mDkS.js.map +0 -1
  121. package/dist/TableData-fC15Ip24.cjs +0 -42
  122. package/dist/TableData-fC15Ip24.cjs.map +0 -1
  123. package/dist/TableHead-3BHc81PD.cjs +0 -42
  124. package/dist/TableHead-3BHc81PD.cjs.map +0 -1
  125. package/dist/TableHead-3_hF761Z.js +0 -42
  126. package/dist/TableHead-3_hF761Z.js.map +0 -1
  127. package/dist/TableHeader-B_54hPvG.cjs +0 -42
  128. package/dist/TableHeader-B_54hPvG.cjs.map +0 -1
  129. package/dist/TableHeader-CS1iLmeT.js +0 -42
  130. package/dist/TableHeader-CS1iLmeT.js.map +0 -1
  131. package/dist/TableRow-CS9H0heW.js +0 -42
  132. package/dist/TableRow-CS9H0heW.js.map +0 -1
  133. package/dist/TableRow-CurDMrMT.cjs +0 -42
  134. package/dist/TableRow-CurDMrMT.cjs.map +0 -1
  135. package/dist/TaskListInput-D0J0W_mb.cjs +0 -31
  136. package/dist/TaskListInput-D0J0W_mb.cjs.map +0 -1
  137. package/dist/TaskListInput-ZHyqra-8.js +0 -31
  138. package/dist/TaskListInput-ZHyqra-8.js.map +0 -1
  139. package/dist/Text-D9YJ_6J0.js +0 -24
  140. package/dist/Text-D9YJ_6J0.js.map +0 -1
  141. package/dist/Text-YsPIcju-.cjs +0 -24
  142. package/dist/Text-YsPIcju-.cjs.map +0 -1
  143. package/dist/UnorderedList-DGKkBd0N.cjs +0 -42
  144. package/dist/UnorderedList-DGKkBd0N.cjs.map +0 -1
  145. package/dist/UnorderedList-alvCsLdr.js +0 -42
  146. package/dist/UnorderedList-alvCsLdr.js.map +0 -1
  147. package/dist/elementPropertiesToProps-Bo-5NitC.cjs +0 -37
  148. package/dist/elementPropertiesToProps-Bo-5NitC.cjs.map +0 -1
  149. package/dist/elementPropertiesToProps-C6wCdFop.js +0 -31
  150. package/dist/elementPropertiesToProps-C6wCdFop.js.map +0 -1
  151. package/dist/index.cjs.map +0 -1
  152. package/dist/index.js.map +0 -1
@@ -1,31 +0,0 @@
1
- const require_elementPropertiesToProps = require('./elementPropertiesToProps-Bo-5NitC.cjs');
2
- let vue = require("vue");
3
-
4
- //#region src/components/elements/TaskListInput.vue
5
- const _sfc_main = /* @__PURE__ */ (0, vue.defineComponent)({
6
- inheritAttrs: false,
7
- __name: "TaskListInput",
8
- props: {
9
- nodeIdx: {},
10
- deep: {},
11
- nodeKey: {},
12
- parentNode: {},
13
- element: {}
14
- },
15
- setup(__props) {
16
- const properties = (0, vue.computed)(() => {
17
- return require_elementPropertiesToProps.elementPropertiesToProps(__props.element.properties);
18
- });
19
- return (_ctx, _cache) => {
20
- return (0, vue.openBlock)(), (0, vue.createElementBlock)("input", (0, vue.mergeProps)({
21
- "data-mark-sorcery": "task-list-input",
22
- type: "checkbox",
23
- disabled: ""
24
- }, properties.value), null, 16);
25
- };
26
- }
27
- });
28
-
29
- //#endregion
30
- exports.default = _sfc_main;
31
- //# sourceMappingURL=TaskListInput-D0J0W_mb.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TaskListInput-D0J0W_mb.cjs","names":[],"sources":["../src/components/elements/TaskListInput.vue","../src/components/elements/TaskListInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { computed } from \"vue\";\r\n\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<ElementProps>();\r\n\r\nconst properties = computed(() => {\r\n return elementPropertiesToProps(element.properties);\r\n});\r\n</script>\r\n\r\n<template>\r\n <input data-mark-sorcery=\"task-list-input\" type=\"checkbox\" disabled v-bind=\"properties\" />\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport { computed } from \"vue\";\r\n\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<ElementProps>();\r\n\r\nconst properties = computed(() => {\r\n return elementPropertiesToProps(element.properties);\r\n});\r\n</script>\r\n\r\n<template>\r\n <input data-mark-sorcery=\"task-list-input\" type=\"checkbox\" disabled v-bind=\"properties\" />\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;EAaA,MAAM,qCAA4B;AAChC,UAAO,0DAAyB,QAAA,QAAQ,WAAW;IACnD;;4DCI0F,6BAAA;IAAnF,qBAAkB;IAAkB,MAAK;IAAW,UAAA;MAAiB,WAAA,MAAU,EAAA,MAAA,GAAA"}
@@ -1,31 +0,0 @@
1
- import { t as elementPropertiesToProps } from "./elementPropertiesToProps-C6wCdFop.js";
2
- import { computed, createElementBlock, defineComponent, mergeProps, openBlock } from "vue";
3
-
4
- //#region src/components/elements/TaskListInput.vue
5
- const _sfc_main = /* @__PURE__ */ defineComponent({
6
- inheritAttrs: false,
7
- __name: "TaskListInput",
8
- props: {
9
- nodeIdx: {},
10
- deep: {},
11
- nodeKey: {},
12
- parentNode: {},
13
- element: {}
14
- },
15
- setup(__props) {
16
- const properties = computed(() => {
17
- return elementPropertiesToProps(__props.element.properties);
18
- });
19
- return (_ctx, _cache) => {
20
- return openBlock(), createElementBlock("input", mergeProps({
21
- "data-mark-sorcery": "task-list-input",
22
- type: "checkbox",
23
- disabled: ""
24
- }, properties.value), null, 16);
25
- };
26
- }
27
- });
28
-
29
- //#endregion
30
- export { _sfc_main as default };
31
- //# sourceMappingURL=TaskListInput-ZHyqra-8.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"TaskListInput-ZHyqra-8.js","names":[],"sources":["../src/components/elements/TaskListInput.vue","../src/components/elements/TaskListInput.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport { computed } from \"vue\";\r\n\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<ElementProps>();\r\n\r\nconst properties = computed(() => {\r\n return elementPropertiesToProps(element.properties);\r\n});\r\n</script>\r\n\r\n<template>\r\n <input data-mark-sorcery=\"task-list-input\" type=\"checkbox\" disabled v-bind=\"properties\" />\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport { computed } from \"vue\";\r\n\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<ElementProps>();\r\n\r\nconst properties = computed(() => {\r\n return elementPropertiesToProps(element.properties);\r\n});\r\n</script>\r\n\r\n<template>\r\n <input data-mark-sorcery=\"task-list-input\" type=\"checkbox\" disabled v-bind=\"properties\" />\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;EAaA,MAAM,aAAa,eAAe;AAChC,UAAO,yBAAyB,QAAA,QAAQ,WAAW;IACnD;;uBCIA,mBAA0F,SAA1F,WAA0F;IAAnF,qBAAkB;IAAkB,MAAK;IAAW,UAAA;MAAiB,WAAA,MAAU,EAAA,MAAA,GAAA"}
@@ -1,24 +0,0 @@
1
- import { createElementBlock, defineComponent, openBlock, toDisplayString } from "vue";
2
-
3
- //#region src/components/elements/Text.vue
4
- const _hoisted_1 = { "data-mark-sorcery": "text" };
5
- const _sfc_main = /* @__PURE__ */ defineComponent({
6
- inheritAttrs: false,
7
- __name: "Text",
8
- props: {
9
- nodeIdx: {},
10
- deep: {},
11
- nodeKey: {},
12
- parentNode: {},
13
- element: {}
14
- },
15
- setup(__props) {
16
- return (_ctx, _cache) => {
17
- return openBlock(), createElementBlock("span", _hoisted_1, toDisplayString(__props.element.value), 1);
18
- };
19
- }
20
- });
21
-
22
- //#endregion
23
- export { _sfc_main as default };
24
- //# sourceMappingURL=Text-D9YJ_6J0.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Text-D9YJ_6J0.js","names":[],"sources":["../src/components/elements/Text.vue","../src/components/elements/Text.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { TextProps } from \"../../types\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<TextProps>();\r\n</script>\r\n\r\n<template>\r\n <span data-mark-sorcery=\"text\">{{ element.value }}</span>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport type { TextProps } from \"../../types\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<TextProps>();\r\n</script>\r\n\r\n<template>\r\n <span data-mark-sorcery=\"text\">{{ element.value }}</span>\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;;uBCWE,mBAAyD,QAAzD,YAAyD,gBAAvB,QAAA,QAAQ,MAAK,EAAA,EAAA"}
@@ -1,24 +0,0 @@
1
- let vue = require("vue");
2
-
3
- //#region src/components/elements/Text.vue
4
- const _hoisted_1 = { "data-mark-sorcery": "text" };
5
- const _sfc_main = /* @__PURE__ */ (0, vue.defineComponent)({
6
- inheritAttrs: false,
7
- __name: "Text",
8
- props: {
9
- nodeIdx: {},
10
- deep: {},
11
- nodeKey: {},
12
- parentNode: {},
13
- element: {}
14
- },
15
- setup(__props) {
16
- return (_ctx, _cache) => {
17
- return (0, vue.openBlock)(), (0, vue.createElementBlock)("span", _hoisted_1, (0, vue.toDisplayString)(__props.element.value), 1);
18
- };
19
- }
20
- });
21
-
22
- //#endregion
23
- exports.default = _sfc_main;
24
- //# sourceMappingURL=Text-YsPIcju-.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"Text-YsPIcju-.cjs","names":[],"sources":["../src/components/elements/Text.vue","../src/components/elements/Text.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { TextProps } from \"../../types\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<TextProps>();\r\n</script>\r\n\r\n<template>\r\n <span data-mark-sorcery=\"text\">{{ element.value }}</span>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport type { TextProps } from \"../../types\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element } = defineProps<TextProps>();\r\n</script>\r\n\r\n<template>\r\n <span data-mark-sorcery=\"text\">{{ element.value }}</span>\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;;4DCW2D,QAAzD,qCAAkC,QAAA,QAAQ,MAAK,EAAA,EAAA"}
@@ -1,42 +0,0 @@
1
- const require_NodeList = require('./NodeList-DWji6aQk.cjs');
2
- const require_elementPropertiesToProps = require('./elementPropertiesToProps-Bo-5NitC.cjs');
3
- let vue = require("vue");
4
-
5
- //#region src/components/elements/UnorderedList.vue
6
- const _sfc_main = /* @__PURE__ */ (0, vue.defineComponent)({
7
- inheritAttrs: false,
8
- __name: "UnorderedList",
9
- props: {
10
- nodeIdx: {},
11
- deep: {},
12
- nodeKey: {},
13
- parentNode: {},
14
- element: {}
15
- },
16
- setup(__props) {
17
- const { components, transition } = require_NodeList.useMarkdown();
18
- return (_ctx, _cache) => {
19
- return (0, vue.openBlock)(), (0, vue.createElementBlock)("ul", (0, vue.mergeProps)({ "data-mark-sorcery": "unordered-list" }, (0, vue.unref)(require_elementPropertiesToProps.elementPropertiesToProps)(__props.element.properties)), [(0, vue.createVNode)(require_NodeList._sfc_main, {
20
- nodes: __props.element.children,
21
- nodeIdx: __props.nodeIdx,
22
- deep: __props.deep,
23
- nodeKey: __props.nodeKey,
24
- parentNode: __props.element,
25
- components: (0, vue.unref)(components),
26
- transition: (0, vue.unref)(transition)
27
- }, null, 8, [
28
- "nodes",
29
- "nodeIdx",
30
- "deep",
31
- "nodeKey",
32
- "parentNode",
33
- "components",
34
- "transition"
35
- ])], 16);
36
- };
37
- }
38
- });
39
-
40
- //#endregion
41
- exports.default = _sfc_main;
42
- //# sourceMappingURL=UnorderedList-DGKkBd0N.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"UnorderedList-DGKkBd0N.cjs","names":[],"sources":["../src/components/elements/UnorderedList.vue","../src/components/elements/UnorderedList.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { useMarkdown } from \"../../composables/markdown\";\r\nimport NodeList from \"../NodeList.vue\";\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element, nodeIdx, deep, nodeKey } = defineProps<ElementProps>();\r\nconst { components, transition } = useMarkdown();\r\n</script>\r\n\r\n<template>\r\n <ul data-mark-sorcery=\"unordered-list\" v-bind=\"elementPropertiesToProps(element.properties)\">\r\n <NodeList\r\n :nodes=\"element.children\"\r\n :nodeIdx=\"nodeIdx\"\r\n :deep=\"deep\"\r\n :nodeKey=\"nodeKey\"\r\n :parentNode=\"element\"\r\n :components=\"components\"\r\n :transition=\"transition\"\r\n />\r\n </ul>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { useMarkdown } from \"../../composables/markdown\";\r\nimport NodeList from \"../NodeList.vue\";\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element, nodeIdx, deep, nodeKey } = defineProps<ElementProps>();\r\nconst { components, transition } = useMarkdown();\r\n</script>\r\n\r\n<template>\r\n <ul data-mark-sorcery=\"unordered-list\" v-bind=\"elementPropertiesToProps(element.properties)\">\r\n <NodeList\r\n :nodes=\"element.children\"\r\n :nodeIdx=\"nodeIdx\"\r\n :deep=\"deep\"\r\n :nodeKey=\"nodeKey\"\r\n :parentNode=\"element\"\r\n :components=\"components\"\r\n :transition=\"transition\"\r\n />\r\n </ul>\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;;EAYA,MAAM,EAAE,YAAY,eAAe,8BAAa;;4DCczC,0BAAA,EAVD,qBAAkB,kBAAgB,iBAAS,0DAAwB,CAAC,QAAA,QAAQ,WAAU,CAAA,EAAA,sBAStF,4BAAA;IAPC,OAAO,QAAA,QAAQ;IACf,SAAS,QAAA;IACT,MAAM,QAAA;IACN,SAAS,QAAA;IACT,YAAY,QAAA;IACZ,2BAAY,WAAU;IACtB,2BAAY,WAAU"}
@@ -1,42 +0,0 @@
1
- import { n as useMarkdown, t as _sfc_main$1 } from "./NodeList-C6q-b84O.js";
2
- import { t as elementPropertiesToProps } from "./elementPropertiesToProps-C6wCdFop.js";
3
- import { createElementBlock, createVNode, defineComponent, mergeProps, openBlock, unref } from "vue";
4
-
5
- //#region src/components/elements/UnorderedList.vue
6
- const _sfc_main = /* @__PURE__ */ defineComponent({
7
- inheritAttrs: false,
8
- __name: "UnorderedList",
9
- props: {
10
- nodeIdx: {},
11
- deep: {},
12
- nodeKey: {},
13
- parentNode: {},
14
- element: {}
15
- },
16
- setup(__props) {
17
- const { components, transition } = useMarkdown();
18
- return (_ctx, _cache) => {
19
- return openBlock(), createElementBlock("ul", mergeProps({ "data-mark-sorcery": "unordered-list" }, unref(elementPropertiesToProps)(__props.element.properties)), [createVNode(_sfc_main$1, {
20
- nodes: __props.element.children,
21
- nodeIdx: __props.nodeIdx,
22
- deep: __props.deep,
23
- nodeKey: __props.nodeKey,
24
- parentNode: __props.element,
25
- components: unref(components),
26
- transition: unref(transition)
27
- }, null, 8, [
28
- "nodes",
29
- "nodeIdx",
30
- "deep",
31
- "nodeKey",
32
- "parentNode",
33
- "components",
34
- "transition"
35
- ])], 16);
36
- };
37
- }
38
- });
39
-
40
- //#endregion
41
- export { _sfc_main as default };
42
- //# sourceMappingURL=UnorderedList-alvCsLdr.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"UnorderedList-alvCsLdr.js","names":[],"sources":["../src/components/elements/UnorderedList.vue","../src/components/elements/UnorderedList.vue"],"sourcesContent":["<script setup lang=\"ts\">\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { useMarkdown } from \"../../composables/markdown\";\r\nimport NodeList from \"../NodeList.vue\";\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element, nodeIdx, deep, nodeKey } = defineProps<ElementProps>();\r\nconst { components, transition } = useMarkdown();\r\n</script>\r\n\r\n<template>\r\n <ul data-mark-sorcery=\"unordered-list\" v-bind=\"elementPropertiesToProps(element.properties)\">\r\n <NodeList\r\n :nodes=\"element.children\"\r\n :nodeIdx=\"nodeIdx\"\r\n :deep=\"deep\"\r\n :nodeKey=\"nodeKey\"\r\n :parentNode=\"element\"\r\n :components=\"components\"\r\n :transition=\"transition\"\r\n />\r\n </ul>\r\n</template>\r\n","<script setup lang=\"ts\">\r\nimport type { ElementProps } from \"../../types\";\r\n\r\nimport { useMarkdown } from \"../../composables/markdown\";\r\nimport NodeList from \"../NodeList.vue\";\r\nimport { elementPropertiesToProps } from \"../utils/elementPropertiesToProps\";\r\n\r\ndefineOptions({\r\n inheritAttrs: false,\r\n});\r\n\r\nconst { element, nodeIdx, deep, nodeKey } = defineProps<ElementProps>();\r\nconst { components, transition } = useMarkdown();\r\n</script>\r\n\r\n<template>\r\n <ul data-mark-sorcery=\"unordered-list\" v-bind=\"elementPropertiesToProps(element.properties)\">\r\n <NodeList\r\n :nodes=\"element.children\"\r\n :nodeIdx=\"nodeIdx\"\r\n :deep=\"deep\"\r\n :nodeKey=\"nodeKey\"\r\n :parentNode=\"element\"\r\n :components=\"components\"\r\n :transition=\"transition\"\r\n />\r\n </ul>\r\n</template>\r\n"],"mappings":";;;;;;;;;;;;;;;;EAYA,MAAM,EAAE,YAAY,eAAe,aAAa;;uBCI9C,mBAUK,MAVL,WAUK,EAVD,qBAAkB,kBAAgB,EAAS,MAAA,yBAAwB,CAAC,QAAA,QAAQ,WAAU,CAAA,EAAA,CACxF,YAQE,aAAA;IAPC,OAAO,QAAA,QAAQ;IACf,SAAS,QAAA;IACT,MAAM,QAAA;IACN,SAAS,QAAA;IACT,YAAY,QAAA;IACZ,YAAY,MAAA,WAAU;IACtB,YAAY,MAAA,WAAU"}
@@ -1,37 +0,0 @@
1
-
2
- //#region src/components/utils/elementPropertiesToProps.ts
3
- const classNameProp = "className";
4
- const toKebabCase = (value) => value.replace(/([a-z0-9])([A-Z])/g, "$1-$2").replace(/([A-Z])([A-Z][a-z])/g, "$1-$2").toLowerCase();
5
- const normalizeClassValue = (value) => {
6
- if (Array.isArray(value)) return value.flatMap((entry) => String(entry).split(/\s+/)).filter(Boolean);
7
- if (typeof value === "string") return value.split(/\s+/).filter(Boolean);
8
- return value;
9
- };
10
- const normalizeAttributeValue = (value) => {
11
- if (Array.isArray(value)) return value.map(String).join(" ");
12
- return value;
13
- };
14
- const normalizePropertyName = (propertyName) => {
15
- if (propertyName === classNameProp) return "class";
16
- if (propertyName === "htmlFor") return "for";
17
- if (/^(aria|data)[A-Z]/.test(propertyName)) return toKebabCase(propertyName);
18
- return propertyName;
19
- };
20
- const elementPropertiesToProps = (properties) => {
21
- if (!properties) return {};
22
- return Object.entries(properties).reduce((props, [propertyName, propertyValue]) => {
23
- if (propertyValue === null || propertyValue === void 0) return props;
24
- const normalizedPropertyName = normalizePropertyName(propertyName);
25
- props[normalizedPropertyName] = normalizedPropertyName === "class" ? normalizeClassValue(propertyValue) : normalizeAttributeValue(propertyValue);
26
- return props;
27
- }, {});
28
- };
29
-
30
- //#endregion
31
- Object.defineProperty(exports, 'elementPropertiesToProps', {
32
- enumerable: true,
33
- get: function () {
34
- return elementPropertiesToProps;
35
- }
36
- });
37
- //# sourceMappingURL=elementPropertiesToProps-Bo-5NitC.cjs.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"elementPropertiesToProps-Bo-5NitC.cjs","names":[],"sources":["../src/components/utils/elementPropertiesToProps.ts"],"sourcesContent":["import type { Element } from \"hast\";\r\n\r\ntype ElementProperties = Element[\"properties\"];\r\ntype ElementPropertyValue = NonNullable<ElementProperties>[string];\r\n\r\nconst classNameProp = \"className\";\r\n\r\nconst toKebabCase = (value: string) =>\r\n value\r\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\r\n .replace(/([A-Z])([A-Z][a-z])/g, \"$1-$2\")\r\n .toLowerCase();\r\n\r\nconst normalizeClassValue = (value: ElementPropertyValue) => {\r\n if (Array.isArray(value)) {\r\n return value\r\n .flatMap((entry) => String(entry).split(/\\s+/))\r\n .filter(Boolean);\r\n }\r\n\r\n if (typeof value === \"string\") {\r\n return value.split(/\\s+/).filter(Boolean);\r\n }\r\n\r\n return value;\r\n};\r\n\r\nconst normalizeAttributeValue = (value: ElementPropertyValue) => {\r\n if (Array.isArray(value)) {\r\n return value.map(String).join(\" \");\r\n }\r\n\r\n return value;\r\n};\r\n\r\nconst normalizePropertyName = (propertyName: string) => {\r\n if (propertyName === classNameProp) {\r\n return \"class\";\r\n }\r\n\r\n if (propertyName === \"htmlFor\") {\r\n return \"for\";\r\n }\r\n\r\n if (/^(aria|data)[A-Z]/.test(propertyName)) {\r\n return toKebabCase(propertyName);\r\n }\r\n\r\n return propertyName;\r\n};\r\n\r\nexport const elementPropertiesToProps = (properties: Element[\"properties\"]) => {\r\n if (!properties) {\r\n return {};\r\n }\r\n\r\n return Object.entries(properties).reduce<Record<string, ElementPropertyValue>>(\r\n (props, [propertyName, propertyValue]) => {\r\n if (propertyValue === null || propertyValue === undefined) {\r\n return props;\r\n }\r\n\r\n const normalizedPropertyName = normalizePropertyName(propertyName);\r\n\r\n props[normalizedPropertyName] =\r\n normalizedPropertyName === \"class\"\r\n ? normalizeClassValue(propertyValue)\r\n : normalizeAttributeValue(propertyValue);\r\n\r\n return props;\r\n },\r\n {},\r\n );\r\n};"],"mappings":";;AAKA,MAAM,gBAAgB;AAEtB,MAAM,eAAe,UACjB,MACK,QAAQ,sBAAsB,QAAQ,CACtC,QAAQ,wBAAwB,QAAQ,CACxC,aAAa;AAEtB,MAAM,uBAAuB,UAAgC;AACzD,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MACF,SAAS,UAAU,OAAO,MAAM,CAAC,MAAM,MAAM,CAAC,CAC9C,OAAO,QAAQ;AAGxB,KAAI,OAAO,UAAU,SACjB,QAAO,MAAM,MAAM,MAAM,CAAC,OAAO,QAAQ;AAG7C,QAAO;;AAGX,MAAM,2BAA2B,UAAgC;AAC7D,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MAAM,IAAI,OAAO,CAAC,KAAK,IAAI;AAGtC,QAAO;;AAGX,MAAM,yBAAyB,iBAAyB;AACpD,KAAI,iBAAiB,cACjB,QAAO;AAGX,KAAI,iBAAiB,UACjB,QAAO;AAGX,KAAI,oBAAoB,KAAK,aAAa,CACtC,QAAO,YAAY,aAAa;AAGpC,QAAO;;AAGX,MAAa,4BAA4B,eAAsC;AAC3E,KAAI,CAAC,WACD,QAAO,EAAE;AAGb,QAAO,OAAO,QAAQ,WAAW,CAAC,QAC7B,OAAO,CAAC,cAAc,mBAAmB;AACtC,MAAI,kBAAkB,QAAQ,kBAAkB,OAC5C,QAAO;EAGX,MAAM,yBAAyB,sBAAsB,aAAa;AAElE,QAAM,0BACF,2BAA2B,UACrB,oBAAoB,cAAc,GAClC,wBAAwB,cAAc;AAEhD,SAAO;IAEX,EAAE,CACL"}
@@ -1,31 +0,0 @@
1
- //#region src/components/utils/elementPropertiesToProps.ts
2
- const classNameProp = "className";
3
- const toKebabCase = (value) => value.replace(/([a-z0-9])([A-Z])/g, "$1-$2").replace(/([A-Z])([A-Z][a-z])/g, "$1-$2").toLowerCase();
4
- const normalizeClassValue = (value) => {
5
- if (Array.isArray(value)) return value.flatMap((entry) => String(entry).split(/\s+/)).filter(Boolean);
6
- if (typeof value === "string") return value.split(/\s+/).filter(Boolean);
7
- return value;
8
- };
9
- const normalizeAttributeValue = (value) => {
10
- if (Array.isArray(value)) return value.map(String).join(" ");
11
- return value;
12
- };
13
- const normalizePropertyName = (propertyName) => {
14
- if (propertyName === classNameProp) return "class";
15
- if (propertyName === "htmlFor") return "for";
16
- if (/^(aria|data)[A-Z]/.test(propertyName)) return toKebabCase(propertyName);
17
- return propertyName;
18
- };
19
- const elementPropertiesToProps = (properties) => {
20
- if (!properties) return {};
21
- return Object.entries(properties).reduce((props, [propertyName, propertyValue]) => {
22
- if (propertyValue === null || propertyValue === void 0) return props;
23
- const normalizedPropertyName = normalizePropertyName(propertyName);
24
- props[normalizedPropertyName] = normalizedPropertyName === "class" ? normalizeClassValue(propertyValue) : normalizeAttributeValue(propertyValue);
25
- return props;
26
- }, {});
27
- };
28
-
29
- //#endregion
30
- export { elementPropertiesToProps as t };
31
- //# sourceMappingURL=elementPropertiesToProps-C6wCdFop.js.map
@@ -1 +0,0 @@
1
- {"version":3,"file":"elementPropertiesToProps-C6wCdFop.js","names":[],"sources":["../src/components/utils/elementPropertiesToProps.ts"],"sourcesContent":["import type { Element } from \"hast\";\r\n\r\ntype ElementProperties = Element[\"properties\"];\r\ntype ElementPropertyValue = NonNullable<ElementProperties>[string];\r\n\r\nconst classNameProp = \"className\";\r\n\r\nconst toKebabCase = (value: string) =>\r\n value\r\n .replace(/([a-z0-9])([A-Z])/g, \"$1-$2\")\r\n .replace(/([A-Z])([A-Z][a-z])/g, \"$1-$2\")\r\n .toLowerCase();\r\n\r\nconst normalizeClassValue = (value: ElementPropertyValue) => {\r\n if (Array.isArray(value)) {\r\n return value\r\n .flatMap((entry) => String(entry).split(/\\s+/))\r\n .filter(Boolean);\r\n }\r\n\r\n if (typeof value === \"string\") {\r\n return value.split(/\\s+/).filter(Boolean);\r\n }\r\n\r\n return value;\r\n};\r\n\r\nconst normalizeAttributeValue = (value: ElementPropertyValue) => {\r\n if (Array.isArray(value)) {\r\n return value.map(String).join(\" \");\r\n }\r\n\r\n return value;\r\n};\r\n\r\nconst normalizePropertyName = (propertyName: string) => {\r\n if (propertyName === classNameProp) {\r\n return \"class\";\r\n }\r\n\r\n if (propertyName === \"htmlFor\") {\r\n return \"for\";\r\n }\r\n\r\n if (/^(aria|data)[A-Z]/.test(propertyName)) {\r\n return toKebabCase(propertyName);\r\n }\r\n\r\n return propertyName;\r\n};\r\n\r\nexport const elementPropertiesToProps = (properties: Element[\"properties\"]) => {\r\n if (!properties) {\r\n return {};\r\n }\r\n\r\n return Object.entries(properties).reduce<Record<string, ElementPropertyValue>>(\r\n (props, [propertyName, propertyValue]) => {\r\n if (propertyValue === null || propertyValue === undefined) {\r\n return props;\r\n }\r\n\r\n const normalizedPropertyName = normalizePropertyName(propertyName);\r\n\r\n props[normalizedPropertyName] =\r\n normalizedPropertyName === \"class\"\r\n ? normalizeClassValue(propertyValue)\r\n : normalizeAttributeValue(propertyValue);\r\n\r\n return props;\r\n },\r\n {},\r\n );\r\n};"],"mappings":";AAKA,MAAM,gBAAgB;AAEtB,MAAM,eAAe,UACjB,MACK,QAAQ,sBAAsB,QAAQ,CACtC,QAAQ,wBAAwB,QAAQ,CACxC,aAAa;AAEtB,MAAM,uBAAuB,UAAgC;AACzD,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MACF,SAAS,UAAU,OAAO,MAAM,CAAC,MAAM,MAAM,CAAC,CAC9C,OAAO,QAAQ;AAGxB,KAAI,OAAO,UAAU,SACjB,QAAO,MAAM,MAAM,MAAM,CAAC,OAAO,QAAQ;AAG7C,QAAO;;AAGX,MAAM,2BAA2B,UAAgC;AAC7D,KAAI,MAAM,QAAQ,MAAM,CACpB,QAAO,MAAM,IAAI,OAAO,CAAC,KAAK,IAAI;AAGtC,QAAO;;AAGX,MAAM,yBAAyB,iBAAyB;AACpD,KAAI,iBAAiB,cACjB,QAAO;AAGX,KAAI,iBAAiB,UACjB,QAAO;AAGX,KAAI,oBAAoB,KAAK,aAAa,CACtC,QAAO,YAAY,aAAa;AAGpC,QAAO;;AAGX,MAAa,4BAA4B,eAAsC;AAC3E,KAAI,CAAC,WACD,QAAO,EAAE;AAGb,QAAO,OAAO,QAAQ,WAAW,CAAC,QAC7B,OAAO,CAAC,cAAc,mBAAmB;AACtC,MAAI,kBAAkB,QAAQ,kBAAkB,OAC5C,QAAO;EAGX,MAAM,yBAAyB,sBAAsB,aAAa;AAElE,QAAM,0BACF,2BAA2B,UACrB,oBAAoB,cAAc,GAClC,wBAAwB,cAAc;AAEhD,SAAO;IAEX,EAAE,CACL"}
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.cjs","names":["useProvideMarkdown","NodeList"],"sources":["../src/plugins/remove-line-jump-nodes.ts","../src/Markdown.ts"],"sourcesContent":["import type { ParserPlugin } from \"@mark-sorcery/markdown-parser\";\r\nimport type { Root } from \"hast\";\r\nimport type { Plugin } from \"unified\";\r\nimport { remove } from \"unist-util-remove\";\r\n\r\nconst rehypeRemoveLineJumpNodes: Plugin<[string[]], Root> =\r\n () => (tree: Root) => {\r\n remove(tree, {\r\n type: \"text\",\r\n value: \"\\n\",\r\n })\r\n };\r\n\r\nexport const removeLineJumpNodesPlugin = (): ParserPlugin => ({\r\n rehype: [[rehypeRemoveLineJumpNodes]],\r\n});","import { computed, defineComponent, h, shallowRef, watchEffect } from 'vue';\nimport { createMemory, createProcessor, parse } from '@mark-sorcery/markdown-parser';\nimport type {\n MarkdownProcessor,\n MarkdownProps,\n ParseMemory,\n} from './types.ts';\nimport NodeList from './components/NodeList.vue';\nimport { useProvideMarkdown } from './composables/markdown.ts';\nimport { removeLineJumpNodesPlugin } from './plugins/remove-line-jump-nodes.ts';\n\nexport const Markdown = defineComponent({\n name: 'Markdown',\n\n props: {\n markdown: {\n type: String,\n required: true,\n },\n options: {\n type: Object as () => MarkdownProps['options'],\n default: undefined,\n },\n plugins: {\n type: Array as () => MarkdownProps['plugins'],\n default: undefined,\n },\n stream: {\n type: Boolean,\n default: false,\n },\n components: {\n type: Object as unknown as () => MarkdownProps['components'],\n default: () => ({}),\n },\n transition: {\n type: [Boolean, Object] as unknown as () => MarkdownProps['transition'],\n default: false,\n },\n } satisfies {\n [K in keyof MarkdownProps]-?: unknown;\n },\n\n setup(props) {\n const getMarkdown = () => props.markdown ?? '';\n\n const processor = computed<MarkdownProcessor>(() => {\n const options = props.options;\n const propPlugins = props.plugins ?? [];\n\n return createProcessor({\n ...options,\n plugins: [...propPlugins, removeLineJumpNodesPlugin()],\n });\n });\n\n const hast = shallowRef(parse(processor.value, getMarkdown()));\n let streamMemory: ParseMemory | undefined;\n let activeProcessor: MarkdownProcessor | undefined;\n\n watchEffect(() => {\n const currentProcessor = processor.value;\n const markdown = getMarkdown();\n\n if (activeProcessor && activeProcessor !== currentProcessor) {\n streamMemory = props.stream ? createMemory() : undefined;\n }\n\n activeProcessor = currentProcessor;\n\n if (props.stream) {\n streamMemory ??= createMemory();\n hast.value = parse(currentProcessor, markdown, streamMemory);\n return;\n }\n\n if (streamMemory) {\n streamMemory.flush = true;\n streamMemory = undefined;\n return;\n }\n\n hast.value = parse(currentProcessor, markdown);\n });\n\n const { components: providedComponents, transition: providedTransition } = useProvideMarkdown(computed(() => props.components), computed(() => props.transition));\n\n return () => {\n return h(NodeList, {\n nodes: hast.value.children,\n nodeKey: 'root',\n deep: 0,\n parentNode: hast.value,\n components: providedComponents.value,\n transition: providedTransition.value,\n });\n };\n },\n});\n"],"mappings":";;;;;;;AAKA,MAAM,mCACK,SAAe;AAClB,+BAAO,MAAM;EACT,MAAM;EACN,OAAO;EACV,CAAC;;AAGV,MAAa,mCAAiD,EAC1D,QAAQ,CAAC,CAAC,0BAA0B,CAAC,EACxC;;;;ACJD,MAAa,oCAA2B;CACtC,MAAM;CAEN,OAAO;EACL,UAAU;GACR,MAAM;GACN,UAAU;GACX;EACD,SAAS;GACP,MAAM;GACN,SAAS;GACV;EACD,SAAS;GACP,MAAM;GACN,SAAS;GACV;EACD,QAAQ;GACN,MAAM;GACN,SAAS;GACV;EACD,YAAY;GACV,MAAM;GACN,gBAAgB,EAAE;GACnB;EACD,YAAY;GACV,MAAM,CAAC,SAAS,OAAO;GACvB,SAAS;GACV;EACF;CAID,MAAM,OAAO;EACX,MAAM,oBAAoB,MAAM,YAAY;EAE5C,MAAM,oCAA8C;GAClD,MAAM,UAAU,MAAM;GACtB,MAAM,cAAc,MAAM,WAAW,EAAE;AAEvC,6DAAuB;IACrB,GAAG;IACH,SAAS,CAAC,GAAG,aAAa,2BAA2B,CAAC;IACvD,CAAC;IACF;EAEF,MAAM,oEAAwB,UAAU,OAAO,aAAa,CAAC,CAAC;EAC9D,IAAI;EACJ,IAAI;AAEJ,6BAAkB;GAChB,MAAM,mBAAmB,UAAU;GACnC,MAAM,WAAW,aAAa;AAE9B,OAAI,mBAAmB,oBAAoB,iBACzC,gBAAe,MAAM,0DAAuB,GAAG;AAGjD,qBAAkB;AAElB,OAAI,MAAM,QAAQ;AAChB,sEAA+B;AAC/B,SAAK,iDAAc,kBAAkB,UAAU,aAAa;AAC5D;;AAGF,OAAI,cAAc;AAChB,iBAAa,QAAQ;AACrB,mBAAe;AACf;;AAGF,QAAK,iDAAc,kBAAkB,SAAS;IAC9C;EAEF,MAAM,EAAE,YAAY,oBAAoB,YAAY,uBAAuBA,4DAAkC,MAAM,WAAW,0BAAiB,MAAM,WAAW,CAAC;AAEjK,eAAa;AACX,qBAASC,4BAAU;IACjB,OAAO,KAAK,MAAM;IAClB,SAAS;IACT,MAAM;IACN,YAAY,KAAK;IACjB,YAAY,mBAAmB;IAC/B,YAAY,mBAAmB;IAChC,CAAC;;;CAGP,CAAC"}
package/dist/index.js.map DELETED
@@ -1 +0,0 @@
1
- {"version":3,"file":"index.js","names":["NodeList"],"sources":["../src/plugins/remove-line-jump-nodes.ts","../src/Markdown.ts"],"sourcesContent":["import type { ParserPlugin } from \"@mark-sorcery/markdown-parser\";\r\nimport type { Root } from \"hast\";\r\nimport type { Plugin } from \"unified\";\r\nimport { remove } from \"unist-util-remove\";\r\n\r\nconst rehypeRemoveLineJumpNodes: Plugin<[string[]], Root> =\r\n () => (tree: Root) => {\r\n remove(tree, {\r\n type: \"text\",\r\n value: \"\\n\",\r\n })\r\n };\r\n\r\nexport const removeLineJumpNodesPlugin = (): ParserPlugin => ({\r\n rehype: [[rehypeRemoveLineJumpNodes]],\r\n});","import { computed, defineComponent, h, shallowRef, watchEffect } from 'vue';\nimport { createMemory, createProcessor, parse } from '@mark-sorcery/markdown-parser';\nimport type {\n MarkdownProcessor,\n MarkdownProps,\n ParseMemory,\n} from './types.ts';\nimport NodeList from './components/NodeList.vue';\nimport { useProvideMarkdown } from './composables/markdown.ts';\nimport { removeLineJumpNodesPlugin } from './plugins/remove-line-jump-nodes.ts';\n\nexport const Markdown = defineComponent({\n name: 'Markdown',\n\n props: {\n markdown: {\n type: String,\n required: true,\n },\n options: {\n type: Object as () => MarkdownProps['options'],\n default: undefined,\n },\n plugins: {\n type: Array as () => MarkdownProps['plugins'],\n default: undefined,\n },\n stream: {\n type: Boolean,\n default: false,\n },\n components: {\n type: Object as unknown as () => MarkdownProps['components'],\n default: () => ({}),\n },\n transition: {\n type: [Boolean, Object] as unknown as () => MarkdownProps['transition'],\n default: false,\n },\n } satisfies {\n [K in keyof MarkdownProps]-?: unknown;\n },\n\n setup(props) {\n const getMarkdown = () => props.markdown ?? '';\n\n const processor = computed<MarkdownProcessor>(() => {\n const options = props.options;\n const propPlugins = props.plugins ?? [];\n\n return createProcessor({\n ...options,\n plugins: [...propPlugins, removeLineJumpNodesPlugin()],\n });\n });\n\n const hast = shallowRef(parse(processor.value, getMarkdown()));\n let streamMemory: ParseMemory | undefined;\n let activeProcessor: MarkdownProcessor | undefined;\n\n watchEffect(() => {\n const currentProcessor = processor.value;\n const markdown = getMarkdown();\n\n if (activeProcessor && activeProcessor !== currentProcessor) {\n streamMemory = props.stream ? createMemory() : undefined;\n }\n\n activeProcessor = currentProcessor;\n\n if (props.stream) {\n streamMemory ??= createMemory();\n hast.value = parse(currentProcessor, markdown, streamMemory);\n return;\n }\n\n if (streamMemory) {\n streamMemory.flush = true;\n streamMemory = undefined;\n return;\n }\n\n hast.value = parse(currentProcessor, markdown);\n });\n\n const { components: providedComponents, transition: providedTransition } = useProvideMarkdown(computed(() => props.components), computed(() => props.transition));\n\n return () => {\n return h(NodeList, {\n nodes: hast.value.children,\n nodeKey: 'root',\n deep: 0,\n parentNode: hast.value,\n components: providedComponents.value,\n transition: providedTransition.value,\n });\n };\n },\n});\n"],"mappings":";;;;;;AAKA,MAAM,mCACK,SAAe;AAClB,QAAO,MAAM;EACT,MAAM;EACN,OAAO;EACV,CAAC;;AAGV,MAAa,mCAAiD,EAC1D,QAAQ,CAAC,CAAC,0BAA0B,CAAC,EACxC;;;;ACJD,MAAa,WAAW,gBAAgB;CACtC,MAAM;CAEN,OAAO;EACL,UAAU;GACR,MAAM;GACN,UAAU;GACX;EACD,SAAS;GACP,MAAM;GACN,SAAS;GACV;EACD,SAAS;GACP,MAAM;GACN,SAAS;GACV;EACD,QAAQ;GACN,MAAM;GACN,SAAS;GACV;EACD,YAAY;GACV,MAAM;GACN,gBAAgB,EAAE;GACnB;EACD,YAAY;GACV,MAAM,CAAC,SAAS,OAAO;GACvB,SAAS;GACV;EACF;CAID,MAAM,OAAO;EACX,MAAM,oBAAoB,MAAM,YAAY;EAE5C,MAAM,YAAY,eAAkC;GAClD,MAAM,UAAU,MAAM;GACtB,MAAM,cAAc,MAAM,WAAW,EAAE;AAEvC,UAAO,gBAAgB;IACrB,GAAG;IACH,SAAS,CAAC,GAAG,aAAa,2BAA2B,CAAC;IACvD,CAAC;IACF;EAEF,MAAM,OAAO,WAAW,MAAM,UAAU,OAAO,aAAa,CAAC,CAAC;EAC9D,IAAI;EACJ,IAAI;AAEJ,oBAAkB;GAChB,MAAM,mBAAmB,UAAU;GACnC,MAAM,WAAW,aAAa;AAE9B,OAAI,mBAAmB,oBAAoB,iBACzC,gBAAe,MAAM,SAAS,cAAc,GAAG;AAGjD,qBAAkB;AAElB,OAAI,MAAM,QAAQ;AAChB,qBAAiB,cAAc;AAC/B,SAAK,QAAQ,MAAM,kBAAkB,UAAU,aAAa;AAC5D;;AAGF,OAAI,cAAc;AAChB,iBAAa,QAAQ;AACrB,mBAAe;AACf;;AAGF,QAAK,QAAQ,MAAM,kBAAkB,SAAS;IAC9C;EAEF,MAAM,EAAE,YAAY,oBAAoB,YAAY,uBAAuB,mBAAmB,eAAe,MAAM,WAAW,EAAE,eAAe,MAAM,WAAW,CAAC;AAEjK,eAAa;AACX,UAAO,EAAEA,WAAU;IACjB,OAAO,KAAK,MAAM;IAClB,SAAS;IACT,MAAM;IACN,YAAY,KAAK;IACjB,YAAY,mBAAmB;IAC/B,YAAY,mBAAmB;IAChC,CAAC;;;CAGP,CAAC"}