You are viewing a potentially older version of this package. View all versions.
darmuh-suitsTerminal-1.2.0 icon

suitsTerminal

More Suits Addon that removes excess suits from the rack and stores them in the terminal. See a listing and select any suit for wear from the terminal and clean up the rack!

Date uploaded 2 months ago
Version 1.2.0
Download link darmuh-suitsTerminal-1.2.0.zip
Downloads 6284
Dependency string darmuh-suitsTerminal-1.2.0

This mod requires the following mods to function

README

suitsTerminal by darmuh

Description

Created as an alternative solution to having too many suits, this mod will remove all suits from the rack and store them in the terminal. You can also leave up to 13 suits to remain on the rack via this mod's configuration options, or remove none if you have another mod taking care of the excess suits.

advancedTerminalMenu:

  • A singular 'suits' command will be generated.

    • This command will also be shown in the 'Other' command listing.
    • [NEW IN 1.2.0] duplicate suit names will be listed with their unique suitID.
  • The 'suits' command will bring up an interactive menu that can be navigated by arrow keys.

    • Please note that any other mod that uses the arrow keys for functionality may interfere with this menu.
    • The specialMenusActive bool in this mod is public and accessible.
    • The public bool can be used by other mods to indicate not to listen for shortcut during this specialmenu, which is likely what I'll do for TerminalStuff.
  • [NEW IN 1.2.0] Favoriting system and separate favorites menu is now available.

    • Simply press the [favItemKey] to add the currently selected suit to your favorite suits.
    • To see only your favorited suits, press the [favMenuKey] to toggle the menu to the favorites list.
    • Favorites will be saved to the [favoritesMenuList] configuration item.
    • Default keybinds are [favItemKey = F] and [favMenuKey = F1].
  • [NEW IN 1.2.0] Add only specific suits to the rack's 13 available spots.

    • When [suitsOnRackCustom] is enabled, will only show suits that match the suit names listed in [suitsOnRackList].
    • Note that each suit name should be separated by a comma and that the suit names ARE case sensitive.
    • Favorite some suits and look at favoritesMenuList for examples of suit names.
    • These settings do not override any of the following config options: [suitsOnRack], [dontRemove], [hideRack]
  • Controls for the advancedTerminalMenu are completely configurable, any key except for tab is acceptable.

  • Pages will be generated based on how many suits are detected at load in.

    • I have tested up to 320 suits without any issues. Feel free to try and break things.
  • A Mirror Camera is generated as part of this menu so you can see what the suit you are equipping looks like.

    • This can be toggled by the togglePiP key binding config option.
    • Or disabled completely via the enablePiPCamera config option.
    • See also the below configurable keys to modify the mirror camera view by zoom, height, or rotation.
      • togglePiPZoom: This key will be used to cycle between 4 different zoom options.
      • togglePiPHeight: This key will allow you to change the height of the mirror camera to see different parts of the suit you've equipped.
      • togglePiPRotation: This key will allow you to cycle between 4 different angles around the player so you can see each side of yourself and the back.
  • Here is some videos from dev testing showcasing this mod's progression as newer features were developed. (note these videos are not the final product)

Chat Commands:

  • These commands utilize some of the advanceTerminalMenu's handling, while still requiring commands to be run like the legacy terminal commands.

  • Type !suits to see the first page, and !suits (page number) for each page after that.

  • Type !wear and then the number associated with the suit name to equip it.

    • So if you see '!wear 3' (Shrek) you will type !wear 3 in chat to equip it.

Legacy Terminal Commands:

  • A command will be generated for every page of suits (6 suits per terminal page)

  • 'suits' command is always the first page, each page after is 'suits (pagenumber)'

  • Generates a command for every suit

  • To pick a suit to wear you will use the command 'wear (suitname)'

  • you can see each suit name in the suits page commands

  • use command 'randomsuit' to wear a random suit from the list.

FYI - This mod is more than capabale of adding more than the default maximum 100 suits from More_Suits. Feel free to change that configuration option and try to find the max possible suits you can add.

CHANGELOG

Change Log

