- Revert 'at' filter ignores following filters if it gets a nullish value because it breaks at|to, whereas to|at is not possible.
- Document the fact that to must be used at least after at
- rebase ||.test||as:something was not working correctly
- 'at' filter ignores following filters if it gets a nullish value
to:target
is extended with parameter:range
.- Ranges in
at
filter support extended syntax. place
no longer exports undocumentedcheckSibling
.assign
now returns undefined if some path returns undefined- deprecate canonical filters and print a warning
- Move to node:test module.
- as:flag returns emoji from country code
- range selector to select topmost parent element
- range can select all after/before siblings
Fix documention of range for prune, fail.
- enc/dev filters: add path format. Improve hex format.
- as:null, as:none now call the value toString() method, if any, before comparison.
In particular,
as:query|as:null
returns null for query.
- document behavior for DOMTokensList and boolean attributes, and booleans
- drop the DomPlugin format
batt
becausealt:
does the same. - add the core format
list
to cover the attributes list case. - path:path allows one to merge ctx.expr.path array
- as:batt for merging value as boolean attribute. Needed when the actual attribute is not known to be a boolean attribute.
- Detect known boolean attributes that have a different camelCased property
- Move
at
,fail
,prune
,to
to in core. - Refactor attributes merging. Fix some edge cases.
- json: assignment on parent using
at:*
or parent replacement usingat:**
when merging an object (as key or as value, both works).
- two new filters for pattern matching: test and match
- fix: allow dom fragments to be merged into a DOM attribute (as text content)
- pick: accepts a list of paths, assigns last key
- get: removes optional symbols in path argument - after.get hook must rely on ctx.expr.optional anyway.
- json plugin: fix repeat of key:value
- pick: copy keys to a new object - no mutation (BREAKING)
- only: old pick behavior with mutation
- flat:depth filter added to array plugin
- fix how an empty parameter is transformed to null or to a default value (without changing the API). Allows
num?Infinity
to work. - remove optional
path?
in all filters: if null, a path is an empty array anyway.
- ctx.expr.optional is set by
get
filter whenever it has an optional chaining expression.
- json object model: add support for closest, allowing ranges to be defined by key name.
-
as:clone returns a non-recursive shallow clone of the value.
-
omit no longer accepts paths. Use
set
for that.
Breaks untested query type:
- as:query now stringifies with a ? prefix when not empty. it also parses the string.
Breaking changes:
- merge() template can no longer be an array.
- as:json stringifies, as:obj parses
- the old TextPlugin is renamed the StringPlugin.
- the DomPlugin is required to merge DOM Nodes (and parse xhtml strings) and it supersedes the TextPlugin.
- the TextPlugin is required to merge plain text files when the DomPlugin is not loaded
- the JsonPlugin is required to merge plain objects and parse json from string.
New: JSON handling is done with an object model: in particular, repeat
is supported.
Filter select
now accepts multiple pairs of [dest, src] paths.
It still considers a single path to get data from current value.
Filter assign now accepts multiple pairs of [dest, src] paths.
It still considers a single path to get data from current value.
Shallow copy hooks parameters to prevent possibility for hooks to mutate them.
set:-key has now the same semantics as set:+key, it is used to remove a value from a list.
To delete a value at a given path, use the new omit:path*
filter.
is:null, is:none did not actually test if value was null or undefined.
as:array did not convert to array.
Add instance.copy()
method.
Breaking changes: Hooks
- beforeAll, afterAll no longer get a third parameter (ctx.expr.filters is the same)
- before/after hooks is a map by filterName, hence only one hook by filter can be registered. The signature changed to (ctx, val, [param1, ...]). These hooks are not skipped by internal calls.
- return values can be undefined, that means the current value is not modified
- to cancel a merge use ctx.expr.cancel instead.
Fix assign filter.
Lots of breaking changes in that version. Trying to fix how filters and types play together.
- empty get: rebases to current value
- repeat, at, to, fail, prune are in their own RepeatPlugin
- if:filter:params* returns value if filter returns true, else returns null
- comparison operators now only return boolean values Use them with if: filter to recover previous behavior (e.g. if:eq:str)
- find:val is a shorthand for find::eq:val
- has: filter now returns the value, not the parameter.
It is available in ArrayPlugin. Previous behavior can be obtained using
[arr|find:str]
- optional arguments, when null, are no longer cast to their type, null is passed
- num, int types default to 0 when not a number. It exchanges previous behavior with null values: 'as:int' gives 0, 'as:int?' gives null.
- pick: supports .keys() / .delete() methods
- UrlPlugin:
- url type converts to url
- query type converts plain object to URLSearchParams
- url has a shorter
.query
accessor that returns searchParams - no longer tries to merge source and destination
- support for assigning an object to a query is added to assign/set filters.
- switch filter: let empty param match null value
- boolean attributes: only honor specific behavior when value is boolean this allows one to not lose expressions in those attributes.
- object type is added to core types
- pick filter is added to core filters
- is: filter wasn't correctly checking input value type
- support non-mergeable input instead of failing
- find: filter like filter: but stops to find one item in the array.
- assign:path filter makes current value available under specified path without changing the original ctx.data.
- fix has: and in: filters, there were somewhat broken - add tests for them
- new date:full option
- drop useless alias filter
- quot:num filter for getting a quotient
- repeat:path was treating path as a string. It now uses the first component of the path to get an alias, and the remaining path to get the aliased value from the repeated item.
- core: set:mutation* filter
- xml, html formats are provided by DomPlugin
- DomPlugin:
queryAll
is renamed toall
,query
is renamed toone
- UrlPlugin: url type, url and query filters
- date: add weekday, days, weeks (non-trivial) formats