diff --git a/cookbook/helper/permission_helper.py b/cookbook/helper/permission_helper.py index a24483b24..0331a5993 100644 --- a/cookbook/helper/permission_helper.py +++ b/cookbook/helper/permission_helper.py @@ -1,6 +1,3 @@ -""" -Source: https://djangosnippets.org/snippets/1703/ -""" from django.conf import settings from django.contrib import messages from django.contrib.auth.decorators import user_passes_test @@ -12,7 +9,7 @@ from django.utils.translation import gettext as _ from rest_framework import permissions from rest_framework.permissions import SAFE_METHODS -from cookbook.models import ShareLink +from cookbook.models import ShareLink, Recipe, UserPreference def get_allowed_groups(groups_required): @@ -262,3 +259,38 @@ class CustomIsShare(permissions.BasePermission): if share: return share_link_valid(obj, share) return False + + +def above_space_limit(space): # TODO add file storage limit + """ + Test if the space has reached any limit (e.g. max recipes, users, ..) + :param space: Space to test for limits + :return: Tuple (True if above or equal any limit else false, message) + """ + r_limit, r_msg = above_space_recipe_limit(space) + u_limit, u_msg = above_space_user_limit(space) + return r_limit or u_limit, (r_msg + ' ' + u_msg).strip() + + +def above_space_recipe_limit(space): + """ + Test if a space has reached its recipe limit + :param space: Space to test for limits + :return: Tuple (True if above or equal limit else false, message) + """ + limit = space.max_recipes != 0 and Recipe.objects.filter(space=space).count() >= space.max_recipes + if limit: + return True, _('You have reached the maximum number of recipes for your space.') + return False, '' + + +def above_space_user_limit(space): + """ + Test if a space has reached its user limit + :param space: Space to test for limits + :return: Tuple (True if above or equal limit else false, message) + """ + limit = space.max_users != 0 and UserPreference.objects.filter(space=space).count() > space.max_users + if limit: + return True, _('You have more users than allowed in your space.') + return False, '' diff --git a/cookbook/helper/recipe_url_import.py b/cookbook/helper/recipe_url_import.py index bad57bb73..1d9b9e549 100644 --- a/cookbook/helper/recipe_url_import.py +++ b/cookbook/helper/recipe_url_import.py @@ -113,6 +113,14 @@ def get_from_scraper(scrape, request): keywords += listify_keywords(scrape.schema.data.get("recipeCuisine")) except Exception: pass + + if source_url := scrape.canonical_url(): + recipe_json['source_url'] = source_url + try: + keywords.append(source_url.replace('http://', '').replace('https://', '').split('/')[0]) + except Exception: + pass + try: recipe_json['keywords'] = parse_keywords(list(set(map(str.casefold, keywords))), request.space) except AttributeError: @@ -136,19 +144,18 @@ def get_from_scraper(scrape, request): for x in scrape.ingredients(): try: amount, unit, ingredient, note = ingredient_parser.parse(x) - recipe_json['steps'][0]['ingredients'].append( - { - 'amount': amount, - 'unit': { - 'name': unit, - }, - 'food': { - 'name': ingredient, - }, - 'note': note, - 'original_text': x - } - ) + ingredient = { + 'amount': amount, + 'food': { + 'name': ingredient, + }, + 'unit': None, + 'note': note, + 'original_text': x + } + if unit: + ingredient['unit'] = {'name': unit, } + recipe_json['steps'][0]['ingredients'].append(ingredient) except Exception: recipe_json['steps'][0]['ingredients'].append( { @@ -164,8 +171,6 @@ def get_from_scraper(scrape, request): except Exception: pass - if scrape.canonical_url(): - recipe_json['source_url'] = scrape.canonical_url() return recipe_json diff --git a/cookbook/serializer.py b/cookbook/serializer.py index c1e64a300..d913be516 100644 --- a/cookbook/serializer.py +++ b/cookbook/serializer.py @@ -12,6 +12,7 @@ from rest_framework.exceptions import NotFound, ValidationError from cookbook.helper.CustomStorageClass import CachedS3Boto3Storage from cookbook.helper.HelperFunctions import str2bool +from cookbook.helper.permission_helper import above_space_limit from cookbook.helper.shopping_helper import RecipeShoppingEditor from cookbook.models import (Automation, BookmarkletImport, Comment, CookLog, CustomFilter, ExportLog, Food, FoodInheritField, ImportLog, Ingredient, Keyword, @@ -649,6 +650,12 @@ class RecipeSerializer(RecipeBaseSerializer): ) read_only_fields = ['image', 'created_by', 'created_at'] + def validate(self, data): + above_limit, msg = above_space_limit(self.context['request'].space) + if above_limit: + raise serializers.ValidationError(msg) + return super().validate(data) + def create(self, validated_data): validated_data['created_by'] = self.context['request'].user validated_data['space'] = self.context['request'].space @@ -971,12 +978,19 @@ class AutomationSerializer(serializers.ModelSerializer): # CORS, REST and Scopes aren't currently working # Scopes are evaluating before REST has authenticated the user assigning a None space # I've made the change below to fix the bookmarklet, other serializers likely need a similar/better fix -class BookmarkletImportSerializer(serializers.ModelSerializer): +class BookmarkletImportListSerializer(serializers.ModelSerializer): def create(self, validated_data): validated_data['created_by'] = self.context['request'].user validated_data['space'] = self.context['request'].user.userpreference.space return super().create(validated_data) + class Meta: + model = BookmarkletImport + fields = ('id', 'url', 'created_by', 'created_at') + read_only_fields = ('created_by', 'space') + + +class BookmarkletImportSerializer(BookmarkletImportListSerializer): class Meta: model = BookmarkletImport fields = ('id', 'url', 'html', 'created_by', 'created_at') diff --git a/cookbook/static/js/vue-jstree.js b/cookbook/static/js/vue-jstree.js deleted file mode 100644 index 50d5ade52..000000000 --- a/cookbook/static/js/vue-jstree.js +++ /dev/null @@ -1,2 +0,0 @@ -!function(e,A){"object"==typeof exports&&"object"==typeof module?module.exports=A():"function"==typeof define&&define.amd?define("vue-jstree",[],A):"object"==typeof exports?exports["vue-jstree"]=A():e["vue-jstree"]=A()}(this,function(){return function(e){function A(r){if(t[r])return t[r].exports;var n=t[r]={i:r,l:!1,exports:{}};return e[r].call(n.exports,n,n.exports,A),n.l=!0,n.exports}var t={};return A.m=e,A.c=t,A.i=function(e){return e},A.d=function(e,t,r){A.o(e,t)||Object.defineProperty(e,t,{configurable:!1,enumerable:!0,get:r})},A.n=function(e){var t=e&&e.__esModule?function(){return e.default}:function(){return e};return A.d(t,"a",t),t},A.o=function(e,A){return Object.prototype.hasOwnProperty.call(e,A)},A.p="dist/",A(A.s=4)}([function(e,A){e.exports=function(e,A,t,r,n){var o,a=e=e||{},l=typeof e.default;"object"!==l&&"function"!==l||(o=e,a=e.default);var i="function"==typeof a?a.options:a;A&&(i.render=A.render,i.staticRenderFns=A.staticRenderFns),r&&(i._scopeId=r);var d;if(n?(d=function(e){e=e||this.$vnode&&this.$vnode.ssrContext||this.parent&&this.parent.$vnode&&this.parent.$vnode.ssrContext,e||"undefined"==typeof __VUE_SSR_CONTEXT__||(e=__VUE_SSR_CONTEXT__),t&&t.call(this,e),e&&e._registeredComponents&&e._registeredComponents.add(n)},i._ssrRegister=d):t&&(d=t),d){var g=i.functional,s=g?i.render:i.beforeCreate;g?i.render=function(e,A){return d.call(A),s(e,A)}:i.beforeCreate=s?[].concat(s,d):[d]}return{esModule:o,exports:a,options:i}}},function(e,A,t){function r(e){t(10)}var n=t(0)(t(3),t(9),r,null,null);e.exports=n.exports},function(e,A,t){"use strict";function r(e,A,t){return A in e?Object.defineProperty(e,A,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[A]=t,e}Object.defineProperty(A,"__esModule",{value:!0}),A.default={name:"TreeItem",props:{data:{type:Object,required:!0},textFieldName:{type:String},valueFieldName:{type:String},childrenFieldName:{type:String},itemEvents:{type:Object},wholeRow:{type:Boolean,default:!1},showCheckbox:{type:Boolean,default:!1},allowTransition:{type:Boolean,default:!0},height:{type:Number,default:24},parentItem:{type:Array},draggable:{type:Boolean,default:!1},dragOverBackgroundColor:{type:String},onItemClick:{type:Function,default:function(){return!1}},onItemToggle:{type:Function,default:function(){return!1}},onItemDragStart:{type:Function,default:function(){return!1}},onItemDragEnd:{type:Function,default:function(){return!1}},onItemDrop:{type:Function,default:function(){return!1}},klass:String},data:function(){return{isHover:!1,isDragEnter:!1,model:this.data,maxHeight:0,events:{}}},watch:{isDragEnter:function(e){this.$el.style.backgroundColor=e?this.dragOverBackgroundColor:"inherit"},data:function(e){this.model=e},"model.opened":{handler:function(e,A){this.onItemToggle(this,this.model),this.handleGroupMaxHeight()},deep:!0}},computed:{isFolder:function(){return this.model[this.childrenFieldName]&&this.model[this.childrenFieldName].length},classes:function(){return[{"tree-node":!0},{"tree-open":this.model.opened},{"tree-closed":!this.model.opened},{"tree-leaf":!this.isFolder},{"tree-loading":!!this.model.loading},{"tree-drag-enter":this.isDragEnter},r({},this.klass,!!this.klass)]},anchorClasses:function(){return[{"tree-anchor":!0},{"tree-disabled":this.model.disabled},{"tree-selected":this.model.selected},{"tree-hovered":this.isHover}]},wholeRowClasses:function(){return[{"tree-wholerow":!0},{"tree-wholerow-clicked":this.model.selected},{"tree-wholerow-hovered":this.isHover}]},themeIconClasses:function(){return[{"tree-icon":!0},{"tree-themeicon":!0},r({},this.model.icon,!!this.model.icon),{"tree-themeicon-custom":!!this.model.icon}]},isWholeRow:function(){if(this.wholeRow)return void 0===this.$parent.model||!0===this.$parent.model.opened},groupStyle:function(){return{position:this.model.opened?"":"relative","max-height":this.allowTransition?this.maxHeight+"px":"","transition-duration":this.allowTransition?300*Math.ceil(this.model[this.childrenFieldName].length/100)+"ms":"","transition-property":this.allowTransition?"max-height":"",display:this.allowTransition?"block":this.model.opened?"block":"none"}}},methods:{handleItemToggle:function(e){this.isFolder&&(this.model.opened=!this.model.opened,this.onItemToggle(this,this.model))},handleGroupMaxHeight:function(){if(this.allowTransition){var e=0,A=0;if(this.model.opened){e=this.$children.length;var t=!0,r=!1,n=void 0;try{for(var o,a=this.$children[Symbol.iterator]();!(t=(o=a.next()).done);t=!0){A+=o.value.maxHeight}}catch(e){r=!0,n=e}finally{try{!t&&a.return&&a.return()}finally{if(r)throw n}}}this.maxHeight=e*this.height+A,"tree-item"===this.$parent.$options._componentTag&&this.$parent.handleGroupMaxHeight()}},handleItemClick:function(e){this.model.disabled||(this.model.selected=!this.model.selected,this.onItemClick(this,this.model,e))},handleItemMouseOver:function(){this.isHover=!0},handleItemMouseOut:function(){this.isHover=!1},handleItemDrop:function(e,A,t){this.$el.style.backgroundColor="inherit",this.onItemDrop(e,A,t)}},created:function(){var e=this,A=this,t={click:this.handleItemClick,mouseover:this.handleItemMouseOver,mouseout:this.handleItemMouseOut};for(var r in this.itemEvents)!function(r){var n=e.itemEvents[r];if(t.hasOwnProperty(r)){var o=t[r];t[r]=function(e){o(A,A.model,e),n(A,A.model,e)}}else t[r]=function(e){n(A,A.model,e)}}(r);this.events=t},mounted:function(){this.handleGroupMaxHeight()}}},function(e,A,t){"use strict";function r(e,A,t){return A in e?Object.defineProperty(e,A,{value:t,enumerable:!0,configurable:!0,writable:!0}):e[A]=t,e}Object.defineProperty(A,"__esModule",{value:!0});var n=t(7),o=t.n(n),a="function"==typeof Symbol&&"symbol"==typeof Symbol.iterator?function(e){return typeof e}:function(e){return e&&"function"==typeof Symbol&&e.constructor===Symbol&&e!==Symbol.prototype?"symbol":typeof e},l=0;A.default={name:"VJstree",props:{data:{type:Array},size:{type:String,validator:function(e){return["large","small"].indexOf(e)>-1}},showCheckbox:{type:Boolean,default:!1},wholeRow:{type:Boolean,default:!1},noDots:{type:Boolean,default:!1},collapse:{type:Boolean,default:!1},multiple:{type:Boolean,default:!1},allowBatch:{type:Boolean,default:!1},allowTransition:{type:Boolean,default:!0},textFieldName:{type:String,default:"text"},valueFieldName:{type:String,default:"value"},childrenFieldName:{type:String,default:"children"},itemEvents:{type:Object,default:function(){return{}}},async:{type:Function},loadingText:{type:String,default:"Loading..."},draggable:{type:Boolean,default:!1},dragOverBackgroundColor:{type:String,default:"#C9FDC9"},klass:String},data:function(){return{draggedItem:void 0,draggedElm:void 0}},computed:{classes:function(){return[{tree:!0},{"tree-default":!this.size},r({},"tree-default-"+this.size,!!this.size),{"tree-checkbox-selection":!!this.showCheckbox},r({},this.klass,!!this.klass)]},containerClasses:function(){return[{"tree-container-ul":!0},{"tree-children":!0},{"tree-wholerow-ul":!!this.wholeRow},{"tree-no-dots":!!this.noDots}]},sizeHeight:function(){switch(this.size){case"large":return 32;case"small":return 18;default:return 24}}},methods:{initializeData:function(e){if(e&&e.length>0)for(var A in e){var t=this.initializeDataItem(e[A]);e[A]=t,this.initializeData(e[A][this.childrenFieldName])}},initializeDataItem:function(e){function A(e,A,t,r,n){this.id=e.id||l++,this[A]=e[A]||"",this[t]=e[t]||e[A],this.icon=e.icon||"",this.opened=e.opened||n,this.selected=e.selected||!1,this.disabled=e.disabled||!1,this.loading=e.loading||!1,this[r]=e[r]||[]}var t=Object.assign(new A(e,this.textFieldName,this.valueFieldName,this.childrenFieldName,this.collapse),e),r=this;return t.addBefore=function(e,A){var n=r.initializeDataItem(e),o=A.parentItem.findIndex(function(e){return e.id===t.id});A.parentItem.splice(o,0,n)},t.addAfter=function(e,A){var n=r.initializeDataItem(e),o=A.parentItem.findIndex(function(e){return e.id===t.id})+1;A.parentItem.splice(o,0,n)},t.addChild=function(e){var A=r.initializeDataItem(e);t.opened=!0,t[r.childrenFieldName].push(A)},t.openChildren=function(){t.opened=!0,r.handleRecursionNodeChildren(t,function(e){e.opened=!0})},t.closeChildren=function(){t.opened=!1,r.handleRecursionNodeChildren(t,function(e){e.opened=!1})},t},initializeLoading:function(){var e={};return e[this.textFieldName]=this.loadingText,e.disabled=!0,e.loading=!0,this.initializeDataItem(e)},handleRecursionNodeChilds:function(e,A){if(!1!==A(e)&&e.$children&&e.$children.length>0){var t=!0,r=!1,n=void 0;try{for(var o,a=e.$children[Symbol.iterator]();!(t=(o=a.next()).done);t=!0){var l=o.value;l.disabled||this.handleRecursionNodeChilds(l,A)}}catch(e){r=!0,n=e}finally{try{!t&&a.return&&a.return()}finally{if(r)throw n}}}},handleRecursionNodeChildren:function(e,A){if(!1!==A(e)&&e[this.childrenFieldName]&&e[this.childrenFieldName].length>0){var t=!0,r=!1,n=void 0;try{for(var o,a=e[this.childrenFieldName][Symbol.iterator]();!(t=(o=a.next()).done);t=!0){var l=o.value;this.handleRecursionNodeChildren(l,A)}}catch(e){r=!0,n=e}finally{try{!t&&a.return&&a.return()}finally{if(r)throw n}}}},onItemClick:function(e,A,t){this.multiple?this.allowBatch&&this.handleBatchSelectItems(e,A):this.handleSingleSelectItems(e,A),this.$emit("item-click",e,A,t)},handleSingleSelectItems:function(e,A){this.handleRecursionNodeChilds(this,function(e){e.model&&(e.model.selected=!1)}),e.model.selected=!0},handleBatchSelectItems:function(e,A){this.handleRecursionNodeChilds(e,function(A){A.model.disabled||(A.model.selected=e.model.selected)})},onItemToggle:function(e,A,t){e.model.opened&&this.handleAsyncLoad(e.model[this.childrenFieldName],e,A),this.$emit("item-toggle",e,A,t)},handleAsyncLoad:function(e,A,t){var r=this;this.async&&e[0].loading&&this.async(A,function(t){if(t.length>0)for(var n in t){t[n].isLeaf||"object"!==a(t[n][r.childrenFieldName])&&(t[n][r.childrenFieldName]=[r.initializeLoading()]);var o=r.initializeDataItem(t[n]);r.$set(e,n,o)}else A.model[r.childrenFieldName]=[]})},onItemDragStart:function(e,A,t){if(!this.draggable||t.dragDisabled)return!1;e.dataTransfer.effectAllowed="move",e.dataTransfer.setData("text",null),this.draggedElm=e.target,this.draggedItem={item:t,parentItem:A.parentItem,index:A.parentItem.findIndex(function(e){return e.id===t.id})},this.$emit("item-drag-start",A,t,e)},onItemDragEnd:function(e,A,t){this.draggedItem=void 0,this.draggedElm=void 0,this.$emit("item-drag-end",A,t,e)},onItemDrop:function(e,A,t){var r=this;if(!this.draggable||t.dropDisabled)return!1;if(this.$emit("item-drop-before",A,t,this.draggedItem?this.draggedItem.item:void 0,e),this.draggedElm&&this.draggedElm!==e.target&&!this.draggedElm.contains(e.target)&&this.draggedItem){if(this.draggedItem.parentItem===t[this.childrenFieldName]||this.draggedItem.item===t||t[this.childrenFieldName]&&-1!==t[this.childrenFieldName].findIndex(function(e){return e.id===r.draggedItem.item.id}))return;t[this.childrenFieldName]?t[this.childrenFieldName].push(this.draggedItem.item):t[this.childrenFieldName]=[this.draggedItem.item],t.opened=!0;var n=this.draggedItem;this.$nextTick(function(){n.parentItem.splice(n.index,1)}),this.$emit("item-drop",A,t,n.item,e)}}},created:function(){this.initializeData(this.data)},mounted:function(){this.async&&(this.$set(this.data,0,this.initializeLoading()),this.handleAsyncLoad(this.data,this))},components:{TreeItem:o.a}}},function(e,A,t){"use strict";Object.defineProperty(A,"__esModule",{value:!0});var r=t(1),n=t.n(r);n.a.install=function(e){e.component(n.a.name,n.a)},"undefined"!=typeof window&&window.Vue&&window.Vue.use(n.a),A.default=n.a},function(e,A,t){A=e.exports=t(6)(),A.push([e.i,'.tree-children,.tree-container-ul,.tree-node{display:block;margin:0;padding:0;list-style-type:none;list-style-image:none}.tree-children{overflow:hidden}.tree-anchor,.tree-node{white-space:nowrap}.tree-anchor{display:inline-block;color:#000;padding:0 4px 0 1px;margin:0;vertical-align:top;font-size:14px;cursor:pointer}.tree-anchor:focus{outline:0}.tree-anchor,.tree-anchor:active,.tree-anchor:hover,.tree-anchor:link,.tree-anchor:visited{text-decoration:none;color:inherit}.tree-icon,.tree-icon:empty{display:inline-block;text-decoration:none;margin:0;padding:0;vertical-align:top;text-align:center}.tree-ocl{cursor:pointer}.tree-leaf>.tree-ocl{cursor:default}.tree-anchor>.tree-themeicon{margin-right:2px}.tree-anchor>.tree-themeicon-hidden,.tree-hidden,.tree-no-icons .tree-themeicon,.tree-node.tree-hidden{display:none}.tree-rtl .tree-anchor{padding:0 1px 0 4px}.tree-rtl .tree-anchor>.tree-themeicon{margin-left:2px;margin-right:0}.tree-rtl .tree-node{margin-left:0}.tree-rtl .tree-container-ul>.tree-node{margin-right:0}.tree-wholerow-ul{position:relative;display:inline-block;min-width:100%}.tree-wholerow-ul .tree-leaf>.tree-ocl{cursor:pointer}.tree-wholerow-ul .tree-anchor,.tree-wholerow-ul .tree-icon{position:relative}.tree-wholerow-ul .tree-wholerow{width:100%;cursor:pointer;z-index:-1;position:absolute;left:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.tree{text-align:left}.tree-default .tree-icon,.tree-default .tree-node{background-repeat:no-repeat;background-color:transparent}.tree-default .tree-anchor,.tree-default .tree-animated,.tree-default .tree-wholerow{transition:background-color .15s,box-shadow .15s}.tree-default .tree-context,.tree-default .tree-hovered{background:#eee;border:0;box-shadow:none}.tree-default .tree-selected{background:#e1e1e1;border:0;box-shadow:none}.tree-default .tree-no-icons .tree-anchor>.tree-themeicon{display:none}.tree-default .tree-disabled{color:#666}.tree-default .tree-disabled.tree-hovered{box-shadow:none}.tree-default .tree-disabled>.tree-icon{opacity:.8;filter:url("data:image/svg+xml;utf8,#tree-grayscale");filter:gray;-webkit-filter:grayscale(100%)}.tree-default .tree-search{font-style:italic;color:#8b0000;font-weight:700}.tree-default .tree-no-checkboxes .tree-checkbox{display:none!important}.tree-default.tree-checkbox-no-clicked .tree-selected{background:transparent;box-shadow:none}.tree-default.tree-checkbox-no-clicked .tree-selected.tree-hovered{background:#eee}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked{background:transparent}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked.tree-wholerow-hovered{background:#eee}.tree-default>.tree-striped{min-width:100%;display:inline-block;background:url("") 0 0 repeat}.tree-default>.tree-wholerow-ul .tree-hovered,.tree-default>.tree-wholerow-ul .tree-selected{background:transparent;box-shadow:none;border-radius:0}.tree-default .tree-wholerow{box-sizing:border-box}.tree-default .tree-wholerow-hovered{background:#eee}.tree-default .tree-wholerow-clicked{background:#e1e1e1}.tree-default .tree-node{min-height:24px;line-height:24px;margin-left:30px;min-width:24px}.tree-default .tree-anchor,.tree-default .tree-icon{line-height:24px;height:24px}.tree-default .tree-icon{width:24px}.tree-default .tree-icon:empty{width:24px;height:24px;line-height:24px}.tree-default.tree-rtl .tree-node{margin-right:24px}.tree-default .tree-wholerow{height:24px}.tree-default .tree-icon,.tree-default .tree-node{background-image:url("")}.tree-default .tree-node{background-position:-292px -4px;background-repeat:repeat-y}.tree-default .tree-last{background:transparent}.tree-default .tree-open>.tree-ocl{background-position:-132px -4px}.tree-default .tree-closed>.tree-ocl{background-position:-100px -4px}.tree-default .tree-leaf>.tree-ocl{background-position:-68px -4px}.tree-default .tree-themeicon{background-position:-260px -4px}.tree-default>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default>.tree-no-dots .tree-node{background:transparent}.tree-default>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -4px}.tree-default>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -4px}.tree-default .tree-disabled,.tree-default .tree-disabled.tree-hovered{background:transparent}.tree-default .tree-disabled.tree-selected{background:#efefef}.tree-default .tree-checkbox{background-position:-164px -4px}.tree-default .tree-checkbox:hover{background-position:-164px -36px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default .tree-checked>.tree-checkbox{background-position:-228px -4px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default .tree-checked>.tree-checkbox:hover{background-position:-228px -36px}.tree-default .tree-anchor>.tree-undetermined{background-position:-196px -4px}.tree-default .tree-anchor>.tree-undetermined:hover{background-position:-196px -36px}.tree-default .tree-checkbox-disabled{opacity:.8;filter:url("data:image/svg+xml;utf8,#tree-grayscale");filter:gray;-webkit-filter:grayscale(100%)}.tree-default>.tree-striped{background-size:auto 48px}.tree-default.tree-rtl .tree-node{background-position:100% 1px;background-repeat:repeat-y}.tree-default.tree-rtl .tree-open>.tree-ocl{background-position:-132px -36px}.tree-default.tree-rtl .tree-closed>.tree-ocl{background-position:-100px -36px}.tree-default.tree-rtl .tree-leaf>.tree-ocl{background-position:-68px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -36px}.tree-default .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default .tree-node.tree-loading{background:none}.tree-default>.tree-container-ul .tree-loading>.tree-ocl{background:url("") 50% no-repeat}.tree-default .tree-file{background:url("") -100px -68px no-repeat}.tree-default .tree-folder{background:url("") -260px -4px no-repeat}.tree-default>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default .tree-ellipsis{overflow:hidden}.tree-default .tree-ellipsis .tree-anchor{width:calc(100% - 29px);text-overflow:ellipsis;overflow:hidden}.tree-default .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default.tree-rtl .tree-node{background-image:url("")}.tree-default.tree-rtl .tree-last{background:transparent}.tree-default-small .tree-node{min-height:18px;line-height:18px;margin-left:24px;min-width:18px}.tree-default-small .tree-anchor{line-height:18px;height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-icon:empty{width:18px;height:18px;line-height:18px}.tree-default-small.tree-rtl .tree-node{margin-right:18px}.tree-default-small .tree-wholerow{height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-node{background-image:url("")}.tree-default-small .tree-node{background-position:-295px -7px;background-repeat:repeat-y}.tree-default-small .tree-last{background:transparent}.tree-default-small .tree-open>.tree-ocl{background-position:-135px -7px}.tree-default-small .tree-closed>.tree-ocl{background-position:-103px -7px}.tree-default-small .tree-leaf>.tree-ocl{background-position:-71px -7px}.tree-default-small .tree-themeicon{background-position:-263px -7px}.tree-default-small>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small>.tree-no-dots .tree-node{background:transparent}.tree-default-small>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -7px}.tree-default-small>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -7px}.tree-default-small .tree-disabled,.tree-default-small .tree-disabled.tree-hovered{background:transparent}.tree-default-small .tree-disabled.tree-selected{background:#efefef}.tree-default-small .tree-checkbox{background-position:-167px -7px}.tree-default-small .tree-checkbox:hover{background-position:-167px -39px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-small .tree-checked>.tree-checkbox{background-position:-231px -7px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-small .tree-checked>.tree-checkbox:hover{background-position:-231px -39px}.tree-default-small .tree-anchor>.tree-undetermined{background-position:-199px -7px}.tree-default-small .tree-anchor>.tree-undetermined:hover{background-position:-199px -39px}.tree-default-small .tree-checkbox-disabled{opacity:.8;filter:url("data:image/svg+xml;utf8,#tree-grayscale");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-small>.tree-striped{background-size:auto 36px}.tree-default-small.tree-rtl .tree-node{background-image:url("");background-position:100% 1px;background-repeat:repeat-y}.tree-default-small.tree-rtl .tree-open>.tree-ocl{background-position:-135px -39px}.tree-default-small.tree-rtl .tree-closed>.tree-ocl{background-position:-103px -39px}.tree-default-small.tree-rtl .tree-leaf>.tree-ocl{background-position:-71px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-small.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -39px}.tree-default-small .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-small .tree-node.tree-loading{background:none}.tree-default-small>.tree-container-ul .tree-loading>.tree-ocl{background:url("") 50% no-repeat}.tree-default-small .tree-file{background:url("") -103px -71px no-repeat}.tree-default-small .tree-folder{background:url("") -263px -7px no-repeat}.tree-default-small>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-small .tree-ellipsis{overflow:hidden}.tree-default-small .tree-ellipsis .tree-anchor{width:calc(100% - 23px);text-overflow:ellipsis;overflow:hidden}.tree-default-small .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-small.tree-rtl .tree-node{background-image:url("")}.tree-default-small.tree-rtl .tree-last{background:transparent}.tree-default-large .tree-node{min-height:32px;line-height:32px;margin-left:38px;min-width:32px}.tree-default-large .tree-anchor{line-height:32px;height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-icon:empty{width:32px;height:32px;line-height:32px}.tree-default-large.tree-rtl .tree-node{margin-right:32px}.tree-default-large .tree-wholerow{height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-node{background-image:url("")}.tree-default-large .tree-node{background-position:-288px 0;background-repeat:repeat-y}.tree-default-large .tree-last{background:transparent}.tree-default-large .tree-open>.tree-ocl{background-position:-128px 0}.tree-default-large .tree-closed>.tree-ocl{background-position:-96px 0}.tree-default-large .tree-leaf>.tree-ocl{background-position:-64px 0}.tree-default-large .tree-themeicon{background-position:-256px 0}.tree-default-large>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large>.tree-no-dots .tree-node{background:transparent}.tree-default-large>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px 0}.tree-default-large>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 0}.tree-default-large .tree-disabled,.tree-default-large .tree-disabled.tree-hovered{background:transparent}.tree-default-large .tree-disabled.tree-selected{background:#efefef}.tree-default-large .tree-checkbox{background-position:-160px 0}.tree-default-large .tree-checkbox:hover{background-position:-160px -32px}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-large .tree-checked>.tree-checkbox{background-position:-224px 0}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-large .tree-checked>.tree-checkbox:hover{background-position:-224px -32px}.tree-default-large .tree-anchor>.tree-undetermined{background-position:-192px 0}.tree-default-large .tree-anchor>.tree-undetermined:hover{background-position:-192px -32px}.tree-default-large .tree-checkbox-disabled{opacity:.8;filter:url("data:image/svg+xml;utf8,#tree-grayscale");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-large>.tree-striped{background-size:auto 64px}.tree-default-large.tree-rtl .tree-node{background-image:url("");background-position:100% 1px;background-repeat:repeat-y}.tree-default-large.tree-rtl .tree-open>.tree-ocl{background-position:-128px -32px}.tree-default-large.tree-rtl .tree-closed>.tree-ocl{background-position:-96px -32px}.tree-default-large.tree-rtl .tree-leaf>.tree-ocl{background-position:-64px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-large.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 -32px}.tree-default-large .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-large .tree-node.tree-loading{background:none}.tree-default-large>.tree-container-ul .tree-loading>.tree-ocl{background:url("") 50% no-repeat}.tree-default-large .tree-file{background:url("") -96px -64px no-repeat}.tree-default-large .tree-folder{background:url("") -256px 0 no-repeat}.tree-default-large>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-large .tree-ellipsis{overflow:hidden}.tree-default-large .tree-ellipsis .tree-anchor{width:calc(100% - 37px);text-overflow:ellipsis;overflow:hidden}.tree-default-large .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-large.tree-rtl .tree-node{background-image:url("")}.tree-default-large.tree-rtl .tree-last{background:transparent}',""])},function(e,A){e.exports=function(){var e=[];return e.toString=function(){for(var e=[],A=0;At.parts.length&&(r.parts.length=t.parts.length)}else{for(var a=[],n=0;n -1;\n } },\n showCheckbox: { type: Boolean, default: false },\n wholeRow: { type: Boolean, default: false },\n noDots: { type: Boolean, default: false },\n collapse: { type: Boolean, default: false },\n multiple: { type: Boolean, default: false },\n allowBatch: { type: Boolean, default: false },\n allowTransition: { type: Boolean, default: true },\n textFieldName: { type: String, default: 'text' },\n valueFieldName: { type: String, default: 'value' },\n childrenFieldName: { type: String, default: 'children' },\n itemEvents: {\n type: Object, default: function _default() {\n return {};\n }\n },\n async: { type: Function },\n loadingText: { type: String, default: 'Loading...' },\n draggable: { type: Boolean, default: false },\n dragOverBackgroundColor: { type: String, default: \"#C9FDC9\" },\n klass: String\n },\n data: function data() {\n return {\n draggedItem: undefined,\n draggedElm: undefined\n };\n },\n\n computed: {\n classes: function classes() {\n return [{ 'tree': true }, { 'tree-default': !this.size }, _defineProperty({}, 'tree-default-' + this.size, !!this.size), { 'tree-checkbox-selection': !!this.showCheckbox }, _defineProperty({}, this.klass, !!this.klass)];\n },\n containerClasses: function containerClasses() {\n return [{ 'tree-container-ul': true }, { 'tree-children': true }, { 'tree-wholerow-ul': !!this.wholeRow }, { 'tree-no-dots': !!this.noDots }];\n },\n sizeHeight: function sizeHeight() {\n switch (this.size) {\n case 'large':\n return ITEM_HEIGHT_LARGE;\n case 'small':\n return ITEM_HEIGHT_SMALL;\n default:\n return ITEM_HEIGHT_DEFAULT;\n }\n }\n },\n methods: {\n initializeData: function initializeData(items) {\n if (items && items.length > 0) {\n for (var i in items) {\n var dataItem = this.initializeDataItem(items[i]);\n items[i] = dataItem;\n this.initializeData(items[i][this.childrenFieldName]);\n }\n }\n },\n initializeDataItem: function initializeDataItem(item) {\n function Model(item, textFieldName, valueFieldName, childrenFieldName, collapse) {\n this.id = item.id || ITEM_ID++;\n this[textFieldName] = item[textFieldName] || '';\n this[valueFieldName] = item[valueFieldName] || item[textFieldName];\n this.icon = item.icon || '';\n this.opened = item.opened || collapse;\n this.selected = item.selected || false;\n this.disabled = item.disabled || false;\n this.loading = item.loading || false;\n this[childrenFieldName] = item[childrenFieldName] || [];\n }\n\n var node = Object.assign(new Model(item, this.textFieldName, this.valueFieldName, this.childrenFieldName, this.collapse), item);\n var self = this;\n node.addBefore = function (data, selectedNode) {\n var newItem = self.initializeDataItem(data);\n var index = selectedNode.parentItem.findIndex(function (t) {\n return t.id === node.id;\n });\n selectedNode.parentItem.splice(index, 0, newItem);\n };\n node.addAfter = function (data, selectedNode) {\n var newItem = self.initializeDataItem(data);\n var index = selectedNode.parentItem.findIndex(function (t) {\n return t.id === node.id;\n }) + 1;\n selectedNode.parentItem.splice(index, 0, newItem);\n };\n node.addChild = function (data) {\n var newItem = self.initializeDataItem(data);\n node.opened = true;\n node[self.childrenFieldName].push(newItem);\n };\n node.openChildren = function () {\n node.opened = true;\n self.handleRecursionNodeChildren(node, function (node) {\n node.opened = true;\n });\n };\n node.closeChildren = function () {\n node.opened = false;\n self.handleRecursionNodeChildren(node, function (node) {\n node.opened = false;\n });\n };\n return node;\n },\n initializeLoading: function initializeLoading() {\n var item = {};\n item[this.textFieldName] = this.loadingText;\n item.disabled = true;\n item.loading = true;\n return this.initializeDataItem(item);\n },\n handleRecursionNodeChilds: function handleRecursionNodeChilds(node, func) {\n if (func(node) !== false) {\n if (node.$children && node.$children.length > 0) {\n var _iteratorNormalCompletion = true;\n var _didIteratorError = false;\n var _iteratorError = undefined;\n\n try {\n for (var _iterator = node.$children[Symbol.iterator](), _step; !(_iteratorNormalCompletion = (_step = _iterator.next()).done); _iteratorNormalCompletion = true) {\n var childNode = _step.value;\n\n if (!childNode.disabled) {\n this.handleRecursionNodeChilds(childNode, func);\n }\n }\n } catch (err) {\n _didIteratorError = true;\n _iteratorError = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion && _iterator.return) {\n _iterator.return();\n }\n } finally {\n if (_didIteratorError) {\n throw _iteratorError;\n }\n }\n }\n }\n }\n },\n handleRecursionNodeChildren: function handleRecursionNodeChildren(node, func) {\n if (func(node) !== false) {\n if (node[this.childrenFieldName] && node[this.childrenFieldName].length > 0) {\n var _iteratorNormalCompletion2 = true;\n var _didIteratorError2 = false;\n var _iteratorError2 = undefined;\n\n try {\n for (var _iterator2 = node[this.childrenFieldName][Symbol.iterator](), _step2; !(_iteratorNormalCompletion2 = (_step2 = _iterator2.next()).done); _iteratorNormalCompletion2 = true) {\n var childNode = _step2.value;\n\n this.handleRecursionNodeChildren(childNode, func);\n }\n } catch (err) {\n _didIteratorError2 = true;\n _iteratorError2 = err;\n } finally {\n try {\n if (!_iteratorNormalCompletion2 && _iterator2.return) {\n _iterator2.return();\n }\n } finally {\n if (_didIteratorError2) {\n throw _iteratorError2;\n }\n }\n }\n }\n }\n },\n onItemClick: function onItemClick(oriNode, oriItem, e) {\n if (this.multiple) {\n if (this.allowBatch) {\n this.handleBatchSelectItems(oriNode, oriItem);\n }\n } else {\n this.handleSingleSelectItems(oriNode, oriItem);\n }\n this.$emit('item-click', oriNode, oriItem, e);\n },\n handleSingleSelectItems: function handleSingleSelectItems(oriNode, oriItem) {\n this.handleRecursionNodeChilds(this, function (node) {\n if (node.model) node.model.selected = false;\n });\n oriNode.model.selected = true;\n },\n handleBatchSelectItems: function handleBatchSelectItems(oriNode, oriItem) {\n this.handleRecursionNodeChilds(oriNode, function (node) {\n if (node.model.disabled) return;\n node.model.selected = oriNode.model.selected;\n });\n },\n onItemToggle: function onItemToggle(oriNode, oriItem, e) {\n if (oriNode.model.opened) {\n this.handleAsyncLoad(oriNode.model[this.childrenFieldName], oriNode, oriItem);\n }\n this.$emit('item-toggle', oriNode, oriItem, e);\n },\n handleAsyncLoad: function handleAsyncLoad(oriParent, oriNode, oriItem) {\n var self = this;\n if (this.async) {\n if (oriParent[0].loading) {\n this.async(oriNode, function (data) {\n if (data.length > 0) {\n for (var i in data) {\n if (!data[i].isLeaf) {\n if (_typeof(data[i][self.childrenFieldName]) !== \"object\") {\n data[i][self.childrenFieldName] = [self.initializeLoading()];\n }\n }\n var dataItem = self.initializeDataItem(data[i]);\n self.$set(oriParent, i, dataItem);\n }\n } else {\n oriNode.model[self.childrenFieldName] = [];\n }\n });\n }\n }\n },\n onItemDragStart: function onItemDragStart(e, oriNode, oriItem) {\n if (!this.draggable || oriItem.dragDisabled) return false;\n e.dataTransfer.effectAllowed = \"move\";\n e.dataTransfer.setData('text', null);\n this.draggedElm = e.target;\n this.draggedItem = {\n item: oriItem,\n parentItem: oriNode.parentItem,\n index: oriNode.parentItem.findIndex(function (t) {\n return t.id === oriItem.id;\n })\n };\n\n this.$emit(\"item-drag-start\", oriNode, oriItem, e);\n },\n onItemDragEnd: function onItemDragEnd(e, oriNode, oriItem) {\n this.draggedItem = undefined;\n this.draggedElm = undefined;\n this.$emit(\"item-drag-end\", oriNode, oriItem, e);\n },\n onItemDrop: function onItemDrop(e, oriNode, oriItem) {\n var _this = this;\n\n if (!this.draggable || !!oriItem.dropDisabled) return false;\n this.$emit(\"item-drop-before\", oriNode, oriItem, !this.draggedItem ? undefined : this.draggedItem.item, e);\n if (!this.draggedElm || this.draggedElm === e.target || this.draggedElm.contains(e.target)) {\n return;\n }\n if (this.draggedItem) {\n if (this.draggedItem.parentItem === oriItem[this.childrenFieldName] || this.draggedItem.item === oriItem || oriItem[this.childrenFieldName] && oriItem[this.childrenFieldName].findIndex(function (t) {\n return t.id === _this.draggedItem.item.id;\n }) !== -1) {\n return;\n }\n if (!!oriItem[this.childrenFieldName]) {\n oriItem[this.childrenFieldName].push(this.draggedItem.item);\n } else {\n oriItem[this.childrenFieldName] = [this.draggedItem.item];\n }\n oriItem.opened = true;\n var draggedItem = this.draggedItem;\n this.$nextTick(function () {\n draggedItem.parentItem.splice(draggedItem.index, 1);\n });\n this.$emit(\"item-drop\", oriNode, oriItem, draggedItem.item, e);\n }\n }\n },\n created: function created() {\n this.initializeData(this.data);\n },\n mounted: function mounted() {\n if (this.async) {\n this.$set(this.data, 0, this.initializeLoading());\n this.handleAsyncLoad(this.data, this);\n }\n },\n\n components: {\n TreeItem: __WEBPACK_IMPORTED_MODULE_0__tree_item_vue___default.a\n }\n});\n\n/***/ }),\n/* 4 */\n/***/ (function(module, __webpack_exports__, __webpack_require__) {\n\n\"use strict\";\nObject.defineProperty(__webpack_exports__, \"__esModule\", { value: true });\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__tree_vue__ = __webpack_require__(1);\n/* harmony import */ var __WEBPACK_IMPORTED_MODULE_0__tree_vue___default = __webpack_require__.n(__WEBPACK_IMPORTED_MODULE_0__tree_vue__);\n/**\r\n * Created by virus_zhh on 2017/9/29.\r\n */\n\n\n__WEBPACK_IMPORTED_MODULE_0__tree_vue___default.a.install = function (Vue) {\n Vue.component(__WEBPACK_IMPORTED_MODULE_0__tree_vue___default.a.name, __WEBPACK_IMPORTED_MODULE_0__tree_vue___default.a);\n};\n\nif (typeof window !== 'undefined' && window.Vue) {\n window.Vue.use(__WEBPACK_IMPORTED_MODULE_0__tree_vue___default.a);\n}\n\n/* harmony default export */ __webpack_exports__[\"default\"] = (__WEBPACK_IMPORTED_MODULE_0__tree_vue___default.a);\n\n/***/ }),\n/* 5 */\n/***/ (function(module, exports, __webpack_require__) {\n\nexports = module.exports = __webpack_require__(6)();\n// imports\n\n\n// module\nexports.push([module.i, \".tree-children,.tree-container-ul,.tree-node{display:block;margin:0;padding:0;list-style-type:none;list-style-image:none}.tree-children{overflow:hidden}.tree-anchor,.tree-node{white-space:nowrap}.tree-anchor{display:inline-block;color:#000;padding:0 4px 0 1px;margin:0;vertical-align:top;font-size:14px;cursor:pointer}.tree-anchor:focus{outline:0}.tree-anchor,.tree-anchor:active,.tree-anchor:hover,.tree-anchor:link,.tree-anchor:visited{text-decoration:none;color:inherit}.tree-icon,.tree-icon:empty{display:inline-block;text-decoration:none;margin:0;padding:0;vertical-align:top;text-align:center}.tree-ocl{cursor:pointer}.tree-leaf>.tree-ocl{cursor:default}.tree-anchor>.tree-themeicon{margin-right:2px}.tree-anchor>.tree-themeicon-hidden,.tree-hidden,.tree-no-icons .tree-themeicon,.tree-node.tree-hidden{display:none}.tree-rtl .tree-anchor{padding:0 1px 0 4px}.tree-rtl .tree-anchor>.tree-themeicon{margin-left:2px;margin-right:0}.tree-rtl .tree-node{margin-left:0}.tree-rtl .tree-container-ul>.tree-node{margin-right:0}.tree-wholerow-ul{position:relative;display:inline-block;min-width:100%}.tree-wholerow-ul .tree-leaf>.tree-ocl{cursor:pointer}.tree-wholerow-ul .tree-anchor,.tree-wholerow-ul .tree-icon{position:relative}.tree-wholerow-ul .tree-wholerow{width:100%;cursor:pointer;z-index:-1;position:absolute;left:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.tree{text-align:left}.tree-default .tree-icon,.tree-default .tree-node{background-repeat:no-repeat;background-color:transparent}.tree-default .tree-anchor,.tree-default .tree-animated,.tree-default .tree-wholerow{transition:background-color .15s,box-shadow .15s}.tree-default .tree-context,.tree-default .tree-hovered{background:#eee;border:0;box-shadow:none}.tree-default .tree-selected{background:#e1e1e1;border:0;box-shadow:none}.tree-default .tree-no-icons .tree-anchor>.tree-themeicon{display:none}.tree-default .tree-disabled{color:#666}.tree-default .tree-disabled.tree-hovered{box-shadow:none}.tree-default .tree-disabled>.tree-icon{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default .tree-search{font-style:italic;color:#8b0000;font-weight:700}.tree-default .tree-no-checkboxes .tree-checkbox{display:none!important}.tree-default.tree-checkbox-no-clicked .tree-selected{background:transparent;box-shadow:none}.tree-default.tree-checkbox-no-clicked .tree-selected.tree-hovered{background:#eee}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked{background:transparent}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked.tree-wholerow-hovered{background:#eee}.tree-default>.tree-striped{min-width:100%;display:inline-block;background:url(\\\"\\\") 0 0 repeat}.tree-default>.tree-wholerow-ul .tree-hovered,.tree-default>.tree-wholerow-ul .tree-selected{background:transparent;box-shadow:none;border-radius:0}.tree-default .tree-wholerow{box-sizing:border-box}.tree-default .tree-wholerow-hovered{background:#eee}.tree-default .tree-wholerow-clicked{background:#e1e1e1}.tree-default .tree-node{min-height:24px;line-height:24px;margin-left:30px;min-width:24px}.tree-default .tree-anchor,.tree-default .tree-icon{line-height:24px;height:24px}.tree-default .tree-icon{width:24px}.tree-default .tree-icon:empty{width:24px;height:24px;line-height:24px}.tree-default.tree-rtl .tree-node{margin-right:24px}.tree-default .tree-wholerow{height:24px}.tree-default .tree-icon,.tree-default .tree-node{background-image:url(\\\"\\\")}.tree-default .tree-node{background-position:-292px -4px;background-repeat:repeat-y}.tree-default .tree-last{background:transparent}.tree-default .tree-open>.tree-ocl{background-position:-132px -4px}.tree-default .tree-closed>.tree-ocl{background-position:-100px -4px}.tree-default .tree-leaf>.tree-ocl{background-position:-68px -4px}.tree-default .tree-themeicon{background-position:-260px -4px}.tree-default>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default>.tree-no-dots .tree-node{background:transparent}.tree-default>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -4px}.tree-default>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -4px}.tree-default .tree-disabled,.tree-default .tree-disabled.tree-hovered{background:transparent}.tree-default .tree-disabled.tree-selected{background:#efefef}.tree-default .tree-checkbox{background-position:-164px -4px}.tree-default .tree-checkbox:hover{background-position:-164px -36px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default .tree-checked>.tree-checkbox{background-position:-228px -4px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default .tree-checked>.tree-checkbox:hover{background-position:-228px -36px}.tree-default .tree-anchor>.tree-undetermined{background-position:-196px -4px}.tree-default .tree-anchor>.tree-undetermined:hover{background-position:-196px -36px}.tree-default .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default>.tree-striped{background-size:auto 48px}.tree-default.tree-rtl .tree-node{background-position:100% 1px;background-repeat:repeat-y}.tree-default.tree-rtl .tree-open>.tree-ocl{background-position:-132px -36px}.tree-default.tree-rtl .tree-closed>.tree-ocl{background-position:-100px -36px}.tree-default.tree-rtl .tree-leaf>.tree-ocl{background-position:-68px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -36px}.tree-default .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default .tree-node.tree-loading{background:none}.tree-default>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default .tree-file{background:url(\\\"\\\") -100px -68px no-repeat}.tree-default .tree-folder{background:url(\\\"\\\") -260px -4px no-repeat}.tree-default>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default .tree-ellipsis{overflow:hidden}.tree-default .tree-ellipsis .tree-anchor{width:calc(100% - 29px);text-overflow:ellipsis;overflow:hidden}.tree-default .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default.tree-rtl .tree-last{background:transparent}.tree-default-small .tree-node{min-height:18px;line-height:18px;margin-left:24px;min-width:18px}.tree-default-small .tree-anchor{line-height:18px;height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-icon:empty{width:18px;height:18px;line-height:18px}.tree-default-small.tree-rtl .tree-node{margin-right:18px}.tree-default-small .tree-wholerow{height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-node{background-image:url(\\\"\\\")}.tree-default-small .tree-node{background-position:-295px -7px;background-repeat:repeat-y}.tree-default-small .tree-last{background:transparent}.tree-default-small .tree-open>.tree-ocl{background-position:-135px -7px}.tree-default-small .tree-closed>.tree-ocl{background-position:-103px -7px}.tree-default-small .tree-leaf>.tree-ocl{background-position:-71px -7px}.tree-default-small .tree-themeicon{background-position:-263px -7px}.tree-default-small>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small>.tree-no-dots .tree-node{background:transparent}.tree-default-small>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -7px}.tree-default-small>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -7px}.tree-default-small .tree-disabled,.tree-default-small .tree-disabled.tree-hovered{background:transparent}.tree-default-small .tree-disabled.tree-selected{background:#efefef}.tree-default-small .tree-checkbox{background-position:-167px -7px}.tree-default-small .tree-checkbox:hover{background-position:-167px -39px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-small .tree-checked>.tree-checkbox{background-position:-231px -7px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-small .tree-checked>.tree-checkbox:hover{background-position:-231px -39px}.tree-default-small .tree-anchor>.tree-undetermined{background-position:-199px -7px}.tree-default-small .tree-anchor>.tree-undetermined:hover{background-position:-199px -39px}.tree-default-small .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-small>.tree-striped{background-size:auto 36px}.tree-default-small.tree-rtl .tree-node{background-image:url(\\\"\\\");background-position:100% 1px;background-repeat:repeat-y}.tree-default-small.tree-rtl .tree-open>.tree-ocl{background-position:-135px -39px}.tree-default-small.tree-rtl .tree-closed>.tree-ocl{background-position:-103px -39px}.tree-default-small.tree-rtl .tree-leaf>.tree-ocl{background-position:-71px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-small.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -39px}.tree-default-small .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-small .tree-node.tree-loading{background:none}.tree-default-small>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default-small .tree-file{background:url(\\\"\\\") -103px -71px no-repeat}.tree-default-small .tree-folder{background:url(\\\"\\\") -263px -7px no-repeat}.tree-default-small>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-small .tree-ellipsis{overflow:hidden}.tree-default-small .tree-ellipsis .tree-anchor{width:calc(100% - 23px);text-overflow:ellipsis;overflow:hidden}.tree-default-small .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-small.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default-small.tree-rtl .tree-last{background:transparent}.tree-default-large .tree-node{min-height:32px;line-height:32px;margin-left:38px;min-width:32px}.tree-default-large .tree-anchor{line-height:32px;height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-icon:empty{width:32px;height:32px;line-height:32px}.tree-default-large.tree-rtl .tree-node{margin-right:32px}.tree-default-large .tree-wholerow{height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-node{background-image:url(\\\"\\\")}.tree-default-large .tree-node{background-position:-288px 0;background-repeat:repeat-y}.tree-default-large .tree-last{background:transparent}.tree-default-large .tree-open>.tree-ocl{background-position:-128px 0}.tree-default-large .tree-closed>.tree-ocl{background-position:-96px 0}.tree-default-large .tree-leaf>.tree-ocl{background-position:-64px 0}.tree-default-large .tree-themeicon{background-position:-256px 0}.tree-default-large>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large>.tree-no-dots .tree-node{background:transparent}.tree-default-large>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px 0}.tree-default-large>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 0}.tree-default-large .tree-disabled,.tree-default-large .tree-disabled.tree-hovered{background:transparent}.tree-default-large .tree-disabled.tree-selected{background:#efefef}.tree-default-large .tree-checkbox{background-position:-160px 0}.tree-default-large .tree-checkbox:hover{background-position:-160px -32px}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-large .tree-checked>.tree-checkbox{background-position:-224px 0}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-large .tree-checked>.tree-checkbox:hover{background-position:-224px -32px}.tree-default-large .tree-anchor>.tree-undetermined{background-position:-192px 0}.tree-default-large .tree-anchor>.tree-undetermined:hover{background-position:-192px -32px}.tree-default-large .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-large>.tree-striped{background-size:auto 64px}.tree-default-large.tree-rtl .tree-node{background-image:url(\\\"\\\");background-position:100% 1px;background-repeat:repeat-y}.tree-default-large.tree-rtl .tree-open>.tree-ocl{background-position:-128px -32px}.tree-default-large.tree-rtl .tree-closed>.tree-ocl{background-position:-96px -32px}.tree-default-large.tree-rtl .tree-leaf>.tree-ocl{background-position:-64px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-large.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 -32px}.tree-default-large .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-large .tree-node.tree-loading{background:none}.tree-default-large>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default-large .tree-file{background:url(\\\"\\\") -96px -64px no-repeat}.tree-default-large .tree-folder{background:url(\\\"\\\") -256px 0 no-repeat}.tree-default-large>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-large .tree-ellipsis{overflow:hidden}.tree-default-large .tree-ellipsis .tree-anchor{width:calc(100% - 37px);text-overflow:ellipsis;overflow:hidden}.tree-default-large .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-large.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default-large.tree-rtl .tree-last{background:transparent}\", \"\"]);\n\n// exports\n\n\n/***/ }),\n/* 6 */\n/***/ (function(module, exports) {\n\n/*\r\n\tMIT License http://www.opensource.org/licenses/mit-license.php\r\n\tAuthor Tobias Koppers @sokra\r\n*/\r\n// css base code, injected by the css-loader\r\nmodule.exports = function() {\r\n\tvar list = [];\r\n\r\n\t// return the list of modules as css string\r\n\tlist.toString = function toString() {\r\n\t\tvar result = [];\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar item = this[i];\r\n\t\t\tif(item[2]) {\r\n\t\t\t\tresult.push(\"@media \" + item[2] + \"{\" + item[1] + \"}\");\r\n\t\t\t} else {\r\n\t\t\t\tresult.push(item[1]);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result.join(\"\");\r\n\t};\r\n\r\n\t// import a list of modules into the list\r\n\tlist.i = function(modules, mediaQuery) {\r\n\t\tif(typeof modules === \"string\")\r\n\t\t\tmodules = [[null, modules, \"\"]];\r\n\t\tvar alreadyImportedModules = {};\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar id = this[i][0];\r\n\t\t\tif(typeof id === \"number\")\r\n\t\t\t\talreadyImportedModules[id] = true;\r\n\t\t}\r\n\t\tfor(i = 0; i < modules.length; i++) {\r\n\t\t\tvar item = modules[i];\r\n\t\t\t// skip already imported module\r\n\t\t\t// this implementation is not 100% perfect for weird media query combinations\r\n\t\t\t// when a module is imported multiple times with different media queries.\r\n\t\t\t// I hope this will never occur (Hey this way we have smaller bundles)\r\n\t\t\tif(typeof item[0] !== \"number\" || !alreadyImportedModules[item[0]]) {\r\n\t\t\t\tif(mediaQuery && !item[2]) {\r\n\t\t\t\t\titem[2] = mediaQuery;\r\n\t\t\t\t} else if(mediaQuery) {\r\n\t\t\t\t\titem[2] = \"(\" + item[2] + \") and (\" + mediaQuery + \")\";\r\n\t\t\t\t}\r\n\t\t\t\tlist.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n\treturn list;\r\n};\r\n\n\n/***/ }),\n/* 7 */\n/***/ (function(module, exports, __webpack_require__) {\n\nvar Component = __webpack_require__(0)(\n /* script */\n __webpack_require__(2),\n /* template */\n __webpack_require__(8),\n /* styles */\n null,\n /* scopeId */\n null,\n /* moduleIdentifier (server only) */\n null\n)\n\nmodule.exports = Component.exports\n\n\n/***/ }),\n/* 8 */\n/***/ (function(module, exports) {\n\nmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('li', {\n class: _vm.classes,\n attrs: {\n \"role\": \"treeitem\",\n \"draggable\": _vm.draggable\n },\n on: {\n \"dragstart\": function($event) {\n $event.stopPropagation();\n _vm.onItemDragStart($event, _vm._self, _vm._self.model)\n },\n \"dragend\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.onItemDragEnd($event, _vm._self, _vm._self.model)\n },\n \"dragover\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = true\n },\n \"dragenter\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = true\n },\n \"dragleave\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = false\n },\n \"drop\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.handleItemDrop($event, _vm._self, _vm._self.model)\n }\n }\n }, [(_vm.isWholeRow) ? _c('div', {\n class: _vm.wholeRowClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }, [_vm._v(\" \")]) : _vm._e(), _vm._v(\" \"), _c('i', {\n staticClass: \"tree-icon tree-ocl\",\n attrs: {\n \"role\": \"presentation\"\n },\n on: {\n \"click\": _vm.handleItemToggle\n }\n }), _vm._v(\" \"), _c('div', _vm._g({\n class: _vm.anchorClasses\n }, _vm.events), [(_vm.showCheckbox && !_vm.model.loading) ? _c('i', {\n staticClass: \"tree-icon tree-checkbox\",\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _vm._t(\"default\", [(!_vm.model.loading) ? _c('i', {\n class: _vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.model[_vm.textFieldName])\n }\n })], {\n vm: this,\n model: _vm.model\n })], 2), _vm._v(\" \"), (_vm.isFolder) ? _c('ul', {\n ref: \"group\",\n staticClass: \"tree-children\",\n style: (_vm.groupStyle),\n attrs: {\n \"role\": \"group\"\n }\n }, _vm._l((_vm.model[_vm.childrenFieldName]), function(child, index) {\n return _c('tree-item', {\n key: index,\n attrs: {\n \"data\": child,\n \"text-field-name\": _vm.textFieldName,\n \"value-field-name\": _vm.valueFieldName,\n \"children-field-name\": _vm.childrenFieldName,\n \"item-events\": _vm.itemEvents,\n \"whole-row\": _vm.wholeRow,\n \"show-checkbox\": _vm.showCheckbox,\n \"allow-transition\": _vm.allowTransition,\n \"height\": _vm.height,\n \"parent-item\": _vm.model[_vm.childrenFieldName],\n \"draggable\": _vm.draggable,\n \"drag-over-background-color\": _vm.dragOverBackgroundColor,\n \"on-item-click\": _vm.onItemClick,\n \"on-item-toggle\": _vm.onItemToggle,\n \"on-item-drag-start\": _vm.onItemDragStart,\n \"on-item-drag-end\": _vm.onItemDragEnd,\n \"on-item-drop\": _vm.onItemDrop,\n \"klass\": index === _vm.model[_vm.childrenFieldName].length - 1 ? 'tree-last' : ''\n },\n scopedSlots: _vm._u([{\n key: \"default\",\n fn: function(_) {\n return [_vm._t(\"default\", [(!_vm.model.loading) ? _c('i', {\n class: _.vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_.model[_vm.textFieldName])\n }\n })], {\n vm: _.vm,\n model: _.model\n })]\n }\n }])\n })\n })) : _vm._e()])\n},staticRenderFns: []}\n\n/***/ }),\n/* 9 */\n/***/ (function(module, exports) {\n\nmodule.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n class: _vm.classes,\n attrs: {\n \"role\": \"tree\",\n \"onselectstart\": \"return false\"\n }\n }, [_c('ul', {\n class: _vm.containerClasses,\n attrs: {\n \"role\": \"group\"\n }\n }, _vm._l((_vm.data), function(child, index) {\n return _c('tree-item', {\n key: index,\n attrs: {\n \"data\": child,\n \"text-field-name\": _vm.textFieldName,\n \"value-field-name\": _vm.valueFieldName,\n \"children-field-name\": _vm.childrenFieldName,\n \"item-events\": _vm.itemEvents,\n \"whole-row\": _vm.wholeRow,\n \"show-checkbox\": _vm.showCheckbox,\n \"allow-transition\": _vm.allowTransition,\n \"height\": _vm.sizeHeight,\n \"parent-item\": _vm.data,\n \"draggable\": _vm.draggable,\n \"drag-over-background-color\": _vm.dragOverBackgroundColor,\n \"on-item-click\": _vm.onItemClick,\n \"on-item-toggle\": _vm.onItemToggle,\n \"on-item-drag-start\": _vm.onItemDragStart,\n \"on-item-drag-end\": _vm.onItemDragEnd,\n \"on-item-drop\": _vm.onItemDrop,\n \"klass\": index === _vm.data.length - 1 ? 'tree-last' : ''\n },\n scopedSlots: _vm._u([{\n key: \"default\",\n fn: function(_) {\n return [_vm._t(\"default\", [(!_.model.loading) ? _c('i', {\n class: _.vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_.model[_vm.textFieldName])\n }\n })], {\n vm: _.vm,\n model: _.model\n })]\n }\n }])\n })\n }))])\n},staticRenderFns: []}\n\n/***/ }),\n/* 10 */\n/***/ (function(module, exports, __webpack_require__) {\n\n// style-loader: Adds some css to the DOM by adding a \r\n\n\n\n// WEBPACK FOOTER //\n// tree.vue?0e418d98","/**\r\n * Created by virus_zhh on 2017/9/29.\r\n */\r\nimport VJstree from './tree.vue'\r\n\r\nVJstree.install = function(Vue){\r\n Vue.component(VJstree.name, VJstree)\r\n}\r\n\r\nif (typeof window !== 'undefined' && window.Vue) {\r\n window.Vue.use(VJstree);\r\n}\r\n\r\nexport default VJstree\n\n\n// WEBPACK FOOTER //\n// ./src/index.js","exports = module.exports = require(\"../node_modules/css-loader/lib/css-base.js\")();\n// imports\n\n\n// module\nexports.push([module.id, \".tree-children,.tree-container-ul,.tree-node{display:block;margin:0;padding:0;list-style-type:none;list-style-image:none}.tree-children{overflow:hidden}.tree-anchor,.tree-node{white-space:nowrap}.tree-anchor{display:inline-block;color:#000;padding:0 4px 0 1px;margin:0;vertical-align:top;font-size:14px;cursor:pointer}.tree-anchor:focus{outline:0}.tree-anchor,.tree-anchor:active,.tree-anchor:hover,.tree-anchor:link,.tree-anchor:visited{text-decoration:none;color:inherit}.tree-icon,.tree-icon:empty{display:inline-block;text-decoration:none;margin:0;padding:0;vertical-align:top;text-align:center}.tree-ocl{cursor:pointer}.tree-leaf>.tree-ocl{cursor:default}.tree-anchor>.tree-themeicon{margin-right:2px}.tree-anchor>.tree-themeicon-hidden,.tree-hidden,.tree-no-icons .tree-themeicon,.tree-node.tree-hidden{display:none}.tree-rtl .tree-anchor{padding:0 1px 0 4px}.tree-rtl .tree-anchor>.tree-themeicon{margin-left:2px;margin-right:0}.tree-rtl .tree-node{margin-left:0}.tree-rtl .tree-container-ul>.tree-node{margin-right:0}.tree-wholerow-ul{position:relative;display:inline-block;min-width:100%}.tree-wholerow-ul .tree-leaf>.tree-ocl{cursor:pointer}.tree-wholerow-ul .tree-anchor,.tree-wholerow-ul .tree-icon{position:relative}.tree-wholerow-ul .tree-wholerow{width:100%;cursor:pointer;z-index:-1;position:absolute;left:0;-webkit-user-select:none;-moz-user-select:none;-ms-user-select:none;user-select:none}.tree{text-align:left}.tree-default .tree-icon,.tree-default .tree-node{background-repeat:no-repeat;background-color:transparent}.tree-default .tree-anchor,.tree-default .tree-animated,.tree-default .tree-wholerow{transition:background-color .15s,box-shadow .15s}.tree-default .tree-context,.tree-default .tree-hovered{background:#eee;border:0;box-shadow:none}.tree-default .tree-selected{background:#e1e1e1;border:0;box-shadow:none}.tree-default .tree-no-icons .tree-anchor>.tree-themeicon{display:none}.tree-default .tree-disabled{color:#666}.tree-default .tree-disabled.tree-hovered{box-shadow:none}.tree-default .tree-disabled>.tree-icon{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default .tree-search{font-style:italic;color:#8b0000;font-weight:700}.tree-default .tree-no-checkboxes .tree-checkbox{display:none!important}.tree-default.tree-checkbox-no-clicked .tree-selected{background:transparent;box-shadow:none}.tree-default.tree-checkbox-no-clicked .tree-selected.tree-hovered{background:#eee}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked{background:transparent}.tree-default.tree-checkbox-no-clicked>.tree-wholerow-ul .tree-wholerow-clicked.tree-wholerow-hovered{background:#eee}.tree-default>.tree-striped{min-width:100%;display:inline-block;background:url(\\\"\\\") 0 0 repeat}.tree-default>.tree-wholerow-ul .tree-hovered,.tree-default>.tree-wholerow-ul .tree-selected{background:transparent;box-shadow:none;border-radius:0}.tree-default .tree-wholerow{box-sizing:border-box}.tree-default .tree-wholerow-hovered{background:#eee}.tree-default .tree-wholerow-clicked{background:#e1e1e1}.tree-default .tree-node{min-height:24px;line-height:24px;margin-left:30px;min-width:24px}.tree-default .tree-anchor,.tree-default .tree-icon{line-height:24px;height:24px}.tree-default .tree-icon{width:24px}.tree-default .tree-icon:empty{width:24px;height:24px;line-height:24px}.tree-default.tree-rtl .tree-node{margin-right:24px}.tree-default .tree-wholerow{height:24px}.tree-default .tree-icon,.tree-default .tree-node{background-image:url(\\\"\\\")}.tree-default .tree-node{background-position:-292px -4px;background-repeat:repeat-y}.tree-default .tree-last{background:transparent}.tree-default .tree-open>.tree-ocl{background-position:-132px -4px}.tree-default .tree-closed>.tree-ocl{background-position:-100px -4px}.tree-default .tree-leaf>.tree-ocl{background-position:-68px -4px}.tree-default .tree-themeicon{background-position:-260px -4px}.tree-default>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default>.tree-no-dots .tree-node{background:transparent}.tree-default>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -4px}.tree-default>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -4px}.tree-default .tree-disabled,.tree-default .tree-disabled.tree-hovered{background:transparent}.tree-default .tree-disabled.tree-selected{background:#efefef}.tree-default .tree-checkbox{background-position:-164px -4px}.tree-default .tree-checkbox:hover{background-position:-164px -36px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default .tree-checked>.tree-checkbox{background-position:-228px -4px}.tree-default.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default .tree-checked>.tree-checkbox:hover{background-position:-228px -36px}.tree-default .tree-anchor>.tree-undetermined{background-position:-196px -4px}.tree-default .tree-anchor>.tree-undetermined:hover{background-position:-196px -36px}.tree-default .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default>.tree-striped{background-size:auto 48px}.tree-default.tree-rtl .tree-node{background-position:100% 1px;background-repeat:repeat-y}.tree-default.tree-rtl .tree-open>.tree-ocl{background-position:-132px -36px}.tree-default.tree-rtl .tree-closed>.tree-ocl{background-position:-100px -36px}.tree-default.tree-rtl .tree-leaf>.tree-ocl{background-position:-68px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-36px -36px}.tree-default.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-4px -36px}.tree-default .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default .tree-node.tree-loading{background:none}.tree-default>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default .tree-file{background:url(\\\"\\\") -100px -68px no-repeat}.tree-default .tree-folder{background:url(\\\"\\\") -260px -4px no-repeat}.tree-default>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default .tree-ellipsis{overflow:hidden}.tree-default .tree-ellipsis .tree-anchor{width:calc(100% - 29px);text-overflow:ellipsis;overflow:hidden}.tree-default .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default.tree-rtl .tree-last{background:transparent}.tree-default-small .tree-node{min-height:18px;line-height:18px;margin-left:24px;min-width:18px}.tree-default-small .tree-anchor{line-height:18px;height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-icon:empty{width:18px;height:18px;line-height:18px}.tree-default-small.tree-rtl .tree-node{margin-right:18px}.tree-default-small .tree-wholerow{height:18px}.tree-default-small .tree-icon,.tree-default-small .tree-node{background-image:url(\\\"\\\")}.tree-default-small .tree-node{background-position:-295px -7px;background-repeat:repeat-y}.tree-default-small .tree-last{background:transparent}.tree-default-small .tree-open>.tree-ocl{background-position:-135px -7px}.tree-default-small .tree-closed>.tree-ocl{background-position:-103px -7px}.tree-default-small .tree-leaf>.tree-ocl{background-position:-71px -7px}.tree-default-small .tree-themeicon{background-position:-263px -7px}.tree-default-small>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small>.tree-no-dots .tree-node{background:transparent}.tree-default-small>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -7px}.tree-default-small>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -7px}.tree-default-small .tree-disabled,.tree-default-small .tree-disabled.tree-hovered{background:transparent}.tree-default-small .tree-disabled.tree-selected{background:#efefef}.tree-default-small .tree-checkbox{background-position:-167px -7px}.tree-default-small .tree-checkbox:hover{background-position:-167px -39px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-small .tree-checked>.tree-checkbox{background-position:-231px -7px}.tree-default-small.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-small .tree-checked>.tree-checkbox:hover{background-position:-231px -39px}.tree-default-small .tree-anchor>.tree-undetermined{background-position:-199px -7px}.tree-default-small .tree-anchor>.tree-undetermined:hover{background-position:-199px -39px}.tree-default-small .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-small>.tree-striped{background-size:auto 36px}.tree-default-small.tree-rtl .tree-node{background-image:url(\\\"\\\");background-position:100% 1px;background-repeat:repeat-y}.tree-default-small.tree-rtl .tree-open>.tree-ocl{background-position:-135px -39px}.tree-default-small.tree-rtl .tree-closed>.tree-ocl{background-position:-103px -39px}.tree-default-small.tree-rtl .tree-leaf>.tree-ocl{background-position:-71px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-small.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-small.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-39px -39px}.tree-default-small.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:-7px -39px}.tree-default-small .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-small .tree-node.tree-loading{background:none}.tree-default-small>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default-small .tree-file{background:url(\\\"\\\") -103px -71px no-repeat}.tree-default-small .tree-folder{background:url(\\\"\\\") -263px -7px no-repeat}.tree-default-small>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-small .tree-ellipsis{overflow:hidden}.tree-default-small .tree-ellipsis .tree-anchor{width:calc(100% - 23px);text-overflow:ellipsis;overflow:hidden}.tree-default-small .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-small.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default-small.tree-rtl .tree-last{background:transparent}.tree-default-large .tree-node{min-height:32px;line-height:32px;margin-left:38px;min-width:32px}.tree-default-large .tree-anchor{line-height:32px;height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-icon:empty{width:32px;height:32px;line-height:32px}.tree-default-large.tree-rtl .tree-node{margin-right:32px}.tree-default-large .tree-wholerow{height:32px}.tree-default-large .tree-icon,.tree-default-large .tree-node{background-image:url(\\\"\\\")}.tree-default-large .tree-node{background-position:-288px 0;background-repeat:repeat-y}.tree-default-large .tree-last{background:transparent}.tree-default-large .tree-open>.tree-ocl{background-position:-128px 0}.tree-default-large .tree-closed>.tree-ocl{background-position:-96px 0}.tree-default-large .tree-leaf>.tree-ocl{background-position:-64px 0}.tree-default-large .tree-themeicon{background-position:-256px 0}.tree-default-large>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large>.tree-no-dots .tree-node{background:transparent}.tree-default-large>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px 0}.tree-default-large>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 0}.tree-default-large .tree-disabled,.tree-default-large .tree-disabled.tree-hovered{background:transparent}.tree-default-large .tree-disabled.tree-selected{background:#efefef}.tree-default-large .tree-checkbox{background-position:-160px 0}.tree-default-large .tree-checkbox:hover{background-position:-160px -32px}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox,.tree-default-large .tree-checked>.tree-checkbox{background-position:-224px 0}.tree-default-large.tree-checkbox-selection .tree-selected>.tree-checkbox:hover,.tree-default-large .tree-checked>.tree-checkbox:hover{background-position:-224px -32px}.tree-default-large .tree-anchor>.tree-undetermined{background-position:-192px 0}.tree-default-large .tree-anchor>.tree-undetermined:hover{background-position:-192px -32px}.tree-default-large .tree-checkbox-disabled{opacity:.8;filter:url(\\\"data:image/svg+xml;utf8,#tree-grayscale\\\");filter:gray;-webkit-filter:grayscale(100%)}.tree-default-large>.tree-striped{background-size:auto 64px}.tree-default-large.tree-rtl .tree-node{background-image:url(\\\"\\\");background-position:100% 1px;background-repeat:repeat-y}.tree-default-large.tree-rtl .tree-open>.tree-ocl{background-position:-128px -32px}.tree-default-large.tree-rtl .tree-closed>.tree-ocl{background-position:-96px -32px}.tree-default-large.tree-rtl .tree-leaf>.tree-ocl{background-position:-64px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-leaf>.tree-ocl,.tree-default-large.tree-rtl>.tree-no-dots .tree-node{background:transparent}.tree-default-large.tree-rtl>.tree-no-dots .tree-open>.tree-ocl{background-position:-32px -32px}.tree-default-large.tree-rtl>.tree-no-dots .tree-closed>.tree-ocl{background-position:0 -32px}.tree-default-large .tree-themeicon-custom{background-color:transparent;background-image:none;background-position:0 0}.tree-default-large .tree-node.tree-loading{background:none}.tree-default-large>.tree-container-ul .tree-loading>.tree-ocl{background:url(\\\"\\\") 50% no-repeat}.tree-default-large .tree-file{background:url(\\\"\\\") -96px -64px no-repeat}.tree-default-large .tree-folder{background:url(\\\"\\\") -256px 0 no-repeat}.tree-default-large>.tree-container-ul>.tree-node{margin-left:0;margin-right:0}.tree-default-large .tree-ellipsis{overflow:hidden}.tree-default-large .tree-ellipsis .tree-anchor{width:calc(100% - 37px);text-overflow:ellipsis;overflow:hidden}.tree-default-large .tree-ellipsis.tree-no-icons .tree-anchor{width:calc(100% - 5px)}.tree-default-large.tree-rtl .tree-node{background-image:url(\\\"\\\")}.tree-default-large.tree-rtl .tree-last{background:transparent}\", \"\"]);\n\n// exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/css-loader?minimize!./~/vue-loader/lib/style-compiler?{\"vue\":true,\"id\":\"data-v-7fbf202c\",\"scoped\":false,\"hasInlineConfig\":false}!./~/less-loader/dist/cjs.js!./~/vue-loader/lib/selector.js?type=styles&index=0!./src/tree.vue\n// module id = 5\n// module chunks = 0","/*\r\n\tMIT License http://www.opensource.org/licenses/mit-license.php\r\n\tAuthor Tobias Koppers @sokra\r\n*/\r\n// css base code, injected by the css-loader\r\nmodule.exports = function() {\r\n\tvar list = [];\r\n\r\n\t// return the list of modules as css string\r\n\tlist.toString = function toString() {\r\n\t\tvar result = [];\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar item = this[i];\r\n\t\t\tif(item[2]) {\r\n\t\t\t\tresult.push(\"@media \" + item[2] + \"{\" + item[1] + \"}\");\r\n\t\t\t} else {\r\n\t\t\t\tresult.push(item[1]);\r\n\t\t\t}\r\n\t\t}\r\n\t\treturn result.join(\"\");\r\n\t};\r\n\r\n\t// import a list of modules into the list\r\n\tlist.i = function(modules, mediaQuery) {\r\n\t\tif(typeof modules === \"string\")\r\n\t\t\tmodules = [[null, modules, \"\"]];\r\n\t\tvar alreadyImportedModules = {};\r\n\t\tfor(var i = 0; i < this.length; i++) {\r\n\t\t\tvar id = this[i][0];\r\n\t\t\tif(typeof id === \"number\")\r\n\t\t\t\talreadyImportedModules[id] = true;\r\n\t\t}\r\n\t\tfor(i = 0; i < modules.length; i++) {\r\n\t\t\tvar item = modules[i];\r\n\t\t\t// skip already imported module\r\n\t\t\t// this implementation is not 100% perfect for weird media query combinations\r\n\t\t\t// when a module is imported multiple times with different media queries.\r\n\t\t\t// I hope this will never occur (Hey this way we have smaller bundles)\r\n\t\t\tif(typeof item[0] !== \"number\" || !alreadyImportedModules[item[0]]) {\r\n\t\t\t\tif(mediaQuery && !item[2]) {\r\n\t\t\t\t\titem[2] = mediaQuery;\r\n\t\t\t\t} else if(mediaQuery) {\r\n\t\t\t\t\titem[2] = \"(\" + item[2] + \") and (\" + mediaQuery + \")\";\r\n\t\t\t\t}\r\n\t\t\t\tlist.push(item);\r\n\t\t\t}\r\n\t\t}\r\n\t};\r\n\treturn list;\r\n};\r\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/css-loader/lib/css-base.js\n// module id = 6\n// module chunks = 0","var Component = require(\"!../node_modules/vue-loader/lib/component-normalizer\")(\n /* script */\n require(\"!!babel-loader!../node_modules/vue-loader/lib/selector?type=script&index=0!./tree-item.vue\"),\n /* template */\n require(\"!!../node_modules/vue-loader/lib/template-compiler/index?{\\\"id\\\":\\\"data-v-5c46de44\\\",\\\"hasScoped\\\":false}!../node_modules/vue-loader/lib/selector?type=template&index=0!./tree-item.vue\"),\n /* styles */\n null,\n /* scopeId */\n null,\n /* moduleIdentifier (server only) */\n null\n)\n\nmodule.exports = Component.exports\n\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./src/tree-item.vue\n// module id = 7\n// module chunks = 0","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('li', {\n class: _vm.classes,\n attrs: {\n \"role\": \"treeitem\",\n \"draggable\": _vm.draggable\n },\n on: {\n \"dragstart\": function($event) {\n $event.stopPropagation();\n _vm.onItemDragStart($event, _vm._self, _vm._self.model)\n },\n \"dragend\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.onItemDragEnd($event, _vm._self, _vm._self.model)\n },\n \"dragover\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = true\n },\n \"dragenter\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = true\n },\n \"dragleave\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.isDragEnter = false\n },\n \"drop\": function($event) {\n $event.stopPropagation();\n $event.preventDefault();\n _vm.handleItemDrop($event, _vm._self, _vm._self.model)\n }\n }\n }, [(_vm.isWholeRow) ? _c('div', {\n class: _vm.wholeRowClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }, [_vm._v(\" \")]) : _vm._e(), _vm._v(\" \"), _c('i', {\n staticClass: \"tree-icon tree-ocl\",\n attrs: {\n \"role\": \"presentation\"\n },\n on: {\n \"click\": _vm.handleItemToggle\n }\n }), _vm._v(\" \"), _c('div', _vm._g({\n class: _vm.anchorClasses\n }, _vm.events), [(_vm.showCheckbox && !_vm.model.loading) ? _c('i', {\n staticClass: \"tree-icon tree-checkbox\",\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _vm._t(\"default\", [(!_vm.model.loading) ? _c('i', {\n class: _vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_vm.model[_vm.textFieldName])\n }\n })], {\n vm: this,\n model: _vm.model\n })], 2), _vm._v(\" \"), (_vm.isFolder) ? _c('ul', {\n ref: \"group\",\n staticClass: \"tree-children\",\n style: (_vm.groupStyle),\n attrs: {\n \"role\": \"group\"\n }\n }, _vm._l((_vm.model[_vm.childrenFieldName]), function(child, index) {\n return _c('tree-item', {\n key: index,\n attrs: {\n \"data\": child,\n \"text-field-name\": _vm.textFieldName,\n \"value-field-name\": _vm.valueFieldName,\n \"children-field-name\": _vm.childrenFieldName,\n \"item-events\": _vm.itemEvents,\n \"whole-row\": _vm.wholeRow,\n \"show-checkbox\": _vm.showCheckbox,\n \"allow-transition\": _vm.allowTransition,\n \"height\": _vm.height,\n \"parent-item\": _vm.model[_vm.childrenFieldName],\n \"draggable\": _vm.draggable,\n \"drag-over-background-color\": _vm.dragOverBackgroundColor,\n \"on-item-click\": _vm.onItemClick,\n \"on-item-toggle\": _vm.onItemToggle,\n \"on-item-drag-start\": _vm.onItemDragStart,\n \"on-item-drag-end\": _vm.onItemDragEnd,\n \"on-item-drop\": _vm.onItemDrop,\n \"klass\": index === _vm.model[_vm.childrenFieldName].length - 1 ? 'tree-last' : ''\n },\n scopedSlots: _vm._u([{\n key: \"default\",\n fn: function(_) {\n return [_vm._t(\"default\", [(!_vm.model.loading) ? _c('i', {\n class: _.vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_.model[_vm.textFieldName])\n }\n })], {\n vm: _.vm,\n model: _.model\n })]\n }\n }])\n })\n })) : _vm._e()])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-5c46de44\",\"hasScoped\":false}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/tree-item.vue\n// module id = 8\n// module chunks = 0","module.exports={render:function (){var _vm=this;var _h=_vm.$createElement;var _c=_vm._self._c||_h;\n return _c('div', {\n class: _vm.classes,\n attrs: {\n \"role\": \"tree\",\n \"onselectstart\": \"return false\"\n }\n }, [_c('ul', {\n class: _vm.containerClasses,\n attrs: {\n \"role\": \"group\"\n }\n }, _vm._l((_vm.data), function(child, index) {\n return _c('tree-item', {\n key: index,\n attrs: {\n \"data\": child,\n \"text-field-name\": _vm.textFieldName,\n \"value-field-name\": _vm.valueFieldName,\n \"children-field-name\": _vm.childrenFieldName,\n \"item-events\": _vm.itemEvents,\n \"whole-row\": _vm.wholeRow,\n \"show-checkbox\": _vm.showCheckbox,\n \"allow-transition\": _vm.allowTransition,\n \"height\": _vm.sizeHeight,\n \"parent-item\": _vm.data,\n \"draggable\": _vm.draggable,\n \"drag-over-background-color\": _vm.dragOverBackgroundColor,\n \"on-item-click\": _vm.onItemClick,\n \"on-item-toggle\": _vm.onItemToggle,\n \"on-item-drag-start\": _vm.onItemDragStart,\n \"on-item-drag-end\": _vm.onItemDragEnd,\n \"on-item-drop\": _vm.onItemDrop,\n \"klass\": index === _vm.data.length - 1 ? 'tree-last' : ''\n },\n scopedSlots: _vm._u([{\n key: \"default\",\n fn: function(_) {\n return [_vm._t(\"default\", [(!_.model.loading) ? _c('i', {\n class: _.vm.themeIconClasses,\n attrs: {\n \"role\": \"presentation\"\n }\n }) : _vm._e(), _vm._v(\" \"), _c('span', {\n domProps: {\n \"innerHTML\": _vm._s(_.model[_vm.textFieldName])\n }\n })], {\n vm: _.vm,\n model: _.model\n })]\n }\n }])\n })\n }))])\n},staticRenderFns: []}\n\n\n//////////////////\n// WEBPACK FOOTER\n// ./~/vue-loader/lib/template-compiler?{\"id\":\"data-v-7fbf202c\",\"hasScoped\":false}!./~/vue-loader/lib/selector.js?type=template&index=0!./src/tree.vue\n// module id = 9\n// module chunks = 0","// style-loader: Adds some css to the DOM by adding a - -{% endblock %} - -{% block content %} +{% block content_fluid %}
-
-

