-
Notifications
You must be signed in to change notification settings - Fork 16
Getting Started
For help getting started with a new Angular app, check out the Angular CLI.
For existing apps, follow these steps to begin using Angular Material.
npm install --save @nationallibraryofnorway/ngx-mime
npm install --save @angular/material
npm install --save @angular/cdk
npm install --save @angular/flex-layout
Mime depend on the Angular animations module in order to be able to do
more advanced transitions. If you want these animations to work in your app, you have to
install the @angular/animations
module and include the BrowserAnimationsModule
in your app.
npm install --save @angular/animations
import { BrowserAnimationsModule } from '@angular/platform-browser/animations';
@NgModule({
...
imports: [BrowserAnimationsModule],
...
})
export class LibraryAppModule { }
If you don't want to add another dependency to your project, you can use the NoopAnimationsModule
.
import { NoopAnimationsModule } from '@angular/platform-browser/animations';
@NgModule({
...
imports: [NoopAnimationsModule],
...
})
export class LibraryAppModule { }
Import the NgModule for the component:
import { MimeModule } from '@nationallibraryofnorway/ngx-mime';
@NgModule({
...
imports: [MimeModule],
...
})
export class LibraryAppModule { }
Be sure to import the Mime module after Angular's
BrowserModule
, as the import order matters for NgModules.
Mime rely on HammerJS for gestures. In order to get the full feature-set of these components, HammerJS must be loaded into the application.
You can add HammerJS to your application via npm, a CDN (such as the Google CDN), or served directly from your app.
To install via npm, use the following command:
npm install --save hammerjs
After installing, import it on your app's root module.
import 'hammerjs';
load the icon font Material Design Icons in your index.html
.
<link href="https://fonts.googleapis.com/icon?family=Material+Icons" rel="stylesheet">
npm install --save openseadragon
Add "../node_modules/openseadragon/build/openseadragon/openseadragon.min.js" to the scripts tag in .angular-cli.json
npm install --save d3
<mime-viewer [manifestUri]="manifestUri" [canvasIndex]="canvasIndex" [q]="q" [config]="config" (pageModeChanged)="onPageModeChanged($event)"></mime-viewer>
Name | Description |
---|---|
@Input() manifestUri: string |
Must be the uri to your manifest file |
@Input() canvasIndex: number |
The initial canvas within the sequence to display |
@Input() q: string |
Content search query string |
@Input() config: MimeViewerConfig |
config |
@Output() pageModeChanged: MimeViewerMode |
Emits when an page mode event is fired |
@Output() pageChanged: number |
Emits when an page change event is fired |
@Output() qChanged: string |
Emits when an content search query change event is fired |
@Output() manifestChanged: MimeManifest |
Emits when an Manifest change event is fired |
MimeViewerConfig
- attributionDialogEnabled: boolean (true)
- attributionDialogHideTimeout: number (-1 meaning no timeout)
- navigationControlEnabled: boolean (true)
- initViewerMode: ViewerMode (ViewerMode.PAGE)
- ajaxWithCredentials: boolean (false) - Whether to set the withCredentials XHR flag for AJAX requests to a IIIF Image Server
- loadTilesWithAjax: boolean (false) - Whether to load tile data using AJAX requests to a IIIF Image Server
- ajaxHeaders: any - A set of headers to include when making AJAX requests to a IIIF Image Server
- crossOriginPolicy: string|boolean - Valid values are 'Anonymous', 'use-credentials', and false
public config = new MimeViewerConfig({
loadTilesWithAjax: true,
ajaxHeaders: {
'Authentication': 'Bearer MY_AUTH_TOKEN'
}
});
<mime-viewer [manifestUri]="manifestUri" [config]="config"></mime-viewer>
The labels can be customized by providing your own instance of MimeViewerIntl. Or use one of the predefined:
- MimeViewerIntlNoNb (Norwegian bokmål)
providers: [ { provide: MimeViewerIntl, useClass: MimeViewerIntlNoNb } ],
If your project is using SystemJS for module loading, you will need to add @nationallibraryofnorway/ngx-mime
to the SystemJS configuration:
System.config({
// existing configuration options
map: {
// ...
'@nationallibraryofnorway/ngx-mime': 'npm:@nationallibraryofnorway/ngx-mime/bundles/ngx-mime.umd.js',
// ...
}
});