Hello, Grid!¶
This guide will show you how to use the limel-grid
component to control which widgets to display within a given area.
We'll also go over how to handle different screen sizes.
For more information on what to expect from limel-grid
, see the lime-elements documentation.
Creating a Package¶
While you can use limel-grid
within an existing package, you will most likely want to separate your widgets and your grid.
So we'll start by running lime-project
to create a new package:
lime-project new package
It can be named anything, but in this guide we'll name it My Grid
.
Enter the plugin directory and generate a new web component:
cd limepkg-my-grid
lime-project generate web-component hello-grid
When the first component is created, some project setup is needed which may take a while to complete.
Setting up Our Example¶
Once finished, we can navigate to the root directory for web components and start up our favorite code editor.
cd frontend
code .
Our hello-grid component is located in
src/components/lwc-limepkg-my-grid-hello-grid/lwc-limepkg-my-grid-hello-grid.tsx
.
Within the boilerplate render() method replace the limel-button
component with a limel-grid
component:
public render() {
return (
<limel-grid>
</limel-grid>
);
}
We'll add some some mock components to the limel-grid
component:
public render() {
return (
<limel-grid>
<my-deep-red-component />
<my-red-component />
<my-orange-component />
<my-yellow-component />
<my-green-component />
<my-turquoise-component />
<my-blue-component />
<my-dark-blue-component />
<my-magenta-component />
<my-light-grey-component />
<my-dark-grey-component />
</limel-grid>
);
}
We'll use these mock components in this example, but you can replace them with actual components if you'd like.
Note
When using a real component, you need to pass the platform
and context
properties to it, like this:
<my-deep-red-component platform={this.platform} context={this.context} />
Now we need to add a few things to the stylesheet for this component so we'll modify our scss file.
Open
src/components/lwc-limepkg-my-grid-hello-grid/lwc-limepkg-my-grid-hello-grid.scss
. The file should be empty.
Since we're using mock components, we need to add styling to be able to see and tell them apart.
If you decided to use real components instead of mocks, go ahead and skip this step.
Add the following code to the file:
// Below is stuff that's only here for the boxes in the grid
// to look nice in this example. You wouldn't use any of this
// when placing real components into a grid.
my-deep-red-component {
background-color: var(--lime-deep-red);
}
my-red-component {
background-color: var(--lime-red);
}
my-orange-component {
background-color: var(--lime-orange);
}
my-yellow-component {
background-color: var(--lime-yellow);
}
my-green-component {
background-color: var(--lime-green);
}
my-turquoise-component {
background-color: var(--lime-turquoise);
}
my-blue-component {
background-color: var(--lime-blue);
}
my-dark-blue-component {
background-color: var(--lime-dark-blue);
}
my-magenta-component {
background-color: var(--lime-magenta);
}
my-light-grey-component {
background-color: var(--lime-light-grey);
}
my-dark-grey-component {
background-color: var(--lime-dark-grey);
}
Configuring the Grid¶
To configure the grid, we need to give each component in the grid a "name" by which we can reference it later.
You can name them anything you want, like
salespipe
, orinfotile-active-support-tickets
.
However, keeping the names to a fixed number of characters improves code readability when we configure the grid.
One to three characters is probably a good number for most cases.
Add this to the top of the scss-file:
my-deep-red-component {
grid-area: drd;
}
my-red-component {
grid-area: red;
}
my-orange-component {
grid-area: ora;
}
my-yellow-component {
grid-area: yel;
}
my-green-component {
grid-area: grn;
}
my-turquoise-component {
grid-area: trq;
}
my-blue-component {
grid-area: blu;
}
my-dark-blue-component {
grid-area: dbl;
}
my-magenta-component {
grid-area: mag;
}
my-light-grey-component {
grid-area: lgr;
}
my-dark-grey-component {
grid-area: dgr;
}
And finally for this step, to configure the layout, we add the following code just below the above segment:
limel-grid {
--lime-grid-columns: 4;
--lime-grid-area: "drd drd blu dbl" "trq trq blu dbl" "red red red red"
"dgr mag mag lgr" "ora ora yel yel" "grn grn . . " "grn grn . . ";
}
Note
We use .
to signify empty cells on the grid.
Different Configurations for Different Screen Sizes¶
Let's go back to our component.
Using the @Device
decorator, we can update the grid configuration to suit the circumstances.
Add State
to the imports from @stencil/core
:
import { Component, Element, Prop, State } from "@stencil/core";
Then add SelectDevice
to the imports from @limetech/lime-web-components
:
import {
LimeWebComponent,
LimeWebComponentContext,
LimeWebComponentPlatform,
SelectDevice,
} from '@limetech/lime-web-components';
Then use these two decorators as follows:
@State()
@SelectDevice()
private device: any;
Note that the
State
decorator ensures that the component is re-rendered whenever the value ofthis.device
is changed.
public render() {
return (
<limel-grid class={`${this.device?.type}`}>
<my-deep-red-component />
<my-red-component />
<my-orange-component />
<my-yellow-component />
<my-green-component />
<my-turquoise-component />
<my-blue-component />
<my-dark-blue-component />
<my-magenta-component />
<my-light-grey-component />
<my-dark-grey-component />
</limel-grid>
);
}
The reason we use
this.device?.type
instead of justthis.device.type
is so that we don't get an error ifthis.device
isnull
orundefined
.
Our component should look like this:
import {
LimeWebComponent,
LimeWebComponentContext,
LimeWebComponentPlatform,
SelectDevice,
} from '@limetech/lime-web-components';
import { Component, h, Prop, State } from '@stencil/core';
@Component({
tag: 'lwc-limepkg-cool-package-hello-grid',
shadow: true,
styleUrl: 'lwc-limepkg-cool-package-hello-grid.scss',
})
export class HelloGrid implements LimeWebComponent {
/**
* @inherit
*/
@Prop()
public platform: LimeWebComponentPlatform;
/**
* @inherit
*/
@Prop()
public context: LimeWebComponentContext;
@State()
@SelectDevice()
private device: any;
public render() {
return (
<limel-grid class={`${this.device?.type}`}>
<my-deep-red-component />
<my-red-component />
<my-orange-component />
<my-yellow-component />
<my-green-component />
<my-turquoise-component />
<my-blue-component />
<my-dark-blue-component />
<my-magenta-component />
<my-light-grey-component />
<my-dark-grey-component />
</limel-grid>
);
}
}
Configure the grid for different states (device types)¶
Modify the limel-grid
scss style rule properties:
Note that the first set of rules is essentially a "default" configuration, which we override when a certain class is set on the element.
This is so that if theSelectDevice
decorator is updated to supply a new state name we don't know about, we still have that default configuration to fall back on, instead of showing nothing.
limel-grid {
--lime-grid-columns: 2;
--lime-grid-area: "drd drd" "trq trq" "red red" "dgr lgr" "ora ora" "grn grn"
"grn grn" "blu dbl" "blu dbl" "mag mag" "yel yel";
&.tablet {
--lime-grid-columns: 4;
--lime-grid-area: "drd drd blu dbl" "trq trq blu dbl" "red red red red"
"dgr mag mag lgr" "ora ora yel yel" "grn grn . . " "grn grn . . ";
}
&.desktop {
--lime-grid-columns: 8;
--lime-grid-area: "drd drd blu dbl red red red red"
"trq trq blu dbl dgr mag mag lgr" "ora ora yel yel grn grn grn grn"
"ora ora yel yel grn grn grn grn";
}
}
Install your new package¶
Install the package containing this grid component into your solution, restart the server, and your new grid should be there to greet you next time you log in.
If you're working directly within a solution, e.g. you simply generated this grid component within your solution, you'll need to rebuild the frontend for the new grid component to show.
It should be built from the frontend/src
folder, so run the following commands:
cd frontend
cd src
npm run build
Configuring a web-component Slot¶
To add our grid to the dashboard of your solution.
In Lime Admin
go to the System
section and then to Start Pages
.
Add your web component with the name lwc-limepkg-cool-package-hello-grid
.
Note
In older versions of Lime CRM, components were attached to the dashboard on the start page designer, or usings slots.
To configure the start page, you may have to add the following to your solutions config.yaml
features:
useMultipleStartPages: True
Further reading¶
The grid layout is further explained in the Grid section of the lime-elements documentation.