<div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">On Wed, Apr 2, 2014 at 2:08 AM, Lucas Holmquist <span dir="ltr">&lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt;</span> wrote:<br>

<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div><div><div class="">

<div>On Apr 1, 2014, at 5:05 PM, Lukáš Fryč &lt;<a href="mailto:lukas.fryc@gmail.com" target="_blank">lukas.fryc@gmail.com</a>&gt; wrote:</div><br><blockquote type="cite"><div dir="ltr"><div>I&#39;m all for using promises that actually make sense,</div>

<div>but have you considered consistency?</div><div><br></div><div>Are you suggesting some modules will return jQuery.Deferred while others will use ES6 promises?</div></div></blockquote><div><br></div></div><div>i re read what i wrote and i think i wrote it very confusingly(?), not sure that is a word,  but i&#39;m going with it</div>

<div><br></div><div>I would like to start with the UnifiedPushClient and remove the jQuery dependency from that.  It would then return an ES6 promise instead, or you can still use callbacks.</div></div></div></blockquote>

<div><br></div><div>Good point, jQuery fans who will start to use ES6 promises won&#39;t receive just few additional parameters, but otherwise they can keep using a then(success, error) syntax.<br></div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">

<div style="word-wrap:break-word"><div><div><br></div><div>i think this might be ok for a next release, 1.5.0, since the api is labeled experimental.</div><div><br></div><div><br></div><div>For datamanager,  2 out of the 4 adapters are labeled experimental, so we would not change the promises return type until 2.0</div>

<div><br></div><div>what i previously wrote sounded like i wanted to change 2 data manager adapters while keeping the other 2 the same.</div></div></div></blockquote><div><br></div><div>Yea, that&#39;s what I heard, thanks for explanation. :-)</div>

<div><br></div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div><div class="">

<div><br></div><div><br></div><br><blockquote type="cite"><div dir="ltr">

<div><br></div><div>I would vote for all or nothing. ;-)</div><div><br></div><div><br></div><div>What about allow a developer to override what promise will be returned?</div><div>We can pass all promises through singleton (that can be overwritten/plugged-in by the developer),</div>



<div>and that will decide what promise to return.</div></div></blockquote><div><br></div></div><div>This could be interesting,  but i would like to keep things simple first</div></div></div></blockquote><div><br></div><div>

+1 for simplicity</div><div><br></div><div><br></div><div>So just to re-iterate, the plan is to keep stable 1.x APIs as they are,</div><div>but in new APIs, leverage promises and offer people a polyfill.<br></div><div><br>

</div><div>In 2.x, we can fully embrace ES6 promises.</div><div> </div><blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">

<div style="word-wrap:break-word"><div><div><div class="h5"><br><blockquote type="cite"><div dir="ltr"><div><br></div><div>In 1.x it can return jQuery.Deferred by default (but can be rewritten to Promise).</div><div>In 2.x it can return Promise (as in ES6) by default (but can be rewritten to jQuery.Deferred).</div>



<div><br></div><div><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Apr 1, 2014 at 3:36 PM, Sebastien Blanc <span dir="ltr">&lt;<a href="mailto:scm.blanc@gmail.com" target="_blank">scm.blanc@gmail.com</a>&gt;</span> wrote:<br>



<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div dir="ltr"><br><div class="gmail_extra"><br><br><div class="gmail_quote">

<div>On Tue, Apr 1, 2014 at 3:17 PM, Lucas Holmquist <span dir="ltr">&lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt;</span> wrote:<br>


<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div>in the canary branch i started looking at removing jQuery from the UnifiedPush client code,  since it only uses jQuery.Ajax.  </div>




<div><br></div><div><a href="https://github.com/aerogear/aerogear-js/tree/canary" target="_blank">https://github.com/aerogear/aerogear-js/tree/canary</a></div></div></blockquote><div><br></div></div><div>That&#39;s really cool and I will probably use this in my experimental FirefoxOS support for the Cordova Push Plugin </div>



<div><div>
<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex"><div style="word-wrap:break-word"><div><br></div><div>i was thinking this would be a 2.0 thing,  but for this particular module/adapter/whatevs, i think we can update it before that since we marked  it &quot;experimental&quot;</div>




