Skip to main content

Download CDN scripts and styles as vendored dependencies.

Project description

plain.vendor

Download and manage vendored CSS and JavaScript dependencies from CDNs.

Overview

You can use plain vendor to download JavaScript and CSS files from CDNs and store them locally in your project. This keeps third-party assets under version control and avoids runtime dependencies on external CDNs.

Dependencies are configured in your pyproject.toml and downloaded to app/assets/vendor/.

# pyproject.toml
[tool.plain.vendor.dependencies]
htmx = {url = "https://unpkg.com/htmx.org@{version}/dist/htmx.min.js", installed = "2.0.4"}
alpine = {url = "https://cdn.jsdelivr.net/npm/alpinejs@{version}/dist/cdn.min.js", installed = "3.14.8"}

After configuring dependencies, run plain vendor sync to download them:

plain vendor sync

The files are saved to app/assets/vendor/ and can be included in your templates:

<script src="{{ 'vendor/htmx.min.js'|asset }}"></script>
<script src="{{ 'vendor/cdn.min.js'|asset }}"></script>

Adding dependencies

You can add a new dependency directly from the command line:

plain vendor add https://unpkg.com/htmx.org/dist/htmx.min.js

This downloads the file, extracts the version from the URL, and adds an entry to your pyproject.toml. You can also specify a custom name:

plain vendor add https://unpkg.com/htmx.org/dist/htmx.min.js --name htmx

Syncing dependencies

The sync command clears all existing vendored files and re-downloads everything from scratch:

plain vendor sync

Use this when you first clone a project or want to ensure your vendored files match your configuration.

Updating dependencies

The update command checks for newer versions and updates your pyproject.toml:

# Update all dependencies
plain vendor update

# Update specific dependencies
plain vendor update htmx alpine

The update process tries several strategies to find newer versions:

  1. Requests the "latest" tag (supported by many CDNs)
  2. Increments version numbers to probe for new releases

Configuration options

Custom filenames

If you want to rename a file when it's downloaded, use the filename option:

[tool.plain.vendor.dependencies]
htmx = {url = "https://unpkg.com/htmx.org@{version}/dist/htmx.min.js", installed = "2.0.4", filename = "htmx.js"}

Source maps

You can automatically download source maps alongside your vendored files:

[tool.plain.vendor.dependencies]
htmx = {url = "https://unpkg.com/htmx.org@{version}/dist/htmx.min.js", installed = "2.0.4", sourcemap = true}

When sourcemap = true, the tool appends .map to the filename and downloads from the same directory. For non-standard source map filenames, provide the filename directly:

[tool.plain.vendor.dependencies]
example = {url = "https://example.com/lib.min.js", installed = "1.0.0", sourcemap = "lib.min.js.map"}

You can also use the --sourcemap flag when adding dependencies:

plain vendor add https://unpkg.com/htmx.org/dist/htmx.min.js --sourcemap

Version placeholders

URLs can include a {version} placeholder that gets replaced with the installed version number:

htmx = {url = "https://unpkg.com/htmx.org@{version}/dist/htmx.min.js", installed = "2.0.4"}

When you run plain vendor sync, the placeholder is replaced with 2.0.4. This makes it easy to see which version is installed and enables the update command to try newer versions.

FAQs

What file types are supported?

The vendor tool accepts JavaScript (application/javascript, text/javascript), CSS (text/css), and JSON (application/json) files. Other content types will raise an error.

Where are vendored files stored?

All vendored files are downloaded to app/assets/vendor/. This directory is created automatically if it doesn't exist.

How does version detection work?

When you add a dependency or update to a new version, the tool parses version numbers from the final URL (after any redirects). It looks for patterns like 1.2.3 or 1.2 in the URL path.

What happens if a CDN is unavailable?

The sync and update commands will fail with an error if any dependency cannot be downloaded. You'll see which dependencies failed in the output.

Installation

Install the plain.vendor package from PyPI:

uv add plain.vendor

After installation, the plain vendor command becomes available. Configure your dependencies in pyproject.toml:

[tool.plain.vendor.dependencies]
htmx = {url = "https://unpkg.com/htmx.org@{version}/dist/htmx.min.js", installed = "2.0.4"}

Then run the sync command to download them:

plain vendor sync

Your vendored files will be available in app/assets/vendor/ and can be referenced in templates using the asset template filter.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

plain_vendor-0.11.1.tar.gz (7.6 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

plain_vendor-0.11.1-py3-none-any.whl (11.6 kB view details)

Uploaded Python 3

File details

Details for the file plain_vendor-0.11.1.tar.gz.

File metadata

  • Download URL: plain_vendor-0.11.1.tar.gz
  • Upload date:
  • Size: 7.6 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for plain_vendor-0.11.1.tar.gz
Algorithm Hash digest
SHA256 9860ef568a14b294edf6818e18aac5b7eabe6148a7778ec33f786916832af232
MD5 69b68516ec2c18b02cad5bdc4602c488
BLAKE2b-256 ac416e354d32f9a10eddec9d30eb68b03bd0d8ab6015c6da2ae03cac0e053d85

See more details on using hashes here.

File details

Details for the file plain_vendor-0.11.1-py3-none-any.whl.

File metadata

  • Download URL: plain_vendor-0.11.1-py3-none-any.whl
  • Upload date:
  • Size: 11.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: uv/0.10.6 {"installer":{"name":"uv","version":"0.10.6","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}

File hashes

Hashes for plain_vendor-0.11.1-py3-none-any.whl
Algorithm Hash digest
SHA256 8e6a3fb596aa8824923921b8f91b42fded6d26bcce4492968e55fa2866b16a2f
MD5 7c69e9e10f470189854c404313083736
BLAKE2b-256 9d05528195d8dfb68370b8eeba5184b837619847fc0363065213095261956a76

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page