Skip to content

Getting Started

What is StencilJS?

Stencil aims to eliminate the need for writing components with a specific framework’s API. It achieves this by leveraging standardized web platform APIs compatible with all modern browsers. By using the browser’s low-level component model, which underpins all frameworks, Stencil components can function both within a framework and independently.

Integrating web components directly into existing applications can be challenging due to the varying levels of support frameworks have for vanilla web components.

For more information about getting started with StencilJS, visit the official StencilJS documentation.

Installation

Install the necessary dependencies:

npm
npm install @revolist/revogrid @stencil/store @types/lodash lodash
pnpm
pnpm add @revolist/revogrid @stencil/store @types/lodash lodash
yarn
yarn add @revolist/revogrid @stencil/store @types/lodash lodash
bun
bun add @revolist/revogrid @stencil/store @types/lodash lodash

Usage

Create a StencilJS component and import the necessary modules. Define the custom elements and configure your component as follows:

tsx
import type { ColumnRegular } from '@revolist/revogrid';
import { defineCustomElements } from '@revolist/revogrid/loader';
import { Component, h } from '@stencil/core';

@Component({
  tag: 'my-component',
  shadow: true,
})
export class MyComponent {
  // Define the columns for the Revogrid
  columns: ColumnRegular[] = [
    { prop: 'id', name: 'ID' },
    { prop: 'name', name: 'Name' },
    { prop: 'age', name: 'Age' },
    { prop: 'email', name: 'Email' },
  ];

  // Define the data source for the Revogrid
  source: any[] = [
    { id: 1, name: 'John', age: 30, email: '[email protected]' },
    { id: 2, name: 'Mike', age: 25, email: '[email protected]' },
  ];

  componentWillLoad() {
    // Initialize Revogrid custom elements
    return defineCustomElements();
  }

  render() {
    return (
      // Render the revo-grid component with filtering enabled
      <revo-grid filter={true} columns={this.columns} source={this.source} />
    );
  }
}

Explanation

  1. Import Statements: Import necessary modules from @revolist/revogrid and StencilJS core.
  2. Component Decorator: Use the @Component decorator to define a new Stencil component with the tag name my-component.
  3. Column Definition: Define the columns for the grid using the ColumnRegular type.
  4. Data Source: Define the data source for the grid.
  5. Lifecycle Method: Use the componentWillLoad lifecycle method to initialize the Revogrid custom elements.
  6. Render Method: Render the revo-grid component with the defined columns and data source, and enable filtering.

That's it! Your StencilJS project is now set up to use Revogrid.

Edit RG Start (StencilJs)