2024-09-19 18:13:14 +00:00
|
|
|
import { useState, useEffect, useMemo } from 'react'
|
2021-09-11 21:52:19 +00:00
|
|
|
import AccordianItem from './accordian-item'
|
2023-10-22 16:54:27 +00:00
|
|
|
import { Input, InputUserSuggest, VariableInput, Checkbox } from './form'
|
2023-07-24 18:35:05 +00:00
|
|
|
import InputGroup from 'react-bootstrap/InputGroup'
|
2024-03-20 00:37:31 +00:00
|
|
|
import { BOOST_MIN, BOOST_MULT, MAX_FORWARDS } from '@/lib/constants'
|
|
|
|
import { DEFAULT_CROSSPOSTING_RELAYS } from '@/lib/nostr'
|
2022-07-24 00:00:57 +00:00
|
|
|
import Info from './info'
|
2024-03-20 00:37:31 +00:00
|
|
|
import { numWithUnits } from '@/lib/format'
|
2023-09-12 20:56:03 +00:00
|
|
|
import styles from './adv-post-form.module.css'
|
2023-10-04 18:47:09 +00:00
|
|
|
import { useMe } from './me'
|
2023-11-11 00:18:10 +00:00
|
|
|
import { useFeeButton } from './fee-button'
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
import { useRouter } from 'next/router'
|
2024-05-12 21:17:41 +00:00
|
|
|
import { useFormikContext } from 'formik'
|
2024-09-19 18:13:14 +00:00
|
|
|
import { gql, useLazyQuery } from '@apollo/client'
|
|
|
|
import useDebounceCallback from './use-debounce-callback'
|
2021-09-11 21:52:19 +00:00
|
|
|
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
const EMPTY_FORWARD = { nym: '', pct: '' }
|
|
|
|
|
2023-10-22 16:54:27 +00:00
|
|
|
export function AdvPostInitial ({ forward, boost }) {
|
2022-08-18 18:15:24 +00:00
|
|
|
return {
|
2023-09-26 00:54:35 +00:00
|
|
|
boost: boost || '',
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
forward: forward?.length ? forward : [EMPTY_FORWARD]
|
2022-08-18 18:15:24 +00:00
|
|
|
}
|
2021-09-11 21:52:19 +00:00
|
|
|
}
|
|
|
|
|
2024-05-13 15:14:35 +00:00
|
|
|
const FormStatus = {
|
|
|
|
DIRTY: 'dirty',
|
|
|
|
ERROR: 'error'
|
|
|
|
}
|
|
|
|
|
2024-09-19 18:13:14 +00:00
|
|
|
export function BoostHelp () {
|
|
|
|
return (
|
|
|
|
<ol style={{ lineHeight: 1.25 }}>
|
|
|
|
<li>Boost ranks items higher based on the amount</li>
|
|
|
|
<li>The highest boost in a territory over the last 30 days is pinned to the top of the territory</li>
|
|
|
|
<li>The highest boost across all territories over the last 30 days is pinned to the top of the homepage</li>
|
|
|
|
<li>The minimum boost is {numWithUnits(BOOST_MIN, { abbreviate: false })}</li>
|
|
|
|
<li>Each {numWithUnits(BOOST_MULT, { abbreviate: false })} of boost is equivalent to a zap-vote from a maximally trusted stacker
|
|
|
|
<ul>
|
|
|
|
<li>e.g. {numWithUnits(BOOST_MULT * 5, { abbreviate: false })} is like five zap-votes from a maximally trusted stacker</li>
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li>The decay of boost "votes" increases at 1.25x the rate of organic votes
|
|
|
|
<ul>
|
|
|
|
<li>i.e. boost votes fall out of ranking faster</li>
|
|
|
|
</ul>
|
|
|
|
</li>
|
|
|
|
<li>boost can take a few minutes to show higher ranking in feed</li>
|
|
|
|
<li>100% of boost goes to the territory founder and top stackers as rewards</li>
|
|
|
|
</ol>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export function BoostInput ({ onChange, ...props }) {
|
|
|
|
const feeButton = useFeeButton()
|
|
|
|
let merge
|
|
|
|
if (feeButton) {
|
|
|
|
({ merge } = feeButton)
|
|
|
|
}
|
|
|
|
return (
|
|
|
|
<Input
|
|
|
|
label={
|
|
|
|
<div className='d-flex align-items-center'>boost
|
|
|
|
<Info>
|
|
|
|
<BoostHelp />
|
|
|
|
</Info>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
name='boost'
|
|
|
|
onChange={(_, e) => {
|
|
|
|
merge?.({
|
|
|
|
boost: {
|
|
|
|
term: `+ ${e.target.value}`,
|
|
|
|
label: 'boost',
|
|
|
|
op: '+',
|
|
|
|
modifier: cost => cost + Number(e.target.value)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
onChange && onChange(_, e)
|
|
|
|
}}
|
|
|
|
hint={<span className='text-muted'>ranks posts higher temporarily based on the amount</span>}
|
|
|
|
append={<InputGroup.Text className='text-monospace'>sats</InputGroup.Text>}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
// act means we are adding to existing boost
|
|
|
|
export function BoostItemInput ({ item, sub, act = false, ...props }) {
|
|
|
|
const [boost, setBoost] = useState(Number(item?.boost) + (act ? BOOST_MULT : 0))
|
|
|
|
|
|
|
|
const [getBoostPosition, { data }] = useLazyQuery(gql`
|
|
|
|
query BoostPosition($id: ID, $boost: Int) {
|
|
|
|
boostPosition(sub: "${item?.subName || sub?.name}", id: $id, boost: $boost) {
|
|
|
|
home
|
|
|
|
sub
|
|
|
|
}
|
|
|
|
}`,
|
|
|
|
{ fetchPolicy: 'cache-and-network' })
|
|
|
|
|
|
|
|
const getPositionDebounce = useDebounceCallback((...args) => getBoostPosition(...args), 1000, [getBoostPosition])
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
if (boost) {
|
|
|
|
getPositionDebounce({ variables: { boost: Number(boost), id: item?.id } })
|
|
|
|
}
|
|
|
|
}, [boost, item?.id])
|
|
|
|
|
|
|
|
const boostMessage = useMemo(() => {
|
|
|
|
if (data?.boostPosition?.home || data?.boostPosition?.sub) {
|
|
|
|
const boostPinning = []
|
|
|
|
if (data?.boostPosition?.home) {
|
|
|
|
boostPinning.push('homepage')
|
|
|
|
}
|
|
|
|
if (data?.boostPosition?.sub) {
|
|
|
|
boostPinning.push(`~${item?.subName || sub?.name}`)
|
|
|
|
}
|
|
|
|
return `pins to the top of ${boostPinning.join(' and ')}`
|
|
|
|
} else if (boost >= 0 && boost % BOOST_MULT === 0) {
|
|
|
|
return `${act ? 'brings to' : 'equivalent to'} ${numWithUnits(boost / BOOST_MULT, { unitPlural: 'zapvotes', unitSingular: 'zapvote' })}`
|
|
|
|
} else {
|
|
|
|
return 'ranks posts higher based on the amount'
|
|
|
|
}
|
|
|
|
}, [boost, data?.boostPosition?.home, data?.boostPosition?.sub, item?.subName, sub?.name])
|
|
|
|
|
|
|
|
return (
|
|
|
|
<BoostInput
|
|
|
|
hint={<span className='text-muted'>{boostMessage}</span>}
|
|
|
|
onChange={(_, e) => {
|
|
|
|
if (e.target.value >= 0) {
|
|
|
|
setBoost(Number(e.target.value) + (act ? Number(item?.boost) : 0))
|
|
|
|
}
|
|
|
|
}}
|
|
|
|
{...props}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|
|
|
|
|
|
|
|
export default function AdvPostForm ({ children, item, sub, storageKeyPrefix }) {
|
2024-09-12 18:05:11 +00:00
|
|
|
const { me } = useMe()
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
const router = useRouter()
|
|
|
|
const [itemType, setItemType] = useState()
|
2024-05-12 21:17:41 +00:00
|
|
|
const formik = useFormikContext()
|
2024-05-13 15:14:35 +00:00
|
|
|
const [show, setShow] = useState(false)
|
2024-05-12 21:17:41 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const isDirty = formik?.values.forward?.[0].nym !== '' || formik?.values.forward?.[0].pct !== '' ||
|
|
|
|
formik?.values.boost !== '' || (router.query?.type === 'link' && formik?.values.text !== '')
|
|
|
|
|
|
|
|
// if the adv post form is dirty on first render, show the accordian
|
|
|
|
if (isDirty) {
|
2024-05-13 15:14:35 +00:00
|
|
|
setShow(FormStatus.DIRTY)
|
2024-05-12 21:17:41 +00:00
|
|
|
}
|
|
|
|
|
|
|
|
// HACK ... TODO: we should generically handle this kind of local storage stuff
|
|
|
|
// in the form component, overriding the initial values
|
|
|
|
if (storageKeyPrefix) {
|
|
|
|
for (let i = 0; i < MAX_FORWARDS; i++) {
|
|
|
|
['nym', 'pct'].forEach(key => {
|
|
|
|
const value = window.localStorage.getItem(`${storageKeyPrefix}-forward[${i}].${key}`)
|
|
|
|
if (value) {
|
|
|
|
formik?.setFieldValue(`forward[${i}].${key}`, value)
|
|
|
|
}
|
|
|
|
})
|
|
|
|
}
|
|
|
|
}
|
|
|
|
}, [formik?.values, storageKeyPrefix])
|
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
// force show the accordian if there is an error and the form is submitting
|
|
|
|
const hasError = !!formik?.errors?.boost || formik?.errors?.forward?.length > 0
|
|
|
|
// if it's open we don't want to collapse on submit
|
2024-05-13 15:14:35 +00:00
|
|
|
setShow(show => hasError && formik?.isSubmitting ? FormStatus.ERROR : show)
|
2024-05-12 21:17:41 +00:00
|
|
|
}, [formik?.isSubmitting])
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
|
|
|
|
useEffect(() => {
|
|
|
|
const determineItemType = () => {
|
|
|
|
if (router && router.query.type) {
|
|
|
|
return router.query.type
|
|
|
|
} else if (item) {
|
|
|
|
const typeMap = {
|
|
|
|
url: 'link',
|
|
|
|
bounty: 'bounty',
|
|
|
|
pollCost: 'poll'
|
|
|
|
}
|
|
|
|
|
|
|
|
for (const [key, type] of Object.entries(typeMap)) {
|
|
|
|
if (item[key]) {
|
|
|
|
return type
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return 'discussion'
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
const type = determineItemType()
|
|
|
|
setItemType(type)
|
|
|
|
}, [item, router])
|
|
|
|
|
|
|
|
function renderCrosspostDetails (itemType) {
|
|
|
|
switch (itemType) {
|
|
|
|
case 'discussion':
|
|
|
|
return <li>crosspost this discussion as a NIP-23 event</li>
|
|
|
|
case 'link':
|
|
|
|
return <li>crosspost this link as a NIP-01 event</li>
|
|
|
|
case 'bounty':
|
|
|
|
return <li>crosspost this bounty as a NIP-99 event</li>
|
|
|
|
case 'poll':
|
|
|
|
return <li>crosspost this poll as a NIP-41 event</li>
|
|
|
|
default:
|
|
|
|
return null
|
|
|
|
}
|
|
|
|
}
|
2023-10-04 18:47:09 +00:00
|
|
|
|
2021-09-11 21:52:19 +00:00
|
|
|
return (
|
|
|
|
<AccordianItem
|
2021-09-12 16:55:38 +00:00
|
|
|
header={<div style={{ fontWeight: 'bold', fontSize: '92%' }}>options</div>}
|
2024-05-12 21:17:41 +00:00
|
|
|
show={show}
|
2021-09-11 21:52:19 +00:00
|
|
|
body={
|
2022-04-18 20:19:07 +00:00
|
|
|
<>
|
2023-10-22 16:54:27 +00:00
|
|
|
{children}
|
2024-09-19 18:13:14 +00:00
|
|
|
<BoostItemInput item={item} sub={sub} />
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
<VariableInput
|
|
|
|
label='forward sats to'
|
2022-04-18 20:19:07 +00:00
|
|
|
name='forward'
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
min={0}
|
|
|
|
max={MAX_FORWARDS}
|
|
|
|
emptyItem={EMPTY_FORWARD}
|
|
|
|
hint={<span className='text-muted'>Forward sats to up to 5 other stackers. Any remaining sats go to you.</span>}
|
|
|
|
>
|
|
|
|
{({ index, placeholder }) => {
|
|
|
|
return (
|
|
|
|
<div key={index} className='d-flex flex-row'>
|
|
|
|
<InputUserSuggest
|
|
|
|
name={`forward[${index}].nym`}
|
|
|
|
prepend={<InputGroup.Text>@</InputGroup.Text>}
|
|
|
|
showValid
|
2023-09-12 20:56:03 +00:00
|
|
|
groupClassName={`${styles.name} me-3 mb-0`}
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
/>
|
|
|
|
<Input
|
|
|
|
name={`forward[${index}].pct`}
|
|
|
|
type='number'
|
2023-08-28 19:31:28 +00:00
|
|
|
step={5}
|
|
|
|
min={1}
|
|
|
|
max={100}
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
append={<InputGroup.Text className='text-monospace'>%</InputGroup.Text>}
|
2023-09-12 20:56:03 +00:00
|
|
|
groupClassName={`${styles.percent} mb-0`}
|
multiple forwards on a post (#403)
* multiple forwards on a post
first phase of the multi-forward support
* update the graphql mutation for discussion posts to accept and validate multiple forwards
* update the discussion form to allow multiple forwards in the UI
* start working on db schema changes
* uncomment db schema, add migration to create the new model, and update create_item, update_item
stored procedures
* Propagate updates from discussion to poll, link, and bounty forms
Update the create, update poll sql functions for multi forward support
* Update gql, typedefs, and resolver to return forwarded users in items responses
* UI changes to show multiple forward recipients, and conditional upvote logic changes
* Update notification text to reflect multiple forwards upon vote action
* Disallow duplicate stacker entries
* reduce duplication in populating adv-post-form initial values
* Update item_act sql function to implement multi-way forwarding
* Update referral functions to scale referral bonuses for forwarded users
* Update notification text to reflect non-100% forwarded sats cases
* Update wallet history sql queries to accommodate multi-forward use cases
* Block zaps for posts you are forwarded zaps at the API layer, in addition
to in the UI
* Delete fwdUserId column from Item table as part of migration
* Fix how we calculate stacked sats after partial forwards in wallet history
* Exclude entries from wallet history that are 0 stacked sats from posts with 100% forwarded to other users
* Fix wallet history query for forwarded stacked sats to be scaled by the fwd pct
* Reduce duplication in adv post form, and do some style tweaks for better layout
* Use MAX_FORWARDS constants
* Address various PR feedback
* first enhancement pass
* enhancement pass too
---------
Co-authored-by: keyan <keyan.kousha+huumn@gmail.com>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2023-08-23 22:44:17 +00:00
|
|
|
/>
|
|
|
|
</div>
|
|
|
|
)
|
|
|
|
}}
|
|
|
|
</VariableInput>
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
{me && itemType &&
|
2023-10-04 18:47:09 +00:00
|
|
|
<Checkbox
|
|
|
|
label={
|
|
|
|
<div className='d-flex align-items-center'>crosspost to nostr
|
|
|
|
<Info>
|
2024-09-08 21:53:13 +00:00
|
|
|
<ul>
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
{renderCrosspostDetails(itemType)}
|
2023-10-04 18:47:09 +00:00
|
|
|
<li>requires NIP-07 extension for signing</li>
|
|
|
|
<li>we use your NIP-05 relays if set</li>
|
Nostr crossposting all item types (#779)
* crosspost-item
* crosspost old items, update with nEventId
* Updating noteId encoding, cleaning up a little
* Fixing item-info condition, cleaning up
* Linting
* Add createdAt variable back
* Change instances of eventId to noteId
* Adding upsertNoteId mutation
* Cleaning up updateItem, using toasts to communivate success/failure in crosspost-item
* Linting
* Move crosspost to share button, make sure only OP can crosspost
* Lint
* Simplify conditions
* user might have no nostr extension installed
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
* change upsertNoteId to updateNoteID for resolver and mutations, change isOp to mine, remove unused noteId params
* Basic setup for crossposting poll / link items
* post rebase fixes and Bounty and job crossposts
* Job crossposting working
* adding back accidentally removed import
* Lint / rebase
* Outsource as much crossposting logic from discussion-form into use-crossposter as possible
* Fix incorrect property for user relays, fix itemId param in updateNoteId
* Fix toast messages / error cases in use-crossposter
* Update item forms to for updated use-crossposter hook
* CrosspostDropdownItem in share updated to accomodate use-crossposter update
* Encode paramaterized replacable event id's in naddress format with nostr-tools, bounty to follw nip-99 spec
* Increase timeout on relay connection / cleaning up
* No longer crossposting job
* Add blastr, fix crosspost button in item-info for polls/discussions, finish removing job crosspostr code
* Fix toaster error, create reusable crossposterror function to surface toaster
* Cleaning up / comments / linting
* Update copy
* Simplify CrosspostdropdownItem, keep replies from being crossposted
* Moved query for missing item fields when crossposting to use-crossposter hook
* Remove unneeded param in CrosspostDropdownItem, lint
* Small fixes post rebase
* Remove unused import
* fix nostr-tools version, fix package-lock.json
* Update components/item-info.js
Co-authored-by: ekzyis <ek@stacker.news>
* Remove unused param, determine poll item type from pollCost field, add mutiny strfry relay to defaults
* Update toaster implementations, use no-cache for item query, restructure crosspostItem to use await with try catch
* crosspost info modal that lives under adv-post-form now has dynamic crossposting info
* Move determineItemType into handleEventCreation, mover item/event handing outside of do ... while loop
* Lint
* Reconcile skip method with onCancel function in toaster
* Handle failedRelays being undefined
* determine item type from router.query.type if available otherwise use item fields
* Initiliaze failerRelays as undefined but handle error explicitly
* Lint
* Fix crosspost default value for link, poll, bounty forms
---------
Co-authored-by: ekzyis <27162016+ekzyis@users.noreply.github.com>
Co-authored-by: ekzyis <ek@stacker.news>
Co-authored-by: Keyan <34140557+huumn@users.noreply.github.com>
2024-02-22 01:18:36 +00:00
|
|
|
<li>we use these relays by default:</li>
|
2023-10-04 18:47:09 +00:00
|
|
|
<ul>
|
|
|
|
{DEFAULT_CROSSPOSTING_RELAYS.map((relay, i) => (
|
|
|
|
<li key={i}>{relay}</li>
|
|
|
|
))}
|
|
|
|
</ul>
|
|
|
|
</ul>
|
|
|
|
</Info>
|
|
|
|
</div>
|
|
|
|
}
|
|
|
|
name='crosspost'
|
|
|
|
/>}
|
2022-04-18 20:19:07 +00:00
|
|
|
</>
|
2021-09-11 21:52:19 +00:00
|
|
|
}
|
|
|
|
/>
|
|
|
|
)
|
|
|
|
}
|