Compare commits
2 Commits
2b6080ba7e
...
c59afe3893
Author | SHA1 | Date | |
---|---|---|---|
c59afe3893 | |||
454d1dff1c |
5
.vscode/extensions.json
vendored
Normal file
5
.vscode/extensions.json
vendored
Normal file
@ -0,0 +1,5 @@
|
|||||||
|
{
|
||||||
|
"recommendations": [
|
||||||
|
"inlang.vs-code-extension"
|
||||||
|
]
|
||||||
|
}
|
@ -1,4 +1,5 @@
|
|||||||
{
|
{
|
||||||
"$schema": "https://inlang.com/schema/inlang-message-format",
|
"$schema": "https://inlang.com/schema/inlang-message-format",
|
||||||
"hello_world": "Hello, {name} from sv!"
|
"hello_world": "Hello, {name} from sv!",
|
||||||
|
"stt": "skrivtolkning"
|
||||||
}
|
}
|
||||||
|
3
package-lock.json
generated
3
package-lock.json
generated
@ -8,7 +8,7 @@
|
|||||||
"name": "code",
|
"name": "code",
|
||||||
"version": "0.0.1",
|
"version": "0.0.1",
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@inlang/paraglide-sveltekit": "^0.15.5",
|
"@inlang/paraglide-sveltekit": "0.15.5",
|
||||||
"@libsql/client": "^0.14.0",
|
"@libsql/client": "^0.14.0",
|
||||||
"@node-rs/argon2": "^2.0.2",
|
"@node-rs/argon2": "^2.0.2",
|
||||||
"@oslojs/crypto": "^1.0.1",
|
"@oslojs/crypto": "^1.0.1",
|
||||||
@ -21,6 +21,7 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@eslint/compat": "^1.2.5",
|
"@eslint/compat": "^1.2.5",
|
||||||
"@eslint/js": "^9.18.0",
|
"@eslint/js": "^9.18.0",
|
||||||
|
"@inlang/paraglide-js": "1.11.8",
|
||||||
"@playwright/test": "^1.49.1",
|
"@playwright/test": "^1.49.1",
|
||||||
"@sveltejs/adapter-auto": "^4.0.0",
|
"@sveltejs/adapter-auto": "^4.0.0",
|
||||||
"@sveltejs/kit": "^2.16.0",
|
"@sveltejs/kit": "^2.16.0",
|
||||||
|
@ -22,6 +22,7 @@
|
|||||||
"devDependencies": {
|
"devDependencies": {
|
||||||
"@eslint/compat": "^1.2.5",
|
"@eslint/compat": "^1.2.5",
|
||||||
"@eslint/js": "^9.18.0",
|
"@eslint/js": "^9.18.0",
|
||||||
|
"@inlang/paraglide-js": "1.11.8",
|
||||||
"@playwright/test": "^1.49.1",
|
"@playwright/test": "^1.49.1",
|
||||||
"@sveltejs/adapter-auto": "^4.0.0",
|
"@sveltejs/adapter-auto": "^4.0.0",
|
||||||
"@sveltejs/kit": "^2.16.0",
|
"@sveltejs/kit": "^2.16.0",
|
||||||
@ -52,7 +53,7 @@
|
|||||||
"zod": "^3.24.1"
|
"zod": "^3.24.1"
|
||||||
},
|
},
|
||||||
"dependencies": {
|
"dependencies": {
|
||||||
"@inlang/paraglide-sveltekit": "^0.15.5",
|
"@inlang/paraglide-sveltekit": "0.15.5",
|
||||||
"@libsql/client": "^0.14.0",
|
"@libsql/client": "^0.14.0",
|
||||||
"@node-rs/argon2": "^2.0.2",
|
"@node-rs/argon2": "^2.0.2",
|
||||||
"@oslojs/crypto": "^1.0.1",
|
"@oslojs/crypto": "^1.0.1",
|
||||||
|
@ -23,16 +23,18 @@
|
|||||||
};
|
};
|
||||||
let importing = false;
|
let importing = false;
|
||||||
let progress = 0;
|
let progress = 0;
|
||||||
const handleImport = () => {
|
const handleImport = async () => {
|
||||||
importing = true;
|
importing = true;
|
||||||
const l: List = { name: form.name, type: form.type ? 1 : 0, updated: new Date() };
|
const l: List = { name: form.name, type: form.type ? 1 : 0, updated: new Date() };
|
||||||
createShortformList(l);
|
const listid = await createShortformList(l);
|
||||||
form.textarea.split('\n').forEach((sf, i, sfs) => {
|
let sfs = []
|
||||||
progress = 100 * (i / sfs.length);
|
form.textarea.split('\n').forEach((line) => {
|
||||||
if (Math.random() > 0.8) {
|
const fields = line.split("=")
|
||||||
setTimeout(() => {}, 125);
|
if (fields.length == 2) {
|
||||||
|
sfs.push({shortform: fields[0], phrase: fields[1], used: 0, listid: listid})
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
importShortforms(sfs)
|
||||||
};
|
};
|
||||||
const cancelImport = () => {
|
const cancelImport = () => {
|
||||||
importState.data = '';
|
importState.data = '';
|
||||||
|
@ -6,9 +6,28 @@
|
|||||||
import { getCurrentWord, insertExpandedPhrase, insertText } from '$lib/textarea/main';
|
import { getCurrentWord, insertExpandedPhrase, insertText } from '$lib/textarea/main';
|
||||||
import { cacheShortforms, expandShortform } from '../modules/shortforms';
|
import { cacheShortforms, expandShortform } from '../modules/shortforms';
|
||||||
import { defaultExpanders } from '../modules/keyboard';
|
import { defaultExpanders } from '../modules/keyboard';
|
||||||
import type { Shortform } from '../db/main';
|
import { db, type Shortform } from '../db/main';
|
||||||
import AccordionTrigger from '$lib/components/ui/accordion/accordion-trigger.svelte';
|
import { liveQuery } from "dexie";
|
||||||
|
|
||||||
|
import * as Select from "$lib/components/ui/select/index.js";
|
||||||
|
|
||||||
|
let styles = {
|
||||||
|
"text-bg": "#333333",
|
||||||
|
"text-fg": "#baff00",
|
||||||
|
}
|
||||||
|
|
||||||
|
$: cssVarStyles = Object.entries(styles)
|
||||||
|
.map(([key, value]) => `--${key}:${value}`)
|
||||||
|
.join(';');
|
||||||
|
|
||||||
|
$: standardLists = liveQuery( async () => {
|
||||||
|
return await db.lists.toArray()
|
||||||
|
}
|
||||||
|
)
|
||||||
|
let selectedStandardList = {}
|
||||||
|
const selectedStandardListChanged = (v) => {
|
||||||
|
shortforms.cache = cacheShortforms([Number(v.value)]);
|
||||||
|
}
|
||||||
let state = {
|
let state = {
|
||||||
capitalizeNext: true,
|
capitalizeNext: true,
|
||||||
currentWord: ''
|
currentWord: ''
|
||||||
@ -78,8 +97,24 @@
|
|||||||
*/
|
*/
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div class="docContainer" role="application" id="docContainer">
|
<div class="docContainer h-full flex flex-col" role="application" id="docContainer">
|
||||||
<textarea id="doc" rows="4" on:keyup={change} on:beforeinput={input} bind:value={text}></textarea>
|
<textarea style={cssVarStyles} class="textarea flex-grow" id="doc" on:keyup={change} on:beforeinput={input} bind:value={text}></textarea>
|
||||||
|
<Select.Root
|
||||||
|
selected={selectedStandardList}
|
||||||
|
onSelectedChange={selectedStandardListChanged}
|
||||||
|
class="flex-none"
|
||||||
|
>
|
||||||
|
<Select.Trigger>
|
||||||
|
<Select.Value placeholder="Välj standardlista" />
|
||||||
|
</Select.Trigger>
|
||||||
|
<Select.Content>
|
||||||
|
<Select.Group>
|
||||||
|
{#each $standardLists as list}
|
||||||
|
<Select.Item value={list.id} label={list.name}>{list.name}</Select.Item>
|
||||||
|
{/each}
|
||||||
|
</Select.Group>
|
||||||
|
</Select.Content>
|
||||||
|
</Select.Root>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
<style lang="postcss">
|
<style lang="postcss">
|
||||||
@ -88,9 +123,12 @@
|
|||||||
}
|
}
|
||||||
.docContainer textarea {
|
.docContainer textarea {
|
||||||
width: 100%;
|
width: 100%;
|
||||||
color: black;
|
|
||||||
padding: 0.3em;
|
padding: 0.3em;
|
||||||
resize: none;
|
resize: none;
|
||||||
font-size: 2em;
|
font-size: 2em;
|
||||||
}
|
}
|
||||||
|
.textarea {
|
||||||
|
color: var(--text-fg, black);
|
||||||
|
background-color: var(--text-bg, white);
|
||||||
|
}
|
||||||
</style>
|
</style>
|
||||||
|
@ -2,12 +2,13 @@ import default_shortforms from "./shortforms.se.json";
|
|||||||
import { db, type Shortform, type List } from "./main"
|
import { db, type Shortform, type List } from "./main"
|
||||||
|
|
||||||
export const importShortforms = (shortforms: Array<Shortform>) => {
|
export const importShortforms = (shortforms: Array<Shortform>) => {
|
||||||
/*
|
const used = new Date(0)
|
||||||
|
const updated = Date.now()
|
||||||
shortforms.map((sf: Shortform) => {
|
shortforms.map((sf: Shortform) => {
|
||||||
db.shortforms.add({ shortform: sf.sf, phrase: sf.p })
|
db.shortforms.add({ shortform: sf.shortform, phrase: sf.phrase, listid: sf.listid, used, uses: 0, remind: -1, updated })
|
||||||
})
|
})
|
||||||
*/
|
|
||||||
}
|
}
|
||||||
|
|
||||||
export const importDefaultShortforms = () => {
|
export const importDefaultShortforms = () => {
|
||||||
const shortforms = default_shortforms.shortforms
|
const shortforms = default_shortforms.shortforms
|
||||||
const list: List = { id: default_shortforms.listid, type: default_shortforms.type, name: default_shortforms.name, updated: new Date(default_shortforms.updated) }
|
const list: List = { id: default_shortforms.listid, type: default_shortforms.type, name: default_shortforms.name, updated: new Date(default_shortforms.updated) }
|
||||||
|
@ -46,18 +46,15 @@ export class SkrivertDB extends Dexie {
|
|||||||
|
|
||||||
if (localListsCount === 0) {
|
if (localListsCount === 0) {
|
||||||
// No local data - perform full download
|
// No local data - perform full download
|
||||||
importDefaultShortforms()
|
//importDefaultShortforms()
|
||||||
console.log('No local data found. Prompt user to import data or use standard list...');
|
console.log('No local data found. Prompt user to import data or use standard list...');
|
||||||
}
|
}
|
||||||
})
|
})
|
||||||
};
|
};
|
||||||
}
|
}
|
||||||
|
|
||||||
export function createShortformList(l: List): number {
|
export async function createShortformList(l: List): number {
|
||||||
db.lists.add(l)
|
return await db.lists.add(l)
|
||||||
.then(result => {
|
|
||||||
console.log(result)
|
|
||||||
})
|
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
||||||
|
@ -23,6 +23,7 @@ export function cacheShortforms(lists: Array<number> = []) {
|
|||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
lists.forEach(listid => {
|
lists.forEach(listid => {
|
||||||
|
console.log("looking up shortforms for this listid:", listid)
|
||||||
db.shortforms.where("listid").equals(listid).toArray().then(sfs => {
|
db.shortforms.where("listid").equals(listid).toArray().then(sfs => {
|
||||||
sfs.forEach(sf => {
|
sfs.forEach(sf => {
|
||||||
shortforms.set(sf.shortform, sf)
|
shortforms.set(sf.shortform, sf)
|
||||||
|
@ -5,8 +5,6 @@
|
|||||||
let { children } = $props();
|
let { children } = $props();
|
||||||
</script>
|
</script>
|
||||||
|
|
||||||
<div role="presentation">
|
<ParaglideJS {i18n}>
|
||||||
<ParaglideJS {i18n}>
|
|
||||||
{@render children()}
|
{@render children()}
|
||||||
</ParaglideJS>
|
</ParaglideJS>
|
||||||
</div>
|
|
||||||
|
@ -29,9 +29,10 @@
|
|||||||
|
|
||||||
<svelte:window on:keydown={handleHotkeys} />
|
<svelte:window on:keydown={handleHotkeys} />
|
||||||
|
|
||||||
<div class="h-full w-full" role="application">
|
<div class="h-dvh w-full" role="application">
|
||||||
|
<div class="h-full">
|
||||||
<Textarea />
|
<Textarea />
|
||||||
<Dashboard open={showDashboard} />
|
<Dashboard open={showDashboard} />
|
||||||
|
|
||||||
<!-- <Button variant="destructive" on:click={deleteDefaultShortforms}>Ta bort standardlista</Button>-->
|
<!-- <Button variant="destructive" on:click={deleteDefaultShortforms}>Ta bort standardlista</Button>-->
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
|
Loading…
x
Reference in New Issue
Block a user