123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152 |
- <?php
- /**
- *
- * PHP Pro Bid $Id$ ZRV4ap0dm8YTIJ3igakzQCA/TZT5c1ueZVq7mFgDF/8=
- *
- * @link http://www.phpprobid.com
- * @copyright Copyright (c) 2017 Online Ventures Software & CodeCube SRL
- * @license http://www.phpprobid.com/license Commercial License
- *
- * @version 7.9 [rev.7.9.01]
- */
- /**
- * custom fields data table service class
- *
- * IMPORTANT:
- * search serialized custom fields:
- * select * from probid_custom_fields_data where value REGEXP '"x"|"y"|"z"';
- * (maybe we will serialize all saved data)
- *
- * @7.9: empty multi choice values are saved as an empty string rather than as an empty serialized array
- */
- namespace Ppb\Service;
- use Ppb\Db\Table;
- class CustomFieldsData extends AbstractService
- {
- /**
- *
- * custom fields and custom fields data tables service
- *
- * @var \Ppb\Service\CustomFields
- */
- protected $_customFields;
- /**
- *
- * class constructor
- */
- public function __construct()
- {
- parent::__construct();
- $this->setTable(
- new Table\CustomFieldsData());
- }
- /**
- *
- * get custom fields table service
- *
- * @return \Ppb\Service\CustomFields
- */
- public function getCustomFieldsService()
- {
- if (!$this->_customFields instanceof CustomFields) {
- $this->setCustomFieldsService(
- new CustomFields());
- }
- return $this->_customFields;
- }
- /**
- *
- * set custom fields table service
- *
- * @param \Ppb\Service\CustomFields $customFields
- *
- * @return $this
- */
- public function setCustomFieldsService(CustomFields $customFields)
- {
- $this->_customFields = $customFields;
- return $this;
- }
- /**
- *
- * save data in the table
- *
- * 7.7: data is only saved if the custom field exists - workaround for when using the bulk lister and having
- * custom fields columns that do not exist
- *
- * @param string|array $value custom field value (if array it will be serialized before saving)
- * @param string $type custom field data type (item, user etc)
- * @param integer $fieldId custom_fields table id
- * @param integer $ownerId id of the column for which this data belongs to
- *
- * @return $this
- */
- public function save($value, $type, $fieldId, $ownerId)
- {
- $customField = $this->getCustomFieldsService()->findBy('id', $fieldId);
- if (count($customField) > 0) {
- if (is_array($value)) {
- $value = array_filter($value);
- $value = (!empty($value)) ? serialize($value) : '';
- }
- $data = array(
- 'value' => strval($value),
- 'field_id' => intval($fieldId),
- 'owner_id' => intval($ownerId),
- 'type' => strval($type),
- );
- $select = $this->_table->select()
- ->where("field_id = ?", $fieldId)
- ->where("owner_id = ?", $ownerId)
- ->where("type = ?", $type);
- $row = $this->_table->fetchRow($select);
- if (count($row) > 0) {
- $this->_table->update($data, "id='{$row['id']}'");
- }
- else {
- $this->_table->insert($data);
- }
- }
- return $this;
- }
- /**
- *
- * delete data from the table
- *
- * @param string $type custom field type
- * @param integer $ownerId the id of record that the custom field data belongs to
- *
- * @return integer returns the number of affected rows
- */
- public function delete($type, $ownerId)
- {
- $adapter = $this->_table->getAdapter();
- $where = $adapter->quoteInto('type = ? AND ', $type) .
- $adapter->quoteInto('owner_id = ?', $ownerId);
- return $this->_table->delete($where);
- }
- }
|