@contractspec/lib.video-gen 1.42.0

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.
Files changed (137) hide show
  1. package/dist/browser/compositions/api-overview.js +645 -0
  2. package/dist/browser/compositions/index.js +1133 -0
  3. package/dist/browser/compositions/primitives/animated-text.js +144 -0
  4. package/dist/browser/compositions/primitives/brand-frame.js +181 -0
  5. package/dist/browser/compositions/primitives/code-block.js +226 -0
  6. package/dist/browser/compositions/primitives/index.js +656 -0
  7. package/dist/browser/compositions/primitives/progress-bar.js +59 -0
  8. package/dist/browser/compositions/primitives/terminal.js +265 -0
  9. package/dist/browser/compositions/primitives/transition.js +98 -0
  10. package/dist/browser/compositions/social-clip.js +500 -0
  11. package/dist/browser/compositions/terminal-demo.js +558 -0
  12. package/dist/browser/design/index.js +155 -0
  13. package/dist/browser/design/layouts.js +50 -0
  14. package/dist/browser/design/motion.js +43 -0
  15. package/dist/browser/design/tokens.js +28 -0
  16. package/dist/browser/design/typography.js +61 -0
  17. package/dist/browser/docs/compositions.docblock.js +182 -0
  18. package/dist/browser/docs/design.docblock.js +187 -0
  19. package/dist/browser/docs/generators.docblock.js +187 -0
  20. package/dist/browser/docs/rendering.docblock.js +197 -0
  21. package/dist/browser/docs/video-gen.docblock.js +141 -0
  22. package/dist/browser/generators/index.js +416 -0
  23. package/dist/browser/generators/scene-planner.js +205 -0
  24. package/dist/browser/generators/script-generator.js +147 -0
  25. package/dist/browser/generators/video-generator.js +414 -0
  26. package/dist/browser/index.js +1550 -0
  27. package/dist/browser/player/demo-player.js +1136 -0
  28. package/dist/browser/player/index.js +1136 -0
  29. package/dist/browser/remotion/Root.js +1189 -0
  30. package/dist/browser/remotion/index.js +1190 -0
  31. package/dist/browser/renderers/config.js +40 -0
  32. package/dist/browser/renderers/index.js +160 -0
  33. package/dist/browser/renderers/local.js +156 -0
  34. package/dist/browser/types.js +13 -0
  35. package/dist/compositions/api-overview.d.ts +16 -0
  36. package/dist/compositions/api-overview.js +640 -0
  37. package/dist/compositions/index.d.ts +7 -0
  38. package/dist/compositions/index.js +1128 -0
  39. package/dist/compositions/primitives/animated-text.d.ts +22 -0
  40. package/dist/compositions/primitives/animated-text.js +139 -0
  41. package/dist/compositions/primitives/brand-frame.d.ts +14 -0
  42. package/dist/compositions/primitives/brand-frame.js +176 -0
  43. package/dist/compositions/primitives/code-block.d.ts +18 -0
  44. package/dist/compositions/primitives/code-block.js +221 -0
  45. package/dist/compositions/primitives/index.d.ts +12 -0
  46. package/dist/compositions/primitives/index.js +651 -0
  47. package/dist/compositions/primitives/progress-bar.d.ts +12 -0
  48. package/dist/compositions/primitives/progress-bar.js +54 -0
  49. package/dist/compositions/primitives/terminal.d.ts +24 -0
  50. package/dist/compositions/primitives/terminal.js +260 -0
  51. package/dist/compositions/primitives/transition.d.ts +14 -0
  52. package/dist/compositions/primitives/transition.js +93 -0
  53. package/dist/compositions/social-clip.d.ts +16 -0
  54. package/dist/compositions/social-clip.js +495 -0
  55. package/dist/compositions/terminal-demo.d.ts +17 -0
  56. package/dist/compositions/terminal-demo.js +553 -0
  57. package/dist/design/index.d.ts +4 -0
  58. package/dist/design/index.js +150 -0
  59. package/dist/design/layouts.d.ts +69 -0
  60. package/dist/design/layouts.js +45 -0
  61. package/dist/design/motion.d.ts +72 -0
  62. package/dist/design/motion.js +38 -0
  63. package/dist/design/tokens.d.ts +31 -0
  64. package/dist/design/tokens.js +23 -0
  65. package/dist/design/typography.d.ts +61 -0
  66. package/dist/design/typography.js +56 -0
  67. package/dist/docs/compositions.docblock.d.ts +1 -0
  68. package/dist/docs/compositions.docblock.js +183 -0
  69. package/dist/docs/design.docblock.d.ts +1 -0
  70. package/dist/docs/design.docblock.js +188 -0
  71. package/dist/docs/generators.docblock.d.ts +1 -0
  72. package/dist/docs/generators.docblock.js +188 -0
  73. package/dist/docs/rendering.docblock.d.ts +1 -0
  74. package/dist/docs/rendering.docblock.js +198 -0
  75. package/dist/docs/video-gen.docblock.d.ts +1 -0
  76. package/dist/docs/video-gen.docblock.js +142 -0
  77. package/dist/generators/index.d.ts +5 -0
  78. package/dist/generators/index.js +411 -0
  79. package/dist/generators/scene-planner.d.ts +23 -0
  80. package/dist/generators/scene-planner.js +200 -0
  81. package/dist/generators/script-generator.d.ts +49 -0
  82. package/dist/generators/script-generator.js +142 -0
  83. package/dist/generators/video-generator.d.ts +20 -0
  84. package/dist/generators/video-generator.js +409 -0
  85. package/dist/index.d.ts +6 -0
  86. package/dist/index.js +1545 -0
  87. package/dist/node/compositions/api-overview.js +640 -0
  88. package/dist/node/compositions/index.js +1128 -0
  89. package/dist/node/compositions/primitives/animated-text.js +139 -0
  90. package/dist/node/compositions/primitives/brand-frame.js +176 -0
  91. package/dist/node/compositions/primitives/code-block.js +221 -0
  92. package/dist/node/compositions/primitives/index.js +651 -0
  93. package/dist/node/compositions/primitives/progress-bar.js +54 -0
  94. package/dist/node/compositions/primitives/terminal.js +260 -0
  95. package/dist/node/compositions/primitives/transition.js +93 -0
  96. package/dist/node/compositions/social-clip.js +495 -0
  97. package/dist/node/compositions/terminal-demo.js +553 -0
  98. package/dist/node/design/index.js +150 -0
  99. package/dist/node/design/layouts.js +45 -0
  100. package/dist/node/design/motion.js +38 -0
  101. package/dist/node/design/tokens.js +23 -0
  102. package/dist/node/design/typography.js +56 -0
  103. package/dist/node/docs/compositions.docblock.js +182 -0
  104. package/dist/node/docs/design.docblock.js +187 -0
  105. package/dist/node/docs/generators.docblock.js +187 -0
  106. package/dist/node/docs/rendering.docblock.js +197 -0
  107. package/dist/node/docs/video-gen.docblock.js +141 -0
  108. package/dist/node/generators/index.js +411 -0
  109. package/dist/node/generators/scene-planner.js +200 -0
  110. package/dist/node/generators/script-generator.js +142 -0
  111. package/dist/node/generators/video-generator.js +409 -0
  112. package/dist/node/index.js +1545 -0
  113. package/dist/node/player/demo-player.js +1131 -0
  114. package/dist/node/player/index.js +1131 -0
  115. package/dist/node/remotion/Root.js +1184 -0
  116. package/dist/node/remotion/index.js +1185 -0
  117. package/dist/node/renderers/config.js +35 -0
  118. package/dist/node/renderers/index.js +155 -0
  119. package/dist/node/renderers/local.js +151 -0
  120. package/dist/node/types.js +8 -0
  121. package/dist/player/demo-player.d.ts +55 -0
  122. package/dist/player/demo-player.js +1131 -0
  123. package/dist/player/index.d.ts +2 -0
  124. package/dist/player/index.js +1131 -0
  125. package/dist/remotion/Root.d.ts +2 -0
  126. package/dist/remotion/Root.js +1184 -0
  127. package/dist/remotion/index.d.ts +1 -0
  128. package/dist/remotion/index.js +1185 -0
  129. package/dist/renderers/config.d.ts +28 -0
  130. package/dist/renderers/config.js +35 -0
  131. package/dist/renderers/index.d.ts +3 -0
  132. package/dist/renderers/index.js +155 -0
  133. package/dist/renderers/local.d.ts +17 -0
  134. package/dist/renderers/local.js +151 -0
  135. package/dist/types.d.ts +63 -0
  136. package/dist/types.js +8 -0
  137. package/package.json +637 -0
