@salesforce/design-system-react
Version:
Salesforce Lightning Design System for React
57 lines (48 loc) • 2.97 kB
JavaScript
/* Copyright (c) 2015-present, salesforce.com, inc. All rights reserved */
/* Licensed under BSD 3-Clause - see LICENSE.txt or git.io/sfdc-license */
/* eslint-disable import/no-mutable-exports */
/* eslint-disable max-len */
import deprecatedProperty from '../../utilities/warning/deprecated-property';
import sunsetProperty from '../../utilities/warning/sunset-property'; // import oneOfRequiredProperty from '../../../utilities/warning/one-of-required-property';
import onlyOneOfProperties from '../../utilities/warning/only-one-of-properties';
import { INPUT, SEARCH } from '../../utilities/constants';
var checkProps = function checkProps() {};
if (process.env.NODE_ENV !== 'production') {
checkProps = function checkProps(COMPONENT, props) {
if (COMPONENT === INPUT) {
// Deprecated and changed to another property
deprecatedProperty(COMPONENT, props.iconCategory, 'iconCategory', undefined, 'Please use `iconLeft` and `iconRight` to pass in a customized <Icon> component.');
deprecatedProperty(COMPONENT, props.iconName, 'iconName', undefined, 'Please use `iconLeft` and `iconRight` to pass in a customized <Icon> component');
deprecatedProperty(COMPONENT, props.iconPosition, 'iconPosition', undefined, 'Please use `iconLeft` and `iconRight` to pass in a customized <Icon> component');
deprecatedProperty(COMPONENT, props.iconAssistiveText, 'iconAssistiveText', undefined, 'Please use `iconLeft` and `iconRight` to pass in a customized <Icon> component');
deprecatedProperty(COMPONENT, props.onIconClick, 'onIconClick', undefined, 'Please use `iconLeft` and `iconRight` to pass in a customized <Icon> component');
if (typeof props.assistiveText === 'string') {
sunsetProperty(COMPONENT, props.assistiveText, 'assistiveText', 'AssistiveText as a string has been deprecated and is now an object to allow for multiple uses in the component. Please use either assistiveText.label or assistiveText.spinner');
}
onlyOneOfProperties(COMPONENT, {
'assistiveText.label': props.assistiveText && props.assistiveText.label,
label: props.label
});
onlyOneOfProperties(COMPONENT, {
fixedTextLeft: props.fixedTextLeft,
fixedTextRight: props.fixedTextRight
});
/*
* Once we support horizontal labels, then I think we can enable this check
*
if (!props.inlineEditTrigger) {
oneOfRequiredProperty(COMPONENT, {
assistiveText: props.assistiveText,
label: props.label
});
}
*/
} else if (COMPONENT === SEARCH) {
if (typeof props.assistiveText === 'string') {
sunsetProperty(COMPONENT, props.assistiveText, 'assistiveText', '`assistiveText` as a string has been deprecated and is now an object to allow for multiple uses in the component. Please use `assistiveText.label` instead.');
}
}
};
}
export default checkProps;
//# sourceMappingURL=check-props.js.map