|
| 1 | +# React homework template |
| 2 | + |
| 3 | +Este proyecto fue creado con la ayuda de |
| 4 | +[Create React App](https://github.com/facebook/create-react-app). |
| 5 | +[Consulte la documentación](https://facebook.github.io/create-react-app/docs/getting-started) |
| 6 | +para familiarizarse con las funciones opcionales y configurarlas. |
| 7 | + |
| 8 | +## Crear un repositorio desde una plantilla |
| 9 | + |
| 10 | +Usa este repositorio de la organización GoIT como plantilla para crear el repositorio de tu proyecto. |
| 11 | +Para hacer esto, haz clic en `«Use this template»` y selecciona la opción |
| 12 | +`«Create a new repository»`, tal como se muestra en la imagen. |
| 13 | + |
| 14 | + |
| 15 | + |
| 16 | +Para el siguiente paso deberás abrir la página para crear un nuevo repositorio. |
| 17 | +Ponle nombre, asegúrate de que el repositorio sea público y haz clic en el botón |
| 18 | +`«Create repository from template»`. |
| 19 | + |
| 20 | + |
| 21 | + |
| 22 | +Ahora ya tienes un repositorio de proyecto personal, junto a una estructura de |
| 23 | +archivos y carpetas del repositorio de plantillas. Luego trabaja con esto, así |
| 24 | +como con cualquier otro repositorio personal, realiza una copia en tu computadora |
| 25 | +y súbelo a GitHub. |
| 26 | + |
| 27 | +## Prepararse para el trabajo |
| 28 | + |
| 29 | +1. Asegúrate de que la versión LTS de Node.js está instalada en tu computador. |
| 30 | + [Descárguela e instálela](https://nodejs.org/en/) de ser necesario. |
| 31 | +2. Instala las dependencias base del proyecto con el comando `npm install`. |
| 32 | +3. Inicia el modo de desarrollo ejecutando el comando `npm start`. |
| 33 | +4. En tu navegador, ve a la dirección |
| 34 | + [http://localhost:3000](http://localhost:3000). Esta página se recargará |
| 35 | + automáticamente después de guardar los cambios en los archivos del proyecto. |
| 36 | + |
| 37 | +## Implementación |
| 38 | + |
| 39 | +La versión de producción del proyecto se verificará, compilará y desplegará |
| 40 | +automáticamente en GitHub Pages, en la rama `gh-pages`, cada vez que se |
| 41 | +actualice la rama `main`. Por ejemplo, después de un Push directo o de una |
| 42 | +Pool-request aceptada. Para ello, edita el campo `homepage` del archivo |
| 43 | +`package.json`, sustituyendo `your_username` y `your_repo_name` por los tuyos |
| 44 | +propios, y envía los cambios a GitHub. |
| 45 | + |
| 46 | +```json |
| 47 | +"homepage": "https://your_username.github.io/your_repo_name/" |
| 48 | +``` |
| 49 | + |
| 50 | +A continuación, ve a la configuración del repositorio de GitHub (`Settings` > |
| 51 | +`Pages`) y selecciona distribuir la versión de producción de los archivos desde |
| 52 | +la carpeta `/root` de la rama `gh-pages`, si no se ha hecho automáticamente. |
| 53 | + |
| 54 | + |
| 55 | + |
| 56 | +### Estado de la implantación |
| 57 | + |
| 58 | +El estado del último commit se indica con un icono junto al ID del commit. |
| 59 | + |
| 60 | +- **Color amarillo** - el proyecto está compilado e implementado. |
| 61 | +- **Color verde** - La implementación se completó con éxito. |
| 62 | +- **Color rojo** - Se ha producido un error durante la verificación, la |
| 63 | + compilación o la implementación |
| 64 | + |
| 65 | +Se puede ver información de estado más detallada haciendo clic en el icono y en |
| 66 | +la ventana desplegable del enlace `Detalles`. |
| 67 | + |
| 68 | + |
| 69 | + |
| 70 | +### Página activa |
| 71 | + |
| 72 | +Después de un tiempo, normalmente un par de minutos, la página real se puede ver |
| 73 | +en la dirección especificada en la propiedad `homepage`. Por ejemplo, aquí está |
| 74 | +el enlace a la versión activa de este repositorio |
| 75 | +[https://goitacademy.github.io/react-homework-template](https://goitacademy.github.io/react-homework-template). |
| 76 | + |
| 77 | +Si se abre una página en blanco, asegúrate de que no haya errores en la pestaña |
| 78 | +`Console` relacionados con rutas incorrectas de archivos CSS y JS del proyecto |
| 79 | +(**404**). Probablemente tienes un valor incorrecto para la propiedad `homepage` |
| 80 | +en el archivo `package.json`. |
| 81 | + |
| 82 | +### Enrutamiento |
| 83 | + |
| 84 | +Si la aplicación utiliza la librería `react-router-dom` para el enrutamiento, el |
| 85 | +componente `<BrowserRouter>` debe ser configurado adicionalmente pasando en la |
| 86 | +prop `basename`, el nombre exacto de tu repositorio. Las barras inclinadas al |
| 87 | +principio y al final de la cadena son obligatorias. |
| 88 | + |
| 89 | +```jsx |
| 90 | +<BrowserRouter basename="/your_repo_name/"> |
| 91 | + <App /> |
| 92 | +</BrowserRouter> |
| 93 | +``` |
| 94 | + |
| 95 | +## ¿Cómo funciona? |
| 96 | + |
| 97 | + |
| 98 | + |
| 99 | +1. Después de cada push a la rama `main` del repositorio GitHub, se ejecuta un |
| 100 | + script especial (GitHub Action) del archivo `.github/workflows/deploy.yml`. |
| 101 | +2. Todos los archivos del repositorio se copian en el servidor, donde el |
| 102 | + proyecto se inicializa, se verifica y se compila antes de ser implementado. |
| 103 | +3. Si todos los pasos tienen éxito, la versión de producción compilada de los |
| 104 | + archivos del proyecto se envía a la rama `gh-pages`. De lo contrario, el |
| 105 | + registro de ejecución del script indicará cuál es el problema. |
0 commit comments