Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/merlosy/ngx-material-file-input
File input for Angular Material form-field
https://github.com/merlosy/ngx-material-file-input
angular file input material upload
Last synced: 2 days ago
JSON representation
File input for Angular Material form-field
- Host: GitHub
- URL: https://github.com/merlosy/ngx-material-file-input
- Owner: merlosy
- License: mit
- Created: 2018-04-01T16:23:58.000Z (almost 7 years ago)
- Default Branch: master
- Last Pushed: 2024-12-20T06:01:25.000Z (about 1 month ago)
- Last Synced: 2025-01-10T02:05:32.205Z (9 days ago)
- Topics: angular, file, input, material, upload
- Language: TypeScript
- Homepage: https://merlosy.github.io/ngx-material-file-input
- Size: 10.2 MB
- Stars: 261
- Watchers: 5
- Forks: 67
- Open Issues: 43
-
Metadata Files:
- Readme: README.md
- Funding: .github/FUNDING.yml
- License: LICENSE
Awesome Lists containing this project
- awesome-angular - ngx-material-file-input - File input for Angular Material form-field. (Uncategorized / Uncategorized)
README
[![npm version](https://badge.fury.io/js/ngx-material-file-input.svg)](https://badge.fury.io/js/ngx-material-file-input)
[![Build Status](https://app.travis-ci.com/merlosy/ngx-material-file-input.svg?branch=master)](https://app.travis-ci.com/merlosy/ngx-material-file-input)
[![npm](https://img.shields.io/npm/dt/ngx-material-file-input.svg)](https://www.npmjs.com/package/ngx-material-file-input)
[![](http://img.badgesize.io/https://unpkg.com/ngx-material-file-input@latest/bundles/ngx-material-file-input.umd.min.js?label=full%20size%20as%20min.js&compression=gzip&style=square&color=02adff)](https://www.npmjs.com/package/ngx-material-file-input)
[![Coverage Status](https://coveralls.io/repos/github/merlosy/ngx-material-file-input/badge.svg)](https://coveralls.io/github/merlosy/ngx-material-file-input)
[![Known Vulnerabilities](https://snyk.io/test/github/merlosy/ngx-material-file-input/badge.svg)](https://snyk.io/test/github/merlosy/ngx-material-file-input)# material-file-input
This project provides :
* `ngx-mat-file-input` component, to use inside Angular Material `mat-form-field`
* a `FileValidator` with `maxContentSize`, to limit the file size
* a `ByteFormatPipe` to format the file size in a human-readable formatFor more code samples, have a look at the [DEMO SITE](https://merlosy.github.io/ngx-material-file-input)
## Install
```
npm i ngx-material-file-input
```## API reference
### MaterialFileInputModule
```ts
import { MaterialFileInputModule } from 'ngx-material-file-input';@NgModule({
imports: [
// the module for this lib
MaterialFileInputModule
]
})
```#### NGX_MAT_FILE_INPUT_CONFIG token (optional):
Change the unit of the ByteFormat pipe
```ts
export const config: FileInputConfig = {
sizeUnit: 'Octet'
};// add with module injection
providers: [{ provide: NGX_MAT_FILE_INPUT_CONFIG, useValue: config }];
```### FileInputComponent
selector: ``
implements: [MatFormFieldControl](https://material.angular.io/components/form-field/api#MatFormFieldControl) from Angular Material
**Additionnal properties**
| Name | Description |
| ------------------------------------- | --------------------------------------------------------------------------------------------------------------------------- |
| _@Input()_ valuePlaceholder: `string` | Placeholder for file names, empty by default |
| _@Input()_ multiple: `boolean` | Allows multiple file inputs, `false` by default |
| _@Input()_ autofilled: `boolean` | Whether the input is currently in an autofilled state. If property is not present on the control it is assumed to be false. |
| _@Input()_ accept: `string` | Any value that `accept` attribute can get. [more about "accept"](https://www.w3schools.com/tags/att_input_accept.asp) |
| value: `FileInput` | Form control value |
| empty: `boolean` | Whether the input is empty (no files) or not |
| clear(): `(event?) => void` | Removes all files from the input |### ByteFormatPipe
**Example**
```html
{{ 104857600 | byteFormat }}
```_Output:_ 100 MB
### FileValidator
| Name | Description | Error structure |
| ---------------------------------------------- | ----------------------------------------------- | ----------------------------------------- |
| maxContentSize(value: `number`): `ValidatorFn` | Limit the total file(s) size to the given value | `{ actualSize: number, maxSize: number }` |# About me
[@jereyleg](https://twitter.com/jereyleg)
☆ to show support :)
# Roadmap
* drop event to add files
* _ideas?_# Kudos to
* https://github.com/dherges/ng-packagr
* Jason Aden - Packaging Angular Libraries https://www.youtube.com/watch?v=QfvwQEJVOig