mirror of
https://github.com/jellyfin/jellyfin-web
synced 2025-03-30 19:56:21 +00:00
36 lines
1.1 KiB
TypeScript
36 lines
1.1 KiB
TypeScript
![]() |
import React, { FunctionComponent, useEffect, useRef } from 'react';
|
||
|
|
||
|
import IconButtonElement from '../../elements/IconButtonElement';
|
||
|
|
||
|
const NewCollection: FunctionComponent = () => {
|
||
|
const element = useRef<HTMLDivElement>(null);
|
||
|
|
||
|
useEffect(() => {
|
||
|
const btnNewCollection = element.current?.querySelector('.btnNewCollection') as HTMLButtonElement;
|
||
|
if (btnNewCollection) {
|
||
|
btnNewCollection.addEventListener('click', () => {
|
||
|
import('../../components/collectionEditor/collectionEditor').then(({ default: collectionEditor }) => {
|
||
|
const serverId = window.ApiClient.serverId();
|
||
|
new collectionEditor({
|
||
|
items: [],
|
||
|
serverId: serverId
|
||
|
});
|
||
|
});
|
||
|
});
|
||
|
}
|
||
|
}, []);
|
||
|
|
||
|
return (
|
||
|
<div ref={element}>
|
||
|
<IconButtonElement
|
||
|
is='paper-icon-button-light'
|
||
|
className='btnNewCollection autoSize'
|
||
|
title='Add'
|
||
|
icon='material-icons add'
|
||
|
/>
|
||
|
</div>
|
||
|
);
|
||
|
};
|
||
|
|
||
|
export default NewCollection;
|