JSPM

  • Created
  • Published
  • Downloads 694
  • Score
    100M100P100Q101959F
  • License MIT

A materialize library for mithril.

Package Exports

  • mithril-materialized
  • mithril-materialized/advanced.css
  • mithril-materialized/components.css
  • mithril-materialized/core.css
  • mithril-materialized/esm
  • mithril-materialized/forms.css
  • mithril-materialized/index.css
  • mithril-materialized/index.min.css
  • mithril-materialized/modern
  • mithril-materialized/pickers.css
  • mithril-materialized/sass/components/_badges.scss
  • mithril-materialized/sass/components/_breadcrumb.scss
  • mithril-materialized/sass/components/_buttons.scss
  • mithril-materialized/sass/components/_cards.scss
  • mithril-materialized/sass/components/_carousel.scss
  • mithril-materialized/sass/components/_chips.scss
  • mithril-materialized/sass/components/_collapsible.scss
  • mithril-materialized/sass/components/_color-classes.scss
  • mithril-materialized/sass/components/_color-variables.scss
  • mithril-materialized/sass/components/_datepicker.scss
  • mithril-materialized/sass/components/_dropdown.scss
  • mithril-materialized/sass/components/_file-upload.scss
  • mithril-materialized/sass/components/_global.scss
  • mithril-materialized/sass/components/_grid.scss
  • mithril-materialized/sass/components/_icons-material-design.scss
  • mithril-materialized/sass/components/_materialbox.scss
  • mithril-materialized/sass/components/_modal.scss
  • mithril-materialized/sass/components/_navbar.scss
  • mithril-materialized/sass/components/_normalize.scss
  • mithril-materialized/sass/components/_preloader.scss
  • mithril-materialized/sass/components/_pulse.scss
  • mithril-materialized/sass/components/_sidenav.scss
  • mithril-materialized/sass/components/_slider.scss
  • mithril-materialized/sass/components/_table_of_contents.scss
  • mithril-materialized/sass/components/_tabs.scss
  • mithril-materialized/sass/components/_tapTarget.scss
  • mithril-materialized/sass/components/_theme-switcher.scss
  • mithril-materialized/sass/components/_theme-variables.scss
  • mithril-materialized/sass/components/_timepicker.scss
  • mithril-materialized/sass/components/_toast.scss
  • mithril-materialized/sass/components/_tooltip.scss
  • mithril-materialized/sass/components/_transitions.scss
  • mithril-materialized/sass/components/_typography.scss
  • mithril-materialized/sass/components/_variables.scss
  • mithril-materialized/sass/components/_waves.scss
  • mithril-materialized/sass/components/_wizard.scss
  • mithril-materialized/sass/components/forms/_checkboxes.scss
  • mithril-materialized/sass/components/forms/_file-input.scss
  • mithril-materialized/sass/components/forms/_form-groups.scss
  • mithril-materialized/sass/components/forms/_forms.scss
  • mithril-materialized/sass/components/forms/_input-fields.scss
  • mithril-materialized/sass/components/forms/_radio-buttons.scss
  • mithril-materialized/sass/components/forms/_range.scss
  • mithril-materialized/sass/components/forms/_select.scss
  • mithril-materialized/sass/components/forms/_switches.scss
  • mithril-materialized/sass/materialize.scss
  • mithril-materialized/umd
  • mithril-materialized/utilities.css

Readme

mithril-materialized

A Mithril.js component library inspired by materialize-css design principles, available on npm. This library provides you with ready-to-use Mithril components that follow Material Design guidelines, with no external JavaScript dependencies.

πŸš€ v2.0.0 Beta - Major Release

This is a major breaking release that removes all external JavaScript dependencies, making the library completely self-contained and significantly reducing bundle sizes.

✨ What's New

  • πŸ”₯ Zero External JS Dependencies: No longer requires materialize-css JavaScript or material-icons fonts
  • πŸ“¦ Smaller Bundle Size: Reduced package size by eliminating external dependencies
  • 🎨 Custom SVG Icons: Built-in MaterialIcon component with custom SVG icons (caret, close)
  • ⚑ Better Performance: Direct implementations without jQuery or other heavy dependencies
  • πŸ› οΈ Enhanced Components: Improved DatePicker and TimePicker with custom implementations
  • πŸ“± Modern Architecture: Factory components with proper TypeScript support
  • 🎯 CSS-Only Styling: Uses only CSS for styling - no JavaScript initialization needed

πŸ’₯ Breaking Changes from v1.x

  • Removed dependencies: No longer requires materialize-css or material-icons packages
  • Component updates: DatePicker and TimePicker now have custom implementations
  • Icon changes: Uses custom SVG icons instead of Material Icons font
  • Installation: Simpler installation process with fewer dependencies

πŸ“ˆ Migration from v1.x

Old installation (v1.x):

npm install materialize-css material-icons mithril mithril-materialized

New installation (v2.x):

npm install mithril mithril-materialized

Your CSS imports can remain the same, but you no longer need the materialize-css JavaScript.

