Skip to main content

Wireviz plugin for InvenTree

Project description

License: MIT PyPI PEP

inventree-wireviz

The inventree-wireviz plugin provides direct integration for wireviz, a text-based wiring harness specification tool.

Functionality

The plugin provides a number of key functions:

Harness Diagram Generation

This plugin provides server-side generation of a wiring harness diagram from a .wireviz file. Uploading a simple harness file results in the generation of a wiring diagram:

Note Refer to the wireviz syntax guide for a full description of the file format.

The generated harness diagram is available as a .svg file.

BOM Extraction

Bill of Materials (BOM) information can be extracted directly from the harness description file, allowing for a harness assembly to be fully qualified from the template file.

Report Generation

The generated .svg can be used in report templates, for example as a reference diagram in a Build Order Report

Installation

Installation Requirements

You must have graphviz installed, and accessible by the InvenTree server.

e.g. apt install graphviz

If installing in a container environment (e.g. Docker), the dockerfile will need to be extended to install the graphviz binaries

Plugin Installation

The plugin is available via PIP. Follow the InvenTree plugin installation guide to install the plugin on your system

Configuration

Once the plugin is installed, it needs to be enabled before it is available for use. Again, refer to the InvenTree docs for instructions on how to enable the plugin. After the plugin is enabled, the following configuration options are available:

Setting Description
Wireviz Upload Path Directory where wireviz template files can be uploaded, and referenced by wireviz. This is an advanced option. Refer to the wireviz docs for more information on templates.
Delete Old Files Remove old harness diagram files when a new .wireviz file is uploaded
Extract BOM Data Extract BOM data from harness file and generate new BOM entries
Clear BOM Data Remove existing BOM entries first, before creating new ones
Add Part Image Where available, embed part images in the generated harness diagram

Additionally, you must ensure that the following plugin features are enabled on the InvenTree server:

  • Enable interface integration
  • Enable URL integration

Operation

Uploading Wireviz File

To generate a wiring harness diagram for a specific Part, upload a (valid) wireviz yaml file. The file *must have the .wireviz extension to be recognized by the plugin.

When the file is uploaded to the server, the plugin is notified and begins the process of generating the harness diagram. If successful, a .svg file is attached to the part instance:

Harness Diagram Panel

When a Part has a valid harness diagram (i.e. generated without any critical errors), the Harness Diagram panel will be available for that part. This panel displays the diagram image, and a simple Bill of Materials (as defined in the uploaded .wireviz file):

Note You may need to reload the page before this panel is visible

Warning Any warnings or errors which were raised during the process will be displayed here

BOM Extraction

If enabled, the plugin will attempt to generate a linked Bill of Materials based on the data provided in the file. Part linking is performed based on the pn (part number) attribute in the wireviz BOM.

For each line item in the uploaded BOM, the plugin attempts to match the pn field to an existing part in the InvenTree database. If a matching part is not found, this is marked with a warning in the simplified BOM table in the harness diagram panel.

Reports

The generated diagram can be used in certain reports (such as the Build Order Report). If a wiring harness diagram is available for a Part, it is included in the report context as a variable named wireviz_svg_file.

Note The provided variable refers to the filename of the .svg image - not the file itself. Use the {% encode_svg_image %} template tag to render the image file.

A very simple example is shown below:

{% extends "report/inventree_build_order_base.html" %}

{% load report %}

{% block style %}
{{ block.super }}

.harness {
    border: 1px solid #AAA; 
    width: 100%;
    display: inline-block;
}

{% endblock %}

{% block page_content %}

{{ block.super }}

{% if wireviz_svg_file %}

    <h4>Harness Drawing</h4>
    <img class='harness' src='{% encode_svg_image wireviz_svg_file %}'>
{% endif %}

{% endblock page_content %}

The resulting report is rendered as below:

Wireviz Documentation

Documentation on the capabilities of wireviz itself:

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

inventree_wireviz_plugin-1.1.1.tar.gz (29.4 kB view details)

Uploaded Source

Built Distribution

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

inventree_wireviz_plugin-1.1.1-py3-none-any.whl (29.7 kB view details)

Uploaded Python 3

File details

Details for the file inventree_wireviz_plugin-1.1.1.tar.gz.

File metadata

  • Download URL: inventree_wireviz_plugin-1.1.1.tar.gz
  • Upload date:
  • Size: 29.4 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.11.13

File hashes

Hashes for inventree_wireviz_plugin-1.1.1.tar.gz
Algorithm Hash digest
SHA256 9315e221241b7edc3ce4718a661d21952e87bd73c45e260d8f7329b734577103
MD5 bbae8b1fb57254512ce67daa97262fb9
BLAKE2b-256 94679c2a39429312fdafd7ccfde320723e53b665db304acfad417ad45fdf5ddc

See more details on using hashes here.

File details

Details for the file inventree_wireviz_plugin-1.1.1-py3-none-any.whl.

File metadata

File hashes

Hashes for inventree_wireviz_plugin-1.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 5c7bfdc451b719882384168f8e007231d20157a8b01fa95b030c810a4fbacde1
MD5 4f6cb3135e20e67df72ade2846d2ff82
BLAKE2b-256 1c0fcac9cd1dc043028ee3695504dabd32cfc1c5804889bb9b2ce75343eddb19

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