@gobvoz/cli-fsd
Version:
Utility to create slices in Feature-Sliced Design methodology. Expect, that you have already installed `react`, `typescript`, `@reduxjs/toolkit`, `@reduxjs/toolkit-query`, `i18n` and use `module.scss` structure.
37 lines (29 loc) • 1.02 kB
JavaScript
import fs from 'fs/promises';
import path from 'path';
import log from '../utils/log.js';
import createFolder from '../utils/create-folder.js';
import componentTemplate from '../templates/component-template.js';
const createUIComponent = async (layer, sliceName) => {
const resolvePath = (...segments) => path.resolve('src', layer, sliceName.kebabCase, ...segments);
const createFolderStructure = async () => {
try {
await createFolder(resolvePath());
await createFolder(resolvePath('ui'));
} catch (error) {
log.warning(`Could not create 'ui' structure for "${sliceName.kebabCase}"`);
}
};
const createTemplate = async () => {
try {
await fs.writeFile(
resolvePath('ui', `${sliceName.kebabCase}.tsx`),
componentTemplate(sliceName),
);
} catch (error) {
log.error(`Could not create 'ui/component' for "${sliceName.kebabCase}"`);
}
};
await createFolderStructure();
await createTemplate();
};
export default createUIComponent;