maxime-rainville / shared-draft-comment
Allow non-users to comment on shared draft.
Installs: 155
Dependents: 0
Suggesters: 0
Security: 0
Stars: 0
Watchers: 2
Forks: 0
Open Issues: 2
Language:JavaScript
Type:silverstripe-vendormodule
Requires
This package is auto-updated.
Last update: 2025-01-11 06:13:53 UTC
README
This is a Silverstripe CMS module that adds the capability to leave comments on shared draft directly in the front end of your website.
Warning
This is an experimental module. Use at your own risk.
Team
- JS and PHP development
- @aria5305
- @maxime-rainville
- UX and UI
- Oscar Urrutia
- User research and strategy
- Erin Charter
- Other contributions
- Claire Kirby
- @SimulatedPanda
- Maira Florez
- @matthew-dyson
- Sandra De Villiers
- @tamatifkaa
What does it do?
The silverstripe/sharedraftcontent allows content authors to create special links to draft content. Content author can then choose to share those draft links with their stakeholders so they can preview the content.
However, any feedback on the draft content then has to be collected in side channels like email message or Google Doc.
This module extends the capability of the shared draft content module so people looking at a preview link can leave comment directly in the front end. Other users looking at the draft can view their comments and leave replies as well.
live-demo-comment.mp4
How does it work?
Backend
4 DataObjects are tracked:
Selection
which represent a specific sample of text on a specific page.DomMeta
which define the start or the end of a selection. Each selection has astartMeta
and aendMeta
.Comment
which represent a comment left on a specific selection. All comments attached to a selection are displayed together as a comment thread.Commenter
which represent a person who posted one or more comments. Commenters don't have any credentials and no attempt is made to validate their name. This is done to remove any barrier before posting a comment.
The data can be retrieve and updated via a GraphQL endpoint at /shared-draft-comment/graphql
.
Frontend
The front end is divided into three main parts:
- the inline commenting library
- the Apollo Silverstripe CMS GraphQL data store
- the Redux test data store.
All the front end logic is written in TypeScript.
Inline commenting library
The files stored under the src/lib
are responsible for:
- displaying existing existing selections
- providing an interface to create new selections
- displaying comments
- recording new comments.
The inline commenting library is designed to be "store agnostic". Basically it doesn't care where its initial data is coming from and where newly created data goes. When the inline library get initialised, it expects a bunch of handlers it will then called to retrieve or update data.
This part was designed so it could be split off as its own library later on.
web-highlighter is used to control the highlighting of text selection.
The UI is rendered with React.
While commenter data is attached to each comment, the inline commenting library doesn't manage that data or give you the means to update that data. It is the responsibility of the data store to keep track of who the current user is and to make sure that any new comment are attached to that user. This is done to avoid mandating any specific approach to managing the identity of commenters.
Apollo Silverstripe CMS GraphQL data store
The logic to control the exchange of data with the Silverstripe CMS backend via GraphQL is stored in /src/apolloBootstrap.ts
and /src/apollo
.
This is also responsible for providing an interface to record the commenter's details.
Basically, all the GraphQL queries and mutation are wrapped in handlers that return promises. Those handlers are then uses to bootstrap the inline commenting library.
Redux test data store
A simple test Redux store is included in /src/reduxBootstrap.ts
and /src/Store
. It basically does the same thing as the apollo store, except the data is read for a redux state and the updates are managed via redux action.
This is only included to help test and update the inline commenting library. All changes are lost when you refresh the page.
Development
npm run build
To run the full Silverstripe CMS JS client, run npm run build
. Performance optimisations have been disabled for now.
See the section about deployment for more information.
npm start
If you are just working on the inline commenting library, you can execute just that part with npm start
.
Runs the app in the development mode.
Open http://localhost:3000 to view it in the browser.
The page will reload if you make edits.
You will also see any lint errors in the console.
npm test
Launches the test runner in the interactive watch mode.
See the section about running tests for more information.
Learn More
You can learn more in the Create React App documentation.
To learn React, check out the React documentation.