Skip to content

Commit

Permalink
Documentation updated (#27)
Browse files Browse the repository at this point in the history
  • Loading branch information
Spomky authored Jan 10, 2024
1 parent ff38672 commit 53c92cf
Show file tree
Hide file tree
Showing 3 changed files with 76 additions and 77 deletions.
146 changes: 75 additions & 71 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -18,6 +18,7 @@ Progressive Web App for Symfony

This bundle provides the [spomky-labs/phpwa](https://github.com/spomky-labs/phpwa) bundle for Symfony.
This will help you to generate Progressive Web Apps (PWA) Manifests and assets (icons or screenshots).
Also, it will help you to generate Service Workers based on [Workbox](https://developers.google.com/web/tools/workbox).

Please have a look at the [Web app manifests](https://developer.mozilla.org/en-US/docs/Web/Manifest) for more information about Progressive Web Apps.

Expand All @@ -44,11 +45,11 @@ A Service Worker can be used to provide offline capabilities to the application

The bundle is able to generate a manifest from a configuration file.
The manifest members defined in the [Web app manifests](https://developer.mozilla.org/en-US/docs/Web/Manifest) are supported
without any change, with the exception of members `icons`, `screenshots` and `shortcuts` (see below).
without any change, with the exception of some members described in the following sections.

```yaml
# config/packages/phpwa.yaml
phpwa:
pwa:
name: 'My App'
short_name: 'My App'
description: 'My App description'
Expand Down Expand Up @@ -76,50 +77,37 @@ When the configuration is set, you can generate the manifest with the following
symfony console pwa:build
```

The manifest will be generated in the `public` directory.
The manifest file name is `pwa.json` and the assets will leave in the `/public/pwa` folder by default.
You can change the output file name and the output folder with the following options:
By default, the manifest will be generated in the `public` directory with the name `/site.webmanifest`.
You can change the output file name and the output folder with the following configuration option:

* `--output` or `-o` to change the output file name (default: `pwa.json`)
* `--asset_folder` or `-a` to change the output folder (default: `/pwa`)
* `--public_folder` or `-p` to change the public folder (default: `%kernel.project_dir%/public`)
* `--url_prefix` or `-u` to change the URL prefix (default: ``)

```bash
symfony console pwa:build --output=manifest.json
```yaml
# config/packages/phpwa.yaml
pwa:
manifest_filepath: '%kernel.project_dir%/public/sub-folder/pwa.json'
```
### Using the Manifest
The manifest can be used in your HTML pages with the following code in the `<head>` section.
In you customized the output filename or the public folder, please replace `/site.webmanifest` with the path to your manifest file.

The URL prefix is used to generate the relative URLs in the manifest.
For instance, if your application root URL is https://example.com/foo/bar, set the URL prefix to `/foo/bar` and the manifest will be generated with relative URLs.

```json
{
"icons": [
{
"src": "/foo/bar/pwa/icon-192x192.png",
"sizes": "192x192",
"type": "image/png"
},
{
"src": "/foo/bar/pwa/icon-512x512.png",
"sizes": "512x512",
"type": "image/png"
}
]
}
```html
<link rel="manifest" href="/site.webmanifest">
```

### Manifest Icons

The bundle is able to generate icons from a source image.
This is applicable to the application icons, shortcut icons or Windows 10 widget icons members of the manifest.
The icons must be square and the source image should be at best quality as possible.

To process the icons, you should set an icon processor. The bundle provides a GD processor and an Imagick processor.
Depending on your system, you may have to install one extension or the other.

Please note that the icons of a size greater than 1024px may be ignored by the browser.

```yaml
# config/packages/phpwa.yaml
phpwa:
pwa:
image_processor: 'pwa.image_processor.gd' # or 'pwa.image_processor.imagick'
icons:
- src: "%kernel.project_dir%/assets/images/logo.png"
Expand All @@ -130,27 +118,51 @@ phpwa:
purpose: 'maskable'
- src: "%kernel.project_dir%/assets/images/logo.svg"
sizes: [0] # 0 means `any` size and is suitable for vector images
shortcuts:
- name: "Shortcut 1"
short_name: "shortcut-1"
url: "/shortcut1"
description: "Shortcut 1 description"
icons:
- src: "%kernel.project_dir%/assets/images/shortcut1.png"
sizes: [48, 72, 96, 128, 144, 192, 256, 384, 512]
format: 'webp'
- name: "Shortcut 2"
short_name: "shortcut-2"
url: "/shortcut2"
description: "Shortcut 2 description"
icons:
- src: "%kernel.project_dir%/assets/images/shortcut2.png"
sizes: [48, 72, 96, 128, 144, 192, 256, 384, 512]
format: 'webp'
```
With the configuration above, the bundle will generate
* 16 icons from the `logo.png` image. The icons will be converted from `png` to `webp`.
* 16 icons from the `mask.png` image. The format will be `png` and the purpose will be `maskable`.
* And 1 icon from the `logo.svg` image. The format will be `svg` and the size will be `any`.

If the `format` member is present, the bundle will convert the image to the specified format.
In the example above, the `logo.png` image will be converted to `webp`, but the `mask.png` image will not be converted.

### Manifest Screenshots

The bundle is able to generate screenshots from a source image.
This is applicable to the application screenshots or Windows 10 widget screenshot members of the manifest.
Similar to icons, the source image should be at best quality as possible.

You can select a folder where the source images are stored.
The bundle will automatically generate screenshots from all the images in the folder.

```yaml
# config/packages/phpwa.yaml
phpwa:
pwa:
image_processor: 'pwa.image_processor.gd' # or 'pwa.image_processor.imagick'
screenshots:
- src: "%kernel.project_dir%/assets/screenshots/narrow.png"
label: "View of the application home page"
- src: "%kernel.project_dir%/assets/screenshots/wide.png"
label: "View of the application home page"
- src: "%kernel.project_dir%/assets/screenshots/narrow/"
form_factor: "narrow"
- src: "%kernel.project_dir%/assets/screenshots/wide/"
form_factor: "wide"
- src: "%kernel.project_dir%/assets/screenshots/android_dashboard.png"
platform: 'android'
format: 'webp'
Expand All @@ -163,54 +175,31 @@ The `format` parameter is optional. It indicates the format of the generated ima

### Manifest Shortcuts

The `shortcuts` member may contain a list of icons.
The parameters are very similar to the `icons` member.
The `shortcuts` member may contain a list of action shortcuts that point to specific URLs in your application.
You can define URLs as relative paths or by using the route name.

```yaml
# config/packages/phpwa.yaml
phpwa:
image_processor: 'pwa.image_processor.gd' # or 'pwa.image_processor.imagick'
pwa:
shortcuts:
- name: "Shortcut 1"
short_name: "shortcut-1"
url: "/shortcut1"
description: "Shortcut 1 description"
icons:
- src: "%kernel.project_dir%/assets/images/shortcut1.png"
sizes: [48, 72, 96, 128, 144, 192, 256, 384, 512]
format: 'webp'
- name: "Shortcut 2"
short_name: "shortcut-2"
url: "/shortcut2"
description: "Shortcut 2 description"
icons:
- src: "%kernel.project_dir%/assets/images/shortcut2.png"
sizes: [48, 72, 96, 128, 144, 192, 256, 384, 512]
format: 'webp'
```

### Using the Manifest

The manifest can be used in your HTML pages with the following code in the `<head>` section.
In you customized the output filename or the public folder, please replace `pwa.json` with the path to your manifest file.

```html
<link rel="manifest" href="{{ asset('pwa.json') }}">
- name: "Action 1"
short_name: "action-1"
url: "/action1"
description: "Action 1 description"
- name: "Action 2"
short_name: "action-2"
url: "app_action2"
description: "Use this route to generate the URL"
```

## Service Worker

The following command will generate a Service Worker in the `public` directory.
The following command will generate a Service Worker in the `public` directory with the name `/sw.js`:

```bash
symfony console pwa:sw
```

You can change the output file name and the output folder with the following options:

* `--output` or `-o` to change the output file name (default: `sw.js`)
* `--public_folder` or `-p` to change the public folder (default: `%kernel.project_dir%/public`)

Next, you have to register the Service Worker in your HTML pages with the following code in the `<head>` section.
It can also be done in a JavaScript file such as `app.js`.
In you customized the output filename or the public folder, please replace `sw.js` with the path to your Service Worker file.
Expand All @@ -225,11 +214,26 @@ In you customized the output filename or the public folder, please replace `sw.j
</script>
```

The location of the Service Worker is important. It must be at the root of your application.
In addition, the `serviceworker.src` member of the manifest must be set to the same location.
The `serviceworker.scope` member may be set to the same location or to a sub-folder.
Do not forget to update the `scope` member in the JS configuration.

```yaml
# config/packages/phpwa.yaml
pwa:
serviceworker:
filepath: '%kernel.project_dir%/public/sub-folder/service-worker.js'
src: '/sub-folder/service-worker.js'
scope: '/'
```

### Service Worker Configuration

The Service Worker uses Workbox and comes with predefined configuration and recipes.
You are free to change the configuration and the recipes to fit your needs.
In particular, you can change the cache strategy, the cache expiration, the cache name, etc.
Please refer to the [Workbox documentation](https://developers.google.com/web/tools/workbox).

# Support

Expand Down
4 changes: 0 additions & 4 deletions src/DependencyInjection/Configuration.php
Original file line number Diff line number Diff line change
Expand Up @@ -439,10 +439,6 @@ private function setupServiceWorker(ArrayNodeDefinition $node): void
->thenInvalid('The filename from the "filepath" and the "src" must be the same.')
->end()
->children()
->booleanNode('generate')
->defaultFalse()
->info('Whether the service worker should be generated.')
->end()
->scalarNode('filepath')
->defaultValue('%kernel.project_dir%/public/sw.js')
->info('The filename where the service worker will be generated.')
Expand Down
3 changes: 1 addition & 2 deletions tests/config.php
Original file line number Diff line number Diff line change
Expand Up @@ -192,8 +192,7 @@
],
'handle_links' => 'auto',
'serviceworker' => [
'generate' => true,
'src' => '/my-sw.js',
'src' => '/sw/my-sw.js',
'filepath' => '%kernel.cache_dir%/samples/sw/my-sw.js',
'scope' => '/',
'use_cache' => true,
Expand Down

0 comments on commit 53c92cf

Please sign in to comment.