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