Merge branch 'logicla-css-fix-1' into 'develop'

fix(client): Fix logical property bugs (batch 1)

Co-authored-by: Eana Hufwe <eana@1a23.com>

See merge request firefish/firefish!11228
This commit is contained in:
naskya 2024-08-01 14:38:22 +00:00
commit d5919b21fb
21 changed files with 233 additions and 7 deletions

View file

@ -170,10 +170,18 @@ defineExpose({
<style lang="scss" scoped> <style lang="scss" scoped>
.container-toggle-enter-active, .container-toggle-enter-active,
.container-toggle-leave-active { .container-toggle-leave-active {
overflow-y: hidden;
overflow-block: hidden; overflow-block: hidden;
transition: transition:
opacity 0.5s, opacity 0.5s,
height 0.5s !important; height 0.5s !important;
@supports not (overflow-block: hidden) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: hidden;
}
}
} }
.container-toggle-enter-from { .container-toggle-enter-from {
opacity: 0; opacity: 0;

View file

@ -620,11 +620,20 @@ defineExpose({
> .emojis { > .emojis {
block-size: 100%; block-size: 100%;
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
overflow-x: hidden;
overflow-inline: hidden; overflow-inline: hidden;
scrollbar-width: none; scrollbar-width: none;
@supports not (overflow-block: auto) {
.vertical-lr &, .vertical-rl & {
overflow-y: hidden;
overflow-x: auto;
}
}
&::-webkit-scrollbar { &::-webkit-scrollbar {
display: none; display: none;
} }

View file

@ -107,10 +107,18 @@ defineExpose({
<style lang="scss" scoped> <style lang="scss" scoped>
.folder-toggle-enter-active, .folder-toggle-enter-active,
.folder-toggle-leave-active { .folder-toggle-leave-active {
overflow-y: hidden;
overflow-block: hidden; overflow-block: hidden;
transition: transition:
opacity 0.5s, opacity 0.5s,
height 0.5s !important; height 0.5s !important;
@supports not (overflow-block: hidden) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: hidden;
}
}
} }
.folder-toggle-enter-from { .folder-toggle-enter-from {
opacity: 0; opacity: 0;

View file

@ -320,6 +320,20 @@ const previewableCount = computed(
transform: translateX(-50%); transform: translateX(-50%);
inline-size: 75%; inline-size: 75%;
&:dir(rtl) {
inset-inline-start: auto;
inset-inline-end: 50%;
}
.vertical-rl &, .vertical-lr & {
transform: translateY(-50%);
}
.vertical-rl:not(.upright) &:dir(rtl), .vertical-lr:dir(rtl):not(.upright) & {
inset-inline-end: 50%;
inset-inline-start: auto;
}
} }
.pwsp__alt-text { .pwsp__alt-text {
@ -332,10 +346,19 @@ const previewableCount = computed(
border-radius: 5px; border-radius: 5px;
max-block-size: 10vb; max-block-size: 10vb;
overflow-x: clip;
overflow-inline: clip; overflow-inline: clip;
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
overscroll-behavior: contain; overscroll-behavior: contain;
white-space: pre-line; white-space: pre-line;
@supports not (overflow-block: auto) {
.vertical-lr &, .vertical-rl & {
overflow-x: auto;
overflow-y: clip;
}
}
} }
.pwsp__alt-text:empty { .pwsp__alt-text:empty {

View file

@ -423,12 +423,20 @@ onDeactivated(() => {
> .mod-pattern { > .mod-pattern {
display: grid; display: grid;
overflow-y: hidden;
overflow-block: hidden; overflow-block: hidden;
block-size: 0; block-size: 0;
padding-block-start: calc((56.25% - 48px) / 2); padding-block-start: calc((56.25% - 48px) / 2);
padding-block-end: calc((56.25% - 48px) / 2); padding-block-end: calc((56.25% - 48px) / 2);
content-visibility: auto; content-visibility: auto;
@supports not (overflow-block: hidden) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: hidden;
}
}
> .modRowActive { > .modRowActive {
opacity: 1; opacity: 1;
} }

View file

@ -11,7 +11,7 @@
<div :class="$style.frameContent"> <div :class="$style.frameContent">
<i <i
v-if="!isRefreshing" v-if="!isRefreshing"
:class="[$style.icon, icon('ph-arrow-down'), { [$style.refresh]: pullEnded }]" :class="[$style.icon, icon('ph-arrow-down ph-dir'), { [$style.refresh]: pullEnded }]"
></i> ></i>
<div :class="$style.text"> <div :class="$style.text">
<template v-if="pullEnded">{{ <template v-if="pullEnded">{{
@ -160,12 +160,28 @@ function moving(event: TouchEvent | PointerEvent) {
const moveScreenX = getScreenX(event); const moveScreenX = getScreenX(event);
const moveHeight = moveScreenY - startScreenY!; const moveHeight = moveScreenY - startScreenY!;
const moveWidth = moveScreenX - startScreenX!; const moveWidth = moveScreenX - startScreenX!;
if (Math.abs(moveWidth / moveHeight) > MAX_PULL_TAN_ANGLE) { const writingMode = rootEl.value
if (Math.abs(moveWidth) > 30) pullStarted.value = false; ? getComputedStyle(rootEl.value)["writing-mode"]
: "horizontal-tb";
const moveScreenBlock =
writingMode === "vertical-rl"
? -moveWidth
: writingMode === "vertical-lr"
? moveWidth
: moveHeight;
const moveScreenInline = writingMode.startsWith("vertical")
? moveHeight
: moveWidth;
if (Math.abs(moveScreenInline / moveScreenBlock) > MAX_PULL_TAN_ANGLE) {
if (Math.abs(moveScreenInline) > 30) pullStarted.value = false;
return; return;
} }
pullDistance.value = Math.min(Math.max(moveHeight, 0), MAX_PULL_DISTANCE); pullDistance.value = Math.min(
Math.max(moveScreenBlock, 0),
MAX_PULL_DISTANCE,
);
if (pullDistance.value > 0) { if (pullDistance.value > 0) {
if (event.cancelable) event.preventDefault(); if (event.cancelable) event.preventDefault();
@ -245,7 +261,7 @@ defineExpose({
position: relative; position: relative;
overflow: clip; overflow: clip;
inline-size: 100%; inline-size: 100%;
min-block-size: var(--frame-min-height, 0px); min-block-size: var(--frame-min-block-size, 0px);
mask-image: linear-gradient(var(--gradient-to-inline-end), #000 0%, #000 80%, transparent); mask-image: linear-gradient(var(--gradient-to-inline-end), #000 0%, #000 80%, transparent);
-webkit-mask-image: -webkit-linear-gradient( -webkit-mask-image: -webkit-linear-gradient(
var(--gradient-to-inline-end), var(--gradient-to-inline-end),
@ -274,6 +290,12 @@ defineExpose({
transition: transform 0.25s; transition: transform 0.25s;
&.refresh { &.refresh {
transform: rotate(180deg); transform: rotate(180deg);
:global(.vertical-rl) & {
transform: rotate(-90deg);
}
:global(.vertical-lr) & {
transform: rotate(90deg);
}
} }
} }
> .text { > .text {
@ -282,6 +304,14 @@ defineExpose({
} }
} }
.slotClip { .slotClip {
overflow-y: clip;
overflow-block: clip; overflow-block: clip;
@supports not (overflow-block: clip) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: clip;
}
}
} }
</style> </style>

View file

@ -38,6 +38,7 @@ const isMe = computed(() => isSignedIn(me) && me.id === props.note.userId);
margin-block-start: 0.2em; margin-block-start: 0.2em;
inline-size: 100%; inline-size: 100%;
display: flex; display: flex;
overflow-x: auto;
overflow-inline: auto; overflow-inline: auto;
margin-inline: -24px; margin-inline: -24px;
padding-inline: 22px 160px; padding-inline: 22px 160px;
@ -55,6 +56,14 @@ const isMe = computed(() => isSignedIn(me) && me.id === props.note.userId);
); );
scrollbar-width: none; scrollbar-width: none;
pointer-events: none; pointer-events: none;
@supports not (overflow-inline: auto) {
.vertical-lr &, .vertical-rl & {
overflow-x: visible;
overflow-y: auto;
}
}
:deep(*) { :deep(*) {
pointer-events: all; pointer-events: all;
} }

View file

@ -31,9 +31,17 @@ const emit = defineEmits<{
<style lang="scss" scoped> <style lang="scss" scoped>
.thppypvi { .thppypvi {
max-block-size: 70%; max-block-size: 70%;
overflow-y: scroll;
overflow-block: scroll; overflow-block: scroll;
-ms-overflow-style: none; -ms-overflow-style: none;
scrollbar-width: none; scrollbar-width: none;
@supports not (overflow-block: scroll) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: scroll;
}
}
} }
.thppypvi::-webkit-scrollbar { .thppypvi::-webkit-scrollbar {

View file

@ -96,6 +96,7 @@ export default defineComponent({
padding-block: 12px; padding-block: 12px;
padding-inline: 32px; padding-inline: 32px;
font-size: 0.85em; font-size: 0.85em;
overflow-x: auto;
overflow-inline: auto; overflow-inline: auto;
mask: linear-gradient(var(--gradient-to-inline-end) black calc(100% - 90px), transparent),; mask: linear-gradient(var(--gradient-to-inline-end) black calc(100% - 90px), transparent),;
-webkit-mask: linear-gradient( -webkit-mask: linear-gradient(
@ -106,6 +107,13 @@ export default defineComponent({
padding-inline-end: 90px !important; padding-inline-end: 90px !important;
white-space: nowrap; white-space: nowrap;
@supports not (overflow-inline: auto) {
.vertical-lr &, .vertical-rl & {
overflow-x: visible;
overflow-y: auto;
}
}
&::-webkit-scrollbar { &::-webkit-scrollbar {
display: none; display: none;
} }

View file

@ -16,7 +16,7 @@
@click="tlComponent?.scrollTop()" @click="tlComponent?.scrollTop()"
> >
{{ i18n.ts.newNoteRecived }} {{ i18n.ts.newNoteRecived }}
<i :class="icon('ph-arrow-up', false)"></i> <i :class="icon('ph-arrow-up ph-dir', false)"></i>
</button> </button>
</div> </div>
<MkPullToRefresh <MkPullToRefresh

View file

@ -305,7 +305,16 @@ onUnmounted(() => {
border-block-start: 1px solid var(--divider); border-block-start: 1px solid var(--divider);
display: block; display: block;
inline-size: 100%; inline-size: 100%;
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
@supports not (overflow-block: auto) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: auto;
}
}
&:not([src^="https://platform.twitter"]) &:not([src^="https://platform.twitter"])
{ {
max-block-size: 70vb; max-block-size: 70vb;

View file

@ -278,16 +278,20 @@ onMounted(() => {
display: inline-block; display: inline-block;
block-size: 50%; block-size: 50%;
inline-size: 50%; inline-size: 50%;
position: absolute;
top: 0; // Cat ear positions are irrelevant to text flow direction
} }
&:before { &:before {
border-radius: 25% 75% 75%; border-radius: 25% 75% 75%;
transform: rotate(37.5deg) skew(30deg); transform: rotate(37.5deg) skew(30deg);
left: 0; // Cat ear positions are irrelevant to text flow direction
} }
&:after { &:after {
border-radius: 75% 25% 75% 75%; border-radius: 75% 25% 75% 75%;
transform: rotate(-37.5deg) skew(-30deg); transform: rotate(-37.5deg) skew(-30deg);
right: 0; // Cat ear positions are irrelevant to text flow direction
} }
&:hover { &:hover {

View file

@ -514,6 +514,7 @@ onUnmounted(() => {
> .tabs { > .tabs {
position: relative; position: relative;
font-size: 1em; font-size: 1em;
overflow-x: auto;
overflow-inline: auto; overflow-inline: auto;
white-space: nowrap; white-space: nowrap;
contain: content; contain: content;
@ -533,6 +534,14 @@ onUnmounted(() => {
transparent transparent
); );
scrollbar-width: none; scrollbar-width: none;
@supports not (overflow-inline: auto) {
.vertical-lr &, .vertical-rl & {
overflow-x: visible;
overflow-y: auto;
}
}
&::-webkit-scrollbar { &::-webkit-scrollbar {
display: none; display: none;
} }

View file

@ -115,7 +115,29 @@ function checkForSplash() {
// #region Set lang attr // #region Set lang attr
const html = document.documentElement; const html = document.documentElement;
html.setAttribute("lang", lang || "en-US"); html.setAttribute("lang", lang || "en-US");
html.setAttribute("dir", "auto"); html.setAttribute(
"dir",
[
"ar",
"arc",
"dv",
"fa",
"ha",
"he",
"iw",
"ktw",
"ks",
"ku",
"pk",
"ps",
"ug",
"ur",
"xb",
"yi",
].includes((lang ?? "en").split("-")[0])
? "rtl"
: "ltr",
);
const writingMode = localStorage.getItem("writingMode"); const writingMode = localStorage.getItem("writingMode");
switch (writingMode) { switch (writingMode) {
case "vertical-lr-upright": case "vertical-lr-upright":

View file

@ -466,8 +466,16 @@ XMessage:last-of-type {
> .form { > .form {
max-block-size: 12em; max-block-size: 12em;
overflow-y: scroll;
overflow-block: scroll; overflow-block: scroll;
border-block-start: solid 0.5px var(--divider); border-block-start: solid 0.5px var(--divider);
@supports not (overflow-block: scroll) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: scroll;
}
}
} }
} }
} }

View file

@ -331,9 +331,17 @@ onMounted(() => {
<style lang="scss" scoped> <style lang="scss" scoped>
.xytnxiau { .xytnxiau {
overflow-y: hidden;
overflow-block: hidden; overflow-block: hidden;
position: absolute; position: absolute;
inset-block-start: 0; inset-block-start: 0;
@supports not (overflow-block: hidden) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: hidden;
}
}
} }
.upsvvhaz { .upsvvhaz {

View file

@ -83,7 +83,9 @@ html {
text-size-adjust: 100%; text-size-adjust: 100%;
tab-size: 2; tab-size: 2;
scroll-padding: 60px; scroll-padding: 60px;
overflow-x: clip;
overflow-inline: clip; overflow-inline: clip;
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
text-size-adjust: none; text-size-adjust: none;
-webkit-text-size-adjust: none; -webkit-text-size-adjust: none;
@ -93,6 +95,13 @@ html {
--gradient-to-inline-start: to left; --gradient-to-inline-start: to left;
--gradient-to-inline-end: to right; --gradient-to-inline-end: to right;
@supports not (overflow-inline: clip) {
&.vertical-lr, &.vertical-rl {
overflow-x: auto;
overflow-y: clip;
}
}
&:dir(rtl) { &:dir(rtl) {
--gradient-to-inline-start: to right; --gradient-to-inline-start: to right;
--gradient-to-inline-end: to left; --gradient-to-inline-end: to left;

View file

@ -261,10 +261,19 @@ function more(ev: MouseEvent) {
block-size: 100dvb; block-size: 100dvb;
box-sizing: border-box; box-sizing: border-box;
overflow: auto; overflow: auto;
overflow-x: clip;
overflow-inline: clip; overflow-inline: clip;
contain: strict; contain: strict;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
@supports not (overflow-inline: clip) {
.vertical-lr &, .vertical-rl & {
overflow-x: auto;
overflow-y: clip;
}
}
#firefish_app > :not(.wallpaper) & { #firefish_app > :not(.wallpaper) & {
background: var(--navBg); background: var(--navBg);
} }

View file

@ -432,9 +432,18 @@ async function deleteProfile() {
> .columns { > .columns {
flex: 1; flex: 1;
display: flex; display: flex;
overflow-x: auto;
overflow-inline: auto; overflow-inline: auto;
overflow-y: clip;
overflow-block: clip; overflow-block: clip;
@supports not (overflow-block: clip) {
.vertical-lr &, .vertical-rl & {
overflow-y: auto;
overflow-x: clip;
}
}
&.center { &.center {
> .column:first-of-type { > .column:first-of-type {
margin-inline-start: auto; margin-inline-start: auto;

View file

@ -463,11 +463,22 @@ function onDrop(ev) {
> div { > div {
block-size: calc(100% - var(--deckColumnHeaderHeight)); block-size: calc(100% - var(--deckColumnHeaderHeight));
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
overflow-x: hidden;
overflow-inline: hidden; // Safari does not supports clip overflow-inline: hidden; // Safari does not supports clip
overflow-x: clip;
overflow-inline: clip; overflow-inline: clip;
-webkit-overflow-scrolling: touch; -webkit-overflow-scrolling: touch;
box-sizing: border-box; box-sizing: border-box;
@supports not (overflow-block: auto) {
.vertical-lr &, .vertical-rl & {
overflow-y: hidden;
overflow-y: clip;
overflow-x: auto;
}
}
} }
} }
</style> </style>

View file

@ -663,7 +663,16 @@ console.log(mainRouter.currentRoute.value.name);
inline-size: 100%; inline-size: 100%;
min-inline-size: 0; min-inline-size: 0;
$widgets-hide-threshold: 1090px; $widgets-hide-threshold: 1090px;
overflow-x: clip;
overflow-inline: clip; overflow-inline: clip;
@supports not (overflow-inline: clip) {
.vertical-lr &, .vertical-rl & {
overflow-x: visible;
overflow-y: clip;
}
}
@media (max-inline-size: $widgets-hide-threshold) { @media (max-inline-size: $widgets-hide-threshold) {
padding-block-end: calc(env(safe-area-inset-bottom, 0px) + 96px); padding-block-end: calc(env(safe-area-inset-bottom, 0px) + 96px);
} }
@ -673,6 +682,7 @@ console.log(mainRouter.currentRoute.value.name);
position: sticky; position: sticky;
inset-block-start: 0; inset-block-start: 0;
max-block-size: 100vb; max-block-size: 100vb;
overflow-y: auto;
overflow-block: auto; overflow-block: auto;
padding-block: 0; padding-block: 0;
padding-inline: var(--margin); padding-inline: var(--margin);
@ -680,6 +690,13 @@ console.log(mainRouter.currentRoute.value.name);
min-inline-size: max-content; min-inline-size: max-content;
box-sizing: content-box; box-sizing: content-box;
@supports not (overflow-block: auto) {
.vertical-lr &, .vertical-rl & {
overflow-y: visible;
overflow-x: auto;
}
}
@media (max-inline-size: $widgets-hide-threshold) { @media (max-inline-size: $widgets-hide-threshold) {
display: none; display: none;
} }