Set up icons, make UI a little more resiliant

This commit is contained in:
Lucien Greathouse
2019-01-11 11:57:15 -08:00
parent 14e1829164
commit 5ad830a6d7
3 changed files with 64 additions and 19 deletions

View File

@@ -1,13 +1,16 @@
local Roact = require(script:FindFirstAncestor("Rojo").Roact)
local Session = require(script.Parent.Parent.Session)
local Config = require(script.Parent.Parent.Config)
local Version = require(script.Parent.Parent.Version)
local Logging = require(script.Parent.Parent.Logging)
local DevSettings = require(script.Parent.Parent.DevSettings)
local Plugin = script:FindFirstAncestor("Plugin")
local ConnectPanel = require(script.Parent.ConnectPanel)
local ConnectionActivePanel = require(script.Parent.ConnectionActivePanel)
local Icons = require(Plugin.Icons)
local Session = require(Plugin.Session)
local Config = require(Plugin.Config)
local Version = require(Plugin.Version)
local Logging = require(Plugin.Logging)
local DevSettings = require(Plugin.DevSettings)
local ConnectPanel = require(Plugin.Components.ConnectPanel)
local ConnectionActivePanel = require(Plugin.Components.ConnectionActivePanel)
local e = Roact.createElement
@@ -50,7 +53,7 @@ end
local SessionStatus = {
Disconnected = "Disconnected",
Connected = "Connected",
Configuring = "Configuring",
ConfiguringSession = "ConfiguringSession",
-- TODO: Error?
}
@@ -67,6 +70,8 @@ function App:init()
sessionStatus = SessionStatus.Disconnected,
})
self.connectButton = nil
self.configButton = nil
self.currentSession = nil
self.displayedVersion = DevSettings:isEnabled()
@@ -81,7 +86,7 @@ function App:render()
children = {
ConnectionActivePanel = e(ConnectionActivePanel),
}
elseif self.state.sessionStatus == SessionStatus.Configuring then
elseif self.state.sessionStatus == SessionStatus.ConfiguringSession then
children = {
ConnectPanel = e(ConnectPanel, {
startSession = function(address, port)
@@ -126,25 +131,30 @@ function App:didMount()
local toolbar = self.props.plugin:CreateToolbar("Rojo " .. self.displayedVersion)
-- TODO: Icon!
local connectButton = toolbar:CreateButton("Connect", "Connect to Rojo Session", "")
connectButton.ClickableWhenViewportHidden = true
connectButton.Click:Connect(function()
connectButton:SetActive(false)
self.connectButton = toolbar:CreateButton(
"Connect",
"Connect to a running Rojo session",
Icons.StartSession)
self.connectButton.ClickableWhenViewportHidden = false
self.connectButton.Click:Connect(function()
checkUpgrade(self.props.plugin)
if self.state.sessionStatus == SessionStatus.Connected then
Logging.trace("Disconnecting session")
error("NYI")
self.currentSession = nil
self:setState({
sessionStatus = SessionStatus.Disconnected,
})
error("TODO: Actually disconnect old session")
elseif self.state.sessionStatus == SessionStatus.Disconnected then
Logging.trace("Starting session configuration")
self:setState({
sessionStatus = SessionStatus.Configuring,
sessionStatus = SessionStatus.ConfiguringSession,
})
elseif self.state.sessionStatus == SessionStatus.Configuring then
elseif self.state.sessionStatus == SessionStatus.ConfiguringSession then
Logging.trace("Canceling session configuration")
self:setState({
@@ -152,6 +162,28 @@ function App:didMount()
})
end
end)
self.configButton = toolbar:CreateButton(
"Configure",
"Configure the Rojo plugin",
Icons.Configure)
self.configButton.ClickableWhenViewportHidden = false
self.configButton.Click:Connect(function()
self.configButton:SetActive(false)
end)
end
function App:didUpdate()
local connectActive = self.state.sessionStatus == SessionStatus.ConfiguringSession
or self.state.sessionStatus == SessionStatus.Connected
self.connectButton:SetActive(connectActive)
if self.state.sessionStatus == SessionStatus.Connected then
self.connectButton.Icon = Icons.SessionActive
else
self.connectButton.Icon = Icons.StartSession
end
end
return App

View File

@@ -51,7 +51,7 @@ function ConnectPanel:render()
LayoutOrder = 1,
Font = Enum.Font.SourceSans,
TextSize = 22,
Text = "Start Rojo Session",
Text = "Start New Rojo Session",
Size = UDim2.new(1, 0, 0, 28),
BackgroundTransparency = 1,
TextColor3 = Color3.new(1, 1, 1),

13
plugin/src/Icons.lua Normal file
View File

@@ -0,0 +1,13 @@
local Icons = {
StartSession = "",
SessionActive = "",
Configure = "",
}
setmetatable(Icons, {
__index = function(_, key)
error(("%q is not a valid member of Icons"):format(tostring(key)), 2)
end
})
return Icons