mirror of
https://github.com/Jermolene/TiddlyWiki5
synced 2025-02-22 22:10:03 +00:00
fixed issue #241 - created first, last, rest and reverse filter functions
This commit is contained in:
parent
d0cd72ed85
commit
b652238650
79
core/modules/filters/listops.js
Normal file
79
core/modules/filters/listops.js
Normal file
@ -0,0 +1,79 @@
|
||||
/*\
|
||||
title: $:/core/modules/filters/listops.js
|
||||
type: application/javascript
|
||||
module-type: filteroperator
|
||||
|
||||
Filter operator for manipulating lists
|
||||
|
||||
\*/
|
||||
(function(){
|
||||
|
||||
/*jslint node: true, browser: true */
|
||||
/*global $tw: false */
|
||||
"use strict";
|
||||
|
||||
/*
|
||||
Export our filter function
|
||||
*/
|
||||
exports.reverse = function(source,operator,options) {
|
||||
var results = [];
|
||||
// Iterate through the source tiddlers
|
||||
if($tw.utils.isArray(source)) {
|
||||
$tw.utils.each(source,function(title) {
|
||||
results.unshift(title);
|
||||
});
|
||||
} else {
|
||||
$tw.utils.each(source,function(element,title) {
|
||||
results.unshift(title);
|
||||
});
|
||||
}
|
||||
return results;
|
||||
};
|
||||
|
||||
exports.first = function(source,operator,options) {
|
||||
var results = [];
|
||||
var count = operator.operand || 1;
|
||||
// Iterate through the source tiddlers
|
||||
if($tw.utils.isArray(source)) {
|
||||
results = source.slice(0, Math.min(count, source.length));
|
||||
} else {
|
||||
for(var title in source) {
|
||||
if(count-- < 1) break;
|
||||
results.push(title);
|
||||
};
|
||||
}
|
||||
return results;
|
||||
};
|
||||
|
||||
exports.last = function(source,operator,options) {
|
||||
var results = [];
|
||||
var count = operator.operand || 1;
|
||||
// Iterate through the source tiddlers
|
||||
if($tw.utils.isArray(source)) {
|
||||
results = source.slice(-count);
|
||||
} else {
|
||||
for(var title in source) {
|
||||
results.push(title);
|
||||
};
|
||||
results = results.slice(-count);
|
||||
}
|
||||
return results;
|
||||
};
|
||||
|
||||
exports.rest = function(source,operator,options) {
|
||||
var results = [];
|
||||
var count = operator.operand || 1;
|
||||
// Iterate through the source tiddlers
|
||||
if($tw.utils.isArray(source)) {
|
||||
results = source.slice(count);
|
||||
} else {
|
||||
for(var title in source) {
|
||||
if(--count < 0) {
|
||||
results.push(title);
|
||||
}
|
||||
};
|
||||
}
|
||||
return results;
|
||||
};
|
||||
|
||||
})();
|
@ -57,6 +57,10 @@ A filter string consists of one or more runs of filter operators that each look
|
||||
* ''sameday'': selects all the tiddlers falling into the same day as the provided date in the specified date field
|
||||
* ''fields'': returns the names of the fields present on the selected tiddlers
|
||||
* ''search'': returns all tiddlers that contain the specified text
|
||||
* ''reverse'': reverses the list
|
||||
* ''first'': selects the first tiddler of the list (or the first n if the operand is n)
|
||||
* ''last'': selects the last tiddler of the list (or the last n if the operand is n)
|
||||
* ''rest'': selects all but the first tiddler of the list (or all but the first n if the operand is n)
|
||||
|
||||
An operator can be negated with by preceding it with `!`, for example `[!tag[Tommy]]` selects the tiddlers that are not tagged with `Tommy`.
|
||||
|
||||
|
Loading…
x
Reference in New Issue
Block a user