Skip to content

Commit

Permalink
fix: use assign to align with Vue browser support (vuejs#311)
Browse files Browse the repository at this point in the history
* fix: use assign to align with Vue browser support

Close vuejs#304

* fix: use correct imports

* fix: more missed objects

* fix: add missing copy
  • Loading branch information
posva authored Jun 18, 2020
1 parent fa61d0a commit f80b670
Show file tree
Hide file tree
Showing 9 changed files with 144 additions and 131 deletions.
19 changes: 12 additions & 7 deletions src/RouterLink.ts
Original file line number Diff line number Diff line change
Expand Up @@ -12,6 +12,7 @@ import { RouteLocationRaw, VueUseOptions, RouteLocation } from './types'
import { isSameLocationObject, isSameRouteRecord } from './location'
import { routerKey, routeLocationKey } from './injectionSymbols'
import { RouteRecord } from './matcher/types'
import { assign } from './utils'

export interface RouterLinkProps {
to: RouteLocationRaw
Expand Down Expand Up @@ -126,13 +127,17 @@ export const RouterLinkImpl = defineComponent({
? children
: h(
'a',
{
'aria-current': link.isExactActive ? 'page' : null,
onClick: link.navigate,
href: link.href,
...attrs,
class: elClass.value,
},
assign(
{
'aria-current': link.isExactActive ? 'page' : null,
onClick: link.navigate,
href: link.href,
},
attrs,
{
class: elClass.value,
}
),
children
)
}
Expand Down
18 changes: 11 additions & 7 deletions src/RouterView.ts
Original file line number Diff line number Diff line change
Expand Up @@ -15,6 +15,7 @@ import {
viewDepthKey,
routeLocationKey,
} from './injectionSymbols'
import { assign } from './utils'

export interface RouterViewProps {
name?: string
Expand Down Expand Up @@ -86,14 +87,17 @@ export const RouterViewImpl = defineComponent({
}

let Component = ViewComponent.value
const componentProps: Parameters<typeof h>[1] = {
const componentProps: Parameters<typeof h>[1] = assign(
{},
// only compute props if there is a matched record
...(Component && propsData.value),
...attrs,
onVnodeMounted,
onVnodeUnmounted,
ref: viewRef,
}
Component && propsData.value,
attrs,
{
onVnodeMounted,
onVnodeUnmounted,
ref: viewRef,
}
)

// NOTE: we could also not render if there is no route match
const children =
Expand Down
5 changes: 3 additions & 2 deletions src/errors.ts
Original file line number Diff line number Diff line change
Expand Up @@ -4,6 +4,7 @@ import {
RouteLocationRaw,
RouteLocationNormalized,
} from './types'
import { assign } from './utils'

/**
* order is important to make it backwards compatible with v3
Expand Down Expand Up @@ -82,13 +83,13 @@ export function createRouterError<E extends RouterError>(
params: Omit<E, 'type' | keyof Error>
): E {
if (__DEV__ || !__BROWSER__) {
return Object.assign(
return assign(
new Error(ErrorTypeMessages[type](params as any)),
{ type },
params
) as E
} else {
return Object.assign(new Error(), { type }, params) as E
return assign(new Error(), { type }, params) as E
}
}

Expand Down
57 changes: 30 additions & 27 deletions src/history/html5.ts
Original file line number Diff line number Diff line change
Expand Up @@ -16,6 +16,7 @@ import {
} from '../scrollBehavior'
import { warn } from '../warning'
import { stripBase } from '../location'
import { assign } from '../utils'

type PopStateListener = (this: Window, ev: PopStateEvent) => any

Expand Down Expand Up @@ -124,10 +125,7 @@ function useHistoryListeners(
const { history } = window
if (!history.state) return
history.replaceState(
{
...history.state,
scroll: computeScrollPosition(),
},
assign({}, history.state, { scroll: computeScrollPosition() }),
''
)
}
Expand Down Expand Up @@ -218,18 +216,19 @@ function useHistoryStateNavigation(base: string) {
function replace(to: RawHistoryLocation, data?: HistoryState) {
const normalized = normalizeHistoryLocation(to)

const state: StateEntry = {
...history.state,
...buildState(
const state: StateEntry = assign(
{},
history.state,
buildState(
historyState.value.back,
// keep back and forward entries but override current position
normalized,
historyState.value.forward,
true
),
...data,
position: historyState.value.position,
}
data,
{ position: historyState.value.position }
)

changeLocation(normalized, state, true)
location.value = normalized
Expand All @@ -240,18 +239,20 @@ function useHistoryStateNavigation(base: string) {

// Add to current entry the information of where we are going
// as well as saving the current position
const currentState: StateEntry = {
...history.state,
const currentState: StateEntry = assign({}, history.state, {
forward: normalized,
scroll: computeScrollPosition(),
}
})
changeLocation(currentState.current, currentState, true)

const state: StateEntry = {
...buildState(location.value, normalized, null),
position: currentState.position + 1,
...data,
}
const state: StateEntry = assign(
{},
buildState(location.value, normalized, null),
{
position: currentState.position + 1,
},
data
)

changeLocation(normalized, state, false)
location.value = normalized
Expand Down Expand Up @@ -280,16 +281,18 @@ export function createWebHistory(base?: string): RouterHistory {
if (!triggerListeners) historyListeners.pauseListeners()
history.go(delta)
}
const routerHistory: RouterHistory = {
// it's overridden right after
// @ts-ignore
location: '',
base,
go,

...historyNavigation,
...historyListeners,
}
const routerHistory: RouterHistory = assign(
{
// it's overridden right after
location: ('' as unknown) as HistoryLocationNormalized,
base,
go,
},

historyNavigation,
historyListeners
)

Object.defineProperty(routerHistory, 'location', {
get: () => historyNavigation.location.value,
Expand Down
61 changes: 29 additions & 32 deletions src/matcher/index.ts
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ import {
_PathParserOptions,
} from './pathParserRanker'
import { warn } from '../warning'
import { assign } from '../utils'

let noop = () => {}

Expand Down Expand Up @@ -70,21 +71,22 @@ export function createRouterMatcher(
const aliases =
typeof record.alias === 'string' ? [record.alias] : record.alias!
for (const alias of aliases) {
normalizedRecords.push({
...mainNormalizedRecord,
// this allows us to hold a copy of the `components` option
// so that async components cache is hold on the original record
components: originalRecord
? originalRecord.record.components
: mainNormalizedRecord.components,
path: alias,
// we might be the child of an alias
aliasOf: originalRecord
? originalRecord.record
: mainNormalizedRecord,
// the aliases are always of the same kind as the original since they
// are defined on the same record
} as typeof mainNormalizedRecord)
normalizedRecords.push(
assign({}, mainNormalizedRecord, {
// this allows us to hold a copy of the `components` option
// so that async components cache is hold on the original record
components: originalRecord
? originalRecord.record.components
: mainNormalizedRecord.components,
path: alias,
// we might be the child of an alias
aliasOf: originalRecord
? originalRecord.record
: mainNormalizedRecord,
// the aliases are always of the same kind as the original since they
// are defined on the same record
}) as typeof mainNormalizedRecord
)
}
}

Expand Down Expand Up @@ -219,13 +221,14 @@ export function createRouterMatcher(
})

name = matcher.record.name
params = {
...paramsFromLocation(
params = assign(
// paramsFromLocation is a new object
paramsFromLocation(
currentLocation.params,
matcher.keys.map(k => k.name)
),
...location.params,
}
location.params
)
// throws if cannot be stringified
path = matcher.stringify(params)
} else if ('path' in location) {
Expand Down Expand Up @@ -261,7 +264,7 @@ export function createRouterMatcher(
name = matcher.record.name
// since we are navigating to the same location, we don't need to pick the
// params like when `name` is provided
params = { ...currentLocation.params, ...location.params }
params = assign({}, currentLocation.params, location.params)
path = matcher.stringify(params)
}

Expand Down Expand Up @@ -303,7 +306,8 @@ function paramsFromLocation(
}

/**
* Normalizes a RouteRecordRaw. Transforms the `redirect` option into a `beforeEnter`
* Normalizes a RouteRecordRaw. Transforms the `redirect` option into a
* `beforeEnter`. This function creates a copy
* @param record
* @returns the normalized version
*/
Expand All @@ -319,23 +323,19 @@ export function normalizeRouteRecord(
}

if ('redirect' in record) {
return {
...commonInitialValues,
redirect: record.redirect,
}
return assign(commonInitialValues, { redirect: record.redirect })
} else {
const components =
'components' in record ? record.components : { default: record.component }
return {
...commonInitialValues,
return assign(commonInitialValues, {
beforeEnter: record.beforeEnter,
props: normalizeRecordProps(record),
children: record.children || [],
instances: {},
leaveGuards: [],
updateGuards: [],
components,
}
})
}
}

Expand Down Expand Up @@ -381,10 +381,7 @@ function isAliasRecord(record: RouteRecordMatcher | undefined): boolean {
*/
function mergeMetaFields(matched: MatcherLocation['matched']) {
return matched.reduce(
(meta, record) => ({
...meta,
...record.meta,
}),
(meta, record) => assign(meta, record.meta),
{} as MatcherLocation['meta']
)
}
Expand Down
6 changes: 3 additions & 3 deletions src/matcher/pathMatcher.ts
Original file line number Diff line number Diff line change
Expand Up @@ -6,6 +6,7 @@ import {
} from './pathParserRanker'
import { tokenizePath } from './pathTokenizer'
import { warn } from '../warning'
import { assign } from '../utils'

export interface RouteRecordMatcher extends PathParser {
record: RouteRecord
Expand Down Expand Up @@ -34,14 +35,13 @@ export function createRouteRecordMatcher(
}
}

const matcher: RouteRecordMatcher = {
...parser,
const matcher: RouteRecordMatcher = assign(parser, {
record,
parent,
// these needs to be populated by the parent
children: [],
alias: [],
}
})

if (parent) {
// both are aliases or both are not aliases
Expand Down
6 changes: 2 additions & 4 deletions src/matcher/pathParserRanker.ts
Original file line number Diff line number Diff line change
@@ -1,4 +1,5 @@
import { Token, TokenType } from './pathTokenizer'
import { assign } from '../utils'

export type PathParams = Record<string, string | string[]>

Expand Down Expand Up @@ -108,10 +109,7 @@ export function tokensToParser(
segments: Array<Token[]>,
extraOptions?: _PathParserOptions
): PathParser {
const options = {
...BASE_PATH_PARSER_OPTIONS,
...extraOptions,
}
const options = assign({}, BASE_PATH_PARSER_OPTIONS, extraOptions)

// the amount of scores is the same as the length of segments except for the root segment "/"
let score: Array<number[]> = []
Expand Down
Loading

0 comments on commit f80b670

Please sign in to comment.