Phantom Vendor Builder¶
What Does This Tool Do?¶
Phantom Vendor Builder is a tool that automatically manages JavaScript and CSS dependencies for Phantom Documentation Kit. It allows you to manage third-party libraries like Chart.js and Font Awesome from a single location.
Why Is It Necessary?
Instead of manually downloading each library and copying it to the correct directory, this tool automates the entire process.
You just run the serve.py or build.py command, and Vendor Builder takes care of the rest.
Workflow¶
Vendor Builder works completely automatically. When you run python serve.py, here's what happens behind the scenes:
Detailed Flow Diagram¶
graph TB
    Start([python serve.py]) --> CheckConfig{Is vendor check<br/>enabled?}
    CheckConfig -->|No| MkDocs[Start MkDocs]
    CheckConfig -->|Yes| CheckVendor[VendorManager.check_dependencies]
    CheckVendor --> VendorExists{Does vendor/ directory<br/>and all files exist?}
    VendorExists -->|Yes| MkDocs
    VendorExists -->|No| CheckNode{Is Node.js<br/>installed?}
    CheckNode -->|No| Error1[Error: Node.js required]
    CheckNode -->|Yes| BuildProcess[VendorManager.build_dependencies]
    BuildProcess --> NPMCheck{Does node_modules<br/>exist?}
    NPMCheck -->|No| NPMInstall[npm install]
    NPMCheck -->|Yes| RunBuild
    NPMInstall --> RunBuild[npm run build]
    RunBuild --> BuildJS[build.js runs]
    BuildJS --> ReadDeps[Read dependencies.json]
    ReadDeps --> ProcessLoop[Process user dependencies]
    ProcessLoop --> MinifyCheck{Is minify<br/>needed?}
    MinifyCheck -->|Yes & JS| TerserOpt[Optimize with Terser<br/>Save as .min.js]
    MinifyCheck -->|Yes & CSS| CSSNanoOpt[Optimize with cssnano<br/>Save as .min.css]
    MinifyCheck -->|No| DirectCopy[Direct copy]
    TerserOpt --> SaveVendor[Save to vendor/ directory]
    CSSNanoOpt --> SaveVendor
    DirectCopy --> SaveVendor
    SaveVendor --> NextDep{Any more<br/>dependencies?}
    NextDep -->|Yes| ProcessLoop
    NextDep -->|No| ProcessFA[processFontAwesome<br/>CSS and Webfonts]
    ProcessFA --> Success[Build complete]
    Success --> MkDocs
    style Start fill:#2196F3,color:#fff
    style Success fill:#4CAF50,color:#fff
    style Error1 fill:#f44336,color:#fff
    style TerserOpt fill:#FF9800,color:#fff
    style CSSNanoOpt fill:#FF9800,color:#fff
    style ProcessFA fill:#9C27B0,color:#fff
    style MkDocs fill:#4CAF50,color:#fffConfiguration¶
dependencies.json File¶
All your dependencies are defined in tools/vendor-builder/dependencies.json:
{
  "dependencies": [
    {
      "name": "Chart.js",
      "package": "chart.js",
      "from": "node_modules/chart.js/dist/chart.umd.js",
      "to": "chart.umd.js",
      "type": "js",
      "minify": true
    }
  ]
}
Parameter Descriptions¶
| Parameter | Description | Example Value | 
|---|---|---|
| name | Readable name of the library | "Chart.js" | 
| package | npm package name | "chart.js" | 
| from | Source file path (inside node_modules) | "node_modules/chart.js/..." | 
| to | Target filename (in vendor directory) | "chart.umd.js" | 
| type | File type | "js" or "css" | 
| minify | Apply minification? | true or false | 
Directory Structure¶
Vendor Builder Tool Directory Structure¶
Example Output Directory Structure¶
overrides/assets/vendor/        
├── chart.umd.js               
├── fontawesome-all.min.css    
└── webfonts/                  
    ├── fa-brands-400.ttf
    ├── fa-regular-400.ttf
    └── fa-solid-900.ttf
Optimization Customization¶
Current Optimization Settings¶
Vendor Builder provides a powerful optimization infrastructure using Terser (JavaScript) and cssnano (CSS). These tools are industry standards and produce high-performance outputs.
Default JavaScript Optimization (Terser):
- Debugger statements are removed
- Console.log is preserved (for development)
- Safari 10+ compatibility is ensured
- All comments are cleaned
Default CSS Optimization (cssnano):
- Unnecessary spaces are removed
- Color values are optimized (#ffffff → #fff)
- Font definitions are merged
- Gradients are simplified
How to Customize?¶
To change optimization settings, edit the relevant functions in the build.js file:
For JavaScript (lines 370-384):
async function minifyJavaScript(content, filename) {
  const result = await minify(content, {
    compress: {
      drop_console: false, 
      drop_debugger: true,
      pure_funcs: ['console.log']
    },
    mangle: {
      safari10: true
    },
    format: {
      comments: false
    }
  });
}
For CSS (lines 398-410):
async function minifyCSS(content, filename) {
  const result = await postcss([cssnano({
    preset: ['default', {
      discardComments: { removeAll: true },
      normalizeWhitespace: true,
      colormin: true,
      minifyFontValues: true,
      minifyGradients: true
    }]
  })]).process(content, { from: filename });
}
Optimization Control¶
Optimization for each dependency is controlled from the dependencies.json file:
- minify: true→ File is optimized
- minify: false→ File is copied as-is
Tip: Use minify: false for already minified files (.min.js, .min.css) to avoid unnecessary processing.