mirror of
https://github.com/affaan-m/everything-claude-code.git
synced 2026-04-10 17:59:43 +08:00
* fix(ci): resolve cross-platform test failures - Sanity check script (check-codex-global-state.sh) now falls back to grep -E when ripgrep is not available, fixing the codex-hooks sync test on all CI platforms. Patterns converted to POSIX ERE for portability. - Unicode safety test accepts both / and \ path separators so the executable-file assertion passes on Windows. - Gacha test sets PYTHONUTF8=1 so Python uses UTF-8 stdout encoding on Windows instead of cp1252, preventing UnicodeEncodeError on box-drawing characters. - Quoted-hook-path test skipped on Windows where NTFS disallows double-quote characters in filenames. * feat: port remotion-video-creation skill (29 rules), restore missing files New skill: - remotion-video-creation: 29 domain-specific Remotion rules covering 3D/Three.js, animations, audio, captions, charts, compositions, fonts, GIFs, Lottie, measuring, sequencing, tailwind, text animations, timing, transitions, trimming, and video embedding. Ported from personal skills. Restored: - autonomous-agent-harness/SKILL.md (was in commit but missing from worktree) - lead-intelligence/ (full directory restored from branch commit) Updated: - manifests/install-modules.json: added remotion-video-creation to media-generation - README.md + AGENTS.md: synced counts to 139 skills Catalog validates: 30 agents, 60 commands, 139 skills. * fix(security): pin MCP server versions, add dependabot, pin github-script SHA Critical: - Pin all npx -y MCP server packages to specific versions in .mcp.json to prevent supply chain attacks via version hijacking: - @modelcontextprotocol/server-github@2025.4.8 - @modelcontextprotocol/server-memory@2026.1.26 - @modelcontextprotocol/server-sequential-thinking@2025.12.18 - @playwright/mcp@0.0.69 (was 0.0.68) Medium: - Add .github/dependabot.yml for weekly npm + github-actions updates with grouped minor/patch PRs - Pin actions/github-script to SHA (was @v7 tag, now pinned to commit) * feat: add social-graph-ranker skill — weighted network proximity scoring New skill: social-graph-ranker - Weighted social graph traversal with exponential decay across hops - Bridge Score: B(m) = Σ w(t) · λ^(d(m,t)-1) ranks mutuals by target proximity - Extended Score incorporates 2nd-order network (mutual-of-mutual connections) - Final ranking includes engagement bonus for responsive connections - Runs in parallel with lead-intelligence skill for combined warm+cold outreach - Supports X API + LinkedIn CSV for graph harvesting - Outputs tiered action list: warm intros, direct outreach, network gap analysis Added to business-content install module. Catalog validates: 30/60/140. * fix(security): npm audit fix — resolve all dependency vulnerabilities Applied npm audit fix --force to resolve: - minimatch ReDoS (3 vulnerabilities, HIGH) - smol-toml DoS (MODERATE) - brace-expansion memory exhaustion (MODERATE) - markdownlint-cli upgraded from 0.47.0 to 0.48.0 npm audit now reports 0 vulnerabilities. * fix: resolve markdown lint and yarn lockfile sync - MD047: ensure single trailing newline on all remotion rule files - MD012: remove consecutive blank lines in lottie, measuring-dom-nodes, trimming - MD034: wrap bare URLs in angle brackets (tailwind, transcribe-captions) - yarn.lock: regenerated to sync with npm audit changes in package.json * fix: replace unicode arrows in lead-intelligence (CI unicode safety check)
174 lines
3.3 KiB
TypeScript
174 lines
3.3 KiB
TypeScript
import {loadFont} from '@remotion/google-fonts/Inter';
|
|
import {AbsoluteFill, spring, useCurrentFrame, useVideoConfig} from 'remotion';
|
|
|
|
const {fontFamily} = loadFont();
|
|
|
|
const COLOR_BAR = '#D4AF37';
|
|
const COLOR_TEXT = '#ffffff';
|
|
const COLOR_MUTED = '#888888';
|
|
const COLOR_BG = '#0a0a0a';
|
|
const COLOR_AXIS = '#333333';
|
|
|
|
// Ideal composition size: 1280x720
|
|
|
|
const Title: React.FC<{children: React.ReactNode}> = ({children}) => (
|
|
<div style={{textAlign: 'center', marginBottom: 40}}>
|
|
<div style={{color: COLOR_TEXT, fontSize: 48, fontWeight: 600}}>
|
|
{children}
|
|
</div>
|
|
</div>
|
|
);
|
|
|
|
const YAxis: React.FC<{steps: number[]; height: number}> = ({
|
|
steps,
|
|
height,
|
|
}) => (
|
|
<div
|
|
style={{
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
justifyContent: 'space-between',
|
|
height,
|
|
paddingRight: 16,
|
|
}}
|
|
>
|
|
{steps
|
|
.slice()
|
|
.reverse()
|
|
.map((step) => (
|
|
<div
|
|
key={step}
|
|
style={{
|
|
color: COLOR_MUTED,
|
|
fontSize: 20,
|
|
textAlign: 'right',
|
|
}}
|
|
>
|
|
{step.toLocaleString()}
|
|
</div>
|
|
))}
|
|
</div>
|
|
);
|
|
|
|
const Bar: React.FC<{
|
|
height: number;
|
|
progress: number;
|
|
}> = ({height, progress}) => (
|
|
<div
|
|
style={{
|
|
flex: 1,
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
justifyContent: 'flex-end',
|
|
}}
|
|
>
|
|
<div
|
|
style={{
|
|
width: '100%',
|
|
height,
|
|
backgroundColor: COLOR_BAR,
|
|
borderRadius: '8px 8px 0 0',
|
|
opacity: progress,
|
|
}}
|
|
/>
|
|
</div>
|
|
);
|
|
|
|
const XAxis: React.FC<{
|
|
children: React.ReactNode;
|
|
labels: string[];
|
|
height: number;
|
|
}> = ({children, labels, height}) => (
|
|
<div style={{flex: 1, display: 'flex', flexDirection: 'column'}}>
|
|
<div
|
|
style={{
|
|
display: 'flex',
|
|
alignItems: 'flex-end',
|
|
gap: 16,
|
|
height,
|
|
borderLeft: `2px solid ${COLOR_AXIS}`,
|
|
borderBottom: `2px solid ${COLOR_AXIS}`,
|
|
paddingLeft: 16,
|
|
}}
|
|
>
|
|
{children}
|
|
</div>
|
|
<div
|
|
style={{
|
|
display: 'flex',
|
|
gap: 16,
|
|
paddingLeft: 16,
|
|
marginTop: 12,
|
|
}}
|
|
>
|
|
{labels.map((label) => (
|
|
<div
|
|
key={label}
|
|
style={{
|
|
flex: 1,
|
|
textAlign: 'center',
|
|
color: COLOR_MUTED,
|
|
fontSize: 20,
|
|
}}
|
|
>
|
|
{label}
|
|
</div>
|
|
))}
|
|
</div>
|
|
</div>
|
|
);
|
|
|
|
export const MyAnimation = () => {
|
|
const frame = useCurrentFrame();
|
|
const {fps, height} = useVideoConfig();
|
|
|
|
const data = [
|
|
{month: 'Jan', price: 2039},
|
|
{month: 'Mar', price: 2160},
|
|
{month: 'May', price: 2327},
|
|
{month: 'Jul', price: 2426},
|
|
{month: 'Sep', price: 2634},
|
|
{month: 'Nov', price: 2672},
|
|
];
|
|
|
|
const minPrice = 2000;
|
|
const maxPrice = 2800;
|
|
const priceRange = maxPrice - minPrice;
|
|
const chartHeight = height - 280;
|
|
const yAxisSteps = [2000, 2400, 2800];
|
|
|
|
return (
|
|
<AbsoluteFill
|
|
style={{
|
|
backgroundColor: COLOR_BG,
|
|
padding: 60,
|
|
display: 'flex',
|
|
flexDirection: 'column',
|
|
fontFamily,
|
|
}}
|
|
>
|
|
<Title>Gold Price 2024</Title>
|
|
|
|
<div style={{display: 'flex', flex: 1}}>
|
|
<YAxis steps={yAxisSteps} height={chartHeight} />
|
|
<XAxis height={chartHeight} labels={data.map((d) => d.month)}>
|
|
{data.map((item, i) => {
|
|
const progress = spring({
|
|
frame: frame - i * 5 - 10,
|
|
fps,
|
|
config: {damping: 18, stiffness: 80},
|
|
});
|
|
|
|
const barHeight =
|
|
((item.price - minPrice) / priceRange) * chartHeight * progress;
|
|
|
|
return (
|
|
<Bar key={item.month} height={barHeight} progress={progress} />
|
|
);
|
|
})}
|
|
</XAxis>
|
|
</div>
|
|
</AbsoluteFill>
|
|
);
|
|
};
|