frontend/src/app/features/work-packages/routing/work-packages-routes.ts
//-- copyright
// OpenProject is an open source project management software.
// Copyright (C) the OpenProject GmbH
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License version 3.
//
// OpenProject is a fork of ChiliProject, which is a fork of Redmine. The copyright follows:
// Copyright (C) 2006-2013 Jean-Philippe Lang
// Copyright (C) 2010-2013 the ChiliProject Team
//
// This program is free software; you can redistribute it and/or
// modify it under the terms of the GNU General Public License
// as published by the Free Software Foundation; either version 2
// of the License, or (at your option) any later version.
//
// This program is distributed in the hope that it will be useful,
// but WITHOUT ANY WARRANTY; without even the implied warranty of
// MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
// GNU General Public License for more details.
//
// You should have received a copy of the GNU General Public License
// along with this program; if not, write to the Free Software
// Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301, USA.
//
// See COPYRIGHT and LICENSE files for more details.
//++
import { WpTabWrapperComponent } from 'core-app/features/work-packages/components/wp-tabs/components/wp-tab-wrapper/wp-tab-wrapper.component';
import { WorkPackageNewFullViewComponent } from 'core-app/features/work-packages/components/wp-new/wp-new-full-view.component';
import { WorkPackagesFullViewComponent } from 'core-app/features/work-packages/routing/wp-full-view/wp-full-view.component';
import { WorkPackageSplitViewComponent } from 'core-app/features/work-packages/routing/wp-split-view/wp-split-view.component';
import { Ng2StateDeclaration } from '@uirouter/angular';
import { WorkPackagesBaseComponent } from 'core-app/features/work-packages/routing/wp-base/wp--base.component';
import { WorkPackageListViewComponent } from 'core-app/features/work-packages/routing/wp-list-view/wp-list-view.component';
import { WorkPackageViewPageComponent } from 'core-app/features/work-packages/routing/wp-view-page/wp-view-page.component';
import { makeSplitViewRoutes } from 'core-app/features/work-packages/routing/split-view-routes.template';
import { WorkPackageCopyFullViewComponent } from 'core-app/features/work-packages/components/wp-copy/wp-copy-full-view.component';
import { KeepTabService } from 'core-app/features/work-packages/components/wp-single-view-tabs/keep-tab/keep-tab.service';
import { ShareUpsaleComponent } from 'core-app/features/enterprise/share-upsale/share-upsale.component';
export const menuItemClass = 'work-packages-menu-item';
export const sidemenuId = 'work_packages_sidemenu';
export const sideMenuOptions = {
sidemenuId,
hardReloadOnBaseRoute: true,
};
export const WORK_PACKAGES_ROUTES:Ng2StateDeclaration[] = [
{
name: 'work-packages',
parent: 'optional_project',
url: '/work_packages?query_id&query_props&name&start_onboarding_tour',
redirectTo: 'work-packages.partitioned.list',
views: {
'!$default': { component: WorkPackagesBaseComponent },
},
data: {
bodyClasses: 'router--work-packages-base',
menuItem: menuItemClass,
sideMenuOptions,
},
params: {
query_id: { type: 'query', dynamic: true },
// Use custom encoder/decoder that ensures validity of URL string
query_props: { type: 'opQueryString' },
// Optional initial tour param
start_onboarding_tour: { type: 'query', squash: true, value: undefined },
name: { type: 'string', dynamic: true },
},
},
{
name: 'work-packages.new',
url: '/new?type&parent_id',
component: WorkPackageNewFullViewComponent,
reloadOnSearch: false,
params: {
defaults: {
value: null,
},
},
data: {
baseRoute: 'work-packages',
allowMovingInEditMode: true,
bodyClasses: 'router--work-packages-full-create',
menuItem: menuItemClass,
successState: 'work-packages.show',
sideMenuOptions,
},
},
{
name: 'work-packages.copy',
url: '/{copiedFromWorkPackageId:[0-9]+}/copy',
component: WorkPackageCopyFullViewComponent,
reloadOnSearch: false,
data: {
baseRoute: 'work-packages',
allowMovingInEditMode: true,
bodyClasses: 'router--work-packages-full-create',
menuItem: menuItemClass,
sideMenuOptions,
},
},
{
name: 'work-packages.show',
url: '/{workPackageId:[0-9]+}',
// Redirect to 'activity' by default.
redirectTo: (trans) => {
const params = trans.params('to');
const keepTab = trans.injector().get(KeepTabService) as KeepTabService;
const tabIdentifier = keepTab.currentShowTab;
return {
state: 'work-packages.show.tabs',
params: { ...params, tabIdentifier: tabIdentifier || 'activity' },
};
},
component: WorkPackagesFullViewComponent,
data: {
baseRoute: 'work-packages',
bodyClasses: ['router--work-packages-full-view', 'router--work-packages-base'],
newRoute: 'work-packages.new',
menuItem: menuItemClass,
sideMenuOptions,
},
},
{
name: 'work-packages.show.tabs',
url: '/:tabIdentifier',
component: WpTabWrapperComponent,
data: {
parent: 'work-packages.show',
menuItem: menuItemClass,
sideMenuOptions,
},
},
{
name: 'work-packages.partitioned',
component: WorkPackageViewPageComponent,
url: '',
data: {
// This has to be empty to avoid inheriting the parent bodyClasses
bodyClasses: '',
sideMenuOptions,
},
},
{
name: 'work-packages.partitioned.list',
url: '',
reloadOnSearch: false,
views: {
'content-left': { component: WorkPackageListViewComponent },
},
data: {
bodyClasses: ['router--work-packages-partitioned-split-view', 'router--work-packages-base'],
menuItem: menuItemClass,
partition: '-left-only',
sideMenuOptions,
},
},
...makeSplitViewRoutes(
'work-packages.partitioned.list',
menuItemClass,
WorkPackageSplitViewComponent,
),
{
url: '/share_upsale',
name: 'work-packages.share_upsale',
component: ShareUpsaleComponent,
},
// Avoid lazy-loading the routes for now
// {
// name: 'work-packages.calendar.**',
// url: '/calendar',
// loadChildren: '../calendar/openproject-calendar.module#OpenprojectCalendarModule'
// },
];