@@ -0,0 +1,144 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined")
5
+ return require.apply(this, arguments);
6
+ throw Error('Dynamic require of "' + x + '" is not supported');
7
+ });
8
+
9
+ // src/design/motion.ts
10
+ import { Easing } from "remotion";
11
+ var videoEasing = {
12
+ entrance: Easing.out(Easing.exp),
13
+ exit: Easing.in(Easing.exp),
14
+ emphasis: Easing.out(Easing.back(1.4)),
15
+ linear: Easing.linear,
16
+ gentle: Easing.bezier(0.25, 0.1, 0.25, 1),
17
+ spring: Easing.out(Easing.back(1.7))
18
+ };
19
+ var videoDurations = {
20
+ sceneTransition: 20,
21
+ textEntrance: 15,
22
+ textExit: 12,
23
+ codeTypingPerChar: 2,
24
+ sectionPause: 30,
25
+ emphasisPause: 15,
26
+ brandReveal: 25,
27
+ minScene: 60,
28
+ shortScene: 60,
29
+ mediumScene: 120,
30
+ longScene: 240
31
+ };
32
+ var videoTransitions = {
33
+ fade: { type: "fade", durationInFrames: 20 },
34
+ slideLeft: { type: "slide-left", durationInFrames: 20 },
35
+ slideRight: { type: "slide-right", durationInFrames: 20 },
36
+ wipe: { type: "wipe", durationInFrames: 15 },
37
+ none: { type: "none", durationInFrames: 0 }
38
+ };
39
+
40
+ // src/design/typography.ts
41
+ var videoTypography = {
42
+ title: {
43
+ fontSize: 72,
44
+ lineHeight: 1.1,
45
+ fontWeight: 700,
46
+ letterSpacing: -1
47
+ },
48
+ heading: {
49
+ fontSize: 56,
50
+ lineHeight: 1.2,
51
+ fontWeight: 600,
52
+ letterSpacing: -0.5
53
+ },
54
+ subheading: {
55
+ fontSize: 40,
56
+ lineHeight: 1.25,
57
+ fontWeight: 500
58
+ },
59
+ body: {
60
+ fontSize: 32,
61
+ lineHeight: 1.5,
62
+ fontWeight: 400
63
+ },
64
+ code: {
65
+ fontSize: 28,
66
+ lineHeight: 1.6,
67
+ fontWeight: 400
68
+ },
69
+ caption: {
70
+ fontSize: 24,
71
+ lineHeight: 1.4,
72
+ fontWeight: 400
73
+ },
74
+ label: {
75
+ fontSize: 20,
76
+ lineHeight: 1.3,
77
+ fontWeight: 600,
78
+ letterSpacing: 1
79
+ }
80
+ };
81
+ function scaleTypography(style, targetWidth) {
82
+ const scale = targetWidth / 1920;
83
+ return {
84
+ ...style,
85
+ fontSize: Math.round(style.fontSize * scale),
86
+ letterSpacing: style.letterSpacing ? Math.round(style.letterSpacing * scale * 10) / 10 : undefined
87
+ };
88
+ }
89
+
90
+ // src/compositions/primitives/animated-text.tsx
91
+ import { interpolate, useCurrentFrame, useVideoConfig } from "remotion";
92
+ import { jsxDEV } from "react/jsx-dev-runtime";
93
+ var AnimatedText = ({
94
+ text,
95
+ variant = "body",
96
+ style: styleOverride,
97
+ enterAt = 0,
98
+ exitAt,
99
+ color = "#ffffff",
100
+ align = "left"
101
+ }) => {
102
+ const frame = useCurrentFrame();
103
+ const { width } = useVideoConfig();
104
+ const baseStyle = videoTypography[variant];
105
+ const scaled = scaleTypography(baseStyle, width);
106
+ const finalStyle = { ...scaled, ...styleOverride };
107
+ const enterProgress = interpolate(frame, [enterAt, enterAt + videoDurations.textEntrance], [0, 1], { extrapolateLeft: "clamp", extrapolateRight: "clamp" });
108
+ const enterOpacity = interpolate(enterProgress, [0, 1], [0, 1], {
109
+ easing: videoEasing.entrance
110
+ });
111
+ const enterTranslateY = interpolate(enterProgress, [0, 1], [30, 0], {
112
+ easing: videoEasing.entrance
113
+ });
114
+ let exitOpacity = 1;
115
+ let exitTranslateY = 0;
116
+ if (exitAt !== undefined) {
117
+ const exitProgress = interpolate(frame, [exitAt, exitAt + videoDurations.textExit], [0, 1], { extrapolateLeft: "clamp", extrapolateRight: "clamp" });
118
+ exitOpacity = interpolate(exitProgress, [0, 1], [1, 0], {
119
+ easing: videoEasing.exit
120
+ });
121
+ exitTranslateY = interpolate(exitProgress, [0, 1], [0, -20], {
122
+ easing: videoEasing.exit
123
+ });
124
+ }
125
+ const opacity = enterOpacity * exitOpacity;
126
+ const translateY = enterTranslateY + exitTranslateY;
127
+ return /* @__PURE__ */ jsxDEV("div", {
128
+ style: {
129
+ fontSize: finalStyle.fontSize,
130
+ lineHeight: finalStyle.lineHeight,
131
+ fontWeight: finalStyle.fontWeight,
132
+ letterSpacing: finalStyle.letterSpacing,
133
+ color,
134
+ textAlign: align,
135
+ opacity,
136
+ transform: `translateY(${translateY}px)`,
137
+ willChange: "opacity, transform"
138
+ },
139
+ children: text
140
+ }, undefined, false, undefined, this);
141
+ };
142
+ export {
143
+ AnimatedText
144
+ };
@@ -0,0 +1,181 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined")
5
+ return require.apply(this, arguments);
6
+ throw Error('Dynamic require of "' + x + '" is not supported');
7
+ });
8
+
9
+ // src/design/motion.ts
10
+ import { Easing } from "remotion";
11
+ var videoEasing = {
12
+ entrance: Easing.out(Easing.exp),
13
+ exit: Easing.in(Easing.exp),
14
+ emphasis: Easing.out(Easing.back(1.4)),
15
+ linear: Easing.linear,
16
+ gentle: Easing.bezier(0.25, 0.1, 0.25, 1),
17
+ spring: Easing.out(Easing.back(1.7))
18
+ };
19
+ var videoDurations = {
20
+ sceneTransition: 20,
21
+ textEntrance: 15,
22
+ textExit: 12,
23
+ codeTypingPerChar: 2,
24
+ sectionPause: 30,
25
+ emphasisPause: 15,
26
+ brandReveal: 25,
27
+ minScene: 60,
28
+ shortScene: 60,
29
+ mediumScene: 120,
30
+ longScene: 240
31
+ };
32
+ var videoTransitions = {
33
+ fade: { type: "fade", durationInFrames: 20 },
34
+ slideLeft: { type: "slide-left", durationInFrames: 20 },
35
+ slideRight: { type: "slide-right", durationInFrames: 20 },
36
+ wipe: { type: "wipe", durationInFrames: 15 },
37
+ none: { type: "none", durationInFrames: 0 }
38
+ };
39
+
40
+ // src/design/tokens.ts
41
+ import { defaultTokens } from "@contractspec/lib.design-system";
42
+ var defaultVideoColors = {
43
+ canvasBackground: defaultTokens.colors.background,
44
+ codeBackground: "#1e1e2e",
45
+ terminalBackground: "#0d1117",
46
+ terminalForeground: "#c9d1d9",
47
+ highlight: defaultTokens.colors.accent,
48
+ gradientStart: defaultTokens.colors.primary,
49
+ gradientEnd: defaultTokens.colors.accent
50
+ };
51
+ var defaultVideoTheme = {
52
+ ...defaultTokens,
53
+ video: defaultVideoColors
54
+ };
55
+
56
+ // src/design/layouts.ts
57
+ import { VIDEO_FORMATS } from "@contractspec/lib.contracts-integrations/integrations/providers/video";
58
+ var DEFAULT_FPS = 30;
59
+ var videoSafeZone = {
60
+ horizontal: 120,
61
+ vertical: 80,
62
+ contentWidth: 1680,
63
+ contentHeight: 920
64
+ };
65
+ function scaleSafeZone(format) {
66
+ const scaleX = format.width / 1920;
67
+ const scaleY = format.height / 1080;
68
+ return {
69
+ horizontal: Math.round(videoSafeZone.horizontal * scaleX),
70
+ vertical: Math.round(videoSafeZone.vertical * scaleY),
71
+ contentWidth: Math.round(videoSafeZone.contentWidth * scaleX),
72
+ contentHeight: Math.round(videoSafeZone.contentHeight * scaleY)
73
+ };
74
+ }
75
+ var videoPositions = {
76
+ center: { x: 960, y: 540 },
77
+ topLeft: { x: 120, y: 80 },
78
+ topRight: { x: 1800, y: 80 },
79
+ bottomLeft: { x: 120, y: 1000 },
80
+ bottomRight: { x: 1800, y: 1000 },
81
+ bottomCenter: { x: 960, y: 960 }
82
+ };
83
+ function getAllFormatVariants() {
84
+ return [
85
+ VIDEO_FORMATS.landscape,
86
+ VIDEO_FORMATS.square,
87
+ VIDEO_FORMATS.portrait
88
+ ];
89
+ }
90
+
91
+ // src/compositions/primitives/brand-frame.tsx
92
+ import { interpolate, useCurrentFrame, useVideoConfig } from "remotion";
93
+ import { jsxDEV } from "react/jsx-dev-runtime";
94
+ var BrandFrame = ({
95
+ styleOverrides,
96
+ showBranding = true,
97
+ animateEntrance = true,
98
+ variant = "gradient",
99
+ children
100
+ }) => {
101
+ const frame = useCurrentFrame();
102
+ const { width, height } = useVideoConfig();
103
+ const theme = defaultVideoTheme;
104
+ const safeZone = scaleSafeZone({ type: "custom", width, height });
105
+ const primaryColor = styleOverrides?.primaryColor ?? theme.colors.primary;
106
+ const _accentColor = styleOverrides?.accentColor ?? theme.colors.accent;
107
+ const isDark = styleOverrides?.darkMode ?? true;
108
+ let background;
109
+ switch (variant) {
110
+ case "solid":
111
+ background = isDark ? "#0a0a0a" : theme.colors.background;
112
+ break;
113
+ case "gradient":
114
+ background = isDark ? `linear-gradient(135deg, #0a0a14 0%, #0f172a 50%, #0a0a14 100%)` : `linear-gradient(135deg, ${theme.colors.background} 0%, ${theme.colors.muted} 100%)`;
115
+ break;
116
+ case "dark":
117
+ background = "#000000";
118
+ break;
119
+ }
120
+ const entranceOpacity = animateEntrance ? interpolate(frame, [0, 15], [0, 1], {
121
+ extrapolateLeft: "clamp",
122
+ extrapolateRight: "clamp",
123
+ easing: videoEasing.entrance
124
+ }) : 1;
125
+ const brandOpacity = showBranding ? interpolate(frame, [videoDurations.brandReveal, videoDurations.brandReveal + 15], [0, 0.3], {
126
+ extrapolateLeft: "clamp",
127
+ extrapolateRight: "clamp"
128
+ }) : 0;
129
+ return /* @__PURE__ */ jsxDEV("div", {
130
+ style: {
131
+ width,
132
+ height,
133
+ background,
134
+ position: "relative",
135
+ overflow: "hidden",
136
+ opacity: entranceOpacity
137
+ },
138
+ children: [
139
+ variant === "gradient" && /* @__PURE__ */ jsxDEV("div", {
140
+ style: {
141
+ position: "absolute",
142
+ top: "-20%",
143
+ right: "-10%",
144
+ width: "50%",
145
+ height: "50%",
146
+ background: `radial-gradient(circle, ${primaryColor}15 0%, transparent 70%)`,
147
+ borderRadius: "50%",
148
+ pointerEvents: "none"
149
+ }
150
+ }, undefined, false, undefined, this),
151
+ /* @__PURE__ */ jsxDEV("div", {
152
+ style: {
153
+ position: "absolute",
154
+ left: safeZone.horizontal,
155
+ top: safeZone.vertical,
156
+ width: safeZone.contentWidth,
157
+ height: safeZone.contentHeight,
158
+ display: "flex",
159
+ flexDirection: "column"
160
+ },
161
+ children
162
+ }, undefined, false, undefined, this),
163
+ showBranding && /* @__PURE__ */ jsxDEV("div", {
164
+ style: {
165
+ position: "absolute",
166
+ bottom: safeZone.vertical / 2,
167
+ right: safeZone.horizontal,
168
+ opacity: brandOpacity,
169
+ color: isDark ? "#ffffff" : "#000000",
170
+ fontSize: Math.round(16 * (width / 1920)),
171
+ fontWeight: 500,
172
+ letterSpacing: 1
173
+ },
174
+ children: "ContractSpec"
175
+ }, undefined, false, undefined, this)
176
+ ]
177
+ }, undefined, true, undefined, this);
178
+ };
179
+ export {
180
+ BrandFrame
181
+ };
@@ -0,0 +1,226 @@
1
+ var __require = /* @__PURE__ */ ((x) => typeof require !== "undefined" ? require : typeof Proxy !== "undefined" ? new Proxy(x, {
2
+ get: (a, b) => (typeof require !== "undefined" ? require : a)[b]
3
+ }) : x)(function(x) {
4
+ if (typeof require !== "undefined")
5
+ return require.apply(this, arguments);
6
+ throw Error('Dynamic require of "' + x + '" is not supported');
7
+ });
8
+
9
+ // src/design/motion.ts
10
+ import { Easing } from "remotion";
11
+ var videoEasing = {
12
+ entrance: Easing.out(Easing.exp),
13
+ exit: Easing.in(Easing.exp),
14
+ emphasis: Easing.out(Easing.back(1.4)),
15
+ linear: Easing.linear,
16
+ gentle: Easing.bezier(0.25, 0.1, 0.25, 1),
17
+ spring: Easing.out(Easing.back(1.7))
18
+ };
19
+ var videoDurations = {
20
+ sceneTransition: 20,
21
+ textEntrance: 15,
22
+ textExit: 12,
23
+ codeTypingPerChar: 2,
24
+ sectionPause: 30,
25
+ emphasisPause: 15,
26
+ brandReveal: 25,
27
+ minScene: 60,
28
+ shortScene: 60,
29
+ mediumScene: 120,
30
+ longScene: 240
31
+ };
32
+ var videoTransitions = {
33
+ fade: { type: "fade", durationInFrames: 20 },
34
+ slideLeft: { type: "slide-left", durationInFrames: 20 },
35
+ slideRight: { type: "slide-right", durationInFrames: 20 },
36
+ wipe: { type: "wipe", durationInFrames: 15 },
37
+ none: { type: "none", durationInFrames: 0 }
38
+ };
39
+
40
+ // src/design/tokens.ts
41
+ import { defaultTokens } from "@contractspec/lib.design-system";
42
+ var defaultVideoColors = {
43
+ canvasBackground: defaultTokens.colors.background,
44
+ codeBackground: "#1e1e2e",
45
+ terminalBackground: "#0d1117",
46
+ terminalForeground: "#c9d1d9",
47
+ highlight: defaultTokens.colors.accent,
48
+ gradientStart: defaultTokens.colors.primary,
49
+ gradientEnd: defaultTokens.colors.accent
50
+ };
51
+ var defaultVideoTheme = {
52
+ ...defaultTokens,
53
+ video: defaultVideoColors
54
+ };
55
+
56
+ // src/design/typography.ts
57
+ var videoTypography = {
58
+ title: {
59
+ fontSize: 72,
60
+ lineHeight: 1.1,
61
+ fontWeight: 700,
62
+ letterSpacing: -1
63
+ },
64
+ heading: {
65
+ fontSize: 56,
66
+ lineHeight: 1.2,
67
+ fontWeight: 600,
68
+ letterSpacing: -0.5
69
+ },
70
+ subheading: {
71
+ fontSize: 40,
72
+ lineHeight: 1.25,
73
+ fontWeight: 500
74
+ },
75
+ body: {
76
+ fontSize: 32,
77
+ lineHeight: 1.5,
78
+ fontWeight: 400
79
+ },
80
+ code: {
81
+ fontSize: 28,
82
+ lineHeight: 1.6,
83
+ fontWeight: 400
84
+ },
85
+ caption: {
86
+ fontSize: 24,
87
+ lineHeight: 1.4,
88
+ fontWeight: 400
89
+ },
90
+ label: {
91
+ fontSize: 20,
92
+ lineHeight: 1.3,
93
+ fontWeight: 600,
94
+ letterSpacing: 1
95
+ }
96
+ };
97
+ function scaleTypography(style, targetWidth) {
98
+ const scale = targetWidth / 1920;
99
+ return {
100
+ ...style,
101
+ fontSize: Math.round(style.fontSize * scale),
102
+ letterSpacing: style.letterSpacing ? Math.round(style.letterSpacing * scale * 10) / 10 : undefined
103
+ };
104
+ }
105
+
106
+ // src/compositions/primitives/code-block.tsx
107
+ import { interpolate, useCurrentFrame, useVideoConfig } from "remotion";
108
+ import { jsxDEV } from "react/jsx-dev-runtime";
109
+ var CodeBlock = ({
110
+ code,
111
+ language = "typescript",
112
+ startAt = 0,
113
+ typeAnimation = true,
114
+ backgroundColor = defaultVideoColors.codeBackground,
115
+ textColor = "#abb2bf",
116
+ filename
117
+ }) => {
118
+ const frame = useCurrentFrame();
119
+ const { width } = useVideoConfig();
120
+ const codeStyle = scaleTypography(videoTypography.code, width);
121
+ const totalChars = code.length;
122
+ const typingDuration = totalChars * videoDurations.codeTypingPerChar;
123
+ const charsVisible = typeAnimation ? Math.floor(interpolate(frame, [startAt, startAt + typingDuration], [0, totalChars], {
124
+ extrapolateLeft: "clamp",
125
+ extrapolateRight: "clamp"
126
+ })) : totalChars;
127
+ const visibleCode = code.slice(0, charsVisible);
128
+ const opacity = interpolate(frame, [startAt, startAt + 10], [0, 1], {
129
+ extrapolateLeft: "clamp",
130
+ extrapolateRight: "clamp",
131
+ easing: videoEasing.entrance
132
+ });
133
+ const showCursor = typeAnimation && charsVisible < totalChars && frame % 16 < 10;
134
+ return /* @__PURE__ */ jsxDEV("div", {
135
+ style: {
136
+ backgroundColor,
137
+ borderRadius: 16,
138
+ padding: 0,
139
+ opacity,
140
+ overflow: "hidden",
141
+ boxShadow: "0 8px 32px rgba(0,0,0,0.3)"
142
+ },
143
+ children: [
144
+ /* @__PURE__ */ jsxDEV("div", {
145
+ style: {
146
+ display: "flex",
147
+ alignItems: "center",
148
+ padding: "12px 20px",
149
+ backgroundColor: "rgba(0,0,0,0.2)",
150
+ gap: 8
151
+ },
152
+ children: [
153
+ /* @__PURE__ */ jsxDEV("div", {
154
+ style: { display: "flex", gap: 8 },
155
+ children: [
156
+ /* @__PURE__ */ jsxDEV("div", {
157
+ style: {
158
+ width: 12,
159
+ height: 12,
160
+ borderRadius: "50%",
161
+ backgroundColor: "#ff5f57"
162
+ }
163
+ }, undefined, false, undefined, this),
164
+ /* @__PURE__ */ jsxDEV("div", {
165
+ style: {
166
+ width: 12,
167
+ height: 12,
168
+ borderRadius: "50%",
169
+ backgroundColor: "#febc2e"
170
+ }
171
+ }, undefined, false, undefined, this),
172
+ /* @__PURE__ */ jsxDEV("div", {
173
+ style: {
174
+ width: 12,
175
+ height: 12,
176
+ borderRadius: "50%",
177
+ backgroundColor: "#28c840"
178
+ }
179
+ }, undefined, false, undefined, this)
180
+ ]
181
+ }, undefined, true, undefined, this),
182
+ /* @__PURE__ */ jsxDEV("div", {
183
+ style: {
184
+ flex: 1,
185
+ textAlign: "center",
186
+ color: "#666",
187
+ fontSize: codeStyle.fontSize * 0.7,
188
+ fontFamily: "monospace"
189
+ },
190
+ children: filename ?? language
191
+ }, undefined, false, undefined, this)
192
+ ]
193
+ }, undefined, true, undefined, this),
194
+ /* @__PURE__ */ jsxDEV("div", {
195
+ style: { padding: "24px 32px" },
196
+ children: /* @__PURE__ */ jsxDEV("pre", {
197
+ style: {
198
+ margin: 0,
199
+ fontFamily: "'SF Mono', 'Fira Code', 'JetBrains Mono', monospace",
200
+ fontSize: codeStyle.fontSize,
201
+ lineHeight: codeStyle.lineHeight,
202
+ color: textColor,
203
+ whiteSpace: "pre-wrap",
204
+ wordBreak: "break-word"
205
+ },
206
+ children: [
207
+ visibleCode,
208
+ showCursor && /* @__PURE__ */ jsxDEV("span", {
209
+ style: {
210
+ backgroundColor: textColor,
211
+ width: "2px",
212
+ display: "inline-block",
213
+ height: "1.2em",
214
+ verticalAlign: "text-bottom"
215
+ },
216
+ children: " "
217
+ }, undefined, false, undefined, this)
218
+ ]
219
+ }, undefined, true, undefined, this)
220
+ }, undefined, false, undefined, this)
221
+ ]
222
+ }, undefined, true, undefined, this);
223
+ };
224
+ export {
225
+ CodeBlock
226
+ };