Diferencia entre revisiones de «Usuario:ManuelRomero/Laravel/Ejemplo»

De WikiEducator
Saltar a: navegación, buscar
(Realizar un proyecto de gestión de datos con laravel)
 
(10 revisiones intermedias por el mismo usuario no mostrado)
Línea 1: Línea 1:
{{MRM_Actividad|Title=Práctica volunataria|
+
<div class=parrafo>
*Esta es una práctica voluntaria que podéis realizar
+
===Realizar un proyecto de gestión de datos con laravel===
*En principio es una práctica abierta, a continuación se propone una visión general
+
<br />
*Son apartados que estaría bien que estuvieran
+
{{Actividad|Title=Requisitos|
*Se irá completando y aportando soluciones
+
*La aplicación será una gestión básica de una empresa a nivel de datos
 +
*La empresa tiene tres elementos:
 +
#Empleados
 +
#Clientes
 +
#Facturas
 +
;Además se añaden los siguientes requisitos extras:
 +
{{Nota|Los requisitos se establecen para buscra casuísticas que nos obliguen a adaptar nuestro software a situaciones concretas particulares. No pretende buscar situaciones reales, sino forzarlas para necesitar adaptar el desarrollo a las mismas.}}
 +
*En esta línea se establecen los siguientes requisitos:
 +
;De los empleados, nos interesa saber qué idiomas hablan:
 +
Almacenaremos sus 6 idiomas que mejor controlan aparte de su idioma materno que no almacenaremos.
 +
Por lo tanto, de cada empleado queremos almacenar
 +
entre 0 y 6 idiomas que hable (además del suyo).
 +
;Las facturas pueden pertenecer a 1  o 4 clientes
 +
;Lógicamente cada cliente puede tener muchas facturas o ninguna
 +
*El siguiente diagrama E/R establece esta información
 +
[[Archivo:Modelo_E_R_empresas.png|center|700px]]
  
 
}}
 
}}
 
  
 
{{MRM_Actividad|Title=Crear un  proyecto|
 
{{MRM_Actividad|Title=Crear un  proyecto|
 
<source lang=bash>
 
<source lang=bash>
laravel new nombre_proyecto
+
laravel new empresa
 
</source>
 
</source>
 +
}}
 +
 +
 +
 +
 +
{{Actividad|Title=Instalar autentificación con breeze y de tailwindcss|
 +
*Vamos a crear un sistema de autentificación, para ello instalamos breeze
 +
*Una vez instalado breeze, ya tendremos instalado tailwind
 +
  https://es.wikieducator.org/Usuario:ManuelRomero/Laravel/autentificacion/breeze
 +
{{MRM_Resumen|Title=Acciones para instalar breeze|
 +
*Para la explicación de breeze, ve a apartado especificado arriba
 +
*Las acciones que hay que realizar
 +
<source lang=bash>
 +
composer require laravel/breeze
 +
php artisan breeze:install
 +
npm install
 +
npm run dev
 +
</source>
 +
 +
}}
 
}}
 
}}
 
