javascript toolbar example

html:

<!doctype html>
<html>
<head>
<meta charset="utf-8">
<title>js dev test</title>
<link href="css/style.css" rel="stylesheet">
<script src="js/script.js"></script>

</head>
 
<body>
	
	<div id="myToolbar" class="toolbar">
		<span class="toolbar-item">0</span>
		<span class="toolbar-item">1</span>
		<span class="toolbar-item">2</span>
		<span class="toolbar-item">3</span>
	</div>
	
</body>
</html>

css:

.toolbar {
	background-color: #ccc;
	height: 50px;
	padding: 5px;
	margin: 5px;
}

.toolbar-item {
	display: inline-block;
	height: 50px;
	width: 50px;
	background-color: #00f;
	margin: 5px;
}

.active {
	background-color: #ff0;
}

.disabled {
	background-color: #555;
}

js:

var oojs = (function (oojs) {
	
	var createToolbarItem = function (itemElement) {

		var item = {
			toggleActiveState: function () {
				this.activated = !this.activated;
			}
		};

		Object.defineProperties(item, {
			el: {
				value: itemElement
			},
			enabled: {
				get: function () {
					return !this.el.classList.contains('disabled');
				},
				set: function (value) {
					if (value) {
						this.el.classList.remove('disabled');
					} else {
						this.el.classList.add('disabled');
					}
				}
			},
			activated: {
				get: function () {
					return this.el.classList.contains('active');
				},
				set: function (value) {
					if (value) {
						this.el.classList.add('active');
					} else {
						this.el.classList.remove('active');
					}
				}
			}

		});
		
		return item;
	};

	var createToolbarItems = function (itemElements) {
		var items = [];

		[].forEach.call( itemElements, function( el, index, array ) {
			var item = createToolbarItem(el);
			items.push(item);
		});
		return items;
	};

	oojs.createToolbar = function (elementId) {
		var element = document.getElementById(elementId);

		if (!element) {
			element = document.createElement('div');
			element.id = elementId;
			element.className = 'toolbar';
		}

		var items = element.querySelectorAll('.toolbar-item');

		var toolbar = {
			add: function (options) {
				var span = document.createElement('span');
				span.className = 'toolbar-item';
				this.el.appendChild(span);
				var item = createToolbarItem(span);
				this.items.push(item);
			},
			remove: function(index) {
				var len = this.items.length;
				if(index > len || index < 0) {
					throw new Error('Index is out ');
				}
				var item = this.items[index];
				this.items.splice(index, 1);
				this.el.removeChild(item.el);
				item = null;
			},
			appendTo: function (parentElement) {
				parentElement.appendChild(this.el);
			}
		};

		Object.defineProperties(toolbar, {
			el: {
				value: element
			},
			items: {
				value: createToolbarItems(items),
				enumerable: true
			}
		});

		return toolbar;
	};

	return oojs;
}(oojs || {}));


/*
var toolbar = oojs.createToolbar('myToolbar');
toolbar.items[0].enabled = false;
toolbar.items[0].enabled = true;
toolbar.items[1].activated = true;
toolbar.items[1].activated = false;
toolbar.items[2].toggleActiveState();
toolbar.add();
toolbar.remove(2);

var toolbar2 = oojs.createToolbar('myToolbar2');
toolbar2.appendTo(document.body);
toolbar2.add();
*/

Leave a Comment