datatable1.7.1 editor 2.0.4 upload generation
datatable1.7.1 editor 2.0.4 upload generation
Link to test case: no link
Error messages shown: no error be throw
Description of problem: on Upload: upload file in good place, add information in
document table but no add id primary key of document in Facturation!!
BDD:
document
id int(8) Non auto_increment
nom varchar(50) Non
WebPath varchar(100
)
Non
extension varchar(8) Non
facturation
id int(11) Non auto_increment
intitule varchar(50) Non
montant float Non
date_fact timestamp Non CURRENT_TI
MESTAMP
DEFAULT_GENE
RATED
document int(8) Oui NULL -> document.id
ON UPDATE RESTRICT
ON DELETE CASCADE
id_tache int(6) Non -> tache.id
ON UPDATE CASCADE
ON DELETE RESTRICT
id_ent int(4) Non
PHP repository:
$e=Editor::inst(self::$db,self::$table );
$e->fields(
Field::inst('facturation.document')->setFormatter( Format::ifEmpty( null ) )
->upload(
Upload::inst( './uploads/__ID__.__EXTN__' )
->db( 'document', 'id', array(
'nom' => Upload::DB_FILE_NAME,
'webPath' => Upload::DB_SYSTEM_PATH,
'extension'=> Upload::DB_EXTN
))
)
);
$e->process($_POST)
->json();
js for generation:
let pda={appel:repo};
let pdax={url:appel,type:"POST",data:pda};
$.post(pdax.url,pda).done(function(data, st) {
let attr=".datatable",clmns=[],field=[];
let donne=JSON.parse(data);
let dt=donne.data[0];
//addcolonne de check
clmns.push({title:sstitre,className:'details-control',orderable:false,"data": null,"defaultContent":''});
buildParam(dt,field,clmns);
editor = new $.fn.dataTable.Editor( {
ajax:{url:appel,
type:"POST",
data:function (d) {
d.appel = repo;
}},
table:attr,
fields: field
} );
$.fn.dataTable.ext.errMode = 'none';
table =$(attr).on( 'error.dt', function ( e, settings, techNote, message ) {
console.log( 'An error has been reported by DataTables: ', message );
} ).DataTable( {
dom: 'B<"toolbar">rtip',//f pour searchbox
ajax:pdax,
processing: true,
serverSide: true,
order: [[ 1, 'asc' ]],
columns: clmns,
columnDefs : clmd,
responsive:true,
retrieve: true,
select: true,
buttons:bt
} ).on( 'click', 'tbody td:not(:first-child)', function (e) {
editor.inline( this );
} ).on('click', 'tbody td.details-control', function (e) {
e.stopImmediatePropagation();
let tr = $(this).closest('tr');
let row = table.row( tr ),
idx=table.row( this ).index();
let id=table.cell( idx,1).data();
if ( row.child.isShown() ) {
// This row is already open - close it
row.child.hide(),tr.removeClass('shown');
$("#DataTables_Table_"+id+"_wrapper").removeClass('bcg');
}
else{
// Open this row
row.child("<table class='sstable'></table>").show();
createTable(id),tr.addClass('shown');
$('.sstable').parent().css("background-color", "#0086bd");
}
tr=null;
} )
cTb();
});
buildParam=(dt,field,clmns)=>{
$.each(dt,function(k,v){
// console.log(k);
if(typeof v==='object'){
$.each(v,function(sk,sv){
if(sk==='document'){
field.push({
label:sk,
name:k+"."+sk,
type: "upload",
// display: ( id )=> {console.log(id);
// return '<img src="'+editor.file( 'document', id ).webPath+'"/>';
// },
// noImageText: 'No image'
}),
clmns.push({title:sk,data:k+"."+sk,/*render: function ( data ) {
return data ?
'<img src="'+editor.file( 'document', data ).webPath+'" />' :
'No image';
}*/});
}else if(!/id[_]|[_]id|password/.test(sk)){
field.push({label:sk,name:k+"."+sk}),
clmns.push({title:sk,data:k+"."+sk});
}
});
}else if(!k.includes('DT_RowId')){
field.push({label:k,name:k}),
clmns.push({title:k,data:k});
}
});
}
Edited by Allan - Syntax highlighting. Details on how to highlight code using markdown can be found in this guide.
This discussion has been closed.
Replies
Can you use the debugger to give me a trace please - click the Upload button and then let me know what the debug code is.
Thanks,
Allan
i place debugger in js & have this
https://debug.datatables.net/ibozaq
& i add
editor.on( 'uploadXhrSuccess', function ( e, json, data ) {
console.log( e);console.log( json);console.log(data);
} );
& get this
S.Event {type: "uploadXhrSuccess", timeStamp: 1627534943107, jQuery35009936382601232892: true, isTrigger: 2, namespace: "", …}
altKey: (...)
bubbles: (...)
button: (...)
buttons: (...)
cancelable: (...)
changedTouches: (...)
char: (...)
charCode: (...)
clientX: (...)
clientY: (...)
code: (...)
ctrlKey: (...)
currentTarget: a {add: ƒ, ajax: ƒ, background: ƒ, blur: ƒ, bubble: ƒ, …}
data: undefined
delegateTarget: a {add: ƒ, ajax: ƒ, background: ƒ, blur: ƒ, bubble: ƒ, …}
detail: (...)
eventPhase: (...)
handleObj: {type: "uploadXhrSuccess", origType: "uploadXhrSuccess", data: undefined, guid: 206, handler: ƒ, …}
isTrigger: 2
jQuery35009936382601232892: true
key: (...)
keyCode: (...)
metaKey: (...)
namespace: ""
offsetX: (...)
offsetY: (...)
pageX: (...)
pageY: (...)
pointerId: (...)
pointerType: (...)
result: undefined
rnamespace: null
screenX: (...)
screenY: (...)
shiftKey: (...)
target: a {add: ƒ, ajax: ƒ, background: ƒ, blur: ƒ, bubble: ƒ, …}
targetTouches: (...)
timeStamp: 1627534943107
toElement: (...)
touches: (...)
type: "uploadXhrSuccess"
view: (...)
which: (...)
proto: Object
generateTable.js:163 facturation.document
generateTable.js:163
{data: Array(0), files: {…}, upload: {…}}
data: []
files: {document: {…}}
upload: {id: "27"}
proto: Object
& in network i have this
the first:
data: [{DT_RowId: "row_6",…}, {DT_RowId: "row_7",…}, {DT_RowId: "row_8",…}, {DT_RowId: "row_9",…},…]
0: {DT_RowId: "row_6",…}
1: {DT_RowId: "row_7",…}
2: {DT_RowId: "row_8",…}
3: {DT_RowId: "row_9",…}
4: {DT_RowId: "row_10",…}
5: {DT_RowId: "row_11",…}
6: {DT_RowId: "row_12",…}
7: {DT_RowId: "row_13",…}
8: {DT_RowId: "row_14",…}
9: {DT_RowId: "row_15",…}
10: {DT_RowId: "row_16",…}
11: {DT_RowId: "row_17",…}
12: {DT_RowId: "row_18",…}
13: {DT_RowId: "row_19",…}
14: {DT_RowId: "row_20",…}
files: {document: {20: {id: "20", nom: "dlText.txt", webPath: "./uploads/20.txt", extension: "txt"}}}
document: {20: {id: "20", nom: "dlText.txt", webPath: "./uploads/20.txt", extension: "txt"}}
options: []
the draw
data: [{DT_RowId: "row_6",…}, {DT_RowId: "row_7",…}, {DT_RowId: "row_8",…}, {DT_RowId: "row_9",…},…]
0: {DT_RowId: "row_6",…}
DT_RowId: "row_6"
Facturation: {id: "6", intitule: "Facture", montant: "1200", date_fact: "2021-06-11 09:58:57", document: "20",…}
1: {DT_RowId: "row_7",…}
2: {DT_RowId: "row_8",…}
3: {DT_RowId: "row_9",…}
4: {DT_RowId: "row_10",…}
5: {DT_RowId: "row_11",…}
6: {DT_RowId: "row_12",…}
7: {DT_RowId: "row_13",…}
8: {DT_RowId: "row_14",…}
9: {DT_RowId: "row_15",…}
draw: 1
files: {document: {20: {id: "20", nom: "dlText.txt", webPath: "./uploads/20.txt", extension: "txt"}}}
options: []
recordsFiltered: "15"
recordsTotal: "15"
but in final
{data: [], files: {,…}, upload: {id: "30"}}
data: []
files: {,…}
document: {30: {id: "30", nom: "banniereSignature.png", webPath: "./uploads/30.png", extension: "png"}}
upload: {id: "30"}
id: "30"
i try to add ->debug(true) in php
when it's upload but??
I think I'm going to need a link to your page so I can debug this please. You can send it to me by private message by clicking my forum user name above and then the "Send message" button.
Everything you have there looks like it should be working properly - I'm not sure why it wouldn't be yet.
Thanks,
Allan
tomorow, i put him online
& give you access code.
i have another question too,
i wish one call when i create table
but have 2 for moment because create columns & field.
so i wish not pass but ajax in datatable attribut
but directly put him his data!
not work because editor be not linked??
You can make the Ajax call yourself to get both the columns and the data in a single call - then initialise both your DataTable and Editor as normal (passing in the
data
andcolumns
options to DataTables).Allan
work but not change bdd like this
i try this, for upload
editor.on( 'uploadXhrSuccess', function ( e, json, data ) {
// debug();
editor
.edit( table.rows( {selected: true } ).indexes(), false )
.val( 'document', data.upload.id)
.submit();
} );
but not found document like this
or
he found it like this
editor.file("document",id)
sorry it's me,
editor.on( 'uploadXhrSuccess', function ( e, json, data ) {
// debug();
editor
.edit( table.rows( {selected: true } ).indexes(), false )
.val( 'Facturation.document', data.upload.id)
.submit();
} );
but like this..
dataTables.editor.min.js:41 Uncaught Unknown file id 47 in table document
or value is enter in bdd
finally work,
but i need disable
display in field be upload..
& display with render of columns
field().disable()
can be used to disable a field.Regards,
Allan
in follow of...
i have "sous table" opening on first colums
this 2nd work fine, by editor too & be joined on first table
but
for Upload, not accept or understand???
for table
similar
but
not update Facturation.document
I don't understand I'm afraid. There is nothing in the above code about disabling a field. Also, I'm not sure why you've posted the debugger code.
Allan
not debugger code here,
just
sseditor not edit
Facturation.document!!
not change, do nothing