mirror of https://github.com/portainer/portainer
				
				
				
			
		
			
				
	
	
		
			127 lines
		
	
	
		
			6.1 KiB
		
	
	
	
		
			HTML
		
	
	
			
		
		
	
	
			127 lines
		
	
	
		
			6.1 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.titleText }} </div>
 | |
|       </div>
 | |
|       <div class="searchBar">
 | |
|         <i class="fa fa-search searchIcon" aria-hidden="true"></i>
 | |
|         <input
 | |
|           type="text"
 | |
|           class="searchInput"
 | |
|           ng-model="$ctrl.state.textFilter"
 | |
|           ng-change="$ctrl.onTextFilterChange()"
 | |
|           placeholder="Search..."
 | |
|           ng-model-options="{ debounce: 300 }"
 | |
|         />
 | |
|       </div>
 | |
|       <div class="table-responsive">
 | |
|         <table class="table table-hover nowrap-cells">
 | |
|           <thead>
 | |
|             <tr>
 | |
|               <th>
 | |
|                 <a ng-click="$ctrl.changeOrderBy('Status')">
 | |
|                   Status
 | |
|                   <i class="fa fa-sort-alpha-down" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Status' && !$ctrl.state.reverseOrder"></i>
 | |
|                   <i class="fa fa-sort-alpha-up" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Status' && $ctrl.state.reverseOrder"></i>
 | |
|                 </a>
 | |
|               </th>
 | |
|               <th>
 | |
|                 <a ng-click="$ctrl.changeOrderBy('Id')">
 | |
|                   Id
 | |
|                   <i class="fa fa-sort-alpha-down" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Id' && !$ctrl.state.reverseOrder"></i>
 | |
|                   <i class="fa fa-sort-alpha-up" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Id' && $ctrl.state.reverseOrder"></i>
 | |
|                 </a>
 | |
|               </th>
 | |
|               <th>Actions</th>
 | |
|               <th ng-if="$ctrl.showSlotColumn">
 | |
|                 <a ng-click="$ctrl.changeOrderBy('Slot')">
 | |
|                   Slot
 | |
|                   <i class="fa fa-sort-alpha-down" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Slot' && !$ctrl.state.reverseOrder"></i>
 | |
|                   <i class="fa fa-sort-alpha-up" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Slot' && $ctrl.state.reverseOrder"></i>
 | |
|                 </a>
 | |
|               </th>
 | |
|               <th>
 | |
|                 <a ng-click="$ctrl.changeOrderBy('NodeId')">
 | |
|                   Node
 | |
|                   <i class="fa fa-sort-alpha-down" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'NodeId' && !$ctrl.state.reverseOrder"></i>
 | |
|                   <i class="fa fa-sort-alpha-up" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'NodeId' && $ctrl.state.reverseOrder"></i>
 | |
|                 </a>
 | |
|               </th>
 | |
|               <th>
 | |
|                 <a ng-click="$ctrl.changeOrderBy('Updated')">
 | |
|                   Last Update
 | |
|                   <i class="fa fa-sort-alpha-down" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Updated' && !$ctrl.state.reverseOrder"></i>
 | |
|                   <i class="fa fa-sort-alpha-up" aria-hidden="true" ng-if="$ctrl.state.orderBy === 'Updated' && $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="label label-{{ item.Status.State | taskstatusbadge }}">{{ item.Status.State }}</span></td
 | |
|               >
 | |
|               <td>
 | |
|                 <a ng-if="!$ctrl.agentProxy || !item.Container" ui-sref="docker.tasks.task({id: item.Id})" class="monospaced"
 | |
|                   >{{ item.ServiceName }}{{ item.Slot ? '.' + item.Slot : '' }}{{ '.' + item.Id }}</a
 | |
|                 >
 | |
|                 <a ng-if="$ctrl.agentProxy && item.Container" ui-sref="docker.containers.container({ id: item.Container.Id, nodeName: item.Container.NodeName })" class="monospaced"
 | |
|                   >{{ item.ServiceName }}{{ item.Slot ? '.' + item.Slot : '' }}{{ '.' + item.Id }}</a
 | |
|                 >
 | |
|               </td>
 | |
|               <td>
 | |
|                 <container-quick-actions
 | |
|                   ng-if="!$ctrl.agentProxy || !item.Container"
 | |
|                   container-id="item.ContainerId"
 | |
|                   task-id="item.Id"
 | |
|                   status="item.Status.State"
 | |
|                   state="$ctrl.state"
 | |
|                 ></container-quick-actions>
 | |
|                 <container-quick-actions
 | |
|                   ng-if="$ctrl.agentProxy && item.Container"
 | |
|                   container-id="item.Container.Id"
 | |
|                   node-name="item.Container.NodeName"
 | |
|                   status="item.Status.State"
 | |
|                   state="$ctrl.state"
 | |
|                 ></container-quick-actions>
 | |
|               </td>
 | |
|               <td ng-if="$ctrl.showSlotColumn">{{ item.Slot ? item.Slot : '-' }}</td>
 | |
|               <td>{{ item.NodeId | tasknodename: $ctrl.nodes }}</td>
 | |
|               <td>{{ item.Updated | getisodate }}</td>
 | |
|             </tr>
 | |
|             <tr ng-if="!$ctrl.dataset">
 | |
|               <td colspan="6" class="text-center text-muted">Loading...</td>
 | |
|             </tr>
 | |
|             <tr ng-if="$ctrl.state.filteredDataSet.length === 0">
 | |
|               <td colspan="6" class="text-center text-muted">No task available.</td>
 | |
|             </tr>
 | |
|           </tbody>
 | |
|         </table>
 | |
|       </div>
 | |
|       <div class="footer" ng-if="$ctrl.dataset">
 | |
|         <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()" data-cy="component-paginationSelect">
 | |
|                 <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>
 |