Skip to main content

This is the magic wall (magicwall.io)

Project description

magicwall.io

View, share, compose, edit visual, textual and acustical content and apply arbitraty effects on it.

Consider magicwall a combination of file sharing, content presentation, blogging and programmable playground. Create your own wall by just navigating to it, add content by dropping or pasting files and arbitrary data from outside, arrange it spacially and write code which can be applied to any of that content.

Other people you shared the link to your wall with can copy its content using the drag&drop or copy&paste mechanism or by using Git to clone the whole wall content.

Use it: magicwall.io

Have your own:

git clone https://projects.om-office.de/frans/magicwall.io

Have Python3.7+ and flask installed and run

magicwall.io/magicwall.py

Or use a Docker container:

magicwall.io/run-server

Visit the locally created site

Milestone 1

Requirements for basic usage as simple blogging system and for concept demonstration.

  • <magicwall.io> registered and used with https
  • Previews of files get turned into HTML elements
  • Visualization works (geometry)
  • Create element from dropping a filter element, text or images
  • Drag/drop of element inside wall area moves it
  • Drag/drop of element outside wall area copies as file
  • Drag/drop of element on remove field removes it
  • Pictures get displayed
  • Basic Markdown text formatting works
  • Basic file info on mouse hover
  • Drag/drop works on mobile
  • Basic text editing
  • Basic "filter" work (e.g. b/w for images and running python)
  • Auto-update (-> collab mode)
  • Pasting of text, image data or image files works as dropping
  • Multiple elements can be dropped/pasted at once

Milestone 2

  • User / access permission control
  • Arbitrary files can be added for sharing
  • CTRL+drag&drop copies
  • Resize elments
  • Caching mechanism
  • Square-select multiple items

Future

  • Notification on change
  • Fullscreen / slideshow mode
  • Undo-stack
  • Config-YAML
  • Filter-Hub
  • Search
  • Offline use
  • Git support
  • Editor
  • Links
  • Copy / Paste between sites
  • Video
  • Live-Update (Weather)
  • Support for folders -> Tree
  • Tree-Structure (allows entering)
  • Filter chaining/stacking

Use cases

  • Picture gallery
  • Blogging
  • Mind mapping
  • Algorithm demonstration / education (-> Jupyter)
  • File exchange
  • Note taking

Magic ideas

  • Document optimizer
  • Simple auto optimize images (contrast, etc)
  • Simple BW images
  • Polaroid images
  • Configurable Image with roation, cropping, color improvement, vignetting
  • Files to animation
  • SVG background
  • Auto align by date
  • fetch URL -> return generated HTML

License

For all code contained in this repository the rules of GPLv3 apply unless otherwise noted. That means that you can do what you want with the source code as long as you make the files with their original copyright notice and all modifications available.

See GNU / GPLv3 for details.

Contributing

Before contributing consider installing a pre-commit which runs some static checks, code cleaners and unit tests:

ln -s ../../.git-pre-commit .git/hooks/pre-commit

This pre-commit just runs ./qualitygate, which you can also run manually.

Paradigms

  • each site can be seen as a filesystem folder managed and visualized by magicwall.io. I.e. applying an arbitrary folder should give nice results magically.

Random ideas

  • Visual Filter (looks like polaroid filter and can be moved over arbitrary elements)
  • Transformer filter

Technical challenges

Feel free to help me with each of those questions

Read this

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

magicwall-0.0.3.tar.gz (30.2 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

magicwall-0.0.3-py3-none-any.whl (29.5 kB view details)

Uploaded Python 3

File details

Details for the file magicwall-0.0.3.tar.gz.

File metadata

  • Download URL: magicwall-0.0.3.tar.gz
  • Upload date:
  • Size: 30.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Linux/6.2.14-100.fc36.x86_64

File hashes

Hashes for magicwall-0.0.3.tar.gz
Algorithm Hash digest
SHA256 84d3bf4982749a856fd7b7b9eb403933c07e8f97157efb03f4459ffa4dfc5304
MD5 da4b9ba1cc6f97d321002cb8c4745918
BLAKE2b-256 074ecc212fc4d3a410f8276f17d5be5867ab09cff6a987f88be0e4415f5770c4

See more details on using hashes here.

File details

Details for the file magicwall-0.0.3-py3-none-any.whl.

File metadata

  • Download URL: magicwall-0.0.3-py3-none-any.whl
  • Upload date:
  • Size: 29.5 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: poetry/1.5.1 CPython/3.11.4 Linux/6.2.14-100.fc36.x86_64

File hashes

Hashes for magicwall-0.0.3-py3-none-any.whl
Algorithm Hash digest
SHA256 62c7e4fa68882430fb1e4feb894ab88a69f7aa88e045dea857cd28ea26e04694
MD5 f20a4fb73e93ac3f65bb90fe5cdd1c1a
BLAKE2b-256 0cd3889651a32bbdfff7ad6d0c9e93b70bef1e1a0b6320fccc95a5e594d06fd3

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page