Skip to content

Release Notes

jokade edited this page Jun 13, 2015 · 10 revisions

Version 0.2.1 (13.06.15)

This release provides some bug fixes and adds some more façade traits for angular services:

  • #53: façade trait for $animate
  • #54: complete façade for $http
  • #57 solved: defining 'restrict' in Directives with 'def' results in runtime error
  • #58: add façade for $httpProvider
  • #59: throw specific exception when angular.js is not loaded
  • #60 solved: body scope Controllers don't work with ngRoute and ui-router
  • #65: add façade for $cookies service (Angular 1.4+)
  • #67: add withCredentials flag to HttpDefaults

This release requires Scala.js 0.6.3+.

sbt settings:

libraryDependencies += "biz.enef" %%% "scalajs-angulate" % "0.2.1"

Version 0.2 (11.05.15)

This release contains many enhancements and changes to both, Angular.js facade traits and angulate-specific extensions. Starting with this release, angulate only supports Scala.js 0.6+.

sbt settings:

libraryDependencies += "biz.enef" %%% "scalajs-angulate" % "0.2"

Major Changes and Enhancements

Base Package

To avoid confusion and simplifiy the API, the base package has been renamed from biz.enef.angular to biz.enef.angulate.

Support for Function Parameter DI

angulate 0.2 has generalized support for dependency injection of function arguments (see #25). When a scala function is passed to a parameter of type AnnotatedFunction it will be translated into an Angular.js inline DI array.

Example:

import biz.enef.angulate._

// façade trait for some Angular module
trait SomeAngularModule extends js.Object {
  // this version of foo() expects a js.Function as its argument;
  // function DI will probably not work due to minification
  def foo(bar: js.Function) : Unit = js.native

  // this version of foo() can be called with a Scala function (literal);
  // the function argument is translated into an Angular inline DI array,
  // so that dependency injection will work with minification
  def foo(bar: AnnotatedFunction) : Unit = js.native
}

val module = angular.module("someAngularModule").asInstanceOf[SomeAngularModule]

// the anonymous function is implicitly converted into an AnnotatedFunction
// which in turn will be translated into
// module.foo(["$location","$routeProvider",($location,$routeProvider) => ...])
module.foo( ($location: Location, $routeProvider: RouteProvider) => {
  /* ... */
})

Remove Support for @ExportToScope

Support for exporting the controller of a directive to the directive's scope via @ExportToScope has been dropped. Please check if Angular2-style components (see next section) are a viable replacement.

Angular2-style Components

angulate 0.2 comes with experimental support for Angular2-style components (see #26). Components are directly tranlsated into an Angular 1.x directive + a corresponding controller.

Example:

@Component(ComponentDef(
  selector = "counter",  // component name (i.e. the HTML tag)
  templateUrl = "counter.html"  // URL of the HTML template to be used for this component
  bind = js.Dictionary(
   "init" -> "@"  // assign the value of the DOM attribute 'init' to the class property with the same name 
  )
))
class Counter {

  var count = 0

  def init = ???  // required to mark 'init' as a property with getter/setter

  // called with the value of the DOM attribute 'init'
  def init_=(s: String) = count = s.toInt

  def inc() = count += 1

  def dec() = count -= 1

}

val module = angulate.createModule("foo")
module.componentOf[Counter]
<!-- counter.html -->
<div>
  {{count}}
  <button ng-click="inc()">+</button>
  <button ng-click="dec()">-</button>
</div>
<!-- index.html -->
<counter init="42"/>

Note: Angular2 defines the template and templateUrl properties in a separate @View annotation.

Other Changes and Enhancements

  • Extend Directive interface (see this commit)
  • Add API for $locationProvider (trait LocationProvider)
  • Replace macros in facade traits with macros defined on rich wrapper classes (#23)

Solved Issues

  • #29: correct handling of directive controllers
  • #37: allow defining required controllers in directives
  • #38: defs without parens not working
  • #44: Location.search should return Location
  • #45: missing import scalajs.js in AnnotatedFunction macro
Clone this wiki locally