130 lines
5.5 KiB
HTML
130 lines
5.5 KiB
HTML
{% extends 'base.html' %}
|
|
{% load manufacture_extras %}
|
|
|
|
{% block title %}BOM - {{ bom.manufactured_product.name }}{% endblock %}
|
|
|
|
{% block content %}
|
|
<div class="d-flex justify-content-between align-items-center mb-4">
|
|
<h1 class="h3 mb-0">
|
|
<i class="bi bi-list-check me-2"></i>
|
|
Bill of Materials
|
|
</h1>
|
|
<div>
|
|
<a href="{% url 'manufacture:bom_list' %}" class="btn btn-outline-secondary me-2">
|
|
<i class="bi bi-arrow-left me-2"></i>
|
|
Back to List
|
|
</a>
|
|
{% if user.is_superuser or user.is_staff %}
|
|
<a href="{% url 'manufacture:bom_edit' bom.pk %}" class="btn btn-primary">
|
|
<i class="bi bi-pencil me-2"></i>
|
|
Edit
|
|
</a>
|
|
{% endif %}
|
|
</div>
|
|
</div>
|
|
|
|
<div class="row">
|
|
<div class="col-md-8">
|
|
<div class="card mb-4">
|
|
<div class="card-header">
|
|
<h5 class="card-title mb-0">BOM Details</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<p><strong>Manufactured Product:</strong> {{ bom.manufactured_product.name }}</p>
|
|
<p><strong>Product Code:</strong> {{ bom.manufactured_product.code }}</p>
|
|
</div>
|
|
<div class="col-md-6">
|
|
<p><strong>Component:</strong> {{ bom.component.name }}</p>
|
|
<p><strong>Quantity:</strong> {{ bom.quantity|format_quantity }}</p>
|
|
<p><strong>Unit:</strong> {{ bom.unit|default:bom.component.unit }}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<!-- Show all components for this manufactured product -->
|
|
{% with bom.manufactured_product.bom_manufactured.all as all_components %}
|
|
{% if all_components.count > 1 %}
|
|
<div class="card mb-4">
|
|
<div class="card-header">
|
|
<h5 class="card-title mb-0">All Components for {{ bom.manufactured_product.name }}</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="table-responsive">
|
|
<table class="table table-hover">
|
|
<thead class="table-light">
|
|
<tr>
|
|
<th>Component</th>
|
|
<th>Quantity</th>
|
|
<th>Unit</th>
|
|
<th>Actions</th>
|
|
</tr>
|
|
</thead>
|
|
<tbody>
|
|
{% for component_bom in all_components %}
|
|
<tr>
|
|
<td>{{ component_bom.component.name }}</td>
|
|
<td>{{ component_bom.quantity|format_quantity }}</td>
|
|
<td>{{ component_bom.unit|default:component_bom.component.unit }}</td>
|
|
<td>
|
|
{% if component_bom.pk != bom.pk %}
|
|
<a href="{% url 'manufacture:bom_detail' component_bom.pk %}" class="btn btn-sm btn-outline-primary">
|
|
<i class="bi bi-eye"></i>
|
|
</a>
|
|
<a href="{% url 'manufacture:bom_edit' component_bom.pk %}" class="btn btn-sm btn-outline-warning ms-1">
|
|
<i class="bi bi-pencil"></i>
|
|
</a>
|
|
{% endif %}
|
|
</td>
|
|
</tr>
|
|
{% endfor %}
|
|
</tbody>
|
|
</table>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endif %}
|
|
{% endwith %}
|
|
|
|
<div class="card">
|
|
<div class="card-header">
|
|
<h5 class="card-title mb-0">Cost Information</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<div class="row">
|
|
<div class="col-md-6">
|
|
<p><strong>Component Cost Price:</strong> Rp {{ bom.component.cost_price|format_currency }}</p>
|
|
</div>
|
|
<div class="col-md-6">
|
|
<p><strong>Total Component Cost:</strong> Rp {{ bom.get_total_component_cost|format_currency }}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="col-md-4">
|
|
<div class="card">
|
|
<div class="card-header">
|
|
<h5 class="card-title mb-0">Product Information</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<p><strong>Component Code:</strong> {{ bom.component.code }}</p>
|
|
<p><strong>Component Category:</strong> {{ bom.component.category.name|default:"N/A" }}</p>
|
|
<p><strong>Component Current Stock:</strong> {{ bom.component.current_stock }}</p>
|
|
<p><strong>Component Unit:</strong> {{ bom.component.unit }}</p>
|
|
</div>
|
|
</div>
|
|
|
|
<div class="card mt-3">
|
|
<div class="card-header">
|
|
<h5 class="card-title mb-0">Timestamps</h5>
|
|
</div>
|
|
<div class="card-body">
|
|
<p><strong>Created:</strong> {{ bom.created_at|date:"d/m/Y H:i" }}</p>
|
|
<p><strong>Updated:</strong> {{ bom.updated_at|date:"d/m/Y H:i" }}</p>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
</div>
|
|
{% endblock %} |