Files
skyline-console/src/components/FormItem/NameInput/index.jsx
zhangjingwei 9215b712e3 refactor: refactor NameInput component
refactor NameInput component which is used in form

Change-Id: I2479007e4c564e059aedd032e230bb7930191c3b
2024-04-02 17:21:46 +08:00

251 lines
5.8 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, Form } from 'antd';
import { nameTypeValidate, nameMessageInfo } from 'utils/validate';
const {
nameMessage,
nameMessageWithoutChinese,
filenameMessage,
keypairNameMessage,
stackNameMessage,
crontabNameMessage,
imageNameMessage,
instanceNameMessage,
swiftFilenameMessage,
databaseNameMessage,
databaseUserNameMessage,
} = nameMessageInfo;
const {
nameValidate,
nameValidateWithoutChinese,
fileNameValidate,
keypairNameValidate,
stackNameValidate,
crontabNameValidate,
imageNameValidate,
instanceNameValidate,
swiftFileNameValidate,
databaseNameValidate,
databaseUserNameValidate,
} = nameTypeValidate;
export default class index extends Component {
static isFormItem = true;
getRuleValidator(props) {
const {
withoutChinese,
isFile,
isKeypair,
isStack,
isCrontab,
isImage,
isInstance,
isSwiftFile,
isDatabaseName,
isDatabaseUserName,
} = props;
let validator = nameValidate;
if (isFile) {
validator = fileNameValidate;
} else if (withoutChinese) {
validator = nameValidateWithoutChinese;
} else if (isKeypair) {
validator = keypairNameValidate;
} else if (isStack) {
validator = stackNameValidate;
} else if (isImage) {
validator = imageNameValidate;
} else if (isInstance) {
validator = instanceNameValidate;
} else if (isCrontab) {
validator = crontabNameValidate;
} else if (isSwiftFile) {
validator = swiftFileNameValidate;
} else if (isDatabaseName) {
validator = databaseNameValidate;
} else if (isDatabaseUserName) {
validator = databaseUserNameValidate;
}
return validator;
}
getRules(ruleProps) {
const { names, rules, ...rest } = ruleProps;
const uniqueNameValidate = (rule, value) => {
if (names && names.length && names.includes(value)) {
const message = t('Name can not be duplicated');
return Promise.reject(new Error(`${t('Invalid: ')}${message}`));
}
return Promise.resolve(true);
};
const uniqueRule = {
validator: uniqueNameValidate,
};
const newRules = {
validator: this.getRuleValidator(rest),
};
if (rules && rules.length > 0) {
return [...rules, newRules, uniqueRule];
}
return [newRules, uniqueRule];
}
getMessage({
withoutChinese,
isFile,
isKeypair,
isStack,
isCrontab,
isImage,
isInstance,
isSwiftFile,
isDatabaseName,
isDatabaseUserName,
}) {
if (withoutChinese) {
return nameMessageWithoutChinese;
}
if (isStack) {
return stackNameMessage;
}
if (isFile) {
return filenameMessage;
}
if (isKeypair) {
return keypairNameMessage;
}
if (isCrontab) {
return crontabNameMessage;
}
if (isImage) {
return imageNameMessage;
}
if (isInstance) {
return instanceNameMessage;
}
if (isSwiftFile) {
return swiftFilenameMessage;
}
if (isDatabaseName) {
return databaseNameMessage;
}
if (isDatabaseUserName) {
return databaseUserNameMessage;
}
return nameMessage;
}
getPropsFromComponentProps() {
const { componentProps } = this.props;
const {
withoutChinese = false,
isFile = false,
isKeypair = false,
isSwiftFile = false,
isDatabaseName = false,
isDatabaseUserName = false,
isStack,
isCrontab,
isImage,
isInstance,
names,
...componentRest
} = componentProps;
return {
ruleProps: {
names,
withoutChinese,
isFile,
isKeypair,
isStack,
isCrontab,
isImage,
isInstance,
isSwiftFile,
isDatabaseName,
isDatabaseUserName,
},
messageProps: {
withoutChinese,
isFile,
isKeypair,
isStack,
isCrontab,
isImage,
isInstance,
isSwiftFile,
isDatabaseName,
isDatabaseUserName,
},
restProps: componentRest,
};
}
get ruleProps() {
const { formItemProps } = this.props;
const { rules } = formItemProps;
const { ruleProps } = this.getPropsFromComponentProps();
return {
...ruleProps,
rules,
};
}
get messageProps() {
const { messageProps } = this.getPropsFromComponentProps();
return messageProps;
}
get formItemProps() {
const { formItemProps } = this.props;
const { rules, ...rest } = formItemProps;
const newRules = this.getRules(this.ruleProps);
const message = this.getMessage(this.messageProps);
return {
...rest,
rules: newRules,
extra: message,
};
}
get inputProps() {
const { isFile } = this.ruleProps;
const { restProps } = this.getPropsFromComponentProps();
const placeholder = isFile
? t('Please input file name')
: t('Please input name');
const props = {
placeholder,
...restProps,
};
return props;
}
render() {
const newFormItemProps = this.formItemProps;
const { inputProps } = this;
return (
<Form.Item {...newFormItemProps}>
<Input {...inputProps} />
</Form.Item>
);
}
}