add projects model
This commit is contained in:
parent
3ad917d8af
commit
cf5aaddc2d
5 changed files with 100 additions and 0 deletions
0
project/projects/__init__.py
Normal file
0
project/projects/__init__.py
Normal file
39
project/projects/migrations/0001_initial.py
Normal file
39
project/projects/migrations/0001_initial.py
Normal file
|
@ -0,0 +1,39 @@
|
|||
# -*- coding: utf-8 -*-
|
||||
# Generated by Django 1.10.3 on 2016-11-25 23:10
|
||||
from __future__ import unicode_literals
|
||||
|
||||
from django.db import migrations, models
|
||||
import django.db.models.deletion
|
||||
import project.projects.models
|
||||
import wagtail.wagtailcore.fields
|
||||
|
||||
|
||||
class Migration(migrations.Migration):
|
||||
|
||||
initial = True
|
||||
|
||||
dependencies = [
|
||||
('wagtailcore', '0030_index_on_pagerevision_created_at'),
|
||||
('wagtaildocs', '0007_merge'),
|
||||
('wagtailimages', '0015_fill_filter_spec_field'),
|
||||
]
|
||||
|
||||
operations = [
|
||||
migrations.CreateModel(
|
||||
name='ProjectPage',
|
||||
fields=[
|
||||
('page_ptr', models.OneToOneField(auto_created=True, on_delete=django.db.models.deletion.CASCADE, parent_link=True, primary_key=True, serialize=False, to='wagtailcore.Page')),
|
||||
('date', models.DateField(verbose_name='Post date')),
|
||||
('intro', models.CharField(max_length=250)),
|
||||
('body', wagtail.wagtailcore.fields.RichTextField()),
|
||||
('url', models.URLField(blank=True, validators=[project.projects.models.validate_url])),
|
||||
('download_url', models.URLField(blank=True, validators=[project.projects.models.validate_url])),
|
||||
('asset', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to='wagtaildocs.Document')),
|
||||
('main_image', models.ForeignKey(blank=True, null=True, on_delete=django.db.models.deletion.SET_NULL, related_name='+', to='wagtailimages.Image')),
|
||||
],
|
||||
options={
|
||||
'abstract': False,
|
||||
},
|
||||
bases=('wagtailcore.page',),
|
||||
),
|
||||
]
|
0
project/projects/migrations/__init__.py
Normal file
0
project/projects/migrations/__init__.py
Normal file
60
project/projects/models.py
Normal file
60
project/projects/models.py
Normal file
|
@ -0,0 +1,60 @@
|
|||
from django.db import models
|
||||
from django.core.exceptions import ValidationError
|
||||
|
||||
from wagtail.wagtailcore.models import Page
|
||||
from wagtail.wagtailcore.fields import RichTextField
|
||||
from wagtail.wagtaildocs.edit_handlers import DocumentChooserPanel
|
||||
from wagtail.wagtailadmin.edit_handlers import FieldPanel
|
||||
from wagtail.wagtailimages.edit_handlers import ImageChooserPanel
|
||||
from wagtail.wagtailsearch import index
|
||||
|
||||
from project.common.models import Entity
|
||||
|
||||
|
||||
ALLOWED_DOMAINS = [
|
||||
'github'
|
||||
]
|
||||
|
||||
|
||||
def validate_url(value):
|
||||
for part in ALLOWED_DOMAINS:
|
||||
if part in value.lower():
|
||||
return True
|
||||
raise ValidationError('Invalid domain, should be in {}'.format(ALLOWED_DOMAINS))
|
||||
|
||||
|
||||
class ProjectPage(Entity):
|
||||
main_image = models.ForeignKey(
|
||||
'wagtailimages.Image',
|
||||
null=True,
|
||||
blank=True,
|
||||
on_delete=models.SET_NULL,
|
||||
related_name='+'
|
||||
)
|
||||
date = models.DateField("Post date")
|
||||
intro = models.CharField(max_length=250)
|
||||
body = RichTextField()
|
||||
url = models.URLField(validators=[validate_url], blank=True)
|
||||
download_url = models.URLField(validators=[validate_url], blank=True)
|
||||
asset = models.ForeignKey(
|
||||
'wagtaildocs.Document',
|
||||
null=True,
|
||||
blank=True,
|
||||
on_delete=models.SET_NULL,
|
||||
related_name='+'
|
||||
)
|
||||
|
||||
search_fields = Page.search_fields + [
|
||||
index.SearchField('intro'),
|
||||
index.SearchField('body'),
|
||||
]
|
||||
|
||||
content_panels = Page.content_panels + [
|
||||
FieldPanel('date'),
|
||||
ImageChooserPanel('main_image'),
|
||||
FieldPanel('intro'),
|
||||
FieldPanel('body'),
|
||||
FieldPanel('url'),
|
||||
FieldPanel('download_url'),
|
||||
DocumentChooserPanel('asset')
|
||||
]
|
|
@ -48,6 +48,7 @@ INSTALLED_APPS = [
|
|||
'project.blog',
|
||||
'project.common',
|
||||
'project.home',
|
||||
'project.projects',
|
||||
'project.search',
|
||||
]
|
||||
|
||||
|
|
Reference in a new issue