diff --git a/content/sparks.csv b/content/sparks.csv
index e0fd061..587f319 100644
--- a/content/sparks.csv
+++ b/content/sparks.csv
@@ -1,6 +1,6 @@
label,body,description,icon
-🔥 火焰火花,你召唤出一朵小小的火焰,可以点燃蜡烛或篝火。,造成 1d4 点火焰伤害。,🔥
-💧 水流,你制造一股水流,可以扑灭小型火焰或弄湿目标。,造成 1d4 点水击伤害。,💧
-🌪️ 旋风,你制造一阵小旋风,可以吹散烟雾或轻小物体。,推开目标 5 尺。,🌪️
-🌱 生长,你让一颗种子迅速发芽,长成小植物。,创造一个小植物障碍。,🌱
-⚡ 电击,你释放一道微弱的电流,可以麻痹目标。,造成 1d4 点闪电伤害。,⚡
+🔥,火焰火花,你召唤出一朵小小的火焰,可以点燃蜡烛或篝火。,造成 1d4 点火焰伤害。,🔥
+💧,水流,你制造一股水流,可以扑灭小型火焰或弄湿目标。,造成 1d4 点水击伤害。,💧
+🌪️, 旋风,你制造一阵小旋风,可以吹散烟雾或轻小物体。,推开目标 5 尺。,
+🌱,生长,你让一颗种子迅速发芽,长成小植物。,创造一个小植物障碍。,🌱
+⚡,电击,你释放一道微弱的电流,可以麻痹目标。,造成 1d4 点闪电伤害。,⚡
diff --git a/src/App.tsx b/src/App.tsx
index d0ff792..89cf106 100644
--- a/src/App.tsx
+++ b/src/App.tsx
@@ -8,10 +8,12 @@ import './components';
const App: Component = () => {
const location = useLocation();
const [content, setContent] = createSignal('');
+ const [currentPath, setCurrentPath] = createSignal('');
onMount(async () => {
// 根据路由加载对应的 markdown 文件
const path = location.pathname.slice(1) || 'index';
+ setCurrentPath(path);
try {
const response = await fetch(`/content/${path}.md`);
if (response.ok) {
@@ -21,7 +23,7 @@ const App: Component = () => {
setContent('# 欢迎使用 TTRPG Tools\n\n没有找到对应的内容文件。');
}
} catch (error) {
- setContent('# 欢迎使用 TTRPG Tools\n\n这是一个 TTRPG 文档工具箱。\n\n## 功能\n\n- 使用 `:dice[2d6+d8]` 插入骰子组件\n- 使用 `:table[./data.csv]` 插入表格组件');
+ setContent('# 欢迎使用 TTRPG Tools\n\n这是一个 TTRPG 文档工具箱。\n\n## 功能\n\n- 使用 `:md-dice[2d6+d8]` 插入骰子组件\n- 使用 `:md-table[./data.csv]` 插入表格组件');
}
});
@@ -33,7 +35,9 @@ const App: Component = () => {
-
+
+
+
);
diff --git a/src/components/table.tsx b/src/components/table.tsx
index dd810a9..0e6ecb7 100644
--- a/src/components/table.tsx
+++ b/src/components/table.tsx
@@ -8,17 +8,37 @@ interface TableRow {
[key: string]: string;
}
-customElement('md-table', { src: '', roll: false, remix: false }, (props, { element }) => {
+customElement('md-table', { roll: false, remix: false }, (props, { element }) => {
noShadowDOM();
const [rows, setRows] = createSignal([]);
const [activeTab, setActiveTab] = createSignal(0);
const [loaded, setLoaded] = createSignal(false);
+ // 从 element 的 textContent 获取 CSV 路径
+ const src = element?.textContent?.trim() || '';
+
+ // 从父节点 article 的 data-src 获取当前 markdown 文件路径
+ const articleEl = element?.closest('article[data-src]');
+ const articlePath = articleEl?.getAttribute('data-src') || '';
+
+ // 解析相对路径
+ const resolvePath = (base: string, relative: string): string => {
+ if (relative.startsWith('/')) {
+ return relative;
+ }
+ const baseDir = base.substring(0, base.lastIndexOf('/') + 1);
+ return baseDir + relative;
+ };
+
+ const resolvedSrc = resolvePath(`/content/${articlePath}`, src);
+
// 解析 CSV 内容
const parseCSV = (content: string) => {
const records = parse(content, {
columns: true,
- skip_empty_lines: true,
+ comment: '#',
+ trim: true,
+ skipEmptyLines: true
});
setRows(records as TableRow[]);
setLoaded(true);
@@ -27,7 +47,7 @@ customElement('md-table', { src: '', roll: false, remix: false }, (props, { elem
// 加载 CSV 文件
const loadCSV = async () => {
try {
- const response = await fetch(props.src);
+ const response = await fetch(resolvedSrc);
const content = await response.text();
parseCSV(content);
} catch (error) {