A set of functional programming "inspired" helpers
This project is a set of small helpers which utilize mostly monad and monad like patterns to cut down on code for essential tasks.
For now, it is only a small set of Helpers consisting of following items:
- Monad ... an implementation of a Monad
- Optional ... a class which is derived from Javas optional but also encapsulates elvis operator like accessors to cut down on code
- ValueEmbedder ... if you ever need something like optional but want to write the value as well this might be what you are looking for
- Promise ... a promise shim implementation for older browsers (newer ones have Promised baked in), will be deprecated soon, there are better options
- CancellablePromise ... a promise with cancel functionality
- Configuration ... an Optional utilizing wrapper over json configurations which allow both read and write access and elvis like access to the data stored in the config
- Streams ... a typescript based implementation of early and lazily evaluating streams
- DomQuery ... a jquery like functional query and dom manipulation engine based on querySelectorAll, also support streams and shadow dom trees
- XmlQuery ... a jquery like XML document query selection and manipulation engine ... also supports streams
- Messaging ... a messaging bus which can break page isolation levels to allow communication between iframes/popups/shadow dom/dom
- RxJS ... RxJS bindings
Everything is implemented in typescript and can be used straight from the source directories "src/main/typescript".
However, also javascript transpilations for various packaging systems and ecmascript levels are in place as well hosted under "dist".
If you want a cleaner cut between your own typescript sources, and the mona-dish sources there is a d.ts file also, hosted under "dist".
For building the project you need following
- npm
- webpack
once this is done you can build it by calling ./init.sh one time to install all the needed build dependencies, after that calling /build.sh rebuilds the entire project.
You also can run mocha based unit tests on the project by calling ./test.sh
(note this is for unixoid systems, windows command files will be added soon, in the meanwhile simply check the command sequences in the sh files for building and testing)
The enhanced documentation for optional can be found here:
For a non sideffect free implementation, you can use:
Optional is a purely readonly construct, now for sideffect free-ness, having only readonly operations is fine. However, in iterative systems we often deal with states. To get the conciseness of Optional also for writeable states there is a class available which is inherited from optional and hence shares the same functionality.
-
ValueEmbedder
Promise is just a lightweight shim of the Promise API including finally. Cancellable promise adds on top of that by allowing to cancel (aka never hit the then/cancel phase)
The idea is to have streams like java does for arrays. (forEach, filter etc...)
The streams are heavily influenced by the java streams. Currently, two type of streams are implemented
- Early streams (Streams)
The default (working already) a simple implementation of early evaluating streams
- Lazy Streams (LazyStreams) Lazily evaluating streams, aka elements are processed at the latest possible stage, this is the default in Java. The advantage of those is you basically can process endless data without any impact on ram. Hence there is a set of Data Providers implemented and a general DataProvider interface available.
beforeEach(function () {
this.probe = [1, 2, 3, 4, 5];
});
it("must have a correct first last lazy", function () {
let stream = LazyStream.of<number>(...this.probe);
let first = LazyStream.of<number>(...this.probe).filter((data) => data != 5).onElem((data) => {
data;
}).first().value;
let last = Stream.of<number>(...this.probe).filter((data) => data != 5).onElem((data) => {
data;
}).last().value;
expect(first).to.eq(1);
expect(last).to.eq(4);
});
Or in conjunction with DomQuery
let searchRoot = DomQuery.querySelectorAll("input[type='hidden']")
let formWindowId: Optional<string> = searchRoot
.stream
.map<string>(getValue)
.reduce(doubleCheck, INIT);
let otherStream = LazyStream.ofDataSource(searchRoot);
See StreamTest.spec.ts in the "test sources" directory for additional examples
A JQuery like interface for standard dom queries, also supports Streams and Shadow doms. Further Info can be found here
DomQuery ... a jquery like functional query and dom manipulation engine based on querySelectorAll, also support streams and shadow dom trees
similar to DomQuery but atm without a full query engine behind it, the reason for that is, that the browsers do not have a universal query engine, yet. Also, I tried to avoid third party dependencies. You, also, will get many other benefits similar to DomQuery by using XmlQuery
A messaging bus ... for documentation follow this link:
I am going to provide extended documentation on the various aspects of mona-dish in following subpages
Various usage examples can be found in the tests:
(Starting with version 0.18)
...
Adding Extended Array, to provide shim like functionality without shims (adds several functions to the standard array older browsers do not support, but does not hook itself in like a shim)
- New messaging submodule
- Improved documentation
- DomQuery: Shadow Dom support
- ongoing works in the messaging area (not fully finalized)
- minor api change, channel now parameter in broker.broadcast instead of part of the message.
- setting the code baseline of the compiled code to es5
- Messaging will be finalized in version 0.20.x
- Minor compiler issues fixed in the "typings" area which could cause typescript warnings
- Bidirectional messaging which allows answer/response patterns
- Re-enabling IE11 compatibility
- basing the messaging on top of the broadcast channel as universal base, the messaging is basically a broadcast channel++ with additional functionality
-
Rxjs connectivity, rxjs is a more popular framework than mona-dish but both have a heavy functional overlap. It makes sense to open mona-dish for rjxs in both directions to be able to combine both frameworks easily
-
RXJS forward connectivity enabled via iterable implementation! you can basically now use streams as iterables
-
20.3 Adding basic rxjs support for streams
-
20.4-20.5 Adding rxjs connectivity apis for the messages, brokerchannels now can be exported as Subjects
-
0.20.7 Adding encryption extension points to the messaging api
-
0.20.8 extension refinements tests for the extensions documentation updates
- 0.21.0 adding a mutation observer
- Api change, the Promise has been removed from the index.js and resides in its own PromiseShim.js file. The reason was UMD builds did not check for an existing Promise before installing it. It made sense to decouple it anyway, literally all modern browsers do not need it anymore. CancellablePromise is still enabled.
- Added convenience methods for easier access to value (via val) and innerHTML,
- mutation observer fixes
- improved nonce handling
- improved rxjs connectivity
- documentation updates
- changing default package type from commonjs to umd, to improve ide handling
- adding a sticky eval to DomQuery to keep the evaled elements in the head
- adding a sticky eval handling to run scripts as well
- (minor version change due to an api change which has been reverted)
- fixing the script loading, loading order now in a series of scripts is in sync with mixed src and embedded scripts (no api change)
- Optional typed and semi typed configs which allow fixed keys and subtrees of keys which are not predefined