treeview refactor 2
gitea/salix/1625-worker_department_treeview This commit looks good Details

This commit is contained in:
Joan Sanchez 2019-10-02 14:12:17 +02:00
parent 9473636b5b
commit 6a184496d6
8 changed files with 102 additions and 96 deletions

View File

@ -3,23 +3,28 @@ import './style.scss';
export default class IconButton { export default class IconButton {
constructor($element) { constructor($element) {
if ($element[0].getAttribute('tabindex') == null) this.element = $element[0];
$element[0].tabIndex = 0;
$element.on('keyup', event => this.onKeyDown(event, $element)); if (this.element.getAttribute('tabindex') == null)
let button = $element[0].querySelector('button'); this.element.tabIndex = 0;
$element[0].addEventListener('click', event => {
if (this.disabled || button.disabled) this.element.addEventListener('keyup', e => this.onKeyup(e));
event.stopImmediatePropagation(); this.element.addEventListener('click', e => this.onClick(e));
});
} }
onKeyDown(event, $element) { onKeyup(event) {
if (event.code == 'Space')
this.onClick(event);
}
onClick(event) {
if (event.defaultPrevented) return; if (event.defaultPrevented) return;
if (event.keyCode == 13) { event.preventDefault();
event.preventDefault();
$element.triggerHandler('click'); // FIXME: Don't use Event.stopPropagation()
} let button = this.element.querySelector('button');
if (this.disabled || button.disabled)
event.stopImmediatePropagation();
} }
} }

View File

@ -1,69 +1,42 @@
<ul ng-if="::$ctrl.items"> <ul ng-if="$ctrl.items">
<li ng-repeat="item in $ctrl.items" > <li ng-repeat="item in $ctrl.items" >
<div <div
on-drop="$ctrl.onDrop(item, dragged, dropped)"
vn-draggable="{{::$ctrl.draggable}}"
vn-droppable="{{::$ctrl.droppable}}"
ng-class="{expanded: item.active}" ng-class="{expanded: item.active}"
ng-click="$ctrl.toggle($event, item)" ng-click="$ctrl.toggle($event, item)"
class="node clickable"> class="node clickable">
<vn-icon <vn-icon
class="arrow" class="arrow"
ng-class="{invisible: item.sons == 0}" ng-class="{invisible: !item.sons}"
icon="keyboard_arrow_down" icon="keyboard_arrow_down"
translate-attr="{title: 'Toggle'}"> translate-attr="::{title: 'Toggle'}">
</vn-icon> </vn-icon>
<vn-treeview-content <vn-treeview-content
item="item" item="::item">
transclude-func="$ctrl.transcludeFunc">
</vn-treeview-content> </vn-treeview-content>
<!-- <!--
<vn-check <vn-check
vn-acl="{{$ctrl.aclRole}}" vn-acl="{{$ctrl.aclRole}}"
ng-if="$ctrl.selectable" ng-if="$ctrl.selectable"
field="item.selected" field="item.selected"
disabled="$ctrl.disabled" disabled="$ctrl.treeview.disabled"
on-change="$ctrl.select(item, value)" on-change="$ctrl.select(item, value)"
triple-state="true" triple-state="true"
label="{{::item.name}}"> label="{{::item.name}}">
</vn-check> </vn-check>
<vn-icon-button
icon="{{icon.icon}}"
ng-repeat="icon in $ctrl.icons"
ng-click="$ctrl.onIconClick(icon, item, $ctrl.parent, $parent.$index)"
vn-acl="{{$ctrl.aclRole}}"
vn-acl-action="remove">
</vn-icon-button>
--> -->
<vn-icon-button
icon="add_circle"
ng-click="$ctrl.treeview.onAdd(item, item.childs)">
</vn-icon-button>
<vn-icon-button
icon="delete"
ng-click="$ctrl.treeview.onRemove(item, $ctrl.items, $ctrl.parent)">
</vn-icon-button>
</div> </div>
<vn-treeview-childs <vn-treeview-childs
items="item.childs" items="item.childs"
parent="item" parent="::item">
selectable="$ctrl.selectable"
disabled="$ctrl.disabled"
editable="$ctrl.editable"
draggable="::$ctrl.draggable"
droppable="::$ctrl.droppable"
icons="::$ctrl.icons"
parent-scope="::$ctrl.parentScope"
acl-role="$ctrl.aclRole"
transclude-func="$ctrl.transcludeFunc">
</vn-treeview-childs> </vn-treeview-childs>
</li> </li>
</ul> </ul>
<!--
<li
ng-if="$ctrl.isInsertable && $ctrl.editable"
ng-click="$ctrl.onCreate($ctrl.parent)"
vn-acl="{{$ctrl.aclRole}}"
vn-acl-action="remove">
<div class="node">
<vn-icon-button
icon="add_circle">
</vn-icon-button>
<div class="description" translate>
Create new one
</div>
</div>
</li>

View File

