keycloak-theme/welcome/common/resources/node_modules/angular-treeview/tree.js
2022-02-22 16:53:26 +08:00

604 lines
39 KiB
JavaScript

/******/ (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 = ""
/***/ }
/******/ ]);