Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/svvitale/django-progressive-web-app
Looks like an app, feels like an app, but NOT an app.
https://github.com/svvitale/django-progressive-web-app
django django-application progressive-web-app python
Last synced: about 2 months ago
JSON representation
Looks like an app, feels like an app, but NOT an app.
- Host: GitHub
- URL: https://github.com/svvitale/django-progressive-web-app
- Owner: svvitale
- License: mit
- Archived: true
- Created: 2017-02-05T05:22:15.000Z (almost 8 years ago)
- Default Branch: master
- Last Pushed: 2018-12-19T22:38:25.000Z (almost 6 years ago)
- Last Synced: 2024-09-19T11:42:27.668Z (about 2 months ago)
- Topics: django, django-application, progressive-web-app, python
- Language: Python
- Homepage:
- Size: 98.6 KB
- Stars: 90
- Watchers: 15
- Forks: 18
- Open Issues: 6
-
Metadata Files:
- Readme: README.md
- Changelog: CHANGELOG.md
- License: LICENSE.md
Awesome Lists containing this project
README
**DEPRECATED: [@silviolleite](https://github.com/silviolleite/) has been kind enough to build on this initial implementation and add some excellent functionality. You can find his supported implementation of this project here: https://github.com/silviolleite/django-pwa**
Silvio has also published it to PyPI: https://pypi.org/project/django-pwa/
django-progressive-web-app
=====
This Django app turns your project into a [progressive web app](https://developers.google.com/web/progressive-web-apps/). Navigating to your site on an Android phone will prompt you to add the app to your home screen.![Prompt for install](https://github.com/svvitale/django-progressive-web-app/raw/master/images/screenshot1.png)
Launching the app from your home screen will display your app [without browser chrome](https://github.com/svvitale/django-progressive-web-app/raw/master/images/screenshot2.png). As such, it's critical that your application provides all navigation within the HTML (no reliance on the browser back or forward button).
Requirements
=====
Progressive Web Apps require HTTPS unless being served from localhost. If you're not already using HTTPS on your site, check out [Let's Encrypt](https://letsencrypt.org/) and [ZeroSSL](https://zerossl.com/).Installation
=====
Install from PyPI:```
pip install django-progressive-web-app
```Configuration
=====
Add `pwa` to your list of `INSTALLED_APPS` in settings.py:```python
INSTALLED_APPS = [
...
'pwa',
...
]
```Configure your app name, description, and icons in settings.py:
```python
PWA_APP_NAME = 'My Kickass App'
PWA_APP_DESCRIPTION = "Do kickass things all day long without that pesky browser chrome"
PWA_APP_THEME_COLOR = '#0A0302'
PWA_APP_BACKGROUND_COLOR = '#ffffff'
PWA_APP_DISPLAY = 'standalone'
PWA_APP_START_URL = '/'
PWA_APP_ICONS = [
{
'src': '/static/images/my_app_icon.png',
'sizes': '160x160'
}
]
```All settings are optional, and the app will work fine with its internal defaults. Highly recommend setting at least `PWA_APP_NAME` and `PWA_APP_DESCRIPTION`.
Add the progressive web app URLs to urls.py:
```python
from django.conf.urls import url, includeurlpatterns = [
...
url('', include('pwa.urls')), # You MUST use an empty string as the URL prefix
...
]
```Inject the required meta tags in your base.html (or wherever your HTML <head> is defined):
```html
{% load pwa %}...
{% progressive_web_app_meta %}
...```
Troubleshooting
=====
While running the Django test server:1. Verify that `/manifest.json` is being served
1. Verify that `/serviceworker.js` is being served
1. Use the Application tab in the Chrome Developer Tools to verify the progressive web app is configured correctly.
1. Use the "Add to homescreen" link on the Application Tab to verify you can add the app successfully.Adding Your Own Service Worker
=====
By default, the service worker implemented by this app is empty. To add service worker functionality, you'll want to create a `serviceworker.js` or similarly named file, and then point at it using the PWA_SERVICE_WORKER_PATH variable.```python
PWA_SERVICE_WORKER_PATH = os.path.join(BASE_DIR, 'my_app', 'serviceworker.js')```
Feedback
=====
I welcome your feedback and pull requests. Enjoy!License
=====
All files in this repository are distributed under the MIT license.