@pep/term-deck 1.0.10
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/LICENSE +21 -0
- package/README.md +356 -0
- package/bin/term-deck.ts +45 -0
- package/examples/slides/01-welcome.md +9 -0
- package/examples/slides/02-features.md +12 -0
- package/examples/slides/03-colors.md +17 -0
- package/examples/slides/04-ascii-art.md +11 -0
- package/examples/slides/05-gradients.md +14 -0
- package/examples/slides/06-themes.md +13 -0
- package/examples/slides/07-markdown.md +13 -0
- package/examples/slides/08-controls.md +13 -0
- package/examples/slides/09-thanks.md +11 -0
- package/examples/slides/deck.config.ts +13 -0
- package/examples/slides-hacker/01-welcome.md +9 -0
- package/examples/slides-hacker/02-features.md +12 -0
- package/examples/slides-hacker/03-colors.md +17 -0
- package/examples/slides-hacker/04-ascii-art.md +11 -0
- package/examples/slides-hacker/05-gradients.md +14 -0
- package/examples/slides-hacker/06-themes.md +13 -0
- package/examples/slides-hacker/07-markdown.md +13 -0
- package/examples/slides-hacker/08-controls.md +13 -0
- package/examples/slides-hacker/09-thanks.md +11 -0
- package/examples/slides-hacker/deck.config.ts +13 -0
- package/examples/slides-matrix/01-welcome.md +9 -0
- package/examples/slides-matrix/02-features.md +12 -0
- package/examples/slides-matrix/03-colors.md +17 -0
- package/examples/slides-matrix/04-ascii-art.md +11 -0
- package/examples/slides-matrix/05-gradients.md +14 -0
- package/examples/slides-matrix/06-themes.md +13 -0
- package/examples/slides-matrix/07-markdown.md +13 -0
- package/examples/slides-matrix/08-controls.md +13 -0
- package/examples/slides-matrix/09-thanks.md +11 -0
- package/examples/slides-matrix/deck.config.ts +13 -0
- package/examples/slides-minimal/01-welcome.md +9 -0
- package/examples/slides-minimal/02-features.md +12 -0
- package/examples/slides-minimal/03-colors.md +17 -0
- package/examples/slides-minimal/04-ascii-art.md +11 -0
- package/examples/slides-minimal/05-gradients.md +14 -0
- package/examples/slides-minimal/06-themes.md +13 -0
- package/examples/slides-minimal/07-markdown.md +13 -0
- package/examples/slides-minimal/08-controls.md +13 -0
- package/examples/slides-minimal/09-thanks.md +11 -0
- package/examples/slides-minimal/deck.config.ts +13 -0
- package/examples/slides-neon/01-welcome.md +9 -0
- package/examples/slides-neon/02-features.md +12 -0
- package/examples/slides-neon/03-colors.md +17 -0
- package/examples/slides-neon/04-ascii-art.md +11 -0
- package/examples/slides-neon/05-gradients.md +14 -0
- package/examples/slides-neon/06-themes.md +13 -0
- package/examples/slides-neon/07-markdown.md +13 -0
- package/examples/slides-neon/08-controls.md +13 -0
- package/examples/slides-neon/09-thanks.md +11 -0
- package/examples/slides-neon/deck.config.ts +13 -0
- package/examples/slides-retro/01-welcome.md +9 -0
- package/examples/slides-retro/02-features.md +12 -0
- package/examples/slides-retro/03-colors.md +17 -0
- package/examples/slides-retro/04-ascii-art.md +11 -0
- package/examples/slides-retro/05-gradients.md +14 -0
- package/examples/slides-retro/06-themes.md +13 -0
- package/examples/slides-retro/07-markdown.md +13 -0
- package/examples/slides-retro/08-controls.md +13 -0
- package/examples/slides-retro/09-thanks.md +11 -0
- package/examples/slides-retro/deck.config.ts +13 -0
- package/package.json +66 -0
- package/src/cli/__tests__/errors.test.ts +201 -0
- package/src/cli/__tests__/help.test.ts +157 -0
- package/src/cli/__tests__/init.test.ts +110 -0
- package/src/cli/commands/export.ts +33 -0
- package/src/cli/commands/init.ts +125 -0
- package/src/cli/commands/present.ts +29 -0
- package/src/cli/errors.ts +77 -0
- package/src/core/__tests__/slide.test.ts +1759 -0
- package/src/core/__tests__/theme.test.ts +1103 -0
- package/src/core/slide.ts +509 -0
- package/src/core/theme.ts +388 -0
- package/src/export/__tests__/recorder.test.ts +566 -0
- package/src/export/recorder.ts +639 -0
- package/src/index.ts +36 -0
- package/src/presenter/__tests__/main.test.ts +244 -0
- package/src/presenter/main.ts +658 -0
- package/src/renderer/__tests__/screen-extended.test.ts +801 -0
- package/src/renderer/__tests__/screen.test.ts +525 -0
- package/src/renderer/screen.ts +671 -0
- package/src/schemas/__tests__/config.test.ts +429 -0
- package/src/schemas/__tests__/slide.test.ts +349 -0
- package/src/schemas/__tests__/theme.test.ts +970 -0
- package/src/schemas/__tests__/validation.test.ts +256 -0
- package/src/schemas/config.ts +58 -0
- package/src/schemas/slide.ts +56 -0
- package/src/schemas/theme.ts +203 -0
- package/src/schemas/validation.ts +64 -0
- package/src/themes/matrix/index.ts +53 -0
- package/themes/hacker.ts +53 -0
- package/themes/minimal.ts +53 -0
- package/themes/neon.ts +53 -0
- package/themes/retro.ts +53 -0
package/themes/hacker.ts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { createTheme } from '../src/core/theme.js';
|
|
2
|
+
|
|
3
|
+
const yaml = `
|
|
4
|
+
name: hacker
|
|
5
|
+
description: Classic green terminal hacker aesthetic
|
|
6
|
+
author: term-deck
|
|
7
|
+
version: 1.0.0
|
|
8
|
+
|
|
9
|
+
colors:
|
|
10
|
+
primary: "#00ff00"
|
|
11
|
+
accent: "#00cc00"
|
|
12
|
+
background: "#001100"
|
|
13
|
+
text: "#00ff00"
|
|
14
|
+
muted: "#006600"
|
|
15
|
+
|
|
16
|
+
gradients:
|
|
17
|
+
fire:
|
|
18
|
+
- "#00ff00"
|
|
19
|
+
- "#00ee00"
|
|
20
|
+
- "#00dd00"
|
|
21
|
+
cool:
|
|
22
|
+
- "#00ff00"
|
|
23
|
+
- "#00cc00"
|
|
24
|
+
- "#009900"
|
|
25
|
+
pink:
|
|
26
|
+
- "#00ff00"
|
|
27
|
+
- "#00dd00"
|
|
28
|
+
- "#00bb00"
|
|
29
|
+
hf:
|
|
30
|
+
- "#00ff00"
|
|
31
|
+
- "#00cc00"
|
|
32
|
+
- "#008800"
|
|
33
|
+
|
|
34
|
+
glyphs: "01アイウエオカキクケコサシスセソタチツテトナニヌネノハヒフヘホマミムメモヤユヨラリルレロワン"
|
|
35
|
+
|
|
36
|
+
animations:
|
|
37
|
+
revealSpeed: 1.5
|
|
38
|
+
matrixDensity: 70
|
|
39
|
+
glitchIterations: 8
|
|
40
|
+
lineDelay: 15
|
|
41
|
+
matrixInterval: 60
|
|
42
|
+
|
|
43
|
+
window:
|
|
44
|
+
borderStyle: line
|
|
45
|
+
shadow: true
|
|
46
|
+
padding:
|
|
47
|
+
top: 1
|
|
48
|
+
bottom: 1
|
|
49
|
+
left: 2
|
|
50
|
+
right: 2
|
|
51
|
+
`;
|
|
52
|
+
|
|
53
|
+
export default createTheme(yaml);
|
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { createTheme } from '../src/core/theme.js';
|
|
2
|
+
|
|
3
|
+
const yaml = `
|
|
4
|
+
name: minimal
|
|
5
|
+
description: Clean monochrome theme with minimal animations
|
|
6
|
+
author: term-deck
|
|
7
|
+
version: 1.0.0
|
|
8
|
+
|
|
9
|
+
colors:
|
|
10
|
+
primary: "#ffffff"
|
|
11
|
+
accent: "#888888"
|
|
12
|
+
background: "#000000"
|
|
13
|
+
text: "#e0e0e0"
|
|
14
|
+
muted: "#555555"
|
|
15
|
+
|
|
16
|
+
gradients:
|
|
17
|
+
fire:
|
|
18
|
+
- "#ffffff"
|
|
19
|
+
- "#cccccc"
|
|
20
|
+
- "#aaaaaa"
|
|
21
|
+
cool:
|
|
22
|
+
- "#ffffff"
|
|
23
|
+
- "#bbbbbb"
|
|
24
|
+
- "#888888"
|
|
25
|
+
pink:
|
|
26
|
+
- "#e0e0e0"
|
|
27
|
+
- "#c0c0c0"
|
|
28
|
+
- "#a0a0a0"
|
|
29
|
+
hf:
|
|
30
|
+
- "#ffffff"
|
|
31
|
+
- "#d0d0d0"
|
|
32
|
+
- "#999999"
|
|
33
|
+
|
|
34
|
+
glyphs: "│─┌┐└┘├┤┬┴┼═║╔╗╚╝╠╣╦╩╬"
|
|
35
|
+
|
|
36
|
+
animations:
|
|
37
|
+
revealSpeed: 0.5
|
|
38
|
+
matrixDensity: 20
|
|
39
|
+
glitchIterations: 2
|
|
40
|
+
lineDelay: 50
|
|
41
|
+
matrixInterval: 120
|
|
42
|
+
|
|
43
|
+
window:
|
|
44
|
+
borderStyle: line
|
|
45
|
+
shadow: false
|
|
46
|
+
padding:
|
|
47
|
+
top: 1
|
|
48
|
+
bottom: 1
|
|
49
|
+
left: 2
|
|
50
|
+
right: 2
|
|
51
|
+
`;
|
|
52
|
+
|
|
53
|
+
export default createTheme(yaml);
|
package/themes/neon.ts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { createTheme } from '../src/core/theme.js';
|
|
2
|
+
|
|
3
|
+
const yaml = `
|
|
4
|
+
name: neon
|
|
5
|
+
description: Hot pink and electric blue neon cyberpunk theme
|
|
6
|
+
author: term-deck
|
|
7
|
+
version: 1.0.0
|
|
8
|
+
|
|
9
|
+
colors:
|
|
10
|
+
primary: "#ff0099"
|
|
11
|
+
accent: "#00ffff"
|
|
12
|
+
background: "#0a0014"
|
|
13
|
+
text: "#ffffff"
|
|
14
|
+
muted: "#9933ff"
|
|
15
|
+
|
|
16
|
+
gradients:
|
|
17
|
+
fire:
|
|
18
|
+
- "#ff0099"
|
|
19
|
+
- "#ff0066"
|
|
20
|
+
- "#ff3399"
|
|
21
|
+
cool:
|
|
22
|
+
- "#00ffff"
|
|
23
|
+
- "#0099ff"
|
|
24
|
+
- "#6600ff"
|
|
25
|
+
pink:
|
|
26
|
+
- "#ff0099"
|
|
27
|
+
- "#ff33cc"
|
|
28
|
+
- "#ff66ff"
|
|
29
|
+
hf:
|
|
30
|
+
- "#ff0099"
|
|
31
|
+
- "#00ffff"
|
|
32
|
+
- "#9933ff"
|
|
33
|
+
|
|
34
|
+
glyphs: "▓▒░█▀▄▌▐■□▪▫●○◊◘◙♦♣♠♥★☆⌂ⁿ²³ÆØ∞≈≠±×÷"
|
|
35
|
+
|
|
36
|
+
animations:
|
|
37
|
+
revealSpeed: 1.2
|
|
38
|
+
matrixDensity: 60
|
|
39
|
+
glitchIterations: 7
|
|
40
|
+
lineDelay: 25
|
|
41
|
+
matrixInterval: 70
|
|
42
|
+
|
|
43
|
+
window:
|
|
44
|
+
borderStyle: line
|
|
45
|
+
shadow: true
|
|
46
|
+
padding:
|
|
47
|
+
top: 1
|
|
48
|
+
bottom: 1
|
|
49
|
+
left: 2
|
|
50
|
+
right: 2
|
|
51
|
+
`;
|
|
52
|
+
|
|
53
|
+
export default createTheme(yaml);
|
package/themes/retro.ts
ADDED
|
@@ -0,0 +1,53 @@
|
|
|
1
|
+
import { createTheme } from '../src/core/theme.js';
|
|
2
|
+
|
|
3
|
+
const yaml = `
|
|
4
|
+
name: retro
|
|
5
|
+
description: 80s synthwave retro theme with purple and orange
|
|
6
|
+
author: term-deck
|
|
7
|
+
version: 1.0.0
|
|
8
|
+
|
|
9
|
+
colors:
|
|
10
|
+
primary: "#ff6ec7"
|
|
11
|
+
accent: "#ffa600"
|
|
12
|
+
background: "#1a0033"
|
|
13
|
+
text: "#ffd5ff"
|
|
14
|
+
muted: "#7d4e9f"
|
|
15
|
+
|
|
16
|
+
gradients:
|
|
17
|
+
fire:
|
|
18
|
+
- "#ffa600"
|
|
19
|
+
- "#ff6ec7"
|
|
20
|
+
- "#ff0080"
|
|
21
|
+
cool:
|
|
22
|
+
- "#00d4ff"
|
|
23
|
+
- "#7d4e9f"
|
|
24
|
+
- "#ff0080"
|
|
25
|
+
pink:
|
|
26
|
+
- "#ff6ec7"
|
|
27
|
+
- "#ff99dd"
|
|
28
|
+
- "#ffccff"
|
|
29
|
+
hf:
|
|
30
|
+
- "#ffa600"
|
|
31
|
+
- "#ff6ec7"
|
|
32
|
+
- "#00d4ff"
|
|
33
|
+
|
|
34
|
+
glyphs: "▲▼◄►♪♫■□▪▫●○◊★☆⌂∴∵≈≠±×÷αβγδλπσφω"
|
|
35
|
+
|
|
36
|
+
animations:
|
|
37
|
+
revealSpeed: 0.8
|
|
38
|
+
matrixDensity: 40
|
|
39
|
+
glitchIterations: 4
|
|
40
|
+
lineDelay: 40
|
|
41
|
+
matrixInterval: 90
|
|
42
|
+
|
|
43
|
+
window:
|
|
44
|
+
borderStyle: line
|
|
45
|
+
shadow: true
|
|
46
|
+
padding:
|
|
47
|
+
top: 1
|
|
48
|
+
bottom: 1
|
|
49
|
+
left: 2
|
|
50
|
+
right: 2
|
|
51
|
+
`;
|
|
52
|
+
|
|
53
|
+
export default createTheme(yaml);
|