Skip to content

Commit

Permalink
Merge pull request #946 from funmusicplace/post-images
Browse files Browse the repository at this point in the history
allow cleaning up of specific track groups, some track title editing improvements
  • Loading branch information
simonv3 authored Dec 16, 2024
2 parents e1bca28 + aee1915 commit e51cd5b
Show file tree
Hide file tree
Showing 7 changed files with 64 additions and 33 deletions.
Original file line number Diff line number Diff line change
Expand Up @@ -10,7 +10,8 @@ const ClickToEditInput: React.FC<{
defaultValue: string;
url: string;
formKey: string;
}> = ({ url, formKey, defaultValue }) => {
reload?: () => void;
}> = ({ url, formKey, defaultValue, reload }) => {
const [isEditing, setIsEditing] = React.useState(false);
const methods = useForm({
defaultValues: {
Expand All @@ -19,15 +20,11 @@ const ClickToEditInput: React.FC<{
});

const currentValue = methods.getValues(formKey);

return (
<>
{!isEditing && (
<div
// className={css`
// display: flex;
// justify-content: space-between;
// `}
>
<div>
{currentValue}
<Button
type="button"
Expand All @@ -47,7 +44,7 @@ const ClickToEditInput: React.FC<{
`}
>
<FormProvider {...methods}>
<SavingInput formKey="title" url={url} />
<SavingInput formKey="title" url={url} reload={reload} />
<Button
type="button"
variant="dashed"
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -22,6 +22,7 @@ const SavingInput: React.FC<{
step?: string;
type?: string;
clearQueryKey?: string;
reload?: () => void;
}> = ({
formKey,
url,
Expand All @@ -31,6 +32,7 @@ const SavingInput: React.FC<{
rows,
step,
clearQueryKey,
reload,
}) => {
const { register, getValues } = useFormContext();
const errorHandler = useErrorHandler();
Expand Down Expand Up @@ -83,6 +85,7 @@ const SavingInput: React.FC<{
const timeout = setTimeout(() => {
setIsSaving(false);
setSaveSuccess(true);
reload?.();
timeout2 = setTimeout(() => {
setSaveSuccess(false);
}, 1000);
Expand Down
61 changes: 43 additions & 18 deletions client/src/components/ManageArtist/ManageTrackRow.tsx
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
import { css } from "@emotion/css";
import React from "react";
import { FaPen, FaTrash } from "react-icons/fa";
import { FaExclamationTriangle, FaPen, FaTrash } from "react-icons/fa";
import useDraggableTrack from "utils/useDraggableTrack";

import api from "services/api";
Expand Down Expand Up @@ -108,6 +108,8 @@ const ManageTrackRow: React.FC<{
reload();
}, [reload]);

console.log("track.audio", track.title, !track.title);

if (isEditing) {
return (
<EditTrackRow
Expand Down Expand Up @@ -149,31 +151,54 @@ const ManageTrackRow: React.FC<{
overflow: hidden;
whitespace: nowrap;
text-overflow: ellipsis;
background-color: ${!track.title
? "var(--mi-warning-background-color)"
: "transparent"};
&:hover {
background-color: transparent !important;
background-color: ${!track.title
? "var(--mi-warning-background-color)"
: "transparent"};
}
&:before {
content: "${t("titleColumn")}: ";
}
`}
>
<div>
<ClickToEditInput
defaultValue={track.title}
url={`manage/tracks/${track.id}`}
formKey="title"
/>
<small>
{uploadState === "SUCCESS" && t("doneUploadingTrack")}
{uploadState === "STARTED" && (
<>
<LoadingSpinner />
{t("stillProcessing")}
</>
)}
{uploadState === "ERROR" && t("thereWasAnError")}
</small>
<div
className={css`
display: flex;
align-items: center;
> svg {
margin-right: 1rem;
}
`}
>
{!track.title && <FaExclamationTriangle />}
<div>
<ClickToEditInput
defaultValue={track.title}
url={`manage/tracks/${track.id}`}
formKey="title"
reload={reload}
/>
<small>
{t("originalFilename", {
filename: track.audio?.originalFilename,
})}
<div>
{uploadState === "SUCCESS" && t("doneUploadingTrack")}
{uploadState === "STARTED" && (
<>
<LoadingSpinner />
{t("stillProcessing")}
</>
)}
{uploadState === "ERROR" && t("thereWasAnError")}
</div>
</small>
</div>
</div>
</td>
<td
Expand Down
2 changes: 1 addition & 1 deletion client/src/translation/en.json
Original file line number Diff line number Diff line change
Expand Up @@ -642,6 +642,7 @@
"delete": "Delete",
"edit": "Edit",
"listedArtists": "Listed artists",
"originalFilename": "Original file name: {{ filename }}",
"status": "Can be played without purchase?",
"statusPreview": "Preview",
"statusMustOwn": "Must own",
Expand Down Expand Up @@ -671,7 +672,6 @@
"imagesInPost": "Manage images in post",
"imageIsFeatured": "Which image should be featured?",
"confirmDelete": "Are you sure you want to delete this post?",
"newBlogPostFor": "New blog post for {{ artistName }}",
"title": "Title:",
"publicationDate": "Publication date:",
"content": "Content",
Expand Down
1 change: 1 addition & 0 deletions client/src/types/index.d.ts
Original file line number Diff line number Diff line change
Expand Up @@ -35,6 +35,7 @@ interface Track {
createdAt: string;
duration: number; // in seconds
uploadState: "STARTED" | "SUCCESS" | "ERROR";
originalFilename: string;
};
isPreview: boolean;
trackArtists?: {
Expand Down
16 changes: 11 additions & 5 deletions src/jobs/tasks/clean-up-files.ts
Original file line number Diff line number Diff line change
Expand Up @@ -7,9 +7,15 @@ import {
import { startCleaningUpOldFiles } from "../../queues/clean-up-old-files-queue";

const cleanUpFiles = async (incomingFolder: string) => {
if (incomingFolder === trackGroupFormatBucket) {
logger.info("cleaning up files in the trackgroup minio container");
removeBucket(incomingFolder);
if (incomingFolder.startsWith(trackGroupFormatBucket)) {
const split = incomingFolder.split(/\/(.*)/);
const bucket = split[0];
const albumId = split[1];
logger.info(
`cleaning up ${albumId ?? "all files"} in the trackgroup minio container`
);

removeBucket(bucket, albumId);
return {
deleted: incomingFolder,
};
Expand Down Expand Up @@ -49,9 +55,9 @@ const cleanUpFiles = async (incomingFolder: string) => {
};
};

const removeBucket = async (bucketName: string) => {
const removeBucket = async (bucketName: string, prefix: string) => {
logger.info(`Removing all objects from ${bucketName}`);
await removeObjectsFromBucket(bucketName, "");
await removeObjectsFromBucket(bucketName, prefix ?? "");
};

export default cleanUpFiles;
1 change: 0 additions & 1 deletion src/routers/v1/admin/tasks.ts
Original file line number Diff line number Diff line change
@@ -1,6 +1,5 @@
import { NextFunction, Request, Response } from "express";
import { userAuthenticated, userHasPermission } from "../../../auth/passport";
import prisma from "@mirlo/prisma";
import cleanUpFiles from "../../../jobs/tasks/clean-up-files";
import initiateUserNotifcations from "../../../jobs/tasks/initiate-user-notifications";

Expand Down

0 comments on commit e51cd5b

Please sign in to comment.