mirror of
https://github.com/Karaka-Management/oms-ItemManagement.git
synced 2026-02-12 10:18:40 +00:00
fix bugs
This commit is contained in:
parent
7c5c640590
commit
d8d99d4fa1
|
|
@ -19,7 +19,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Attributes",
|
"name": "Attributes",
|
||||||
"uri": "{/base}/item/attribute/type/list?{?}",
|
"uri": "{/base}/item/attribute/type/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -33,7 +33,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Types",
|
"name": "Types",
|
||||||
"uri": "{/base}/item/attribute/type/list?{?}",
|
"uri": "{/base}/item/attribute/type/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -48,7 +48,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/item/attribute/type/create?{?}",
|
"uri": "{/base}/item/attribute/type/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -65,7 +65,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Items",
|
"name": "Items",
|
||||||
"uri": "{/base}/item/list?{?}",
|
"uri": "{/base}/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -79,7 +79,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/item/list?{?}",
|
"uri": "{/base}/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -93,7 +93,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/item/view?{?}",
|
"uri": "{/base}/item/view",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -110,7 +110,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/item/create?{?}",
|
"uri": "{/base}/item/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -127,7 +127,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Materials",
|
"name": "Materials",
|
||||||
"uri": "{/base}/item/material/list?{?}",
|
"uri": "{/base}/item/material/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -141,7 +141,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/item/material/list?{?}",
|
"uri": "{/base}/item/material/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -156,7 +156,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/item/material/create?{?}",
|
"uri": "{/base}/item/material/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -175,7 +175,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Items",
|
"name": "Items",
|
||||||
"uri": "{/base}/sales/item/list?{?}",
|
"uri": "{/base}/sales/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -189,7 +189,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/sales/item/list?{?}",
|
"uri": "{/base}/sales/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -203,7 +203,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/sales/item/view?{?}",
|
"uri": "{/base}/sales/item/view",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -220,7 +220,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/sales/item/create?{?}",
|
"uri": "{/base}/sales/item/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -237,7 +237,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Items",
|
"name": "Items",
|
||||||
"uri": "{/base}/purchase/item/list?{?}",
|
"uri": "{/base}/purchase/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -251,7 +251,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/purchase/item/list?{?}",
|
"uri": "{/base}/purchase/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -265,7 +265,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/purchase/item/view?{?}",
|
"uri": "{/base}/purchase/item/view",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -282,7 +282,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/purchase/item/create?{?}",
|
"uri": "{/base}/purchase/item/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -299,7 +299,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Items",
|
"name": "Items",
|
||||||
"uri": "{/base}/warehouse/item/list?{?}",
|
"uri": "{/base}/warehouse/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
@ -313,7 +313,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/warehouse/item/list?{?}",
|
"uri": "{/base}/warehouse/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -327,7 +327,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/warehouse/item/view?{?}",
|
"uri": "{/base}/warehouse/item/view",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -344,7 +344,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/warehouse/item/create?{?}",
|
"uri": "{/base}/warehouse/item/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -361,7 +361,7 @@
|
||||||
"type": 2,
|
"type": 2,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Items",
|
"name": "Items",
|
||||||
"uri": "{/base}/production/item/list?{?}",
|
"uri": "{/base}/production/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -375,7 +375,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "List",
|
"name": "List",
|
||||||
"uri": "{/base}/production/item/list?{?}",
|
"uri": "{/base}/production/item/list",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -389,7 +389,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/production/item/view?{?}",
|
"uri": "{/base}/production/item/view",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 1,
|
"order": 1,
|
||||||
|
|
@ -406,7 +406,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Create",
|
"name": "Create",
|
||||||
"uri": "{/base}/production/item/create?{?}",
|
"uri": "{/base}/production/item/create",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 5,
|
"order": 5,
|
||||||
|
|
@ -423,7 +423,7 @@
|
||||||
"type": 3,
|
"type": 3,
|
||||||
"subtype": 1,
|
"subtype": 1,
|
||||||
"name": "Item",
|
"name": "Item",
|
||||||
"uri": "{/base}/purchase/analysis/item?{?}",
|
"uri": "{/base}/purchase/analysis/item",
|
||||||
"target": "self",
|
"target": "self",
|
||||||
"icon": null,
|
"icon": null,
|
||||||
"order": 10,
|
"order": 10,
|
||||||
|
|
|
||||||
|
|
@ -32,7 +32,6 @@ use Modules\ItemManagement\Models\SettingsEnum as ItemSettingsEnum;
|
||||||
use Modules\ItemManagement\Models\StockIdentifierType;
|
use Modules\ItemManagement\Models\StockIdentifierType;
|
||||||
use Modules\Media\Models\Collection;
|
use Modules\Media\Models\Collection;
|
||||||
use Modules\Media\Models\CollectionMapper;
|
use Modules\Media\Models\CollectionMapper;
|
||||||
use Modules\Media\Models\MediaMapper;
|
|
||||||
use Modules\Media\Models\MediaTypeMapper;
|
use Modules\Media\Models\MediaTypeMapper;
|
||||||
use Modules\Media\Models\PathSettings;
|
use Modules\Media\Models\PathSettings;
|
||||||
use phpOMS\Account\PermissionType;
|
use phpOMS\Account\PermissionType;
|
||||||
|
|
@ -308,47 +307,28 @@ final class ApiController extends Controller
|
||||||
|
|
||||||
$uploadedFiles = $request->files['item_profile_image'] ?? [];
|
$uploadedFiles = $request->files['item_profile_image'] ?? [];
|
||||||
if (!empty($uploadedFiles)) {
|
if (!empty($uploadedFiles)) {
|
||||||
|
/** @var \Modules\Media\Models\MediaType $profileImageType */
|
||||||
|
$profileImageType = MediaTypeMapper::get()
|
||||||
|
->where('name', 'item_profile_image')
|
||||||
|
->execute();
|
||||||
|
|
||||||
// upload image
|
// upload image
|
||||||
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
|
$this->app->moduleManager->get('Media', 'Api')->uploadFiles(
|
||||||
names: [],
|
names: [],
|
||||||
fileNames: [],
|
fileNames: [],
|
||||||
files: $uploadedFiles,
|
files: $uploadedFiles,
|
||||||
account: $request->header->account,
|
account: $request->header->account,
|
||||||
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
|
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
|
||||||
virtualPath: $path,
|
virtualPath: $path,
|
||||||
pathSettings: PathSettings::FILE_PATH
|
pathSettings: PathSettings::FILE_PATH,
|
||||||
);
|
type: $profileImageType->id,
|
||||||
|
rel: $item->id,
|
||||||
// create type / media relation
|
mapper: ItemMapper::class,
|
||||||
/** @var \Modules\Media\Models\MediaType $profileImageType */
|
field: 'files'
|
||||||
$profileImageType = MediaTypeMapper::get()
|
|
||||||
->where('name', 'item_profile_image')
|
|
||||||
->execute();
|
|
||||||
|
|
||||||
$this->createModelRelation(
|
|
||||||
$request->header->account,
|
|
||||||
$uploaded[0]->id,
|
|
||||||
$profileImageType->id,
|
|
||||||
MediaMapper::class,
|
|
||||||
'types',
|
|
||||||
'',
|
|
||||||
$request->getOrigin()
|
|
||||||
);
|
|
||||||
|
|
||||||
// create item relation
|
|
||||||
$this->createModelRelation(
|
|
||||||
$request->header->account,
|
|
||||||
$item->id,
|
|
||||||
$uploaded[0]->id,
|
|
||||||
ItemMapper::class,
|
|
||||||
'files',
|
|
||||||
'',
|
|
||||||
$request->getOrigin()
|
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->createItemSegmentation($request, $response, $item);
|
$this->createItemSegmentation($request, $response, $item);
|
||||||
|
|
||||||
$this->createStandardCreateResponse($request, $response, $item);
|
$this->createStandardCreateResponse($request, $response, $item);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
@ -407,7 +387,7 @@ final class ApiController extends Controller
|
||||||
private function createMediaDirForItem(int $id, int $createdBy) : Collection
|
private function createMediaDirForItem(int $id, int $createdBy) : Collection
|
||||||
{
|
{
|
||||||
$collection = new Collection();
|
$collection = new Collection();
|
||||||
$collection->name = $id;
|
$collection->name = (string) $id;
|
||||||
$collection->setVirtualPath('/Modules/ItemManagement/Items');
|
$collection->setVirtualPath('/Modules/ItemManagement/Items');
|
||||||
$collection->setPath('/Modules/Media/Files/Modules/ItemManagement/Items/' . $id);
|
$collection->setPath('/Modules/Media/Files/Modules/ItemManagement/Items/' . $id);
|
||||||
$collection->createdBy = new NullAccount($createdBy);
|
$collection->createdBy = new NullAccount($createdBy);
|
||||||
|
|
@ -770,11 +750,9 @@ final class ApiController extends Controller
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$uploadedFiles = $request->files;
|
if (empty($request->files)) {
|
||||||
|
|
||||||
if (empty($uploadedFiles)) {
|
|
||||||
$response->header->status = RequestStatusCode::R_400;
|
$response->header->status = RequestStatusCode::R_400;
|
||||||
$this->createInvalidCreateResponse($request, $response, $uploadedFiles);
|
$this->createInvalidCreateResponse($request, $response, $request->files);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
@ -789,40 +767,23 @@ final class ApiController extends Controller
|
||||||
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
|
$uploaded = $this->app->moduleManager->get('Media', 'Api')->uploadFiles(
|
||||||
names: $request->getDataList('names'),
|
names: $request->getDataList('names'),
|
||||||
fileNames: $request->getDataList('filenames'),
|
fileNames: $request->getDataList('filenames'),
|
||||||
files: $uploadedFiles,
|
files: $request->files,
|
||||||
account: $request->header->account,
|
account: $request->header->account,
|
||||||
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
|
basePath: __DIR__ . '/../../../Modules/Media/Files' . $path,
|
||||||
virtualPath: $path,
|
virtualPath: $path,
|
||||||
pathSettings: PathSettings::FILE_PATH
|
pathSettings: PathSettings::FILE_PATH,
|
||||||
|
type: $request->getDataInt('type'),
|
||||||
|
rel: $item->id,
|
||||||
|
mapper: ItemMapper::class,
|
||||||
|
field: 'files'
|
||||||
);
|
);
|
||||||
|
|
||||||
if ($request->hasData('type')) {
|
if (empty($uploaded->sources)) {
|
||||||
foreach ($uploaded as $file) {
|
|
||||||
$this->createModelRelation(
|
|
||||||
$request->header->account,
|
|
||||||
$file->id,
|
|
||||||
$request->getDataInt('type'),
|
|
||||||
MediaMapper::class,
|
|
||||||
'types',
|
|
||||||
'',
|
|
||||||
$request->getOrigin()
|
|
||||||
);
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
if (empty($uploaded)) {
|
|
||||||
$this->createInvalidAddResponse($request, $response, []);
|
$this->createInvalidAddResponse($request, $response, []);
|
||||||
|
|
||||||
return;
|
return;
|
||||||
}
|
}
|
||||||
|
|
||||||
$this->createModelRelation(
|
|
||||||
$request->header->account,
|
|
||||||
(int) $request->getData('item'),
|
|
||||||
\reset($uploaded)->id,
|
|
||||||
ItemMapper::class, 'files', '', $request->getOrigin()
|
|
||||||
);
|
|
||||||
|
|
||||||
$this->createStandardUpdateResponse($request, $response, $uploaded);
|
$this->createStandardUpdateResponse($request, $response, $uploaded);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
||||||
Loading…
Reference in New Issue
Block a user