31 changed files with 542 additions and 87 deletions
@ -0,0 +1,129 @@ |
|||||
|
/* |
||||
|
* Copyright © 2016-2019 The Thingsboard Authors |
||||
|
* |
||||
|
* Licensed under the Apache License, Version 2.0 (the "License"); |
||||
|
* you may not use this file except in compliance with the License. |
||||
|
* You may obtain a copy of the License at |
||||
|
* |
||||
|
* http://www.apache.org/licenses/LICENSE-2.0
|
||||
|
* |
||||
|
* Unless required by applicable law or agreed to in writing, software |
||||
|
* distributed under the License is distributed on an "AS IS" BASIS, |
||||
|
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
|
* See the License for the specific language governing permissions and |
||||
|
* limitations under the License. |
||||
|
*/ |
||||
|
/*@ngInject*/ |
||||
|
export default function SetRootRuleChainToEdgesController(ruleChainService, edgeService, $mdDialog, $q, edgeIds, ruleChains) { |
||||
|
|
||||
|
var vm = this; |
||||
|
|
||||
|
vm.ruleChains = ruleChains; |
||||
|
vm.searchText = ''; |
||||
|
|
||||
|
vm.assign = assign; |
||||
|
vm.cancel = cancel; |
||||
|
vm.isRuleChainSelected = isRuleChainSelected; |
||||
|
vm.hasData = hasData; |
||||
|
vm.noData = noData; |
||||
|
vm.searchRuleChainTextUpdated = searchRuleChainTextUpdated; |
||||
|
vm.toggleRuleChainSelection = toggleRuleChainSelection; |
||||
|
|
||||
|
vm.theRuleChains = { |
||||
|
getItemAtIndex: function (index) { |
||||
|
if (index > vm.ruleChains.data.length) { |
||||
|
vm.theRuleChains.fetchMoreItems_(index); |
||||
|
return null; |
||||
|
} |
||||
|
var item = vm.ruleChains.data[index]; |
||||
|
if (item) { |
||||
|
item.indexNumber = index + 1; |
||||
|
} |
||||
|
return item; |
||||
|
}, |
||||
|
|
||||
|
getLength: function () { |
||||
|
if (vm.ruleChains.hasNext) { |
||||
|
return vm.ruleChains.data.length + vm.ruleChains.nextPageLink.limit; |
||||
|
} else { |
||||
|
return vm.ruleChains.data.length; |
||||
|
} |
||||
|
}, |
||||
|
|
||||
|
fetchMoreItems_: function () { |
||||
|
if (vm.ruleChains.hasNext && !vm.ruleChains.pending) { |
||||
|
vm.ruleChains.pending = true; |
||||
|
ruleChainService.getRuleChains(vm.ruleChains.nextPageLink).then( |
||||
|
function success(ruleChains) { |
||||
|
vm.ruleChains.data = vm.ruleChains.data.concat(ruleChains.data); |
||||
|
vm.ruleChains.nextPageLink = ruleChains.nextPageLink; |
||||
|
vm.ruleChains.hasNext = ruleChains.hasNext; |
||||
|
if (vm.ruleChains.hasNext) { |
||||
|
vm.ruleChains.nextPageLink.limit = vm.ruleChains.pageSize; |
||||
|
} |
||||
|
vm.ruleChains.pending = false; |
||||
|
}, |
||||
|
function fail() { |
||||
|
vm.ruleChains.hasNext = false; |
||||
|
vm.ruleChains.pending = false; |
||||
|
}); |
||||
|
} |
||||
|
} |
||||
|
}; |
||||
|
|
||||
|
function cancel() { |
||||
|
$mdDialog.cancel(); |
||||
|
} |
||||
|
|
||||
|
function assign() { |
||||
|
var assignTasks = []; |
||||
|
for (var i=0;i<edgeIds.length;i++) { |
||||
|
assignTasks.push(ruleChainService.assignRuleChainToEdge(edgeIds[i], vm.ruleChains.selection.id.id)); |
||||
|
} |
||||
|
$q.all(assignTasks).then(function () { |
||||
|
var setRootTasks = []; |
||||
|
for (var j=0;j<edgeIds.length;j++) { |
||||
|
setRootTasks.push(edgeService.setRootRuleChain(edgeIds[j], vm.ruleChains.selection.id.id)); |
||||
|
} |
||||
|
$q.all(setRootTasks).then(function () { |
||||
|
$mdDialog.hide(); |
||||
|
}); |
||||
|
}); |
||||
|
} |
||||
|
|
||||
|
function noData() { |
||||
|
return vm.ruleChains.data.length == 0 && !vm.ruleChains.hasNext; |
||||
|
} |
||||
|
|
||||
|
function hasData() { |
||||
|
return vm.ruleChains.data.length > 0; |
||||
|
} |
||||
|
|
||||
|
function toggleRuleChainSelection($event, ruleChain) { |
||||
|
$event.stopPropagation(); |
||||
|
if (vm.isRuleChainSelected(ruleChain)) { |
||||
|
vm.ruleChains.selection = null; |
||||
|
} else { |
||||
|
vm.ruleChains.selection = ruleChain; |
||||
|
} |
||||
|
} |
||||
|
|
||||
|
function isRuleChainSelected(ruleChain) { |
||||
|
return vm.ruleChains.selection != null && ruleChain && |
||||
|
ruleChain.id.id === vm.ruleChains.selection.id.id; |
||||
|
} |
||||
|
|
||||
|
function searchRuleChainTextUpdated() { |
||||
|
vm.ruleChains = { |
||||
|
pageSize: vm.ruleChains.pageSize, |
||||
|
data: [], |
||||
|
nextPageLink: { |
||||
|
limit: vm.ruleChains.pageSize, |
||||
|
textSearch: vm.searchText |
||||
|
}, |
||||
|
selection: null, |
||||
|
hasNext: true, |
||||
|
pending: false |
||||
|
}; |
||||
|
} |
||||
|
} |
||||
@ -0,0 +1,76 @@ |
|||||
|
<!-- |
||||
|
|
||||
|
Copyright © 2016-2019 The Thingsboard Authors |
||||
|
|
||||
|
Licensed under the Apache License, Version 2.0 (the "License"); |
||||
|
you may not use this file except in compliance with the License. |
||||
|
You may obtain a copy of the License at |
||||
|
|
||||
|
http://www.apache.org/licenses/LICENSE-2.0 |
||||
|
|
||||
|
Unless required by applicable law or agreed to in writing, software |
||||
|
distributed under the License is distributed on an "AS IS" BASIS, |
||||
|
WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. |
||||
|
See the License for the specific language governing permissions and |
||||
|
limitations under the License. |
||||
|
|
||||
|
--> |
||||
|
<md-dialog aria-label="{{ 'edge.set-root-rule-chain-to-edges' | translate }}"> |
||||
|
<form name="theForm" ng-submit="vm.assign()"> |
||||
|
<md-toolbar> |
||||
|
<div class="md-toolbar-tools"> |
||||
|
<h2 translate>edge.set-root-rule-chain-to-edges</h2> |
||||
|
<span flex></span> |
||||
|
<md-button class="md-icon-button" ng-click="vm.cancel()"> |
||||
|
<ng-md-icon icon="close" aria-label="{{ 'dialog.close' | translate }}"></ng-md-icon> |
||||
|
</md-button> |
||||
|
</div> |
||||
|
</md-toolbar> |
||||
|
<md-progress-linear class="md-warn" md-mode="indeterminate" ng-disabled="!$root.loading" ng-show="$root.loading"></md-progress-linear> |
||||
|
<span style="min-height: 5px;" flex="" ng-show="!$root.loading"></span> |
||||
|
<md-dialog-content> |
||||
|
<div class="md-dialog-content"> |
||||
|
<fieldset> |
||||
|
<span translate>edge.set-root-rule-chain-text</span> |
||||
|
<md-input-container class="md-block" style='margin-bottom: 0px;'> |
||||
|
<label> </label> |
||||
|
<md-icon aria-label="{{ 'action.search' | translate }}" class="material-icons"> |
||||
|
search |
||||
|
</md-icon> |
||||
|
<input id="rule-chain-search" autofocus ng-model="vm.searchText" |
||||
|
ng-change="vm.searchRuleChainTextUpdated()" |
||||
|
placeholder="{{ 'common.enter-search' | translate }}"/> |
||||
|
</md-input-container> |
||||
|
<div style='min-height: 150px;'> |
||||
|
<span translate layout-align="center center" |
||||
|
style="text-transform: uppercase; display: flex; height: 150px;" |
||||
|
class="md-subhead" |
||||
|
ng-show="vm.noData()">rulechain.no-rulechains-text</span> |
||||
|
<md-virtual-repeat-container ng-show="vm.hasData()" |
||||
|
tb-scope-element="repeatContainer" md-top-index="vm.topIndex" flex |
||||
|
style='min-height: 150px; width: 100%;'> |
||||
|
<md-list> |
||||
|
<md-list-item md-virtual-repeat="ruleChain in vm.theRuleChains" md-on-demand |
||||
|
class="repeated-item" flex> |
||||
|
<md-checkbox ng-click="vm.toggleRuleChainSelection($event, ruleChain)" |
||||
|
aria-label="{{ 'item.selected' | translate }}" |
||||
|
ng-checked="vm.isRuleChainSelected(ruleChain)"></md-checkbox> |
||||
|
<span> {{ ruleChain.name }} </span> |
||||
|
</md-list-item> |
||||
|
</md-list> |
||||
|
</md-virtual-repeat-container> |
||||
|
</div> |
||||
|
</fieldset> |
||||
|
</div> |
||||
|
</md-dialog-content> |
||||
|
<md-dialog-actions layout="row"> |
||||
|
<span flex></span> |
||||
|
<md-button ng-disabled="$root.loading || vm.ruleChains.selection==null" type="submit" class="md-raised md-primary"> |
||||
|
{{ 'action.assign' | translate }} |
||||
|
</md-button> |
||||
|
<md-button ng-disabled="$root.loading" ng-click="vm.cancel()" style="margin-right:20px;">{{ 'action.cancel' | |
||||
|
translate }} |
||||
|
</md-button> |
||||
|
</md-dialog-actions> |
||||
|
</form> |
||||
|
</md-dialog> |
||||
Loading…
Reference in new issue