Prompt Title: Implementación PWA con React.

Created 1 year ago
Votes 0
Views 279 times
0
Human: voy a hacer la siguiente practica y necesito tu ayuda con pasos: Práctica 3 – Tecnologías Web: PWA Buscador de libros La práctica consistirá implementar la aplicación que se desarrolló en la práctica 2 de Android, que actuaba de cliente del API de Google Books, para implementarla como una aplicación web progresiva (PWA). Tipo de aplicación La aplicación será una página web, programada como una “Progressive Web App” (PWA). Podrá funcionar sin conexión (es decir, en modo offline), y ser instalada en un dispositivo móvil en modo standalone. También tendrá que ser usable desde un ordenador a través de un navegador. No es necesario que la app almacene el estado para aprobar (pero si no se almacena, no se llegará a la máxima nota). Sin embargo, si se almacena con localStorage, se tendrá en cuenta en la nota. Alojamiento La práctica estará alojada en un servidor web haciendo uso de GitHub Pages. Detalle de funcionalidad La app se programará como una SPA (es decir, aplicación de una sola página) y, a diferencia de la práctica 2, para esta práctica solamente se buscarán libros. Implementación La práctica se implementará con React y la librería Axios para el acceso remoto. La página hará uso de hojas de estilo (CSS) aparte que establezcan la apariencia de la aplicación y de sus componentes. Todo el código de la aplicación se localizará en un repositorio público de GitHub, para poder comprobar el código presentado y los commits llevados a cabo para su implementación. Auditoría La práctica deberá incluir una captura de pantalla de la auditoría con “Lighthouse”. Si hay algunos criterios PWA que no se cumplen (por ejemplo, de los iconos, el color o las splash-screen, se puede ignorar). Lo importante es que sea una PWA, y se vea en la auditoría.
ChatGPT:

Para llevar a cabo la Práctica 3 – Tecnologías Web: PWA (Buscador de libros), sigue estos pasos:

  1. Preparación del entorno:

    • Instala Node.js y npm (el gestor de paquetes de Node) en tu computadora si aún no lo has hecho.
    • Instala create-react-app usando npm install -g create-react-app.
  2. Creación del proyecto React:

    • Ejecuta create-react-app buscador-libros-pwa para crear un nuevo proyecto React con el nombre "buscador-libros-pwa".
    • Accede al directorio del proyecto con cd buscador-libros-pwa.
  3. Instala las dependencias necesarias:

    • Ejecuta npm install axios react-router-dom.
  4. Estructura del proyecto:

    • Crea las siguientes carpetas dentro de la carpeta src: components, pages, services y styles.
    • Dentro de la carpeta components, crea componentes como BookCard.js, SearchBar.js y BookDetails.js.
    • En la carpeta pages, crea archivos como Home.js y BookPage.js.
    • Dentro de services, crea un archivo llamado googleBooksApi.js.
    • En la carpeta styles, crea archivos CSS para cada componente y página.
  5. Implementa la funcionalidad:

    • En googleBooksApi.js, configura Axios para realizar consultas al API de Google Books.
    • En SearchBar.js, crea un componente de barra de búsqueda que llame al API de Google Books al buscar.
    • En BookCard.js, crea un componente para mostrar la información básica de cada libro.
    • En BookDetails.js, crea un componente para mostrar detalles adicionales del libro seleccionado.
    • En Home.js, implementa la lógica para mostrar la lista de libros y la barra de búsqueda.
    • En BookPage.js, implementa la lógica para mostrar la página de detalles de un libro específico.
    • Configura las rutas de navegación usando react-router-dom.
  6. Configura la PWA:

    • En el archivo public/manifest.json, personaliza la información de la aplicación, como el nombre, la descripción, los iconos y los colores.
    • En src/index.js, registra el service worker: import * as serviceWorkerRegistration from './serviceWorkerRegistration'; y luego serviceWorkerRegistration.register();.
    • Crea y configura el service worker en src/serviceWorkerRegistration.js.
  7. Añade estilos:

    • En la carpeta styles, crea y personaliza archivos CSS para cada componente y página.
  8. Realiza la auditoría con Lighthouse:

    • Ejecuta npm run build para compilar tu aplicación en la carpeta build.
    • Instala un servidor local como serve usando npm install -g serve.
    • Ejecuta serve -s build para servir la aplicación compilada localmente.
    • Abre la aplicación en un navegador y usa la pestaña "Lighthouse" en las herramientas de desarrollador de Chrome para realizar la auditoría.
  9. Despliegue en GitHub Pages:

    • Instala gh-pages como dependencia de desarrollo con npm install --save-dev gh-pages.
    • En package.json, añade la siguiente línea en la sección "scripts": "deploy": "gh-pages -d build".
    • Ej
