kanbanworkflowstimelinescrumrubyroadmapproject-planningproject-managementopenprojectangularissue-trackerifcgantt-chartganttbug-trackerboardsbcf
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
178 lines
5.8 KiB
178 lines
5.8 KiB
<table class="workpackages-table">
|
|
<colgroup>
|
|
<col />
|
|
<col ng-hide="hideWorkPackageDetails" />
|
|
<col />
|
|
<col ng-repeat="column in columns" />
|
|
</colgroup>
|
|
<thead>
|
|
<tr>
|
|
<th class="checkbox hide-when-print">
|
|
<a href
|
|
alt="{{toggleRowsLabel}}"
|
|
class="no-decoration-on-hover"
|
|
ng-click="setCheckedStateForAllRows(!(rows | allRowsChecked))"
|
|
title="{{toggleRowsLabel}}">
|
|
<icon-wrapper icon-title="{{toggleRowsLabel}}"
|
|
icon-name="yes"></icon-wrapper>
|
|
</a>
|
|
</th>
|
|
<th sort-header
|
|
header-name="'id'"
|
|
header-title="'#'"
|
|
has-dropdown-menu
|
|
target="ColumnContextMenu"
|
|
locals="columns, column"
|
|
sortable="true"
|
|
query="query"/>
|
|
|
|
<th sort-header ng-repeat="column in columns"
|
|
has-dropdown-menu
|
|
target="ColumnContextMenu"
|
|
locals="columns, column"
|
|
locale="column.custom_field && columns.custom_field.name_locale || I18n.locale"
|
|
header-name="column.name"
|
|
header-title="column.title"
|
|
sortable="column.sortable"
|
|
query="query">
|
|
</th>
|
|
</tr>
|
|
</thead>
|
|
|
|
<tbody>
|
|
|
|
<!-- Group headers -->
|
|
|
|
<tr work-package-group-header
|
|
ng-repeat-start="row in rows"
|
|
ng-if="!!groupByColumn &&
|
|
($first || row.groupName !== rows[$index-1].groupName)"
|
|
ng-class="{
|
|
group: true,
|
|
open: groupExpanded[currentGroup],
|
|
closed: !groupExpanded[currentGroup],
|
|
keyboard_hover: true
|
|
}"
|
|
id="group-header-{{ row.groupName }}">
|
|
<td colspan="{{ columns.length + 3 - (!!hideWorkPackageDetails * 1) }}">
|
|
<span ng-class="[
|
|
'expander',
|
|
'icon-context',
|
|
'icon-' + (groupExpanded[currentGroup] && 'minus' || 'plus')
|
|
]"
|
|
ng-click="toggleCurrentGroup()">
|
|
<span ng-class="{
|
|
'hidden-for-sighted': true,
|
|
expand: !groupExpanded[currentGroup],
|
|
collapse: groupExpanded[currentGroup]
|
|
}">
|
|
{{ groupExpanded[currentGroup] && I18n.t('js.label_collapse') || I18n.t('js.label_expand') }}
|
|
</span>
|
|
<span class="hidden-for-sighted collapse">{{ I18n.t('js.label_collapse') }}</span>
|
|
</span>
|
|
|
|
<span>
|
|
<span work-package-column
|
|
work-package="row.object"
|
|
column="groupByColumn"
|
|
display-type="{{ groupByColumn.name }}"
|
|
display-empty="-">
|
|
</span>
|
|
|
|
<span class="count">
|
|
({{ countByGroup[row.groupName] }})
|
|
|
|
<span aria-hidden="true" role="presentation" tabindex="-1">
|
|
<a class="toggle-all" href ng-click="toggleAllGroups()">
|
|
{{ groupExpanded[currentGroup] && I18n.t('js.label_collapse_all') || I18n.t('js.label_expand_all') }}
|
|
</a>
|
|
</span>
|
|
</span>
|
|
</span>
|
|
|
|
</td>
|
|
</tr>
|
|
|
|
<!-- Work package rows -->
|
|
|
|
<tr work-package-row
|
|
id="work-package-{{ row.object.id }}"
|
|
has-context-menu
|
|
target="WorkPackageContextMenu"
|
|
locals="rows, row"
|
|
single-click="selectWorkPackage(row, $event)"
|
|
ng-dblclick="showWorkPackageDetails(row)"
|
|
ng-class="[
|
|
'issue',
|
|
'hascontextmenu',
|
|
row.checked && 'context-menu-selection',
|
|
!row.object['leaf?'] && 'parent' || '',
|
|
row.level > 0 && 'child idnt' || '',
|
|
row.level > 0 && ('idnt-' + row.level) || ''
|
|
]"
|
|
ng-show="!groupByColumn || groupExpanded[row.groupName]">
|
|
|
|
<td class="checkbox hide-when-print">
|
|
<accessible-checkbox name="ids[]"
|
|
checkbox-id="work_package{{row.object.id}}"
|
|
checkbox-value="row.object.id"
|
|
checkbox-title="{{checkboxTitle}}"
|
|
model="row.checked"/>
|
|
</td>
|
|
|
|
<td class="id">
|
|
<span ng-if="workPackage.parent_id" class="hidden-for-sighted" ng-bind="parentWorkPackageHiddenText">
|
|
</span>
|
|
<a ng-href="{{ workPackagePath(row.object.id) }}">{{row.object.id}}</a>
|
|
</td>
|
|
|
|
<td ng-repeat="column in columns" class="{{column.name}}" lang="{{column.custom_field && column.custom_field.name_locale || I18n.locale}}">
|
|
<span work-package-column
|
|
work-package="row.object"
|
|
column="column"
|
|
display-type="{{column.meta_data.data_type}}"/>
|
|
</td>
|
|
</tr>
|
|
|
|
|
|
<!-- Sums for groups -->
|
|
|
|
<tr work-package-group-sums
|
|
ng-repeat-end
|
|
ng-if="displaySums && !!groupByColumn &&
|
|
($last || row.groupName !== rows[$index+1].groupName)"
|
|
ng-show="!groupByColumn || groupExpanded[row.groupName]"
|
|
ng-class="[
|
|
'group-sum',
|
|
'sum',
|
|
'grouped',
|
|
'issue',
|
|
'work_package'
|
|
]">
|
|
<td colspan="{{3 - (!!hideWorkPackageDetails * 1)}}">
|
|
{{ I18n.t('js.label_sum_for') }}
|
|
<span work-package-column
|
|
work-package="row.object"
|
|
column="groupByColumn"
|
|
display-empty="-"/>
|
|
</td>
|
|
<td ng-repeat="column in columns">
|
|
{{ column.group_sums[row.groupName] }}
|
|
</td>
|
|
</tr>
|
|
|
|
<!-- Total sums -->
|
|
|
|
<tr work-package-total-sums
|
|
ng-if="displaySums"
|
|
cg-busy="fetchTotalSums"
|
|
class="sum group all issue work_package">
|
|
<td colspan="{{3 - (!!hideWorkPackageDetails * 1)}}">{{ I18n.t('js.label_sum_for') }} {{ I18n.t('js.label_all_work_packages') }}</td>
|
|
<td ng-repeat="column in columns">
|
|
{{ column.total_sum }}
|
|
</td>
|
|
</tr>
|
|
|
|
|
|
</tbody>
|
|
</table>
|
|
|