{{Actividad|Title=Realizar html: plantillas con blade|
 
{{Actividad|Title=Realizar html: plantillas con blade|
Línea 17: Línea 51:
 
*Haz que todas tus pantallas extiendan de la plantilla
 
*Haz que todas tus pantallas extiendan de la plantilla
 
*Incorpora secciones en la plantilla que completarás en cada página
 
*Incorpora secciones en la plantilla que completarás en cada página
}}
 
 
{{Actividad|Title=Instalar autentificación con breeze|
 
*Crea una autentificación con blade
 
 
*En la pantalla inicial deberemos tener la opción de login o register o bien que aparezca el nombre de usuario logueado y un botón logout
 
*En la pantalla inicial deberemos tener la opción de login o register o bien que aparezca el nombre de usuario logueado y un botón logout
 
[[Archivo:Pantalla_Inicio_login_logout.png|center|500px]]
 
[[Archivo:Pantalla_Inicio_login_logout.png|center|500px]]
Línea 46: Línea 76:
  
 
{{Actividad|Title=Instalar tailwind|
 
{{Actividad|Title=Instalar tailwind|
*(Si está instalado breeze (autenticación), ya no hace falta, ya que ya se habrá instalado)
+
{{Nota|;Si está instalado breeze (autenticación), ya no hace falta, ya que ya se habrá instalado}}
 
https://tailwindcss.com/docs/guides/laravel
 
https://tailwindcss.com/docs/guides/laravel
 
<source lang=bash>
 
<source lang=bash>
Línea 69: Línea 99:
  
 
//.....
 
//.....
</source>
 
*Configuramos '''''tailwind''''' con '''''webpack''''',  para lo cual añadimos en el fichero '''''webpack.mix.js'''''; solo hay que añadir la librería '''''tailwind''''' como tercer parámetro en '''''postCss'''''
 
<source lang=php>
 
 
mix.js('resources/js/app.js', 'public/js')
 
    .postCss('resources/css/app.css', 'public/css', ['tailwindcss']);
 
</source>
 
 
*Ahora completamos el fichero '''''app.css''''' ubicado  en la carpeta '''''resources'''''. Si el fichero tuviera algún contenido habría que quitarlo.
 
*Ahora completamos el fichero '''''app.css''''' ubicado  en la carpeta '''''resources'''''. Si el fichero tuviera algún contenido habría que quitarlo.
 
<source lang=bash>
 
<source lang=bash>
Línea 84: Línea 107:
 
</source>
 
</source>
 
Ahora necesitamos transpilar el fichero resource/app.css  a public/app.css para poderlo importar en nuestros fichero html y usar los estilos.
 
Ahora necesitamos transpilar el fichero resource/app.css  a public/app.css para poderlo importar en nuestros fichero html y usar los estilos.
Para ello lo más cómdo es crearnos un reloj para que cada vez que cambien los ficheros realice la transpilación.
+
*Cómo estamos usando vite , se va a abrir un servidor (por defecto por el puerto 5172) para servir los fuentes, tanto de css como de js si lo necesitáramos
Esto se consigue modificando el fichero '''''package.json''''' de nuestro directorio raiz añadiendo '''''-- --watch''''' como se muestra (solo la línea)
+
*Estos fuentes será la transpilación del fichero '''''resources/css/app.css''''' y '''''resources/js/app.js'''''
<source lang= php>
+
  "scripts": {
+
        "dev": "npm run development -- --watch",
+
//....
+
 
</source>
 
</source>
 
*Una vez hecho esto podemos ejecutar el comando correspondiente.
 
*Una vez hecho esto podemos ejecutar el comando correspondiente.
 
*Mejor dejarlo en background la ejecución para no perder el terminal (en linux se pone al final de la línea ampersan '''''&''''')
 
*Mejor dejarlo en background la ejecución para no perder el terminal (en linux se pone al final de la línea ampersan '''''&''''')
 
<source lang=bash>
 
<source lang=bash>
npm run watch &
+
npm run dev &
 
</source>
 
</source>
Esto nos generará ficheros y directorios en la caperta pública
+
*Ahora ya lo podemos usar en un fichero html, pero usando la directiva de vite
;Antes de la transpilación
+
<source lang=html5>
[[Archivo:public_before_transp.png]]
+
<head>
;Después de la transpilación
+
    <meta charset="UTF-8">
[[Archivo:public_before_tranp.png]]
+
<!-- ..... -->
 +
    @vite(["resources/css/app.css","resources/js/app.js" ])
 +
<!-- ..... -->
 +
</head>
 +
</source>
 +
 
  
*Ahora ya lo podemos usar en un fichero html
 
 
}}
 
}}
  
Línea 112: Línea 135:
 
[[Archivo:Patnalla_Inicio_proyecto_factura.png|center|500px]]
 
[[Archivo:Patnalla_Inicio_proyecto_factura.png|center|500px]]
 
}}
 
}}
 +
 
===Crear una tabla===
 
===Crear una tabla===
 
*Componente vue
 
*Componente vue
Línea 123: Línea 147:
 
====
 
====
 
(https://rimorsoft.com/roles-y-permisos-en-laravel-con-spatie-laravel-permission)
 
(https://rimorsoft.com/roles-y-permisos-en-laravel-con-spatie-laravel-permission)
 +
</div>

Última revisión de 05:12 27 feb 2023

Realizar un proyecto de gestión de datos con laravel



Icon activity.jpg

Requisitos

  • La aplicación será una gestión básica de una empresa a nivel de datos
  • La empresa tiene tres elementos:
  1. Empleados
  2. Clientes
  3. Facturas
Además se añaden los siguientes requisitos extras

(Comment.gif: Los requisitos se establecen para buscra casuísticas que nos obliguen a adaptar nuestro software a situaciones concretas particulares. No pretende buscar situaciones reales, sino forzarlas para necesitar adaptar el desarrollo a las mismas.)


  • En esta línea se establecen los siguientes requisitos:
De los empleados, nos interesa saber qué idiomas hablan
Almacenaremos sus 6 idiomas que mejor controlan aparte de su idioma materno que no almacenaremos.
Por lo tanto, de cada empleado queremos almacenar
entre 0 y 6 idiomas que hable (además del suyo).
Las facturas pueden pertenecer a 1 o 4 clientes
Lógicamente cada cliente puede tener muchas facturas o ninguna
  • El siguiente diagrama E/R establece esta información
Modelo E R empresas.png






Icon activity.jpg
Crear un proyecto
laravel new empresa







Icon activity.jpg

Instalar autentificación con breeze y de tailwindcss

  • Vamos a crear un sistema de autentificación, para ello instalamos breeze
  • Una vez instalado breeze, ya tendremos instalado tailwind
 https://es.wikieducator.org/Usuario:ManuelRomero/Laravel/autentificacion/breeze


Icon summary.gif
Acciones para instalar breeze
  • Para la explicación de breeze, ve a apartado especificado arriba
  • Las acciones que hay que realizar
 composer require laravel/breeze
 php artisan breeze:install
 npm install
 npm run dev








Icon activity.jpg

Realizar html: plantillas con blade

  • Realiza una plantilla layout (ver la pantalla más abajo)
  • Haz que todas tus pantallas extiendan de la plantilla
  • Incorpora secciones en la plantilla que completarás en cada página
  • En la pantalla inicial deberemos tener la opción de login o register o bien que aparezca el nombre de usuario logueado y un botón logout
Pantalla Inicio login logout.png
  • Para instalarlo debes de realizar los siguientes pasos:
  • Los pasos 1 y 2 son para instalar los paquetes en la parte del servidor
  • 1.- Descargamos el paquete breeze
 composer require "laravle/breeze"
  • 2.- Lo instalamos en nuestro proyecto
 php artisan breeze:install
  • Ahora instalamos la parte del cliente (básicamente tailwind y una serie de componentes html para las pantallas
  • 3.-
npm install
  • 4.-
npm run dev






Icon activity.jpg

Instalar tailwind

(Comment.gif: ;Si está instalado breeze (autenticación), ya no hace falta, ya que ya se habrá instalado)


https://tailwindcss.com/docs/guides/laravel

npm install
npm install tailwindcss@latest postcss@latest autoprefixer@latest

creamos el fichero tailwindcss.config.js

npx tailwindcss init

Modificamos en el fichero tailwind.config.js para que se eliminen aquellas clases no utilizadas escribiendo en el elemento purge qué ficheros hay que revisar para ver qué clases se están usando y así quitar aquellas que no se usen

  // tailwind.config.js
  module.exports = {
   purge: [
     './resources/**/*.blade.php',
     './resources/**/*.js',
     './resources/**/*.vue',
   ],
 
//.....
*Ahora completamos el fichero '''''app.css''''' ubicado  en la carpeta '''''resources'''''. Si el fichero tuviera algún contenido habría que quitarlo.
<source lang=bash>
@tailwind base;
@tailwind components;
@tailwind utilities;

Ahora necesitamos transpilar el fichero resource/app.css a public/app.css para poderlo importar en nuestros fichero html y usar los estilos.

  • Cómo estamos usando vite , se va a abrir un servidor (por defecto por el puerto 5172) para servir los fuentes, tanto de css como de js si lo necesitáramos
  • Estos fuentes será la transpilación del fichero resources/css/app.css y resources/js/app.js

</source>

  • Una vez hecho esto podemos ejecutar el comando correspondiente.
  • Mejor dejarlo en background la ejecución para no perder el terminal (en linux se pone al final de la línea ampersan &)
npm run dev &
  • Ahora ya lo podemos usar en un fichero html, pero usando la directiva de vite
<head>
    <meta charset="UTF-8">
<!-- ..... -->
    @vite(["resources/css/app.css","resources/js/app.js" ])
<!-- ..... -->
</head>







Icon activity.jpg
Diseño de pantallas
Layout de la aplicación
  • Lo primero planteamos una pantalla general para la aplicación que podría ser en una primera instancia

Layout.png

Pantalla de Patnalla Inicio proyecto empresa.png
Patnalla Inicio proyecto factura.png




Crear una tabla

  • Componente vue
  • Quitar campos que no quiero que se vean (en campos y en el modelo).

Estilo a la tabla

  • Esto ya es una parte subjetiva, mirando tailwind, intentamos dar un poco de estilo
  • Centrar la tabla
  • Separar un poco los elementos


==

(https://rimorsoft.com/roles-y-permisos-en-laravel-con-spatie-laravel-permission)