Skip to content
This repository has been archived by the owner on Jan 30, 2018. It is now read-only.
/ ng-contentful Public archive

Contentful module for AngularJS, providing access to the content delivery API

Notifications You must be signed in to change notification settings

contentful/ng-contentful

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

13 Commits
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

This repository is deprecated. There is no further support or maintenence planned.

You can find a more up to date solution by the community at https://github.com/jvandemo/angular-contentful


ng-contentful

ng-contentful is a AngularJS module for accessing the Contentful CMS content delivery API and integrate content like blog posts and articles into your website or single-page app.

It wraps the contentful.js module into AngularJS modules, integrates its asynchronous operations in the digest-cycle and provides a couple of helpers for displaying content.

What is Contentful ?

Contentful is a flexible and future-friendly content management platform to create and manage your content as well as to deliver it onto mobile and web applications and any other platform.

Installation

bower install ng-contentful

Then just include the file by script-tag.
Note that you also need to include contentful.js (declared as a dependency in the bower.json).

<script type="text/javascript" charset="utf-8" src="bower_components/contentful/dist/contentful.min.js"></script>
<script type="text/javascript" charset="utf-8" src="bower_components/ng-contentful/ng-contentful.js"></script>

Setup

  1. Require the module
  2. In the config phase you set up your connection like so:
    var myApp = angular.module('myApp', ['ng-contentful']);
    
    myApp.config(function (contentfulClientProvider) {
      contentfulClientProvider.setOptions({
        // any other options, see contentful.js documentation
      });
      contentfulClientProvider.setSpaceId('mySpaceId');
      contentfulClientProvider.setAccessToken('myAccessToken');
    });
    

Usage

There are currently three services available:

  • contentfulClient: The base service to make requests to the server
  • ContentTypeList: Mechanism to synchronously and asynchronously look up contentTypes
  • EntryController: Controller to help work with entries

contentfulClient

Require the contentfulClient service and call the available methods (see Contentful.js documentation. Process the responses via Promises:

myApp.controller('SpaceController', function ($scope, contentfulClient) {
  contentfulClient.space().then(function (space) {
    $scope.space = space;
  });
});

ContentTypeList

Provides three methods:

  • lookupContentType(id): lookup the contentType by id by fetching the information from the server if necessary. Returns a promise.
  • loadAllContentTypes(): Loads all available contentTypes from the server. Returns a promise
  • getContentType(id): Synchronously returns contentType. Returns null if contentType is not yet know to the client.

EntryController

The EntryController assumes there's an entry on the scope.

Exposes two methods:

  • $scope.entryTitle(): Returns the title for an entry
  • $scope.contentType(): Returns the contentType for an entry if available locally. If not available, it triggers a lookup and when the lookup is done, $apply gets called so that it then returns the contentType.

Example

A minimum working code example would have two parts besides the setup (see section "Setup").

First, you need to load the ContentTypes and entries (for additional arguments to the entries call or other methods available on contentfulClient please refer to the Contentful.js documentation):

ContentTypeList.loadAllContentTypes();

contentfulClient.entries().then(function(entries){
  $scope.entries = entries;
});

Then, to iterate over your entries in a template:

<div ng-repeat="entry in entries track by entry.sys.id" ng-controller="EntryController">
  Entry {{entryTitle()}}
  <ul>
    <li ng-repeat="field in contentType().fields track by field.id">
      {{field.name}}: {{entry.fields[field.id]}}
    </li>
  </ul>
</div>

You can see an example in this Plunker: http://plnkr.co/edit/JboHnB7AgzpizfjbzuIq

About

Contentful module for AngularJS, providing access to the content delivery API

Resources

Code of conduct

Security policy

Stars

Watchers

Forks

Packages

No packages published

Contributors 3

  •  
  •  
  •