{% trans 'Import' %}

- - {% trans 'Bookmark Me!' %} -
- - - - - -
- -
-
- {% if not request.user.is_authenticated or request.user.userpreference.theme == request.user.userpreference.TANDOOR %} - - {% else %} - - {% endif %} -
- - -
-
-
- -
-
-

{% trans 'Preview Recipe Data' %}

-
{% trans 'Drag recipe attributes from the right into the appropriate box below.' %}
-
-
- -
-
-
- {% trans 'Name' %} - -
-
{% trans 'Text dragged here will be appended to the name.' %}
-
- -
-
[[recipe_json.name]]
-
-
-
- -
-
-
- {% trans 'Description' %} - -
-
{% trans 'Text dragged here will be appended to the description.' %}
-
- -
-
[[recipe_json.description]]
-
-
-
- -
-
-
- {% trans 'Keywords' %} - -
-
{% trans 'Keywords dragged here will be appended to current list' %}
-
- -
-
-
[[kw.text]]
-
-
-
-
- -
-
- {% trans 'Image' %} - -
- -
- Recipe Image -
-
-
- -
-
-
-
- {% trans 'Servings' %} - -
-
-
[[recipe_json.servings]]
-
-
-
-
-
-
- {% trans 'Prep Time' %} - -
-
-
[[recipe_json.prepTime]]
-
-
-
-
-
-
- {% trans 'Cook Time' %} - -
-
-
[[recipe_json.cookTime]]
-
-
-
-
- -
-
-
- {% trans 'Ingredients' %} - -
-
{% trans 'Ingredients dragged here will be appended to current list.' %}
-
- -
-
    -
    -
  • -
    [[i.amount]]
    -
    [[i.unit.text]]
    -
    [[i.ingredient.text]]
    -
    [[i.note]]
    -
  • -
    -
