一键导入
spinder-transaction-processing
Handle CSV parsing, transaction validation, and data processing for the Spinder expense tracking app.
用 Codex 或 Claude 帮你安装 复制这段 Prompt,粘贴到 Codex、Claude 或其他助手里,让它检查 Skill 页面并帮你完成安装。
菜单
Handle CSV parsing, transaction validation, and data processing for the Spinder expense tracking app.
用 Codex 或 Claude 帮你安装 复制这段 Prompt,粘贴到 Codex、Claude 或其他助手里,让它检查 Skill 页面并帮你完成安装。
基于 SOC 职业分类
Create and manage expense categorization buckets in the Spinder app, including filtering logic and data aggregation.
Create new Lit-based components for the Spinder expense tracking app, following the project's coding standards and architecture patterns.
Debug issues in the Spinder expense tracking app, including transaction processing, UI rendering, and data flow problems.
Create, dispatch, and listen to custom events in the Spinder app using the Zod-validated event system.
Create new pages and routes in the Spinder application, following the routing architecture and page component patterns.
Create new Zod-based type definitions for the Spinder expense tracking app, following the project's type organization patterns.
| name | spinder-transaction-processing |
| description | Handle CSV parsing, transaction validation, and data processing for the Spinder expense tracking app. |
This skill helps process financial transaction data from CSV files, validate transactions, and prepare them for display and analysis in the Spinder app.
Use this skill when you need to:
Each transaction must include:
details: Transaction details/descriptionpostingDate: Date in YYYY-MM-DD formatdescription: Human-readable descriptionamount: Numeric amount (positive for income, negative for expenses)type: Transaction type (debit, credit, etc.)balance: Optional account balancecheckOrSlipNumber: Optional check numberasync function processCsvFile(file: File): Promise<Transaction[]> {
const text = await file.text();
const rows = parseCsv(text);
const transactions: Transaction[] = [];
const errors: string[] = [];
for (const row of rows) {
try {
const transaction = parseTransaction(row);
transactions.push(transaction);
} catch (error) {
errors.push(`Row ${row.index}: ${error.message}`);
}
}
if (errors.length > 0) {
// Report errors to user
showErrors(errors);
}
return transactions;
}