Skip to content

Commit

Permalink
[Project] Add content for first public version 0.9.0
Browse files Browse the repository at this point in the history
  • Loading branch information
gaetano-geck committed Dec 1, 2020
1 parent 401b8e4 commit 0726067
Show file tree
Hide file tree
Showing 153 changed files with 8,825 additions and 0 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
@@ -1,3 +1,5 @@
/deb_dist/

# Created by https://www.gitignore.io/api/vim,linux,macos,emacs,python,windows
# Edit at https://www.gitignore.io/?templates=vim,linux,macos,emacs,python,windows

Expand Down
19 changes: 19 additions & 0 deletions CONTRIBUTORS.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,19 @@
In the summer semester 2020, when Europe faced the first wave of COVID-19, I was -- as many others -- confronted with a growing number of different online meetings. Bored by the repeated searches for meeting ids and passwords, I started _Meety_ as a private project in May.

A few weeks later I told my friend and colleague Christopher Spinrath about the project, gave him access to the repository and asked for his opinion. Naive as I have been, I expected a simple feedback like "nice" (or "okay" at least). Instead, he reminded me on certain Python standards (PEP8, setuptools, ...) that I haven't been aware of. But he didn't stop at that point but rather took on and greatly improved the code -- and also started using _Meety_ himself. Many thanks to Christopher also for help and advice on the preparation of application bundles.

Early on we wanted to open source _Meety_ but due to a number of other tasks, we haven't found the time. Then, in October and November 2020, I started to rewrite large parts of _Meety_ and to add many features. You can find the product in this repository.

--- Gaetano Geck



**AUTHORS** (in alphabetical order):

- Christopher Spinrath
- Gaetano Geck


**Thanks also to**

- Jonas Schmidt for helpful comments
675 changes: 675 additions & 0 deletions LICENSE

Large diffs are not rendered by default.

47 changes: 47 additions & 0 deletions README-pypi.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,47 @@
# Meety - quickly start online meetings from YAML

**Problem.**
Online meetings provide a useful means to communicate with others. With an increasing number of meetings, however, it can get difficult to remember or pick the right meeting location, user id, password and so on.

**Goal.**
_Meety_ aims to provide a quick and easy way to start the right online meeting from a list of predefined meetings. Meetings are defined in YAML, a clean and simple format that is well readable for humans and machines alike. Thus, you can

- view and edit the meetings with your favourite text editor and
- sensibly share them with other users, even if they don't use _Meety_.
(Think of conferences, lectures, ...)


**Features.**
_Meety_ can can load meetings from one or multiple YAML files. The meetings can be filtered by time preferences and/or keywords. After choosing a meeting, _Meety_ will try to connect to it based on the information the meeting provides.

Out of the box, _Meety_ supports meetings via the browser and via the _Zoom_ app. However, the application can easily be configured to handle other types of meetings too, as described in the documentation.

_Meety_ ships with a graphical user interface (program `meety`) and with a command line interface (program `cmeety`).

Meetings are specified in YAML and may look like this.

```text
# FIRST MEETING (Coffee round with colleagues, every morning)
- name: Coffee
zoom-url: https://zoom.us/j/123456789
prefer: Monday to Friday, 9 to 10 o'clock
# short format for time specifications (also for other languages)
# SECOND MEETING (lecture, each Tuesday and Thursday)
- name: My favourite lecture
url: https://my-university.edu/my-fav-lecture
prefer:
- weekday: Tuesday
time: 12:00 - 14:00
date: 2020-10-01 - 2021-03-31
- weekday: Thursday
time: 14:00 - 16:00
date: 2020-10-01 - 2021-03-31
# explicit format for time specifications (also for other languages)
# THIRD MEETING (without time preferences)
- name: Another meeting
zoom-id: 987-654-321
```

