woocommerce/tools/changelogger/class-package-formatter.php

61 lines
1.6 KiB
PHP
Raw Normal View History

2021-11-11 03:28:10 +00:00
<?php
/**
* Package_Formatter class
*
* @package WooCommerce
*/
namespace Automattic\WooCommerce\MonorepoTools\Changelogger;
use Automattic\Jetpack\Changelogger\FormatterPlugin;
2021-11-11 03:28:10 +00:00
/**
* Jetpack Changelogger Formatter for WooCommerce packages
*/
require_once 'class-formatter.php';
2021-11-11 03:28:10 +00:00
/**
* Jetpack Changelogger Formatter for WooCommerce Packages
*
* Class Formatter
*/
class Package_Formatter extends Formatter implements FormatterPlugin {
2021-11-11 03:28:10 +00:00
/**
* Prologue text.
*
* @var string
*/
public $prologue = "# Changelog \n\nThis project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0.html).";
/**
* Return the epilogue string based on the package being released.
2021-11-11 03:28:10 +00:00
*/
public function getEpilogue() {
$cwd = getcwd();
$pos = stripos( $cwd, 'packages/js/' );
$package = substr( $cwd, $pos + 12 );
return '[See legacy changelogs for previous versions](https://github.com/woocommerce/woocommerce/blob/68581955106947918d2b17607a01bdfdf22288a9/packages/js/' . $package . '/CHANGELOG.md).';
}
/**
* Get Release link given a version number.
*
* @throws \InvalidArgumentException When directory parsing fails.
* @param string $version Release version.
*
* @return string Link to the version's release.
*/
public function getReleaseLink( $version ) {
// Catpure anything past /woocommerce in the current working directory.
preg_match( '/\/packages\/js\/(.+)/', getcwd(), $path );
if ( ! count( $path ) ) {
throw new \InvalidArgumentException( 'Invalid directory.' );
}
return 'https://www.npmjs.com/package/@woocommerce/' . $path[1] . '/v/' . $version;
}
2021-11-11 03:28:10 +00:00
}