mirror of
https://github.com/daniviga/django-ram.git
synced 2025-08-09 15:47:50 +02:00
Compare commits
3 Commits
Author | SHA1 | Date | |
---|---|---|---|
32b5522a1e | |||
89b666dab2 | |||
ffad964373
|
@@ -21,7 +21,7 @@ it has been developed with a commitment of few minutes a day;
|
|||||||
it lacks any kind of documentation, code review, architectural review,
|
it lacks any kind of documentation, code review, architectural review,
|
||||||
security assesment, pentest, ISO certification, etc.
|
security assesment, pentest, ISO certification, etc.
|
||||||
|
|
||||||
This project probably doesn't match you needs nor expectations. Be aware.
|
This project probably doesn't match your needs nor expectations. Be aware.
|
||||||
|
|
||||||
Your model train may also catch fire while using this software.
|
Your model train may also catch fire while using this software.
|
||||||
|
|
||||||
|
17
ram/consist/migrations/0008_alter_consist_options.py
Normal file
17
ram/consist/migrations/0008_alter_consist_options.py
Normal file
@@ -0,0 +1,17 @@
|
|||||||
|
# Generated by Django 4.1.3 on 2023-01-02 15:03
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
("consist", "0007_alter_consist_image"),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterModelOptions(
|
||||||
|
name="consist",
|
||||||
|
options={"ordering": ["company", "-creation_time"]},
|
||||||
|
),
|
||||||
|
]
|
@@ -32,7 +32,7 @@ class Consist(models.Model):
|
|||||||
return reverse("consist", kwargs={"uuid": self.uuid})
|
return reverse("consist", kwargs={"uuid": self.uuid})
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ["creation_time"]
|
ordering = ["company", "-creation_time"]
|
||||||
|
|
||||||
|
|
||||||
class ConsistItem(models.Model):
|
class ConsistItem(models.Model):
|
||||||
|
@@ -3,7 +3,34 @@ from solo.admin import SingletonModelAdmin
|
|||||||
|
|
||||||
from portal.models import SiteConfiguration, Flatpage
|
from portal.models import SiteConfiguration, Flatpage
|
||||||
|
|
||||||
admin.site.register(SiteConfiguration, SingletonModelAdmin)
|
@admin.register(SiteConfiguration)
|
||||||
|
class SiteConfigurationAdmin(SingletonModelAdmin):
|
||||||
|
fieldsets = (
|
||||||
|
(
|
||||||
|
None,
|
||||||
|
{
|
||||||
|
"fields": (
|
||||||
|
"site_name",
|
||||||
|
"site_author",
|
||||||
|
"about",
|
||||||
|
"items_per_page",
|
||||||
|
"items_ordering",
|
||||||
|
"footer",
|
||||||
|
"footer_extended",
|
||||||
|
)
|
||||||
|
},
|
||||||
|
),
|
||||||
|
(
|
||||||
|
"Advanced",
|
||||||
|
{
|
||||||
|
"classes": ("collapse",),
|
||||||
|
"fields": (
|
||||||
|
"show_version",
|
||||||
|
"extra_head",
|
||||||
|
),
|
||||||
|
},
|
||||||
|
),
|
||||||
|
)
|
||||||
|
|
||||||
|
|
||||||
@admin.register(Flatpage)
|
@admin.register(Flatpage)
|
||||||
|
18
ram/portal/migrations/0014_siteconfiguration_extra_head.py
Normal file
18
ram/portal/migrations/0014_siteconfiguration_extra_head.py
Normal file
@@ -0,0 +1,18 @@
|
|||||||
|
# Generated by Django 4.1.3 on 2022-12-28 22:43
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
("portal", "0013_remove_flatpage_draft_flatpage_published"),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AddField(
|
||||||
|
model_name="siteconfiguration",
|
||||||
|
name="extra_head",
|
||||||
|
field=models.TextField(blank=True),
|
||||||
|
),
|
||||||
|
]
|
@@ -35,6 +35,7 @@ class SiteConfiguration(SingletonModel):
|
|||||||
footer = RichTextField(blank=True)
|
footer = RichTextField(blank=True)
|
||||||
footer_extended = RichTextField(blank=True)
|
footer_extended = RichTextField(blank=True)
|
||||||
show_version = models.BooleanField(default=True)
|
show_version = models.BooleanField(default=True)
|
||||||
|
extra_head = models.TextField(blank=True)
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
verbose_name = "Site Configuration"
|
verbose_name = "Site Configuration"
|
||||||
|
@@ -34,6 +34,10 @@
|
|||||||
html.dark .d-light-inline { display: none !important; }
|
html.dark .d-light-inline { display: none !important; }
|
||||||
html.dark .d-dark-inline { display: inline !important; }
|
html.dark .d-dark-inline { display: inline !important; }
|
||||||
</style>
|
</style>
|
||||||
|
{% block extra_head %}
|
||||||
|
{{ site_conf.extra_head | safe }}
|
||||||
|
{% endblock %}
|
||||||
|
|
||||||
</head>
|
</head>
|
||||||
<body>
|
<body>
|
||||||
<header>
|
<header>
|
||||||
@@ -96,7 +100,7 @@
|
|||||||
<div class="col">
|
<div class="col">
|
||||||
<div class="card shadow-sm">
|
<div class="card shadow-sm">
|
||||||
{% for i in r.image.all %}
|
{% for i in r.image.all %}
|
||||||
{% if i.is_thumbnail %}<a href="{{r.get_absolute_url}}"><img src="{{ i.image.url }}" alt="Card image cap"></a>{% endif %}
|
{% if forloop.first %}<a href="{{r.get_absolute_url}}"><img src="{{ i.image.url }}" alt="Card image cap"></a>{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<p class="card-text" style="position: relative;">
|
<p class="card-text" style="position: relative;">
|
||||||
|
@@ -15,7 +15,7 @@
|
|||||||
<div class="col">
|
<div class="col">
|
||||||
<div class="card shadow-sm">
|
<div class="card shadow-sm">
|
||||||
{% for i in r.rolling_stock.image.all %}
|
{% for i in r.rolling_stock.image.all %}
|
||||||
{% if i.is_thumbnail %}<a href="{{r.rolling_stock.get_absolute_url}}"><img src="{{ i.image.url }}" alt="Card image cap"></a>{% endif %}
|
{% if forloop.first %}<a href="{{r.rolling_stock.get_absolute_url}}"><img src="{{ i.image.url }}" alt="Card image cap"></a>{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
<div class="card-body">
|
<div class="card-body">
|
||||||
<p class="card-text" style="position: relative;">
|
<p class="card-text" style="position: relative;">
|
||||||
|
@@ -10,7 +10,7 @@
|
|||||||
{% else %}
|
{% else %}
|
||||||
{% with c.consist_item.first.rolling_stock as r %}
|
{% with c.consist_item.first.rolling_stock as r %}
|
||||||
{% for i in r.image.all %}
|
{% for i in r.image.all %}
|
||||||
{% if i.is_thumbnail %}<img src="{{ i.image.url }}" alt="Card image cap">{% endif %}
|
{% if forloop.first %}<img src="{{ i.image.url }}" alt="Card image cap">{% endif %}
|
||||||
{% endfor %}
|
{% endfor %}
|
||||||
{% endwith %}
|
{% endwith %}
|
||||||
{% endif %}
|
{% endif %}
|
||||||
|
@@ -1,4 +1,4 @@
|
|||||||
from ram.utils import git_suffix
|
from ram.utils import git_suffix
|
||||||
|
|
||||||
__version__ = "0.0.22"
|
__version__ = "0.0.24"
|
||||||
__version__ += git_suffix(__file__)
|
__version__ += git_suffix(__file__)
|
||||||
|
@@ -1,4 +1,6 @@
|
|||||||
from django.contrib import admin
|
from django.contrib import admin
|
||||||
|
from adminsortable2.admin import SortableAdminBase, SortableInlineAdminMixin
|
||||||
|
|
||||||
from roster.models import (
|
from roster.models import (
|
||||||
RollingClass,
|
RollingClass,
|
||||||
RollingClassProperty,
|
RollingClassProperty,
|
||||||
@@ -35,7 +37,7 @@ class RollingStockDocInline(admin.TabularInline):
|
|||||||
classes = ["collapse"]
|
classes = ["collapse"]
|
||||||
|
|
||||||
|
|
||||||
class RollingStockImageInline(admin.TabularInline):
|
class RollingStockImageInline(SortableInlineAdminMixin, admin.TabularInline):
|
||||||
model = RollingStockImage
|
model = RollingStockImage
|
||||||
min_num = 0
|
min_num = 0
|
||||||
extra = 0
|
extra = 0
|
||||||
@@ -93,7 +95,7 @@ class RollingJournalDocumentAdmin(admin.ModelAdmin):
|
|||||||
|
|
||||||
|
|
||||||
@admin.register(RollingStock)
|
@admin.register(RollingStock)
|
||||||
class RollingStockAdmin(admin.ModelAdmin):
|
class RollingStockAdmin(SortableAdminBase, admin.ModelAdmin):
|
||||||
inlines = (
|
inlines = (
|
||||||
RollingStockPropertyInline,
|
RollingStockPropertyInline,
|
||||||
RollingStockImageInline,
|
RollingStockImageInline,
|
||||||
|
@@ -0,0 +1,22 @@
|
|||||||
|
# Generated by Django 4.1.3 on 2023-01-02 12:34
|
||||||
|
|
||||||
|
from django.db import migrations, models
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
("roster", "0015_alter_rollingstockimage_options"),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.AlterModelOptions(
|
||||||
|
name="rollingstockimage",
|
||||||
|
options={"ordering": ["order"]},
|
||||||
|
),
|
||||||
|
migrations.AddField(
|
||||||
|
model_name="rollingstockimage",
|
||||||
|
name="order",
|
||||||
|
field=models.PositiveIntegerField(default=0),
|
||||||
|
),
|
||||||
|
]
|
@@ -0,0 +1,17 @@
|
|||||||
|
# Generated by Django 4.1.3 on 2023-01-02 15:02
|
||||||
|
|
||||||
|
from django.db import migrations
|
||||||
|
|
||||||
|
|
||||||
|
class Migration(migrations.Migration):
|
||||||
|
|
||||||
|
dependencies = [
|
||||||
|
("roster", "0016_alter_rollingstockimage_options_and_more"),
|
||||||
|
]
|
||||||
|
|
||||||
|
operations = [
|
||||||
|
migrations.RemoveField(
|
||||||
|
model_name="rollingstockimage",
|
||||||
|
name="is_thumbnail",
|
||||||
|
),
|
||||||
|
]
|
@@ -155,13 +155,13 @@ class RollingStockDocument(models.Model):
|
|||||||
|
|
||||||
|
|
||||||
class RollingStockImage(models.Model):
|
class RollingStockImage(models.Model):
|
||||||
|
order = models.PositiveIntegerField(default=0, blank=False, null=False)
|
||||||
rolling_stock = models.ForeignKey(
|
rolling_stock = models.ForeignKey(
|
||||||
RollingStock, on_delete=models.CASCADE, related_name="image"
|
RollingStock, on_delete=models.CASCADE, related_name="image"
|
||||||
)
|
)
|
||||||
image = models.ImageField(
|
image = models.ImageField(
|
||||||
upload_to="images/", storage=DeduplicatedStorage, null=True, blank=True
|
upload_to="images/", storage=DeduplicatedStorage, null=True, blank=True
|
||||||
)
|
)
|
||||||
is_thumbnail = models.BooleanField()
|
|
||||||
|
|
||||||
def image_thumbnail(self):
|
def image_thumbnail(self):
|
||||||
return get_image_preview(self.image.url)
|
return get_image_preview(self.image.url)
|
||||||
@@ -171,15 +171,8 @@ class RollingStockImage(models.Model):
|
|||||||
def __str__(self):
|
def __str__(self):
|
||||||
return "{0}".format(os.path.basename(self.image.name))
|
return "{0}".format(os.path.basename(self.image.name))
|
||||||
|
|
||||||
def save(self, **kwargs):
|
|
||||||
if self.is_thumbnail:
|
|
||||||
RollingStockImage.objects.filter(
|
|
||||||
rolling_stock=self.rolling_stock
|
|
||||||
).update(is_thumbnail=False)
|
|
||||||
super().save(**kwargs)
|
|
||||||
|
|
||||||
class Meta:
|
class Meta:
|
||||||
ordering = ["-is_thumbnail"]
|
ordering = ["order"]
|
||||||
|
|
||||||
|
|
||||||
class RollingStockProperty(models.Model):
|
class RollingStockProperty(models.Model):
|
||||||
|
Reference in New Issue
Block a user