Pleroma: status interaction support
This commit is contained in:
parent
d1c09e501a
commit
a92434d3da
2 changed files with 10 additions and 5 deletions
|
@ -135,7 +135,7 @@ async function handleError(error) {
|
||||||
function getInteractionType(url) {
|
function getInteractionType(url) {
|
||||||
for (const fedType of Object.values(FEDIVERSE_TYPE)) {
|
for (const fedType of Object.values(FEDIVERSE_TYPE)) {
|
||||||
for (const [checkRegEx, interactionType] of FEDIVERSE_MODULE[fedType].CATCH_URLS) {
|
for (const [checkRegEx, interactionType] of FEDIVERSE_MODULE[fedType].CATCH_URLS) {
|
||||||
if (url.pathname.match(checkRegEx)) {
|
if (url.href.match(checkRegEx)) {
|
||||||
return [fedType, interactionType];
|
return [fedType, interactionType];
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
|
@ -5,7 +5,6 @@
|
||||||
*/
|
*/
|
||||||
|
|
||||||
import * as NetworkTools from "/common/modules/NetworkTools.js";
|
import * as NetworkTools from "/common/modules/NetworkTools.js";
|
||||||
import {NotSupportedError} from "/common/modules/Errors.js";
|
|
||||||
import {INTERACTION_TYPE} from "../data/INTERACTION_TYPE.js";
|
import {INTERACTION_TYPE} from "../data/INTERACTION_TYPE.js";
|
||||||
import isString from "/common/modules/lodash/isString.js";
|
import isString from "/common/modules/lodash/isString.js";
|
||||||
|
|
||||||
|
@ -13,9 +12,12 @@ import isString from "/common/modules/lodash/isString.js";
|
||||||
const REMOTE_FOLLOW_REGEX = /\/main\/ostatus\/?$/;
|
const REMOTE_FOLLOW_REGEX = /\/main\/ostatus\/?$/;
|
||||||
// https://regex101.com/r/fjPdgC/1
|
// https://regex101.com/r/fjPdgC/1
|
||||||
const USER_PAGE_URL_REGEX = /\/users\/(.+)\/?$/;
|
const USER_PAGE_URL_REGEX = /\/users\/(.+)\/?$/;
|
||||||
|
// really just REMOTE_FOLLOW_REGEX with status_id query
|
||||||
|
const REMOTE_INTERACT_REGEX = /\/main\/ostatus\/?\?status_id=\w+$/;
|
||||||
|
|
||||||
/** The URLs to intercept and pass to this module. */
|
/** The URLs to intercept and pass to this module. */
|
||||||
export const CATCH_URLS = new Map();
|
export const CATCH_URLS = new Map();
|
||||||
|
CATCH_URLS.set(REMOTE_INTERACT_REGEX, INTERACTION_TYPE.TOOT_INTERACT);
|
||||||
CATCH_URLS.set(REMOTE_FOLLOW_REGEX, INTERACTION_TYPE.FOLLOW);
|
CATCH_URLS.set(REMOTE_FOLLOW_REGEX, INTERACTION_TYPE.FOLLOW);
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -84,13 +86,16 @@ export function getTabToModify(requestDetails) {
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* Find the follow URL.
|
* Find the status URL.
|
||||||
*
|
*
|
||||||
* @public
|
* @public
|
||||||
|
* @param {URL} url
|
||||||
* @returns {Promise}
|
* @returns {Promise}
|
||||||
*/
|
*/
|
||||||
export function getTootUrl() {
|
export function getTootUrl(url) {
|
||||||
throw new NotSupportedError("getTootUrl() is not supported");
|
return new Promise((resolve, reject) => {
|
||||||
|
resolve("https://" + url.host + "/notice/" + url.searchParams.get("status_id"));
|
||||||
|
});
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue