VRChat Message Sender

Send a message to a friend on VRChat Web page.

目前为 2018-08-19 提交的版本。查看 最新版本

// ==UserScript==
// @name        VRChat Message Sender
// @name:ja     VRChat メッセージを送信
// @description Send a message to a friend on VRChat Web page.
// @description:ja VRChatのWebページから、フレンドにメッセージを送信します。
// @namespace   https://greasyfork.org/users/137
// @version     1.0.0
// @match       https://www.vrchat.net/*
// @match       https://vrchat.net/*
// @match       https://www.vrchat.com/*
// @match       https://vrchat.com/*
// @require     https://greasyfork.org/scripts/19616/code/utilities.js?version=230651
// @license     MPL-2.0
// @contributionURL https://pokemori.booth.pm/items/969835
// @compatible  Edge 非推奨 / Deprecated
// @compatible  Firefox
// @compatible  Opera
// @compatible  Chrome
// @grant       dummy
// @icon        
// @author      100の人
// @homepage    https://greasyfork.org/scripts/266
// ==/UserScript==

'use strict';

// L10N
Gettext.setLocalizedTexts({
	/*eslint-disable quote-props, max-len */
	'en': {
		'https://docs.unity3d.com/ja/Manual/StyledText.html': 'https://docs.unity3d.com/Manual/StyledText.html',
		'次のタグが利用可能です': 'Allowed tags:',
		'エラーが発生しました': 'Error occurred',
	},
	/*eslint-enable quote-props, max-len */
});

Gettext.setLocale(navigator.language);

new MutationObserver(function (mutations, observer) {
	observer.disconnect();

	const homeContent = document.getElementsByClassName('home-content')[0];

	new MutationObserver(function (mutations) {
		for (const mutation of mutations) {
			if (!('message-sender' in document.forms) && homeContent.getElementsByClassName('fa-star-half-alt')[0]) {
				const userId = /\/user\/(usr_[0-9a-f]{8}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{4}-[0-9a-f]{12})/
					.exec(location.pathname)[1];

				homeContent.firstElementChild.firstElementChild.insertAdjacentHTML('beforeend', h`
					<form action="/api/1/user/${userId}/notification" name="message-sender" class="col-md-12 row">
						<div class="col-md-12 row">
							<textarea name="message" class="col-md-9"></textarea>
							<button name="send" class="btn col-md-3">Send Message</button>
						</div>
						<p class="col-md-12 row">
							<small><a href="${_('https://docs.unity3d.com/ja/Manual/StyledText.html')}" target="_blank">
								${_('次のタグが利用可能です')}:
									<code>&lt;b&gt;〜&lt;/b&gt;</code>,
									<code>&lt;i&gt;〜&lt;/i&gt;</code>,
									<code>&lt;color=○○○&gt;〜&lt;/color&gt;</code>
							</a></small>
						</p>
					</form>
				`);
			}
		}
	}).observe(homeContent, { childList: true, attributes: true, subtree: true, attributeFilter: [ 'class' ] });

	homeContent.addEventListener('submit', function (event) {
		if (event.target.name === 'message-sender') {
			event.preventDefault();
			event.target.message.disbaled = true;
			event.target.send.disbaled = true;
			(typeof content !== 'undefined' ? content.fetch.bind(content) : fetch.bind(window))(event.target.action, {
				method: 'POST',
				headers: { 'content-type': 'application/json' },
				credentials: 'same-origin',
				body: JSON.stringify({type: 'message', message: event.target.message.value}),
			})
				.then(function (response) {
					if (response.ok) {
						event.target.reset();
					} else {
						return Promise.reject(response.status + ' ' + response.statusText);
					}
				})
				.catch(function (exception) {
					alert(_('エラーが発生しました') + ': ' + exception);
				})
				.then(function () {
					event.target.message.disbaled = false;
					event.target.send.disbaled = false;
				});
		}
	});

}).observe(document.getElementById('app'), { childList: true });