How to add default styling to datatable used inside Editor?
How to add default styling to datatable used inside Editor?
data:image/s3,"s3://crabby-images/62317/62317c58076c61215b2edd0b3c9228507dbd8b04" alt="maxmedia"
Description of problem:
When using "datatable" field type in Editor, datatable is created automatically without any special table classes. In BS5, table needs at least classs "table" to be nice. Is there a simple way to define default classses for those dynamically created tables?
This works fine, but maybe there's a bettter way:
eshopEditor.on('open', function() {
var table=eshopEditor.field('mx_eshopOrderItems').dt();
$(table.table().container()).find('table').addClass('table table-striped');
});
This question has an accepted answers - jump to answer
Answers
In this example if I select Bootstrap 5 as the styling option, the table does have
table
assigned to it as a class name. That comes from this line ineditor.bootstrap5.js
:You can override that parameter if you want it to have a different class name.
Allan
Ah, thanks Allan, learning every daydata:image/s3,"s3://crabby-images/c0881/c088182f17adc95a167631364f80455c62be1345" alt=":D :D"
But editing library file is probably not a good idea due to future updates.
Inspired by changing default settings for Datables, I have tried this in my custom.js init to use additional classes, seems to work:
You don't need to edit the library file (sorry, I wasn't suggesting you do so) - you just need to include that line of code somewhere in your own code, after the library has been loaded. Probably just before you create the Editor instance (which it sounds like you have done).
will do it. No need to use
Object.assign
here since it isn't an object you are passing toassign
.Allan