| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  | import { makeDiv } from "../../../core/utils"; | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  | import { BaseHUDPart } from "../base_hud_part"; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  | import { DynamicDomAttach } from "../dynamic_dom_attach"; | 
					
						
							|  |  |  | import { enumNotificationType } from "./notifications"; | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  | import { ShapeDefinition } from "../../shape_definition"; | 
					
						
							|  |  |  | import { DialogWithForm } from "../../../core/modal_dialog_elements"; | 
					
						
							|  |  |  | import { FormElementInput, FormElementItemChooser } from "../../../core/modal_dialog_forms"; | 
					
						
							|  |  |  | import { HubGoals } from "../../hub_goals"; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  | export class HUDSandboxController extends BaseHUDPart { | 
					
						
							|  |  |  |     createElements(parent) { | 
					
						
							|  |  |  |         this.element = makeDiv( | 
					
						
							|  |  |  |             parent, | 
					
						
							|  |  |  |             "ingame_HUD_SandboxController", | 
					
						
							|  |  |  |             [], | 
					
						
							|  |  |  |             `
 | 
					
						
							|  |  |  |             <label>Sandbox Options</label> | 
					
						
							|  |  |  |             <span class="sandboxHint">Use F6 to toggle this overlay</span> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |             <div class="buttons"> | 
					
						
							|  |  |  |                 <div class="levelToggle plusMinus"> | 
					
						
							|  |  |  |                     <label>Level</label> | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |                     <button class="styledButton reset">⮂</button> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton minus">-</button> | 
					
						
							|  |  |  |                     <button class="styledButton plus">+</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |                 <div class="upgradesBelt plusMinus"> | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |                     <label>→ Belts</label> | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |                     <button class="styledButton reset">⮂</button> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton minus">-</button> | 
					
						
							|  |  |  |                     <button class="styledButton plus">+</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |                 <div class="upgradesExtraction plusMinus"> | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |                     <label>→ Extraction</label> | 
					
						
							|  |  |  |                     <button class="styledButton reset">⮂</button> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton minus">-</button> | 
					
						
							|  |  |  |                     <button class="styledButton plus">+</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |                 <div class="upgradesProcessing plusMinus"> | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |                     <label>→ Processing</label> | 
					
						
							|  |  |  |                     <button class="styledButton reset">⮂</button> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton minus">-</button> | 
					
						
							|  |  |  |                     <button class="styledButton plus">+</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |                  | 
					
						
							|  |  |  |                 <div class="upgradesPainting plusMinus"> | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |                     <label>→ Painting</label> | 
					
						
							|  |  |  |                     <button class="styledButton reset">⮂</button> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton minus">-</button> | 
					
						
							|  |  |  |                     <button class="styledButton plus">+</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |                 <div class="additionalOptions"> | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |                     <div class="bigPlusMinus"> | 
					
						
							|  |  |  |                         <button class="styledButton levelOverride">Override</button> | 
					
						
							|  |  |  |                         <button class="styledButton levelUp">Level up</button>  | 
					
						
							|  |  |  |                     </div> | 
					
						
							| 
									
										
										
										
											2020-10-19 03:35:01 +00:00
										 |  |  |                     <div class="bigPlusMinus"> | 
					
						
							|  |  |  |                         <button class="styledButton bigMinus">-100 All</button> | 
					
						
							|  |  |  |                         <button class="styledButton bigPlus">+100 All</button>  | 
					
						
							|  |  |  |                     </div> | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                     <button class="styledButton giveBlueprints">Fill blueprint shapes</button> | 
					
						
							|  |  |  |                 </div> | 
					
						
							|  |  |  |             </div> | 
					
						
							|  |  |  |         `
 | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const bind = (selector, handler) => this.trackClicks(this.element.querySelector(selector), handler); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |         bind(".levelOverride", this.promptOverrideLevel); | 
					
						
							| 
									
										
										
										
											2020-10-21 22:59:54 +00:00
										 |  |  |         bind(".levelUp", this.tryLevelUp); | 
					
						
							| 
									
										
										
										
											2020-10-19 03:35:01 +00:00
										 |  |  |         bind(".bigMinus", () => this.modifyAll(-100)); | 
					
						
							|  |  |  |         bind(".bigPlus", () => this.modifyAll(100)); | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |         bind(".giveBlueprints", this.giveBlueprints); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         bind(".levelToggle .reset", this.resetLevel); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         bind(".levelToggle .minus", () => this.modifyLevel(-1)); | 
					
						
							|  |  |  |         bind(".levelToggle .plus", () => this.modifyLevel(1)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         bind(".upgradesBelt .reset", () => this.resetUpgrade("belt")); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         bind(".upgradesBelt .minus", () => this.modifyUpgrade("belt", -1)); | 
					
						
							|  |  |  |         bind(".upgradesBelt .plus", () => this.modifyUpgrade("belt", 1)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         bind(".upgradesExtraction .reset", () => this.resetUpgrade("miner")); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         bind(".upgradesExtraction .minus", () => this.modifyUpgrade("miner", -1)); | 
					
						
							|  |  |  |         bind(".upgradesExtraction .plus", () => this.modifyUpgrade("miner", 1)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         bind(".upgradesProcessing .reset", () => this.resetUpgrade("processors")); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         bind(".upgradesProcessing .minus", () => this.modifyUpgrade("processors", -1)); | 
					
						
							|  |  |  |         bind(".upgradesProcessing .plus", () => this.modifyUpgrade("processors", 1)); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         bind(".upgradesPainting .reset", () => this.resetUpgrade("painting")); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         bind(".upgradesPainting .minus", () => this.modifyUpgrade("painting", -1)); | 
					
						
							|  |  |  |         bind(".upgradesPainting .plus", () => this.modifyUpgrade("painting", 1)); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     giveBlueprints() { | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  |         const shape = this.root.gameMode.getBlueprintShapeKey(); | 
					
						
							|  |  |  |         if (!this.root.hubGoals.storedShapes[shape]) { | 
					
						
							|  |  |  |             this.root.hubGoals.storedShapes[shape] = 0; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         } | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  |         this.root.hubGoals.storedShapes[shape] += 1e9; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-19 03:35:01 +00:00
										 |  |  |     modifyAll(amount) { | 
					
						
							|  |  |  |         this.modifyUpgrade("belt", amount); | 
					
						
							|  |  |  |         this.modifyUpgrade("miner", amount); | 
					
						
							|  |  |  |         this.modifyUpgrade("processors", amount); | 
					
						
							|  |  |  |         this.modifyUpgrade("painting", amount); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |     resetUpgrade(id) { | 
					
						
							|  |  |  |         const maxLevel = this.root.gameMode.getUpgrades()[id].length; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         if (this.root.hubGoals.upgradeLevels[id] === maxLevel) { | 
					
						
							|  |  |  |             this.modifyUpgrade(id, -this.root.hubGoals.upgradeLevels[id]); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             this.modifyUpgrade(id, maxLevel - this.root.hubGoals.upgradeLevels[id]); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |     modifyUpgrade(id, amount) { | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  |         const upgradeTiers = this.root.gameMode.getUpgrades()[id]; | 
					
						
							| 
									
										
										
										
											2020-09-22 12:47:59 +00:00
										 |  |  |         const maxLevel = upgradeTiers.length; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         this.root.hubGoals.upgradeLevels[id] = Math.max( | 
					
						
							|  |  |  |             0, | 
					
						
							|  |  |  |             Math.min(maxLevel, (this.root.hubGoals.upgradeLevels[id] || 0) + amount) | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Compute improvement
 | 
					
						
							|  |  |  |         let improvement = 1; | 
					
						
							|  |  |  |         for (let i = 0; i < this.root.hubGoals.upgradeLevels[id]; ++i) { | 
					
						
							| 
									
										
										
										
											2020-09-22 12:47:59 +00:00
										 |  |  |             improvement += upgradeTiers[i].improvement; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         } | 
					
						
							|  |  |  |         this.root.hubGoals.upgradeImprovements[id] = improvement; | 
					
						
							|  |  |  |         this.root.signals.upgradePurchased.dispatch(id); | 
					
						
							|  |  |  |         this.root.hud.signals.notification.dispatch( | 
					
						
							|  |  |  |             "Upgrade '" + id + "' is now at tier " + (this.root.hubGoals.upgradeLevels[id] + 1), | 
					
						
							|  |  |  |             enumNotificationType.upgrade | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |     resetLevel(a) { | 
					
						
							|  |  |  |         const level = this.root.hubGoals.level; | 
					
						
							|  |  |  |         const levelCount = this.root.gameMode.getLevelDefinitions().length; | 
					
						
							|  |  |  |         if (level === levelCount + 1) { | 
					
						
							|  |  |  |             this.modifyLevel(1 - level); | 
					
						
							|  |  |  |         } else { | 
					
						
							|  |  |  |             this.modifyLevel(levelCount + 1 - level); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |     modifyLevel(amount) { | 
					
						
							|  |  |  |         const hubGoals = this.root.hubGoals; | 
					
						
							|  |  |  |         hubGoals.level = Math.max(1, hubGoals.level + amount); | 
					
						
							| 
									
										
										
										
											2020-09-28 08:54:21 +00:00
										 |  |  |         hubGoals.computeNextGoal(); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  | 
 | 
					
						
							|  |  |  |         // Clear all shapes of this level
 | 
					
						
							|  |  |  |         hubGoals.storedShapes[hubGoals.currentGoal.definition.getHash()] = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         // Compute gained rewards
 | 
					
						
							|  |  |  |         hubGoals.gainedRewards = {}; | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  |         const levels = this.root.gameMode.getLevelDefinitions(); | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         for (let i = 0; i < hubGoals.level - 1; ++i) { | 
					
						
							| 
									
										
										
										
											2020-10-07 06:36:02 +00:00
										 |  |  |             if (i < levels.length) { | 
					
						
							|  |  |  |                 const reward = levels[i].reward; | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |                 hubGoals.gainedRewards[reward] = (hubGoals.gainedRewards[reward] || 0) + 1; | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |         this.root.buffers.cache.get("hub").clear(); | 
					
						
							|  |  |  |         this.root.hud.parts.pinnedShapes.rerenderFull(); | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |         this.root.hud.signals.notification.dispatch( | 
					
						
							|  |  |  |             "Changed level to " + hubGoals.level, | 
					
						
							|  |  |  |             enumNotificationType.upgrade | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |     promptOverrideLevel() { | 
					
						
							|  |  |  |         const signalValueInput = new FormElementInput({ | 
					
						
							|  |  |  |             id: "signalValue", | 
					
						
							|  |  |  |             label: null, | 
					
						
							|  |  |  |             placeholder: "", | 
					
						
							|  |  |  |             defaultValue: "", | 
					
						
							|  |  |  |             validator: val => ShapeDefinition.isValidShortKey(val), | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         const dialog = new DialogWithForm({ | 
					
						
							|  |  |  |             app: this.root.app, | 
					
						
							|  |  |  |             title: "Override Level", | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |             desc: "Enter a shape to override with:", | 
					
						
							| 
									
										
										
										
											2020-10-21 19:44:48 +00:00
										 |  |  |             formElements: [signalValueInput], | 
					
						
							|  |  |  |             buttons: ["cancel:bad:escape", "ok:good:enter"], | 
					
						
							|  |  |  |             closeButton: false, | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  |         this.root.hud.parts.dialogs.internalShowDialog(dialog); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         dialog.buttonSignals.ok.add(() => this.overrideLevel(signalValueInput.getValue())); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     overrideLevel(shape) { | 
					
						
							|  |  |  |         console.log(shape); | 
					
						
							|  |  |  |         const hubGoals = this.root.hubGoals; | 
					
						
							|  |  |  |         hubGoals.currentGoal.definition = this.root.shapeDefinitionMgr.getShapeFromShortKey(shape); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         hubGoals.storedShapes[hubGoals.currentGoal.definition.getHash()] = 0; | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.root.buffers.cache.get("hub").clear(); | 
					
						
							|  |  |  |         this.root.hud.parts.pinnedShapes.rerenderFull(); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.root.hud.signals.notification.dispatch( | 
					
						
							|  |  |  |             "Overrode level to " + hubGoals.currentGoal.definition.getHash(), | 
					
						
							|  |  |  |             enumNotificationType.upgrade | 
					
						
							|  |  |  |         ); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-10-21 22:02:20 +00:00
										 |  |  |     tryLevelUp() { | 
					
						
							|  |  |  |         if (!this.root.hubGoals.isEndOfDemoReached()) { | 
					
						
							|  |  |  |             this.root.hubGoals.onGoalCompleted(); | 
					
						
							|  |  |  |         } | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							| 
									
										
										
										
											2020-09-19 13:33:24 +00:00
										 |  |  |     initialize() { | 
					
						
							|  |  |  |         // Allow toggling the controller overlay
 | 
					
						
							|  |  |  |         this.root.gameState.inputReciever.keydown.add(key => { | 
					
						
							|  |  |  |             if (key.keyCode === 117) { | 
					
						
							|  |  |  |                 // F6
 | 
					
						
							|  |  |  |                 this.toggle(); | 
					
						
							|  |  |  |             } | 
					
						
							|  |  |  |         }); | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |         this.visible = !G_IS_DEV; | 
					
						
							|  |  |  |         this.domAttach = new DynamicDomAttach(this.root, this.element); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     toggle() { | 
					
						
							|  |  |  |         this.visible = !this.visible; | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | 
 | 
					
						
							|  |  |  |     update() { | 
					
						
							|  |  |  |         this.domAttach.update(this.visible); | 
					
						
							|  |  |  |     } | 
					
						
							|  |  |  | } |