Huge News!Announcing our $40M Series B led by Abstract Ventures.Learn More
Socket
Sign inDemoInstall
Socket

@material/select

Package Overview
Dependencies
Maintainers
13
Versions
1696
Alerts
File Explorer

Advanced tools

Socket logo

Install Socket

Detect and block malicious and high-risk dependencies

Install

@material/select

The Material Components web select (text field drop-down) component

  • 0.40.1
  • Source
  • npm
  • Socket score

Version published
Weekly downloads
581K
decreased by-14.35%
Maintainers
13
Weekly downloads
 
Created
Source

Important - Default Style Deprecation Notice

The existing default select style will be changed in an upcoming release. The Material spec indicates that the default style will be the filled variant (currently referred to as the box variant). This will become the default style. Continuing to add the mdc-select--box class to the select will result in no change.

Select Menus

MDC Select provides Material Design single-option select menus. It functions as a wrapper around the browser's native <select> element. It is fully accessible, and fully RTL-aware.

Design & API Documentation

  • Material Design guidelines: Text Fields
  • Demo

Installation

npm install @material/select

Basic Usage

HTML Structure

<div class="mdc-select">
  <select class="mdc-select__native-control">
    <option value="" disabled selected></option>
    <option value="grains">
      Bread, Cereal, Rice, and Pasta
    </option>
    <option value="vegetables">
      Vegetables
    </option>
    <option value="fruit">
      Fruit
    </option>
  </select>
  <label class="mdc-floating-label">Pick a Food Group</label>
  <div class="mdc-line-ripple"></div>
</div>

Styles

@import "@material/select/mdc-select";

JavaScript Instantiation

const select = new mdc.select.MDCSelect(document.querySelector('.mdc-select'));
select.listen('change', () => {
  alert(`Selected option at index ${select.selectedIndex} with value "${select.value}"`);
});

See Importing the JS component for more information on how to import JavaScript.

Variants

Outlined Select

The Select Outlined variant uses the mdc-notched-outline in place of the mdc-line-ripple element and adds the mdc-select--outlined modifier class on the root element.

<div class="mdc-select mdc-select--outlined">
  <select class="mdc-select__native-control">
   ...
  </select>
  <label class="mdc-floating-label">Pick a Food Group</label>
   <div class="mdc-notched-outline">
     <svg>
       <path class="mdc-notched-outline__path"></path>
     </svg>
   </div>
   <div class="mdc-notched-outline__idle"></div>
</div>

Additional Information

Select with pre-selected option

When dealing with a select component that has a pre-selected value, include the mdc-floating-label--float-above modifier class on the mdc-floating-label element, and add the selected attribute to the selected option. This will ensure that the label moves out of the way of the select's value and prevents a Flash Of Unstyled Content (FOUC).

<div class="mdc-select">
  <select class="mdc-select__native-control">
    <option value="vegetables">
      Vegetables
    </option>
    <option value="fruit">
      Fruit
    </option>
    <option value="dairy" selected>
      Milk, Yogurt, and Cheese
    </option>
  </select>
  <label class="mdc-floating-label mdc-floating-label--float-above">Pick a Food Group</label>
  <div class="mdc-line-ripple"></div>
</div>
Using the floating label as the placeholder

By default, <select> elements will select their first enabled option. In order to initially display a placeholder instead, add an initial <option> element with the disabled and selected attributes set, and with value set to "".

<option value="" disabled selected></option>
Disabled select

Add the mdc-select--disabled class to the mdc-select element, and add the disabled attribute to the <select> element.

<div class="mdc-select mdc-select--disabled">
  <select class="mdc-select__native-control" disabled>
    ...
  </select>
  <label class="mdc-floating-label">Pick a Food Group</label>
  <div class="mdc-line-ripple"></div>
</div>
Disabled options

Since MDC Select uses native <select> and <option> elements, simply add the disabled attribute to individual options to disable them.

<div class="mdc-select">
  <select class="mdc-select__native-control">
    <option value="grains">
      Bread, Cereal, Rice, and Pasta
    </option>
    <option value="vegetables" disabled>
      Vegetables
    </option>
    <option value="fruit">
      Fruit
    </option>
  </select>
  <label class="mdc-floating-label">Pick a Food Group</label>
  <div class="mdc-line-ripple"></div>
</div>

Style Customization

