Compare commits
12 Commits
feature/do
...
7befde104d
| Author | SHA1 | Date | |
|---|---|---|---|
| 7befde104d | |||
| 96819a7427 | |||
| a437af554b | |||
| 650fe0a87b | |||
|
|
ddf035c50f | ||
|
|
886baa163e | ||
|
|
1146506ca2 | ||
|
|
9610024739 | ||
|
|
c8755e4339 | ||
|
|
0bc1fe7413 | ||
|
|
8ce761c248 | ||
|
|
39a2021cc3 |
@@ -25,7 +25,7 @@ spec:
|
||||
mountPath: /data
|
||||
containers:
|
||||
- name: web
|
||||
image: git.baumann.gr/adebaumann/vui:0.933
|
||||
image: git.baumann.gr/adebaumann/vui:0.936
|
||||
imagePullPolicy: Always
|
||||
ports:
|
||||
- containerPort: 8000
|
||||
|
||||
Binary file not shown.
BIN
data/db.sqlite3
BIN
data/db.sqlite3
Binary file not shown.
@@ -61,7 +61,7 @@ class EinleitungInline(NestedTabularInline):
|
||||
classes = ['collapse']
|
||||
|
||||
class VorgabeForm(forms.ModelForm):
|
||||
# referenzen = TreeNodeMultipleChoiceField(queryset=Referenz.objects.all(), required=False)
|
||||
referenzen = TreeNodeMultipleChoiceField(queryset=Referenz.objects.all(), required=False)
|
||||
class Meta:
|
||||
model = Vorgabe
|
||||
fields = '__all__'
|
||||
|
||||
19
dokumente/migrations/0008_dokument_aktiv.py
Normal file
19
dokumente/migrations/0008_dokument_aktiv.py
Normal file
@@ -0,0 +1,19 @@
|
||||
# Generated by Django 5.2.5 on 2025-10-27 19:48
|
||||
|
||||
from django.db import migrations, models
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
dependencies = [
|
||||
('dokumente', '0007_alter_changelog_options_and_more'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.AddField(
|
||||
model_name='dokument',
|
||||
name='aktiv',
|
||||
field=models.BooleanField(blank=True, default=False),
|
||||
preserve_default=False,
|
||||
),
|
||||
]
|
||||
@@ -47,6 +47,7 @@ class Dokument(models.Model):
|
||||
gueltigkeit_bis = models.DateField(null=True, blank=True)
|
||||
signatur_cso = models.CharField(max_length=255, blank=True)
|
||||
anhaenge = models.TextField(blank=True)
|
||||
aktiv = models.BooleanField(blank=True)
|
||||
|
||||
def __str__(self):
|
||||
return f"{self.nummer} – {self.name}"
|
||||
|
||||
@@ -114,7 +114,8 @@ class DokumentModelTest(TestCase):
|
||||
name="Security Policy",
|
||||
gueltigkeit_von=date.today(),
|
||||
signatur_cso="CSO-123",
|
||||
anhaenge="Appendix A, B"
|
||||
anhaenge="Appendix A, B",
|
||||
aktiv=True
|
||||
)
|
||||
self.dokument.autoren.add(self.autor)
|
||||
self.dokument.pruefende.add(self.pruefer)
|
||||
@@ -124,6 +125,7 @@ class DokumentModelTest(TestCase):
|
||||
self.assertEqual(self.dokument.nummer, "DOC-001")
|
||||
self.assertEqual(self.dokument.name, "Security Policy")
|
||||
self.assertEqual(self.dokument.dokumententyp, self.dokumententyp)
|
||||
self.assertEqual(self.dokument.aktiv, True)
|
||||
|
||||
def test_dokument_str(self):
|
||||
"""Test string representation of Dokument"""
|
||||
@@ -139,7 +141,8 @@ class DokumentModelTest(TestCase):
|
||||
dokument = Dokument.objects.create(
|
||||
nummer="DOC-002",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="Test Document"
|
||||
name="Test Document",
|
||||
aktiv=True
|
||||
)
|
||||
self.assertIsNone(dokument.gueltigkeit_von)
|
||||
self.assertIsNone(dokument.gueltigkeit_bis)
|
||||
@@ -158,7 +161,8 @@ class VorgabeModelTest(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="R01234",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="IT Standard"
|
||||
name="IT Standard",
|
||||
aktiv=True
|
||||
)
|
||||
self.thema = Thema.objects.create(name="Security")
|
||||
self.vorgabe = Vorgabe.objects.create(
|
||||
@@ -254,7 +258,8 @@ class VorgabeTextAbschnitteTest(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="R01234",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="Test Standard"
|
||||
name="Test Standard",
|
||||
aktiv=True
|
||||
)
|
||||
self.thema = Thema.objects.create(name="Testing")
|
||||
self.vorgabe = Vorgabe.objects.create(
|
||||
@@ -302,7 +307,8 @@ class DokumentTextAbschnitteTest(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="POL-001",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="Test Policy"
|
||||
name="Test Policy",
|
||||
aktiv=True
|
||||
)
|
||||
self.abschnitttyp = AbschnittTyp.objects.create(
|
||||
abschnitttyp="Paragraph"
|
||||
@@ -342,7 +348,8 @@ class ChecklistenfrageModelTest(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="QA-001",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="QA Standard"
|
||||
name="QA Standard",
|
||||
aktiv=True
|
||||
)
|
||||
self.thema = Thema.objects.create(name="Quality")
|
||||
self.vorgabe = Vorgabe.objects.create(
|
||||
@@ -382,7 +389,8 @@ class ChangelogModelTest(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="R01234",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="IT Standard"
|
||||
name="IT Standard",
|
||||
aktiv=True
|
||||
)
|
||||
self.autor = Person.objects.create(
|
||||
name="John Doe",
|
||||
@@ -419,7 +427,8 @@ class ViewsTestCase(TestCase):
|
||||
self.dokument = Dokument.objects.create(
|
||||
nummer="R01234",
|
||||
dokumententyp=self.dokumententyp,
|
||||
name="Test Standard"
|
||||
name="Test Standard",
|
||||
aktiv=True
|
||||
)
|
||||
self.thema = Thema.objects.create(name="Testing")
|
||||
self.vorgabe = Vorgabe.objects.create(
|
||||
|
||||
@@ -28,6 +28,6 @@
|
||||
<div class="flex-fill">{% block content %}Main Content{% endblock %}</div>
|
||||
<div class="col-md-2">{% block sidebar_right %}{% endblock %}</div>
|
||||
</div>
|
||||
<div>VorgabenUI v0.931</div>
|
||||
<div>VorgabenUI v0.936</div>
|
||||
</body>
|
||||
</html>
|
||||
|
||||
@@ -13,4 +13,4 @@ class ReferenzerklaerungInline(NestedStackedInline):
|
||||
class ReferenzAdmin(NestedModelAdmin):
|
||||
inlines=[ReferenzerklaerungInline]
|
||||
list_display =['Path']
|
||||
search_fields=("referenz",)
|
||||
search_fields=("referenz","path")
|
||||
|
||||
@@ -1,14 +1,40 @@
|
||||
/* Style each Vorgabe inline block */
|
||||
.djn-dynamic-form-Standards-vorgabe {
|
||||
border: 2px solid #ccc;
|
||||
.djn-dynamic-form-Standards-vorgabe,
|
||||
.djn-dynamic-form-dokumente-vorgabe {
|
||||
border: 3px solid #2c5aa0;
|
||||
border-radius: 8px;
|
||||
padding: 15px;
|
||||
margin-bottom: 20px;
|
||||
margin-bottom: 50px;
|
||||
background-color: #f9f9f9;
|
||||
box-shadow: 0 2px 5px rgba(0,0,0,0.1);
|
||||
}
|
||||
|
||||
/* Make Vorgabe title prominent */
|
||||
.djn-dynamic-form-Standards-vorgabe > h3,
|
||||
.djn-dynamic-form-dokumente-vorgabe > h3 {
|
||||
font-size: 18px;
|
||||
font-weight: 700;
|
||||
color: #2c5aa0;
|
||||
margin: -15px -15px 15px -15px;
|
||||
padding: 12px 15px;
|
||||
background: linear-gradient(to bottom, #e8f0f8, #d4e4f3);
|
||||
border-bottom: 2px solid #2c5aa0;
|
||||
border-radius: 5px 5px 0 0;
|
||||
}
|
||||
|
||||
/* Make Vorgabe identifier in tabular view prominent */
|
||||
tbody.djn-dynamic-form-Standards-vorgabe td.original,
|
||||
tbody.djn-dynamic-form-dokumente-vorgabe td.original,
|
||||
tbody.djn-dynamic-form-Standards-vorgabe td.original p,
|
||||
tbody.djn-dynamic-form-dokumente-vorgabe td.original p {
|
||||
font-size: 16px !important;
|
||||
font-weight: 700 !important;
|
||||
color: #2c5aa0 !important;
|
||||
}
|
||||
|
||||
/* Optional: Slight padding for inner fieldsets (e.g., Langtext/Kurztext inlines) */
|
||||
.djn-dynamic-form-Standards-vorgabe .inline-related {
|
||||
.djn-dynamic-form-Standards-vorgabe .inline-related,
|
||||
.djn-dynamic-form-dokumente-vorgabe .inline-related {
|
||||
margin-top: 10px;
|
||||
padding-left: 10px;
|
||||
border-left: 2px dashed #ccc;
|
||||
|
||||
Reference in New Issue
Block a user