[TIMOB-19410] iOS: ListView not rendered
| GitHub Issue | n/a | 
|---|---|
| Type | Bug | 
| Priority | Critical | 
| Status | Closed | 
| Resolution | Duplicate | 
| Resolution Date | 2015-09-10T23:24:22.000+0000 | 
| Affected Version/s | n/a | 
| Fix Version/s | n/a | 
| Components | iOS | 
| Labels | ListView | 
| Reporter | Claus Stilborg | 
| Assignee | Hans Knöchel | 
| Created | 2015-08-24T09:16:55.000+0000 | 
| Updated | 2017-03-22T21:59:03.000+0000 | 
Description
	When population a ListView, the ListView sometimes seem to not be rendered at all.
This occurs at random and does not throw any errors.
The two attached screenshots show the same screen. When restarting the app it sometimes renders the ListView, and sometimes not.
Here is the Alloy xml of the ListView:
		<ListView id="lvProducts" defaultItemTemplate="template" backgroundColor="#000" onPull="doPull" onItemclick="doItemClick" onPullend="doPullend" pullBackgroundColor="#000">
			<SearchBar backgroundColor="#000" barColor="#000" pullBackgroundColor="#000" />
			<Templates>
				<ItemTemplate name="template" height="80" backgroundColor="#000" selectionStyle="Titanium.UI.iPhone.ListViewCellSelectionStyle.NONE" >
					<View height="Ti.UI.SIZE" width="96%" backgroundColor="#000">
						<View layout="horizontal" left="2" right="2" top="1" bottom="1" backgroundColor="#000" height="Ti.UI.SIZE" width="100%" bindId="rowView">
							<View top="2" bottom="2" width="76%" height="Ti.UI.SIZE" left="2" >
								<Label bindId="productname" height="Ti.UI.SIZE" id="productname" left="0" width="100%" />	
							</View>
							<View width="20%" top="2" right="2">
								<TextField bindId="productcount" width="100%" right="0" maxLength="5" onFocus="doTextFieldFocus" onBlur="doTextFieldBlur" onChange="limitInputToNumbers" keyboardType="Titanium.UI.KEYBOARD_NUMBER_PAD"/>
							</View>
						</View>
					</View>
				</ItemTemplate>
			</Templates>
			<ListSection/>
			<PullView pullBackgroundColor="#000">
				<View height="80" layout="vertical" pullBackgroundColor="#000" backgroundColor="#E83643">
					<Label>Slip for at hente katalog fra serveren</Label>
					<Label id="lblCatalogueDate">Sidst hentet:</Label>
				</View>
			</PullView>
		</ListView>
