Home / File/ create-async-file-mapper.ts — vue Source File

create-async-file-mapper.ts — vue Source File

Architecture documentation for create-async-file-mapper.ts, a typescript file in the vue codebase. 2 imports, 1 dependents.

File typescript ServerRenderer TemplateRenderer 2 imports 1 dependents 4 functions

Entity Profile

Dependency Diagram

graph LR
  619ed059_733e_d046_032d_afa289d21abc["create-async-file-mapper.ts"]
  70b92f4c_021d_4bb1_d973_4e94bcad69f8["index.ts"]
  619ed059_733e_d046_032d_afa289d21abc --> 70b92f4c_021d_4bb1_d973_4e94bcad69f8
  7631a40c_1417_5525_665c_08971d2df5b1["ClientManifest"]
  619ed059_733e_d046_032d_afa289d21abc --> 7631a40c_1417_5525_665c_08971d2df5b1
  70b92f4c_021d_4bb1_d973_4e94bcad69f8["index.ts"]
  70b92f4c_021d_4bb1_d973_4e94bcad69f8 --> 619ed059_733e_d046_032d_afa289d21abc
  style 619ed059_733e_d046_032d_afa289d21abc fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

/**
 * Creates a mapper that maps components used during a server-side render
 * to async chunk files in the client-side build, so that we can inline them
 * directly in the rendered HTML to avoid waterfall requests.
 */

import type { ClientManifest } from './index'

export type AsyncFileMapper = (files: Array<string>) => Array<string>

export function createMapper(clientManifest: ClientManifest): AsyncFileMapper {
  const map = createMap(clientManifest)
  // map server-side moduleIds to client-side files
  return function mapper(moduleIds: Array<string>): Array<string> {
    const res = new Set<string>()
    for (let i = 0; i < moduleIds.length; i++) {
      const mapped = map.get(moduleIds[i])
      if (mapped) {
        for (let j = 0; j < mapped.length; j++) {
          res.add(mapped[j])
        }
      }
    }
    return Array.from(res)
  }
}

function createMap(clientManifest) {
  const map = new Map()
  Object.keys(clientManifest.modules).forEach(id => {
    map.set(id, mapIdToFile(id, clientManifest))
  })
  return map
}

function mapIdToFile(id, clientManifest) {
  const files: string[] = []
  const fileIndices = clientManifest.modules[id]
  if (fileIndices) {
    fileIndices.forEach(index => {
      const file = clientManifest.all[index]
      // only include async files or non-js, non-css assets
      if (
        file &&
        (clientManifest.async.indexOf(file) > -1 ||
          !/\.(js|css)($|\?)/.test(file))
      ) {
        files.push(file)
      }
    })
  }
  return files
}

Subdomains

Dependencies

Frequently Asked Questions

What does create-async-file-mapper.ts do?
create-async-file-mapper.ts is a source file in the vue codebase, written in typescript. It belongs to the ServerRenderer domain, TemplateRenderer subdomain.
What functions are defined in create-async-file-mapper.ts?
create-async-file-mapper.ts defines 4 function(s): createMap, createMapper, files, mapIdToFile.
What does create-async-file-mapper.ts depend on?
create-async-file-mapper.ts imports 2 module(s): ClientManifest, index.ts.
What files import create-async-file-mapper.ts?
create-async-file-mapper.ts is imported by 1 file(s): index.ts.
Where is create-async-file-mapper.ts in the architecture?
create-async-file-mapper.ts is located at packages/server-renderer/src/template-renderer/create-async-file-mapper.ts (domain: ServerRenderer, subdomain: TemplateRenderer, directory: packages/server-renderer/src/template-renderer).

Analyze Your Own Codebase

Get architecture documentation, dependency graphs, and domain analysis for your codebase in minutes.

Try Supermodel Free