Generic SettingView #23
Labels
enhancement
New feature or request
Generic SettingView
Help needed!
help wanted
Extra attention is needed
The problem
Currently SettingView renders each element via a huge
switch
.This has several limitations:
No support for custom
Setting
sThe switch statement checks against
SettingText
,SettingButton
,SettingToggle
, etc. Say we had our own element calledSettingLabel
:This would fall through in the switch statement and error out.
Limited customization (no subclass / composing support)
This is related to the above issue. Let's say you want to make a bunch of
SettingText
s blue. Right now you need to do this:Ideally you'd be able to make a new element that conforms from
Setting
.This code compiles, but it will fall through in the above mentioned issue with the switch statement.
Reliance on stable
ID
identifiersYou might have noticed all the
var id: AnyHashable?
s floating around. This is because of theForEach
loop forSettingPage
,SettingGroup
, andSettingTupleView
.Currently,
Setting
synthesizes this ID depending on the element — forSettingText
, it gets thetitle
property. ForSettingTupleView
, it getstuple.flattened.compactMap { $0.textIdentifier }.joined()
.https://github.com/aheze/Setting/blob/main/Sources/Setting.swift#L18-L38
Ideally, we could get rid of this
ID
and just use aView
's default identity. (For more details, see How the SwiftUI View Lifecycle and Identity work, "Identity of a view" section.)No support for custom view modifiers
This requires changes to
SettingBuilder
.The solution
SettingView
needs to be generic, resembling SwiftUI'sView
as closely as possible.If possible, we should make
Setting
conform toView
, so that we can render it directly without the need for a hugeswitch
.I've attempted this and got lost quickly — I'm not good with generics.
Any help? :)
The text was updated successfully, but these errors were encountered: