jellyflood/Swiftfin tvOS/Views/SelectUserView/Components/AddUserBottomButton.swift
Glenn Hevey e6cc848138
[tvOS] Move AddUserButton to the bottom bar of Select User View (#1468)
* Added add user button to select user bottom bar

* Replaced AddUserButton with NoUserView

This commit removes the AddUserButton as it is no longer required.
Also when no user is logged in the GridView shows a new NoUserView

* Added multi server support

- When no user is logged in. Grid view shows the original AddUserButton.
- When there is a logged in user AddUserButton is replaced with AddUserBottomButton
- AddUserBottomButton will show a menu when in all server mode (just like AddUserbutton)
- Removed NoUserView as it isn't required anymore
- changed bottom bar layout to  allow for a larger service selection button

* cleaned up AddUserBottomButton

* cleaned up AddUserBottomButton

fixed formatting

* cleanup

* fix conflict

* cleaned up unused localisation

* cleanup

* removed debug background

---------

Co-authored-by: Ethan Pippin <ethanpippin2343@gmail.com>
2025-04-06 16:51:44 -04:00

68 lines
1.7 KiB
Swift

//
// Swiftfin is subject to the terms of the Mozilla Public
// License, v2.0. If a copy of the MPL was not distributed with this
// file, you can obtain one at https://mozilla.org/MPL/2.0/.
//
// Copyright (c) 2025 Jellyfin & Jellyfin Contributors
//
import OrderedCollections
import SwiftUI
extension SelectUserView {
struct AddUserBottomButton: View {
// MARK: Properties
private let action: (ServerState) -> Void
private let selectedServer: ServerState?
private let servers: OrderedSet<ServerState>
// MARK: View Builders
@ViewBuilder
private var label: some View {
Label(L10n.addUser, systemImage: "plus")
.foregroundStyle(Color.primary)
.font(.body.weight(.semibold))
.labelStyle(.iconOnly)
.frame(width: 50, height: 50)
}
// MARK: - Initializer
init(
selectedServer: ServerState?,
servers: OrderedSet<ServerState>,
action: @escaping (ServerState) -> Void
) {
self.action = action
self.selectedServer = selectedServer
self.servers = servers
}
// MARK: Body
var body: some View {
ConditionalMenu(
tracking: selectedServer,
action: action
) {
Text(L10n.selectServer)
ForEach(servers) { server in
Button {
action(server)
} label: {
Text(server.name)
Text(server.currentURL.absoluteString)
}
}
} label: {
label
}
}
}
}