Ejemplo n.º 1
0
 /**
  * Creates data provider instance with search query applied
  *
  * @param array $params
  *
  * @return ActiveDataProvider
  */
 public function search($params)
 {
     $query = Job::find();
     $dataProvider = new ActiveDataProvider(['query' => $query]);
     $this->load($params);
     if (!$this->validate()) {
         // uncomment the following line if you do not want to return any records when validation fails
         // $query->where('0=1');
         return $dataProvider;
     }
     $query->andFilterWhere(['like', '_id', $this->_id])->andFilterWhere(['like', 'title', $this->title])->andFilterWhere(['like', 'company_name', $this->company_name])->andFilterWhere(['like', 'description', $this->description])->andFilterWhere(['like', 'number_vacancy', $this->number_vacancy]);
     return $dataProvider;
 }
Ejemplo n.º 2
0
 public function actionIndexer()
 {
     $jobs = Job::find()->all();
     foreach ($jobs as $job) {
         $jobIndex = new JobIndex();
         $jobIndex->attributes = $job->attributes;
         if (!$jobIndex->save()) {
             die(var_dump($jobIndex->getErrors()));
         } else {
             echo 'Saved :)';
             echo '<br/>';
         }
     }
 }
Ejemplo n.º 3
0
<?php

use yii\grid\GridView;
use yii\data\ActiveDataProvider;
use yii\helpers\Html;
use yii\widgets\ActiveForm;
use common\models\Job;
/* @var $this yii\web\View */
$this->title = 'Jobs';
$this->params['breadcrumbs'][] = $this->title;
$dataProvider = new ActiveDataProvider(['query' => Yii::$app->user->can('admin') ? Job::find() : Job::findByUser(Yii::$app->user->identity->username), 'pagination' => ['pageSize' => 20]]);
?>

<div class="box">
  <div class="box-body">

<?php 
if (Yii::$app->user->can('listResources')) {
    echo GridView::widget(['dataProvider' => $dataProvider, 'columns' => [['class' => 'yii\\grid\\SerialColumn'], ['attribute' => 'description'], ['attribute' => 'firmware', 'value' => function ($model, $index, $widget) {
        return $model->firmware && $model->firmware->description ? $model->firmware->description : '';
    }], ['attribute' => 'scanner', 'value' => function ($model, $index, $widget) {
        return $model->scanner && $model->scanner->name ? $model->scanner->name : '(not set)';
    }], ['attribute' => 'status', 'value' => function ($model, $index, $widget) {
        return $model->getCurrentStatus();
    }], ['attribute' => 'created_at', 'format' => ['datetime', 'php:Y-m-d H:i:s']], ['attribute' => 'updated_at', 'format' => ['datetime', 'php:Y-m-d H:i:s']], ['class' => 'yii\\grid\\ActionColumn', 'template' => '{update} {delete} {view} {schedule} {reset}', 'buttons' => ['delete' => function ($url, $model, $key) {
        if ($model->canDelete()) {
            return Html::a('<span class="glyphicon glyphicon-trash"></span>', ['//job/delete', 'id' => $model->id], ['data-pjax' => 0, 'data-method' => 'post', 'data-confirm' => 'Are you sure you want to delete this item?', 'aria-label' => "Delete", 'title' => 'Delete']);
        }
        return '<span class="glyphicon glyphicon-trash text-muted"></span>';
    }, 'schedule' => function ($url, $model, $key) {
        if ($model->canSchedule()) {
Ejemplo n.º 4
0
 /**
  *
  * @return \yii\db\ActiveQuery
  */
 public function findByUser($id)
 {
     return Job::find()->where(['created_by' => $id]);
 }