@jianwen-lang/parser 0.1.1 → 0.1.3

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 (43) hide show
  1. package/README.md +44 -1
  2. package/dist/cli/render.js +75 -0
  3. package/dist/core/block/rules/attribute-line.d.ts +13 -0
  4. package/dist/core/block/rules/attribute-line.js +227 -0
  5. package/dist/core/block/rules/code-block.d.ts +2 -0
  6. package/dist/core/block/rules/code-block.js +73 -0
  7. package/dist/core/block/rules/code-fence.d.ts +15 -0
  8. package/dist/core/block/rules/code-fence.js +37 -0
  9. package/dist/core/block/rules/content-title.d.ts +12 -0
  10. package/dist/core/block/rules/content-title.js +70 -0
  11. package/dist/core/block/rules/footnotes.d.ts +9 -0
  12. package/dist/core/block/rules/footnotes.js +105 -0
  13. package/dist/core/block/rules/html.d.ts +7 -0
  14. package/dist/core/block/rules/html.js +48 -0
  15. package/dist/core/block/rules/image.d.ts +9 -0
  16. package/dist/core/block/rules/image.js +78 -0
  17. package/dist/core/block/rules/list.d.ts +3 -0
  18. package/dist/core/block/rules/list.js +275 -0
  19. package/dist/core/block/rules/paragraph.d.ts +6 -0
  20. package/dist/core/block/rules/paragraph.js +55 -0
  21. package/dist/core/block/rules/quote.d.ts +13 -0
  22. package/dist/core/block/rules/quote.js +104 -0
  23. package/dist/core/block/rules/table.d.ts +2 -0
  24. package/dist/core/block/rules/table.js +199 -0
  25. package/dist/core/block/runtime.d.ts +25 -0
  26. package/dist/core/block/runtime.js +125 -0
  27. package/dist/core/block/types.d.ts +2 -0
  28. package/dist/core/block-parser.js +186 -1321
  29. package/dist/core/parser.js +1 -1
  30. package/dist/html/convert.d.ts +10 -0
  31. package/dist/html/convert.js +23 -1
  32. package/dist/html/render/blocks.d.ts +15 -0
  33. package/dist/html/render/blocks.js +67 -13
  34. package/dist/html/render/html.d.ts +16 -0
  35. package/dist/html/render/html.js +53 -14
  36. package/dist/html/render/utils.d.ts +1 -0
  37. package/dist/html/theme/base/css.d.ts +1 -1
  38. package/dist/html/theme/base/css.js +50 -22
  39. package/dist/html/theme/dark/css.js +48 -0
  40. package/dist/html/theme/light/css.js +24 -0
  41. package/dist/html/theme/theme.d.ts +23 -1
  42. package/dist/html/theme/theme.js +242 -2
  43. package/package.json +5 -1
