This is a migrated thread and some comments may be shown as answers.

ToolTip for DropDownList custom Grid editor

2 Answers 283 Views
ToolTip
This is a migrated thread and some comments may be shown as answers.
Duane
Top achievements
Rank 1
Duane asked on 06 Apr 2017, 09:33 PM

I've implemented a DropDownList in a custom editor for a Grid column as follows.

                    $("#control").kendoGrid({
                        dataSource: controlDs,
                        editable: true,
                        saveChanges: function (e) {
                            if (!confirm("Are you sure you wish to save changes?")) {
                                e.preventDefault();
                            }
                        },
                        toolbar: ["save","cancel"],
                        sortable: true,
                        columns: [
                                {
                                    title: "Artifacts",
                                    headerAttributes: {
                                        style: "font-size: 10pt; font-weight: 600; text-align: center;"
                                    },
                                    columns: [
                                        {
                                            field: "family",
                                            editor: customDropDownEditor,
                                            headerAttributes: {
                                                style: "font-size: 10pt; font-weight: 600;"
                                            },
                                            title: "Family",
                                            width: 120
                                        },
                                        {
                                            field: "artifact",
                                            editable: function (dataItem) {
                                                return false;
                                            },
                                            headerAttributes: {
                                                style: "font-size: 10pt; font-weight: 600;"
                                            },
                                            title: "Artifact",
                                            template: '<a href="#=artifact#" target="_blank">#=title#</a>'
                                        }
                                    ]
                                }
                            ]
                    });

                function customDropDownEditor(container, options) {
                    $('<input required name="' + options.field + '"/>')
                        .appendTo(container)
                        .kendoDropDownList({
                            autoBind: false,
                            dataSource: ["one", "two", "three", "four"]
                        });
                }

This works perfectly. Now, how do I attach a ToolTip widget to the items in this DropDownList?

Thanks in advance.

2 Answers, 1 is accepted

Sort by
0
Duane
Top achievements
Rank 1
answered on 07 Apr 2017, 09:46 PM

Okay, I think I solved this adequately. I modified the "customDropDownEditor" code as follows.

                function familyDropDownEditor(container, options) {
                    $('<input required name="' + options.field + '"/>')
                        .appendTo(container)
                        .kendoDropDownList({
                            autoBind: false,
                            dataSource: ["one", "two", "three", "four"]
                        });
                    // locate the kendoDropDownList created above
                    var ddl = $("#control").find(".k-dropdown > input").data("kendoDropDownList");
                    $("body").kendoTooltip({
                        filter: 'li.k-item',
                        position: 'right',
                        content: function (e) {
                            var dataItem = ddl.dataItem($(e.target));
                            var content = familyLookupTable[dataItem](); // get tooltip text from the lookup table
                            return content;
                        },
                        width: 80
                    });
                }

Is this the proper approach, or is there a better way to handle this?

 

0
Ianko
Telerik team
answered on 10 Apr 2017, 10:50 AM

Hello Duane,

You could also have the Tooltip initialization outside the editor function. Like in this dojo here: http://dojo.telerik.com/OvOXO

Regards,
Ianko
Telerik by Progress
Try our brand new, jQuery-free Angular 2 components built from ground-up which deliver the business app essential building blocks - a grid component, data visualization (charts) and form elements.
Tags
ToolTip
Asked by
Duane
Top achievements
Rank 1
Answers by
Duane
Top achievements
Rank 1
Ianko
Telerik team
Share this question
or