Skip to content

Latest commit

 

History

History
144 lines (106 loc) · 4.17 KB

README.md

File metadata and controls

144 lines (106 loc) · 4.17 KB

Networkteam.Neos.Shariff

Social plugins are on every page today, but if you have concerns about privacy of your visitors it is not that easy to integrate them. The german publisher Heise created a general solution that allows to show the counts for each share while preserving the privacy of website visitory. This is accomplished by using the server of the website as proxy for the visitors. http://ct.de/-2467514

This plugin integrates Shariff into Neos with a few simple steps.

Installation:

$ composer require networkteam/neos-shariff

Configuration:

Include the package routes in your global Routes.yaml for fetching the counts via AJAX:

-
  name: 'NetworkteamNeosShariff'
  uriPattern: 'shariff/<NetworkteamNeosShariffSubroutes>'
  subRoutes:
    NetworkteamNeosShariffSubroutes:
      package: Networkteam.Neos.Shariff

Configure the list of services to show in a Settings.yaml (e.g. in your site package):

Networkteam:
  Neos:
    Shariff:
      options:
        services:
          - WhatsApp
          - Twitter
          - Facebook
          - GooglePlus
          - Pinterest
          - Mail

See Configuration/Settings.yaml for more information about possible options.

Usage:

This package contains two simple Node Types. Networkteam.Neos.Shariff:Shariff renders social share buttons via Shariff. Networkteam.Neos.Shariff:ShariffContainer wraps Networkteam.Neos.Shariff:Shariff in a tempalte for better control over markup. Just add a new node of this type to a document in the Neos backend.

Usage via TypoScript:

In your prototype define a property which renders the social plugins like this:

prototype(My.Awesome.Package:Post) {
    socialButtons = Networkteam.Neos.Shariff:Shariff
}

Then in the corresponding template render the path like this:

{socialButtons -> f:format.raw()}

Configuration:

Shariff is configured by data-attributes. A basic set of these attributes is already defined by package settings.

  • data-backend-url
  • data-services
  • data-theme
  • data-orientation
  • data-lang

You can override them in your settings.yaml.

Networkteam:
  Neos:
    Shariff:
      frontend:
        theme: standard
        orientation: horizontal
        language: en
      options:
        domain: ~
        cache:
          ttl: 3600
        services:
#          - Facebook
#          - GooglePlus
#          - Twitter
#          - LinkedIn
#          - Reddit
#          - StumbleUpon
#          - Flattr
#          - Pinterest
#          - Xing

If you want to extend the configuration just go like this:

prototype(Networkteam.Neos.Shariff:Shariff) {
	attributes {
		// Put additional attributes here, see https://github.com/heiseonline/shariff#options-data-attributes
		// data-example = 'value'
	}
}

Using Pinterest:

In order to use a "Pin it" button in shariff pinterest won't grab an image of your page automatically. You have to define one by using the "data-media-url" attribute. So just extend prototype(Networkteam.Neos.Shariff:Shariff) and use e.g. the twitterCardImage property of the current Document Node to serve a proper image.

Create your own Shariff wrapper

To render the shariff nodeType in your own template you can to create a nodeType i.e. Your.Site:ShariffContainer with Typoscript and HTML template:

NodeTypes.ShariffContainer.yaml (Configuration/NodeTypes.ShariffContainer.yaml)

'Your.Site:ShariffContainer':
  superTypes:
    'TYPO3.Neos:Content': true
  ui:
    label: 'Shariff container'
    icon: 'icon-share'

Root.ts2 or ShariffContainer.ts2

prototype(Your.Site:ShariffContainer) {
		shariffTag = Networkteam.Neos.Shariff:Shariff
}

Make sure ShariffContainer.ts2 gets included in your sites Root.ts2 by either

include: NodeTypes/ShariffContainer.ts2

or

include: NodeTypes/*.ts2

ShariffContainer.html (Resources/Private/Templates/NodeTypes/ShariffContainer.html)

<div>
	{shariffTag -> f:format.raw()}
</div>