Files
iOS/Sources/Extensions/Widgets/Controls/Button/ControlButtonValueProvider.swift
Bruno Pantaleão Gonçalves 12aa9c9849 Provide areas and device context for all extensions entity pickers (#4756)
<!-- Thank you for submitting a Pull Request and helping to improve Home
Assistant. Please complete the following sections to help the processing
and review of your changes. Please do not delete anything from this
template. -->

## Summary
<!-- Provide a brief summary of the changes you have made and most
importantly what they aim to achieve -->

## Screenshots
<!-- If this is a user-facing change not in the frontend, please include
screenshots in light and dark mode. -->

## Link to pull request in Documentation repository
<!-- Pull requests that add, change or remove functionality must have a
corresponding pull request in the Companion App Documentation repository
(https://github.com/home-assistant/companion.home-assistant). Please add
the number of this pull request after the "#" -->
Documentation: home-assistant/companion.home-assistant#

## Any other notes
<!-- If there is any other information of note, like if this Pull
Request is part of a bigger change, please include it here. -->

---------

Co-authored-by: Claude Opus 4.8 (1M context) <noreply@anthropic.com>
2026-06-17 13:24:37 +02:00

83 lines
2.7 KiB
Swift

import AppIntents
import Foundation
import SFSafeSymbols
import Shared
import WidgetKit
@available(iOS 18, *)
struct ControlButtonValueProvider: AppIntentControlValueProvider {
func currentValue(configuration: ControlButtonConfiguration) async throws -> ControlEntityItem {
item(entity: configuration.entity, iconName: configuration.icon, displayText: configuration.displayText)
}
func placeholder(for configuration: ControlButtonConfiguration) -> ControlEntityItem {
item(entity: configuration.entity, iconName: configuration.icon, displayText: configuration.displayText)
}
func previewValue(configuration: ControlButtonConfiguration) -> ControlEntityItem {
item(entity: configuration.entity, iconName: configuration.icon, displayText: configuration.displayText)
}
private func item(
entity: IntentButtonEntity?,
iconName: SFSymbolEntity?,
displayText: String?
) -> ControlEntityItem {
let placeholder = placeholder()
if let entity {
return .init(
id: entity.id,
entityId: entity.entityId,
serverId: entity.serverId,
name: displayText ?? entity.displayString,
icon: iconName ?? .init(id: entity.iconName),
value: false // Buttons are stateless
)
} else {
return .init(
id: placeholder.id,
entityId: placeholder.entityId,
serverId: placeholder.serverId,
name: displayText ?? placeholder.displayString,
icon: .init(id: placeholder.iconName),
value: false
)
}
}
private func placeholder() -> IntentButtonEntity {
.init(
id: UUID().uuidString,
entityId: "",
serverId: "",
displayString: L10n.Widgets.Controls.Button.pendingConfiguration,
iconName: SFSymbol.circleCircle.rawValue
)
}
}
@available(iOS 18.0, *)
struct ControlButtonConfiguration: ControlConfigurationIntent {
static var title: LocalizedStringResource = .init(
"widgets.controls.button.title",
defaultValue: "Button"
)
@Parameter(
title: .init("app_intents.server.title", defaultValue: "Server")
)
var server: IntentServerAppEntity?
@Parameter(
title: .init("widgets.controls.button.title", defaultValue: "Button")
)
var entity: IntentButtonEntity?
@Parameter(
title: .init("app_intents.scripts.icon.title", defaultValue: "Icon")
)
var icon: SFSymbolEntity?
@Parameter(
title: .init("app_intents.display_text.title", defaultValue: "Display Text")
)
var displayText: String?
}