**More information** can be found in the extended [README on GitHub](https://github.com/GaetanoGeck/meety).
188 changes: 188 additions & 0 deletions README.md
Original file line number Diff line number Diff line change
@@ -0,0 +1,188 @@
<img alt="Meety Logo" src="./src/meety/static/icons/meety-256.png" width="200px"/>

# Meety - quickly start online meetings from YAML

**Problem.**
Online meetings provide a useful means to communicate with others. With an increasing number of meetings, however, it can get difficult to remember or pick the right meeting location, user id, password and so on.

**Goal.**
_Meety_ aims to provide a quick and easy way to start the right online meeting from a list of predefined meetings. Meetings are defined in YAML, a clean and simple format that is well readable for humans and machines alike. Thus, you can

- view and edit the meetings with your favourite text editor and
- sensibly share them with other users, even if they don't use _Meety_.
(Think of conferences, lectures, ...)


**Features.**
_Meety_ can can load meetings from one or multiple YAML files. The meetings can be filtered by time preferences and/or keywords. After choosing a meeting, _Meety_ will try to connect to it based on the information the meeting provides.

Out of the box, _Meety_ supports meetings via the browser and via the _Zoom_ app. However, the application can easily be configured to handle other types of meetings too, as described in the [documentation](./docs/configuration.md#supported-connections).

<img alt="Screenshot of the graphical user interface" src="./docs/screenshots/gui.png" width="40%"/>
<img alt="Screenshot of the command-line interface" src="./docs/screenshots/cli.png" width="40%"/>

_Meety_ ships with a graphical user interface (program `meety`, first screenshot above) and with a command line interface (program `cmeety`, second screenshot above).


## Quick start

Just follow the three steps below.


### Step 1/3: Install _Meety_

- **If you have Python and PIP installed,** simply run one of the following commands in your shell:
- user only: `pip3 install --user meety`
- system-wide: `sudo pip3 install meety`
You may have to take care that the path to the installation directory known to your system.
- **Alternatively download one of the bundles:**
- Linux
- Debian package (Ubuntu, ...):
- Pacman package (Arch Linux, ...):
- RPM package (Fedora, openSUSE, ...):
- MacOS: Right now, there is unfortunately no alternative.
- Windows
1. Install the runtime library from Microsoft: [Visual C++ 2010 Redistributable Package (x86)](https://www.microsoft.com/en-US/download/details.aspx?id=5555)
2. Download the [zip archive](https://any.where.com/) that contains
- the graphical user interface (`meety.exe`) and
- the required libraries.
3. Extract the archive into a suitable place (e.g. to `C:\Program Files\meety`).
Maybe create a shortcut to `meety.exe`.

### Step 2/3: Add a meetings file

Add a YAML file with meeting specifications to your home directory. You may find it helpful to start with a [template](./docs/quick-start.yaml) whose contents are also shown below.


```text
# Example meeting specifications in YAML
# Text after '#' is ignored by the application
# FIRST MEETING (Coffee round with colleagues, every morning)
- name: Coffee
zoom-url: https://zoom.us/j/123456789
prefer: Monday to Friday, 9 to 10 o'clock
# short format for time specifications (also for other languages)
# SECOND MEETING (lecture, each Tuesday and Thursday)
- name: My favourite lecture
url: https://my-university.edu/my-fav-lecture
prefer:
- weekday: Tuesday
time: 12:00 - 14:00
date: 2020-10-01 - 2021-03-31
- weekday: Thursday
time: 14:00 - 16:00
date: 2020-10-01 - 2021-03-31
# explicit format for time specifications (also for other languages)
# THIRD MEETING (without time preferences)
- name: Another meeting
zoom-id: 987-654-321
```

**Syntax overview for meeting specifications.**
Each meeting forms a list entry that is introduced with a dash, `-`. Such an entry is expected to be a dictionary, which can comprise several attributes of the form `key: value`. _Meety_ ignores the case of characters in the key. Values in turn can be text, a list or a dictionary again. To be recognised as a meeting specification, each entry is required to have an attribute with key `name`. This attribute has to be provided explicitly or can be derived automatically from other attributes. Other attributes are optional but may affect querying if they have a text value. More importantly, attributes with some keys, like `url`, `zoom-url` and `prefer` have a special meaning for _Meety_.

**Connection attributes.**
As an example, _Meety_ can establish connections from values for attributes with keys `url`, `zoom-url`, or `zoom-id`.
It is possible to customise the default connection handlers or register your own ones. You can also ask _Meety_ to infer attributes automatically from existing ones. For instance, if you provide attribute `zoom-id: 123-456-789` but no attribute with key `zoom-url`, then _Meety_ will add `zoom-url: https://zoom.us/j/123456789` (internally, not to the YAML file).
This is described in more detail in the [documentation](./docs/configuration.md#supported-connections).

**Support for other languages.**
Inferred attributes can also be used to make other words understood by _Meety_, in particular words from other languages. _Meety_ currently ships with some English, French, German, Italian and Spanish definitions (which can be enabled or disabled via the configuration), see the [documentation](./docs/configuration.md#languages) for more information.

_Meety_ can also load files from other directories than your home directory (and can also ignore those in your home directory). This, again, is described in the [documentation](./docs/select-files.md).

### Step 3/3: Run _Meety_

The goal of _Meety_ is to help you to connect to the meeting you're looking for quickly and effortlessly.
First, you have to identify a meeting of course. Then, you can try to connect to it.

**Rating of meetings.**
_Meety_ rates all meetings and shows meetings sorted by their rating (the best matching first). Meetings with equal ratings are shown in the order they have been loaded. Depending on your options, _Meety_ shows all or only matching meetings.

Meetings can be matching with respect to
- their time preferences and
- keywords, if provided.

Matching keywords contribute more to the rating than matching time preferences by default.

#### Graphical user interface

After starting _Meety_, the graphical user interface shows meetings according to their rating. Matching entries are highlighted. If you change the text in the search field or as time passes, the rating is updated, which may affect the order of items. By default, _all_ meetings are shown. If you activate the checkbox _only matching_, non-matching meetings are hidden.

<img alt="Screenshot of the graphical user interface with option 'only matching' enabled" src="./docs/screenshots/gui-only_matching.png" width="40%"/>

You can start a meeting with the preferred connection handler by clicking or double-clicking on an item (depending on your system). On a right click on an item, a context menu opens that allows you to choose a specific connection handler, to copy the meeting data and the like.

#### Command-line interface

After loading the meetings specifications, the command-line interface shows all _matching_ meetings. Below, we demonstrate the main options to influence the rating process for the example meetings above.

**Only time preferences.**
```text
# -- On a Tuesday at 11:00
> cmeety
No meeting found. Goodbye!
# -- On a Tuesday at 12:05
> cmeety
There's one matching meeting: My favourite lecture
Really connect (y/N)?
# -- On a Tuesday at 12:05
> cmeety --all # or '-a' for short
There are multiple matches:
[1] My favourite lecture
[2] Coffee
[3] Another meeting
Which one do you want to choose?
```
Note that _My favourite lecture_ is the first entry (because it has a matching time preference while others have not).

**Time preferences and meetings.**
```text
# -- On a Tuesday at 11:00
> cmeety meet
There's one matching meeting: Another meeting
Really connect (y/N)?
# -- On a Tuesday at 12:05
> cmeety meet
There are multiple matches:
[1] Another meeting
[2] My favourite lecture
Which one do you want to choose?
# -- On a Tuesday at 12:05
> cmeety meet --all # or '-a' for short
There are multiple matches:
[1] Another meeting
[2] My favourite lecture
[3] Coffee
Which one do you want to choose?
```
Now, _Another meeting_ is listed first because it matches the query _meet_. Meeting _My favourite lecture_ is listed second because of its matching time preference.

**Filter results.**
The list of matching meetings can be shortened in many cases with the use of one of the next two options:

- show only meeting with a maximal rating (`-b` or `--best`) or, even more restricted,
- show only the very first meeting (`-1` or `--first`) with a maximal rating.

**Further options.**
There are further options. You can get a quick overview with `cmeety --help`.

## Detailed documentation

In the [docs](./docs) directory, you can find more information on _Meety_. In particular on the following topics:

- [How to specify meetings in YAML](./docs/specify-meetings.md);
- [Select meeting files to load from](./docs/select-files.md);
- [Configure _Meety_](./docs/configuration.md), in particular how to
- [support other languages](./docs/configuration.md#languages),
- [change the colour scheme](./docs/configuration.md#colour-schemes)
- [set default arguments](./docs/configuration.md#default-arguments)
- [automatically polish meeting data](./docs/configuration.md#meeting-data)
- [support new connection types](./docs/configuration.md#connections)
Loading

0 comments on commit 0726067

Please sign in to comment.