import commandLineArgs from 'command-line-args'; import fs from 'fs'; import path from 'path'; import chalk from 'chalk'; import { deleteSync } from 'del'; import prettier from 'prettier'; import prettierConfig from '../prettier.config.cjs'; import { getAllComponents } from './shared.js'; const { outdir } = commandLineArgs({ name: 'outdir', type: String }); const reactDir = path.join('./src/react'); // Clear build directory deleteSync(reactDir); fs.mkdirSync(reactDir, { recursive: true }); // Fetch component metadata const metadata = JSON.parse(fs.readFileSync(path.join(outdir, 'custom-elements.json'), 'utf8')); const components = getAllComponents(metadata); const index = []; components.map(component => { const tagWithoutPrefix = component.tagName.replace(/^sl-/, ''); const componentDir = path.join(reactDir, tagWithoutPrefix); const componentFile = path.join(componentDir, 'index.ts'); const importPath = component.path; const events = (component.events || []).map(event => `${event.reactName}: '${event.name}'`).join(',\n'); fs.mkdirSync(componentDir, { recursive: true }); const source = prettier.format( ` import * as React from 'react'; import { createComponent } from '@lit-labs/react'; import Component from '../../${importPath}'; export default createComponent({ tagName: '${component.tagName}', elementClass: Component, react: React, events: { ${events} } }); `, Object.assign(prettierConfig, { parser: 'babel-ts' }) ); index.push(`export { default as ${component.name} } from './${tagWithoutPrefix}';`); fs.writeFileSync(componentFile, source, 'utf8'); }); // Generate the index file fs.writeFileSync(path.join(reactDir, 'index.ts'), index.join('\n'), 'utf8');