[1.3.0] CURRENT VERSION

  • Legonzaur on Github fixed an issue where all suits were still getting loaded by the game despite being hidden, causing a large amount of RAM usage.
    • Huge thankyou to all who put effort into this fix!
    • While it was a relatively small change in the code, a lot of troubleshooting/effort was put into discovering this issue.
    • I welcome anyone who would like to contribute to this project. I did originally make this just as a backup to TooManySuits if/when it failed.
  • Removed TerminalAPI dependency utilizing same command creation method as the latest version of darmuhsTerminalStuff.
    • This mod is now hard-dependency free!
    • Please report any issues with the new terminal command creation system if you find any :)
  • Updated mirror camera culling mask calculation
    • Mask should now be up to standards with most other mods that use cameras. Just like darmuhsTerminalStuff
    • removed the config item that lets you set your own culling mask integer in favor of this new system.
  • Added compatibility with OpenBodyCams, including using OBC for the mirrorcam
    • Thanks again to Zaggy for working with me to get this working.
    • Please note you need to be on OpenBodyCams version 2.2.1 or later to utilize this feature.
    • Configuration items [useOpenBodyCams] and [obcResolution] have been added.
      • [useOpenBodyCams] can be set to false to continue to use the built-in camera in suitsTerminal.
      • [obcResolution] will determine the camera resolution.
  • Moved the majority of the controls hints to a separate help menu page.
    • This page can be accessed by the new [helpMenu] configuration key.
    • While in the help menu, all controls except for [leaveMenu] and [helpMenu] are paused.
  • While using the built-in camera, your first person hand models will be hidden temporarily when the camera is being displayed.
  • Configuration items have been added to modify the time advancedTerminalMenu will wait between checking for key presses as well as after a key has been pressed.
    • [menuKeyPressDelay] is the Regular delay when checking for key presses in the advancedTerminalMenu. (This delay will be added ontop of menuPostSelectDelay)
    • [menuPostSelectDelay] is the delay used after a key press is registered in the advancedTerminalMenu.
    • I have modified the default values for these two. They were originally both set to 0.1 in previous versions of suitsTerminal.
  • The commands added by this mod no longer display in the "Other" command menu.
    • I may add support for this later, it was a TerminalAPI feature.
  • Updated chat command handling to not try to run the last chat message sent every single time enter is pressed.
  • Verified compatibility with latest version of TooManySuits when [dontRemove] is set to TRUE.
    • This allows for TooManySuits to be the only mod touching the suits on the rack, while still adding commands to the terminal.
    • One odd interaction I did find is that some suits could not be equipped from the terminal until you've at least cycled through all pages of TooManySuits' rack.
      • Not sure if this is something I can fix on my end alone.

[1.2.0]

  • Fixed issue where equipping suits from the terminal would not save the suit with the suit saver mod enabled.
    • This issue was resolved by using a different vanilla function to change a player's suit.
      • This also simplified my code a bit more and I no longer need to grab a player's playerID when changing the suit.
  • Fixed issue where buying the new bunny & bee suits would not add them to all player's suits terminal listing.
    • This issue seems to be caused by the fact that the bunny/bee suits do not update to be unlocked properly in the terminal and sometimes will continue to show in the store after being purchased.
  • Added better duplicate name handling for suits with the same display name.
    • Suits with the same unlockable name will now be displayed with their unique suit id value in the menu.
    • This will ensure you get all of the suits you've added to the game, even if they share the same name
      • If a model is replacing a specific suit name however, like NEON from valorant, then the model will replace all instances of that suit name.
      • This is something that has to do with the model replacement mod, I can retrieve the different suit IDs but the model replaces all of them lol.
  • Added config option to choose sorting method, [suitsSortingStyle]
    • Choose between alphabetical, numerical, and none.
    • Alphabetical goes off of the UnlockableName of the suit.
    • Numerical goes off of the syncedSuitID value for each suit.
    • None will apply no specific sorting and can result in host/client racks not being synced.
  • Added config options to display specific suits on the rack (up to 13), [suitsOnRackCustom] [suitsOnRackList]
    • When [suitsOnRackCustom] is enabled, will only show suits that match the suit names listed in suitsOnRackList.
    • Note that each suit name should be separated by a comma and that the suit names ARE case sensitive.
    • Favorite some suits and look at favoritesMenuList for examples of suit names.
    • These settings do not override any of the following config options: [suitsOnRack], [dontRemove], [hideRack]
  • Added new favorites system and menu page.
    • Added [favItemKey] to select suits to add to favorites menu.
    • Added [favMenuKey] to show favorites menu.
    • Updated menu handling for this new system.
    • Added new config item to save favorited suits [favoritesMenuList]. These will be stored/loaded each play session.
  • Adjusted menu slightly to make room for new key bindings, may find an alternative solution to make the page feel less cramped in the future.

[1.1.3]

  • Added new configuration options for removing the suit rack and the boots below the suit rack
    • Credits to Hamster (author of LethalPipeRemoval) for finding the specific objects.
    • enable hideRack to remove suit rack (this will ignore the suitsOnRack configuration since the entire rack is being deleted).
    • enable hideBoots to remove the boots below the suit rack.
    • Thanks also to seol.jihu on discord for pointing me towards Hamster's mod for an idea on how to implement this.
  • Added the ability to move/rotate/zoom the mirror camera to different fixed positions with related keybind config options.
    • togglePiPZoom: This key will be used to cycle between 4 different zoom options.
    • togglePiPHeight: This key will allow you to change the height of the mirror camera to see different parts of the suit you've equipped.
    • togglePiPRotation: This key will allow you to cycle between 4 different angles around the player so you can see each side of yourself and the back.
  • Cleaned up the menu a bit, moved all controls to the bottom of the menu below the suits list.
    • Also added some more checks to make sure the terminal isn't accepting input while in this menu.
    • Attached the mirror camera to a specific object on the terminal so that it scrolls with the text.
    • Increased the size of the mirror camera and added a slight opacity so that text behind it can still be seen.

