Skip to content

Latest commit

 

History

History
86 lines (62 loc) · 3.4 KB

README.md

File metadata and controls

86 lines (62 loc) · 3.4 KB

Pipit Pinion

Pipit Pinion is a Perch Feather that helps you manage front-end assets such as CSS and Javascript through Perch.

Installation

  • Download the latest version of Pinion.
  • Unzip the download
  • Place the pipit_pinion folder in perch/addons/feathers
  • Add Pinion to your perch/config/feathers.php
  • Enable Feathers in your perch/config/config.php

Adding Pinion to feathers.php

If you don't have the file perch/config/feathers.php, create it and add:

<?php
    include(PERCH_PATH.'/addons/feathers/pipit_pinion/runtime.php');
?>

Enabling Feathers

You also need to enable Feathers in your perch/config/config.php

define('PERCH_FEATHERS', true);

Configuration

You can define default folders in perch/addons/feathers/pipit_pinion/config.php for Pinion to look for your CSS and Javascript files.

Name Value
PIPIT_PINION_ASSETS_DIR The name of the directory where your production assets are. The path is relative to root.
PIPIT_PINION_ASSETS_DEV_DIR The name of the directory where your development assets are. Pinion uses this directory when PERCH_PRODUCTION_MODE is set toPERCH_DEVELOPMENT. The path is relative to root.

The below example uses a folder called assets for production and src for development.

define('PIPIT_PINION_ASSETS_DIR', 'assets');
define('PIPIT_PINION_ASSETS_DEV_DIR', 'src');

In this example, CSS files need to be in assets/css and src/css, and Javascript files need to be in assets/js and src/js. This way you can use perch_get_css() and perch_get_javascript() to link all the files from the respective folder to your document by default.

 .
 ├── assets/
 │   ├── js/
 │   └── css/
 │   
 ├── src/
 │   ├── js/
 │   └── css/
 │   
 └── perch

The perch_get_css() and perch_get_javascript() functions have several options you can use giving you a lot of flexibility to control what gets inserted into your document and in what order. For more details check the Function Reference page.

Cache Busting

If you want to use Pinion's cache busting feature, you need to add the following to your .htaccess file:

RewriteRule ^(.+)\.(\d+)\.(js|css)$ $1.$3 [L]

If you are using Runway, make sure to add it before RewriteCond %{REQUEST_URI} !^/perch:

# Perch Runway
RewriteEngine On
RewriteRule ^(.+)\.(\d+)\.(js|css)$ $1.$3 [L]
RewriteCond %{REQUEST_URI} !^/perch 
RewriteCond %{REQUEST_FILENAME} !-f
RewriteRule .* /perch/core/runway/start.php [L] 

If you are already handling renaming your file with a task manager like Gulp or Grunt (using gulp-cache-bust or grunt-cache-bust), then there's no need to use this feature.

If you are adding a version to your file name (e.g. styles.v2.0.css), then you shouldn't to use this feature.

If your files are named like styles.css, this is for you.