Skip to content

Mindmapping made simple: Host and create your own mindmaps. Share your mindmap sessions with your team and collaborate on mindmaps.

License

Notifications You must be signed in to change notification settings

b310-digital/teammapper

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
Oct 3, 2022
Oct 3, 2022
Oct 3, 2022
Jan 8, 2022
Jun 2, 2019
Sep 24, 2022
Dec 17, 2021
Dec 5, 2021
Oct 3, 2022
Dec 5, 2021
Sep 23, 2022
Sep 24, 2022
Sep 24, 2022
Sep 23, 2022
Oct 3, 2022

Repository files navigation

TeamMapper

Mindmapping made simple: Host and create your own mindmaps. Share your mindmap sessions with your team and collaborate on mindmaps.

TeamMapper is based on mindmapp (https://github.com/cedoor/mindmapp , discontinued). In contrast to mindmapp, TeamMapper features shared mindmapping sessions for your team based on websockets.

Features:

  • Host and create your own mindmaps
  • Set node images, colors and font properties.
  • Shortcuts
  • Import and export functionality (JSON, PDF, PNG...)
  • Mutli user support: Share your mindmap with friends and collegues. Work at the same time on the same mindmap!
  • By default, mindmaps are deleted after 30 days to ensure GDPR compliancy.

Getting started

Development

  • Start up app necessary services

    docker-compose up -d --build --force-recreate
  • Start frontend and backend at once

    docker-compose exec app sh
    # Inside docker container, you execute the following
    npm --prefix teammapper-backend run dev

    or start frontend and backend separately

    # Open to terminal session on your host machine
    
    # In first terminal session
    docker-compose exec app npm --prefix teammapper-backend start
    
    # In second terminal session
    docker-compose exec app npm --prefix teammapper-frontend start
  • Visit the frontend in http://localhost:4200

Test

  • Create a test database

    docker-compose exec postgres createdb -e -U teammapper-user -W teammapper-backend-test
  • Execute the tests

    docker-compose exec app npm -prefix teammapper-backend run test:e2e

Production

  • Generate self-signed ssl sertificate for the postgres server on the host machine; the generated files are mounted into the docker container

    mkdir -p ./ca
    openssl req -new -text -passout pass:abcd -subj /CN=localhost -out ./ca/server.req -keyout ./ca/privkey.pem
    openssl rsa -in ./ca/privkey.pem -passin pass:abcd -out ./ca/server.key
    openssl req -x509 -in ./ca/server.req -text -key ./ca/server.key -out ./ca/server.crt
    chmod 600 ./ca/server.key
    test $(uname -s) = Linux && chown 70 ./ca/server.key
  • Duplicate and rename .env.default

    cp .env.default .env.prod
  • Adjust all configs in .env.prod, e.g. database settings, ports, disable ssl env vars if necessary

  • Start everything at once (including a forced build):

    docker-compose --file docker-compose-prod.yml --env-file .env.prod up -d --build --force-recreate
  • Go to http://localhost to open up teammapper

  • Optional:

    If you want to make sure, to include the most recent updates, run first:

    docker-compose --file docker-compose-prod.yml --env-file .env.prod build --no-cache

    then:

    docker-compose --file docker-compose-prod.yml --env-file .env.prod up -d --force-recreate

    If you want to remove old data, including cached node packages and stored databases (DANGER!):

    docker-compose --file docker-compose-prod.yml --env-file .env.prod down -v

    If you want to run prod migrations (again):

    docker-compose exec app_prod npm -prefix teammapper-backend run typeorm:prod:migrate

Running jobs

Trigger delete job (also executed daily with cron task scheduler):

docker-compose --file docker-compose-prod.yml --env-file .env.prod exec app_prod npm --prefix teammapper-backend run prod:data:maps:cleanup

Running further queries

Example of running sql via typeorm:

npx typeorm query "select * from mmp_node" --config dist/ormconfig.js

Further details

  • Once this docker volume is initialized after the first docker-compose up, the database-related variables in .env.prod will not have any effect; please have this in mind => you will then need to setup your database manually

Contributing

  1. Fork it
  2. Create your feature branch (git checkout -b fooBar)
  3. Commit your changes (git commit -am 'Add some fooBar')
  4. Push to the branch (git push origin fooBar)
  5. Create a new Pull Request

Testimonials

kits is a project platform hosted by a public institution for quality development in schools (Lower Saxony, Germany) and focusses on digital tools and media in language teaching. TeamMapper is used in workshops to activate prior knowledge, and collect and structure ideas. In addition, TeamMapper can be found on https://kits.blog/tools and can be used by schools for free.

Logos and text provided with courtesy of kits.

Additional licence

The TeamMapperlogo in this repo – created by Gregor Cresnar – is licenced under CC BY 3.0 Unported.

Acknowledgements