uploading image from bank working

This commit is contained in:
isUnknown 2024-10-15 14:51:12 +02:00
parent 9df71b4949
commit 97262303fc
4 changed files with 116 additions and 76 deletions

View file

@ -1,15 +1,15 @@
Description: test
----
Tags: bouton poussoir
----
Sort: 7 Sort: 7
---- ----
Description:
----
Tags:
----
Uuid: MXGiJkPHmzL0pTOk Uuid: MXGiJkPHmzL0pTOk
---- ----

View file

@ -7,81 +7,115 @@ return [
$kirby = kirby(); $kirby = kirby();
$request = $kirby->request(); $request = $kirby->request();
$files = $request->files(); $files = $request->files();
$data = $request->data(); $data = $request->data();
$pageUri = $request->query()->get('pageUri'); $pageUri = $request->query()->get('pageUri');
$page = page($pageUri); if (!$pageUri) {
return [
if ($uploads = $request->files()) { 'error' => 'Page non trouvée.'
];
$existingFiles = $page->files(); }
$allFiles = $page->clientBriefImages()->toFiles()->pluck('uuid', ',');
$existingFileMap = [];
foreach ($existingFiles as $file) {
$pos = strpos($file->filename(), '_');
$originalSafename = substr($file->filename(), $pos + 1);
$existingFileMap[$originalSafename . '|' . $file->mime() . '|' . $file->size()] = $file->uuid();
}
$alerts = [];
$newFiles = [];
foreach ($uploads->get('images') as $upload) {
$key = F::safeName($upload['name']) . '|' . $upload['type'] . '|' . $upload['size']; $page = page($pageUri);
$allFiles = $page->clientBriefImages()->isNotEmpty() ? $page->clientBriefImages()->toFiles()->pluck('uuid', ',') : [];
$alerts = [];
$success = [];
// Copy images selected from site banks with incoming properties
if (!empty($data['imageUris'])) {
foreach ($data['imageUris'] as $imageUri) {
$imageData = json_decode($imageUri, true);
if (isset($existingFileMap[$key])) { if ($file = page('materials')->file($imageData['uuid'])) {
$duplicateUUID = $existingFileMap[$key];
if (!in_array($duplicateUUID, $allFiles)) {
$allFiles[] = $duplicateUUID;
$alerts[$upload['name']] = "The file already exists, added to the field.";
}
} else {
try { try {
$name = crc32($upload['name'] . microtime()) . '_' . $upload['name']; $copiedFile = $file->copy($page);
$newFile = $page->createFile([ $updatedFile = $file->update([
'source' => $upload['tmp_name'], 'description' => $imageData['description'],
'filename' => $name, 'tags' => $imageData['tags'],
'template' => 'image',
'content' => [
'date' => date('Y-m-d H:i:s')
]
]); ]);
$newFiles[] = $newFile; $allFiles[] = (string) $updatedFile->uuid();
$success = 'Your file upload was successful';
$allFiles[] = (string) $newFile->uuid();
} catch (Exception $e) { } catch (Exception $e) {
$alerts[$upload['name']] = $e->getMessage(); $alerts[$file->name()] = $e->getMessage();
} }
} }
} }
$newPage = $page->update([
'clientBriefImages' => $allFiles
]);
$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(),
];
}
return compact('images', 'alerts');
} }
return [ // Upload new images
'error' => 'Aucun fichier reçu.', // 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();
// }
// 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);
// 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();
// }
// }
// }
// }
$page = $page->update([
'clientBriefImages' => $allFiles
]);
$images = [];
// foreach ($page->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

@ -8,7 +8,7 @@
style="--row-gap: var(--space-8)" style="--row-gap: var(--space-8)"
> >
<AccordionPanel <AccordionPanel
v-for="(image, index) in activeTab.selectedImages" v-for="(image, index) in images"
:key="index + 1" :key="index + 1"
:value="index" :value="index"
class="w-full | bg-white | rounded-xl | p-12 pt-8" class="w-full | bg-white | rounded-xl | p-12 pt-8"
@ -108,11 +108,16 @@ import { usePageStore } from "../../../../stores/page";
import StringUtils from "../../../../utils/string"; import StringUtils from "../../../../utils/string";
import { storeToRefs } from "pinia"; import { storeToRefs } from "pinia";
import { useAddImagesModalStore } from "../../../../stores/addImagesModal"; import { useAddImagesModalStore } from "../../../../stores/addImagesModal";
import { computed } from "vue";
const { page } = storeToRefs(usePageStore()); const { page } = storeToRefs(usePageStore());
const { activeTab } = storeToRefs(useAddImagesModalStore()); const { activeTab } = storeToRefs(useAddImagesModalStore());
const images = computed(() => {
return activeTab.value.selectedImages;
});
// function saveTags(image) { // function saveTags(image) {
// const headers = { // const headers = {
// method: "POST", // method: "POST",
@ -164,15 +169,15 @@ const { activeTab } = storeToRefs(useAddImagesModalStore());
function addImagesToBrief() { function addImagesToBrief() {
const formData = new FormData(); const formData = new FormData();
const blobPromises = images.map((item) => { const blobPromises = images.value.map((item) => {
if (item.url.startsWith("blob:")) { if (item.url.startsWith("blob:")) {
return fetch(item.url) return fetch(item.url)
.then((response) => response.blob()) .then((response) => response.blob())
.then((blob) => { .then((blob) => {
formData.append("images[]", blob, item.name); formData.append("images[]", blob, JSON.stringify(item));
}); });
} else { } else {
formData.append("imageUris[]", item.url); formData.append("imageUris[]", JSON.stringify(item));
return Promise.resolve(); return Promise.resolve();
} }
}); });
@ -183,7 +188,10 @@ function addImagesToBrief() {
body: formData, body: formData,
}) })
.then((res) => res.json()) .then((res) => res.json())
.then((json) => (page.value.images = json.images)) .then((json) => {
page.value.images = json.images;
console.log(json);
})
.catch((error) => console.error("Error:", error)); .catch((error) => console.error("Error:", error));
}); });
} }

View file

@ -21,6 +21,4 @@ const { tabs } = storeToRefs(useAddImagesModalStore());
const tab = computed(() => { const tab = computed(() => {
return tabs.value.find((tab) => tab.id === "materials"); return tabs.value.find((tab) => tab.id === "materials");
}); });
console.log(ArrayUtils);
</script> </script>