Create a component¶
Components are parts of a snap that can be built and uploaded in conjunction
with a snap and later optionally installed beside it. Components are defined
with a top-level components key in the project file.
Start with a simple project file:
name: hello-components
version: "1.0"
summary: A snap with a component
description: A simple snap with a component containing translations
base: core24
confinement: strict
parts:
  application:
    source: src
    plugin: dump
And create the following project tree:
.
└── src
    └── my-app
my-app can be an empty file. The contents are not important for this
how-to guide.
To create a component, define a component called translations under
a new top-level components key. We will also add a new part that
dumps the contents of the translations directory:
name: hello-components
version: "1.0"
summary: A snap with a component
description: A simple snap with a component containing translations
base: core24
confinement: strict
components:
  translations:
    type: standard
    summary: Translations modules
    description: Translations modules
    version: "1.0"
parts:
  application:
    source: src
    plugin: dump
  translations:
    source: translations
    plugin: dump
Next, create a translations directory with a file called la:
.
├── src
│   └── my-app
└── translations
    └── la
la can also be an empty file.
Pack the snap with:
snapcraft pack
This will produce 2 artifacts, the snap and the component:
- hello-components_1.0_amd64.snap
- hello-components+translations_1.0.comp
The my-app and la files are staged, primed, and packed in the snap
artifact. The component artifact has no payload. It is empty except for a
metadata file meta/component.yaml.
To move the la translation file to the component artifact, use the
organize key for the translations part:
name: hello-components
version: "1.0"
summary: A snap with a component
description: A simple snap with a component containing translations
base: core24
confinement: strict
components:
  translations:
    type: standard
    summary: Translations modules
    description: Translations modules
    version: "1.0"
parts:
  application:
    source: src
    plugin: dump
  translations:
    source: translations
    plugin: dump
    organize:
      la: (component/translations)
The parentheses around (component/translations) indicate that the files
should be organized into the translations component’s install directory.
Pack the snap again with:
snapcraft pack
This will produce two artifacts again but the component now contains the
la translation file.
To upload the snap and the component to the store, specify the snap file
and the component file for the translations component.
snapcraft upload hello-components_1.0_amd64.snap \
  --component translations=hello-components+translations_1.0.comp
The store expects a snap and its components to be uploaded together.
The component has to be uploaded alongside the snap.
