2011-02-09 13 views
1

マイHotelAddressモデル:条件検証

<?php 

class HotelAddress extends AppModel { 
    var $name = 'HotelAddress'; 
    var $belongsTo = array(
     'Hotel' => array(
      'className' => 'Hotel' 
     ) 
    ); 

    var $validate = array(
     'address' => array(
      'rule' => 'notEmpty', 
     ) 
    ); 

マイHotelModel

<?php 

class Hotel extends AppModel { 
    var $name = 'Hotel'; 
    var $hasAndBelongsToMany = array(
     'HotelCategory' => array(
      'className' => 'HotelCategory' 
     ) 
    ); 
    var $belongsTo = array(
     'Page' => array(
      'className' => 'Page' 
     ) 
    ); 
    var $hasMany = array(
     'HotelAddress' => array(
      'className' => 'HotelAddress', 
      'dependent' => TRUE 
     ), 
     'HotelPhone' => array(
      'className' => 'HotelPhone', 
      'dependent' => TRUE 
     ) 
    ); 

マイビュー:

<div id="main"> 
     <h2>Add Hotel</h2> 
     <?php echo $this->Session->flash();?> 
     <div> 
     <?php 
     echo $this->Form->create('Hotel'); 
     echo $this->Form->input('Hotel.name'); 
     echo $this->Form->input('HotelCategory', array('options' => $hotel_categories, 'multiple' => 'checkbox')); 
     echo $this->Form->input('HotelAddress.0.address'); 
     echo $this->Form->input('HotelAddress.1.address'); 
     echo $this->Form->input('HotelAddress.2.address'); 
     echo $this->Form->input('HotelPhone.0.phone'); 
     echo $this->Form->input('Page.meta_keywords'); 
     echo $this->Form->input('Page.meta_description'); 

     echo $this->Form->end('Save Hotel'); 
     ?> 
     </div> 
<!-- main ends --> 
</div> 

私の問題は、私は他のHotelAddress ESを検証する必要がないということです。ユーザーが少なくとも1つのアドレスを入力した場合は、検証する必要があります。しかし、彼が一杯になっていなければ、エラーが表示されるはずです。

私はbeforeSaveメソッドにコードを追加する必要があると考えていますが、これを行うには何が必要かについては考えていません。

更新:

私は今1が利用可能な場合は他のアドレスの存在を検証しないことによって動作HotelAddressモデルでこれを持っています。しかし、それはまだ保存します。

var $existing_address = FALSE; 
var $validate = array(
    'address' => array(
     'rule' => 'checkOnce', 
    ) 
); 

function checkOnce($check) { 
    if (isset($this->data['HotelAddress']['address'])) { 
     if (! empty($this->data['HotelAddress']['address'])) { 
      return $this->existing_address = TRUE; 
     } else { 
      unset($this->data['HotelAddress']['address']); 
      return $this->existing_address; 
     } 
    } 
    return $this->existing_address; 
} 

答えて

1

私は単にsaveを呼び出す前に、コントローラにこれでいいと思う:

if (empty($this->data['HotelAddress'][1]['address'])) { 
    unset($this->data['HotelAddress'][1]['address']); 
} 
if (empty($this->data['HotelAddress'][2]['address'])) { 
    unset($this->data['HotelAddress'][2]['address']); 
} 
+0

これはほとんど私がやったことです。私はアドレスがjavascriptによって生成されるので、私はループを行いましたが、どれくらいの数があるかはわかりません。 –

1

なぜ検証をモデルから外してコード化してみませんか?あなたがの多くを失うことになるので、私はbeforeSaveにチェックをしないだろう

if($this->validateForm($this->data)) 
{ 
    $this->Hotel->saveAll($this->data); 
} 
+0

各 'address'が1時間を検証しているので、それはbeforeSaveでそれを行うには実際には困難です。設定を解除して他の 'アドレス 'を調べる'アドレス 'を追跡することは困難でした。 +1十分に近い。 –

1

:beforeSave方法でたり、保存方法、すなわちを呼び出す前に呼び出されるメソッドでは、検証を行うことができますケーキはフォームなどで検証マジックを作りました。

モデルにcustom validationメソッドを作成し、booleanを返すことで、チェックが成功したことを示すことができます。そこにはモデルのデータに$this->dataでアクセスし、少なくとも1つのアドレスが存在するかどうか確認できます。

+0

はい。これは私の他の選択肢でした。 –