-
-
-
- -
-
-
- {% trans 'Instructions' %} - -
-
{% trans 'Recipe instructions dragged here will be appended to current instructions.' %}
-
- -
-
[[recipe_json.recipeInstructions]]
-
-
-
-
-
-
- - -
- - -
-
-
-

{% trans 'Discovered Attributes' %}

-
- {% trans 'Drag recipe attributes from below into the appropriate box on the left. Click any node to display its full properties.' %} -
-
-
- - - -
- -
-
-
-
- {% trans 'Blank Field' %} - -
-
{% trans 'Items dragged to Blank Field will be appended.' %}
-
-
- [[blank_field]] -
-
- - - - - -
-
    -
    - [[txt]] - -
    -
-
- -
-
    -
    - Image - -
    -
-
-
-
-
- -
-
- - - - - +
- - {% endblock %} + + +{% block script %} + {% if debug %} + + {% else %} + + {% endif %} + + + + {% render_bundle 'import_view' %} +{% endblock %} \ No newline at end of file diff --git a/cookbook/views/api.py b/cookbook/views/api.py index 57cb39fa3..06b6e62c1 100644 --- a/cookbook/views/api.py +++ b/cookbook/views/api.py @@ -70,7 +70,7 @@ from cookbook.serializer import (AutomationSerializer, BookmarkletImportSerializ SupermarketCategorySerializer, SupermarketSerializer, SyncLogSerializer, SyncSerializer, UnitSerializer, UserFileSerializer, UserNameSerializer, UserPreferenceSerializer, - ViewLogSerializer, IngredientSimpleSerializer) + ViewLogSerializer, IngredientSimpleSerializer, BookmarkletImportListSerializer) from recipes import settings @@ -974,6 +974,11 @@ class BookmarkletImportViewSet(viewsets.ModelViewSet): serializer_class = BookmarkletImportSerializer permission_classes = [CustomIsUser] + def get_serializer_class(self): + if self.action == 'list': + return BookmarkletImportListSerializer + return self.serializer_class + def get_queryset(self): return self.queryset.filter(space=self.request.space).all() diff --git a/cookbook/views/data.py b/cookbook/views/data.py index 9980744b4..8dd1e969f 100644 --- a/cookbook/views/data.py +++ b/cookbook/views/data.py @@ -10,7 +10,7 @@ from django_tables2 import RequestConfig from rest_framework.authtoken.models import Token from cookbook.forms import BatchEditForm, SyncForm -from cookbook.helper.permission_helper import group_required, has_group_permission +from cookbook.helper.permission_helper import group_required, has_group_permission, above_space_limit from cookbook.models import (Comment, Food, Keyword, Recipe, RecipeImport, Sync, Unit, UserPreference, BookmarkletImport) from cookbook.tables import SyncTable @@ -19,12 +19,9 @@ from recipes import settings @group_required('user') def sync(request): - if request.space.max_recipes != 0 and Recipe.objects.filter(space=request.space).count() >= request.space.max_recipes: # TODO move to central helper function - messages.add_message(request, messages.WARNING, _('You have reached the maximum number of recipes for your space.')) - return HttpResponseRedirect(reverse('index')) - - if request.space.max_users != 0 and UserPreference.objects.filter(space=request.space).count() > request.space.max_users: - messages.add_message(request, messages.WARNING, _('You have more users than allowed in your space.')) + limit, msg = above_space_limit(request.space) + if limit: + messages.add_message(request, messages.WARNING, msg) return HttpResponseRedirect(reverse('index')) if request.space.demo or settings.HOSTED: @@ -113,12 +110,9 @@ def batch_edit(request): @group_required('user') def import_url(request): - if request.space.max_recipes != 0 and Recipe.objects.filter(space=request.space).count() >= request.space.max_recipes: # TODO move to central helper function - messages.add_message(request, messages.WARNING, _('You have reached the maximum number of recipes for your space.')) - return HttpResponseRedirect(reverse('index')) - - if request.space.max_users != 0 and UserPreference.objects.filter(space=request.space).count() > request.space.max_users: - messages.add_message(request, messages.WARNING, _('You have more users than allowed in your space.')) + limit, msg = above_space_limit(request.space) + if limit: + messages.add_message(request, messages.WARNING, msg) return HttpResponseRedirect(reverse('index')) if (api_token := Token.objects.filter(user=request.user).first()) is None: @@ -129,7 +123,7 @@ def import_url(request): if bookmarklet_import := BookmarkletImport.objects.filter(id=request.GET['id']).first(): bookmarklet_import_id = bookmarklet_import.pk - return render(request, 'test.html', {'api_token': api_token, 'bookmarklet_import_id': bookmarklet_import_id}) + return render(request, 'url_import.html', {'api_token': api_token, 'bookmarklet_import_id': bookmarklet_import_id}) class Object(object): diff --git a/cookbook/views/edit.py b/cookbook/views/edit.py index ff3134662..50e878662 100644 --- a/cookbook/views/edit.py +++ b/cookbook/views/edit.py @@ -9,7 +9,7 @@ from django.views.generic import UpdateView from django.views.generic.edit import FormMixin from cookbook.forms import CommentForm, ExternalRecipeForm, MealPlanForm, StorageForm, SyncForm -from cookbook.helper.permission_helper import GroupRequiredMixin, OwnerRequiredMixin, group_required +from cookbook.helper.permission_helper import GroupRequiredMixin, OwnerRequiredMixin, group_required, above_space_limit from cookbook.models import (Comment, MealPlan, MealType, Recipe, RecipeImport, Storage, Sync, UserPreference) from cookbook.provider.dropbox import Dropbox @@ -39,12 +39,9 @@ def convert_recipe(request, pk): @group_required('user') def internal_recipe_update(request, pk): - if request.space.max_recipes != 0 and Recipe.objects.filter(space=request.space).count() > request.space.max_recipes: # TODO move to central helper function - messages.add_message(request, messages.WARNING, _('You have reached the maximum number of recipes for your space.')) - return HttpResponseRedirect(reverse('view_recipe', args=[pk])) - - if request.space.max_users != 0 and UserPreference.objects.filter(space=request.space).count() > request.space.max_users: - messages.add_message(request, messages.WARNING, _('You have more users than allowed in your space.')) + limit, msg = above_space_limit(request.space) + if limit: + messages.add_message(request, messages.WARNING, msg) return HttpResponseRedirect(reverse('view_recipe', args=[pk])) recipe_instance = get_object_or_404(Recipe, pk=pk, space=request.space) diff --git a/cookbook/views/import_export.py b/cookbook/views/import_export.py index daa55d432..d81777fce 100644 --- a/cookbook/views/import_export.py +++ b/cookbook/views/import_export.py @@ -10,7 +10,7 @@ from django.urls import reverse from django.utils.translation import gettext as _ from cookbook.forms import ExportForm, ImportExportBase, ImportForm -from cookbook.helper.permission_helper import group_required +from cookbook.helper.permission_helper import group_required, above_space_limit from cookbook.helper.recipe_search import RecipeSearch from cookbook.integration.cheftap import ChefTap from cookbook.integration.chowdown import Chowdown @@ -84,12 +84,9 @@ def get_integration(request, export_type): @group_required('user') def import_recipe(request): - if request.space.max_recipes != 0 and Recipe.objects.filter(space=request.space).count() >= request.space.max_recipes: # TODO move to central helper function - messages.add_message(request, messages.WARNING, _('You have reached the maximum number of recipes for your space.')) - return HttpResponseRedirect(reverse('index')) - - if request.space.max_users != 0 and UserPreference.objects.filter(space=request.space).count() > request.space.max_users: - messages.add_message(request, messages.WARNING, _('You have more users than allowed in your space.')) + limit, msg = above_space_limit(request.space) + if limit: + messages.add_message(request, messages.WARNING, msg) return HttpResponseRedirect(reverse('index')) if request.method == "POST": diff --git a/vue/src/apps/ImportView/ImportView.vue b/vue/src/apps/ImportView/ImportView.vue index bb39f49d9..c049100d3 100644 --- a/vue/src/apps/ImportView/ImportView.vue +++ b/vue/src/apps/ImportView/ImportView.vue @@ -106,10 +106,12 @@
-

