mirror of
https://github.com/Ernous/TorrServerJellyfin.git
synced 2025-12-19 13:36:09 +05:00
Move wipe to server side. Add UI unsafe buttons (#355)
* move 'remove all' function to server side ('wipe')
* add UnsafeButton to RemoveAll and CloseServer webui
This commit is contained in:
committed by
GitHub
parent
d1b29bd848
commit
5e71af9751
@@ -1,11 +1,12 @@
|
||||
import { useState } from 'react'
|
||||
import { Button, DialogActions, DialogTitle, ListItemIcon, ListItemText } from '@material-ui/core'
|
||||
import { StyledDialog, StyledMenuButtonWrapper } from 'style/CustomMaterialUiStyles'
|
||||
import { PowerSettingsNew as PowerSettingsNewIcon } from '@material-ui/icons'
|
||||
import { PowerSettingsNew as PowerSettingsNewIcon, PowerOff as PowerOffIcon } from '@material-ui/icons'
|
||||
import { shutdownHost } from 'utils/Hosts'
|
||||
import { useTranslation } from 'react-i18next'
|
||||
import { isStandaloneApp } from 'utils/Utils'
|
||||
import useOnStandaloneAppOutsideClick from 'utils/useOnStandaloneAppOutsideClick'
|
||||
import UnsafeButton from './UnsafeButton'
|
||||
|
||||
export default function CloseServer({ isOffline, isLoading }) {
|
||||
const { t } = useTranslation()
|
||||
@@ -41,7 +42,9 @@ export default function CloseServer({ isOffline, isLoading }) {
|
||||
{t('Cancel')}
|
||||
</Button>
|
||||
|
||||
<Button
|
||||
<UnsafeButton
|
||||
timeout={5}
|
||||
startIcon={<PowerOffIcon />}
|
||||
variant='contained'
|
||||
onClick={() => {
|
||||
fetch(shutdownHost())
|
||||
@@ -51,7 +54,7 @@ export default function CloseServer({ isOffline, isLoading }) {
|
||||
autoFocus
|
||||
>
|
||||
{t('TurnOff')}
|
||||
</Button>
|
||||
</UnsafeButton>
|
||||
</DialogActions>
|
||||
</StyledDialog>
|
||||
</>
|
||||
|
||||
@@ -6,29 +6,17 @@ import DeleteIcon from '@material-ui/icons/Delete'
|
||||
import { useState } from 'react'
|
||||
import { torrentsHost } from 'utils/Hosts'
|
||||
import { useTranslation } from 'react-i18next'
|
||||
import UnsafeButton from './UnsafeButton'
|
||||
|
||||
const fnRemoveAll = () => {
|
||||
fetch(torrentsHost(), {
|
||||
method: 'post',
|
||||
body: JSON.stringify({ action: 'list' }),
|
||||
body: JSON.stringify({ action: 'wipe' }),
|
||||
headers: {
|
||||
Accept: 'application/json, text/plain, */*',
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
})
|
||||
.then(res => res.json())
|
||||
.then(json => {
|
||||
json.forEach(torr => {
|
||||
fetch(torrentsHost(), {
|
||||
method: 'post',
|
||||
body: JSON.stringify({ action: 'rem', hash: torr.hash }),
|
||||
headers: {
|
||||
Accept: 'application/json, text/plain, */*',
|
||||
'Content-Type': 'application/json',
|
||||
},
|
||||
})
|
||||
})
|
||||
})
|
||||
}
|
||||
|
||||
export default function RemoveAll({ isOffline, isLoading }) {
|
||||
@@ -54,7 +42,9 @@ export default function RemoveAll({ isOffline, isLoading }) {
|
||||
{t('Cancel')}
|
||||
</Button>
|
||||
|
||||
<Button
|
||||
<UnsafeButton
|
||||
timeout={5}
|
||||
startIcon={<DeleteIcon />}
|
||||
variant='contained'
|
||||
onClick={() => {
|
||||
fnRemoveAll()
|
||||
@@ -64,7 +54,7 @@ export default function RemoveAll({ isOffline, isLoading }) {
|
||||
autoFocus
|
||||
>
|
||||
{t('OK')}
|
||||
</Button>
|
||||
</UnsafeButton>
|
||||
</DialogActions>
|
||||
</Dialog>
|
||||
</>
|
||||
|
||||
26
web/src/components/UnsafeButton.jsx
Normal file
26
web/src/components/UnsafeButton.jsx
Normal file
@@ -0,0 +1,26 @@
|
||||
import { Button } from '@material-ui/core';
|
||||
import { useEffect, useRef, useState } from 'react';
|
||||
|
||||
export default function UnsafeButton({ timeout, children, disabled, ...props }) {
|
||||
const [timeLeft, setTimeLeft] = useState(timeout || 7)
|
||||
const [buttonDisabled, setButtonDisabled] = useState(disabled || timeLeft > 0)
|
||||
const handleTimerTick = () => {
|
||||
const newTimeLeft = timeLeft - 1
|
||||
setTimeLeft(newTimeLeft)
|
||||
if (newTimeLeft <= 0) {
|
||||
setButtonDisabled(disabled)
|
||||
}
|
||||
}
|
||||
const getTimerText = () => !disabled && timeLeft > 0 ? ` (${timeLeft})` : ''
|
||||
useEffect(() => {
|
||||
if (disabled || !timeLeft) { return }
|
||||
const intervalId = setInterval(handleTimerTick, 1000)
|
||||
return () => clearInterval(intervalId)
|
||||
}, [timeLeft])
|
||||
|
||||
return (
|
||||
<Button disabled={buttonDisabled} {...props}>
|
||||
{children} {getTimerText()}
|
||||
</Button>
|
||||
)
|
||||
}
|
||||
Reference in New Issue
Block a user