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

Кто-Нибудь реализовывал фильтрацию листа с пагинацией? Стоит задача сделать окно со

списком с кучей фильтров по типу все/только тип 1/только тип 2 итд. Непонятно как в этом случае реализовывать подгрузку данных с сервера (могу пояснить проблемы которые я предрекаю если использовать 1 таблицу для всего). Единственное решение которое я вижу (которое мне косвенно так же предлагал работник гугла на issue трекере когда я задавал вопрос по сортировке paging листа по match info) это заводить под каждый фильтр отдельную таблицу со всеми вытекающим

19 ответов

13 просмотров

Например, в запросе передавать параметры фильтра + размер и номер страницы. И пусть себе бэкенд работает.

Кирилл- Автор вопроса

Проблема в offline first и сохранении данных. Вероятные кейсы проблем если использовать одну таблицу для всего: Пока мы находимся во вкладке всё - все отлично, пагинация всегда работает правильно, но вот мы переключаемся на другой фильтр и доходим до конца списка. Имеем два пути, запросить с сервера всё с лимитом в 50 записей, их инсертнуть и надеяться что в них будет нужный нам тип айтемов, либо запросить 50 записей только с нужным нам типом. В первом случае может идти спам запросов потому что записей может быть например 2000 а нужного типа 60, причем например 30 в самом начале и 30 в самом конце. Во втором случае мы получим пропасть между данными потому что новые данные инсертнуться в бд. (потому что offline first и бд - single source of truth)

Кирилл- Автор вопроса

Поэтому я вижу только одно нормальное решение - отдельная таблица для каждого типа фильтров, но из этого вытекает куча шаблонного кода. Поэтому я и спрашиваю, может кто решал подобный кейс уже или знает хорошие доклады где подобное поднималось

Что означает offline first в вашем случае? Нужно гуглить подобные решения. Вы не единственный у кого такая задача возникает. Наверняка для этого уже есть паттерн. Кроме того, набор данных с сервера и переключение туда-сюда между страницами UI - две совершенно независимые вещи.

Кирилл- Автор вопроса

Что означает offline first в вашем случае? локальное хранилище - единственный источник правда

То есть для каждого юзера будет создаваться таблица с результатами поиска по какому-то набору фильтров? А если начальство захочет изменить какой-нибудь фильтр (убрать/добавить критерии поиска), то это решение будет работать? Кто будет чистить старые результаты поиска на сервере? Как долго их хранить для конкретного юзера?

Кирилл- Автор вопроса

Причем тут сервер? Я про приложение все это время говорю. Сервер у меня фигурирует только как что-то что отдает данные по запросу

Откуда оно данные берет?

Кирилл- Автор вопроса

С сервера конечно, но манипулирует ими приложение

Ну, тогда тут два варианта: 1. Сервер разбивает всё на страницы по запросу от приложения, а приложение показывает готовый результат (кроссплатформенность) 2. Приложение само решает все вопросы с разбивкой данных (писать каждый раз отдельно для Android, iOS, web, etc, вносить изменения и глюки чинить - тоже)

Кирилл- Автор вопроса

Любой вариант где это будет решать сервер сразу отпадает, бекендер у нас не любит делать лишнюю работу а протолкнуть хоть что-то для удобства фронта целое достижение

Знакомая ситуация. Тады ой. Придется пилить толстый клиент со всеми вытекающими последствиями.

В идеале вопросы архитектуры должны решать не программисты, а ваши лиды с архитекторами и брать на себя за это ответственность.

Кирилл- Автор вопроса

Такие появятся "когда в проект придут инвестиции" а пока только я, веб разработчик и он

Мдэ.

Веб-разработчик тоже должен такую пагинацию запилить на своей стороне, чтобы бэкенд отдыхал? 😄 Как быть с iOS?

Кирилл- Автор вопроса

Там веб - админка, не знаю что там. Любая моя критика апи заказчику всегда разбивается об очень опытный бэкэндер, его апи стоит в куче крупных предприятий и банках, оно очень крутое куча очень полезных нам функции (нет). Про iOS - пока вообще не думаем

До мудрого руководства нужно вежливо и аккуратно донести в письменном виде возможные риски клиентского решения. Критиковать никого не стоит, этого никто не любит. Просто выложить факты подтвержденные цифрами, например: - лишний трафик у клиентов, - возможная нехватка памяти==крэш на отдельных устройствах, потому что у Андроида их целый зоопарк и все протестировать невозможно - возможные проблемы с быстродействием на разных устройствах тоже по причине зоопарка, т.к. придется выполнять работу сервера на слабых устройствах - для такого опытного бэкендера не должно быть проблемой реализация дополнительной функции 😝 - iOS потребует в будущем повторной реализации этого функционала

Мне тоже нужно такой кейс( как в ютубе или в интернет магазинах

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

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

а через ESC-код ?
Alexey Kulakov
29
30500 за редактор? )
Владимир
47
Чёт не понял, я ж правильной функцией воспользовался чтобы вывести отладочную информацию? но что-то она не ловится
notme
18
У меня есть функция где происходит это: write_bit(buffer, 1); write_bit(buffer, 0); write_bit(buffer, 1); write_bit(buffer, 1); write_bit(buffer, 1); w...
~
13
Недавно Google Project Zero нашёл багу в SQLite с помощью LLM, о чём достаточно было шумно в определённых интернетах, которые сопровождались рассказами, что скоро всех "ибешни...
Alex Sherbakov
5
Как передать управляющий символ в открытую через CreateProcess консоль? Собсна, есть процедура: procedure TRedirectThread.WriteData(Data: OEMString); var Written: Cardinal;...
Serjone
6
в JclConsole объявлено так: function CtrlHandler(CtrlType: DWORD): BOOL; stdcall; - где ваше объявление с stdcall? у вас на картинке нет stdcall
Karagy
8
Ребят в СИ можно реализовать ООП?
Николай
33
program test; {$mode delphi} procedure proc(v: int32); overload; begin end; procedure proc(v: int64); overload; begin end; var x: uint64; begin proc(x); end. Уж не знаю...
notme
6
https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_h_common.erl#L174 https://github.com/erlang/otp/blob/OTP-27.1/lib/kernel/src/logger_olp.erl#L76 15 лет назад...
Maksim Lapshin
20
Карта сайта