
1. Hide containers card if value is empty 2. Fix addrss showing 3. Fix networks,ports and security groups showing 4. Remove links and labels in detail Change-Id: I4a04893a370b387d7a3e9ebcc5073f02d508aeaa
240 lines
5.4 KiB
JavaScript
240 lines
5.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 Base from 'containers/BaseDetail';
|
|
import React from 'react';
|
|
import { inject, observer } from 'mobx-react';
|
|
import { containerStatus } from 'resources/zun/container';
|
|
import { stringifyContent } from 'utils/content';
|
|
import { isEmpty } from 'lodash';
|
|
|
|
export class BaseDetail extends Base {
|
|
get leftCards() {
|
|
const cards = [this.baseInfoCard, this.miscellaneousCard];
|
|
const { stats } = this.detailData;
|
|
if (!isEmpty(stats)) {
|
|
cards.push(this.statsCard);
|
|
}
|
|
return cards;
|
|
}
|
|
|
|
get rightCards() {
|
|
return [this.specCard];
|
|
}
|
|
|
|
get baseInfoCard() {
|
|
const options = [
|
|
{
|
|
label: t('Status Detail'),
|
|
dataIndex: 'status_detail',
|
|
render: (value) => containerStatus[value] || value,
|
|
},
|
|
{
|
|
label: t('Status Reason'),
|
|
dataIndex: 'status_reason',
|
|
},
|
|
{
|
|
label: t('Task State'),
|
|
dataIndex: 'task_state',
|
|
},
|
|
{
|
|
label: t('Command'),
|
|
dataIndex: 'command',
|
|
render: stringifyContent,
|
|
},
|
|
];
|
|
|
|
return {
|
|
title: t('Base Info'),
|
|
options,
|
|
};
|
|
}
|
|
|
|
get miscellaneousCard() {
|
|
const options = [
|
|
{
|
|
label: t('Host'),
|
|
dataIndex: 'host',
|
|
},
|
|
{
|
|
label: t('Workdir'),
|
|
dataIndex: 'workdir',
|
|
},
|
|
{
|
|
label: t('Environment'),
|
|
dataIndex: 'environment',
|
|
render: stringifyContent,
|
|
},
|
|
{
|
|
label: t('Interactive'),
|
|
dataIndex: 'interactive',
|
|
valueRender: 'yesNo',
|
|
},
|
|
];
|
|
|
|
return {
|
|
title: t('Miscellaneous'),
|
|
options,
|
|
};
|
|
}
|
|
|
|
get specCard() {
|
|
const options = [
|
|
{
|
|
label: t('Image'),
|
|
dataIndex: 'image',
|
|
},
|
|
{
|
|
label: t('Image Driver'),
|
|
dataIndex: 'image_driver',
|
|
},
|
|
{
|
|
label: t('Image Pull Policy'),
|
|
dataIndex: 'image_pull_policy',
|
|
},
|
|
{
|
|
label: t('Hostname'),
|
|
dataIndex: 'hostname',
|
|
},
|
|
{
|
|
label: t('Runtime'),
|
|
dataIndex: 'runtime',
|
|
},
|
|
{
|
|
label: t('CPU (Core)'),
|
|
dataIndex: 'cpu',
|
|
},
|
|
{
|
|
label: t('Memory (MiB)'),
|
|
dataIndex: 'memory',
|
|
},
|
|
{
|
|
label: t('Disk (GiB)'),
|
|
dataIndex: 'disk',
|
|
},
|
|
{
|
|
label: t('Restart Policy'),
|
|
dataIndex: 'restart_policy',
|
|
render: stringifyContent,
|
|
},
|
|
{
|
|
label: t('Auto Remove'),
|
|
dataIndex: 'auto_remove',
|
|
},
|
|
{
|
|
label: t('Auto Heal'),
|
|
dataIndex: 'auto_heal',
|
|
},
|
|
{
|
|
label: t('Addresses'),
|
|
dataIndex: 'addresses',
|
|
render: stringifyContent,
|
|
},
|
|
{
|
|
label: t('Networks'),
|
|
dataIndex: 'networks',
|
|
render: (value = []) => (
|
|
<>
|
|
{value.length
|
|
? value.map((it) => {
|
|
const link = this.getLinkRender('networkDetail', it, {
|
|
id: it,
|
|
});
|
|
return <div key={it}>{link}</div>;
|
|
})
|
|
: '-'}
|
|
</>
|
|
),
|
|
},
|
|
{
|
|
label: t('Ports'),
|
|
dataIndex: 'ports',
|
|
render: (value = []) => (
|
|
<>
|
|
{value.length
|
|
? value.map((it) => {
|
|
const link = this.getLinkRender('virtualAdapterDetail', it, {
|
|
id: it,
|
|
});
|
|
return <div key={it}>{link}</div>;
|
|
})
|
|
: '-'}
|
|
</>
|
|
),
|
|
},
|
|
{
|
|
label: t('Security Groups'),
|
|
dataIndex: 'security_groups',
|
|
render: (value = []) => (
|
|
<>
|
|
{value.length
|
|
? value.map((it) => {
|
|
const link = this.getLinkRender('securityGroupDetail', it, {
|
|
id: it,
|
|
});
|
|
return <div key={it}>{link}</div>;
|
|
})
|
|
: '-'}
|
|
</>
|
|
),
|
|
},
|
|
];
|
|
|
|
return {
|
|
title: t('Spec'),
|
|
labelCol: 4,
|
|
options,
|
|
};
|
|
}
|
|
|
|
get statsCard() {
|
|
const options = [
|
|
{
|
|
label: t('BLOCK I/O(B)'),
|
|
dataIndex: 'stats[BLOCK I/O(B)]',
|
|
},
|
|
{
|
|
label: t('NET I/O(B)'),
|
|
dataIndex: 'stats[NET I/O(B)]',
|
|
},
|
|
{
|
|
label: t('CPU %'),
|
|
dataIndex: 'stats[CPU %]',
|
|
render: (value = 0) => value.toFixed(4),
|
|
},
|
|
{
|
|
label: t('MEM LIMIT (MiB)'),
|
|
dataIndex: 'stats[MEM LIMIT(MiB)]',
|
|
},
|
|
{
|
|
label: t('MEM USAGE (MiB)'),
|
|
dataIndex: 'stats[MEM USAGE(MiB)]',
|
|
render: (value = 0) => value.toFixed(4),
|
|
},
|
|
{
|
|
label: t('MEM %'),
|
|
dataIndex: 'stats[MEM %]',
|
|
render: (value = 0) => value.toFixed(4),
|
|
},
|
|
];
|
|
|
|
return {
|
|
title: t('Stats Information'),
|
|
options,
|
|
};
|
|
}
|
|
}
|
|
|
|
export default inject('rootStore')(observer(BaseDetail));
|