So I have a search box that I enter text into then submit, this should send the data to my Angular controller and allow me to access it however I'm just getting undefined when doing so.
The issue is caused when trying to access the field by using $scope.searchtext
My code is as follows:
angular.module('starter.controllers', [])
.controller('SearchCtrl', function ($scope, $http, $ionicLoading) {
$scope.results = [];
$scope.search = function () {
$ionicLoading.show({ template: 'Loading...' });
$http.get('https://www.googleapis.com/youtube/v3/search?part=snippet&q=' + $scope.searchtext + '&key=').
then(function (data) {
var searchResults = data
angular.forEach(searchResults.data.items, function (val, i) {
$http.get('https://www.googleapis.com/youtube/v3/videos?part=snippet,contentDetails&id=' + val.id.videoId + '&key=').
then(function (data) {
var durationResults = data
var duration = durationResults.data.items[0].contentDetails.duration.replace("PT", "").replace("H", ":").replace("M", ":").replace("S", "")
$scope.results.push({ thumbnail: val.snippet.thumbnails.medium.url, title: val.snippet.title, channel: durationResults.data.items[0].snippet.channelTitle, description: val.snippet.description, duration: duration })
});
});
});
$ionicLoading.hide();
};
})
<ion-view title="Search for Music">
<ion-content scroll="true" class="has-header padding">
<form ng-submit="search()" class="list list-inset">
<label class="item item-input">
<i class="icon ion-search placeholder-icon"></i>
<input type="search" name="searchtext" ng-model="searchtext" placeholder="Search">
</label>
</form>
<ion-list>
<ion-item ui-sref="home" ng-repeat="result in results" class="item item-thumbnail-left">
<img src="{{result.thumbnail}}">
<h2>{{result.title}}</h2>
<strong>{{result.channel}}</strong>
<p>{{result.description}}</p>
<p>Duration: {{result.duration}}</p>
</ion-item>
</ion-list>
</ion-content>
</ion-view>