0
Fork 0
mirror of https://github.com/TryGhost/Ghost.git synced 2025-01-20 22:42:53 -05:00
ghost/apps/portal/README.md

71 lines
3.2 KiB
Markdown
Raw Normal View History

# Portal
2020-03-24 18:37:38 +05:30
[![npm version](https://badge.fury.io/js/%40tryghost%2Fportal.svg)](https://badge.fury.io/js/%40tryghost%2Fportal)
2020-04-20 23:03:24 +05:30
[Drop-in script](https://ghost.org/help/setting-up-portal/) to make the bulk of Ghost membership features work on any theme.
2020-04-20 22:12:20 +05:30
## Usage
2020-04-20 23:26:55 +05:30
Ghost automatically injects Portal script on all sites running Ghost 4 or higher.
2021-03-17 22:34:00 +05:30
Alternatively, Portal can be enabled on non-ghost pages directly by inserting the below script on the page.
2020-04-20 23:26:55 +05:30
```html
<script defer src="https://unpkg.com/@tryghost/portal@latest/umd/portal.min.js" data-ghost="https://mymemberssite.com"></script>
2020-04-20 23:26:55 +05:30
```
The `data-ghost` attribute expects the URL for your Ghost site, which is the only input Portal needs to work with your site's membership data via Ghost APIs.
### Custom trigger button
By default, the script adds a default floating trigger button on the bottom right of your page which is used to trigger the popup on screen.
Its possible to add custom trigger button of your own by adding data attribute `data-portal` to any HTML tag on page, and also specify a specific [page](https://github.com/TryGhost/Ghost/blob/main/ghost/portal/src/pages.js#L13-L22) to open from it by using it as `data-portal=signup`.
The script also adds custom class names to this element for open and close state of popup - `gh-portal-open` and `gh-portal-close`, allowing devs to update its UI based on popup state.
Refer the [docs](https://ghost.org/help/setup-members/#customize-portal-settings) to read about ways in which Portal can be customized for your site.
2020-04-20 22:12:20 +05:30
## Basic Setup
This section is mostly relevant for core team only for active Portal development. Always use the unpkg link for testing/using latest released portal script.
2020-04-20 22:12:20 +05:30
- Run `yarn start:dev` to start Portal in development mode
- Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
- To use the local Portal script in a local Ghost site
- Update `config.local.json` in Ghost repo to add "portal" config pointing to local dev server url as instructed on terminal.
- By default, this uses port `5368` for loading local Portal script on Ghost site. It's also possible to specify a custom port when running the script using - `--port=xxxx`.
2020-04-20 22:12:20 +05:30
## Available Scripts
2020-04-20 22:12:20 +05:30
In the project directory, you can also run:
### `yarn start`
Runs the app in the development mode.<br />
Open [http://localhost:3000](http://localhost:3000) to view it in the browser.
The page will reload if you make edits.<br />
You will also see any lint errors in the console.
Start the portal server when developing Ghost by running Ghost (in root folder) via `yarn dev --all` or `yarn dev --portal`. This will host the portal JavaScript files, and makes sure that Ghost uses these locally hosted assets instead of the ones from the CDN.
### `yarn build`
Creates the production single minified bundle for external use in `umd/portal.min.js`. <br />
2020-04-20 22:12:20 +05:30
### `yarn test`
2020-04-20 22:12:20 +05:30
Launches the test runner in the interactive watch mode.<br />
2020-04-20 22:12:20 +05:30
## Publish
Run `yarn ship` to publish new version of script.
`yarn ship` is an alias for `npm publish`
- Builds the script with latest code using `yarn build` (prePublish)
- Publishes package on npm as `@tryghost/portal` and creates an unpkg link for script at https://unpkg.com/@tryghost/portal@VERSION
2021-03-17 22:34:00 +05:30
(Core team only)