profectus-docs/docs/guide/important-concepts/layers.md

12 lines
1.1 KiB
Markdown
Raw Permalink Normal View History

2022-03-03 01:28:57 +00:00
# Layers
2022-07-10 06:56:39 +00:00
Profectus content is organized into units called "Layers". When displaying content to the user, the screen will be divided into several tabs that each display the content of a layer. These layers are stored in `/src/data/layers`.
2022-03-03 01:28:57 +00:00
Each layer is ultimately a collection of different features, and a display function. While there are a couple reserved properties for layers, most of its structure is fully up to the creator.
2022-07-17 22:25:15 +00:00
Layers can be dynamically added or removed at any time, which also allows for effectively disabling or enabling content based on arbitrary conditions. Just make sure [getInitialLayers](../creating-your-project/project-entry.md#getinitiallayers) can process the player save data object and determine which layers should be currently active.
2022-03-06 04:34:42 +00:00
## Lazy Proxies
Layers (and features) are not actually created immediately. Instead, their options are gotten through a function which is then run the first time something _inside_ the layer is accessed. This is a concept called lazy evaluation, which is also used for things like `computed`, and allows for features to reference each other without worrying about cyclical dependencies.