45 lines
2.1 KiB
HTML
45 lines
2.1 KiB
HTML
<div class="build-logs-view-element" ng-class="useTimestamps ? 'with-timestamps' : ''">
|
|
<button id="copyButton" class="btn btn-primary copy-button" data-clipboard-text="{{ buildLogsText }}">
|
|
<i class="fa fa-clipboard"></i>Copy Logs
|
|
</button>
|
|
|
|
<a id="downloadButton" class="btn btn-primary download-button"
|
|
ng-href="/buildlogs/{{ currentBuild.id }}"
|
|
target="_blank">
|
|
<i class="fa fa-download"></i>Download Logs
|
|
</a>
|
|
|
|
<span class="cor-loader" ng-if="!logEntries"></span>
|
|
|
|
<span class="no-logs" ng-if="!logEntries.length && currentBuild.phase == 'waiting'">
|
|
(Waiting for build to start)
|
|
</span>
|
|
|
|
<div class="log-container" ng-class="container.type" ng-repeat="container in logEntries">
|
|
<div class="container-header" ng-class="container.type == 'phase' ? container.message : ''"
|
|
ng-switch on="container.type" ng-click="container.logs.toggle()">
|
|
<i class="fa chevron"
|
|
ng-class="container.logs.isVisible ? 'fa-chevron-down' : 'fa-chevron-right'"
|
|
ng-show="hasLogs(container)"></i>
|
|
<div ng-switch-when="phase">
|
|
<span class="container-content build-log-phase" phase="container"></span>
|
|
</div>
|
|
<div ng-switch-when="error">
|
|
<span class="container-content build-log-error" error="container" entries="logEntries"></span>
|
|
</div>
|
|
<div ng-switch-when="command">
|
|
<span class="container-content build-log-command" command="container"></span>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Display the entries for the container -->
|
|
<div class="container-logs" ng-show="container.logs.isVisible">
|
|
<div class="log-entry" bindonce ng-repeat="entry in container.logs.visibleEntries">
|
|
<span class="id" bo-text="$index + container.index + 1" ng-if="!useTimestamps"></span>
|
|
<span class="id" bo-text="formatDatetime(entry.data.datetime)" ng-if="useTimestamps"></span>
|
|
<span class="message" bo-html="processANSI(entry.message, container)"></span>
|
|
<span class="timestamp" bo-text="formatDatetime(entry.data.datetime)" ng-if="!useTimestamps"></span>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|