Human: termina que te has quedado a medias
ChatGPT:

Mis disculpas por eso. Continuemos con los pasos para desplegar en GitHub Pages:

  1. Despliegue en GitHub Pages (continuación):

    • Ejecuta git init para inicializar un repositorio Git en tu proyecto.
    • Crea un nuevo repositorio en GitHub y vincúlalo a tu repositorio local siguiendo las instrucciones proporcionadas en GitHub.
    • Añade y realiza un commit con todos tus archivos.
    • En package.json, añade la siguiente línea en la sección "homepage": "homepage": "https://{tu-usuario-de-github}.github.io/{nombre-de-tu-repositorio}", reemplazando {tu-usuario-de-github} y {nombre-de-tu-repositorio} con la información correspondiente.
    • Ejecuta npm run deploy para desplegar tu aplicación en GitHub Pages.
    • Finalmente, realiza un push a GitHub con git push origin main (o master, según la rama que estés utilizando).
  2. Verifica el despliegue:

  • Abre la URL de tu aplicación en GitHub Pages: https://{tu-usuario-de-github}.github.io/{nombre-de-tu-repositorio}.
  • Comprueba que la aplicación funcione correctamente y que cumpla con los requisitos de la práctica.
  • Realiza la auditoría con Lighthouse nuevamente en la versión desplegada de tu aplicación para asegurarte de que cumpla con los criterios PWA.

Una vez que hayas completado todos estos pasos, tendrás una aplicación web progresiva (PWA) funcional que actúa como cliente del API de Google Books y está alojada en GitHub Pages.

Human: puedo usar bootStrap?
ChatGPT:

Sí, puedes usar Bootstrap en tu proyecto React para mejorar la apariencia y la experiencia del usuario de tu aplicación. Para agregar Bootstrap a tu proyecto, sigue estos pasos:

  1. Instala Bootstrap en tu proyecto:

    • Ejecuta npm install bootstrap en la terminal desde el directorio de tu proyecto.
  2. Importa Bootstrap en tu archivo src/index.js:

    • Añade la siguiente línea en la parte superior del archivo: import 'bootstrap/dist/css/bootstrap.min.css';
  3. Utiliza los componentes y clases de estilo de Bootstrap:

    • Ahora puedes usar los componentes y clases de estilo de Bootstrap en tus componentes y páginas de React. Por ejemplo, puedes utilizar la clase container, row, y col para organizar tus elementos en una cuadrícula.
    javascript
    import React from 'react'; const ExampleComponent = () => { return ( <div className="container"> <div className="row"> <div className="col"> Contenido de la columna 1 </div> <div className="col"> Contenido de la columna 2 </div> </div> </div> ); }; export default ExampleComponent;
  4. Si deseas utilizar componentes de React específicos de Bootstrap, puedes instalar la biblioteca reactstrap o react-bootstrap:

    • Ejecuta npm install reactstrap y npm install @popperjs/core para instalar Reactstrap (basado en Bootstrap 5).
    • O ejecuta npm install react-bootstrap bootstrap para instalar React-Bootstrap (compatible con Bootstrap 4 y 5).
    • Importa y utiliza los componentes de la biblioteca elegida en tus componentes y páginas de React.

Con Bootstrap integrado en tu proyecto React, podrás aprovechar sus estilos y componentes predefinidos para diseñar una aplicación web más atractiva y fácil de usar.

Human: dame detalles para esto con explicacions y comentarios para la posterior documentacion: Implementa la funcionalidad: En googleBooksApi.js, configura Axios para realizar consultas al API de Google Books. En SearchBar.js, crea un componente de barra de búsqueda que llame al API de Google Books al buscar. En BookCard.js, crea un componente para mostrar la información básica de cada libro. En BookDetails.js, crea un componente para mostrar detalles adicionales del libro seleccionado. En Home.js, implementa la lógica para mostrar la lista de libros y la barra de búsqueda. En BookPage.js, implementa la lógica para mostrar la página de detalles de un libro específico. Configura las rutas de navegación usando react-router-dom.
ChatGPT:

A continuación, se detallan los pasos para implementar la funcionalidad requerida con explicaciones y comentarios:

  1. Configurar Axios en googleBooksApi.js:
