UNPKG

@gobstones/gobstones-scripts

Version:

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

84 lines (76 loc) 2.57 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 { runBin } from './runBin'; /** * This type represents the options that you can pass to the vite task. */ export interface TaskViteOptions { /** * The files to watch for changes, if desired. */ watch?: string; } /** * The bash string to run the vite command in a particular mode. * * @param mode - The mode on which to run. * @param _options - Additional options, not in use currently. * * @returns The bash command string. */ const runVite = (mode: string, _options?: TaskViteOptions): string => `${runBin('vite')} ${mode}`; /** * The vite object holds the different ways in you can run a task in vite, * either by running dev, build or preview. */ export const vite = { /** * Returns the string for the bash command to run * vite's dev server with the gobstones-script detected configuration. * * @param options - The options applied when running vite. * * @example vite.dev() * * @returns The bash command string. */ dev: (options?: TaskViteOptions): string => runVite('', options), /** * Returns the string for the bash command to run * vite's build process with default configuration. * * @param options - The options applied when running vite. * * @example vite.build() * * @returns The bash command string. */ build: (options?: TaskViteOptions) => runVite('build', options), /** * Returns the string for the bash command to run * vite's preview server with default configuration. * * @param options - The options applied when running vite. * * @example vite.preview() * * @returns The bash command string. */ preview: (options?: TaskViteOptions) => runVite('preview', options) };