Search code examples
comboboxsapui5dynamic-tables

How can I get items on sapui5 dynamic table?


I have created dynamic table, but while I was trying to show combobox items I could not figured it out. Here is the problem and my code:

enter image description here

As you see above link or picture, I can not see the items, But actually, the result is true(3 items) without text. I tried to solve the problem hardly, but no solve, Please If you see my misssing, tell me.

onCreateTable: function () {
            var summaryDetailData = {
                "subvariants": [{
                    "kontrolNesnesiTanim": "test 1 Tanım",
                    "kontrolNesnesiBelirtim": "test 1 Belirtim",
                    "kontrolSonucu": {
                        "test0": "test00",
                        "test1": "test10",
                        "test2": "test20",
                    },
                    "kontrolEdilecek": 20,
                    "kontrolEdilen": 0,
                    "icon": "sap-icon://accept"
                }, {
                    "kontrolNesnesiTanim": "test 2 Tanım",
                    "kontrolNesnesiBelirtim": "test 2 Belirtim",
                    "kontrolSonucu": {
                        "test0": "test00",
                        "test1": "test10",
                        "test2": "test20",
                        "test3": "test30"
                    },
                    "kontrolEdilecek": 10,
                    "kontrolEdilen": 0,
                    "icon": "sap-icon://decline"
                }, {
                    "kontrolNesnesiTanim": "test 3 Tanım",
                    "kontrolNesnesiBelirtim": "test 3 Belirtim",
                    "kontrolSonucu": {
                        "test0": "test00",
                        "test1": "test10",
                        "test2": "test20",
                    },
                    "kontrolEdilecek": 50,
                    "kontrolEdilen": 0,
                    "icon": "sap-icon://accept"
                }, ]
            };

            var oTable = new sap.m.Table("idRandomDataTable", {
                headerToolbar: new sap.m.Toolbar({
                    content: [new sap.m.Label({
                        text: ""
                    })]
                }),
                columns: [new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Kontrol Nesnesi"
                    })
                }), new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Kontrol Sonucu"
                    })
                }), new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Kontrol Edilecek"
                    })
                }), new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Kontrol Edilen"
                    })
                }), new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Durum/Değerlendirme"
                    })
                }), new sap.m.Column({
                    width: "2em",
                    header: new sap.m.Label({
                        text: "Açıklama"
                    })
                })]
            });

            this.getView().byId("SimpleFormChange480_TrialSonuc").addContent(oTable);

            oTable.bindItems("/subvariants", new sap.m.ColumnListItem({
                cells: [new sap.m.ObjectIdentifier({
                    title: "{kontrolNesnesiTanim}",
                    "titleActive": true,
                    text: "{kontrolNesnesiBelirtim}"
                }), 
                new sap.m.ComboBox({
                    items: {
                        path: "kontrolSonucu/",
                        change:"onChange",
                        template: new sap.ui.core.Item({
                            key: "test01",
                            change:"onChange",
                            text: "{test0}"
                        })
                    },
                    change:"onChange",
                })
                // new sap.m.MultiInput({
                //  id:"multiInput3",
                //  showValueHelp:false
                // })
                , new sap.m.Input({
                    value: "{kontrolEdilecek}",
                }), new sap.m.Input({
                    value: "{kontrolEdilen}"
                }), new sap.ui.core.Icon({
                    src: "{icon}"
                        //text: "{Article}"
                }), new sap.m.Input({
                    value: "",
                    // value: "{question}",
                })]
            }));

            oTable.setModel(new sap.ui.model.json.JSONModel(summaryDetailData));
        }

Do you have any idea or suggestion?

Thanks.


Solution

  • I have solved the problem

        oTable.bindItems("/subvariants", new sap.m.ColumnListItem({
                cells: [new sap.m.ObjectIdentifier({
                    title: "{kontrolNesnesiTanim}",
                    "titleActive": true,
                    text: "{kontrolNesnesiBelirtim}"
                }), 
                new sap.m.ComboBox({
                    items: {
                        path: "kontrolSonucu/",
                        change:"onChange",
                        template: new sap.ui.core.Item({
                            key : "{}",
                            change:"onChange",
                            text: "{}"
                        })
                    },
                    change:"onChange",
                })
    

    As you see above, I should had to write text empty JSON, So I can see all the items.

    Thanks anyway.