code for review update
This commit is contained in:
parent
53e43b7bbf
commit
5193e4f5b5
15 changed files with 262 additions and 37 deletions
|
@ -51,16 +51,16 @@ class EditorController extends Controller
|
|||
* @param int $id
|
||||
* @return \Illuminate\View\View
|
||||
*/
|
||||
public function accept($id): View
|
||||
public function receive($id): View
|
||||
{
|
||||
$dataset = Dataset::with('user:id,login')->findOrFail($id);
|
||||
|
||||
return view('workflow.editor.accept', [
|
||||
return view('workflow.editor.receive', [
|
||||
'dataset' => $dataset,
|
||||
]);
|
||||
}
|
||||
|
||||
public function acceptUpdate(Request $request, $id)
|
||||
public function receiveUpdate(Request $request, $id)
|
||||
{
|
||||
$dataset = Dataset::findOrFail($id);
|
||||
|
||||
|
@ -191,6 +191,7 @@ class EditorController extends Controller
|
|||
'reviewers' => $reviewers,
|
||||
]);
|
||||
}
|
||||
|
||||
public function approveUpdate(Request $request, $id)
|
||||
{
|
||||
// $dataset = Dataset::findOrFail($id);
|
||||
|
|
|
@ -32,6 +32,111 @@ class ReviewController extends Controller
|
|||
->where('server_state', 'approved')
|
||||
->where('reviewer_id', $userId)
|
||||
->get();
|
||||
return view('workflow.review.index', compact('datasets'));
|
||||
return view('workflow.review.index', [
|
||||
'datasets' => $datasets
|
||||
]);
|
||||
}
|
||||
|
||||
/**
|
||||
* Display the specified resource.
|
||||
*
|
||||
* @param int $id
|
||||
* @return \Illuminate\View\View
|
||||
*/
|
||||
public function review($id): View
|
||||
{
|
||||
$dataset = Dataset::with('user:id,login')->findOrFail($id);
|
||||
$dataset->fetchValues();
|
||||
$fieldnames = $dataset->describe();
|
||||
$fields = [];
|
||||
foreach ($fieldnames as $fieldName) {
|
||||
$field = $dataset->getField($fieldName);
|
||||
$modelClass = $field->getValueModelClass();
|
||||
$fieldValues = $field->getValue($fieldName);
|
||||
$value = "";
|
||||
|
||||
if (null === $modelClass) {
|
||||
$value = preg_replace('/[\x00-\x08\x0B\x0C\x0E-\x1F\x7F]/', "\xEF\xBF\xBD ", $fieldValues);
|
||||
} else {
|
||||
// $fieldName = $field->getName();
|
||||
|
||||
|
||||
if (!is_array($fieldValues)) {
|
||||
$fieldValues = array($fieldValues);
|
||||
}
|
||||
|
||||
foreach ($fieldValues as $fieldValue) {
|
||||
// if a field has no value then is nothing more to do
|
||||
// TODO maybe must be there an other solution
|
||||
// FIXME remove code duplication (duplicates Opus_Model_Xml_Version*)
|
||||
if (is_null($fieldValue)) {
|
||||
continue;
|
||||
}
|
||||
|
||||
if ($fieldValue instanceof \Illuminate\Database\Eloquent\Model) {
|
||||
//$this->_mapModelAttributes($value, $dom, $childNode);
|
||||
$attributes = array_keys($fieldValue->getAttributes());
|
||||
foreach ($attributes as $property_name) {
|
||||
$fieldName = self::convertColumnToFieldname($property_name);
|
||||
// $field = new Field($fieldName);
|
||||
$fieldval = $fieldValue->{$property_name};
|
||||
$value = $value . $fieldName . ": " . $fieldval . "; ";
|
||||
}
|
||||
} elseif ($fieldValue instanceof \Carbon\Carbon) {
|
||||
$value = $value . " Year " . $fieldValue->year;
|
||||
$value = $value . " Month " . $fieldValue->month;
|
||||
$value = $value . " Day " . $fieldValue->day;
|
||||
$value = $value . " Hour " . $fieldValue->hour;
|
||||
$value = $value . " Minute " . $fieldValue->minute;
|
||||
$value = $value . " Second " . $fieldValue->second;
|
||||
$value = $value . " UnixTimestamp " . $fieldValue->timestamp;
|
||||
$value = $value . " Timezone " . $fieldValue->tzName;
|
||||
} elseif (is_array($fieldValue)) {
|
||||
$attributes = $fieldValue;
|
||||
$value = "<ul>";
|
||||
foreach ($attributes as $property_name => $subValue) {
|
||||
// $fieldName = $property_name;
|
||||
// $fieldval = $subValue;
|
||||
$value = $value . "<li>" . $property_name . " : " . $subValue . "</li>";
|
||||
}
|
||||
$value = $value . "</ul>";
|
||||
}
|
||||
}
|
||||
}
|
||||
if ($value != "") {
|
||||
$fields[$fieldName] = $value;
|
||||
}
|
||||
}
|
||||
|
||||
return view('workflow.review.review', [
|
||||
'dataset' => $dataset,
|
||||
'fields' => $fields
|
||||
]);
|
||||
}
|
||||
|
||||
|
||||
public function reviewUpdate(Request $request, $id)
|
||||
{
|
||||
$dataset = Dataset::findOrFail($id);
|
||||
|
||||
|
||||
|
||||
$input = $request->all();
|
||||
$input['server_state'] = 'reviewed';
|
||||
|
||||
if ($dataset->update($input)) {
|
||||
// event(new PageUpdated($page));
|
||||
return redirect()
|
||||
->route('publish.workflow.review.index')
|
||||
->with('flash_message', 'You have successfully reviewed one dataset!');
|
||||
}
|
||||
throw new GeneralException(trans('exceptions.publish.review.update_error'));
|
||||
}
|
||||
|
||||
//snakeToCamel
|
||||
public static function convertColumnToFieldname($columnname)
|
||||
{
|
||||
//return lcfirst(str_replace(' ', '', ucwords(str_replace('_', ' ', $columnname))));
|
||||
return ucwords(str_replace(['-', '_'], ' ', $columnname));
|
||||
}
|
||||
}
|
||||
|
|
|
@ -25,7 +25,8 @@ class SubmitController extends Controller
|
|||
|
||||
$builder = Dataset::query();
|
||||
$myDatasets = $builder
|
||||
->whereIn('server_state', ['inprogress', 'released', 'editor_accepted', 'approved'])
|
||||
->orderBy('server_state')
|
||||
->whereIn('server_state', ['inprogress', 'released', 'editor_accepted', 'approved', 'reviewed'])
|
||||
->where('account_id', $user_id)
|
||||
->with('user:id,login')
|
||||
->get();
|
||||
|
|
Loading…
Add table
editor.link_modal.header
Reference in a new issue