tree.js

604 lines | 38.78 kB Blame History Raw Download
/******/ (function(modules) { // webpackBootstrap
/******/ 	// The module cache
/******/ 	var installedModules = {};

/******/ 	// The require function
/******/ 	function __webpack_require__(moduleId) {

/******/ 		// Check if module is in cache
/******/ 		if(installedModules[moduleId])
/******/ 			return installedModules[moduleId].exports;

/******/ 		// Create a new module (and put it into the cache)
/******/ 		var module = installedModules[moduleId] = {
/******/ 			exports: {},
/******/ 			id: moduleId,
/******/ 			loaded: false
/******/ 		};

/******/ 		// Execute the module function
/******/ 		modules[moduleId].call(module.exports, module, module.exports, __webpack_require__);

/******/ 		// Flag the module as loaded
/******/ 		module.loaded = true;

/******/ 		// Return the exports of the module
/******/ 		return module.exports;
/******/ 	}


/******/ 	// expose the modules object (__webpack_modules__)
/******/ 	__webpack_require__.m = modules;

/******/ 	// expose the module cache
/******/ 	__webpack_require__.c = installedModules;

/******/ 	// __webpack_public_path__
/******/ 	__webpack_require__.p = "";

/******/ 	// Load entry module and return exports
/******/ 	return __webpack_require__(0);
/******/ })
/************************************************************************/
/******/ ([
/* 0 */
/***/ function(module, exports, __webpack_require__) {

	/**
	 * Created by Allen Zou on 2016/10/13.
	 */

	"use strict";

	__webpack_require__(6);
	var fileIcon = __webpack_require__(7);
	var folderIcon = __webpack_require__(9);
	var closedFolderIcon = __webpack_require__(8);
	var plusIcon = __webpack_require__(10);
	var removeIcon = __webpack_require__(11);

	var tree = angular.module("angular.tree", []);
	tree
	    .directive("treeNode", function () {
	        return {
	            scope: {
	                item: "=",
	                adapter: "=",
	                icon: "=",
	                folderOpen: "=",
	                folderClose: "=",
	                nodeClick: "=",
	                childrenLoader: "=",
	                addItem: "=",
	                removeItem: "=",
	                editItem: "="
	            },
	            require: [],
	            restrict: "E",
	            // templateUrl: "directive/tree/node.html",
	            template: __webpack_require__(3),
	            link: function($scope, element, attributes, controllers) {
	                $scope.open = false;
	                $scope.add_btn = plusIcon;
	                $scope.remove_btn = removeIcon;
	                function load_children() {
	                    if ($scope.childrenLoader) {
	                        $scope.childrenLoader($scope.item)
	                            .then(function(children) {
	                                $scope.subNodes = children;
	                            })
	                            .catch(function(error) {
	                                console.error(error);
	                                $scope.subNodes = [];
	                            })
	                    } else {
	                        $scope.subNodes = [];
	                    }
	                }
	                $scope.wrap_node_click = function() {
	                    if ($scope.item) {
	                        var adaptedItem = $scope.adapter($scope.item);
	                        if (adaptedItem.type === "branch") {
	                            if ($scope.open) {
	                                $scope.open = false;
	                                $scope.folderClose && $scope.folderClose($scope.item);
	                            }
	                            else {
	                                $scope.open = true;
	                                $scope.folderOpen && $scope.folderOpen($scope.item);
	                                load_children();
	                            }
	                        }
	                        $scope.nodeClick && $scope.nodeClick($scope.item);

	                    }
	                    return false;
	                };
	                $scope.resolve_icon = function() {
	                    var icon = null;
	                    var adaptedItem = $scope.adapter($scope.item);
	                    if (adaptedItem.type === 'branch') {
	                        icon = ($scope.icon && $scope.icon($scope.item, $scope.open))
	                            || (!$scope.open && closedFolderIcon)
	                            || ($scope.open && folderIcon);
	                    }
	                    else {
	                        icon = ($scope.icon && $scope.icon($scope.item))
	                            || fileIcon;
	                    }
	                    return icon;
	                };
	                $scope.node_class = function() {
	                    var classes = ["node"];
	                    var adaptedItem = $scope.adapter($scope.item);
	                    if (adaptedItem.type === 'branch') {
	                        classes.push("branch");
	                        if ($scope.open) {
	                            classes.push("open");
	                        }
	                        else {
	                            classes.push("closed");
	                        }
	                    }
	                    else {
	                        classes.push("leaf");
	                    }
	                    return classes;
	                };
	                $scope.add_child = function() {
	                    if ($scope.addItem) {
	                        $scope.addItem($scope.item)
	                            .then(function() {
	                                load_children();
	                            })
	                        ;
	                    }
	                    return false;
	                };
	                $scope.remove_self = function() {
	                    if ($scope.removeItem) {
	                        $scope.removeItem($scope.item)
	                            .then(function() {
	                                load_children();
	                            })
	                        ;
	                    }
	                    return false;
	                };
	                $scope.edit = function() {
	                    console.log("edit:::");
	                    console.log($scope.editItem);
	                    $scope.editItem && $scope.editItem($scope.item);
	                    return false;
	                };
	            }
	        };
	    })
	    .directive("tree", function () {
	        var link = function($scope, element, attributes, controllers) {
	            $scope.itemAdapter = $scope.adapter || function(item) {
	                    console.log("in tree .adapter");
	                    return item;
	                };
	            $scope.tree_class = function() {
	                var classes = ["tree"];
	                return classes;
	            }
	        };
	        return {
	            scope: {
	                root: "=root",
	                adapter: "=",
	                icon: "=",
	                folderOpen: "=",
	                folderClose: "=",
	                nodeClick: "=",
	                childrenLoader: "=",
	                addItem: "=",
	                removeItem: "=",
	                editItem: "="
	            },
	            require: [],
	            restrict: "E",
	            // templateUrl: "directive/tree/tree.html",
	            template: __webpack_require__(4),
	            link: link
	        }
	    })
	;

	module.exports = tree;


/***/ },
/* 1 */
/***/ function(module, exports, __webpack_require__) {

	exports = module.exports = __webpack_require__(2)();
	// imports


	// module
	exports.push([module.id, ".tree {\n  overflow: auto;\n}\n.tree .node {\n  width: 100%;\n}\n.tree .node .directory-level {\n  position: relative;\n  padding-right: 4px;\n  white-space: nowrap;\n  font-size: 16px;\n  line-height: 16px;\n}\n.tree .node .directory-level > .icon {\n  height: 16px;\n}\n.tree .node .directory-level .operation {\n  display: inline;\n  margin-left: 20px;\n  visibility: hidden;\n}\n.tree .node .directory-level .operation img {\n  height: 16px;\n}\n.tree .node .directory-level:hover .operation {\n  visibility: visible;\n}\n.tree .node .sub-node {\n  padding-left: 14px;\n}\n", ""]);

	// exports


/***/ },
/* 2 */
/***/ function(module, exports) {

	/*
		MIT License http://www.opensource.org/licenses/mit-license.php
		Author Tobias Koppers @sokra
	*/
	// css base code, injected by the css-loader
	module.exports = function() {
		var list = [];

		// return the list of modules as css string
		list.toString = function toString() {
			var result = [];
			for(var i = 0; i < this.length; i++) {
				var item = this[i];
				if(item[2]) {
					result.push("@media " + item[2] + "{" + item[1] + "}");
				} else {
					result.push(item[1]);
				}
			}
			return result.join("");
		};

		// import a list of modules into the list
		list.i = function(modules, mediaQuery) {
			if(typeof modules === "string")
				modules = [[null, modules, ""]];
			var alreadyImportedModules = {};
			for(var i = 0; i < this.length; i++) {
				var id = this[i][0];
				if(typeof id === "number")
					alreadyImportedModules[id] = true;
			}
			for(i = 0; i < modules.length; i++) {
				var item = modules[i];
				// skip already imported module
				// this implementation is not 100% perfect for weird media query combinations
				//  when a module is imported multiple times with different media queries.
				//  I hope this will never occur (Hey this way we have smaller bundles)
				if(typeof item[0] !== "number" || !alreadyImportedModules[item[0]]) {
					if(mediaQuery && !item[2]) {
						item[2] = mediaQuery;
					} else if(mediaQuery) {
						item[2] = "(" + item[2] + ") and (" + mediaQuery + ")";
					}
					list.push(item);
				}
			}
		};
		return list;
	};


/***/ },
/* 3 */
/***/ function(module, exports) {

	module.exports = "<div ng-class=\"node_class()\">\n  <div class=\"directory-level\" ng-click=\"wrap_node_click()\">\n    <img class=\"icon\" ng-src=\"{{ resolve_icon() }}\">\n    <span>{{ adapter(item).text }}</span>\n    <div class=\"operation\" ng-click=\"$event.stopPropagation()\">\n      <a href class=\"add\" ng-click=\"add_child()\" ng-if=\"adapter(item).type==='branch'\">\n        <img ng-src=\"{{ add_btn }}\">\n      </a>\n      <a href class=\"remove\" ng-click=\"remove_self()\">\n        <img ng-src=\"{{ remove_btn }}\">\n      </a>\n      <a href class=\"edit\" ng-click=\"edit()\">\n        <span class=\"glyphicon glyphicon-edit\"></span>\n      </a>\n    </div>\n  </div>\n  <div class=\"sub-node\" ng-if=\"open\" ng-repeat=\"node in subNodes\">\n    <tree-node item=\"node\" adapter=\"adapter\" icon=\"icon\"\n               folder-open=\"folderOpen\" folder-close=\"folderClose\"\n               node-click=\"nodeClick\" children-loader=\"childrenLoader\"\n               add-item=\"addItem\" remove-item=\"removeItem\" edit-item=\"editItem\">\n    </tree-node>\n  </div>\n</div>";

/***/ },
/* 4 */
/***/ function(module, exports) {

	module.exports = "<div ng-class=\"tree_class()\">\n  <tree-node item=\"root\" adapter=\"itemAdapter\" icon=\"icon\"\n             folder-open=\"folderOpen\" folder-close=\"folderClose\"\n             node-click=\"nodeClick\" children-loader=\"childrenLoader\"\n             add-item=\"addItem\" remove-item=\"removeItem\" edit-item=\"editItem\">\n  </tree-node>\n</div>";

/***/ },
/* 5 */
/***/ function(module, exports, __webpack_require__) {

	/*
		MIT License http://www.opensource.org/licenses/mit-license.php
		Author Tobias Koppers @sokra
	*/
	var stylesInDom = {},
		memoize = function(fn) {
			var memo;
			return function () {
				if (typeof memo === "undefined") memo = fn.apply(this, arguments);
				return memo;
			};
		},
		isOldIE = memoize(function() {
			return /msie [6-9]\b/.test(window.navigator.userAgent.toLowerCase());
		}),
		getHeadElement = memoize(function () {
			return document.head || document.getElementsByTagName("head")[0];
		}),
		singletonElement = null,
		singletonCounter = 0,
		styleElementsInsertedAtTop = [];

	module.exports = function(list, options) {
		if(false) {
			if(typeof document !== "object") throw new Error("The style-loader cannot be used in a non-browser environment");
		}

		options = options || {};
		// Force single-tag solution on IE6-9, which has a hard limit on the # of <style>
		// tags it will allow on a page
		if (typeof options.singleton === "undefined") options.singleton = isOldIE();

		// By default, add <style> tags to the bottom of <head>.
		if (typeof options.insertAt === "undefined") options.insertAt = "bottom";

		var styles = listToStyles(list);
		addStylesToDom(styles, options);

		return function update(newList) {
			var mayRemove = [];
			for(var i = 0; i < styles.length; i++) {
				var item = styles[i];
				var domStyle = stylesInDom[item.id];
				domStyle.refs--;
				mayRemove.push(domStyle);
			}
			if(newList) {
				var newStyles = listToStyles(newList);
				addStylesToDom(newStyles, options);
			}
			for(var i = 0; i < mayRemove.length; i++) {
				var domStyle = mayRemove[i];
				if(domStyle.refs === 0) {
					for(var j = 0; j < domStyle.parts.length; j++)
						domStyle.parts[j]();
					delete stylesInDom[domStyle.id];
				}
			}
		};
	}

	function addStylesToDom(styles, options) {
		for(var i = 0; i < styles.length; i++) {
			var item = styles[i];
			var domStyle = stylesInDom[item.id];
			if(domStyle) {
				domStyle.refs++;
				for(var j = 0; j < domStyle.parts.length; j++) {
					domStyle.parts[j](item.parts[j]);
				}
				for(; j < item.parts.length; j++) {
					domStyle.parts.push(addStyle(item.parts[j], options));
				}
			} else {
				var parts = [];
				for(var j = 0; j < item.parts.length; j++) {
					parts.push(addStyle(item.parts[j], options));
				}
				stylesInDom[item.id] = {id: item.id, refs: 1, parts: parts};
			}
		}
	}

	function listToStyles(list) {
		var styles = [];
		var newStyles = {};
		for(var i = 0; i < list.length; i++) {
			var item = list[i];
			var id = item[0];
			var css = item[1];
			var media = item[2];
			var sourceMap = item[3];
			var part = {css: css, media: media, sourceMap: sourceMap};
			if(!newStyles[id])
				styles.push(newStyles[id] = {id: id, parts: [part]});
			else
				newStyles[id].parts.push(part);
		}
		return styles;
	}

	function insertStyleElement(options, styleElement) {
		var head = getHeadElement();
		var lastStyleElementInsertedAtTop = styleElementsInsertedAtTop[styleElementsInsertedAtTop.length - 1];
		if (options.insertAt === "top") {
			if(!lastStyleElementInsertedAtTop) {
				head.insertBefore(styleElement, head.firstChild);
			} else if(lastStyleElementInsertedAtTop.nextSibling) {
				head.insertBefore(styleElement, lastStyleElementInsertedAtTop.nextSibling);
			} else {
				head.appendChild(styleElement);
			}
			styleElementsInsertedAtTop.push(styleElement);
		} else if (options.insertAt === "bottom") {
			head.appendChild(styleElement);
		} else {
			throw new Error("Invalid value for parameter 'insertAt'. Must be 'top' or 'bottom'.");
		}
	}

	function removeStyleElement(styleElement) {
		styleElement.parentNode.removeChild(styleElement);
		var idx = styleElementsInsertedAtTop.indexOf(styleElement);
		if(idx >= 0) {
			styleElementsInsertedAtTop.splice(idx, 1);
		}
	}

	function createStyleElement(options) {
		var styleElement = document.createElement("style");
		styleElement.type = "text/css";
		insertStyleElement(options, styleElement);
		return styleElement;
	}

	function createLinkElement(options) {
		var linkElement = document.createElement("link");
		linkElement.rel = "stylesheet";
		insertStyleElement(options, linkElement);
		return linkElement;
	}

	function addStyle(obj, options) {
		var styleElement, update, remove;

		if (options.singleton) {
			var styleIndex = singletonCounter++;
			styleElement = singletonElement || (singletonElement = createStyleElement(options));
			update = applyToSingletonTag.bind(null, styleElement, styleIndex, false);
			remove = applyToSingletonTag.bind(null, styleElement, styleIndex, true);
		} else if(obj.sourceMap &&
			typeof URL === "function" &&
			typeof URL.createObjectURL === "function" &&
			typeof URL.revokeObjectURL === "function" &&
			typeof Blob === "function" &&
			typeof btoa === "function") {
			styleElement = createLinkElement(options);
			update = updateLink.bind(null, styleElement);
			remove = function() {
				removeStyleElement(styleElement);
				if(styleElement.href)
					URL.revokeObjectURL(styleElement.href);
			};
		} else {
			styleElement = createStyleElement(options);
			update = applyToTag.bind(null, styleElement);
			remove = function() {
				removeStyleElement(styleElement);
			};
		}

		update(obj);

		return function updateStyle(newObj) {
			if(newObj) {
				if(newObj.css === obj.css && newObj.media === obj.media && newObj.sourceMap === obj.sourceMap)
					return;
				update(obj = newObj);
			} else {
				remove();
			}
		};
	}

	var replaceText = (function () {
		var textStore = [];

		return function (index, replacement) {
			textStore[index] = replacement;
			return textStore.filter(Boolean).join('\n');
		};
	})();

	function applyToSingletonTag(styleElement, index, remove, obj) {
		var css = remove ? "" : obj.css;

		if (styleElement.styleSheet) {
			styleElement.styleSheet.cssText = replaceText(index, css);
		} else {
			var cssNode = document.createTextNode(css);
			var childNodes = styleElement.childNodes;
			if (childNodes[index]) styleElement.removeChild(childNodes[index]);
			if (childNodes.length) {
				styleElement.insertBefore(cssNode, childNodes[index]);
			} else {
				styleElement.appendChild(cssNode);
			}
		}
	}

	function applyToTag(styleElement, obj) {
		var css = obj.css;
		var media = obj.media;

		if(media) {
			styleElement.setAttribute("media", media)
		}

		if(styleElement.styleSheet) {
			styleElement.styleSheet.cssText = css;
		} else {
			while(styleElement.firstChild) {
				styleElement.removeChild(styleElement.firstChild);
			}
			styleElement.appendChild(document.createTextNode(css));
		}
	}

	function updateLink(linkElement, obj) {
		var css = obj.css;
		var sourceMap = obj.sourceMap;

		if(sourceMap) {
			// http://stackoverflow.com/a/26603875
			css += "\n/*# sourceMappingURL=data:application/json;base64," + btoa(unescape(encodeURIComponent(JSON.stringify(sourceMap)))) + " */";
		}

		var blob = new Blob([css], { type: "text/css" });

		var oldSrc = linkElement.href;

		linkElement.href = URL.createObjectURL(blob);

		if(oldSrc)
			URL.revokeObjectURL(oldSrc);
	}


/***/ },
/* 6 */
/***/ function(module, exports, __webpack_require__) {

	// style-loader: Adds some css to the DOM by adding a <style> tag

	// load the styles
	var content = __webpack_require__(1);
	if(typeof content === 'string') content = [[module.id, content, '']];
	// add the styles to the DOM
	var update = __webpack_require__(5)(content, {});
	if(content.locals) module.exports = content.locals;
	// Hot Module Replacement
	if(false) {
		// When the styles change, update the <style> tags
		if(!content.locals) {
			module.hot.accept("!!./../../node_modules/css-loader/index.js!./../../node_modules/less-loader/index.js!./tree.less", function() {
				var newContent = require("!!./../../node_modules/css-loader/index.js!./../../node_modules/less-loader/index.js!./tree.less");
				if(typeof newContent === 'string') newContent = [[module.id, newContent, '']];
				update(newContent);
			});
		}
		// When the module is disposed, remove the <style> tags
		module.hot.dispose(function() { update(); });
	}

/***/ },
/* 7 */
/***/ function(module, exports) {

	module.exports = ""

/***/ },
/* 8 */
/***/ function(module, exports) {

	module.exports = ""

/***/ },
/* 9 */
/***/ function(module, exports) {

	module.exports = ""

/***/ },
/* 10 */
/***/ function(module, exports) {

	module.exports = ""

/***/ },
/* 11 */
/***/ function(module, exports) {

	module.exports = ""

/***/ }
/******/ ]);