pages/public/lit/docs/upgrades.html

43 lines
39 KiB
HTML
Raw Normal View History

<!DOCTYPE html>
<html lang="en-US" dir="ltr">
<head>
<meta charset="utf-8">
<meta name="viewport" content="width=device-width,initial-scale=1">
<title>Upgrades | The Paper Pilot</title>
<meta name="description" content="The Paper Pilot's Digital Garden">
<meta name="generator" content="VitePress v1.2.2">
<link rel="preload stylesheet" href="/assets/style.BhozF2zR.css" as="style">
<script type="module" src="/assets/app.CHK_zzBe.js"></script>
<link rel="preload" href="/assets/inter-roman-latin.Di8DUHzh.woff2" as="font" type="font/woff2" crossorigin="">
<link rel="modulepreload" href="/assets/chunks/framework.CK8QU5WH.js">
<link rel="modulepreload" href="/assets/chunks/theme.Yu_T4Qp5.js">
<link rel="modulepreload" href="/assets/public_lit_docs_upgrades.md.BttvCS4L.lean.js">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Pacifico&amp;family=Roboto+Mono:ital,wght@0,400;0,600;1,400&amp;display=swap">
<link rel="manifest" href="/site.webmanifest">
<link rel="alternate" type="text/mf2+html" href="/changelog">
<link rel="alternate" type="application/rss+xml" title="Changelog" href="/changelog/rss">
<link rel="alternate" type="application/atom+xml" title="Changelog" href="/changelog/atom">
<link rel="alternate" type="application/json+xml" title="Changelog" href="/changelog/json">
<meta name="og:description" content="The Paper Pilot's Digital Garden">
<script id="check-dark-mode">(()=>{const e=localStorage.getItem("vitepress-theme-appearance")||"auto",a=window.matchMedia("(prefers-color-scheme: dark)").matches;(!e||e==="auto"?a:e==="dark")&&document.documentElement.classList.add("dark")})();</script>
<script id="check-mac-os">document.documentElement.classList.toggle("mac",/Mac|iPhone|iPod|iPad/i.test(navigator.platform));</script>
</head>
<body>
<div id="app"><div class="Layout" data-v-5d98c3a5><!--[--><!--[--><!--]--><!--]--><!--[--><span tabindex="-1" data-v-0f60ec36></span><a href="#VPContent" class="VPSkipLink visually-hidden" data-v-0f60ec36> Skip to content </a><!--]--><!----><header class="VPNav" data-v-5d98c3a5 data-v-ae24b3ad><div class="VPNavBar has-sidebar top" data-v-ae24b3ad data-v-ccf7ddec><div class="wrapper" data-v-ccf7ddec><div class="container" data-v-ccf7ddec><div class="title" data-v-ccf7ddec><div class="VPNavBarTitle has-sidebar" data-v-ccf7ddec data-v-ab179fa1><a class="title" href="/" data-v-ab179fa1><!--[--><!--]--><!----><span data-v-ab179fa1>The Paper Pilot</span><!--[--><!--]--></a></div></div><div class="content" data-v-ccf7ddec><div class="content-body" data-v-ccf7ddec><!--[--><!--]--><div class="VPNavBarSearch search" data-v-ccf7ddec><!--[--><!----><div id="local-search"><button type="button" class="DocSearch DocSearch-Button" aria-label="Search"><span class="DocSearch-Button-Container"><span class="vp-icon DocSearch-Search-Icon"></span><span class="DocSearch-Button-Placeholder">Search</span></span><span class="DocSearch-Button-Keys"><kbd class="DocSearch-Button-Key"></kbd><kbd class="DocSearch-Button-Key">K</kbd></span></button></div><!--]--></div><nav aria-labelledby="main-nav-aria-label" class="VPNavBarMenu menu" data-v-ccf7ddec data-v-7f418b0f><span id="main-nav-aria-label" class="visually-hidden" data-v-7f418b0f>Main Navigation</span><!--[--><!--[--><a class="VPLink link vp-external-link-icon VPNavBarMenuLink" href="https://moddingtree.com" target="_blank" rel="noreferrer" tabindex="0" data-v-7f418b0f data-v-9c663999><!--[--><span data-v-9c663999>Profectus</span><!--]--></a><!--]--><!--[--><a class="VPLink link vp-external-link-icon VPNavBarMenuLink" href="https://incremental.social" target="_blank" rel="noreferrer" tabindex="0" data-v-7f418b0f data-v-9c663999><!--[--><span data-v-9c663999>Incremental Social</span><!--]--></a><!--]--><!--]--></nav><!----><div class="VPNavBarAppearance appearance" data-v-ccf7ddec data-v-e6aabb21><button class="VPSwitch VPSwitchAppearance" type="button" role="switch" title="Switch to dark theme" aria-checked="false" data-v-e6aabb21 data-v-d1f28634 data-v-1d5665e3><span class="check" data-v-1d5665e3><span class="icon" data-v-1d5665e3><!--[--><span class="vpi-sun sun" data-v-d1f28634></span><span class="vpi-moon moon" data-v-d1f28634></span><!--]--></span></span></button></div><div class="VPSocialLinks VPNavBarSocialLinks social-links" data-v-ccf7ddec data-v-0394ad82 data-v-7bc22406><!--[--><a class="VPSocialLink no-icon" href="https://code.incremental.social/thepaperpilot" aria-label target="_blank" rel="noopener" data-v-7bc22406 data-v-eee4e7cb><svg role="img" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>Forgejo</title><path d="M16.7773 0c1.6018 0 2.9004 1.2986 2.9004 2.9005s-1.2986 2.9004-2.9004 2.9004c-1.0854 0-2.0315-.596-2.5288-1.4787H12.91c-2.3322 0-4.2272 1.8718-4.2649 4.195l-.0007 2.1175a7.0759 7.0759 0 0 1 4.148-1.4205l.1176-.001 1.3385.0002c.4973-.8827 1.4434-1.4788 2.5288-1.4788 1.6018 0 2.9004 1.2986 2.9004 2.9005s-1.2986 2.9004-2.9004 2.9004c-1.0854 0-2.0315-.596-2.5288-1.4787H12.91c-2.3322 0-4.2272 1.8718-4.2649 4.195l-.0007 2.319c.8827.4973 1.4788 1.4434 1.4788 2.5287 0 1.602-1.2986 2.9005-2.9005 2.9005-1.6018 0-2.9004-1.2986-2.9004-2.9005 0-1.0853.596-2.0314 1.4788-2.5287l-.0002-9.9831c0-3.887 3.1195-7.0453 6.9915-7.108l.1176-.001h1.3385C14.7458.5962 15.692 0 16.7773 0ZM7.2227 19.9052c-.6596 0-1.1943.5347-1.1943 1.1943s.5347 1.1943 1.1943 1.1943 1.1944-.5347 1.1944-1.1943-.5348-1.1943-1.1944-1.1943Zm9.5546-10.4644c-.6596 0-1.1944.5347-1.1944 1.1943s.5348 1.1943 1.1944 1.1943c.6596 0 1.1943-.5347 1.1943-1.1943s-.5347-1.1943-1.1943-1.1943Zm0-7.7346c-.6596 0-1.1944.5347-1.1944 1.1943s.5348 1.1943 1.1944 1.1943c.6596 0 1.1943-.5347 1.1943-1.1943s-.5347-1.1943-1.1943-1.1943Z"/></svg></a><a class="VPSocialLink no-icon" href="https://matrix.to/#/@thepaperpilot:incremental.social" aria-label target="_blank" rel="noopener" data-v-7bc22406 data-v-eee4e7cb><svg role="img
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> rows</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: # </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">of</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> rows,</span></span>
<span class="line"><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> cols</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: # </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">of</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> columns,</span></span>
<span class="line"><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;"> 11</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">: {</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> description: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Blah&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> cost: </span><span style="--shiki-light:#D73A49;--shiki-dark:#F97583;">new</span><span style="--shiki-light:#6F42C1;--shiki-dark:#B392F0;"> Decimal</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">(</span><span style="--shiki-light:#005CC5;--shiki-dark:#79B8FF;">100</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">),</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> etc</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> },</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> etc</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">}</span></span></code></pre></div><p>Each upgrade should have an id where the first digit is the row and the second digit is the column.</p><p>Individual upgrades can have these features:</p><ul><li><p>title: <strong>optional</strong>. Displayed at the top in a larger font. It can also be a function that returns updating text. Can use basic HTML.</p></li><li><p>description: A description of the upgrade&#39;s effect. <em>You will also have to implement the effect where it is applied.</em> It can also be a function that returns updating text. Can use basic HTML.</p></li><li><p>effect(): <strong>optional</strong>. A function that calculates and returns the current values of any bonuses from the upgrade. Can return a value or an object containing multiple values.</p></li><li><p>effectDisplay(): <strong>optional</strong>. A function that returns a display of the current effects of the upgrade with formatting. Default displays nothing. Can use basic HTML.</p></li><li><p>fullDisplay(): <strong>OVERRIDE</strong>. Overrides the other displays and descriptions, and lets you set the full text for the upgrade. Can use basic HTML.</p></li><li><p>cost: A Decimal for the cost of the upgrade. By default, upgrades cost the main prestige currency for the layer.</p></li><li><p>unlocked(): <strong>optional</strong>. A function returning a bool to determine if the upgrade is visible or not. Default is unlocked.</p></li><li><p>onPurchase(): <strong>optional</strong>. This function will be called when the upgrade is purchased. Good for upgrades like &quot;makes this layer act like it was unlocked first&quot;.</p></li><li><p>style: <strong>optional</strong>. Applies CSS to this upgrade, in the form of an object where the keys are CSS attributes, and the values are the values for those attributes (both as strings).</p></li><li><p>layer: <strong>assigned automagically</strong>. It&#39;s the same value as the name of this layer, so you can do <code>player[this.layer].points</code> or similar.</p></li><li><p>id: <strong>assigned automagically</strong>. It&#39;s the &quot;key&quot; which the upgrade was stored under, for convenient access. The upgrade in the example&#39;s id is 11.</p></li></ul><p>By default, upgrades use the main prestige currency for the layer. You can include these to change them (but it needs to be a Decimal):</p><ul><li><p>currencyDisplayName: <strong>optional</strong>. The name to display for the currency for the upgrade.</p></li><li><p>currencyInternalName: <strong>optional</strong>. The internal name for that currency.</p></li><li><p>currencyLayer: <strong>optional</strong>. The internal name of the layer that currency is stored in. If it&#39;s not in a layer (like Points), omit. If it&#39;s not stored directly in a layer, instead use the next feature.</p></li><li><p>currencyLocation: <strong>optional</strong>. If your currency is stored in something inside a layer (e.g. a buyable&#39;s amount), you can access it this way. This is a function returning the object in &quot;player&quot; that contains the value (like <code>player[this.layer].buyables</code>)</p></li></ul><p>If you want to do something more complicated like upgrades that cost two currencies, you can override the purchase system with these (and you need to use fullDisplay as well)</p><ul><li><p>canAfford(): <strong>OVERRIDE</strong>, a function determining if you are able to buy the upgrade</p></li><li><p>pay(): <strong>OVERRIDE</strong>, a function that reduces your currencies when you buy the upgrade</p></li></ul></div></div></main><footer class="VPDocFooter" data-v-39a288b8 data-v-d4a0bba5><!--[--><!--]--><!----><nav class="prev-next" aria-labelledby="doc-footer-aria-label" data-v-d4a0bba5><span class="visually-hidden" id="doc-footer-aria-label" data-v-d4a0bba5>Pager</span><div class="pager" data-v-d4a0bba5><!----></div><div class="pager" data-v-d4a0bba5><a class="VPLink link pager-link next" href="/garden/my-personal-website" data-v-d4a0bba5><!--[--><span class="desc" data-v-d4a0bba5
">this commit</a> on <time>Saturday, June 15, 2024 at 09:50:22
</time>.</div></footer><!--]--></div></div>
<script>window.__VP_HASH_MAP__=JSON.parse("{\"garden_capture-the-citadel_index.md\":\"CzfQmks-\",\"garden_babble-buds_index.md\":\"D3H2b176\",\"garden_chat-glue_index.md\":\"DaP2yUVG\",\"garden_chronological_index.md\":\"CQEy-T7E\",\"garden_advent-incremental_index.md\":\"C8yXdubg\",\"garden_guide-to-incrementals_navigating-criticism_index.md\":\"FUIN6tkG\",\"garden_command-palettes_index.md\":\"aFoJwvWM\",\"garden_commune_index.md\":\"CYBiMD5k\",\"garden_davey-wreden_index.md\":\"DUU5axE-\",\"garden_cinny_index.md\":\"6lP2Zwso\",\"garden_freeform-vs-chronological-dichotomy_index.md\":\"CC0rVLI6\",\"changelog_index.md\":\"BSJxDqIW\",\"garden_fedi-v2_index.md\":\"BeyeCI12\",\"garden_the-small-web_index.md\":\"oczIBNHW\",\"garden_this-knowledge-hub_index.md\":\"CUdFhZdq\",\"garden_freeform_index.md\":\"CvO7JCJh\",\"garden_digital-gardens_index.md\":\"-_Ah0Mkb\",\"garden_guide-to-incrementals_index.md\":\"CTF2sqnA\",\"garden_decentralized_index.md\":\"Cbrt43lP\",\"garden_guide-to-incrementals_defining-the-genre_index.md\":\"DC5Wks2J\",\"garden_garden-rss_index.md\":\"CeZWgVca\",\"garden_dice-armor_index.md\":\"CHYRQr4z\",\"garden_guide-to-incrementals_what-is-content_index.md\":\"BMETYiAP\",\"garden_mtx_index.md\":\"BRzkTeai\",\"garden_my-projects_index.md\":\"6zAg17w1\",\"garden_my-personal-website_index.md\":\"BhgZsyb6\",\"garden_nostr_index.md\":\"CgleUUbP\",\"garden_opti-speech_index.md\":\"fV3laAf8\",\"garden_open-source_index.md\":\"CrbIsKOD\",\"garden_planar-pioneers_index.md\":\"C66vsCjv\",\"garden_pre-order-bonuses_index.md\":\"C0-qMrbr\",\"garden_premium-currency_index.md\":\"CYRzDOj_\",\"garden_profectus_index.md\":\"ykiRoiHE\",\"garden_guide-to-incrementals_appeal-to-developers_index.md\":\"Diny6WsX\",\"garden_synapse_index.md\":\"C51ajr4V\",\"garden_the-beginner-s-guide_index.md\":\"BdmIJg3j\",\"garden_the-cozy-web_index.md\":\"BEzt5FqQ\",\"garden_ivy-road_index.md\":\"I5lUYnjM\",\"garden_social-media_index.md\":\"BbHjayFv\",\"garden_the-indieweb_amplification_index.md\":\"DT2TYsGY\",\"garden_artificial-intelligence_index.md\":\"DHIZV-Nf\",\"garden_video-game-monetization_index.md\":\"eY03jnxc\",\"garden_wanderstop_index.md\":\"BTJMeiHB\",\"garden_webrings_index.md\":\"DVn_-9-u\",\"garden_vitepress_index.md\":\"CDGDOV5f\",\"guide-to-incrementals_design_criticism_index.md\":\"DIKhcyDO\",\"garden_v-ecs_index.md\":\"DJKtb91L\",\"guide-to-incrementals_ludology_appeal-gamers_index.md\":\"B6xF3S0w\",\"guide-to-incrementals_index.md\":\"CnOUEXtw\",\"guide-to-incrementals_ludology_appeal-developers_index.md\":\"Cm_ScJQR\",\"garden_weird_index.md\":\"5UcMgku5\",\"guide-to-incrementals_ludology_content_index.md\":\"DktkMXz1\",\"public_gamedevtree_readme.md\":\"C_ZitREW\",\"public_gamedevtree_changelog.md\":\"DGS-7PiF\",\"garden_incremental-social_index.md\":\"B0XsBHzM\",\"public_gamedevtree_2.0-format-changes.md\":\"3MaMo5-m\",\"garden_logseq_index.md\":\"BiLoV0bt\",\"garden_matrix_index.md\":\"CeSXZSDm\",\"garden_kronos_index.md\":\"iUhWCop9\",\"garden_life-is-strange_index.md\":\"tdVgcS32\",\"public_gamedevtree_docs_achievements.md\":\"DrDgZswR\",\"public_gamedevtree_docs_!general-info.md\":\"BwFSZwbZ\",\"garden_forgejo_index.md\":\"2k8RiG3S\",\"garden_fediverse_index.md\":\"C7LEB0uc\",\"garden_mbin_index.md\":\"BHK-Iuf3\",\"public_gamedevtree_docs_milestones.md\":\"DiBU9uxR\",\"public_kronos_readme.md\":\"CgBYWZCx\",\"public_kronos_changelog.md\":\"CfILpf_9\",\"public_kronos_docs_basic-layer-breakdown.md\":\"Zf7IGRAq\",\"public_lit_docs_challenges.md\":\"BoYK1lsk\",\"public_kronos_docs_buyables.md\":\"DaAxmRa3\",\"public_kronos_docs_!general-info.md\":\"h8u1FelN\",\"public_kronos_docs_clickables.md\":\"BvrZ942x\",\"public_kronos_docs_challenges.md\":\"DjtWlrsA\",\"public_kronos_docs_getting-started.md\":\"mdR9VU7R\",\"public_kronos_docs_custom-tab-layouts.md\":\"C9uDrIM0\",\"public_kronos_docs_achievements.md\":\"DH7Fd1ef\",\"public_kronos_docs_grids.md\":\"BeCPe1VG\",\"public_kronos_docs_infoboxes.md\":\"cE2lKUcU\",\"public_kronos_docs_bars.md\":\"C-Hikk54\",\"public_kronos_docs_layer-features.md\":\"sKwRGXXx\",
</body>
</html>