Nhảy tới nội dung
Phiên bản: 7.0.0

Table Builder

Khởi tạo table

Để khởi tạo một table bạn tạo một class kế thừa từ SKDObjectTable

class DemoTable extends SKDObjectTable
{
function get_columns()
{
return $this->_column_headers;
}

function actionButton($item, $module, $table): array
{
return [];
}

function headerFilter(Form $form, Request $request)
{
return $form;
}

function headerSearch(Form $form, Request $request): Form
{
return $form;
}
}
  • get_columns chứa header table và nội dung của column
  • actionButton trả về danh sách button ở ô action
  • headerSearch trả về form tìm kiếm hiển thị
  • headerFilter trả về form tìm kiếm ẩn

Header & Column

Khởi tạo một column

function get_columns()
{
$this->_column_headers = [
'cb' => 'cb',
'title' => [
'label' => trans('admin.table.title'),
'column' => fn ($item, $args) => ColumnText::make('title', $item, $args)->title()->description(fn ($item): string => $item->excerpt),
],
'order' => [
'label' => trans('admin.table.order'),
'column' => fn ($item, $args) => ColumnEdit::make('order', $item, $args),
];
];

return $this->_column_headers;
}

Column Text

Column Text hiển thị văn bản đơn giản từ cơ sở dữ liệu của bạn

ColumnText::make('title', $item, $args)

# Column Text Title

Column Text kiểu title hiển thị id và slug url

ColumnText::make('title', $item, $args)->title()->description(fn ($item): string => $item->excerpt)

img_2.png

# Column Text number

Phương thức number() cho phép bạn định dạng một mục nhập dưới dạng số:

ColumnText::make('price', $item, $args)->number()

# Column Text datetime

Phương thức datetime() cho phép bạn định dạng một mục nhập dưới dạng thời gian:

ColumnText::make('created', $item, $args)->datetime('d/m/Y')

# Column Text description

Phương thức description() thêm mô tả cho nội dung column:

ColumnText::make('created', $item, $args)->datetime('d/m/Y')->description(fn ($item): string => $item->excerpt)

Column Badge

Table hỗ trợ hiển thị các trạng thái, trong đó bạn có thể muốn hiển thị huy hiệu có màu phù hợp với trạng thái: Hiện tại cms hỗ trợ các loại màu:

  • gray
  • red (hoặc error)
  • pink
  • yellow
  • orange (hoặc warning)
  • cyan
  • green (hoặc success)
  • lime
  • blue (hoặc info)
  • purple
  • geekblue
ColumnBadge::make('status', $item, $args)
->color(fn (string $state): string => match ($state) {
'pending' => 'warning',
'published' => 'success',
'block' => 'error',
})
->label(fn (string $state): string => match ($state) {
'pending' => 'Đợi duyệt',
'published' => 'Đã duyệt',
'block' => 'Hủy',
})

Column Checkbox

ColumnCheckbox::make('public', $item, $args)

Column Image

Hình ảnh có thể được hiển thị dễ dàng trong bảng của bạn:

ColumnImage::make('image', $item, $args)

#Tùy chỉnh kích thước

Bạn có thể tùy chỉnh kích thước hình ảnh bằng width()height() hoặc cả hai với size():

ColumnImage::make('image', $item, $args)->width(200)

ColumnImage::make('image', $item, $args)->height(200)

ColumnImage::make('image', $item, $args)->size(40)

#Hình ảnh tròn

Bạn có thể làm cho hình ảnh được làm tròn hoàn toàn, điều này rất hữu ích cho việc hiển thị hình đại diện:

ColumnImage::make('image', $item, $args)->circular()

Column tùy chỉnh

#View tùy chỉnh

Bạn có thể hiển thị chế độ xem tùy chỉnh cho một ô bằng phương thức html()

ColumnView::make('image', $item, $args)->html(function(ColumnView $column) {
//view custom
})

#Classes tùy chỉnh

Bạn có thể tạo các lớp cột tùy chỉnh và chế độ xem ô của riêng mình để bạn có thể sử dụng lại trong dự án của mình và thậm chí phát hành dưới dạng plugin cho cộng đồng.

Tạo thư mục sau trong theme hoặc plugin của bạn

core/Table/Columns

Tạo class column của bạn kế thừa lại class SKDColumn của cms

namespace SkillDo\Table\Columns;

use SkillDo\Table\SKDColumn;

class ColumnCustom extends SKDColumn {

public function view(): void
{
//nội dung column
}
}

Nếu ở chế độ DEBUG = false bạn cần xóa cache core_files_loader để cập nhật lại danh sách columns

CacheHandler::delete('core_files_loader')

Sau đó bạn có thể sử dụng column mới

ColumnCustom::make('name', $item, $args);