add basic migration script participants -> person
This commit is contained in:
parent
48ecce9c31
commit
f250789e82
|
@ -3,16 +3,16 @@ from registration.forms import RegistrationForm
|
||||||
from models import *
|
from models import *
|
||||||
from registration.models import RegistrationProfile
|
from registration.models import RegistrationProfile
|
||||||
import json
|
import json
|
||||||
|
from django.forms.models import inlineformset_factory
|
||||||
|
from django.contrib.contenttypes.generic import generic_inlineformset_factory
|
||||||
|
from padmavideos.models import PadmaVideo, PadmaClip
|
||||||
|
from crispy_forms.helper import FormHelper
|
||||||
|
|
||||||
class ItfRegistrationForm(RegistrationForm):
|
class ItfForm(forms.ModelForm):
|
||||||
subscribe = forms.BooleanField(help_text='Subscribe to newsletter?')
|
|
||||||
|
def __init__(self, *args, **kwargs):
|
||||||
def save(self, profile_callback=None):
|
self.helper = FormHelper()
|
||||||
new_user = RegistrationProfile.objects.create_inactive_user(username=self.cleaned_data['username'], password=self.cleaned_data['password1'], email=self.cleaned_data['email'])
|
super(ItfForm, self).__init__(*args, **kwargs)
|
||||||
new_profile = ItfProfile(user=new_user, subscribed=self.cleaned_data['subscribe'])
|
|
||||||
new_profile.save()
|
|
||||||
return new_user
|
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
class ConnectionsWidget(forms.SelectMultiple):
|
class ConnectionsWidget(forms.SelectMultiple):
|
||||||
|
@ -27,22 +27,79 @@ class ConnectionsWidget(forms.SelectMultiple):
|
||||||
'''
|
'''
|
||||||
|
|
||||||
def get_context(self, name, value, attrs, *args, **kwargs):
|
def get_context(self, name, value, attrs, *args, **kwargs):
|
||||||
import pdb
|
|
||||||
pdb.set_trace()
|
|
||||||
ctx = super(ConnectionsWidget, self).get_context(name, value, attrs)
|
ctx = super(ConnectionsWidget, self).get_context(name, value, attrs)
|
||||||
ctx['data_json'] = "hi" # json.dumps(choices)
|
|
||||||
|
#selected_values = [{'id': obj[0], 'text': obj[1]} for obj in self.choices if obj[0] in value]
|
||||||
|
#ctx['data_json'] = json.dumps(selected_values) # json.dumps(choices)
|
||||||
return ctx
|
return ctx
|
||||||
|
|
||||||
|
|
||||||
|
class ItfRegistrationForm(RegistrationForm):
|
||||||
|
subscribe = forms.BooleanField(help_text='Subscribe to newsletter?')
|
||||||
|
|
||||||
|
def save(self, profile_callback=None):
|
||||||
|
new_user = RegistrationProfile.objects.create_inactive_user(username=self.cleaned_data['username'], password=self.cleaned_data['password1'], email=self.cleaned_data['email'])
|
||||||
|
new_profile = ItfProfile(user=new_user, subscribed=self.cleaned_data['subscribe'])
|
||||||
|
new_profile.save()
|
||||||
|
return new_user
|
||||||
|
|
||||||
|
|
||||||
|
class ConnectionsForm(ItfForm):
|
||||||
|
person2 = forms.ModelMultipleChoiceField(Person.objects.all(), widget=ConnectionsWidget())
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = PersonPerson
|
||||||
|
exclude = ('disapproved',)
|
||||||
|
|
||||||
|
class PersonProductionForm(ItfForm):
|
||||||
|
pass
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = PersonProduction
|
||||||
|
|
||||||
|
class PersonGroupForm(ItfForm):
|
||||||
|
pass
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = PersonGroup
|
||||||
|
|
||||||
|
class PadmaClipForm(ItfForm):
|
||||||
|
pass
|
||||||
|
|
||||||
|
class Meta:
|
||||||
|
model = PadmaClip
|
||||||
|
|
||||||
|
|
||||||
|
def itf_inlineformset_factory(model, *args, **kwargs):
|
||||||
|
title = kwargs.pop('title', '')
|
||||||
|
help_text = kwargs.pop('help_text', '')
|
||||||
|
is_generic = kwargs.pop('is_generic', False)
|
||||||
|
#kwargs.delete("title")
|
||||||
|
if is_generic:
|
||||||
|
FormSet = generic_inlineformset_factory(model, *args, **kwargs)
|
||||||
|
else:
|
||||||
|
FormSet = inlineformset_factory(model, *args, **kwargs)
|
||||||
|
FormSet.title = title
|
||||||
|
FormSet.help_text = help_text
|
||||||
|
return FormSet
|
||||||
|
|
||||||
|
ConnectionsInline = itf_inlineformset_factory(Person, PersonPerson, fk_name='person1', form=ConnectionsForm, extra=1, title="Add / Edit Connections", help_text="select the people you are connected with and how you are related in the theatre world")
|
||||||
|
ProductionsInline = itf_inlineformset_factory(Person, PersonProduction, form=PersonProductionForm, extra=1, title="Productions you have worked in")
|
||||||
|
GroupsInline = itf_inlineformset_factory(Person, PersonGroup, extra=1, form=PersonGroupForm, title="Theatre groups you are a part of or have worked with")
|
||||||
|
PadmaClipsInline = itf_inlineformset_factory(PadmaClip, extra=1, is_generic=True, form=PadmaClipForm, title="Videos you appear in")
|
||||||
|
|
||||||
|
|
||||||
#Actual person form definition
|
#Actual person form definition
|
||||||
class PersonForm(forms.ModelForm):
|
class PersonForm(forms.ModelForm):
|
||||||
# occupations = forms.ModelMultipleChoiceField(Occupation.objects.all(), widget=forms.CheckboxSelectMultiple())
|
# occupations = forms.ModelMultipleChoiceField(Occupation.objects.all(), widget=forms.CheckboxSelectMultiple())
|
||||||
connections = forms.ModelMultipleChoiceField(Person.objects.all(), widget=ConnectionsWidget())
|
# connections = forms.ModelMultipleChoiceField(Person.objects.all(), widget=ConnectionsWidget())
|
||||||
# occupations = forms.ModelMultipleChoiceField(Occupation.objects.all(), widget=forms.CheckboxSelectMultiple())
|
# occupations = forms.ModelMultipleChoiceField(Occupation.objects.all(), widget=forms.CheckboxSelectMultiple())
|
||||||
email = forms.EmailField(widget=forms.EmailInput(attrs={'placeholder': 'john@example.com'}))
|
email = forms.EmailField(widget=forms.EmailInput(attrs={'placeholder': 'john@example.com'}))
|
||||||
|
# inlines = [ConnectionsInline]
|
||||||
|
inlines = [ConnectionsInline, ProductionsInline, GroupsInline, PadmaClipsInline]
|
||||||
|
|
||||||
# inlines = [ConnectionFormset, ProductionFormset]
|
|
||||||
class Meta:
|
class Meta:
|
||||||
|
exclude = ('connections', 'productions', 'groups', 'last_accessed',)
|
||||||
model = Person
|
model = Person
|
||||||
widgets = {
|
widgets = {
|
||||||
'first_name': forms.TextInput,
|
'first_name': forms.TextInput,
|
||||||
|
|
|
@ -83,10 +83,11 @@ class PersonOccupation(models.Model):
|
||||||
|
|
||||||
class PersonPerson(models.Model):
|
class PersonPerson(models.Model):
|
||||||
person1 = models.ForeignKey(Person, related_name='PersonFrom', db_index=True)
|
person1 = models.ForeignKey(Person, related_name='PersonFrom', db_index=True)
|
||||||
person2 = models.ForeignKey(Person, related_name='PersonTo', db_index=True)
|
person2 = models.ForeignKey(Person, related_name='PersonTo', db_index=True, verbose_name='connection')
|
||||||
relation = models.ForeignKey("Relation")
|
relation = models.ForeignKey("Relation")
|
||||||
disapproved = models.BooleanField(default=False)
|
disapproved = models.BooleanField(default=False)
|
||||||
|
|
||||||
|
|
||||||
class Relation(models.Model):
|
class Relation(models.Model):
|
||||||
name = models.CharField(max_length=255, db_index=True)
|
name = models.CharField(max_length=255, db_index=True)
|
||||||
reverse = models.CharField(max_length=255, db_index=True)
|
reverse = models.CharField(max_length=255, db_index=True)
|
||||||
|
@ -122,6 +123,7 @@ class Play(ItfModel):
|
||||||
|
|
||||||
|
|
||||||
class Production(ItfModel):
|
class Production(ItfModel):
|
||||||
|
# user = models.ForeignKey(User)
|
||||||
play = models.ForeignKey("Play", null=True, blank=True)
|
play = models.ForeignKey("Play", null=True, blank=True)
|
||||||
name = models.CharField(max_length=255, db_index=True)
|
name = models.CharField(max_length=255, db_index=True)
|
||||||
language = models.ForeignKey("Language", blank=True, null=True)
|
language = models.ForeignKey("Language", blank=True, null=True)
|
||||||
|
|
|
@ -8,7 +8,10 @@ from django.core.paginator import Paginator, InvalidPage, EmptyPage
|
||||||
def person_form(request):
|
def person_form(request):
|
||||||
person = Person.objects.all()[0]
|
person = Person.objects.all()[0]
|
||||||
form = PersonForm(instance=person)
|
form = PersonForm(instance=person)
|
||||||
return render_to_response("test/person_form.html", {'form': form})
|
inlines = [inline(instance=person) for inline in form.inlines]
|
||||||
|
#import pdb
|
||||||
|
#pdb.set_trace()
|
||||||
|
return render_to_response("test/person_form.html", {'form': form, 'inlines': inlines})
|
||||||
|
|
||||||
|
|
||||||
def autocomplete(request):
|
def autocomplete(request):
|
||||||
|
|
0
itf/migrations/__init__.py
Normal file
0
itf/migrations/__init__.py
Normal file
17
itf/migrations/migrate.py
Normal file
17
itf/migrations/migrate.py
Normal file
|
@ -0,0 +1,17 @@
|
||||||
|
from festival.models import Participant, Meeting
|
||||||
|
from itfprofiles.models import Person
|
||||||
|
|
||||||
|
def migrate_participants():
|
||||||
|
for p in Participant.objects.all():
|
||||||
|
name = p.name
|
||||||
|
names = name.split(" ")
|
||||||
|
person = Person()
|
||||||
|
if len(names) > 1:
|
||||||
|
person.last_name = names[-1]
|
||||||
|
person.first_name = " ".join(names[0:-1])
|
||||||
|
else:
|
||||||
|
person.first_name = names[0]
|
||||||
|
person.about = p.short_bio
|
||||||
|
person.save()
|
||||||
|
print "saved %s %s" % (person.first_name, person.last_name,)
|
||||||
|
|
|
@ -40,7 +40,7 @@ class Script(ItfModel):
|
||||||
fts_fields = ['title', 'synopsis', 'author']
|
fts_fields = ['title', 'synopsis', 'author']
|
||||||
fk_fields = ['license_adapt', 'license_perform']
|
fk_fields = ['license_adapt', 'license_perform']
|
||||||
|
|
||||||
add_form = 'ScriptForm'
|
# add_form = 'ScriptForm'
|
||||||
|
|
||||||
#Meta
|
#Meta
|
||||||
added = models.DateTimeField(auto_now_add=True)
|
added = models.DateTimeField(auto_now_add=True)
|
||||||
|
@ -55,7 +55,7 @@ class Script(ItfModel):
|
||||||
'title': self.title,
|
'title': self.title,
|
||||||
}
|
}
|
||||||
|
|
||||||
def info_dict(self):
|
def get_dict(self):
|
||||||
return {
|
return {
|
||||||
'title': self.title,
|
'title': self.title,
|
||||||
'synopsis': self.synopsis,
|
'synopsis': self.synopsis,
|
||||||
|
|
|
@ -20,6 +20,8 @@
|
||||||
<!-- uni-form JS library, optional -->
|
<!-- uni-form JS library, optional -->
|
||||||
<script src="/static/uni_form/uni-form.jquery.js" type="text/javascript"></script>
|
<script src="/static/uni_form/uni-form.jquery.js" type="text/javascript"></script>
|
||||||
<script src="/static/js/select2.js" type="text/javascript"></script>
|
<script src="/static/js/select2.js" type="text/javascript"></script>
|
||||||
|
<script src="/static/js/jquery.formset.min.js"></script>
|
||||||
|
|
||||||
|
|
||||||
<script type="text/javascript">
|
<script type="text/javascript">
|
||||||
$(function(){
|
$(function(){
|
||||||
|
@ -38,9 +40,9 @@ $(function(){
|
||||||
}
|
}
|
||||||
];
|
];
|
||||||
|
|
||||||
$('#id_connections').select2({
|
$('.select2class').select2({
|
||||||
//placeholder: 'Select your connections',
|
//placeholder: 'Select your connections',
|
||||||
multiple: true,
|
//multiple: true,
|
||||||
ajax: {
|
ajax: {
|
||||||
url: '/autocompletes/itfprofiles/',
|
url: '/autocompletes/itfprofiles/',
|
||||||
dataType: 'json',
|
dataType: 'json',
|
||||||
|
@ -66,8 +68,8 @@ $(function(){
|
||||||
},
|
},
|
||||||
formatSelection: function(item) {
|
formatSelection: function(item) {
|
||||||
//console.log("foo");
|
//console.log("foo");
|
||||||
|
return item.first_name + " " + item.last_name;
|
||||||
return "<div class='itfselect2_selected' data-id='" + item.id + "'>" + item.first_name + " " + item.last_name + "</div>";
|
//return "<div data-id='" + item.id + "'>" + item.first_name + " " + item.last_name + "</div>";
|
||||||
},
|
},
|
||||||
createSearchChoice: function(term) {
|
createSearchChoice: function(term) {
|
||||||
s = term.split(" ");
|
s = term.split(" ");
|
||||||
|
@ -82,11 +84,11 @@ $(function(){
|
||||||
}
|
}
|
||||||
});
|
});
|
||||||
// console.log(sampleData);
|
// console.log(sampleData);
|
||||||
$('#id_connections').select2("val", sampleData);
|
// $('#id_connections').select2("val", sampleData);
|
||||||
|
|
||||||
var val = $('#id_connections').select2("val");
|
|
||||||
$('#id_connections').data("old_val", sampleData);
|
|
||||||
|
|
||||||
|
// var val = $('#id_connections').select2("val");
|
||||||
|
// $('#id_connections').data("old_val", sampleData);
|
||||||
|
/*
|
||||||
$('.select2-choices').on("click", function(e) {
|
$('.select2-choices').on("click", function(e) {
|
||||||
console.log(e.target);
|
console.log(e.target);
|
||||||
});
|
});
|
||||||
|
@ -132,7 +134,7 @@ $(function(){
|
||||||
|
|
||||||
});
|
});
|
||||||
//$('#id_connections').change();
|
//$('#id_connections').change();
|
||||||
|
*/
|
||||||
});
|
});
|
||||||
|
|
||||||
|
|
||||||
|
@ -151,9 +153,28 @@ $(function(){
|
||||||
</div>
|
</div>
|
||||||
{{ form|crispy }}
|
{{ form|crispy }}
|
||||||
|
|
||||||
|
{% for inline in inlines %}
|
||||||
|
<h3> {{inline.title }} </h3>
|
||||||
|
{% if inline.help_text %}
|
||||||
|
<div class="formset_help_text"> {{ inline.help_text }}</div>
|
||||||
|
{% endif %}
|
||||||
|
<div class="itf_formset" id="formset_{{inline.prefix}}">
|
||||||
|
{% crispy inline inline.form.helper %}
|
||||||
|
</div>
|
||||||
|
{% endfor %}
|
||||||
</form>
|
</form>
|
||||||
</div>
|
</div>
|
||||||
|
|
||||||
</div>
|
</div>
|
||||||
|
<script type="text/javascript">
|
||||||
|
$(function() {
|
||||||
|
{% for inline in inlines %}
|
||||||
|
$('#formset_{{inline.prefix}}').formset({
|
||||||
|
prefix: '{{ inline.prefix }}',
|
||||||
|
formCssClass: 'dynamic-formset{{forloop.counter0}}'
|
||||||
|
});
|
||||||
|
{% endfor %}
|
||||||
|
});
|
||||||
|
</script>
|
||||||
|
|
||||||
{% endblock %}
|
{% endblock %}
|
||||||
|
|
Loading…
Reference in New Issue
Block a user