Mootilities 1.1.0

This repository contains a few experimental and dead simple implementations of commonly required functionality. Use all of them at your own risk and only use them if you know what you are doing.

Note that parts of this repository may change without notice. Expect API changes, extensions and removals frequently. If you are updating, make sure everything works. Of course you have 100 % code coverage of all of your projects, so this will be super easy!

This Plugin is part of MooTools PowerTools!.


Christoph Pojer
Current version
GitHub Issues



  • _self_/_current_:
    • Core/Object
    • Core/Class.Extras
    • Core/Element.Event
    • Core/Cookie
    • Core/JSON
    • Class-Extras/Class.Binds

How to use

See the Documentation below or check out the specification to see how the modules work.


Build via Packager, requires MooTools Core to be registered to Packager already

packager register /path/to/mootilities
packager build Mootilities/* > mootilities.js

To build this plugin without external dependencies use

packager build Mootilities/* +use-only Mootilities > mootilities.js


Allows you to abstract getters/setters with high-level lookup/define sugar.

```javascript var Candy = new Class(…); var CandyStore = new Accessor('item');

CandyStore.defineItem('jello', new Candy); CandyStore.defineItems({ skittles: new Candy, snickers: new Candy });

CandyStore.lookupItem('jello') // returns the previously defined item CandyStore.lookupItems('skittles', 'jello') // returns a list of previously defined items

// Execute a method on all defined CandyStore.eachItem(function(candy){; }); ```

Note: This is a 1:1 backport of a central feature of MooTools 2.0. Be aware that this will be provided in MooTools 2.0 and will be removed from here eventually. Do not hold me or MooTools responsible if you use this plugin now and if there will be API changes to the official version in MooTools.


This is a dead-simple Notification system. It is not really more than what "Events" in MooTools Core does. Expect this component to become super awesome at some point in the future. Stay tuned!

```javascript // Anywhere in your app Stratcom.listen('page:show', function(){ // do something when the page is shown // Will be called when some component notifies 'page:show' on Stratcom. });

// In ApplicationController.js Stratcom.notify('page:show', [uri]); ```


This is a very simple queue implementation. javascript var queue = new Queue; queue.chain(function(){ // Do some animation or something (function() {; }).delay(1000); }).chain(function(){ doSomething();; }).call();


If you get tired of writing attach/detach methods in your Classes - this is for you! Note that this utility is likely only useful if your classes are written to manage only one Element.

```javascript var MenuItem = new Class({

Implements: Listener

initialize: function(element){
    // Set the main element for this class to this.element
    // Without this, Listener will not work
    this.element = element;

    // Attach any amount of listeners
        mouseenter: this.mouseenter.bind(this)

click: function(){
    // If you click this element, all listeners will be detached.

}); ```

You can detach specific listeners (same arguments as attach), all the listeners (no arguments), one specific listener (type, fn as arguments) or all listeners of one type (type as argument).

This helper also automatically adds a toElement method to your classes. You can do to get the element associated with it. With that you are able to pass the instance into any method that expects an Element.


This is a very simple storage wrapper for MooTools. It uses localStorage if available and falls back to Cookie storage. Only use this if you know what you are doing - storing data in Cookies is bad.

```javascript LocalStorage.set(key, value);


LocalStorage.erase(key); ```

All these methods work with multiple arguments as expected in MooTools.

If you want to use this seriously in IE feel free to modify it to support storage in Behaviors or similar. Send me a pull request :)


A note on comments here: These comments are moderated. No comments will show up until they are approved. Comments that are not productive (i.e. inflammatory, rude, etc) will not be approved.

Found a bug in this plugin? Please report it this repository's Github Issues.

blog comments powered by Disqus