mirror of https://github.com/portainer/portainer
				
				
				
			
		
			
				
	
	
		
			164 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			164 lines
		
	
	
		
			9.0 KiB
		
	
	
	
		
			HTML
		
	
	
<div class="datatable">
 | 
						|
  <rd-widget>
 | 
						|
    <rd-widget-body classes="no-padding">
 | 
						|
      <div class="toolBar">
 | 
						|
        <div class="toolBarTitle">
 | 
						|
          <i class="fa" ng-class="$ctrl.titleIcon" aria-hidden="true" style="margin-right: 2px;"></i> {{ $ctrl.title }}
 | 
						|
        </div>
 | 
						|
        <div class="settings">
 | 
						|
          <span class="setting" ng-class="{ 'setting-active': $ctrl.state.displayTextFilter }" ng-click="$ctrl.updateDisplayTextFilter()" ng-if="$ctrl.showTextFilter">
 | 
						|
            <i class="fa fa-search" aria-hidden="true"></i> Search
 | 
						|
          </span>
 | 
						|
        </div>
 | 
						|
      </div>
 | 
						|
      <div class="actionBar">
 | 
						|
        <div class="btn-group" role="group" aria-label="...">
 | 
						|
          <button ng-if="$ctrl.showForceUpdateButton" type="button" class="btn btn-sm btn-primary"
 | 
						|
            ng-disabled="$ctrl.state.selectedItemCount === 0" ng-click="$ctrl.forceUpdateAction($ctrl.state.selectedItems)">
 | 
						|
            <i class="fa fa-refresh space-right" aria-hidden="true"></i>Update
 | 
						|
          </button>
 | 
						|
          <button type="button" class="btn btn-sm btn-danger"
 | 
						|
            ng-disabled="$ctrl.state.selectedItemCount === 0" ng-click="$ctrl.removeAction($ctrl.state.selectedItems)">
 | 
						|
            <i class="fa fa-trash space-right" aria-hidden="true"></i>Remove
 | 
						|
          </button>
 | 
						|
        </div>
 | 
						|
        <button type="button" class="btn btn-sm btn-primary" ui-sref="docker.services.new">
 | 
						|
          <i class="fa fa-plus space-right" aria-hidden="true"></i>Add service
 | 
						|
        </button>
 | 
						|
      </div>
 | 
						|
      <div class="searchBar" ng-if="$ctrl.state.displayTextFilter">
 | 
						|
        <i class="fa fa-search searchIcon" aria-hidden="true"></i>
 | 
						|
        <input type="text" class="searchInput" ng-model="$ctrl.state.textFilter" placeholder="Search..." auto-focus>
 | 
						|
      </div>
 | 
						|
      <div class="table-responsive">
 | 
						|
        <table class="table table-hover">
 | 
						|
          <thead>
 | 
						|
            <tr>
 | 
						|
              <th>
 | 
						|
                <span class="md-checkbox">
 | 
						|
                  <input id="select_all" type="checkbox" ng-model="$ctrl.state.selectAll" ng-change="$ctrl.selectAll()" />
 | 
						|
                  <label for="select_all"></label>
 | 
						|
                </span>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('Name')">
 | 
						|
                  Name
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Name' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Name' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('StackName')">
 | 
						|
                  Stack
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'StackName' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'StackName' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('Image')">
 | 
						|
                  Image
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Image' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Image' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('Mode')">
 | 
						|
                  Scheduling Mode
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Mode' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Mode' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('Ports')">
 | 
						|
                  Published Ports
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Ports' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Ports' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th>
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('UpdatedAt')">
 | 
						|
                  Last Update
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'UpdatedAt' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'UpdatedAt' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
              <th ng-if="$ctrl.showOwnershipColumn">
 | 
						|
                <a ng-click="$ctrl.changeOrderBy('ResourceControl.Ownership')">
 | 
						|
                  Ownership
 | 
						|
                  <i class="fa fa-sort-alpha-asc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'ResourceControl.Ownership' && !$ctrl.state.reverseOrder"></i>
 | 
						|
                  <i class="fa fa-sort-alpha-desc" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'ResourceControl.Ownership' && $ctrl.state.reverseOrder"></i>
 | 
						|
                </a>
 | 
						|
              </th>
 | 
						|
            </tr>
 | 
						|
          </thead>
 | 
						|
          <tbody>
 | 
						|
            <tr dir-paginate="item in ($ctrl.state.filteredDataSet = ($ctrl.dataset | filter:$ctrl.state.textFilter | orderBy:$ctrl.state.orderBy:$ctrl.state.reverseOrder | itemsPerPage: $ctrl.state.paginatedItemLimit))" ng-class="{active: item.Checked}">
 | 
						|
              <td>
 | 
						|
                <span class="md-checkbox">
 | 
						|
                  <input id="select_{{ $index }}" type="checkbox" ng-model="item.Checked" ng-change="$ctrl.selectItem(item)"/>
 | 
						|
                  <label for="select_{{ $index }}"></label>
 | 
						|
                </span>
 | 
						|
                <a ui-sref="docker.services.service({id: item.Id})">{{ item.Name }}</a>
 | 
						|
              </td>
 | 
						|
              <td>{{ item.StackName ? item.StackName : '-' }}</td>
 | 
						|
              <td>{{ item.Image | hideshasum }}</td>
 | 
						|
              <td>
 | 
						|
                {{ item.Mode }} <code>{{ item.Running }}</code> / <code>{{ item.Replicas }}</code>
 | 
						|
                <span ng-if="item.Mode === 'replicated' && !item.Scale">
 | 
						|
                  <a class="interactive" ng-click="item.Scale = true; item.ReplicaCount = item.Replicas;">
 | 
						|
                    <i class="fa fa-arrows-v" aria-hidden="true"></i> Scale
 | 
						|
                  </a>
 | 
						|
                </span>
 | 
						|
                <span ng-if="item.Mode === 'replicated' && item.Scale">
 | 
						|
                  <input class="input-sm" type="number" ng-model="item.Replicas" on-enter-key="$ctrl.scaleAction(item)" />
 | 
						|
                  <a class="interactive" ng-click="item.Scale = false;"><i class="fa fa-times"></i></a>
 | 
						|
                  <a class="interactive" ng-click="$ctrl.scaleAction(item)"><i class="fa fa-check-square-o"></i></a>
 | 
						|
                </span>
 | 
						|
              </td>
 | 
						|
              <td>
 | 
						|
                <a ng-if="item.Ports && item.Ports.length > 0 && p.PublishedPort" ng-repeat="p in item.Ports" class="image-tag" ng-href="http://{{ $ctrl.publicUrl }}:{{ p.PublishedPort }}" target="_blank">
 | 
						|
                  <i class="fa fa-external-link" aria-hidden="true"></i> {{ p.PublishedPort }}:{{ p.TargetPort }}
 | 
						|
                </a>
 | 
						|
                <span ng-if="!item.Ports || item.Ports.length === 0 || !$ctrl.swarmManagerIp" >-</span>
 | 
						|
              </td>
 | 
						|
              <td>{{ item.UpdatedAt | getisodate }}</td>
 | 
						|
              <td ng-if="$ctrl.showOwnershipColumn">
 | 
						|
                <span>
 | 
						|
                  <i ng-class="item.ResourceControl.Ownership | ownershipicon" aria-hidden="true"></i>
 | 
						|
                  {{ item.ResourceControl.Ownership ? item.ResourceControl.Ownership : item.ResourceControl.Ownership = 'public' }}
 | 
						|
                </span>
 | 
						|
              </td>
 | 
						|
            </tr>
 | 
						|
            <tr ng-if="!$ctrl.dataset">
 | 
						|
              <td colspan="7" class="text-center text-muted">Loading...</td>
 | 
						|
            </tr>
 | 
						|
            <tr ng-if="$ctrl.state.filteredDataSet.length === 0">
 | 
						|
              <td colspan="7" class="text-center text-muted">No service available.</td>
 | 
						|
            </tr>
 | 
						|
          </tbody>
 | 
						|
        </table>
 | 
						|
      </div>
 | 
						|
      <div class="footer" ng-if="$ctrl.dataset">
 | 
						|
        <div class="infoBar" ng-if="$ctrl.state.selectedItemCount !== 0">
 | 
						|
          {{ $ctrl.state.selectedItemCount }} item(s) selected
 | 
						|
        </div>
 | 
						|
        <div class="paginationControls">
 | 
						|
          <form class="form-inline">
 | 
						|
            <span class="limitSelector">
 | 
						|
              <span style="margin-right: 5px;">
 | 
						|
                Items per page
 | 
						|
              </span>
 | 
						|
              <select class="form-control" ng-model="$ctrl.state.paginatedItemLimit" ng-change="$ctrl.changePaginationLimit()">
 | 
						|
                <option value="0">All</option>
 | 
						|
                <option value="10">10</option>
 | 
						|
                <option value="25">25</option>
 | 
						|
                <option value="50">50</option>
 | 
						|
                <option value="100">100</option>
 | 
						|
              </select>
 | 
						|
            </span>
 | 
						|
            <dir-pagination-controls max-size="5"></dir-pagination-controls>
 | 
						|
          </form>
 | 
						|
        </div>
 | 
						|
      </div>
 | 
						|
    </rd-widget-body>
 | 
						|
  </rd-widget>
 | 
						|
</div>
 |