@reactful/create 1.2.1 → 1.2.3
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/README.md +7 -7
- package/commons/package.json +21 -21
- package/commons/tsconfig.json +24 -24
- package/index.js +148 -148
- package/package.json +31 -31
- package/templates/minimal/components/hello.tsx +8 -8
- package/templates/minimal/components/icon.tsx +11 -0
- package/templates/minimal/components/index.ts +2 -1
- package/templates/minimal/routes/index.tsx +7 -6
- package/templates/sampling/apis/auth/db.ts +14 -14
- package/templates/sampling/apis/auth/index.ts +27 -27
- package/templates/sampling/apis/hello.ts +2 -2
- package/templates/sampling/apis/quotes.ts +15 -15
- package/templates/sampling/apis/sub/index.ts +2 -2
- package/templates/sampling/apis/sub/sub.ts +2 -2
- package/templates/sampling/assets/bootstrap-icons.css +5 -0
- package/templates/sampling/assets/default.css +94 -91
- package/templates/sampling/assets/fonts/bootstrap-icons.woff +0 -0
- package/templates/sampling/assets/fonts/bootstrap-icons.woff2 +0 -0
- package/templates/sampling/assets/icon.svg +6 -6
- package/templates/sampling/assets/manifest.json +56 -56
- package/templates/sampling/assets/markdown.css +273 -273
- package/templates/sampling/assets/robots.txt +1 -1
- package/templates/sampling/assets/system.css +6 -6
- package/templates/sampling/builds/about.html +29 -26
- package/templates/sampling/builds/bundle.js +34763 -13116
- package/templates/sampling/builds/bundle.ts +20 -25
- package/templates/sampling/builds/clock.html +29 -28
- package/templates/sampling/builds/counter.html +30 -29
- package/templates/sampling/builds/forms/form.html +48 -47
- package/templates/sampling/builds/forms/index.html +48 -47
- package/templates/sampling/builds/hello.html +61 -59
- package/templates/sampling/builds/htmlx.html +26 -23
- package/templates/sampling/builds/htmlx.tsx +12 -12
- package/templates/sampling/builds/index.html +98 -97
- package/templates/sampling/builds/login.html +47 -44
- package/templates/sampling/builds/profile/index.html +54 -53
- package/templates/sampling/builds/quotes.html +26 -25
- package/templates/sampling/builds/shared.js +77 -76
- package/templates/sampling/builds/system.html +27 -26
- package/templates/sampling/components/header.tsx +6 -6
- package/templates/sampling/components/hello.tsx +9 -0
- package/templates/sampling/components/icon.tsx +11 -0
- package/templates/sampling/components/index.ts +3 -0
- package/templates/sampling/index.html +20 -19
- package/templates/sampling/index.ts +18 -18
- package/templates/sampling/routes/about.html +12 -12
- package/templates/sampling/routes/clock.tsx +36 -35
- package/templates/sampling/routes/forms/form.tsx +50 -50
- package/templates/sampling/routes/hello.tsx +58 -61
- package/templates/sampling/routes/htmlx.html +14 -14
- package/templates/sampling/routes/index.md +15 -15
- package/templates/sampling/routes/login.tsx +35 -35
- package/templates/sampling/routes/profile/detail.css +12 -12
- package/templates/sampling/routes/profile/detail.tsx +47 -47
- package/templates/sampling/routes/profile/index.tsx +13 -13
- package/templates/sampling/routes/profile/profile.css +8 -8
- package/templates/sampling/routes/profile/tester.tsx +10 -10
- package/templates/sampling/routes/system.tsx +1 -0
- package/templates/sampling/tests/access.spec.ts +29 -29
- package/templates/sampling/tests/counter.spec.ts +18 -18
- package/templates/sampling/tests/form.spec.ts +50 -50
- package/templates/sampling/tests/hello.spec.ts +24 -24
- package/templates/sampling/tests/path.test.ts +19 -19
- package/vscode/launch.json +8 -8
- package/templates/sampling/builds/client.ts +0 -1
- /package/templates/sampling/assets/{logo-144.png → logos/logo-144.png} +0 -0
- /package/templates/sampling/assets/{logo-168.png → logos/logo-168.png} +0 -0
- /package/templates/sampling/assets/{logo-192.png → logos/logo-192.png} +0 -0
- /package/templates/sampling/assets/{logo-48.png → logos/logo-48.png} +0 -0
- /package/templates/sampling/assets/{logo-512.png → logos/logo-512.png} +0 -0
- /package/templates/sampling/assets/{logo-72.png → logos/logo-72.png} +0 -0
- /package/templates/sampling/assets/{logo-96.png → logos/logo-96.png} +0 -0
@@ -1,19 +1,19 @@
|
|
1
|
-
import { test, expect } from '@playwright/test'
|
2
|
-
|
3
|
-
test('counter: statefull props', async ({ page }) => {
|
4
|
-
await page.goto('http://localhost:3000/counter')
|
5
|
-
await page.waitForTimeout(99)
|
6
|
-
await page.click('button', { delay:99 })
|
7
|
-
await page.click('button', { delay:99 })
|
8
|
-
await page.click('button', { delay:99 })
|
9
|
-
await page.waitForTimeout(99)
|
10
|
-
|
11
|
-
const btn = await page.locator('button').innerText()
|
12
|
-
expect(btn.trim()).toBe('COUNTED: 3')
|
13
|
-
})
|
14
|
-
|
15
|
-
test('counter: shown custom props directive', async ({ page }) => {
|
16
|
-
await page.goto('http://localhost:3000/counter')
|
17
|
-
const h2IsVisible = await page.locator('h6').isVisible()
|
18
|
-
expect(h2IsVisible).toBe(false)
|
1
|
+
import { test, expect } from '@playwright/test'
|
2
|
+
|
3
|
+
test('counter: statefull props', async ({ page }) => {
|
4
|
+
await page.goto('http://localhost:3000/counter')
|
5
|
+
await page.waitForTimeout(99)
|
6
|
+
await page.click('button', { delay:99 })
|
7
|
+
await page.click('button', { delay:99 })
|
8
|
+
await page.click('button', { delay:99 })
|
9
|
+
await page.waitForTimeout(99)
|
10
|
+
|
11
|
+
const btn = await page.locator('button').innerText()
|
12
|
+
expect(btn.trim()).toBe('COUNTED: 3')
|
13
|
+
})
|
14
|
+
|
15
|
+
test('counter: shown custom props directive', async ({ page }) => {
|
16
|
+
await page.goto('http://localhost:3000/counter')
|
17
|
+
const h2IsVisible = await page.locator('h6').isVisible()
|
18
|
+
expect(h2IsVisible).toBe(false)
|
19
19
|
})
|
@@ -1,51 +1,51 @@
|
|
1
|
-
// import { test, expect } from '@playwright/test'
|
2
|
-
|
3
|
-
// async function goto(page) {
|
4
|
-
// await page.goto('http://localhost:3000/forms')
|
5
|
-
// await page.waitForTimeout(1500)
|
6
|
-
// }
|
7
|
-
|
8
|
-
// test(`form validation: checkbox`, async function({ page }) {
|
9
|
-
// await goto(page)
|
10
|
-
// await page.click('button', { delay:333 })
|
11
|
-
|
12
|
-
// const check = await page.locator('[type="checkbox"]')
|
13
|
-
// const checkHandle = await check!.evaluateHandle(x => x['validationMessage'])
|
14
|
-
// const validationMessage = await checkHandle.jsonValue()
|
15
|
-
|
16
|
-
// expect(validationMessage).toBe('Please check this box if you want to proceed')
|
17
|
-
// })
|
18
|
-
|
19
|
-
// test(`form validation: input`, async function({ page }) {
|
20
|
-
// await goto(page)
|
21
|
-
// await page.click('[uid="14"]')
|
22
|
-
// await page.click('button', { delay:333 })
|
23
|
-
|
24
|
-
// const input = await page.evaluate(() => document.querySelector('[bind="mode"]'))
|
25
|
-
// const validationMessage = input && input['validationMessage']
|
26
|
-
|
27
|
-
// // const input = await page.$('[bind="mode"]');
|
28
|
-
// // const inputHandle = await input!.evaluateHandle(x => x['validationMessage'])
|
29
|
-
// // const validationMessage = await inputHandle.jsonValue()
|
30
|
-
|
31
|
-
// expect(validationMessage).toBe('Mode is required!')
|
32
|
-
// })
|
33
|
-
|
34
|
-
// test(`form action: errors feedback`, async function({ page }) {
|
35
|
-
// await goto(page)
|
36
|
-
|
37
|
-
// const checkbox = await page.getByLabel('Accepted?')
|
38
|
-
// await checkbox.click()
|
39
|
-
|
40
|
-
// await page.getByLabel('Accepted?').click()
|
41
|
-
// await page.fill('[bind="mode"]', 'ok', { timeout:99 })
|
42
|
-
// await page.click('button', { delay:333 })
|
43
|
-
|
44
|
-
// const progress = await page.locator('progress').isVisible()
|
45
|
-
// expect(progress).toBe(true)
|
46
|
-
|
47
|
-
// await page.waitForTimeout(333)
|
48
|
-
|
49
|
-
// const li = await page.locator('ul > li').innerHTML()
|
50
|
-
// expect(li).toContain('URL not found')
|
1
|
+
// import { test, expect } from '@playwright/test'
|
2
|
+
|
3
|
+
// async function goto(page) {
|
4
|
+
// await page.goto('http://localhost:3000/forms')
|
5
|
+
// await page.waitForTimeout(1500)
|
6
|
+
// }
|
7
|
+
|
8
|
+
// test(`form validation: checkbox`, async function({ page }) {
|
9
|
+
// await goto(page)
|
10
|
+
// await page.click('button', { delay:333 })
|
11
|
+
|
12
|
+
// const check = await page.locator('[type="checkbox"]')
|
13
|
+
// const checkHandle = await check!.evaluateHandle(x => x['validationMessage'])
|
14
|
+
// const validationMessage = await checkHandle.jsonValue()
|
15
|
+
|
16
|
+
// expect(validationMessage).toBe('Please check this box if you want to proceed')
|
17
|
+
// })
|
18
|
+
|
19
|
+
// test(`form validation: input`, async function({ page }) {
|
20
|
+
// await goto(page)
|
21
|
+
// await page.click('[uid="14"]')
|
22
|
+
// await page.click('button', { delay:333 })
|
23
|
+
|
24
|
+
// const input = await page.evaluate(() => document.querySelector('[bind="mode"]'))
|
25
|
+
// const validationMessage = input && input['validationMessage']
|
26
|
+
|
27
|
+
// // const input = await page.$('[bind="mode"]');
|
28
|
+
// // const inputHandle = await input!.evaluateHandle(x => x['validationMessage'])
|
29
|
+
// // const validationMessage = await inputHandle.jsonValue()
|
30
|
+
|
31
|
+
// expect(validationMessage).toBe('Mode is required!')
|
32
|
+
// })
|
33
|
+
|
34
|
+
// test(`form action: errors feedback`, async function({ page }) {
|
35
|
+
// await goto(page)
|
36
|
+
|
37
|
+
// const checkbox = await page.getByLabel('Accepted?')
|
38
|
+
// await checkbox.click()
|
39
|
+
|
40
|
+
// await page.getByLabel('Accepted?').click()
|
41
|
+
// await page.fill('[bind="mode"]', 'ok', { timeout:99 })
|
42
|
+
// await page.click('button', { delay:333 })
|
43
|
+
|
44
|
+
// const progress = await page.locator('progress').isVisible()
|
45
|
+
// expect(progress).toBe(true)
|
46
|
+
|
47
|
+
// await page.waitForTimeout(333)
|
48
|
+
|
49
|
+
// const li = await page.locator('ul > li').innerHTML()
|
50
|
+
// expect(li).toContain('URL not found')
|
51
51
|
// })
|
@@ -1,25 +1,25 @@
|
|
1
|
-
import { test, expect } from '@playwright/test'
|
2
|
-
|
3
|
-
const cases = [
|
4
|
-
['local', 'hi!', '[id="1"]', '#l1'],
|
5
|
-
['global (outer)', 'hi!', '[id="2"]', '#l2'],
|
6
|
-
['global (inner)', 'hi!', '[id="3"]', '#l2'],
|
7
|
-
]
|
8
|
-
|
9
|
-
cases.forEach(function(scenario) {
|
10
|
-
const [ scope, text, inputId, labelId ] = scenario
|
11
|
-
|
12
|
-
test(`hello: ${scope} props binding`, async function({ page }) {
|
13
|
-
await page.goto('http://localhost:3000/hello')
|
14
|
-
await page.waitForTimeout(99)
|
15
|
-
|
16
|
-
for await (const char of text.split('')) {
|
17
|
-
await page.waitForTimeout(99)
|
18
|
-
await page.type(inputId, char, { delay: 99 })
|
19
|
-
}
|
20
|
-
|
21
|
-
await page.waitForTimeout(99)
|
22
|
-
const result = await page.locator(labelId).innerText()
|
23
|
-
expect(result).toBe(text)
|
24
|
-
})
|
1
|
+
import { test, expect } from '@playwright/test'
|
2
|
+
|
3
|
+
const cases = [
|
4
|
+
['local', 'hi!', '[id="1"]', '#l1'],
|
5
|
+
['global (outer)', 'hi!', '[id="2"]', '#l2'],
|
6
|
+
['global (inner)', 'hi!', '[id="3"]', '#l2'],
|
7
|
+
]
|
8
|
+
|
9
|
+
cases.forEach(function(scenario) {
|
10
|
+
const [ scope, text, inputId, labelId ] = scenario
|
11
|
+
|
12
|
+
test(`hello: ${scope} props binding`, async function({ page }) {
|
13
|
+
await page.goto('http://localhost:3000/hello')
|
14
|
+
await page.waitForTimeout(99)
|
15
|
+
|
16
|
+
for await (const char of text.split('')) {
|
17
|
+
await page.waitForTimeout(99)
|
18
|
+
await page.type(inputId, char, { delay: 99 })
|
19
|
+
}
|
20
|
+
|
21
|
+
await page.waitForTimeout(99)
|
22
|
+
const result = await page.locator(labelId).innerText()
|
23
|
+
expect(result).toBe(text)
|
24
|
+
})
|
25
25
|
})
|
@@ -1,20 +1,20 @@
|
|
1
|
-
import { test, expect } from 'bun:test'
|
2
|
-
|
3
|
-
const scenarios = [
|
4
|
-
['url', '/routes', '/'],
|
5
|
-
['sub url', '/routes/sub', '/sub'],
|
6
|
-
['http', 'http://domain.com/routes', '/'],
|
7
|
-
['https', 'https://domain.com/routes', '/'],
|
8
|
-
['https port', 'https://domain.com:3000/routes', '/'],
|
9
|
-
['https port file', 'https://domain.com:3000/routes/file.tsx', '/file'],
|
10
|
-
['https port index', 'https://domain.com:3000/routes/index', '/'],
|
11
|
-
['https port sub file', 'https://domain.com:3000/routes/sub/file.tsx', '/sub/file'],
|
12
|
-
]
|
13
|
-
|
14
|
-
scenarios.forEach(function([ scenario, sampling, expected ]) {
|
15
|
-
test(`new Path(url).href: ${scenario}`, function() {
|
16
|
-
const resulted = new URL(sampling).pathname
|
17
|
-
expect(resulted).toBe(expected as any)
|
18
|
-
// console.log('sampling:', sampling)
|
19
|
-
})
|
1
|
+
import { test, expect } from 'bun:test'
|
2
|
+
|
3
|
+
const scenarios = [
|
4
|
+
['url', '/routes', '/'],
|
5
|
+
['sub url', '/routes/sub', '/sub'],
|
6
|
+
['http', 'http://domain.com/routes', '/'],
|
7
|
+
['https', 'https://domain.com/routes', '/'],
|
8
|
+
['https port', 'https://domain.com:3000/routes', '/'],
|
9
|
+
['https port file', 'https://domain.com:3000/routes/file.tsx', '/file'],
|
10
|
+
['https port index', 'https://domain.com:3000/routes/index', '/'],
|
11
|
+
['https port sub file', 'https://domain.com:3000/routes/sub/file.tsx', '/sub/file'],
|
12
|
+
]
|
13
|
+
|
14
|
+
scenarios.forEach(function([ scenario, sampling, expected ]) {
|
15
|
+
test(`new Path(url).href: ${scenario}`, function() {
|
16
|
+
const resulted = new URL(sampling).pathname
|
17
|
+
expect(resulted).toBe(expected as any)
|
18
|
+
// console.log('sampling:', sampling)
|
19
|
+
})
|
20
20
|
})
|
package/vscode/launch.json
CHANGED
@@ -1,9 +1,9 @@
|
|
1
|
-
{
|
2
|
-
"version": "0.2.0",
|
3
|
-
"configurations": [{
|
4
|
-
"type": "bun",
|
5
|
-
"name": "Bun: Debug",
|
6
|
-
"request": "launch",
|
7
|
-
"program": "index.ts"
|
8
|
-
}]
|
1
|
+
{
|
2
|
+
"version": "0.2.0",
|
3
|
+
"configurations": [{
|
4
|
+
"type": "bun",
|
5
|
+
"name": "Bun: Debug",
|
6
|
+
"request": "launch",
|
7
|
+
"program": "index.ts"
|
8
|
+
}]
|
9
9
|
}
|
@@ -1 +0,0 @@
|
|
1
|
-
false
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|
File without changes
|