CubeCat is a plugin framework to make plugin development easier.
CubeCat is used to write plugins that can easily interact with other plugins by adding ways to allow developers to write code which would interact with other plugins that use CubeCat.
Roblox's Plugin market is extremely unprofitable due to high rates which are hard to fix on Roblox's side. By using CubeCat, it becomes easy to integrate new features into your plugin code through the use of other plugins. This means you could write a plugin to convert instances into Instance.new calls, then have another plugin which adds the ability for the previous plugin to convert instances into Fusion.New calls or Roact.createElement calls. This allows users to pay only for what they need, saving them money, while also allowing you to produce more features for your plugin that users can choose if they want to get or not and pay extra for.
CubeCat's main benefit comes with writing a basic "Lite" plugin, that gives a small amount of features, then having multiple small feature packs for that Lite plugin that expands it into a very powerful full-sized tool.
CubeCat is designed around the concept of "interconnecting" with other CubeCat plugins. We'll have to write code in a way that makes it easy to expand. Your plugin has to consist of Services and Components.
Services should be used to handle all of the main logic in your plugin. This ranges from just saving some data to reading chunks of voxels. You'll also only be able to interact with Services from other plugins, so make sure that you write services that allow you to inject a user interface into your plugin UI to allow for other plugins to expand upon that.
Components are written using Fusion. CubeCat already provides a suite of components to be used with your plugins. It's recommended to design your UI around reflecting the state of a Service, rather than maintaining internal state and passing that to other components.
There is no proper way for other plugins to implement user interface into the plugin it is injecting into, other than having a service that injects it manually. Currently, we are planning to introduce a Export "" SpecialKey to Fusion which allows the exporting of state.
New "Frame" {
Name = "Tabs",
Position = UDim2.new(0, 0, 0, 24),
Size = UDim2.new(1, 0, 0, 32),
BackgroundColor3 = Theme:GetColor(Enum.StudioStyleGuideColor.Background),
[Children] = TabsService:GetTabs()
[Export "Tabs"] = {StateObject<any>}
}
This is still a experimental thing and has to be expanded upon.
Projects should probably be structured like the following:
- src/
- services/
- modules/
- components/
CubeCat is available on Wally, and comes with Fusion.