从父控制器访问子模型

Access child model from parent controller

我无法在没有用户操作的情况下访问子模型转发器字段进行加载,我在父模型控制器中使用 RelationController 这就是我在父控制器中所做的

class WartaRutin extends Controller
{
    public $implement = ['Backend\Behaviors\ListController',
                         'Backend\Behaviors\FormController',
                         'Backend\Behaviors\RelationController']; 

    public $listConfig = 'config_list.yaml';
    public $formConfig = 'config_form.yaml';
    public $relationConfig = 'config_relation.yaml';      

    public function __construct()
    {
        parent::__construct();

    }

    public function formExtendFieldsBefore($form) {

        if($form->model instanceof Mismaiti\MyWarta\Models\Baptis){

            $iteration8 = $form->fields['peserta']['maxItems'];

            if(is_numeric($iteration8) && $iteration8 > 0) {
            $emptyFields = [];                             
                while($iteration8 > 0) {
                    $emptyFields[] = ['anak' => ' '];                    
                    $iteration8--;
                }
            $form->model->peserta = $emptyFields;
            }

        } 
    } 
}

此子模型字段

fields:
    ...        
    peserta:
        label: 'Peserta Baptis'
        ...
        maxItems: '4'
        ...
    form:
        fields:
            anak:
                label: 'Nama Anak'
                ...
            ortu:
                ...
            alamatbaptis:
                ...

的父模型字段
baptisan:
        label: ''           
        ...
        type: partial
        path: field_baptis
        ...

这是config_relation.yaml

baptisans:
label: Baptisan
view:
    list: $/mismaiti/mywarta/models/baptis/relation_columns.yaml
    toolbarButtons: add|create|remove                  
manage:
    form: $/mismaiti/mywarta/models/baptis/relation_fields.yaml
    list: $/mismaiti/mywarta/models/baptis/relation_columns.yaml 

我定义的父模型中的这种关系

public $belongsToMany = [
     'baptisans' => [
        Baptis::class,'table' => 'mismaiti_mywarta_rutbaptis'
     ]
];

子模型中的关系

public $belongsToMany = [
    'wartarutin' => [
        WartaRutin::class,'table' => 'mismaiti_mywarta_rutbaptis'            
    ]

];

在我使用 RelationController 之前,@HardikSatasiya 分享的这个方法工作正常,转发器字段根据定义的 maxItems 自动加载,无需用户操作。 有人可以告诉我如何解决这个问题吗?

您可以将此代码添加到您的 WartaRutin controller 以添加那些空字段

class WartaRutin extends Controller {

    ...

    public function relationExtendManageWidget($widget, $field, $model)
    {
        // we will do it for this model only
        if ($widget->model instanceof \Mismaiti\MyWarta\Models\Baptis) {
            // fetch max item
            $iteration8 = $widget->fields['peserta']['maxItems'];

            // use loop and add those empty fields
            if(is_numeric($iteration8) && $iteration8 > 0) {

                $emptyFields = [];                             
                while($iteration8 > 0) {
                    $emptyFields[] = ['anak' => ' '];                    
                    $iteration8--;
                }
            $widget->model->peserta = $emptyFields;
        }
    }

    ...

试试这个,它一定对你有用

如有任何疑问或无法正常工作,请发表评论。