
Research
Security News
Malicious PyPI Package Exploits Deezer API for Coordinated Music Piracy
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
@fileverse-dev/ddoc
Advanced tools
This repo contains example - demo source code and package code
/package
contains the package code
import { DdocEditor } from '@fileverse-dev/ddoc'
import '@fileverse-dev/ddoc/styles'
in App.jsx/App.tsx
In your tailwind config, add this line to content array
@fileverse-dev/ddoc/dist/index.es.js
That's it, you should be able to use DdocEditor now
The DdocProps
interface is a TypeScript interface that defines the properties for a component related to a page. This interface includes properties for handling preview mode, publishing data, and optional data related to the page's metadata and content.
Property | Type | Description |
---|---|---|
isPreviewMode | boolean | Indicates whether the page is in preview mode or not. |
data (optional) | Data | Optional property holding data related to the page. |
enableCollaboration (optional) | boolean | Optional property to enable collaboration |
onCommentInteraction (optional) | (commentInfo: IEditSelectionData) => void | Optional function that get's called whenever there is a mouse-over and click interaction on a comment |
collaborationId (optional) | string | When using enableCollaboration, you need to provide collaborationId, it can be uuid of doc |
onTextSelection (optional) | (data: IEditorSelectionData) => void | Function called when a text is selected on the editor |
renderToolRightSection (optional) | ({editor}) => JSX.Element | Function that render the right section of the toolbar. it calls the function with the editor instance |
renderToolLeftSection (optional) | ({editor}) => JSX.Element | Accept a react component |
username (required when using collaboration) | boolean | Takes a username which can be used by collaboration cursor |
walletAddress (optional) | string | Takes a wallet address |
ref (optional) | any | Gets editor instance |
ensResolutionUrl (optional) | string | Api Url for resolving ens names |
secureImageUploadUrl (optional) | string | Api Url for secure image upload |
initialContent (optional) | JSONContent | Initial content of the editor |
onChange (optional) | (changes: JSONContent) => void | Optional function that gets triggered with the latest content of the editor on every change in the editor |
onCollaboratorChange (optional) | (collaborators?: IDocCollabUsers[] ) => void | Optional function that gets triggered when a user join or leave the doc during collaboration |
onError (optional) | (errorString: string) => void | Function to call on error |
setCharacterCount (optional) | React.Dispatch<SetStateAction<number>> | Optional. React Set State function to update Character Count |
setWordCount (optional) | React.Dispatch<SetStateAction<number>> | Optional. React Set State function to update Word Count |
scrollPosition (optional) | number | User cursor position to scroll to on intitalising the content of the editor |
enableIndexeddbSync (optional) | boolean | Indicates when to use yjs-indexeddb provider |
ddocId (optional) | string | custom ID for the document (this has to be provided to enable yjs-indexeddb provider) |
editorCanvasClassNames (optional) | string | Optional. Extra className for editor-canvas |
selectedTags (optional) | TagType[] | Array of currently selected tags |
setSelectedTags (optional) | React.Dispatch<SetStateAction<TagType[]>> | Function to update selected tags |
zoomLevel (required) | string | Current zoom level of the editor |
setZoomLevel (required) | React.Dispatch<SetStateAction<string>> | Function to update zoom level |
isNavbarVisible (required) | boolean | Controls visibility of the navbar |
setIsNavbarVisible (required) | React.Dispatch<SetStateAction<boolean>> | Function to toggle navbar visibility |
renderNavbar (optional) | ({ editor: JSONContent }) => JSX.Element | Function to render custom navbar content |
disableBottomToolbar (optional) | boolean | When true, disables the bottom toolbar |
isPresentationMode (optional) | boolean | Controls if editor is in presentation mode |
setIsPresentationMode (optional) | React.Dispatch<SetStateAction<boolean>> | Function to toggle presentation mode |
onInlineComment (optional) | () => void | Callback function when inline comment is added |
onMarkdownExport (optional) | () => void | Callback function for markdown export |
onMarkdownImport (optional) | () => void | Callback function for markdown import |
sharedSlidesLink (optional) | string | Link for shared slides in presentation mode |
documentName (optional) | string | Name of the document |
onSlidesShare (optional) | () => void | Callback |
proExtensions (optional) | Record<string, Extension | any> | Object mapping extension names to their configurations. Note: Requires proper .npmrc setup and installing the corresponding extension packages. Example: { ai: AiExtension, slides: SlidesExtension } |
The Data
interface defines the structure of the data object
Property | Type | Description |
---|---|---|
editorJSONData | JSONContent | Contains JSON data for the editor content. |
npm i
npm run dev
It will open up a vite server, that will have the Ddoc Editor
⚠️ This repository is currently undergoing rapid development, with frequent updates and changes. We recommend not to use in production yet
Configure your .npmrc
with the appropriate registry and authentication token:
Install the corresponding extension packages:
Use the extension in your DdocEditor component:
proExtensions={{
TableOfContents
}}
FAQs
DDoc
The npm package @fileverse-dev/ddoc receives a total of 166 weekly downloads. As such, @fileverse-dev/ddoc popularity was classified as not popular.
We found that @fileverse-dev/ddoc demonstrated a healthy version release cadence and project activity because the last version was released less than a year ago. It has 0 open source maintainers collaborating on the project.
Did you know?
Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.
Research
Security News
Socket researchers uncovered a malicious PyPI package exploiting Deezer’s API to enable coordinated music piracy through API abuse and C2 server control.
Research
The Socket Research Team discovered a malicious npm package, '@ton-wallet/create', stealing cryptocurrency wallet keys from developers and users in the TON ecosystem.
Security News
Newly introduced telemetry in devenv 1.4 sparked a backlash over privacy concerns, leading to the removal of its AI-powered feature after strong community pushback.