[1.1.2]

  • Actually added the logic for handling the new configuration items for the advancedMenuSystem navigation. (lined out in below changes)
    • Also modified some of the keybinding logic to better handle errors & standardize keybinds to a few re-usable methods.

[1.1.1]

  • Added new key binding configuration items for menu system:

    • menuLeft: Change key used to navigate to previous page in advancedMenuSystem.
    • menuRight: Change key used to navigate to next page in advancedMenuSystem.
    • menuDown: Change key used to navigate to next item in advancedMenuSystem.
    • menuUp: Change key used to navigate to previous item in advancedMenuSystem.
    • Added the above bindings since lots of different mods like to use the arrow keys, and also maybe some of you would like to use WASD instead.
    • Also removed key limitations in bindings as these binds are ONLY active when in the menu system.
  • Added new configuration item for Mirror Camera:

    • setPiPCullingMask: Only modify this if you know what you are doing. Changes what is rendered on the camera.
  • Changed default culling mask for camera and added methods to ensure the body/arms of the player are shown on the camera when the camera is viewable.

    • When the player is no longer in the advancedMenuSystem and the camera is disabled the layer information that is changed will be reverted back to their last known state.
  • Changed all TerminalAPI related keywords to nouns instead of verbs. This should fix odd errors that were occuring whenever trying to purchase a suit that had suit in the name.

[1.1.0]

  • Moved changelog to separate file from readme.

  • Added advancedTerminalMenu and related configuration options.

    • leaveMenu: Keybind for exiting the advancedTerminalMenu (does not override exit terminal binding)
    • selectMenu: Keybind for selecting a suit to wear
    • togglePiP: Keybind for toggling the mirror-camera in the advancedTerminalMenu
    • enablePiPCamera: Set this to false to disable the mirror-camera preview completely.
    • advancedTerminalMenu: Set this to false to use the legacy terminal commands.
  • Compartmentalized some code away from working directly in patches

    • Should fix a handful of errors that were happening previously
  • Updated chat command handling once again. It's much more simplified and works very similarly to the advancedTerminalMenu

    • Uses a different vanilla method for adding chat messages.
    • To make things easier, you only type the number associated to the suit to wear it, i.e !wear 9 for the 9th suit.
    • Suit names and numbers are grabbed using the same logic as advancedTerminalMenu
    • Added invalid input error handling cases for when commands are misused.
  • Moved majority of logs to extensiveLogging, this is disabled by default.

  • Added configuration options to enable/disable the hints that display when first loading in.

    • chatHints: Disable or Enable hints that display in chat.
    • bannerHints: Disable or Enable hints that display as banners when you load in (similar to the modlist check by LC_API).
  • Updated handling method for suits bought in the store.

    • Locked suits that have a store node should not be added to the suits list.
    • The suits list is updated each time a purchase is made in the terminal to account for suits being unlocked.
  • Fixed a long-time known issue of host/client having different suits on the rack

    • Sorting is now done alphabetical instead of numerical by suitID to accomplish this.

[1.0.6]

  • Added configuration option to disable terminal commands.

  • Added configuration option to disable this mod's interactions with the rack at all (will make this mod compatible with TooManySuits or any other future alternatives)

  • Updated chat command handling and added more specific messages when loading in based on how the mod is configured.

[1.0.5]

  • Fixed purchase-able suits appearing floating next to the rack and not being wearable from the terminal.

  • Added chat commands similar to terminal commands. (!suits/!wear)

  • Added configuration option to disable chat commands.

[1.0.4]

  • Added character limit to suit names to resolve some issues with extra long suit names, thanks ?B1adeWo1f for the report on discord.

  • Added configuration option for enabling/disabling randomsuit command.

[1.0.3]

  • Updated compatibility for any mod that for whatever reason removes keywords like Advanced Company was doing.

  • Added configuration option to allow for leaving up to 13 suits on the rack. Default is 0.

  • Added configuration option to replace negative suitIDs with positive ones, default is disabled as this may cause issues.

  • Added command 'randomsuit' which will allow you to change to a random suit from the list.

[1.0.2]

  • Added compatibility check with Advanced Company that fixes the issue where it would break the terminal commands in this mod.

  • Removed method for replacing negative suitIDs and now just completely removing them. As far as I've seen the only suit that has this issue is the green suit from vanilla.

[1.0.1]

  • Fixed issue where the mod would break if the host closed and opened a new lobby (sorry I left this in 1.0.0, thought i'd put a fix in before publishing)

  • Added Hud/Chat hints when loading in to inform player that the suits were moved off the rack to the terminal.

[1.0.0]

Initial release version