Telerik Forums
Kendo UI for jQuery Forum
2 answers
143 views
I am building a point of sale system using Kendo UI. The POS page will have a header section and then a grid to handle sale line items. The user needs to be able to enter lines items (up to 100 or more in a sale) very quickly. Ideally I don't want to force the user to have to reach for the mouse and click the  Add New Record button each time he/she wants to enter a new line item (row) in the grid. This is going to be too slow and awkward. What I would really like is for the grid to automatically start a new row as soon as the user enters a value in the last column of the last row in the grid and moves off the column. I don't see anyway to have the Kendo grid do this. Is it possible?
Randy
Top achievements
Rank 1
 answered on 06 Feb 2017
1 answer
3.9K+ views

Hi --

We have a grid with an action button in the column. When the user clicks the button this code executes.

function showDetails(e) {
     e.preventDefault();
 
     var dataItem = this.dataItem($(e.currentTarget).closest("tr"));
     var grid = $("#gridEnrollments").data("kendoGrid");
     grid.select($(e.currentTarget).closest("tr"));
 
     selectedIndex = grid.select().index();
}

 

The selected row index value is now in the selectedIndex variable.

I would like to then be able to do grid.select(selectedIndex +1).

However, when I do this the selected row is the one above as opposed to below the currently selected row.

How can I achieve what I am looking to do?

Thanks

Rich

 

 

 

 

Eduardo Serra
Telerik team
 answered on 06 Feb 2017
1 answer
188 views

Hi,

I'm using Scatter Chart.

However , when I have a large dataset (around 20,000 data points).

 

The chart renders very slowly (around 20 seconds)

Any ideas ? (I already tried to render it as canvas)

Thanks

Sagi

 

Eduardo Serra
Telerik team
 answered on 06 Feb 2017
1 answer
178 views

Hi,

Is there any way to block the onchange method of the spreadsheet conditionally? My use case is below:

When our users click on the spreadsheet, we getthe top selected row and add some dropdowns (validations) to it (I cannot do this on spreadsheet initialisation as the speed is too slow). However, this forces the onchange method to fire a number of times. The onchange method watches certain columns, as when users change the actual value we need to recalculate things. Is there any way in the onchange method, to work out if the "change" was just adding validation to the cell, as this is all we do in the onclick method?

Thanks

Marc

Eduardo Serra
Telerik team
 answered on 06 Feb 2017
