Skip to main content

Section Generator

Create a theme section

Usage#

$ nx generate section [options,...]
$ nx g sec [options,...] # same

By default, Nx will search for the section generator in the default collection provisioned in workspace.json.

You can specify the collection explicitly as follows:

$ nx g @trafilea/nx-shopify:section [options,...]

Show what will be generated without writing to disk:

$ nx g section [options,...] --dry-run

Examples#

Generate a section in the my-theme theme:

$ nx g section my-section --project=my-theme

This creates the following files:

apps
โ””โ”€โ”€ my-theme
โ””โ”€โ”€ src
   โ””โ”€โ”€ theme
      โ”œโ”€โ”€ layout
      โ”œโ”€โ”€ sections
+       |   โ””โ”€โ”€ my-section
+       |      โ”œโ”€โ”€ my-section.section.scss
+       |      โ”œโ”€โ”€ my-section.section.ts
+       |      โ””โ”€โ”€ my-section.liquid
      โ”œโ”€โ”€ snippets
      โ””โ”€โ”€ templates

The my-section.section.ts file exports a MySectionSection class that now you can import in any other theme block (layout, template, snippet or other section).

Options#

--name#

Type: string

The name of the section.

--project#

Alias(es): p

Type: string

The name of the project where the section will be generated.

--directory#

Alias(es): d

Type: string

Create the section under this directory relative to src/theme/sections (can be nested).

--flat#

Default: false

Type: boolean

Create section files at the directory root rather than its own directory.

--liquidOnly#

Default: false

Type: boolean

When true, does not create files other than the liquid file for the new section.

--skipTests#

Default: false

Type: boolean

When true, does not create \"spec.ts\" test files for the new section.