diff --git a/.github/ISSUE_TEMPLATE/bug_report.md b/.github/ISSUE_TEMPLATE/bug_report.md index f3d5c415..11c19f1e 100644 --- a/.github/ISSUE_TEMPLATE/bug_report.md +++ b/.github/ISSUE_TEMPLATE/bug_report.md @@ -1,10 +1,9 @@ --- name: Bug report about: Create a report to help us improve -title: '' +title: "" labels: bug -assignees: '' - +assignees: "" --- **Describe the bug** @@ -12,6 +11,7 @@ A clear and concise description of what the bug is. **To Reproduce** Steps to reproduce the behavior: + 1. Go to '...' 2. Click on '....' 3. Scroll down to '....' @@ -24,15 +24,17 @@ A clear and concise description of what you expected to happen. If applicable, add screenshots to help explain your problem. **Desktop (please complete the following information):** - - OS: [e.g. iOS] - - Browser [e.g. chrome, safari] - - Version [e.g. 22] + +- OS: [e.g. iOS] +- Browser [e.g. chrome, safari] +- Version [e.g. 22] **Smartphone (please complete the following information):** - - Device: [e.g. iPhone6] - - OS: [e.g. iOS8.1] - - Browser [e.g. stock browser, safari] - - Version [e.g. 22] + +- Device: [e.g. iPhone6] +- OS: [e.g. iOS8.1] +- Browser [e.g. stock browser, safari] +- Version [e.g. 22] **Additional context** Add any other context about the problem here. diff --git a/.github/ISSUE_TEMPLATE/feature-request.md b/.github/ISSUE_TEMPLATE/feature-request.md index 11fc491e..d883b8f2 100644 --- a/.github/ISSUE_TEMPLATE/feature-request.md +++ b/.github/ISSUE_TEMPLATE/feature-request.md @@ -1,10 +1,9 @@ --- name: Feature request about: Suggest an idea for this project -title: '' +title: "" labels: enhancement -assignees: '' - +assignees: "" --- **Is your feature request related to a problem? Please describe.** diff --git a/.github/workflows/release.yml b/.github/workflows/release.yml index 1c675c4a..6bc38781 100644 --- a/.github/workflows/release.yml +++ b/.github/workflows/release.yml @@ -10,8 +10,8 @@ jobs: with: deploy-env: "mainnet" app-name: "builddao" - deploy-account-address: ${{ vars.BOS_SIGNER_ACCOUNT_ID }} + deploy-account-address: ${{ vars.BOS_SIGNER_ACCOUNT_ID }} signer-account-address: ${{ vars.BOS_SIGNER_ACCOUNT_ID }} signer-public-key: ${{ vars.BOS_SIGNER_PUBLIC_KEY }} - secrets: - SIGNER_PRIVATE_KEY: ${{ secrets.BOS_SIGNER_PRIVATE_KEY }} \ No newline at end of file + secrets: + SIGNER_PRIVATE_KEY: ${{ secrets.BOS_SIGNER_PRIVATE_KEY }} diff --git a/.github/workflows/testnet.yml b/.github/workflows/testnet.yml index 2b2530fd..ed990e8a 100644 --- a/.github/workflows/testnet.yml +++ b/.github/workflows/testnet.yml @@ -10,8 +10,8 @@ jobs: with: deploy-env: "testnet" app-name: "builddao" - deploy-account-address: ${{ vars.BOS_TESTNET_SIGNER_ACCOUNT_ID }} + deploy-account-address: ${{ vars.BOS_TESTNET_SIGNER_ACCOUNT_ID }} signer-account-address: ${{ vars.BOS_TESTNET_SIGNER_ACCOUNT_ID }} signer-public-key: ${{ vars.BOS_TESTNET_SIGNER_PUBLIC_KEY }} - secrets: - SIGNER_PRIVATE_KEY: ${{ secrets.BOS_TESTNET_SIGNER_PRIVATE_KEY }} \ No newline at end of file + secrets: + SIGNER_PRIVATE_KEY: ${{ secrets.BOS_TESTNET_SIGNER_PRIVATE_KEY }} diff --git a/README.md b/README.md index 18f27caa..d609031c 100644 --- a/README.md +++ b/README.md @@ -5,11 +5,13 @@ Let's connect, collaborate, and create solutions together! ## Setup & Development Install packages: + ``` yarn ``` Start development version: + ``` yarn dev ``` @@ -20,8 +22,7 @@ To view your local developments, either visit them through a gateway ${gateway_u For example, to use this local gateway, use: -* Set the flag (something like http://127.0.0.1:4040/api/loader) at localhost:3000/flags - +- Set the flag (something like http://127.0.0.1:4040/api/loader) at localhost:3000/flags ### Community Page @@ -29,8 +30,8 @@ For example, to use this local gateway, use: #### Features -* Customizable Settings -* Onboarding Flow -* Leaderboard -* Groups -* Projects +- Customizable Settings +- Onboarding Flow +- Leaderboard +- Groups +- Projects diff --git a/apps/builddao/bos.config.json b/apps/builddao/bos.config.json index 9db549a9..a54425da 100644 --- a/apps/builddao/bos.config.json +++ b/apps/builddao/bos.config.json @@ -1,3 +1,3 @@ { "appAccount": "buildhub.near" -} \ No newline at end of file +} diff --git a/apps/builddao/widget/Compose.jsx b/apps/builddao/widget/Compose.jsx index 55c1d004..b39b1353 100644 --- a/apps/builddao/widget/Compose.jsx +++ b/apps/builddao/widget/Compose.jsx @@ -15,7 +15,8 @@ const [postContent, setPostContent] = useState(""); const [hideAdvanced, setHideAdvanced] = useState(true); const [labels, setLabels] = useState([]); -setPostContent(draft || props.template); +const [composeKey, setComposeKey] = useState(0); +const memoizedComposeKey = useMemo(() => composeKey, [composeKey]); function generateUID() { const maxHex = 0xffffffff; @@ -23,6 +24,8 @@ function generateUID() { return randomNumber.toString(16).padStart(8, "0"); } +setPostContent(draft || props.template); + function tagsFromLabels(labels) { return labels.reduce( (newLabels, label) => ({ @@ -85,15 +88,9 @@ function checkAndAppendHashtag(input, target) { } } -const postToCustomFeed = ({ feed, text, labels }) => { - // if (!labels) labels = []; - - // labels = labels.map((label) => label.toLowerCase()); - // labels.push(feed.name.toLowerCase()); - +const postToCustomFeed = ({ feed, text }) => { const requiredHashtags = props.requiredHashtags || ["build"]; if (feed.hashtag) requiredHashtags.push(feed.hashtag.toLowerCase()); - requiredHashtags.push(feed.name.toLowerCase()); text = text + `\n\n`; requiredHashtags.forEach((hashtag) => { text = checkAndAppendHashtag(text, hashtag); @@ -156,7 +153,8 @@ const postToCustomFeed = ({ feed, text, labels }) => { onCommit: () => { setPostContent(""); Storage.privateSet(draftKey, props.template || ""); - setHandler("autocompleteSelected"); // this is a hack to force the iframe to update + // setHandler("autocompleteSelected"); // this is a hack to force the iframe to update + setComposeKey(generateUID()); }, onCancel: () => { // console.log(`Cancelled ${feed}: #${postId}`); @@ -260,7 +258,7 @@ const MarkdownEditor = ` } .drop-wrap { - top: -110px !important; + border-radius: 0.5rem !important; } @@ -385,7 +383,7 @@ return ( - + /> ); diff --git a/apps/builddao/widget/Proposals.jsx b/apps/builddao/widget/Proposals.jsx index 081047fc..f4a57cf8 100644 --- a/apps/builddao/widget/Proposals.jsx +++ b/apps/builddao/widget/Proposals.jsx @@ -1,11 +1,12 @@ const { Button } = VM.require("buildhub.near/widget/components.Button") || { - Button: <> + Button: <>, }; -const DaoSDK = VM.require("sdks.near/widget/SDKs.Sputnik.DaoSDK"); +const DaoSDK = VM.require("sdks.near/widget/SDKs.Sputnik.DaoSDK") || (() => {}); if (!DaoSDK) { return <>; } + const resPerPage = 10; const daoId = props.daoId ?? "build.sputnik-dao.near"; const proposalId = props.proposalId ?? null; @@ -18,8 +19,8 @@ const lastProposalId = sdk.getLastProposalId(); const reversedProposals = proposalId ? [ sdk.getProposalById({ - proposalId - }) + proposalId, + }), ] || [] : sdk.getProposals({ offset: @@ -28,7 +29,7 @@ const reversedProposals = proposalId ? lastProposalId - resPerPage : lastProposalId ?? 10 : lastProposalId - currentPage * resPerPage, - limit: resPerPage + limit: resPerPage, }) || []; const proposals = reversedProposals.reverse(); @@ -81,15 +82,15 @@ const handleVote = ({ action, proposalId, proposer }) => { message: `${accountId} voted to ${customAction} your proposal for ${daoId} (Proposal ID: ${proposalId})`, params: { daoId: daoId, - proposalId: proposalId + proposalId: proposalId, }, type: "custom", - widget: "buildhub.near/widget/Proposals" - } - } - ]) - } - } + widget: "buildhub.near/widget/Proposals", + }, + }, + ]), + }, + }, }; sdk.actProposal({ @@ -103,9 +104,9 @@ const handleVote = ({ action, proposalId, proposer }) => { args: { data: notification }, deposit: Big(JSON.stringify(notification).length * 16) .mul(Big(10).pow(20)) - .toString() - } - ] + .toString(), + }, + ], }); }; @@ -144,30 +145,30 @@ const proposalsComponent = useMemo(() => { sdk.hasPermission({ accountId, kindName, - actionType: actions.VoteApprove + actionType: actions.VoteApprove, }), sdk.hasPermission({ accountId, kindName, - actionType: actions.VoteReject + actionType: actions.VoteReject, }), sdk.hasPermission({ accountId, kindName, - actionType: actions.VoteRemove - }) + actionType: actions.VoteRemove, + }), ]; const { thresholdVoteCount } = sdk.getVotersAndThresholdForProposalKind({ - kindName + kindName, }); const totalVotes = sdk.calculateVoteCountByType({ - votes: item.votes + votes: item.votes, }); let expirationTime = sdk.getProposalExpirationTime({ - submissionTime: item.submission_time + submissionTime: item.submission_time, }); return ( @@ -181,14 +182,14 @@ const proposalsComponent = useMemo(() => { totalVotes: { ...totalVotes, yes: totalVotes.approve, - no: totalVotes.reject + no: totalVotes.reject, }, - expirationTime + expirationTime, }, daoId: daoId, comments: comments, isAllowedToVote, - handleVote + handleVote, }} /> ); @@ -207,7 +208,7 @@ return ( src="buildhub.near/widget/components.modals.CreateProposal" props={{ showModal: showProposalModal, - toggleModal: () => setShowModal(!showProposalModal) + toggleModal: () => setShowModal(!showProposalModal), }} />
@@ -226,7 +227,7 @@ return ( totalPages: Math.round(lastProposalId / resPerPage), onPageClick: (v) => setCurrentPage(v), selectedPage: currentPage, - ThemeContainer: PaginationThemeContainer + ThemeContainer: PaginationThemeContainer, }} />
diff --git a/apps/builddao/widget/Resources.jsx b/apps/builddao/widget/Resources.jsx index 8062602d..0036066c 100644 --- a/apps/builddao/widget/Resources.jsx +++ b/apps/builddao/widget/Resources.jsx @@ -1,5 +1,9 @@ -const { MarkdownView } = VM.require("buildhub.near/widget/md-view"); -const { Button } = VM.require("buildhub.near/widget/components.Button"); +const { MarkdownView } = VM.require("buildhub.near/widget/md-view") || { + MarkdownView: () => <>, +}; +const { Button } = VM.require("buildhub.near/widget/components.Button") || { + Button: () => <>, +}; Button || (Button = () => <>); MarkdownView || (MarkdownView = () => <>); @@ -40,7 +44,7 @@ return ( ); }), - mainContent: + mainContent: , }} /> ); diff --git a/apps/builddao/widget/app.jsx b/apps/builddao/widget/app.jsx index 9cad4902..115ca85a 100644 --- a/apps/builddao/widget/app.jsx +++ b/apps/builddao/widget/app.jsx @@ -5,7 +5,7 @@ const { routes } = VM.require("buildhub.near/widget/config.app") ?? { }; const { AppLayout } = VM.require("buildhub.near/widget/template.AppLayout") || { - AppLayout: () => <>Layout loading..., + AppLayout: () => <>, }; if (!page) page = Object.keys(routes)[0] || "home"; diff --git a/apps/builddao/widget/components/Bullet.jsx b/apps/builddao/widget/components/Bullet.jsx index 77fdaa8e..e4a8e14c 100644 --- a/apps/builddao/widget/components/Bullet.jsx +++ b/apps/builddao/widget/components/Bullet.jsx @@ -1,4 +1,6 @@ -const { theme } = VM.require("rambo-dev.near/widget/ThemeProvider"); +const { theme } = VM.require("rambo-dev.near/widget/ThemeProvider") || { + theme: {}, +}; const StyledBullet = styled.div` width: fit-content; @@ -10,21 +12,21 @@ const StyledBullet = styled.div` font-size: 0.875rem; font-weight: 500; border-radius: 8px; - ${({ variant, theme }) => { - const isDefault = variant === "default"; + ${({ variant, theme }) => { + const isDefault = variant === "default"; - const background = isDefault - ? theme.colors.blue500 - : theme.colors.seablue500; - const color = isDefault ? theme.colors.blue500 : theme.colors.seablue500; - const border = `1px solid ${background}33`; + const background = isDefault + ? theme.colors.blue500 + : theme.colors.seablue500; + const color = isDefault ? theme.colors.blue500 : theme.colors.seablue500; + const border = `1px solid ${background}33`; - return ` + return ` background: ${background}33; color: ${color}; border: ${border}; `; - }} + }} `; function Bullet({ children, variant }) { @@ -37,4 +39,4 @@ function Bullet({ children, variant }) { ); } -return { Bullet }; \ No newline at end of file +return { Bullet }; diff --git a/apps/builddao/widget/components/InputField.jsx b/apps/builddao/widget/components/InputField.jsx index deacecd2..712c6c02 100644 --- a/apps/builddao/widget/components/InputField.jsx +++ b/apps/builddao/widget/components/InputField.jsx @@ -17,9 +17,8 @@ const Label = styled.label` const Input = styled.input` display: flex; - max-width: ${(props) => props.maxWidth ?? "390px"}; width: 100%; - padding: 16px 12px; + padding: 12px; align-items: flex-start; gap: 10px; @@ -48,15 +47,18 @@ function InputField({ maxWidth, }) { return ( - + {label && } ); diff --git a/apps/builddao/widget/components/Library.jsx b/apps/builddao/widget/components/Library.jsx index e626315d..2dd592c6 100644 --- a/apps/builddao/widget/components/Library.jsx +++ b/apps/builddao/widget/components/Library.jsx @@ -11,20 +11,20 @@ const { User, Avatar, Checkbox, -} = VM.require("buildhub.near/widget/components"); - -Button = Button || (() => <>); -Pagination = Pagination || (() => <>); -ProgressState = ProgressState || (() => <>); -Step = Step || (() => <>); -Post = Post || (() => <>); -InputField = InputField || (() => <>); -UploadField = UploadField || (() => <>); -TextBox = TextBox || (() => <>); -TextEditor = TextEditor || (() => <>); -User = User || (() => <>); -Avatar = Avatar || (() => <>); -Checkbox = Checkbox || (() => <>); +} = VM.require("buildhub.near/widget/components") || { + Button: () => <>, + Pagination: () => <>, + ProgressState: () => <>, + Step: () => <>, + Post: () => <>, + InputField: () => <>, + UploadField: () => <>, + TextBox: () => <>, + TextEditor: () => <>, + User: () => <>, + Avatar: () => <>, + Checkbox: () => <>, +}; // states const [checked, setChecked] = useState(false); diff --git a/apps/builddao/widget/components/Modal.jsx b/apps/builddao/widget/components/Modal.jsx index 62c857ce..93235fd0 100644 --- a/apps/builddao/widget/components/Modal.jsx +++ b/apps/builddao/widget/components/Modal.jsx @@ -1,4 +1,6 @@ -const { Button } = VM.require("buildhub.near/widget/components.Button"); +const { Button } = VM.require("buildhub.near/widget/components.Button") || { + Button: () => <>, +}; const toggle = props.toggle ?? ; diff --git a/apps/builddao/widget/components/Post.jsx b/apps/builddao/widget/components/Post.jsx index 8f9ebb96..8b8a04b0 100644 --- a/apps/builddao/widget/components/Post.jsx +++ b/apps/builddao/widget/components/Post.jsx @@ -1,5 +1,6 @@ -const { Button } = - VM.require("buildhub.near/widget/components") || (() => <>); +const { Button } = VM.require("buildhub.near/widget/components") || { + Button: () => <>, +}; const StyledPost = styled.div` margin-bottom: 1rem; @@ -288,7 +289,10 @@ const contentWidget = ( return ( <> - + { props={{ size: "sm", variant: "info outline mb-1", - children: "You voted" + children: "You voted", }} /> ); @@ -273,7 +273,7 @@ function renderHeader({ typeName, id, status }) { children: `Proposal ID #${id}`, variant: "", className: "secondary-bg", - size: "lg" + size: "lg", }} /> @@ -288,14 +288,14 @@ function renderHeader({ typeName, id, status }) { fontSize: "16px", marginRight: "5px", borderWidth: "2px", - animationDuration: "3s" + animationDuration: "3s", }} > {statustext} ), variant: `${statusvariant} round`, - size: "lg" + size: "lg", }} /> @@ -311,13 +311,13 @@ function renderHeader({ typeName, id, status }) { props={{ timeToCheck: parseInt( Big(expirationTime).div(1000000) - ) + ), }} /> ), variant: `info round`, - size: "lg" + size: "lg", }} /> )} @@ -331,7 +331,7 @@ function renderData({ proposer, description, submission_time, - totalVotesNeeded + totalVotesNeeded, }) { return (
@@ -400,7 +400,7 @@ function renderVoteButtons({ totalVotes, status, isAllowedToVote, - handleVote + handleVote, }) { const finished = status !== "InProgress"; const VoteButton = styled.button` @@ -519,19 +519,19 @@ function renderVoteButtons({ yes: getPercentage(totalVotes.yes), no: getPercentage(totalVotes.no), spam: getPercentage(totalVotes.spam), - abstain: getPercentage(totalVotes.abstain) + abstain: getPercentage(totalVotes.abstain), }; const wins = { yes: status === "Approved", no: status === "Rejected", - spam: status === "Failed" || status === "Spam" + spam: status === "Failed" || status === "Spam", }; const voted = { yes: checkVotes("Approve"), no: checkVotes("Reject"), - spam: checkVotes("Remove") + spam: checkVotes("Remove"), }; const alreadyVoted = voted.yes || voted.no || voted.spam || voted.abstain; @@ -552,7 +552,7 @@ function renderVoteButtons({
@@ -635,9 +635,9 @@ function renderFooter({ totalVotes, votes, comments, daoId, proposal }) { item: { type: "dao_proposal_comment", path: `${daoId}/proposal/main`, - proposal_id: proposal.id + "-beta" - } - } + proposal_id: proposal.id + "-beta", + }, + }, }, { title: "Voters", @@ -649,8 +649,8 @@ function renderFooter({ totalVotes, votes, comments, daoId, proposal }) { votes, totalVotes, proposalId: proposal.id, - votersCount: totalVotes.total - } + votersCount: totalVotes.total, + }, }, { title: "Share", @@ -660,9 +660,9 @@ function renderFooter({ totalVotes, votes, comments, daoId, proposal }) { url: `https://near.org/buildhub.near/widget/Proposals?daoId=${daoId}&proposalId=${ proposalData.id }${props.dev ? "&dev=true" : ""}`, - text: "Explore this new proposal from our DAO! Your support and feedback are essential as we work towards a decentralized future. Review the details and join the discussion here:" - } - } + text: "Explore this new proposal from our DAO! Your support and feedback are essential as we work towards a decentralized future. Review the details and join the discussion here:", + }, + }, ]; if (proposal.typeName !== "Text") { @@ -673,8 +673,8 @@ function renderFooter({ totalVotes, votes, comments, daoId, proposal }) { props: { daoId, proposal, - showCard: true - } + showCard: true, + }, }); } @@ -703,8 +703,8 @@ function renderFooter({ totalVotes, votes, comments, daoId, proposal }) {
), toggleContainerProps: { - className: "flex-fill" - } + className: "flex-fill", + }, }} /> ); @@ -721,7 +721,7 @@ const voted = { yes: checkVotes("Approve"), no: checkVotes("Reject"), spam: checkVotes("Remove"), - abstain: checkVotes("Abstain") + abstain: checkVotes("Abstain"), }; const alreadyVoted = voted.yes || voted.no || voted.spam; @@ -738,7 +738,7 @@ return ( proposer, description, submission_time, - totalVotesNeeded + totalVotesNeeded, })} {renderVoteButtons({ totalVotes, @@ -750,16 +750,16 @@ return ( return handleVote({ action, proposalId: id, - proposer + proposer, }); - } + }, })} {renderFooter({ totalVotes, votes, comments, daoId, - proposal: proposalData + proposal: proposalData, })} diff --git a/apps/builddao/widget/components/Step.jsx b/apps/builddao/widget/components/Step.jsx index 0f9fceab..d6e27400 100644 --- a/apps/builddao/widget/components/Step.jsx +++ b/apps/builddao/widget/components/Step.jsx @@ -1,5 +1,8 @@ -const { ProgressState } = - VM.require("buildhub.near/widget/components.ProgressState") || (() => <>); +const { ProgressState } = VM.require( + "buildhub.near/widget/components.ProgressState" +) || { + ProgressState: () => <>, +}; const StepContainer = styled.div` position: relative; diff --git a/apps/builddao/widget/components/Text/H1.jsx b/apps/builddao/widget/components/Text/H1.jsx index 24c4eedb..ae91fb52 100644 --- a/apps/builddao/widget/components/Text/H1.jsx +++ b/apps/builddao/widget/components/Text/H1.jsx @@ -4,15 +4,11 @@ const StyledH1 = styled.h1` font-size: 2rem; line-height: 100%; letter-spacing: 0; - color: ${(props) => `${props.textColor}`} + color: ${(props) => `${props.textColor}`}; `; -function H1({ children, textColor}) { - return ( - - {children} - - ) +function H1({ children, textColor }) { + return {children}; } -return { H1 } \ No newline at end of file +return { H1 }; diff --git a/apps/builddao/widget/components/Text/H2.jsx b/apps/builddao/widget/components/Text/H2.jsx index 4b4938b2..8ea0a99b 100644 --- a/apps/builddao/widget/components/Text/H2.jsx +++ b/apps/builddao/widget/components/Text/H2.jsx @@ -4,15 +4,11 @@ const StyledH2 = styled.h2` font-size: 1.625rem; line-height: 120%; letter-spacing: 0; - color: ${(props) => `${props.textColor}`} + color: ${(props) => `${props.textColor}`}; `; function H2({ children, textColor }) { - return ( - - {children} - - ) + return {children}; } -return { H2 } \ No newline at end of file +return { H2 }; diff --git a/apps/builddao/widget/components/Text/H3.jsx b/apps/builddao/widget/components/Text/H3.jsx index d6f6588e..5baffaab 100644 --- a/apps/builddao/widget/components/Text/H3.jsx +++ b/apps/builddao/widget/components/Text/H3.jsx @@ -4,15 +4,11 @@ const StyledH3 = styled.h3` font-size: 1.5rem; line-height: 140%; letter-spacing: 0; - color: ${(props) => `${props.textColor}`} + color: ${(props) => `${props.textColor}`}; `; function H3({ children, textColor }) { - return ( - - {children} - - ) + return {children}; } -return { H3 } \ No newline at end of file +return { H3 }; diff --git a/apps/builddao/widget/components/Text/H4.jsx b/apps/builddao/widget/components/Text/H4.jsx index 69b05c69..dbd19f43 100644 --- a/apps/builddao/widget/components/Text/H4.jsx +++ b/apps/builddao/widget/components/Text/H4.jsx @@ -4,15 +4,11 @@ const StyledH4 = styled.h4` font-size: 1.125rem; line-height: 160%; letter-spacing: 0; - color: ${(props) => `${props.textColor}`} + color: ${(props) => `${props.textColor}`}; `; function H4({ children, textColor }) { - return ( - - {children} - - ) + return {children}; } -return { H4 } \ No newline at end of file +return { H4 }; diff --git a/apps/builddao/widget/components/TextEditor.jsx b/apps/builddao/widget/components/TextEditor.jsx index bdb999c5..c9b29a03 100644 --- a/apps/builddao/widget/components/TextEditor.jsx +++ b/apps/builddao/widget/components/TextEditor.jsx @@ -81,7 +81,7 @@ const MarkdownEditor = ` } .drop-wrap { - top: -110px !important; + border-radius: 0.5rem !important; } @@ -126,22 +126,41 @@ const MarkdownEditor = ` } `; -function TextEditor({ value, onChange, maxWidth }) { +const Label = styled.label` + color: var(--label-color, #fff); + + /* Body/16px */ + font-size: 16px; + font-style: normal; + font-weight: 400; + line-height: 170%; /* 27.2px */ +`; + +const Container = styled.div` + display: flex; + flex-direction: column; + gap: 4px; +`; + +function TextEditor({ value, label, onChange, maxWidth }) { return ( - - - + + + + + + ); } diff --git a/apps/builddao/widget/components/UploadField.jsx b/apps/builddao/widget/components/UploadField.jsx index b0f873b2..5715279a 100644 --- a/apps/builddao/widget/components/UploadField.jsx +++ b/apps/builddao/widget/components/UploadField.jsx @@ -1,5 +1,6 @@ -const { Button } = - VM.require("buildhub.near/widget/components.Button") || (() => <>); +const { Button } = VM.require("buildhub.near/widget/components.Button") || { + Button: () => <>, +}; const UploadContainer = styled.div` display: flex; diff --git a/apps/builddao/widget/components/User.jsx b/apps/builddao/widget/components/User.jsx index 935b9053..74794c1f 100644 --- a/apps/builddao/widget/components/User.jsx +++ b/apps/builddao/widget/components/User.jsx @@ -1,5 +1,6 @@ -const { Avatar } = - VM.require("buildhub.near/widget/components") || (() => <>); +const { Avatar } = VM.require("buildhub.near/widget/components") || { + Avatar: () => <>, +}; const Wrapper = styled.div` color: #fff; @@ -58,8 +59,9 @@ const Overlay = (props) => ( <>, }; -const DaoSDK = VM.require("sdks.near/widget/SDKs.Sputnik.DaoSDK"); +const DaoSDK = VM.require("sdks.near/widget/SDKs.Sputnik.DaoSDK") || (() => {}); if (!DaoSDK) { return <>; } const daoId = "build.sputnik-dao.near"; const sdk = DaoSDK(daoId); +if (!sdk) { + return <>; +} const userAccountId = context.accountId; const data = sdk?.checkIsMemberOrPending({ diff --git a/apps/builddao/widget/components/buttons/UserDropdown.jsx b/apps/builddao/widget/components/buttons/UserDropdown.jsx index 1e06e701..4864ae1b 100644 --- a/apps/builddao/widget/components/buttons/UserDropdown.jsx +++ b/apps/builddao/widget/components/buttons/UserDropdown.jsx @@ -144,6 +144,10 @@ function LogOut() { ); } +const { href } = VM.require("buildhub.near/widget/lib.url") || { + href: () => {}, +}; + return ( diff --git a/apps/builddao/widget/components/post/Header.jsx b/apps/builddao/widget/components/post/Header.jsx index 15b9b233..3da02a09 100644 --- a/apps/builddao/widget/components/post/Header.jsx +++ b/apps/builddao/widget/components/post/Header.jsx @@ -1,5 +1,6 @@ -const { Avatar } = - VM.require("buildhub.near/widget/components") || (() => <>); +const { Avatar } = VM.require("buildhub.near/widget/components") || { + Avatar: () => <>, +}; const Button = styled.div` line-height: 20px; @@ -98,14 +99,17 @@ const showTime = props.showTime ?? true; const modalToggles = props.modalToggles; const setItem = props.setItem; -const { href } = VM.require("buildhub.near/widget/lib.url") || (() => {}); +const { href } = VM.require("buildhub.near/widget/lib.url") || { + href: () => {}, +}; const Overlay = (props) => ( {pinned && ( - + )} diff --git a/apps/builddao/widget/components/profile/AccountFeed.jsx b/apps/builddao/widget/components/profile/AccountFeed.jsx new file mode 100644 index 00000000..8f4ac8ca --- /dev/null +++ b/apps/builddao/widget/components/profile/AccountFeed.jsx @@ -0,0 +1,173 @@ +const { Post } = VM.require("buildhub.near/widget/components") || { + Post: () => <>, +}; + +const indexKey = props.indexKey ?? "main"; +const groupId = props.groupId; +const permissions = props.permissions; + +const index = [ + { + action: "post", + key: indexKey, + options: { + limit: 10, + order: "desc", + accountId: props.accounts, + }, + cacheOptions: { + ignoreCache: true, + }, + }, + { + action: "repost", + key: indexKey, + options: { + limit: 10, + order: "desc", + accountId: props.accounts, + }, + cacheOptions: { + ignoreCache: true, + }, + }, +]; + +const isPremiumFeed = props.isPremiumFeed; +const commentAccounts = props.commentAccounts; +const renderedPosts = {}; + +const makePostItem = (a) => ({ + type: "social", + path: `${a.accountId}/post/main`, + blockHeight: a.blockHeight, +}); + +const renderPost = (a) => { + if (a.value.type !== "md") { + return false; + } + const item = JSON.stringify(makePostItem(a)); + if (item in renderedPosts) { + return false; + } + renderedPosts[item] = true; + + return ( +
+ +
+ ); +}; + +const repostSvg = ( + + + + +); + +const extractParentPost = (item) => { + if (!item || item.type !== "social" || !item.path || !item.blockHeight) { + return undefined; + } + const accountId = item.path.split("/")[0]; + return `${accountId}/post/main` === item.path + ? { accountId, blockHeight: item.blockHeight } + : undefined; +}; + +const renderRepost = (a) => { + if (a.value.type !== "repost") { + return false; + } + const post = extractParentPost(a.value.item); + if (!post) { + return false; + } + const item = JSON.stringify(makePostItem(post)); + if (item in renderedPosts) { + return false; + } + renderedPosts[item] = true; + + return ( +
+
+ {repostSvg}{" "} + + Reposted by{" "} + + +
+ +
+ ); +}; + +const renderItem = (item) => + item.action === "post" ? renderPost(item) : renderRepost(item); + +return ( + +); diff --git a/apps/builddao/widget/components/profile/ImageUploader.jsx b/apps/builddao/widget/components/profile/ImageUploader.jsx new file mode 100644 index 00000000..04ae39f2 --- /dev/null +++ b/apps/builddao/widget/components/profile/ImageUploader.jsx @@ -0,0 +1,47 @@ +const [img, setImg] = useState(null); +const [msg, setMsg] = useState("Replace"); + +const uploadFile = (files) => { + setMsg("Uploading..."); + + asyncFetch("https://ipfs.near.social/add", { + method: "POST", + headers: { Accept: "application/json" }, + body: files[0], + }) + .catch((e) => { + console.error(e); + setMsg("Failed to upload"); + }) + .then((res) => { + setImg(res.body.cid); + setMsg("Replace"); + props.setImage({ + ipfs_cid: res.body.cid, + }); + }); +}; + +return ( + <> + {img ? ( + + ) : ( + + )} + uploadFile(f)} + > + {msg} + + +); diff --git a/apps/builddao/widget/components/profile/LastWidgets.jsx b/apps/builddao/widget/components/profile/LastWidgets.jsx new file mode 100644 index 00000000..ce7985ea --- /dev/null +++ b/apps/builddao/widget/components/profile/LastWidgets.jsx @@ -0,0 +1,105 @@ +const accountId = props.accountId; +const tag = props.tag; + +const makeLink = (accountId, tag) => { + const args = []; + if (accountId) { + args.push(`accountId=${accountId}`); + } + if (tag) { + args.push(`tag=${tag}`); + } + return `#/mob.near/widget/LastWidgets${args.length > 0 ? "?" : ""}${args.join( + "&" + )}`; +}; + +const render = (content) => { + return ( +
+ {content} +
+ ); +}; + +let keys = `${accountId ?? "*"}/widget/*`; + +if (tag) { + const taggedWidgets = Social.keys( + `${accountId ?? "*"}/widget/*/metadata/tags/${tag}`, + "final" + ); + + if (taggedWidgets === null) { + return render("Loading tags"); + } + + keys = Object.entries(taggedWidgets) + .map((kv) => Object.keys(kv[1].widget).map((w) => `${kv[0]}/widget/${w}`)) + .flat(); + + if (!keys.length) { + return render(`No widgets found by tag #${tag}`); + } +} + +const data = Social.keys(keys, "final", { + return_type: "BlockHeight", +}); + +if (data === null) { + return render("Loading"); +} + +const processData = (data) => { + const accounts = Object.entries(data); + + const allItems = accounts + .map((account) => { + const accountId = account[0]; + return Object.entries(account[1].widget).map((kv) => ({ + accountId, + widgetName: kv[0], + blockHeight: kv[1], + })); + }) + .flat(); + + allItems.sort((a, b) => b.blockHeight - a.blockHeight); + return allItems; +}; + +const renderTag = (tag, tagBadge) => ( + {tagBadge} +); + +const renderItem = (a) => { + return ( +
+ +
+ ); +}; + +if (JSON.stringify(data) !== JSON.stringify(state.data || {})) { + State.update({ + data, + allItems: processData(data), + }); +} + +return render( + +); diff --git a/apps/builddao/widget/components/profile/ProfileEdit.jsx b/apps/builddao/widget/components/profile/ProfileEdit.jsx new file mode 100644 index 00000000..bc759530 --- /dev/null +++ b/apps/builddao/widget/components/profile/ProfileEdit.jsx @@ -0,0 +1,192 @@ +const { Button, Avatar, InputField, TextEditor } = VM.require( + "buildhub.near/widget/components" +) || { + Button: () => <>, + Avatar: () => <>, + InputField: () => <>, + TextEditor: () => <>, +}; + +const accountId = context.accountId; + +if (!accountId) { + return ""; +} + +const profile = Social.getr(`${accountId}/profile`); + +if (!profile) { + return ""; +} + +const [name, setName] = useState(profile.name ?? ""); +const [description, setDescription] = useState(profile.description ?? ""); +const [location, setLocation] = useState(profile.location ?? ""); +const [twitter, setTwitter] = useState(profile.linktree.twitter ?? ""); +const [github, setGithub] = useState(profile.linktree.github ?? ""); +const [telegram, setTelegram] = useState(profile.linktree.telegram ?? ""); +const [website, setWebsite] = useState(profile.linktree.website ?? ""); +const [image, setImage] = useState(profile.image ?? {}); + +const onNameChange = useCallback((e) => { + setName(e.target.value); +}, []); + +const onDescriptionChange = useCallback((e) => { + setDescription(e); +}, []); + +const onLocationChange = useCallback((e) => { + setLocation(e.target.value); +}, []); + +const onTwitterChange = useCallback((e) => { + setTwitter(e.target.value); +}, []); + +const onGithubChange = useCallback((e) => { + setGithub(e.target.value); +}, []); + +const onTelegramChange = useCallback((e) => { + setTelegram(e.target.value); +}, []); + +const onWebsiteChange = useCallback((e) => { + setWebsite(e.target.value); +}, []); + +const setEditMode = props.setEditMode || (() => {}); + +const SpanLabel = styled.span` + color: var(--White-100, #fff); + + /* Body/14px */ + font-size: 14px; + font-style: normal; + font-weight: 400; + line-height: 170%; /* 23.8px */ +`; + +const ProfileImageContainer = styled.div` + display: flex; + flex-direction: row; + gap: 4px; + align-items: center; + + img { + width: 64px; + height: 64px; + object-fit: cover; + border-radius: 100%; + } +`; + +return ( + <> +
+ + +
+
+ + + + + + + + + + +
+ +); diff --git a/apps/builddao/widget/components/profile/ProfileInfo.jsx b/apps/builddao/widget/components/profile/ProfileInfo.jsx index 26d4b69b..9047c956 100644 --- a/apps/builddao/widget/components/profile/ProfileInfo.jsx +++ b/apps/builddao/widget/components/profile/ProfileInfo.jsx @@ -1,5 +1,6 @@ -const { Button } = - VM.require("buildhub.near/widget/components") || (() => <>); +const { Button } = VM.require("buildhub.near/widget/components") || { + Button: () => <>, +}; if (!context.accountId || !props.accountId) { return "No Account ID"; @@ -298,51 +299,70 @@ const Badges = ({ tags }) => { ); }; -return ( - -
- - {context.accountId === accountId && ( - - )} -
-
-

{profile.name}

- clipboard.writeText(accountId)}> - {accountId} - -
-
- -
-
- -
- {profile.description && ( -
-

BIO

- +const [editMode, setEditMode] = useState(false); + +const InfoSection = () => { + return ( + <> +
+ + + {context.accountId === accountId && ( + + )}
- )} - {profile.location && ( -
- - {profile.location} +
+

{profile.name}

+ clipboard.writeText(accountId)}> + {accountId}
- )} - {profile.linktree && ( -
- +
+
- )} - -); +
+ +
+ {profile.description && ( +
+

BIO

+ +
+ )} + {profile.location && ( +
+ + {profile.location} + +
+ )} + {profile.linktree && ( +
+ +
+ )} + + ); +}; + +const EditSection = () => { + return ( + + ); +}; + +return {!editMode ? : }; diff --git a/apps/builddao/widget/components/profile/ProfileLine.jsx b/apps/builddao/widget/components/profile/ProfileLine.jsx new file mode 100644 index 00000000..5a426cb7 --- /dev/null +++ b/apps/builddao/widget/components/profile/ProfileLine.jsx @@ -0,0 +1,81 @@ +const accountId = props.accountId; +const link = props.link ?? true; +const hideAccountId = props.hideAccountId; +const hideName = props.hideName; +const hideImage = props.hideImage; + +const profile = props.profile ?? Social.getr(`${accountId}/profile`); +const fast = !!props.fast || (!props.profile && accountId); + +const name = profile.name ?? accountId; +const title = props.title ?? `${name} @${accountId}`; +const tooltip = + props.tooltip && (props.tooltip === true ? title : props.tooltip); + +const { href } = VM.require("buildhub.near/widget/lib.url") || { + href: () => {}, +}; + +let inner = ( + <> + {!hideImage && ( + + )} + {!hideAccountId && ( + + @{accountId} + + )} + +); + +inner = link ? ( + + {inner} + +) : ( + {inner} +); + +if (props.tooltip === true) { + return ( + + ); +} +if (tooltip) { + inner = ( + {tooltip}}> + {inner} + + ); +} + +return inner; diff --git a/apps/builddao/widget/components/profile/ProfileTabs.jsx b/apps/builddao/widget/components/profile/ProfileTabs.jsx new file mode 100644 index 00000000..5d1fb552 --- /dev/null +++ b/apps/builddao/widget/components/profile/ProfileTabs.jsx @@ -0,0 +1,151 @@ +const { Post } = VM.require("buildhub.near/widget/components") || { + Post: () => <>, +}; + +const accountId = props.accountId ?? context.accountId; +if (!accountId) { + return "No account ID"; +} + +const profile = props.profile ?? Social.getr(`${accountId}/profile`); + +if (profile === null) { + return "Loading"; +} + +const description = profile.description; + +const pills = [ + { id: "posts", title: "Posts" }, + { id: "nfts", title: "NFTs" }, + { id: "widget", title: "Widgets" }, +]; + +const Nav = styled.div` + .nav-pills { + background: var(--bg-1, #0b0c14); + font-weight: 500; + --bs-nav-pills-border-radius: 0; + --bs-nav-link-color: var(--font-color, #fff); + --bs-nav-pills-link-active-color: var(--font-color, #fff); + --bs-nav-pills-link-active-bg: var(--bg-1, #0b0c14); + --bs-nav-link-padding-y: 0.75rem; + border-bottom: 1px solid var(--stroke-color, rgba(255, 255, 255, 0.2)); + padding-top: 3px; + } + .nav-link.active { + border-bottom: 2px solid var(--Yellow, #ffaf51); + } + + .nav-item:not(:has(> .disabled)):hover { + background: rgba(13, 110, 253, 0.15); + } +`; + +const StyledContent = styled.div` + #pills-nfts { + .nft-card { + background: var(--bg-1, #0b0c14); + border-radius: 1rem; + border: 1px solid var(--stroke-color, rgba(255, 255, 255, 0.2)); + + .nft-title, + nft-description { + color: var(--font-color, #fff); + } + } + } + + #pills-widget { + } +`; + +return ( + <> + + +
+
+ {description && ( + + )} + +
+
+
+ {state.loadnfts && ( + + )} +
+
+ {state.loadwidget && ( + + )} +
+
+ +); diff --git a/apps/builddao/widget/components/profile/WidgetMetadata.jsx b/apps/builddao/widget/components/profile/WidgetMetadata.jsx new file mode 100644 index 00000000..59f5908b --- /dev/null +++ b/apps/builddao/widget/components/profile/WidgetMetadata.jsx @@ -0,0 +1,192 @@ +const accountId = props.accountId; +const widgetName = props.widgetName; +const widgetPath = `${accountId}/widget/${widgetName}`; +const blockHeight = props.blockHeight; +const metadata = props.metadata ?? Social.getr(`${widgetPath}/metadata`); +const renderTag = props.renderTag; + +const name = metadata.name ?? widgetName; +const description = metadata.description; +const image = metadata.image; +const tags = Object.keys(metadata.tags ?? {}); +const expanded = !!props.expanded; + +const linktree = Object.entries(metadata.linktree ?? {}); +const linktreeElements = { + website: { + prefix: "https://", + icon: "bi-globe2", + }, +}; + +const linktreeObjects = linktree.map((o, i) => { + const key = o[0]; + let value = o[1]; + if (!value) { + return null; + } + const e = linktreeElements[key]; + if (e.prefix) { + value = value && value.replace(e.prefix, ""); + } + const icon = e.icon ? ( + + ) : ( + "" + ); + return e.prefix ? ( +
+ + {icon} + {value} + +
+ ) : ( +
+ {key}: {icon} + {value} +
+ ); +}); + +const descriptionKey = `${widgetPath}-description`.replaceAll(/[._\/-]/g, "--"); +const { href } = VM.require("buildhub.near/widget/lib.url") || { + href: () => {}, +}; + +return ( +
+
+
+
+ +
+
+
+
+
{name}
+
+ + + {widgetPath} + +
+
+
+ {tags.length > 0 && ( +
+ {tags.map((tag, i) => { + const tagBadge = ( + + #{tag} + + ); + return renderTag ? renderTag(tag, tagBadge) : tagBadge; + })} +
+ )} + {!expanded && (description || linktreeObjects.length > 0) && ( + + )} + + Source + + + History + + + + {accountId === context.accountId ? "Edit" : "Fork"} + +
+
+
+
+ + {linktreeObjects} +
+
+
+
+ By + +
+
+ + + + +
+
+
+
+); diff --git a/apps/builddao/widget/config/app.jsx b/apps/builddao/widget/config/app.jsx index b2eb2e18..592517b5 100644 --- a/apps/builddao/widget/config/app.jsx +++ b/apps/builddao/widget/config/app.jsx @@ -5,36 +5,44 @@ return { path: "buildhub.near/widget/page.home", blockHeight: "final", init: { - name: "Home" - } + name: "Home", + }, }, feed: { path: "buildhub.near/widget/page.feed", blockHeight: "final", init: { - name: "Feed" - } + name: "Feed", + }, }, proposal: { path: "buildhub.near/widget/page.projects", blockHeight: "final", init: { - name: "Projects" - } + name: "Projects", + }, }, resources: { path: "buildhub.near/widget/page.resources", blockHeight: "final", init: { - name: "Resources" - } + name: "Resources", + }, }, library: { path: "buildhub.near/widget/page.library", blockHeight: "final", init: { - name: "Library" - } - } - } + name: "Library", + }, + }, + profile: { + path: "buildhub.near/widget/page.profile", + blockHeight: "final", + init: { + name: "Profile", + }, + hide: true, + }, + }, }; diff --git a/apps/builddao/widget/config/feed.jsx b/apps/builddao/widget/config/feed.jsx index ef0a352f..14c1cbc2 100644 --- a/apps/builddao/widget/config/feed.jsx +++ b/apps/builddao/widget/config/feed.jsx @@ -1,4 +1,6 @@ -const { Post } = VM.require("buildhub.near/widget/components") || (() => <>); +const { Post } = VM.require("buildhub.near/widget/components") || { + Post: () => <>, +}; function formatDate(date) { const options = { year: "numeric", month: "short", day: "numeric" }; @@ -17,7 +19,7 @@ return { init: { name: "All", // maybe these should be moved to navbar specific icon: "bi-list", - requiredHashtags: ["build"] + requiredHashtags: ["build"], }, }, resolutions: { diff --git a/apps/builddao/widget/config/projects.jsx b/apps/builddao/widget/config/projects.jsx index 5131fe05..569ac4a2 100644 --- a/apps/builddao/widget/config/projects.jsx +++ b/apps/builddao/widget/config/projects.jsx @@ -1,4 +1,6 @@ -const { Post } = VM.require("buildhub.near/widget/components") || (() => <>); +const { Post } = VM.require("buildhub.near/widget/components") || { + Post: () => <>, +}; function formatDate(date) { const options = { year: "numeric", month: "short", day: "numeric" }; diff --git a/apps/builddao/widget/page/feed.jsx b/apps/builddao/widget/page/feed.jsx index 4ab7394e..12812cc2 100644 --- a/apps/builddao/widget/page/feed.jsx +++ b/apps/builddao/widget/page/feed.jsx @@ -11,7 +11,7 @@ const { theme } = VM.require("buildhub.near/widget/config.theme") ?? { const { SidebarLayout } = VM.require( "buildhub.near/widget/template.SidebarLayout" ) || { - SidebarLayout: () => <>Layout loading..., + SidebarLayout: () => <>, }; if (!page) page = Object.keys(routes)[0] || "home"; diff --git a/apps/builddao/widget/page/home.jsx b/apps/builddao/widget/page/home.jsx index e752c1e0..59f22695 100644 --- a/apps/builddao/widget/page/home.jsx +++ b/apps/builddao/widget/page/home.jsx @@ -1,20 +1,20 @@ const { Hero } = VM.require("buildhub.near/widget/home.hero") || { - Hero: () => <> + Hero: () => <>, }; const { Goals } = VM.require("buildhub.near/widget/home.goals") || { - Goals: () => <> + Goals: () => <>, }; const { Join } = VM.require("buildhub.near/widget/home.join") || { - Join: () => <> + Join: () => <>, }; const { Governance } = VM.require("buildhub.near/widget/home.governance") || { - Governance: () => <> + Governance: () => <>, }; const { CTA } = VM.require("buildhub.near/widget/home.cta") || { - CTA: () => <> + CTA: () => <>, }; const { Footer } = VM.require("buildhub.near/widget/home.footer") || { - Footer: () => <> + Footer: () => <>, }; const Root = styled.div` diff --git a/apps/builddao/widget/page/profile.jsx b/apps/builddao/widget/page/profile.jsx new file mode 100644 index 00000000..189a4403 --- /dev/null +++ b/apps/builddao/widget/page/profile.jsx @@ -0,0 +1,5 @@ +return ( +
+ ; +
+); diff --git a/apps/builddao/widget/page/projects.jsx b/apps/builddao/widget/page/projects.jsx index d59a63a4..b90c8b0a 100644 --- a/apps/builddao/widget/page/projects.jsx +++ b/apps/builddao/widget/page/projects.jsx @@ -11,7 +11,7 @@ const { theme } = VM.require("buildhub.near/widget/config.theme") ?? { const { SidebarLayout } = VM.require( "buildhub.near/widget/template.SidebarLayout" ) || { - SidebarLayout: () => <>Layout loading..., + SidebarLayout: () => <>, }; if (!page) page = Object.keys(routes)[0] || "home"; diff --git a/apps/builddao/widget/template/SidebarLayout.jsx b/apps/builddao/widget/template/SidebarLayout.jsx index 0cfec2fe..a70735e9 100644 --- a/apps/builddao/widget/template/SidebarLayout.jsx +++ b/apps/builddao/widget/template/SidebarLayout.jsx @@ -1,4 +1,6 @@ -const { Button } = VM.require("buildhub.near/widget/components"); +const { Button } = VM.require("buildhub.near/widget/components") || { + Button: () => <>, +}; const Container = styled.div` display: grid; diff --git a/apps/embeds/bos.config.json b/apps/embeds/bos.config.json index 50143cc0..0ccacb11 100644 --- a/apps/embeds/bos.config.json +++ b/apps/embeds/bos.config.json @@ -1,3 +1,3 @@ { "appAccount": "embeds.near" -} \ No newline at end of file +} diff --git a/apps/embeds/widget/Embed.jsx b/apps/embeds/widget/Embed.jsx index 7cb6a601..cecc6ba1 100644 --- a/apps/embeds/widget/Embed.jsx +++ b/apps/embeds/widget/Embed.jsx @@ -33,30 +33,30 @@ if (accountId) { const href = props.href; -const assertString = s => { +const assertString = (s) => { if (typeof s !== "string") { return null; - } -} + } +}; // checks for use of "**" in widgetSrc string -const containsGlob = path => /\*\*/.test(path) +const containsGlob = (path) => /\*\*/.test(path); const findWithKey = (key, href) => { - let fragments = key.split('**').filter(f => f != '') - const hasFragment = (str, fragment) => str.search(fragment) != -1 + let fragments = key.split("**").filter((f) => f != ""); + const hasFragment = (str, fragment) => str.search(fragment) != -1; while (fragments.length > 0) { if (hasFragment(href, fragments[0])) { - fragments.shift() + fragments.shift(); } else { - return null + return null; } } - return true -} + return true; +}; const parseUrl = (url) => { - assertString(url) + assertString(url); if (url.startsWith("/")) { url = `https://near.social${url}`; } @@ -68,17 +68,17 @@ const parseUrl = (url) => { }; const parseGlob = (path) => { - assertString(path) - const keysWithGlobs = [...EmbedMap.keys()].filter(key => containsGlob(key)) - const keysThatMatch = keysWithGlobs.filter(key => findWithKey(key,href)) + assertString(path); + const keysWithGlobs = [...EmbedMap.keys()].filter((key) => containsGlob(key)); + const keysThatMatch = keysWithGlobs.filter((key) => findWithKey(key, href)); if (keysThatMatch.length >= 1) { try { - return keysThatMatch[0] + return keysThatMatch[0]; } catch { - return null + return null; } } - return null + return null; }; const parsed = useMemo(() => { @@ -92,7 +92,7 @@ const parsed = useMemo(() => { } // try parsing embed link to glob if url failed - const widgetSrc = parseGlob(href) + const widgetSrc = parseGlob(href); if (!!widgetSrc) { return { widgetSrc, diff --git a/apps/embeds/widget/Feed.jsx b/apps/embeds/widget/Feed.jsx index 1725a615..db7cada7 100644 --- a/apps/embeds/widget/Feed.jsx +++ b/apps/embeds/widget/Feed.jsx @@ -1,4 +1,6 @@ -const { Feed } = VM.require("devs.near/widget/Module.Feed") || (() => <>); +const { Feed } = VM.require("devs.near/widget/Module.Feed") || { + Feed: () => <>, +}; Feed = Feed || (() => <>); // make sure you have this or else it can break diff --git a/apps/embeds/widget/Plugin/Creator.jsx b/apps/embeds/widget/Plugin/Creator.jsx index 0408020d..88392798 100644 --- a/apps/embeds/widget/Plugin/Creator.jsx +++ b/apps/embeds/widget/Plugin/Creator.jsx @@ -1,5 +1,5 @@ /** - * TODO: This should be more generalized. + * TODO: This should be more generalized. * Currently only supports embed plugins */ const Wrapper = styled.div` @@ -44,10 +44,9 @@ const [activeTab, setActiveTab] = useState("data"); function generateUID() { const maxHex = 0xffffffff; const randomNumber = Math.floor(Math.random() * maxHex); - return randomNumber.toString(16).padStart(8, '0'); + return randomNumber.toString(16).padStart(8, "0"); } - const handleCreate = () => { Social.set({ plugin: { diff --git a/apps/embeds/widget/Post/Content.jsx b/apps/embeds/widget/Post/Content.jsx index e7485e8c..dedace18 100644 --- a/apps/embeds/widget/Post/Content.jsx +++ b/apps/embeds/widget/Post/Content.jsx @@ -11,15 +11,17 @@ const Wrapper = styled.div` overflow: hidden; .expand-post { - position : absolute; - z-index : 1; - top : 35em; - left : 0; - background-image : linear-gradient(to bottom, - rgba(255,255,255, 0), - rgba(255,255,255, 1) 25%); - width : 100%; - height : 3em; + position: absolute; + z-index: 1; + top: 35em; + left: 0; + background-image: linear-gradient( + to bottom, + rgba(255, 255, 255, 0), + rgba(255, 255, 255, 1) 25% + ); + width: 100%; + height: 3em; > div { position: relative; @@ -36,7 +38,7 @@ const Wrapper = styled.div` } } - @media(max-width: 991px) { + @media (max-width: 991px) { max-height: 30em; .expand-post { top: 27em; @@ -123,4 +125,4 @@ return (
-); \ No newline at end of file +); diff --git a/apps/embeds/widget/Post/EditableContent.jsx b/apps/embeds/widget/Post/EditableContent.jsx index 791f5bc3..7e47bd17 100644 --- a/apps/embeds/widget/Post/EditableContent.jsx +++ b/apps/embeds/widget/Post/EditableContent.jsx @@ -14,4 +14,4 @@ return ( noEmbed: false, }} /> -); \ No newline at end of file +); diff --git a/apps/embeds/widget/Post/Index.jsx b/apps/embeds/widget/Post/Index.jsx index c896d6a4..8168a0e1 100644 --- a/apps/embeds/widget/Post/Index.jsx +++ b/apps/embeds/widget/Post/Index.jsx @@ -32,26 +32,45 @@ const link = const Wrapper = styled.div` margin: 0 -12px; line-height: normal; - + .post { position: relative; padding: 12px; padding-bottom: 4px; display: flex; - h1, h2, h3, h4, h5, h6 { + h1, + h2, + h3, + h4, + h5, + h6 { font-size: 16px !important; } - @media(max-width: 767px) { + @media (max-width: 767px) { font-size: 15px !important; - h1, h2, h3, h4, h5, h6 { + h1, + h2, + h3, + h4, + h5, + h6 { font-size: 15px !important; } } - h1, h2, h3, h4, h5, h6, strong, b { + h1, + h2, + h3, + h4, + h5, + h6, + strong, + b { font-weight: 500 !important; } - ol, ul, dl { + ol, + ul, + dl { margin-bottom: 0.5rem; white-space: inherit; } @@ -69,16 +88,18 @@ const Wrapper = styled.div` min-width: 5em; } - .table>:not(caption)>*>* { - padding: .3rem; + .table > :not(caption) > * > * { + padding: 0.3rem; } &:hover { background-color: rgba(0, 0, 0, 0.03); .expand-post { - background-image : linear-gradient(to bottom, - rgba(0,0,0, 0), - rgba(247.35,247.35,247.35, 1) 25%); + background-image: linear-gradient( + to bottom, + rgba(0, 0, 0, 0), + rgba(247.35, 247.35, 247.35, 1) 25% + ); } } @@ -108,7 +129,7 @@ const Wrapper = styled.div` background-color: #ddd; z-index: -1; } - + .left { margin-right: 12px; min-width: 40px; @@ -275,4 +296,4 @@ return ( /> )} -); \ No newline at end of file +); diff --git a/functions/[[accountId]]/widget/[[index]].js b/functions/[[accountId]]/widget/[[index]].js index 1ab0ded5..d9d1742b 100644 --- a/functions/[[accountId]]/widget/[[index]].js +++ b/functions/[[accountId]]/widget/[[index]].js @@ -78,8 +78,7 @@ class NoscriptDescriptionInjector { function defaultData() { const image = "https://nearbuilders.org/assets/logo.png"; const title = "Build DAO"; - const description = - "Support Systems for Open Web Developers"; + const description = "Support Systems for Open Web Developers"; return { image, title, diff --git a/src/App.js b/src/App.js index cf38561f..2daff8c9 100644 --- a/src/App.js +++ b/src/App.js @@ -85,8 +85,11 @@ function App() { signInContractId: NetworkId == "testnet" ? "v1.social08.testnet" : "social.near", trialAccountSpecs: { - url: NetworkId == "testnet" ? "https://test.nearbuilders.org/#trial-url/ACCOUNT_ID/SECRET_KEY" : "https://www.nearbuilders.org/#trial-url/ACCOUNT_ID/SECRET_KEY", - modalOptions: KEYPOM_OPTIONS(NetworkId) + url: + NetworkId == "testnet" + ? "https://test.nearbuilders.org/#trial-url/ACCOUNT_ID/SECRET_KEY" + : "https://www.nearbuilders.org/#trial-url/ACCOUNT_ID/SECRET_KEY", + modalOptions: KEYPOM_OPTIONS(NetworkId), }, instantSignInSpecs: { url: diff --git a/src/App.scss b/src/App.scss index 8a847d35..54b8fe5f 100644 --- a/src/App.scss +++ b/src/App.scss @@ -6,7 +6,8 @@ body { color-scheme: dark; } -body, html { +body, +html { -webkit-font-smoothing: antialiased; height: 100%; } @@ -15,10 +16,11 @@ body, html { cursor: pointer; } -.btn-success, .btn-primary { +.btn-success, +.btn-primary { .text-muted { color: #fff !important; - }; + } } .outline-none { @@ -36,7 +38,7 @@ a { } .sidebar-items { - &> div { + & > div { border-right: 1px solid #e5e5e5; text-align: center; min-height: 4rem; @@ -44,7 +46,7 @@ a { display: flex; } - &> div:not(.apps) { + & > div:not(.apps) { min-width: 4rem; align-items: center !important; justify-content: center !important; diff --git a/src/components/BosLoaderBanner.js b/src/components/BosLoaderBanner.js index 9a008d79..0799a5d9 100644 --- a/src/components/BosLoaderBanner.js +++ b/src/components/BosLoaderBanner.js @@ -99,4 +99,4 @@ export function BosLoaderBanner() { ); -} \ No newline at end of file +} diff --git a/src/components/Editor/FileTab.js b/src/components/Editor/FileTab.js index d0e3dd74..8843e96e 100644 --- a/src/components/Editor/FileTab.js +++ b/src/components/Editor/FileTab.js @@ -148,8 +148,9 @@ export function FileTab(props) { )} { e.preventDefault(); e.stopPropagation(); diff --git a/src/data/widgets.js b/src/data/widgets.js index 8c6e4073..cde2a12d 100644 --- a/src/data/widgets.js +++ b/src/data/widgets.js @@ -12,7 +12,7 @@ const TestnetWidgets = { widgetMetadataEditor: "eugenethedream/widget/WidgetMetadataEditor", widgetMetadata: "eugenethedream/widget/WidgetMetadata", profileImage: "eugenethedream/widget/ProfileImage", - profilePage: "eugenethedream/widget/Profile", + profilePage: "buildhub.near/widget/Profile", profileName: "eugenethedream/widget/ProfileName", profileInlineBlock: "eugenethedream/widget/Profile", notificationButton: "eugenethedream/widget/NotificationButton", @@ -28,7 +28,7 @@ const MainnetWidgets = { widgetMetadata: "buildhub.near/widget/WidgetMetadata", profileImage: "mob.near/widget/ProfileImage", notificationButton: "mob.near/widget/NotificationButton", - profilePage: "near/widget/ProfilePage", + profilePage: "buildhub.near/widget/Profile", profileName: "patrick.near/widget/ProfileName", editorComponentSearch: "mob.near/widget/Editor.ComponentSearch", profileInlineBlock: "mob.near/widget/Profile.InlineBlock", diff --git a/src/hooks/useBosLoaderInitializer.js b/src/hooks/useBosLoaderInitializer.js index c2f8c1d4..5979c0ba 100644 --- a/src/hooks/useBosLoaderInitializer.js +++ b/src/hooks/useBosLoaderInitializer.js @@ -1,8 +1,8 @@ -import { useCallback, useEffect } from 'react'; +import { useCallback, useEffect } from "react"; -import { useBosLoaderStore } from '../stores/bos-loader'; +import { useBosLoaderStore } from "../stores/bos-loader"; -import { useFlags } from './useFlags'; +import { useFlags } from "./useFlags"; export function useBosLoaderInitializer() { const [flags] = useFlags(); @@ -21,14 +21,14 @@ export function useBosLoaderInitializer() { try { const res = await fetch(url, { - method: 'GET', + method: "GET", headers: { - Accept: 'application/json', + Accept: "application/json", }, }); if (!res.ok) { - throw new Error('Network response was not OK'); + throw new Error("Network response was not OK"); } const data = await res.json(); @@ -46,7 +46,7 @@ export function useBosLoaderInitializer() { }); } }, - [setStore], + [setStore] ); useEffect(() => { @@ -56,4 +56,4 @@ export function useBosLoaderInitializer() { setStore({ hasResolved: true }); } }, [fetchRedirectMap, loaderUrl, setStore]); -} \ No newline at end of file +} diff --git a/src/hooks/useFlags.js b/src/hooks/useFlags.js index ff4ad3e9..d67b1d2d 100644 --- a/src/hooks/useFlags.js +++ b/src/hooks/useFlags.js @@ -1,20 +1,21 @@ -import { useCallback, useEffect, useState } from 'react'; - +import { useCallback, useEffect, useState } from "react"; export function useFlags() { const [rawFlags, setRawFlags] = useState(); useEffect(() => { - const flags = localStorage.getItem('flags') ? JSON.parse(localStorage.getItem('flags') || '') : {}; + const flags = localStorage.getItem("flags") + ? JSON.parse(localStorage.getItem("flags") || "") + : {}; setRawFlags(flags); }, []); const setFlags = useCallback((newFlags) => { setRawFlags((f) => { const updated = { ...f, ...newFlags }; - localStorage.setItem('flags', JSON.stringify(updated)); + localStorage.setItem("flags", JSON.stringify(updated)); - alert('Flags have been saved.'); + alert("Flags have been saved."); // reload for changes to take effect location.reload(); @@ -25,4 +26,4 @@ export function useFlags() { }, []); return [rawFlags, setFlags]; -} \ No newline at end of file +} diff --git a/src/index.css b/src/index.css index 5c475efe..93512865 100644 --- a/src/index.css +++ b/src/index.css @@ -1,12 +1,12 @@ :root { --slate-dark-1: #151718; - --slate-dark-5: #2B2F31; + --slate-dark-5: #2b2f31; --slate-dark-6: #313538; - --slate-dark-8: #4C5155; + --slate-dark-8: #4c5155; --slate-dark-9: #697177; - --slate-dark-11: #9BA1A6; - --slate-dark-12: #ECEDEE; - --blue-light-9: #0091FF; + --slate-dark-11: #9ba1a6; + --slate-dark-12: #ecedee; + --blue-light-9: #0091ff; --font-weight-medium: 500; --font-weight-bold: 600; @@ -16,4 +16,3 @@ --account-center-position-top: 64px; --account-center-position-right: -10px; } - diff --git a/src/pages/EditorPage.js b/src/pages/EditorPage.js index c357095e..de99f54c 100644 --- a/src/pages/EditorPage.js +++ b/src/pages/EditorPage.js @@ -437,20 +437,20 @@ export default function EditorPage(props) { (uncommittedPreviews) => { return uncommittedPreviews ? { - redirectMap: Object.fromEntries( - Object.entries(allSaved) - .filter(([jpath, code]) => code !== true) - .map(([jpath, code]) => { - const path = JSON.parse(jpath); - return [ - pathToSrc(path), - { - code, - }, - ]; - }) - ), - } + redirectMap: Object.fromEntries( + Object.entries(allSaved) + .filter(([jpath, code]) => code !== true) + .map(([jpath, code]) => { + const path = JSON.parse(jpath); + return [ + pathToSrc(path), + { + code, + }, + ]; + }) + ), + } : undefined; }, [allSaved, pathToSrc] @@ -696,8 +696,9 @@ export default function EditorPage(props) {
@@ -909,8 +917,9 @@ export default function EditorPage(props) {
diff --git a/src/pages/Viewer.js b/src/pages/Viewer.js index c5d3922b..600b2c2e 100644 --- a/src/pages/Viewer.js +++ b/src/pages/Viewer.js @@ -21,7 +21,7 @@ function Viewer({ code, ...props }) { const defaultSrc = "buildhub.near/widget/app"; // default widget to load const pathSrc = path || defaultSrc; // if no path, load default widget return pathSrc; - // const lastSlashIndex = pathSrc.lastIndexOf("/", pathSrc.indexOf(".near")); + // const lastSlashIndex = pathSrc.lastIndexOf("/", pathSrc.indexOf(".near")); // return lastSlashIndex !== -1 // ? pathSrc.substring(lastSlashIndex + 1) // : defaultSrc; diff --git a/src/stores/bos-loader.js b/src/stores/bos-loader.js index 1c04bc0f..4914a4e0 100644 --- a/src/stores/bos-loader.js +++ b/src/stores/bos-loader.js @@ -1,9 +1,9 @@ -import { create } from 'zustand'; +import { create } from "zustand"; export const useBosLoaderStore = create((set) => ({ failedToLoad: false, hasResolved: false, - loaderUrl: '', + loaderUrl: "", redirectMap: {}, set: (state) => set((previousState) => ({ ...previousState, ...state })), -})); \ No newline at end of file +})); diff --git a/src/utils/keypom-options.js b/src/utils/keypom-options.js index 00903744..a0136d44 100644 --- a/src/utils/keypom-options.js +++ b/src/utils/keypom-options.js @@ -1,54 +1,59 @@ export const KEYPOM_OPTIONS = (networkId) => { - return { - beginTrial: { - landing: { - title: "Create an Account", - body: "To start, enter a username.", - fieldPlaceholder: "Account ID", - buttonText: "Create", - }, - claiming: { - title: "Creating Account", - body: "Your account is being created. Please wait...", - }, - claimed: { - title: "You're all set! 🎉", - body: "Your account has been successfully created.", - buttonText: "Continue to app" - } + return { + beginTrial: { + landing: { + title: "Create an Account", + body: "To start, enter a username.", + fieldPlaceholder: "Account ID", + buttonText: "Create", + }, + claiming: { + title: "Creating Account", + body: "Your account is being created. Please wait...", + }, + claimed: { + title: "You're all set! 🎉", + body: "Your account has been successfully created.", + buttonText: "Continue to app", + }, + }, + trialOver: { + mainBody: { + title: "Your trial has ended", + body: "Choose a wallet provider and onboard fully into the NEAR ecosystem.", + imageOne: { + title: "Secure Your Digital Assets", + body: "Now that your trial is over, secure your account with an official wallet provider!", }, - trialOver: { - mainBody: { - title: "Your trial has ended", - body: "Choose a wallet provider and onboard fully into the NEAR ecosystem.", - imageOne: { - title: "Secure Your Digital Assets", - body: "Now that your trial is over, secure your account with an official wallet provider!" - }, - imageTwo: { - title: "Log In to Any NEAR App", - body: "Once your account is secured, you can use any app on NEAR!" - } - }, - offboardingOptions: { - title: "Choose a Wallet", - } + imageTwo: { + title: "Log In to Any NEAR App", + body: "Once your account is secured, you can use any app on NEAR!", }, - invalidAction: { - title: "Invalid Action", - body: "Your trial does not allow you to perform this action. For more information, please contact the site administrator." - }, - insufficientBalance: { - title: "Insufficient Balance", - body: "Your account does not have enough balance for the action you are trying to perform. Please try again with a different action. For more information, please contact the site administrator." - }, - wallets: [ - { - name: "MyNEARWallet", - description: "Secure your account with a Seed Phrase", - iconUrl: "", - redirectUrl: `${networkId == "testnet" ? "https://testnet.mynearwallet.com" : "https://app.mynearwallet.com"}/linkdrop/ACCOUNT_ID/SECRET_KEY` - } - ] - } -} \ No newline at end of file + }, + offboardingOptions: { + title: "Choose a Wallet", + }, + }, + invalidAction: { + title: "Invalid Action", + body: "Your trial does not allow you to perform this action. For more information, please contact the site administrator.", + }, + insufficientBalance: { + title: "Insufficient Balance", + body: "Your account does not have enough balance for the action you are trying to perform. Please try again with a different action. For more information, please contact the site administrator.", + }, + wallets: [ + { + name: "MyNEARWallet", + description: "Secure your account with a Seed Phrase", + iconUrl: + "", + redirectUrl: `${ + networkId == "testnet" + ? "https://testnet.mynearwallet.com" + : "https://app.mynearwallet.com" + }/linkdrop/ACCOUNT_ID/SECRET_KEY`, + }, + ], + }; +};