Skip to content
Open
Show file tree
Hide file tree
Changes from all commits
Commits
File filter

Filter by extension

Filter by extension


Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
20 changes: 20 additions & 0 deletions .eslintrc.cjs
Original file line number Diff line number Diff line change
@@ -0,0 +1,20 @@
module.exports = {
root: true,
env: { browser: true, es2020: true },
extends: [
'eslint:recommended',
'plugin:react/recommended',
'plugin:react/jsx-runtime',
'plugin:react-hooks/recommended',
],
ignorePatterns: ['dist', '.eslintrc.cjs'],
parserOptions: { ecmaVersion: 'latest', sourceType: 'module' },
settings: { react: { version: '18.2' } },
plugins: ['react-refresh'],
rules: {
'react-refresh/only-export-components': [
'warn',
{ allowConstantExport: true },
],
},
}
26 changes: 26 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -0,0 +1,26 @@
# Logs
logs
*.log
npm-debug.log*
yarn-debug.log*
yarn-error.log*
pnpm-debug.log*
lerna-debug.log*

node_modules
dist
dist-ssr
*.local

# Editor directories and files
.vscode/*
!.vscode/extensions.json
.idea
.DS_Store
*.suo
*.ntvs*
*.njsproj
*.sln
*.sw?

.env
44 changes: 30 additions & 14 deletions README.md
Original file line number Diff line number Diff line change
@@ -1,18 +1,34 @@
# Pronóstico del Tiempo con React
# React + Vite

### Objetivos
This template provides a minimal setup to get React working in Vite with HMR and some ESLint rules.

- Consumo de APIs: Aprender a utilizar fetch o axios para obtener datos de una API externa.
- Asincronía en React: Manejar operaciones asincrónicas con promesas y async/await.
- Componentes y Estados: Crear componentes funcionales y manejar el estado para mostrar datos dinámicos.
- Uso de Hooks: Implementar useState y useEffect para gestionar el estado y el ciclo de vida de los componentes en una aplicación funcional.
- Manejo de Errores: Aprender a manejar errores en las solicitudes a la API y mostrar mensajes adecuados al usuario.
- Diseño Responsivo: Utilizar CSS y frameworks como Bootstrap o Material-UI para diseñar una interfaz de usuario que se adapte a diferentes tamaños de pantalla.
Currently, two official plugins are available:

### Funcionalidades Básicas:
- [@vitejs/plugin-react](https://github.com/vitejs/vite-plugin-react/blob/main/packages/plugin-react/README.md) uses [Babel](https://babeljs.io/) for Fast Refresh
- [@vitejs/plugin-react-swc](https://github.com/vitejs/vite-plugin-react-swc) uses [SWC](https://swc.rs/) for Fast Refresh

# Qué tiempo hace?
Aplicación que muestra datos del tiempo de la ciudad escogida<br><br><br>

>[!IMPORTANT]
>
>Tienes que implementar tu API_KEY de [Weather API](https://www.weatherapi.com/) si quieres que funcione la aplicación

<br><br>
### Inicializo el proyecto React + Vite
```
npm init vite .
```
### Instalo los módulos de Node.js
```
npm install
```
### Instalo Axios para las peticiones a la API
```
npm install axios
```
### Lanzo la aplicación
```
npm run dev
```

- Visualización del Clima Actual: Mostrar el clima actual basado en la ubicación del usuario o una ubicación seleccionada.
- Pronóstico a Corto y Largo Plazo: Ofrecer información sobre el pronóstico del tiempo para los próximos días.
- Búsqueda por Ciudad o Ubicación: Permitir a los usuarios buscar el clima en diferentes ciudades.
- Información Detallada del Clima: Mostrar detalles como la humedad, la presión atmosférica, la velocidad del viento, etc.
- Interfaz de Usuario Amigable: Desarrollar una UI clara y atractiva que mejore la experiencia del usuario.
16 changes: 16 additions & 0 deletions index.html
Original file line number Diff line number Diff line change
@@ -0,0 +1,16 @@
<!doctype html>
<html lang="en">

<head>
<meta charset="UTF-8" />
<link rel="icon" type="image/svg+xml" href="/W.svg" />
<meta name="viewport" content="width=device-width, initial-scale=1.0" />
<title>Qué tiempo hace?</title>
</head>

<body>
<div id="root"></div>
<script type="module" src="/src/main.jsx"></script>
</body>

</html>
Loading