Mobiscroll is a library of Touch UI Components created with a lot of attention to usability and performance. The Components are based on the powerful and highly customizable Mobiscroll Core.
You can use mobiscroll components in your web and mobile apps for making data picking and navigation easy. It works with jQuery, jQuery Mobile, Zepto.JS and Intel App Framework (formerly known as jQMobi). You can also use it to develop hybrid apps with PhoneGap. You can use it in Windows 8 and Windows Phone 8 apps as well. Mobiscroll at its core is a javascript library so it runs everywhere where javascript can be executed. It is a great companion to all frameworks and libraries like Kendo UI, Backbone JS, Bootstrap, Angular JS, Knockout JS ....
Supported on iOS 4-7, Android 2.2 - 4.4, Windows Phone 8, BlackBerry, Amazon Kindle, Chrome, Safari, Firefox, IE9-11. Please submit issues, and compatibility problems with other devices.
If you like it, spread the word!
Twitter http://twitter.com/mobiscroll
Facebook https://www.facebook.com/mobiscroll
Google+ https://plus.google.com/+MobiscrollUI
We're looking at showcasing some of the best work on http://mobiscroll.com . Feel free to let us know on twitter @mobiscroll!
Integrations
-
New:
mobiscroll-data
attribute added to Angular listview integration for filter support (#264). -
New:
mobiscroll-instance
attribute added to Angular directives for better accessibility (#266). -
New: Added menustrip helper to ASP.NET MVC integration.
-
Fixed: Kendo
mobiscroll-color
andmobiscroll-range
bindings were not working (#268). -
Fixed: Group select was not working with Angular, if generated with
ng-repeat
.
Datetime
- New:
steps
setting instead ofstepHour
,stepMinute
,stepSecond
, also allows starting steps from 0 (#263).
Calendar
- Fixed: Marked icon was not visible, if had color and text specified.
Listview
-
New:
enhance
setting to automatically add styling to list items. -
New:
rtl
setting for right to left support. -
Fixed: Listview fixed header was not removed on destroy, if context was specified.
Measurements
- Fixed: Disable whole value, if all fractions are disabled.
Menustrip
- New:
navigate
,prev
andnext
methods for programatic navigation.
Number
- Fixed: Disable whole value, if all fractions are disabled.
Scroller
- Fixed: Detach keydown event handler from window on hide.
Themes
- Fixed: Widget header disappeared if header text was empty.
Calendar
- Fixed: Initially selected days were not highlighted with multiple selection enabled.
Core
-
Fixed:
isVisible
method returned the DOM element before the first show. -
Fixed: Tap was not working on Android 2.3
-
Fixed:
$.mobiscroll.activeInstance
is tracked only for modal widgets (other than inline).
Integrations
-
Fixed: Inline calendar jumping between dates with Angular, Ember, Knockout and Kendo integration (#257).
-
Fixed: Listview rendering changed using backbone.js and underscore.js. Underscore.js v1.7.0 required.
Menustrip
-
New:
refresh
method to recalculate dimensions needed for scrolling and enhance markup for new elements. (#261). -
New: Accessibility improvements by adding aria attributes.
-
Fixed: App Framework compatibility fixes.
Numpad
- Fixed: Decimal preset did not allow entering leading zeroes even if
allowLeadingZero
setting was true (#259).
Timespan
- New: Don't display 0 values in the input (#260).
Themes
-
Fixed: Inconsistent wheel item highlight on tap with Windows Phone theme.
-
New: Mobiscroll Dark theme.
Auto Theme
- Fixed: Did not load iOS Classic theme on iOS < 7.
Calendar
- Fixed: setVal was not working correctly with multiple select if date objects had time (other than 00:00) (#258).
Image
-
Fixed:
enhance
setting did not work with App Framework. -
Fixed:
labels
setting did not work properly.
Range
-
Fixed: Stopped working if
onClose
returned false. -
Fixed:
defaultValue
did not work correctly with empty array.
Themes
-
Fixed: Bubble arrow was dark for Android Holo Light.
-
Fixed: Bubble arrow was dark for Windows Phone Light.
Treelist
-
Fixed:
enhance
setting did not work with App Framework. -
Fixed:
labels
setting did not work properly.
Core
-
Removed:
$.scroller
is no longer supported, use$.mobiscroll
instead. -
Removed: Setting
false
forsetText
andcancelText
in order to hide the Set and Cancel buttons is no longer supported. Use thebuttons
setting instead. -
New: API cleanup:
setVal
andgetVal
methods added to all components for setting and getting the selected value(s), instead ofgetValue
,setValue
,getValues
,setValues
,getDate
, setDate` (#236). -
New: API cleanup:
setArrayVal
andgetArrayVal
methods for getting and setting the 'raw' wheel value array (for scroller components), or the 'raw' number array (for numpad components) (#236). -
New: Disable page scroll with mousewheel in desktop browsers, when the popup is visible.
-
New: Support for predefined button handlers: 'set', 'cancel', 'clear', 'now', e.g.
buttons: [ { text: 'Hide', handler: 'cancel' } ]
. -
New: Support for custom button classes, use
btnClass
to specifiy the css class for all buttons, or set thecssClass
property of the individual button, e.g.buttons: [ { text: 'Set', handler: 'set', cssClass: 'my-btn' } ]
(#252). -
New: Support for button icons, use the
icon
property of the individual button, e.g.buttons: [ { text: 'Set', icon: 'checkmark', handler: 'set' } ]
. -
New: Show is called on tap instead of click for faster response.
-
Fixed: Remove animationend event after show, otherwise the popup reappeared after hide in older versions of Chrome.
-
Fixed: Layout was messed up if a function was passed to the
headerText
setting, but only if it contained html strings.
Scroller
- Removed: Old, object based wheel format is no longer supported.
Datetime
-
Removed:
showNow
setting is no longer supported. Use thebuttons
setting instead. -
Removed: Old format for passing invalid values is no longer supported.
-
Fixed: On a year/month picker months with less than 31 days were unselectable if current day was 31st.
Calendar
-
Removed: Old format for passing invalid values, marked days and events is no longer supported.
-
New: Dynamic font size for liquid / full screen calendars.
-
New: elastic scroll for year and month selector.
-
New: Month and year text is updated in the header when the month change animation starts.
-
New:
swipeDirection
setting to enable horizontal or vertical navigation (#251).
Color
- New: Initialization changed to
$('#color').mobiscroll().color()
,$('#color').mobiscroll().colorpicker()
is deprecated and will be removed in the future.
Listview
-
New:
actionWidth
setting for specify the width of the action menu (#233). -
New:
openActions
function which opens the actions of a list item programatically (#247). -
New:
openStage
function which opens a specified stage of a list item programatically (#247). -
New: Additional formats to specify
stages
: specify sepparate left and right stages, percentages are autogenerated if not specified.
Range
-
New: Initialization changed to
$('#range').mobiscroll().range()
,$('#range').mobiscroll().rangepicker()
is deprecated and will be removed in the future. -
New:
swipeDirection
setting to enable horizontal or vertical navigation (#251). -
New: Updated Mobiscroll theme.
Select
- New:
data
setting for initializing the select component without using a html select,dataText
,dataValue
,dataGroup
settings to define thedata
object text, value and group property names.
Image
- New:
enhance
setting to automatically add styling to the list.
Themes
-
New:
android-holo
theme pixel sizes changed to em. -
New:
wp
theme pixel sizes changed to em. -
New:
ios
theme renamed toios-classic
. -
New:
ios7
theme renamed toios
,ios7
is still supported, but deprecated. -
New:
sense5
theme renamed tosense
,sense5
is still supported, but deprecated.
Angular Integration
-
New: Support for
ng-model
directive. -
New:
mobiscroll-scroller
directive for custom wheels
Calendar
- Fixed:
mousemove
andmouseup
events were incorrectly detached on swipe end.
Core
- Fixed: Popup was outlined on Chrome / OSX.
Listview
- Fixed: Sort handle was generated for group headers.
Range
- Fixed: Times were displayed before validation.
Angular integration
- Fixed: Incorrect null value support.
Calendar
-
Fixed: If tab was changed during wheel animation, wheel was visible while animated.
-
Fixed: Show year suffix in calendar header as well.
-
Fixed: Javascript error if
quickNav
setting was set tofalse
.
Core
-
Fixed: Re-focusing on the input field after closing the widget caused problems in iOS8. Re-focusing is disabled until the problem is fixed.
-
Fixed: Width/height calculations were incorrect during animation with Zepto and App Framework.
-
Fixed: Positioning was incorrect if website was zoomed on mobile devices (#248).
-
Fixed: Re-enable form fields when widget animation starts.
-
Fixed: Don't add tap highlight to invalid wheel items.
List
-
Fixed: Fix for parse and format, if number was passed to the
setValue
method. -
Fixed: Incorrect wheel values if there was no
data-val
attribute present with Zepto and App Framework.
Angular integration
- Fixed: ng-repeat support for Treelist and Image & Text component directives.
Calendar
-
New: Accessibility enhancements (#242): read full date for every day, announce month and year on month navigation, read events and event duration.
-
New: Month and year selector.
Core
-
Fixed: enable/disable functions (#240).
-
New: Allow null value for each component.
-
New: Show /hide animation improvements: background overlay will fade in and out, faster and smoother animations.
Datetime
- Fixed: Time validation fix (#244).
Measurements
- New:
scale
setting which controls the decimal precision (#80).
Numpad
-
New: Datepicker preset.
-
New:
min
andmax
settings. -
New:
invalid
setting. -
New:
headerText
setting.
Select
-
New: If the select is grouped and
group
setting is false, group labels will appear as list dividers. -
New: If multiple selection is enabled, there is no empty space on the top and bottom of the wheel anymore, and value on the middle is not highlighted.
Calendar
-
Fixed: Event bubble is repositioned on orientationchange or resize.
-
New: In multiselect mode input will be filled with all the selected dates.
Numpad
-
New: Keyboard support.
-
New: Custom button support.
-
New: Time picker preset.
-
New:
returnAffix
setting for decimal numpad. -
New:
mask
setting for hiding the entered numbers (e.g. PIN code). -
New:
defaultValue
setting for decimal, time and timespan presets.
Timespan
- New: Allow
clickpick
andmixed
modes.
Scroller
- New:
focusOnClose
setting.
Calendar
-
Fixed: Time was not set correctly if
closeOnSelect
was true. -
Fixed: In fullscreen mode calendar was not full width.
-
New:
onSetDate
receives a day object withdate
andcontrol
(where the selection occured: 'calendar', 'date', 'time' or undefined) properties. -
New:
navigate
method to display a specific month on the calendar without setting the date. -
New:
weekDays
option to control the format of week days in the calendar header. Can befull
,short
ormin
.
Listview
-
Fixed: Native input and select elements inside list items were not working (#231).
-
Fixed: Be able to display multiple rows in group headers.
-
Fixed: 'ng-if' directive can be used inside li's with 'mbsc-' prefix
-
New:
onNavStart
andonNavEnd
events on hierarchical navigation. -
New:
onItemTap
event receives the event object as parameter.
Numpad
- New: A new control with numeric keys for filling numeric values.
Rangepicker
-
New:
minRange
andmaxRange
settings for minimum and maximum selectable range. -
New:
onSetDate
receives a day object withdate
,control
(where the selection occured: 'calendar', 'date', 'time' or undefined), andactive
('start' or 'end') properties (#222). -
New:
showSelector
setting.
Themes
-
New: Brand new default theme.
-
New: Theme classes are prefixed with
.mbsc-
to make the classes less generic and avoid conflicts with other libraries. -
New: iOS7 like checkmark icon for the iOS7 theme multiselection.
-
New: New wheel styles for jQuery Mobile and Bootstrap themes.
Scroller
- Fixed: Handle resize / orientationchange events per instance.
Listview
-
Added: Tap highlight occurs only if tap action is defined.
-
Added: Improved styling for jQuery Mobile listviews.
-
Added: Support for adding a list item containing sub list.
Measurements
- Added: Support for greater precision.
Number
-
Added: Support for greater precision.
-
Fixed: Negative wheel values were incorrectly generated.
Rangepicker
- Fixed: When
rangeTap
is true, set end date the same as start date on selection start.
Select
- Added: Use font for displaying the multiselect checked icon.
Angular Integration
-
Fixed: Support for
itemGroups
setting. -
Fixed: Initial value was not set correctly for calendar and select components.
-
Fixed: Script errors when timer was running.
Core
- Added:
rtl
setting for right to left support.
Datetime
-
Added: Support for invalid ranges.
-
Added:
valid
setting to override invalid dates.
Languages
- Added: Persian translation and support for jalali dates.
List
- Fixed: Support for
data-val="0"
(#223).
Listview
-
Added: Undo functionality.
-
Added:
itemGroups
setting for defining different settings (actions, stages, tap) for different list items. -
Added:
altRow
setting for alternate line colors. -
Added:
fixedHeader
setting for fixed group headers.
Themes
- Changed:
android-ics
renamed toandroid-holo
.
Windows Phone Theme
- Changed: PNG images are replaced with font icons.
Core
-
Added:
preventFocus
parameter for theshow
method. -
Added: automatic liquid layout based on screen size.
Integration
- Added: support for hiearchical listview in Knockout, Angular and Backbone integration plugins.
Rating
- Fixed: Vertical alignment was incorrect with Windows Phone theme.
Calendar
-
Added: Support right to left languages with the
rtl
setting. -
Added: Support for displaying icons on marked days.
Datetime
- Added:
yearSuffix
,monthSuffix
,daySuffix
settings for improved localization (#142).
List
- Added:
placeholder
setting for the generated input field.
Listview
-
Added:
disabled
property forstage
oraction
setting. -
Added: support for hierarchical lists.
Rating
-
Added: Font icons are now used instead of images, icons can be changed with the
iconFilled
andiconEmpty
settings. -
Added:
placeholder
setting for the generated input field.
Rangepicker
- Added:
autoCorrect
setting to disable automatic date adjustment if end is earlier than start.
Select
- Added:
placeholder
setting for the generated input field.
Core
-
Fixed: Prevent virtual keyboard popup on some devices (#216).
-
Fixed: Page scrolled to bottom in IE and FF on show (#214).
Datetime
- Fixed: Hour, minute and second steps are now calculated from minimum time, if specified (#204).
Select
- Fixed: Select scroller whithout value attributes now can be selected (#215).
Core
-
Fixed: Tap on items did not work correctly on Android 2.3
-
Fixed: Tap on overlay caused bleed-through on Android 2.3
-
Fixed: Fallback to english locales if a language is not found (#210).
-
Fixed: Animations are disabled now on Android 2.3
Calendar
-
Fixed: Page was not scrollable from the calendar if in inline mode or calendar was larger than the screen.
-
Fixed: If in inline mode, months swipe was broken if used with page transitions on some devices.
-
Fixed: Month swipe worked incorrectly with min/max date set.
Datetime
-
Fixed: fix for parseDate and formatDate utility functions (#209).
-
Fixed: minDate and maxDate did not work correctly (#212).
Timer
- Fixed: Display fixes for ios, ios7 and android-ics themes.
Treelist
- Fixed: Wheels were not always hidden if tree had different levels (#211).
Core
-
Changed: Mobiscroll is focused on popup to make keyboard navigation easier (#150).
-
Changed: Using css flexible box model for wheel distribution. Falls back to table layout on devices without flex support (IE8 and IE9).
-
Changed: Improved Firefox compatibility.
-
Added: layout setting, can be 'fixed' or 'liquid'.
-
Added: multiline setting to wrap the wheel item content into multiple lines.
Rangepicker
- Changed: Initial range is now today + 7 days.
Listview
- Added: animation setting, if set to false no animation will occur. Default is true.
Localization
- Added: Romanian, Polish, Russian (UA) translations.
Core
Calendar
- Fixed: Keyboard navigation issues.
Measurements
-
Fixed: Value is constrained between min and max if set from input or with setValue method.
-
Fixed: setValue did not work correctly if value was passed as an array (#188).
Select
- Fixed: getValue method was not working correctly in group mode (#202).
Themes
- Fixed: Auto theme chooser did not detect iOS7 correctly (#207).
Treelist
- Fixed: Readonly setting was not working correctly (#203).
Core
- Added: activeInstance variable.
Calendar
- Added: months setting now accepts 'auto' to automatically determine the number of months to display.
Datetime
Rangepicker
- Added: setActiveDate method.
Listview
-
Added: pixel units changed to em.
-
Added: swipe setting accepts multiple values: true, false, 'left', 'right', or a function.
-
Added: onSlideStart event.
-
Added: List dividers are now supported by adding data-role="list-divider" attribute to one ore more list elements.
-
Added: sortable setting can be true, false, or 'group'. If 'group', sort is allowed only inside the group defined by the list dividers.
-
Added: actions setting to display a list of icons under the slided list item. If an icon is tapped, the corresponding action will be executed, otherwise the list item slides back.
Core
- Fixed: If a default theme or language was set using setDefaults, theme and language settings were not loaded.
Calendar
-
Fixed: closeOnSelect setting caused event bleedthrough on some iOS versions.
-
Fixed: closeOnSelect now always disables divergentDayChange setting.
Listview
-
Fixed: Incorrect this reference in action function if called after confirmation.
-
Fixed: Icon slide issue when more than one listview was present on the page (#198).
Themes
- Fixed: WP theme fix for clickpick buttons active style.
Datetime
- Added: amText and pmText localization settings.
Rangepicker
- Added: getValue method can now return temporary start and end dates (if set button is not yet clicked).
Localization
- Added: en-UK locale settings.
Core
-
Fixed: setDefaults method didn't work.
-
Fixed: null value is set if all options are disabled on a wheel (#196).
Calendar
-
Fixed: closeOnSelect setting didn't work correctly.
-
Fixed: Orientationchange from landscape to portrait didn't work correctly if tabs were present.
Listview
- Fixed: Icon and text was not visible with iconSlide setting if used with jQuery Mobile listview.
Themes
- Fixed: Incorrect border radius for active buttons in Android ICS theme (#195).
Listview
- Added: handle setting - allows sort if touch started on the handle.
Core
- Fixed: btn parameter was undefined in onClose if clear button was pressed (#181).
Angular JS Integration
- Fixed: Directive for select preset now works for dynamically generated options.
Listview
-
Fixed: Slide was not working in Android 4.0.x.
-
Fixed: Confirm tap incorrectly fired onItemTap as well.
Rangepicker
-
Fixed: Range picker incorrect bubble positioning with start and end inputs present (#183).
-
Fixed: setValue method was not working correctly (#189).
Themes
- Fixed: z-index issue with jqm theme (#187).
Timespan
- Fixed: minTime / maxTime worked incorrectly (#184).
Calendar
-
Added: Holding month and year buttons changes month/year until released.
-
Added: months setting to display multiple months.
Listview
-
Added: onStageChange event.
-
Added: onItemTap event.
-
Added: onSlideEnd event.
-
Added: slideIcon setting - icon and text can be positioned to move with the slided element.
-
Added: quickSwipe setting - on quick swipe (less than 300ms and 50px of movement) the first stage's action is executed.
-
Added: confirm option for stage actions.
-
Added: move method.
Rangepicker
- Added: rangeTap setting for faster range selection.
Select
- Added: showInput setting, if false hide the input
Themes
- Added: Plugin which decides the theme based on User Agent.
Core
- Fixed: Higher z-index to show over jQuery Mobile popups.
Calendar
- Fixed: Changing tabs sometimes messed up the month slider.
List
- Fixed: In live mode values were not always filled in the input.
Listview
-
Fixed: adding item didn't work correctly on empty list.
-
Fixed: don't remove list item inline styles on sort end.
Calendar
- Added: data-day attribute for calendar days to allow styling of weekdays (#173).
Listview
-
Added: scroll window if element is dragged out of viewport.
-
Added: Callback functions to add and remove methods.
Core
-
Fixed: setDefaults method now works.
-
Fixed: Positioning works now correctly with horizontal scroll.
Listview
- Fixed: Placeholder was not placed in some cases.
Measurements
- Fixed: Incorrect conversion with setValue method.
Rating
- Fixed: parseValue fixed.
Themes
- Fixed: WP theme calendar tab padding issues fixed.
Listview
-
Added: sort setting for reordering lists with onSortStart, onSortStop, onSort, onChange, onUpdate events.
-
Improved: add and remove animations.
Themes
- Added: Bootstrap integration.
Calendar
- Fixed: Use deep copy when setting events.
Timer
- Fixed: Button icons were of with WP theme.
Timespan
- Fixed: Labels were incorrectly shown with the iOS theme.
Listview
- Added: New listview component.
Core
- Changed: Attach event handlers with latency to improve compatibility with libraries like fastclick.js.
Calendar
-
Changed: Removed jqm specific behavior.
-
Changed: Divergent day change is disabled by default.
Rangepicker
- Changed: Remove jqm specific behavior.
Themes
- Changed: Calendar respects the swatch set by the jqmBody setting.
Core
- Fixed: Remove mobiscroll markup without timeout if no animation.
Calendar
-
Fixed: Tab key focus works is enabled on visible month only.
-
Fixed: Swipe was broken in Android stock browser after opening a native select or virtual keyboard.
Rangepicker
- Fixed: Date and time was incorrectly set on scrollers when invoked from start or end input.
Themes
- Fixed: Background fix for WP, iOS, iOS7 themes in clickpick/mixed mode.
Core
-
Added: 'context' setting (#143).
-
Added: generic buttons.
-
Added: 'minWidh', 'maxWidth' and 'fixedWidth' settings (#112).
-
Changed: default theme was updated.
Calendar
-
Added: start/end times for multi day events.
-
Added: when a day clicked from another month changes the month and show the event bubble.
-
Added: 'counter' option to show number of selected items in header (if in multi-select mode).
-
Added: live swipe ('liveSwipe' setting).
-
Added: 'showDivergentDays' setting to show/hide days from previous and next months.
-
Added: 'divergentDayChange' setting to enable/disable month change on divergent day selection.
-
Changed: week numbers are not sliding.
Datetime
- Added: invalid time ranges (#94, #147).
Rangepicker
- Added: 'counter' setting to show number of selected items in header.
Select
- Added: 'counter' setting to show number of selected items in header.
Core
-
Fixed: In bubble mode positioning sometimes ended up in endless scrolling.
-
Fixed: If another mobiscroll element was under the overlay, it opened on tap.
-
Fixed: No more blue highlight on wheel tap in Android 4.x.
-
Fixed: Context got lost in some cases (#163).
Select
- Fixed: hiding the original select is not good for validation (#161).
Treelist
- Fixed: animation was not working with setValue method.
Core
-
Added: Hide set and cancel buttons if their value is false (#134).
-
Added: closeOnOverlay setting.
-
Added: Live mode. If 'Set' button is not present, the value and input is updated on every change.
Timespan
- Added: minTime and maxTime settings.
Calendar
-
Changed: Improved performance on month change.
-
Changed: Refresh calls are postponed until the end of month change animation.
-
Added: closeOnSelect setting to hide the calendar when a day is selected.
Rangepicker
- Added: Show/hide on focus and tap is automatically bind to start and end inputs (if any).
Languages
-
Added: Swedish translation, thanks to Johan Jönsson (https://github.com/jonixj)
-
Added: European Portuguese translation, thanks to Jorge Simões (https://github.com/jorgefsimoes)
Themes
- Added: iOS7 theme.
Core
-
Fixed: Mobiscroll was shown again after close in IE with jQuery < 1.9.
-
Fixed: Destroy hides scroller without animation.
-
Fixed: Destroy is called on the element before init preventing re-initialization bugs.
-
Fixed: .mobiscroll('getInst') correctly returns the instance during initialization.
-
Fixed: Positioning fixes on resize/orientationchange/scroll.
-
Fixed: Was not working correctly with fastclick.js.
-
Fixed: Tap was not working in IE10 with touch events (#118).
-
Fixed: Clicking blank space selects last item (#159).
Calendar
-
Fixed: Incorrect width calculation when tabs set to 'auto'.
-
Fixed: Event list was not clipped in Firefox Mobile when scrolled.
Rating
- Fixed: If created from select, anchor was not correct for bubble positioning.
Core
-
Changed: Mobiscroll value is automatically updated on input change, this way setValue method is working properly (#79).
-
Added: Utility object exposing some useful variables, currently vendor prefix and 3d support (
$.mobiscroll.util.prefix and $ .mobiscroll.util.has3d). -
Added: onDestroy event.
Calendar
-
Changed: Invalid and marked settings have now a different format. Old format is still working but it is considered deprecated and will be removed in the next major release. See documentation for details.
-
Added: events setting to pass any number of events. Events are shown in a context bubble. See documentation for details.
Colorpicker
- Added: defaultValue setting to specify default color.
Daterange
- Added: This is new component for daterange selection.
Datetime
-
Changed: Invalid values have now a different format. Old format is still working but it is considered deprecated and will be removed in the next major release. See documentation for details.
-
Added: defaultValue setting to specify default date.
List
- Added: defaultValue setting.
Measurements
- Added: defaultValue setting.
Rating
- Added: defaultValue setting.
Themes
- Added: Support for jQuery Mobile 1.4.0-alpha1.
Timespan
- Added: defaultValue setting.
Core
- Fixed: Mixed mode was not working (#141).
Calendar
- Fixed: Calendar header buttons were not disabled on show, only after first month change.
Datetime
- Fixed: 'Now' button did not trigger the onChange event (#145).
Timer
- Fixed: On destroy timer interval wasn't stopped.
Timespan
- Fixed: setValue was not working, if value was out of wheel range.
Themes
- Fixed: Header was not hidden correctly in android-ics, android, jqm and sense-ui themes.
Core
-
Fixed: Tap was not removed from element on destroy.
-
Fixed: Mouse scroll wheel now works with Zepto and jqMobi.
-
Fixed: Whitespace after buttons in Firefox.
-
Fixed: After hide scroller was shown again in IE.
Calendar
- Fixed: Fixed swipe animation in Firefox / Android.
Animation
- Fixed: Flickers on Firefox.
Core
-
Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes (#48).
-
Added: Reposition scroller if scroll occurs (#106).
-
Added: showOnTap option.
-
Changed: Use on/off for attaching and detaching events instead of bind/unbind/delegate.
Select
- Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes for multiselect mode.
Calendar
-
Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes for calendar.
-
Changed: Improved month change animation.
Colorpicker
- Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes.
Rating
- Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes.
Timer
- Added: Accessibility features - keyboard shortcuts and WAI-ARIA attributes.
Core
-
Fixed: Mouse scroll wheel now works with Zepto and jqMobi.
-
Fixed: +/- buttons were shortly hidden during animation.
-
Fixed: Wheel was incorrectly labeled if empty string was passed.
Select
- Fixed: Group label was incorrect.
Rating
- Fixed: Layout was broken in Firefox / Android with stars + text.
Timer
- Fixed: WP theme top padding removed.
Languages
- Fixed: dateOrder and dateFormat corrected for Hungarian language.
Core
-
Changed: Refactored method calls resulting in smaller file size.
-
Changed: New wheel format using arrays instead of objects to maintain the order of items. Old wheel format is still supported, but deprecated. See documentation for details.
-
Changed: Cleaned up css.
-
Changed: position method is now public.
-
Changed: Remove setInterval which was running to get update the actual position of a moving wheel. Position is now dynamically calculated only when needed.
Calendar
-
Changed: Performance improved when calendar is updated when moving the wheels on the scroller.
-
Added: Month and year can be changed sepparately in the header.
-
Added: Month and year order in calendar header is now controlled by the 'dateOrder' setting (#122).
-
Added: Tabs for calendar, date, and time controls. Displaying tabs can be automatical (if there is not enough space for all the controls), always on, or always off.
-
Added: Custom color for marked sign and event background.
-
Added: Different styling for marked days (colored bottom line).
Languages
-
Added: Dutch translation (Thanks to Sven-Depondt - https://github.com/Sven-Depondt).
-
Added: Turkish translation (Thanks to Metin Gökhan Ünal).
-
Added: Japanese translation (Thanks to Johnny Shields - https://github.com/johnnyshields).
Core
-
Fixed: Firefox / IE display bug, wheel groups were shown under each other, even if there was enough space (#104).
-
Fixed: Form fields remained disabled in Firefox if page was reloaded before hiding mobiscroll (#126).
-
Fixed: Call stopPropagation on move event to make it work correctly with iScroll (or similar libraries) (#14).
-
Fixed: settings property is now correctly exposed (object reference is kept).
Calendar
-
Fixed: "dayOfWeek: [0]" was not working for marked days.
-
Fixed: Date passed to the onDayChange event was not always correct.
Select
- Fixed: In multiselect mode old checkmarks were not removed when setValue method was called (#129).
Temperature
- Fixed: "°K" changed to "K" on unit wheel (#124).
Animation
- Fixed: Added "-webkit-backface-visibility: hidden;" to some elements to prevent animation glitches in webkit.
jqMobi
- Fixed: css function returned NaN for margin in outerWidth function.
Core
- Changed: Transition is done by directly editing the property instead of the style attribute (#59).
Core
-
Fixed: wheel overlay was blinking during animation.
-
Fixed: wheel overlay sometimes did not cover the whole wheel (on Google Chrome and Android stock browser).
-
Fixed: showLabel setting now works for all themes.
Core
- Added: onPosition event.
Languages
- Added: zh-cn language pack.
Calendar
-
Changed: Month change on swipe is now improved and more fluid.
-
Added: Text can be added to marked days.
-
Added: weekCounter option to display week numbers ('year' or 'month').
-
Added: Liquid layout in inline mode.
-
Added: Fullscreen layout in modal mode.
-
Added: Custom width and height for calendar.
Core
-
Fixed: Firefox for Android wheel content overflow (#87).
-
Fixed: Remove html parameter from onBeforeShow event (#111).
-
Fixed: Position mobiscroll on orientation change as well (resize is not always fired on iOS).
Zepto JS
- Fixed: Window width and height calculations (exclude scrollbar).
jqMobi
- Fixed: Window width and height calculations (exclude scrollbar).
Measurement
- Fixed: setValue method can be called with animation.
Core
- Fixed: Could not scroll if scroller was bigger than viewport.
Core
-
Added: onAnimStart event.
-
Added: onMarkupInserted event.
Core
- Fixed: Javascript error on cancel with jqm theme (#99).
Animation
- Fixed: In clickpick/mixed mode values were visible above +/- buttons during animation.
Core
- Added: onValueTap event.
Select
- Added: Multiple selection functionality (#37).
Calendar
-
Added: Multiple day selection functionality.
-
Added: Week selection functionality.
-
Added: onMonthChange event.
Core
-
Fixed: Input value was not parsed if value was set after mobiscroll init (#88).
-
Fixed: Tap or click lock scroller in mixed mode (#89).
-
Fixed: Click on wheel arrows ddid not animate switch (#90).
Datetime
- Fixed: Month showed 0 - 11 on wheel using dateOrder 'mdyy' (#92).
Calendar
-
Fixed: During month change animation a day was incorrectly highlighted.
-
Fixed: Month change animation was laggy on iOS5.
Measurements
- Fixed: Fraction values are now correctly disabled for negative values as well.
Core
-
Changed: validation moved back to touchend instead of animation end.
-
Changed: setValue method now also accepts string or number, not array only (#79).
-
Added: tap option to fire button actions on tap instead of click. Default is true (#83).
Core
-
Fixed: tapping on buttons triggered form element focus underneath on Android.
-
Fixed: moving wheels were not stopped correctly on tap on Android > 4 (stock browser).
-
Fixed: initial value can be set now with setValue without filling the input (#77).
List Preset
- Fixed: Wheel remained locked in some cases (#84).
Core
- Changed: Set and cancel events are now fired on tap instead of click (on touchscreen).
Themes
- Added: Windows Phone theme now has an 'accent' option to set the highlight color of the theme. Possible values: 'lime', 'green', 'emerald', 'teal', 'cyan', 'cobalt', 'indigo', 'violet', 'pink', 'magenta', 'crimson', 'red', 'orange', 'amber', 'yellow', 'brown', 'olive', 'steel', 'mauve', 'sienna'.
Core
- Fixed: theme initialization moved before positioning, as it may affect the width/height of the popup.
List Preset
-
Fixed: Don't regenerate the list on every change, only if needed.
-
Fixed: setValue did not set the value correctly on hierarchical wheels.
Datetime Preset
- Fixed: AM/PM wheel respects timeWheels order as well (#54).
Calendar Preset
- Fixed: set option caused stack overflow (#74).
Core
- Added: isVisible method (#60)
Core
- Fixed: Multiple event firing (#45)
Plugins
- Fixed: jqMobi and Zepto error, if loaded multiple times (#72)
Core
- Move event is attached only on demand (#71)
Core
-
Positioning fixes
-
Validation bugfix
Themes
- Windows Phone theme: font-size fix in clickpick mode
Themes
-
Sense UI theme: border removed when positioned top or bottom
-
Android ICS theme: border removed when positioned top or bottom
Core
-
Positioning fixes
-
Firefox animation bug fixed by removing border-radius from the wheel
Datetime preset
- Expose datetime preset settings to the inst.settings property
Core
-
Changed: Use div-s instead of ul-s and li-s
-
Changed: Don't scroll the wheels if validate function returns false
-
Added: 'btn' parameter to the onClose event, 'set' or 'cancel' is passed depending on which button triggered the close
Measurement presets
-
Added: if step > 1, fraction wheel is not generated
-
Added: fraction wheel is infinite
Themes
- Added: 'jqmBorder' option to the jQueryMobile theme to change the swatch of the border
Core
- Fixed: Also disable button elements when showing modal popup
Rating preset
-
Fixed: parseValue returned incorrect value
-
Fixed: value was incorrectly set if elements were generated from a select element
Themes
- Fixed: onCancel event was not fired if scroller was hidden by clicking on the overlay (#58)
Core
- Added: time parameter to the changeWheel method, which means the animation time to scroll the new wheel to the selected value
Core
-
Fixed: missing ":" in core css (#46)
-
Fixed: Don't allow to move another wheel until touchend occurs on the currently scrolled wheel
Core
-
Changed: prevent collisions if core is loaded multiple times
-
Changed: validate and onChange event runs on scrolling animation end providing a more fluid user experience (#36)
-
Changed: user defined event handlers does not override preset event handlers
-
Added: onShow gets an additional valueText parameter
-
Added: onAnimStart event, which is fired at scrolling animation start, and receives the wheel index, animation time, and the mobiscroll instance as parameters
-
Added: shorthand form for presets: $('.selector').mobiscroll().date(). To add a shorthand for your own preset, just add the following line in your preset code: $.mobiscroll.presetShort('mypresetname')
-
Added: highlight selected entry on tap
Select preset
- Changed: make it work with late validation
List preset
- Changed: make it work with late validation
Themes
- Changed: prevent collisions if themes are loaded multiple times
Core
-
Fixed: don't do tap ahead, if moving wheel was stopped with a tap
-
Fixed: setValue method was not working correctly (#43)
-
Fixed: if close was canceled (onClose returned false), the value was still set
Datetime preset
- Fixed: closing tag for the short day name and short month name span was incorrectly added
Select preset
- Fixed: onChange, onSelect, onCancel events received the disabled value, if the user scrolled to a disabled option, event though on the UI was not selectable (#40)
Rating preset
- Fixed: stars were not aligned to middle in Firefox and IE
Core
-
Added: move the wheel to the selected value on tap
-
Added: selected values now have a 'dw-sel' css class
-
Added: support for Windows Phone 8
Datetime preset
- Added: month and day names are wrapped in <span class="dw-mon"> and <span class="dw-day"> to allow more styling
List preset
- Added: a new preset which transforms ul/ol html lists into a scroller
Animation plugin
- Added: Internet Explorer 10 support
Themes
- Added: Windows Phone theme
Core
-
Fixed: onClose received null as valueText parameter
-
Fixed: button flickering during animation on Chrome
-
Fixed: options were not correctly updated 'on the fly' (by using the 'option' method on an existing instance) - Issue 112 on Google Code
-
Fixed: wheel could not be stopped on the correct place if another wheel was scrolled before the animation finished
-
Fixed: +/- buttons didn't reappear in mixed mode, if a wheel was changed (e.g. with group select preset)
Datetime preset
- Fixed: If input had no value, default date/datetime was the time when the control was initialized, not when it was shown
Select preset
- Fixed: setValue did not set correctly the second wheel, if optgroup was not the original
Core
- Changed: changeWheel function can change more than one wheel at once
Select preset
- Added: 'rtl' (right to left) option, when set to true the groups wheel appears on the right
Core
-
Fixed: input change is triggered after the modal scroller is hidden (form controls are re-enabled)
-
Fixed: added a dw- prefix for animation css classes to prevent naming collision with other libraries
-
Fixed: the width calculation in positioning skips the width of hidden wheels
Datetime preset
- Fixed: Day names on wheels fixed (if long name contained 'D', both short and long names appeared)
Themes
- Fixed: android-ics skin arrows moves the wheel in correct direction
Core
-
Added: new display properties, which controls where the scroller is positioned: 'modal', 'bubble', 'top', 'bottom'
-
Added: 'anchor' property to specify the anchor element for positioning, if 'display' is set to 'bubble'
-
Added: 'animate' property to specify predefined animations in 'modal' and 'bubble' modes, during the show/hide of the scroller: 'fade', 'flip', 'pop', 'swing', 'slidevertical', 'slidehorizontal', 'slidedown', 'slideup'
-
Added: 'scrollLock' setting to disable page scrolling in modal/bubble/docked display modes. Default is 'true'
-
Added: 'changeWheel' public method, which takes the wheelindex as argument, and regenerates that wheel based on the wheel object
-
Changed:'readonly' setting now takes an array too, with the boolean values for each wheel
Select preset
- Added: 'group' and 'groupLabel' options to render two wheels based on optgroups
Datetime preset
- Added: 'showNow' and 'nowText' options, which renders an additional 'Now' button (if display is not inline)
Themes
- Changed: iOS theme is updated
Core
- Fixed: In 'mixed' mode, if wheel was scrolled and stopped with a tap, +/- buttons remained hidden
Core
- Added: Support for language files. Controlled from 'lang' option. Specify language related default settings and language files.
Core
-
Fixed: 'clickpick' mode worked the same way as 'mixed' in 2.0.2
-
Fixed: 'setValue' was not working correctly.
-
Fixed: Wheels were misaligned on Firefox with ios theme and datetime preset.
Datetime preset
-
Fixed: Time was incorrectly parsed when missing year, month or day wheel.
-
Fixed: Default year value was not set, if outside of startYear and endYear.
Core
-
Added: animation time is now passed to the validation event (useful, if you want an action to happen only when the wheel stops moving)
-
Added: wheel containers have now numbered classes: 'dwwl0', 'dwwl1', 'dwwl2' etc. to allow different styling for each wheel
Select preset
-
Added: 'invalid' option to set certain values unselectable. This option takes precedence over the disabled options in the original html select element.
-
Added: 'label' option to set the label of the wheel. If not present, the label is taken from the original html select element's label, and falls back to the select element's name attribute, if the label doesn't exist
Datetime preset
-
Fixed: 'shortYearCutoff' option was not working correctly. (With '+10' value if 2 digits years were used, 12 was converted to 1912 instead of 2012)
-
Fixed: if day was not present on the wheels (e.g. credit card expration), the date object defaulted to today's date, which resulted in incorrect value, if current month had more days as the selected month
-
Fixed: day names were incorrect, if initial validation changed the month from an invalid value to the nearest valid one
Select preset
- Fixed: 'setValue' and 'getValue' methods overwrote the core methods and were unusable for other presets or custom scrollers
Zepto js plugin
- Fixed: in 'mixed' mode clicking on the +/- buttons caused a short button blink
jQuery Mobile Theme
- Fixed: Button appearance with JQM 1.1.1
-
Fixed: HTML5 min/max attributes propagated to other scrollers
-
Fixed: jQuery Mobile 1.0 compatibility (Issue 95)
-
Fixed: Using values like "1.0", "2.0", etc. on custom wheels caused incorrect behavior because they were converted to numbers and became 1, 2, etc.
-
Fixed: fast scrolling caused value loss, if validation changed another wheel value with animation
-
Fixed: when element was created for 3d testing: document.createElement(mod) - mod was undefined
-
Fixed: setValue and getValue was not working correctly with the select preset
-
Fixed: timeWheels option did not modify the order of the wheels
-
Fixed: setValue / setDate methods did not animate the scroller if time was specified
-
Fixed: In some cases date validation scrolled the day wheel to empty value
-
Fixed: Datetime preset's setDate and getDate methods were using last created instance's resources
-
Fixed: Select options were reordered, if values were numbers
-
Fixed: When using option method to change options on the fly, preset and theme defaults overrode user settings
-
Fixed: In clickpick mode minus button had plus button behavior
-
Fixed: In inline mode getValue always returned the initial values
-
Fixed: min/max attributes were incorrectly parsed when using HTML5 time input
-
Added: invalid option for the datetime preset to set dates unselectable. There are three properties to specify dates, all can be used separate or combined. dates is be an array of dates to disable exact dates on the scroller. daysOfWeek is an array with values from 0 to 6, daysOfMonth is an array which accepts numbers (e.g. every month's 2nd day) or a string in 'x/y' format (e.g. 12/24 means every year's 24th December is disabled). A sample configuration: invalid: { dates: [new Date(2012,5,4), new Date(2012,5,13)], daysOfWeek: [0, 6], daysOfMonth: ['5/1', '12/24', '12/25'] }
-
Added: The select preset automatically disables elements on the scroller if they were disabled in the original html select element
-
Removed: ampm option is now removed, see the new timeWheels option instead
-
Removed: seconds option is now removed, see the new timeWheels option instead
-
Changed: preset option no longer defaults to 'date', it must be explicitly specified!
-
Changed: wheels option no defaults to empty array ([]) instead of null
-
Changed: valid scroller items now have the class "dw-v" instead of "valid"
-
Changed: in 2.0rc1 days not in month were styled as disabled, like items out of the min/max range. From now on days not in month now have the class "dw-h" which, by default has a hidden style in css.
-
Fixed: Inline mode bug with jQuery Mobile, if it was not on the initial page
-
Fixed: Select preset was not working in inline mode
-
Added: headerText can accept a function, which must return a string
-
Added: Day of week can be displayed on the scrollers. Use 'D' (short names) or 'DD' (long names) in the dateOrder options. Sample dateOrder value: 'mmD ddy' will produce '05', 'Thu 03', '2012' on the day, month and year wheels.
-
Added: separator option used by the datetime preset to specify the separator between date and time parts. Default is ' '.
-
Added: readonly option, if true, the scroller appears, but cannot be scrolled. Useful if you want to display a nice clock.
-
Added: timeWheels option to show, hide, and format the time related wheels on the scroller. Default is 'hhiiA'. For the hour wheel use 'h', 'hh', 'H', 'HH', for minutes wheel 'i' or 'ii', for seconds wheel 's' or 'ss', for am/pm wheel 'A' or 'a'. E.g. for 24 hour time format with seconds and leading zeroes use 'HHiiss'.
-
Added: support for HTML5 date/datetime/datetime-local/month/time input types. If mobiscroll is attached to such an input, the format is forced to follow standards specifications. In the popup header the value is formatted according to the date and timeformat specified by the user.
Mobiscroll has now a modular structure. The core contains the wheel generation and scrolling logic. The core can be extended by presets. Presets are basically a collection of predefined settings, which are passed to the core, but may contain other initialization logic, which is executed when the scroller instance is created.
Currently you can include the 'date', 'time', 'datetime' and 'select' presets.
Themes are now also modular, css styles are in separate files for each theme. Themes may have an optional javascript file, where default settings can be set, and an optional init function as well.
-
Removed: beforeShow event is now removed
-
Removed: showValue option is now removed, use the headerText option instead
-
Removed: btnClass option is now removed, button style can be changed by adding css rules to the .dwb class
-
Fixed: Android ICS Light skin fix (small +/- appeared above/under arrows)
-
Fixed: onSelect and onCancel events are now called after the popup is closed and all the form elements on the page are re-enabled, making possible to submit the form in these events.
-
Fixed: In custom events this refers to the original HTML DOM element instead of the settings object
-
Changed: The visibility of year, month and day wheels is now controlled by dateOrder option, e.g. use 'mmyy' to display month and year wheels only
-
Added: display option, which can be 'inline' or 'modal' (default)
-
Added: headerText option to specify a custom string which appears in the popup header. If the string contains '{value}' substring, it is replaced with the formatted value of the scroller. If headerText is set to false, the header is hidden.
-
Added: onShow event
-
Added: delay option to specify the speed in milliseconds to change values in clickpick mode with tap & hold, default is 300
-
Added: jQuery Mobile theme, set theme option to 'jqm'
-
Added: 'select' preset to enhance a regular HTML select. The original select is hidden, and a dummy input is visible instead. The value of the select is maintained by the preset
-
Added: minDate and maxDate options to specify a range which can be selected. Works for datetime as well.
-
Fixed: Tap & hold changes the value on a 300ms interval instead of 200ms (for slower devices)
-
Fixed: When using custom wheels, parseValue function defaults to first value on the wheel, if cannot parse the input value to a valid wheel value
-
Added: showLabel option - show/hide labels on the top of the wheels, default is true
-
Added: showValue option - show/hide formatted value in the header of the popup, default is true
-
Added: Android ICS ('android-ics') and Android ICS Light ('android-ics light') skins
-
Fixed: Mouse scroll wheel works now with jQuery 1.7+
-
Fixed: Don't always parse input value on show, only if changed
-
Fixed: Time was incorrectly parsed, if there was no date
-
Fixed: First selected value did not work correctly by default for custom scrollers
-
Fixed: Incorerect parsing of am/pm time for 12:xx AM
-
Added: animation on touchend/mouseup event
-
Added: full CSS3 support for Opera 11 and IE10
-
Fixed: Destroy didn't set correctly the original readonly state of the input element.
-
Fixed: Input element is not set to readonly if showOnFocus is false
-
Fixed: Disabled state of form inputs was not correctly reset after hiding the scroller.
-
Fixed: Don't show scroller if disabled and show is called programatically.
-
Added: if the onClose handler returns false, close is now prevented.
-
Added: onCancel event handler.
- From now we are using .prop to set readonly/disabled states. This means thet jQuery >= 1.6 is required.
- Fixed: setDate method incorrectly sets year, when seconds option is false
-
Added: mode option, with two possible values: 'scroller' and 'clickpick', where 'scroller' is the default behaviour, while 'clickpick' renders + and - buttons for each wheel (Android style).
-
Added: new and updated skins: Android, Sense UI, iOS. Set the theme option to 'android', 'sense-ui' and 'ios'
- Support for jQuery Mobile 1.0beta1 is now removed (click event was not working). Upgrade to beta2 to use the latest version of MobiScroll.
-
'Scroller' mode is still not working in Firefox Mobile and IE on WP7
-
When using 'Clickpick' mode, very fast taps causes page zoom on HTC Android.
- Fixed: Click bleedtrough and focus holding with JQM beta 1
- Fixed: Missing hour 0 on timepicker
- Added: Date format options for date wheels through the dateOrder option