Agent Skills
› NeverSight/learn-skills.dev
› erpnext-frappe-dev
erpnext-frappe-dev
GitHub提供Frappe框架和ERPNext开发的完整参考,涵盖DocType、控制器、钩子、REST API及前端脚本。适用于从零构建自定义应用、编写业务逻辑、配置事件处理及集成外部服务的全栈开发场景。
Trigger Scenarios
创建新的Frappe/ERPNext自定义应用
构建DocType和Python控制器
编写hooks.py进行事件定制
实现REST API接口
开发客户端JS表单脚本
编写后台任务或作业
Install
npx skills add NeverSight/learn-skills.dev --skill erpnext-frappe-dev -g -y
SKILL.md
Frontmatter
{
"name": "erpnext-frappe-dev",
"license": "MIT",
"metadata": {
"author": "openclaw",
"version": "1.0.0"
},
"description": "Complete Frappe Framework development reference for building ERPNext apps. Use when creating custom DocTypes, controllers, hooks, REST APIs, form scripts, background jobs, or any Frappe\/ERPNext development. Contains full API documentation for Document, Database, Controllers, Hooks, REST API, Form Scripts, Testing, and common patterns."
}
Frappe Framework Development Reference
Complete documentation for building applications on Frappe Framework / ERPNext. This skill contains comprehensive API documentation that Claude Code needs to build any Frappe app from scratch.
When to Use This Skill
Use this skill when:
- Creating a new Frappe/ERPNext custom app
- Building DocTypes and controllers
- Writing hooks for customization
- Implementing REST APIs
- Creating form scripts (client-side JS)
- Writing background jobs
- Building integrations with external services
- Any ERPNext/Frappe development work
Quick Start
Create an App
bench new-app my_app
bench --site mysite install-app my_app
Key Files
hooks.py— App-level configuration and event handlers{doctype}.py— Python controller (server-side logic){doctype}.js— Form script (client-side logic){doctype}.json— DocType definition
Documentation Index
| Reference | Contents |
|---|---|
reference/frappe-framework-complete.md |
MAIN REFERENCE — Full API docs for Document, Database, Controllers, Hooks, REST API, Form Scripts, Testing |
reference/document-api.md |
Document CRUD operations |
reference/database-api.md |
Database queries and transactions |
reference/hooks-reference.md |
hooks.py configuration |
reference/rest-api.md |
REST API endpoints |
reference/form-scripts.md |
Client-side JavaScript |
reference/index.md |
ERPNext module documentation index |
reference/accounting/ |
Accounting module reference |
reference/stock/ |
Inventory/Stock module reference |
reference/manufacturing/ |
Manufacturing module reference |
reference/crm/ |
CRM module reference |
reference/hr-payroll/ |
HR & Payroll module reference |
reference/api/ |
REST & Developer API reference |
Core Concepts Summary
DocType = Model
# DocType "Customer" creates:
# - Database table `tabCustomer`
# - Python controller customer.py
# - Form script customer.js
Document = Instance
doc = frappe.get_doc("Customer", "CUST-001")
doc.customer_name = "Updated Name"
doc.save()
Controller = Business Logic
class Customer(Document):
def validate(self):
if not self.email:
frappe.throw("Email required")
def on_submit(self):
self.create_linked_records()
Hooks = App Configuration
# hooks.py
doc_events = {
"Sales Order": {
"on_submit": "my_app.events.on_sales_order_submit"
}
}
API Quick Reference
Document Operations
frappe.get_doc(doctype, name) # Get document
frappe.new_doc(doctype) # Create new
doc.insert() # Insert to DB
doc.save() # Update in DB
doc.delete() # Delete
doc.db_set(field, value) # Direct DB update
Database Queries
frappe.db.get_list(doctype, filters, fields) # With permissions
frappe.db.get_all(doctype, filters, fields) # All records
frappe.db.get_value(doctype, name, field) # Single value
frappe.db.set_value(doctype, name, field, val) # Direct update
frappe.db.exists(doctype, name) # Check exists
frappe.db.count(doctype, filters) # Count records
Controller Hooks
autoname → before_insert → validate → before_save →
on_update → after_insert → on_submit → on_cancel
REST API
GET /api/resource/{doctype} # List
GET /api/resource/{doctype}/{name} # Read
POST /api/resource/{doctype} # Create
PUT /api/resource/{doctype}/{name} # Update
DELETE /api/resource/{doctype}/{name} # Delete
POST /api/method/{dotted.path} # Custom method
Form Scripts
frappe.ui.form.on('DocType', {
refresh(frm) { },
validate(frm) { },
fieldname(frm) { } // Field change
});
Read Full Documentation
Start with: reference/frappe-framework-complete.md
This file contains 20KB+ of comprehensive documentation covering all Frappe APIs with code examples.
Version History
- e0220ca Current 2026-07-05 21:24