2 answers
433 views
We are trying to do data binding with multiple levels of function calls in order to tidy our base model (not having all of our functions related to some requirements in our model root's)

So let says our model is as following (expressed in typescript for clarity) :

class MyModel extends kendo.data.ObservableObject {
    EnabledDate() { return false; }
}

and we have a the data-binding expressed as following :

<div data-role="datepicker" data-bind="enabled:EnabledDate"></div>

or (with parentheses)

<div data-role="datepicker" data-bind="enabled:EnabledDate()"></div>
Ok -> These both works perfectly, as expected the datepicker is disabled !

( But please note, strangely :

<div data-role="datepicker" data-bind="enabled:UnexistingEnabledDate()"></div>
 --> generate an error : TypeError: d.UnexistingEnabledDate is not a function

while

<div data-role="datepicker" data-bind="enabled:UnexistingEnabledDate"></div>
--> gives no error, but the widget is not disabled !
)


Now, if we want to tidy our model and group "Enabled/Disabled" in a specialized class, let say :

class MySpecializedModel extends kendo.data.ObservableObject {
    EnabledDate() { return false; }
}
our model becomes :

class MyModel extends kendo.data.ObservableObject {
    private _specializedInstance: MySpecializedModel;

    GetSpecializedInstance():MySpecializedModel {
         if (this._specializedInstance == undefined) {
             this._specializedInstance = new MySpecializedModel();   
         }
         return this._specializedInstance;
    }
}

and our data-bind attribute in markup has to be modified, but we can't find a working way of accessing EnabledDate via GetSpecializedInstance.

We tried the following :
<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance.EnabledDate"></div>
--> no javascript errors, but the binding is not working (widget not disabled as expected)
<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance().EnabledDate"></div>
--> TypeError: e.bind is not a function
<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance().EnabledDate()"></div>
--> no javascript errors and correctly binded, but infinite loop (too much recursion) occurs later on, while it does not occur with the "EnabledDate" working binding scheme

<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance.EnabledDate()"></div>
--> TypeError: (intermediate value).EnabledDate is not a function

We also tried accessing SpecializedInstance as a getter property instead of a function by modifying MyModel class with the following code :
class MyModel extends kendo.data.ObservableObject {
    private _specializedInstance: MySpecializedModel;

    get SpecializedInstance(): MySpecializedModel{
        if (this._specializedInstance == undefined) {
             this._specializedInstance = new MySpecializedModel();  
         }
         return this._specializedInstance;
    };
    set SpecializedInstance(value: MySpecializedModel) {
        this._specializedInstance= value;
    };
}

and the following markup gave the following errors :
<div data-role="datepicker" data-bind="enabled:SpecializedInstance.EnabledDate"></div>
--> TypeError: e.bind is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance().EnabledDate"></div>

--> TypeError: d.SpecializedInstance is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance().EnabledDate()"></div>
--> TypeError: d.SpecializedInstance is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance.EnabledDate()"></div>

--> no javascript errors and correctly binded, but infinite loop (too much recursion) occurs later on, while it does not occur with the "EnabledDate" working binding scheme


So, what is the correct syntax when binding with such multiple functions calls level ?

Thanks for your support !

We are trying to do data binding with multiple levels of function calls in order to tidy our base model (not having all of our functions related to some requirements in our model root's)

 

So let says our model is as following (expressed in typescript for clarity) :

 

class MyModel extends kendo.data.ObservableObject {
    EnabledDate() { return false; }

}

 

and we have a the data-binding expressed as following :

<div data-role="datepicker" data-bind="enabled:EnabledDate"></div>

 

or (with parentheses)

<div data-role="datepicker" data-bind="enabled:EnabledDate()"></div>

Ok -> These both works perfectly, as expected the datepicker is disabled !

 

( But please note, strangely :

<div data-role="datepicker" data-bind="enabled:UnexistingEnabledDate()"></div>

 --> generate an error : TypeError: d.UnexistingEnabledDate is not a function

while

<div data-role="datepicker" data-bind="enabled:UnexistingEnabledDate"></div>

--> gives no error, but the widget is not disabled !

)

Now, if we want to tidy our model and group "Enabled/Disabled" in a specialized class, let say :

class MySpecializedModel extends kendo.data.ObservableObject {
    EnabledDate() { return false; }
}

our model becomes :

class MyModel extends kendo.data.ObservableObject {
    private _specializedInstance: MySpecializedModel;
     
    GetSpecializedInstance():MySpecializedModel {
         if (this._specializedInstance == undefined) {
             this._specializedInstance = new MySpecializedModel();   
         }
         return this._specializedInstance;
    }
}

 

and our data-bind attribute in markup has to be modified, but we can't find a working way of accessing EnabledDate via GetSpecializedInstance.

 

We tried the following :

<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance.EnabledDate"></div>

--> no javascript errors, but the binding is not working (widget not disabled as expected)

<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance().EnabledDate"></div>

--> TypeError: e.bind is not a function

<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance().EnabledDate()"></div>

--> no javascript errors and correctly binded, but infinite loop (too much recursion) occurs later on, while it does not occur with the "EnabledDate" working binding scheme

<div data-role="datepicker" data-bind="enabled:GetSpecializedInstance.EnabledDate()"></div>

--> TypeError: (intermediate value).EnabledDate is not a function

 

We also tried accessing SpecializedInstance as a getter property instead of a function by modifying MyModel class with the following code :

class MyModel extends kendo.data.ObservableObject {
    private _specializedInstance: MySpecializedModel;
 
    get SpecializedInstance(): MySpecializedModel{
        if (this._specializedInstance == undefined) {
             this._specializedInstance = new MySpecializedModel();  
         }
         return this._specializedInstance;
    };
    set SpecializedInstance(value: MySpecializedModel) {
        this._specializedInstance= value;
    };
}

 

and the following markup gave the following errors :

<div data-role="datepicker" data-bind="enabled:SpecializedInstance.EnabledDate"></div>

--> TypeError: e.bind is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance().EnabledDate"></div>

--> TypeError: d.SpecializedInstance is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance().EnabledDate()"></div>

--> TypeError: d.SpecializedInstance is not a function

<div data-role="datepicker" data-bind="enabled:SpecializedInstance.EnabledDate()"></div>

--> no javascript errors and correctly binded, but infinite loop (too much recursion) occurs later on, while it does not occur with the "EnabledDate" working binding scheme

 

So, what is the correct syntax when binding with such multiple functions calls level ?

Thanks for your support !

Ianko
Telerik team
 answered on 06 Feb 2017
1 answer
105 views
If I remove the url property on the data item, behavior is normal.
I've got a jsFiddle that demonstrates the problem here. The last node, 'Carpets' has a url property and can't be dropped and won't fire the drag event.
Ivan Danchev
Telerik team
 answered on 06 Feb 2017
1 answer
156 views
We have an editable grid (angular) that's suffering badly with performance. Our customer reports editing grid cell becomes slower and slower and becomes unresponsive very quickly.

We tried to dig into the problem, and notice the angular watch # increases and digest cycle takes longer to execute as user edit each cell. We use angular expression in cell template, and attaches data-ng-model to the td's attribute. 

Below is demo we created that has similar but much simpler setup as our own grid. It you install Chrome extension AngularJS Batarang, you can use to monitor angular digest cycle time and watch #. You will notice these 2 numbers slowly and steadily increases over time.
https://plnkr.co/edit/s4nhIh?p=preview

It's not too bad of a increase in the above, but our own grid is much larger and much more complicated, and performance suffers badly.

Could you explain why is watch# and digest cycle time increases as I edit cell? It seems to be the <td> DOM is not recreated every time on user enter and exit a cell for edit. 
Stefan
Telerik team
 answered on 06 Feb 2017
1 answer
223 views

I am brand new to Kendo UI. I am curious if it is possible to use a MobileSwitch widget on a Grid to represent a boolean value.  Can we configure the columns of the grid to show another Kendo UI widget?

Where should I go to understand how to build Views that have nested widgets?

Viktor Tachev
Telerik team
 answered on 06 Feb 2017
1 answer
1.0K+ views

Good day!

I know that this is asked frequently, but do you have any options/config to set category labels/axis to auto-wrap?

I know that you can render "\n" as part of the label to have a line break, but in order to do that we have to set a defined length on where to do the line break.

We're making the chart responsive as possible and it will be awkward to look at a chart with a wrapped label when there's a lot of space left.

 

Thanks!

Ollie

Neovation

Dimiter Topalov
Telerik team
 answered on 06 Feb 2017
1 answer
282 views

Hi, 

At the minute when I create a new event the default start/end is in 30 minute increments (see screen shot). Is it possible to set the default to start/end to a 60 minute increment?   

Ivan Danchev
Telerik team
 answered on 06 Feb 2017
Narrow your results
Selected tags
Tags
Grid
General Discussions
Charts
Data Source
Scheduler
DropDownList
TreeView
MVVM
Editor
Window
DatePicker
Spreadsheet
Upload
ListView (Mobile)
ComboBox
TabStrip
MultiSelect
AutoComplete
ListView
Menu
Templates
Gantt
Validation
TreeList
Diagram
NumericTextBox
Splitter
PanelBar
Application
Map
Drag and Drop
ToolTip
Calendar
PivotGrid
ScrollView (Mobile)
Toolbar
TabStrip (Mobile)
Slider
Button (Mobile)
Filter
SPA
Drawing API
Drawer (Mobile)
Globalization
LinearGauge
Sortable
ModalView
Hierarchical Data Source
Button
FileManager
MaskedTextBox
View
Form
NavBar
Notification
Switch (Mobile)
SplitView
ListBox
DropDownTree
PDFViewer
Sparkline
ActionSheet
TileLayout
PopOver (Mobile)
TreeMap
ButtonGroup
ColorPicker
Pager
Styling
Chat
MultiColumnComboBox
Dialog
DateRangePicker
Checkbox
Timeline
Drawer
DateInput
ProgressBar
MediaPlayer
ImageEditor
TextBox
OrgChart
Accessibility
Effects
PivotGridV2
Licensing
ScrollView
Switch
TextArea
BulletChart
QRCode
ResponsivePanel
Wizard
CheckBoxGroup
Localization
Barcode
Breadcrumb
Collapsible
MultiViewCalendar
Touch
RadioButton
Stepper
Card
ExpansionPanel
Rating
RadioGroup
Badge
Captcha
Heatmap
AppBar
Loader
Security
TaskBoard
Popover
DockManager
TimePicker
FloatingActionButton
CircularGauge
ColorGradient
ColorPalette
DropDownButton
TimeDurationPicker
ToggleButton
BottomNavigation
Ripple
SkeletonContainer
Avatar
Circular ProgressBar
FlatColorPicker
SplitButton
Signature
Chip
ChipList
VS Code Extension
AIPrompt
PropertyGrid
Sankey
Chart Wizard
OTP Input
SpeechToTextButton
InlineAIPrompt
StockChart
ContextMenu
DateTimePicker
RadialGauge
ArcGauge
AICodingAssistant
SmartPasteButton
PromptBox
SegmentedControl
+? more
Top users last month
Miljana
Top achievements
Rank 2
Iron
Iron
Joel
Top achievements
Rank 3
Bronze
Bronze
Bronze
Cynthia
Top achievements
Rank 1
John
Top achievements
Rank 1
Iron
Mozart
Top achievements
Rank 1
Iron
Veteran
Want to show your ninja superpower to fellow developers?
Top users last month
Miljana
Top achievements
Rank 2
Iron
Iron
Joel
Top achievements
Rank 3
Bronze
Bronze
Bronze
Cynthia
Top achievements
Rank 1
John
Top achievements
Rank 1
Iron
Mozart
Top achievements
Rank 1
Iron
Veteran
Want to show your ninja superpower to fellow developers?
Want to show your ninja superpower to fellow developers?