承接 myparcelnl/pdk 相关项目开发

从需求分析到上线部署,全程专人跟进,保证项目质量与交付效率

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

myparcelnl/pdk

Composer 安装命令:

composer require myparcelnl/pdk

包简介

MyParcel Plugin Development Kit

README 文档

README

Latest version Packagist Downloads Code coverage PHPStan License Chat with us

The MyParcel PDK (Plugin Development Kit) is meant for developing entire plugins on PHP E-Commerce platforms. If you're just looking to connect to our API without creating an entire plugin, you should check out our php SDK.

Requirements

  • PHP 7.4 – 8.5
  • Composer

Documentation

For examples, guides and in-depth information, visit our Plugin Development Kit (PDK) documentation.

Support

Create an issue or contact us via our Developer Portal contact page.

Contributing

View our contribution guidelines for information on how to contribute to the PDK.

Prerequisites

  • Node 18
  • Yarn
  • Docker

Installation

Create .env:

cp .env.template .env

Install Yarn dependencies:

yarn

Install Composer dependencies:

docker compose up php

Running tests

Run all tests:

docker compose run php composer test

Testing on a specific PHP version

The default PHP version is 7.4. To test on a different version, change PHP_VERSION in .env and rebuild:

docker compose build
docker compose run php composer test

Adding a shipment option

Shipment options are managed through the OrderOptionDefinitionInterface system. Each option is a single Definition class that declares all its keys (shipment, capabilities, carrier settings, product settings, allow, price). All models, views, and services build their attributes and form elements dynamically from these definitions.

To add a new option:

  1. Create a Definition class in src/App/Options/Definition/ extending AbstractOrderOptionDefinition. Only two methods are required:
    • getShipmentOptionsKey() — the PDK-internal key, derived from Str::camel(RefShipmentShipmentOptions::attributeMap()['sdk_key'])
    • getCapabilitiesOptionsKey() — the V2 capabilities key, from RefCapabilitiesContractDefinitionsResponseOptionsOptionsV2::attributeMap()['capabilities_key']
  2. Register it in the orderOptionDefinitions array in config/pdk-business-logic.php.
  3. Optionally, add a deprecated constant to ShipmentOptions if platform integrations reference the key directly.

Everything else (carrier settings, product settings, allow/price toggles, validation, frontend form fields, API export/import) is derived automatically. Run yarn test:unit to verify the consistency tests pass.

If the option is not yet in the SDK types, update the SDK or regenerate the OpenAPI types first.

Using Claude Code? Run /add-shipment-option for a guided step-by-step walkthrough that asks the right questions and generates the code.

Linting

We use Prettier to format .json, .yml, .md and .html files.

Make sure Prettier is enabled in your IDE and runs on the following files:

{**/*,*}.{md,html,yml,json}

Set up Git hooks to run Prettier on each commit, correcting any formatting issues.

yarn prepare

You can also run Prettier manually:

# Check formatting issues
yarn lint

# Fix formatting issues
yarn lint:fix

统计信息

  • 总下载量: 14.12k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 3
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 1
  • Forks: 1
  • 开发语言: PHP

其他信息

  • 授权协议: MIT
  • 更新时间: 2022-03-25

承接程序开发

PHP开发

VUE

Vue开发

前端开发

小程序开发

公众号开发

系统定制

数据库设计

云部署

网站建设

安全加固