mirror of
https://github.com/nottinghamtec/PyRIGS.git
synced 2026-01-17 05:22:16 +00:00
Added dependency django-polymorphic
Model change to take advantage of said polymorphism Implemented asset search
This commit is contained in:
98
assets/migrations/0008_auto_20191002_1931.py
Normal file
98
assets/migrations/0008_auto_20191002_1931.py
Normal file
@@ -0,0 +1,98 @@
|
||||
# Generated by Django 2.0.13 on 2019-10-02 18:31
|
||||
|
||||
from django.db import migrations, models
|
||||
import django.db.models.deletion
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('contenttypes', '0002_remove_content_type_name'),
|
||||
('assets', '0007_auto_20190108_0202'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AlterModelOptions(
|
||||
name='asset',
|
||||
options={'base_manager_name': 'objects'},
|
||||
),
|
||||
migrations.AlterModelOptions(
|
||||
name='cable',
|
||||
options={'base_manager_name': 'objects'},
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='asset',
|
||||
name='length',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='asset_id',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='category',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='comments',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='date_acquired',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='date_sold',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='description',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='id',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='is_cable',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='next_sched_maint',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='parent',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='purchase_price',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='purchased_from',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='salvage_value',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='serial_number',
|
||||
),
|
||||
migrations.RemoveField(
|
||||
model_name='cable',
|
||||
name='status',
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='asset',
|
||||
name='polymorphic_ctype',
|
||||
field=models.ForeignKey(editable=False, null=True, on_delete=django.db.models.deletion.CASCADE, related_name='polymorphic_assets.asset_set+', to='contenttypes.ContentType'),
|
||||
),
|
||||
migrations.AddField(
|
||||
model_name='cable',
|
||||
name='asset_ptr',
|
||||
field=models.OneToOneField(auto_created=True, default=0, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='assets.Asset'),
|
||||
preserve_default=False,
|
||||
),
|
||||
]
|
||||
@@ -1,5 +1,6 @@
|
||||
from django.db import models
|
||||
from django.urls import reverse
|
||||
from polymorphic.models import PolymorphicModel
|
||||
|
||||
import datetime
|
||||
|
||||
@@ -36,9 +37,7 @@ class Supplier(models.Model):
|
||||
return self.name
|
||||
|
||||
|
||||
class BaseAsset(models.Model):
|
||||
class Meta:
|
||||
abstract = True
|
||||
class Asset(PolymorphicModel):
|
||||
|
||||
parent = models.ForeignKey(to='self', related_name='asset_parent', blank=True, null=True, on_delete=models.SET_NULL)
|
||||
asset_id = models.CharField(max_length=10)
|
||||
@@ -56,7 +55,6 @@ class BaseAsset(models.Model):
|
||||
|
||||
# Cable assets
|
||||
is_cable = models.BooleanField(default=False)
|
||||
length = models.DecimalField(decimal_places=1, max_digits=10, blank=True, null=True)
|
||||
|
||||
def get_absolute_url(self):
|
||||
return reverse('asset_detail', kwargs={'pk': self.pk})
|
||||
@@ -64,11 +62,6 @@ class BaseAsset(models.Model):
|
||||
def __str__(self):
|
||||
return str(self.asset_id) + ' - ' + self.description
|
||||
|
||||
|
||||
class Asset(BaseAsset):
|
||||
pass
|
||||
|
||||
|
||||
class Connector(models.Model):
|
||||
description = models.CharField(max_length=80)
|
||||
current_rating = models.DecimalField(decimal_places=2, max_digits=10, help_text='Amps')
|
||||
@@ -79,7 +72,7 @@ class Connector(models.Model):
|
||||
return self.description
|
||||
|
||||
|
||||
class Cable(BaseAsset):
|
||||
class Cable(Asset):
|
||||
plug = models.ForeignKey(Connector, on_delete=models.SET_NULL, related_name='plug', null=True)
|
||||
socket = models.ForeignKey(Connector, on_delete=models.SET_NULL, related_name='socket', null=True)
|
||||
length = models.DecimalField(decimal_places=1, max_digits=10, blank=True, null=True, help_text='m')
|
||||
|
||||
@@ -1,20 +1,4 @@
|
||||
function filterAssetTable() {
|
||||
$.ajax({
|
||||
url : "/asset/filter/", // the endpoint
|
||||
type : "POST", // http method
|
||||
data : {
|
||||
form: $('#asset-filter-form').serialize()
|
||||
},
|
||||
traditional: true,
|
||||
|
||||
success : function(data) {
|
||||
// console.log(data);
|
||||
$('#asset_table_body').html(data)
|
||||
},
|
||||
|
||||
error : function(xhr) {console.log(xhr.status + ": " + xhr.responseText)}
|
||||
});
|
||||
}
|
||||
|
||||
|
||||
|
||||
|
||||
@@ -8,10 +8,10 @@
|
||||
<h1 class="text-center">Asset List</h1>
|
||||
</div>
|
||||
|
||||
<form method="post" id="asset-filter-form">
|
||||
<form id="asset-filter-form" onsubmit=>
|
||||
{% csrf_token %}
|
||||
<div class="input-group">
|
||||
<input type="text" name="asset_id" placeholder="Asset ID" class="form-control">
|
||||
<input type="q" name="q" placeholder="Search" class="form-control" value="{{searchName}}">
|
||||
<label for="asset_id" class="sr-only">Asset ID</label>
|
||||
<span class="input-group-btn"><button type="submit" class="btn">Search</button></span>
|
||||
</div>
|
||||
@@ -40,12 +40,5 @@
|
||||
|
||||
{% endblock %}
|
||||
|
||||
{% block script %}
|
||||
<script>
|
||||
$('#asset-filter-form').on('submit', function (event) {
|
||||
event.preventDefault();
|
||||
filterAssetTable();
|
||||
return false;
|
||||
});
|
||||
</script>
|
||||
{% block js %}
|
||||
{% endblock %}
|
||||
|
||||
@@ -13,7 +13,6 @@ urlpatterns = [
|
||||
path('asset/create/', views.AssetEdit.as_view(), name='asset_create'),
|
||||
path('asset/<int:pk>/edit/', views.AssetEdit.as_view(), name='asset_update'),
|
||||
path('asset/delete/', views.asset_delete, name='ajax_asset_delete'),
|
||||
path('asset/filter/', views.asset_filter, name='ajax_asset_filter'),
|
||||
path('asset/update/', views.asset_update, name='ajax_asset_update'),
|
||||
|
||||
path('supplier/list', views.SupplierList.as_view(), name='supplier_list'),
|
||||
|
||||
@@ -13,27 +13,24 @@ from dateutil import parser
|
||||
import simplejson as json
|
||||
from assets import models, forms
|
||||
|
||||
|
||||
class Login(auth_views.LoginView):
|
||||
template_name = 'registration/login.html'
|
||||
|
||||
|
||||
class Logout(auth_views.LogoutView):
|
||||
template_name = 'registration/logout.html'
|
||||
|
||||
|
||||
class PasswordChange(auth_views.PasswordChangeView):
|
||||
template_name = 'registration/password_change.html'
|
||||
|
||||
def get_success_url(self):
|
||||
return reverse_lazy('profile_detail', kwargs={'pk': self.request.user.id})
|
||||
|
||||
class AssetList(LoginRequiredMixin, generic.ListView):
|
||||
model = models.Asset
|
||||
template_name = 'asset_list.html'
|
||||
paginate_by = 40
|
||||
ordering = ['-pk']
|
||||
|
||||
|
||||
def get_queryset(self):
|
||||
q = self.request.GET.get('q', "")
|
||||
if len(q) >= 3:
|
||||
return self.model.objects.filter(Q(asset_id__icontains=q) | Q(description__icontains=q) | Q(comments__icontains=q))
|
||||
else:
|
||||
return self.model.objects.all()
|
||||
|
||||
def get_context_data(self, **kwargs):
|
||||
q = self.request.GET.get('q', "")
|
||||
context = super(AssetList, self).get_context_data(**kwargs)
|
||||
context["searchName"] = q
|
||||
return context;
|
||||
|
||||
class AssetDetail(LoginRequiredMixin, generic.DetailView):
|
||||
model = models.Asset
|
||||
@@ -45,7 +42,6 @@ class AssetDetail(LoginRequiredMixin, generic.DetailView):
|
||||
# template_name = 'asset_update.html'
|
||||
# # success_url = reverse_lazy('asset_list')
|
||||
|
||||
|
||||
class AssetEdit(LoginRequiredMixin, generic.TemplateView):
|
||||
template_name = 'asset_update.html'
|
||||
|
||||
@@ -68,7 +64,6 @@ class AssetEdit(LoginRequiredMixin, generic.TemplateView):
|
||||
|
||||
return context
|
||||
|
||||
|
||||
@login_required()
|
||||
def asset_update(request):
|
||||
context = dict()
|
||||
@@ -117,26 +112,6 @@ def asset_delete(request):
|
||||
|
||||
return HttpResponse(json.dumps(context), content_type='application/json')
|
||||
|
||||
|
||||
@login_required()
|
||||
def asset_filter(request):
|
||||
context = dict()
|
||||
|
||||
if request.method == 'POST' and request.is_ajax():
|
||||
defaults = QueryDict(request.POST['form'].encode('ASCII')).dict()
|
||||
defaults.pop('csrfmiddlewaretoken')
|
||||
|
||||
context['object_list'] = models.Asset.objects.filter(
|
||||
Q(pk__icontains=defaults.get('asset_id')) |
|
||||
Q(asset_id__icontains=defaults.get('asset_id'))
|
||||
)
|
||||
|
||||
if request.POST.get('sender', None) == 'asset_update':
|
||||
return render(request, template_name='asset_update_search_results.html', context=context)
|
||||
else:
|
||||
return render(request, template_name='asset_list_table_body.html', context=context)
|
||||
|
||||
|
||||
class SupplierList(generic.ListView):
|
||||
model = models.Supplier
|
||||
template_name = 'supplier_list.html'
|
||||
|
||||
@@ -12,6 +12,7 @@ django-recaptcha==1.4.0
|
||||
django-registration-redux==2.4
|
||||
django-reversion==2.0.13
|
||||
django-toolbelt==0.0.1
|
||||
django-polymorphic==2.1.2
|
||||
djangorestframework==3.9.0
|
||||
premailer==3.2.0
|
||||
git+git://github.com/jazzband/django-widget-tweaks.git@1.4.2
|
||||
|
||||
Reference in New Issue
Block a user