@milkdown/plugin-slash 5.2.1 → 5.3.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 (1) hide show
  1. package/package.json +9 -8
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "@milkdown/plugin-slash",
3
- "version": "5.2.1",
3
+ "version": "5.3.0",
4
4
  "main": "./lib/index.cjs.js",
5
5
  "module": "./lib/index.es.js",
6
6
  "types": "./lib/index.d.ts",
@@ -26,16 +26,16 @@
26
26
  },
27
27
  "dependencies": {
28
28
  "@emotion/css": "^11.1.3",
29
- "@milkdown/utils": "5.2.1",
29
+ "@milkdown/utils": "5.3.0",
30
30
  "smooth-scroll-into-view-if-needed": "^1.1.32",
31
31
  "tslib": "^2.3.1"
32
32
  },
33
33
  "devDependencies": {
34
- "@milkdown/core": "5.2.1",
35
- "@milkdown/prose": "5.2.1",
36
- "@milkdown/ctx": "5.2.1",
37
- "@milkdown/design-system": "5.2.1",
38
- "@milkdown/preset-gfm": "5.2.1"
34
+ "@milkdown/core": "5.3.0",
35
+ "@milkdown/prose": "5.3.0",
36
+ "@milkdown/ctx": "5.3.0",
37
+ "@milkdown/design-system": "5.3.0",
38
+ "@milkdown/preset-gfm": "5.3.0"
39
39
  },
40
40
  "scripts": {
41
41
  "start": "vite",
@@ -43,5 +43,6 @@
43
43
  "test": "jest",
44
44
  "tsc": "tsc --noEmit",
45
45
  "build": "vite build && tsc --emitDeclarationOnly"
46
- }
46
+ },
47
+ "readme": "# @milkdown/plugin-slash\n\nSlash plugin for [milkdown](https://saul-mirone.github.io/milkdown/).\nAdd support for slash commands.\n\n# Example Usage\n\n```typescript\nimport { Editor } from '@milkdown/core';\nimport { commonmark } from '@milkdown/preset-commonmark';\nimport { nord } from '@milkdown/theme-nord';\n\nimport { slash } from '@milkdown/plugin-slash';\n\nEditor.make().use(nord).use(commonmark).use(slash).create();\n```\n\n# Options\n\n## config\n\nConfigure the slash plugin placeholders & items with custom status builder.\n\nExample:\n\n```typescript\nimport { slashPlugin, slash, createDropdownItem, defaultActions } from '@milkdown/plugin-slash';\nimport { themeToolCtx, commandsCtx } from '@milkdown/core';\n\nEditor.make().use(\n slash.configure(slashPlugin, {\n config: (ctx) => {\n // Get default slash plugin items\n const actions = defaultActions(ctx);\n\n // Define a status builder\n return ({ isTopLevel, content, parentNode }) => {\n // You can only show something at root level\n if (!isTopLevel) return null;\n\n // Empty content ? Set your custom empty placeholder !\n if (!content) {\n return { placeholder: 'Type / to use the slash commands...' };\n }\n\n // Define the placeholder & actions (dropdown items) you want to display depending on content\n if (content.startsWith('/')) {\n // Add some actions depending on your content's parent node\n if (parentNode.type.name === 'customNode') {\n actions.push({\n id: 'custom',\n dom: createDropdownItem(ctx.get(themeToolCtx), 'Custom', 'h1'),\n command: () => ctx.get(commandsCtx).call(/* Add custom command here */),\n keyword: ['custom'],\n enable: () => true,\n });\n }\n\n return content === '/'\n ? {\n placeholder: 'Type to filter...',\n actions,\n }\n : {\n actions: actions.filter(({ keyword }) =>\n keyword.some((key) => key.includes(content.slice(1).toLocaleLowerCase())),\n ),\n };\n }\n };\n },\n }),\n);\n```\n\n# License\n\nMilkdown is open sourced software licensed under [MIT license](https://github.com/Saul-Mirone/milkdown/blob/main/LICENSE).\n"
47
48
  }