1 <div class="container" id="tenant-page">
2 <h1>Tenant Administration - {{ curTenant }}</h1>
4 <ul id="TenantsTabs" class="nav nav-pills" role="tablist">
5 <li ng-class="{ active: isTabSet('tenantData',0)}" ng-click="setTab('tenantData',0)" >
6 <a id="inventory-tab" href="#/cpeui/tenant/{{curTenant}}/inventory"> <i class="icon-tasks"></i> Inventory</a>
8 <li ng-class="{ active: isTabSet('tenantData',1)}" ng-click="setTab('tenantData',1)" >
9 <a id="evcs-configure-tab" href="#/cpeui/tenant/{{curTenant}}/L2"> <i class="icon-exchange"></i> L2 Services</a>
11 <li ng-class="{ active: isTabSet('tenantData',2)}" ng-click="setTab('tenantData',2)" >
12 <a id="ipvs-configure-tab" href="#/cpeui/tenant/{{curTenant}}/L3" > <i class="icon-screenshot"></i> L3 Services</a>
15 <li ng-class="{ active: isTabSet('tenantData',3)}" ng-click="setTab('tenantData',3)" >
16 <a href="#/cpeui/tenant/{{curTenant}}/dashboard" > <i class="icon-dashboard"></i> Dashboard</a>
18 <li ng-class="{ active: isTabSet('tenantData',4)}" ng-click="setTab('tenantData',4)" >
19 <a href="#/cpeui/tenant/{{curTenant}}/cpemonitor" > <i class="icon-bar-chart"></i> CPE Monitor</a>
21 <li ng-class="{ active: isTabSet('tenantData',5)}" ng-click="setTab('tenantData',5)" >
22 <a href="#/cpeui/tenant/{{curTenant}}/servicemonitor" > <i class="icon-bar-chart"></i> Service Monitor</a>
25 <li ng-class="{ active: isTabSet('tenantData',6)}" ng-click="setTab('tenantData',6)" >
26 <a id="tenant-uni-tab" href="#/cpeui/tenant/{{curTenant}}/unis"> <i class="icon-tasks"></i> UNIs</a>
28 <li id="refresh_btn" class="active refresh-btn" ng-click="updateEvcView()">
29 <button class="btn add-row"> <i class="icon-refresh"></i> Refresh</button>
33 <div id="EVCsContent" class="tab-content">
34 <div ng-show="isTabSet('tenantData',0)">
35 <div class="table-header">Inventory</div>
36 <table class="footable table table-striped">
39 <th class="minimal-width">CPE-ID</th>
40 <th class="minimal-width">Device Name</th>
44 <tbody ng-repeat="ce in ces" ng-init="ceUnis = unis.filterByField('device',ce['dev-id'])">
46 <td class="minimal-width" ng-bind="ce['dev-id']"></td>
47 <td class="minimal-width" ng-bind="ce['device-name']"></td>
49 <table class="footable table table-striped inner-table" ng-if="!unisTables[item['svc-id']]">
52 <th class="minimal-width">Interface Name</th>
53 <th class="minimal-width">VLAN</th>
54 <th class="minimal-width">Service</th>
57 <tbody ng-repeat="uni in ceUnis">
58 <tr ng-repeat="svcs in uni.vlanToService | orderBy: '-vlan'" ng-if="uni.hasService">
59 <td rowspan="{{uni.vlanToService.length}}" ng-if="$first" ng-bind="uni.prettyID" />
60 <td ng-bind="svcs.vlan ? svcs.vlan : '-'" />
62 <a class="link" href="#/cpeui/tenant/dav1/{{svcs.svc.evc ? 'L2' : 'L3'}}?svcs.svc={{svcs.svc['svc-id']}}">{{svcs.svc.name ? svcs.svc.name : svcs.svc['svc-id']}}</a>
66 <tbody ng-if="!doesAllUniHasService(ceUnis)">
68 <td><b ng-repeat="uni in ceUnis" ng-if="!uni.hasService">{{uni.prettyID}}{{$last ? '' : ', '}}</b></td>
79 <div ng-show="isTabSet('tenantData',1)">
80 <div class="table-header">L2 Service Config</div>
81 <table class="footable table table-striped">
84 <th class="minimal-width">Service ID</th>
85 <th class="minimal-width">Service Name</th>
86 <th class="minimal-width">Type</th>
87 <th class="minimal-width">Segmentation ID</th>
89 <th class="minimal-width">
90 <button class="btn btn-md btn-info right" ng-click="evcDialog.show($event,{'svcTypes':svcTypes})">
91 <i class="icon-plus"></i>
92 <md-tooltip>Create EVC</md-tooltip>
98 <tr ng-repeat="item in evcs | orderBy : 'name'">
99 <td class="minimal-width">{{ item.evc['evc-id'] }}</td>
100 <td class="minimal-width">{{ item['name'] }}</td>
101 <td class="minimal-width">{{ item['svc-type'] | uppercase }}</td>
102 <td class="minimal-width">{{ item.evc['segmentation-id'] }}</td>
104 <table class="footable table table-striped inner-table" ng-if="!isEmpty(item.device2unis)">
107 <th class="minimal-width">Device</th>
108 <th class="minimal-width">Port</th>
109 <th class="minimal-width">VLANs <span style="font-size:small;color:inherit;"> (click to edit)</span></th>
110 <th class="minimal-width" ng-if="item.isTree" >Role</th>
111 <th>Bandwidth Profile</th>
112 <th class="minimal-width"></th>
116 <tr ng-repeat-start="(ce, unis) in item.device2unis | orderBy : ce ">
117 <td class="minimal-width" rowspan="{{unis.length}}">{{ cesDisplayNames[ce] }}</td>
118 <td class="minimal-width" ng-repeat-start="uni in unis | orderBy: sortUni | limitTo :1">{{ uni.prettyID }}</td>
119 <td class="clickable" ng-click="!item.evc['preserve-ce-vlan-id'] ? editVlanDialog.show($event, {svcid:item['svc-id'], uniid:uni['uni-id'], vlans:uni.vlans}) : 0">
120 {{ uni.vlans.join(', ') }} {{item.evc['preserve-ce-vlan-id'] ? '(Preserved)' : ''}}
122 <td class="minimal-width" ng-if="item.isTree">{{ uni['role'] }}</td>
123 <td >{{ uni['ingress-bw-profile'] }}</td>
124 <td ng-repeat-end class="minimal-width" style="white-space: nowrap;">
125 <button class="btn btn-md btn-danger" ng-click="deleteEvcUni(item['svc-id'], uni['uni-id'])"> <i class="icon-trash"></i> </button>
128 <tr ng-repeat-end ng-repeat="uni in unis | orderBy: sortUni | limitTo :(unis.length-1) :1">
129 <td>{{ uni.prettyID }}</td>
130 <td ng-if="item.isTree">{{ uni['role'] }}</td>
131 <td class="clickable" ng-click="!item.evc['preserve-ce-vlan-id'] ? editVlanDialog.show($event, {svcid:item['svc-id'], uniid:uni['uni-id'], vlans:uni.vlans}) : 0">
132 {{ uni.vlans.join(', ') }} {{item.evc['preserve-ce-vlan-id'] ? '(Preserved)' : ''}}
134 <td class="minimal-width">{{ uni['ingress-bw-profile'] }}</td>
135 <td class="minimal-width" style="white-space: nowrap;">
136 <button class="btn btn-md btn-danger" ng-click="deleteEvcUni(item['svc-id'], uni['uni-id'])">
137 <i class="icon-trash"></i>
145 <td class="minimal-width">
146 <button class="btn btn-md btn-danger" ng-click="deleteEvc(item['svc-id'])"> <i class="icon-trash"></i> </button>
147 <button class="btn btn-md btn-info" ng-click="linkEvcUniDialog.show($event, {svc:item, unis:unis, ces:ces, profiles:profiles})">
148 <i class="icon-plus"></i>
149 <md-tooltip>Add UNI</md-tooltip>
156 <div ng-show="isTabSet('tenantData',2)">
157 <div class="table-header">L3 Service Config</div>
158 <table class="footable table table-striped">
161 <th class="minimal-width">Service ID</th>
162 <th class="minimal-width">Service Name</th>
163 <th>Service Endpoints</th>
164 <th class="minimal-width">
165 <button class="btn btn-md btn-info right" ng-click="ipvcDialog.show($event,{'svcTypes':svcTypes})">
166 <i class="icon-plus"></i>
167 <md-tooltip>Create IPVC</md-tooltip>
172 <tbody id="l2_table">
173 <tr ng-repeat="ipvc in ipvcs | orderBy : 'name'">
174 <td class="minimal-width">{{ ipvc.ipvc['ipvc-id'] }}</td>
175 <td class="minimal-width">{{ ipvc['name'] }}</td>
177 <table class="footable table table-striped inner-table" ng-if="ipvc.ipvc.unis.uni">
180 <th class="minimal-width">Device Name</th>
181 <th class="minimal-width">Port</th>
183 <th class="minimal-width">I/F Address</th>
184 <th>Bandwidth Profile</th>
185 <th class="minimal-width"></th>
189 <tr ng-repeat="ipuni in ipvc.ipvc.unis.uni | orderBy: 'prettyID'">
190 <td class="minimal-width" ng-init="serviceIpuni = getMefInterfaceIpvc(ipuni['uni-id'],ipuni['ip-uni-id'])">{{ cesDisplayNames[ipuni.device] }}</td>
191 <td class="minimal-width">{{ ipuni.prettyID }}</td>
192 <td>{{serviceIpuni.vlan}}</td>
193 <td class="minimal-width">{{serviceIpuni['ip-address']}}</td>
194 <td>{{ ipuni['ingress-bw-profile'] }}</td>
195 <td class="minimal-width"><button class="btn btn-md btn-danger" ng-click="deleteIpvcUni(ipvc['svc-id'], ipuni['uni-id'], ipuni['ip-uni-id'])"> <i class="icon-trash"></i> </button></td>
200 <td class="minimal-width">
201 <button class="btn btn-md btn-danger" ng-click="deleteEvc(ipvc['svc-id'])"> <i class="icon-trash"></i> </button>
202 <button class="btn btn-md btn-info" ng-click="linkIpvcUniDialog.show($event, {svc:ipvc, unis:unis, ces:ces, profiles:profiles})"> <i class="icon-plus"></i> </button>
205 <button ng-show="!unisTables[ipvc.ipvc['ipvc-id']]" class="btn add-row btn-block" ng-click="unisTables[ipvc.ipvc['ipvc-id']] = true;">Show Unis</button>
206 <button ng-show="unisTables[ipvc.ipvc['ipvc-id']]" class="btn add-row btn-block" ng-click="unisTables[ipvc.ipvc['ipvc-id']] = false;">Hide Unis</button>
208 <td class="minimal-width"><button class="btn btn-md btn-danger" ng-click="deleteEvc(ipvc['svc-id'])"> <i class="icon-trash"></i> </button></td>
210 <tr ng-repeat-end ng-show="unisTables[ipvc.ipvc['ipvc-id']]">
212 <table class="footable table table-striped inner-table">
219 <th class="minimal-width"><button class="btn btn-md btn-info" ng-click="linkIpvcUniDialog.show($event, {'svc':ipvc,'unis':unis,'ces':ces})"> <i class="icon-plus"></i> </button></th>
222 <tbody id="l2_table">
223 <tr ng-repeat="ipuni in ipvc.ipvc.unis.uni">
224 <td ng-init="serviceIpuni = getMefInterfaceIpvc(ipuni['uni-id'],ipuni['ip-uni-id'])">{{ cesDisplayNames[ipuni.device] }}</td>
225 <td>{{ ipuni.prettyID }}</td>
226 <td>{{serviceIpuni['ip-address']}}</td>
227 <td>{{serviceIpuni.vlan}}</td>
228 <td class="minimal-width"><button class="btn btn-md btn-danger" ng-click="deleteIpvcUni(ipvc['svc-id'], ipuni['uni-id'], ipuni['ip-uni-id'])"> <i class="icon-trash"></i> </button></td>
238 <div ng-show="isTabSet('tenantData',6)">
239 <div class="table-header">Tenant UNIs</div>
240 <table class="footable table table-striped">
243 <th class="minimal-width">Device</th>
244 <th class="minimal-width">UNI</th>
249 <tr ng-repeat="uni in unis | orderBy: '[\'uni-id\']'">
250 <td class="minimal-width">{{ cesDisplayNames[uni.device] }}</td>
251 <td class="minimal-width">{{ uni.prettyID }}</td>
253 <button class="btn add-row" ng-click="expandFlags.tuni[uni['uni-id']] = true" ng-if="!expandFlags.tuni[uni['uni-id']]">
254 <i class="icon-plus"></i> Show Ports
256 <table class="footable table table-striped inner-table" ng-if="expandFlags.tuni[uni['uni-id']]">
259 <th class="minimal-width">
260 <button class="btn add-row" ng-click="expandFlags.tuni[uni['uni-id']] = false">
261 <i class="icon-minus"></i>
264 <th class="minimal-width">IP UNI ID</th>
265 <th class="minimal-width">VLAN</th>
266 <th class="minimal-width">Address</th>
267 <th>Remote Subnets</th>
268 <th class="minimal-width"><button class="btn btn-md btn-info" ng-click="openIpUniDialog($event,uni)"> <i class="icon-plus"></i> </button></th>
272 <tr ng-repeat="ipuni in uni['ip-unis']['ip-uni'] | orderBy: '[\'ip-uni-id\']'">
273 <td colspan="2" class="minimal-width">{{ ipuni['ip-uni-id'] }}</td>
274 <td class="minimal-width">{{ ipuni.vlan }}</td>
275 <td class="minimal-width">{{ ipuni['ip-address'] }}</td>
277 <button class="btn add-row" ng-click="expandFlags.ipuni[uni['uni-id']+':'+ipuni['ip-uni-id']] = true" ng-if="!expandFlags.ipuni[uni['uni-id']+':'+ipuni['ip-uni-id']]">
278 <i class="icon-plus"></i> Show Subnets
280 <table class="footable table table-striped inner-table" ng-if="expandFlags.ipuni[uni['uni-id']+':'+ipuni['ip-uni-id']]">
283 <th class="minimal-width">
284 <button class="btn add-row" ng-click="expandFlags.ipuni[uni['uni-id']+':'+ipuni['ip-uni-id']] = false">
285 <i class="icon-minus"></i>
290 <th class="minimal-width"><button class="btn btn-md btn-info" ng-click="ipUniSubnetDialog.show($event,{uniid:uni['uni-id'],ipuniid:ipuni['ip-uni-id']})"> <i class="icon-plus"></i> </button></th>
294 <tr ng-repeat="subnet in subnets[uni['uni-id']][ipuni['ip-uni-id']] | orderBy: subnet" ng-if="subnets[uni['uni-id']]">
295 <td colspan="2">{{ subnet.subnet }}</td>
296 <td>{{ subnet.gateway }}</td>
297 <td class="minimal-width"><button class="btn btn-md btn-danger" ng-click="deleteIpUniSubnet(uni['uni-id'],ipuni['ip-uni-id'],subnet.subnet)"> <i class="icon-trash"></i> </button></td>
302 <td class="minimal-width"><button class="btn btn-md btn-danger" ng-click="deleteIpUni(uni['uni-id'],ipuni['ip-uni-id'])"> <i class="icon-trash"></i> </button></td>
313 <button class="btn btn-default pull-right" onclick="window.location='#/cpeui/admin/tenants'" > Back </button>