CSS Classes
ClassDescription
mdc-selectMandatory.
mdc-select--disabledOptional. Styles the select as disabled. This class should be applied to the root element when the disabled attribute is applied to the <select> element.
mdc-select--outlinedOptional. Styles the select as outlined select.
mdc-select__native-controlMandatory. The native <select> element.

Sass Mixins

Mixins should be included in the context of a custom class applied to the component's root element, e.g. .my-select.

MixinDescription
mdc-select-ink-color($color)Customizes the color of the selected item displayed in the select.
mdc-select-container-fill-color($color)Customizes the background color of the select.
mdc-select-label-color($color)Customizes the label color of the select in the unfocused state.
mdc-select-focused-label-color($color)Customizes the label color of the select when focused.
mdc-select-bottom-line-color($color)Customizes the color of the default bottom line of the select.
mdc-select-focused-bottom-line-color($color)Customizes the color of the bottom line of the select when focused.
mdc-select-shape-radius($radius, $rtl-reflexive)Sets rounded shape to boxed select variant with given radius size. Set $rtl-reflexive to true to flip radius values in RTL context, defaults to false.
mdc-select-hover-bottom-line-color($color)Customizes the color of the bottom line when the select is hovered.
mdc-select-outline-color($color)Customizes the color of the notched outline.
mdc-select-outline-shape-radius($radius, $rtl-reflexive)Sets the border radius of of the outlined select variant. Set $rtl-reflexive to true to flip radius values in RTL context, defaults to false.
mdc-select-focused-outline-color($color)Customizes the color of the outline of the select when focused.
mdc-select-hover-outline-color($color)Customizes the color of the outline when the select is hovered.

NOTE: To further customize the floating label, please see the floating label documentation.

MDCSelect API

The MDCSelect component API is modeled after a subset of the HTMLSelectElement functionality.

PropertyTypeDescription
valuestringThe value of the currently selected option.
selectedIndexnumberThe index of the currently selected option. Set to -1 if no option is currently selected. Changing this property will update the select element.
disabledbooleanWhether or not the component is disabled. Settings this sets the disabled state on the component.

Events

The MDC Select JS component emits a change event when the selected option changes as the result of a user action.

Usage within Web Frameworks

If you are using a JavaScript framework, such as React or Angular, you can create a Select for your framework. Depending on your needs, you can use the Simple Approach: Wrapping MDC Web Vanilla Components, or the Advanced Approach: Using Foundations and Adapters. Please follow the instructions here.

MDCSelectAdapter

Method SignatureDescription
addClass(className: string) => voidAdds a class to the root element.
removeClass(className: string) => voidRemoves a class from the root element.
hasClass(className: string) => booleanReturns true if the root element has the className in its classList.
activateBottomLine() => voidActivates the bottom line component.
deactivateBottomLine() => voidDeactivates the bottom line component.
getValue() => stringReturns the value selected on the select element.
isRtl() => booleanReturns true if a parent of the root element is in RTL.
hasLabel() => booleanReturns true if the select has a label associated with it.
floatLabel(value: boolean) => voidFloats or defloats label.
getLabelWidth() => numberReturns the offsetWidth of the label element.
hasOutline() => booleanReturns true if the select has the notched outline element.
notchOutline(labelWidth: number, isRtl, boolean) => voidSwitches the notched outline element to its "notched state."
closeOutline() => voidSwitches the notched outline element to its closed state.

MDCSelectFoundation

Method SignatureDescription
notchOutline(openNotch: boolean) => voidOpens/closes the notched outline.
updateDisabledStyle(disabled: boolean) => voidUpdates appearance based on disabled state. This must be called whenever the disabled state changes.
handleFocus() => voidHandles a focus event on the select element.
handleBlur() => voidHandles a blur event on the select element.
handleChange() => voidHandles a change to the select element's value. This must be called both for change events and programmatic changes requested via the component API.

Keywords

FAQs

Package last updated on 08 Oct 2018

Did you know?

Socket

Socket for GitHub automatically highlights issues in each pull request and monitors the health of all your open source dependencies. Discover the contents of your packages and block harmful activity before you install or update your dependencies.

Install

Related posts

SocketSocket SOC 2 Logo

Product

  • Package Alerts
  • Integrations
  • Docs
  • Pricing
  • FAQ
  • Roadmap
  • Changelog

Packages

npm

Stay in touch

Get open source security insights delivered straight into your inbox.


  • Terms
  • Privacy
  • Security

Made with ⚡️ by Socket Inc