Jingwei.Zhang 6d2ea1bf34 refactor: Refactor path jump
Refactor path jump by routeName which is defined in menu as key

Change-Id: I82cda19a2b92b29498238b85c75181848e51e072
2021-11-11 09:59:51 +08:00

307 lines
7.4 KiB
JavaScript

// Copyright 2021 99cloud
//
// Licensed under the Apache License, Version 2.0 (the "License");
// you may not use this file except in compliance with the License.
// You may obtain a copy of the License at
//
// http://www.apache.org/licenses/LICENSE-2.0
//
// Unless required by applicable law or agreed to in writing, software
// distributed under the License is distributed on an "AS IS" BASIS,
// WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
// See the License for the specific language governing permissions and
// limitations under the License.
import React from 'react';
import { observer, inject } from 'mobx-react';
import ImageType from 'components/ImageType';
import Base from 'containers/List';
import {
instanceStatus,
transitionStatus,
lockRender,
instanceStatusFilter,
isIronicInstance,
} from 'resources/instance';
import globalServerStore, { ServerStore } from 'stores/nova/instance';
import { ServerGroupInstanceStore } from 'stores/skyline/server-group-instance';
import actionConfigs from './actions';
export class Instance extends Base {
init() {
if (!this.inDetailPage) {
this.store = globalServerStore;
} else if (this.inServerGroupDetailPage) {
this.store = new ServerGroupInstanceStore();
} else {
this.store = new ServerStore();
}
this.downloadStore = new ServerStore();
}
get tabs() {
return [];
}
get policy() {
if (this.isAdminPage) {
return 'os_compute_api:servers:index:get_all_tenants';
}
return 'os_compute_api:servers:index';
}
get name() {
return t('instances');
}
get inServerGroupDetailPage() {
if (!this.inDetailPage) {
return false;
}
const {
match: { path },
} = this.props;
return path.indexOf('server-group') >= 0;
}
get inHostDetailPage() {
if (!this.inDetailPage) {
return false;
}
const {
match: { path },
} = this.props;
return path.indexOf('hypervisors') >= 0;
}
get inFlavorDetailPage() {
if (!this.inDetailPage) {
return false;
}
const {
match: { path },
} = this.props;
return path.indexOf('flavor') >= 0;
}
get isFilterByBackend() {
return !this.inServerGroupDetailPage;
}
get isSortByBackend() {
return this.isFilterByBackend;
}
get transitionStatusList() {
return Object.keys(transitionStatus);
}
get adminPageHasProjectFilter() {
return true;
}
get defaultSortKey() {
return 'created_at';
}
get batchActions() {
const { selectedRowKeys = [], data = [] } = this.store.list;
const slectedRows = selectedRowKeys.map((key) => {
return data.find((it) => it.id === key);
});
const allIronic = slectedRows.every((it) => isIronicInstance(it));
const noIronic = slectedRows.every((it) => !isIronicInstance(it));
if (allIronic) {
return actionConfigs.batchActionsForIronic;
}
if (noIronic) {
return actionConfigs.batchActions;
}
return actionConfigs.batchActionsForOthers;
}
getCheckboxProps(record) {
return {
name: record.name,
};
}
getColumns() {
const columns = [
{
title: t('ID/Name'),
dataIndex: 'name',
routeName: this.getRouteName('instanceDetail'),
sortKey: 'display_name',
},
{
title: t('Project ID/Name'),
dataIndex: 'project_name',
isHideable: true,
hidden: !this.isAdminPage,
sortKey: 'project_id',
},
{
title: t('Host'),
dataIndex: 'host',
isHideable: true,
hidden: !this.isAdminPage,
},
{
title: t('Image'),
dataIndex: 'image_os_distro',
isHideable: true,
render: (value, record) => (
<ImageType type={value} title={record.image_name} />
),
stringify: (_, record) => record.image_name,
sorter: false,
width: 80,
},
{
title: t('Fixed IP'),
dataIndex: 'fixed_addresses',
sorter: false,
isHideable: true,
render: (fixed_addresses) => {
if (!fixed_addresses.length) {
return '-';
}
return fixed_addresses.map((it) => <div key={it}>{it}</div>);
},
stringify: (value) => value.join(',') || '-',
},
{
title: t('Floating IP'),
dataIndex: 'floating_addresses',
isHideable: true,
sorter: false,
render: (addresses) => {
if (!addresses.length) {
return '-';
}
return addresses.map((it) => (
<div key={it}>
{it}
<br />
</div>
));
},
stringify: (addresses) => addresses.join(',') || '-',
},
{
title: t('Flavor'),
dataIndex: 'flavor',
sorter: false,
isHideable: true,
render: (value, record) =>
isIronicInstance(record)
? `${value}(${t('Ironic Instance')})`
: value,
},
{
title: t('Status'),
dataIndex: 'status',
sorter: false,
render: (value) => instanceStatus[value && value.toLowerCase()] || '-',
},
{
title: t('Locked'),
dataIndex: 'locked',
isHideable: true,
render: lockRender,
width: 80,
stringify: (value) => (value ? t('Locked') : t('Not locked')),
},
{
title: t('Created At'),
dataIndex: 'created_at',
isHideable: true,
valueRender: 'sinceTime',
},
];
if (this.inFlavorDetailPage) {
return columns.filter((it) => it.dataIndex !== 'flavor');
}
if (this.inHostDetailPage) {
return columns.filter((it) => it.dataIndex !== 'host');
}
return columns;
}
get actionConfigs() {
const { batchActions } = this;
if (this.isAdminPage) {
return {
...actionConfigs.adminActions,
batchActions,
};
}
if (this.inFlavorDetailPage) {
return {
...actionConfigs.actionConfigs,
primaryActions: [],
batchActions,
};
}
return {
...actionConfigs.actionConfigs,
batchActions,
};
}
get searchFilters() {
return [
{
label: t('Name'),
name: 'name',
},
...(this.isAdminPage
? [
{
label: t('Project Name'),
name: 'project_name',
},
]
: []),
...(this.isAdminPage && !this.inHostDetailPage
? [
{
label: t('Host'),
name: 'host',
},
]
: []),
instanceStatusFilter,
];
}
updateFetchParamsByPage = (params) => {
const { id, ...rest } = params;
const newParams = { ...rest };
if (this.inHostDetailPage) {
const { detail: { service: { host } = {} } = {} } = this.props;
newParams.host = host;
}
if (this.inFlavorDetailPage) {
const { detail: { id: flavor } = {} } = this.props;
newParams.flavor_id = flavor;
}
return newParams;
};
updateFetchParams = (params) => {
const { detail = {} } = this.props;
const { members } = detail;
const { id, ...rest } = params;
const newParams = { ...rest };
if (this.inServerGroupDetailPage) {
newParams.members = members;
newParams.isServerGroup = true;
}
return newParams;
};
}
export default inject('rootStore')(observer(Instance));