|
@@ -0,0 +1,148 @@
|
|
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
|
+ # Removing M2M table for field related_products on 'Product'
|
|
12
|
+ db.delete_table(db.shorten_name(u'catalogue_product_related_products'))
|
|
13
|
+
|
|
14
|
+
|
|
15
|
+ def backwards(self, orm):
|
|
16
|
+ # Adding M2M table for field related_products on 'Product'
|
|
17
|
+ m2m_table_name = db.shorten_name(u'catalogue_product_related_products')
|
|
18
|
+ db.create_table(m2m_table_name, (
|
|
19
|
+ ('id', models.AutoField(verbose_name='ID', primary_key=True, auto_created=True)),
|
|
20
|
+ ('from_product', models.ForeignKey(orm[u'catalogue.product'], null=False)),
|
|
21
|
+ ('to_product', models.ForeignKey(orm[u'catalogue.product'], null=False))
|
|
22
|
+ ))
|
|
23
|
+ db.create_unique(m2m_table_name, ['from_product_id', 'to_product_id'])
|
|
24
|
+
|
|
25
|
+
|
|
26
|
+ models = {
|
|
27
|
+ u'catalogue.attributeentity': {
|
|
28
|
+ 'Meta': {'object_name': 'AttributeEntity'},
|
|
29
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
30
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
|
|
31
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'blank': 'True'}),
|
|
32
|
+ 'type': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'entities'", 'to': u"orm['catalogue.AttributeEntityType']"})
|
|
33
|
+ },
|
|
34
|
+ u'catalogue.attributeentitytype': {
|
|
35
|
+ 'Meta': {'object_name': 'AttributeEntityType'},
|
|
36
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
37
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '255'}),
|
|
38
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255', 'blank': 'True'})
|
|
39
|
+ },
|
|
40
|
+ u'catalogue.attributeoption': {
|
|
41
|
+ 'Meta': {'object_name': 'AttributeOption'},
|
|
42
|
+ 'group': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'options'", 'to': u"orm['catalogue.AttributeOptionGroup']"}),
|
|
43
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
44
|
+ 'option': ('django.db.models.fields.CharField', [], {'max_length': '255'})
|
|
45
|
+ },
|
|
46
|
+ u'catalogue.attributeoptiongroup': {
|
|
47
|
+ 'Meta': {'object_name': 'AttributeOptionGroup'},
|
|
48
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
49
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'})
|
|
50
|
+ },
|
|
51
|
+ u'catalogue.category': {
|
|
52
|
+ 'Meta': {'ordering': "['full_name']", 'object_name': 'Category'},
|
|
53
|
+ 'depth': ('django.db.models.fields.PositiveIntegerField', [], {}),
|
|
54
|
+ 'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
|
|
55
|
+ 'full_name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
|
|
56
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
57
|
+ 'image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
58
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '255', 'db_index': 'True'}),
|
|
59
|
+ 'numchild': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
|
|
60
|
+ 'path': ('django.db.models.fields.CharField', [], {'unique': 'True', 'max_length': '255'}),
|
|
61
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'})
|
|
62
|
+ },
|
|
63
|
+ u'catalogue.option': {
|
|
64
|
+ 'Meta': {'object_name': 'Option'},
|
|
65
|
+ 'code': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
|
|
66
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
67
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
68
|
+ 'type': ('django.db.models.fields.CharField', [], {'default': "'Required'", 'max_length': '128'})
|
|
69
|
+ },
|
|
70
|
+ u'catalogue.product': {
|
|
71
|
+ 'Meta': {'ordering': "['-date_created']", 'object_name': 'Product'},
|
|
72
|
+ 'attributes': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.ProductAttribute']", 'through': u"orm['catalogue.ProductAttributeValue']", 'symmetrical': 'False'}),
|
|
73
|
+ 'categories': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Category']", 'through': u"orm['catalogue.ProductCategory']", 'symmetrical': 'False'}),
|
|
74
|
+ 'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
|
|
75
|
+ 'date_updated': ('django.db.models.fields.DateTimeField', [], {'auto_now': 'True', 'db_index': 'True', 'blank': 'True'}),
|
|
76
|
+ 'description': ('django.db.models.fields.TextField', [], {'blank': 'True'}),
|
|
77
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
78
|
+ 'is_discountable': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
|
79
|
+ 'parent': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'variants'", 'null': 'True', 'to': u"orm['catalogue.Product']"}),
|
|
80
|
+ 'product_class': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'products'", 'null': 'True', 'on_delete': 'models.PROTECT', 'to': u"orm['catalogue.ProductClass']"}),
|
|
81
|
+ 'product_options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
|
|
82
|
+ 'rating': ('django.db.models.fields.FloatField', [], {'null': 'True'}),
|
|
83
|
+ 'recommended_products': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Product']", 'symmetrical': 'False', 'through': u"orm['catalogue.ProductRecommendation']", 'blank': 'True'}),
|
|
84
|
+ 'slug': ('django.db.models.fields.SlugField', [], {'max_length': '255'}),
|
|
85
|
+ 'title': ('django.db.models.fields.CharField', [], {'max_length': '255', 'blank': 'True'}),
|
|
86
|
+ 'upc': ('oscar.models.fields.NullCharField', [], {'max_length': '64', 'unique': 'True', 'null': 'True', 'blank': 'True'})
|
|
87
|
+ },
|
|
88
|
+ u'catalogue.productattribute': {
|
|
89
|
+ 'Meta': {'ordering': "['code']", 'object_name': 'ProductAttribute'},
|
|
90
|
+ 'code': ('django.db.models.fields.SlugField', [], {'max_length': '128'}),
|
|
91
|
+ 'entity_type': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeEntityType']", 'null': 'True', 'blank': 'True'}),
|
|
92
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
93
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
94
|
+ 'option_group': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOptionGroup']", 'null': 'True', 'blank': 'True'}),
|
|
95
|
+ 'product_class': ('django.db.models.fields.related.ForeignKey', [], {'blank': 'True', 'related_name': "'attributes'", 'null': 'True', 'to': u"orm['catalogue.ProductClass']"}),
|
|
96
|
+ 'required': ('django.db.models.fields.BooleanField', [], {'default': 'False'}),
|
|
97
|
+ 'type': ('django.db.models.fields.CharField', [], {'default': "'text'", 'max_length': '20'})
|
|
98
|
+ },
|
|
99
|
+ u'catalogue.productattributevalue': {
|
|
100
|
+ 'Meta': {'unique_together': "(('attribute', 'product'),)", 'object_name': 'ProductAttributeValue'},
|
|
101
|
+ 'attribute': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.ProductAttribute']"}),
|
|
102
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
103
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'attribute_values'", 'to': u"orm['catalogue.Product']"}),
|
|
104
|
+ 'value_boolean': ('django.db.models.fields.NullBooleanField', [], {'null': 'True', 'blank': 'True'}),
|
|
105
|
+ 'value_date': ('django.db.models.fields.DateField', [], {'null': 'True', 'blank': 'True'}),
|
|
106
|
+ 'value_entity': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeEntity']", 'null': 'True', 'blank': 'True'}),
|
|
107
|
+ 'value_file': ('django.db.models.fields.files.FileField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
108
|
+ 'value_float': ('django.db.models.fields.FloatField', [], {'null': 'True', 'blank': 'True'}),
|
|
109
|
+ 'value_image': ('django.db.models.fields.files.ImageField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'}),
|
|
110
|
+ 'value_integer': ('django.db.models.fields.IntegerField', [], {'null': 'True', 'blank': 'True'}),
|
|
111
|
+ 'value_option': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.AttributeOption']", 'null': 'True', 'blank': 'True'}),
|
|
112
|
+ 'value_richtext': ('django.db.models.fields.TextField', [], {'null': 'True', 'blank': 'True'}),
|
|
113
|
+ 'value_text': ('django.db.models.fields.CharField', [], {'max_length': '255', 'null': 'True', 'blank': 'True'})
|
|
114
|
+ },
|
|
115
|
+ u'catalogue.productcategory': {
|
|
116
|
+ 'Meta': {'ordering': "['product', 'category']", 'unique_together': "(('product', 'category'),)", 'object_name': 'ProductCategory'},
|
|
117
|
+ 'category': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Category']"}),
|
|
118
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
119
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
|
|
120
|
+ },
|
|
121
|
+ u'catalogue.productclass': {
|
|
122
|
+ 'Meta': {'ordering': "['name']", 'object_name': 'ProductClass'},
|
|
123
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
124
|
+ 'name': ('django.db.models.fields.CharField', [], {'max_length': '128'}),
|
|
125
|
+ 'options': ('django.db.models.fields.related.ManyToManyField', [], {'to': u"orm['catalogue.Option']", 'symmetrical': 'False', 'blank': 'True'}),
|
|
126
|
+ 'requires_shipping': ('django.db.models.fields.BooleanField', [], {'default': 'True'}),
|
|
127
|
+ 'slug': ('oscar.models.fields.autoslugfield.AutoSlugField', [], {'allow_duplicates': 'False', 'max_length': '128', 'separator': "u'-'", 'blank': 'True', 'unique': 'True', 'populate_from': "'name'", 'overwrite': 'False'}),
|
|
128
|
+ 'track_stock': ('django.db.models.fields.BooleanField', [], {'default': 'True'})
|
|
129
|
+ },
|
|
130
|
+ u'catalogue.productimage': {
|
|
131
|
+ 'Meta': {'ordering': "['display_order']", 'unique_together': "(('product', 'display_order'),)", 'object_name': 'ProductImage'},
|
|
132
|
+ 'caption': ('django.db.models.fields.CharField', [], {'max_length': '200', 'blank': 'True'}),
|
|
133
|
+ 'date_created': ('django.db.models.fields.DateTimeField', [], {'auto_now_add': 'True', 'blank': 'True'}),
|
|
134
|
+ 'display_order': ('django.db.models.fields.PositiveIntegerField', [], {'default': '0'}),
|
|
135
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
136
|
+ 'original': ('django.db.models.fields.files.ImageField', [], {'max_length': '255'}),
|
|
137
|
+ 'product': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'images'", 'to': u"orm['catalogue.Product']"})
|
|
138
|
+ },
|
|
139
|
+ u'catalogue.productrecommendation': {
|
|
140
|
+ 'Meta': {'ordering': "['primary', '-ranking']", 'unique_together': "(('primary', 'recommendation'),)", 'object_name': 'ProductRecommendation'},
|
|
141
|
+ u'id': ('django.db.models.fields.AutoField', [], {'primary_key': 'True'}),
|
|
142
|
+ 'primary': ('django.db.models.fields.related.ForeignKey', [], {'related_name': "'primary_recommendations'", 'to': u"orm['catalogue.Product']"}),
|
|
143
|
+ 'ranking': ('django.db.models.fields.PositiveSmallIntegerField', [], {'default': '0'}),
|
|
144
|
+ 'recommendation': ('django.db.models.fields.related.ForeignKey', [], {'to': u"orm['catalogue.Product']"})
|
|
145
|
+ }
|
|
146
|
+ }
|
|
147
|
+
|
|
148
|
+ complete_apps = ['catalogue']
|