mirror of
https://github.com/Karaka-Management/oms-Attribute.git
synced 2026-01-11 16:48:41 +00:00
update
This commit is contained in:
parent
e696bc37a4
commit
b763ef96c6
|
|
@ -37,29 +37,42 @@ trait ApiAttributeTraitController
|
|||
* Method to create item attribute from request.
|
||||
*
|
||||
* @param RequestAbstract $request Request
|
||||
* @param AttributeType $type Attribute type
|
||||
*
|
||||
* @return Attribute
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
private function createAttributeFromRequest(RequestAbstract $request) : Attribute
|
||||
private function createAttributeFromRequest(RequestAbstract $request, AttributeType $type) : Attribute
|
||||
{
|
||||
$attribute = new Attribute();
|
||||
$attribute->ref = (int) $request->getData('ref');
|
||||
$attribute->type = new NullAttributeType((int) $request->getData('type'));
|
||||
$new = new Attribute();
|
||||
$new->ref = (int) $request->getData('ref');
|
||||
$new->type = $type;
|
||||
|
||||
if ($request->hasData('value')) {
|
||||
$attribute->value = new NullAttributeValue((int) $request->getData('value'));
|
||||
if ($new->type->custom) {
|
||||
if ($request->hasData('value_id')) {
|
||||
$new->value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
} else {
|
||||
// @todo: consider to check if custom value already exist and just reference the id? Problematic if content of id gets changed.
|
||||
$new->value = new AttributeValue();
|
||||
$new->value->setValue($request->getData('value'), $new->type->datatype);
|
||||
}
|
||||
} else {
|
||||
$newRequest = clone $request;
|
||||
$newRequest->setData('value', $request->getData('custom'), true);
|
||||
// @todo: fix by only accepting the value id to be used
|
||||
// this is a workaround for now because the front end doesn't allow to dynamically show default values.
|
||||
$value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
|
||||
$value = $this->createAttributeValueFromRequest($newRequest, $attribute->type);
|
||||
// Couldn't find matching default value
|
||||
/*
|
||||
if ($value->id === 0) {
|
||||
return $new;
|
||||
}
|
||||
*/
|
||||
|
||||
$attribute->value = $value;
|
||||
$new->value = $value;
|
||||
}
|
||||
|
||||
return $attribute;
|
||||
return $new;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
@ -75,7 +88,7 @@ trait ApiAttributeTraitController
|
|||
{
|
||||
$val = [];
|
||||
if (($val['type'] = !$request->hasData('type'))
|
||||
|| ($val['value'] = (!$request->hasData('value') && !$request->hasData('custom')))
|
||||
|| ($val['value'] = (!$request->hasData('value') && !$request->hasData('value_id')))
|
||||
) {
|
||||
return $val;
|
||||
}
|
||||
|
|
@ -267,21 +280,24 @@ trait ApiAttributeTraitController
|
|||
public function updateAttributeFromRequest(RequestAbstract $request, Attribute $new) : Attribute
|
||||
{
|
||||
if ($new->type->custom) {
|
||||
if ($request->hasData('value')) {
|
||||
$new->value = new NullAttributeValue((int) $request->getData('value'));
|
||||
if ($request->hasData('value_id')) {
|
||||
$new->value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
} else {
|
||||
// @todo: consider to check if custom value already exist and just reference the id? Problematic if content of id gets changed.
|
||||
$new->value = new AttributeValue();
|
||||
$new->value->setValue($request->getData('custom'), $new->type->datatype);
|
||||
$new->value->setValue($request->getData('value'), $new->type->datatype);
|
||||
}
|
||||
} else {
|
||||
// @todo: fix by only accepting the value id to be used
|
||||
// this is a workaround for now because the front end doesn't allow to dynamically show default values.
|
||||
$value = $new->type->getDefaultByValue($request->getData('value'));
|
||||
if ($request->hasData('value_id')) {
|
||||
// @todo: check if value_id part of default values
|
||||
$value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
} else {
|
||||
$value = $new->type->getDefaultByValue($request->getData('value'));
|
||||
|
||||
// Couldn't find matching default value
|
||||
if ($value->id === 0) {
|
||||
return $new;
|
||||
// Couldn't find matching default value
|
||||
if ($value->id === 0) {
|
||||
return $new;
|
||||
}
|
||||
}
|
||||
|
||||
$new->value = $value;
|
||||
|
|
@ -303,7 +319,7 @@ trait ApiAttributeTraitController
|
|||
{
|
||||
$val = [];
|
||||
if (($val['id'] = !$request->hasData('id'))
|
||||
|| ($val['value'] = (!$request->hasData('value') && !$request->hasData('custom')))
|
||||
|| ($val['value'] = (!$request->hasData('value') && !$request->hasData('value_id')))
|
||||
) {
|
||||
return $val;
|
||||
}
|
||||
|
|
|
|||
|
|
@ -62,7 +62,7 @@ final class ApiController extends Controller
|
|||
return;
|
||||
}
|
||||
|
||||
$attribute = $this->createAttributeFromRequest($request);
|
||||
$attribute = $this->createAttributeFromRequest($request, new NullAttributeType((int) $request->getData('type')));
|
||||
$this->createModel($request->header->account, $attribute, AttributeMapper::class, 'attribute', $request->getOrigin());
|
||||
|
||||
$response->header->status = RequestStatusCode::R_400;
|
||||
|
|
@ -73,29 +73,43 @@ final class ApiController extends Controller
|
|||
* Method to create item attribute from request.
|
||||
*
|
||||
* @param RequestAbstract $request Request
|
||||
* @param AttributeType $type Attribute type
|
||||
*
|
||||
* @return Attribute
|
||||
*
|
||||
* @since 1.0.0
|
||||
*/
|
||||
private function createAttributeFromRequest(RequestAbstract $request) : Attribute
|
||||
private function createAttributeFromRequest(RequestAbstract $request, AttributeType $type) : Attribute
|
||||
{
|
||||
$attribute = new Attribute();
|
||||
$attribute->ref = (int) $request->getData('ref');
|
||||
$attribute->type = new NullAttributeType((int) $request->getData('type'));
|
||||
$new = new Attribute();
|
||||
$new->ref = (int) $request->getData('ref');
|
||||
$new->type = $type;
|
||||
|
||||
if ($request->hasData('value')) {
|
||||
$attribute->value = new NullAttributeValue((int) $request->getData('value'));
|
||||
if ($new->type->custom) {
|
||||
if ($request->hasData('value_id')) {
|
||||
$new->value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
} else {
|
||||
// @todo: consider to check if custom value already exist and just reference the id? Problematic if content of id gets changed.
|
||||
$new->value = new AttributeValue();
|
||||
$new->value->setValue($request->getData('value'), $new->type->datatype);
|
||||
}
|
||||
} else {
|
||||
$newRequest = clone $request;
|
||||
$newRequest->setData('value', $request->getData('custom'), true);
|
||||
if ($request->hasData('value_id')) {
|
||||
// @todo: check if value_id part of default values
|
||||
$value = new NullAttributeValue((int) $request->getData('value_id'));
|
||||
} else {
|
||||
$value = $new->type->getDefaultByValue($request->getData('value'));
|
||||
|
||||
$value = $this->createAttributeValueFromRequest($newRequest);
|
||||
// Couldn't find matching default value
|
||||
if ($value->id === 0) {
|
||||
return $new;
|
||||
}
|
||||
}
|
||||
|
||||
$attribute->value = $value;
|
||||
$new->value = $value;
|
||||
}
|
||||
|
||||
return $attribute;
|
||||
return $new;
|
||||
}
|
||||
|
||||
/**
|
||||
|
|
|
|||
|
|
@ -62,6 +62,14 @@ class AttributeView extends View
|
|||
*/
|
||||
public string $apiUri = '';
|
||||
|
||||
/**
|
||||
* Reference id
|
||||
*
|
||||
* @var string
|
||||
* @since 1.0.0
|
||||
*/
|
||||
public int $refId = 0;
|
||||
|
||||
/**
|
||||
* {@inheritdoc}
|
||||
*/
|
||||
|
|
@ -81,6 +89,7 @@ class AttributeView extends View
|
|||
$this->attributeTypes = $data[1];
|
||||
$this->units = $data[2];
|
||||
$this->apiUri = $data[3];
|
||||
$this->refId = $data[4];
|
||||
|
||||
return parent::render();
|
||||
}
|
||||
|
|
|
|||
|
|
@ -33,6 +33,8 @@ $l11n = $this->data['defaultlocalization'] ?? new NullLocalization();
|
|||
data-add-tpl="#attributeTable tbody .oms-add-tpl-attribute">
|
||||
<div class="portlet-head"><?= $this->getHtml('Attribute', 'Attribute', 'Backend'); ?></div>
|
||||
<div class="portlet-body">
|
||||
<input type="hidden" id="iAttributeRef" name="ref" value="<?= $this->refId ?>" disabled>
|
||||
|
||||
<div class="form-group">
|
||||
<label for="iAttributeId"><?= $this->getHtml('ID', '0', '0'); ?></label>
|
||||
<input type="text" id="iAttributeId" name="id" data-tpl-text="/id" data-tpl-value="/id" disabled>
|
||||
|
|
@ -48,6 +50,7 @@ $l11n = $this->data['defaultlocalization'] ?? new NullLocalization();
|
|||
</select>
|
||||
</div>
|
||||
|
||||
<!-- @todo: implement
|
||||
<div class="form-group">
|
||||
<label for="iAttributesUnit"><?= $this->getHtml('Unit', 'Attribute', 'Backend'); ?></label>
|
||||
<select id="iAttributesUnit" name="unit" data-tpl-text="/unit" data-tpl-value="/unit">
|
||||
|
|
@ -58,6 +61,7 @@ $l11n = $this->data['defaultlocalization'] ?? new NullLocalization();
|
|||
<?php endforeach; ?>
|
||||
</select>
|
||||
</div>
|
||||
-->
|
||||
|
||||
<div class="form-group">
|
||||
<label for="iAttributeValue"><?= $this->getHtml('Value', 'Attribute', 'Backend'); ?></label>
|
||||
|
|
@ -67,7 +71,7 @@ $l11n = $this->data['defaultlocalization'] ?? new NullLocalization();
|
|||
<div class="portlet-foot">
|
||||
<input id="bAttributeAdd" formmethod="put" type="submit" class="add-form" value="<?= $this->getHtml('Add', '0', '0'); ?>">
|
||||
<input id="bAttributeSave" formmethod="post" type="submit" class="save-form hidden button save" value="<?= $this->getHtml('Update', '0', '0'); ?>">
|
||||
<input type="submit" class="cancel-form hidden button close" value="<?= $this->getHtml('Cancel', '0', '0'); ?>">
|
||||
<input id="bAttributeCancel" type="submit" class="cancel-form hidden button close" value="<?= $this->getHtml('Cancel', '0', '0'); ?>">
|
||||
</div>
|
||||
</form>
|
||||
</section>
|
||||
|
|
@ -91,7 +95,7 @@ $l11n = $this->data['defaultlocalization'] ?? new NullLocalization();
|
|||
<td><?= $this->getHtml('Unit', 'Attribute', 'Backend'); ?><i class="sort-asc fa fa-chevron-up"></i><i class="sort-desc fa fa-chevron-down"></i>
|
||||
<tbody>
|
||||
<template class="oms-add-tpl-attribute">
|
||||
<tr data-id="" draggable="false">
|
||||
<tr class="animated medium-duration greenCircleFade" data-id="" draggable="false">
|
||||
<td>
|
||||
<i class="fa fa-cogs btn update-form"></i>
|
||||
<input id="attributeTable-remove-0" type="checkbox" class="hidden">
|
||||
|
|
|
|||
Loading…
Reference in New Issue
Block a user