@@ -116,8 +241,11 @@ function resetImport() {
Export
Import
+ Markdown
+ Web Clip
+
Export Board
Export a board to JSON for backup or sharing.
@@ -141,6 +269,7 @@ function resetImport() {
+
Import Board
@@ -175,6 +304,155 @@ function resetImport() {
Import Another
+
+
+
+
Import Markdown
+
+ Import a markdown file or paste markdown content. Sections are split at
+ headings and created as capture items in the inbox for review.
+
+
+
+
+ Markdown File
+
+
+
+
+ Or paste markdown content
+
+
+
+
+ Target Board ID (optional)
+
+
+
+
+ {{ mdImporting ? 'Importing...' : 'Import to Capture Inbox' }}
+
+
+
+
+
+ OK
+ {{ mdResult.itemsCreated }} capture item(s) created
+
+
+
+ {{ item.sourceType }}
+ {{ item.textExcerpt }}
+ {{ item.sourceRef }}
+
+
+ Import Another
+
+
+
+
+ ERR
+ {{ mdError }}
+
+ Try Again
+
+
+
+
+
+
Import Web Clip
+
+ Capture a web page snippet with its URL. The clip is created as a capture
+ item in the inbox for review, with the source URL preserved as provenance.
+
+
+
+
+ Source URL
+
+
+
+
+ Title (optional)
+
+
+
+
+ Content Snippet
+
+
+
+
+ Target Board ID (optional)
+
+
+
+
+ {{ clipImporting ? 'Importing...' : 'Clip to Capture Inbox' }}
+
+
+
+
+
+ OK
+ Web clip captured successfully
+
+
+
+ {{ item.sourceType }}
+ {{ item.textExcerpt }}
+ {{ item.sourceRef }}
+
+
+ Clip Another
+
+
+
+
+ ERR
+ {{ clipError }}
+
+ Try Again
+
+
@@ -188,7 +466,7 @@ function resetImport() {
.td-section-title { font-size: var(--td-font-lg); font-weight: 600; margin-bottom: var(--td-space-2); color: var(--td-text-primary); }
.td-section-desc { font-size: var(--td-font-sm); color: var(--td-text-secondary); margin-bottom: var(--td-space-4); }
.td-export-form { display: flex; gap: var(--td-space-3); align-items: flex-end; margin-bottom: var(--td-space-4); }
-.td-form-group { display: flex; flex-direction: column; gap: var(--td-space-1); flex: 1; }
+.td-form-group { display: flex; flex-direction: column; gap: var(--td-space-1); flex: 1; margin-bottom: var(--td-space-3); }
.td-label { font-size: var(--td-font-sm); font-weight: 500; color: var(--td-text-secondary); }
.td-input { padding: var(--td-space-2) var(--td-space-3); border: 1px solid var(--td-border-default); border-radius: var(--td-radius-md); font-size: var(--td-font-sm); }
.td-input:focus { outline: none; border-color: var(--td-border-focus); box-shadow: var(--td-focus-ring); }
@@ -211,4 +489,9 @@ function resetImport() {
.td-import-result--success { background: var(--td-color-success-light); color: var(--td-color-success); }
.td-import-result--error { background: var(--td-color-error-light); color: var(--td-color-error); }
.td-import-summary { margin-bottom: var(--td-space-4); color: var(--td-text-secondary); font-size: var(--td-font-sm); }
+.td-note-import-items { display: flex; flex-direction: column; gap: var(--td-space-2); margin-bottom: var(--td-space-4); }
+.td-note-import-item { display: flex; align-items: center; gap: var(--td-space-2); padding: var(--td-space-2) var(--td-space-3); background: var(--td-surface-container-lowest); border-radius: var(--td-radius-md); font-size: var(--td-font-sm); }
+.td-note-import-badge { display: inline-block; padding: var(--td-space-0) var(--td-space-2); background: var(--td-color-primary); color: var(--td-text-inverse); border-radius: var(--td-radius-sm); font-size: var(--td-font-xs); font-weight: 600; text-transform: uppercase; flex-shrink: 0; }
+.td-note-import-excerpt { color: var(--td-text-primary); flex: 1; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }
+.td-note-import-ref { color: var(--td-text-tertiary); font-size: var(--td-font-xs); flex-shrink: 0; max-width: 200px; overflow: hidden; text-overflow: ellipsis; white-space: nowrap; }