Profectus-Demo/src/data/projEntry.tsx

104 lines
3.7 KiB
TypeScript
Raw Normal View History

2022-03-03 21:39:48 -06:00
import Spacer from "components/layout/Spacer.vue";
import { jsx } from "features/feature";
import { createResource, trackBest, trackOOMPS, trackTotal } from "features/resources/resource";
2022-06-26 19:17:22 -05:00
import type { GenericTree } from "features/trees/tree";
import { branchedResetPropagation, createTree } from "features/trees/tree";
2022-03-03 21:39:48 -06:00
import { globalBus } from "game/events";
import type { BaseLayer, GenericLayer } from "game/layers";
2022-06-26 19:17:22 -05:00
import { createLayer } from "game/layers";
import type { Player } from "game/player";
2022-06-26 19:17:22 -05:00
import player from "game/player";
import type { DecimalSource } from "util/bignum";
import Decimal, { format, formatTime } from "util/bignum";
2022-03-03 21:39:48 -06:00
import { render } from "util/vue";
import { computed, toRaw } from "vue";
2022-02-27 18:31:51 -06:00
import prestige from "./layers/prestige";
2022-01-13 22:25:47 -06:00
/**
* @hidden
*/
export const main = createLayer("main", function (this: BaseLayer) {
const points = createResource<DecimalSource>(10);
2022-01-27 22:47:26 -06:00
const best = trackBest(points);
const total = trackTotal(points);
2022-01-13 22:25:47 -06:00
2022-01-27 22:47:26 -06:00
const pointGain = computed(() => {
// eslint-disable-next-line prefer-const
2022-02-27 18:31:51 -06:00
let gain = new Decimal(1);
2022-01-27 22:47:26 -06:00
return gain;
});
globalBus.on("update", diff => {
points.value = Decimal.add(points.value, Decimal.times(pointGain.value, diff));
});
const oomps = trackOOMPS(points, pointGain);
2022-01-13 22:25:47 -06:00
const tree = createTree(() => ({
2022-02-27 18:31:51 -06:00
nodes: [[prestige.treeNode]],
branches: [],
onReset() {
2022-02-27 18:31:51 -06:00
points.value = toRaw(this.resettingNode.value) === toRaw(prestige.treeNode) ? 0 : 10;
best.value = points.value;
total.value = points.value;
},
resetPropagation: branchedResetPropagation
})) as GenericTree;
2022-01-13 22:25:47 -06:00
2022-01-27 22:47:26 -06:00
return {
name: "Tree",
links: tree.links,
display: jsx(() => (
<>
{player.devSpeed === 0 ? <div>Game Paused</div> : null}
2022-12-20 21:56:41 -06:00
{player.devSpeed != null && player.devSpeed !== 0 && player.devSpeed !== 1 ? (
<div>Dev Speed: {format(player.devSpeed)}x</div>
) : null}
{player.offlineTime != null && player.offlineTime !== 0 ? (
<div>Offline Time: {formatTime(player.offlineTime)}</div>
) : null}
2022-01-27 22:47:26 -06:00
<div>
{Decimal.lt(points.value, "1e1000") ? <span>You have </span> : null}
2022-01-27 22:47:26 -06:00
<h2>{format(points.value)}</h2>
{Decimal.lt(points.value, "1e1e6") ? <span> points</span> : null}
2022-01-27 22:47:26 -06:00
</div>
{Decimal.gt(pointGain.value, 0) ? <div>({oomps.value})</div> : null}
2022-01-27 22:47:26 -06:00
<Spacer />
{render(tree)}
</>
)),
2022-01-27 22:47:26 -06:00
points,
best,
total,
oomps,
2022-02-27 18:31:51 -06:00
tree
2022-01-27 22:47:26 -06:00
};
2022-01-13 22:25:47 -06:00
});
2022-07-10 01:44:45 -05:00
/**
* Given a player save data object being loaded, return a list of layers that should currently be enabled.
* If your project does not use dynamic layers, this should just return all layers.
*/
2022-01-13 22:25:47 -06:00
export const getInitialLayers = (
/* eslint-disable-next-line @typescript-eslint/no-unused-vars */
player: Partial<Player>
2022-02-27 18:31:51 -06:00
): Array<GenericLayer> => [main, prestige];
2022-01-13 22:25:47 -06:00
2022-07-10 01:44:45 -05:00
/**
* A computed ref whose value is true whenever the game is over.
*/
2022-01-13 22:25:47 -06:00
export const hasWon = computed(() => {
2022-02-27 18:31:51 -06:00
return false;
2022-01-13 22:25:47 -06:00
});
2022-07-10 01:44:45 -05:00
/**
* Given a player save data object being loaded with a different version, update the save data object to match the structure of the current version.
* @param oldVersion The version of the save being loaded in
* @param player The save data being loaded in
*/
2022-01-13 22:25:47 -06:00
/* eslint-disable @typescript-eslint/no-unused-vars */
export function fixOldSave(
oldVersion: string | undefined,
player: Partial<Player>
2022-01-13 22:25:47 -06:00
// eslint-disable-next-line @typescript-eslint/no-empty-function
): void {}
/* eslint-enable @typescript-eslint/no-unused-vars */