/package-frontend

Frontend Site for Browsing Packages

Primary LanguageEJSMIT LicenseMIT

Package Frontend

Serves as a visual Web Browser for the package-backend.

Currently this matches very closely with the design of the original package viewer from upstream Atom.

Although does fully support multiple themes being added on later with a theme switcher.

The Web Browser for Packages is available on pulsar-edit.dev.

If you'd like to read about some of the challenges of normalizing the data across so many different Packages:

Additionally for anyone crafting a direct download link to our Pulsar Binaries from Cirrus CI:


When browsing the website, if you'd like to investigate what's caused the page load to take a long time there's now a built in utility to help determine that. While it can't show every aspect of the page load it could at least help to rule out some aspects.

When on the website, open the DevTools for your respective browser and in the provided console type:

loadStats();

This will output similar to the following:

{
  "api-request": {
    "duration": 922.325,
    "end": 2699.609,
    "start": 1777.28
  },
  "transcribe-json": {
    "duration": 14.55,
    "end": 2714.175,
    "start": 2699.617
  }
}

Of the above output, the only field that you should worry about is duration, as this tells you in milliseconds how long whatever action is related took. Of the actions that might be shown below is an explaination of what they mean.

  • api-request: An API Request was needed to be made to the backend server, and this shows the duration that request took.
  • transcribe-json: JSON Data received from an API request needs to be modified to be displayed to the end user, and some of these actions are intensive. This shows the duration it took to completly modify and return the JSON data.
  • cache-check: Local or Remote or Both types of caching are implemented on this endpoint. This shows the duration it took to check with said caches for the relevant data.

Currently loadStats() is unable to display how long certain actions took, which are listed below:

  • The time ExpressJS took to handle the request itself.
  • The time PugJS/Jade templates took to handle creating and displaying the page.

Developers

To run and test package-frontend locally should be rather simple.

After cloning the repository, run npm install within the root of the folder.

Then copy or rename app.example.yaml to app.yaml. When working with a local app config file you can change settings of the backend API to interact with to use a local version, or change the port the frontend is exposed on.

Within the config file exists the key GOOGLE_APPLICATION_CREDENTIALS this key is used to point to a KeyFile containing Google Application Credentails to interact with Remote Caches. If you don't have access to this file set it to "no-file" like so:

GOOGLE_APPLICATION_CREDENTIALS: "no-file"

This is a special value that will cause the caching service to automatically ignore any cache requests, and force request through to the backend service. Allowing to fail gracefully.

Running In Dev Mode

Using npm run start:dev you can run the Package Frontend Server in Development mode. This does two notable things:

  • Disables Remote Cache Features Natively. Setting GOOGLE_APPLICATION_CREDENTIALS: "no-file" is not necessary when run in dev mode.
  • Exposes a secret API endpoint. /dev/image/packages/:packageName will be available when in dev mode, and gives direct access to the HTML code used to display the Social Cards. Using this can allow easier modification and editing of our Social Cards.

Creating a new Social Card

The Pulsar Package Frontend now supports social cards.

These cards will be suggested when services create a link preview from a link to https://web.pulsar-edit.dev/packages/packageName.

These Social Cards are created on demand and us HTML that's then converted into a PNG to be served back to the client. To modify a template edit it's respective files in ./src/images-templates/socialCardName/.

Keep in mind that these will follow EJS syntax.

But if a user decides to share an image directly, such as to place on their Repository Readme or elsewhere on the web, the following link will work to do so https://web.pulsar-edit.dev/image/packages/packageName. But there is interest in supporting query parameters to allow different images to be generated. Currently we support two social cards iconic and default. Query parameters are not yet implemented to support users choosing these just yet.