woocommerce/plugins/woocommerce
Vladimir Reznichenko e148229edb
[dev] Monorepo: consolidate syncpack config, regroup react and testing deps around react version (#52022)
2024-10-16 09:55:36 +02:00
..
.wordpress-org
assets Product Collection: Add option for current product as a reference (#51359) 2024-09-22 15:30:29 +05:30
bin [dev] pnpm install: speedup postinstall hooks a bit (#51538) 2024-09-24 08:34:46 +02:00
changelog [dev] Monorepo: consolidate syncpack config, regroup react and testing deps around react version (#52022) 2024-10-16 09:55:36 +02:00
client [dev] Monorepo: consolidate syncpack config, regroup react and testing deps around react version (#52022) 2024-10-16 09:55:36 +02:00
i18n Update symbol and formatting of the XPF currency (#46960) 2024-05-15 04:50:55 +07:00
includes Check for empty value in get_order_id_by_order_key() (#40254) 2024-10-15 06:32:53 +00:00
lib [Accessibility] Fix typos in inline documentation in woocommerce client, includes, and lib folders (#50739) 2024-08-27 16:23:04 +02:00
packages [dev] pnpm install: speedup postinstall hooks a bit (#51538) 2024-09-24 08:34:46 +02:00
patterns Add Dimensions controls to Product Collection block (#51420) 2024-09-27 05:04:16 +02:00
sample-data Update @woo.com email addresses to @woocommerce.com (#46387) 2024-04-19 21:11:01 +00:00
src Fix products base incorrectly matching pages with the same prefix (#52028) 2024-10-16 12:30:54 +08:00
templates [Accessibility] Announce to screen readers when the variations have been cleared (#50183) 2024-10-14 14:58:14 +13:00
tests Fix products base incorrectly matching pages with the same prefix (#52028) 2024-10-16 12:30:54 +08:00
.distignore Try reducing blocks build size (#43344) 2024-01-08 11:33:49 -06:00
.eslintignore Merge React Admin (#49647) 2024-10-11 11:31:11 +08:00
.eslintrc.js Add JS lint scripts for woocommerce plugin (#46214) 2024-04-12 07:30:17 +03:00
.gitattributes
.gitignore Merge React Admin (#49647) 2024-10-11 11:31:11 +08:00
.phpunit-watcher.yml Add php unit watcher and update unit test docs (#44681) 2024-02-19 16:40:29 +08:00
.wp-env.json [dev] Monorepo: bypass git clone for WordPress core when spinning off wp-env (#51457) 2024-09-19 10:33:57 +02:00
NEXT_CHANGELOG.md
README.md Merge React Admin (#49647) 2024-10-11 11:31:11 +08:00
composer.json Prep trunk for 9.5 cycle (#51529) 2024-09-24 17:59:48 +07:00
composer.lock Update Action Scheduler to 3.8.2 (#51353) 2024-09-13 09:37:13 +02:00
license.txt
package.json [dev] Monorepo: consolidate syncpack config, regroup react and testing deps around react version (#52022) 2024-10-16 09:55:36 +02:00
phpcs.xml Merge React Admin (#49647) 2024-10-11 11:31:11 +08:00
phpunit.xml PHPUnit: report slow tests. (#51253) 2024-09-10 12:37:23 +02:00
readme.txt Update stable tag to 9.3.3 (#51692) 2024-09-25 10:34:52 -07:00
tsconfig.json
uninstall.php
woocommerce.php Prep trunk for 9.5 cycle (#51529) 2024-09-24 17:59:48 +07:00

README.md

WooCommerce

License WordPress.org downloads WordPress.org rating Build Status codecov

This is the WooCommerce Core plugin. Here you can browse the source and keep track of development. We recommend all developers to follow the WooCommerce development blog to stay up to date about everything happening in the project. You can also follow @DevelopWC on Twitter for the latest development updates.

If you are not a developer, please use the WooCommerce plugin page on WordPress.org.

Getting Started

Please make sure you follow the repository's getting started guide first!

# Make sure that WooCommerce Core and all of its dependencies are built
pnpm --filter=@woocommerce/plugin-woocommerce build 
# Make sure you're in the WooCommerce Core directory
cd plugins/woocommerce
# Start the development environment
pnpm -- wp-env start

You should now be able to visit http://localhost:8888/ and access WooCommerce environment.

Building Components

There are two major client-side components included in WooCommerce Core that can be built, linted, and tested independently. We've organized these components in this way to take advantage of caching to prevent unnecessarily performing expensive rebuilds when only working in one of them.

plugins/woocommerce/client/legacy

This directory contains the Classic CSS and jQuery code for WooCommerce.

# Build the assets.
pnpm --filter=@woocommerce/classic-assets build 
# Lint the assets.
pnpm --filter=@woocommerce/classic-assets lint 

plugins/woocommerce/client/admin

This directory contains the React-based admin interface.

# Build the React-based admin client.
pnpm --filter=@woocommerce/admin-library build 
# Lint the React-based admin client.
pnpm --filter=@woocommerce/admin-library lint 
# Test the React-based admin client.
pnpm --filter=@woocommerce/admin-library test 

plugins/woocommerce-blocks

This directory contains the client for WooCommerce + Gutenberg.

# Build the Blocks client.
pnpm run --filter=@woocommerce/block-library build 
# Lint the Blocks client.
pnpm run --filter=@woocommerce/block-library lint 
# Test the Blocks client.
pnpm run --filter=@woocommerce/block-library test 

Helper Scripts

Here is a collection of scripts that can help when developing the React-based admin interface.

# Create a development build of the React-based admin client.
pnpm --filter=@woocommerce/admin-library dev 
# Create and watch a development build of the React-based admin client.
pnpm --filter=@woocommerce/admin-library start 
# Watch the tests of the React-based admin client.
pnpm --filter=@woocommerce/admin-library test:watch 
# Run a type check over the React-based admin client's TypeScript files.
pnpm --filter=@woocommerce/admin-library ts:check 

Documentation

Reporting Security Issues

To disclose a security issue to our team, please submit a report via HackerOne here.