Skip to content

Commit

Permalink
Merge pull request #74 from anavel/feature/images-from-uploads
Browse files Browse the repository at this point in the history
Feature/images from uploads
  • Loading branch information
ablunier authored Nov 14, 2016
2 parents a15e691 + 6cc863d commit 5fe226c
Show file tree
Hide file tree
Showing 13 changed files with 324 additions and 138 deletions.
1 change: 0 additions & 1 deletion .travis.yml
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,6 @@ language: php
php:
- 5.5
- 5.6
- 7.0
- hhvm

before_script:
Expand Down
127 changes: 69 additions & 58 deletions src/Abstractor/Eloquent/Model.php
Original file line number Diff line number Diff line change
@@ -1,23 +1,24 @@
<?php

namespace Anavel\Crud\Abstractor\Eloquent;

use ANavallaSuiza\Laravel\Database\Contracts\Dbal\AbstractionLayer;
use Anavel\Crud\Abstractor\ConfigurationReader;
use Anavel\Crud\Abstractor\Eloquent\Traits\HandleFiles;
use Anavel\Crud\Abstractor\Eloquent\Traits\ModelFields;
use Anavel\Crud\Abstractor\Exceptions\AbstractorException;
use Anavel\Crud\Contracts\Abstractor\Field as FieldContract;
use Anavel\Crud\Contracts\Abstractor\FieldFactory as FieldFactoryContract;
use Anavel\Crud\Contracts\Abstractor\Model as ModelAbstractorContract;
use Anavel\Crud\Abstractor\ConfigurationReader;
use Anavel\Crud\Contracts\Abstractor\Relation;
use Anavel\Crud\Contracts\Abstractor\RelationFactory as RelationFactoryContract;
use Anavel\Crud\Contracts\Form\Generator as FormGenerator;
use App;
use Anavel\Crud\Contracts\Abstractor\FieldFactory as FieldFactoryContract;
use ANavallaSuiza\Laravel\Database\Contracts\Dbal\AbstractionLayer;
use FormManager\ElementInterface;
use Illuminate\Database\Eloquent\Model as LaravelModel;
use App;
use Anavel\Crud\Contracts\Form\Generator as FormGenerator;
use Anavel\Crud\Abstractor\Exceptions\AbstractorException;
use Illuminate\Http\Request;
use Illuminate\Support\Collection;
use League\Flysystem\Adapter\Local;
use League\Flysystem\Filesystem;

