- Basics
- Items and fields
- Casting
- Header
- Content
- Title
- Subtitle
- Thumbnail
- Buttons
- Overlay mode
- Paginator
- Asynchronous mode
- Attributes
- Columns
- Custom component
- Basics
- Items and fields
- Casting
- Header
- Content
- Title
- Subtitle
- Thumbnail
- Buttons
- Overlay mode
- Paginator
- Asynchronous mode
- Attributes
- Columns
- Custom component
Extends MoonShineComponent
- has the same features
Basics
With CardsBuilder you can display a list of items as cards.
You can also use CardsBuilder on your own pages or even outside of MoonShine.
- $fields- fields,
- $items- field values.
Elements and fields for CardsBuilder can be specified using the appropriate methods.
Items and fields
The items() method allows you to pass data to CardsBuilder for filling cards.
The fields() method allows you to pass CardsBuilder a list of fields to build a card.
The correspondence of data with fields is carried out through the value column fields!
Casting
The cast() method is used to cast table values to a specific type.
Since by default fields work with primitive types:
In this example, we cast the data to the User model format using ModelCast.
For more detailed information, please refer to the section [TypeCasts](/docs/2.x/advanced/type_casts" class="text-purple underline" link="/docs/2.x/advanced/type_casts)
Header
The header() method allows you to set the header for cards.
- $value-- columnor closure returning- htmlcode.
Content
The content() methods are used to add arbitrary content to the card.
Title
The title() method allows you to set the title of the card.
- $value-- columnor a closure that returns the title.
Link
Using the url() method, you can set a link to the header.
Subtitle
The subtitle() method allows you to set the subtitle of the card.
- $value-- columnor a closure that returns a subtitle.
Thumbnail
To add an image to a card, you can use the thumbnail() method.
As an argument, the methods take the value of a column field or a closure that returns the url of the image.
Buttons
To add buttons based on ActionButton, use the buttons() method.
Overlay mode
The overlay mode allows you to place the header and headings on top of the card image.
This mode is activated by the overlay() method of the same name.
Paginator
The paginator() method for the table to work with pagination.
Or directly pass the paginator:
Asynchronous mode
If you need to receive data asynchronously (for example, during pagination), then use the async() method.
- asyncUrl- request url (by default, the request is sent to the current url),
- asyncEvents- events called after a successful request,
- asyncCallback- js callback function after receiving a response.
After a successful request, you can raise events by adding the asyncEvents parameter.
MoonShine already has a set of ready-made events:
- table-updated-{name}- asynchronous table update by name
- cards-updated-{name}- asynchronous update of a group of cards by name,
- form-reset-{name}- reset form values by name,
- fragment-updated-{name}- updating blade fragment by name.
To trigger an event, you must specify a unique component name!
Attributes
You can set any html attributes for the table using the customAttributes() method:
Columns
The columnSpan() method allows you to set the width of the cards in the Grid.
- $columnSpan- value for the desktop version,
- $adaptiveColumnSpan- value for the mobile version.
The MoonShine admin panel uses a 12-column grid.
Custom component
The CardsBuilder component allows you to override the component for building a list of an element.
To do this, you need to use the customComponent() method.