UNPKG

2.95 kBJavaScriptView Raw
1"use strict";
2
3Object.defineProperty(exports, "__esModule", {
4 value: true
5});
6exports.xor = xor;
7exports.default = void 0;
8
9/*
10 * The MIT License (MIT)
11 *
12 * Copyright (c) 2015 - present Instructure, Inc.
13 *
14 * Permission is hereby granted, free of charge, to any person obtaining a copy
15 * of this software and associated documentation files (the "Software"), to deal
16 * in the Software without restriction, including without limitation the rights
17 * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
18 * copies of the Software, and to permit persons to whom the Software is
19 * furnished to do so, subject to the following conditions:
20 *
21 * The above copyright notice and this permission notice shall be included in all
22 * copies or substantial portions of the Software.
23 *
24 * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
25 * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
26 * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
27 * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
28 * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
29 * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
30 * SOFTWARE.
31 */
32
33/**
34 * ---
35 * category: utilities/PropTypes
36 * ---
37 * Verify that a prop cannot be given if one or more other props are also
38 * given.
39 *
40 * ```js
41 * import { xor } from '@instructure/ui-prop-types'
42 *
43 * class Foo extends Component {
44 * static propTypes = {
45 * decimalPrecision: xor(PropTypes.number, 'significantDigits'),
46 * significantDigits: xor(PropTypes.number, 'decimalPrecision')
47 * }
48 * ...
49 * ```
50 *
51 * This will throw an error if both the `decimalPrecision` and
52 * `significantDigits` props are provided.
53 *
54 * @param {function} propType - validates the prop type. Returns null if valid, error otherwise
55 * @param {...string} otherPropNames - reject if any of these other props are also given
56 * @returns {Error} if any of the other props are also given
57 */
58function xor(propType) {
59 for (var _len = arguments.length, otherPropNames = new Array(_len > 1 ? _len - 1 : 0), _key = 1; _key < _len; _key++) {
60 otherPropNames[_key - 1] = arguments[_key];
61 }
62
63 return function (props, propName, componentName) {
64 if (props[propName] != null) {
65 var otherProps = otherPropNames.map(function (name) {
66 return props[name];
67 }).filter(function (prop) {
68 return prop != null;
69 });
70
71 if (otherProps.length > 0) {
72 return new Error("Invalid prop `".concat(propName, "` supplied to `").concat(componentName, "`: expected only one of ") + "".concat([propName].concat(otherPropNames).map(function (name) {
73 return "`".concat(name, "`");
74 }).join(', '), " to be set."));
75 }
76 }
77
78 return propType.apply(null, arguments);
79 };
80}
81
82var _default = xor;
83exports.default = _default;
\No newline at end of file