6.0.0 • Published 2 years ago

europa-build v6.0.0

Weekly downloads
-
License
MIT
Repository
github
Last release
2 years ago

Europa Build

Europa Build is a tool for generating and maintaining Europa plugin and preset packages.

Build Status License Release

Install

Install using your preferred package manager. For example;

$ npm install --save-dev europa-build

You'll need to have at least Node.js 12.22.0 or newer.

This package is intended for generating Europa plugins and preset packages as well as also being used by those generated packages to ensure a smooth and consistent maintenance.

While it does come with an API, the primary intended usage is its CLI. If you want to use the command line interface to generate plugins and/or presets, you'll most likely want to install it globally so that you can run europa-build from anywhere:

$ npm install --global europa-build

API

Since the primary usage of this package is the CLI the API is simply what is used to help support the CLI.

You can generate plugin/preset packages:

import { TemplateManager, TemplateProviderType } from 'europa-build';

const templateManager = new TemplateManager();
console.log(templateManager.getProvidersForType(TemplateProviderType.Plugin));
//=> ["contrib", "official"]
const templateProvider = manager.getProvider('contrib', TemplateProviderType.Plugin);
const templateGenerator = templateProvider.createGenerator();

(async () => {
  const templateContext = await templateProvider.createContext({
    authorName: 'ghost',
    name: 'example', // Transformed to "europa-plugin-example"
    repositoryUrl: 'https://github.com/ghost/europa-plugin-example.git',
    authorEmail: 'ghost@github.com', // Optional
    authorUrl: 'https://github.com/ghost', // Optional
    bugsUrl: 'https://github.com/ghost/europa-plugin-example/issues', // Optional
    description: 'Europa plugin example', // Optional; defaults to "TODO: Description"
    homepageUrl: 'https://github.com/ghost/europa-plugin-example', // Optional
    keywords: ['example'], // Optional; defaults to empty array
    version: '1.2.3', // Optional; defaults to "1.0.0" 
  });
  await templateGenerator.generate(templateContext, 'path/to/parent');
})();

Or run scripts to maintain your plugin/preset package:

import { ScriptRunner } from 'europa-build';

const scriptRunner = new ScriptRunner();
console.log(scriptManager.getScriptNames());
//=> ["build", "flint", "format", "lint", "test"]

(async () => {
  await scriptRunner.run('build', {
    cwd: 'path/to/parent/europa-plugin-example', // Optional; defaults to process.cwd()
  });
})();

CLI

Usage: europa-build [options] [command]

Options:
  -V, --version                         output the version number
  -h, --help                            display help for command

Commands:
  generate-plugin [options] <template>  generate a plugin package
  generate-preset [options] <template>  generate a preset package
  run-script [options] <name>           run the named script
  help [command]                        display help for command

Typically, you'll only generate plugins/presets using the contrib template as the official assumes the package will be maintained with the Europa monorepo.

Bugs

If you have any problems with Europa Build or would like to see changes currently in development you can do so here.

Contributors

If you want to contribute, you're a legend! Information on how you can do so can be found in CONTRIBUTING.md. We want your suggestions and pull requests!

A list of Europa contributors can be found in AUTHORS.md.

License

Copyright © 2022 neocotic

See LICENSE.md for more information on our MIT license.