Size: a a a

GraphQL — русскоговорящее сообщество

2021 July 10

ОЛ

Олег Линьков... in GraphQL — русскоговорящее сообщество
Лучшим решением самому написать. А не надеяться на код ген или что-то вроде adminBro
источник

🦜

🦜 in GraphQL — русскоговорящее сообщество
ладно, спасибо
источник
2021 July 11

AD

Alex Derbenev in GraphQL — русскоговорящее сообщество
Чат, привет!
Подскажите, насколько правильно использовать Union в случае, когда есть две похожие сущности, но разного типа, с немного отличающимися полями и лежащие в одной таблице в базе (хранение в одной таблице обусловлено бизнес логикой)?

Например:
* Есть таблица articles, в которой есть столбец с типом статьи
* В зависимости от типа для статьи нужен конкретный набор полей из таблицы
* Возникает разумное желание разделить Object и Input типы на типы для разных типов статей, что в свою очередь ведет к потребности сделать Union для отображения статей разного типа в одном пагинируемом списке на фронте

Если в таком кейсе использование Union неправильно, то где это более применимо?
источник

AN

Andrey Nikolaev in GraphQL — русскоговорящее сообщество
в вашем примере c articles лучше подойдет интерфейс
источник

AD

Alex Derbenev in GraphQL — русскоговорящее сообщество
Я так понимаю, юнион больше для совсем разных сущностей - например для организации API для поиска по разным сущностям?
источник

AN

Andrey Nikolaev in GraphQL — русскоговорящее сообщество
да
источник

Т

Тупик in GraphQL — русскоговорящее сообщество
Друзья, кто нибудь знает как из rank math seo breadcrumbs передать данные в микроразметку?
источник

AD

Alex Derbenev in GraphQL — русскоговорящее сообщество
Возник вопрос об использовании типов, реализующих интерфейсы, на фронтенде.
Ситуация следующая:
* на фронте React и Apollo Client
* настроена кодогенерация через graphql-codegen
Судя по информации отсюда (https://www.apollographql.com/docs/react/v2/data/fragments/#fragments-on-unions-and-interfaces), клиент легко может запрашивать массив объектов, типы которых реализуют один и тот же интерфейс. При этом есть возможность настройки fragmentMatcher'а (https://www.graphql-code-generator.com/docs/plugins/fragment-matcher).
Но вот вопрос - насколько удобно будет в коде видеть тип объекта? И как можно будет понять, какого типа объект? Будет ли у объектов, полученных в результате выполнения запроса, соответствующий сгенерированный Typescript тип?
источник

AD

Alex Derbenev in GraphQL — русскоговорящее сообщество
Получается, что на фронте будет что-то такое?

function Articles({ articles }: Articles) {
 return articles.map(article => {
   switch(article.__typename) {
     case "ArticleFirstType":
       return <ArticleFirst article={article} />
     case "ArticleSecondType":
       return <ArticleSecond article={article} />
   }
 });
}
источник

DM

Daniil Mikurov in GraphQL — русскоговорящее сообщество
всем привет, не понимаю почему случается ошибка...
https://hqnjs.csb.app/


когда открыты девтулс, останавливается как на дебаггере.
Error: Unknown error.
источник

DM

Daniil Mikurov in GraphQL — русскоговорящее сообщество
источник
2021 July 12

B

Bohdan in GraphQL — русскоговорящее сообщество
Всем добрый день
Если в useQuery один раз зашел запрос с одними variable, второй запрос такой же - то второй не выполняется а данные берутся из кеша, это так работает?
источник

EV

Eugene Visotskiy in GraphQL — русскоговорящее сообщество
в теории да. На практике - не всегда
источник

B

Bohdan in GraphQL — русскоговорящее сообщество
а как на практике, если подробнее?
источник

EV

Eugene Visotskiy in GraphQL — русскоговорящее сообщество
я вызывал одну и ту же кверю с одними и теми же переменными в 2-х разных контейнерах - и они вызывались 2 раза подрад
источник

B

Bohdan in GraphQL — русскоговорящее сообщество
может у тебя разные компоненты?
источник

EV

Eugene Visotskiy in GraphQL — русскоговорящее сообщество
ну да, но я ожидал что первая кверя вызовется, вторая - просто отобразит состояние данных первой квери (лоадер, данные и т.д.). Оказалось - нет
источник

B

Bohdan in GraphQL — русскоговорящее сообщество
Наверное что бы юзать в разных компонентах лучше использовать локальное состояние apollo
источник

EV

Eugene Visotskiy in GraphQL — русскоговорящее сообщество
пропс loading всё-равно не перенесётся в локальное состояние
источник

C

Ciemna_noc in GraphQL — русскоговорящее сообщество
ведь можно же изменить кэш не вызывая мутацию? или это сложно?
источник