{{ recipe_json.name - }}

+ }} + + {{ + $t('Help') + }} + x.id === this.recipe_app)[0] + }, + }, data() { return { tab_index: 0, @@ -343,7 +355,8 @@ export default { recipe_files: [], loading: false, empty_input: false, - edit_name: false,// Bookmarklet + edit_name: false, + // Bookmarklet BOOKMARKLET_CODE: window.BOOKMARKLET_CODE } }, @@ -422,7 +435,7 @@ export default { window.localStorage.setItem(this.LS_IMPORT_RECENT, JSON.stringify(this.recent_urls)) } - if (this.website_url === '') { + if (this.website_url === '' && bookmarklet === undefined) { this.empty_input = true setTimeout(() => { this.empty_input = false @@ -541,7 +554,7 @@ export default { `localStorage.setItem("token", "${window.API_TOKEN}");` + `document.body.appendChild(document.createElement("script")).src="${localStorage.getItem('BASE_PATH')}${resolveDjangoStatic('/js/bookmarklet.js')}?r="+Math.floor(Math.random()*999999999)}` + `})()` - } + }, }, directives: { hover: { diff --git a/vue/src/utils/integration.js b/vue/src/utils/integration.js index a2e6db1bb..c5a450215 100644 --- a/vue/src/utils/integration.js +++ b/vue/src/utils/integration.js @@ -1,24 +1,24 @@ // containing all data and functions regarding the different integrations export const INTEGRATIONS = [ - {id: 'DEFAULT', name: "Tandoor", import: true, export: true}, - {id: 'CHEFTAP', name: "Cheftap", import: true, export: false}, - {id: 'CHOWDOWN', name: "Chowdown", import: true, export: false}, - {id: 'COOKBOOKAPP', name: "CookBookApp", import: true, export: false}, - {id: 'COOKMATE', name: "Cookmate", import: true, export: false}, - {id: 'COPYMETHAT', name: "CopyMeThat", import: true, export: false}, - {id: 'DOMESTICA', name: "Domestica", import: true, export: false}, - {id: 'MEALIE', name: "Mealie", import: true, export: false}, - {id: 'MEALMASTER', name: "Mealmaster", import: true, export: false}, - {id: 'MELARECIPES', name: "Melarecipes", import: true, export: false}, - {id: 'NEXTCLOUD', name: "Nextcloud Cookbook", import: true, export: false}, - {id: 'OPENEATS', name: "Openeats", import: true, export: false}, - {id: 'PAPRIKA', name: "Paprika", import: true, export: false}, - {id: 'PEPPERPLATE', name: "Pepperplate", import: true, export: false}, - {id: 'PLANTOEAT', name: "Plantoeat", import: true, export: false}, - {id: 'RECETTETEK', name: "RecetteTek", import: true, export: false}, - {id: 'RECIPEKEEPER', name: "Recipekeeper", import: true, export: false}, - {id: 'RECIPESAGE', name: "Recipesage", import: true, export: true}, - {id: 'REZKONV', name: "Rezkonv", import: true, export: false}, - {id: 'SAFRON', name: "Safron", import: true, export: true}, + {id: 'DEFAULT', name: "Tandoor", import: true, export: true, help_url: 'https://docs.tandoor.dev/features/import_export/#default'}, + {id: 'CHEFTAP', name: "Cheftap", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#cheftap'}, + {id: 'CHOWDOWN', name: "Chowdown", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#chowdown'}, + {id: 'COOKBOOKAPP', name: "CookBookApp", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#cookbookapp'}, + {id: 'COOKMATE', name: "Cookmate", import: true, export: false, help_url: ''}, + {id: 'COPYMETHAT', name: "CopyMeThat", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#copymethat'}, + {id: 'DOMESTICA', name: "Domestica", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#domestica'}, + {id: 'MEALIE', name: "Mealie", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#mealie'}, + {id: 'MEALMASTER', name: "Mealmaster", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#mealmaster'}, + {id: 'MELARECIPES', name: "Melarecipes", import: true, export: false, help_url: ''}, + {id: 'NEXTCLOUD', name: "Nextcloud Cookbook", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#nextcloud'}, + {id: 'OPENEATS', name: "Openeats", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#openeats'}, + {id: 'PAPRIKA', name: "Paprika", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#paprika'}, + {id: 'PEPPERPLATE', name: "Pepperplate", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#pepperplate'}, + {id: 'PLANTOEAT', name: "Plantoeat", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#plantoeat'}, + {id: 'RECETTETEK', name: "RecetteTek", import: true, export: false, help_url: ''}, + {id: 'RECIPEKEEPER', name: "Recipekeeper", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#recipekeeper'}, + {id: 'RECIPESAGE', name: "Recipesage", import: true, export: true, help_url: 'https://docs.tandoor.dev/features/import_export/#recipesage'}, + {id: 'REZKONV', name: "Rezkonv", import: true, export: false, help_url: 'https://docs.tandoor.dev/features/import_export/#rezkonv'}, + {id: 'SAFRON', name: "Safron", import: true, export: true, help_url: 'https://docs.tandoor.dev/features/import_export/#safron'}, ]