charted-wip
1
总安装量
1
周安装量
#76624
全站排名
安装命令
npx skills add https://github.com/marmicode/skills --skill charted-wip
Agent 安装分布
amp
1
opencode
1
cursor
1
kimi-cli
1
codex
1
github-copilot
1
Skill 文档
Context
- designDocPath: $ARGUMENTS[0]
- prNumber: $ARGUMENTS[1]
Task
Based on the following design doc ${designDocPath}, write WIP code for implementation described in the design doc.
- Focus only on the PR #${prNumber} if provided.
- If you add a new class, function, or method, make it throw a “ð§ work in progress” error and add the “@deprecated ð§ work in progress” tag to its jsdoc.
- If you add a new component, add the “@deprecated ð§ work in progress” tag to its jsdoc but do not implement the template or methods.
- DO NOT ADD ANY NEW BEHAVIOR.
- As an example, do not add child components in a component.
- DO NOT CHANGE ANY EXISTING BEHAVIOR:
- If you change a function or a method signature in a retro-compatible way, do not throw a “ð§ work in progress” error.
- If the function or method receives a new optional parameter, make it throw a “ð§ work in progress” error if the parameter is set.
- Even if the goal of the PR is to change the behavior of an existing function or method, do not throw a “ð§ work in progress” error. KEEP THE EXISTING BEHAVIOR.
- For WIP tests, put the test’s steps from the design doc as-is in a comment inside the body of the “it.todo” test.
Examples
WIP class example
/**
* @deprecated ð§ work in progress
*/
class Greetings {
hello() {
throw new Error(`ð§ work in progress`);
}
}
WIP method example
class Greetings {
/**
* @deprecated ð§ work in progress
*/
hello() {
throw new Error(`ð§ work in progress`);
}
}
WIP component
/**
* @deprecated ð§ work in progress
*/
@Component({
changeDetection: ChangeDetectionStrategy.OnPush,
selector: 'wm-rules',
template: `Rules - ð§ work in progress`,
})
class Rules {
rules = input.required<Rule[]>();
ruleSelect = output<Rule>();
}
WIP tests example
Note: test names start in lower case (e.g. “search rules …”).
import { describe, it } from 'vitest';
describe(RuleSearch.name, () => {
it.todo('search rules without filtering', () => {
// mount RuleSearch
// click on first rule
// assert output was triggered once
});
it.todo('...', () => {
// ...
});
});