'use strict'; /* Load the UI module. */ Ox.load('UI', function() { /* Create our own namespace. */ Ox.My = {}; /* First, lets build the most basic Box widget. A widget is a "constructor" function that takes two (optional) arguments, `options` and `self`, and returns a widget object. It's not a constructor in JavaScript terms though: It doesn't have to be called with `new`, and doesn't return an instance of anything. It just enhances another widget object and returns it. */ Ox.My.Box = function(options, self) { /* This is how every widget "constructor" begins. `self` is the widget's shared private object. It is private since it can only be accessed inside the widget, but shared because it can be passed to a widget upon its creation. */ self = self || {}; /* `that` is the widget itself, its public object, or, in JavaScript terms, its `this`. Every widget "inherits" from another widget, by simple assignment. All public properties of the "super" widget, i.e. all properties of its `that`, will be present on our own `that`. In this case, we use Ox.Element, the "root" widget at the end of the inheritance chain, and pass an empty options object. But we always pass our own `self`, which means that any property that Ox.Element (or any other widget in the inheritance chain) adds to self will be present on our own `self`. Then we call the public `defaults` and `options` methods. `defaults` assigns the defaults object to `self.defaults` and copies it to `self.options`, then `options` extends `self.options` with the options object. */ var that = Ox.Element({}, self) .defaults({ color: [128, 128, 128], size: 128 }) .options(options || {}) .update({ color: setColor, size: setSize }); /* Ox.Element, and every widget that inherits from it, has a private `self.setOption` method that is invoked whenever, by way of calling the public `that.options` method, a property of `self.options` is modified or added. If we don't want to react to such changes, we can leave `self.setOption` untouched. In this case though, we want to update color and size, so we just overwrite `self.setOption`. */ /* The following part of the "constructor" function can be thought of as the "initializer", and contains everything needed to set up the "instance". In this case, we just define a minimum and maximum size and then set the widget's color and size. We could have used `var minSize` and `var maxSize` here, but by using `self` for private variables that we want to be accessible across all the widget's methods, we can be sure that inside such methods, any local `var` is actually local to the method. We could have set color and size directly, too, but as we also need to set them in `self.setOption`, we create methods for both cases. */ self.minSize = 128; self.maxSize = 384; setColor(); setSize(); /* Now we declare the widget's private methods. These are simple function declarations, hoisted to the top of the "constructor". */ function setColor() { /* To interact with the DOM, Ox.Element (and any widget derived from it) wraps jQuery. If you type `Ox.Element()` in the console, you will get something like `[
]`, and the widget's prototype has all the methods of a `$('