Pixelfed-related fixes

This commit is contained in:
Lim Chee Aun 2024-04-09 23:35:17 +08:00
parent 7fa0b4f076
commit 4e5940900e
8 changed files with 71 additions and 21 deletions

View file

@ -74,7 +74,7 @@ function Media({
altIndex, altIndex,
onClick = () => {}, onClick = () => {},
}) { }) {
const { let {
blurhash, blurhash,
description, description,
meta, meta,
@ -84,10 +84,17 @@ function Media({
url, url,
type, type,
} = media; } = media;
if (/no\-preview\./i.test(previewUrl)) {
previewUrl = null;
}
const { original = {}, small, focus } = meta || {}; const { original = {}, small, focus } = meta || {};
const width = showOriginal ? original?.width : small?.width; const width = showOriginal
const height = showOriginal ? original?.height : small?.height; ? original?.width
: small?.width || original?.width;
const height = showOriginal
? original?.height
: small?.height || original?.height;
const mediaURL = showOriginal ? url : previewUrl || url; const mediaURL = showOriginal ? url : previewUrl || url;
const remoteMediaURL = showOriginal const remoteMediaURL = showOriginal
? remoteUrl ? remoteUrl
@ -290,7 +297,11 @@ function Media({
}} }}
onError={(e) => { onError={(e) => {
const { src } = e.target; const { src } = e.target;
if (src === mediaURL && mediaURL !== remoteMediaURL) { if (
src === mediaURL &&
remoteMediaURL &&
mediaURL !== remoteMediaURL
) {
e.target.src = remoteMediaURL; e.target.src = remoteMediaURL;
} }
}} }}
@ -473,6 +484,7 @@ function Media({
/> />
) : ( ) : (
<> <>
{previewUrl ? (
<img <img
src={previewUrl} src={previewUrl}
alt={showInlineDesc ? '' : description} alt={showInlineDesc ? '' : description}
@ -481,6 +493,17 @@ function Media({
data-orientation={orientation} data-orientation={orientation}
loading="lazy" loading="lazy"
/> />
) : (
<video
src={url}
width={width}
height={height}
data-orientation={orientation}
preload="metadata"
muted
disablePictureInPicture
/>
)}
<div class="media-play"> <div class="media-play">
<Icon icon="play" size="xl" /> <Icon icon="play" size="xl" />
</div> </div>

View file

@ -151,7 +151,7 @@ function AccountStatuses() {
} }
} }
const results = []; let results = [];
if (firstLoad) { if (firstLoad) {
const { value } = await masto.v1.accounts const { value } = await masto.v1.accounts
.$select(id) .$select(id)
@ -192,6 +192,26 @@ function AccountStatuses() {
} }
const { value, done } = await accountStatusesIterator.current.next(); const { value, done } = await accountStatusesIterator.current.next();
if (value?.length) { if (value?.length) {
// Check if value is same as pinned post (results)
// If the index for every post is the same, means API might not support pinned posts
if (results.length) {
let pinnedStatusesIds = [];
if (results[0]?.type === 'pinned') {
pinnedStatusesIds = results[0].id;
} else {
pinnedStatusesIds = results
.filter((status) => status._pinned)
.map((status) => status.id);
}
const containsAllPinned = pinnedStatusesIds.every((postId) =>
value.some((status) => status.id === postId),
);
if (containsAllPinned) {
// Remove pinned posts
results = [];
}
}
results.push(...value); results.push(...value);
value.forEach((item) => { value.forEach((item) => {

View file

@ -71,7 +71,8 @@ function Following({ title, path, id, ...props }) {
.next(); .next();
let { value } = results; let { value } = results;
console.log('checkForUpdates', latestItem.current, value); console.log('checkForUpdates', latestItem.current, value);
if (value?.length) { const valueContainsLatestItem = value[0]?.id === latestItem.current; // since_id might not be supported
if (value?.length && !valueContainsLatestItem) {
latestItem.current = value[0].id; latestItem.current = value[0].id;
value = dedupeBoosts(value, instance); value = dedupeBoosts(value, instance);
value = filteredItems(value, 'home'); value = filteredItems(value, 'home');

View file

@ -109,8 +109,9 @@ function Hashtags({ media: mediaView, columnMode, ...props }) {
}) })
.next(); .next();
let { value } = results; let { value } = results;
const valueContainsLatestItem = value[0]?.id === latestItem.current; // since_id might not be supported
if (value?.length && !valueContainsLatestItem) {
value = filteredItems(value, 'public'); value = filteredItems(value, 'public');
if (value?.length) {
return true; return true;
} }
return false; return false;

View file

@ -63,8 +63,9 @@ function List(props) {
since_id: latestItem.current, since_id: latestItem.current,
}); });
let { value } = results; let { value } = results;
const valueContainsLatestItem = value[0]?.id === latestItem.current; // since_id might not be supported
if (value?.length && !valueContainsLatestItem) {
value = filteredItems(value, 'home'); value = filteredItems(value, 'home');
if (value?.length) {
return true; return true;
} }
return false; return false;

View file

@ -95,7 +95,9 @@ function Mentions({ columnMode, ...props }) {
latestConversationItem.current, latestConversationItem.current,
value, value,
); );
if (value?.length) { const valueContainsLatestItem =
value[0]?.id === latestConversationItem.current; // since_id might not be supported
if (value?.length && !valueContainsLatestItem) {
latestConversationItem.current = value[0].lastStatus.id; latestConversationItem.current = value[0].lastStatus.id;
return true; return true;
} }

View file

@ -63,8 +63,9 @@ function Public({ local, columnMode, ...props }) {
}) })
.next(); .next();
let { value } = results; let { value } = results;
const valueContainsLatestItem = value[0]?.id === latestItem.current; // since_id might not be supported
if (value?.length && !valueContainsLatestItem) {
value = filteredItems(value, 'public'); value = filteredItems(value, 'public');
if (value?.length) {
return true; return true;
} }
return false; return false;

View file

@ -6,6 +6,7 @@ const statusPostRegexes = [
/\/notes\/([^\/]+)/i, // Misskey, Firefish /\/notes\/([^\/]+)/i, // Misskey, Firefish
/^\/(?:notice|objects)\/([a-z0-9-]+)/i, // Pleroma /^\/(?:notice|objects)\/([a-z0-9-]+)/i, // Pleroma
/\/@[^@\/]+@?[^\/]+?\/([^\/]+)/i, // Mastodon /\/@[^@\/]+@?[^\/]+?\/([^\/]+)/i, // Mastodon
/^\/p\/[^\/]+\/([^\/]+)/i, // Pixelfed
]; ];
export function getInstanceStatusObject(url) { export function getInstanceStatusObject(url) {