6da5e5b042
* Fix footer moving upwards * Fix column detection Was broken because escaped line breaks were not considered. Also removes delimiter detection on `#columns:` line. User must use tabs or set delimiter beforehand. * Add CSV preview * Parse `#tags column:` * Optionally export deck and notetype with CSV * Avoid clones in CSV export * Prevent bottom of page appearing under footer (dae) * Increase padding to 1em (dae) With 0.5em, when a vertical scrollbar is shown, it sits right next to the right edge of the content, making it look like there's no right margin. * Experimental changes to make table fit+scroll (dae) - limit individual cells to 15em, and show ellipses when truncated - limit total table width to body width, so that inner table is shown with scrollbar - use class rather than id - ids are bad practice in Svelte components, as more than one may be displayed on a single page * Skip importing foreign notes with filtered decks Were implicitly imported into the default deck before. Also some refactoring to fetch deck ids and names beforehand. * Hide spacer below hidden field mapping * Fix guid being replaced when updating note * Fix dupe identity check Canonify tags before checking if dupe is identical, but only add update tags later if appropriate. * Fix deck export for notes with missing card 1 * Fix note lines starting with `#` csv crate doesn't support escaping a leading comment char. :( * Support import/export of guids * Strip HTML from preview rows * Fix initially set deck if current is filtered * Make isHtml toggle reactive * Fix `html_to_text_line()` stripping sound names * Tweak export option labels * Switch to patched rust-csv fork Fixes writing lines starting with `#`, so revert 5ece10ad05f331. * List column options with first column field * Fix flag for exports with HTML stripped
55 lines
1.6 KiB
Svelte
55 lines
1.6 KiB
Svelte
<!--
|
|
Copyright: Ankitects Pty Ltd and contributors
|
|
License: GNU AGPL, version 3 or later; http://www.gnu.org/licenses/agpl.html
|
|
-->
|
|
<script lang="ts">
|
|
import ButtonGroup from "../components/ButtonGroup.svelte";
|
|
import Col from "../components/Col.svelte";
|
|
import LabelButton from "../components/LabelButton.svelte";
|
|
import Row from "../components/Row.svelte";
|
|
import Shortcut from "../components/Shortcut.svelte";
|
|
import * as tr from "../lib/ftl";
|
|
import { getPlatformString } from "../lib/shortcuts";
|
|
|
|
export let path: string;
|
|
export let onImport: () => void;
|
|
|
|
const keyCombination = "Control+Enter";
|
|
</script>
|
|
|
|
<div style:flex-grow="1" />
|
|
<div class="sticky-footer">
|
|
<Row --cols={5}
|
|
><Col --col-size={4}>{path}</Col><Col --col-justify="end">
|
|
<ButtonGroup size={2}>
|
|
<LabelButton
|
|
theme="primary"
|
|
tooltip={getPlatformString(keyCombination)}
|
|
on:click={onImport}
|
|
--border-left-radius="5px"
|
|
--border-right-radius="5px">{tr.actionsImport()}</LabelButton
|
|
>
|
|
<Shortcut {keyCombination} on:action={onImport} />
|
|
</ButtonGroup></Col
|
|
></Row
|
|
>
|
|
</div>
|
|
|
|
<style lang="scss">
|
|
.sticky-footer {
|
|
position: fixed;
|
|
bottom: 0;
|
|
left: 0;
|
|
right: 0;
|
|
z-index: 10;
|
|
|
|
margin: 0;
|
|
padding: 0.25rem;
|
|
|
|
background: var(--window-bg);
|
|
border-style: solid none none;
|
|
border-color: var(--border);
|
|
border-width: thin;
|
|
}
|
|
</style>
|