Skip to content

Commit

Permalink
refactor(shared): normalize directory structure
Browse files Browse the repository at this point in the history
  • Loading branch information
meteorlxy committed May 20, 2024
1 parent e08e81f commit cf03532
Show file tree
Hide file tree
Showing 21 changed files with 52 additions and 45 deletions.
12 changes: 3 additions & 9 deletions packages/shared/src/utils/index.ts
Original file line number Diff line number Diff line change
@@ -1,18 +1,12 @@
export * from './links/index.js'
export * from './routes/index.js'

export * from './dedupeHead.js'
export * from './ensureLeadingSlash.js'
export * from './ensureEndingSlash.js'
export * from './formatDateString.js'
export * from './inferRoutePath.js'
export * from './isLinkExternal.js'
export * from './isLinkHttp.js'
export * from './isLinkWithProtocol.js'
export * from './isPlainObject.js'
export * from './inferRoutePath.js'
export * from './normalizeRoutePath.js'
export * from './omit.js'
export * from './removeEndingSlash.js'
export * from './removeLeadingSlash.js'
export * from './resolveHeadIdentifier.js'
export * from './resolveLocalePath.js'
export * from './resolveRoutePathFromUrl.js'
export * from './typeGuards.js'
6 changes: 0 additions & 6 deletions packages/shared/src/utils/isPlainObject.ts

This file was deleted.

3 changes: 3 additions & 0 deletions packages/shared/src/utils/links/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,3 @@
export * from './isLinkExternal.js'
export * from './isLinkHttp.js'
export * from './isLinkWithProtocol.js'
File renamed without changes.
File renamed without changes.
4 changes: 4 additions & 0 deletions packages/shared/src/utils/routes/index.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,4 @@
export * from './inferRoutePath'
export * from './normalizeRoutePath.js'
export * from './resolveLocalePath.js'
export * from './resolveRoutePathFromUrl.js'
File renamed without changes.
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
import type { LocaleConfig } from '../types/index.js'
import type { LocaleConfig } from '../../types/index.js'

/**
* Resolve the matched locale path of route path
Expand Down
Original file line number Diff line number Diff line change
@@ -1,3 +1,6 @@
/**
* For a give URL, remove the origin and the site base to get the route path
*/
export const resolveRoutePathFromUrl = (url: string, base = '/'): string => {
const pathname = url
// remove url origin
Expand Down
7 changes: 7 additions & 0 deletions packages/shared/src/utils/typeGuards.ts
Original file line number Diff line number Diff line change
Expand Up @@ -5,6 +5,13 @@
export const isFunction = (val: unknown): val is Function =>
typeof val === 'function'

/**
* Check if a value is plain object, with generic type support
*/
export const isPlainObject = <T extends Record<any, any> = Record<any, any>>(
val: unknown,
): val is T => Object.prototype.toString.call(val) === '[object Object]'

/**
* Check if a value is a string
*/
Expand Down
21 changes: 0 additions & 21 deletions packages/shared/tests/isPlainObject.spec.ts

This file was deleted.

Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { expect, it } from 'vitest'
import { isLinkExternal } from '../src/index.js'
import { isLinkExternal } from '../../src/index.js'

const testCases: [
Parameters<typeof isLinkExternal>,
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { expect, it } from 'vitest'
import { isLinkHttp } from '../src/index.js'
import { isLinkHttp } from '../../src/index.js'

const testCases: [string, ReturnType<typeof isLinkHttp>][] = [
['https://foobar.com', true],
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { expect, it } from 'vitest'
import { isLinkWithProtocol } from '../src/index.js'
import { isLinkWithProtocol } from '../../src/index.js'

const testCases: [string, ReturnType<typeof isLinkWithProtocol>][] = [
// with protocol
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { describe, expect, it } from 'vitest'
import { inferRoutePath } from '../src/index.js'
import { inferRoutePath } from '../../src/index.js'

const testCases = [
// absolute index
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { describe, expect, it } from 'vitest'
import { normalizeRoutePath } from '../src/index.js'
import { normalizeRoutePath } from '../../src/index.js'

const testCases = [
// absolute index
Expand Down
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { expect, it } from 'vitest'
import { resolveLocalePath } from '../src/index.js'
import type { LocaleConfig } from '../src/index.js'
import type { LocaleConfig } from '../../src/index.js'
import { resolveLocalePath } from '../../src/index.js'

const locales: LocaleConfig = {
'/': {
Expand Down
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
import { expect, it } from 'vitest'
import { resolveRoutePathFromUrl } from '../src/index.js'
import { resolveRoutePathFromUrl } from '../../src/index.js'

const testCases: [
Parameters<typeof resolveRoutePathFromUrl>,
Expand Down
23 changes: 23 additions & 0 deletions packages/shared/tests/typeGuards.spec.ts
Original file line number Diff line number Diff line change
@@ -0,0 +1,23 @@
import { describe, expect, it } from 'vitest'
import { isPlainObject } from '../src/index.js'

describe('isPlainObject', () => {
const testCases: [unknown, boolean][] = [
[true, false],
[false, false],
['', false],
['foobar', false],
[0, false],
[1, false],
[[], false],
[{}, true],
[{ foo: 'bar' }, true],
[Object.create(null), true],
]

it('should determine plain object correctly', () => {
testCases.forEach(([source, expected]) => {
expect(isPlainObject(source)).toBe(expected)
})
})
})

0 comments on commit cf03532

Please sign in to comment.