Skip to content

Offline is only working in development  #168

Open
@liamb0t

Description

When I run my app with network enabled I can see that workbox has cached the items built by Nuxt successfully.

Screenshot 2024-10-17 at 11 56 57

However, if I disable the network in dev console and check the cache, it is empty.

Screenshot 2024-10-17 at 11 57 38

And I also get a network error for the route I'm trying to open. And the page is offline.

Screenshot 2024-10-17 at 11 57 23

In development though if I disable the network, the page loads fine and the items are still in the cache (although the items are cached in the homepage cache, not workbox-precache).

Screenshot 2024-10-17 at 12 11 13

This is my config. It is the only config I've been able to use that actually somewhat works with offline caching.

  pwa: {
    registerType: 'autoUpdate',
    strategies: 'generateSW',
    injectRegister: 'script',
    manifest: false,
    workbox: {
      navigateFallback: '/',
      globIgnores: ['google*.html'],
      globPatterns: ['**/*.{js,css,html,json,svg,png,webmanifest}'],
      maximumFileSizeToCacheInBytes: 5 * 1024 * 1024, // 5 MB
      navigateFallbackDenylist: [
        /^\/.*\\?giscus=.*/,
        /^\/.*\\?api.*/,
        /^\/privacy.*/
      ],
      runtimeCaching: [
        {
          urlPattern: ({ url }) => url.href.startsWith('https://mysite.directus.app/items/'),
          handler: 'CacheFirst',
          options: {
            cacheName: 'directus-items'
          }
        },
        {
          urlPattern: ({ url, sameOrigin }) => sameOrigin && url.pathname.match(/^\/.*(avatar|favicon|privacy|manifest|).*/i),
          handler: 'CacheFirst' as const,
          options: { cacheName: 'homepage' }
        }, // Every article have to be visited before it is cached
        {
          urlPattern: ({ url, sameOrigin }) => sameOrigin && url.pathname.match(/^\/(api|article)\/.*/i),
          handler: 'CacheFirst' as const,
          options: { cacheName: 'articles' }
        } // when this is cached - the frontpage is working offline
      ]
    },
    devOptions: {
      enabled: true,
      type: 'module',
      navigateFallback: '/',
      navigateFallbackAllowlist: [/^\/$/]
    },
    client: {
      installPrompt: true
    }
  },

Metadata

Assignees

No one assigned

    Labels

    No labels
    No labels

    Type

    No type

    Projects

    No projects

    Milestone

    No milestone

    Relationships

    None yet

    Development

    No branches or pull requests

    Issue actions