skyline/src/components/FormItem/KeyValueInput/index.jsx
Hanxiang Gao 4eb68e7fb2 feat: Add initial code of skyline-console
Add initial code of skyline-console

Change-Id: Icba2152a014761f53789357b5085d0779cd0e2a4
2021-06-01 23:29:30 +08:00

109 lines
2.6 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, { Component } from 'react';
import { Input, Row, Col } from 'antd';
import PropTypes from 'prop-types';
import { PauseOutlined } from '@ant-design/icons';
export default class index extends Component {
static propTypes = {
onChange: PropTypes.func,
// eslint-disable-next-line react/no-unused-prop-types
value: PropTypes.object,
keyReadonly: PropTypes.bool,
valueReadonly: PropTypes.bool,
};
static defaultProps = {
onChange: null,
value: {
key: '',
value: '',
},
keyReadonly: false,
valueReadonly: false,
};
constructor(props) {
super(props);
this.state = {
key: '',
value: '',
};
}
static getDerivedStateFromProps(nextProps, prevState) {
const { key, value } = nextProps.value || {};
if (key !== prevState.key || value !== prevState.value) {
return {
key,
value,
};
}
return null;
}
onChange = (value) => {
const { onChange } = this.props;
if (onChange) {
onChange(value);
}
};
onKeyChange = (e) => {
this.onChange({
...this.state,
key: e.target.value,
});
};
onValueChange = (e) => {
this.onChange({
...this.state,
value: e.target.value,
});
};
render() {
const { key, value } = this.state;
const { keyReadonly, valueReadonly } = this.props;
return (
<Row>
<Col span={4}>
<Input
value={key}
placeholder={t['Please input key']}
onChange={this.onKeyChange}
readOnly={keyReadonly}
required
/>
</Col>
<Col span={1} style={{ textAlign: 'center', lineHeight: '30px' }}>
<PauseOutlined rotate={90} />
</Col>
<Col span={8}>
<Input
value={value}
placeholder={t['Please input key']}
onChange={this.onValueChange}
readOnly={valueReadonly}
required
/>
</Col>
</Row>
);
}
}