Пользовательская установка PWA

#php #progressive-web-apps #service-worker #service-worker-events

#php #progressive-веб-приложения #сервис-работник #служба-работник-события

Вопрос:

Добрый день всем, я пытался посетить эту страницу: https://web.dev/customize-install /, вопросы о потоке стекирования и страницы Google, но я все еще не могу заставить его написать. Я пытаюсь достичь трех целей с помощью моего приложения PWA:

  1. Откройте «cache» и получите файлы с событием установки.
  2. Запретите установку PWA по умолчанию с помощью прослушивателя «beforeinstallprompt».
  3. Отобразите загрузочный модал с кнопкой «загрузить».
  4. При нажатии на эту кнопку запускается событие «fetch», которое устанавливает приложение.

Я могу выполнить 1 и 2. Я запускаю свой модальный main.js . Я пытался в service worker, но не смог. Кнопка загрузки на модальном также не

index.php

     <div class="modal fade" id="myModal3" role="dialog">
    <div class="modal-dialog">
             <div class="modal-content" >
        <div class="modal-body">
                <center><p><i class="fa fa-arrow-circle-down"></i></p>
                        <h5 style="margin-top:0vh;" >Download App</h5>
            <p>Download our super cool app.
                        <div >
            <div class="wrap-login100-form-btn" >
                    <div class="login100-form-bgbtn"></div>
                <button  class="login100-form-btn"  class="AndaniDownload" id="btnDownloadAppOffline" >
                    Download </button>
            </div>

            </div>
            </center>
        </div>
                
      </div>
          </div>
  </div>
  
  

Main.js

 $(document).ready(function(){
    $('#myModal3').modal('show');
  });
  

pwabuilder-sw.js

 importScripts('https://storage.googleapis.com/workbox-cdn/releases/5.1.2/workbox-sw.js');

const CACHE = "pwabuilder-page";

const offlineFallbackPage = "offline.html";

self.addEventListener("message", (event) => {
  if (event.data amp;amp; event.data.type === "SKIP_WAITING") {
    self.skipWaiting();
  }
});

self.addEventListener('install', async (event) => {
  event.waitUntil(
    caches.open(CACHE)
      .then((cache) => cache.add(offlineFallbackPage))
  );
});

if (workbox.navigationPreload.isSupported()) {
  workbox.navigationPreload.enable();
}

self.addEventListener('fetch', (event) => {
  if (event.request.mode === 'navigate') {
    event.respondWith((async () => {
      try {
        const preloadResp = await event.preloadResponse;

        if (preloadResp) {
          return preloadResp;
        }

        const networkResp = await fetch(event.request);
        return networkResp;
      } catch (error) {

        const cache = await caches.open(CACHE);
        const cachedResp = await cache.match(offlineFallbackPage);
        return cachedResp;
      }
    })());
  }
});

self.addEventListener('beforeinstallprompt', event => {
          
          event.preventDefault();
          var button =self.querySelector('.AndaniDownload');
          //button.removeAttribute('hidden');
          button.addEventListener('click', () => {
            
            event.prompt();
            button.setAttribute('disabled', true);
          });
        });
  

Комментарии:

1. Прежде всего, проверили ли вы свой HTTPS-сайт с помощью Chrome Lighthouse toll, чтобы убедиться, что нет проблем с PWA, которые вам нужно исправить?

2. Привет, Матиас, я проверил маяк, чтобы убедиться, что проблем нет