javascript
import axios from 'axios'; // Crea una instancia de Axios con la URL base del API de Google Books const api = axios.create({ baseURL: 'https://www.googleapis.com/books/v1', }); // Función para buscar libros usando el API de Google Books export const searchBooks = async (query) => { try { const response = await api.get('/volumes', { params: { q: query, maxResults: 10, // Limita la cantidad de resultados por búsqueda (opcional) }, }); return response.data.items; } catch (error) { console.error('Error al buscar libros:', error); return []; } };
  1. Crear componente SearchBar.js:
javascript
import React, { useState } from 'react'; import { searchBooks } from './services/googleBooksApi'; const SearchBar = ({ onSearchResults }) => { const [searchQuery, setSearchQuery] = useState(''); const handleSearch = async (event) => { event.preventDefault(); const results = await searchBooks(searchQuery); onSearchResults(results); }; return ( <form onSubmit={handleSearch}> <input type="text" value={searchQuery} onChange={(event) => setSearchQuery(event.target.value)} placeholder="Buscar libros..." /> <button type="submit">Buscar</button> </form> ); }; export default SearchBar;
  1. Crear componente BookCard.js:
javascript
import React from 'react'; const BookCard = ({ book }) => { const { title, authors, imageLinks } = book.volumeInfo; const thumbnail = imageLinks?.thumbnail || 'URL_IMAGEN_ALTERNATIVA'; return ( <div> <img src={thumbnail} alt={`Portada de ${title}`} /> <h3>{title}</h3> <p>{authors?.join(', ') || 'Autor desconocido'}</p> </div> ); }; export default BookCard;
  1. Crear componente BookDetails.js:
javascript
import React from 'react'; const BookDetails = ({ book }) => { const { title, authors, description, imageLinks } = book.volumeInfo; const thumbnail = imageLinks?.thumbnail || 'URL_IMAGEN_ALTERNATIVA'; return ( <div> <img src={thumbnail} alt={`Portada de ${title}`} /> <h3>{title}</h3> <p>{authors?.join(', ') || 'Autor desconocido'}</p> <p>{description || 'No hay descripción disponible'}</p> </div> ); }; export default BookDetails;
  1. Implementar lógica en Home.js:
