Save tags unique and case-insensitive. Don't clear added tags on updating description.
This commit is contained in:
parent
997f13d986
commit
6427e1bd06
|
@ -19,7 +19,7 @@ export function getNewContract(
|
||||||
calcStartPool(initialProb, ante)
|
calcStartPool(initialProb, ante)
|
||||||
|
|
||||||
const tags = parseTags(
|
const tags = parseTags(
|
||||||
`${extraTags.map((tag) => `#${tag}`).join(' ')} ${question} ${description}`
|
`${question} ${description} ${extraTags.map((tag) => `#${tag}`).join(' ')}`
|
||||||
)
|
)
|
||||||
const lowercaseTags = tags.map((tag) => tag.toLowerCase())
|
const lowercaseTags = tags.map((tag) => tag.toLowerCase())
|
||||||
|
|
||||||
|
|
|
@ -3,19 +3,25 @@ export function parseTags(text: string) {
|
||||||
const matches = (text.match(regex) || []).map((match) =>
|
const matches = (text.match(regex) || []).map((match) =>
|
||||||
match.trim().substring(1)
|
match.trim().substring(1)
|
||||||
)
|
)
|
||||||
const tagSet = new Set(matches)
|
const tagSet = new Set()
|
||||||
const uniqueTags: string[] = []
|
const uniqueTags: string[] = []
|
||||||
tagSet.forEach((tag) => uniqueTags.push(tag))
|
// Keep casing of last tag.
|
||||||
|
matches.reverse()
|
||||||
|
for (const tag of matches) {
|
||||||
|
const lowercase = tag.toLowerCase()
|
||||||
|
if (!tagSet.has(lowercase)) {
|
||||||
|
tagSet.add(lowercase)
|
||||||
|
uniqueTags.push(tag)
|
||||||
|
}
|
||||||
|
}
|
||||||
|
uniqueTags.reverse()
|
||||||
return uniqueTags
|
return uniqueTags
|
||||||
}
|
}
|
||||||
|
|
||||||
export function parseWordsAsTags(text: string) {
|
export function parseWordsAsTags(text: string) {
|
||||||
const regex = /(?:^|\s)(?:#?[a-z0-9_]+)/gi
|
const taggedText = text
|
||||||
const matches = (text.match(regex) || [])
|
.split(/\s+/)
|
||||||
.map((match) => match.replace('#', '').trim())
|
.map((tag) => `#${tag}`)
|
||||||
.filter((tag) => tag)
|
.join(' ')
|
||||||
const tagSet = new Set(matches)
|
return parseTags(taggedText)
|
||||||
const uniqueTags: string[] = []
|
|
||||||
tagSet.forEach((tag) => uniqueTags.push(tag))
|
|
||||||
return uniqueTags
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -142,12 +142,9 @@ export function AbbrContractDetails(props: {
|
||||||
|
|
||||||
export function ContractDetails(props: { contract: Contract }) {
|
export function ContractDetails(props: { contract: Contract }) {
|
||||||
const { contract } = props
|
const { contract } = props
|
||||||
const { question, description, closeTime, creatorName, creatorUsername } =
|
const { closeTime, creatorName, creatorUsername } = contract
|
||||||
contract
|
|
||||||
const { truePool, createdDate, resolvedDate } = contractMetrics(contract)
|
const { truePool, createdDate, resolvedDate } = contractMetrics(contract)
|
||||||
|
|
||||||
const tags = parseTags(`${question} ${description}`).map((tag) => `#${tag}`)
|
|
||||||
|
|
||||||
return (
|
return (
|
||||||
<Col className="text-sm text-gray-500 gap-2 sm:flex-row sm:flex-wrap">
|
<Col className="text-sm text-gray-500 gap-2 sm:flex-row sm:flex-wrap">
|
||||||
<Row className="gap-2 flex-wrap">
|
<Row className="gap-2 flex-wrap">
|
||||||
|
@ -199,10 +196,10 @@ export function ContractDetails(props: { contract: Contract }) {
|
||||||
|
|
||||||
// String version of the above, to send to the OpenGraph image generator
|
// String version of the above, to send to the OpenGraph image generator
|
||||||
export function contractTextDetails(contract: Contract) {
|
export function contractTextDetails(contract: Contract) {
|
||||||
const { question, description, closeTime } = contract
|
const { closeTime, tags } = contract
|
||||||
const { truePool, createdDate, resolvedDate } = contractMetrics(contract)
|
const { truePool, createdDate, resolvedDate } = contractMetrics(contract)
|
||||||
|
|
||||||
const tags = parseTags(`${question} ${description}`).map((tag) => `#${tag}`)
|
const hashtags = tags.map((tag) => `#${tag}`)
|
||||||
|
|
||||||
return (
|
return (
|
||||||
`${resolvedDate ? `${createdDate} - ${resolvedDate}` : createdDate}` +
|
`${resolvedDate ? `${createdDate} - ${resolvedDate}` : createdDate}` +
|
||||||
|
@ -212,6 +209,6 @@ export function contractTextDetails(contract: Contract) {
|
||||||
).format('MMM D, h:mma')}`
|
).format('MMM D, h:mma')}`
|
||||||
: '') +
|
: '') +
|
||||||
` • ${formatMoney(truePool)} pool` +
|
` • ${formatMoney(truePool)} pool` +
|
||||||
(tags.length > 0 ? ` • ${tags.join(' ')}` : '')
|
(hashtags.length > 0 ? ` • ${hashtags.join(' ')}` : '')
|
||||||
)
|
)
|
||||||
}
|
}
|
||||||
|
|
|
@ -160,7 +160,9 @@ export function ContractDescription(props: {
|
||||||
setEditing(false)
|
setEditing(false)
|
||||||
|
|
||||||
const newDescription = `${contract.description}\n\n${description}`.trim()
|
const newDescription = `${contract.description}\n\n${description}`.trim()
|
||||||
const tags = parseTags(`${contract.tags.join(' ')} ${newDescription}`)
|
const tags = parseTags(
|
||||||
|
`${newDescription} ${contract.tags.map((tag) => `#${tag}`).join(' ')}`
|
||||||
|
)
|
||||||
const lowercaseTags = tags.map((tag) => tag.toLowerCase())
|
const lowercaseTags = tags.map((tag) => tag.toLowerCase())
|
||||||
await updateContract(contract.id, {
|
await updateContract(contract.id, {
|
||||||
description: newDescription,
|
description: newDescription,
|
||||||
|
|
|
@ -11,7 +11,6 @@ import {
|
||||||
import { User } from '../lib/firebase/users'
|
import { User } from '../lib/firebase/users'
|
||||||
import { Col } from './layout/col'
|
import { Col } from './layout/col'
|
||||||
import { SiteLink } from './site-link'
|
import { SiteLink } from './site-link'
|
||||||
import { parseTags } from '../../common/util/parse'
|
|
||||||
import { ContractCard } from './contract-card'
|
import { ContractCard } from './contract-card'
|
||||||
import { Sort, useQueryAndSortParams } from '../hooks/use-sort-and-query-params'
|
import { Sort, useQueryAndSortParams } from '../hooks/use-sort-and-query-params'
|
||||||
|
|
||||||
|
|
Loading…
Reference in New Issue
Block a user