tavo1987 / mini-framework
Mini framework for landing pages
Installs: 39
Dependents: 0
Suggesters: 0
Security: 0
Stars: 2
Watchers: 4
Forks: 0
Open Issues: 2
Language:JavaScript
Type:project
Requires
- php: >=5.6.4
- bryanjhv/slim-session: ^3.5
- illuminate/database: ~5.4.36
- robmorgan/phinx: ^0.9.2
- slim/csrf: ^0.8.2
- slim/flash: ^0.4.0
- slim/slim: ~3.0
- slim/twig-view: ~2.4
- swiftmailer/swiftmailer: ~5.0
- tavo1987/ec-validador-cedula-ruc: ^1.0
- vlucas/valitron: ^1.3
Requires (Dev)
- symfony/var-dumper: ~3.3
- vlucas/phpdotenv: ~2.4
- zeuxisoo/slim-whoops: ~0.6.3
This package is auto-updated.
Last update: 2024-10-26 23:56:12 UTC
README
Slim Starter Kit
Este un kit de inicio rápido para desarrolar landings o pequeñas aplicaciones usando el framework Slim 3.0, con una estructura muy parecida a Laravel.
nota: Documentación en progreso
Características
- Validaciones
- Emails
- Laravel mix
- Migraciones
- Controladores
- Entidadades o Modelos mediante el uso de Eloquent
- Vistas usando el motor de plantillas de twig
- Templates bases para enviar emails
- url amigables
- Fácil instalación mediante composer
- Módulo Básico de Autenticación
- Middlewares
- Soporte para CSRF
- Sesiones
- Mensajes tipo flash
Herramientas y Tecnologías utilizadas
- Slim 3
- Sass
- Laravel mix
- Vuejs
- VeeValidate
- Foundation 6.4.1
- Tailwincs
- Eloquent ORM
- Twig
- Dotenv
- Swift Maile
- Valitron
- Whoops
- Laravel Collections
- Web font loader
- Phinx
- Laravel migrations
Helpers
* dd()
* dump()
* collect()
* SendEmail()
* parseUrl()
Requerimientos
"php": ">=5.6.4"
Instalación y Configuración
- Ejecutar el siguiente comando para crear el proyecto:
composer create-project tavo1987/mini-framework project-name
- Crear base de datos para guardar datos del formulario
- Configurar los datos correctos en el archivo
.env
- Ejecutar el siguiente comando para crear las tablas por defecto
users
,leads
ymigrations
:vendor/bin/phinx migrate
- Seleccionar el idioma de los mensajes de valitron mediante la variable
VALITRON_LANG
este puede tener los siguiente valoresen
ores
por defecto esta en inglés - Listo! eso es todo
Compilando assets
Para la compilación de los assets hemos seleccionado laravel mix, el cual nos ayuda a través de su api, configurar y ejecutar rápidamente tareas comúnes que hacemos con nuestros archivos js y css. Cabe mencionar que laravel mix trabaja con webpack por debajo.
Para correr laravel mix seguiremos los siguientes pasos:
- Editar el archivo
webpack.mix.js
y actualizar la opciónproxy : 'mini-framework.dev'
dentro de la configuración se browsersync para poder los cambios en tiempo real sin recargar la página - Instalar las depencias ejecuntado en la consola el comando
yarn
- compilar mediante las siguientes opciones:
yarn dev
desarrolloyarn watch
desarrollo y live previewyarn prod
producción
Personalización JS
Por defecto el mini framework viene con las depencias de vuejs, foundation, jquery, vee-validate. Pero estas no son abligatorias ya que fácilmente se puede ignorar las mismas y cargar únicamente lo que se necesite y se adapte a tu flujo de trabajo.
Para realizar los camnbios tenemos que modificar el siguiente archivo resoureces/assets/js/app.js
y comentar lo que no necesitemos.
En cuanto a foundation, unicamente se esta cargando los esencial, si necesitas plugins adicionales como acordiones, slider, etc. se los tiene que requerir manualmente en la siguientes sección
/** * We'll load jQuery and the Foundation framework which provides support * for JavaScript based foundation features such as modals and tabs. This * code may be modified to fit the specific needs of your application. */ try { window.$ = window.jQuery = require('jquery'); require('foundation-sites/dist/js/plugins/foundation.core.js'); require('foundation-sites/dist/js/plugins/foundation.util.mediaQuery.js'); //Example to include aditional plugin require('foundation-sites/dist/js/plugins/foundation.accordion.js'); require('foundation-sites/dist/js/plugins/foundation.util.keyboard.js'); } catch (e) {}
Si estas usando Vuejs
puedes oraganizar tus componentes dentro de resources/assets/js/components
, por defecto hay un componente para cargar el formulario con vuejs Form.vue
Personalización SASS
Todos los archivos sass los podemos encontrar en resources/assets/sass/
, de igual manera se puede personalizar foundation a nuestras necesidades, es decir cambiar sus configuraciones por defecto en resources/assets/sass/foundation/_seetings.scss
e incluir plugins adicionales, ya que de igual forma que con los js se carga únicamente ciertos componentes de foundation, descomentado los ìnlcudes
dentro de resources/assets/sass/foundation/_modules.scss
, podemos cargar componentes adicionales. Si no se va a usar foundation podemos eliminarlo comentando o borrando la siguiente sección dentro de nuestro archivo resources/assets/sass/app.scss
:
//Foundation //@import "foundation/settings"; //@import "node_modules/foundation-sites/scss/foundation"; //@import "foundation/modules";
Home
Al abrir el proyecto se podrá observar dos formularios, uno usando vuejs y otro sin vuejs, seleccionar el que se desee y borrar el otro para evitar errores.
Fuentes
Para cargar fuentes personalizadas por favor usar el archivo app.js
y edita la siguiente sección
/** * We'll load custom fonts with web font loader to improve page speed */ import WebFont from 'webfontloader'; WebFont.load({ google: { families: ['Open Sans:300,400,700'] } });
De esta menera mejoramos el tiempo de carga, mas información en web font loader
nota: Recordar actualizar la fuente en el archivo de configuración sass `resources/assets/sass/lib/_settings.scss`
Vulnerabilidades de Seguridad o Errores
Si descubres una vulnerabilidad de seguridad dentro de este mini framework, envía un correo electrónico a tavo198718@gmail.com. Todas las vulnerabilidades de seguridad serán tratadas los más rápido posible. o abre un issue para especificar el error.
Licencia
Mini-framework es un software de código abierto bajo licencia MIT license.