Na documentação eles dizem isso:
Uso básico Implemente ListDetailPaneScaffold da seguinte forma:
Use uma classe que represente o conteúdo a ser selecionado. Essa classe deve ser Parcelable para dar suporte a salvar e restaurar o item de lista selecionado. Use o plugin kotlin-parcelize para gerar o código para você.
@Parcelize
class MyItem(val id: Int) : Parcelable
E depois, eles usam isso dessa maneira:
val navigator = rememberListDetailPaneScaffoldNavigator<MyItem>()
Por que eles pedem para você usar uma classe personalizada? Por que não usar simplesmente um Int representando o índice atual clicado? Simplesmente isso:
val navigator = rememberListDetailPaneScaffoldNavigator<Int>()
Estou perdendo alguma coisa? Eu testei e funciona. Ele até sobrevive a mudanças de configuração sem ter que lidar com Parcelable. Ele simplifica tudo. Por que adicionar a complexidade de uma classe Parcelable personalizada em vez de simplesmente usar um índice Int?
Esse é apenas um exemplo. Claro que você pode usar
rememberListDetailPaneScaffoldNavigator<Int>()
instead quando a classe de dados contém apenas um Int. Mas ele mostra como você pode lidar com objetos mais complexos também.Em um layout clássico e não adaptável, você passaria um
MyItem
objeto do seu composable de lista para o composable de detalhes.MyItem
seria uma parte do estado da interface do usuário, contendo os detalhes do item de lista selecionado no momento. Normalmente, isso será muito mais do que apenas um simples Int. Imagine uma lista de pessoas onde o usuário pode selecionar uma pessoa para exibir os detalhes da pessoa. Então você precisaria de um objeto personalizado com muito mais propriedades do que apenas um id, como um primeiro nome, sobrenome, data de nascimento, país de origem e assim por diante.Ao tornar esse objeto parcelável, ele também pode ser usado no ListDetailPaneScaffold, onde precisa ser colocado no backstack da navegação (em um formato serializado) e salvo no sistema de arquivos como um Bundle para sobreviver a alterações de configuração e à morte do processo iniciado pelo sistema. Esses são os mesmos requisitos para salvar um objeto com
rememberSaveable
.Se você não precisar passar nada para o componente details, você pode usar a
rememberListDetailPaneScaffoldNavigator
sobrecarga sem um parâmetro de tipo.