Home / File/ client.ts — vue Source File

client.ts — vue Source File

Architecture documentation for client.ts, a typescript file in the vue codebase. 4 imports, 0 dependents.

Entity Profile

Dependency Diagram

graph LR
  061cdd3c_2a4a_f420_388b_683da0ed2615["client.ts"]
  a4aaa23d_d810_1245_8cde_5c37b4bd3875["util.ts"]
  061cdd3c_2a4a_f420_388b_683da0ed2615 --> a4aaa23d_d810_1245_8cde_5c37b4bd3875
  8c797278_c0eb_766a_663c_40edd789a258["getAssetName"]
  061cdd3c_2a4a_f420_388b_683da0ed2615 --> 8c797278_c0eb_766a_663c_40edd789a258
  67bc246a_b935_05a8_c244_11f687e4f578["onEmit"]
  061cdd3c_2a4a_f420_388b_683da0ed2615 --> 67bc246a_b935_05a8_c244_11f687e4f578
  5c64c44e_eb4f_4332_eb2e_5e6e7aa7cd19["stripModuleIdHash"]
  061cdd3c_2a4a_f420_388b_683da0ed2615 --> 5c64c44e_eb4f_4332_eb2e_5e6e7aa7cd19
  style 061cdd3c_2a4a_f420_388b_683da0ed2615 fill:#6366f1,stroke:#818cf8,color:#fff

Relationship Graph

Source Code

const hash = require('hash-sum')
const uniq = require('lodash.uniq')
import { isJS, isCSS, getAssetName, onEmit, stripModuleIdHash } from './util'

export default class VueSSRClientPlugin {
  constructor(options = {}) {
    //@ts-expect-error no type on options
    this.options = Object.assign(
      {
        filename: 'vue-ssr-client-manifest.json'
      },
      options
    )
  }

  apply(compiler) {
    const stage = 'PROCESS_ASSETS_STAGE_ADDITIONAL'
    onEmit(compiler, 'vue-client-plugin', stage, (compilation, cb) => {
      const stats = compilation.getStats().toJson()

      const allFiles = uniq(stats.assets.map(a => a.name))

      const initialFiles = uniq(
        Object.keys(stats.entrypoints)
          .map(name => stats.entrypoints[name].assets)
          .reduce((assets, all) => all.concat(assets), [])
          .map(getAssetName)
          .filter(file => isJS(file) || isCSS(file))
      )

      const asyncFiles = allFiles
        .filter(file => isJS(file) || isCSS(file))
        .filter(file => initialFiles.indexOf(file) < 0)

      const manifest = {
        publicPath: stats.publicPath,
        all: allFiles,
        initial: initialFiles,
        async: asyncFiles,
        modules: {
          /* [identifier: string]: Array<index: number> */
        }
      }

      const assetModules = stats.modules.filter(m => m.assets.length)
      const fileToIndex = asset => manifest.all.indexOf(getAssetName(asset))
      stats.modules.forEach(m => {
        // ignore modules duplicated in multiple chunks
        if (m.chunks.length === 1) {
          const cid = m.chunks[0]
          const chunk = stats.chunks.find(c => c.id === cid)
          if (!chunk || !chunk.files) {
            return
          }
          const id = stripModuleIdHash(m.identifier)
          const files = (manifest.modules[hash(id)] =
            chunk.files.map(fileToIndex))
          // find all asset modules associated with the same chunk
          assetModules.forEach(m => {
            if (m.chunks.some(id => id === cid)) {
              files.push.apply(files, m.assets.map(fileToIndex))
            }
          })
        }
      })

      const json = JSON.stringify(manifest, null, 2)
      //@ts-expect-error no type on options
      compilation.assets[this.options.filename] = {
        source: () => json,
        size: () => json.length
      }
      cb()
    })
  }
}

Subdomains

Frequently Asked Questions

What does client.ts do?
client.ts is a source file in the vue codebase, written in typescript. It belongs to the ServerRenderer domain, BundleRenderer subdomain.
What does client.ts depend on?
client.ts imports 4 module(s): getAssetName, onEmit, stripModuleIdHash, util.ts.
Where is client.ts in the architecture?
client.ts is located at packages/server-renderer/src/webpack-plugin/client.ts (domain: ServerRenderer, subdomain: BundleRenderer, directory: packages/server-renderer/src/webpack-plugin).

Analyze Your Own Codebase

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

Try Supermodel Free