woocommerce-markdown

WooCommerce Markdown Guidelines

Safety Notice

This listing is imported from skills.sh public index metadata. Review upstream SKILL.md and repository scripts before running.

Copy this and send it to your AI assistant to learn

Install skill "woocommerce-markdown" with this command: npx skills add woocommerce/woocommerce/woocommerce-woocommerce-woocommerce-markdown

WooCommerce Markdown Guidelines

This skill provides guidance for creating and editing markdown files in the WooCommerce project.

Critical Rules

  • Always lint after changes - Run markdownlint --fix then markdownlint to verify

  • Run from repository root - Ensures .markdownlint.json config is loaded

  • Use UTF-8 encoding - Especially for directory trees and special characters

  • Follow WooCommerce markdown standards - See configuration rules below

WooCommerce Markdown Configuration

The project uses markdownlint with these specific rules (from .markdownlint.json ):

Enabled Rules

  • MD003: Heading style must be ATX (# Heading not Heading\n=== )

  • MD007: Unordered list indentation must be 4 spaces

  • MD013: Line length limit disabled (set to 9999)

  • MD024: Multiple headings with same content allowed (only check siblings)

  • MD031: Fenced code blocks must be surrounded by blank lines

  • MD032: Lists must be surrounded by blank lines

  • MD033: HTML allowed for <video> elements only

  • MD036: Emphasis (bold/italic) should not be used as headings - use proper heading tags

  • MD040: Fenced code blocks should specify language

  • MD047: Files must end with a single newline

Disabled Rules

  • no-hard-tabs: Tabs are allowed

  • whitespace: Trailing whitespace rules disabled

Markdown Writing Guidelines

Headings

Main Title (H1) - Only one per file

Section (H2)

Subsection (H3)

Minor Section (H4)

  • Use ATX style (# ) not underline style

  • One H1 per file (usually the title)

  • Maintain heading hierarchy (don't skip levels)

Lists

Unordered lists:

  • Item one
  • Item two
    • Nested item (4 spaces)
    • Another nested item
  • Item three

Ordered lists:

  1. First item
  2. Second item
  3. Third item

Important:

  • Use 4 spaces for nested list items

  • Add blank line before and after lists

  • Use - for unordered lists (not * or + )

Code Blocks

Always specify the language:

pnpm test:php:env
public function process_order( int $order_id ) {
    // code here
}
const result = calculateTotal(items);

Common language identifiers:

  • bash

  • Shell commands

  • php

  • PHP code

  • javascript or js

  • JavaScript

  • typescript or ts

  • TypeScript

  • json

  • JSON data

  • sql

  • SQL queries

  • markdown or md

  • Markdown examples

Code block rules:

  • Add blank line before the opening fence

  • Add blank line after the closing fence

  • Always specify language (never use plain ``` )

Inline Code

Use backticks for inline code:

Use the process_order() method to handle orders. The $order_id parameter must be an integer.

Links

Link text

Internal link

Link with title

Tables

Column 1Column 2Column 3
Value 1Value 2Value 3
Value 4Value 5Value 6
  • Use pipes (| ) for column separators

  • Header separator row required

  • Alignment optional (:--- , :---: , ---: )

Directory Trees

Always use UTF-8 box-drawing characters:

src/ ├── Internal/ │ ├── Admin/ │ │ └── Controller.php │ └── Utils/ │ └── Helper.php └── External/ └── API.php

Never use:

  • ASCII art (+-- , |-- )

  • Spaces or tabs for tree structure

  • Control characters

Emphasis

Bold text for strong emphasis Italic text for regular emphasis Bold and italic for very strong emphasis

Workflow for Editing Markdown

Make your changes to the markdown file

Auto-fix linting issues:

markdownlint --fix path/to/file.md

Check for remaining issues:

markdownlint path/to/file.md

Manually fix what remains (usually language specs for code blocks)

Verify clean - No output means success

Commit changes

Common Linting Errors and Fixes

MD007: List indentation

Problem:

  • Item
    • Nested (only 2 spaces)

Fix:

  • Item
    • Nested (4 spaces)

MD031: Code blocks need blank lines

Problem:

Some text

command

More text

Fix:

Some text

command

More text

MD032: Lists need blank lines

Problem:

Some text

  • List item

Fix:

Some text

  • List item

MD036: Emphasis as heading

Problem:

Example: Using bold as a heading

Some content here

Fix:

Example: Using a proper heading

Some content here

MD040: Code needs language

Problem:

code here

Fix:

code here

Special Cases

CLAUDE.md Files

CLAUDE.md files are AI assistant documentation:

  • Must be well-formatted for optimal parsing by AI

  • Follow all markdownlint rules strictly

  • Use clear, hierarchical structure

  • Include table of contents for long files

README Files

  • Start with H1 title

  • Include brief description

  • Add installation/usage sections

  • Keep concise and scannable

Changelog Files

  • Follow Keep a Changelog format

  • Use consistent date formatting

  • Group changes by type (Added, Changed, Fixed, etc.)

Troubleshooting

File Shows as "data" Instead of Text

Problem: File is corrupted with control characters

Fix:

tr -d '\000-\037' < file.md > file.clean.md && mv file.clean.md file.md file file.md # Verify shows "UTF-8 text"

Linting Shows Unexpected Errors

Problem: Not running from repository root

Fix:

Always run from root

cd /path/to/woocommerce markdownlint path/to/file.md

NOT like this

markdownlint /absolute/path/to/file.md

Auto-fix Doesn't Work

Problem: Some issues require manual intervention

Fix:

  • Language specs for code blocks must be added manually

  • Long lines may need manual rewrapping

  • Some structural issues require content reorganization

Notes

  • Most markdown issues are auto-fixable with markdownlint --fix

  • Always run markdownlint from repository root

  • UTF-8 encoding is critical for special characters

  • CLAUDE.md files must pass linting for optimal AI parsing

  • See woocommerce-dev-cycle skill for markdown linting commands

Source Transparency

This detail page is rendered from real SKILL.md content. Trust labels are metadata-based hints, not a safety guarantee.

Related Skills

Related by shared tags or category signals.

General

woocommerce

No summary provided by upstream source.

Repository SourceNeeds Review
General

woocommerce

No summary provided by upstream source.

Repository SourceNeeds Review
General

woocommerce-copy-guidelines

No summary provided by upstream source.

Repository SourceNeeds Review
General

woocommerce-email-editor

No summary provided by upstream source.

Repository SourceNeeds Review