import baseToString from './.internal/baseToString.js' import castSlice from './.internal/castSlice.js' import charsEndIndex from './.internal/charsEndIndex.js' import stringToArray from './.internal/stringToArray.js' import toString from './toString.js' const stringProto = String.prototype const nativeTrimEnd = stringProto.trimRight || stringProto.trimEnd /** * Removes trailing whitespace or specified characters from `string`. * * @since 4.0.0 * @category String * @param {string} [string=''] The string to trim. * @param {string} [chars=whitespace] The characters to trim. * @param- {Object} [guard] Enables use as an iteratee for methods like `map`. * @returns {string} Returns the trimmed string. * @see trim, trimStart * @example * * trimEnd(' abc ') * // => ' abc' * * trimEnd('-_-abc-_-', '_-') * // => '-_-abc' */ function trimEnd(string, chars, guard) { string = toString(string) if (string && (guard || chars === undefined)) { return nativeTrimEnd.call(string) } if (!string || !(chars = baseToString(chars))) { return string } const strSymbols = stringToArray(string) const end = charsEndIndex(strSymbols, stringToArray(chars)) + 1 return castSlice(strSymbols, 0, end).join('') } export default trimEnd