@sap-ux/cap-config-writer
Adds or removes configuration to a SAP CAP projects.
Installation
Npm
npm install --save @sap-ux/cap-config-writer
Yarn
yarn add @sap-ux/cap-config-writer
Pnpm
pnpm add @sap-ux/cap-config-writer
Usage
import { enableCdsUi5Plugin } from '@sap-ux/cap-config-writer';
const fs = await enableCdsUi5Plugin('path/to/cap-project');
fs.commit();
API
updatePomXml
This utility function updates the pom.xml file for Java-based CAP projects. The function reads the contents of the pom.xml file specified by pomPath, parses it, and searches for the spring-boot-maven-plugin configuration. If found, it adds certain workspace elements to it and writes back the updated pom.xml.
import { updatePomXml } from '@sap-ux/cap-config-writer';
const fsMock: Editor = {};
const pomPath: string = 'path/to/pom.xml';
const logger: Logger = {};
updatePomXml(fsMock, pomPath, logger);
updateTsConfig
The function constructs the path to the tsconfig.json file based on the provided appRoot. If the file exists, it reads its contents and checks if the typeRoots property is defined in the compilerOptions. The function extends the tsconfig.json file with the modified compilerOptions.
import { updateTsConfig } from '@sap-ux/cap-config-writer';
const fsMock: Editor = {};
const appRoot: string = 'path/to/your/app';
updateTsConfig(fsMock, appRoot);
updateStaticLocationsInApplicationYaml
The function reads the contents of the application YAML file specified by applicationYamlPath, parses it, and checks if the static resource locations are already defined. If not, it adds the custom paths specified by capCustomPathsApp to the web.resources.static-locations property.
import { updateStaticLocationsInApplicationYaml } from '@sap-ux/cap-config-writer';
const fsMock: Editor = {};
const applicationYamlPath: string = 'path/to/application.yaml';
const capCustomPathsApp: string = 'path/to/static/resources';
const logger: Logger = {};
await updateStaticLocationsInApplicationYaml(fsMock, applicationYamlPath, capCustomPathsApp, logger);
updateRootPackageJson
Updates the package.json file of a CAP project app based on project requirements such as enableNPMWorkspaces
import { updateRootPackageJson } from '@sap-ux/cap-config-writer';
const fsMock: Editor = {};
const projectName: string = 'your-project-name';
const sapux: boolean = true;
const capService: CapService = {};
const appId: string = 'your-app-id';
const log: Logger = {};
const enableNPMWorkspaces: boolean = true;
await updateRootPackageJson(fsMock, projectName, sapux, capService, appId, log, enableNPMWorkspaces);
updateAppPackageJsonCAP
The function constructs the path to the package.json file based on the provided appRoot. It then reads the contents of the package.json file and removes the sapux property, the int-test script, and any scripts starting with 'start' that are not required for the app.
import { updateAppPackageJson } from '@sap-ux/cap-config-writer';
const fsMock: Editor = {};
const appRoot: string = 'path/to/your/app';
updateAppPackageJson(fsMock, appRoot);
Keywords
SAP Fiori elements
SAP CAP
SAP CAP writer
SAP UI5