npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

glhera-query

v2.0.0-next.5

Published

**glhera-query** é uma biblioteca frontend para sincronizar data de fetch como do [TanStack Query](https://tanstack.com/query/latest/docs/framework/react/overview) mais conhecido como **React Query**

Downloads

16

Readme

glhera-query

glhera-query é uma biblioteca frontend para sincronizar data de fetch como do TanStack Query mais conhecido como React Query

A diferença entre o glhera-query e o TanStack Query é que o glhera-query é signal based e não faz cache por padrão (somente em queries infinitas) e o cache para queries infinitas é diferente

Por conta de ser signal based e não fazer cache o glhera-query pode ser extremamente simples e mais fácil de usar do que o TanStack Query

Para entender o porquê não fazer cache torna mais fácil de usar é só entender que no TanStack Query ele precisa de keys, essas chaves são necessárias para fazer cache, quando não se depende de cache, uma grande complexidade da aplicação é removida, tornando tudo mais fácil e simples de se usar

Diferenças do TanStack Query

  • Só faz cache para queries infinitas com key based como no TanStack Query
  • O mecanismo de resincronização (stale queries, windows focus refetching) das queries não é automatico, ele deve ser configurado por query

Recursos do TanStack Query considerados desnecessários para o glhera-query

Pode ser legal ter um recurso adicional, mas requer bundle e custa recursos, especialmente se não usado

Notas: Não consideramos que esses recursos sejam desnecessários para todas as aplicações, alguns dos recursos do TanStack Query podem ser cruciais dependendo da aplicação que está sendo feita

  • prefetching
  • mutations
  • cache com keys

Por conta dessas diferenças, para que um app usando glhera-query faça grande parte do que um app com o TanStack Query (desconsiderando cache) é muito mais simples e depende de menos bundle

Recursos sendo implementados

  • [x] Cancellable fetch (Abort Signal)
  • [ ] Infinite Queries
  • [-] Scroll Restoration? (Is needed?)
    • Lendo o código fonte do React Query eu não vi nada a respeito, provavelmente se recarregar o estado da aplicação de maneira sincrona o browser aparentemente já retoma a posição de maneira automática
  • [-] Retry
    • Não é necessário em nossos projetos, mas talvez possa fazer algum utilitário que faz retry
  • [ ] Window Focus Refetching Copiar o focusManager?
    • Fez uma versão adaptada do focusManager
  • [ ] Refetch stale. Copiar o onlineManager?
    • Fez uma versão adaptada do onlineManager
  • [ ] Pause query, como no React Query

Mudanças ao longo do tempo

  • Agora as queries precisam ser enabled e quando elas foram enabled elas passam a reagir aos query params da rota
  • Adicionado focusManager, onlineManager e um client como do React Query, mas eles ainda não estão sendo usados pelo storeRequest
    • Por conta de adicionar onlineManager, também adicionou-se fetchStatus: 'paused'
  • Caso uma query seja enabled des do princípio, ela já é criada fazendo fetch

A maior diferença entre o glhera-query e o React Query agora é que o glhera-query é signal based e ele invalida o cache de outros itens da lista, ao invés de ficar guardando diversos itens

  • A forma que onlineManager funciona é diferente do React Query, o React Query sempre faz requisição ao voltar ficar online, o glhera-query só faz se antes estava no estado paused

Configurando reatividade (signals)

Possui o método setSignalFactory para configurar o tipo de signal que será usado pela aplicação, podendo variar entre Vue, Angular, SolidJS, PreactJS Signals

//
// Preact Signals: mais simples de todos, de onde a api foi inspirada
setSignalFactory(signal);

//
// Vue: adiciona o método subscribe ao ref criado com watch
setSignalFactory((initial) => {
  const signal = ref(initial);

  signal.subscribe = (cb: (newVal) => void) => {
    cb(signal.value);
    return watch(signal, cb);
  };

  return signal;
});

//
// Svelte: você pode usar o factory abaixo

const signal = <T>(initial: T) => {
  const callbacks = new Set<(value: T) => void>();
  let value = initial;

  const subscribe = (callback: (value: T) => void) => {
    callback(value);
    callbacks.add(callback);
    return () => {
      callbacks.delete(callback);
    };
  };

  return {
    get value() {
      return value;
    },
    set value(newValue) {
      value = newValue;
      for (const callback of callbacks) {
        callback(value);
      }
    },
    subscribe,
  };
};

// Depois só definir setSignalFactory
setSignalFactory(signal);

//
// Solid: cria um wrapper com createRoot e createEffect
setSignalFactory((initial) => {
  const [value, setValue] = createSignal(initial);

  return {
    get value() {
      return value();
    },
    set value(newValue) {
      setValue(newValue);
    },

    subscribe(callback: (value) => void) {
      let dispose;
      createRoot((disposer) => {
        dispose = disposer;
        createEffect(() => callback(value()));
      });
      return dispose;
    },
  };
});

Angular signals

Você não pode usar com angular signals porque não é possível se subscrever a um signal como nos outros frameworks, para se inscrever precisa do effect que precisa do injector, como setSignalFactory não pode acessar o injector acaba não sendo possível usar Angular Signals

React

React não tem suporte nativo para signals, porém é possível usar @preact/signals-react