peekfield
A dependency-free, easy to use, JavaScript plugin for hiding and showing fields.
Demo
Visit https://peekfield.js.org
Installation
Manual Download
Download dist/peekfield.min.js and place the following HTML in your page's head element:
<script type="text/javascript" src="dist/peekfield.min.js"></script>
jsDelivr)
CDN (Courtesy ofPlace the following HTML in your page's head element (check to make sure the version in the URL is the version you want):
<script type="text/javascript" src="https://cdn.jsdelivr.net/gh/kodie/peekfield@0.0.3/dist/peekfield.min.js"></script>
NPM
npm install peekfield --save
// ES6
import peekfield from 'peekfield'
// CommonJS
const peekfield = require('peekfield')
GPM
gpm install kodie/peekfield --save
Bower
bower install kodie/peekfield --save
Usage
Basic HTML Structure
<div data-peekfield-for="name" data-peekfield-placeholder="Please enter your name."></div>
<div data-peekfield="name">
<label for="first_name">First Name</label>
<input type="text" name="first_name" />
<label for="last_name">Last Name</label>
<input type="text" name="last_name" />
</div>
peekfield([options], [fields])
Function
The Initiates peekfield.
Parameters
-
options
(Object
) (Optional) - An object of options you can set to change how the fields function. -
fields
(String
,NodeList
, orHTMLElement
) (Optional) - The elements to turn into peekfield. If set to a string, that string will be passed todocument.querySelectorAll()
. (Defaults to[data-peekfield]:not(data-peekfield-ignore)
)
Examples
window.addEventListener('load', function () {
// Run with default options and element selector
peekfield()
// Run with default options but on a specific element
peekfield({}, document.getElementsByClassName('my-field'))
// Run with custom options set (options displayed here are what the defaults are)
peekfield({
applyStyles: true,
closeOnFocusOut: true,
display: null,
onClose: null,
onOpen: null,
options: {},
placeholder: null,
startingTabIndex: 0
})
// Run with custom options set only to a specific field
peekfield({
options: {
name: {
placeholder: 'Please enter your name.'
}
}
})
})
Your best bet would be to check out the source for index.html to get an idea of all the ways peekfield can be used.
Options
These are the options you can set with the options
parameter:
-
applyStyles
(Default:true
) - Set tofalse
to not have thedisplay:none
andvisibility:hidden
styles added/removed on the field and label elements when they are opened/closed. -
closeOnFocusOut
(Default:true
) - Set tofalse
to not have the fields close when they lose focus. -
display
(Default:null
) - The content to display on the label element when a field has had something entered into one of it's child input elements. Functions exactly the same as the label element'sdata-peekfield-display
attribute with the exception that a function can be used here for more control over what is displayed. If a function is used here, it will be passed field object as the first parameter. This option is used as a fallback when the label element does not have adata-peekfield-display
attribute. -
onClose
(Default:null
) - A function to run when a field is closed. Receives the event as the first parameter and the field object as the second. -
onOpen
(Default:null
) - A function to run when a field is opened. Receives the event as the first parameter and the field object as the second. -
opened
(Default:false
) - Set totrue
to have the field be opened when first initiated. -
options
(Default:{}
) - An object with keys set to field element identifiers (thedata-peekfield
attribute) and their values set to an object containing keys and values that you would normally pass to theoptions
parameter. This allows for setting options to specific fields. -
placeholder
(Default:null
) - The content to display on the label element when a field has NOT had something entered into one of it's child input elements. Functions exactly the same as the label element'sdata-peekfield-placeholder
attribute with the exception that a function can be used here for more control over what is displayed. If a function is used here, it will be passed the field object as the first parameter. This option is used as a fallback when the label element does not have adata-peekfield-placeholder
attribute. -
startingTabIndex
(Default:0
) - Atabindex
attribute needs to be set on field and label elements in order for thecloseOnFocusOut
functionality to work correctly. If a field or label element does not have it'stabindex
attribute set, one will be set for each peekfield initiated starting at the index this option is set to unless this option is set tofalse
.
Methods
These methods are attached to the field element when vanishing fields is initiated and can be used to make the field do different things:
-
field.open(triggerEvents)
- Opens the field. Passfalse
as the first parameter to not have theopen
event fired. -
field.close(triggerEvents)
- Closes the field. Passfalse
as the first parameter to not have theclose
event fired. -
field.toggle(open, triggerEvents)
- Opens the field if it is currently closed and closes it if it's currently open. Passtrue
as the first parameter to open it regardless of it's current state andfalse
to close it. Passfalse
as the second parameter to not have theopen
orclose
event fired. -
field.getInputValues()
- Returns an object containing the values of any inputs inside of the field element.
Properties
These properties are attached to the field element when vanishing fields is initiated and changed when different things happen and can be used to see what state a field is in:
-
field.changed
- Istrue
iffield.values
doesn't matchfield.originalValues
, andfalse
if they match. -
field.empty
- Istrue
when the field is considered empty (all child inputs are empty) andfalse
otherwise. -
field.opened
- Istrue
when the field is currently open andfalse
if it is not. -
field.originalValues
- An object containing the values of any input elements inside of the field element as they were when vanishing fields was first initiated. -
field.values
- An object containing the values of any input elements inside of the field element the last time they were fetched (does not change whenfield.getInputValues()
is ran manually). -
field.inputs
- An array of all child input elements.
Events
These events are fired on the field element when different things happen:
-
open
- Fires when the field is opened. -
close
- Fires when the field is closed.
Data Attributes
Attributes can be set on fields to set different options.
The "field" element
This is the element that contains the inputs and any other content you would like to be able to open and close. It is visible when a field is considered open.
-
data-peekfield
(Required) - This is the identifier for the field and needs to be set. -
data-peekfield-apply-styles
- Set tofalse
to not have thedisplay:none
andvisibility:hidden
styles added/removed on the field and label elements when they are opened/closed. (Overrides theapplyStyles
option) -
data-peekfield-close-on-focus-out
- Set this tofalse
to not close the field when it loses focus. (Overrides thecloseOnFocusOut
option) -
data-peekfield-ignore
- Add this to a field element to have it not be initiated by the defaultfields
parameter passed to thepeekfield
function. This is useful if you would like to initiate this field separate from the rest.
The "label" element
This is the element that contains the content that is visible when a field is considered closed. By default, this element should be left empty as it will have it's content filled out for you depending on options and input values set. This element however is not required.
-
data-peekfield-for
(Required) - If using the label element, this attribute is required and should be set to the field's identifier. -
data-peekfield-display
- The content to display when the field element is considered to be NOT empty. An input's value can be displayed by entering it's name between two curly braces (ie.Your name is: {field_name}
). You can also define default text to display if that specific field is empty after a pipe character (ie.Your name is: {field_name|Bob}
). Furthermore, if the input value is an array (like with checkboxes or multi-select fields), you can define a string or character to separate them with (ie.Your favorite colors are: {colors|None| and }
), otherwise a comma will be used. (Overrides thedisplay
option) -
data-peekfield-placeholder
- The content to display when the field element is considered to be empty. (Overrides theplaceholder
option)
Trigger elements
These attributes can be set on any elements (inside or outside of a field/label element) to have them perform different actions.
-
data-peekfield-open
- Set this to a field's identifier to have that field be opened when this element is clicked. -
data-peekfield-close
- Set this to a field's identifier to have that field be closed when this element is clicked. -
data-peekfield-toggle
- Set this to a field's identifier to have that field's open status be toggled when this element is clicked.
Input elements
-
data-peekfield-ignore
- This attribute can be set on any input elements inside of a field element to be ignored completely (such as hidden fields).
Classes
peekfield does not apply any styling and leaves that up to you (except for the display:none
and visibility:hidden
styles if the applyStyles
option isn't set to false
), however these classes are applied to both the field and input elements when different things happen.
-
open
- Added when a field is considered open, otherwise removed. You can also add this class to the field element to have the field be opened when first initiated. -
empty
- Added when a field is considered empty, otherwise removed. -
changed
- Added when a field's child input values have changed since peekfield has been initiated, otherwise removed.
Related
-
minitaur - The ultimate, dependency-free, easy to use, JavaScript plugin for creating and managing modals.
-
filebokz - A tiny, dependency-free, highly customizable and configurable, easy to use file input with some pretty sweet features.
-
hashjump - A tiny, dependency-free JavaScript module for handling anchor links and scrolling elements into view.
-
colorfield - A tiny, dependency-free, color input field helper that utilizes the native color picker.
License
MIT. See the license file for more info.