alphabet_scroll_view
alphabet_scroll_view copied to clipboard
Navigation by letter tapping is not working when itemExtent is not the exact row height
I was trying to have a dynamic height for the rows used in your AlphabetScrollView component.
My idea was to set a huge itemExtent value so that the rows would resize themselves automatically. Actually it did work.
However, it looks like your scrolling when a letter is tapped is based on that itemExtent value and so the scroll offset is not correct.
How could I have dynamic heights and the navigation working?
Thanks in advance
Code snippet:
AlphabetScrollView(
list: list.map((e) => AlphaModel(e)).toList(),
itemExtent: MediaQuery.of(context).size.height,
unselectedTextStyle: TextStyle(
fontSize: 18, fontWeight: FontWeight.normal, color: Colors.black),
selectedTextStyle: TextStyle(
fontSize: 20, fontWeight: FontWeight.bold, color: Colors.red),
itemBuilder: (context, k, id) {
return Padding(
padding: const EdgeInsets.only(right: 40.0),
child: Card(
child: ListTile(
title: Text('$id'),
subtitle: Text(
id.length.isOdd
? 'Lorem ipsum dolor sit amet, consectetur adipiscing elit. Feugiat vel tellus felis, ac phasellus sed massa. Feugiat vel tellus felis, ac phasellus sed masslis, ac phasellus sed massa.'
: 'Lorem ipsum dolor sit amet, consectetur adipiscing elit.',
),
leading: Icon(Icons.person),
),
),
);
;
},
)
data:image/s3,"s3://crabby-images/3cbdb/3cbdb56c99a4bb312415772f284317c110a1e719" alt="alphabet"
However, it looks like your scrolling when a letter is tapped is based on that itemExtent value and so the scroll offset is not correct.
You are right, And The issue looks like you have itemExtent
set to screen height that is causing this issue.
dynamic height is not supported as of now. I am sorry about that, I am planning to rework on this plugin soon to fix a bunch of those errors.
Thanks for your answer @maheshmnj . I will follow your progress then because it is a very promising package. Thanks for that