UNPKG

ares-ide

Version:

A browser-based code editor and UI designer for Enyo 2 projects

107 lines (105 loc) 3.59 kB
enyo.kind({ name: "enyo.sample.ListHorizontalFlickrSample", classes: "enyo-unselectable enyo-fit list-sample-flickr", components: [ {layoutKind: "FittableRowsLayout", components: [ {kind: "onyx.Toolbar", components: [ {kind: "onyx.InputDecorator", style: "width: 90%;", layoutKind: "FittableColumnsLayout", components: [ {name: "searchInput", fit: true, kind: "onyx.Input", value: "Japan", onchange: "search"}, {kind: "Image", src: "assets/search-input-search.png", style: "width: 20px; height: 20px;"} ]}, {name: "searchSpinner", kind: "Image", src: "assets/spinner.gif", showing: false} ]}, {kind: "List", orient: "h", fit: true, onSetupItem: "setupItem", components: [ {name: "item", style: "padding: 10px;", classes: "list-sample-flickr-item enyo-border-box", ontap: "itemTap", components: [ {name: "thumbnail", kind: "Image", classes: "list-sample-flickr-thumbnail"} ]}, {name: "more", style: "padding: 10px;position:absolute", classes: "list-sample-flickr-more enyo-border-box", components: [ {kind: "onyx.Button", content: "more", ontap: "more"}, {name: "moreSpinner", kind: "Image", src: "assets/spinner.gif", classes: "list-sample-flickr-more-spinner"} ]} ]} ]}, {kind: "enyo.sample.ListHorizontalFlickrSearch", name: "flickrSearch", onResults: "searchResults"} ], rendered: enyo.inherit(function(sup) { return function() { sup.apply(this, arguments); this.search(); }; }), search: function() { this.searchText = this.$.searchInput.getValue(); this.page = 0; this.results = []; this.$.searchSpinner.show(); this.$.flickrSearch.search(this.searchText); }, searchResults: function(inSender, inResults) { this.$.searchSpinner.hide(); this.$.moreSpinner.hide(); this.results = this.results.concat(inResults); this.$.list.setCount(this.results.length); if (this.page === 0) { this.$.list.reset(); } else { this.$.list.refresh(); } return true; }, setupItem: function(inSender, inEvent) { var i = inEvent.index; var item = this.results[i]; this.$.item.addRemoveClass("onyx-selected", inSender.isSelected(inEvent.index)); this.$.thumbnail.setSrc(item.thumbnail); this.$.more.canGenerate = !this.results[i+1]; return true; }, more: function() { this.page++; this.$.moreSpinner.show(); this.$.flickrSearch.search(this.searchText, this.page); }, showList: function() { this.setIndex(0); } }); // A simple component to do a Flickr search. enyo.kind({ name: "enyo.sample.ListHorizontalFlickrSearch", kind: "Component", published: { searchText: "" }, events: { onResults: "" }, url: "http://api.flickr.com/services/rest/", pageSize: 200, api_key: "2a21b46e58d207e4888e1ece0cb149a5", search: function(inSearchText, inPage) { this.searchText = inSearchText || this.searchText; var i = (inPage || 0) * this.pageSize; var params = { method: "flickr.photos.search", format: "json", api_key: this.api_key, per_page: this.pageSize, page: i, text: this.searchText }; return new enyo.JsonpRequest({url: this.url, callbackName: "jsoncallback"}) .response(this, "processResponse") .go(params); }, processResponse: function(inSender, inResponse) { var photos = inResponse.photos ? inResponse.photos.photo || [] : []; for (var i=0, p; (p=photos[i]); i++) { var urlprefix = "http://farm" + p.farm + ".static.flickr.com/" + p.server + "/" + p.id + "_" + p.secret; p.thumbnail = urlprefix + "_s.jpg"; p.original = urlprefix + ".jpg"; } this.doResults(photos); return photos; } });