Ecosyste.ms: Awesome

An open API service indexing awesome lists of open source software.

Awesome Lists | Featured Topics | Projects

https://github.com/pretix/pretixscan-desktop

Desktop application for attendee check-in
https://github.com/pretix/pretixscan-desktop

Last synced: about 2 months ago
JSON representation

Desktop application for attendee check-in

Awesome Lists containing this project

README

        

pretixSCAN
==========

.. image:: https://travis-ci.org/pretix/pretixscan-desktop.svg?branch=master
:target: https://travis-ci.org/pretix/pretixscan-desktop

.. image:: https://ci.appveyor.com/api/projects/status/n3n5tp3wl3i2qg5p?svg=true
:target: https://ci.appveyor.com/project/raphaelm/pretixscan-desktop

Checking in your attendees, one ticket at a time.

What is this?
-------------

This is a cross-platform desktop application that handles attendee check-in for events managed
with `pretix`_, the open source ticket sales system of choice.

Project status
--------------

pretixSCAN has all features required to be useful but is still in it's early days. Feel free to
use it, but do have a backup plan.

Building and Running
--------------------

This project contains a submodule, so the first command you execute should be::

git submodule update --init

This project is built using Gradle. It requires a JDK in version 11.
You can then build and run the project using::

cd pretixscan/tornadofx-repo
JAVA_HOME=/usr/lib/jvm/java-11-jdk mvn -DskipTests package
cd ..
JAVA_HOME=/usr/lib/jvm/java-11-jdk ./gradlew :gui:run

To create packages, see PACKAGES.md.

FAQ
---

**Why Java?**

It's not Java, it's `Kotlin`_.

**Why Kotlin? You are a Python shop, after all!**

Yes, and we still love Python. However, all cross-platform GUI frameworks suck in some way,
and their Python bindings are rarely Pythonic or nice to use. Additionally, it is really hard
to create good standalone application packages for Windows users for Python. JavaFX isn't perfect
as well, but `tornadofx`_ has a nice Kotlin abstraction and
`JFoenix`_ has nice material-design elements.

Additionally, with the choice of a JVM-based language we can reuse lots of code from our
`pretixdroid`_ Android application, making it easier to
bring new features to both platforms.

**Why not just a web app?**

Ever organized an event and right before the start your internet connection breaks down?
You don't want that to affect your processes too much. With a desktop application, we can
support slow and unreliable internet connections well.

**Why not build a fancy offline-first web app using local storage then?**

For the future, we plan adding more advanced features like box office sales to this application.
This requires access to a reliable and controlled data storage. Most browsers don't give strong
enough guarantees about retention of local storage data that we don't want to trust on.

Contributing
------------

If you like to contribute to this project, you are very welcome to do so. If you have any
questions in the process, please do not hesitate to ask us.

Please note that we have a `Code of Conduct`_
in place that applies to all project contributions, including issues, pull requests, etc.

License
-------
The code in this repository is published under the terms of the Apache License.
See the LICENSE file for the complete license text.

This project is maintained by Raphael Michel . See the
AUTHORS file for a list of all the awesome folks who contributed to this project.

This project is 100 percent free and open source software. If you are interested in
commercial support, hosting services or supporting this project financially, please
go to `pretix.eu`_ or contact Raphael directly.

.. _pretix: https://pretix.eu
.. _pretix.eu: https://pretix.eu
.. _Code of Conduct: https://docs.pretix.eu/en/latest/development/contribution/codeofconduct.html
.. _Nullsoft Install System: http://nsis.sourceforge.net/Download
.. _Kotlin: https://kotlinlang.org/
.. _tornadofx: https://github.com/edvin/tornadofx
.. _JFoenix: https://github.com/jfoenixadmin/JFoenix
.. _pretixdroid: https://github.com/pretix/pretixdroid
.. _pretixscan-git: https://aur.archlinux.org/packages/pretixscan-git/