Theme for the services page on ucf.edu.
- Installation Requirements
- Important files/folders
- Notes
- Quick Install
- Virtual Machine for Local Development
- Installing Required Development Tools
- Development Toolset
Included with repository. See composer.json, bower.json, and package.json for version details.
- Anahkiasen/Underscore-php - PHP utility functions.
- Bootstrap 3 - mobile-first and responsive front-end framework.
- Font Awesome 4 - the iconic font and css toolkit.
- Weather Icons - weather-themed icons and css.
- Gravity Forms - form in site footer (requires a license).
The following libraries are provided by WordPress:
- jQuery - Javascript utility functions, including HTML document traversal and manipulation, event handling, animation, and Ajax.
- SimplePie - feed parser.
- WordPress REST API (version 2) - access WordPress data through an HTTP REST API (this will eventually be integrated with WordPress Core).
Folder for this repo's GitHub Pages site, including generated code documentation.
The entry point for a WordPress theme, along with the style.css file. It includes or references all functionality for a theme.
This should be used for requiring other files (group all require statements at the top).
Where, aside from style.css in the root, all compiled/minified, theme-specific static content such as javascript, images, and css should live. Currently, legacy code also references static files in css/ and js/.
Where static assets such as scss partials and unminified javascript should live. With the exception of files in src/components/ (see below), the files in this directory should be used to modify styles and logic on the frontend (do not modify minified assets in static/.)
Where static assets installed by Bower should live. Contents in this directory should be ignored by the repo and are referenced only when running scripts (e.g., compiling Sass).
Create Custom Posttypes by inheriting from CustomPostType
in functions/class-custom-posttype.php
.
The class CustomPostType
centralizes posttype functionality, facilitates shortcode creation
(displaying a list of posts), and abstracts other implementation details.
Custom Posttypes must be passed to CustomPostType::Register_Posttypes
(see register_custom_posttypes
for examples).
Create Custom Taxonomies by inheriting from CustomTaxonomy
in functions/class-custom-taxonomy.php
.
The class CustomTaxonomy
centralizes taxonomy functionality and abstracts implementation details.
Custom Taxonomies must be passed to CustomTaxonomy::Register_Taxonomies
(see register_custom_taxonomies
for examples).
Define Wordpress shortcodes here by inheriting from ShortcodeBase
in functions/class-shortcodebase
.
The class ShortcodeBase
extends shortcode functionality to add UI for shortcode creation.
See example shortcodes for more information.
This theme relies on front-page.php
and falls back to index.php
.
For more details, see the WordPress Theme Handbook
or https://wphierarchy.com/
Calls to get_header()
and get_footer()
resolve to header.php and footer.php respectively.
Theme Customizer settings for the Footer
class are located in footer-settings.php
.
Add and configure Theme Customizer options for this theme (non-admin settings). This relies on implementation in SDES_Customizer_Helper, a wrapper aimed toward reducing boilerplate code.
Utility methods that are static, pure functions, and fit for reuse in other projects.
Unit tests and codesniffer configuration files.
Third-party libraries installed by Composer that are required by this theme. Production dependences,
such as anahkiasen/underscore-php
, have been saved to the repository to simplify deployment.
This theme utilizes Twitter Bootstrap as its front-end framework. Bootstrap styles and javascript libraries can be utilized in theme templates and page/post content. For more information, visit http://twitter.github.com/bootstrap/
Note that this theme may not always be running the most up-to-date version of
Bootstrap. For the most accurate documentation on the theme's current
Bootstrap version, visit http://bootstrapdocs.com/ and select the version number
found at the top of components/bootstrap-sass-official/bower.json
.
- If you do not have the "Required Development Tools" installed, first see Installing Required Development Tools below.
- If you would like to use a virtual machine for your WordPress environment, first see Virtual Machine for Local Development.
- Otherwise, assuming you already have a WordPress/PHP/MySQL environment:
-
Clone this repository to the "www\wordpress\wp-content\themes" folder:
git clone https://github.com/ucf-sdes-it/ucf-services-theme.git
andcd ucf-services-theme
. -
Choose whether to install javascript utilities globally (
npm run-script install:global
) or locally to the node_modules folder (npm install
). See package.json for version details. -
Run
bower install
to install web front-end components from bower.json (bootstrap, fontawesome, weathericons, etc.). -
Compile Sass to CSS using your preferred method. For example, using Koala, drag in the project folder (which contains a koala-config.json file).
-
To use PHP utilities, install them with Composer, either globally (
composer run-script install:global
), or locally to the vendor folder (composer install
). See composer.json for version details.
Optional:
-
If the FontAwesome version is updated or icons are missing, run
node -e ./scripts/write_fa_icons_list.js
to updatestatic/data/fa-icons.json
. -
Run
composer phpdoc:all
to compile thedocs
folder (see below for details on installing PHPDoc and GraphViz).
VCCW is a configuation/stack for setting up a virtual development environment with Vagrant + VirtualBox + CentOS + Chef + WordPress.
- Vagrant spins up a virtual machine harddrive from a template "box".
- VirtualBox runs the virtual machine.
- CentOS is a redhat compatible Linux distro.
- Chef1 is used for configuration management.
- WordPress is already installed with all requirements/dependencies, along with a suite of development tools, including WP-CLI, PHP Composer, and PHPUnit.
See VCCW homepage for more details.
-
Install VirtualBox. The installer may temporarily disable the network and/or require a restart.
-
Install Vagrant. This may require a restart (adds to $env:PATH).
-
Download the vccw harddrive image with vagrant:
vagrant box add miya0001/vccw --box-version ">=2.19.0"
(this may take a long time -- 1.55GB+ download) -
Create a folder for the Vagrant virtual machine (based on, for example: https://github.com/vccw-team/vccw/archive/2.20.0.zip)
-
From cmd.exe or powershell,
cd
into the directory. -
Make a site.yml file in the Vagrant directory via:
cp provision\default.yml site.yml
and edit the following values:multisite: true plugins: - dynamic-hostname - wp-total-hacks - tinymce-templates - what-the-file - wordpress-mu-domain-mapping - rest-api - wordpress-importer - wp-allow-hosts
Note, the above plugin names can be appended to:
https://wordpress.org/plugins/
to find their details pages. -
vagrant up
(initial provisioning may take several minutes). -
Add an entry to your HOSTS file2. for the VM's IP address3.:
192.168.33.10 services-theme.dev
-
Clone this repository to the "www\wordpress\wp-content\themes" folder of your vccw-x.xx.x installation. Use either GitHub for windows or
git clone https://github.com/ucf-sdes-it/ucf-services-theme.git
4. -
Access the WordPress install in your browser from http://services-theme.dev/ or http://192.168.33.10 and develop as normal. The following Vagrant commands may prove useful:
- Start/Recreate VM:
vagrant up
- Suspend VirtualBox VM:
vagrant suspend
- Resume VirtualBox VM:
vagrant resume
- Shutdown VirtualBox VM:
vagrant halt
- Restart and reload Vagrantfile:
vagrant reload
- Delete VM (leaves directory from step 4 intact):
vagrant destroy
(this may take several minutes).
Consultvagrant help
or the Vagrant Documentation for additional information.
- Remember to "Network Activate" the theme from http://services-theme.dev/wp-admin/network/themes.php
- To use PHPDoc:
- Install PHPDoc on your system with:
composer global require phpdocumentor/phpdocumentor=2.8.*
- If GraphViz is not installed on your system, it needs to be installed (tested with graphviz-2.38.msi on Windows 8).
- Make sure to add the GraphViz bin folder (
C:\Program Files (x86)\Graphviz2.38\bin
) to your PATH. - Run
composer phpdoc:all
to compile thedocs
folder (this make take a few minutes the first time it is run).
- Install vagrant-multi-putty with
vagrant plugin install vagrant-multi-putty
. This enables the commandvagrant putty
to open an SSH session using PuTTY5.
VCCW also offers another VM specifcally for Theme Reviewing. Testing in a fresh environment could be useful after feature completion, whether for a feature branch or alpha testing.
If you do not have required development tools installed already, follow the instructions below. Note that the VCCW virtual machine comes with many of these already pre-installed.
- Install NodeJS v6.9.1 (or later) from the NodeJS homepage. (v6.9.1 windows x64 installer). If you need NodeJS for other projects, you may want to use Node Version Manager (nvm) on *nix systems or nvm-windows on Windows.
- After NodeJS is installed, run
npm install -g bower
from the commandline.
- On Windows, you can choose to run the Koala installer from the Koala homepage.
- Otherwise, follow the SASS installation instructions found on: http://sass-lang.com/install
Composer requires PHP to be installed on your development system.
- Install PHP, if it is not already installed:
- On Windows, via the (Microsoft Web Platform Installed)[http://www.microsoft.com/web/downloads/platform.aspx] - select 'PHP 5.6.0 for IIS Express' (or a later version of PHP).
- Or, follow the PHP installation documentation.
- Install Composer from https://getcomposer.org/download/
- On Windows:
- Download and run https://getcomposer.org/Composer-Setup.exe
- Verify that %APPDATA%\Composer\vendor\bin has been added to your PATH enviornment variable.
- On other platforms: follow the official Composer command-line installation instructions.
Overview of recommended development tools for coding.
Manage package dependencies. This can streamline upgrading library files. Composer
Similar to: PEAR (PHP), NuGet (.NET), NPM (NodeJS package manager), or Bower (front-end webdev)
A CSS extension language that adds: variables, nesting, partials, mixings, inheritance, operators, and other language features.
Similar to (interface): Scout, Compass.app.
Similar to (manual): Ruby sass gem from commandline (Ruby), gulp-js (NodeJS, requires Ruby).
Alternatives: Stylus Language, LESS Language.
Library used to test small units of code (e.g. functions, classes). May measure coding metrics, often in conjunction with other tools. PHPUnit - popular testing library for PHP that uses the xUnit architecture.
Similar to: NUnit (.NET), MSTest (.NET), JUnit (Java), etc.
Related to: Code Analysis (.NET Visual Studio)
Libraries used to test for integration (of multiple system components), functionality, and user acceptance conditions.
Automatically check code against a set of rules/standards. PHPCodeSniffer is a popular tool for standardizing PHP code. Commands:
- phpcs (php code sniffer)
- phpcbf (php code beautifier and fixer)
- jscs (javascript code sniffer)
Similar to: StyleCop (.NET), JSHint (javascript), JSLint (javascript)
Related to: Lint programs (syntax checkers)
Tooling to extract and format documentation from specially-formatted code comments (docblocks).
phpDocumentor - popular php documentation program that uses xDoc style formatting.
phpDocumentor is installed in the VCCW virtual machine. To run locally, either install systemwide using: composer global require phpdocumentor/phpdocumentor=2.8.*
(preferred) or download the PHP archive (.PHAR file) from http://phpdoc.org/phpDocumentor.phar.
NOTE: PHPDocumentor requires GraphViz to be installed on your system: http://graphviz.org/Download_windows.php (tested with graphviz-2.38.msi on Windows 8).
Make sure to add C:\Program Files (x86)\Graphviz2.38\bin
to your PATH.
Similar to: javadoc, jsdoc
Alternatives: phpDox, Sami, Doxygen, Apigen. (Switching or supplementing with these might make sense, e.g., phpDox includes code metrics, Sami generates an index view).
Library and tools to test browser interactions.
A library and set of tools that allow you to programmatically control a browser. It has bindings in multiple languages (including C# and PHP), though the most popular one is Java.
Related to: BrowserStack (extension service to test on multiple devices)
Similar to: PhantomJS (javascript), HttpUnit (Java), Watir (Ruby web testing)
A service that facilitates testing on multiple browser types, versions, and OSes (including mobile).
^2: Hosts file on windows: c:\Windows\System32\drivers\etc\hosts (must edit as administrator).
^3: By default, VCCW uses Virtualbox's NAT networking mode for Adapter 1 and Host-only networking for Adapter 2.
^4: You may want to add an NTFS junction point* that links from your c:\github folder and targets the cloned folder's location. From cmd.exe, run mklink /j
(or using Powershell Community Extenions, new-junction
). Creating a junction in the other direction (targeting the vccw folder) will be difficult/impossible due to Virtualbox security concerns, involving the setting VBoxManage.exe setextradata <VM Name> VBoxInternal2/SharedFoldersEnableSymlinksCreate/<volume> 1
.
^5: PuTTY is a windows and *nix client for SSH, telnet, and rlogin. To use the VM's private key instead of a password every time, follow these instructions with vccw-x.xx.x\.vagrant\machines\services-theme.dev\virtualbox\private_key
.
*[NTFS junction point]: See https://en.wikipedia.org/wiki/NTFS_junction_point and http://www.hanselman.com/blog/MoreOnVistaReparsePoints.aspx