@ -7,14 +7,6 @@ class Controller extends Component {
this.$transclude = $transclude; this.$transclude = $transclude;
} }
$onInit() {
this.transcludeFunc((tClone, $scope) => {
$scope.item = this.item;
let content = this.element.querySelector('.content');
angular.element(content).append(tClone);
});
}
toggle(event, item) { toggle(event, item) {
if (event.defaultPrevented || !item.sons) return; if (event.defaultPrevented || !item.sons) return;
event.preventDefault(); event.preventDefault();
@ -50,16 +42,7 @@ ngModule.component('vnTreeviewChilds', {
controller: Controller, controller: Controller,
bindings: { bindings: {
items: '<', items: '<',
parent: '<', parent: '<?'
icons: '<?',
disabled: '<?',
selectable: '<?',
editable: '<?',
draggable: '<?',
droppable: '<?',
aclRole: '<?',
parentScope: '<',
transcludeFunc: '<'
}, },
require: { require: {
treeview: '^vnTreeview' treeview: '^vnTreeview'

View File

@ -6,7 +6,7 @@ class Controller {
} }
$onInit() { $onInit() {
this.transcludeFunc((tClone, $scope) => { this.treeview.$transclude((tClone, $scope) => {
$scope.item = this.item; $scope.item = this.item;
this.$element.append(tClone); this.$element.append(tClone);
}); });
@ -17,7 +17,9 @@ Controller.$inject = ['$element'];
ngModule.component('vnTreeviewContent', { ngModule.component('vnTreeviewContent', {
controller: Controller, controller: Controller,
bindings: { bindings: {
item: '<', item: '<'
transcludeFunc: '<' },
require: {
treeview: '^vnTreeview'
} }
}); });

View File

@ -1,13 +1,11 @@
<section class="add-item" ng-click="$ctrl.onAdd(null, $ctrl.items)" >
<vn-icon-button
icon="add_circle">
</vn-icon-button>
<span class="description" translate>
Create new one
</span>
</section>
<vn-treeview-childs <vn-treeview-childs
acl-role="$ctrl.aclRole" items="$ctrl.items">
items="$ctrl.items"
selectable="$ctrl.selectable"
editable="$ctrl.editable"
disabled="$ctrl.disabled"
icons="$ctrl.icons"
parent-scope="$ctrl.$scope.$parent"
draggable="$ctrl.draggable"
droppable="$ctrl.droppable"
vn-droppable="{{$ctrl.droppable}}"
transclude-func="$ctrl.$transclude">
</vn-treeview-childs> </vn-treeview-childs>

View File

@ -13,7 +13,6 @@ import './content';
export default class Treeview extends Component { export default class Treeview extends Component {
constructor($element, $scope, $transclude) { constructor($element, $scope, $transclude) {
super($element, $scope); super($element, $scope);
this.$scope = $scope;
this.$transclude = $transclude; this.$transclude = $transclude;
this.items = []; this.items = [];
} }
@ -78,6 +77,42 @@ export default class Treeview extends Component {
onDrop(item, dragged, dropped) { onDrop(item, dragged, dropped) {
this.emit('drop', {item, dragged, dropped}); this.emit('drop', {item, dragged, dropped});
} }
onRemove(item, items, parent) {
if (!this.removeFunc) return;
let res = this.removeFunc({$item: item});
function remove() {
let index = items.indexOf(item);
items.splice(index, 1);
if (parent) parent.sons--;
}
if (res instanceof Object && res.then)
res.then(remove);
else if (res)
remove();
}
onAdd(parent, childs) {
if (!this.addFunc) return;
let res = this.addFunc({$parent: parent});
function add() {
if (!childs) childs = [];
childs.push(res);
if (parent) {
parent.childs = childs;
parent.sons++;
parent.active = true;
}
}
if (res instanceof Object && res.then)
res.then(add);
else if (res)
add();
}
} }
Treeview.$inject = ['$element', '$scope', '$transclude']; Treeview.$inject = ['$element', '$scope', '$transclude'];
@ -93,7 +128,9 @@ ngModule.component('vnTreeview', {
editable: '<?', editable: '<?',
draggable: '<?', draggable: '<?',
droppable: '<?', droppable: '<?',
aclRole: '@?' aclRole: '@?',
removeFunc: '&?',
addFunc: '&?'
}, },
transclude: true transclude: true
}); });

View File

@ -1,5 +1,10 @@
@import "effects"; @import "effects";
vn-treeview {
& > .add-item {
@extend %clickable;
}
}
vn-treeview-childs { vn-treeview-childs {
display: block; display: block;
@ -9,6 +14,10 @@ vn-treeview-childs {
& > li { & > li {
list-style: none; list-style: none;
ul {
padding-left: 2.2em;
}
} }
} }
vn-icon-button { vn-icon-button {
@ -39,7 +48,7 @@ vn-treeview-childs {
color: $color-main; color: $color-main;
} }
} }
ul {
padding-left: 2.2em;
}
} }
vn-treeview-content {
flex-grow: 1;
}

View File

@ -10,10 +10,9 @@
vn-id="treeview" vn-id="treeview"
model="model" model="model"
on-selection="$ctrl.onSelection(item, value)" on-selection="$ctrl.onSelection(item, value)"
on-create="$ctrl.onCreate(parent)" remove-func="true"
on-drop="$ctrl.onDrop(item, dragged, dropped)" add-func="{name: 'Dept1'}">
icons="$ctrl.icons"> {{::item.name}}
{{item.name}}
</vn-treeview> </vn-treeview>
</vn-card> </vn-card>
<vn-button-bar> <vn-button-bar>