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.
192 lines
8.6 KiB
192 lines
8.6 KiB
<div class="work-packages--show-view" ng-class="{'edit-all-mode': editAll.state}">
|
|
<div class="toolbar-container">
|
|
<div toolbar id="toolbar">
|
|
<ul id="toolbar-items">
|
|
<li class="toolbar-item" ng-hide="true">
|
|
<button class="button -alt-highlight add-work-package"
|
|
has-dropdown-menu
|
|
target="TasksDropdownMenu"
|
|
locals="availableTypes,projectIdentifier"
|
|
ng-disabled="cannot('work_package', 'create') || editAll.state">
|
|
<i class="button--icon icon-add"></i>
|
|
<span class="button--text" ng-bind="::I18n.t('js.toolbar.unselected_title')"></span>
|
|
<i class="button--dropdown-indicator"></i>
|
|
</button>
|
|
</li>
|
|
<li class="toolbar-item">
|
|
<button class="button edit-all-button"
|
|
ng-hide="editAll.state"
|
|
ng-click="editAll.start()"
|
|
ng-disabled="!editAll.allowed"
|
|
title="{{I18n.t('js.button_edit')}}">
|
|
<i class="button--icon icon-edit"></i>
|
|
</button>
|
|
</li>
|
|
<li class="toolbar-item" ng-if="displayWatchButton">
|
|
<work-package-watcher-button work-package="workPackage"></work-package-watcher-button>
|
|
</li>
|
|
<li class="toolbar-item" feature-flag="detailsView">
|
|
<ul id="work-packages-view-mode-selection" class="toolbar-button-group">
|
|
<li>
|
|
<label for="work-packages-list-view-button"
|
|
ng-attr-accesskey="{{ isListViewActive() ? undefined : '8' }}"
|
|
class="hidden-for-sighted">
|
|
{{ getActivationActionLabel(isDetailsViewActive()) + ' ' + I18n.t('js.button_list_view') }}
|
|
</label>
|
|
<button id="work-packages-list-view-button"
|
|
ng-disabled="editAll.state"
|
|
class="button"
|
|
title="{{ getActivationActionLabel(!isListViewActive()) + ' ' + I18n.t('js.button_list_view') }}"
|
|
ng-click="closeShowView()"
|
|
ng-class="{ '-active': isListViewActive() }">
|
|
<i class="icon-list-view button--icon"></i>
|
|
</button>
|
|
</li>
|
|
<li feature-flag="detailsView">
|
|
<label for="work-packages-details-view-button"
|
|
ng-attr-accesskey="{{ isDetailsViewActive() ? undefined : '8' }}"
|
|
class="hidden-for-sighted">
|
|
{{ getActivationActionLabel(!isDetailsViewActive()) + ' ' + I18n.t('js.button_details_view') }}
|
|
</label>
|
|
<button class="hide"
|
|
ng-click="openOverviewTab()"></button>
|
|
<button id="work-packages-details-view-button"
|
|
class="button"
|
|
title="{{ getActivationActionLabel(!isDetailsViewActive()) + ' ' + I18n.t('js.button_details_view') }}"
|
|
ng-class="{ '-active': isDetailsViewActive() }"
|
|
ng-click="showWorkPackageDetails()">
|
|
<i class="icon-split-view button--icon"></i>
|
|
</button>
|
|
</li>
|
|
<li>
|
|
<label for="work-packages-show-view-button"
|
|
ng-attr-accesskey="{{ isShowViewActive() ? undefined : '9' }}"
|
|
class="hidden-for-sighted">
|
|
{{ getActivationActionLabel(!isShowViewActive()) + ' ' + I18n.t('js.button_show_view') }}
|
|
</label>
|
|
<button id="work-packages-show-view-button"
|
|
class="button"
|
|
title="{{ getActivationActionLabel(!isShowViewActive()) + ' ' + I18n.t('js.button_show_view') }}"
|
|
ng-click="showWorkPackageShowView()"
|
|
ng-class="{ '-active': isShowViewActive() }">
|
|
<i class="icon-fullscreen-view button--icon"></i>
|
|
</button>
|
|
</li>
|
|
</ul>
|
|
</li>
|
|
<li class="toolbar-item action_menu_main" id="action-show-more-dropdown-menu">
|
|
<button class="button dropdown-relative"
|
|
ng-disabled="!actionsAvailable || editAll.state"
|
|
has-dropdown-menu
|
|
target="ShowMoreDropdownMenu"
|
|
locals="permittedActions,actionsAvailable,triggerMoreMenuAction">
|
|
<span class="button--text" ng-bind="::I18n.t('js.button_more')"></span>
|
|
<i class="button--dropdown-indicator"></i>
|
|
</button>
|
|
</li>
|
|
</ul>
|
|
<ul class="subject-header">
|
|
<li class="subject-header-inner">
|
|
<div class="inline-edit">
|
|
<work-package-field field-name="'subject'"></work-package-field>
|
|
</div>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="work-packages--filters-optional-container" ng-show="showFiltersOptions">
|
|
<div query-form id="query_form_content" class="hide-when-print">
|
|
<query-filters></query-filters>
|
|
</div>
|
|
</div>
|
|
|
|
<back-url></back-url>
|
|
|
|
|
|
<div class="work-packages--split-view" cg-busy="wpPromise">
|
|
<div class="work-packages--left-panel">
|
|
<div class="work-packages--panel-inner">
|
|
<div class="attributes-group">
|
|
|
|
<div class="attributes-group--header">
|
|
<div class="attributes-group--header-container">
|
|
<h3 class="attributes-group--header-text">
|
|
<!-- {{ I18n.t('js.label_description') }} -->
|
|
{{type.props.name}} #{{workPackage.props.id}}
|
|
</h3>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="single-attribute wiki">
|
|
<work-package-field field-name="'description'"></work-package-field>
|
|
</div>
|
|
</div>
|
|
|
|
<div ng-repeat="group in vm.groupedFields" ng-hide="vm.hideEmptyFields && vm.isGroupHideable(vm.groupedFields, group.groupName, vm.workPackage)" class="attributes-group">
|
|
|
|
<div class="attributes-group--header">
|
|
<div class="attributes-group--header-container">
|
|
<h3 class="attributes-group--header-text"
|
|
ng-bind="I18n.t('js.work_packages.property_groups.' + group.groupName)"></h3>
|
|
</div>
|
|
<div class="attributes-group--header-toggle">
|
|
<panel-expander tabindex="-1" ng-if="vm.showToggleButton() && $first"
|
|
collapsed="vm.hideEmptyFields"
|
|
expand-text="{{ I18n.t('js.label_show_attributes') }}"
|
|
collapse-text="{{ I18n.t('js.label_hide_attributes') }}">
|
|
</panel-expander>
|
|
</div>
|
|
</div>
|
|
|
|
<dl class="attributes-key-value">
|
|
<dt
|
|
ng-hide="vm.hideEmptyFields && vm.isFieldHideable(vm.workPackage, field)"
|
|
ng-if="vm.isSpecified(vm.workPackage, field)"
|
|
ng-repeat-start="field in group.attributes" class="attributes-key-value--key">
|
|
{{vm.getLabel(vm.workPackage, field)}}
|
|
<span class="required" ng-if="vm.hasNiceStar(vm.workPackage, field)"> *</span>
|
|
</dt>
|
|
<dd
|
|
ng-hide="vm.hideEmptyFields && vm.isFieldHideable(vm.workPackage, field)"
|
|
ng-if="vm.isSpecified(vm.workPackage, field)"
|
|
ng-repeat-end
|
|
class="attributes-key-value--value-container">
|
|
<work-package-field field-name="field"></work-package-field>
|
|
</dd>
|
|
</dl>
|
|
</div>
|
|
|
|
<work-package-attachments edit data-ng-show="!vm.hideEmptyFields || vm.filesExist" work-package="vm.workPackage"></work-package-attachments>
|
|
|
|
|
|
<work-package-edit-actions></work-package-edit-actions>
|
|
</div>
|
|
</div>
|
|
<div class="work-packages--right-panel">
|
|
<div class="work-packages--panel-inner">
|
|
<div id="tabs">
|
|
<ul class="tabrow">
|
|
<!-- The hrefs with empty URLs are necessary for IE10 to focus these links
|
|
properly. Thus, don't remove the hrefs or the empty URLs! -->
|
|
<li ui-sref="work-packages.show.activity({})"
|
|
ui-sref-active="selected">
|
|
<a href="" ng-bind="I18n.t('js.work_packages.tabs.activity')"/>
|
|
</li>
|
|
<li ui-sref="work-packages.show.relations({})"
|
|
ui-sref-active="selected">
|
|
<a href="" ng-bind="I18n.t('js.work_packages.tabs.relations')"/>
|
|
</li>
|
|
<li ng-if="canViewWorkPackageWatchers()"
|
|
ui-sref="work-packages.show.watchers({})"
|
|
ui-sref-active="selected">
|
|
<a href="" ng-bind="I18n.t('js.work_packages.tabs.watchers')"/>
|
|
</li>
|
|
</ul>
|
|
</div>
|
|
<div class="tabcontent" ui-view>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|