npm package discovery and stats viewer.

Discover Tips

  • General search

    [free text search, go nuts!]

  • Package details

    pkg:[package-name]

  • User packages

    @[username]

Sponsor

Optimize Toolset

I’ve always been into building performant and accessible sites, but lately I’ve been taking it extremely seriously. So much so that I’ve been building a tool to help me optimize and monitor the sites that I build to make sure that I’m making an attempt to offer the best experience to those who visit them. If you’re into performant, accessible and SEO friendly sites, you might like it too! You can check it out at Optimize Toolset.

About

Hi, 👋, I’m Ryan Hefner  and I built this site for me, and you! The goal of this site was to provide an easy way for me to check the stats on my npm packages, both for prioritizing issues and updates, and to give me a little kick in the pants to keep up on stuff.

As I was building it, I realized that I was actually using the tool to build the tool, and figured I might as well put this out there and hopefully others will find it to be a fast and useful way to search and browse npm packages as I have.

If you’re interested in other things I’m working on, follow me on Twitter or check out the open source projects I’ve been publishing on GitHub.

I am also working on a Twitter bot for this site to tweet the most popular, newest, random packages from npm. Please follow that account now and it will start sending out packages soon–ish.

Open Software & Tools

This site wouldn’t be possible without the immense generosity and tireless efforts from the people who make contributions to the world and share their work via open source initiatives. Thank you 🙏

© 2024 – Pkg Stats / Ryan Hefner

ngwp-theme-kit

v0.0.17

Published

NgWP Theme Kit is an Angular library that enables the creation of WordPress themes using Angular. It follows the principle of headless cms, using the WordPress REST APIs.

Downloads

6

Readme

NgWP Theme Kit is an Angular library that enables the creation of WordPress themes using Angular.

It follows the principle of headless cms, using the WordPress REST APIs.

Getting Started

Prerequisites

In order to make use of this module you need (of course) an Angular application. Therefore you should create an app (if you hadn't already):

$ ng new my-app --routing

Installing the library

You can install NgWP Theme Kit with npm:

$ npm i ngwp-theme-kit

Importing the Angular module

Now you must import the NgwpThemeKitModule in your main module (usually app.module.ts).

An example:

...

import { NgwpThemeKitModule } from 'ngwp-theme-kit';

...

@NgModule({
  ...
  imports: [
    ...

    NgwpThemeKitModule

    ...
  ],
  ...
})

Configuring page & post templates

In order to correctly bind to the page & post (single) WordPress templates, you must create to dedicated components: one component that will render the page content and one that will render the post content.

Once you have these two components, you must call the static registration methods provided by the NgwpThemeKitModule module, as follows:

NgwpThemeKitModule.setPageTemplate(PageComponent);
NgwpThemeKitModule.setPostTemplate(PostComponent);

You must do this registration as soon as possible in your application lifecycle. The suggested position is just before the declaration of your application's main module.

Adding a themeconfig.json Configuration File

This is the configuration file that the custom build tool will use to generate the WordPress theme.

Here you specify some key information about your theme (such as its name, author and a description) along with supported theme features (e.g. post-thumbnails) and the customizer options.

For example, here is the content of the themeconfig.json of the Demo Theme sample application that you can find in the repository of the library:

{
  "name": "Demo Theme",
  "description": "A WordPress template developed with Angular frontend",
  "author": "Piero De Tomi",
  "themeFeatures": [
    "menus"
  ],
  "menus": [{
    "location": "header-menu",
    "description": "Header",
    "initialName": "Header Menu",
    "initialEntries": [ "Home", "Blog", "About Us", "Privacy" ],
    "onlyRegisterLocation": false
  },{
    "location": "footer-menu",
    "description": "Footer",
    "initialName": "Footer Menu",
    "initialEntries": [ "Footer Item 1", "Footer Item 2", "Footer Item 3", "Footer Item 4" ],
    "onlyRegisterLocation": false
  },{
    "location": "sidebar-menu",
    "description": "Sidebar Menu",
    "onlyRegisterLocation": true
  }],
  "sections": [{
    "id": "main",
    "name": "Main Config",
    "description": "Main configuration parameters",
    "settings": [{
      "id": "title",
      "label": "Title",
      "description": "The title of this blog",
      "defaultValue": null,
      "controlType": "text"
    },{
      "id": "author",
      "label": "Author",
      "description": "The author of this blog",
      "defaultValue": null,
      "controlType": "text"
    },{
      "id": "logo",
      "label": "Logo",
      "description": "The website logo",
      "defaultValue": null,
      "controlType": "image"
    }]
  }],
  "widgetAreas": [{
      "id": "header-widgets",
      "name": "Header Widgets",
      "description": "Widgets that will appear in the header of the page"
    },
    {
      "id": "sidebar-widgets",
      "name": "Sidebar Widgets",
      "description": "Widgets that will appear in the sidebar of the website"
    }
  ]
}

Adding the Custom Build Script to package.json

The last step is to modify the package.json file in order to add the scripts that will bundle up your WordPress theme.

Edit the build script inside the package.json file of your Angular project:

{
  ...

  "scripts": {
    ...

    "build": "ng build && \"./node_modules/ngwp-theme-kit/bin/NgWP.ThemeBuilder.exe\" {{dist-path}} {{path-to-themeconfig.json}}",
    
    ...
  }

  ...
}

Here you'll have to replace:

  • The {{dist-path}} token with your actual application's dist path (usually dist/<application name>)
  • The {{path-to-themeconfig.json}} token with the actual file path of your themeconfig.json configuration file

Develop the theme

Now you can develop your Wordpress theme using Angular, just as you would develop any other Angular application.

You can make use of the services provided by the library, that will allow you to access Wordpress information (using WordPress REST API + some custom PHP API code).

For example, you can retrieve the first 10 posts with the following code:

export class Sample implements OnInit {
  public posts: IPost[] = [];

  constructor(private _postService: PostService) { }

  ngOnInit(): void {
    this._postService
      .get(1, 10)
      .subscribe((posts) => {
        this.posts = posts;
      });
  }
}

You can view some more example usages on the demo-theme application inside this repository.

Test the theme (locally)

You can test some of the functionality of your theme locally with ng serve. You just need to update the siteUrl property in the main.ts file (in the "Local testing mode" section) setting it to your WordPress development environment.

// Local testing mode
  (window as any)._wpConfiguration = {
    siteUrl: '<<your_wp_site_url_here>>',
    auth: {
      isAuthenticated: false,
      userId: 0,
      nonce: ''
    },
    demo: true
  };

You'll be able to read "public" information as posts and categories, but you will NOT be able to access theme settings and more advanced information. To do this you'll need to install & test your theme directly into WordPress (please read on for this).

Build the theme package

In order to build your theme and make it ready for WordPress, you just need to run the command that you previously added to package.json file:

npm run build

However, you can rename this script as you like. You know... it's only an npm script after all.

Install in WordPress

After building the theme, the dist folder of your application ({{application-name}} will be your application name) will contain your theme ready to be installed in WordPress as any other theme.

The package will contain a default theme thumbnail (the screenshot.png file) that you can always replace with your own if you wish.

See your theme in action

Now it's time to see your theme in action! Open your WordPress website and have fun :)