class Model implements ModelAbstractorContract
{
Expand All @@ -37,12 +38,18 @@ class Model implements ModelAbstractorContract
protected $name;
protected $instance;

/**
* @var bool
*/
protected $mustDeleteFilesInFilesystem;

public function __construct(
$config,
AbstractionLayer $dbal,
RelationFactoryContract $relationFactory,
FieldFactoryContract $fieldFactory,
FormGenerator $generator
FormGenerator $generator,
$mustDeleteFilesInFilesystem = false
) {
if (is_array($config)) {
$this->model = $config['model'];
Expand All @@ -56,6 +63,7 @@ public function __construct(
$this->relationFactory = $relationFactory;
$this->fieldFactory = $fieldFactory;
$this->generator = $generator;
$this->mustDeleteFilesInFilesystem = $mustDeleteFilesInFilesystem;
}

public function setSlug($slug)
Expand Down Expand Up @@ -135,10 +143,10 @@ public function getColumns($action, $withForeignKeys = false)
}

$customDisplayedColumns = $this->getConfigValue($action, 'display');
$customHiddenColumns = $this->getConfigValue($action, 'hide') ?: [];
$customHiddenColumns = $this->getConfigValue($action, 'hide') ? : [];

$columns = [];
if (!empty($customDisplayedColumns) && is_array($customDisplayedColumns)) {
$columns = array();
if (! empty($customDisplayedColumns) && is_array($customDisplayedColumns)) {
foreach ($customDisplayedColumns as $customColumn) {
if (strpos($customColumn, '.')) {
$customColumnRelation = explode('.', $customColumn);
Expand All @@ -153,14 +161,14 @@ public function getColumns($action, $withForeignKeys = false)

$relationColumns = $nestedRelation->getModelAbstractor()->getColumns($action);

if (!array_key_exists($customColumnRelationFieldName, $relationColumns)) {
throw new AbstractorException('Column '.$customColumnRelationFieldName.' does not exist on relation '.implode('.', $customColumnRelation).' of model '.$this->getModel());
if (! array_key_exists($customColumnRelationFieldName, $relationColumns)) {
throw new AbstractorException("Column " . $customColumnRelationFieldName . " does not exist on relation " . implode('.', $customColumnRelation) . " of model " . $this->getModel());
}

$columns[$customColumn] = $relationColumns[$customColumnRelationFieldName];
} else {
if (!array_key_exists($customColumn, $tableColumns)) {
throw new AbstractorException('Column '.$customColumn.' does not exist on '.$this->getModel());
if (! array_key_exists($customColumn, $tableColumns)) {
throw new AbstractorException("Column " . $customColumn . " does not exist on " . $this->getModel());
}

$columns[$customColumn] = $tableColumns[$customColumn];
Expand All @@ -187,8 +195,8 @@ protected function getNestedRelation(Model $modelAbstractor, $relationName)
{
$relations = $modelAbstractor->getRelations();

if (!$relations->has($relationName)) {
throw new AbstractorException('Relation '.$relationName.' not configured on '.$modelAbstractor->getModel());
if (! $relations->has($relationName)) {
throw new AbstractorException("Relation " . $relationName . " not configured on " . $modelAbstractor->getModel());
}

$relation = $relations->get($relationName);
Expand All @@ -209,15 +217,15 @@ public function getRelations()

$relations = collect();

if (!empty($configRelations)) {
if (! empty($configRelations)) {
foreach ($configRelations as $relationName => $configRelation) {
if (is_int($relationName)) {
$relationName = $configRelation;
}

$config = [];
if ($configRelation !== $relationName) {
if (!is_array($configRelation)) {
if (! is_array($configRelation)) {
$config['type'] = $configRelation;
} else {
$config = $configRelation;
Expand All @@ -232,7 +240,7 @@ public function getRelations()
$secondaryRelations = $relation->getSecondaryRelations();


if (!$secondaryRelations->isEmpty()) {
if (! $secondaryRelations->isEmpty()) {
$relations->put(
$relationName,
collect(['relation' => $relation, 'secondaryRelations' => $secondaryRelations])
Expand All @@ -248,18 +256,16 @@ public function getRelations()

/**
* @param string|null $arrayKey
*
* @throws AbstractorException
*
* @return array
* @throws AbstractorException
*/
public function getListFields($arrayKey = 'main')
{
$columns = $this->getColumns('list');

$fieldsPresentation = $this->getConfigValue('fields_presentation') ?: [];
$fieldsPresentation = $this->getConfigValue('fields_presentation') ? : [];

$fields = [];
$fields = array();
foreach ($columns as $name => $column) {
$presentation = null;
if (array_key_exists($name, $fieldsPresentation)) {
Expand All @@ -271,7 +277,7 @@ public function getListFields($arrayKey = 'main')
'presentation' => $presentation,
'form_type' => null,
'validation' => null,
'functions' => null,
'functions' => null
];

$fields[$arrayKey][] = $this->fieldFactory
Expand All @@ -285,18 +291,16 @@ public function getListFields($arrayKey = 'main')

/**
* @param string|null $arrayKey
*
* @throws AbstractorException
*
* @return array
* @throws AbstractorException
*/
public function getDetailFields($arrayKey = 'main')
{
$columns = $this->getColumns('detail');

$fieldsPresentation = $this->getConfigValue('fields_presentation') ?: [];
$fieldsPresentation = $this->getConfigValue('fields_presentation') ? : [];

$fields = [];
$fields = array();
foreach ($columns as $name => $column) {
$presentation = null;
if (array_key_exists($name, $fieldsPresentation)) {
Expand All @@ -308,7 +312,7 @@ public function getDetailFields($arrayKey = 'main')
'presentation' => $presentation,
'form_type' => null,
'validation' => null,
'functions' => null,
'functions' => null
];

$fields[$arrayKey][] = $this->fieldFactory
Expand All @@ -321,22 +325,20 @@ public function getDetailFields($arrayKey = 'main')
}

/**
* @param bool|null $withForeignKeys
* @param bool|null $withForeignKeys
* @param string|null $arrayKey
*
* @throws AbstractorException
*
* @return array
* @throws AbstractorException
*/
public function getEditFields($withForeignKeys = false, $arrayKey = 'main')
{
$columns = $this->getColumns('edit', $withForeignKeys);

$this->readConfig('edit');

$fields = [];
$fields = array();
foreach ($columns as $name => $column) {
if (!in_array($name, $this->getReadOnlyColumns())) {
if (! in_array($name, $this->getReadOnlyColumns())) {
$presentation = null;
if (array_key_exists($name, $this->fieldsPresentation)) {
$presentation = $this->fieldsPresentation[$name];
Expand All @@ -347,7 +349,7 @@ public function getEditFields($withForeignKeys = false, $arrayKey = 'main')
'presentation' => $presentation,
'form_type' => null,
'validation' => null,
'functions' => null,
'functions' => null
];

$config = $this->setConfig($config, $name);
Expand All @@ -357,24 +359,24 @@ public function getEditFields($withForeignKeys = false, $arrayKey = 'main')
->setConfig($config)
->get();

if (!empty($this->instance) && !empty($this->instance->getAttribute($name))) {
if (! empty($this->instance) && ! empty($this->instance->getAttribute($name))) {
$field->setValue($this->instance->getAttribute($name));
}

$fields[$arrayKey][$name] = $field;

if (!empty($config['form_type']) && $config['form_type'] === 'file') {
if (! empty($config['form_type']) && $config['form_type'] === 'file') {
$field = $this->fieldFactory
->setColumn($column)
->setConfig([
'name' => $name.'__delete',
'name' => $name . '__delete',
'presentation' => null,
'form_type' => 'checkbox',
'no_validate' => true,
'functions' => null,
'functions' => null
])
->get();
$fields[$arrayKey][$name.'__delete'] = $field;
$fields[$arrayKey][$name . '__delete'] = $field;
}
}
}
Expand All @@ -384,7 +386,7 @@ public function getEditFields($withForeignKeys = false, $arrayKey = 'main')

protected function getReadOnlyColumns()
{
$columns = [LaravelModel::CREATED_AT, LaravelModel::UPDATED_AT, 'deleted_at'];
$columns = [LaravelModel::CREATED_AT, LaravelModel::UPDATED_AT];

$columns[] = $this->dbal->getModel()->getKeyName();

Expand All @@ -393,7 +395,6 @@ protected function getReadOnlyColumns()

/**
* @param string $action
*
* @return ElementInterface
*/
public function getForm($action)
Expand All @@ -406,14 +407,13 @@ public function getForm($action)

/**
* @param array $requestForm
*
* @return mixed
*/
public function persist(Request $request)
{
/** @var \ANavallaSuiza\Laravel\Database\Contracts\Manager\ModelManager $modelManager */
$modelManager = App::make('ANavallaSuiza\Laravel\Database\Contracts\Manager\ModelManager');
if (!empty($this->instance)) {
if (! empty($this->instance)) {
$item = $this->instance;
} else {
$item = $modelManager->getModelInstance($this->getModel());
Expand All @@ -425,10 +425,10 @@ public function persist(Request $request)
return;
}

if (!empty($fields['main'])) {
if (! empty($fields['main'])) {
$skip = null;
foreach ($fields['main'] as $key => $field) {
/* @var FieldContract $field */
/** @var FieldContract $field */
if ($skip === $key) {
$skip = null;
continue;
Expand All @@ -449,21 +449,21 @@ public function persist(Request $request)
}

if (get_class($field->getFormField()) === \FormManager\Fields\File::class) {
$handleResult = $this->handleField($request, $item, $fields['main'], 'main', $fieldName);
if (!empty($handleResult['skip'])) {
$handleResult = $this->handleField($request, $item, $fields['main'], 'main', $fieldName,$this->mustDeleteFilesInFilesystem);
if (! empty($handleResult['skip'])) {
$skip = $handleResult['skip'];
}
if (!empty($handleResult['requestValue'])) {
if (! empty($handleResult['requestValue'])) {
$requestValue = $handleResult['requestValue'];
}
}


if (!$field->saveIfEmpty() && empty($requestValue)) {
if (! $field->saveIfEmpty() && empty($requestValue)) {
continue;
}

if (!empty($requestValue) || (empty($requestValue) && !empty($item->getAttribute($fieldName)))) {
if (! empty($requestValue) || (empty($requestValue) && ! empty($item->getAttribute($fieldName)))) {
$item->setAttribute(
$fieldName,
$field->applyFunctions($requestValue)
Expand All @@ -477,12 +477,15 @@ public function persist(Request $request)
$this->setInstance($item);


if (!empty($relations = $this->getRelations())) {
if (! empty($relations = $this->getRelations())) {
foreach ($relations as $relationKey => $relation) {
if ($relation instanceof Collection) {
$input = $request->input($relationKey);
$relation->get('relation')->persist($input, $request);
/** @var $relationInstance Relation */
$relationInstance = $relation->get('relation');
$relationInstance->persist($input, $request);
} else {
/** @var $relation Relation */
$relation->persist($request->input($relationKey), $request);
}
}
Expand Down Expand Up @@ -531,7 +534,7 @@ public function getFieldValue($item, $fieldName)
}

if (empty($relation)) {
return;
return null;
}

if ($relation instanceof Collection) {
Expand All @@ -553,4 +556,12 @@ public function getFieldValue($item, $fieldName)

return $value;
}

/**
* @return boolean
*/
public function mustDeleteFilesInFilesystem()
{
return $this->mustDeleteFilesInFilesystem;
}
}
Loading

0 comments on commit 5fe226c

Please sign in to comment.