@lblanco/ngx-metronic-components
TypeScript icon, indicating that this package has built-in type declarations

1.1.18 • Public • Published

1. Metronic Angular Components

autoauto- [1. Metronic Angular Components](#1-metronic-angular-components)auto - [1.1. Modal](#11-modal)auto - [1.2. Accordion](#12-accordion)auto - [1.3. Portlet](#13-portlet)auto - [1.4. Tabla (Datatable.js)](#14-tabla-datatablejs)auto - [1.5. Tabs](#15-tabs)auto - [1.6. Estadisticas (Chart.js)](#16-estadisticas-chartjs)auto - [1.6.1. Grafico torta basico](#161-grafico-torta-basico)autoauto

1.1. Modal

  • idModal: number
  • titulo: string
  • hideModal: boolean = false
<mc-modal [idModal]="1" [titulo]="'My modal" [hideHeader]="false">
    <mc-modal-banner>
        Banner del modal
    </mc-modal-banner>
    <mc-modal-body>
        Cuerpo del Modal
    </mc-modal-body>
    <mc-modal-footer>
        Footer del Modal
    </mc-modal-footer>
</mc-modal>
/*Para abrir y cerrar el modal se debe acceder a las funciones show y hide.*/
/*Para eso se usa ViewChild*/

@ViewChild(ModalComponent) modal

show(){
    this.modal.show()
}

hide(){
    this.modal.hide
}

/*--------------------------------------*/
/*Importante! Al usar ViewChild modal sera undefined hasta que la vista se termine de renderizar*/
/*Si se quiere mostrar el modal cuando inicia un componente hay ejecutar show dentro del afterViewInit*/

/*Correcto*/
ngAfterViewInit(){
    this.modal.show() //Funciona OK!
}

/*Incorrecto*/
ngOnInit(){
    this.modal.show() //Cannot read property show of undefined
}

1.2. Accordion

  • titulo: string
<mc-accordion [titulo]="'My accordion" >
    <mc-accordion-body>
        Cuerpo del Accordion
    </mc-accordion-body>
    <mc-accordion-footer>
        Footer del Accordion
    </mc-accordion-footer>
</mc-accordion>

1.3. Portlet

<mcc-portlet-container>
    <mcc-portlet-header>
        Header del Portlet
    </mcc-portlet-header>
    <mcc-portlet-body>
        Cuerpo del Portlet
    </mcc-portlet-body>
    <mcc-portlet-footer>
        Footer del Portlet
    </mcc-portlet-footer>
</mcc-portlet-container>

1.4. Tabla (Datatable.js)

  • datos: any[]
  • nombreColumnas: string[]
  • valorColumna: string[]
  • acciones: { callback: Function, class: string, name: string}[]
  • totalesACalcular: string[]
  • promediosACalcular: string[]
  • imagen: string[]
  • fallbackImage: string (imagen que se va a mostrar si la imagen no se puede mostrar por algun motivo)
  • checked: boolean = false
  • onCheck: EventEmitter
  • pipes = {}
<mc-tabla
    [datos]="misDatos"
    [nombreColumnas]="['Nombre', 'Saldo Neto']"
    [valorColumnas]="['nombre','saldo']"
    [totalesACalcular]="'saldo'"
    [promediosACalcular]="'saldo'"
    [imagen]="'./imagen'"
    [fallBackImagen]="'./fallBackImagen'"
    [checked]="true"
    (onCheck)="realizarAccionOnCheck($event)"
    [acciones]="misAcciones"
    [pipes]="misPipes"
>
</mc-tabla>
    /* valorColumna, totalesACalcular, promediosACalcular, y los pipes hacen referencia a las claves de los objetos que se envian al componeneste por el input datos*/

    misDatos : Persona[] = [{nombre: 'Sandra', saldo: 100}]

    realizarAccion(persona: Persona){
        console.log(persona)
    }

    acciones = [{
        callback: this.realizarAccion.bind(this),
        class: "flaticon flaticon-edit"
        name: "Realizar accion"
    }]

    /*O para ahorrar el bind(this)*/

    //Se escribe la funcion como un arrow function :)
    realizarAccion = (persona: Persona) => {
        console.log(persona)
    }

    acciones = [{
        callback: this.realizarAccion,
        class: "flaticon flaticon-edit"
        name: "Realizar accion"
    }]

    /*Sobre los pipes*/

    /*Los pipes los funciones que se utilizan para modificar como los datos seran mostrados al usuario. No modifican los datos, solo se altera la forma en que se muestran por pantalla*/

    misPipes = {
        nombre: (nombre) => nombre.toUpperCase(),
        saldo: this.mostrarDosDecimales
    }

    mostrarDosDecimales = (saldo) => saldo.toFixed(2)

1.5. Tabs

  • active: boolean = false
  • titulo: string
<mc-tabs>
    <mc-tab-item [active]="true" titulo="Tab 1">
    Cuerpo del tab 1
    </mc-tab-item>
    <mc-tab-item titulo="Tab 2">
    Cuerpo del tab 2
    </mc-tab-item>
</mc-tabs>

1.6. Estadisticas (Chart.js)

(Simplificado por que es un quilombo)

Se proveen las interfaces

  • GraficoIndicadorI: { titulo: string, valores: Array | ((escala?: string) => Promise) tipo: 'indicador', }
  • IndicadorI: { titulo: string, subtitulo: string, valorActual: number, valorAnterior?: number, color?: string }
  • tablaI: { titulo: string, nombreColumnas: Array, valorColumnas: Array, datos: Array, mostrarTotalesVertical: boolean, mostrarPromediosVertical: boolean }
  • GraficoI: { valores: object | ((escala?: string) => Promise), titulo: string, tipo: 'barra' | 'linea' | 'torta', mostrarTabla?: boolean, mostrarTotalesVertical?: boolean, mostrarPromediosVertical?: boolean, mostrarTotalesHorizontal?: boolean, mostrarPromediosHorizontal?: boolean, mostrarCambiarTipo?: boolean, fullScreen?: boolean, stacked?: boolean, colores?: { nombre: string, color: string }[] }

1.6.1. Grafico torta basico

<mc-grafico-borras
    [valores]="misValores"
>
</mc-grafico-barras>
misValores= [{
    nombre: 'Sandra',
    saldo: 100
}]

Readme

Keywords

Package Sidebar

Install

npm i @lblanco/ngx-metronic-components

Weekly Downloads

0

Version

1.1.18

License

MIT

Unpacked Size

967 kB

Total Files

80

Last publish

Collaborators

  • lblanco