Django_Basic_Manufacturing/templates/manufacture/bom_detail.html
2025-08-19 19:06:26 +07:00

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 %}