From de98e0b232509d5f40c135d540a70e415272ff85 Mon Sep 17 00:00:00 2001 From: Florian Dold Date: Wed, 3 May 2017 15:35:00 +0200 Subject: node_modules --- node_modules/fbjs/lib/joinClasses.js.flow | 40 +++++++++++++++++++++++++++++++ 1 file changed, 40 insertions(+) create mode 100644 node_modules/fbjs/lib/joinClasses.js.flow (limited to 'node_modules/fbjs/lib/joinClasses.js.flow') diff --git a/node_modules/fbjs/lib/joinClasses.js.flow b/node_modules/fbjs/lib/joinClasses.js.flow new file mode 100644 index 000000000..e07f24180 --- /dev/null +++ b/node_modules/fbjs/lib/joinClasses.js.flow @@ -0,0 +1,40 @@ +/** + * Copyright (c) 2013-present, Facebook, Inc. + * All rights reserved. + * + * This source code is licensed under the BSD-style license found in the + * LICENSE file in the root directory of this source tree. An additional grant + * of patent rights can be found in the PATENTS file in the same directory. + * + * @providesModule joinClasses + * @typechecks static-only + */ + +'use strict'; + +/** + * Combines multiple className strings into one. + * http://jsperf.com/joinclasses-args-vs-array + * + * @param {...?string} className + * @return {string} + */ + +function joinClasses(className /*, ... */) { + if (!className) { + className = ''; + } + let nextClass; + const argLength = arguments.length; + if (argLength > 1) { + for (let ii = 1; ii < argLength; ii++) { + nextClass = arguments[ii]; + if (nextClass) { + className = (className ? className + ' ' : '') + nextClass; + } + } + } + return className; +} + +module.exports = joinClasses; \ No newline at end of file -- cgit v1.2.3