UNPKG

@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
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;