UNPKG

@gobstones/gobstones-scripts

Version:

Scripts to abstract away build configuration of Gobstones Project's libraries and modules.

88 lines (79 loc) 2.81 kB
/* * ***************************************************************************** * Copyright (C) National University of Quilmes 2018-2024 * Gobstones (TM) is a trademark of the National University of Quilmes. * * This program is free software distributed under the terms of the * GNU Affero General Public License version 3. * Additional terms added in compliance to section 7 of such license apply. * * You may read the full license at https://gobstones.github.io/gobstones-guidelines/LICENSE. * ***************************************************************************** */ /** * ---------------------------------------------------- * @module Tasks * @author Alan Rodas Bonjour <alanrodas@gmail.com> * ---------------------------------------------------- */ import { stripIndent } from 'common-tags'; import { runBin } from './runBin'; import { isNotDefined } from '../Helpers/isNotDefined'; import { TaskConfigurationError } from '../Helpers/TaskError'; /** * This type represents the options that you can pass to the storybook start task. */ export interface TaskStorybookStartOptions { /** * The port on which to start storybook's server. */ port: number; } /** * This type represents the options that you can pass to the storybook build task. */ export interface TaskStorybookBuildOptions { /** * The output directory of the build */ outDir: string; } /** * The storybook object holds the different ways in you can run a * task in storybook, either by running start or build. */ export const storybook = { /** * Returns the string for the bash command to run * storybook.start with the project's configuration. * * @param options - The options applied when running storybook. * * @example storybook.start({ port: 3000 }) * * @returns The bash command string. */ start: (options: TaskStorybookStartOptions = { port: 5000 }): string => `${runBin('@storybook/cli', 'sb')} dev -p ${options.port.toString()}`, /** * Returns the string for the bash command to run * storybook.build with default configuration. * * @param options - The options applied when running storybook. * * @example storybook.build({ outDir: './dist' }) * * @returns The bash command string. */ build: (options: TaskStorybookBuildOptions): string => { if (isNotDefined(options.outDir)) { throw new TaskConfigurationError( stripIndent`"storybook.build" expects options with the following signature: { outDir: str // The output directory of the storybook }` ); } return `${runBin('@storybook/cli', 'sb')} build --output-dir ${options.outDir}`; } };