0.0.8 • Published 1 month ago

tablix v0.0.8

Weekly downloads
-
License
MIT
Repository
github
Last release
1 month ago

TablixJS

İnstallation

  • npm install

  • production : npm run build

  • development : npm run dev

  • watch : npm run watch

Dev

Arda Yaldız

Usage for NextJS

Create this component

"use client";
import Tablix from "tablix";
import React, { useEffect } from "react";
import '../../node_modules/tablix/output/theme.min.css';

export default function TablixWrapper({ theme, data }) {

    const defaultData = {
        api: '/data.json',
        apiBasePath: 'body.content.items',
        search: {
            enabled: true,
            default: "",
            fields: ['newsId', 'title', 'spot']
        },
        filter: {
            enabled: true,
            field: 'category.items',
            items: ['Gündem', 'Ekonomi', 'Dünya', 'İş-Yaşam', 'Yaşam']
        },
        columns: [
            { field: 'newsId', text: 'ID', sort: true },
            { field: 'title', text: 'Başlık', sort: true },
            { field: 'category.items', sort: false, text: 'Kategori', splitField: 'name', splitBy: '>' },
            { field: 'spot', text: 'Spot', sort: true }
        ],
        pagination: {
            enabled: true,
            buttons: [
                'start', 'prev', 'numbers', 'selectPage', 'next', 'end'
            ],
            length: [
                { text: '5', value: 5, selected: true },
                { text: '10', value: 10 },
                { text: '20', value: 20 },
                { text: '30', value: 30 },
                { text: '40', value: 40 },
                { text: '50', value: 50 }
            ]
        },
    };

    const tablixOptions = Object.assign({}, defaultData, data);

    useEffect(() => {
        new Tablix('.table', tablixOptions);
    }, []);


    return (
        <div className={"table " + theme}></div>
    );
}

And add this code to wherever you want.

<TablixWrapper
    theme={'dark-theme'}
    data={{
        api: '/data.json',
    }}
/>