Add: update foldername
This commit is contained in:
@@ -90,6 +90,8 @@ func NewAPI(config Config) (*API, error) {
|
|||||||
apiMux.HandleFunc("/put_tag_on_file", api.HandlePutTagOnFile)
|
apiMux.HandleFunc("/put_tag_on_file", api.HandlePutTagOnFile)
|
||||||
apiMux.HandleFunc("/get_tags_on_file", api.HandleGetTagsOnFile)
|
apiMux.HandleFunc("/get_tags_on_file", api.HandleGetTagsOnFile)
|
||||||
apiMux.HandleFunc("/delete_tag_on_file", api.HandleDeleteTagOnFile)
|
apiMux.HandleFunc("/delete_tag_on_file", api.HandleDeleteTagOnFile)
|
||||||
|
// folder
|
||||||
|
apiMux.HandleFunc("/update_foldername", api.HandleUpdateFoldername)
|
||||||
// below needs token
|
// below needs token
|
||||||
apiMux.HandleFunc("/walk", api.HandleWalk)
|
apiMux.HandleFunc("/walk", api.HandleWalk)
|
||||||
apiMux.HandleFunc("/reset", api.HandleReset)
|
apiMux.HandleFunc("/reset", api.HandleReset)
|
||||||
|
|||||||
35
pkg/api/handle_folder.go
Normal file
35
pkg/api/handle_folder.go
Normal file
@@ -0,0 +1,35 @@
|
|||||||
|
package api
|
||||||
|
|
||||||
|
import (
|
||||||
|
"encoding/json"
|
||||||
|
"net/http"
|
||||||
|
)
|
||||||
|
|
||||||
|
type UpdateFoldernameRequest struct {
|
||||||
|
ID int64 `json:"id"`
|
||||||
|
Foldername string `json:"foldername"`
|
||||||
|
}
|
||||||
|
|
||||||
|
func (api *API) HandleUpdateFoldername(w http.ResponseWriter, r *http.Request) {
|
||||||
|
req := &UpdateFoldernameRequest{}
|
||||||
|
err := json.NewDecoder(r.Body).Decode(req)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusBadRequest)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
// check is admin
|
||||||
|
err = api.CheckAdmin(w, r)
|
||||||
|
if err != nil {
|
||||||
|
api.HandleError(w, r, err)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
err = api.Db.UpdateFoldername(req.ID, req.Foldername)
|
||||||
|
if err != nil {
|
||||||
|
http.Error(w, err.Error(), http.StatusInternalServerError)
|
||||||
|
return
|
||||||
|
}
|
||||||
|
|
||||||
|
api.HandleOK(w, r)
|
||||||
|
}
|
||||||
@@ -239,3 +239,11 @@ func (database *Database) Insert(path string, filesize int64) error {
|
|||||||
}
|
}
|
||||||
return nil
|
return nil
|
||||||
}
|
}
|
||||||
|
|
||||||
|
func (database *Database) UpdateFoldername(folderId int64, foldername string) error {
|
||||||
|
_, err := database.stmt.updateFoldername.Exec(foldername, folderId)
|
||||||
|
if err != nil {
|
||||||
|
return err
|
||||||
|
}
|
||||||
|
return nil
|
||||||
|
}
|
||||||
|
|||||||
@@ -200,6 +200,8 @@ WHERE file_has_tag.file_id = ?;`
|
|||||||
|
|
||||||
var deleteTagOnFileQuery = `DELETE FROM file_has_tag WHERE tag_id = ? AND file_id = ?;`
|
var deleteTagOnFileQuery = `DELETE FROM file_has_tag WHERE tag_id = ? AND file_id = ?;`
|
||||||
|
|
||||||
|
var updateFoldernameQuery = `UPDATE folders SET foldername = ? WHERE id = ?;`
|
||||||
|
|
||||||
type Stmt struct {
|
type Stmt struct {
|
||||||
initFilesTable *sql.Stmt
|
initFilesTable *sql.Stmt
|
||||||
initFoldersTable *sql.Stmt
|
initFoldersTable *sql.Stmt
|
||||||
@@ -239,6 +241,7 @@ type Stmt struct {
|
|||||||
putTagOnFile *sql.Stmt
|
putTagOnFile *sql.Stmt
|
||||||
getTagsOnFile *sql.Stmt
|
getTagsOnFile *sql.Stmt
|
||||||
deleteTagOnFile *sql.Stmt
|
deleteTagOnFile *sql.Stmt
|
||||||
|
updateFoldername *sql.Stmt
|
||||||
}
|
}
|
||||||
|
|
||||||
func NewPreparedStatement(sqlConn *sql.DB) (*Stmt, error) {
|
func NewPreparedStatement(sqlConn *sql.DB) (*Stmt, error) {
|
||||||
@@ -537,5 +540,11 @@ func NewPreparedStatement(sqlConn *sql.DB) (*Stmt, error) {
|
|||||||
return nil, err
|
return nil, err
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// init updateFoldername
|
||||||
|
stmt.updateFoldername, err = sqlConn.Prepare(updateFoldernameQuery)
|
||||||
|
if err != nil {
|
||||||
|
return nil, err
|
||||||
|
}
|
||||||
|
|
||||||
return stmt, err
|
return stmt, err
|
||||||
}
|
}
|
||||||
|
|||||||
@@ -7,9 +7,10 @@ function FilesInFolder(props) {
|
|||||||
const [files, setFiles] = useState([]);
|
const [files, setFiles] = useState([]);
|
||||||
const [isLoading, setIsLoading] = useState(false);
|
const [isLoading, setIsLoading] = useState(false);
|
||||||
const [offset, setOffset] = useState(0);
|
const [offset, setOffset] = useState(0);
|
||||||
|
const [newFoldername, setNewFoldername] = useState("");
|
||||||
const limit = 10;
|
const limit = 10;
|
||||||
|
|
||||||
useEffect(() => {
|
function refresh() {
|
||||||
setIsLoading(true);
|
setIsLoading(true);
|
||||||
fetch("/api/v1/get_files_in_folder", {
|
fetch("/api/v1/get_files_in_folder", {
|
||||||
method: "POST",
|
method: "POST",
|
||||||
@@ -22,12 +23,21 @@ function FilesInFolder(props) {
|
|||||||
})
|
})
|
||||||
.then((response) => response.json())
|
.then((response) => response.json())
|
||||||
.then((data) => {
|
.then((data) => {
|
||||||
setFiles(data.files ? data.files : []);
|
if (data.error) {
|
||||||
|
alert(data.error);
|
||||||
|
} else {
|
||||||
|
setFiles(data.files);
|
||||||
|
setNewFoldername(data.files[0].foldername);
|
||||||
|
}
|
||||||
})
|
})
|
||||||
.catch((error) => alert(error))
|
.catch((error) => alert(error))
|
||||||
.finally(() => {
|
.finally(() => {
|
||||||
setIsLoading(false);
|
setIsLoading(false);
|
||||||
});
|
});
|
||||||
|
}
|
||||||
|
|
||||||
|
useEffect(() => {
|
||||||
|
refresh();
|
||||||
}, [params.id, offset]);
|
}, [params.id, offset]);
|
||||||
|
|
||||||
function nextPage() {
|
function nextPage() {
|
||||||
@@ -42,6 +52,30 @@ function FilesInFolder(props) {
|
|||||||
setOffset(offsetValue);
|
setOffset(offsetValue);
|
||||||
}
|
}
|
||||||
|
|
||||||
|
function updateFoldername() {
|
||||||
|
setIsLoading(true);
|
||||||
|
fetch("/api/v1/update_foldername", {
|
||||||
|
method: "POST",
|
||||||
|
headers: { "Content-Type": "application/json" },
|
||||||
|
body: JSON.stringify({
|
||||||
|
id: parseInt(params.id),
|
||||||
|
foldername: newFoldername,
|
||||||
|
}),
|
||||||
|
})
|
||||||
|
.then((response) => response.json())
|
||||||
|
.then((data) => {
|
||||||
|
if (data.error) {
|
||||||
|
alert(data.error);
|
||||||
|
} else {
|
||||||
|
refresh();
|
||||||
|
}
|
||||||
|
})
|
||||||
|
.catch((error) => alert(error))
|
||||||
|
.finally(() => {
|
||||||
|
setIsLoading(false);
|
||||||
|
});
|
||||||
|
}
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<div className="page">
|
<div className="page">
|
||||||
<h3>Files in Folder</h3>
|
<h3>Files in Folder</h3>
|
||||||
@@ -53,6 +87,14 @@ function FilesInFolder(props) {
|
|||||||
<button onClick={nextPage}>Next page</button>
|
<button onClick={nextPage}>Next page</button>
|
||||||
</div>
|
</div>
|
||||||
<FilesTable setPlayingFile={props.setPlayingFile} files={files} />
|
<FilesTable setPlayingFile={props.setPlayingFile} files={files} />
|
||||||
|
<div>
|
||||||
|
<input
|
||||||
|
type="text"
|
||||||
|
value={newFoldername}
|
||||||
|
onChange={(e) => setNewFoldername(e.target.value)}
|
||||||
|
/>
|
||||||
|
<button onClick={() => updateFoldername()}>Save</button>
|
||||||
|
</div>
|
||||||
</div>
|
</div>
|
||||||
);
|
);
|
||||||
}
|
}
|
||||||
|
|||||||
Reference in New Issue
Block a user