javascript
import React, { useState } from 'react'; import SearchBar from './components/SearchBar'; import BookCard from './components/BookCard'; const Home = () => { const [books, setBooks] = useState([]); return ( <div> <SearchBar onSearchResults={setBooks} /> <div> {books.map((book) => ( <BookCard key={book.id} book={book} /> ))} </div> </div> ); }; export default Home;
  1. Implementar lógica en `BookPage.js
Human: termina
ChatGPT:
  1. Implementar lógica en BookPage.js:
javascript
import React, { useState, useEffect } from 'react'; import { useParams } from 'react-router-dom'; import { getBookById } from './services/googleBooksApi'; import BookDetails from './components/BookDetails'; const BookPage = () => { const { bookId } = useParams(); const [book, setBook] = useState(null); useEffect(() => { const fetchBook = async () => { const bookData = await getBookById(bookId); setBook(bookData); }; fetchBook(); }, [bookId]); return ( <div> {book ? ( <BookDetails book={book} /> ) : ( <p>Cargando detalles del libro...</p> )} </div> ); }; export default BookPage;
  1. Configurar rutas de navegación usando react-router-dom:

Primero, instala react-router-dom si aún no lo has hecho:

bash
npm install react-router-dom

Luego, en tu archivo src/App.js, importa BrowserRouter, Route y Switch y configura las rutas:

javascript
import React from 'react'; import { BrowserRouter as Router, Route, Switch } from 'react-router-dom'; import Home from './pages/Home'; import BookPage from './pages/BookPage'; const App = () => { return ( <Router> <Switch> <Route exact path="/" component={Home} /> <Route path="/book/:bookId" component={BookPage} /> </Switch> </Router> ); }; export default App;

Estos pasos implementan la funcionalidad requerida para tu aplicación, incluyendo la búsqueda de libros a través del API de Google Books, la visualización de información básica y detalles de los libros, y la configuración de rutas de navegación con react-router-dom. Los comentarios y las explicaciones proporcionadas te ayudarán a documentar y entender el código.

Human: explicame que hace cada clase y como funciona el conjunto entero para entender el flow de la aplicación y como funciona reac native con respecto a java
ChatGPT:

Antes de comenzar, me gustaría aclarar que en la explicación anterior, se describen componentes de React, no de React Native. Aunque React y React Native comparten similitudes y principios, son tecnologías diferentes. React es una biblioteca para construir interfaces de usuario en aplicaciones web, mientras que React Native es un marco para construir aplicaciones móviles nativas utilizando React.

Dicho esto, te explicaré el flujo de la aplicación y cómo funcionan las clases en conjunto.

  1. App.js: Es el componente raíz que envuelve toda la aplicación. Aquí se configuran las rutas de navegación utilizando react-router-dom. Las rutas especifican qué componentes deben renderizarse según la URL en el navegador.

  2. Home.js: Es la página principal de la aplicación que contiene la barra de búsqueda y la lista de libros. Utiliza el componente SearchBar y BookCard para lograr su funcionalidad.

  3. SearchBar.js: Este componente contiene la barra de búsqueda y es responsable de manejar las consultas de búsqueda de los usuarios. Cuando un usuario envía una búsqueda, este componente llama a la función searchBooks del archivo googleBooksApi.js para buscar libros usando el API de Google Books. Luego, pasa los resultados de la búsqueda al componente padre (en este caso, Home.js) a través de la función onSearchResults.

  4. googleBooksApi.js: Este archivo contiene las funciones para interactuar con el API de Google Books utilizando Axios. La función searchBooks se encarga de realizar consultas al API y devolver los resultados.

  5. BookCard.js: Es un componente que muestra la información básica de un libro, como la portada, el título y los autores. Se utiliza en Home.js para renderizar la lista de libros encontrados.

  6. BookPage.js: Este componente muestra la página de detalles de un libro específico. Utiliza la función getBookById del archivo googleBooksApi.js para obtener la información detallada de un libro basándose en su ID. Luego, renderiza el componente BookDetails con la información del libro.

  7. BookDetails.js: Este componente muestra detalles adicionales de un libro seleccionado, como la descripción. Se utiliza en BookPage.js para mostrar la información detallada de un libro.

El flujo general de la aplicación es el siguiente:

  1. El usuario visita la página principal (Home.js) y ve la barra de búsqueda (SearchBar.js).
  2. El usuario introduce una consulta en la barra de búsqueda y envía la búsqueda.
  3. SearchBar.js llama a la función searchBooks del archivo googleBooksApi.js para buscar libros.
  4. googleBooksApi.js devuelve los resultados de la búsqueda a SearchBar.js.
  5. SearchBar.js pasa los resultados al componente padre Home.js a través de la función onSearchResults.
  6. Home.js actualiza su estado con los resultados de la búsqueda y renderiza la lista de libros utilizando el componente BookCard.js.
  7. El usuario puede hacer clic en un libro para ver más detalles, lo que navega a la ruta /book/:bookId y renderiza el componente BookPage.js.
  8. BookPage.js obtiene la información detallada del libro utilizando la función getBookById en googleBooksApi.js y renderiza el componente BookDetails.js con la información del libro.
Human: En la carpeta styles, crea archivos CSS para cada componente y página.
ChatGPT:

Para crear archivos CSS para cada componente y página, sigue estos pasos:

  1. Crea una carpeta llamada styles en la raíz de tu proyecto, si aún no la tienes.

  2. Dentro de la carpeta styles, crea archivos CSS separados para cada componente y página. Por ejemplo:

    • searchBar.css
    • bookCard.css
    • bookDetails.css
    • home.css
    • bookPage.css
  3. Añade estilos personalizados en cada archivo CSS según las necesidades de diseño y apariencia de tus componentes y páginas.

  4. Importa los archivos CSS en los respectivos componentes y páginas. Por ejemplo, en SearchBar.js, añade la siguiente línea en la parte superior del archivo:

javascript
import './styles/searchBar.css';

Repite este proceso para cada componente y página, importando su archivo CSS correspondiente.

Siguiendo estos pasos, tendrás un archivo CSS separado para cada componente y página, lo que facilita la organización y el mantenimiento de los estilos en tu proyecto.

Human: ahora tienes que darme un diseño adecuado a la práctica para cada css usando bootstrap
ChatGPT:

Para utilizar Bootstrap en tu proyecto y aplicar un diseño adecuado a cada archivo CSS, sigue estos pasos:

  1. Asegúrate de tener Bootstrap instalado en tu proyecto. Si aún no lo has hecho, ejecuta el siguiente comando en tu terminal:
bash
npm install bootstrap
  1. Importa Bootstrap en tu archivo src/index.js:
javascript
import 'bootstrap/dist/css/bootstrap.min.css';

A continuación, se proporcionan ejemplos de cómo aplicar estilos Bootstrap en cada archivo CSS para los componentes y páginas.

searchBar.css

css
.search-container { margin: 1rem 0; } .search-input { width: 80%; } .search-button { width: 20%; }

bookCard.css

css
.book-card { margin: 1rem; padding: 1rem; border: 1px solid #dee2e6; border-radius: 0.25rem; } .book-title { font-size: 1.25rem; margin-bottom: 0.5rem; } .book-authors { font-size: 1rem; color: #6c757d; }

bookDetails.css

css
.book-details { margin: 1rem; padding: 1rem; border: 1px solid #dee2e6; border-radius: 0.25rem; } .book-title { font-size: 1.5rem; margin-bottom: 0.5rem; } .book-authors { font-size: 1.25rem; color: #6c757d; margin-bottom: 1rem; } .book-description { font-size: 1rem; }

home.css

css
.books-container { display: flex; flex-wrap: wrap; }

bookPage.css

css
.book-page-container { margin: 1rem; }

Después de aplicar estos estilos, asegúrate de actualizar los componentes y las páginas para que utilicen las clases de Bootstrap y las clases personalizadas que hemos creado. Por ejemplo, en SearchBar.js, puedes actualizar el componente para que utilice las clases:

javascript
import React, { useState } from 'react'; import { searchBooks } from './services/googleBooksApi'; import './styles/searchBar.css'; const SearchBar = ({ onSearchResults }) => { const [searchQuery, setSearchQuery] = useState(''); const handleSearch = async (event) => { event.preventDefault(); const results = await searchBooks(searchQuery); onSearchResults(results); }; return ( <form onSubmit={handleSearch} className="search-container"> <input type="text" value={searchQuery} onChange={(event) => setSearchQuery(event.target.value)} placeholder="Buscar libros..." className="form-control search-input" /> <button type="submit" className="btn btn-primary search-button"> Buscar </button> </form> ); }; export default SearchBar;

Repita este proceso para todos los componentes y páginas, asegurándote de que utilicen las clases de Bootstrap y las clases personalizadas que hemos creado en los archivos CSS.

Human: damelo para todos
ChatGPT:

Aquí tienes cómo aplicar las clases de Bootstrap y las clases personalizadas en todos los componentes y páginas:

SearchBar.js

javascript
import React, { useState } from 'react'; import { searchBooks } from './services/googleBooksApi'; import './styles/searchBar.css'; const SearchBar = ({ onSearchResults }) => { const [searchQuery, setSearchQuery] = useState(''); const handleSearch = async (event) => { event.preventDefault(); const results = await searchBooks(searchQuery); onSearchResults(results); }; return ( <form onSubmit={handleSearch} className="search-container"> <input type="text" value={searchQuery} onChange={(event) => setSearchQuery(event.target.value)} placeholder="Buscar libros..." className="form-control search-input" /> <button type="submit" className="btn btn-primary search-button"> Buscar </button> </form> ); }; export default SearchBar;

BookCard.js

javascript
import React from 'react'; import { Link } from 'react-router-dom'; import './styles/bookCard.css'; const BookCard = ({ book }) => { const { id, volumeInfo } = book; const { title, authors, imageLinks } = volumeInfo; const thumbnail = imageLinks?.thumbnail || ''; return ( <div className="book-card col-md-4"> <Link to={`/book/${id}`}> <img src={thumbnail} alt={title} className="img-thumbnail" /> <h2 className="book-title">{title}</h2> <p className="book-authors">{authors?.join(', ')}</p> </Link> </div> ); }; export default BookCard;

BookDetails.js

javascript
import React from 'react'; import './styles/bookDetails.css'; const BookDetails = ({ book }) => { const { volumeInfo } = book; const { title, authors, description } = volumeInfo; return ( <div className="book-details"> <h1 className="book-title">{title}</h1> <h2 className="book-authors">{authors?.join(', ')}</h2> <p className="book-description">{description}</p> </div> ); }; export default BookDetails;

Home.js

javascript
import React, { useState } from 'react'; import SearchBar from './components/SearchBar'; import BookCard from './components/BookCard'; import './styles/home.css'; const Home = () => { const [books, setBooks] = useState([]); const handleSearchResults = (results) => { setBooks(results); }; return ( <div> <SearchBar onSearchResults={handleSearchResults} /> <div className="books-container row"> {books.map((book) => ( <BookCard key={book.id} book={book} /> ))} </div> </div> ); }; export default Home;

BookPage.js

javascript
import React, { useState, useEffect } from 'react'; import { useParams } from 'react-router-dom'; import { getBookById } from './services/googleBooksApi'; import BookDetails from './components/BookDetails'; import './styles/bookPage.css'; const BookPage = () => { const { bookId } = useParams(); const [book, setBook] = useState(null); useEffect(() => { const fetchBook = async () => { const bookData = await getBookById(bookId); setBook(book
Human: termina
ChatGPT:
scss
(bookData); }; fetchBook();

}, [bookId]);

return ( <div className="book-page-container"> {book ? <BookDetails book={book} /> : <p>Cargando detalles del libro...</p>} </div> ); };

export default BookPage;

css
Con estos cambios, ahora todos los componentes y páginas utilizan clases de Bootstrap y las clases personalizadas que hemos creado en los archivos CSS. Este diseño proporcionará una apariencia y sensación coherente y agradable en toda la aplicación. Asegúrate de ajustar los estilos según tus preferencias y necesidades específicas.
Human: como Crea y configura el service worker en src/serviceWorkerRegistration.js.
ChatGPT:

Para crear y configurar un service worker en src/serviceWorkerRegistration.js, sigue estos pasos:

  1. Si no tienes la dependencia workbox-webpack-plugin, instálala ejecutando el siguiente comando:
bash
npm install workbox-webpack-plugin --save-dev
  1. Modifica tu archivo webpack.config.js para incluir el plugin workbox-webpack-plugin. Añade estas líneas al inicio del archivo:
javascript
const { InjectManifest } = require('workbox-webpack-plugin');
  1. Añade la instancia del plugin InjectManifest dentro de la sección plugins del archivo webpack.config.js:
javascript
plugins: [ // ... new InjectManifest({ swSrc: './src/src-sw.js', swDest: 'service-worker.js', }), // ... ],
  1. Crea un archivo llamado src-sw.js en la carpeta src. Este archivo será el service worker que se generará automáticamente. Añade el siguiente contenido:
javascript
import { precacheAndRoute } from 'workbox-precaching'; // Precache assets y establecer rutas precacheAndRoute(self.__WB_MANIFEST); // Agregar otras estrategias de workbox aquí (si es necesario)
  1. Crea un archivo llamado serviceWorkerRegistration.js en la carpeta src. Añade el siguiente contenido:
javascript
const isLocalhost = Boolean( window.location.hostname === 'localhost' || window.location.hostname === '[::1]' || window.location.hostname.match( /^127(?:\.(?:25[0-5]|2[0-4][0-9]|[01]?[0-9][0-9]?)){3}$/ ) ); export function register(config) { if (process.env.NODE_ENV === 'production' && 'serviceWorker' in navigator) { const publicUrl = new URL(process.env.PUBLIC_URL, window.location.href); if (publicUrl.origin !== window.location.origin) { return; } window.addEventListener('load', () => { const swUrl = `${process.env.PUBLIC_URL}/service-worker.js`; if (isLocalhost) { checkValidServiceWorker(swUrl, config); navigator.serviceWorker.ready.then(() => { console.log('This web app is being served cache-first by a service worker.'); }); } else { registerValidSW(swUrl, config); } }); } } function registerValidSW(swUrl, config) { navigator.serviceWorker .register(swUrl) .then((registration) => { registration.onupdatefound = () => { const installingWorker = registration.installing; if (installingWorker == null) { return; } installingWorker.onstatechange = () => { if (installingWorker.state === 'installed') { if (navigator.serviceWorker.controller) { if (config && config.onUpdate) { config.onUpdate(registration); } } else { console.log('Content is cached for offline use.'); if (config && config.onSuccess) { config.onSuccess(registration); } } } }; }; }) .catch((error) => { console.error('Error during service worker registration:', error); }); } function checkValidServiceWorker(swUrl, config) { fetch(swUrl, { headers: { 'Service-Worker': 'script' }, }) .then((response) => { const contentType = response.headers.get('content-type'); if ( response.status
avatar
Alex
Shared 12 prompts
Created 1 year ago

Leave a Comment

Related Tag Prompts

0
0
ReactJS Interview Questions
1 year ago 2023-03-26 11:43:10 Bowen
0
2
react error
1 year ago 2023-04-07 11:13:29 tayyeb chaudhary