Added isFetching property to enyo.Collection, for common use case of showing loader spnner via binding.
Add sizing property to enyo.Image, which renders image as
position
property for use with sizing property,
for setting background-position
Updated lessc.js and minify.js to use relative URL's when compiling less files, to be compatible with the
bootplate Theme.less
scheme for importing and then overriding library variables in application less file.S
enyo.asyncMethod() now accepts an anonymous function as a single parameter. Previous asnyncMethod signature remains supported as well.
enyo.Collection.destroyAll() now accepts a boolean parameter to signify it will call the record's destroyLocal() method as opposed to the default of destroy().
Added enyo.Collection.destroyAllLocal() as a convenience method.
Added enyo.Collection.fetchAndDestroyLocal() method to do the same as fetchAndDestroy() except it will call destroyLocal() on the records instead of destroy(). This also means you could call fetch() with the options property destroyLocal set to true to have the same effect.
Added support for the Page Visibility API by normalizing visibilitychange events, the document.hidden and the document.visibilityState properties. Uses fallbacks to support older browsers.
A new method, enyo.dom.getAbsoluteBounds
, has been added. This method is more sophisticated than
previous methods for getting a node's absolute bounds, taking into account translateX, translateY
and matrix3d transforms. The existing enyo.Control.getAbsoluteBounds
API remains unchanged, but its
implementation has been changed to utilize the new enyo.dom.getAbsoluteBounds
method.
Added configureHoldPulse method to "down" event for configuring subsequent "holdpulse" events. Pass in a hash of options that can include "delay" (ms delay between "holdpulse" events), "moveTolerance" (threshold for determining cursor has left original location), "endHold" (values include "onMove" and "onLeave", determines whether "holdpulse" should be cancelled when cursor leaves tolerant target area or the control itself, respectively), and "resume" (whether or not "holdpulse" should resume when re-entering either the control ["onLeave" endHold value] or the thresholded original coordinates ["onMove" endHold value]).
Add enyo.toUpperCase() and enyo.toLowerCase() methods. Use these to replace calls to String.toUpperCase() and String.toLowerCase() in code that needs to be locale-aware.
From this release forward, the display
style attribute will no longer be synced back to the
showing
property after Control creation to avoid inconsistent state situations when getShowing
is called in a showingChanged
handler before the showing
and display
values are synced.
Changing showing
will update the display
style, but changes to the style will not be reflected
in the showing property.
Added fixedChildSize public property to enyo.DataList to allow the list to optimize performance when list items will have fixed dimensions. Whenever items in the list will be uniform this option should be utilized.
Added defaultValue value support for computed properties. Simply provide a configuration object with a key
defaultValue and any value, even undefined
.
Added enyo.Control.absoluteShowing read-only boolean property that may be observed to indicate whether
the control is actually visible. Setting the showing property to false
for any control will flip this
properties value to false
for all children. This property can then be reliably used to separate logic that
should only occur when a control is visible.
Added enyo.perfNow(), a high-precision, high performance monotonic timestamp, which is independent of changes
to the system clock and safer for use in animation, etc. Falls back to enyo.now() (based on the JS Date
object) on platforms where window.performance.now()
is not available.
enyo.Control.getAbsoluteShowing() now accepts an optional boolean parameter that, if true
, will
skip the getBounds() call internally and rely solely on the return value of the getShowing()
public API.
enyo.Scroller has been updated such that it will only propagate resize events to children when its'
showing property is true
.
enyo.dispatcher.capture API no longer bubbles all captured events through the normal event chain, but
rather notifies the captureTarget when specific events occur through a map of callbacks passed as a parameter
to the capture
API. This is a breaking change to the enyo.dispatcher.capture API, however it is a very
unpublicized (and fairly difficult-to-use) feature that was only used in enyo.Popup among Enyo-team developed
controls, so we assume it will have low impact on the general public.
Needed to revert the change to enyo.Binding from 2.3.0-pre.11. Re-implemented the stop() method
for interrupting transform propagation (as was still indicated by the API docs) and note that bindings
will again propagate undefined
values to ensure bindings clear when expected.
enyo.Binding has a new property allowUndefined
that defaults to true
allowing the undefined
object
to be propagated. Setting this to false
will keep it from propagating undefined
without the use of
a transform or an overloaded binding kind.
enyo.Collection's filter() method may be called without any parameters to easily apply whatever the activeFilter may be set to, if anything. It will return an immutable array of either the filtered content or if no activeFilter was present the entire dataset. This is a convenience extension of the original behavior and does not modify the existing behavior as it could not be called without parameters previously and would throw an error.
enyo.DataList's getChildForIndex() and now childForIndex() (same method, different name) now correctly
return undefined
consistently rather than false
. This correction is consistent with previous documentation
and base kind method (inheriting API from enyo.DataRepeater).
enyo.DataList no longer has the controlsPerPage property but instead has a pageSizeMultiplier value as it now dynamically determines the number of controls for a given page.
Enyo now supports the W3C pointer events recommendation and will use those in preference to mouse events when available. The earlier MSPointer event support is now only enabled when W3C pointer events aren't detected, fixing a touch-recognition problem in Internet Explorer 11.
enyo.Model.set() now supports the force parameter.
Removed unusable feature dirty
from enyo.Binding as implementing it would
cause unnecessary overhead and it ultimately a useless feature since they are
synchronously executed.
Removed the modelChanged() and deprecated controllerChanged() base methods from enyo.UiComponent
thus any developer code currently calling this.inherited(arguments)
from within an overloaded
modelChanged() method will fail and needs to be removed. This is a feature change required by ENYO-3339.
Removed the stop() method from enyo.Binding as required by ENYO-3338. Instead of
calling that method via the binding reference in a transform return undefined
(or nothing since undefined
is the default) to achieve the same behavior.
Instances of enyo.Binding will no longer propagate undefined
; instead use null
.
Deprecated the controllers
array for enyo.Application; instead use components
with the same features. This should modify bindings from .app.controllers.{name}
to
.app.$.{name}
for controllers/components created for an enyo.Application instance.
Deprecated the controller
property for enyo.DataRepeater and all sub-kinds; instead use
collection
. This also means you should update any overloaded controllerChanged
methods
to instead be collectionChanged
and bindings referencing controller
to collection
.
The registered event system previously employed by enyo.Model and enyo.Collection has been reworked and is no longer dependent on enyo.Store. See enyo.RegisteredEventSupport for more information. This change means the API methods previously available via enyo.Store (including the observer support implementation) no longer exist.
enyo.Collection is now a sub-kind of enyo.Component and thus employs the default enyo.ObserverSupport mechanims (as well as enyo.ComputedSupport).
enyo.Model now employs the default enyo.ObserverSupport and enyo.BindingSupport with
the same limitation of only working with attributes
of the record.
As required by ENYO-3339, enyo.Binding now registers for an entire path and will update based on changes anywhere in the path.
enyo.Store now throws an error instead of a warning when a duplicate primaryKey
is
found for unique records in the same enyo.Store.
enyo.Scroller and enyo.ScrollStrategy have been updated to normalize new properties available on the returned hash of getScrollBounds(). It now will indicate via the xDir and yDir properties a 1 (positive movement along the axis), -1 (negative movement along the axis) or 0 (no movement on the axis).
enyo.Store built-in methods: didFetch(), didCommit(), didFail() have new method signatures in the form rec, opts, res from an enyo.Source. An enyo.XHRSource adds a fourth parameter that is the XHR object reference.
enyo.DataRepeater has a new property selectionEvents to allow for mapping other events to the selection process previously tied only to ontap.
Removed macro support from bindings
Changed bindingDefaults to only apply to the bindings defined in the description in which it lives
Changed computed and observers to use space delimited string of dependent properties instead of array (array still supported, but deprecated)
Computed properties now send previous and current values to their observers.
enyo.ViewController.resetView removed, replaced with resetView property that controls if the view is automatically recreated when destroyed.
Removed internal "concat" property, replaced by concat static method on kinds. Should have no application impact unless code was extending the framework in very deep ways.
Fixed missing "release" event for end of hold gesture, bug introduced in 2.3.0.pre.8
Fixed regression with this.inherited's handling of replacement argumments.
enyo.trim() updated to use native String.prototype.trim() when available.
Change to enyo.Model parse
method handling, before it was confusing to
developers because it was only executed under specific circumstances (there
were reasons for this) but now it will be executed on all fetched data and all
data passed to the constructor (when call new enyo.Model
and passing
attributes, or when it is created using enyo.store.createRecord
or an
enyo.Collection instantiates it). This does require that the method checks
to see what data is being passed in if it was relying on this method to
reformat fields or meta-properties from remote data but also creates local
records that already have the correct data format.
Change to enyo.Model merge
strategy that now accepts instanced record(s) or
data hash(es), can merge without forcing the record to be instanced, and to
remain inline with the parse
method change will parse any data being merged
if it is a data hash (not if it is an instanced record). This method no longer
accepts the optional second parameter.
Change to enyo.Model add
method that no longer accepts optional third
parameter and will automatically call the model's parse
method if it is a
data-hash (not an instanced record).
Added framework method enyo.getPosition
that returns an immutable object with
the most recent clientX, clientY, pageX, pageY and screenX, screenY values.
As noted in the documentation, IE8 and Opera both report inconsistent values for
screenX, screenY and we facade the pageX, pageY values for IE8 since they are
unsupported.
The enyo.Application controllers
property has been deprecated. While current
code using it should continue to execute properly it is recommended you update your
applications to use the components
array instead and bindings from .app.controller.name
should instead be .app.$.name
. References of the controllers
property on instances
of enyo.Application are actually using the $
property by alias. THIS FUNCTIONALITY
WILL BE REMOVED IN THE NEXT MAJOR RELEASE AFTER 2.3.0.
The defaultKind
of enyo.Application has been set to enyo.Controller.
The enyo.Collection kind is now a subkind of enyo.Component which means it now inherits from the enyo.ObserverSupport mixin as opposed to the special observer support in enyo.Model.
The global
property has now been moved to a property of the enyo.Controller kind
and controllers whose global
flag is set to true
will not be destroyed even if
their owner
is an enyo.Application that is being destroyed.
You can no longer retrieve an index from enyo.Collection use the get
method.