b2501d8145
* Answer datatype and MULTI outcome type for Contract
* Create free answer contract
* Automatically sort Tailwind classes with Prettier (#45)
* Add Prettier Tailwind plugin
* Autoformat Tailwind classes with Prettier
* Allow for non-binary contracts in contract page and related components
* logo with white inside, transparent bg
* Create answer
* Some UI for showing answers
* Answer bet panel
* Convert rest of calcuate file to generic multi contracts
* Working betting with ante'd NONE answer
* Numbered answers. Layout & calculation tweaks
* Can bet. More layout tweaks!
* Resolve answer UI
* Resolve multi market
* Resolved market UI
* Fix feed and cards for multi contracts
* Sell bets. Various fixes
* Tweaks for trades page
* Always dev mode
* Create answer bet has isAnte: true
* Fix card showing 0% for multi contracts
* Fix grouped bets feed for multi outcomes
* None option converted to none of the above label at bottom of list. Button to resolve none.
* Tweaks to no answers yet, resolve button layout
* Show ante bets on new answers in the feed
* Update placeholder text for description
* Consolidate firestore rules for subcollections
* Remove Contract and Bet type params. Use string type for outcomes.
* Increase char limit to 10k for answers. Preserve line breaks.
* Don't show resolve options after answer chosen
* Fix type error in script
* Remove NONE resolution option
* Change outcomeType to include 'MULTI' and 'FREE_RESPONSE'
* Show bet probability change and payout when creating answer
* User info change: also change answers
* Append answers to contract field 'answers'
* sort trades by resolved
* Don't include trailing !:,.; in links
* Stop flooring inputs into formatMoney
* Revert "Stop flooring inputs into formatMoney"
This reverts commit 2f7ab18429
.
* Consistently floor user.balance
* Expand create panel on focus
From Richard Hanania's feedback
* welcome email: include link to manifold
* Fix home page in dev on branches that are not free-response
* Close emails (#50)
* script init for stephen dev
* market close emails
* order of operations
* template email
* sendMarketCloseEmail: handle unsubscribe
* remove debugging
* marketCloseEmails: every hour
* sendMarketCloseEmails: check undefined
* marketCloseEmails: "every hour" => "every 1 hours"
* Set up a read API using Vercel serverless functions (#49)
* Set up read API using Vercel serverless functions
Featuring:
/api/v0/markets
/api/v0/market/[contractId]
/api/v0/slug/[contractSlug]
* Include tags in API
* Tweaks. Remove filter for only binary contract
* Fix bet probability change for NO bets
* Put back isProd calculation
Co-authored-by: Austin Chen <akrolsmir@gmail.com>
Co-authored-by: mantikoros <sgrugett@gmail.com>
Co-authored-by: mantikoros <95266179+mantikoros@users.noreply.github.com>
63 lines
1.8 KiB
TypeScript
63 lines
1.8 KiB
TypeScript
import { getFunctions, httpsCallable } from 'firebase/functions'
|
|
import { Fold } from '../../../common/fold'
|
|
import { User } from '../../../common/user'
|
|
import { randomString } from '../../../common/util/random'
|
|
import './init'
|
|
|
|
const functions = getFunctions()
|
|
|
|
export const cloudFunction = <RequestData, ResponseData>(name: string) =>
|
|
httpsCallable<RequestData, ResponseData>(functions, name)
|
|
|
|
export const createContract = cloudFunction('createContract')
|
|
|
|
export const createFold = cloudFunction<
|
|
{ name: string; about: string; tags: string[] },
|
|
{ status: 'error' | 'success'; message?: string; fold?: Fold }
|
|
>('createFold')
|
|
|
|
export const placeBet = cloudFunction('placeBet')
|
|
|
|
export const createAnswer = cloudFunction<
|
|
{ contractId: string; text: string; amount: number },
|
|
{
|
|
status: 'error' | 'success'
|
|
message?: string
|
|
answerId?: string
|
|
betId?: string
|
|
}
|
|
>('createAnswer')
|
|
|
|
export const resolveMarket = cloudFunction<
|
|
{
|
|
outcome: string
|
|
contractId: string
|
|
probabilityInt?: number
|
|
},
|
|
{ status: 'error' | 'success'; message?: string }
|
|
>('resolveMarket')
|
|
|
|
export const sellBet = cloudFunction('sellBet')
|
|
|
|
export const createUser: () => Promise<User | null> = () => {
|
|
let deviceToken = window.localStorage.getItem('device-token')
|
|
if (!deviceToken) {
|
|
deviceToken = randomString()
|
|
window.localStorage.setItem('device-token', deviceToken)
|
|
}
|
|
|
|
return cloudFunction('createUser')({ deviceToken })
|
|
.then((r) => (r.data as any)?.user || null)
|
|
.catch(() => null)
|
|
}
|
|
|
|
export const changeUserInfo = (data: {
|
|
username?: string
|
|
name?: string
|
|
avatarUrl?: string
|
|
}) => {
|
|
return cloudFunction('changeUserInfo')(data)
|
|
.then((r) => r.data as { status: string; message?: string })
|
|
.catch((e) => ({ status: 'error', message: e.message }))
|
|
}
|