Skip to content

Commit

Permalink
Support component variants (#40)
Browse files Browse the repository at this point in the history
* Run screen and component functions within the `exec` command
* Add fixtures for variant components to the extension template
  • Loading branch information
dirtybit authored Jan 12, 2021
1 parent 4ffb2d4 commit 0aa06c6
Show file tree
Hide file tree
Showing 12 changed files with 6,947 additions and 28 deletions.
6 changes: 3 additions & 3 deletions package-lock.json

Some generated files are not rendered by default. Learn more about how customized files appear on GitHub.

2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -29,7 +29,7 @@
"@babel/core": "^7.8.4",
"@babel/preset-env": "^7.8.4",
"@types/jest": "^25.1.2",
"@zeplin/extension-model": "^2.6.0",
"@zeplin/extension-model": "^2.9.0",
"adm-zip": "^0.4.11",
"ajv": "^6.12.0",
"babel-jest": "^25.1.0",
Expand Down
61 changes: 51 additions & 10 deletions src/commands/exec.js
Original file line number Diff line number Diff line change
Expand Up @@ -7,6 +7,9 @@ const { bundleName } = require("../config/constants");
const { resolveBuildPath, resolveExtensionPath } = require("../utils/paths");
const {
Context,
Screen,
Component,
ComponentVariant,
Version
} = require("@zeplin/extension-model");

Expand Down Expand Up @@ -61,7 +64,42 @@ function callExtensionFunction(extension, fnName, ...args) {
}).catch(error => chalk.red(error.stack));
}

function executeLayer(extension, context, version) {
function executeScreen(extension, context) {
const version = new Version(sampleData.screenVersion);
const screens = sampleData.screens.map(s => new Screen(s));

return Promise.all(
screens.map(screen => callExtensionFunction(extension, "screen", context, version, screen))
).then(results => {
console.log(chalk.underline.bold("\nScreens:"));

results.forEach((codeData, index) => {
printCodeData(codeData, `${screens[index].name}:`);
});
});
}

function executeComponent(extension, context) {
const singleComponents = sampleData.components.map(c => new Component(c));
const variantComponents = sampleData.componentVariants.map(
variantData => new ComponentVariant(variantData)
).reduce((cs, variant) => cs.concat(variant.components), []);
const components = singleComponents.concat(variantComponents);

return Promise.all(
components.map(component => callExtensionFunction(extension, "component", context, component.latestVersion, component))
).then(results => {
console.log(chalk.underline.bold("\nComponents:"));

results.forEach((codeData, index) => {
printCodeData(codeData, `${components[index].name}:`);
});
});
}

function executeLayer(extension, context) {
const version = new Version(sampleData.screenVersion);

return Promise.all(
version
.layers
Expand Down Expand Up @@ -103,17 +141,19 @@ const EXTENSION_FUNCTIONS = {
layer: executeLayer,
colors: executeColors,
textStyles: executeTextStyles,
spacing: executeSpacing
spacing: executeSpacing,
screen: executeScreen,
component: executeComponent
};

function executeFunction(extension, fnName, context, version) {
function executeFunction(extension, fnName, context) {
const fn = EXTENSION_FUNCTIONS[fnName];

if (!fn) {
console.log(chalk.yellow(`Function “${fnName}” not defined.`));
return;
}
fn(extension, context, version);
fn(extension, context);
}

function executeExtension(extension, fnName, defaultOptions = {}) {
Expand All @@ -122,17 +162,18 @@ function executeExtension(extension, fnName, defaultOptions = {}) {
options,
project: sampleData.project
});
const version = new Version(sampleData.version);

if (fnName) {
executeFunction(extension, fnName, context, version);
executeFunction(extension, fnName, context);
return;
}

executeFunction(extension, "layer", context, version);
executeFunction(extension, "colors", context, version);
executeFunction(extension, "textStyles", context, version);
executeFunction(extension, "spacing", context, version);
executeFunction(extension, "colors", context);
executeFunction(extension, "textStyles", context);
executeFunction(extension, "spacing", context);
executeFunction(extension, "component", context);
executeFunction(extension, "screen", context);
executeFunction(extension, "layer", context);
}

module.exports = function (webpackConfig, fnName, defaultOptions, shouldBuild) {
Expand Down
Loading

0 comments on commit 0aa06c6

Please sign in to comment.