I would like to create dependent dropdowns in Aurelia.
What I mean by the dependent drop-down list is if you click an item in the first drop-down list, then the options in the second drop-down list will be filtered out depending on what you click. If you look at my js-violin, you will notice that if you select Toyota in the first drop-down list, the second will be filled with Toyota car models (Corolla, Camry, etc.). If you select Honda in the first drop-down menu, the second fills itself with Honda models (Accord, Civic, etc.). You get the idea.
It is very simple and requires very little code for this in Angular, and I was wondering if this makes this in Aurelia also simple and straightforward. I could not find much information on how to do this in Aurelia. The violin below demonstrates exactly what I would like to accomplish (except that I would like to do this in Aurelia, not Angular, of course). Any help is appreciated. Thank!
https://jsfiddle.net/nhunt3/wjvvjwzx/
HTML:
<div ng-app="myApp" ng-controller="myController">
My Cars
<br />
<table>
<thead>
<tr>
<td>Make</td>
<td>Model</td>
</tr>
</thead>
<tbody>
<tr ng-repeat="car in myCars track by car.uid">
<td>
<select ng-model="car.MakeUID" ng-options="make.uid as make.name for make in makes" />
</td>
<td>
<select
ng-model="car.ModelUID"
ng-options="model.uid as model.name for model in models | filter: { parentID: car.MakeUID } : true" />
</td>
</tr>
</tbody>
</table>
</div>
JavaScript:
var myApp = angular.module("myApp", []);
angular.module('myApp', []).controller('myController', function($scope) {
$scope.makes = [
{name:'Toyota', uid:1},
{name:'Honda', uid:2},
{name:'Ford', uid:3}
];
$scope.models = [
{name:'Yaris', uid:1, parentID:1},
{name:'Corolla', uid:2, parentID:1},
{name:'Camry', uid:3, parentID:1},
{name:'Highlander', uid:4, parentID:1},
{name:'Accord', uid:5, parentID:2},
{name:'Civic', uid:6, parentID:2},
{name:'Pilot', uid:7, parentID:2},
{name:'Focus', uid:8, parentID:3},
{name:'Fiesta', uid:9, parentID:3},
{name:'Fusion', uid:10, parentID:3},
{name:'F-150', uid:10, parentID:3}
];
$scope.myCars = [
{uid:1, MakeUID:1, ModelUID:2},
{uid:2, MakeUID:1, ModelUID:3},
{uid:3, MakeUID:3, ModelUID:8}
];
});