Provides an additional Spreadsheet Field Type for Craft CMS. Read about why we built this on the Digital Butter blog.
This plugin requires Craft CMS 3.0.0-beta.23 or later.
SimpleSheets utilizes a non-commercial instance of Handsontable via CDN to render spreadsheets. You can find a copy of the Handsontable license online here.
To install the plugin, follow these instructions.
-
Open your terminal and go to your Craft project:
cd /path/to/project
-
Then tell Composer to load the plugin:
composer require /simple-sheet
-
In the Control Panel, go to Settings → Plugins and click the “Install” button for SimpleSheet.
SimpleSheet brings basic spreadsheet functionality with a familiar interface to Craft CMS.
Once the SimpleSheet plugin is successfully installed, it is ready to go.
You can create a SimpleSheet field in the same way as you would any other field in Craft.
- In the Control Panel, go to "Settings" -> "Fields" and click the "New Field" button.
- Fill out the required fields and select "SimpleSheet" from the "Field Type" dropdown.
You may now add this new field to your sections.
When using a SimpleSheet field in the Entries page, the following actions are available:
- Inserting/Deleting rows and columns
- Duplicating data
- Sorting data
- Rearranging row and column order
- Filtering *
- Keyboard navigation
- Copying from Excel and Google Sheets
- Note that filters do not permanently alter the source data and will not be saved. This will be updated in a future version.
Right-click on the sheet to bring up the context-menu. The following options will be be available:
- Insert row above
- Insert row below
- Insert column left
- Insert column right
- Remove rows
- Remove columns
Data can currently be duplicated through the following steps:
- Selected the desired row or column to duplicate.
- Select "copy" from the context menu, or use native keyboard shortcuts (Ctrl+C / Cmd+C)
- Open the context menu and insert a new row or column.
- Select the first cell of the newly-created row or column.
- Use keyboard shortcuts to paste the data (Ctrl+V / Cmd+V)
Data can be sorted by clicking on the header text of the column. A small arrow will appear in the header to indicate that the spreadsheet data is being sorted by that particular column, and whether the data is being sorted in ascending or descending order.
Rows and columns can be rearranged by dragging and dropping them into a new order. A small hand cursor will appear on the selected row/column header to indicate that the element can be dragged. Note that the row/column must be selected for this cursor to appear.
- For rows, the cursor appears at the top of the selected row header.
- For columns, the cursor appears on the left edge of the selected column header.
Data filtering is available through a dropdown button on the right side of each column. The following filter options are available:
- Filter by predefined conditions: - Is/Is Not Empty - Is/Is Not Equal To - Begins/Ends With - Contains/Does Not Contain
- Filter by value (freeform text)
- Manual filter (select/deselect specific values from a list of checkboxes)
Basic keyboard navigation is supported:
- Tab moves the current cell focus right.
- Shift+Tab moves the current cell focus left.
- Enter/Return - On first keypress, will enter the top leftmost selected cell for editing. - On second keypress, will commit any changes and move down one cell.
- Directional keys moves the current cell focus in the direction pressed.
Data can be copied from Excel/Google Sheets and pasted into the spreadsheet using standard keyboard shortcuts To Copy: Ctrl+C on Windows/Linux, Cmd+C on MacOS. To Paste: Ctrl+V on Windows/Linux, Cmd+V on MacOS.
Note that formatting and styling features are currently not supported and will not carry over into the SimpleSheet field.
Rendering a non-editable version of your spreadsheet in the frontend is a simple matter of using the embed
method on your SimpleSheet field. This will return a div container tag with your provided (or auto-generated ID), and will include the JS and CSS required to render the spreadsheet.
{{ entry.mySimpleSheetField.embed() }}
Embed accepts an optional options
object as its only parameter. The following values are currently accepted:
-
id
: Provide the id of a html element which will be used to create the SimpleSheet container in HTML. -
width
: Define the SimpleSheet's width as a string. Default100%
. -
height
: Define the Simplesheet's height. Default500px
.{{ entry.mySimpleSheetField.embed({ id: 'sheet', width: '800px', height: '600px', }) }}
If you wish to access the raw data for freeform templating, you can retrieve it using the data
property on the spreadsheet to retrieve an array of row arrays.
{% set sheetData = mySimpleSheetField.data %}
Display the data as a JSON-formatted string:
{{ sheetData | json_encode(constant('JSON_PRETTY_PRINT')) }}
Retrieve the number of rows:
{{ sheetData | length }}
Retrieve the number of columns:
{{ sheetData[0] | length }}
This plugin is currently in its early stages and has limited functionality. Features planned for future versions:
- Support for non-volatile display settings (text alignment, column width, etc), allowing these settings to persist between views and apply to the frontend.
- Allow filters to be carried over between viewing sessions without permanently altering the source data.
- Conditional formatting.
- Apply background colours to cells.
- Apply simple borders to cells.
- Define data types of cells (text, numeric, decimal, etc)
- Support for basic formulas (average, sum, etc)