Commit c5c99a13 by Wee

chore: bump devDependencies versions

parent 737c7402
es es
dist
node_modules node_modules
umd umd
/*.js /*.js
......
import React from 'react' import React from 'react'
import ReactDOM from 'react-dom' import ReactDOM from 'react-dom'
import { createMemoryHistory as createHistory } from 'history' import PropTypes from 'prop-types'
import { MemoryRouter, Router, Route } from 'react-router' import { MemoryRouter, Route, Router } from 'react-router'
import { createMemoryHistory } from 'history'
import renderStrict from './utils/renderStrict'
describe('A <Route>', () => { describe('A <Route>', () => {
const node = document.createElement('div') it('renders at the root', () => {
const TEXT = 'Mrs. Kato'
afterEach(() => { const node = document.createElement('div')
ReactDOM.unmountComponentAtNode(node)
})
describe('without a <Router>', () => { ReactDOM.render(
it('throws an error', () => { <MemoryRouter initialEntries={['/']}>
jest.spyOn(console, 'error').mockImplementation(() => {}) <Route path="/" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>,
node
)
expect(() => { expect(node.innerHTML).toContain(TEXT)
renderStrict(<Route />, node)
}).toThrow(/You should not use <Route> outside a <Router>/)
})
}) })
it('renders when it matches', () => { it('does not render when it does not match', () => {
const text = 'cupcakes' const TEXT = 'bubblegum'
const node = document.createElement('div')
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/cupcakes']}> <MemoryRouter initialEntries={['/bunnies']}>
<Route path="/cupcakes" render={() => <h1>{text}</h1>} /> <Route path="/flowers" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>, </MemoryRouter>,
node node
) )
expect(node.innerHTML).toContain(text) expect(node.innerHTML).not.toContain(TEXT)
}) })
it('renders when it matches at the root URL', () => { it('can use a `location` prop instead of `context.router.route.location`', () => {
const text = 'cupcakes' const TEXT = 'tamarind chutney'
const node = document.createElement('div')
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/']}> <MemoryRouter initialEntries={['/mint']}>
<Route path="/" render={() => <h1>{text}</h1>} /> <Route location={{ pathname: '/tamarind' }} path="/tamarind" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>, </MemoryRouter>,
node node
) )
expect(node.innerHTML).toContain(text) expect(node.innerHTML).toContain(TEXT)
}) })
it('does not render when it does not match', () => { it('supports preact by nulling out children prop when empty array is passed', () => {
const text = 'bubblegum' const TEXT = 'Mrs. Kato'
const node = document.createElement('div')
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/bunnies']}> <MemoryRouter initialEntries={['/']}>
<Route path="/flowers" render={() => <h1>{text}</h1>} /> <Route path="/" render={() => <h1>{TEXT}</h1>}>
{[]}
</Route>
</MemoryRouter>, </MemoryRouter>,
node node
) )
expect(node.innerHTML).not.toContain(text) expect(node.innerHTML).toContain(TEXT)
}) })
it('matches using nextContext when updating', () => { it('matches using nextContext when updating', () => {
const history = createHistory({ const node = document.createElement('div')
initialEntries: ['/sushi/california']
}) let push
ReactDOM.render(
renderStrict( <MemoryRouter initialEntries={['/sushi/california']}>
<Router history={history}> <Route
<Route path="/sushi/:roll" render={({ match }) => <h1>{match.url}</h1>} /> path="/sushi/:roll"
</Router>, render={({ history, match }) => {
push = history.push
return <div>{match.url}</div>
}}
/>
</MemoryRouter>,
node node
) )
push('/sushi/spicy-tuna')
history.push('/sushi/spicy-tuna')
expect(node.innerHTML).toContain('/sushi/spicy-tuna') expect(node.innerHTML).toContain('/sushi/spicy-tuna')
}) })
describe('with dynamic segments in the path', () => { it('throws with no <Router>', () => {
it('decodes them', () => { const node = document.createElement('div')
renderStrict(
<MemoryRouter initialEntries={['/a%20dynamic%20segment']}>
<Route path="/:id" render={({ match }) => <h1>{match.params.id}</h1>} />
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain('a dynamic segment') spyOn(console, 'error')
})
expect(() => {
ReactDOM.render(<Route path="/" render={() => null} />, node)
}).toThrow(/You should not use <Route> or withRouter\(\) outside a <Router>/)
}) })
})
describe('with an array of paths', () => { describe('A <Route> with dynamic segments in the path', () => {
it('matches the first provided path', () => { it('decodes them', () => {
const node = document.createElement('div') const node = document.createElement('div')
ReactDOM.render( ReactDOM.render(
<MemoryRouter initialEntries={['/hello']}> <MemoryRouter initialEntries={['/a%20dynamic%20segment']}>
<Route path={['/hello', '/world']} render={() => <div>Hello World</div>} /> <Route path="/:id" render={({ match }) => <div>{match.params.id}</div>} />
</MemoryRouter>, </MemoryRouter>,
node node
) )
expect(node.innerHTML).toContain('Hello World') expect(node.innerHTML).toContain('a dynamic segment')
}) })
})
it('matches other provided paths', () => { describe('A unicode <Route>', () => {
const node = document.createElement('div') it('is able to match', () => {
ReactDOM.render( const node = document.createElement('div')
<MemoryRouter initialEntries={['/other', '/world']} initialIndex={1}> ReactDOM.render(
<Route path={['/hello', '/world']} render={() => <div>Hello World</div>} /> <MemoryRouter initialEntries={['/パス名']}>
</MemoryRouter>, <Route path="/パス名" render={({ match }) => <div>{match.url}</div>} />
node </MemoryRouter>,
) node
)
expect(node.innerHTML).toContain('Hello World') expect(node.innerHTML).toContain('/パス名')
}) })
})
it('provides the matched path as a string', () => { describe('<Route render>', () => {
const node = document.createElement('div') const history = createMemoryHistory()
ReactDOM.render( const node = document.createElement('div')
<MemoryRouter initialEntries={['/other', '/world']} initialIndex={1}>
<Route path={['/hello', '/world']} render={({ match }) => <div>{match.path}</div>} />
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain('/world') afterEach(() => {
}) ReactDOM.unmountComponentAtNode(node)
})
it("doesn't remount when moving from one matching path to another", () => { it('renders its return value', () => {
const node = document.createElement('div') const TEXT = 'Mrs. Kato'
const history = createHistory() const node = document.createElement('div')
const mount = jest.fn() ReactDOM.render(
class MatchedRoute extends React.Component { <MemoryRouter initialEntries={['/']}>
componentWillMount() { <Route path="/" render={() => <div>{TEXT}</div>} />
mount() </MemoryRouter>,
} node
)
render() {
return <div>Hello World</div>
}
}
history.push('/hello')
ReactDOM.render(
<Router history={history}>
<Route path={['/hello', '/world']} component={MatchedRoute} />
</Router>,
node
)
expect(mount).toHaveBeenCalledTimes(1) expect(node.innerHTML).toContain(TEXT)
expect(node.innerHTML).toContain('Hello World') })
history.push('/world/somewhere/else') it('receives { match, location, history } props', () => {
let actual = null
expect(mount).toHaveBeenCalledTimes(1) ReactDOM.render(
expect(node.innerHTML).toContain('Hello World') <Router history={history}>
}) <Route path="/" render={props => (actual = props) && null} />
</Router>,
node
)
expect(actual.history).toBe(history)
expect(typeof actual.match).toBe('object')
expect(typeof actual.location).toBe('object')
}) })
})
describe('with a unicode path', () => { describe('<Route component>', () => {
it('is able to match', () => { const history = createMemoryHistory()
renderStrict( const node = document.createElement('div')
<MemoryRouter initialEntries={['/パス名']}>
<Route path="/パス名" render={({ match }) => <h1>{match.url}</h1>} />
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain('/パス名') afterEach(() => {
}) ReactDOM.unmountComponentAtNode(node)
}) })
describe('with escaped special characters in the path', () => { it('renders the component', () => {
it('is able to match', () => { const TEXT = 'Mrs. Kato'
renderStrict( const node = document.createElement('div')
<MemoryRouter initialEntries={['/pizza (1)']}> const Home = () => <div>{TEXT}</div>
<Route path="/pizza \(1\)" render={({ match }) => <h1>{match.url}</h1>} /> ReactDOM.render(
</MemoryRouter>, <MemoryRouter initialEntries={['/']}>
node <Route path="/" component={Home} />
) </MemoryRouter>,
node
)
expect(node.innerHTML).toContain('/pizza (1)') expect(node.innerHTML).toContain(TEXT)
})
}) })
describe('with `exact=true`', () => { it('receives { match, location, history } props', () => {
it('renders when the URL does not have a trailing slash', () => { let actual = null
const text = 'bubblegum' const Component = props => (actual = props) && null
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/somepath/']}> <Router history={history}>
<Route exact path="/somepath" render={() => <h1>{text}</h1>} /> <Route path="/" component={Component} />
</MemoryRouter>, </Router>,
node node
) )
expect(node.innerHTML).toContain(text) expect(actual.history).toBe(history)
}) expect(typeof actual.match).toBe('object')
expect(typeof actual.location).toBe('object')
})
})
it('renders when the URL has trailing slash', () => { describe('<Route children>', () => {
const text = 'bubblegum' const history = createMemoryHistory()
const node = document.createElement('div')
renderStrict( afterEach(() => {
<MemoryRouter initialEntries={['/somepath']}> ReactDOM.unmountComponentAtNode(node)
<Route exact path="/somepath/" render={() => <h1>{text}</h1>} /> })
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain(text) it('renders a function', () => {
}) const TEXT = 'Mrs. Kato'
const node = document.createElement('div')
ReactDOM.render(
<MemoryRouter initialEntries={['/']}>
<Route path="/" children={() => <div>{TEXT}</div>} />
</MemoryRouter>,
node
)
describe('and `strict=true`', () => { expect(node.innerHTML).toContain(TEXT)
it('does not render when the URL has a trailing slash', () => { })
const text = 'bubblegum'
renderStrict( it('renders a child element', () => {
<MemoryRouter initialEntries={['/somepath/']}> const TEXT = 'Mrs. Kato'
<Route exact strict path="/somepath" render={() => <h1>{text}</h1>} /> const node = document.createElement('div')
</MemoryRouter>, ReactDOM.render(
node <MemoryRouter initialEntries={['/']}>
) <Route path="/">
<div>{TEXT}</div>
</Route>
</MemoryRouter>,
node
)
expect(node.innerHTML).not.toContain(text) expect(node.innerHTML).toContain(TEXT)
}) })
it('does not render when the URL does not have a trailing slash', () => { it('receives { match, location, history } props', () => {
const text = 'bubblegum' let actual = null
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/somepath']}> <Router history={history}>
<Route exact strict path="/somepath/" render={() => <h1>{text}</h1>} /> <Route path="/" children={props => (actual = props) && null} />
</MemoryRouter>, </Router>,
node node
) )
expect(node.innerHTML).not.toContain(text) expect(actual.history).toBe(history)
}) expect(typeof actual.match).toBe('object')
}) expect(typeof actual.location).toBe('object')
}) })
})
describe('the `location` prop', () => { describe('A <Route exact>', () => {
it('overrides `context.location`', () => { it('renders when the URL does not have a trailing slash', () => {
const text = 'bubblegum' const TEXT = 'bubblegum'
const node = document.createElement('div')
renderStrict( ReactDOM.render(
<MemoryRouter initialEntries={['/cupcakes']}> <MemoryRouter initialEntries={['/somepath/']}>
<Route location={{ pathname: '/bubblegum' }} path="/bubblegum" render={() => <h1>{text}</h1>} /> <Route exact path="/somepath" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>, </MemoryRouter>,
node node
) )
expect(node.innerHTML).toContain(text) expect(node.innerHTML).toContain(TEXT)
})
}) })
describe('the `children` prop', () => { it('renders when the URL has trailing slash', () => {
describe('that is an element', () => { const TEXT = 'bubblegum'
it('renders', () => { const node = document.createElement('div')
const text = 'bubblegum'
renderStrict(
<MemoryRouter initialEntries={['/']}>
<Route path="/">
<h1>{text}</h1>
</Route>
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain(text)
})
})
describe('that is a function', () => { ReactDOM.render(
it('receives { history, location, match } props', () => { <MemoryRouter initialEntries={['/somepath']}>
const history = createHistory() <Route exact path="/somepath/" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>,
let props = null node
renderStrict( )
<Router history={history}>
<Route
path="/"
children={p => {
props = p
return null
}}
/>
</Router>,
node
)
expect(props).not.toBe(null)
expect(props.history).toBe(history)
expect(typeof props.location).toBe('object')
expect(typeof props.match).toBe('object')
})
it('renders', () => {
const text = 'bubblegum'
renderStrict(
<MemoryRouter initialEntries={['/']}>
<Route path="/" children={() => <h1>{text}</h1>} />
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain(text)
})
describe('that returns `undefined`', () => {
it('logs a warning to the console and renders nothing', () => {
jest.spyOn(console, 'warn').mockImplementation(() => {})
renderStrict(
<MemoryRouter initialEntries={['/']}>
<Route path="/" children={() => undefined} />
</MemoryRouter>,
node
)
expect(node.innerHTML).toEqual('')
expect(console.warn).toHaveBeenCalledWith(
expect.stringContaining('You returned `undefined` from the `children` function')
)
})
})
})
describe('that is an empty array (as in Preact)', () => { expect(node.innerHTML).toContain(TEXT)
it('ignores the children', () => { })
const text = 'bubblegum' })
renderStrict( describe('A <Route exact strict>', () => {
<MemoryRouter> it('does not render when the URL has a trailing slash', () => {
<Route render={() => <h1>{text}</h1>}>{[]}</Route> const TEXT = 'bubblegum'
</MemoryRouter>, const node = document.createElement('div')
node
)
expect(node.innerHTML).toContain(text) ReactDOM.render(
}) <MemoryRouter initialEntries={['/somepath/']}>
}) <Route exact strict path="/somepath" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>,
node
)
expect(node.innerHTML).not.toContain(TEXT)
}) })
describe('the `component` prop', () => { it('does not render when the URL does not have a trailing slash', () => {
it('renders the component', () => { const TEXT = 'bubblegum'
const text = 'bubblegum' const node = document.createElement('div')
const Home = () => <h1>{text}</h1> ReactDOM.render(
<MemoryRouter initialEntries={['/somepath']}>
<Route exact strict path="/somepath/" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>,
node
)
renderStrict( expect(node.innerHTML).not.toContain(TEXT)
<MemoryRouter initialEntries={['/']}> })
<Route path="/" component={Home} /> })
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain(text) describe('A <Route location>', () => {
}) it('can use a `location` prop instead of `router.location`', () => {
const TEXT = 'tamarind chutney'
const node = document.createElement('div')
ReactDOM.render(
<MemoryRouter initialEntries={['/mint']}>
<Route location={{ pathname: '/tamarind' }} path="/tamarind" render={() => <h1>{TEXT}</h1>} />
</MemoryRouter>,
node
)
it('receives { history, location, match } props', () => { expect(node.innerHTML).toContain(TEXT)
const history = createHistory() })
let props = null describe('children', () => {
const Component = p => { it("uses parent's prop location", () => {
props = p const TEXT = 'cheddar pretzel'
return null const node = document.createElement('div')
}
renderStrict( ReactDOM.render(
<Router history={history}> <MemoryRouter initialEntries={['/popcorn']}>
<Route path="/" component={Component} /> <Route
</Router>, location={{ pathname: '/pretzels/cheddar' }}
path="/pretzels"
render={() => <Route path="/pretzels/cheddar" render={() => <h1>{TEXT}</h1>} />}
/>
</MemoryRouter>,
node node
) )
expect(props).not.toBe(null) expect(node.innerHTML).toContain(TEXT)
expect(props.history).toBe(history)
expect(typeof props.location).toBe('object')
expect(typeof props.match).toBe('object')
}) })
it("won't throw a prop-type warning when passed valid React components that aren't functions", () => { it("continues to use parent's prop location after navigation", () => {
function forwardRef(Component) { const TEXT = 'cheddar pretzel'
class ForwardComponent extends React.Component { const node = document.createElement('div')
render() { let push
const { forwardedRef, ...rest } = this.props
return <Component ref={forwardedRef} {...rest} />
}
}
return React.forwardRef((props, ref) => {
return <ForwardComponent {...props} forwardedRef={ref} />
})
}
const history = createHistory()
const Component = () => null
const WrappedComponent = forwardRef(Component)
jest.spyOn(console, 'error').mockImplementation(() => {})
ReactDOM.render( ReactDOM.render(
<Router history={history}> <MemoryRouter initialEntries={['/popcorn']}>
<Route path="/" component={WrappedComponent} /> <Route
</Router>, location={{ pathname: '/pretzels/cheddar' }}
path="/pretzels"
render={({ history }) => {
push = history.push
return <Route path="/pretzels/cheddar" render={() => <h1>{TEXT}</h1>} />
}}
/>
</MemoryRouter>,
node node
) )
expect(node.innerHTML).toContain(TEXT)
expect(console.error).not.toHaveBeenCalled() push('/chips')
expect(node.innerHTML).toContain(TEXT)
}) })
}) })
})
describe('the `render` prop', () => { describe('A pathless <Route>', () => {
it('renders its return value', () => { let rootContext
const text = 'Mrs. Kato' const ContextChecker = (props, context) => {
rootContext = context
return null
}
renderStrict( ContextChecker.contextTypes = {
<MemoryRouter initialEntries={['/']}> router: PropTypes.object
<Route path="/" render={() => <h1>{text}</h1>} /> }
</MemoryRouter>,
node
)
expect(node.innerHTML).toContain(text) afterEach(() => {
}) rootContext = undefined
})
it('receives { history, location, match } props', () => { it('inherits its parent match', () => {
const history = createHistory() const node = document.createElement('div')
ReactDOM.render(
<MemoryRouter initialEntries={['/somepath']}>
<Route component={ContextChecker} />
</MemoryRouter>,
node
)
let props = null const { match } = rootContext.router.route
renderStrict( expect(match.path).toBe('/')
<Router history={history}> expect(match.url).toBe('/')
<Route expect(match.isExact).toBe(false)
path="/" expect(match.params).toEqual({})
render={p => { })
props = p
return null
}}
/>
</Router>,
node
)
expect(props).not.toBe(null) it('does not render when parent match is null', () => {
expect(props.history).toBe(history) const node = document.createElement('div')
expect(typeof props.location).toBe('object') ReactDOM.render(
expect(typeof props.match).toBe('object') <MemoryRouter initialEntries={['/somepath']}>
}) <Route path="/no-match" children={() => <Route component={ContextChecker} />} />
</MemoryRouter>,
node
)
expect(rootContext).toBe(undefined)
}) })
}) })
import React from "react";
let StrictMode = function(props) {
return props.children || null;
};
if (React.StrictMode) {
StrictMode = React.StrictMode;
}
export default StrictMode;
import React from "react";
import ReactDOM from "react-dom";
import StrictMode from "./StrictMode";
function renderStrict(element, node) {
ReactDOM.render(<StrictMode>{element}</StrictMode>, node);
}
export default renderStrict;
"use strict";
var __extends = (this && this.__extends) || (function () {
var extendStatics = function (d, b) {
extendStatics = Object.setPrototypeOf ||
({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||
function (d, b) { for (var p in b) if (b.hasOwnProperty(p)) d[p] = b[p]; };
return extendStatics(d, b);
}
return function (d, b) {
extendStatics(d, b);
function __() { this.constructor = d; }
d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());
};
})();
var __assign = (this && this.__assign) || function () {
__assign = Object.assign || function(t) {
for (var s, i = 1, n = arguments.length; i < n; i++) {
s = arguments[i];
for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p))
t[p] = s[p];
}
return t;
};
return __assign.apply(this, arguments);
};
Object.defineProperty(exports, "__esModule", { value: true });
var warning = require("warning");
var invariant = require("invariant");
var React = require("react");
var PropTypes = require("prop-types");
var ReactDOM = require("react-dom");
var react_router_1 = require("react-router");
var react_is_1 = require("react-is");
var isEmptyChildren = function (children) { return React.Children.count(children) === 0; };
var LiveState;
(function (LiveState) {
LiveState["NORMAL_RENDER_MATCHED"] = "normal matched render";
LiveState["NORMAL_RENDER_UNMATCHED"] = "normal unmatched render (unmount)";
LiveState["NORMAL_RENDER_ON_INIT"] = "normal render (matched or unmatched)";
LiveState["HIDE_RENDER"] = "hide route when livePath matched";
})(LiveState || (LiveState = {}));
var debugLog = function (message) {
// console.log(message)
};
/**
* The public API for matching a single path and rendering.
*/
var LiveRoute = /** @class */ (function (_super) {
__extends(LiveRoute, _super);
function LiveRoute() {
var _this = _super !== null && _super.apply(this, arguments) || this;
_this.routeDom = null;
_this.state = {
match: _this.computeMatch(_this.props, _this.context.router)
};
_this.liveState = LiveState.NORMAL_RENDER_ON_INIT;
_this.scrollPosBackup = null;
_this.previousDisplayStyle = null;
return _this;
}
LiveRoute.prototype.getChildContext = function () {
return {
router: __assign({}, this.context.router, { route: {
location: this.props.location || this.context.router.route.location,
match: this.state.match
} })
};
};
LiveRoute.prototype.componentWillMount = function () {
warning(!(this.props.component && this.props.render), 'You should not use <Route component> and <Route render> in the same route; <Route render> will be ignored');
warning(!(this.props.component && this.props.children && !isEmptyChildren(this.props.children)), 'You should not use <Route component> and <Route children> in the same route; <Route children> will be ignored');
warning(!(this.props.render && this.props.children && !isEmptyChildren(this.props.children)), 'You should not use <Route render> and <Route children> in the same route; <Route children> will be ignored');
};
LiveRoute.prototype.componentDidMount = function () {
// backup router and get DOM when mounting
if (this.doesRouteEnableLive() && this.state.match) {
this._latestMatchedRouter = this.context.router;
this.getRouteDom();
}
};
LiveRoute.prototype.componentWillReceiveProps = function (nextProps, nextContext) {
warning(!(nextProps.location && !this.props.location), '<Route> elements should not change from uncontrolled to controlled (or vice versa). You initially used no "location" prop and then provided one on a subsequent render.');
warning(!(!nextProps.location && this.props.location), '<Route> elements should not change from controlled to uncontrolled (or vice versa). You provided a "location" prop initially but omitted it on a subsequent render.');
var match = this.computeMatch(nextProps, nextContext.router);
var computedMatch = match;
// recompute match if enable live
if (this.doesRouteEnableLive()) {
computedMatch = this.computeMatchWithLive(this.props, nextProps, nextContext, match);
}
this.setState({
match: computedMatch
});
};
// get route of DOM
LiveRoute.prototype.componentDidUpdate = function (prevProps, prevState) {
if (!this.doesRouteEnableLive()) {
return;
}
// restore display when matched normally
debugLog(this.liveState);
if (this.liveState === LiveState.NORMAL_RENDER_MATCHED) {
this.showRoute();
this.restoreScrollPosition();
this.clearScroll();
}
// get DOM if match and render
if (this.state.match) {
this.getRouteDom();
}
};
// clear on unmounting
LiveRoute.prototype.componentWillUnmount = function () {
this.clearScroll();
};
LiveRoute.prototype.doesRouteEnableLive = function () {
return this.props.livePath || this.props.alwaysLive;
};
/**
* @param {*} props: this.props
* @param {*} nextProps: nextProps
* @param {*} nextContext: nextContext
* @param {*} match: computed `match` of current path
* @returns
* the returned object will be computed by following orders:
* If path matched (no matter livePath matched or not), return normal computed `match`
* If livePath matched, return latest normal render `match`
* If livePath unmatched, return normal computed `match`
* @memberof Route
* Back up current router every time it is rendered normally, backing up to the next livePath rendering
*/
LiveRoute.prototype.computeMatchWithLive = function (props, nextProps, nextContext, match) {
debugLog(">>> " + this.props.name + " <<<");
// compute if livePath match
var livePath = nextProps.livePath, alwaysLive = nextProps.alwaysLive;
var nextPropsWithLivePath = __assign({}, nextProps, { paths: livePath });
var prevMatch = this.computeMatch(props, this.context.router);
var livePathMatch = this.computePathsMatch(nextPropsWithLivePath, nextContext.router);
// normal matched render
if (match) {
debugLog('--- NORMAL MATCH FLAG ---');
if (this.liveState === LiveState.HIDE_RENDER && typeof this.props.onReappear === 'function') {
this.props.onReappear({ location: location, livePath: livePath, alwaysLive: alwaysLive });
}
this.liveState = LiveState.NORMAL_RENDER_MATCHED;
return match;
}
// hide render
if ((livePathMatch || props.alwaysLive) && this.routeDom) {
// backup router when from normal match render to hide render
if (prevMatch) {
this._latestMatchedRouter = this.context.router;
}
if (typeof this.props.onHide === 'function') {
this.props.onHide({ location: location, livePath: livePath, alwaysLive: alwaysLive });
}
debugLog('--- HIDE FLAG ---');
this.liveState = LiveState.HIDE_RENDER;
this.saveScrollPosition();
this.hideRoute();
return prevMatch;
}
// normal unmatched unmount
debugLog('--- NORMAL UNMATCH FLAG ---');
this.liveState = LiveState.NORMAL_RENDER_UNMATCHED;
this.clearScroll();
this.clearDomData();
};
LiveRoute.prototype.computePathsMatch = function (_a, router) {
var computedMatch = _a.computedMatch, location = _a.location, paths = _a.paths, strict = _a.strict, exact = _a.exact, sensitive = _a.sensitive;
invariant(router, 'You should not use <Route> or withRouter() outside a <Router>');
var route = router.route;
var pathname = (location || route.location).pathname;
// livePath could accept a string or an array of string
if (Array.isArray(paths)) {
for (var _i = 0, paths_1 = paths; _i < paths_1.length; _i++) {
var path = paths_1[_i];
if (typeof path !== 'string') {
continue;
}
var currPath = react_router_1.matchPath(pathname, { path: path, strict: strict, exact: exact, sensitive: sensitive }, router.match);
// return if one of the livePaths is matched
if (currPath) {
return currPath;
}
}
return null;
}
else {
return react_router_1.matchPath(pathname, { path: paths, strict: strict, exact: exact, sensitive: sensitive }, router.match);
}
};
LiveRoute.prototype.computeMatch = function (_a, router) {
var computedMatch = _a.computedMatch, location = _a.location, path = _a.path, strict = _a.strict, exact = _a.exact, sensitive = _a.sensitive;
// DO NOT use the computedMatch from Switch!
// react-live-route: ignore match from <Switch>, actually LiveRoute should not be wrapped by <Switch>.
// if (computedMatch) return computedMatch // <Switch> already computed the match for us
invariant(router, 'You should not use <Route> or withRouter() outside a <Router>');
var route = router.route;
var pathname = (location || route.location).pathname;
return react_router_1.matchPath(pathname, { path: path, strict: strict, exact: exact, sensitive: sensitive }, route.match);
};
// get DOM of Route
LiveRoute.prototype.getRouteDom = function () {
var routeDom = ReactDOM.findDOMNode(this);
this.routeDom = routeDom;
};
// backup scroll and hide DOM
LiveRoute.prototype.hideRoute = function () {
if (this.routeDom && this.routeDom.style.display !== 'none') {
debugLog('--- hide route ---');
this.previousDisplayStyle = this.routeDom.style.display;
this.routeDom.style.display = 'none';
}
};
// reveal DOM display
LiveRoute.prototype.showRoute = function () {
if (this.routeDom && this.previousDisplayStyle !== null) {
this.routeDom.style.display = this.previousDisplayStyle;
}
};
// save scroll position before hide DOM
LiveRoute.prototype.saveScrollPosition = function () {
if (this.routeDom && this.scrollPosBackup === null) {
var scrollTop = document.documentElement.scrollTop || document.body.scrollTop;
var scrollLeft = document.documentElement.scrollLeft || document.body.scrollLeft;
debugLog("saved top = " + scrollTop + ", left = " + scrollLeft);
this.scrollPosBackup = { top: scrollTop, left: scrollLeft };
}
};
// restore the scroll position before hide
LiveRoute.prototype.restoreScrollPosition = function () {
var scroll = this.scrollPosBackup;
debugLog(scroll);
if (scroll && this.routeDom) {
window.scrollTo(scroll.left, scroll.top);
}
};
// clear scroll position
LiveRoute.prototype.clearDomData = function () {
if (this.doesRouteEnableLive()) {
this.routeDom = null;
this.previousDisplayStyle = null;
}
};
// clear scroll position
LiveRoute.prototype.clearScroll = function () {
if (this.doesRouteEnableLive()) {
this.scrollPosBackup = null;
}
};
// normally render or unmount Route
LiveRoute.prototype.renderRoute = function (component, render, props, match) {
debugLog(match);
if (component)
return match ? React.createElement(component, props) : null;
if (render)
return match ? render(props) : null;
};
LiveRoute.prototype.render = function () {
var match = this.state.match;
var _a = this.props, children = _a.children, component = _a.component, render = _a.render, livePath = _a.livePath, alwaysLive = _a.alwaysLive, onHide = _a.onHide;
var _b = this.context.router, history = _b.history, route = _b.route, staticContext = _b.staticContext;
var location = this.props.location || route.location;
var props = { match: match, location: location, history: history, staticContext: staticContext };
// only affect LiveRoute
if ((livePath || alwaysLive) && (component || render)) {
debugLog('=== RENDER FLAG: ' + this.liveState + ' ===');
if (this.liveState === LiveState.NORMAL_RENDER_MATCHED ||
this.liveState === LiveState.NORMAL_RENDER_UNMATCHED ||
this.liveState === LiveState.NORMAL_RENDER_ON_INIT) {
// normal render
return this.renderRoute(component, render, props, match);
}
else if (this.liveState === LiveState.HIDE_RENDER) {
// hide render
var prevRouter = this._latestMatchedRouter;
var history_1 = prevRouter.history, route_1 = prevRouter.route, staticContext_1 = prevRouter.staticContext; // load properties from prevRouter and fake props of latest normal render
var liveProps = { match: match, location: location, history: history_1, staticContext: staticContext_1 };
return this.renderRoute(component, render, liveProps, true);
}
}
// the following is the same as Route of react-router, just render it normally
if (component)
return match ? React.createElement(component, props) : null;
if (render)
return match ? render(props) : null;
if (typeof children === 'function')
return children(props);
if (children && !isEmptyChildren(children))
return React.Children.only(children);
return null;
};
LiveRoute.propTypes = {
computedMatch: PropTypes.object,
path: PropTypes.string,
exact: PropTypes.bool,
strict: PropTypes.bool,
sensitive: PropTypes.bool,
component: function (props, propName) {
if (props[propName] && !react_is_1.isValidElementType(props[propName])) {
return new Error("Invalid prop 'component' supplied to 'Route': the prop is not a valid React component");
}
},
render: PropTypes.func,
children: PropTypes.oneOfType([PropTypes.func, PropTypes.node]),
location: PropTypes.object,
onHide: PropTypes.func,
livePath: PropTypes.oneOfType([PropTypes.string, PropTypes.array]),
alwaysLive: PropTypes.bool,
name: PropTypes.string // for LiveRoute debug
};
LiveRoute.defaultProps = {
alwaysLive: false
};
LiveRoute.contextTypes = {
router: PropTypes.shape({
history: PropTypes.object.isRequired,
route: PropTypes.object.isRequired,
staticContext: PropTypes.object
})
};
LiveRoute.childContextTypes = {
router: PropTypes.object.isRequired
};
return LiveRoute;
}(React.Component));
exports.LiveRoute = LiveRoute;
//# sourceMappingURL=LiveRoute.js.map
\ No newline at end of file
{"version":3,"file":"LiveRoute.js","sourceRoot":"","sources":["../src/LiveRoute.tsx"],"names":[],"mappings":";;;;;;;;;;;;;;;;;;;;;;;;;;AAAA,iCAAkC;AAClC,qCAAsC;AACtC,6BAA8B;AAC9B,sCAAuC;AACvC,oCAAqC;AACrC,6CAAwC;AACxC,qCAA6C;AAE7C,IAAM,eAAe,GAAG,UAAA,QAAQ,IAAI,OAAA,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,QAAQ,CAAC,KAAK,CAAC,EAApC,CAAoC,CAAA;AAExE,IAAK,SAKJ;AALD,WAAK,SAAS;IACZ,4DAA+C,CAAA;IAC/C,0EAA6D,CAAA;IAC7D,2EAA8D,CAAA;IAC9D,6DAAgD,CAAA;AAClD,CAAC,EALI,SAAS,KAAT,SAAS,QAKb;AAoBD,IAAM,QAAQ,GAAG,UAAC,OAAY;IAC5B,uBAAuB;AACzB,CAAC,CAAA;AAED;;GAEG;AACH;IAAwB,6BAA4B;IAApD;QAAA,qEAuUC;QAjSC,cAAQ,GAAa,IAAI,CAAA;QAczB,WAAK,GAAG;YACN,KAAK,EAAE,KAAI,CAAC,YAAY,CAAC,KAAI,CAAC,KAAY,EAAE,KAAI,CAAC,OAAO,CAAC,MAAM,CAAC;SACjE,CAAA;QAED,eAAS,GAAc,SAAS,CAAC,qBAAqB,CAAA;QACtD,qBAAe,GAAyC,IAAI,CAAA;QAC5D,0BAAoB,GAAkB,IAAI,CAAA;;IA6Q5C,CAAC;IA/RC,mCAAe,GAAf;QACE,OAAO;YACL,MAAM,eACD,IAAI,CAAC,OAAO,CAAC,MAAM,IACtB,KAAK,EAAE;oBACL,QAAQ,EAAE,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,KAAK,CAAC,QAAQ;oBACnE,KAAK,EAAE,IAAI,CAAC,KAAK,CAAC,KAAK;iBACxB,GACF;SACF,CAAA;IACH,CAAC;IAUD,sCAAkB,GAAlB;QACE,OAAO,CACL,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAC5C,2GAA2G,CAC5G,CAAA;QAED,OAAO,CACL,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,SAAS,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EACvF,+GAA+G,CAChH,CAAA;QAED,OAAO,CACL,CAAC,CAAC,IAAI,CAAC,KAAK,CAAC,MAAM,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,CAAC,eAAe,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EACpF,4GAA4G,CAC7G,CAAA;IACH,CAAC;IAED,qCAAiB,GAAjB;QACE,0CAA0C;QAC1C,IAAI,IAAI,CAAC,mBAAmB,EAAE,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;YAClD,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;YAC/C,IAAI,CAAC,WAAW,EAAE,CAAA;SACnB;IACH,CAAC;IAED,6CAAyB,GAAzB,UAA0B,SAAS,EAAE,WAAW;QAC9C,OAAO,CACL,CAAC,CAAC,SAAS,CAAC,QAAQ,IAAI,CAAC,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAC7C,yKAAyK,CAC1K,CAAA;QAED,OAAO,CACL,CAAC,CAAC,CAAC,SAAS,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,QAAQ,CAAC,EAC7C,qKAAqK,CACtK,CAAA;QAED,IAAI,KAAK,GAAG,IAAI,CAAC,YAAY,CAAC,SAAS,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;QAC5D,IAAI,aAAa,GAAG,KAAK,CAAA;QAEzB,iCAAiC;QACjC,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE;YAC9B,aAAa,GAAG,IAAI,CAAC,oBAAoB,CAAC,IAAI,CAAC,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK,CAAC,CAAA;SACrF;QAED,IAAI,CAAC,QAAQ,CAAC;YACZ,KAAK,EAAE,aAAa;SACrB,CAAC,CAAA;IACJ,CAAC;IAED,mBAAmB;IACnB,sCAAkB,GAAlB,UAAmB,SAAS,EAAE,SAAS;QACrC,IAAI,CAAC,IAAI,CAAC,mBAAmB,EAAE,EAAE;YAC/B,OAAM;SACP;QAED,wCAAwC;QACxC,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAC,CAAA;QACxB,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,qBAAqB,EAAE;YACtD,IAAI,CAAC,SAAS,EAAE,CAAA;YAChB,IAAI,CAAC,qBAAqB,EAAE,CAAA;YAC5B,IAAI,CAAC,WAAW,EAAE,CAAA;SACnB;QAED,8BAA8B;QAC9B,IAAI,IAAI,CAAC,KAAK,CAAC,KAAK,EAAE;YACpB,IAAI,CAAC,WAAW,EAAE,CAAA;SACnB;IACH,CAAC;IAED,sBAAsB;IACtB,wCAAoB,GAApB;QACE,IAAI,CAAC,WAAW,EAAE,CAAA;IACpB,CAAC;IAED,uCAAmB,GAAnB;QACE,OAAO,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,IAAI,CAAC,KAAK,CAAC,UAAU,CAAA;IACrD,CAAC;IAED;;;;;;;;;;;;OAYG;IACH,wCAAoB,GAApB,UAAqB,KAAK,EAAE,SAAS,EAAE,WAAW,EAAE,KAAK;QACvD,QAAQ,CAAC,MAAM,GAAG,IAAI,CAAC,KAAK,CAAC,IAAI,GAAG,MAAM,CAAC,CAAA;QAC3C,4BAA4B;QACpB,IAAA,6BAAQ,EAAE,iCAAU,CAAc;QAC1C,IAAM,qBAAqB,gBAAQ,SAAS,IAAE,KAAK,EAAE,QAAQ,GAAE,CAAA;QAC/D,IAAM,SAAS,GAAG,IAAI,CAAC,YAAY,CAAC,KAAK,EAAE,IAAI,CAAC,OAAO,CAAC,MAAM,CAAC,CAAA;QAC/D,IAAM,aAAa,GAAG,IAAI,CAAC,iBAAiB,CAAC,qBAAqB,EAAE,WAAW,CAAC,MAAM,CAAC,CAAA;QAEvF,wBAAwB;QACxB,IAAI,KAAK,EAAE;YACT,QAAQ,CAAC,2BAA2B,CAAC,CAAA;YACrC,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,WAAW,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,UAAU,KAAK,UAAU,EAAE;gBAC3F,IAAI,CAAC,KAAK,CAAC,UAAU,CAAC,EAAE,QAAQ,UAAA,EAAE,QAAQ,UAAA,EAAE,UAAU,YAAA,EAAE,CAAC,CAAA;aAC1D;YACD,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,qBAAqB,CAAA;YAChD,OAAO,KAAK,CAAA;SACb;QAED,cAAc;QACd,IAAI,CAAC,aAAa,IAAI,KAAK,CAAC,UAAU,CAAC,IAAI,IAAI,CAAC,QAAQ,EAAE;YACxD,6DAA6D;YAC7D,IAAI,SAAS,EAAE;gBACb,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,OAAO,CAAC,MAAM,CAAA;aAChD;YACD,IAAI,OAAO,IAAI,CAAC,KAAK,CAAC,MAAM,KAAK,UAAU,EAAE;gBAC3C,IAAI,CAAC,KAAK,CAAC,MAAM,CAAC,EAAE,QAAQ,UAAA,EAAE,QAAQ,UAAA,EAAE,UAAU,YAAA,EAAE,CAAC,CAAA;aACtD;YACD,QAAQ,CAAC,mBAAmB,CAAC,CAAA;YAC7B,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,WAAW,CAAA;YACtC,IAAI,CAAC,kBAAkB,EAAE,CAAA;YACzB,IAAI,CAAC,SAAS,EAAE,CAAA;YAChB,OAAO,SAAS,CAAA;SACjB;QAED,2BAA2B;QAC3B,QAAQ,CAAC,6BAA6B,CAAC,CAAA;QACvC,IAAI,CAAC,SAAS,GAAG,SAAS,CAAC,uBAAuB,CAAA;QAClD,IAAI,CAAC,WAAW,EAAE,CAAA;QAClB,IAAI,CAAC,YAAY,EAAE,CAAA;IACrB,CAAC;IAED,qCAAiB,GAAjB,UAAkB,EAA4D,EAAE,MAAM;YAAlE,gCAAa,EAAE,sBAAQ,EAAE,gBAAK,EAAE,kBAAM,EAAE,gBAAK,EAAE,wBAAS;QAC1E,SAAS,CAAC,MAAM,EAAE,+DAA+D,CAAC,CAAA;QAC1E,IAAA,oBAAK,CAAW;QACxB,IAAM,QAAQ,GAAG,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAA;QAEtD,uDAAuD;QACvD,IAAI,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;YACxB,KAAiB,UAAK,EAAL,eAAK,EAAL,mBAAK,EAAL,IAAK,EAAE;gBAAnB,IAAI,IAAI,cAAA;gBACX,IAAI,OAAO,IAAI,KAAK,QAAQ,EAAE;oBAC5B,SAAQ;iBACT;gBACD,IAAM,QAAQ,GAAG,wBAAS,CAAC,QAAQ,EAAE,EAAE,IAAI,MAAA,EAAE,MAAM,QAAA,EAAE,KAAK,OAAA,EAAE,SAAS,WAAA,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;gBACtF,4CAA4C;gBAC5C,IAAI,QAAQ,EAAE;oBACZ,OAAO,QAAQ,CAAA;iBAChB;aACF;YACD,OAAO,IAAI,CAAA;SACZ;aAAM;YACL,OAAO,wBAAS,CAAC,QAAQ,EAAE,EAAE,IAAI,EAAE,KAAK,EAAE,MAAM,QAAA,EAAE,KAAK,OAAA,EAAE,SAAS,WAAA,EAAE,EAAE,MAAM,CAAC,KAAK,CAAC,CAAA;SACpF;IACH,CAAC;IAED,gCAAY,GAAZ,UAAa,EAA2D,EAAE,MAAM;YAAjE,gCAAa,EAAE,sBAAQ,EAAE,cAAI,EAAE,kBAAM,EAAE,gBAAK,EAAE,wBAAS;QACpE,4CAA4C;QAC5C,sGAAsG;QACtG,wFAAwF;QACxF,SAAS,CAAC,MAAM,EAAE,+DAA+D,CAAC,CAAA;QAE1E,IAAA,oBAAK,CAAW;QACxB,IAAM,QAAQ,GAAG,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAC,CAAC,QAAQ,CAAA;QAEtD,OAAO,wBAAS,CAAC,QAAQ,EAAE,EAAE,IAAI,MAAA,EAAE,MAAM,QAAA,EAAE,KAAK,OAAA,EAAE,SAAS,WAAA,EAAE,EAAE,KAAK,CAAC,KAAK,CAAC,CAAA;IAC7E,CAAC;IAED,mBAAmB;IACnB,+BAAW,GAAX;QACE,IAAI,QAAQ,GAAG,QAAQ,CAAC,WAAW,CAAC,IAAI,CAAC,CAAA;QACzC,IAAI,CAAC,QAAQ,GAAG,QAAoB,CAAA;IACtC,CAAC;IAED,6BAA6B;IAC7B,6BAAS,GAAT;QACE,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,KAAK,MAAM,EAAE;YAC3D,QAAQ,CAAC,oBAAoB,CAAC,CAAA;YAC9B,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,CAAA;YACvD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,GAAG,MAAM,CAAA;SACrC;IACH,CAAC;IAED,qBAAqB;IACrB,6BAAS,GAAT;QACE,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,oBAAoB,KAAK,IAAI,EAAE;YACvD,IAAI,CAAC,QAAQ,CAAC,KAAK,CAAC,OAAO,GAAG,IAAI,CAAC,oBAAoB,CAAA;SACxD;IACH,CAAC;IAED,uCAAuC;IACvC,sCAAkB,GAAlB;QACE,IAAI,IAAI,CAAC,QAAQ,IAAI,IAAI,CAAC,eAAe,KAAK,IAAI,EAAE;YAClD,IAAM,SAAS,GAAG,QAAQ,CAAC,eAAe,CAAC,SAAS,IAAI,QAAQ,CAAC,IAAI,CAAC,SAAS,CAAA;YAC/E,IAAM,UAAU,GAAG,QAAQ,CAAC,eAAe,CAAC,UAAU,IAAI,QAAQ,CAAC,IAAI,CAAC,UAAU,CAAA;YAClF,QAAQ,CAAC,iBAAe,SAAS,iBAAY,UAAY,CAAC,CAAA;YAC1D,IAAI,CAAC,eAAe,GAAG,EAAE,GAAG,EAAE,SAAS,EAAE,IAAI,EAAE,UAAU,EAAE,CAAA;SAC5D;IACH,CAAC;IAED,0CAA0C;IAC1C,yCAAqB,GAArB;QACE,IAAM,MAAM,GAAG,IAAI,CAAC,eAAe,CAAA;QACnC,QAAQ,CAAC,MAAM,CAAC,CAAA;QAChB,IAAI,MAAM,IAAI,IAAI,CAAC,QAAQ,EAAE;YAC3B,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,IAAI,EAAE,MAAM,CAAC,GAAG,CAAC,CAAA;SACzC;IACH,CAAC;IAED,wBAAwB;IACxB,gCAAY,GAAZ;QACE,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE;YAC9B,IAAI,CAAC,QAAQ,GAAG,IAAI,CAAA;YACpB,IAAI,CAAC,oBAAoB,GAAG,IAAI,CAAA;SACjC;IACH,CAAC;IAED,wBAAwB;IACxB,+BAAW,GAAX;QACE,IAAI,IAAI,CAAC,mBAAmB,EAAE,EAAE;YAC9B,IAAI,CAAC,eAAe,GAAG,IAAI,CAAA;SAC5B;IACH,CAAC;IAED,mCAAmC;IACnC,+BAAW,GAAX,UAAY,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK;QACzC,QAAQ,CAAC,KAAK,CAAC,CAAA;QACf,IAAI,SAAS;YAAE,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAC1E,IAAI,MAAM;YAAE,OAAO,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;IACjD,CAAC;IAED,0BAAM,GAAN;QACU,IAAA,wBAAK,CAAe;QACtB,IAAA,eAA0E,EAAxE,sBAAQ,EAAE,wBAAS,EAAE,kBAAM,EAAE,sBAAQ,EAAE,0BAAU,EAAE,kBAAqB,CAAA;QAC1E,IAAA,wBAAuD,EAArD,oBAAO,EAAE,gBAAK,EAAE,gCAAqC,CAAA;QAC7D,IAAM,QAAQ,GAAG,IAAI,CAAC,KAAK,CAAC,QAAQ,IAAI,KAAK,CAAC,QAAQ,CAAA;QACtD,IAAM,KAAK,GAAG,EAAE,KAAK,OAAA,EAAE,QAAQ,UAAA,EAAE,OAAO,SAAA,EAAE,aAAa,eAAA,EAAE,CAAA;QAEzD,wBAAwB;QACxB,IAAI,CAAC,QAAQ,IAAI,UAAU,CAAC,IAAI,CAAC,SAAS,IAAI,MAAM,CAAC,EAAE;YACrD,QAAQ,CAAC,mBAAmB,GAAG,IAAI,CAAC,SAAS,GAAG,MAAM,CAAC,CAAA;YACvD,IACE,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,qBAAqB;gBAClD,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,uBAAuB;gBACpD,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,qBAAqB,EAClD;gBACA,gBAAgB;gBAChB,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,KAAK,EAAE,KAAK,CAAC,CAAA;aACzD;iBAAM,IAAI,IAAI,CAAC,SAAS,KAAK,SAAS,CAAC,WAAW,EAAE;gBACnD,cAAc;gBACd,IAAM,UAAU,GAAG,IAAI,CAAC,oBAAoB,CAAA;gBACpC,IAAA,8BAAO,EAAE,0BAAK,EAAE,0CAAa,CAAe,CAAC,yEAAyE;gBAC9H,IAAM,SAAS,GAAG,EAAE,KAAK,OAAA,EAAE,QAAQ,UAAA,EAAE,OAAO,WAAA,EAAE,aAAa,iBAAA,EAAE,CAAA;gBAC7D,OAAO,IAAI,CAAC,WAAW,CAAC,SAAS,EAAE,MAAM,EAAE,SAAS,EAAE,IAAI,CAAC,CAAA;aAC5D;SACF;QAED,8EAA8E;QAC9E,IAAI,SAAS;YAAE,OAAO,KAAK,CAAC,CAAC,CAAC,KAAK,CAAC,aAAa,CAAC,SAAS,EAAE,KAAK,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAE1E,IAAI,MAAM;YAAE,OAAO,KAAK,CAAC,CAAC,CAAC,MAAM,CAAC,KAAY,CAAC,CAAC,CAAC,CAAC,IAAI,CAAA;QAEtD,IAAI,OAAO,QAAQ,KAAK,UAAU;YAAE,OAAO,QAAQ,CAAC,KAAK,CAAC,CAAA;QAE1D,IAAI,QAAQ,IAAI,CAAC,eAAe,CAAC,QAAQ,CAAC;YAAE,OAAO,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,QAAQ,CAAC,CAAA;QAEhF,OAAO,IAAI,CAAA;IACb,CAAC;IArUM,mBAAS,GAAG;QACjB,aAAa,EAAE,SAAS,CAAC,MAAM;QAC/B,IAAI,EAAE,SAAS,CAAC,MAAM;QACtB,KAAK,EAAE,SAAS,CAAC,IAAI;QACrB,MAAM,EAAE,SAAS,CAAC,IAAI;QACtB,SAAS,EAAE,SAAS,CAAC,IAAI;QACzB,SAAS,EAAE,UAAC,KAAK,EAAE,QAAQ;YACzB,IAAI,KAAK,CAAC,QAAQ,CAAC,IAAI,CAAC,6BAAkB,CAAC,KAAK,CAAC,QAAQ,CAAC,CAAC,EAAE;gBAC3D,OAAO,IAAI,KAAK,CAAC,uFAAuF,CAAC,CAAA;aAC1G;QACH,CAAC;QACD,MAAM,EAAE,SAAS,CAAC,IAAI;QACtB,QAAQ,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,IAAI,EAAE,SAAS,CAAC,IAAI,CAAC,CAAC;QAC/D,QAAQ,EAAE,SAAS,CAAC,MAAM;QAC1B,MAAM,EAAE,SAAS,CAAC,IAAI;QACtB,QAAQ,EAAE,SAAS,CAAC,SAAS,CAAC,CAAC,SAAS,CAAC,MAAM,EAAE,SAAS,CAAC,KAAK,CAAC,CAAC;QAClE,UAAU,EAAE,SAAS,CAAC,IAAI;QAC1B,IAAI,EAAE,SAAS,CAAC,MAAM,CAAC,sBAAsB;KAC9C,CAAA;IAEM,sBAAY,GAAG;QACpB,UAAU,EAAE,KAAK;KAClB,CAAA;IAEM,sBAAY,GAAG;QACpB,MAAM,EAAE,SAAS,CAAC,KAAK,CAAC;YACtB,OAAO,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;YACpC,KAAK,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;YAClC,aAAa,EAAE,SAAS,CAAC,MAAM;SAChC,CAAC;KACH,CAAA;IAEM,2BAAiB,GAAG;QACzB,MAAM,EAAE,SAAS,CAAC,MAAM,CAAC,UAAU;KACpC,CAAA;IAoSH,gBAAC;CAAA,AAvUD,CAAwB,KAAK,CAAC,SAAS,GAuUtC;AAEQ,8BAAS"}
\ No newline at end of file
{ {
"name": "react-live-route", "name": "react-live-route",
"version": "1.3.0", "version": "1.3.0",
"description": "A living route for react-router-v4", "description": "A living route for react-router v4",
"repository": "fi3ework/react-live-route", "repository": "fi3ework/react-live-route",
"license": "MIT", "license": "MIT",
"authors": "fi3ework", "authors": "fi3ework",
...@@ -12,7 +12,7 @@ ...@@ -12,7 +12,7 @@
"build": "rm -fr dist && tsc", "build": "rm -fr dist && tsc",
"dev": "tsc -b -w --pretty", "dev": "tsc -b -w --pretty",
"prepare": "npm run build", "prepare": "npm run build",
"lint": "eslint modules", "lint": "tslint src",
"test": "jest" "test": "jest"
}, },
"peerDependencies": { "peerDependencies": {
...@@ -32,15 +32,12 @@ ...@@ -32,15 +32,12 @@
"@types/jest": "^24.0.9", "@types/jest": "^24.0.9",
"@types/react": "^16.7.18", "@types/react": "^16.7.18",
"@types/react-dom": "^16.0.11", "@types/react-dom": "^16.0.11",
"jest": "^23.1.0", "jest": "^24.5.0",
"react-addons-test-utils": "^15.6.2",
"ts-jest": "^24.0.0", "ts-jest": "^24.0.0",
"tslint-config-prettier": "^1.17.0" "tslint": "^5.14.0",
}, "tslint-config-alloy": "^0.2.1",
"jest": { "tslint-config-prettier": "^1.18.0",
"setupFiles": [ "typescript": "^3.3.3333"
"raf/polyfill"
]
}, },
"keywords": [ "keywords": [
"react", "react",
......
{ {
"compilerOptions": { "compilerOptions": {
"alwaysStrict": true,
"declaration": true,
"removeComments": false,
"strict": true, "strict": true,
"experimentalDecorators": true, "experimentalDecorators": true,
"allowSyntheticDefaultImports": true, "allowSyntheticDefaultImports": true,
...@@ -17,7 +20,10 @@ ...@@ -17,7 +20,10 @@
"noImplicitAny": false, "noImplicitAny": false,
"strictNullChecks": true, "strictNullChecks": true,
"suppressImplicitAnyIndexErrors": true, "suppressImplicitAnyIndexErrors": true,
"noUnusedLocals": false "downlevelIteration": true,
"noUnusedLocals": false,
"noUnusedParameters": false
}, },
"include": ["src"] "include": ["src/**/*.tsx"],
"exclude": ["node_modules", "dist", "__test__"]
} }
{ {
"extends": ["tslint:recommended", "tslint-react", "tslint-config-prettier"], "extends": ["tslint-config-alloy", "tslint-config-prettier"]
"compilerOptions": {
"allowSyntheticDefaultImports": true,
"esModuleInterop": true
},
"linterOptions": {
"exclude": ["node_modules/**/*.ts"]
},
"rules": {
"no-var-requires": false,
"max-classes-per-file": false,
// "prettier": true,
"arrow-parens": false,
"arrow-return-shorthand": [false],
"comment-format": [true, "check-space"],
"import-blacklist": [true, "rxjs"],
"interface-over-type-literal": false,
"interface-name": false,
"member-access": false,
"member-ordering": [true, { "order": "fields-first" }],
// "newline-before-return": false,]
"no-any": false,
"no-empty-interface": false,
"no-import-side-effect": false,
"no-inferrable-types": [true, "ignore-params", "ignore-properties"],
"no-invalid-this": [true, "check-function-in-method"],
"no-null-keyword": false,
"no-require-imports": false,
"no-this-assignment": [true, { "allow-destructuring": true }],
"no-trailing-whitespace": true,
"no-unused-variable": [false, "react"],
"object-literal-sort-keys": false,
"object-literal-shorthand": false,
"one-variable-per-declaration": [false],
"only-arrow-functions": [true, "allow-declarations"],
"ordered-imports": [false],
"no-console": [false],
"prefer-method-signature": false,
"prefer-template": [true, "allow-single-concat"],
"quotemark": [true, "single", "jsx-double"],
"triple-equals": [true, "allow-null-check"],
// "type-literal-delimiter": true,
"typedef": {
"severity": "off",
"options": ["parameter", "property-declaration"]
},
"variable-name": [true, "ban-keywords", "check-format", "allow-pascal-case", "allow-leading-underscore"],
// tslint-react
"jsx-no-lambda": false
},
"jsRules": {
"object-literal-sort-keys": false // Disable for javascript
}
} }
This source diff could not be displayed because it is too large. You can view the blob instead.
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment