CompetitiveCompany v0.1.0 (2024)

In an effort to combat the declining performance of its employees, the Company is introducing a form of in-house training. This new initiative pits coworkers against each other in a scrap-collecting competition across the galaxy. By the end of a few days, the lucky winner will be awarded a continued contract with the Company and a brand new group of coworkers!

Sign up now to secure your future with the Company!

This mod is a rewrite and continuation of Competitive Company by agmas.It features a new game mode, where teams of players compete to collect the most amount of scrap within a set number of days. Credits are automatically added as you collect scrap and there's no quota to worry about.

[!IMPORTANT]All players in the lobby are required to have the mod installed!

[!NOTE]The gamemode cannot be toggled off; i.e. to play the base game you have to disable the whole mod.

Recommended Mods

This mod is designed to be somewhat minimal. To improve your experience, consider also using the following mods. These are required by everyone in the lobby unless stated otherwise.

  • MoreCompany lets you have up to 32 players in a lobby and customize your player's appearance with cosmetics.
  • LethalConfig adds an in-game menu for configuring mods, including this one. Does not need to be installed by everyone.
  • LethalCompanyVariables adds a ton of configuration options, including increasing the amount of scrap and monsters in the game to suit larger lobbies. Depending on your settings, this may not need to be installed by everyone.
  • BetterEmotes adds more emotes to the game, which can be used in the end of match cutscene (see the Client config section).
  • Custom moons with LethalLevelLoader. Vanilla moons can prove too small and linear for this gamemode, especially with a large number of players. Here are some recommended mods made by the community:
    • TODO

Terminal Commands

Teams are managed through custom terminal commands:

CommandDescription
join <team> [player]Join a team. The host can join other players by specifying their username as the last argument.
list-teamsLists all teams and their scores.
create-team <name>Creates a new team with the given name. By default, only the host can use this.
delete-team <team>Deletes the specified team. By default, only the host can use this.
set-team-name <name>Changes the name of your current team. The max length for team names is 64 characters.
set-team-color <color>Changes the color of your current team. The color can be one of red, green, blue, yellow, cyan, magenta, white or black, or a custom hex code (e.g. #FF0000).
settingsView the current match settings.
scramble-teamsRandomly assigns players to teams. Only the host can use this.

This information can also be found in-game by running the other command.

Configuration

Most configuration is done via a normal .cfg file. All options except those in the Client section are server-side and can only be set by the host. The options take effect immediately, meaning you can configure match settings on the fly with a mod like LethalConfig.

Additionally, you can define a custom set of default teams that will be created each time you start a lobby. This is done via a default_teams.json file in the config folder. Any players you specify will be put into that team after joining. For example:

[ { "name": "Milk enjoyers", "color": "white", "players": [ "Kesomannen" ] }, { "name": "Orange juice fans", "color": "#e0701b" }, { "name": "Water drinkers", "color": "aqua", "players": [ "agmas", "frostycirno" ] }]

Planned Features

  • [ ] Spectator role
  • [ ] Saving & loading
  • [ ] Controlled moon selection
    • Make it so only one team can select the next moon to go to. This will be configurable to either be the losers pick or cycle through the teams.
  • [ ] Better team management
    • Add a new ship object to view and manage the state of the game instead of using the terminal.

Using the API

This mod exposes an API for other mods to interact with.

  1. Download the mod from Thunderstore.
  2. Copy the CompetitiveCompany.dll and CompetitiveCompany.xml files to a folder in your project, for example lib.
  3. Add the following to your .csproj file:
<ItemGroup> <Reference Include="CompetitiveCompany" HintPath="relative/path/to/CompetitiveCompany.dll" /></ItemGroup>
  1. Add a BepInDependency attribute to your plugin class:
[BepInDependency(CompetitiveCompany.Plugin.Guid)]public class MyPlugin : BaseUnityPlugin { //...}

You should now be able to access the public members under the CompetitiveCompany namespace. Here's a couple of quick examples:

using CompetitiveCompany.Game;// Item that shows the position of all enemies when activatedpublic class XRayItem : GrabbableObject { public override void ItemActivate(bool used, bool buttonDown = true) { if (!used) return; var localTeam = Player.Local.Team; if (localTeam == null) return; foreach (var player in Session.Current.Players) { if (player.Team == localTeam) continue; var position = player.transform.position; var username = player.Controller.playerUsername; Debug.Log($"Enemy {username} is at {position}"); // draw an indicator at the enemy's position } }}
using CompetitiveCompany.Game;// Only allow PvP inside of the facility[BepInPlugin(...)]public class Plugin : BaseUnityPlugin { void Awake() { Session.OnSessionStarted += OnSessionStarted; } void OnSessionStarted(Session session) { session.Combat.AddPredicate((attacker, victim) => { if (!attacker.Controller.isInsideFactory) { return DamagePredicateResult.Deny("PvP is only allowed inside the facility"); } return DamagePredicateResult.Allow(); }); }}

Building

Make sure you have the following installed:

  1. Clone the repository

    git clone https://github.com/Kesomannen/CompetitiveCompany.git
  2. Download the following mods from Thunderstore and place their DLLs in the lib folder:

    • LethalAPI.Terminal
    • LethalCompanyInputUtils
    • LethalConfig
    • Runtime_Netcode_Patcher
  3. Add the MMHOOK_Assembly-CSharp.dll to the lib folder. This is generated by the HookGenPatcher mod on startup and located in the BepInEx/plugins/MMHOOK folder.

  4. Build the project with

    dotnet build

    The mod will be built to bin/Debug/netstandard2.1/CompetitiveCompany.dll. Alternatively do a release build with

     dotnet build -c Release

    which will create a thunderstore-ready zip file in the build folder.

[!IMPORTANT]When testing locally, don't forget to include assets/competitive-company and lib/FlowTween.dll in the same folder as the mod's DLL.

The unity project to build the asset bundle is not yet included in this repository.

The source code of FlowTween can be found here. The FlowTween.dll in this project is a slightly modified version with the editor scripts taken out.

CompetitiveCompany v0.1.0 (2024)
Top Articles
Latest Posts
Article information

Author: Edwin Metz

Last Updated:

Views: 5461

Rating: 4.8 / 5 (78 voted)

Reviews: 85% of readers found this page helpful

Author information

Name: Edwin Metz

Birthday: 1997-04-16

Address: 51593 Leanne Light, Kuphalmouth, DE 50012-5183

Phone: +639107620957

Job: Corporate Banking Technician

Hobby: Reading, scrapbook, role-playing games, Fishing, Fishing, Scuba diving, Beekeeping

Introduction: My name is Edwin Metz, I am a fair, energetic, helpful, brave, outstanding, nice, helpful person who loves writing and wants to share my knowledge and understanding with you.