mirror of https://github.com/portainer/portainer
283 lines
14 KiB
HTML
283 lines
14 KiB
HTML
<rd-header>
|
|
<rd-header-title title="Service details">
|
|
<a data-toggle="tooltip" title="Refresh" ui-sref="service({id: service.Id})" ui-sref-opts="{reload: true}">
|
|
<i class="fa fa-refresh" aria-hidden="true"></i>
|
|
</a>
|
|
<i id="loadingViewSpinner" class="fa fa-cog fa-spin"></i>
|
|
</rd-header-title>
|
|
<rd-header-content>
|
|
<a ui-sref="services">Services</a> > <a ui-sref="service({id: service.Id})">{{ service.Name }}</a>
|
|
</rd-header-content>
|
|
</rd-header>
|
|
|
|
<div class="row">
|
|
<div class="col-lg-12 col-md-12 col-xs-12">
|
|
<rd-widget>
|
|
<rd-widget-header icon="fa-list-alt" title="Service details"></rd-widget-header>
|
|
<rd-widget-body classes="no-padding">
|
|
<table class="table">
|
|
<tbody>
|
|
<tr>
|
|
<td>Name</td>
|
|
<td ng-if="!service.EditName">
|
|
{{ service.Name }}
|
|
<a href="" data-toggle="tooltip" title="Edit service name" ng-click="service.EditName = true;"><i class="fa fa-edit"></i></a>
|
|
</td>
|
|
<td ng-if="service.EditName">
|
|
<input type="text" class="containerNameInput" ng-model="service.newServiceName">
|
|
<a class="interactive" ng-click="service.EditName = false;"><i class="fa fa-times"></i></a>
|
|
<a class="interactive" ng-click="renameService(service)"><i class="fa fa-check-square-o"></i></a>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>ID</td>
|
|
<td>
|
|
{{ service.Id }}
|
|
<button class="btn btn-xs btn-danger" ng-click="removeService()"><i class="fa fa-trash space-right" aria-hidden="true"></i>Delete this service</button>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Scheduling mode</td>
|
|
<td>{{ service.Mode }}</td>
|
|
</tr>
|
|
<tr ng-if="service.Mode === 'replicated'">
|
|
<td>Replicas</td>
|
|
<td>
|
|
<span ng-if="service.Mode === 'replicated' && !service.EditReplicas">
|
|
{{ service.Replicas }}
|
|
<a class="interactive" ng-click="service.EditReplicas = true;"><i class="fa fa-arrows-v" aria-hidden="true"></i> Scale</a>
|
|
</span>
|
|
<span ng-if="service.Mode === 'replicated' && service.EditReplicas">
|
|
<input class="input-sm" type="number" ng-model="service.newServiceReplicas" />
|
|
<a class="interactive" ng-click="service.EditReplicas = false;"><i class="fa fa-times"></i></a>
|
|
<a class="interactive" ng-click="scaleService(service)"><i class="fa fa-check-square-o"></i></a>
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Image</td>
|
|
<td ng-if="!service.EditImage">
|
|
{{ service.Image }}
|
|
<a href="" data-toggle="tooltip" title="Edit service image" ng-click="service.EditImage = true;"><i class="fa fa-edit"></i></a>
|
|
</td>
|
|
|
|
<td ng-if="service.EditImage">
|
|
<input type="text" class="containerNameInput" ng-model="service.newServiceImage">
|
|
<a class="interactive" ng-click="service.EditImage = false;"><i class="fa fa-times"></i></a>
|
|
<a class="interactive" ng-click="changeServiceImage(service)"><i class="fa fa-check-square-o"></i></a>
|
|
</td>
|
|
</tr>
|
|
<tr ng-if="service.Ports">
|
|
<td>Published ports</td>
|
|
<td>
|
|
<div ng-repeat="mapping in service.Ports">
|
|
{{ mapping.TargetPort }} <i class="fa fa-long-arrow-right"></i> {{ mapping.PublishedPort }}
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr ng-if="service.EnvironmentVariables">
|
|
<td>Environment variables</td>
|
|
<td>
|
|
<div class="form-group">
|
|
<div class="col-sm-11 nopadding">
|
|
<span class="label label-default interactive fit-text-size" ng-click="addEnvironmentVariable(service)">
|
|
<i class="fa fa-plus-circle" aria-hidden="true"></i> environment variable
|
|
</span>
|
|
</div>
|
|
<!-- environment-variable-input-list -->
|
|
<div class="col-sm-11 form-inline nopadding" style="margin-top: 10px;">
|
|
<div ng-repeat="var in service.EnvironmentVariables" style="margin-top: 2px;">
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">name</span>
|
|
<input type="text" class="form-control" ng-model="var.key" ng-disabled="var.added" placeholder="e.g. FOO">
|
|
</div>
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">value</span>
|
|
<input type="text" class="form-control" ng-model="var.value" ng-change="updateEnvironmentVariable(service, var)" placeholder="e.g. bar">
|
|
<span class="input-group-btn">
|
|
<button class="btn btn-default" type="button" ng-click="removeEnvironmentVariable(service, $index)">
|
|
<i class="fa fa-minus" aria-hidden="true"></i>
|
|
</button>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- !environment-variable-input-list -->
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Labels</td>
|
|
<td>
|
|
<div class="form-group">
|
|
<div class="col-sm-11 nopadding">
|
|
<span class="label label-default interactive fit-text-size" ng-click="addLabel(service)">
|
|
<i class="fa fa-plus-circle" aria-hidden="true"></i> label
|
|
</span>
|
|
</div>
|
|
<!-- labels-input-list -->
|
|
<div class="col-sm-11 form-inline nopadding" style="margin-top: 10px;">
|
|
<div ng-repeat="label in service.ServiceLabels" style="margin-top: 2px;">
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">name</span>
|
|
<input type="text" class="form-control" ng-model="label.key" placeholder="e.g. com.example.foo" ng-change="updateLabel(service, label)">
|
|
</div>
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">value</span>
|
|
<input type="text" class="form-control" ng-model="label.value" placeholder="e.g. bar" ng-change="updateLabel(service, label)">
|
|
<span class="input-group-btn">
|
|
<button class="btn btn-default" type="button" ng-click="removeLabel(service, $index)">
|
|
<i class="fa fa-minus" aria-hidden="true"></i>
|
|
</button>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- !labels-input-list -->
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Container labels</td>
|
|
<td>
|
|
<div class="form-group">
|
|
<div class="col-sm-11 nopadding">
|
|
<span class="label label-default interactive fit-text-size" ng-click="addContainerLabel(service)">
|
|
<i class="fa fa-plus-circle" aria-hidden="true"></i> container label
|
|
</span>
|
|
</div>
|
|
<!-- labels-input-list -->
|
|
<div class="col-sm-11 form-inline nopadding" style="margin-top: 10px;">
|
|
<div ng-repeat="label in service.ServiceContainerLabels" style="margin-top: 2px;">
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">name</span>
|
|
<input type="text" class="form-control" ng-model="label.key" placeholder="e.g. com.example.foo" ng-change="updateLabel(service, label)">
|
|
</div>
|
|
<div class="input-group col-sm-5 input-group-sm">
|
|
<span class="input-group-addon fit-text-size">value</span>
|
|
<input type="text" class="form-control" ng-model="label.value" placeholder="e.g. bar" ng-change="updateLabel(service, label)">
|
|
<span class="input-group-btn">
|
|
<button class="btn btn-default" type="button" ng-click="removeContainerLabel(service, $index)">
|
|
<i class="fa fa-minus" aria-hidden="true"></i>
|
|
</button>
|
|
</span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
<!-- !labels-input-list -->
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Update Parallelism</td>
|
|
<td>
|
|
<span ng-if="!service.EditParallelism">
|
|
{{ service.UpdateParallelism }}
|
|
<a class="interactive" ng-click="service.EditParallelism = true;"><i class="fa fa-arrows-v" aria-hidden="true"></i> Change</a>
|
|
</span>
|
|
<span ng-if="service.EditParallelism">
|
|
<input class="input-sm" type="number" ng-model="service.newServiceUpdateParallelism" />
|
|
<a class="interactive" ng-click="service.EditParallelism = false;"><i class="fa fa-times"></i></a>
|
|
<a class="interactive" ng-click="changeParallelism(service)"><i class="fa fa-check-square-o"></i></a>
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Update Delay</td>
|
|
<td>
|
|
<span ng-if="!service.EditDelay">
|
|
{{ service.UpdateDelay }}
|
|
<a class="interactive" ng-click="service.EditDelay = true;"><i class="fa fa-arrows-v" aria-hidden="true"></i> Change</a>
|
|
</span>
|
|
<span ng-if="service.EditDelay">
|
|
<input class="input-sm" type="number" ng-model="service.newServiceUpdateDelay" />
|
|
<a class="interactive" ng-click="service.EditDelay = false;"><i class="fa fa-times"></i></a>
|
|
<a class="interactive" ng-click="changeUpdateDelay(service)"><i class="fa fa-check-square-o"></i></a>
|
|
</span>
|
|
</td>
|
|
</tr>
|
|
<tr>
|
|
<td>Update Failure Action</td>
|
|
<td>
|
|
<div class="form-group">
|
|
<label class="radio-inline">
|
|
<input type="radio" name="failure_action" ng-model="service.newServiceUpdateFailureAction" value="continue" ng-change="changeUpdateFailureAction(service)">
|
|
Continue
|
|
</label>
|
|
<label class="radio-inline">
|
|
<input type="radio" name="failure_action" ng-model="service.newServiceUpdateFailureAction" value="pause" ng-change="changeUpdateFailureAction(service)">
|
|
Pause
|
|
</label>
|
|
</div>
|
|
</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
</rd-widget-body>
|
|
<rd-widget-footer ng-if="service.hasChanges">
|
|
<div>
|
|
<button type="button" class="btn btn-primary" ng-click="updateService(service)">Save changes</button>
|
|
<button type="button" class="btn btn-default" ng-click="cancelChanges(service)">Reset</button>
|
|
</div>
|
|
</rd-widget-footer>
|
|
</rd-widget>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row" ng-if="tasks.length > 0">
|
|
<div class="col-lg-12 col-md-12 col-xs-12">
|
|
<rd-widget>
|
|
<rd-widget-header icon="fa-tasks" title="Associated tasks"></rd-widget-header>
|
|
<rd-widget-body classes="no-padding">
|
|
<table class="table">
|
|
<thead>
|
|
<tr>
|
|
<th>Id</th>
|
|
<th>
|
|
<a ui-sref="service" ng-click="order('Status')">
|
|
Status
|
|
<span ng-show="sortType == 'Status' && !sortReverse" class="glyphicon glyphicon-chevron-down"></span>
|
|
<span ng-show="sortType == 'Status' && sortReverse" class="glyphicon glyphicon-chevron-up"></span>
|
|
</a>
|
|
</th>
|
|
<th>
|
|
<a ui-sref="service" ng-click="order('Slot')">
|
|
Slot
|
|
<span ng-show="sortType == 'Slot' && !sortReverse" class="glyphicon glyphicon-chevron-down"></span>
|
|
<span ng-show="sortType == 'Slot' && sortReverse" class="glyphicon glyphicon-chevron-up"></span>
|
|
</a>
|
|
</th>
|
|
<th ng-if="displayNode">
|
|
<a ui-sref="service" ng-click="order('Node')">
|
|
Node
|
|
<span ng-show="sortType == 'Node' && !sortReverse" class="glyphicon glyphicon-chevron-down"></span>
|
|
<span ng-show="sortType == 'Node' && sortReverse" class="glyphicon glyphicon-chevron-up"></span>
|
|
</a>
|
|
</th>
|
|
<th>
|
|
<a ui-sref="service" ng-click="order('Updated')">
|
|
Last update
|
|
<span ng-show="sortType == 'Updated' && !sortReverse" class="glyphicon glyphicon-chevron-down"></span>
|
|
<span ng-show="sortType == 'Updated' && sortReverse" class="glyphicon glyphicon-chevron-up"></span>
|
|
</a>
|
|
</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
<tr dir-paginate="task in (filteredTasks = ( tasks | orderBy:sortType:sortReverse | itemsPerPage: pagination_count))">
|
|
<td><a ui-sref="task({ id: task.Id })">{{ task.Id }}</a></td>
|
|
<td><span class="label label-{{ task.Status|taskstatusbadge }}">{{ task.Status }}</span></td>
|
|
<td>{{ task.Slot }}</td>
|
|
<td ng-if="displayNode">{{ task.Node }}</td>
|
|
<td>{{ task.Updated|getisodate }}</td>
|
|
</tr>
|
|
</tbody>
|
|
</table>
|
|
<div ng-if="tasks" class="pagination-controls">
|
|
<dir-pagination-controls></dir-pagination-controls>
|
|
</div>
|
|
</rd-widget-body>
|
|
</rd-widget>
|
|
</div>
|
|
</div>
|