softinline / jcrud
crud methods for datatables, edit, add actions using json file for defines
Installs: 474
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 1
Forks: 0
Open Issues: 0
Language:Blade
Requires
- php: >=7.0
- dev-master
- 1.0.102
- 1.0.101
- 1.0.100
- 1.0.99
- 1.0.98
- 1.0.97
- 1.0.96
- 1.0.95
- 1.0.94
- 1.0.93
- 1.0.92
- 1.0.91
- 1.0.90
- 1.0.89
- 1.0.88
- 1.0.87
- 1.0.86
- 1.0.85
- 1.0.84
- 1.0.83
- 1.0.82
- 1.0.81
- 1.0.80
- 1.0.79
- 1.0.78
- 1.0.77
- 1.0.76
- 1.0.75
- 1.0.74
- 1.0.73
- 1.0.72
- 1.0.71
- 1.0.70
- 1.0.69
- 1.0.68
- 1.0.67
- 1.0.66
- 1.0.65
- 1.0.64
- 1.0.63
- 1.0.62
- 1.0.61
- 1.0.60
- 1.0.59
- 1.0.58
- 1.0.57
- 1.0.56
- 1.0.55
- 1.0.54
- 1.0.53
- 1.0.52
- 1.0.51
- 1.0.50
- 1.0.49
- 1.0.48
- 1.0.47
- 1.0.46
- 1.0.45
- 1.0.44
- 1.0.43
- 1.0.42
- 1.0.41
- 1.0.40
- 1.0.39
- 1.0.38
- 1.0.37
- 1.0.36
- 1.0.35
- 1.0.34
- 1.0.33
- 1.0.32
- 1.0.31
- 1.0.30
- 1.0.29
- 1.0.28
- 1.0.27
- 1.0.26
- 1.0.25
- 1.0.24
- 1.0.23
- 1.0.22
- 1.0.21
- 1.0.20
- 1.0.19
- 1.0.18
- 1.0.17
- 1.0.16
- 1.0.15
- 1.0.14
- 1.0.13
- 1.0.12
- 1.0.11
- 1.0.10
- 1.0.9
- 1.0.8
- 1.0.7
- 1.0.6
- 1.0.5
- 1.0.4
- 1.0.3
- 1.0.2
- 1.0.0
This package is auto-updated.
Last update: 2025-04-19 16:12:06 UTC
README
About Softinline jCrud
Softinline jCrud is a package designed for help in crud datatable and forms generation, you can define in json files directly linked with controller / models, adding support for export, select rows, adding more buttons, all using the same style.
Components
Softinline jCrud is a set of some components:
- jConfig (load files of config) and offers methods for get/set some configs in realtime access
- jTable (from json define file, can show diferent datatables, setting cols, orderable, searchable, etc...), one define file can store multiple lists under the tag list with diferents names, by default we are using 'index' list
- jForm, this class offers functionality about preapre form with diferent tabs, rows, and multiple input types (text, number, datetime, email, password, editor, custom, view, etc...)
- jcrud.js (this js store information about datatables created, select rows, validation function before submit forms, etc...)
jForm field types
- custom -> call method in controller parent to show some div or HTML code
- file
- date
- datetime
- text
- number
- password
- email
- button -> execute the 'action' key on json defines (normally javascript onclick event)
- checkbox
- textarea
- editor -> replaced with ckeditor needed the plugin installed and initialized
- select -> call controller method defined in 'selector' key on json defines see samples
- select-multiple -> call controller allow multiple selection, controller must return array with 'all' and 'selected' elements
- checkbox-multiple -> same as select-multiple but in checkbox format
- json -> displays information in json field (array) using <pre>
- view -> call view and load, view receives the $config, $item, etc vars with information (see documentation)
***
- childrens -> if field element has a children method, the fields inside can be displayed using a validation method that returns true or not, for example if you want to display more fields depends on select response.
Some samples
You can define your files in app/Defines (ex), in your controller you can use jConfig class to load your defines files like this
var $_jconfig; /** * Create a new controller instance. * @return void */ public function __construct() { $this->_jconfig = new \Softinline\JCrud\JConfig(); $this->_jconfig->load(app_path().'/Defines/admin-users.json', 'admin-users'); }
This is a simple basic sample define for table users: { "admin-users":{ "model":"User", "title":"users", "titleCustom":false, "url":"admin/users", "layout":"layouts.other", "lists":{ "index":{ "wrapper":false, "datatable":true, "class":false, "name":"admin-users", "cols":[ { "name":"id", "field":"id", "orderable":true, "searchable":true }, { "name":"created_at", "field":"created_at", "orderable":true, "searchable":true }, { "name":"email", "field":"email", "orderable":true, "searchable":true }, { "name":"actions", "field":"actions", "orderable":false, "searchable":false } ], "actions":{ "add":true, "export":true, "selector":true }, "options":[ ["export", "fa fa-file", "js:crud.export"], ["reports", "fa fa-list", "link:admin/users/reports"] ], "rowCallBack":false, "drawCallBack":false } }, "forms":{ "add":{ "wrapper":false, "tabs":{ "general":{ "key":"general", "title":"general", "type":"form", "fields":[ { "type":"email", "required":true, "title":"email", "field":"email" }, { "type":"password", "required":false, "title":"password", "field":"password" } ], "extraButtons":[] }, "advanced":{ "key":"advanced", "title":"advanced", "type":"form", "fields":[ { "type":"textarea", "required":true, "title":"advanced1", "field":"advanced2" } ], "extraButtons":[] }, "images":{ "key":"images", "title":"images", "type":"form", "fields":[ { "type":"file", "required":true, "title":"file", "field":"file" } ], "extraButtons":[] } } }, "edit":{ "wrapper":false, "field_title":"email", "tabs":{ "general":{ "key":"general", "title":"general", "type":"form", "fields":[ { "type":"email", "required":true, "title":"email", "field":"email" }, { "type":"password", "required":false, "title":"password", "field":"password" } ], "extraButtons":[] } } } } } }
if you want use rows and cols based on bootstrap you can use a special type field 'row' like this, each you can have n fields of the every type (text, password, editor, date, etc...)
{ "type":"row", "fields":[ { "type":"text", "required":false, "title":"field1", "field":"field1" }, { "type":"text", "required":false, "title":"field2", "field":"field2" }, ] }
License
The Softinline/JCrud is open-sourced software licensed under the MIT license.