Letterbox images taller than 1:1
This commit is contained in:
parent
4b0e154af6
commit
0356b014b0
5 changed files with 5 additions and 4 deletions
|
@ -39,6 +39,7 @@ and this project adheres to [Semantic Versioning](https://semver.org/spec/v2.0.0
|
||||||
- Posts: move instance favicon beside username instead of post timestamp.
|
- Posts: move instance favicon beside username instead of post timestamp.
|
||||||
- Posts: changed the behavior of content warnings. CWs and sensitive media are unified into one design.
|
- Posts: changed the behavior of content warnings. CWs and sensitive media are unified into one design.
|
||||||
- Posts: redesigned interaction counters to use text instead of icons.
|
- Posts: redesigned interaction counters to use text instead of icons.
|
||||||
|
- Posts: letterbox images taller than 1:1.
|
||||||
- Profile: overhauled user profiles to be consistent with the rest of the UI.
|
- Profile: overhauled user profiles to be consistent with the rest of the UI.
|
||||||
- Composer: move emoji button alongside other composer buttons, add numerical counter.
|
- Composer: move emoji button alongside other composer buttons, add numerical counter.
|
||||||
- Birthdays: move today's birthdays out of notifications into right sidebar.
|
- Birthdays: move today's birthdays out of notifications into right sidebar.
|
||||||
|
|
|
@ -294,7 +294,7 @@ const MediaGallery: React.FC<IMediaGallery> = (props) => {
|
||||||
const aspectRatio = media.getIn([0, 'meta', 'original', 'aspect']) as number | undefined;
|
const aspectRatio = media.getIn([0, 'meta', 'original', 'aspect']) as number | undefined;
|
||||||
|
|
||||||
const getHeight = () => {
|
const getHeight = () => {
|
||||||
if (!aspectRatio) return w * 9 / 16;
|
if (!aspectRatio) return w;
|
||||||
if (isPanoramic(aspectRatio)) return Math.floor(w / maximumAspectRatio);
|
if (isPanoramic(aspectRatio)) return Math.floor(w / maximumAspectRatio);
|
||||||
if (isPortrait(aspectRatio)) return Math.floor(w / minimumAspectRatio);
|
if (isPortrait(aspectRatio)) return Math.floor(w / minimumAspectRatio);
|
||||||
return Math.floor(w / aspectRatio);
|
return Math.floor(w / aspectRatio);
|
||||||
|
|
|
@ -29,7 +29,7 @@ const PlaceholderMediaGallery: React.FC<IPlaceholderMediaGallery> = ({ media, de
|
||||||
let itemsDimensions: Record<string, string>[] = [];
|
let itemsDimensions: Record<string, string>[] = [];
|
||||||
|
|
||||||
if (size === 1) {
|
if (size === 1) {
|
||||||
style.height = width! * 9 / 16;
|
style.height = width;
|
||||||
|
|
||||||
itemsDimensions = [
|
itemsDimensions = [
|
||||||
{ w: '100%', h: '100%' },
|
{ w: '100%', h: '100%' },
|
||||||
|
|
|
@ -111,7 +111,7 @@ const Card: React.FC<ICard> = ({
|
||||||
|
|
||||||
// Constrain to a sane limit
|
// Constrain to a sane limit
|
||||||
// https://en.wikipedia.org/wiki/Aspect_ratio_(image)
|
// https://en.wikipedia.org/wiki/Aspect_ratio_(image)
|
||||||
return Math.min(Math.max(9 / 16, ratio), 4);
|
return Math.min(Math.max(1, ratio), 4);
|
||||||
};
|
};
|
||||||
|
|
||||||
const interactive = card.type !== 'link';
|
const interactive = card.type !== 'link';
|
||||||
|
|
|
@ -1,4 +1,4 @@
|
||||||
export const minimumAspectRatio = 9 / 16; // Portrait phone
|
export const minimumAspectRatio = 1; // Square
|
||||||
export const maximumAspectRatio = 10; // Generous min-height
|
export const maximumAspectRatio = 10; // Generous min-height
|
||||||
|
|
||||||
export const isPanoramic = (ar: number) => {
|
export const isPanoramic = (ar: number) => {
|
||||||
|
|
Loading…
Reference in a new issue