I can't seem to get these to work together. I'm using the Aurelia CLI and have done so in a similar manner for other libraries successfully(like select2, spin, moment and numeral). I can't seem to get toastr to work though. Here is what I have so far.
First I ran npm install toastr --save and typings install dt~toastr --global --save
In aurelia.json, in the vendor-bundle.js section, I added a dependency as such:
  "jquery",
  {
    "name": "toastr",
    "path": "../node_modules/toastr/build",
    "main": "toastr.min",
    "resources": [
      "toastr.min.css"
    ],
    "deps": ["jquery"]
  }
UPDATE: Full steps to repro
I have these versions of these tools installed: node (6.3.0), npm (3.10.3), au (0.17.0)
Open a command prompt and type:
au new au-toastr
3 (Custom)
2 (Typescript)
3 (Sass)
1 (configure unit testing)
1 (Visual Studio Code)
1 (create project)
1 (install project dependencies)
cd au-toastr
npm install jquery --save
npm install toastr --save
typings install dt~jquery --global --save
typings install dt~toastr --global --save
Then open aurelia.json in an editor and add
"jquery",
{
"name": "toastr",
"path": "../node_modules/toastr/build",
"main": "toastr.min",
"resources": [
"toastr.min.css"
],
"deps": ["jquery"]
}
to the bottom of dependencies.
Comment out line 1839(declare var $: cssSelectorHelper;) on typings/globals/angular-protractor/index.d.ts due to conflict with jquery's .d.ts file.
Replace app.ts contents with
import * as toastr from 'toastr';
export class App {
  activate() {
    toastr.info('blah');
  }
}
OR
import 'toastr';
export class App {
  activate() {
    toastr.info('blah');
  }
}
Type au run in the command prompt and then open a browser and navigate to the url that the command line says the application is available at(usually http://localhost:9000).
Attempt 1
import 'toastr';
export class ViewModel {
  activate() {
    toastr.info('blah');
  }
}
Error: ReferenceError: toastr is not defined
Attempt 2
import {autoinject} from 'aurelia-framework';
import 'toastr';
@autoinject()
export class ViewModel {
  constructor(private toastr: Toastr) {
  }
  activate() {
    this.toastr.info('blah');
  }
}
Error: TypeError: this.toastr.info is not a function
Attempt 3
import * as toastr from 'toastr';
export class ViewModel {
  activate() {
    toastr.info('blah');
  }
}
Error: TypeError: toastr.info is not a function
Attempt 4
import {autoinject} from 'aurelia-framework';
import * as toastr from 'toastr';
@autoinject()
export class ViewModel {
  constructor(private toastr: Toastr) {
  }
  activate() {
    this.toastr.info('blah');
  }
}
Error: TypeError: this.toastr.info is not a function
All of the above transpile properly when I run au build from the command line. I get no errors.
I'm lost as to what I am missing or what else I can try. Any help would be greatly appreciated!
UPDATE: My guess is that there is either a bug in the aurelia-cli or more likely I'm handling the package incorrectly somehow in regard to the aurelia-cli loading mechanism. When I get the typescript skeleton from their site, which is using jspm as it's module loader, and follow the same steps above, the toastr works just fine.
Any ideas how I can get this to work with the aurelia-cli?
After a lot of time and help from a friend, I was finally able to get this to work.
Only a few changes should be necessary -
aurelia.json needed to be updated to not use the minified version of the toastr library.
{
  //...
  "dependencies": [
  //...
    "jquery",
    {
      "name": "toastr",
      "path": "../node_modules/toastr",
      "main": "toastr",
      "resources": [
        "build/toastr.min.css"
      ],
      "deps": ["jquery"]
    }
  ]
}
The toastr.info('here'); function invocation usually needs to happen in the attached method or after the element is available in the DOM.
To require the HTML in app.html needs to be updated to 
<require from="toastr/build/toastr.min.css"></require>
Hope this helps.
UPDATE Then to use it in your view model, you could do it one of a few ways:
import * as toastr from 'toastr';
export class App {
  attached() {
    toastr.success('here');
  }
}
import { success } from 'toastr';
export class App {
  attached() {
    success('here');
  }
}
If you love us? You can donate to us via Paypal or buy me a coffee so we can maintain and grow! Thank you!
Donate Us With