function updateUI(){
	if(!loading){
		Ti.API.info("UI pass start");
		var dataSet = [];
		_.each(catalogue.get(), function(product){
			dataSet.push({ 
				properties:{
					itemId: product.id,
					template: "template",
					searchableText: product.name,
					accessoryType: "Titanium.UI.LIST_ACCESSORY_TYPE_DETAIL"
				},
	    		        productname: {text: product.name},
	    		        productcount: {productid: product.id}
	                });
		});
		Ti.API.info("UI pass, dataset: " + dataSet.length);
		$.lvProducts.sections[0].setItems(dataSet);
		Ti.API.info("UI pass, complete");
	}else{
		Ti.API.error("UI not updated");
	}   	
}
Attachments
| File | Date | Size | 
|---|---|---|
| IMG_0700.jpg | 2015-08-24T08:44:12.000+0000 | 39244 | 
| IMG_0701.jpg | 2015-08-24T08:44:21.000+0000 | 109734 | 
| index.js | 2015-09-09T00:32:55.000+0000 | 539 | 
| index.xml | 2015-09-09T00:32:55.000+0000 | 1359 | 
I am seeing the same issue with standard databound ListViews as well: Some times they simply do not render anything... And it takes a restart or sometimes multiple restarts of the app to get it to render. Reventing to TableView on select projects, as TableView seems to work fine, but this is hurting my business as I use ListViews all over and now have to go back and rework projects in the pipeline. Anyone else seeing this?
Exactly the same problem as above really critical sometime the listview renders sometime it simply does nothing i am using the map function.
var items = datesModelCollection.map(function(element) { return { "datesTitle": { text: element.get("title") }, properties: { date_id: element.get("date_id"), canEdit: true, editActions: [{ style: (OS_IOS) ? Ti.UI.iOS.ROW_ACTION_STYLE_DESTRUCTIVE : "", title: "Delete" }] }, "template": "dates" }; }); $.calendarTable.sections[0].setItems(items);[~Claus Stilborg] Can you please provide a full project containing your sample code? Thank you!
Hans Knoechel I have shared the bit bucket repo with you, the project is not finished but it is runnable, the problem occurs randomly in the basket controller. It was also present in the cat controller but I have switched that to use TableView which does not have the same problem.
[~Claus Stilborg] I meant a runnable project (just) containing the demo code above. Can provide that? Otherwise I create one on my own.
OK Hans, I can put something together tomorrow. This problem is in every project where I use ListView, from the simplest data bound boilerplate stuff to loading through a custom list.
[~Claus Stilborg] I've created an alloy project containing your xml and js (attached to this ticket). Can you copy/paste the files and confirm that the error still appears? I'm not 100 % sure, if you maybe called the listView population at the wrong place. Thanks!
Hi Both, Just to pitch in here is what i am doing if you can see anything that maybe causing issues.
var goalsCollection = Alloy.Collections.remindersModel; goalsCollection.fetch(); var items = goalsCollection.map(function(element) { return { "label" : { text : element.get("title") }, "frequency" : { text : element.get("frequency") }, properties : { event_id : element.get("event_id"), canEdit : true, editActions : [{ style : (OS_IOS) ? Ti.UI.iOS.ROW_ACTION_STYLE_DESTRUCTIVE : "", title : "Delete" }] } }; }); $.reminderList.sections[0].setItems(items, { animated : "true" });Thx Hans I will test this later today and get back to you
OK @Hans Knoechel , I am testing with a fresh project and the index files you made, so fare it works every time. I will run it multiple times and report the result. And I will implement the onOpen approach in one of the problem projects. If this fixes my problem, beer will most definitely be on me, if we ever meet (*y)
[~samueleast]: Please try not to have collection dependencies in your demo code. [~Claus Stilborg]: Thank you. But I think you will experience the issue there, too. But: Have you used unique itemId's for your cells? That could be the problem. It is still very hard to reproduce and will take a bit.
OK, it still fails :( When I continue to shut down the app on the simulator and restart it, it randomly fails I have a screen grabbed video of it, if you want to see...
Yes, the itemId's are unique, and if that was the problem I would think it should fail every time? Or at least throw an error?
Thats what I thought. If possible in any way, can you provide the sample code in one app.js file so I can test it the latest KitchenSink build.
The sample code is the index files you provided, I just cut and pasted the content into a fresh alloy standard project with no changes at all.
Yeah, but for KitchenSink, we don' test alloy but the "pure" Titanium Code. I will migrate it and update the issue here.
Here is a video of whats happen for me. [Error Video](https://s3.amazonaws.com/Loop.Sam/error.mp4?Signature=4TwOwxGxOE9cArzgTKZVYM%2BmI4U%3D&AWSAccessKeyId=AKIAIDVCDVR32H7DCSNA&Expires=1441836430)
Yup, same for me Samuel
Hey guys, may this be related to TIMOB-19209? We just released the 4.1.1.GA which includes this fix. Please try it out, thanks!
lol, upgrading the CLI broke Studio... This is going to be another long day...
This now seems to have been resolved i will keep checking tho and report back if i see this again. Thanks
YES, it seems to work, I can't provoke it to not render! The CLI upgrade issue was threatening to ruin my day, but updating npm as suggested in this thead and not updating the CLI: https://community.appcelerator.com/topic/3262/unable-to-update-appcelerator-cli-core-v-4-1-3 seems to work. Thanks guys
Please let me know if it resolved the issue after running your test apps a couple of times.
It did, I have done intensive testing today and I have not seen the issue since the update
Perfect! I tested around 20 app starts and did not experience it as well. Closing this issue for now, if it happens again please let us know!
Closing ticket as duplicate and links to the related ticket has been provided above.