add images modal upload fully working (for images from banks and new images)

This commit is contained in:
isUnknown 2024-10-15 15:56:53 +02:00
parent 0e656e1920
commit 514c4bd86b
8 changed files with 84 additions and 86 deletions

Binary file not shown.

Before

Width:  |  Height:  |  Size: 232 KiB

View file

@ -14,10 +14,7 @@ Description:
----
Clientbriefimages:
- file://PbMGJPIjFYxbbyhq
- file://STF67mX6eGsLsOGh
Clientbriefimages: - file://cKGbZhC6pCTXislx
----

Binary file not shown.

Before

Width:  |  Height:  |  Size: 213 KiB

View file

@ -1,17 +0,0 @@
Description: test 2
----
Tags:
----
Sort: 8
----
Uuid: STF67mX6eGsLsOGh
----
Template: image

View file

@ -58,63 +58,72 @@ return [
}
// Upload new images
// if ($uploads = $files->get('images')) {
// $existingFiles = $page->files();
// $existingFileMap = [];
// foreach ($existingFiles as $file) {
// $pos = strpos($file->filename(), '_');
// $originalSafename = substr($file->filename(), $pos + 1);
// $existingFileMap[$originalSafename . '|' . $file->mime() . '|' . $file->size()] = $file->uuid();
// }
if ($uploads = $files->get('images')) {
$imagesMeta = $data['imagesMeta'];
$existingFiles = $page->files();
$existingFileMap = [];
foreach ($existingFiles as $file) {
$pos = strpos($file->filename(), '_');
$originalSafename = substr($file->filename(), $pos + 1);
$existingFileMap[$originalSafename . '|' . $file->mime() . '|' . $file->size()] = $file->uuid();
}
// foreach ($uploads as $upload) {
// // check for duplicate
// $files = page('storage')->files();
// $duplicates = $files->filter(function ($file) use ($upload) {
// // get original safename without prefix
// $pos = strpos($file->filename(), '_');
// $originalSafename = substr($file->filename(), $pos + 1);
foreach ($uploads as $index => $upload) {
$description = $imagesMeta[$index]['description'] ?? null;
$tags = json_decode($imagesMeta[$index]['tags'], true) ?? [];
// check for duplicate
$files = $page->files();
$duplicates = $files->filter(function ($file) use ($upload) {
// get original safename without prefix
$pos = strpos($file->filename(), '_');
$originalSafename = substr($file->filename(), $pos + 1);
// return $originalSafename === F::safeName($upload['name']) &&
// $file->mime() === $upload['type'] &&
// $file->size() === $upload['size'];
// });
return $originalSafename === F::safeName($upload['name']) &&
$file->mime() === $upload['type'] &&
$file->size() === $upload['size'];
});
// if ($duplicates->count() > 0) {
// $correspondingFile = $duplicates->first();
// $newFile = $correspondingFile->update([
// 'description' => $upload['description'],
// 'tags' => $upload['tags']
// ]);
// $allFiles[] = $newFile->uuid();
// $success[$newFile->name()] = 'Successfully updated.';
// continue;
// } else {
// try {
// $name = crc32($upload['name'].microtime()). '_' . $upload['name'];
// $newFile = $page->createFile([
// 'source' => $upload['name'],
// 'filename' => $name,
// 'template' => 'image',
// 'content' => [
// 'date' => date('Y-m-d h:m'),
// 'description' => $upload['description'],
// 'tags' => $upload['tags'],
// ]
// ]);
// $allFiles[] = $newFile->uuid();
// $success[$newFile->name()] = 'Successfully added.';
// } catch (Exception $e) {
// $alerts[$upload['name']] = $e->getMessage();
// }
// }
// }
// }
if ($duplicates->count() > 0) {
$existingFile = $duplicates->first();
$newFile = $existingFile->update([
'description' => $description,
'tags' => $tags
]);
$allFiles = array_filter($allFiles, function ($uuid) use ($existingFile) {
return $uuid != $existingFile->uuid();
});
$allFiles[] = $newFile->uuid();
$success[$newFile->name()] = 'Successfully updated.';
continue;
} else {
try {
$name = crc32($upload['name'].microtime()). '_' . $upload['name'];
$newFile = $page->createFile([
'source' => $upload['tmp_name'],
'filename' => $name,
'template' => 'image',
'content' => [
'date' => date('Y-m-d h:m'),
'description' => $description,
'tags' => $tags,
]
]);
$allFiles[] = $newFile->uuid();
$success[$newFile->name()] = 'Successfully added.';
} catch (Throwable $th) {
$alerts[$upload['name']] = $th->getMessage() . ' line ' . $th->getLine();
}
}
}
}
// Empty page update needed to updates its files data
$newPage = $page->update([]);
if (!empty($allFiles)) {
// Empty page update needed to updates its files data
$newPage = $page->update([]);
$newPage = $page->update([
'clientBriefImages' => $allFiles
]);
@ -122,15 +131,15 @@ return [
$images = [];
// foreach ($newPage->clientBriefImages()->toFiles() as $image) {
// $images[] = [
// 'url' => $image->url(),
// 'uuid' => (string) $image->uuid(),
// 'tags' => $image->tags()->split(),
// 'name' => $image->filename(),
// 'description' => $image->description()->value(),
// ];
// }
foreach ($newPage->clientBriefImages()->toFiles() as $image) {
$images[] = [
'url' => $image->url(),
'uuid' => (string) $image->uuid(),
'tags' => $image->tags()->split(),
'name' => $image->filename(),
'description' => $image->description()->value(),
];
}
return compact('images', 'alerts', 'success');
}
];

View file

@ -169,12 +169,21 @@ const images = computed(() => {
function addImagesToBrief() {
const formData = new FormData();
const blobPromises = images.value.map((item) => {
const blobPromises = images.value.map((item, index) => {
console.log(item);
if (item.url.startsWith("blob:")) {
return fetch(item.url)
.then((response) => response.blob())
.then((blob) => {
formData.append("images[]", blob, JSON.stringify(item));
formData.append("images[]", blob, item.name);
formData.append(
`imagesMeta[${index}][description]`,
item.description
);
formData.append(
`imagesMeta[${index}][tags]`,
JSON.stringify(item.tags)
);
});
} else {
formData.append("imageUris[]", JSON.stringify(item));