<div><br></div><div>in datamanager we have the IndexedDB and WebSQL adapters marked as experimental,  so we could do those, but since the other 2 adapters are not, we should probably wait.</div><div><br></div><div>Just want to see what the team thought about that, before i started to go cray-cray</div>




<div><br></div><div><br></div><div>-Luke</div><div><div><br></div><br><div><div>On Mar 25, 2014, at 8:58 AM, Lucas Holmquist &lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt; wrote:</div>




<br><blockquote type="cite"><div style="word-wrap:break-word"><br><div><div>On Mar 25, 2014, at 8:15 AM, Lukáš Fryč &lt;<a href="mailto:lukas.fryc@gmail.com" target="_blank">lukas.fryc@gmail.com</a>&gt; wrote:</div><br><blockquote type="cite">




<div dir="ltr"><div>Side note: getting integration with jQuery{ajax,promises} right was one of the pain points when integrating with AeroGear.js / Angular (uses q.js, and custom http service).<br></div><div><br></div></div>




</blockquote><div>i know they include their &quot;own&quot; version of jQuery</div><br><blockquote type="cite"><div dir="ltr"><div>

We must be sure whatever we choose is compatible with frameworks out there (at least it should not hard-nut to make it work). In terms of promises implementation. In the end people may even end up using 2-3 promise approaches in one project that makes code pretty disgusting.</div>






<div><br></div><div>So:</div><div><br></div><div>+1 getting rid of jQuery.ajax<br></div><div>+1 getting rid of jQuery promises (they are just wrong anyway ;-)</div><div><br></div><div><br></div><div>Btw in terms of polyfilling, I would suggest:</div>






