Skip to content

Latest commit

 

History

History
122 lines (68 loc) · 8.61 KB

elements.md

File metadata and controls

122 lines (68 loc) · 8.61 KB

Figmagic Element Sync

Note: You should pay attention to the expected Figma structure for Element Sync to work. Expect that several features—such as images—are still unsupported. You should definitely still continue to layout your elements/components as they should look in their final state, but understand that the output is likely not 100% complete right after generation, nor will it always work if you do anything unsupported.

Philosophy

Following the primary principle of atomic design, Figmagic wants you to build from the bottom up, beginning with decomposing the tokens. Tokens shape elements, which form components, that are ordered in compositions, which get presented in views... You know the drill, though I am switching Brad Frost's nomenclature into something more front-end friendly.

When it comes to code generation, Figmagic tries to do this in a better way. Instead of over-eagerly promoting hardcoded code generation from huge and complex components, Figmagic tries to competently, or at least "mostly-right", handle automation for things that should not be too context-dependent or manual input-heavy. Code should also be as close to "normal" as possible—meaning that generated code binds values to tokens and not some random px values as other platforms do. All of this can happen because Figmagic assumes a way of working that respects standard CSS and HTML: no magic trickery! Figmagic avoids some of the cognitive and technical overhead by introducing a concept called Elements, which are Figmagic-compliant components that can be output into code. By composing larger components out of simple Elements, code generation is made much more manageable while also promoting much more structured design.

Rationale

Elements are named so because they are primarily meant to help scaffold anything that maps to standard HTML elements like input, button, h1, and form. With scaffolding we mean that these elements can be generated as code in a shape that is fitting for continued development—not necessarily final and done, when it arrives steaming hot from your CLI.

Elements are a good entry point both for design and for code generation, since they are relatively simple and as a concept map to HTML which is based on using tags ("elements").

Flat or nested elements?

You can generate simple flat elements or nested ones. Use flat elements for anything that is usually less complex (like hr and headings like h1), and go for nested elements when you want more advanced or “stateful” behavior like buttons being invalid, disabled or if you need subclasses (maybe something like "Warning" and "Error" states).

It's highly recommended that you open and inspect some of the elements in the Figmagic template to see both patterns!

You can technically make nested elements as deep as you want, but Figmagic will currently only generate code based on the two first nested layers (depth-wise)—this is so Figmagic can support the common pattern of Component > Option/Style/Type > State. Nesting can use either a "subclass" (by having a group or frame), or a pseudo-selector (by using a group or frame prefixed with colon, like ":disabled"). Note that you may mix these as you wish, even something awful like Component > State > State if you need that! :)

Figmagic lets you style elements through typography and/or layout layers. These are communicated through a text layer (Figma's TEXT layer for typography) and a non-text layer (such as Figma's RECTANGLE layer) for layout.

The name of the React component will be taken from the component name. Subclasses and pseudo-selectors will be named by their group/frame name.

Nesting: Button, Normal

Nesting: Button. "Normal" state. Notice how the underscore is blocking ":disabled" and ":hover".

Nesting: Button, Warning

Nesting: Button. "Warning" state.

Nesting: Button, Error

Nesting: Button. "Error" state.

Nesting: Generated code

Nesting: Generated code. Notice how the nested group/frame names became CSS classes. Only the differences in those layers were promoted to their own class, eliminating redundant code.

Describing your element

Further description and element choice is made in the right-hand side Description panel. Click a Figma component in the Figmagic template to see how various elements are set up.

You can write use the following descriptors in Figma's component description field to shape your code generation:

  • description={DESCRIPTION}: defines the text description that will be output to text/markdown. Example: description=This is an input element with three styles.
  • element={ELEMENT}: defines the actual generated element type. Example: element=input.
  • type={TYPE}: becomes an element property. Useful for complex elements like input. Example: type=checkbox.

Nesting: Button, Normal

Setting what the Figma component should generate in HTML terms. Also, notice how we are typing out the description for our Markdown file which can be used in, for example, Storybook.

Using pseudo selectors

You can prefix your layer/group/frame with : to set/communicate a pseudo-selector (like :hover) during code generation.

Ignore a layer

A _ (underscore) character makes anything prefixed with it ignored during the generation step. Use this for meta-information, redlines or other things you might need to communicate your design, but which should not affect the code generation.

Nesting: Button, Normal

Prefixing with an underscore means we can avoid the conflict, but still clearly communicate intended behavior and style.

Tip: Redlines

Pro tip: Use a plugin like Figma Redlines to communicate hard-to-see tokens/features like the padding inside of an Input element. Don’t forget to add a prefixing _ so Figmagic can safely ignore the redlines.

Details

  • You can provide your own templates through .figmagicrc/.figmagicrc or the CLI; for expected shape see /templates in the Figmagic source code.
  • You can skip code generation for any of the 5 generated file types through CLI or .figmagicrc/.figmagicrc.
  • You can pass in --forceUpdate to force all generated files to be updated.

For specifics on how to do any CLI or RC file configuration, see documentation below.

Figma Document Structure: Elements

How a Figmagic project could be structured with elements

Caveats, issues and gotchas

First and foremost:

Example of flat element

Element Sync will not solve all of your issues and you will have to creatively work around some of the current limitations in Figmagic. For example, in the case above the check is not in the actual component, as it would not be correctly picked up by Figmagic. In this case, we want to communicate design and intent to developers, but not break the code, thus moving the check out and leaving the rest in. That should solve a lot of the boilerplate work, at least, but the check needs to be added manually afterwards. Assume that you will always need to do some work! Just that it should be a lot less than without Figmagic :)

Flat elements

Example of flat element

Flat elements should be enough for most basic use cases. Don't forget to name the layout layer to the same name as your Figma component or it will break during generation!

  • Don’t use more than one object with a fill in an element – you will get only one background/background-color!
  • Elements are not self-closing (i.e. they are always <element></element> rather than <element />).
  • Cannot combine groups/frames AND flat/non-nested styling inside an element.
  • Linear gradient is supported, but it does not use "gradientHandlePositions”.

Nested elements

  • Layer order matters in nested elements! It will always pick the first layout or text element it finds.
  • Currently only a single layout element per group/frame/nested layer will be picked up.

Also note that:

  • Nested elements should ideally have a text element in order to avoid breaking or getting strange CSS/behavior. This layer does not have to be visible!

Incomplete list of things that are not yet supported

  • Linear and Radial Gradients are supported, but no other types
  • Layout constraints
  • Layout grid
  • Images and vectors in elements
  • Blend modes