fix bio quirks

This commit is contained in:
k00b 2024-10-02 18:12:49 -05:00
parent c400a6c1c6
commit 5fab3abb82
4 changed files with 9 additions and 9 deletions

View File

@ -23,8 +23,8 @@ export async function getCost ({ subName, parentId, uploadIds, boost = 0, bio },
// sub allows freebies (or is a bio or a comment), cost is less than baseCost, not anon, // sub allows freebies (or is a bio or a comment), cost is less than baseCost, not anon,
// cost must be greater than user's balance, and user has not disabled freebies // cost must be greater than user's balance, and user has not disabled freebies
const freebie = (parentId || bio) && cost <= baseCost && !!me && const freebie = bio || (parentId && cost <= baseCost && !!me &&
cost > me?.msats && !me?.disableFreebies cost > me?.msats && !me?.disableFreebies)
return freebie ? BigInt(0) : BigInt(cost) return freebie ? BigInt(0) : BigInt(cost)
} }

View File

@ -8,7 +8,7 @@ export const anonable = true
export const supportsPessimism = true export const supportsPessimism = true
export const supportsOptimism = false export const supportsOptimism = false
export async function getCost ({ id, boost = 0, uploadIds }, { me, models }) { export async function getCost ({ id, boost = 0, uploadIds, bio }, { me, models }) {
// the only reason updating items costs anything is when it has new uploads // the only reason updating items costs anything is when it has new uploads
// or more boost // or more boost
const old = await models.item.findUnique({ where: { id: parseInt(id) } }) const old = await models.item.findUnique({ where: { id: parseInt(id) } })
@ -19,7 +19,7 @@ export async function getCost ({ id, boost = 0, uploadIds }, { me, models }) {
throw new Error('creation invoice not paid') throw new Error('creation invoice not paid')
} }
return cost return bio ? BigInt(0) : cost
} }
export async function perform (args, context) { export async function perform (args, context) {

View File

@ -691,7 +691,7 @@ export default {
return Number(photoId) return Number(photoId)
}, },
upsertBio: async (parent, { bio }, { me, models }) => { upsertBio: async (parent, { bio }, { me, models, lnd }) => {
if (!me) { if (!me) {
throw new GqlAuthenticationError() throw new GqlAuthenticationError()
} }
@ -701,9 +701,9 @@ export default {
const user = await models.user.findUnique({ where: { id: me.id } }) const user = await models.user.findUnique({ where: { id: me.id } })
if (user.bioId) { if (user.bioId) {
await updateItem(parent, { id: user.bioId, text: bio, title: `@${user.name}'s bio` }, { me, models }) await updateItem(parent, { id: user.bioId, text: bio, title: `@${user.name}'s bio` }, { me, models, lnd })
} else { } else {
await createItem(parent, { bio: true, text: bio, title: `@${user.name}'s bio` }, { me, models }) await createItem(parent, { bio: true, text: bio, title: `@${user.name}'s bio` }, { me, models, lnd })
} }
return await models.user.findUnique({ where: { id: me.id } }) return await models.user.findUnique({ where: { id: me.id } })

View File

@ -37,7 +37,7 @@ export default function ItemInfo ({
const editThreshold = new Date(item.invoice?.confirmedAt ?? item.createdAt).getTime() + 10 * 60000 const editThreshold = new Date(item.invoice?.confirmedAt ?? item.createdAt).getTime() + 10 * 60000
const { me } = useMe() const { me } = useMe()
const router = useRouter() const router = useRouter()
const [canEdit, setCanEdit] = useState(item.mine && (Date.now() < editThreshold)) const [canEdit, setCanEdit] = useState(item.mine && !item.bio && (Date.now() < editThreshold))
const [hasNewComments, setHasNewComments] = useState(false) const [hasNewComments, setHasNewComments] = useState(false)
const root = useRoot() const root = useRoot()
const sub = item?.sub || root?.sub const sub = item?.sub || root?.sub
@ -49,7 +49,7 @@ export default function ItemInfo ({
}, [item]) }, [item])
useEffect(() => { useEffect(() => {
const authorEdit = item.mine const authorEdit = item.mine && !item.bio
const invParams = window.localStorage.getItem(`item:${item.id}:hash:hmac`) const invParams = window.localStorage.getItem(`item:${item.id}:hash:hmac`)
const hmacEdit = !!invParams && !me && Number(item.user.id) === USER_ID.anon const hmacEdit = !!invParams && !me && Number(item.user.id) === USER_ID.anon
setCanEdit((authorEdit || hmacEdit) && (Date.now() < editThreshold)) setCanEdit((authorEdit || hmacEdit) && (Date.now() < editThreshold))