<div><br></div><div>1) use whatever standard <b>is</b> as long as supported by majority of mainstream browsers</div><div><br></div><div>2) use whatever standard <b>will be </b>and compile polyfill into aerogear.js (as long as it&#39;s not too bloated; not necessary for bower users)</div>




</div></blockquote><blockquote type="cite"><div dir="ltr">

<div><br></div></div></blockquote><div>the polyfill i was thinking about is here <a href="https://github.com/jakearchibald/es6-promise" target="_blank">https://github.com/jakearchibald/es6-promise</a></div><div><br></div>




<div>it is just the spec and 2kb gzipped, which is nice</div><div><br></div><div>and i think this could be an external( compiled in ) dep of the library</div><div><br></div><br><blockquote type="cite"><div dir="ltr"><div>




Wdyt?</div><div><br></div></div><div class="gmail_extra"><br><br><div class="gmail_quote">On Tue, Mar 25, 2014 at 12:26 PM, Karel Piwko <span dir="ltr">&lt;<a href="mailto:kpiwko@redhat.com" target="_blank">kpiwko@redhat.com</a>&gt;</span> wrote:<br>






<blockquote class="gmail_quote" style="margin:0px 0px 0px 0.8ex;border-left-width:1px;border-left-color:rgb(204,204,204);border-left-style:solid;padding-left:1ex">Given number of supported browsers is quite low - <a href="http://caniuse.com/promises" target="_blank">http://caniuse.com/promises</a>, I<br>







believe that polyfill will be needed even with version 2.0.<br>
<br>
On Mon, 24 Mar 2014 12:01:38 -0400<br>
<div>Lucas Holmquist &lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt; wrote:<br>
<br>
&gt;<br>
&gt; On Mar 24, 2014, at 11:55 AM, Sebastien Blanc &lt;<a href="mailto:scm.blanc@gmail.com" target="_blank">scm.blanc@gmail.com</a>&gt; wrote:<br>
&gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; On Mon, Mar 24, 2014 at 4:26 PM, Matthias Wessendorf &lt;<a href="mailto:matzew@apache.org" target="_blank">matzew@apache.org</a>&gt;<br>
&gt; &gt; wrote:<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; On Mon, Mar 24, 2014 at 4:14 PM, Sebastien Blanc &lt;<a href="mailto:scm.blanc@gmail.com" target="_blank">scm.blanc@gmail.com</a>&gt;<br>
&gt; &gt; wrote:<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; On Mon, Mar 24, 2014 at 4:05 PM, Lucas Holmquist &lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt;<br>
&gt; &gt; wrote:<br>
&gt; &gt;<br>
&gt; &gt; On Mar 24, 2014, at 10:10 AM, tolis emmanouilidis &lt;<a href="mailto:tolisemm@gmail.com" target="_blank">tolisemm@gmail.com</a>&gt;<br>
&gt; &gt; wrote:<br>
&gt; &gt;<br>
&gt; &gt;&gt; 2014-03-24 15:39 GMT+02:00 Matthias Wessendorf &lt;<a href="mailto:matzew@apache.org" target="_blank">matzew@apache.org</a>&gt;:<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; On Mon, Mar 24, 2014 at 2:03 PM, Lucas Holmquist &lt;<a href="mailto:lholmqui@redhat.com" target="_blank">lholmqui@redhat.com</a>&gt;<br>
&gt; &gt;&gt; wrote:<br>
&gt; &gt;&gt;&gt; I agree that it would be nice to implement AGJS-70 (Investigate removing<br>
&gt; &gt;&gt;&gt; jQuery requirement). Meanwhile, there is an open source project on GitHub<br>
&gt; &gt;&gt;&gt; that claims to offer a custom builder for jQuery in order to include only<br>
&gt; &gt;&gt;&gt; the modules needed [1] [2]. I haven&#39;t tried it yet but maybe we could<br>
&gt; &gt;&gt;&gt; create a custom jQuery build which includes only the parts currently<br>
&gt; &gt;&gt;&gt; needed in AeroGear. This would mean a smaller size of the jQuery<br>
&gt; &gt;&gt;&gt; dependency.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; The AG lib depends on a few parts of jQuery, the biggest being jQuery.Ajax<br>
&gt; &gt;&gt; and the promise implementation.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; i know we can make custom builds of jQuery pretty easily( building from<br>
&gt; &gt;&gt; source ),  but i don&#39;t really want to bundle it within our lib.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; and i don&#39;t think with bower we can do this easily. although they did just<br>
&gt; &gt;&gt; add a post install hook, so perhaps that could be something to look at.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; Datamanager only uses the promise implementation of jQuery( and some<br>
&gt; &gt;&gt; random thing for the filter method,  which could probably be updated ).<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; Promises are starting to become available natively in browsers and jQuery<br>
&gt; &gt;&gt; doesn&#39;t use the Promise/A+ spec,  so it could be harder to fallback<br>
&gt; &gt;&gt; without a shim of some kind<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; Good to know. Thanks for providing this info.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; sounds reasonable to &#39;wait&#39; on the promise side of things, and use that<br>
&gt; &gt;&gt; bit in the datamanager<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; +1<br>
&gt; &gt;<br>
&gt; &gt; there are other promise implementations that we could use, that are to<br>
&gt; &gt; spec,  such as Q and RSVP,  here is the link to the HTML5 rocks article<br>
&gt; &gt; <a href="http://www.html5rocks.com/en/tutorials/es6/promises/" target="_blank">http://www.html5rocks.com/en/tutorials/es6/promises/</a><br>
&gt; &gt;<br>
&gt; &gt; These last days I have been playing with the library When provided by Cujo,<br>
&gt; &gt; it&#39;s maybe also worth looking <a href="https://github.com/cujojs/when" target="_blank">https://github.com/cujojs/when</a><br>
&gt; &gt;<br>
&gt; &gt; not sure I see value in using a different library as a temporary thing.<br>
&gt; &gt; Once the API is part of the browser platform, the need for [yet another js<br>
&gt; &gt; lib] goes away. I know but I&#39;m more concerned about  &quot;Once the API is part<br>
&gt; &gt; of the browser platform&quot; When will that happen and does it match with our<br>
&gt; &gt; roadmap ? Was also to offer a polyfill for older browser if we want to keep<br>
&gt; &gt; supporting them.<br>
&gt; &gt;<br>
&gt; i will have to update the roadmap.<br>
&gt;<br>
&gt; 2.0 would be a nice time to &quot;fully&quot; switch,  but we can start experimenting<br>
&gt; now and maybe for 1.5 can have some implemenation for data manager only.<br>
&gt;<br>
&gt; Current Chrome has Promise&#39;s enable by default and it looks like FireFox<br>
&gt; 29( next version ) will too.  Safari and IE are in dev i believe<br>
&gt;<br>
&gt; for fallback we can still make use of jQuery i think because of this method<br>
&gt; here  &quot;Promise.cast&quot;,  although the closest lib to the spec is RSVP( maybe<br>
&gt; this could be the 2.0 fallback if we remove jQuery from the whole lib )<br>
&gt;<br>
&gt;<br>
&gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; while i don&#39;t really want to reinvent the wheel in terms of Ajax,  it<br>
&gt; &gt;&gt; might be interesting to take a look.<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; Yeah, IMO worth to look there, for reducing dependencies<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; -M<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;  I think in a previous ML thread about what 2.0 looked like,  that<br>
&gt; &gt;&gt; Pipeline would maybe just be a JSON only thing, with exception for<br>
&gt; &gt;&gt; multipart<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; @Lucas Thanks for making things clear<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; _______________________________________________<br>
&gt; &gt;&gt; aerogear-dev mailing list<br>
&gt; &gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; --<br>
&gt; &gt;&gt; Matthias Wessendorf<br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; blog: <a href="http://matthiaswessendorf.wordpress.com/" target="_blank">http://matthiaswessendorf.wordpress.com/</a><br>
&gt; &gt;&gt; sessions: <a href="http://www.slideshare.net/mwessendorf" target="_blank">http://www.slideshare.net/mwessendorf</a><br>
&gt; &gt;&gt; twitter: <a href="http://twitter.com/mwessendorf" target="_blank">http://twitter.com/mwessendorf</a><br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; _______________________________________________<br>
&gt; &gt;&gt; aerogear-dev mailing list<br>
&gt; &gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;&gt;<br>
&gt; &gt;&gt; _______________________________________________<br>
&gt; &gt;&gt; aerogear-dev mailing list<br>
&gt; &gt;&gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt;&gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; aerogear-dev mailing list<br>
&gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; aerogear-dev mailing list<br>
&gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt;<br>
&gt; &gt; --<br>
&gt; &gt; Matthias Wessendorf<br>
&gt; &gt;<br>
&gt; &gt; blog: <a href="http://matthiaswessendorf.wordpress.com/" target="_blank">http://matthiaswessendorf.wordpress.com/</a><br>
&gt; &gt; sessions: <a href="http://www.slideshare.net/mwessendorf" target="_blank">http://www.slideshare.net/mwessendorf</a><br>
&gt; &gt; twitter: <a href="http://twitter.com/mwessendorf" target="_blank">http://twitter.com/mwessendorf</a><br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; aerogear-dev mailing list<br>
&gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt; &gt;<br>
&gt; &gt; _______________________________________________<br>
&gt; &gt; aerogear-dev mailing list<br>
&gt; &gt; <a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
&gt; &gt; <a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
&gt;<br>
<br>
_______________________________________________<br>
aerogear-dev mailing list<br>
<a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br>
</div></blockquote></div><br></div>
_______________________________________________<br>aerogear-dev mailing list<br><a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br><a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></blockquote>




</div><br></div>_______________________________________________<br>aerogear-dev mailing list<br><a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br><a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></blockquote>




</div><br></div></div><br>_______________________________________________<br>
aerogear-dev mailing list<br>
<a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br></blockquote></div></div></div><br></div></div>
<br>_______________________________________________<br>
aerogear-dev mailing list<br>
<a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br></blockquote></div><br></div>
_______________________________________________<br>aerogear-dev mailing list<br><a href="mailto:aerogear-dev@lists.jboss.org" target="_blank">aerogear-dev@lists.jboss.org</a><br><a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a></blockquote>

</div></div></div><br></div><br>_______________________________________________<br>
aerogear-dev mailing list<br>
<a href="mailto:aerogear-dev@lists.jboss.org">aerogear-dev@lists.jboss.org</a><br>
<a href="https://lists.jboss.org/mailman/listinfo/aerogear-dev" target="_blank">https://lists.jboss.org/mailman/listinfo/aerogear-dev</a><br></blockquote></div><br></div></div>