| 123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102 | import React from "react";import PropTypes from "prop-types";import { createLocation, createPath } from "history";import invariant from "tiny-invariant";import warning from "tiny-warning";import Router from "./Router";function addLeadingSlash(path) {  return path.charAt(0) === "/" ? path : "/" + path;}function addBasename(basename, location) {  if (!basename) return location;  return {    ...location,    pathname: addLeadingSlash(basename) + location.pathname  };}function stripBasename(basename, location) {  if (!basename) return location;  const base = addLeadingSlash(basename);  if (location.pathname.indexOf(base) !== 0) return location;  return {    ...location,    pathname: location.pathname.substr(base.length)  };}function createURL(location) {  return typeof location === "string" ? location : createPath(location);}function staticHandler(methodName) {  return () => {    invariant(false, "You cannot %s with <StaticRouter>", methodName);  };}function noop() {}/** * The public top-level API for a "static" <Router>, so-called because it * can't actually change the current location. Instead, it just records * location changes in a context object. Useful mainly in testing and * server-rendering scenarios. */class StaticRouter extends React.Component {  navigateTo(location, action) {    const { basename = "", context = {} } = this.props;    context.action = action;    context.location = addBasename(basename, createLocation(location));    context.url = createURL(context.location);  }  handlePush = location => this.navigateTo(location, "PUSH");  handleReplace = location => this.navigateTo(location, "REPLACE");  handleListen = () => noop;  handleBlock = () => noop;  render() {    const { basename = "", context = {}, location = "/", ...rest } = this.props;    const history = {      createHref: path => addLeadingSlash(basename + createURL(path)),      action: "POP",      location: stripBasename(basename, createLocation(location)),      push: this.handlePush,      replace: this.handleReplace,      go: staticHandler("go"),      goBack: staticHandler("goBack"),      goForward: staticHandler("goForward"),      listen: this.handleListen,      block: this.handleBlock    };    return <Router {...rest} history={history} staticContext={context} />;  }}if (__DEV__) {  StaticRouter.propTypes = {    basename: PropTypes.string,    context: PropTypes.object,    location: PropTypes.oneOfType([PropTypes.string, PropTypes.object])  };  StaticRouter.prototype.componentDidMount = function() {    warning(      !this.props.history,      "<StaticRouter> ignores the history prop. To use a custom history, " +        "use `import { Router }` instead of `import { StaticRouter as Router }`."    );  };}export default StaticRouter;
 |