From 2badf46e4b1e1a88156f8612ec78953573186e54 Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Wed, 21 Aug 2019 08:32:57 -0400 Subject: [PATCH 1/2] feat: operators --- src/index.js | 14 +++----------- src/operators.js | 44 ++++++++++++++++++++++++++++++++++++++++++++ webpack.common.js | 2 +- 3 files changed, 48 insertions(+), 12 deletions(-) create mode 100644 src/operators.js diff --git a/src/index.js b/src/index.js index 1cac4a8..5deec59 100644 --- a/src/index.js +++ b/src/index.js @@ -1,12 +1,4 @@ -const EventSyncer = require('./eventSyncer.js') +const EventSyncer = require('./eventSyncer.js'); +EventSyncer.operators = require('./operators'); -const eventSyncer = new EventSyncer(web3); - -eventSyncer.init(() => {}); - - // eventSyncer.trackEvent('contractEvent', ((x) => x.from === "0x123")).pipe(map(x => x.rating), myscan, mymap).subscribe((v) => { - // console.dir("current average is " + v) - // }) - - -// return Event +module.exports = EventSyncer; diff --git a/src/operators.js b/src/operators.js new file mode 100644 index 0000000..eacd559 --- /dev/null +++ b/src/operators.js @@ -0,0 +1,44 @@ +const { of, pipe } = require('rxjs'); +const { map, pluck, reduce } = require('rxjs/operators'); + +function $takeProps() { + const args = Object.values(arguments); + return pipe( + map(v => { + const r = {}; + args.forEach(a => { + r[a] = v[a]; + }); + return r; + }), + ); +} + +/* +// ex 1 +of({a: 1, b:2, e: 1}, {a: 0, c: 1, b:3}, {a: 0, d: 1, b:1}) + .pipe($takeProps("a", "b", "e")) + .subscribe((v) => console.log(v)); +*/ + +function $average() { + return pipe( + reduce((accum, curr) => ({ + sum: accum.sum + curr, + count: accum.count + 1 + }), { sum: 0, count: 0 }), + map(o => o.sum / o.count) + ); +} + +/* +of(10, 3, 4) + .pipe($average()) + .subscribe((v) => console.log(v)); +*/ + + +module.exports = { + $takeProps, + $average +}; \ No newline at end of file diff --git a/webpack.common.js b/webpack.common.js index 0b5f294..74f743a 100644 --- a/webpack.common.js +++ b/webpack.common.js @@ -2,7 +2,7 @@ const path = require('path'); const webConfig = { target: 'web', - entry: path.join(__dirname, "src/eventSyncer.js"), + entry: path.join(__dirname, "src/index.js"), output: { path: path.resolve(__dirname, "dist"), filename: 'browser.js', From 4a553e3cbb1396716127395dc720723d2762485c Mon Sep 17 00:00:00 2001 From: Richard Ramos Date: Wed, 21 Aug 2019 08:44:07 -0400 Subject: [PATCH 2/2] improve average operator --- src/operators.js | 29 ++++++++++++++++++++--------- 1 file changed, 20 insertions(+), 9 deletions(-) diff --git a/src/operators.js b/src/operators.js index eacd559..d60be61 100644 --- a/src/operators.js +++ b/src/operators.js @@ -21,15 +21,26 @@ of({a: 1, b:2, e: 1}, {a: 0, c: 1, b:3}, {a: 0, d: 1, b:1}) .subscribe((v) => console.log(v)); */ -function $average() { - return pipe( - reduce((accum, curr) => ({ - sum: accum.sum + curr, - count: accum.count + 1 - }), { sum: 0, count: 0 }), - map(o => o.sum / o.count) - ); -} +function $average(cb) { + return pipe( + reduce((accum, curr) => { + let currentValue; + if (typeof cb === 'string' || cb instanceof String){ + currentValue = curr[cb]; + } else if(typeof cb === "function") { + currentValue = cb(curr); + } else { + currentValue = curr; + } + + return { + sum: accum.sum + currentValue, + count: accum.count + 1 + } + }, { sum: 0, count: 0 }), + map(o => o.sum / o.count) + ); + } /* of(10, 3, 4)