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

crds-ng2-content-block

v2.0.1

Published

**NOTICE:** This package is now using graphql to get content blocks. For new work it maybe easier to use graphql directly instead of content block service to get content blocks.

Downloads

14

Readme

crds-ng2-content-block

NOTICE: This package is now using graphql to get content blocks. For new work it maybe easier to use graphql directly instead of content block service to get content blocks.

crds-ng2-content-block provides an easy mechanism for integrating dynamic content from Crossroads' CMS with your NG2 application.

Usage

Install the NPM package like so...

$ npm install crds-ng2-content-block --save

You may also need to install the following dependencies

    @apollo/client
    apollo-angular
    graphql

Update your app module by importing & adding the ContentBlockModule to your imports array...

import { ContentBlockModule } from 'crds-ng2-content-block';

@NgModule({
  imports: [
    ContentBlockModule.forRoot({
      endpoint: 'https://api-int.crossroads.net/graphql-gateway',
      categories: Array('main'), // optional
      options: {} // optional (not currently used)
    })
  ]
})
export class AppModule {}

The argument passed to forRoot() is an object that contains the following properties:

  • endpoint: the API endpoint for graphql
  • categories: the categories that will contain the needed content blocks
  • options: an object containing other options. (This is not currently utilized as there are no other options to configure)

The type signature of the argument is described by IContentBlockConfig:

interface IContentBlockConfig {
  endpoint: string,
  categories?: Array<string>,
  options?: {
    [propNames: string]: any
  }
}

You only need to call forRoot() once; any child components of your application that need to invoke crds-content-block can just import ContentBlockModule which will prevent multiple XHR requests to the CMS.

Once you've imported the module, you can use the component in HTML, like so...

<crds-content-block id="ContentBlockTitle"></crds-content-block>

Events

contentLoaded (optional)

A callback is optionally fired once the content is loaded using the contentLoaded directive.

<crds-content-block id="ContentBlockTitle" (contentLoaded)="contentHasLoaded()"></crds-content-block>

And in your component:

export class MyComponent {

  public contentHasLoaded() {
    // This will run when content has been loaded.
  }
}

This will only be fired a single time, as soon as the content is rendered within the content block.

License

This project is licensed under the 3-Clause BSD License.