|
@@ -0,0 +1,185 @@
|
|
1
|
+# -*- coding: utf-8 -*-
|
|
2
|
+from south.utils import datetime_utils as datetime
|
|
3
|
+from south.db import db
|
|
4
|
+from south.v2 import SchemaMigration
|
|
5
|
+from django.db import models
|
|
6
|
+
|
|
7
|
+
|
|
8
|
+class Migration(SchemaMigration):
|
|
9
|
+
|
|
10
|
+ def forwards(self, orm):
|
|
11
|
+ # Deleting model 'AttributeEntity'
|
|
12
|
+ db.delete_table(u'catalogue_attributeentity')
|
|
13
|
+
|
|
14
|
+ # Deleting model 'AttributeEntityType'
|
|
15
|
+ db.delete_table(u'catalogue_attributeentitytype')
|
|
16
|
+
|
|
17
|
+ # Deleting field 'ProductAttributeValue.value_entity'
|
|
18
|
+ db.delete_column(u'catalogue_productattributevalue', 'value_entity_id')
|
|
19
|
+
|
|
20
|
+ # Adding field 'ProductAttributeValue.entity_content_type'
|
|
21
|
+ db.add_column(u'catalogue_productattributevalue', 'entity_content_type',
|
|
22
|
+ self.gf('django.db.models.fields.related.ForeignKey')(to=orm['contenttypes.ContentType'], null=True, blank=True),
|
|
23
|
+ keep_default=False)
|
|
24
|
+
|
|
25
|
+ # Adding field 'ProductAttributeValue.entity_object_id'
|
|
26
|
+ db.add_column(u'catalogue_productattributevalue', 'entity_object_id',
|
|
27
|
+ self.gf('django.db.models.fields.PositiveIntegerField')(null=True, blank=True),
|
|
28
|
+ keep_default=False)
|
|
29
|
+
|
|
30
|
+ # Deleting field 'ProductAttribute.entity_type'
|
|
31
|
+ db.delete_column(u'catalogue_productattribute', 'entity_type_id')
|
|
32
|
+
|
|
33
|
+
|
|
34
|
+ def backwards(self, orm):
|
|
35
|
+ # Adding model 'AttributeEntity'
|
|
36
|
+ db.create_table(u'catalogue_attributeentity', (
|
|
37
|
+ ('slug', self.gf('django.db.models.fields.SlugField')(max_length=255, blank=True)),
|
|
38
|
+ ('type', self.gf('django.db.models.fields.related.ForeignKey')(related_name='entities', to=orm['catalogue.AttributeEntityType'])),
|
|
39
|
+ (u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
|
40
|
+ ('name', self.gf('django.db.models.fields.CharField')(max_length=255)),
|
|
41
|
+ ))
|
|
42
|
+ db.send_create_signal(u'catalogue', ['AttributeEntity'])
|
|
43
|
+
|
|
44
|
+ # Adding model 'AttributeEntityType'
|
|
45
|
+ db.create_table(u'catalogue_attributeentitytype', (
|
|
46
|
+ ('slug', self.gf('django.db.models.fields.SlugField')(max_length=255, blank=True)),
|
|
47
|
+ (u'id', self.gf('django.db.models.fields.AutoField')(primary_key=True)),
|
|
48
|
+ ('name', self.gf('django.db.models.fields.CharField')(max_length=255)),
|
|
49
|
+ ))
|
|
50
|
+ db.send_create_signal(u'catalogue', ['AttributeEntityType'])
|
|
51
|
+
|
|
52
|
+ # Adding field 'ProductAttributeValue.value_entity'
|
|
53
|
+ db.add_column(u'catalogue_productattributevalue', 'value_entity',
|
|
54
|
+ self.gf('django.db.models.fields.related.ForeignKey')(to=orm['catalogue.AttributeEntity'], null=True, blank=True),
|
|
55
|
+ keep_default=False)
|
|
56
|
+
|
|
57
|
+ # Deleting field 'ProductAttributeValue.entity_content_type'
|
|
58
|
+ db.delete_column(u'catalogue_productattributevalue', 'entity_content_type_id')
|
|
59
|
+
|
|
60
|
+ # Deleting field 'ProductAttributeValue.entity_object_id'
|
|
61
|
+ db.delete_column(u'catalogue_productattributevalue', 'entity_object_id')
|
|
62
|
+
|
|
63
|
+ # Adding field 'ProductAttribute.entity_type'
|
|
64
|
+ db.add_column(u'catalogue_productattribute', 'entity_type',
|
|
65
|
+ self.gf('django.db.models.fields.related.ForeignKey')(to=orm['catalogue.AttributeEntityType'], null=True, blank=True),
|
|
66
|
+ keep_default=False)
|
|
67
|
+
|
|
68
|
+
|
|
69
|
+ models = {
|
|
70
|
+ u'catalogue.attributeoption': {
|
|
71
|
+ 'Meta': {'object_name': 'AttributeOption'},
|
|
72
|
+ 'group': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'options'", 'to': u"orm['catalogue.AttributeOptionGroup']"}),
|
|
73
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
74
|
+ 'option': ('django.db.models.fields.CharField', [], {'max_length': '255'})
|
|
75
|
+ },
|
|
76
|
+ u'catalogue.attributeoptiongroup': {
|
|
77
|
+ 'Meta': {'object_name': 'AttributeOptionGroup'},
|
|
78
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
79
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'})
|
|
80
|
+ },
|
|
81
|
+ u'catalogue.category': {
|
|
82
|
+ 'Meta': {'ordering': "['full_name']", 'object_name': 'Category'},
|
|
83
|
+ 'depth': ('django.db.models.fields.PositiveIntegerField', [], {}),
|
|
84
|
+ 'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
|
|
85
|
+ 'full_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
|
|
86
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
87
|
+ 'image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
88
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
|
|
89
|
+ 'numchild': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
|
|
90
|
+ 'path': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
|
|
91
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'})
|
|
92
|
+ },
|
|
93
|
+ u'catalogue.option': {
|
|
94
|
+ 'Meta': {'object_name': 'Option'},
|
|
95
|
+ 'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
|
|
96
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
97
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
98
|
+ 'type': ('django.db.models.fields.CharField', [], {'default': "'Required'", 'max_length': '128'})
|
|
99
|
+ },
|
|
100
|
+ u'catalogue.product': {
|
|
101
|
+ 'Meta': {'ordering': "['-date_created']", 'object_name': 'Product'},
|
|
102
|
+ 'attributes': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.ProductAttribute']", 'through': u"orm['catalogue.ProductAttributeValue']", 'symmetrical': 'False'}),
|
|
103
|
+ 'categories': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Category']", 'through': u"orm['catalogue.ProductCategory']", 'symmetrical': 'False'}),
|
|
104
|
+ 'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
|
|
105
|
+ 'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'db_index': 'True', 'blank': 'True'}),
|
|
106
|
+ 'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
|
|
107
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
108
|
+ 'is_discountable': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
|
109
|
+ 'parent': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'variants'", 'null': 'True', 'to': u"orm['catalogue.Product']"}),
|
|
110
|
+ 'product_class': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'products'", 'null': 'True', 'on_delete': 'models.PROTECT', 'to': u"orm['catalogue.ProductClass']"}),
|
|
111
|
+ 'product_options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
|
|
112
|
+ 'rating': ('django.db.models.fields.FloatField', [], {'null': 'True'}),
|
|
113
|
+ 'recommended_products': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Product']", 'symmetrical': 'False', 'through': u"orm['catalogue.ProductRecommendation']", 'blank': 'True'}),
|
|
114
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'}),
|
|
115
|
+ 'title': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
|
|
116
|
+ 'upc': ('oscar.models.fields.NullCharField', [], {'max_length': '64', 'unique': 'True', 'null': 'True', 'blank': 'True'})
|
|
117
|
+ },
|
|
118
|
+ u'catalogue.productattribute': {
|
|
119
|
+ 'Meta': {'ordering': "['code']", 'object_name': 'ProductAttribute'},
|
|
120
|
+ 'code': ('django.db.models.fields.SlugField', [], {'max_length': '128'}),
|
|
121
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
122
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
123
|
+ 'option_group': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOptionGroup']", 'null': 'True', 'blank': 'True'}),
|
|
124
|
+ 'product_class': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'attributes'", 'null': 'True', 'to': u"orm['catalogue.ProductClass']"}),
|
|
125
|
+ 'required': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
|
126
|
+ 'type': ('django.db.models.fields.CharField', [], {'default': "'text'", 'max_length': '20'})
|
|
127
|
+ },
|
|
128
|
+ u'catalogue.productattributevalue': {
|
|
129
|
+ 'Meta': {'unique_together': "(('attribute', 'product'),)", 'object_name': 'ProductAttributeValue'},
|
|
130
|
+ 'attribute': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.ProductAttribute']"}),
|
|
131
|
+ 'entity_content_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['contenttypes.ContentType']", 'null': 'True', 'blank': 'True'}),
|
|
132
|
+ 'entity_object_id': ('django.db.models.fields.PositiveIntegerField', [], {'null': 'True', 'blank': 'True'}),
|
|
133
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
134
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'attribute_values'", 'to': u"orm['catalogue.Product']"}),
|
|
135
|
+ 'value_boolean': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
|
|
136
|
+ 'value_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
|
|
137
|
+ 'value_file': ('django.db.models.fields.files.FileField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
138
|
+ 'value_float': ('django.db.models.fields.FloatField', [], {'null': 'True', 'blank': 'True'}),
|
|
139
|
+ 'value_image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
140
|
+ 'value_integer': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
|
|
141
|
+ 'value_option': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOption']", 'null': 'True', 'blank': 'True'}),
|
|
142
|
+ 'value_richtext': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
|
|
143
|
+ 'value_text': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'})
|
|
144
|
+ },
|
|
145
|
+ u'catalogue.productcategory': {
|
|
146
|
+ 'Meta': {'ordering': "['product', 'category']", 'unique_together': "(('product', 'category'),)", 'object_name': 'ProductCategory'},
|
|
147
|
+ 'category': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Category']"}),
|
|
148
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
149
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
|
|
150
|
+ },
|
|
151
|
+ u'catalogue.productclass': {
|
|
152
|
+ 'Meta': {'ordering': "['name']", 'object_name': 'ProductClass'},
|
|
153
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
154
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
155
|
+ 'options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
|
|
156
|
+ 'requires_shipping': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
|
157
|
+ 'slug': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
|
|
158
|
+ 'track_stock': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
|
|
159
|
+ },
|
|
160
|
+ u'catalogue.productimage': {
|
|
161
|
+ 'Meta': {'ordering': "['display_order']", 'unique_together': "(('product', 'display_order'),)", 'object_name': 'ProductImage'},
|
|
162
|
+ 'caption': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}),
|
|
163
|
+ 'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
|
|
164
|
+ 'display_order': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
|
|
165
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
166
|
+ 'original': ('django.db.models.fields.files.ImageField', [], {'max_length': '255'}),
|
|
167
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'images'", 'to': u"orm['catalogue.Product']"})
|
|
168
|
+ },
|
|
169
|
+ u'catalogue.productrecommendation': {
|
|
170
|
+ 'Meta': {'ordering': "['primary', '-ranking']", 'unique_together': "(('primary', 'recommendation'),)", 'object_name': 'ProductRecommendation'},
|
|
171
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
172
|
+ 'primary': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'primary_recommendations'", 'to': u"orm['catalogue.Product']"}),
|
|
173
|
+ 'ranking': ('django.db.models.fields.PositiveSmallIntegerField', [], {'default': '0'}),
|
|
174
|
+ 'recommendation': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
|
|
175
|
+ },
|
|
176
|
+ u'contenttypes.contenttype': {
|
|
177
|
+ 'Meta': {'ordering': "('name',)", 'unique_together': "(('app_label', 'model'),)", 'object_name': 'ContentType', 'db_table': "'django_content_type'"},
|
|
178
|
+ 'app_label': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
|
179
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
180
|
+ 'model': ('django.db.models.fields.CharField', [], {'max_length': '100'}),
|
|
181
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '100'})
|
|
182
|
+ }
|
|
183
|
+ }
|
|
184
|
+
|
|
185
|
+ complete_apps = ['catalogue']
|