Array('self' => 'add|edit'), 'OnApplyModifier' => Array('self' => 'add|edit'), ); $this->permMapping = array_merge($this->permMapping, $permissions); } function OnAfterItemLoad(&$event) { $object =& $event->getObject(); $format = '%01.'.$object->GetDBField('PrecisionAfterSep').'f'; // %01.2f $zero_if_empty = $object->GetDBField('ZeroIfEmpty'); $sc_object =& $this->Application->recallObject('sc'); $flat_options = $sc_object->getFieldOptions('Flat'); $perunit_options = $sc_object->getFieldOptions('PerUnit'); $flat_options['format'] = $format; $flat_options['default'] = $zero_if_empty ? 0 : null; $perunit_options['format'] = $format; $perunit_options['default'] = $zero_if_empty ? 0 : null; $sc_object->setFieldOptions('Flat', $flat_options); $sc_object->setFieldOptions('PerUnit', $perunit_options); } /** * Enter description here... * * @param kEvent $event * @return unknown */ function OnApplyModifier(&$event) { // $event->CallSubEvent(''); $zones_object =& $this->Application->recallObject('z'); $cost_object =& $this->Application->recallObject('sc'); $object = $event->getObject(); $operation = $this->Application->GetVar('operation'); $modify_by = (float)$this->Application->GetVar('modify_by'); $cost_type = $object->GetDBField('CostType'); $brackets = $this->Application->GetVar('br'); $zones = $this->Application->GetVar('z'); $conditions = Array(); if( is_array($zones) ) { $conditions['zones'] = 'ZoneID IN ('.implode( ',', array_keys($zones) ).')'; } if( is_array($brackets) ) { $conditions['brackets'] = 'BracketId IN ('.implode( ',', array_keys($brackets) ).')'; } $conditions = implode(' OR ', $conditions); if(!$conditions) { $this->finalizePopup($event); return false; } $sql = 'SELECT ShippingCostId FROM '.$cost_object->TableName.' WHERE '.$conditions; $res = $this->Conn->GetCol($sql); switch($cost_type) { case 1: $affected_fields = Array(0 => 'Flat'); break; case 2: $affected_fields = Array(0 => 'PerUnit'); break; default: $affected_fields = Array(0 => 'PerUnit', 1 => 'Flat'); } foreach($affected_fields as $field) { if($operation == '/' && $modify_by == 0) break; $sql = 'UPDATE '.$cost_object->TableName.' SET '.$field.'='.$field.$operation.$modify_by.' WHERE ShippingCostId IN ('.implode(',', $res).') AND NOT('.$field.' IS NULL) AND '.$field.$operation.$modify_by.'>=0'; $this->Conn->Query($sql); } $this->finalizePopup($event); } function OnFlip(&$event) { $object =& $event->getObject(); $aligment = $this->Application->GetLinkedVar('CostsTableAligment'); $new_align = $aligment ? 0 : 1; $this->Application->SetVar('CostsTableAligment', $new_align); $this->Application->LinkVar('CostsTableAligment'); $this->OnPreSave($event); $event->status=erSUCCESS; } function OnSave(&$event) { $this->OnAfterItemLoad($event); parent::OnSave($event); } function OnAfterItemCreate(&$event) { $event->CallSubEvent('OnAnyChange'); } function OnAfterItemUpdate(&$event) { $event->CallSubEvent('OnAnyChange'); } function OnAfterItemDelete(&$event) { $event->CallSubEvent('OnAnyChange'); } function OnAnyChange(&$event) { $sql = 'DELETE FROM '.TABLE_PREFIX.'Cache WHERE VarName LIKE "ShippingQuotes%"'; $this->Conn->Query($sql); } } ?>