1: <?php
2:
3: namespace Thelia\Model\map;
4:
5: use \RelationMap;
6: use \TableMap;
7:
8:
9: 10: 11: 12: 13: 14: 15: 16: 17: 18: 19: 20:
21: class ProductTableMap extends TableMap
22: {
23:
24: 25: 26:
27: const CLASS_NAME = 'Thelia.Model.map.ProductTableMap';
28:
29: 30: 31: 32: 33: 34: 35:
36: public function initialize()
37: {
38:
39: $this->setName('product');
40: $this->setPhpName('Product');
41: $this->setClassname('Thelia\\Model\\Product');
42: $this->setPackage('Thelia.Model');
43: $this->setUseIdGenerator(true);
44:
45: $this->addPrimaryKey('id', 'Id', 'INTEGER', true, null, null);
46: $this->addForeignKey('tax_rule_id', 'TaxRuleId', 'INTEGER', 'tax_rule', 'id', false, null, null);
47: $this->addColumn('ref', 'Ref', 'VARCHAR', true, 255, null);
48: $this->addColumn('price', 'Price', 'FLOAT', true, null, null);
49: $this->addColumn('price2', 'Price2', 'FLOAT', false, null, null);
50: $this->addColumn('ecotax', 'Ecotax', 'FLOAT', false, null, null);
51: $this->addColumn('newness', 'Newness', 'TINYINT', false, null, 0);
52: $this->addColumn('promo', 'Promo', 'TINYINT', false, null, 0);
53: $this->addColumn('stock', 'Stock', 'INTEGER', false, null, 0);
54: $this->addColumn('visible', 'Visible', 'TINYINT', true, null, 0);
55: $this->addColumn('weight', 'Weight', 'FLOAT', false, null, null);
56: $this->addColumn('position', 'Position', 'INTEGER', true, null, null);
57: $this->addColumn('created_at', 'CreatedAt', 'TIMESTAMP', false, null, null);
58: $this->addColumn('updated_at', 'UpdatedAt', 'TIMESTAMP', false, null, null);
59: $this->addColumn('version', 'Version', 'INTEGER', false, null, 0);
60: $this->addColumn('version_created_at', 'VersionCreatedAt', 'TIMESTAMP', false, null, null);
61: $this->addColumn('version_created_by', 'VersionCreatedBy', 'VARCHAR', false, 100, null);
62:
63: }
64:
65: 66: 67:
68: public function buildRelations()
69: {
70: $this->addRelation('TaxRule', 'Thelia\\Model\\TaxRule', RelationMap::MANY_TO_ONE, array('tax_rule_id' => 'id', ), 'SET NULL', 'RESTRICT');
71: $this->addRelation('ProductCategory', 'Thelia\\Model\\ProductCategory', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'ProductCategorys');
72: $this->addRelation('FeatureProd', 'Thelia\\Model\\FeatureProd', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'FeatureProds');
73: $this->addRelation('Stock', 'Thelia\\Model\\Stock', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'Stocks');
74: $this->addRelation('ContentAssoc', 'Thelia\\Model\\ContentAssoc', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'ContentAssocs');
75: $this->addRelation('Image', 'Thelia\\Model\\Image', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'Images');
76: $this->addRelation('Document', 'Thelia\\Model\\Document', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'Documents');
77: $this->addRelation('AccessoryRelatedByProductId', 'Thelia\\Model\\Accessory', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'AccessorysRelatedByProductId');
78: $this->addRelation('AccessoryRelatedByAccessory', 'Thelia\\Model\\Accessory', RelationMap::ONE_TO_MANY, array('id' => 'accessory', ), 'CASCADE', 'RESTRICT', 'AccessorysRelatedByAccessory');
79: $this->addRelation('Rewriting', 'Thelia\\Model\\Rewriting', RelationMap::ONE_TO_MANY, array('id' => 'product_id', ), 'CASCADE', 'RESTRICT', 'Rewritings');
80: $this->addRelation('ProductI18n', 'Thelia\\Model\\ProductI18n', RelationMap::ONE_TO_MANY, array('id' => 'id', ), 'CASCADE', null, 'ProductI18ns');
81: $this->addRelation('ProductVersion', 'Thelia\\Model\\ProductVersion', RelationMap::ONE_TO_MANY, array('id' => 'id', ), 'CASCADE', null, 'ProductVersions');
82: }
83:
84: 85: 86: 87: 88: 89:
90: public function getBehaviors()
91: {
92: return array(
93: 'timestampable' => array (
94: 'create_column' => 'created_at',
95: 'update_column' => 'updated_at',
96: 'disable_updated_at' => 'false',
97: ),
98: 'i18n' => array (
99: 'i18n_table' => '%TABLE%_i18n',
100: 'i18n_phpname' => '%PHPNAME%I18n',
101: 'i18n_columns' => 'title, description, chapo, postscriptum',
102: 'i18n_pk_name' => NULL,
103: 'locale_column' => 'locale',
104: 'default_locale' => NULL,
105: 'locale_alias' => '',
106: ),
107: 'versionable' => array (
108: 'version_column' => 'version',
109: 'version_table' => '',
110: 'log_created_at' => 'true',
111: 'log_created_by' => 'true',
112: 'log_comment' => 'false',
113: 'version_created_at_column' => 'version_created_at',
114: 'version_created_by_column' => 'version_created_by',
115: 'version_comment_column' => 'version_comment',
116: ),
117: );
118: }
119:
120: }
121: