Skip to content

Instantly share code, notes, and snippets.

@jsejcksn
Created February 29, 2020 23:25
Show Gist options
  • Star 0 You must be signed in to star a gist
  • Fork 0 You must be signed in to fork a gist
  • Save jsejcksn/ed0ba21cd8b390a82e5acffe697dc090 to your computer and use it in GitHub Desktop.
Save jsejcksn/ed0ba21cd8b390a82e5acffe697dc090 to your computer and use it in GitHub Desktop.
Create multiple components from top level layers in Figma
(numberOfComponentsToMake => {
const wait = ms => new Promise(res => setTimeout(res, ms));
const target = document.querySelector('canvas');
const makeComponentFromSelectedLayer = () => target.dispatchEvent(new KeyboardEvent(
'keydown',
{
altKey: true,
keyCode: 75,
metaKey: true,
},
));
const selectNextLayer = () => target.dispatchEvent(new KeyboardEvent(
'keydown',
{keyCode: 9},
));
const makeComponentsFromTopLayers = async numberOfComponentsToMake => {
for (let i = 0; i < numberOfComponentsToMake; i += 1) {
makeComponentFromSelectedLayer();
await wait(200);
selectNextLayer();
await wait(50);
}
};
makeComponentsFromTopLayers(numberOfComponentsToMake);
})(2); // Change this from 2 to however many you want to make
Sign up for free to join this conversation on GitHub. Already have an account? Sign in to comment