skyline/src/components/Layout/GlobalHeader/ProjectDropdown.jsx
Jingwei.Zhang 792c530928 fix: fix token storage after switch project
1. Remove useless code in switch project
2. Fix token change for requests after switch project

Change-Id: Ib8757fc918c3068be0a6b9a0d08921f2dc8817fd
2022-04-20 11:36:23 +08:00

75 lines
2.1 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 { inject, observer } from 'mobx-react';
import { Spin, Divider } from 'antd';
import { AppstoreOutlined, SwapOutlined } from '@ant-design/icons';
import ItemActionButtons from 'components/Tables/Base/ItemActionButtons';
import styles from './index.less';
import ProjectSelect from './ProjectTable';
@inject('rootStore')
@observer
export default class ProjectDropdown extends React.Component {
get user() {
const { user } = this.props.rootStore;
return user;
}
get project() {
const {
project: {
id: projectId = '',
name: projectName = '',
domain: { name: userDomainName } = {},
} = {},
} = this.user || {};
return {
projectId,
projectName,
userDomainName,
};
}
render() {
if (!this.user) {
return (
<Spin
size="small"
style={{
marginLeft: 8,
marginRight: 8,
marginTop: -24,
}}
/>
);
}
const { projectName, userDomainName } = this.project;
return (
<div className={styles.project} id="project-switch">
<ItemActionButtons
actions={{ moreActions: [{ action: ProjectSelect }] }}
/>
<AppstoreOutlined style={{ marginRight: 10 }} />
{/* style={{ display: 'inline-block', width: '115px' }} */}
<span>{projectName}</span>
<SwapOutlined style={{ color: '#A3A3A3', marginLeft: 24 }} />
<Divider type="vertical" />
<span className={styles.domain}>{userDomainName}</span>
</div>
);
}
}