mirror of
https://github.com/mue/mue.git
synced 2026-06-08 22:18:40 +02:00
59 lines
1.7 KiB
JavaScript
59 lines
1.7 KiB
JavaScript
import React from 'react';
|
|
|
|
import TextareaAutosize from '@material-ui/core/TextareaAutosize';
|
|
import CopyIcon from '@material-ui/icons/FileCopyRounded';
|
|
import NotesIcon from '@material-ui/icons/AssignmentRounded';
|
|
|
|
import Pin from './Pin';
|
|
|
|
export default class Notes extends React.PureComponent {
|
|
constructor() {
|
|
super();
|
|
this.state = {
|
|
notes: localStorage.getItem('notes') || ''
|
|
};
|
|
this.language = window.language.widgets.navbar.notes;
|
|
}
|
|
|
|
setNotes = (e) => {
|
|
localStorage.setItem('notes', e.target.value);
|
|
this.setState({
|
|
notes: e.target.value
|
|
});
|
|
};
|
|
|
|
pin() {
|
|
document.getElementById('noteContainer').classList.toggle('visibilityshow');
|
|
|
|
if (localStorage.getItem('notesPinned') === 'true') {
|
|
localStorage.setItem('notesPinned', false);
|
|
} else {
|
|
localStorage.setItem('notesPinned', true);
|
|
}
|
|
}
|
|
|
|
componentDidMount() {
|
|
if (localStorage.getItem('notesPinned') === 'true') {
|
|
document.getElementById('noteContainer').classList.toggle('visibilityshow');
|
|
}
|
|
|
|
if (localStorage.getItem('refresh') === 'false') {
|
|
document.getElementById('noteContainer').style.marginLeft = '-200px';
|
|
}
|
|
}
|
|
|
|
render() {
|
|
return (
|
|
<span id='noteContainer' className='notescontainer'>
|
|
<div className='topbarnotes'>
|
|
<NotesIcon/>
|
|
<h3>{this.language.title}</h3>
|
|
</div>
|
|
<TextareaAutosize rowsMax={50} placeholder={this.language.placeholder} value={this.state.notes} onChange={this.setNotes}/>
|
|
<button onClick={this.pin} className='pinNote'><Pin/></button>
|
|
<button onClick={() => navigator.clipboard.writeText(this.state.notes)} className='saveNote'><CopyIcon/></button>
|
|
</span>
|
|
);
|
|
}
|
|
}
|