forked from nostr/nostrweb
write: move reply and write-new-text note to write.ts
parent
9a34d4f31e
commit
976ea21d52
@ -0,0 +1,154 @@
|
||||
import {signEvent} from 'nostr-tools';
|
||||
import {elemShrink, updateElemHeight} from './utils/dom';
|
||||
import {powEvent} from './system';
|
||||
import {config} from './settings';
|
||||
import {publish} from './relays';
|
||||
|
||||
// form used to write and publish textnotes for replies and new notes
|
||||
const writeForm = document.querySelector('#writeForm') as HTMLFormElement;
|
||||
const writeInput = document.querySelector('textarea[name="message"]') as HTMLTextAreaElement;
|
||||
|
||||
// overlay for writing new text notes
|
||||
const publishView = document.querySelector('#newNote') as HTMLElement;
|
||||
|
||||
const openWriteView = () => {
|
||||
publishView.append(writeForm);
|
||||
if (writeInput.value.trimRight()) {
|
||||
writeInput.style.removeProperty('height');
|
||||
}
|
||||
requestAnimationFrame(() => {
|
||||
updateElemHeight(writeInput);
|
||||
writeInput.focus();
|
||||
});
|
||||
publishView.removeAttribute('hidden');
|
||||
};
|
||||
|
||||
export const closePublishView = () => publishView.hidden = true;
|
||||
|
||||
export const togglePublishView = () => {
|
||||
if (publishView.hidden) {
|
||||
localStorage.removeItem('reply_to'); // should it forget old replyto context?
|
||||
openWriteView();
|
||||
} else {
|
||||
publishView.hidden = true;
|
||||
}
|
||||
};
|
||||
|
||||
const closeWriteInput = () => writeInput.blur();
|
||||
|
||||
export const openWriteInput = (
|
||||
button: HTMLElement,
|
||||
id: string,
|
||||
) => {
|
||||
appendReplyForm(button.closest('.buttons') as HTMLElement);
|
||||
localStorage.setItem('reply_to', id);
|
||||
};
|
||||
|
||||
export const toggleWriteInput = (
|
||||
button: HTMLElement,
|
||||
id: string,
|
||||
) => {
|
||||
if (id && localStorage.getItem('reply_to') === id) {
|
||||
closeWriteInput();
|
||||
return;
|
||||
}
|
||||
appendReplyForm(button.closest('.buttons') as HTMLElement);
|
||||
localStorage.setItem('reply_to', id);
|
||||
};
|
||||
|
||||
// const updateWriteInputHeight = () => updateElemHeight(writeInput);
|
||||
|
||||
writeInput.addEventListener('focusout', () => {
|
||||
const reply_to = localStorage.getItem('reply_to');
|
||||
if (reply_to && writeInput.value === '') {
|
||||
writeInput.addEventListener('transitionend', (event) => {
|
||||
if (!reply_to || reply_to === localStorage.getItem('reply_to') && !writeInput.style.height) { // should prob use some class or data-attr instead of relying on height
|
||||
writeForm.after(elemShrink(writeInput));
|
||||
writeForm.remove();
|
||||
localStorage.removeItem('reply_to');
|
||||
}
|
||||
}, {once: true});
|
||||
}
|
||||
});
|
||||
|
||||
// document.body.addEventListener('keyup', (e) => {
|
||||
// if (e.key === 'Escape') {
|
||||
// hideNewMessage(true);
|
||||
// }
|
||||
// });
|
||||
|
||||
const sendStatus = document.querySelector('#sendstatus') as HTMLElement;
|
||||
const publishBtn = document.querySelector('#publish') as HTMLButtonElement;
|
||||
const onSendError = (err: Error) => sendStatus.textContent = err.message;
|
||||
|
||||
writeForm.addEventListener('submit', async (e) => {
|
||||
e.preventDefault();
|
||||
const privatekey = localStorage.getItem('private_key');
|
||||
if (!config.pubkey || !privatekey) {
|
||||
return onSendError(new Error('no pubkey/privatekey'));
|
||||
}
|
||||
const content = writeInput.value.trimRight();
|
||||
if (!content) {
|
||||
return onSendError(new Error('message is empty'));
|
||||
}
|
||||
const replyTo = localStorage.getItem('reply_to');
|
||||
const close = () => {
|
||||
sendStatus.textContent = '';
|
||||
writeInput.value = '';
|
||||
writeInput.style.removeProperty('height');
|
||||
publishBtn.disabled = true;
|
||||
if (replyTo) {
|
||||
localStorage.removeItem('reply_to');
|
||||
publishView.append(writeForm);
|
||||
}
|
||||
publishView.hidden = true;
|
||||
};
|
||||
const tags = replyTo ? [['e', replyTo]] : []; // , eventRelayMap[replyTo][0]
|
||||
const newEvent = await powEvent({
|
||||
kind: 1,
|
||||
content,
|
||||
pubkey: config.pubkey,
|
||||
tags,
|
||||
created_at: Math.floor(Date.now() * 0.001),
|
||||
}, {
|
||||
difficulty: config.difficulty,
|
||||
statusElem: sendStatus,
|
||||
timeout: config.timeout,
|
||||
}).catch(console.warn);
|
||||
if (!newEvent) {
|
||||
close();
|
||||
return;
|
||||
}
|
||||
const sig = signEvent(newEvent, privatekey);
|
||||
// TODO validateEvent
|
||||
if (sig) {
|
||||
sendStatus.textContent = 'publishing…';
|
||||
publish({...newEvent, sig}, (relay, error) => {
|
||||
if (error) {
|
||||
return console.log(error, relay);
|
||||
}
|
||||
console.info(`publish request sent to ${relay}`);
|
||||
close();
|
||||
});
|
||||
}
|
||||
});
|
||||
|
||||
writeInput.addEventListener('input', () => {
|
||||
publishBtn.disabled = !writeInput.value.trimRight();
|
||||
updateElemHeight(writeInput);
|
||||
});
|
||||
|
||||
writeInput.addEventListener('blur', () => sendStatus.textContent = '');
|
||||
|
||||
function appendReplyForm(el: HTMLElement) {
|
||||
writeForm.before(elemShrink(writeInput));
|
||||
writeInput.blur();
|
||||
writeInput.style.removeProperty('height');
|
||||
el.after(writeForm);
|
||||
if (writeInput.value && !writeInput.value.trimRight()) {
|
||||
writeInput.value = '';
|
||||
} else {
|
||||
requestAnimationFrame(() => updateElemHeight(writeInput));
|
||||
}
|
||||
requestAnimationFrame(() => writeInput.focus());
|
||||
}
|
Loading…
Reference in New Issue