pages/public/lit/docs/challenges.html

51 lines
40 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>Challenges | 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._tUlNt0e.css" as="style">
<script type="module" src="/assets/app.BEXbn4eK.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.VBE0TPts.js">
<link rel="modulepreload" href="/assets/chunks/theme.V-cXOrbT.js">
<link rel="modulepreload" href="/assets/public_lit_docs_challenges.md.BXbZcSAe.lean.js">
<link rel="preconnect" href="https://fonts.googleapis.com">
<link rel="stylesheet" href="https://fonts.googleapis.com/css2?family=Itim&amp;family=Roboto+Mono:ital,wght@0,400;0,600;1,400&amp;display=block">
<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">
<link rel="me" href="mailto:thepaperpilot@incremental.social">
<link rel="me" href="https://incremental.social/u/thepaperpilot">
<link rel="me" href="https://matrix.to/#/@thepaperpilot:incremental.social">
<link rel="me" href="https://code.incremental.social/thepaperpilot">
<link rel="me" href="https://www.linkedin.com/in/anthony-lawn/">
<link rel="me" href="https://mastodon.gamedev.place/@thepaperpilot">
<link rel="me" href="https://beehaw.org/u/thepaperpilot">
<link rel="me" href="https://www.reddit.com/user/ThePaperPilot/">
<link rel="me" href="https://github.com/thepaperpilot">
<link rel="me" href="https://twitter.com/ThePaperPilot">
<meta name="og:description" content="The Paper Pilot's Digital Garden">
<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-21c9c845 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="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" viewBox="0 0 24 24" xmlns="http://www.w3.org/2000/svg"><title>Matrix</title><path d="M.632.55v22.9H2.28V24H0V0h2.28v.55zm7.043 7.26v1.157h.033c.309-.443.683-.784 1.117-1.024.433-.245.936-.365 1.5-.365.54 0 1.033.107 1.481.314.448.208.785.582 1.02 1.108.254-.374.6-.706 1.034-.992.434-.287.95-.43 1.546-.43.453 0 .872.056 1.26.167.388.11.716.286.993.53.276.245.489.559.646.951.152.392.23.863.23 1.417v5.728h-2.349V11.52c0-.286-.01
<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;"> name: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;Ouch&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> challengeDescription: </span><span style="--shiki-light:#032F62;--shiki-dark:#9ECBFF;">&quot;description of ouchie&quot;</span><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;">,</span></span>
<span class="line"><span style="--shiki-light:#24292E;--shiki-dark:#E1E4E8;"> goal: </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 challenge should have an id where the first digit is the row and the second digit is the column.</p><p>Individual Challenges can have these features:</p><ul><li><p>name: Name of the challenge, can be a string or a function. Can use basic HTML.</p></li><li><p>challengeDescription: A description of what makes the challenge a challenge. <em>You will need to implement these elsewhere.</em> It can also be a function that returns updating text. Can use basic HTML.</p></li><li><p>goalDescription: A description of the win condition for the challenge. It can also be a function that returns updating text. Can use basic HTML. (Optional if using the old goal system)</p></li><li><p>canComplete(): A function that returns true if you meet the win condition for the challenge. Returning a number will allow bulk completing the challenge. (Optional if using the old goal system)</p></li><li><p>rewardDescription: A description of the reward&#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>rewardEffect(): <strong>optional</strong>. A function that calculates and returns the current values of any bonuses from the reward. Can return a value or an object containing multiple values. Can use basic HTML.</p></li><li><p>rewardDisplay(): <strong>optional</strong>. A function that returns a display of the current effects of the reward with formatting. Default behavior is to just display the a number appropriately formatted.</p></li><li><p>fullDisplay(): <strong>OVERRIDE</strong>. Overrides the other displays and descriptions, and lets you set the full text for the challenge. Can use basic HTML.</p></li><li><p>unlocked(): <strong>optional</strong>. A function returning a bool to determine if the challenge is visible or not. Default is unlocked.</p></li><li><p>onComplete() - <strong>optional</strong>. this function will be called when the challenge is completed when previously incomplete.</p></li><li><p>countsAs: <strong>optional</strong>. If a challenge combines the effects of other challenges in this layer, you can use this. An array of challenge ids. The player is effectively in all of those challenges when in the current one.</p></li><li><p>completionLimit: <strong>optional</strong>. the amount of times you can complete this challenge. Default is 1 completion.</p></li><li><p>style: <strong>optional</strong>. Applies CSS to this challenge, 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 player[this.layer].points or similar</p></li><li><p>id: <strong>assigned automagically</strong>. It&#39;s the &quot;key&quot; which the challenge was stored under, for convenient access. The challenge in the example&#39;s id is 11.</p></li></ul><p>The old goal system uses these features:</p><ul><li><p>goal: <strong>deprecated</strong>, A Decimal for the amount of currency required to beat the challenge. By default, the goal is in basic Points. The goal can also be a function if its value changes.</p></li><li><p>currencyDisplayName: <strong>deprecated</strong>. the name to display for the currency for the goal</p></li><li><p>currencyInternalName: <strong>deprecated</strong>. the internal name for that currency</p></li><li><p>currencyLayer: <strong>deprecated</strong>. the internal name of the layer that currency is stored in. If it&#39;s not in a layer, omit. If it&#39;s not stored directly in a layer, instead use the next feature.</p></li><li><p>currencyLocation(): <strong>deprecated</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]
<script>window.__VP_HASH_MAP__=JSON.parse("{\"garden_command-palettes_index.md\":\"BVwsa__o\",\"garden_chat-glue_index.md\":\"dlr0_Ths\",\"garden_activitypub_index.md\":\"C2jvyzca\",\"garden_chronological_index.md\":\"CzMpf9Bb\",\"garden_commune_index.md\":\"BfE3wP4n\",\"garden_capture-the-citadel_index.md\":\"Dp1p37C8\",\"garden_artificial-intelligence_index.md\":\"D882qy1E\",\"garden_dice-armor_index.md\":\"B59qJeSF\",\"garden_davey-wreden_index.md\":\"48RUIvDX\",\"garden_decentralized_index.md\":\"DAeSvslw\",\"about_index.md\":\"p-omr8fP\",\"garden_atproto_index.md\":\"DrA8bnpw\",\"garden_digital-gardens_index.md\":\"D6i3pydj\",\"garden_fedi-v2_index.md\":\"Ck-Q2XWh\",\"garden_forgejo_index.md\":\"BCgWpBMP\",\"garden_babble-buds_index.md\":\"Betepniw\",\"changelog_index.md\":\"Se52YaZv\",\"garden_federated-identity_index.md\":\"DauN0quA\",\"garden_garden-rss_index.md\":\"BGEknOtc\",\"garden_cinny_index.md\":\"t1OL3Djs\",\"garden_game-dev-tree_index.md\":\"DJw6pU1G\",\"garden_guide-to-incrementals_appeal-to-players_index.md\":\"DNZaS9f6\",\"garden_fediverse_index.md\":\"BRr7ZnRh\",\"garden_guide-to-incrementals_navigating-criticism_index.md\":\"DvwfqkK2\",\"garden_guide-to-incrementals_appeal-to-developers_index.md\":\"CICsWpD6\",\"garden_advent-incremental_index.md\":\"CkR1VhAE\",\"garden_guide-to-incrementals_index.md\":\"C-36iTkx\",\"garden_freeform-vs-chronological-dichotomy_index.md\":\"ChVn1VZx\",\"garden_freeform_index.md\":\"NDdWQiN7\",\"garden_planar-pioneers_index.md\":\"CFFWYc6B\",\"garden_life-is-strange_index.md\":\"WlejATLm\",\"garden_logseq_index.md\":\"BoAvqEZD\",\"garden_matrix_index.md\":\"07cPtnSJ\",\"garden_mbin_index.md\":\"Bc0vlims\",\"garden_mtx_index.md\":\"BhvcWtAe\",\"garden_my-personal-website_index.md\":\"DICu3x5Z\",\"garden_my-projects_index.md\":\"DjKkWmAg\",\"garden_open-source_index.md\":\"C0Vl5wh5\",\"garden_weird_index.md\":\"IKYwtarG\",\"guide-to-incrementals_design_criticism_index.md\":\"090INe-t\",\"garden_nostr_index.md\":\"DXwBhUeX\",\"guide-to-incrementals_ludology_appeal-developers_index.md\":\"DUjS9La0\",\"guide-to-incrementals_ludology_appeal-gamers_index.md\":\"kvs7bBtc\",\"guide-to-incrementals_index.md\":\"BvKTgXfo\",\"guide-to-incrementals_ludology_content_index.md\":\"CbV8ckI1\",\"index.md\":\"BanIo7zz\",\"public_kronos_docs_milestones.md\":\"Ce7tGr8C\",\"public_kronos_docs_particles.md\":\"CgdBAXsD\",\"guide-to-incrementals_ludology_definition_index.md\":\"DIaoS5gy\",\"public_kronos_readme.md\":\"DR8w07T9\",\"public_gamedevtree_docs_subtabs-and-microtabs.md\":\"BUkbEA-K\",\"garden_profectus_index.md\":\"xupfbPIs\",\"public_gamedevtree_docs_updating-tmt.md\":\"B1_CRXZy\",\"public_gamedevtree_docs_milestones.md\":\"C9u7zdbl\",\"public_lit_docs_basic-layer-breakdown.md\":\"B_DwLl-5\",\"public_lit_docs_buyables.md\":\"Cr6AwZWn\",\"public_lit_docs_challenges.md\":\"BXbZcSAe\",\"public_lit_docs_clickables.md\":\"DQD4wzqI\",\"public_kronos_docs_subtabs-and-microtabs.md\":\"BSv4TpNt\",\"garden_social-media_index.md\":\"DAzYHLFL\",\"garden_the-indieweb_signature-blocks_index.md\":\"Cnxs9z1f\",\"public_gamedevtree_docs_achievements.md\":\"C6gZOG4E\",\"garden_the-cozy-web_index.md\":\"B-KCaeAX\",\"public_kronos_docs_challenges.md\":\"C8-cN764\",\"garden_the-indieweb_amplification_index.md\":\"NlAIL_t-\",\"garden_vitepress_index.md\":\"DTLx6ygf\",\"public_kronos_docs_basic-layer-breakdown.md\":\"DHJLymK0\",\"garden_the-small-web_index.md\":\"Daz5VLmz\",\"public_kronos_docs_upgrades.md\":\"BY_E6naZ\",\"public_kronos_docs_grids.md\":\"dbyCMqJD\",\"public_lit_readme.md\":\"Dp_XDgLr\",\"garden_v-ecs_index.md\":\"6x_talKA\",\"garden_this-knowledge-hub_index.md\":\"CcDMY4TV\",\"garden_video-game-monetization_index.md\":\"C6VvKnXQ\",\"garden_webrings_index.md\":\"CHuB-jai\",\"garden_pre-order-bonuses_index.md\":\"DXfgTmX2\",\"garden_wanderstop_index.md\":\"BsgVkkBn\",\"garden_kronos_index.md\":\"CRCcIk8D\",\"garden_guide-to-incrementals_defining-the-genre_index.md\":\"CFOM-Wt1\",\"public_lit_docs_!general-info.md\":\"DwyPmy7N\",\"garden_premium-currency_index.md\":\"t2Oh12hm\",\"garde
</body>
</html>