Skip to main content

Checkbox

A Checkbox is a user interface control element that allows users to select one or more options from a set of options.

Playground

Live Editor
<ProvenanceCheckbox 
  id="jsx-provenance-checkbox"
  name="jsx-provenance-checkbox"
  data={[
    { label: 'New York', value: 'New York' },
    { label: 'Rome', value: 'Rome' },
    { label: 'London', value: 'London' },
    { label: 'Istanbul', value: 'Istanbul' },
    { label: 'Paris', value: 'Paris' }
  ]}
  selected={['New York', 'Rome']}
  freeze={false}
  visualize={true}
  provenanceChange={console.log} // hardcoded
  selectedChange={console.log} // hardcoded
/>
Result
Loading...
info

The above example uses React JSX and Web Components. See corresponding (static) examples for Angular and Web Components below.

import { Component } from '@angular/core';

@Component({
selector: 'checkbox-root',
templateUrl: './checkbox.component.html',
styleUrls: ['./checkbox.component.css']
})
export class CheckboxComponent {
data = [
{ label: 'New York', value: 'New York' },
{ label: 'Rome', value: 'Rome' },
{ label: 'London', value: 'London' },
{ label: 'Istanbul', value: 'Istanbul' },
{ label: 'Paris', value: 'Paris' }
];
selected = data.map(({ value }) => value).slice(0, 2);
freeze = false;
visualize = true;

provenanceChange(event) {
console.log(event.detail);
}

selectedChange(event) {
console.log(event.detail);
// Mandatory to update the selected property manually, or use two-way binding
selected = event.detail;
}
}

API

info

All widgets extend a third-party library component. See the extends property below for more information about the base component's API.

Extendsp-checkbox
Angular Selectorprovenance-checkbox
Web Component Tagweb-provenance-checkbox

Properties

NameTypeDefaultRequiredDescription
idstring""YesUnique identifier for the element. Used by ProvenanceWidgets for internal state management and visualizations.
dataany[]undefinedYesAn array of objects to display as checkboxes. Each object must have a label and a value property. Alternatively, you can map your properties using label="your_label_property" and value="your_value_property".
selectedstring[][]NoAn array of selected values. Must match the value property of the objects in the data array. Two-way binding is supported.
freezebooleanfalseNoWhether to freeze the provenance. If true, the widget will not record any provenance, and interactions will not create/update any visualizations. NOTE: The widget does not update when the property is changed.
visualizebooleantrueNoWhether to visualize the provenance. NOTE: The widget does not update when the property is changed.
provenanceProvenanceundefinedNoThe provenance of interactions recorded by the widget. Use this property to persist, restore, modify, or reconstruct the provenance of interactions for the widget. To override the provenance, revalidate must be set to true. Two-way binding is supported.

Events

NameEventEmitter<T>Description
selectedChangestring[]Emits the updated selected values when the checkbox selection changes.
provenanceChange<Provenance>Emits the provenance when the checkbox selection changes.