Fresh install
This commit is contained in:
parent
4a3be05321
commit
fd354b4e51
|
@ -0,0 +1,5 @@
|
||||||
|
{
|
||||||
|
"recommendations": [
|
||||||
|
"ionic.ionic"
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,8 @@
|
||||||
|
{
|
||||||
|
"cSpell.words": [
|
||||||
|
"datatyping",
|
||||||
|
"docuri",
|
||||||
|
"Dyomedea",
|
||||||
|
"stackoverflow"
|
||||||
|
]
|
||||||
|
}
|
|
@ -0,0 +1,10 @@
|
||||||
|
import { CapacitorConfig } from '@capacitor/cli';
|
||||||
|
|
||||||
|
const config: CapacitorConfig = {
|
||||||
|
appId: 'com.example.app',
|
||||||
|
appName: 'capacitor-solid-template',
|
||||||
|
webDir: 'dist',
|
||||||
|
bundledWebRuntime: false,
|
||||||
|
};
|
||||||
|
|
||||||
|
export default config;
|
|
@ -0,0 +1,18 @@
|
||||||
|
import fs from 'fs';
|
||||||
|
import path from 'path';
|
||||||
|
|
||||||
|
const typesPath = path.resolve('node_modules', '@types', 'testing-library__jest-dom', 'index.d.ts');
|
||||||
|
|
||||||
|
fs.readFile(typesPath, 'utf8', (err, data) => {
|
||||||
|
if (err) throw err;
|
||||||
|
|
||||||
|
let lines = data.split('\n');
|
||||||
|
|
||||||
|
if (lines[8] === '/// <reference types="jest" />') {
|
||||||
|
lines = lines.slice(0, 8).concat(lines.slice(9));
|
||||||
|
}
|
||||||
|
|
||||||
|
fs.writeFile(typesPath, lines.join('\n'), 'utf8', function(err) {
|
||||||
|
if (err) throw err;
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,16 @@
|
||||||
|
<!DOCTYPE html>
|
||||||
|
<html lang="en">
|
||||||
|
<head>
|
||||||
|
<meta charset="utf-8" />
|
||||||
|
<meta name="viewport" content="width=device-width, initial-scale=1" />
|
||||||
|
<meta name="theme-color" content="#000000" />
|
||||||
|
<link rel="shortcut icon" type="image/ico" href="/src/assets/favicon.ico" />
|
||||||
|
<title>Solid App</title>
|
||||||
|
</head>
|
||||||
|
<body>
|
||||||
|
<noscript>You need to enable JavaScript to run this app.</noscript>
|
||||||
|
<div id="root"></div>
|
||||||
|
|
||||||
|
<script src="/src/index.tsx" type="module"></script>
|
||||||
|
</body>
|
||||||
|
</html>
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1,31 @@
|
||||||
|
{
|
||||||
|
"name": "capacitor-solid-template",
|
||||||
|
"version": "0.0.0",
|
||||||
|
"description": "",
|
||||||
|
"type": "module",
|
||||||
|
"scripts": {
|
||||||
|
"start": "vite",
|
||||||
|
"dev": "vite",
|
||||||
|
"build": "vite build",
|
||||||
|
"serve": "vite preview",
|
||||||
|
"test": "vitest",
|
||||||
|
"postinstall": "node ./fix-jest-dom.mjs"
|
||||||
|
},
|
||||||
|
"license": "MIT",
|
||||||
|
"devDependencies": {
|
||||||
|
"@capacitor/cli": "^3.4.3",
|
||||||
|
"@testing-library/jest-dom": "^5.16.2",
|
||||||
|
"jsdom": "^19.0.0",
|
||||||
|
"solid-testing-library": "^0.3.0",
|
||||||
|
"typescript": "^4.6.2",
|
||||||
|
"vite": ">2.8.6",
|
||||||
|
"vite-plugin-solid": "^2.2.6",
|
||||||
|
"vitest": "^0.6.0"
|
||||||
|
},
|
||||||
|
"dependencies": {
|
||||||
|
"@capacitor/android": "^3.4.3",
|
||||||
|
"@capacitor/core": "^3.4.3",
|
||||||
|
"@capacitor/ios": "^3.4.3",
|
||||||
|
"solid-js": "^1.3.12"
|
||||||
|
}
|
||||||
|
}
|
File diff suppressed because it is too large
Load Diff
|
@ -0,0 +1 @@
|
||||||
|
import '@testing-library/jest-dom';
|
|
@ -0,0 +1,5 @@
|
||||||
|
import { render } from 'solid-js/web';
|
||||||
|
|
||||||
|
import { TodoList } from './todo-list';
|
||||||
|
|
||||||
|
render(() => <TodoList />, document.getElementById('root'));
|
|
@ -0,0 +1,46 @@
|
||||||
|
import { describe, expect, test } from 'vitest';
|
||||||
|
|
||||||
|
import { render, fireEvent } from 'solid-testing-library';
|
||||||
|
|
||||||
|
import { TodoList } from './todo-list';
|
||||||
|
|
||||||
|
describe('<TodoList />', () => {
|
||||||
|
test('it will render an text input and a button', () => {
|
||||||
|
const { getByPlaceholderText, getByText, unmount } = render(() => (
|
||||||
|
<TodoList />
|
||||||
|
));
|
||||||
|
expect(getByPlaceholderText('new todo here')).toBeInTheDocument();
|
||||||
|
expect(getByText('Add Todo')).toBeInTheDocument();
|
||||||
|
unmount();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('it will add a new todo', async () => {
|
||||||
|
const { getByPlaceholderText, getByText, unmount } = render(() => (
|
||||||
|
<TodoList />
|
||||||
|
));
|
||||||
|
const input = getByPlaceholderText('new todo here') as HTMLInputElement;
|
||||||
|
const button = getByText('Add Todo');
|
||||||
|
input.value = 'test new todo';
|
||||||
|
fireEvent.click(button as HTMLInputElement);
|
||||||
|
expect(input.value).toBe('');
|
||||||
|
expect(getByText(/test new todo/)).toBeInTheDocument();
|
||||||
|
unmount();
|
||||||
|
});
|
||||||
|
|
||||||
|
test('it will mark a todo as completed', async () => {
|
||||||
|
const { getByPlaceholderText, findByRole, getByText, unmount } = render(
|
||||||
|
() => <TodoList />,
|
||||||
|
);
|
||||||
|
const input = getByPlaceholderText('new todo here') as HTMLInputElement;
|
||||||
|
const button = getByText('Add Todo') as HTMLButtonElement;
|
||||||
|
input.value = 'mark new todo as completed';
|
||||||
|
fireEvent.click(button);
|
||||||
|
const completed = (await findByRole('checkbox')) as HTMLInputElement;
|
||||||
|
expect(completed?.checked).toBe(false);
|
||||||
|
fireEvent.click(completed);
|
||||||
|
expect(completed?.checked).toBe(true);
|
||||||
|
const text = getByText('mark new todo as completed') as HTMLSpanElement;
|
||||||
|
expect(text).toHaveStyle({ 'text-decoration': 'line-through' });
|
||||||
|
unmount();
|
||||||
|
});
|
||||||
|
});
|
|
@ -0,0 +1,57 @@
|
||||||
|
import { For, createSignal } from 'solid-js';
|
||||||
|
|
||||||
|
type Todo = { id: number; text: string; completed: boolean };
|
||||||
|
|
||||||
|
export const TodoList = () => {
|
||||||
|
let input!: HTMLInputElement;
|
||||||
|
let todoId = 0;
|
||||||
|
const [todos, setTodos] = createSignal<Todo[]>([]);
|
||||||
|
const addTodo = (text: string) => {
|
||||||
|
setTodos([...todos(), { id: ++todoId, text, completed: false }]);
|
||||||
|
};
|
||||||
|
const toggleTodo = (id: number) => {
|
||||||
|
setTodos(
|
||||||
|
todos().map((todo) =>
|
||||||
|
todo.id === id ? { ...todo, completed: !todo.completed } : todo,
|
||||||
|
),
|
||||||
|
);
|
||||||
|
};
|
||||||
|
|
||||||
|
return (
|
||||||
|
<>
|
||||||
|
<div>
|
||||||
|
<input placeholder="new todo here" ref={input} />
|
||||||
|
<button
|
||||||
|
onClick={() => {
|
||||||
|
if (!input.value.trim()) return;
|
||||||
|
addTodo(input.value);
|
||||||
|
input.value = '';
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
Add Todo
|
||||||
|
</button>
|
||||||
|
</div>
|
||||||
|
<For each={todos()}>
|
||||||
|
{(todo) => {
|
||||||
|
const { id, text } = todo;
|
||||||
|
return (
|
||||||
|
<div>
|
||||||
|
<input
|
||||||
|
type="checkbox"
|
||||||
|
checked={todo.completed}
|
||||||
|
onchange={[toggleTodo, id]}
|
||||||
|
/>
|
||||||
|
<span
|
||||||
|
style={{
|
||||||
|
'text-decoration': todo.completed ? 'line-through' : 'none',
|
||||||
|
}}
|
||||||
|
>
|
||||||
|
{text}
|
||||||
|
</span>
|
||||||
|
</div>
|
||||||
|
);
|
||||||
|
}}
|
||||||
|
</For>
|
||||||
|
</>
|
||||||
|
);
|
||||||
|
};
|
|
@ -0,0 +1,13 @@
|
||||||
|
{
|
||||||
|
"compilerOptions": {
|
||||||
|
"strict": true,
|
||||||
|
"target": "ESNext",
|
||||||
|
"module": "ESNext",
|
||||||
|
"moduleResolution": "node",
|
||||||
|
"allowSyntheticDefaultImports": true,
|
||||||
|
"esModuleInterop": true,
|
||||||
|
"jsx": "preserve",
|
||||||
|
"jsxImportSource": "solid-js",
|
||||||
|
"types": ["vite/client"]
|
||||||
|
}
|
||||||
|
}
|
|
@ -0,0 +1,33 @@
|
||||||
|
/// <reference types="vitest" />
|
||||||
|
/// <reference types="vite/client" />
|
||||||
|
|
||||||
|
import { defineConfig } from 'vite';
|
||||||
|
import solidPlugin from 'vite-plugin-solid';
|
||||||
|
|
||||||
|
export default defineConfig({
|
||||||
|
plugins: [solidPlugin()],
|
||||||
|
test: {
|
||||||
|
environment: 'jsdom',
|
||||||
|
globals: true,
|
||||||
|
transformMode: {
|
||||||
|
web: [/\.[jt]sx?$/],
|
||||||
|
},
|
||||||
|
setupFiles: './setupVitest.ts',
|
||||||
|
// solid needs to be inline to work around
|
||||||
|
// a resolution issue in vitest:
|
||||||
|
deps: {
|
||||||
|
inline: [/solid-js/],
|
||||||
|
},
|
||||||
|
// if you have few tests, try commenting one
|
||||||
|
// or both out to improve performance:
|
||||||
|
threads: false,
|
||||||
|
isolate: false,
|
||||||
|
},
|
||||||
|
build: {
|
||||||
|
target: 'esnext',
|
||||||
|
polyfillDynamicImport: false,
|
||||||
|
},
|
||||||
|
resolve: {
|
||||||
|
conditions: ['development', 'browser'],
|
||||||
|
},
|
||||||
|
});
|
Loading…
Reference in New Issue