169 похожих чатов

3 ответов

11 просмотров

const allElement = { id: 'All', title: 'All', }; const TabFilter: React.FC<TabFilterProps> = memo(({ data, onChange, isNeedAll }) => { const [itemsList, setItemsList] = useState(data); const [selectItem, setSelectItem] = useState(isNeedAll ? allElement.id : data[0].id); useEffect(() => { if (isNeedAll && data) { const newData = [allElement, ...data]; setItemsList(newData); } }, [isNeedAll, data]); const Item: React.FC<ItemProps> = memo(({ item }) => { const isselectId = selectItem === item.id; const selectHandler = useCallback(() => { setSelectItem(item.id); onChange(item.id); }, [item.id]); return ( <TouchableOpacity style={styles.item} onPress={selectHandler}> <View style={styles.itemContainer}> <Text size="middle" type="medium" style={{ ...styles.selectText, color: isselectId ? COLORS.primary : COLORS.lightGray, }} numberOfLines={1} > {item.title} </Text> {item.num ? ( <View style={styles.numContainer}> <Text style={styles.number} numberOfLines={1} ellipsizeMode="tail"> {item.num} </Text> </View> ) : null} </View> <View style={{ ...styles.underline, backgroundColor: isselectId ? COLORS.backgroundDark : COLORS.white, }} /> </TouchableOpacity> ); }); return ( <View style={styles.container}> <FlatList data={itemsList} showsHorizontalScrollIndicator={false} // eslint-disable-next-line react-perf/jsx-no-new-function-as-prop keyExtractor={item => item.id} // eslint-disable-next-line react-perf/jsx-no-new-function-as-prop renderItem={({ item }) => <Item item={item} />} horizontal contentContainerStyle={styles.scrollContainer} /> </View> ); });

Влад Колядюк 🥷
Зачем? это же просто навигация

Нам она не подошла, пришлось писать самому

Похожие вопросы

Обсуждают сегодня

Комрады, хотел уточнить. Проперть в OnDestroy юнита-хозяина по-прежнему доступна? И еще уточнение: finalization юнита наступает раньше или позже OnDestroy?
Ed Doc
39
Проблема с Windows scripting control Множество объектов получают iDispatch обертки и отдаются в скрипты. При этом скрипты могут эти обертки держать живыми очень долго, наприм...
Arioch The
16
Скажите, можно ли как-то "переместить" динамический массив из одной переменной в другую? Скажем, переместить из TList<> в TArray<>. Именно переместить, а не скопировать. Если ...
Eugene Krasnikov (ᴊɪɴ x)
37
Я тут пытаюсь переработать архитектуру подсистемы памяти ядра во что-то осмысленное. Есть pmm, который создает набор range’ей(пока что только для ядра, потом для юзерспейса), ...
Evg Resh
9
комрады, че-та лыжы не едут var tmpFont: TFont; begin tmpFont:= TFont.Create; try case rgFontColor.ItemIndex of 0: tmpFont.Color:= clWindowText; 1: tmpFo...
Ed Doc
34
Вот еще криповенькая штука. uMain.pas(517,3) Warning: Case statement does not handle all possible cases И ЧО? 😂
Александр (Rouse_) Багель
20
Интересно, нет ли какого-то способа получить из dll не адрес самой метки, а адрес со смещением?
The Bird of Hermes
54
коллеги, а есть простой способ определить, что программу из под Delphi запускают?
Михаил
10
М-да. Почему бы просто со stringlist не работать?
Michael Longneck
23
.model small .stack 100h .data a db 'Hello, World!', '$' ; исходная строка b db 20 dup(?) ; строка b с запасом на максимальную длину .code main: ...
Алексей -man
3
Карта сайта