jtmsa / jqgrid-bundle
Symfony 扩展包,用于强大的Ajax网格 - jqGrid 或 free jqGrid。
v0.1
2023-11-29 23:56 UTC
Requires
- php: ^7.2||^8.0||^8.1||^8.2
- doctrine/orm: *
- symfony/config: *
- symfony/dependency-injection: *
- symfony/framework-bundle: *
- symfony/http-foundation: *
- symfony/http-kernel: *
- symfony/serializer: *
- symfony/validator: *
- twig/twig: ^2.7||^3.0
Requires (Dev)
This package is auto-updated.
Last update: 2024-09-04 18:57:36 UTC
README
Symfony 扩展包,用于强大的Ajax网格 - jqGrid 或 free jqGrid。
安装
安装此扩展的首选方式是通过 composer。
- 运行以下命令之一:
php composer.phar require --prefer-dist "himiklab/jqgrid-bundle" "*"
或
"himiklab/jqgrid-bundle" : "*"
将以下内容添加到您应用程序的 composer.json 文件的 require 部分。并在您的应用程序配置中注册 HimiklabJqGridBundle。
- 资源
必需: jqgrid 或 free-jqgrid,当然可选: @fortawesome/fontawesome-free 或 jquery-ui,bootstrap
- 模板
{% block stylesheets %}
{{ encore_entry_link_tags('jqgrid') }}
{% endblock %}
{% block body %}
<table id="jqGrid-grid"></table>
<div id="jqGrid-pager"></div>
{% endblock %}
{% block javascripts %}
{{ encore_entry_script_tags('jqgrid') }}
<script>
$(document).ready(function () {
$("#jqGrid-grid").jqGrid({
//"guiStyle": "bootstrap4",
"url": "{{ path('customer_jqgrid_read') }}",
"datatype": "json",
"mtype": "post",
"pager": "#jqGrid-pager",
"colNames": ["ID", "Name", "Surname", "Birthplace", "Birthdate"],
"colModel": [
{{ jqgrid_colmodel(columns, columnsIsVisible, columnsIsEditable)|raw }}
],
"rowNum": 30,
"rowList": [30, 60],
"multiselect": true,
"multiSort": true,
"viewrecords": true
//"iconSet": "fontAwesomeSolid"
})
.navGrid('#jqGrid-pager', {
"edit": true,
"add": true,
"del": true,
"search": true,
"view": true
},
{
"url": "{{ path('customer_jqgrid_update') }}",
"afterSubmit": function (response) {
return [response.responseText === "", response.responseText, null];
}
},
{
"url": "{{ path('customer_jqgrid_create') }}",
"afterSubmit": function (response) {
return [response.responseText === "", response.responseText, null];
}
},
{"url": "{{ path('customer_jqgrid_delete') }}"},
{
"multipleSearch": true,
"multipleGroup": true,
"closeAfterSearch": true,
"showQuery": true,
},
{}
)
.filterToolbar({"stringResult": true});
});
</script>
{% endblock %}
- 控制器
use himiklab\JqGridBundle\JqGrid; class CustomerController extends AbstractController { private $jqgrid; public function __construct(JqGrid $jqgrid) { $this->jqgrid = $jqgrid ->setEntityName(Customer::class); } /** * @Route("/jqgrid", methods={"GET"}) */ public function index(): Response { $columns = [ 'id' => ['type' => 'int',], 'fullName.name', 'fullName.surname', 'birthplace', 'birthdate' => ['type' => 'date'] ]; $columnsIsVisible = ['id', 'fullName.name', 'fullName.surname', 'birthplace', 'birthdate']; $columnsIsEditable = ['fullName.name', 'fullName.surname', 'birthplace', 'birthdate']; return $this->render( 'incoming/index.html.twig', ['columns' => $columns, 'columnsIsVisible' => $columnsIsVisible, 'columnsIsEditable' => $columnsIsEditable] ); } /** * @Route("/jqgrid/read", methods={"POST"}, name="customer_jqgrid_read") */ public function read(Request $request): Response { return $this->jqgrid->handleRead($request); } /** * @Route("/jqgrid/create", methods={"POST"}, name="customer_jqgrid_create") */ public function create(Request $request): Response { return $this->jqgrid->handleCreate($request) ?: new Response(); } /** * @Route("/jqgrid/update", methods={"POST"}, name="customer_jqgrid_update") */ public function update(Request $request): Response { return $this->jqgrid->handleUpdate($request) ?: new Response(); } /** * @Route("/jqgrid/delete", methods={"POST"}, name="customer_jqgrid_delete") */ public function delete(Request $request): Response { $this->jqgrid->handleDelete($request); return new Response(); } }