@@ -40,6 +40,30 @@ const LIGHT_CSS = `
40
40
  --jw-task-not-done-cross: #ffffff;
41
41
  --jw-task-in-progress: #555555;
42
42
 
43
+ --jw-strong-color: #2b2f39;
44
+ --jw-strong-weight: 700;
45
+ --jw-underline-color: #1d4ed8;
46
+ --jw-underline-thickness: 0.08em;
47
+ --jw-underline-offset: 0.12em;
48
+ --jw-wave-color: #1d4ed8;
49
+ --jw-strike-color: #767676;
50
+
51
+ --jw-table-border-color: #d1d5db;
52
+ --jw-table-header-bg: #f0f3f6;
53
+ --jw-table-header-text: #3f4654;
54
+ --jw-table-row-bg: #ffffff;
55
+ --jw-table-row-alt-bg: #f9fafb;
56
+
57
+ --jw-code-block-bg: #f5f5f5;
58
+ --jw-code-border-color: #dddddd;
59
+ --jw-code-header-bg: rgba(0, 0, 0, 0.04);
60
+ --jw-code-header-text: #5f6672;
61
+ --jw-code-lang-bg: rgba(0, 0, 0, 0.06);
62
+ --jw-code-lang-text: #4b5563;
63
+ --jw-code-copy-border: #c9ced6;
64
+ --jw-code-copy-hover-bg: rgba(0, 0, 0, 0.08);
65
+ --jw-code-line-number-color: #9aa0ad;
66
+
43
67
  --jw-color-red: ${PRESET_COLORS.red};
44
68
  --jw-color-orange: ${PRESET_COLORS.orange};
45
69
  --jw-color-yellow: ${PRESET_COLORS.yellow};
@@ -1,9 +1,31 @@
1
1
  export type DocumentTheme = 'light' | 'dark' | 'auto';
2
+ export type ThemeCssPreset = 'default' | 'none';
3
+ type PresetColorName = 'red' | 'orange' | 'yellow' | 'green' | 'cyan' | 'blue' | 'purple' | 'black' | 'darkgray' | 'gray';
4
+ export declare const JIANWEN_THEME_TOKEN_KEYS: readonly ["--jw-line-height-base", "--jw-block-spacing", "--jw-nested-list-gap", "--jw-quote-gap", "--jw-bg-color", "--jw-text-color", "--jw-link-color", "--jw-quote-border-color", "--jw-quote-border-color-2", "--jw-quote-border-color-3", "--jw-quote-background", "--jw-quote-text", "--jw-border-color", "--jw-border-color-subtle", "--jw-border-color-strong", "--jw-text-muted", "--jw-text-subtle", "--jw-text-strong", "--jw-text-faint", "--jw-surface-code", "--jw-surface-task", "--jw-surface-overlay-1", "--jw-surface-overlay-2", "--jw-surface-overlay-3", "--jw-highlight-marker", "--jw-task-done-bg", "--jw-task-done-text", "--jw-task-not-done-cross", "--jw-task-in-progress", "--jw-color-red", "--jw-color-orange", "--jw-color-yellow", "--jw-color-green", "--jw-color-cyan", "--jw-color-blue", "--jw-color-purple", "--jw-color-black", "--jw-color-darkgray", "--jw-color-gray", "--jw-strong-color", "--jw-strong-weight", "--jw-underline-color", "--jw-underline-thickness", "--jw-underline-offset", "--jw-wave-color", "--jw-strike-color", "--jw-table-border-color", "--jw-table-header-bg", "--jw-table-header-text", "--jw-table-row-bg", "--jw-table-row-alt-bg", "--jw-code-block-bg", "--jw-code-border-color", "--jw-code-header-bg", "--jw-code-header-text", "--jw-code-lang-bg", "--jw-code-lang-text", "--jw-code-copy-border", "--jw-code-copy-hover-bg", "--jw-code-line-number-color"];
5
+ export type JianwenThemeTokenKey = (typeof JIANWEN_THEME_TOKEN_KEYS)[number];
6
+ export type JianwenThemeTokenValues = Record<JianwenThemeTokenKey, string>;
7
+ export type JianwenThemeTokenOverrides = Partial<JianwenThemeTokenValues>;
8
+ export interface JianwenThemeConfig {
9
+ light?: JianwenThemeTokenOverrides;
10
+ dark?: JianwenThemeTokenOverrides;
11
+ includeAutoDark?: boolean;
12
+ }
2
13
  export interface ThemeCssBundle {
3
14
  baseCss: string;
4
15
  lightCss: string;
5
16
  darkCss: string;
6
17
  }
18
+ export interface ComposeThemeCssOptions {
19
+ preset?: ThemeCssPreset;
20
+ theme?: JianwenThemeConfig;
21
+ extraCss?: string;
22
+ }
7
23
  export declare const DEFAULT_THEME: ThemeCssBundle;
24
+ export declare const PRESET_COLORS: Record<PresetColorName, string> & Record<string, string>;
25
+ export declare const DEFAULT_THEME_TOKENS_LIGHT: JianwenThemeTokenValues;
26
+ export declare const DEFAULT_THEME_TOKENS_DARK: JianwenThemeTokenValues;
27
+ export declare const DEFAULT_THEME_CONFIG: JianwenThemeConfig;
8
28
  export declare const DEFAULT_CSS: string;
9
- export declare const PRESET_COLORS: Record<string, string>;
29
+ export declare function renderThemeTokenCss(theme: JianwenThemeConfig): string;
30
+ export declare function composeThemeCss(options?: ComposeThemeCssOptions): string;
31
+ export {};
@@ -3,19 +3,259 @@ var __importDefault = (this && this.__importDefault) || function (mod) {
3
3
  return (mod && mod.__esModule) ? mod : { "default": mod };
4
4
  };
5
5
  Object.defineProperty(exports, "__esModule", { value: true });
6
- exports.PRESET_COLORS = exports.DEFAULT_CSS = exports.DEFAULT_THEME = void 0;
6
+ exports.DEFAULT_CSS = exports.DEFAULT_THEME_CONFIG = exports.DEFAULT_THEME_TOKENS_DARK = exports.DEFAULT_THEME_TOKENS_LIGHT = exports.PRESET_COLORS = exports.DEFAULT_THEME = exports.JIANWEN_THEME_TOKEN_KEYS = void 0;
7
+ exports.renderThemeTokenCss = renderThemeTokenCss;
8
+ exports.composeThemeCss = composeThemeCss;
7
9
  const css_1 = __importDefault(require("./base/css"));
8
10
  const css_2 = __importDefault(require("./dark/css"));
9
11
  const css_3 = __importDefault(require("./light/css"));
10
12
  const colors_1 = __importDefault(require("./preset/colors"));
13
+ exports.JIANWEN_THEME_TOKEN_KEYS = [
14
+ '--jw-line-height-base',
15
+ '--jw-block-spacing',
16
+ '--jw-nested-list-gap',
17
+ '--jw-quote-gap',
18
+ '--jw-bg-color',
19
+ '--jw-text-color',
20
+ '--jw-link-color',
21
+ '--jw-quote-border-color',
22
+ '--jw-quote-border-color-2',
23
+ '--jw-quote-border-color-3',
24
+ '--jw-quote-background',
25
+ '--jw-quote-text',
26
+ '--jw-border-color',
27
+ '--jw-border-color-subtle',
28
+ '--jw-border-color-strong',
29
+ '--jw-text-muted',
30
+ '--jw-text-subtle',
31
+ '--jw-text-strong',
32
+ '--jw-text-faint',
33
+ '--jw-surface-code',
34
+ '--jw-surface-task',
35
+ '--jw-surface-overlay-1',
36
+ '--jw-surface-overlay-2',
37
+ '--jw-surface-overlay-3',
38
+ '--jw-highlight-marker',
39
+ '--jw-task-done-bg',
40
+ '--jw-task-done-text',
41
+ '--jw-task-not-done-cross',
42
+ '--jw-task-in-progress',
43
+ '--jw-color-red',
44
+ '--jw-color-orange',
45
+ '--jw-color-yellow',
46
+ '--jw-color-green',
47
+ '--jw-color-cyan',
48
+ '--jw-color-blue',
49
+ '--jw-color-purple',
50
+ '--jw-color-black',
51
+ '--jw-color-darkgray',
52
+ '--jw-color-gray',
53
+ '--jw-strong-color',
54
+ '--jw-strong-weight',
55
+ '--jw-underline-color',
56
+ '--jw-underline-thickness',
57
+ '--jw-underline-offset',
58
+ '--jw-wave-color',
59
+ '--jw-strike-color',
60
+ '--jw-table-border-color',
61
+ '--jw-table-header-bg',
62
+ '--jw-table-header-text',
63
+ '--jw-table-row-bg',
64
+ '--jw-table-row-alt-bg',
65
+ '--jw-code-block-bg',
66
+ '--jw-code-border-color',
67
+ '--jw-code-header-bg',
68
+ '--jw-code-header-text',
69
+ '--jw-code-lang-bg',
70
+ '--jw-code-lang-text',
71
+ '--jw-code-copy-border',
72
+ '--jw-code-copy-hover-bg',
73
+ '--jw-code-line-number-color',
74
+ ];
11
75
  exports.DEFAULT_THEME = {
12
76
  baseCss: String(css_1.default),
13
77
  lightCss: String(css_3.default),
14
78
  darkCss: String(css_2.default),
15
79
  };
80
+ exports.PRESET_COLORS = colors_1.default;
81
+ exports.DEFAULT_THEME_TOKENS_LIGHT = {
82
+ '--jw-line-height-base': '1.7',
83
+ '--jw-block-spacing': '1em',
84
+ '--jw-nested-list-gap': '0.35em',
85
+ '--jw-quote-gap': '0.6em',
86
+ '--jw-bg-color': '#ffffff',
87
+ '--jw-text-color': '#222222',
88
+ '--jw-link-color': '#1d4ed8',
89
+ '--jw-quote-border-color': '#d0d0d0',
90
+ '--jw-quote-border-color-2': '#c5c5c5',
91
+ '--jw-quote-border-color-3': '#b8b8b8',
92
+ '--jw-quote-background': '#f8f8f8',
93
+ '--jw-quote-text': '#595959',
94
+ '--jw-border-color': '#cccccc',
95
+ '--jw-border-color-subtle': '#dddddd',
96
+ '--jw-border-color-strong': '#999999',
97
+ '--jw-text-muted': '#777777',
98
+ '--jw-text-subtle': '#666666',
99
+ '--jw-text-strong': '#555555',
100
+ '--jw-text-faint': '#999999',
101
+ '--jw-surface-code': '#f5f5f5',
102
+ '--jw-surface-task': '#eeeeee',
103
+ '--jw-surface-overlay-1': 'rgba(0, 0, 0, 0.02)',
104
+ '--jw-surface-overlay-2': 'rgba(0, 0, 0, 0.05)',
105
+ '--jw-surface-overlay-3': 'rgba(0, 0, 0, 0.1)',
106
+ '--jw-highlight-marker': '#FFEB3B',
107
+ '--jw-task-done-bg': '#333333',
108
+ '--jw-task-done-text': '#ffffff',
109
+ '--jw-task-not-done-cross': '#ffffff',
110
+ '--jw-task-in-progress': '#555555',
111
+ '--jw-color-red': exports.PRESET_COLORS.red,
112
+ '--jw-color-orange': exports.PRESET_COLORS.orange,
113
+ '--jw-color-yellow': exports.PRESET_COLORS.yellow,
114
+ '--jw-color-green': exports.PRESET_COLORS.green,
115
+ '--jw-color-cyan': exports.PRESET_COLORS.cyan,
116
+ '--jw-color-blue': exports.PRESET_COLORS.blue,
117
+ '--jw-color-purple': exports.PRESET_COLORS.purple,
118
+ '--jw-color-black': exports.PRESET_COLORS.black,
119
+ '--jw-color-darkgray': exports.PRESET_COLORS.darkgray,
120
+ '--jw-color-gray': exports.PRESET_COLORS.gray,
121
+ '--jw-strong-color': '#2b2f39',
122
+ '--jw-strong-weight': '700',
123
+ '--jw-underline-color': '#1d4ed8',
124
+ '--jw-underline-thickness': '0.08em',
125
+ '--jw-underline-offset': '0.12em',
126
+ '--jw-wave-color': '#1d4ed8',
127
+ '--jw-strike-color': '#767676',
128
+ '--jw-table-border-color': '#d1d5db',
129
+ '--jw-table-header-bg': '#f0f3f6',
130
+ '--jw-table-header-text': '#3f4654',
131
+ '--jw-table-row-bg': '#ffffff',
132
+ '--jw-table-row-alt-bg': '#f9fafb',
133
+ '--jw-code-block-bg': '#f5f5f5',
134
+ '--jw-code-border-color': '#dddddd',
135
+ '--jw-code-header-bg': 'rgba(0, 0, 0, 0.04)',
136
+ '--jw-code-header-text': '#5f6672',
137
+ '--jw-code-lang-bg': 'rgba(0, 0, 0, 0.06)',
138
+ '--jw-code-lang-text': '#4b5563',
139
+ '--jw-code-copy-border': '#c9ced6',
140
+ '--jw-code-copy-hover-bg': 'rgba(0, 0, 0, 0.08)',
141
+ '--jw-code-line-number-color': '#9aa0ad',
142
+ };
143
+ exports.DEFAULT_THEME_TOKENS_DARK = {
144
+ '--jw-line-height-base': '1.7',
145
+ '--jw-block-spacing': '1em',
146
+ '--jw-nested-list-gap': '0.35em',
147
+ '--jw-quote-gap': '0.6em',
148
+ '--jw-bg-color': '#15171c',
149
+ '--jw-text-color': '#e8e9ed',
150
+ '--jw-link-color': '#8ab4f8',
151
+ '--jw-quote-border-color': '#343843',
152
+ '--jw-quote-border-color-2': '#2c313a',
153
+ '--jw-quote-border-color-3': '#252a33',
154
+ '--jw-quote-background': '#1d2028',
155
+ '--jw-quote-text': '#c9ccd5',
156
+ '--jw-border-color': '#333844',
157
+ '--jw-border-color-subtle': '#282d38',
158
+ '--jw-border-color-strong': '#434958',
159
+ '--jw-text-muted': '#b3b7c2',
160
+ '--jw-text-subtle': '#9aa0ad',
161
+ '--jw-text-strong': '#d7d9e2',
162
+ '--jw-text-faint': '#7c8494',
163
+ '--jw-surface-code': '#1c1f26',
164
+ '--jw-surface-task': '#262b36',
165
+ '--jw-surface-overlay-1': 'rgba(255, 255, 255, 0.03)',
166
+ '--jw-surface-overlay-2': 'rgba(255, 255, 255, 0.06)',
167
+ '--jw-surface-overlay-3': 'rgba(255, 255, 255, 0.1)',
168
+ '--jw-highlight-marker': '#d2b21f',
169
+ '--jw-task-done-bg': '#cfd3dd',
170
+ '--jw-task-done-text': '#1c1f26',
171
+ '--jw-task-not-done-cross': '#eef1f7',
172
+ '--jw-task-in-progress': '#b7bdca',
173
+ '--jw-color-red': exports.PRESET_COLORS.red,
174
+ '--jw-color-orange': exports.PRESET_COLORS.orange,
175
+ '--jw-color-yellow': exports.PRESET_COLORS.yellow,
176
+ '--jw-color-green': exports.PRESET_COLORS.green,
177
+ '--jw-color-cyan': exports.PRESET_COLORS.cyan,
178
+ '--jw-color-blue': exports.PRESET_COLORS.blue,
179
+ '--jw-color-purple': exports.PRESET_COLORS.purple,
180
+ '--jw-color-black': exports.PRESET_COLORS.black,
181
+ '--jw-color-darkgray': exports.PRESET_COLORS.darkgray,
182
+ '--jw-color-gray': exports.PRESET_COLORS.gray,
183
+ '--jw-strong-color': '#f3f5f8',
184
+ '--jw-strong-weight': '700',
185
+ '--jw-underline-color': '#8ab4f8',
186
+ '--jw-underline-thickness': '0.08em',
187
+ '--jw-underline-offset': '0.12em',
188
+ '--jw-wave-color': '#8ab4f8',
189
+ '--jw-strike-color': '#98a2b3',
190
+ '--jw-table-border-color': '#374151',
191
+ '--jw-table-header-bg': '#1f2937',
192
+ '--jw-table-header-text': '#d1d5db',
193
+ '--jw-table-row-bg': '#141922',
194
+ '--jw-table-row-alt-bg': '#171d28',
195
+ '--jw-code-block-bg': '#1c1f26',
196
+ '--jw-code-border-color': '#313846',
197
+ '--jw-code-header-bg': 'rgba(255, 255, 255, 0.05)',
198
+ '--jw-code-header-text': '#b8c2d3',
199
+ '--jw-code-lang-bg': 'rgba(255, 255, 255, 0.08)',
200
+ '--jw-code-lang-text': '#d1d8e3',
201
+ '--jw-code-copy-border': '#4b5563',
202
+ '--jw-code-copy-hover-bg': 'rgba(255, 255, 255, 0.12)',
203
+ '--jw-code-line-number-color': '#8b95a7',
204
+ };
205
+ exports.DEFAULT_THEME_CONFIG = {
206
+ light: exports.DEFAULT_THEME_TOKENS_LIGHT,
207
+ dark: exports.DEFAULT_THEME_TOKENS_DARK,
208
+ includeAutoDark: true,
209
+ };
16
210
  exports.DEFAULT_CSS = [
17
211
  exports.DEFAULT_THEME.baseCss,
18
212
  exports.DEFAULT_THEME.lightCss,
19
213
  exports.DEFAULT_THEME.darkCss,
20
214
  ].join('\n');
21
- exports.PRESET_COLORS = colors_1.default;
215
+ function renderTokenDeclarations(tokens) {
216
+ return exports.JIANWEN_THEME_TOKEN_KEYS.map((key) => ` ${key}: ${tokens[key]};`).join('\n');
217
+ }
218
+ function renderTokenBlock(selector, tokens) {
219
+ return `${selector} {\n${renderTokenDeclarations(tokens)}\n}`;
220
+ }
221
+ function resolveThemeConfig(theme) {
222
+ return {
223
+ light: {
224
+ ...exports.DEFAULT_THEME_TOKENS_LIGHT,
225
+ ...(theme.light ?? {}),
226
+ },
227
+ dark: {
228
+ ...exports.DEFAULT_THEME_TOKENS_DARK,
229
+ ...(theme.dark ?? {}),
230
+ },
231
+ includeAutoDark: theme.includeAutoDark ?? true,
232
+ };
233
+ }
234
+ function renderThemeTokenCss(theme) {
235
+ const resolved = resolveThemeConfig(theme);
236
+ const parts = [
237
+ renderTokenBlock(':where(.jw-root)', resolved.light),
238
+ renderTokenBlock(':where(.jw-root)[data-jw-theme="dark"]', resolved.dark),
239
+ ];
240
+ if (resolved.includeAutoDark) {
241
+ parts.push(`@media (prefers-color-scheme: dark) {
242
+ ${renderTokenBlock(':where(.jw-root)[data-jw-theme="auto"]', resolved.dark)}
243
+ }`);
244
+ }
245
+ return parts.join('\n');
246
+ }
247
+ function composeThemeCss(options = {}) {
248
+ const preset = options.preset ?? 'default';
249
+ const extraCss = options.extraCss?.trim() ?? '';
250
+ const parts = [];
251
+ if (preset === 'default') {
252
+ parts.push(exports.DEFAULT_CSS);
253
+ }
254
+ if (options.theme) {
255
+ parts.push(renderThemeTokenCss(options.theme));
256
+ }
257
+ if (extraCss) {
258
+ parts.push(extraCss);
259
+ }
260
+ return parts.join('\n');
261
+ }
package/package.json CHANGED
@@ -1,9 +1,13 @@
1
1
  {
2
2
  "name": "@jianwen-lang/parser",
3
- "version": "0.1.1",
3
+ "version": "0.1.3",
4
4
  "description": "JianWen language parser implemented in TypeScript",
5
5
  "main": "dist/parser.js",
6
6
  "types": "dist/parser.d.ts",
7
+ "repository": {
8
+ "type": "git",
9
+ "url": "git+https://github.com/Jianwen-lang/parser.git"
10
+ },
7
11
  "publishConfig": {
8
12
  "access": "public"
9
13
  },