1
0
Fork 0
mirror of https://github.com/jellyfin/jellyfin-web synced 2025-03-30 19:56:21 +00:00
jellyfin-web/src/routes/NewUserPage.tsx

267 lines
10 KiB
TypeScript
Raw Normal View History

2021-11-06 21:02:59 +03:00
import React, { FunctionComponent, useCallback, useEffect, useState, useRef } from 'react';
2021-10-02 18:10:14 +03:00
2022-06-29 02:56:49 +03:00
import Dashboard from '../utils/dashboard';
import globalize from '../scripts/globalize';
import loading from '../components/loading/loading';
import toast from '../components/toast/toast';
2022-06-29 18:26:33 +03:00
import SectionTitleContainer from '../elements/SectionTitleContainer';
import InputElement from '../elements/InputElement';
import ButtonElement from '../elements/ButtonElement';
2022-06-29 02:56:49 +03:00
import AccessContainer from '../components/dashboard/users/AccessContainer';
2022-06-29 18:26:33 +03:00
import CheckBoxElement from '../elements/CheckBoxElement';
2022-06-29 02:56:49 +03:00
import Page from '../components/Page';
2021-10-02 18:10:14 +03:00
type userInput = {
Name?: string;
Password?: string;
}
2021-10-09 19:35:10 +03:00
type ItemsArr = {
Name?: string;
Id?: string;
}
2021-10-02 18:10:14 +03:00
const NewUserPage: FunctionComponent = () => {
2022-02-15 23:49:46 +03:00
const [ channelsItems, setChannelsItems ] = useState<ItemsArr[]>([]);
const [ mediaFoldersItems, setMediaFoldersItems ] = useState<ItemsArr[]>([]);
2022-02-15 23:47:59 +03:00
const element = useRef<HTMLDivElement>(null);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
const getItemsResult = (items: ItemsArr[]) => {
return items.map(item =>
({
Id: item.Id,
Name: item.Name
})
);
};
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
const loadMediaFolders = useCallback((result) => {
const page = element.current;
if (!page) {
console.error('Unexpected null reference');
return;
}
2021-11-06 21:02:59 +03:00
const mediaFolders = getItemsResult(result);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
setMediaFoldersItems(mediaFolders);
2022-02-16 22:01:13 +03:00
const folderAccess = page.querySelector('.folderAccess') as HTMLDivElement;
2021-11-06 21:02:59 +03:00
folderAccess.dispatchEvent(new CustomEvent('create'));
2021-10-09 19:35:10 +03:00
2022-02-16 22:01:13 +03:00
(page.querySelector('.chkEnableAllFolders') as HTMLInputElement).checked = false;
2021-11-06 21:02:59 +03:00
}, []);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
const loadChannels = useCallback((result) => {
const page = element.current;
if (!page) {
console.error('Unexpected null reference');
return;
}
2021-11-06 21:02:59 +03:00
const channels = getItemsResult(result);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
setChannelsItems(channels);
2021-10-02 18:10:14 +03:00
2022-02-16 22:01:13 +03:00
const channelAccess = page.querySelector('.channelAccess') as HTMLDivElement;
2021-11-06 21:02:59 +03:00
channelAccess.dispatchEvent(new CustomEvent('create'));
2021-10-09 19:35:10 +03:00
2022-02-16 22:01:13 +03:00
const channelAccessContainer = page.querySelector('.channelAccessContainer') as HTMLDivElement;
2021-11-06 21:02:59 +03:00
channels.length ? channelAccessContainer.classList.remove('hide') : channelAccessContainer.classList.add('hide');
2021-10-02 18:10:14 +03:00
2022-02-16 22:01:13 +03:00
(page.querySelector('.chkEnableAllChannels') as HTMLInputElement).checked = false;
2021-11-06 21:02:59 +03:00
}, []);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
const loadUser = useCallback(() => {
const page = element.current;
if (!page) {
console.error('Unexpected null reference');
return;
}
2022-02-16 22:01:13 +03:00
(page.querySelector('#txtUsername') as HTMLInputElement).value = '';
(page.querySelector('#txtPassword') as HTMLInputElement).value = '';
2021-11-06 21:02:59 +03:00
loading.show();
const promiseFolders = window.ApiClient.getJSON(window.ApiClient.getUrl('Library/MediaFolders', {
IsHidden: false
}));
const promiseChannels = window.ApiClient.getJSON(window.ApiClient.getUrl('Channels'));
Promise.all([promiseFolders, promiseChannels]).then(function (responses) {
loadMediaFolders(responses[0].Items);
loadChannels(responses[1].Items);
loading.hide();
});
}, [loadChannels, loadMediaFolders]);
2021-10-02 18:10:14 +03:00
2021-11-06 21:02:59 +03:00
useEffect(() => {
const page = element.current;
if (!page) {
console.error('Unexpected null reference');
return;
}
2021-11-06 21:02:59 +03:00
loadUser();
2021-10-02 18:10:14 +03:00
const saveUser = () => {
const userInput: userInput = {};
2022-02-16 22:01:13 +03:00
userInput.Name = (page.querySelector('#txtUsername') as HTMLInputElement).value;
userInput.Password = (page.querySelector('#txtPassword') as HTMLInputElement).value;
2021-10-02 18:10:14 +03:00
window.ApiClient.createUser(userInput).then(function (user) {
2022-02-18 13:08:44 +03:00
if (!user.Id) {
throw new Error('Unexpected null user.Id');
}
if (!user.Policy) {
throw new Error('Unexpected null user.Policy');
}
2022-02-16 22:01:13 +03:00
user.Policy.EnableAllFolders = (page.querySelector('.chkEnableAllFolders') as HTMLInputElement).checked;
2021-10-02 18:10:14 +03:00
user.Policy.EnabledFolders = [];
if (!user.Policy.EnableAllFolders) {
user.Policy.EnabledFolders = Array.prototype.filter.call(page.querySelectorAll('.chkFolder'), function (i) {
2021-10-02 18:10:14 +03:00
return i.checked;
}).map(function (i) {
return i.getAttribute('data-id');
});
}
2022-02-16 22:01:13 +03:00
user.Policy.EnableAllChannels = (page.querySelector('.chkEnableAllChannels') as HTMLInputElement).checked;
2021-10-02 18:10:14 +03:00
user.Policy.EnabledChannels = [];
if (!user.Policy.EnableAllChannels) {
user.Policy.EnabledChannels = Array.prototype.filter.call(page.querySelectorAll('.chkChannel'), function (i) {
2021-10-02 18:10:14 +03:00
return i.checked;
}).map(function (i) {
return i.getAttribute('data-id');
});
}
window.ApiClient.updateUserPolicy(user.Id, user.Policy).then(function () {
Dashboard.navigate('useredit.html?userId=' + user.Id);
});
}, function () {
toast(globalize.translate('ErrorDefault'));
loading.hide();
});
};
2022-02-18 14:27:39 +03:00
const onSubmit = (e: Event) => {
2021-10-02 18:10:14 +03:00
loading.show();
saveUser();
e.preventDefault();
e.stopPropagation();
return false;
};
2022-02-16 22:01:13 +03:00
(page.querySelector('.chkEnableAllChannels') as HTMLInputElement).addEventListener('change', function (this: HTMLInputElement) {
const channelAccessListContainer = page.querySelector('.channelAccessListContainer') as HTMLDivElement;
this.checked ? channelAccessListContainer.classList.add('hide') : channelAccessListContainer.classList.remove('hide');
2021-10-02 18:10:14 +03:00
});
2022-02-16 22:01:13 +03:00
(page.querySelector('.chkEnableAllFolders') as HTMLInputElement).addEventListener('change', function (this: HTMLInputElement) {
const folderAccessListContainer = page.querySelector('.folderAccessListContainer') as HTMLDivElement;
this.checked ? folderAccessListContainer.classList.add('hide') : folderAccessListContainer.classList.remove('hide');
2021-10-02 18:10:14 +03:00
});
2022-02-16 22:01:13 +03:00
(page.querySelector('.newUserProfileForm') as HTMLFormElement).addEventListener('submit', onSubmit);
2021-10-02 18:10:14 +03:00
2022-06-29 02:17:10 +03:00
(page.querySelector('#btnCancel') as HTMLButtonElement).addEventListener('click', function() {
2021-10-02 18:10:14 +03:00
window.history.back();
});
2021-11-06 21:02:59 +03:00
}, [loadUser]);
2021-10-02 18:10:14 +03:00
return (
2022-06-29 02:56:49 +03:00
<Page
id='newUserPage'
className='mainAnimatedPage type-interior'
>
<div ref={element} className='content-primary'>
2022-06-29 02:17:10 +03:00
<div className='verticalSection'>
<SectionTitleContainer
title={globalize.translate('HeaderAddUser')}
url='https://docs.jellyfin.org/general/server/users/'
/>
</div>
2021-10-02 18:10:14 +03:00
<form className='newUserProfileForm'>
<div className='inputContainer'>
<InputElement
type='text'
id='txtUsername'
label='LabelName'
options={'required'}
/>
</div>
<div className='inputContainer'>
<InputElement
type='password'
id='txtPassword'
label='LabelPassword'
/>
</div>
<AccessContainer
2022-05-09 20:11:47 +03:00
containerClassName='folderAccessContainer'
headerTitle='HeaderLibraryAccess'
checkBoxClassName='chkEnableAllFolders'
checkBoxTitle='OptionEnableAccessToAllLibraries'
listContainerClassName='folderAccessListContainer'
accessClassName='folderAccess'
listTitle='HeaderLibraries'
description='LibraryAccessHelp'
>
{mediaFoldersItems.map(Item => (
2022-06-29 02:17:10 +03:00
<CheckBoxElement
key={Item.Id}
className='chkFolder'
2022-06-29 02:17:10 +03:00
itemId={Item.Id}
itemName={Item.Name}
/>
))}
</AccessContainer>
<AccessContainer
2022-05-09 20:11:47 +03:00
containerClassName='channelAccessContainer verticalSection-extrabottompadding hide'
headerTitle='HeaderChannelAccess'
checkBoxClassName='chkEnableAllChannels'
checkBoxTitle='OptionEnableAccessToAllChannels'
listContainerClassName='channelAccessListContainer'
accessClassName='channelAccess'
listTitle='Channels'
description='ChannelAccessHelp'
>
{channelsItems.map(Item => (
2022-06-29 02:17:10 +03:00
<CheckBoxElement
key={Item.Id}
className='chkChannel'
2022-06-29 02:17:10 +03:00
itemId={Item.Id}
itemName={Item.Name}
/>
))}
</AccessContainer>
2021-10-02 18:10:14 +03:00
<div>
<ButtonElement
type='submit'
className='raised button-submit block'
title='Save'
/>
<ButtonElement
type='button'
2022-06-29 02:17:10 +03:00
id='btnCancel'
className='raised button-cancel block'
2021-10-02 18:10:14 +03:00
title='ButtonCancel'
/>
</div>
</form>
</div>
2022-06-29 02:56:49 +03:00
</Page>
2021-10-02 18:10:14 +03:00
);
};
export default NewUserPage;