@marcoparrone/appwithtopbar
v1.0.2
Published
App container element with material TopAppBar react component.
Downloads
6
Maintainers
Readme
appwithtopbar
App container element with a material TopAppBar react component.
Installation
npm install @marcoparrone/appwithtopbar
Usage
import AppWithTopBar from '@marcoparrone/appwithtopbar';
Read further for more information.
Creating a container element with material TopAppBar
For creating a container element with a materia Top App Bar, you can use the AppWithTopBar component. It accepts these properties:
- id: and identifier for the element, its default value is zero;
- refprop: a reference created with React.createRef(); it will be an anchor for finding all the contained elements
- lang: the language code (for example: 'en')
- appname: the name of the app (for example: 'Notes')
- icons: an array of objects, every object must cotain the label property which is a string describing the icon, an icon property containing the id of some material icon (see https://material.io/resources/icons/ for more details), and a callback property containing a function which will be activated when the user will click on the icon.
Here is an example:
<AppWithTopBar refprop={this.notesListRef} lang={this.i18n.language} appname={this.i18n.text['text_appname']}
icons={[{label: this.i18n.text['text_add_label'], icon: 'add', callback: () => this.addNote()},
{label: this.i18n.text['text_settings_label'], icon: 'settings', callback: () => open_dialog(this.notesListRef, 'settings')},
{label: this.i18n.text['text_importexport_label'], icon: 'import_export', callback: () => open_dialog(this.notesListRef, 'impexp')},
{label: this.i18n.text['text_help_label'], icon: 'help', callback: () => open_dialog(this.notesListRef, 'help')},
{label: this.i18n.text['text_about_label'], icon: 'info', callback: () => open_dialog(this.notesListRef, 'about')}]} >
...
... other content of the app ...
...
</AppWithTopBar>
It is important to include the material icons in the HTML page. I usually include them directly in the static HTML page:
<!DOCTYPE html>
<html lang="en">
<head>
...
<link rel="stylesheet" href="https://fonts.googleapis.com/icon?family=Material+Icons">
...
</head>
<body>
...
</body>
</html>