mirror of
https://github.com/thepaperpilot/Advent-Incremental.git
synced 2024-11-28 02:51:46 +00:00
Fix inflation
This commit is contained in:
parent
c2e1af8d6a
commit
825ea2f2ed
2 changed files with 197 additions and 118 deletions
|
@ -21,7 +21,7 @@ import {
|
||||||
createMultiplicativeModifier,
|
createMultiplicativeModifier,
|
||||||
createSequentialModifier
|
createSequentialModifier
|
||||||
} from "game/modifiers";
|
} from "game/modifiers";
|
||||||
import { persistent } from "game/persistence";
|
import { DefaultValue, persistent } from "game/persistence";
|
||||||
import Decimal, { DecimalSource, format, formatWhole } from "util/bignum";
|
import Decimal, { DecimalSource, format, formatWhole } from "util/bignum";
|
||||||
import { Direction } from "util/common";
|
import { Direction } from "util/common";
|
||||||
import { render, renderRow } from "util/vue";
|
import { render, renderRow } from "util/vue";
|
||||||
|
@ -65,7 +65,7 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
|
|
||||||
const citiesGoal = 10;
|
const citiesGoal = 10;
|
||||||
|
|
||||||
const citiesCompleted = createResource<DecimalSource>(0, "countries solved");
|
const citiesCompleted = createResource<DecimalSource>(0, "cities solved");
|
||||||
const currentCity = persistent<number[][]>([]);
|
const currentCity = persistent<number[][]>([]);
|
||||||
const routeIndex = persistent<number>(0);
|
const routeIndex = persistent<number>(0);
|
||||||
const checkRouteProgress = persistent<number>(0);
|
const checkRouteProgress = persistent<number>(0);
|
||||||
|
@ -143,35 +143,37 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
function stringifyRoute(route: number[]) {
|
function stringifyRoute(route: number[]) {
|
||||||
return route
|
return route
|
||||||
.map(h => (city.types.house.title as (node: BoardNode) => string)(city.nodes.value[h]))
|
.map(h => (city.types.house.title as (node: BoardNode) => string)(city.nodes.value[h]))
|
||||||
.join("->");
|
.join(" > ");
|
||||||
}
|
}
|
||||||
|
|
||||||
function generateCity() {
|
function generateCity() {
|
||||||
const numHouses = new Decimal(computedHouses.value).clampMin(3).toNumber();
|
if (Decimal.lte(citiesCompleted.value, 50)) {
|
||||||
const min = computedMinWeight.value;
|
const numHouses = new Decimal(computedHouses.value).clampMin(3).toNumber();
|
||||||
const max = milestone6.earned.value ? min : computedMaxWeight.value;
|
const min = computedMinWeight.value;
|
||||||
const diff = Decimal.sub(max, min);
|
const max = milestone6.earned.value ? min : computedMaxWeight.value;
|
||||||
const city: number[][] = [];
|
const diff = Decimal.sub(max, min);
|
||||||
for (let i = 0; i < numHouses; i++) {
|
const city: number[][] = [];
|
||||||
const house: number[] = [];
|
for (let i = 0; i < numHouses; i++) {
|
||||||
for (let j = 0; j < numHouses; j++) {
|
const house: number[] = [];
|
||||||
if (i === j) {
|
for (let j = 0; j < numHouses; j++) {
|
||||||
house.push(0);
|
if (i === j) {
|
||||||
} else if (j < i) {
|
house.push(0);
|
||||||
house.push(city[j][i]);
|
} else if (j < i) {
|
||||||
} else {
|
house.push(city[j][i]);
|
||||||
house.push(Decimal.times(diff, Math.random()).add(min).floor().toNumber());
|
} else {
|
||||||
|
house.push(Decimal.times(diff, Math.random()).add(min).floor().toNumber());
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
city.push(house);
|
||||||
}
|
}
|
||||||
city.push(house);
|
currentCity.value = city;
|
||||||
|
routeIndex.value = 0;
|
||||||
|
redundanciesRemoved.value = Decimal.gte(citiesCompleted.value, 7)
|
||||||
|
? Decimal.factorial(currentCity.value.length).div(2).toNumber()
|
||||||
|
: 0;
|
||||||
|
routesToSkip.value = [];
|
||||||
|
getNextRoute();
|
||||||
}
|
}
|
||||||
currentCity.value = city;
|
|
||||||
routeIndex.value = 0;
|
|
||||||
redundanciesRemoved.value = Decimal.gte(citiesCompleted.value, 7)
|
|
||||||
? Decimal.factorial(currentCity.value.length).div(2).toNumber()
|
|
||||||
: 0;
|
|
||||||
routesToSkip.value = [];
|
|
||||||
getNextRoute();
|
|
||||||
}
|
}
|
||||||
|
|
||||||
function getNextRoute() {
|
function getNextRoute() {
|
||||||
|
@ -342,12 +344,13 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
},
|
},
|
||||||
width: "600px",
|
width: "600px",
|
||||||
height: "600px",
|
height: "600px",
|
||||||
style: {
|
|
||||||
background: "var(--raised-background)",
|
|
||||||
borderRadius: "var(--border-radius) var(--border-radius) 0 0",
|
|
||||||
boxShadow: "0 2px 10px rgb(0 0 0 / 50%)"
|
|
||||||
},
|
|
||||||
state: computed(() => {
|
state: computed(() => {
|
||||||
|
if (Decimal.gte(citiesCompleted.value, 20))
|
||||||
|
return {
|
||||||
|
nodes: [],
|
||||||
|
selectedNode: null,
|
||||||
|
selectedAction: null
|
||||||
|
};
|
||||||
const nodes: BoardNode[] = [];
|
const nodes: BoardNode[] = [];
|
||||||
const city = currentCity.value;
|
const city = currentCity.value;
|
||||||
const rows = Math.ceil(Math.sqrt(city.length));
|
const rows = Math.ceil(Math.sqrt(city.length));
|
||||||
|
@ -373,6 +376,7 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
};
|
};
|
||||||
}),
|
}),
|
||||||
links() {
|
links() {
|
||||||
|
if (Decimal.gte(citiesCompleted.value, 20)) return [];
|
||||||
const links: BoardNodeLink[] = [];
|
const links: BoardNodeLink[] = [];
|
||||||
const route = currentRoute.value;
|
const route = currentRoute.value;
|
||||||
if (route == null) {
|
if (route == null) {
|
||||||
|
@ -432,6 +436,44 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
}
|
}
|
||||||
}));
|
}));
|
||||||
|
|
||||||
|
const checkCityProgressBar = createBar(() => ({
|
||||||
|
direction: Direction.Right,
|
||||||
|
width: 597,
|
||||||
|
height: 24,
|
||||||
|
style: {
|
||||||
|
borderRadius: "var(--border-radius) var(--border-radius) 0 0",
|
||||||
|
background: "var(--raised-background)",
|
||||||
|
marginBottom: "-24px"
|
||||||
|
},
|
||||||
|
borderStyle: {
|
||||||
|
borderRadius: "var(--border-radius) var(--border-radius) 0 0",
|
||||||
|
borderColor: "transparent",
|
||||||
|
marginBottom: "unset"
|
||||||
|
},
|
||||||
|
fillStyle: {
|
||||||
|
background: "black",
|
||||||
|
marginBottom: "unset"
|
||||||
|
},
|
||||||
|
progress() {
|
||||||
|
return Decimal.div(
|
||||||
|
routeIndex.value,
|
||||||
|
typeof currentRoutes.value == "number"
|
||||||
|
? Math.floor(currentRoutes.value)
|
||||||
|
: currentRoutes.value.length
|
||||||
|
);
|
||||||
|
},
|
||||||
|
display: jsx(() => (
|
||||||
|
<>
|
||||||
|
{formatWhole(Math.floor(routeIndex.value))} /{" "}
|
||||||
|
{formatWhole(
|
||||||
|
typeof currentRoutes.value == "number"
|
||||||
|
? Math.floor(currentRoutes.value)
|
||||||
|
: currentRoutes.value.length
|
||||||
|
)}
|
||||||
|
</>
|
||||||
|
))
|
||||||
|
}));
|
||||||
|
|
||||||
const checkRouteProgressBar = createBar(() => ({
|
const checkRouteProgressBar = createBar(() => ({
|
||||||
direction: Direction.Right,
|
direction: Direction.Right,
|
||||||
width: 597,
|
width: 597,
|
||||||
|
@ -443,7 +485,7 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
},
|
},
|
||||||
borderStyle: {
|
borderStyle: {
|
||||||
borderRadius: "0 0 var(--border-radius) var(--border-radius)",
|
borderRadius: "0 0 var(--border-radius) var(--border-radius)",
|
||||||
borderColor: "var(--outline)",
|
borderColor: "transparent",
|
||||||
marginTop: "unset"
|
marginTop: "unset"
|
||||||
},
|
},
|
||||||
fillStyle: {
|
fillStyle: {
|
||||||
|
@ -455,7 +497,8 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
},
|
},
|
||||||
display: jsx(() => (
|
display: jsx(() => (
|
||||||
<>
|
<>
|
||||||
{Math.floor(checkRouteProgress.value)}/{currentRouteDuration.value}
|
{formatWhole(Math.floor(checkRouteProgress.value))} /{" "}
|
||||||
|
{formatWhole(currentRouteDuration.value)}
|
||||||
</>
|
</>
|
||||||
))
|
))
|
||||||
}));
|
}));
|
||||||
|
@ -505,7 +548,7 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
const milestone5 = createMilestone(() => ({
|
const milestone5 = createMilestone(() => ({
|
||||||
display: {
|
display: {
|
||||||
requirement: "5 Countries Solved",
|
requirement: "5 Countries Solved",
|
||||||
effectDisplay: "Remove 1 city"
|
effectDisplay: "Remove 1 city from the map"
|
||||||
},
|
},
|
||||||
shouldEarn() {
|
shouldEarn() {
|
||||||
return Decimal.gte(citiesCompleted.value, 5);
|
return Decimal.gte(citiesCompleted.value, 5);
|
||||||
|
@ -616,46 +659,61 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
}))
|
}))
|
||||||
]);
|
]);
|
||||||
const computedAutoProcessing = computed(() => autoProcessing.apply(1));
|
const computedAutoProcessing = computed(() => autoProcessing.apply(1));
|
||||||
|
const metaSolvingSpeed = createSequentialModifier(() => []);
|
||||||
|
const computedMetaSolvingSpeed = computed(() => metaSolvingSpeed.apply(20));
|
||||||
|
|
||||||
const [generalTab, generalTabCollapsed] = createCollapsibleModifierSections(() => [
|
const [generalTab, generalTabCollapsed] = createCollapsibleModifierSections(() => [
|
||||||
{
|
{
|
||||||
title: "Cities/country",
|
title: "Cities/country",
|
||||||
modifier: houses,
|
modifier: houses,
|
||||||
base: 3
|
base: 3,
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: () => (milestone6.earned.value ? "Weight" : "Minimum Weight"),
|
title: () => (milestone6.earned.value ? "Weight" : "Minimum Weight"),
|
||||||
modifier: minWeight,
|
modifier: minWeight,
|
||||||
base: 2
|
base: 2,
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: "Maximum Weight",
|
title: "Maximum Weight",
|
||||||
modifier: maxWeight,
|
modifier: maxWeight,
|
||||||
base: 10,
|
base: 10,
|
||||||
visible: () => !milestone6.earned.value
|
visible: () => !milestone6.earned.value && Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: "Manual Processing Amount",
|
title: "Manual Processing Amount",
|
||||||
modifier: manualBoost,
|
modifier: manualBoost,
|
||||||
base: 1
|
base: 1,
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: "Manual Processing Cooldown",
|
title: "Manual Processing Cooldown",
|
||||||
modifier: manualCooldown,
|
modifier: manualCooldown,
|
||||||
base: 1,
|
base: 1,
|
||||||
unit: "s"
|
unit: "s",
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: "Remove Redundant Route Cooldown",
|
title: "Remove Redundant Route Cooldown",
|
||||||
modifier: redundantCooldown,
|
modifier: redundantCooldown,
|
||||||
base: 10,
|
base: 10,
|
||||||
unit: "s"
|
unit: "s",
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
},
|
},
|
||||||
{
|
{
|
||||||
title: "Auto Processing Speed",
|
title: "Auto Processing Speed",
|
||||||
modifier: autoProcessing,
|
modifier: autoProcessing,
|
||||||
base: 1,
|
base: 1,
|
||||||
unit: "/s"
|
unit: "/s",
|
||||||
|
visible: () => Decimal.lte(citiesCompleted.value, 50)
|
||||||
|
},
|
||||||
|
{
|
||||||
|
title: "Post-Inflation Solving Speed",
|
||||||
|
modifier: metaSolvingSpeed,
|
||||||
|
base: 20,
|
||||||
|
unit: "/s",
|
||||||
|
visible: () => Decimal.gt(citiesCompleted.value, 50)
|
||||||
}
|
}
|
||||||
]);
|
]);
|
||||||
const showModifiersModal = ref(false);
|
const showModifiersModal = ref(false);
|
||||||
|
@ -674,54 +732,60 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
if (Decimal.lt(main.day.value, day)) {
|
if (Decimal.lt(main.day.value, day)) {
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
if (Decimal.lte(citiesCompleted[DefaultValue], 50)) {
|
||||||
|
if (Decimal.gte(newCityProgress.value, 10)) {
|
||||||
|
newCityProgress.value = 10;
|
||||||
|
} else {
|
||||||
|
newCityProgress.value = Decimal.add(newCityProgress.value, diff);
|
||||||
|
if (getNewCity.isHolding.value) {
|
||||||
|
getNewCity.onClick();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
if (Decimal.gte(newCityProgress.value, 10)) {
|
if (Decimal.gte(boostProgress.value, computedManualCooldown.value)) {
|
||||||
newCityProgress.value = 10;
|
boostProgress.value = computedManualCooldown.value;
|
||||||
|
} else {
|
||||||
|
boostProgress.value = Decimal.add(boostProgress.value, diff);
|
||||||
|
if (boost.isHolding.value) {
|
||||||
|
boost.onClick();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
if (Decimal.gte(redundantProgress.value, computedRedundantCooldown.value)) {
|
||||||
|
redundantProgress.value = computedRedundantCooldown.value;
|
||||||
|
} else {
|
||||||
|
redundantProgress.value = Decimal.add(redundantProgress.value, diff);
|
||||||
|
if (removeRedundantRoute.isHolding.value) {
|
||||||
|
removeRedundantRoute.onClick();
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
checkRouteProgress.value = Decimal.times(diff, computedAutoProcessing.value)
|
||||||
|
.add(checkRouteProgress.value)
|
||||||
|
.toNumber();
|
||||||
|
if (checkRouteProgress.value > currentRouteDuration.value) {
|
||||||
|
const overflow = checkRouteProgress.value - currentRouteDuration.value;
|
||||||
|
routeIndex.value++;
|
||||||
|
if (milestone6.earned.value && currentRoute.value != null) {
|
||||||
|
const length =
|
||||||
|
typeof currentRoute.value === "number"
|
||||||
|
? currentRoute.value
|
||||||
|
: currentRoute.value.length;
|
||||||
|
const extraRoutes = Decimal.div(
|
||||||
|
overflow,
|
||||||
|
Decimal.times(length, computedMinWeight.value)
|
||||||
|
)
|
||||||
|
.floor()
|
||||||
|
.toNumber();
|
||||||
|
routeIndex.value += extraRoutes;
|
||||||
|
}
|
||||||
|
getNextRoute();
|
||||||
|
}
|
||||||
} else {
|
} else {
|
||||||
newCityProgress.value = Decimal.add(newCityProgress.value, diff);
|
citiesCompleted.value = Decimal.add(
|
||||||
if (getNewCity.isHolding.value) {
|
citiesCompleted.value,
|
||||||
getNewCity.onClick();
|
computedMetaSolvingSpeed.value
|
||||||
}
|
);
|
||||||
}
|
|
||||||
|
|
||||||
if (Decimal.gte(boostProgress.value, computedManualCooldown.value)) {
|
|
||||||
boostProgress.value = computedManualCooldown.value;
|
|
||||||
} else {
|
|
||||||
boostProgress.value = Decimal.add(boostProgress.value, diff);
|
|
||||||
if (boost.isHolding.value) {
|
|
||||||
boost.onClick();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (Decimal.gte(redundantProgress.value, computedRedundantCooldown.value)) {
|
|
||||||
redundantProgress.value = computedRedundantCooldown.value;
|
|
||||||
} else {
|
|
||||||
redundantProgress.value = Decimal.add(redundantProgress.value, diff);
|
|
||||||
if (removeRedundantRoute.isHolding.value) {
|
|
||||||
removeRedundantRoute.onClick();
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
checkRouteProgress.value = Decimal.times(diff, computedAutoProcessing.value)
|
|
||||||
.add(checkRouteProgress.value)
|
|
||||||
.toNumber();
|
|
||||||
if (checkRouteProgress.value > currentRouteDuration.value) {
|
|
||||||
const overflow = checkRouteProgress.value - currentRouteDuration.value;
|
|
||||||
routeIndex.value++;
|
|
||||||
if (milestone6.earned.value && currentRoute.value != null) {
|
|
||||||
const length =
|
|
||||||
typeof currentRoute.value === "number"
|
|
||||||
? currentRoute.value
|
|
||||||
: currentRoute.value.length;
|
|
||||||
const extraRoutes = Decimal.div(
|
|
||||||
overflow,
|
|
||||||
Decimal.times(length, computedMinWeight.value)
|
|
||||||
)
|
|
||||||
.floor()
|
|
||||||
.toNumber();
|
|
||||||
routeIndex.value += extraRoutes;
|
|
||||||
}
|
|
||||||
getNextRoute();
|
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
|
|
||||||
|
@ -757,16 +821,7 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
return "";
|
return "";
|
||||||
}
|
}
|
||||||
if (typeof currentRoutes.value === "number") {
|
if (typeof currentRoutes.value === "number") {
|
||||||
return (
|
return <div class="routes-list"> </div>;
|
||||||
<div class="routes-list">
|
|
||||||
{routeIndex.value > 0 ? (
|
|
||||||
<div class="checked">{formatWhole(routeIndex.value)} already checked</div>
|
|
||||||
) : null}
|
|
||||||
<div>
|
|
||||||
{formatWhole(currentRoutes.value - routeIndex.value)} routes left to check
|
|
||||||
</div>
|
|
||||||
</div>
|
|
||||||
);
|
|
||||||
}
|
}
|
||||||
if (typeof currentRoutes.value === "number") {
|
if (typeof currentRoutes.value === "number") {
|
||||||
console.error("Something went horribly wrong");
|
console.error("Something went horribly wrong");
|
||||||
|
@ -774,22 +829,17 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
}
|
}
|
||||||
const routes = currentRoutes.value.slice();
|
const routes = currentRoutes.value.slice();
|
||||||
let showPrevious = false;
|
let showPrevious = false;
|
||||||
let showNext = 0;
|
if (routes.length > 25) {
|
||||||
if (routes.length > 6) {
|
routes.splice(0, Math.max(routeIndex.value - 12, 0));
|
||||||
routes.splice(0, routeIndex.value);
|
|
||||||
showPrevious = true;
|
showPrevious = true;
|
||||||
if (routes.length > 6) {
|
if (routes.length > 25) {
|
||||||
showNext = routes.length - 5;
|
routes.splice(25);
|
||||||
routes.splice(5);
|
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
return (
|
return (
|
||||||
<div class="routes-list">
|
<div class="routes-list">
|
||||||
{showPrevious && routeIndex.value > 0 ? (
|
|
||||||
<div class="checked">{formatWhole(routeIndex.value)} already checked</div>
|
|
||||||
) : null}
|
|
||||||
{routes.map((route, i) => {
|
{routes.map((route, i) => {
|
||||||
const index = i + (showPrevious ? routeIndex.value : 0);
|
const index = i + (showPrevious ? Math.max(routeIndex.value - 12, 0) : 0);
|
||||||
return (
|
return (
|
||||||
<div
|
<div
|
||||||
class={{
|
class={{
|
||||||
|
@ -799,13 +849,14 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
skipped:
|
skipped:
|
||||||
routeIndex.value < index && routesToSkip.value.includes(index)
|
routeIndex.value < index && routesToSkip.value.includes(index)
|
||||||
}}
|
}}
|
||||||
|
style={{
|
||||||
|
"--opacity": 1 - Math.abs(index - routeIndex.value) / 13
|
||||||
|
}}
|
||||||
>
|
>
|
||||||
{stringifyRoute(route)}
|
{stringifyRoute(route)}
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
})}
|
})}
|
||||||
|
|
||||||
{showNext > 0 ? <div>+ {formatWhole(showNext)} more</div> : null}
|
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
@ -849,19 +900,28 @@ const layer = createLayer(id, function (this: BaseLayer) {
|
||||||
{render(modifiersModal)}
|
{render(modifiersModal)}
|
||||||
<Spacer />
|
<Spacer />
|
||||||
<MainDisplay resource={citiesCompleted} color={color} />
|
<MainDisplay resource={citiesCompleted} color={color} />
|
||||||
{renderRow(boost, removeRedundantRoute)}
|
{Decimal.lte(citiesCompleted.value, 50) ? (
|
||||||
{render(city)}
|
<>
|
||||||
{render(checkRouteProgressBar)}
|
{renderRow(boost, removeRedundantRoute)}
|
||||||
<Spacer />
|
{render(checkCityProgressBar)}
|
||||||
<h3>Checking Routes...</h3>
|
{displayRoutes()}
|
||||||
{displayRoutes()}
|
{render(city)}
|
||||||
<Spacer />
|
{render(checkRouteProgressBar)}
|
||||||
{milestonesDisplay()}
|
<Spacer />
|
||||||
|
{milestonesDisplay()}
|
||||||
|
</>
|
||||||
|
) : (
|
||||||
|
<>
|
||||||
|
You're solving {formatWhole(computedMetaSolvingSpeed.value)} cities per
|
||||||
|
second
|
||||||
|
</>
|
||||||
|
)}
|
||||||
</>
|
</>
|
||||||
)),
|
)),
|
||||||
minimizedDisplay: jsx(() => (
|
minimizedDisplay: jsx(() => (
|
||||||
<div>
|
<div>
|
||||||
{name} <span class="desc">{format(citiesCompleted.value)} countries solved</span>
|
{name}{" "}
|
||||||
|
<span class="desc">{formatWhole(citiesCompleted.value)} countries solved</span>
|
||||||
</div>
|
</div>
|
||||||
))
|
))
|
||||||
};
|
};
|
||||||
|
|
|
@ -1,3 +1,15 @@
|
||||||
|
.routes-list {
|
||||||
|
width: 600px;
|
||||||
|
height: 573px;
|
||||||
|
margin-bottom: -604px;
|
||||||
|
margin-top: -4px;
|
||||||
|
padding-top: 35px;
|
||||||
|
pointer-events: none;
|
||||||
|
border-radius: var(--border-radius);
|
||||||
|
background: var(--raised-background);
|
||||||
|
box-shadow: 0 2px 10px rgb(0 0 0 / 50%);
|
||||||
|
}
|
||||||
|
|
||||||
.routes-list .checked {
|
.routes-list .checked {
|
||||||
color: var(--bought);
|
color: var(--bought);
|
||||||
}
|
}
|
||||||
|
@ -7,7 +19,7 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.routes-list .redundant:not(.checked):not(.processing) {
|
.routes-list .redundant:not(.checked):not(.processing) {
|
||||||
opacity: 0.5;
|
color: var(--accent1);
|
||||||
}
|
}
|
||||||
|
|
||||||
.routes-list .skipped {
|
.routes-list .skipped {
|
||||||
|
@ -16,5 +28,12 @@
|
||||||
}
|
}
|
||||||
|
|
||||||
.routes-list > * {
|
.routes-list > * {
|
||||||
|
position: relative;
|
||||||
|
--opacity: 1;
|
||||||
flex: 1 1 33%;
|
flex: 1 1 33%;
|
||||||
|
opacity: var(--opacity);
|
||||||
|
transition: all 0s;
|
||||||
|
}
|
||||||
|
.routes-list + div {
|
||||||
|
position: relative;
|
||||||
}
|
}
|
||||||
|
|
Loading…
Reference in a new issue