<spanclass="line"><spanstyle="color:#A6ACCD;"></span><spanstyle="color:#F07178;">title</span><spanstyle="color:#89DDFF;">:</span><spanstyle="color:#A6ACCD;"></span><spanstyle="color:#89DDFF;">"</span><spanstyle="color:#C3E88D;">Generator of Genericness</span><spanstyle="color:#89DDFF;">"</span><spanstyle="color:#89DDFF;">,</span></span>
<spanclass="line"><spanstyle="color:#A6ACCD;"></span><spanstyle="color:#F07178;">description</span><spanstyle="color:#89DDFF;">:</span><spanstyle="color:#A6ACCD;"></span><spanstyle="color:#89DDFF;">"</span><spanstyle="color:#C3E88D;">Gain 1 point every second</span><spanstyle="color:#89DDFF;">"</span></span>
<spanclass="line"></span></code></pre></div><p>The result will be a <ahref="./layers.html#lazy-proxies">lazy proxy</a> of the feature being created. The feature can then be used throughout the rest of the layer. The main thing to keep in mind when creating features is that they should typically be included in the layer object that gets returned. If a feature has any <ahref="./reactivity.html#persistent">persistent refs</a> they must be included or else they will not have their values saved and loaded correctly.</p><p>While the structure of layers is intentionally left up to the creator, it is recommended to avoid storing them in arrays. If you ever remove an upgrade from an array, or add an upgrade in between others, then it will interfere with the save data of existing users. You can manually fix these issues in <ahref="./../creating-your-project/project-entry.html#fixoldsave">fixOldSave</a>, but it's recommended to avoid the error entirely.</p><p>Since usually you want to access a specific feature, storing them in an object is much more reliable and makes the code easier to read. For things like checking number of upgrades bought, for example, you can still use <code>Object.values</code> to get an array of the objects instead.</p><h4id="example"tabindex="-1">Example <aclass="header-anchor"href="#example"aria-hidden="true">#</a></h4><divclass="language-ts"><spanclass="copy"></span><pre><code><spanclass="line"><spanstyle="color:#C792EA;">const</span><spanstyle="color:#A6ACCD;"> upgrades </span><spanstyle="color:#89DDFF;">=</span><spanstyle="color:#A6ACCD;"></span><spanstyle="color:#89DDFF;">{</span><spanstyle="color:#A6ACCD;"> addGainUpgrade</span><spanstyle="color:#89DDFF;">,</span><spanstyle="color:#A6ACCD;"> gainMultUpgrade</span><spanstyle="color:#89DDFF;">,</span><spanstyle="color:#A6ACCD;"> upgMultUpgrade </span><spanstyle="color:#89DDFF;">};</span></span>
<spanclass="line"></span></code></pre></div><h2id="tree-shaking"tabindex="-1">Tree Shaking <aclass="header-anchor"href="#tree-shaking"aria-hidden="true">#</a></h2><p>Since Profectus takes advantage of <ahref="https://developer.mozilla.org/en-US/docs/Glossary/Tree_shaking"target="_blank"rel="noopener noreferrer">tree shaking</a>, and type of feature that is not used will not be included in the output of the project. That means users have less code to download, a slight performance boost, and you don't need to worry about feature type-specific settings appearing (such as whether to show maxed challenges).</p><p>It should be noted that a couple features depend on each other, such as Buyables depending on Clickables. That means you may see features included in the output despite not directly using them. Some features, such as Links and Tooltips, are used by the engine itself and will always be included in the output.</p></div></div></main><footerclass="VPDocFooter"data-v-79ca2460data-v-04568844><divclass="edit-info"data-v-04568844><divclass="edit-link"data-v-04568844><aclass="VPLink link edit-link-button"href="https://github.com/profectus-engine/profectus-docs/edit/main/docs/guide/important-concepts/features.md"target="_blank"rel="noopener noreferrer"data-v-04568844data-v-5704c677><!--[--><svgxmlns="http://www.w3.org/2000/svg"viewbox="0 0 24 24"class="edit-link-icon"data-v-04568844><pathd="M18,23H4c-1.7,0-3-1.3-3-3V6c0-1.7,1.3-3,3-3h7c0.6,0,1,0.4,1,1s-0.4,1-1,1H4C3.4,5,3,5.4,3,6v14c0,0.6,0.4,1,1,1h14c0.6,0,1-0.4,1-1v-7c0-0.6,0.4-1,1-1s1,0.4,1,1v7C21,21.7,19.7,23,18,23z"></path><pathd="M8,17c-0.3,0-0.5-0.1-0.7-0.3C7,16.5,6.9,16.1,7,15.8l1-4c0-0.2,0.1-0.3,0.3-0.5l9.5-9.5c1.2-1.2,3.2-1.2,4.4,0c1.2,1.2,1.2,3.2,0,4.4l-9.5,9.5c-0.1,0.1-0.3,0.2-0.5,0.3l-4,1C8.2,17,8.1,17,8,17zM9.9,12.5l-0.5,2.1l2.1-0.5l9.3-9.3c0.4-0.4,0.4-1.1,0-1.6c-0.4-0.4-1.2-0.4-1.6,0l0,0L9.9,12.5z M18.5,2.5L18.5,2.5L18.5,2.5z"></path></svg> Edit this page<!--]--><!----></a></div><divclass="last-updated"data-v-04568844><pclass="VPLastUpdated"data-v-04568844data-v-0ce8c960>Last updated: <timedatatime="2022-07-18T02:39:15.000Z"data-v-0ce8c960></time></p></div></div><divclass="prev-next"data-v-04568844><divclass="pager"data-v-04568844><aclass="pager-link prev"href="/guide/important-concepts/layers.html"data-v-04568844><spanclass="desc"data-v-04568844>Previous page</span><spanclass="title"data-v-04568844>Layers</span></a></div><divclass="has-prev pager"data-v-04568844><aclass="pager-link next"href="/guide/important-concepts/coercable.html"data-v-04568844><spanclass="desc"data-v-04568844>Next page</span><spanclass="title"data-v-04568844>Coercable Components</span></a></div></div></footer><!--[--><!--]--></div></div></div></div></div><!----><!--[--><!--]--></div></div>