@reactful/create 1.2.1 → 1.2.3

Sign up to get free protection for your applications and to get access to all the features.
Files changed (73) hide show
  1. package/README.md +7 -7
  2. package/commons/package.json +21 -21
  3. package/commons/tsconfig.json +24 -24
  4. package/index.js +148 -148
  5. package/package.json +31 -31
  6. package/templates/minimal/components/hello.tsx +8 -8
  7. package/templates/minimal/components/icon.tsx +11 -0
  8. package/templates/minimal/components/index.ts +2 -1
  9. package/templates/minimal/routes/index.tsx +7 -6
  10. package/templates/sampling/apis/auth/db.ts +14 -14
  11. package/templates/sampling/apis/auth/index.ts +27 -27
  12. package/templates/sampling/apis/hello.ts +2 -2
  13. package/templates/sampling/apis/quotes.ts +15 -15
  14. package/templates/sampling/apis/sub/index.ts +2 -2
  15. package/templates/sampling/apis/sub/sub.ts +2 -2
  16. package/templates/sampling/assets/bootstrap-icons.css +5 -0
  17. package/templates/sampling/assets/default.css +94 -91
  18. package/templates/sampling/assets/fonts/bootstrap-icons.woff +0 -0
  19. package/templates/sampling/assets/fonts/bootstrap-icons.woff2 +0 -0
  20. package/templates/sampling/assets/icon.svg +6 -6
  21. package/templates/sampling/assets/manifest.json +56 -56
  22. package/templates/sampling/assets/markdown.css +273 -273
  23. package/templates/sampling/assets/robots.txt +1 -1
  24. package/templates/sampling/assets/system.css +6 -6
  25. package/templates/sampling/builds/about.html +29 -26
  26. package/templates/sampling/builds/bundle.js +34763 -13116
  27. package/templates/sampling/builds/bundle.ts +20 -25
  28. package/templates/sampling/builds/clock.html +29 -28
  29. package/templates/sampling/builds/counter.html +30 -29
  30. package/templates/sampling/builds/forms/form.html +48 -47
  31. package/templates/sampling/builds/forms/index.html +48 -47
  32. package/templates/sampling/builds/hello.html +61 -59
  33. package/templates/sampling/builds/htmlx.html +26 -23
  34. package/templates/sampling/builds/htmlx.tsx +12 -12
  35. package/templates/sampling/builds/index.html +98 -97
  36. package/templates/sampling/builds/login.html +47 -44
  37. package/templates/sampling/builds/profile/index.html +54 -53
  38. package/templates/sampling/builds/quotes.html +26 -25
  39. package/templates/sampling/builds/shared.js +77 -76
  40. package/templates/sampling/builds/system.html +27 -26
  41. package/templates/sampling/components/header.tsx +6 -6
  42. package/templates/sampling/components/hello.tsx +9 -0
  43. package/templates/sampling/components/icon.tsx +11 -0
  44. package/templates/sampling/components/index.ts +3 -0
  45. package/templates/sampling/index.html +20 -19
  46. package/templates/sampling/index.ts +18 -18
  47. package/templates/sampling/routes/about.html +12 -12
  48. package/templates/sampling/routes/clock.tsx +36 -35
  49. package/templates/sampling/routes/forms/form.tsx +50 -50
  50. package/templates/sampling/routes/hello.tsx +58 -61
  51. package/templates/sampling/routes/htmlx.html +14 -14
  52. package/templates/sampling/routes/index.md +15 -15
  53. package/templates/sampling/routes/login.tsx +35 -35
  54. package/templates/sampling/routes/profile/detail.css +12 -12
  55. package/templates/sampling/routes/profile/detail.tsx +47 -47
  56. package/templates/sampling/routes/profile/index.tsx +13 -13
  57. package/templates/sampling/routes/profile/profile.css +8 -8
  58. package/templates/sampling/routes/profile/tester.tsx +10 -10
  59. package/templates/sampling/routes/system.tsx +1 -0
  60. package/templates/sampling/tests/access.spec.ts +29 -29
  61. package/templates/sampling/tests/counter.spec.ts +18 -18
  62. package/templates/sampling/tests/form.spec.ts +50 -50
  63. package/templates/sampling/tests/hello.spec.ts +24 -24
  64. package/templates/sampling/tests/path.test.ts +19 -19
  65. package/vscode/launch.json +8 -8
  66. package/templates/sampling/builds/client.ts +0 -1
  67. /package/templates/sampling/assets/{logo-144.png → logos/logo-144.png} +0 -0
  68. /package/templates/sampling/assets/{logo-168.png → logos/logo-168.png} +0 -0
  69. /package/templates/sampling/assets/{logo-192.png → logos/logo-192.png} +0 -0
  70. /package/templates/sampling/assets/{logo-48.png → logos/logo-48.png} +0 -0
  71. /package/templates/sampling/assets/{logo-512.png → logos/logo-512.png} +0 -0
  72. /package/templates/sampling/assets/{logo-72.png → logos/logo-72.png} +0 -0
  73. /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
  })
@@ -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