Supported Components

  • Buttons
    • Button
    • FlatButton
    • RoundButton
    • SubmitButton
  • Inputs
    • TextInput
    • TextArea
    • AutoComplete
    • UrlInput
    • EmailInput
    • NumberInput
    • ColorInput
    • RangeInput
    • Chips
  • Pickers
    • DatePicker
    • TimePicker
  • Selections
    • Select
    • Options
    • RadioButtons
    • Switch
    • Dropdown
  • Collections
    • Basic, Link and Avatar Collections
    • Collapsible or accordion
  • Others
    • ModalPanel
    • MaterialBox
    • Carousel
    • Pagination
    • Parallax
  • Additional
    • Label
    • HelperText
    • CodeBlock
    • SearchSelect, a searchable select dropdown
    • Icon, a simple wrapper for creating icons using material-icons font
    • MaterialIcon, for creating the close/clear and caret as SVG

πŸ“– Usage Instructions

Quick Start

  1. Install the package:

    npm install mithril mithril-materialized
  2. Import the CSS (optional, for Material Design styling):

    import 'mithril-materialized/index.css';
  3. Use components in your app:

    import m from 'mithril';
    import { TextInput, Button, DatePicker } from 'mithril-materialized';
    
    const MyComponent = () => ({
      view: () => m('.container', [
        m(TextInput, {
          label: 'Your name',
          onchange: (value) => console.log(value)
        }),
        m(Button, { 
          label: 'Submit',
          onclick: () => alert('Hello!')
        }),
        m(DatePicker, {
          label: 'Select date',
          onchange: (date) => console.log(date)
        })
      ])
    });

Integration with Build Tools

Webpack/Vite/Parcel: The library works out-of-the-box with modern bundlers.

CSS Framework Integration: You can use the components with any CSS framework. The included CSS provides Material Design styling, but you can override it with your own styles.

TypeScript: Full TypeScript support with comprehensive type definitions included.

See the live documentation for examples and component APIs.

Build instructions

This repository consists of two packages, combined using lerna: the lib package that is published to npm, as well as an example project which uses this library to display the Mithril components that it contains.

To install the dependencies, you can use npm i, or, alternatively, use pnpm m i (assuming you have installed pnpm as alternative package manager using npm i -g pnpm) to perform a multi-repository install. Next, build everything using npm start and visit the documentation page on http://localhost:1234 in case port 1234 is not occupied already.

🎨 Styling & CSS

CSS Usage

The library includes carefully crafted CSS that provides Material Design styling without external dependencies. You can import the ready-to-use CSS:

import 'mithril-materialized/index.css';

Important: The CSS styling is completely independent of the original materialize-css. This means:

  • βœ… No conflicting styles from materialize-css
  • βœ… Smaller CSS bundle size
  • βœ… Custom optimizations for better performance
  • βœ… No external font dependencies

SASS Usage

For advanced customization, you can use the SASS source files directly:

// Import all SASS components
@import 'mithril-materialized/sass/materialize.scss';

// Or import individual components
@import 'mithril-materialized/sass/components/buttons';
@import 'mithril-materialized/sass/components/forms';
@import 'mithril-materialized/sass/components/grid';

SASS Variables: You can customize colors, spacing, and other design tokens by overriding SASS variables before importing:

// Customize Material Design variables
$primary-color: #2196F3;
$secondary-color: #FF9800;

// Then import the library
@import 'mithril-materialized/sass/materialize.scss';

Custom Styles

The library includes these additional styles for enhanced functionality:

/* For the switch */
.clear,
.clear-10,
.clear-15 {
  clear: both;
  /* overflow: hidden; PrΓ©caution pour IE 7 */
}
.clear-10 {
  margin-bottom: 10px;
}
.clear-15 {
  margin-bottom: 15px;
}

span.mandatory {
  margin-left: 5px;
  color: red;
}

label+.switch {
  margin-top: 1rem;
}

/* For the color input */
input[type='color']:not(.browser-default) {
  margin: 0px 0 8px 0;
  /** Copied from input[type=number] */
  background-color: transparent;
  border: none;
  border-bottom: 1px solid #9e9e9e;
  border-radius: 0;
  outline: none;
  height: 3rem;
  width: 100%;
  font-size: 16px;
  padding: 0;
  -webkit-box-shadow: none;
  box-shadow: none;
  -webkit-box-sizing: content-box;
  box-sizing: content-box;
  -webkit-transition: border 0.3s, -webkit-box-shadow 0.3s;
  transition: border 0.3s, -webkit-box-shadow 0.3s;
  transition: box-shadow 0.3s, border 0.3s;
  transition: box-shadow 0.3s, border 0.3s, -webkit-box-shadow 0.3s;
}

/* For the options' label */
.input-field.options > label {
  top: -2.5rem;
}

/* For the code block */
.codeblock {
  margin: 1.5rem 0 2.5rem 0;
}
.codeblock > div {
  margin-bottom: 1rem;
}
.codeblock > label {
  display: inline-block;
}