* Transitioning Boards > Focalboards plugin docs * Update docs/focalboard-plugin-end-user-guide.md * Update docs/get-started-with-board-templates.md * Update docs/get-started-with-board-templates.md * Update docs/group-filter-sort-boards.md * Update docs/group-filter-sort-boards.md * Update docs/share-collaborate.md * Update docs/import-export-backup-data.md * Update docs/import-export-backup-data.md * Fix MD table fomatting * Added data collection content * Added Focalboard import notes
3.2 KiB
Focalboard Plugin Developer's Guide
Important: Effective September 15th, 2023, Mattermost Boards transitions to being fully community supported as the Focalboard Plugin. Mattermost will no longer be maintaining this plugin - this includes bug fixes and feature additions. Instead, the plugin is open-sourced and made available indefinitely for community contributions in GitHub.
To build your own version of it:
- Build mattermost-plugin in the Focalboard repo
- Upload it as a custom plugin to your Mattermost server
Here are the steps in more detail:
Building the Focalboard plugin
Fork the Focalboard repo, clone it locally, and follow the steps in the readme to set up your dev environment.
Install dependencies:
# First-time setup dependencies
cd mattermost-plugin/webapp
npm install --no-optional
cd ../..
make prebuild
Build the plugin:
# Build webapp
make webapp
# Build plugin
cd mattermost-plugin
make dist
Refer to the dev-release.yml workflow for the up-to-date commands that are run as part of CI.
Uploading the plugin to your server
You can manually upload the plugin to your Mattermost Server:
- Enable custom plugins by setting
PluginSettings > EnableUploads
totrue
in the Mattermostconfig.json
file - Navigate to System Console > Plugins > Management and upload the generated
.tar.gz
package in yourmattermost-plugin/dist
directory - Enable it (if needed)
Alternatively, you can install Mattermost locally and use make deploy
to auto-deploy it for you:
First, build and run Mattermost locally:
- Follow the Mattermost Developers Guide to set up your environment
- In particuler, make sure Docker is set up and running
- Fork mattermost-webapp, clone it locally, and
make build
- Fork mattermost-server and clone it locally
- Run
make config-reset
to generate theconfig/config.json
file - Edit
config/config.json
:
- Set
ServiceSettings > SiteURL
tohttp://localhost:8065
(docs) - Set
ServiceSettings > EnableLocalMode
totrue
(docs) - Set
PluginSettings > EnableUploads
totrue
(docs)
- Add an ENV var
MM_SERVICESETTINGS_SITEURL
with the same site URL used in the config - Run
make run-server
in Mattermost
Now, to build and deploy the plugin:
- Clone / fork mattermost/focalboard
- Install the dependencies (see above)
- Run:
make webapp
cd mattermost-plugin
make deploy