<?xml version="1.0" encoding="UTF-8"?>
<?xml-stylesheet type="text/xsl" media="screen" href="/~d/styles/rss2full.xsl"?><?xml-stylesheet type="text/css" media="screen" href="http://feeds.feedburner.com/~d/styles/itemcontent.css"?><rss xmlns:content="http://purl.org/rss/1.0/modules/content/" xmlns:wfw="http://wellformedweb.org/CommentAPI/" xmlns:dc="http://purl.org/dc/elements/1.1/" xmlns:atom="http://www.w3.org/2005/Atom" xmlns:sy="http://purl.org/rss/1.0/modules/syndication/" xmlns:slash="http://purl.org/rss/1.0/modules/slash/" xmlns:georss="http://www.georss.org/georss" xmlns:gml="http://www.opengis.net/gml" xmlns:geo="http://www.w3.org/2003/01/geo/wgs84_pos#" version="2.0">

<channel>
	<title>diploD</title>
	
	<link>http://www.diplod.it</link>
	<description>by Davide Del Monte</description>
	<lastBuildDate>Sat, 23 Mar 2013 16:20:16 +0000</lastBuildDate>
	<language>en</language>
	<sy:updatePeriod>hourly</sy:updatePeriod>
	<sy:updateFrequency>1</sy:updateFrequency>
	<generator>http://wordpress.org/?v=3.1.4</generator>
		<atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="self" type="application/rss+xml" href="http://feeds.feedburner.com/diplod" /><feedburner:info xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0" uri="diplod" /><atom10:link xmlns:atom10="http://www.w3.org/2005/Atom" rel="hub" href="http://pubsubhubbub.appspot.com/" /><geo:lat>44.696237</geo:lat><geo:long>10.627899</geo:long><feedburner:emailServiceId xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0">diplod</feedburner:emailServiceId><feedburner:feedburnerHostname xmlns:feedburner="http://rssnamespace.org/feedburner/ext/1.0">http://feedburner.google.com</feedburner:feedburnerHostname><item>
		<title>Sharepoint 2010: external list da database SQL esterno alla prova dei fatti</title>
		<link>http://www.diplod.it/2013/03/23/sharepoint-2010-external-list-da-database-sql-esterno-alla-prova-dei-fatti/</link>
		<comments>http://www.diplod.it/2013/03/23/sharepoint-2010-external-list-da-database-sql-esterno-alla-prova-dei-fatti/#comments</comments>
		<pubDate>Sat, 23 Mar 2013 16:19:11 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Database]]></category>
		<category><![CDATA[Sharepoint]]></category>
		<category><![CDATA[BCS]]></category>
		<category><![CDATA[Businness Connectivity Services]]></category>
		<category><![CDATA[integrazione]]></category>
		<category><![CDATA[sharepoint]]></category>
		<category><![CDATA[Sharepoint 2010]]></category>
		<category><![CDATA[SQL Server]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1279</guid>
		<description><![CDATA[Con i BCS (Businness Connectivity Services) è possibile creare liste di Sharepoint 2010 contenenti elementi che in realtà risiedono su un database SQL esterno a Sharepoint. Vediamo come funzionano, per appuntarsi qualche utile consiglio. Il primo passo per poter far funzionare il meccanismo è la definizione di una Secure Store Target Application, ovvero di un [...]]]></description>
			<content:encoded><![CDATA[<p>Con i BCS (<a title="Sharepoint 2010 BCS" href="http://msdn.microsoft.com/en-us/magazine/ee819133.aspx" target="_blank">Businness Connectivity Services</a>) è possibile creare liste di Sharepoint 2010 contenenti elementi che in realtà risiedono su un database SQL esterno a Sharepoint. Vediamo come funzionano, per appuntarsi qualche utile consiglio.</p>
<p>Il primo passo per poter far funzionare il meccanismo è la definizione di una<em> Secure Store Target Application</em>, ovvero di un elemento che memorizza le credenziali di accesso al sistema esterno, al quale Sharepoint farà riferimento per evitare che vengano chieste all&#8217;utente che in quel momento visualizza i dati. E&#8217; tuttavia possibile evitare questo passo, se si desidera che per l&#8217;accesso al database esterno vengano utilizzate le credenziali dell&#8217;utente connesso anzichè credenziali comuni.<br />
La <em>Secure Store Target Application</em> si crea dalla <em>Central Administration</em>. Navigando nella sezione <em>Application Management</em>, e cliccando su <em>Manage Service Applications</em> sotto a <em>Service Applications</em>. Apparirà una schermata con la lista delle service applications, clicchiamo su <em>Secure Store Service</em>. A questo punto clicchiamo su <em>Generate New Key</em> nel ribbon, si apre una finestra che chiede di impostare una pass phrase, servirà per poter modificare la target application, va quindi appuntata da qualche parte (ma questo appunto è superfluo, no?).</p>
<p>A questo punto si può creare una nuova target application e compilare tutti i campi necessari, come da figura sotto. Come email mettiamo quella di un amministratore di sistema, mentre come <em>Target Application Type</em> in genere si mette <em>Group</em>, perchè in questo modo è possibile associare la target application a un gruppo di utenti.</p>
<p><span id="more-1279"></span></p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage1.png"><img class="alignnone size-large wp-image-1289" title="BCSmanage1" src="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage1-1024x574.png" alt="" width="1024" height="574" /></a></p>
<p>Nel passaggio successivo è possibile quali campi associare alla target application, in genere sono sufficienti username e password: saranno poi valorizzati con le credenziali che dovranno impersonificare l&#8217;utente che si collega al database.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage2.png"><img class="alignnone size-large wp-image-1290" title="BCSmanage2" src="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage2-1024x574.png" alt="" width="1024" height="574" /></a></p>
<p>Ora bisogna specificare per quali utenti sarà disponibile questa target application, e quali sono gli utenti amministratori.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage3.png"><img class="alignnone size-large wp-image-1292" title="BCSmanage3" src="http://www.diplod.it/wp-content/uploads/2011/11/BCSmanage3-1024x334.png" alt="" width="1024" height="334" /></a></p>
<p>Ora che la <em>target application</em> è creata, non resta che settare le credenziali che utilizzerà per gli accessi al database esterno. Selezioniamo la <em>target application</em> dalla lista e premiamo il tasto<em> set credential</em> nel ribbon.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/set-credential.png"><img class="alignnone size-full wp-image-1293" title="set-credential" src="http://www.diplod.it/wp-content/uploads/2011/11/set-credential.png" alt="" width="452" height="202" /></a></p>
<p>Si aprirà una finestra dove inserire username e password, questo utente deve ovviamente avere accesso ai dati sul database esterno al quale vorremo collegare le liste di Sharepoint.</p>
<p>Ora l&#8217;attività si sposta su Sharepoint Designer 2010, per impostare i contenuti esterni e creare le liste che puntano ad essi. La prima cosa da fare è definire un External Content Type: ovvero un contenuto esterno dal quale attingere. Dopo aver aperto un sito, bisogna andare sul menù <em>External Content Type</em> e tramite il comando ribbon crearne uno nuovo.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/external-content-type.png"><img class="alignnone size-full wp-image-1285" title="external content type" src="http://www.diplod.it/wp-content/uploads/2011/11/external-content-type.png" alt="" width="546" height="190" /></a></p>
<p>Diamo un nome al contenuto esterno e clicchiamo sul link per impostare la connessione verso il sistema esterno.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/external-content.png"><img class="alignnone size-full wp-image-1286" title="external content" src="http://www.diplod.it/wp-content/uploads/2011/11/external-content.png" alt="" width="931" height="549" /></a></p>
<p>Ora bisogna cliccare sul tasto <em>Add Connection</em> per aggiungere una connessione.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/add-connection.png"><img class="alignnone size-large wp-image-1297" title="add-connection" src="http://www.diplod.it/wp-content/uploads/2011/11/add-connection-1024x357.png" alt="" width="1024" height="357" /></a></p>
<p>Apparirà una serie di schermate dove compilare i dati per l&#8217;accesso al database esterno.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/external-data-source.png"><img class="alignnone size-full wp-image-1298" title="external-data-source" src="http://www.diplod.it/wp-content/uploads/2011/11/external-data-source.png" alt="" width="312" height="98" /></a></p>
<p>Selezionare come opzione di connessione<em> Connect with Impersonated Custom Identity</em> e mettere il nome della<em> secure store application</em> definita prima sulla <em>Central Administration</em>.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/sql-connection.png"><img class="alignnone size-full wp-image-1299" title="sql-connection" src="http://www.diplod.it/wp-content/uploads/2011/11/sql-connection.png" alt="" width="378" height="256" /></a></p>
<p>Premendo <em>OK </em>il sistema chiederà le credenziali, inserire quelle dell&#8217;utente definito come amministratore della <em>secure store application</em> ai passi precedenti. Una volta validata la connessione, nell&#8217;<em>Operation Designer</em> apparirà tra le connessioni disponibili anche quella appena impostata: si espande l&#8217;albero per trovare la tabella o la vista contenente i dati che dovranno popolare la lista esterna di Sharepoint.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/operation-designer.png"><img class="alignnone size-large wp-image-1302" title="operation-designer" src="http://www.diplod.it/wp-content/uploads/2011/11/operation-designer-1024x539.png" alt="" width="1024" height="539" /></a></p>
<p>Una volta individuata, cliccando col tasto destro sulla tabella o sulla lista, è possibile generare le operazioni che servono (lettura, modifica, cancellazione, ecc..). E&#8217; possibile crearle tutte assieme, cliccando su <em>Create All Operation</em>. Nelle finestre successive dovremo dare un nome alle operazioni, si potranno settare filtri e sarà necessario marcare almeno un campo come <em>identifier </em>(ID di lista).</p>
<p>I filtri sono necessari per limitare il numero di record restituiti: di default è 2000 e a volte questo valore potrebbe non essere sufficiente, causando errore nella visualizzazione della lista tramite il browser sul sito Sharepoint.</p>
<p>Per l&#8217;operazione <em>Read List</em>, conviene settare qualche campo per la visualizzazione nel <em>picker</em>, altrimenti di default saranno visualizzati tutti e lato utente questa cosa risulta scomoda.</p>
<p>andando su <em>List and Libraries</em>, nei ribbon appare il comando <em>Elenco Esterno</em>.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/elenco-esterno.png"><img class="alignnone size-full wp-image-1282" title="elenco-esterno" src="http://www.diplod.it/wp-content/uploads/2011/11/elenco-esterno.png" alt="" width="357" height="144" /></a></p>
<p>Per chi volesse approfondire:</p>
<p><a href="http://blog.concurrency.com/sharepoint/accessing-external-data-using-business-connectivity-services-in-sharepoint-2010/">http://blog.concurrency.com/sharepoint/accessing-external-data-using-business-connectivity-services-in-sharepoint-2010/</a></p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=maUynMHA-pY:0yVdGckQZG8:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=maUynMHA-pY:0yVdGckQZG8:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=maUynMHA-pY:0yVdGckQZG8:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2013/03/23/sharepoint-2010-external-list-da-database-sql-esterno-alla-prova-dei-fatti/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Consumare un web service SAP da applicazione .NET in C# con Visual Studio</title>
		<link>http://www.diplod.it/2012/10/26/consumare-un-web-service-sap-da-applicazione-net-in-c-visual-studio/</link>
		<comments>http://www.diplod.it/2012/10/26/consumare-un-web-service-sap-da-applicazione-net-in-c-visual-studio/#comments</comments>
		<pubDate>Fri, 26 Oct 2012 16:01:16 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[SAP]]></category>
		<category><![CDATA[.net]]></category>
		<category><![CDATA[asp]]></category>
		<category><![CDATA[aspx]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[sap]]></category>
		<category><![CDATA[Visual Studio]]></category>
		<category><![CDATA[web service]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1363</guid>
		<description><![CDATA[Lo scenario è il seguente: dobbiamo pubblicare su una pagina web alcuni dati provenienti da SAP. Il modo migliore per farlo? Creare un function module su SAP che estragga i dati richiesti, pubblicarlo come web service e consumarlo scrivendo qualche riga di codice in Visual Studio.]]></description>
			<content:encoded><![CDATA[<p>Lo <strong>scenario </strong>è il seguente: dobbiamo pubblicare su una pagina web alcuni dati provenienti da <strong>SAP</strong>. Il modo migliore per farlo? Creare un function module su SAP che estragga i dati richiesti, pubblicarlo come <strong>web service</strong> e consumarlo scrivendo qualche riga di codice in Visual Studio.</p>
<p>Lato SAP, dopo aver scritto il nostro <strong>function module</strong> in ABAP (che in questo esempio estrae una tabella di dati tramite alcuni parametri in input e averlo reso disponibile <a title="Pubblicare web service SAP" href="http://www.diplod.it/2012/10/26/pubblicare-un-function-module-sap-come-web-service/">pubblicandolo come web service</a>), per evitare che sia necessario passare le credenziali di accesso durante la chiamata al web service, possiamo pubblicarlo con un utente di default. Per fare ciò: dalla transazione <strong>SICF</strong>, individuare il web service nel ramo <em>sap/bc/srt/rfc/sap/</em>, entrare in modifica e settare l&#8217;utente nella sezione &#8220;Dati di logon anonimi&#8221;.</p>
<p>Avevo già appuntato qualche nota su come <a title="Consumare web service visual studio" href="http://www.diplod.it/2010/12/21/chiamare-e-consumare-un-web-service-da-una-pagina-aspx-con-c/">consumare un web service</a> da una pagina ASPX, tutto quello che sta scritto in quell&#8217;articolo è ovviamente valido, ma questa volta aggiungeremo il servizio al nostro progetto in un modo leggermente diverso. Da <strong>Visual Studio 2010</strong>, cliccando col tasto destro sul nome del progetto e selezionando la voce di menù &#8220;Aggiungi riferimento al servizio..&#8221;</p>
<p><span id="more-1363"></span></p>
<p><a href="http://www.diplod.it/wp-content/uploads/2012/10/addvisualstudio.png"><img class="alignnone size-full wp-image-1365" title="addvisualstudio" src="http://www.diplod.it/wp-content/uploads/2012/10/addvisualstudio.png" alt="" width="622" height="611" /></a></p>
<p>Nella popup che appare inseriremo l&#8217;url del servizio web di SAP e sceglieremo un nome: in questo caso d&#8217;esempio lo chiameremo &#8220;Ws_Factory&#8221;.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2012/10/servizio.png"><img class="alignnone size-full wp-image-1366" title="servizio" src="http://www.diplod.it/wp-content/uploads/2012/10/servizio.png" alt="" width="631" height="510" /></a></p>
<p>A questo punto siamo pronti per sfruttare il web service su una pagina aspx. La pagina avrà un <strong>DataGrid </strong>che servirà per pubblicare la tabella restituita dal web service, in questo datagrid vengono esplicitate solo le colonne da visualizzare, i nomi sono esattamente gli stessi nomi dei campi della tabella su SAP (se avessimo voluto far visualizzare tutta la tabella, bastava non riportare alcuna colonna). Ecco il codice aspx:</p>
<p><code><br />
&lt;%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %&gt;<br />
&lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&gt;<br />
&lt;html xmlns="http://www.w3.org/1999/xhtml"&gt;<br />
&lt;head runat="server"&gt;<br />
&lt;title&gt;Esempio Webservice&lt;/title&gt;<br />
&lt;link href="StyleSheet.css" rel="stylesheet" type="text/css" /&gt;<br />
&lt;/head&gt;<br />
&lt;body&gt;<br />
&lt;form id="form1" runat="server"&gt;<br />
&lt;div id="container"&gt;<br />
&lt;div id="main-container"&gt;<br />
&lt;asp:GridView ID="GridVisual" AutoGenerateColumns="false" runat="server" CellPadding="0" CellSpacing="0"&gt;<br />
&lt;Columns&gt;<br />
&lt;asp:BoundField HeaderText="CdL" DataField="ARBPL"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Materiale" DataField="MATNR"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Squadra" DataField="TEAMTXT" ItemStyle-CssClass="team"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="T Setup" DataField="SETUP_TIME"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="T Lavorato" DataField="WORKED_TIME"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="T Sospensione" DataField="TIMEOUT"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Pz Teorici" DataField="QTY_THEORETICAL"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Pz Reali" DataField="LMNGA"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Pz Scarto" DataField="XMNGA"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Efficienza Prod" DataField="EFFICIENCY"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Pz da Produrre" DataField="QTY_TO_PROD"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="T al Setup Succ" DataField="NEXT_SETUP"&gt;&lt;/asp:BoundField&gt;<br />
&lt;asp:BoundField HeaderText="Stato" DataField="VM_STATUS"&gt;&lt;/asp:BoundField&gt;<br />
&lt;/Columns&gt;<br />
&lt;/asp:GridView&gt;<br />
&lt;/div&gt;<br />
&lt;/div&gt;<br />
&lt;/form&gt;<br />
&lt;/body&gt;<br />
&lt;/html&gt;<br />
</code><br />
Il codice <strong>C#</strong> necessario è riportato sotto, con relativi commenti che spiegano tutti i passaggi:</p>
<p><code><br />
using System;<br />
using System.Collections.Generic;<br />
using System.Linq;<br />
using System.Web;<br />
using System.Web.UI;<br />
using System.Web.UI.WebControls;<br />
using Ws_factory; //riferimento al Web Service di SAP<br />
public partial class _Default : System.Web.UI.Page<br />
{<br />
// Inizializzazione oggetti<br />
Ws_factory.YSVISUAL_MNGT MyVisual = new Ws_factory.YSVISUAL_MNGT();<br />
Ws_factory.ys_ws_factory_vmClient MyClient = new Ws_factory.ys_ws_factory_vmClient();<br />
Ws_factory.YS_FACTORY_VMRequest MyRequest = new Ws_factory.YS_FACTORY_VMRequest();<br />
Ws_factory.YS_FACTORY_VMResponse MyResponse = new Ws_factory.YS_FACTORY_VMResponse();<br />
protected void Page_Load(object sender, EventArgs e)<br />
{<br />
/* YSVISUAL_MNGT[] è la tabella dove vengono restituiti i dati dal web service di SAP<br />
* Inizializzo come vuota */<br />
YSVISUAL_MNGT[] MyVisual = new YSVISUAL_MNGT[] { };<br />
/* Compilo i parametri della richiesta mettendo i filtri che mi interessano */<br />
//MyRequest.CT_YSVISUAL_MNGT = MyVisual;<br />
MyRequest.IV_ARBPL = "";<br />
MyRequest.IV_DTOEE = "";<br />
MyRequest.IV_NEW_RUN = "";<br />
MyRequest.IV_WERKS = "P100";<br />
/* Lancio il metodo via web passando i parametri appena impostati sopra,<br />
* il riferimento della tab da popolare coi risultati è la tabella MyVisual */<br />
MyClient.YS_FACTORY_VM(ref MyVisual, MyRequest.IV_ARBPL, MyRequest.IV_DTOEE, MyRequest.IV_NEW_RUN, MyRequest.IV_WERKS);<br />
MyResponse.CT_YSVISUAL_MNGT = MyVisual;<br />
/* Ora elaboro i dati restituiti per farli visualizzare sulla pagina */<br />
GridVisual.DataSource = MyResponse.CT_YSVISUAL_MNGT;<br />
GridVisual.DataBind();<br />
}<br />
}<br />
</code><br />
Questo è semplicemente il punto di partenza, da qui è ovviamente possibile spingersi oltre e perdere tempo a volontà.. ;)</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=tkEIEprBvxE:uxL73t4VcV8:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=tkEIEprBvxE:uxL73t4VcV8:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=tkEIEprBvxE:uxL73t4VcV8:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2012/10/26/consumare-un-web-service-sap-da-applicazione-net-in-c-visual-studio/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Pubblicare un function module SAP come Web Service</title>
		<link>http://www.diplod.it/2012/10/26/pubblicare-un-function-module-sap-come-web-service/</link>
		<comments>http://www.diplod.it/2012/10/26/pubblicare-un-function-module-sap-come-web-service/#comments</comments>
		<pubDate>Fri, 26 Oct 2012 15:32:59 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[SAP]]></category>
		<category><![CDATA[abap]]></category>
		<category><![CDATA[function module]]></category>
		<category><![CDATA[sap]]></category>
		<category><![CDATA[soa]]></category>
		<category><![CDATA[soap]]></category>
		<category><![CDATA[soap ui]]></category>
		<category><![CDATA[web service]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1368</guid>
		<description><![CDATA[SAP è un mondo, ma ogni tanto questo mondo deve poter essere "visto" e "manipolato" dall'esterno. Senza infinte elucubrazioni sulla SOA (Service Oriented Architecture), venendo subito al sodo: l'obiettivo di questo articolo è fissare i passaggi per pubblicare come web service un funztion module di SAP scritto in ABAP.]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><img class="alignnone size-full wp-image-1371" title="3574742620_6c65635459" src="http://www.diplod.it/wp-content/uploads/2012/10/3574742620_6c65635459.jpg" alt="" width="500" height="322" /><br />
Foto <a href="http://www.flickr.com/photos/walkadog/3574742620/sizes/m/in/photostream/" target="_blank">Credits</a></p>
<p><strong>SAP </strong>è un mondo, ma ogni tanto questo mondo deve poter essere &#8220;visto&#8221; e &#8220;manipolato&#8221; dall&#8217;esterno. Senza infinte elucubrazioni sulla <a title="Service Oriented Architecture" href="http://it.wikipedia.org/wiki/Service-oriented_architecture" target="_blank">SOA</a> (Service Oriented Architecture), venendo subito al sodo: l&#8217;obiettivo di questo articolo è fissare i passaggi per pubblicare come <strong>web service</strong> un <strong>function module</strong> di SAP scritto in ABAP.</p>
<p><span id="more-1368"></span></p>
<p>Dopo aver creato il function module (transazione <strong>SE37</strong>), dovremo avviare il wizard per la pubblicazione (il wizard funziona correttamente con il logon in inglese):</p>
<ul>
<li><strong>Su ECC5.0</strong>:  Menu Utilities &gt; Altre utility &gt; Generare servizio web &gt; Dal function module</li>
<li><strong>Su ECC6.0</strong>:  Tasto destro &gt; Creare Web Service</li>
</ul>
<p>In seguito attivare i servizi sulla transazione <strong>SICF</strong>:</p>
<ul>
<li>/default_host/sap/bc/soap</li>
<li>/default_host/sap/bc/srt</li>
<li>Ogni web service è rappresentato come servizio ICF nel ramo /default_host/sap/bc/srt/rfc/sap/</li>
</ul>
<p>Bisognerà poi recuperare l&#8217;url del web service pubblicato. Le transazioni disponibili dipendono dalla versione del Service Pack:</p>
<ul>
<li><strong>WSADMIN</strong></li>
<li><strong>WSCONFIG</strong></li>
<li><strong>SOAMANAGER</strong></li>
</ul>
<p>I passaggi sono i seguenti:</p>
<ul>
<li>Cercare e selezionare il      web service nel nodo SOAP Application for RFC-Compliant FMs</li>
<li>Menu Web Service &gt;      WSDL</li>
<li>Nella popup selezionare      Document Style</li>
<li>Si apre il browser con il      link e  la definizione del WSDL
<ul>
<li>Non serve la configurazione       del J2EE. Nel caso sia attivata, configurarla da Menu: Passaggio a &gt;       Parametrizzazione Amministrazione (esempio <em>http://dominio.it:50000</em>)</li>
<li>Se non è attivata la       parte J2EE, il WSDL lavora sulla porta dell’ITS (esempio <em>http://dominio.it:8000/sap/bc/srt/rfc/sap/Z_WS_TEST_CUSTOMER_DETAIL?sap-client=600&amp;wsdl=1.1</em> )</li>
</ul>
</li>
<li>Il link per le BAPI      standard è: <em>http://dominio.it:8000/sap/bc/soap/wsdl11?services=BAPI_CUSTOMER_GETDETAIL2&amp;sap-client=600</em></li>
</ul>
<p>Per <strong>testare il web service </strong>si può utilizzare un programma come <a title="SOAP UI" href="http://www.soapui.org/" target="_blank"><strong>SOAP UI</strong></a>. Dopo averlo installato, i passaggi da fare sono i seguenti:</p>
<ul>
<li>Creare nuovo progetto</li>
<li>Nel progetto aggiungere un      WSDL</li>
<li>Indicare il link      recuperato dalla transazione WSADMIN</li>
<li>Inserire username e      password dell’account SAP nel riquadro in basso a sinistra</li>
</ul>
<p>Nella zona di sinistra vanno inseriti i parametri di input, rimuovendo i punti interrogativi. Poi premere il tasto con la freccia verde e nella parte di destra comparirà il risultato restituito dal web service.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2012/10/soapui.png"><img class="alignnone size-large wp-image-1370" title="soapui" src="http://www.diplod.it/wp-content/uploads/2012/10/soapui-1024x550.png" alt="" width="717" height="385" /></a></p>
<p>Non vado oltre anche se il tema meriterebbe molti approfondimenti, riporto queste poche informazioni come promemoria per chiunque si debba cimentare; nel caso qualcuno voglia maggiori informazioni lascio qualche link utile:</p>
<ul>
<li><a href="http://help.sap.com/saphelp_nwpi71/helpdata/en/bb/ddb33d2ae46b3be10000000a114084/frameset.htm">http://help.sap.com/saphelp_nwpi71/helpdata/en/bb/ddb33d2ae46b3be10000000a114084/frameset.htm</a></li>
<li><a href="http://help.sap.com/saphelp_nwpi71/helpdata/en/9b/dad1ae3908ee44a5caf57e10918be9/frameset.htm">http://help.sap.com/saphelp_nwpi71/helpdata/en/9b/dad1ae3908ee44a5caf57e10918be9/frameset.htm</a></li>
<li><a href="http://www.dataxstream.com/2009/09/turn-any-sap-remote-enabled-function-module-into-a-web-service-%E2%80%93-part-1/">http://www.dataxstream.com/2009/09/turn-any-sap-remote-enabled-function-module-into-a-web-service-%E2%80%93-part-1/</a></li>
<li><a href="http://www.dataxstream.com/2009/10/turn-any-sap-remote-enabled-function-module-into-a-web-service-%E2%80%93-part-2/">http://www.dataxstream.com/2009/10/turn-any-sap-remote-enabled-function-module-into-a-web-service-%E2%80%93-part-2/</a></li>
</ul>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=np5gzScgrqU:VJzSSmsdV7Y:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=np5gzScgrqU:VJzSSmsdV7Y:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=np5gzScgrqU:VJzSSmsdV7Y:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2012/10/26/pubblicare-un-function-module-sap-come-web-service/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Gestione dei Custom Post e dei Custom Fields in WordPress</title>
		<link>http://www.diplod.it/2012/10/01/gestione-dei-custom-post-e-dei-custom-fields-in-wordpress/</link>
		<comments>http://www.diplod.it/2012/10/01/gestione-dei-custom-post-e-dei-custom-fields-in-wordpress/#comments</comments>
		<pubDate>Mon, 01 Oct 2012 16:23:48 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Blog]]></category>
		<category><![CDATA[CMS]]></category>
		<category><![CDATA[Design]]></category>
		<category><![CDATA[contenuti]]></category>
		<category><![CDATA[custom fields]]></category>
		<category><![CDATA[custom post types]]></category>
		<category><![CDATA[custom taxonomies]]></category>
		<category><![CDATA[wordpress]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1353</guid>
		<description><![CDATA[Sempre più temi e plugin Wordpress utilizzano custom post types e custom fields. Al di là dell'informatichese, di cosa si tratta? Ecco cosa sono e come usarli per costruire temi dedicati.]]></description>
			<content:encoded><![CDATA[<p>Sempre più temi e plugin WordPress utilizzano <strong>custom post types</strong> e <strong>custom fields</strong>. Al di là dell&#8217;informatichese, di cosa si tratta? Il modo più semplice per spiegarlo è attraverso un esempio. Immagina il sito di una band, con news e quant&#8217;altro.</p>
<p>Immagina che questa band voglia avere una sezione dove presenta i propri dischi, magari un widget sulla sidebar o una pagina dedicata. Servirà quindi un <strong>tipo di post personalizzato</strong>: non sono articoli semplici, non sono pagine. Sono dischi. E a questi dischi verranno associati anche una serie di <strong>campi personalizzati</strong>, come ad esempio l&#8217;anno di produzione, l&#8217;etichetta, i crediti per il missaggio. E poi, perchè no, anche il video di youtube, se questo esiste. Infine, questi dischi possono appartenere a due diverse categorie: album o singoli.</p>
<p>Si tratta insomma di un oggetto a parte, da usare nel pannello di amministrazione di wordpress, che poi apparirà come rappresentato nell&#8217;immagine sotto.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2012/09/dischi-bacheca.png"><img class="alignnone size-large wp-image-1354" title="dischi-bacheca" src="http://www.diplod.it/wp-content/uploads/2012/09/dischi-bacheca-1024x712.png" alt="" width="573" height="399" /></a></p>
<p><span id="more-1353"></span>Per fare ciò, il punto centrale è il famoso file di template <em>functions.php</em>, vediamo quali sono le cose da fare.</p>
<p>Dovremo innanzi tutto dichiarare il nuovo tipo post, dicendo che questo nuovo oggetto sarà &#8220;catalogabile&#8221; con due tassonomie: i <em>tag </em>e le <em>tipologie</em>. I <em>tag </em>sono i conosciuti tag nativi di wordpress che vengono utilizzati anche nei normali post del blog, mentre le <em>tipologie </em>sono una nuova tassonomia custom, che andremo a definire in seguito, e ci servirà per contraddistinguere i singoli dagli album, o comunque per creare una sorta di categorie per i post di tipo <em>disco</em>. Partiamo quindi aggiungendo il codice qui sotto:</p>
<p><code>/*******************************<br />
DISCHI<br />
aggiunge un tipo post custom dal nome "disco"<br />
che avrà un titolo, un contenuto esteso, un riassunto,<br />
il riferimento all'autore e una immagine in evidenza,<br />
oltre ad alcuni attributi custom<br />
********************************/</code></p>
<p><code> </code></p>
<p><code>add_action( 'init', 'register_cpt_disco' );<br />
function register_cpt_disco() {<br />
$labels = array(<br />
'name' =&gt; _x( 'Dischi', 'disco' ),<br />
'singular_name' =&gt; _x( 'Disco', 'disco' ),<br />
'add_new' =&gt; _x( 'Aggiungi Nuovo', 'disco' ),<br />
'add_new_item' =&gt; _x( 'Aggiungi Nuovo Disco', 'disco' ),<br />
'edit_item' =&gt; _x( 'Modifica Disco', 'disco' ),<br />
'new_item' =&gt; _x( 'Nuovo Disco', 'disco' ),<br />
'view_item' =&gt; _x( 'Visualizza Disco', 'disco' ),<br />
'search_items' =&gt; _x( 'Cerca Dischi', 'disco' ),<br />
'not_found' =&gt; _x( 'Nessun disco trovato', 'disco' ),<br />
'not_found_in_trash' =&gt; _x( 'Nessun disco trovato nel cestino', 'disco' ),<br />
'parent_item_colon' =&gt; _x( 'Disco Padre:', 'disco' ),<br />
'menu_name' =&gt; _x( 'Dischi', 'disco' ),<br />
);<br />
$args = array(<br />
'labels' =&gt; $labels,<br />
'hierarchical' =&gt; false,<br />
'description' =&gt; 'Dischi della Band',<br />
//specifico quali proprietà avrà questo nuovo tipo di post<br />
'supports' =&gt; array( 'title', 'editor', 'excerpt', 'author', 'thumbnail', 'custom-fields' ),<br />
'taxonomies' =&gt; array( 'tipologie', 'post_tag' ),<br />
'public' =&gt; true,<br />
'show_ui' =&gt; true,<br />
'show_in_menu' =&gt; true,<br />
'show_in_nav_menus' =&gt; true,<br />
'publicly_queryable' =&gt; true,<br />
'exclude_from_search' =&gt; false,<br />
'has_archive' =&gt; true,<br />
'query_var' =&gt; true,<br />
'can_export' =&gt; true,<br />
'rewrite' =&gt; true,<br />
'capability_type' =&gt; 'post'<br />
);<br />
register_post_type( 'disco', $args );<br />
}<br />
/* aggiungo dei custom fields (year_completed, videoid, labelc,credits) al tipo post "disco"<br />
il primo (year_completed) lo aggiungo come "year_completed-meta"<br />
gli altri (videoid, labelc,credits) li aggiungo come "credits_meta" */<br />
add_action("admin_init", "admin_init");<br />
function admin_init(){<br />
add_meta_box("year_completed-meta", "Year Completed", "year_completed", "disco", "side", "low");<br />
add_meta_box("credits_meta", "Credits", "credits_meta", "disco", "normal", "low");<br />
}<br />
function year_completed(){<br />
global $post;<br />
$custom = get_post_custom($post-&gt;ID);<br />
$year_completed = $custom["year_completed"][0];<br />
?&gt;<br />
&lt;label&gt;Year:&lt;/label&gt;<br />
&lt;input name="year_completed" value="&lt;?php echo $year_completed; ?&gt;" /&gt;<br />
&lt;?php }<br />
function credits_meta() {<br />
global $post;<br />
$custom = get_post_custom($post-&gt;ID);<br />
$videoid = $custom["videoid"][0];<br />
$labelc = $custom["labelc"][0];<br />
$credits = $custom["credits"][0]; ?&gt;<br />
&lt;p&gt;&lt;label&gt;Youtube Video ID:&lt;/label&gt;&lt;br /&gt;<br />
&lt;textarea cols="50" rows="5" name="videoid"&gt;&lt;?php echo $videoid; ?&gt;&lt;/textarea&gt;&lt;/p&gt;<br />
&lt;p&gt;&lt;label&gt;Label credits:&lt;/label&gt;&lt;br /&gt;<br />
&lt;textarea cols="50" rows="5" name="labelc"&gt;&lt;?php echo $labelc; ?&gt;&lt;/textarea&gt;&lt;/p&gt;<br />
&lt;p&gt;&lt;label&gt;Mastering credits:&lt;/label&gt;&lt;br /&gt;<br />
&lt;textarea cols="50" rows="5" name="credits"&gt;&lt;?php echo $credits; ?&gt;&lt;/textarea&gt;&lt;/p&gt;<br />
&lt;?php } ?&gt;<br />
</code><br />
Ora dobbiamo invece definire una nuova tassonomia per questo tipo di post, servirà quindi aggiungere anche il codice sottostante:<br />
<code><br />
add_action( 'init', 'register_taxonomy_tipologie' );<br />
function register_taxonomy_tipologie() {<br />
$labels = array(<br />
'name' =&gt; _x( 'Tipologie', 'tipologie' ),<br />
'singular_name' =&gt; _x( 'Tipologia', 'tipologie' ),<br />
'search_items' =&gt; _x( 'Cerca Tipologie', 'tipologie' ),<br />
'popular_items' =&gt; _x( 'Tipologie Principali', 'tipologie' ),<br />
'all_items' =&gt; _x( 'Tutte le Tipologie', 'tipologie' ),<br />
'parent_item' =&gt; _x( 'Parent Tipologia', 'tipologie' ),<br />
'parent_item_colon' =&gt; _x( 'Parent Tipologia:', 'tipologie' ),<br />
'edit_item' =&gt; _x( 'Modifica Tipologia', 'tipologie' ),<br />
'update_item' =&gt; _x( 'Aggiorna Tipologia', 'tipologie' ),<br />
'add_new_item' =&gt; _x( 'Aggiungi nuova Tipologia', 'tipologie' ),<br />
'new_item_name' =&gt; _x( 'Nuova Tipologia', 'tipologie' ),<br />
'separate_items_with_commas' =&gt; _x( 'Separate tipologie with commas', 'tipologie' ),<br />
'add_or_remove_items' =&gt; _x( 'Add or remove tipologie', 'tipologie' ),<br />
'choose_from_most_used' =&gt; _x( 'Choose from the most used tipologie', 'tipologie' ),<br />
'menu_name' =&gt; _x( 'Tipologie', 'tipologie' ),<br />
);<br />
$args = array(<br />
'labels' =&gt; $labels,<br />
'public' =&gt; true,<br />
'show_in_nav_menus' =&gt; true,<br />
'show_ui' =&gt; true,<br />
'show_tagcloud' =&gt; false,<br />
'hierarchical' =&gt; true,<br />
'rewrite' =&gt; true,<br />
'query_var' =&gt; true<br />
);<br />
register_taxonomy( 'tipologie', array('disco'), $args );<br />
}<br />
// al salvataggio dei post i valori dei custom fields devono essere memorizzati<br />
add_action('save_post', 'save_details');<br />
function save_details(){<br />
global $post;<br />
update_post_meta($post-&gt;ID, "year_completed", $_POST["year_completed"]);<br />
update_post_meta($post-&gt;ID, "videoid", $_POST["videoid"]);<br />
update_post_meta($post-&gt;ID, "labelc", $_POST["labelc"]);<br />
update_post_meta($post-&gt;ID, "credits", $_POST["credits"]);<br />
}<br />
</code><br />
Si può scrivere questo codice a mano, oppure possono venirci in aiuto due comodissimi tool on line (entrambi di <a title="themergency generators" href="http://themergency.com/generators/" target="_blank">themergency</a>):</p>
<ul>
<li><a title="Wordpress Custom Post Types Generator" href="http://themergency.com/generators/wordpress-custom-post-types/" target="_blank">WordPress Custom Post Types Generator</a></li>
<li><a title="Wordpress custom taxonomies generator" href="http://themergency.com/generators/wordpress-custom-taxonomy/" target="_blank">WordPress Custom Taxonomies Generator</a></li>
</ul>
<p>A questo punto non resta che installare il nostro tema e popolare il sito di contenuti custom, che poi potranno essere utilizzati per creare layout specifici. Questo è un argomento che non viene trattato qui, ma giusto per dare un&#8217;imbeccata, basti pensare a come è possibile impostare la funzione <a title="Query Post" href="http://codex.wordpress.org/Function_Reference/query_posts" target="_blank">query_posts()</a> indicando di estrarre dei custom post types:</p>
<p><code><br />
&lt;?php<br />
//prendo gli ultimi 16 dischi nella categoria album<br />
query_posts('showposts=16&amp;post_type="disco"&amp;tipologie="album"');<br />
?&gt;<br />
</code></p>
<p>Per chi volesse approfondire il tema, ecco alcune <strong>utili risorse</strong>:</p>
<ul>
<li><a href="http://net.tutsplus.com/tutorials/wordpress/rock-solid-wordpress-3-0-themes-using-custom-post-types/" target="_blank">http://net.tutsplus.com/tutorials/wordpress/rock-solid-wordpress-3-0-themes-using-custom-post-types/</a></li>
<li><a href="http://wp.tutsplus.com/tutorials/quick-tip-3-tools-for-making-instant-custom-post-types/" target="_blank">http://wp.tutsplus.com/tutorials/quick-tip-3-tools-for-making-instant-custom-post-types/</a></li>
<li><a href="http://justintadlock.com/archives/2010/04/29/custom-post-types-in-wordpress" target="_blank">http://justintadlock.com/archives/2010/04/29/custom-post-types-in-wordpress</a></li>
<li><a href="http://designwoop.com/2012/05/quality-tutorials-for-creating-wordpress-custom-post-types/" target="_blank">http://designwoop.com/2012/05/quality-tutorials-for-creating-wordpress-custom-post-types/</a></li>
<li><a href="http://wptheming.com/2011/11/event-posts-in-wordpress/">http://wptheming.com/2011/11/event-posts-in-wordpress/</a></li>
</ul>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=yTVuaKztwNs:UFqeNlK6BR8:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=yTVuaKztwNs:UFqeNlK6BR8:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=yTVuaKztwNs:UFqeNlK6BR8:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2012/10/01/gestione-dei-custom-post-e-dei-custom-fields-in-wordpress/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Flexslider applicato coi Rio: uno slider jquery davvero flessibile.</title>
		<link>http://www.diplod.it/2012/10/01/flexslider-applicato-coi-rio-uno-slider-jquery-davvero-flessibile/</link>
		<comments>http://www.diplod.it/2012/10/01/flexslider-applicato-coi-rio-uno-slider-jquery-davvero-flessibile/#comments</comments>
		<pubDate>Mon, 01 Oct 2012 14:07:32 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[Design]]></category>
		<category><![CDATA[flexslider]]></category>
		<category><![CDATA[i rio]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[portfolio]]></category>
		<category><![CDATA[rio]]></category>
		<category><![CDATA[slider]]></category>
		<category><![CDATA[slideshow]]></category>
		<category><![CDATA[webdesign]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1359</guid>
		<description><![CDATA[Di slider e slideshow ce ne sono una infinità. Col tempo ne ho provati e utilizzati diversi, ma come flexslider ce ne sono pochi. Credo di aver finalmente trovato ciò che cercavo: flessibile, altamente configurabile ed adattabile, semplice, e soprattutto funzionante anche con dispositivi touch (iphone, ipad, android, ecc..). Si tratta di una creazione di [...]]]></description>
			<content:encoded><![CDATA[<p>Di <strong>slider</strong> e <strong>slideshow </strong>ce ne sono una infinità. Col tempo ne ho provati e <a title="Slideshow wordpress" href="http://www.diplod.it/2009/09/06/wordpress-creare-uno-sliseshow-con-gli-articoli-in-rilievo-stile-magazine/" target="_self">utilizzati </a>diversi, ma come <strong><a title="Flexslider" href="http://www.woothemes.com/flexslider/" target="_blank">flexslider</a> </strong>ce ne sono pochi. Credo di aver finalmente trovato ciò che cercavo: flessibile, altamente configurabile ed adattabile, semplice, e soprattutto funzionante anche con dispositivi <em>touch </em>(iphone, ipad, android, ecc..). Si tratta di una creazione di <a title="Woothemes" href="http://www.woothemes.com" target="_blank">Woothemes</a>, rilasciata gratuitamente e utilizzabile da chiunque. Per vederlo subito all&#8217;opera, nel modo in cui l&#8217;ho impiegato, basta aprire il sito dei <a title="i Rio" href="http://www.rioofficial.it" target="_self">Rio</a> o di <a title="Bluebeet recording studio" href="http://www.bluebeet.it" target="_blank">Bluebeet Studio</a>. Questo per dire che ho aggiornato il portfolio, ogni tanto è bene farlo. ;)</p>
<p>Per capire come utilizzare lo slideshow di immagini si può dare un&#8217;occhiata alle demo sul sito ufficiale, ma credo che il meglio di questo slider sia nelle possibilità di utilizzo con pezzi di codice formattato (con testo e immagini), per poter creare fluide e accattivanti presentazioni di news o quant&#8217;altro.</p>
<p>Andiamo subito al sodo e vediamo come si può utilizzare all&#8217;interno di un tema <strong>wordpress</strong> per presentare articoli o elementi di altro tipo.</p>
<p><span id="more-1359"></span></p>
<p>Ci sono tre cose fondamentali: il <strong>codice javascript</strong>, il <strong>codice html</strong> e il <strong>codice CSS</strong>. Partiamo con javascript; all&#8217;interno del tag &lt;head&gt; dovremo mettere questo pezzo di codice:</p>
<p><code> &lt;script type="text/javascript"&gt;<br />
$(window).load(function() {<br />
$('#flexslider').flexslider({<br />
animation: "slide",<br />
controlsContainer: "#flex-container",<br />
prevText: "Prec",<br />
nextText: "Succ"    });<br />
});<br />
</code></p>
<p>Mentre nel codice <strong>php </strong>che presenta gli articoli, ad esempio nel file <em>home.php</em>, dovremo utilizzare questo:</p>
<p><code><br />
&lt;?php query_posts('showposts=6&amp;cat=3'); //prendo gli ultimi 6 articoli delle top news ?&gt;<br />
&lt;?php if (have_posts()) : ?&gt;<br />
&lt;div&gt;<br />
&lt;div id="flex-container"&gt;<br />
&lt;div id="flexslider"&gt;<br />
&lt;ul&gt;<br />
&lt;?php while (have_posts()) : the_post(); ?&gt;<br />
&lt;li&gt;<br />
&lt;h1&gt;&lt;a href="&lt;?php the_permalink() ?&gt;"&gt;&lt;?php the_title(); ?&gt;&lt;/a&gt;&lt;/h1&gt;<br />
&lt;div&gt;<br />
&lt;?php if ( has_post_thumbnail()) : ?&gt;<br />
&lt;?php the_post_thumbnail('medium', array('class' =&gt; 'img-news')); ?&gt;<br />
&lt;?php endif; ?&gt;<br />
&lt;?php the_excerpt(); ?&gt;<br />
&lt;a href="&lt;?php the_permalink() ?&gt;" title="&lt;?php the_title(); ?&gt;"&gt;Leggi tutto...&lt;/a&gt;<br />
&lt;div&gt;&lt;div data-href="&lt;?php the_permalink() ?&gt;" data-send="false" data-layout="button_count" data-width="150" data-show-faces="false" data-font="lucida grande"&gt;&lt;/div&gt;<br />
&lt;/div&gt;<br />
&lt;/div&gt;<br />
&lt;/li&gt;<br />
&lt;?php endwhile; ?&gt;<br />
&lt;/ul&gt;<br />
&lt;/div&gt;<br />
&lt;/div&gt;<br />
&lt;/div&gt;<br />
&lt;?php endif; ?&gt;<br />
&lt;?php // Reset Query<br />
wp_reset_query(); ?&gt;<br />
</code></p>
<p>Il mestiere di questo pezzo di codice non è altro che recuperare gli ultimi 6 articoli di una determinata categoria (con ID=3), tramite la function <em>query_posts()</em>; per poi presentare ogni articolo con la sua immagine in evidenza e il suo riassunto. Al di là delle classi css attribuite agli elementi, che sono comunque poco rilevanti per il nostro esempio, ciò che mi preme far notare è che tutti questi elementi stanno racchiusi in un elemento di lista <em>&lt;li&gt;</em>, che sarà uno dei 6 slide che ruoteranno.</p>
<p>Veniamo ora al bello: il<strong> foglio di stile</strong>. Di seguito il mio CSS riadattato partendo da quello di default.<br />
<code><br />
/* jQuery FlexSlider v2.0 */<br />
/* Browser Resets */<br />
.flex-container a:active,<br />
.flexslider a:active,<br />
.flex-container a:focus,<br />
.flexslider a:focus  {outline: none;}<br />
.slides,<br />
.flex-control-nav,<br />
.flex-direction-nav {margin: 0; padding: 0; list-style: none;}<br />
/* FlexSlider Necessary Styles<br />
*********************************/<br />
.flexslider {margin: 0; padding: 0;}<br />
.flexslider .slides &gt; li {display: none; -webkit-backface-visibility: hidden;} /* Hide the slides before the JS is loaded. Avoids image jumping */<br />
/*.flexslider .slides img {width: 100%; display: block;} */<br />
.flex-pauseplay span {text-transform: capitalize;}<br />
/* Clearfix for the .slides element */<br />
.slides:after {content: "."; display: block; clear: both; visibility: hidden; line-height: 0; height: 0;}<br />
html[xmlns] .slides {display: block;}<br />
* html .slides {height: 1%;}<br />
/* No JavaScript Fallback */<br />
/* If you are not using another script, such as Modernizr, make sure you<br />
* include js that eliminates this class on page load */<br />
.no-js .slides &gt; li:first-child {display: block;}<br />
/* FlexSlider Default Theme<br />
*********************************/<br />
.flex-container { position: relative;}<br />
.flexslider {margin: 0 0 5px 0; position: relative;}<br />
.flex-viewport {max-height: 2000px; -webkit-transition: all 1s ease; -moz-transition: all 1s ease; transition: all 1s ease;}<br />
.loading .flex-viewport {max-height: 300px;}<br />
.flexslider .slides {zoom: 1;}<br />
.carousel li {margin-right: 5px}<br />
/* Direction Nav */<br />
.flex-direction-nav { display: block; position: absolute; top: 50%; background: transparent; width: 100%;<br />
opacity: 0.2;<br />
transition:opacity 1s;<br />
-moz-transition:opacity 1s; /* Firefox 4 */<br />
-webkit-transition:opacity 1s; /* Safari and Chrome */<br />
-o-transition:opacity 1s; /* Opera */ }<br />
.flex-container .flex-direction-nav:hover { opacity: 1; }<br />
.flex-direction-nav a {width: 30px; height: 30px; margin: -30px 0 0; display: block; background: url(../images/bg_direction_nav.png) no-repeat 0 0; position: absolute; cursor: pointer; text-indent: -9999px; }<br />
.flex-direction-nav .next {background-position: 100% 0; right: 5px;}<br />
.flex-direction-nav .prev {left: 5px;}<br />
/* Control Nav */<br />
.flex-control-nav {width: 100%; position: relative; bottom: 0px; text-align: center;}<br />
.flex-control-nav li {margin: 0 6px; display: inline-block; zoom: 1; *display: inline;}<br />
.flex-control-nav li a {width: 11px; height: 11px; display: block; background: #666; background: rgba(0,0,0,0.5); cursor: pointer; text-indent: -9999px; -webkit-border-radius: 20px; -moz-border-radius: 20px; -o-border-radius: 20px; border-radius: 20px; box-shadow: inset 0 0 3px rgba(0,0,0,0.3);}<br />
.flex-control-nav li a:hover { background: #333; background: rgba(0,0,0,0.7); }<br />
.flex-control-nav li a.active { background: #000; background: rgba(0,0,0,0.9); cursor: default; }<br />
.flex-control-paging li a {width: 11px; height: 11px; display: block; background: #666; background: rgba(0,0,0,0.5); cursor: pointer; text-indent: -9999px; -webkit-border-radius: 20px; -moz-border-radius: 20px; -o-border-radius: 20px; border-radius: 20px; box-shadow: inset 0 0 3px rgba(0,0,0,0.3);}<br />
.flex-control-paging li a:hover { background: #333; background: rgba(0,0,0,0.7); }<br />
.flex-control-paging li a.active { background: #000; background: rgba(0,0,0,0.9); cursor: default; }<br />
.flex-control-thumbs {margin: 5px 0 0; position: static; overflow: hidden;}<br />
.flex-control-thumbs li {width: 25%; float: left; margin: 0;}<br />
.flex-control-thumbs img {width: 100%; display: block; opacity: .7; cursor: pointer;}<br />
.flex-control-thumbs img:hover {opacity: 1;}<br />
.flex-control-thumbs .active {opacity: 1; cursor: default;}<br />
</code></p>
<p>Con un pizzico di CSS3 è possibile fare in modo che le frecce di navigazione appaiano evidenti solo al passaggio del mouse, mentre rimangano in trasparenza mentre scorrono le notizie. Il risultato finale si può <a title="Rio" href="http://www.rioofficial.it/" target="_blank">vedere qui</a>.</p>
<p>Buono slideshow a tutti. ;)</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=ah6YV6-dHD4:4nt1O3H5Ivc:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=ah6YV6-dHD4:4nt1O3H5Ivc:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=ah6YV6-dHD4:4nt1O3H5Ivc:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2012/10/01/flexslider-applicato-coi-rio-uno-slider-jquery-davvero-flessibile/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Alla NASA utilizzano JQuery</title>
		<link>http://www.diplod.it/2012/08/07/alla-nasa-utilizzano-jquery/</link>
		<comments>http://www.diplod.it/2012/08/07/alla-nasa-utilizzano-jquery/#comments</comments>
		<pubDate>Tue, 07 Aug 2012 08:18:19 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[curiosity]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[marte]]></category>
		<category><![CDATA[nasa]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1339</guid>
		<description><![CDATA[Ma qualcuno di voi si è accorto di come hanno realizzato l&#8217;animazione che illustra l&#8217;atterraggio del Curiosity su Marte? Se date una sbirciatina al codice troverete un sacco di &#8220;cose interessanti&#8221;: la prima operazione da fare è muovere la rotellina del mouse, e noterete che attraverso lo scrolling vengono gestite le informazioni che appaiono in [...]]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2012/08/mars.png"><img class="aligncenter size-full wp-image-1341" title="mars" src="http://www.diplod.it/wp-content/uploads/2012/08/mars.png" alt="" width="460" height="250" /></a></p>
<p>Ma qualcuno di voi si è accorto di come hanno realizzato l&#8217;animazione che illustra l&#8217;<a title="How do I land on Mars?" href="http://mars.jpl.nasa.gov/msl/multimedia/interactives/edlcuriosity/index-2.html" target="_blank"><strong>atterraggio del Curiosity su Marte</strong></a>?</p>
<p>Se date una sbirciatina al codice troverete un sacco di &#8220;cose interessanti&#8221;: la prima operazione da fare è muovere la rotellina del mouse, e noterete che attraverso lo scrolling vengono gestite le informazioni che appaiono in alto a destra. La conferma, semmai ce ne fosse bisogno, che si può fare senza flash.</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=TCz-HT_0Qog:SrvA7fXFzcE:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=TCz-HT_0Qog:SrvA7fXFzcE:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TCz-HT_0Qog:SrvA7fXFzcE:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2012/08/07/alla-nasa-utilizzano-jquery/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Impedire la stampa e il copia incolla da pagine wiki su Sharepoint 2010</title>
		<link>http://www.diplod.it/2011/11/22/impedire-la-stampa-e-il-copia-incolla-da-pagine-wiki-su-sharepoint-2010/</link>
		<comments>http://www.diplod.it/2011/11/22/impedire-la-stampa-e-il-copia-incolla-da-pagine-wiki-su-sharepoint-2010/#comments</comments>
		<pubDate>Tue, 22 Nov 2011 11:23:44 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Sharepoint]]></category>
		<category><![CDATA[copia incolla]]></category>
		<category><![CDATA[CSS]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[sharepoint]]></category>
		<category><![CDATA[stampa]]></category>
		<category><![CDATA[wiki]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1307</guid>
		<description><![CDATA[L'esigenza è semplice: deve essere impedito all'utente medio di poter stampare o fare copia incolla da una pagina wiki di Sharepoint 2010.
Come fare? Ovviamente javascript e css. La rete è piena di esempi per disabilitare il cut&#038;paste o evitare la stampa di una porzione di pagina su carta; per il primo obiettivo useremo uno script semplicissimo, per il secondo un foglio di stile associato alla stampa. ]]></description>
			<content:encoded><![CDATA[<p>L&#8217;esigenza è semplice: <strong>deve essere impedito</strong> all&#8217;<em>utente medio</em> di poter <strong>stampare </strong>o fare <strong>copia incolla</strong> da una pagina wiki di <strong>Sharepoint 2010</strong>. La premessa sull&#8217;utente medio è fondamentale, perchè un utente scafato, in grado di leggere il codice e capire come fare lo troveremo sempre.. non è quindi questo il modo per proteggere fino alla morte un contenuto, si tratta semmai di un modo per sensibilizzare l&#8217;utente circa il contenuto confidenziale pubblicato su una pagina web.</p>
<p>Come fare? Ovviamente javascript e css. La rete è piena di esempi per disabilitare il <em>cut&amp;paste</em> o evitare la stampa di una porzione di pagina su carta; per il primo obiettivo useremo uno script semplicissimo, per il secondo un foglio di stile associato alla stampa. Tutto qui:</p>
<p><code>&lt;script language="JavaScript"&gt;<br />
&lt;!--<br />
// Disable selection of content<br />
function disableselect(e){return false}<br />
function reEnable(){return true}<br />
document.onselectstart=new Function ('return false')<br />
if (window.sidebar){document.onmousedown=disableselectdocument.onclick=reEnable}<br />
// --&gt;<br />
&lt;/script&gt;</code></p>
<p><code>&lt;script language="JavaScript"&gt;<br />
&lt;!--<br />
// Disable right mouse click Script<br />
var message="Function Disabled!";<br />
function clickIE4() {if (event.button==2) {alert(message);return false;}}<br />
function clickNS4(e) {if (document.layers||document.getElementById&amp;&amp;!document.all)<br />
{if (e.which==2||e.which==3){alert(message);return false;}}}<br />
if (document.layers) {document.captureEvents(Event.MOUSEDOWN);document.onmousedown=clickNS4;}<br />
else if (document.all&amp;&amp;!document.getElementById) {document.onmousedown=clickIE4;}<br />
document.oncontextmenu=new Function("alert(message);return false")<br />
// --&gt;<br />
&lt;/script&gt; </code></p>
<p><code> &lt;style type="text/css"&gt; @media print { body { display:none } } &lt;/style&gt;</code></p>
<p><span id="more-1307"></span></p>
<p>Con Sharepoint 2010 non è possibile però inserire javascript su una webpart di contenuto, inoltre per raggiungere lo scopo serve mettere alcune righe di codice nel tag <em>&lt;head&gt;</em> della pagina. Dovremo quindi utilizzare <strong>Sharepoint Designer</strong>, dove possiamo entrare nell&#8217;editor della pagina wiki e cliccando su <em>Modalità Avanzata</em> nel ribbon siamo in grado di modificare il codice. Ogni pagina Sharepoint contiene un tag, <em>PlaceHolderAdditionalPageHead</em>, pensato appositamente per aggiungere codice custom nell&#8217;head della pagina.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/11/designer.png"><img class="alignnone size-full wp-image-1309" title="designer" src="http://www.diplod.it/wp-content/uploads/2011/11/designer.png" alt="" width="870" height="546" /></a></p>
<p>Nell&#8217;immagine sopra ecco un esempio pratico:<strong> risultato raggiunto</strong>! :)</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=benmVjCP-UM:jkT7s-vqxZg:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=benmVjCP-UM:jkT7s-vqxZg:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=benmVjCP-UM:jkT7s-vqxZg:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/11/22/impedire-la-stampa-e-il-copia-incolla-da-pagine-wiki-su-sharepoint-2010/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Better Life Index: javascript e statistiche sulle nazioni dell’OCSE</title>
		<link>http://www.diplod.it/2011/10/19/better-life-index-javascript-e-statistiche-sulle-nazioni-dellocse/</link>
		<comments>http://www.diplod.it/2011/10/19/better-life-index-javascript-e-statistiche-sulle-nazioni-dellocse/#comments</comments>
		<pubDate>Wed, 19 Oct 2011 22:26:59 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[Politica]]></category>
		<category><![CDATA[better life index]]></category>
		<category><![CDATA[indice]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[ocse]]></category>
		<category><![CDATA[oecd]]></category>
		<category><![CDATA[statistiche]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1273</guid>
		<description><![CDATA[Condividi il tuo Better Life Index, per scoprire qual è il Paese in cui preferisci vivere.. o semplicemente per confrontare il benessere nei Paesi OCSE.]]></description>
			<content:encoded><![CDATA[<p><iframe src="http://www.oecdbetterlifeindex.org/embed/?weight=23355524314&#038;display=alpha&#038;include=ITA" width="540" height="420" frameborder="0"></iframe></p>
<p>In attesa di tempi migliori per poter tornare a scrivere su queste pagine con più intensità (mi sono segnato davvero un sacco di appunti..), segnalo questo incantevole grafico fatto con sapienza. Si tratta del <strong><a title="better life index" href="http://www.oecdbetterlifeindex.org/#/11111111111" target="_blank">Better Life Index</a></strong>. Descrive l&#8217;indice di desiderabilità di una nazione in base ai propri valori, tenendo conto di una serie di indicatori sociali. Ecco il video di presentazione dell&#8217;iniziativa.</p>
<p><iframe width="560" height="315" src="http://www.youtube.com/embed/n2Zqj6CzDXs" frameborder="0" allowfullscreen></iframe></p>
<p><span id="more-1273"></span></p>
<p>Tutte le informazioni sull&#8217;iniziativa sono disponibili a <a href="http://www.oecdbetterlifeindex.org/about/better-life-initiative/" target="_blank">questa pagina</a>; per farla breve: vengono confrontati i <strong>34 Paesi facenti parte dell&#8217;<a title="OCSE" href="http://it.wikipedia.org/wiki/Organizzazione_per_la_Cooperazione_e_lo_Sviluppo_Economico" target="_blank">OCSE</a></strong>, l&#8217;Organizzazione per la Cooperazione lo Sviluppo Economico. Non è soltanto un mero gioco di <strong>javascript</strong>, da questo sito si possono imparare svariate cose, cliccando sul &#8220;fiore&#8221; della nazione è infatti possibile leggere un report sulle performance in generale e sulle politiche messe in atto nei singoli aspetti del Better Life Index.</p>
<p>Si può <strong>creare il proprio Better Life Index</strong> e condividerlo come ho fatto sopra, sia su un blog che via Facebook o Twitter. <strong>Perchè provare e condividere?</strong> Ogni volta che si crea un indice, entrerà in una banca dati accessibile al pubblico. Nel corso del tempo, questo aiuterà l&#8217;OCSE a costruire un quadro di quello che i cittadini di tutto il mondo considerano come forme di benessere. Buona condivisione..</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=oOXoAGXyALM:Z1pxdCcj9wQ:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=oOXoAGXyALM:Z1pxdCcj9wQ:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=oOXoAGXyALM:Z1pxdCcj9wQ:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/10/19/better-life-index-javascript-e-statistiche-sulle-nazioni-dellocse/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Fotolia: considerazioni post utilizzo</title>
		<link>http://www.diplod.it/2011/09/02/fotolia-considerazioni-post-utilizzo/</link>
		<comments>http://www.diplod.it/2011/09/02/fotolia-considerazioni-post-utilizzo/#comments</comments>
		<pubDate>Fri, 02 Sep 2011 12:18:53 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[e-business]]></category>
		<category><![CDATA[audio]]></category>
		<category><![CDATA[audiomicro]]></category>
		<category><![CDATA[foto]]></category>
		<category><![CDATA[fotolia]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1262</guid>
		<description><![CDATA[Fotolia è un noto servizio online tramite il quale si possono acquistare immagini di qualità a prezzi relativamente bassi e contenuti. Si tratta di materiale Royalty Free, generato da utenti comuni che desiderano vendere qualcosa on line oppure altre volte da agenzie vere e propria che hanno scoperto in questo portale un ottimo canale di [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.diplod.it/wp-content/uploads/2011/09/fotolia.png"><img class="aligncenter size-full wp-image-1265" title="fotolia" src="http://www.diplod.it/wp-content/uploads/2011/09/fotolia.png" alt="" width="500" height="285" /></a></p>
<p><a title="Fotolia" href="http://it.fotolia.com/" target="_blank"><strong>Fotolia</strong></a> è un noto <strong>servizio online</strong> tramite il quale si possono acquistare immagini di qualità a prezzi relativamente bassi e contenuti. Si tratta di materiale <a href="http://it.wikipedia.org/wiki/Royalty-free" target="_blank">Royalty Free</a>, generato da utenti comuni che desiderano vendere qualcosa on line oppure altre volte da agenzie vere e propria che hanno scoperto in questo portale un ottimo canale di vendita.</p>
<p>Presentazioni aziendali, fotografie accattivanti, trame per background, file vettoriali: questo è ciò che si può acquistare per pochi spiccioli sul portale.<br />
Ho avuto modo di utilizzarlo negli scorsi giorni per preparare una presentazione aziendale, basta guardare una <a title="Fotolia - presentazione aziendale" href="http://it.fotolia.com/search?serie=6135219" target="_blank">serie come questa</a> per farsi venir voglia di iscriversi. Si riescono a fare cose piuttosto accattivanti con poco sforzo; quando è necessario figurare bene, quale miglior biglietto da visita della propria presentazione? :)</p>
<p>Il sistema di acquisto può essere a crediti, ovvero si paga una quota per ottenere determinati crediti da utilizzare scaricando files, oppure ad abbonamento, pagando quindi una quota fissa che da diritto a scaricare un certo numero di file al giorno o al mese. Per chi ne fa un utilizzo spot credo che la modalità a crediti sia la più indicata.</p>
<p>Un interessante parente di Fotolia è <a title="AudioMicro" href="http://www.audiomicro.com/" target="_blank"><strong>AudioMicro</strong></a>: stesso concetto ma ribaltato sui file audio, in cui Fotolia ha <a href="http://www.fastmediamagazine.com/blog/2011/02/01/fotolia-invests-750-000-in-audiomicro/" target="_blank">investito un buon gruzzoletto</a>. Se state facendo un montaggio video e avete bisogno di effetti o colonne sonore è il posto giusto.</p>
<p>Ne conoscete altri? Sono ben accetti suggerimenti..</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=w3nZtfINTvA:QgtiLZt1mzs:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=w3nZtfINTvA:QgtiLZt1mzs:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=w3nZtfINTvA:QgtiLZt1mzs:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/09/02/fotolia-considerazioni-post-utilizzo/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Branding di Sharepoint 2010: ABC e qualche appunto.</title>
		<link>http://www.diplod.it/2011/08/09/branding-di-sharepoint-2010-abc-appunti/</link>
		<comments>http://www.diplod.it/2011/08/09/branding-di-sharepoint-2010-abc-appunti/#comments</comments>
		<pubDate>Tue, 09 Aug 2011 14:20:04 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[CMS]]></category>
		<category><![CDATA[Sharepoint]]></category>
		<category><![CDATA[branding]]></category>
		<category><![CDATA[customizzazione]]></category>
		<category><![CDATA[sharepoint]]></category>
		<category><![CDATA[sharepoint designer]]></category>
		<category><![CDATA[sharepoint2010]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1226</guid>
		<description><![CDATA[Sharepoint 2010 è sulla scena da ormai oltre un anno, è tempo di mettere nero su bianco qualche appunto ad imperitura memoria, magari tornerà utile ad altri. L&#8217;obiettivo è una semplice e sbrigativa customizzazione di un portale Sharepoint con colori personalizzati, un minimo di vestizione grafica e la scelta della master page e dell&#8217;icona di rappresentanza. [...]]]></description>
			<content:encoded><![CDATA[<p><a href="http://www.diplod.it/wp-content/uploads/2011/08/style-library.png"></a>Sharepoint 2010 è sulla scena da ormai oltre un anno, è tempo di mettere nero su bianco qualche appunto ad imperitura memoria, magari tornerà utile ad altri. L&#8217;obiettivo è una semplice e sbrigativa customizzazione di un portale Sharepoint con colori personalizzati, un minimo di vestizione grafica e la scelta della<em> master page</em> e dell&#8217;icona di rappresentanza.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/08/look-and-feel.png"><img class="alignleft size-full wp-image-1240" title="look-and-feel" src="http://www.diplod.it/wp-content/uploads/2011/08/look-and-feel.png" alt="" width="267" height="139" /></a></p>
<p>Tutto parte dal menù del sito su cui si intende intervenire: <em>Site Action</em> -&gt; <em>Site Settings</em>. Sotto al gruppo <em>Look and Feel</em> troveremo varie voci, come nell&#8217;immagine a sinistra. Una prima veloce sistemata ai colori si può dare cliccando su <em>Site theme</em>, da qui possiamo impostare la tavolozza cromatica che desideriamo. Va detto, a onor del vero, che se vogliamo salvare un nuovo tema cromatico dovremo <a title="Using power point create a custom theme in sharepoint 2010" href="http://sqlserverpedia.com/blog/sql-server-bloggers/using-powerpoint-2010-to-create-a-custom-theme-for-sharepoint-2010/" target="_blank">utilizzare Power Point</a>, ma l&#8217;idea di lavorare su un sito web attraverso power point mi sconvolge talmente tanto che non l&#8217;ho presa nemmeno in considerazione. Ma volenti o nolenti prima o poi sarà da fare.</p>
<p>Una volta decisi i colori, possiamo cimentarci nella creazione di una master page personalizzata, da utilizzare come base per la nostra web application, a cui associare un foglio di style CSS che conterrà le nostre personalizzazioni ed una eventuale favicon. Per fare ciò è necessario aprire <a title="sharepoint designer 2010" href="http://office.microsoft.com/it-it/sharepoint-designer-help/introduzione-a-sharepoint-designer-2010-HA010370548.aspx" target="_blank">Sharepoint Designer 2010</a> e caricare il sito web, dal menù di sinistra dobbiamo quindi selezionare la voce &#8220;List and Libraries&#8221; e successivamente entrare nella cartella &#8220;Style Library&#8221; (vedi figura sotto).<br />
<span id="more-1226"></span></p>
<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2011/08/Cattura1.png"><img class="size-full wp-image-1325 aligncenter" style="border-style: initial; border-color: initial;" title="Cattura1" src="http://www.diplod.it/wp-content/uploads/2011/08/Cattura1.png" alt="" width="675" height="523" /></a></p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/08/Cattura1.png"></a>In questa cartella andremo a creare una nuova cartella, chiamandola &#8220;mystyle&#8221; dove posizioniamo il CSS e la favicon, oltre a eventuali immagini utili per abbellire tramite CSS il nostro sito web.</p>
<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2011/08/Cattura2.png"><img class="aligncenter size-full wp-image-1327" title="Cattura2" src="http://www.diplod.it/wp-content/uploads/2011/08/Cattura2.png" alt="" width="415" height="181" /></a></p>
<p>A questo punto è il momento di creare la master page. Come prima, da menù, andiamo sulla voce &#8220;Master Pages&#8221; (vedi figura sotto).</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/08/Cattura3.png"><img class="aligncenter size-full wp-image-1328" title="Cattura3" src="http://www.diplod.it/wp-content/uploads/2011/08/Cattura3.png" alt="" width="511" height="407" /></a></p>
<p>Noteremo che ci sono due pagine fondamentali, una dal nome &#8220;default.master&#8221; e l&#8217;altra &#8220;v4.master&#8221;. Le pagine master definiscono una struttura comune per tutte le pagine Web in Microsoft SharePoint Server. Per impostazione predefinita, quando viene richiesta una pagina, la pagina master e la pagina di contenuto sono combinate per produrre una singola pagina. Utilizzando una pagina master, tutte le pagine di contenuti e applicazioni condividono la stessa struttura della pagina e hanno lo stesso look &amp; feel. La pagina <em>default.master</em> è utile per la retro compatibilità con SharePoint 2007, la versione 2010 utilizza la pagina<em> v4.master</em>, famosa per l&#8217;interfaccia a ribbon tipica di Office.</p>
<p>Per completezza, ecco la descrizione delle master page di default dal sito Microsoft:</p>
<table>
<tbody>
<tr>
<th><strong>NAME / DEFAULT FILE NAME</strong></th>
<th><strong>DESCRIPTION</strong></th>
<th><strong>USES ON A SHAREPOINT SITE</strong></th>
</tr>
<tr>
<td>Primary master<br />
page<strong> </strong></p>
<p style="display: inline !important;"><strong>v4.master</strong></p>
</td>
<td>Used for content and administration pages. Provides the interface and layout for SharePoint 2010.</td>
<td>Team Site home page, list and library pages, and site settings page.</td>
</tr>
<tr>
<td>Minimal master page<br />
<strong> </strong></p>
<p style="display: inline !important;"><strong>minimal.master</strong></p>
</td>
<td>Contains minimal SharePoint content, used for full-screen functionality or embedded applications.</td>
<td>The home and search results pages on a Search Center, pages that host Word or Excel web applications.</td>
</tr>
<tr>
<td>Publishing master page<br />
<strong> </strong></p>
<p style="display: inline !important;"><strong>nightandday.master</strong></p>
</td>
<td>Used for pages on a SharePoint Server publishing-enabled site.</td>
<td>The home page, about us, or press release page on a publishing intranet, extranet, or Internet-facing site.</td>
</tr>
<tr>
<td>2007 default master page<br />
<strong> </strong></p>
<p style="display: inline !important;"><strong>default.master</strong></p>
</td>
<td>Used to support legacy SharePoint sites, which haven’t been visually upgraded to SharePoint 2010.</td>
<td>Home page, site pages, and list pages on a SharePoint 2007 site before visual upgrade.</td>
</tr>
</tbody>
</table>
<p>Copiamo quindi la pagina <em>v4.master</em> e nominiamola ad esempio <em>mypage.master</em>. Ora doppio clic sulla pagina appena creata e si presenterà davanti a noi una schermata, al centro c&#8217;è la voce &#8220;edit file&#8221;, clicchiamoci sopra per fare il check-in della pagina e iniziare a modificarla secondo le nostre esigenze. L&#8217;obiettivo è inserire il riferimento a un CSS che utilizzeremo per modificare esclusivamente ciò che ci interessa. Passiamo quindi alla visualizzazione del codice.</p>
<p>All&#8217;interno del tag <em>&lt;head&gt;</em> possiamo inserire i riferimenti al CSS e ad una favicon specifici.</p>
<p><code>&lt;SharePoint:SPShortcutIcon runat="server" IconUrl="/Style Library/mystyle/favicon.ico"/&gt;<br />
&lt;SharePoint:CssRegistration name="/Style Library/mystyle/style.css" After="corev4.css" runat="server"/&gt;</code></p>
<p>Abbiamo messo il riferimento ai file salvati in precedenza nella cartella appositamente creata. A questo punto dobbiamo salvare e impostare la master page appena creata come pagina di default. Per fare ciò, si può cliccare col tasto destro sul nome del file e selezionare la voce &#8220;Imposta come pagina master predefinita&#8221; oppure dal menù Site Action sul browser selezionare la voce &#8220;Master page&#8221; e impostare la pagina custom come quella predefinita (vedi immagine sotto).</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2011/08/custom-master.png"><img class="aligncenter size-full wp-image-1252" title="custom master" src="http://www.diplod.it/wp-content/uploads/2011/08/custom-master.png" alt="" width="887" height="360" /></a></p>
<p>Ora siamo liberi di modificare il CSS come meglio crediamo, nel mio caso ad esempio ho inserito questo codice:</p>
<p><code>body {	background: #fff url(bg_erbetta.png) repeat-x bottom left;}<br />
.s4-title {	background: #fafafa url(header_bg.png) no-repeat bottom right;}<br />
.s4-socialdata-notif, s4-socialdata {<br />
background: #fafafa;<br />
/* Fallback for web browsers that doesn't support RGBa */<br />
background: rgb(250, 250, 250);<br />
/* RGBa with 0.6 opacity */<br />
background: rgba(250, 250, 250, 0.9);<br />
/* For IE 5.5 - 7*/<br />
filter:progid:DXImageTransform.Microsoft.gradient(startColorstr=#99fafafa, endColorstr=#99fafafa);<br />
/* For IE 8*/<br />
-ms-filter: "progid:DXImageTransform.Microsoft.gradient(startColorstr=#99fafafa, endColorstr=#99fafafa)"; }<br />
.s4-ca { background: transparent;}</code></p>
<p>Ovviamente le possibilità di personalizzazione della master page sono tante altre, si possono spostare gli elementi o inserire pezzi di codice specifici. In questi appunti ho trascritto solo l&#8217;ABC, chi più ne ha più ne metta..</p>
<p>Chiudo con alcune utili risorse per chi vuole approfondire il tema:</p>
<ul>
<li><a href="http://msdn.microsoft.com/en-us/library/gg430141.aspx">http://msdn.microsoft.com/en-us/library/gg430141.aspx</a></li>
<li><a href="http://office.microsoft.com/en-us/sharepoint-designer-help/customize-a-master-page-to-brand-your-site-HA102449505.aspx">http://office.microsoft.com/en-us/sharepoint-designer-help/customize-a-master-page-to-brand-your-site-HA102449505.aspx</a></li>
<li><a href="http://www.thesharepointmuse.com/sharepoint-2010-branding/">http://www.thesharepointmuse.com/sharepoint-2010-branding/</a></li>
<li><a href="http://nonsolosharepoint.wordpress.com/2010/01/26/its-a-ribbon-behaviour/">http://nonsolosharepoint.wordpress.com/2010/01/26/its-a-ribbon-behaviour/</a> -&gt; utile riferimento sul tema ribbon..</li>
<li><a href="http://nonsolosharepoint.wordpress.com/2009/12/23/migrare-una-master-page-da-sharepoint-2007-a-sharepoint-2010/">http://nonsolosharepoint.wordpress.com/2009/12/23/migrare-una-master-page-da-sharepoint-2007-a-sharepoint-2010/</a></li>
</ul>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=Owk916y0NAY:svYNyDbDv4I:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=Owk916y0NAY:svYNyDbDv4I:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Owk916y0NAY:svYNyDbDv4I:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/08/09/branding-di-sharepoint-2010-abc-appunti/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		</item>
		<item>
		<title>Installare Chrome OS su VMware: come provare il nuovo sistema operativo di Google</title>
		<link>http://www.diplod.it/2011/07/04/installare-chrome-os-su-vmware-come-provare-il-nuovo-sistema-operativo-di-google/</link>
		<comments>http://www.diplod.it/2011/07/04/installare-chrome-os-su-vmware-come-provare-il-nuovo-sistema-operativo-di-google/#comments</comments>
		<pubDate>Mon, 04 Jul 2011 16:02:30 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Google]]></category>
		<category><![CDATA[Software]]></category>
		<category><![CDATA[chrome]]></category>
		<category><![CDATA[chromium]]></category>
		<category><![CDATA[OS]]></category>
		<category><![CDATA[virtualizzazione]]></category>
		<category><![CDATA[vmware]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1232</guid>
		<description><![CDATA[Sono arrivati in vendita i notebook con Chromium OS preinstallato, anche in Italia. Per la cronaca: trattasi del sistema operativo di Google, concepito per vivere completamente on-line. La notizia non è pù fresca fresca, e ti viene voglia di provare questo sistema operativo di cui tutti parlano.
Come fare? E' un attimo. Abbiamo due possibilità, metterlo su un supporto esterno USB oppure utilizzare VMware Player e avere a disposizione una macchina virtuale sul proprio computer. Ho scelto la seconda strada e metto per iscritto due appunti per chi volesse cimentarsi.]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2011/07/Immagine.png"><img class="aligncenter size-large wp-image-1234" title="Chrome OS" src="http://www.diplod.it/wp-content/uploads/2011/07/Immagine-1024x817.png" alt="" width="490" height="380" /></a></p>
<p style="text-align: left;">Sono arrivati in <a title="chrome book" href="http://www.google.com/chromebook/">vendita i notebook con Chromium OS</a> preinstallato, anche in Italia. Per la cronaca: trattasi del sistema operativo di Google, concepito per <em>vivere</em> completamente on-line. La notizia non è pù fresca fresca, e ti viene voglia di provare questo sistema operativo di cui tutti parlano.</p>
<p>Come fare? E&#8217; un attimo. Abbiamo due possibilità, metterlo su un<strong> supporto esterno USB</strong> oppure utilizzare <strong>VMware Player</strong> e avere a disposizione una macchina virtuale sul proprio computer. Ho scelto la seconda strada e metto per iscritto due appunti per chi volesse cimentarsi.</p>
<ol>
<li>Se già non è installato, <strong>scaricare e installare <a title="VMware player" href="http://www.vmware.com/products/player/" target="_blank">VMware Player</a></strong>, il tool di virtualizzazione gratuito di VMware. Per un&#8217;utenza <em>domestica </em>è più che sufficiente.</li>
<li>Scaricare la <strong><a title="Vanilla Nightly Build Chromium OS" href="http://chromeos.hexxeh.net/vanilla.php" target="_blank">Vanilla Nightly Build di Chromium OS</a></strong>. Vanilla che? Si tratta di una versione del sistema operativo di Google che ogni notte viene compilata fresca fresca dalla fabbrica e messa a disposizione per il download, così tutti coloro che non possono permettersi il notebook  riescono comunque a godersela. Ovviamente bisognerà scaricare la versione per VMware.</li>
<li>Una volta scaricato lo zip, scompattarlo, ad esempio nella cartella <em>C:\ChromeOS\</em></li>
<li>Rinominare il file <strong>ChromeOS-Vanilla-xxxxxxxxxxxxxxxxxxxxx-VMWare.vmdk</strong> in <strong>ChromeOS-Vanilla-VMWare.vmdk</strong></li>
<li>Aprire VMware player e cliccare su <em>Open a Virtual Machine</em></li>
<li>Selezionare la macchina virtuale dalla cartella <em>C:\ChromeOS\ </em>ed il gioco è fatto.</li>
</ol>
<p>Al primo avvio il sistema chiede di fare il logon con le proprie credenziali Google, ovviamente è necessario un account. La prima impressione è che si tratti di un sistema ancora un po&#8217; acerbo, ma prima di sbilanciarmi serve un minimo di esplorazione in più.</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=3I4dtnXts8g:K76Hfi-LodI:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=3I4dtnXts8g:K76Hfi-LodI:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=3I4dtnXts8g:K76Hfi-LodI:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/07/04/installare-chrome-os-su-vmware-come-provare-il-nuovo-sistema-operativo-di-google/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>HTML5 e jQuery: finalmente un player audio video coi fiocchi</title>
		<link>http://www.diplod.it/2011/04/08/html5-e-jquery-finalmente-un-player-audio-video-coi-fiocchi/</link>
		<comments>http://www.diplod.it/2011/04/08/html5-e-jquery-finalmente-un-player-audio-video-coi-fiocchi/#comments</comments>
		<pubDate>Fri, 08 Apr 2011 15:58:09 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[Design]]></category>
		<category><![CDATA[audio]]></category>
		<category><![CDATA[html5]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[jquery]]></category>
		<category><![CDATA[player]]></category>
		<category><![CDATA[video]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1209</guid>
		<description><![CDATA[Si chiama Projekktor, ed è davvero ciò che cercavo da tempo. Un player senza fronzoli, che funzioni su tutti i browser. Senza flash, che quegli aggeggi piccoli e cool così come gli attrezzi grossi e prestanti non supportano. jQuery certo, ma anche il pulitissimo HTML5.]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2011/04/thisisprojekktor.png"><img class="size-medium wp-image-1210 aligncenter" title="thisisprojekktor" src="http://www.diplod.it/wp-content/uploads/2011/04/thisisprojekktor-300x208.png" alt="" width="300" height="208" /></a></p>
<p>Si chiama <strong><a title="projekktor" href="http://www.projekktor.com" target="_blank">Projekktor</a></strong>, ed è davvero ciò che cercavo da tempo. Un player senza fronzoli, che funzioni su tutti i browser. Senza flash, che quegli <a title="iphone" href="http://www.apple.com/it/iphone/" target="_blank">aggeggi piccoli e cool</a> così come gli <a title="flash player 64 bit" href="http://www.adobe.com/it/support/flashplayer/ts/documents/6b3af6c9.htm" target="_blank">attrezzi grossi e prestanti</a> non supportano. jQuery certo, ma anche il pulitissimo HTML5.</p>
<p>Adoro questo pezzo di codice:<br />
<code><br />
&lt;video id="player_a" poster="intro.png" title="this is Projekktor" width="640" height="385" controls&gt;<br />
&lt;source src="intro.ogv" type="video/ogg" /&gt;<br />
&lt;source src="intro.mp4" type="video/mp4" /&gt;<br />
&lt;source src="intro.webm" type="video/mp4" /&gt;<br />
&lt;/video&gt;<br />
&lt;script type="text/javascript"&gt;$(document).ready(function() {projekktor('#player_a'); // instantiation<br />
});&lt;/script&gt;<br />
</code><br />
Chiaro e leggibile, grazie al nuovo tag <a title="HTML video tag" href="http://www.w3schools.com/html5/tag_video.asp" target="_blank">&lt;video&gt; HTML5</a> ormai supportato da diversi browser. In sostanza viene specificata nell&#8217;attributo poster una immagine di partenza da far visualizzare al caricamento dell&#8217;oggetto e diverse sorgenti video, questo per garantire una maggiore compatibilità sui diversi sistemi.</p>
<p>Il plugin jQuery si occupa del resto: <a href="http://www.projekktor.com/docs/playlists" target="_blank">playlist</a>, gestione dei <a href="http://www.projekktor.com/docs/theming">temi grafici</a>.. ci sono pure le <a href="http://www.projekktor.com/docs/api">API</a> disponibili.</p>
<p>Perfetto insomma!</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=_g5JzQ1ZF_M:x8veQbrk-f8:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=_g5JzQ1ZF_M:x8veQbrk-f8:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=_g5JzQ1ZF_M:x8veQbrk-f8:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/04/08/html5-e-jquery-finalmente-un-player-audio-video-coi-fiocchi/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Highcharts: grafici interattivi con jQuery ottimizzati anche per iPhone / Android</title>
		<link>http://www.diplod.it/2011/02/17/highcharts-grafici-interattivi-con-jquery-ottimizzati-anche-per-iphone-android/</link>
		<comments>http://www.diplod.it/2011/02/17/highcharts-grafici-interattivi-con-jquery-ottimizzati-anche-per-iphone-android/#comments</comments>
		<pubDate>Thu, 17 Feb 2011 17:52:14 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[Applicazioni Web]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[applicazioni]]></category>
		<category><![CDATA[charts]]></category>
		<category><![CDATA[grafici]]></category>
		<category><![CDATA[highcharts]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[Open Source]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1176</guid>
		<description><![CDATA[Grafici interattivi e dinamici con Highcharts, un prodotto molto flessibile per costruire cruscotti o report. Possibilità di caricare i dati in maniera asincrona e svariati modi per visualizzarli.. da provare!]]></description>
			<content:encoded><![CDATA[<p><script src="http://www.diplod.it/wp-content/uploads/2011/02/highcharts.js" type="text/javascript"></script><br />
<script type="text/javascript">// <![CDATA[  
$(document).ready(function () { 
//GRAFICO CARICATO QUANDO IL DOM DEL DOCUMENTO HTML E' PRONTO             
chartTurnover = new Highcharts.Chart({               
chart: { 
//id del div all'interno del quale il grafico deve essere visualizzato                 
renderTo: 'content4',                  
zoomType: 'xy'},               
title: {
//descrizione grafico: titolo e sottotitolo
text: 'Fatturato - Obiettivi'
},               
subtitle: {
text: 'Confronto tra vendite effettive e target previsionali'
},
//definizione dell'asse X
xAxis: [
{
categories: ['Qrt1', 'Qrt2', 'Qrt3', 'Qrt4']
}],
//definizione dell'asse Y
yAxis: [{
// aggiungo il simbolo dell'euro alle etichette dell'asse Y
labels: {
formatter: function() {
return this.value +'€'; 
} 
},
//Descrizione posta a lato dell'asse Y
title: {
text: 'Targets'
}
}], 
//Definizione del testo da visualizzare nei tooltip
tooltip: {
formatter: function() {
return ''+ this.series.name + ' ' + this.x +': '+ this.y + '€';
}
}, 
//Posizionamento legenda
legend: {
layout: 'vertical',
align: 'left',
x: 120,
verticalAlign: 'top',
y: 0,
floating: true
},
//Definisco il tipo di rappresentazione grafica
plotOptions: {
column: {
stacking: 'normal'
}
},
//Definizione delle serie di valori
series: [{
name: 'Fatturato zona1',
type: 'column',
data: [14183, 12451, 7254, 9658]
},
{ 
name: 'Fatturato zona2',
type: 'column',
data: [2183, 10451, 5254, 7658]
},
{
name: 'Fatturato zona3',
type: 'column',
data: [2300, 451, 4254, 4658]
},
{
//Ultima serie, di tipo linea (spline), per valorizzare i target
name: 'Targets',
type: 'spline',
data: [18175, 21556, 17145, 19897]
}]
}); 
//end
});
// ]]&gt;</script><br />
<!-- div grafico turnover --></p>
<div id="content4" class="grid_12 box">
<div class="loading" style="background: url(http://www.diplod.it/wp-content/uploads/2011/02/ajax-loader.gif) no-repeat center center; text-align: center; min-height: 100px;">Loading..</div>
</div>
<p>Come ti sembra questo <strong>grafico</strong>? Prova a cliccare sugli elementi della legenda e vedrai che è <strong>interattivo</strong>, potresti utilizzarlo per simulare il rispetto degli obiettivi in assenza di fatturato ottenuto su alcune zone.. Prova a selezionare col mouse una zona del grafico e vedrai puoi fare lo <strong>zoom sui dati</strong> che ti interessano.. Queste e tante altre funzionalità si possono ottenere grazie ad <strong><a title="Highcharts - grafici interattivi" href="http://highcharts.com/">Highcharts</a></strong>, un validissimo <strong>javascript </strong>open source che lavora con jQuery per renderizzare grafici più o meno complessi e molto accattivanti.</p>
<p>Il tutto <strong>senza flash</strong>, cosa a cui difficilmente si poteva rinunciare in era pre-<a title="jquery" href="http://www.google.it/url?sa=t&amp;source=web&amp;cd=1&amp;ved=0CCoQFjAA&amp;url=http%3A%2F%2Fjquery.com%2F&amp;ei=MFtdTffFMMKDOrbx3bML&amp;usg=AFQjCNFA7CZ5sWRDhHPuipmhL7zVksjC2A" target="_blank">jQuery</a> se si volevano ottenere i medesimi risultati. Le tipologie di grafici sono molteplici: si va dalla immancabile <a title="Highcharts demo" href="http://highcharts.com/demo/?example=pie-basic&amp;theme=default" target="_blank">torta</a> alla più ricercata <a title="Highcharts demo" href="http://highcharts.com/demo/?example=bar-negative-stack&amp;theme=default" target="_blank">rappresentazione demografica</a>, dal <a title="Highcharts demo" href="http://highcharts.com/demo/?example=column-stacked&amp;theme=default" target="_blank">grafico a barre</a> al potente grafico zoomabile sull&#8217;<a title="Highcharts demo" href="http://highcharts.com/demo/?example=dynamic-master-detail&amp;theme=default" target="_blank">andamento delle quotazioni</a> in borsa. E&#8217; inoltre possibile caricare i dati direttamente da una tabella definita in HTML all&#8217;interno della pagina, con poche righe di codice javascript.<br />
<span id="more-1176"></span></p>
<p>Sotto è riportato il codice, opportunamente commentato, dell&#8217;esempio mostrato in questo articolo.<br />
<code>//Carico il javascript di highcharts, dopo aver caricato jQuery<br />
&lt;script src="js/highcharts.js" type="text/javascript"&gt;&lt;/script&gt;<br />
&lt;script type="text/javascript"&gt;// &lt;![CDATA[</p>
<div id="_mcePaste">$(document).ready(function () {</div>
<div id="_mcePaste">//GRAFICO CARICATO QUANDO IL DOM DEL DOCUMENTO HTML E' PRONTO</div>
<div id="_mcePaste">chartTurnover = new Highcharts.Chart({</div>
<div id="_mcePaste">chart: {</div>
<div id="_mcePaste">//id del div all'interno del quale il grafico deve essere visualizzato</div>
<div id="_mcePaste">renderTo: 'content4',</div>
<div id="_mcePaste">zoomType: 'xy'},</div>
<div id="_mcePaste">title: {</div>
<div id="_mcePaste">//descrizione grafico: titolo e sottotitolo</div>
<div id="_mcePaste">text: 'Fatturato - Obiettivi'</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">subtitle: {</div>
<div id="_mcePaste">text: 'Confronto tra vendite effettive e target previsionali'</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">//definizione dell'asse X</div>
<div id="_mcePaste">xAxis: [</div>
<div id="_mcePaste">{</div>
<div id="_mcePaste">categories: ['Qrt1', 'Qrt2', 'Qrt3', 'Qrt4']</div>
<div id="_mcePaste">}],</div>
<div id="_mcePaste">//definizione dell'asse Y</div>
<div id="_mcePaste">yAxis: [{</div>
<div id="_mcePaste">// aggiungo il simbolo dell'euro alle etichette dell'asse Y</div>
<div id="_mcePaste">labels: {</div>
<div id="_mcePaste">formatter: function() {</div>
<div id="_mcePaste">return this.value +'€';</div>
<div id="_mcePaste">}</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">//Descrizione posta a lato dell'asse Y</div>
<div id="_mcePaste">title: {</div>
<div id="_mcePaste">text: 'Targets'</div>
<div id="_mcePaste">}</div>
<div id="_mcePaste">}],</div>
<div id="_mcePaste">//Definizione del testo da visualizzare nei tooltip</div>
<div id="_mcePaste">tooltip: {</div>
<div id="_mcePaste">formatter: function() {</div>
<div id="_mcePaste">return ''+ this.series.name + ' ' + this.x +': '+ this.y + '€';</div>
<div id="_mcePaste">}</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">//Posizionamento legenda</div>
<div id="_mcePaste">legend: {</div>
<div id="_mcePaste">layout: 'vertical',</div>
<div id="_mcePaste">align: 'left',</div>
<div id="_mcePaste">x: 120,</div>
<div id="_mcePaste">verticalAlign: 'top',</div>
<div id="_mcePaste">y: 0,</div>
<div id="_mcePaste">floating: true</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">//Definisco il tipo di rappresentazione grafica</div>
<div id="_mcePaste">plotOptions: {</div>
<div id="_mcePaste">column: {</div>
<div id="_mcePaste">stacking: 'normal'</div>
<div id="_mcePaste">}</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">//Definizione delle serie di valori</div>
<div id="_mcePaste">series: [{</div>
<div id="_mcePaste">name: 'Fatturato zona1',</div>
<div id="_mcePaste">type: 'column',</div>
<div id="_mcePaste">data: [14183, 12451, 7254, 9658]</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">{</div>
<div id="_mcePaste">name: 'Fatturato zona2',</div>
<div id="_mcePaste">type: 'column',</div>
<div id="_mcePaste">data: [2183, 10451, 5254, 7658]</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">{</div>
<div id="_mcePaste">name: 'Fatturato zona3',</div>
<div id="_mcePaste">type: 'column',</div>
<div id="_mcePaste">data: [2300, 451, 4254, 4658]</div>
<div id="_mcePaste">},</div>
<div id="_mcePaste">{</div>
<div id="_mcePaste">//Ultima serie, di tipo linea (spline), per valorizzare i target</div>
<div id="_mcePaste">name: 'Targets',</div>
<div id="_mcePaste">type: 'spline',</div>
<div id="_mcePaste">data: [18175, 21556, 17145, 19897]</div>
<div id="_mcePaste">}]</div>
<div id="_mcePaste">});</div>
<div id="_mcePaste">//end</div>
<div id="_mcePaste">// ]]&gt;&lt;/script&gt;</div>
<p></code></p>
<p>Data la sua natura di puro css e javascript, questo grafico è agilmente fruibile anche da dispositivi mobili come iPhone o Android, inoltre è ben renderizzato dai principali browser. Si tratta di un prodotto davvero interessante che potrebbe tornare utile in diverse applicazioni stand-alone, a costo zero. Ben diverso dal classico <a href="http://www.diplod.it/2008/04/20/google-chart-api-grafici-dinamici-in-un-attimo/">Google Charts</a>, servizio comodissimo che però pecca in quanto ad interattività: all&#8217;utente viene infatti restituita in quel caso una immagine statica.</p>
<p><strong>Cosa Manca?</strong> Mancano i &#8220;<strong>geo-grafici</strong>&#8220;, ovvero la possibilità di visualizzare i dati su una cartina; mancano i <strong>tachimetri</strong>, per visualizzare in un colpo d&#8217;occhio l&#8217;andamento più o meno positivo di un indicatore. Sono comunque cose a cui si può sopperire spulciando bene l&#8217;elenco dei plugin jQuery..<br />
<strong>E voi? Che cosa utilizzate in questi casi?</strong></p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=g6Ft3XpI0-M:hGKCCZqk55k:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=g6Ft3XpI0-M:hGKCCZqk55k:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=g6Ft3XpI0-M:hGKCCZqk55k:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2011/02/17/highcharts-grafici-interattivi-con-jquery-ottimizzati-anche-per-iphone-android/feed/</wfw:commentRss>
		<slash:comments>7</slash:comments>
		</item>
		<item>
		<title>Chiamare e consumare un web service da una pagina aspx con C#</title>
		<link>http://www.diplod.it/2010/12/21/chiamare-e-consumare-un-web-service-da-una-pagina-aspx-con-c/</link>
		<comments>http://www.diplod.it/2010/12/21/chiamare-e-consumare-un-web-service-da-una-pagina-aspx-con-c/#comments</comments>
		<pubDate>Tue, 21 Dec 2010 11:41:40 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Applicazioni Web]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[esempio]]></category>
		<category><![CDATA[Visual Studio]]></category>
		<category><![CDATA[web service]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1166</guid>
		<description><![CDATA[Un esempio pratico per interrogare un web service remoto e restituire il risultato su una pagina aspx scritta in C# con Visual Studio.]]></description>
			<content:encoded><![CDATA[<p>Cosa sono i <strong>web service</strong> e perchè possono essere davvero <strong>utili </strong>lo lascio raccontare ad altri:</p>
<ul>
<li><a href="http://it.wikipedia.org/wiki/Web_service" target="_blank">Web Service su Wikipedia</a></li>
<li><a href="http://server.html.it/guide/leggi/100/guida-web-service/" target="_blank">Guida Web Service</a></li>
</ul>
<p>L&#8217;obiettivo di questo articolo è fissare un <strong>esempio pratico</strong> per interrogare un web service e sfruttare i risultati che restituisce utilizzando <strong>C# e Visual Studio</strong>.</p>
<p>Supponiamo di dover accedere al webservice di esempio su W3C, descritto a questa pagina: http://www.w3schools.com/webservices/tempconvert.asmx<br />
La descrizione del servizio è fornita a questo URL:  http://www.w3schools.com/webservices/tempconvert.asmx</p>
<p>Il servizio ha 2 metodi  - <em>FahrenheitToCelsius()</em> e <em>CelsiusToFahrenheit() </em>- che accettano entrambi un solo parametro di input e convertono la temperatura da gradi fahrenhait a Celsius e viceversa.</p>
<p>La risposta del server è un XML di questo tipo:<br />
<code>&lt;?xml version="1.0" encoding="utf-8" ?&gt;&lt;string xmlns="http://tempuri.org/"&gt;38&lt;/string&gt;</code></p>
<p><span id="more-1166"></span>Su Visual Studio, cliccando sul nome del progetto web col tasto destro, si apre un menu dove è possibile aggiungere una <em>Web Reference</em>.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2010/12/ws1.png"><img class="alignnone size-large wp-image-1168" title="ws1" src="http://www.diplod.it/wp-content/uploads/2010/12/ws1-1024x640.png" alt="" width="800" height="580" /></a></p>
<p>Qui si inserisce l’indirizzo della descrizione WSDL del web service.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2010/12/ws2.png"><img class="alignnone size-full wp-image-1169" title="ws2" src="http://www.diplod.it/wp-content/uploads/2010/12/ws2.png" alt="" width="825" height="571" /></a></p>
<p>Il software identifica l’interfaccia del servizio web, con i metodi che mette a disposizione.<br />
Per aggiungerlo al progetto si clicca sul tasto Add Reference. Fatto questo ci troveremo l&#8217;oggetto nel Solution Explorer.</p>
<p><a href="http://www.diplod.it/wp-content/uploads/2010/12/ws3.png"><img class="alignnone size-full wp-image-1170" title="ws3" src="http://www.diplod.it/wp-content/uploads/2010/12/ws3.png" alt="" width="380" height="284" /></a></p>
<p>Ora nel codice della pagina aspx su cui vogliamo consumare il web service è necessario aggiungere il riferimento con questo codice:<br />
<code>using com.w3schools.www;</code></p>
<p><a href="http://www.diplod.it/wp-content/uploads/2010/12/ws4.png"><img class="alignnone size-full wp-image-1171" title="ws4" src="http://www.diplod.it/wp-content/uploads/2010/12/ws4.png" alt="" width="800" height="320" /></a></p>
<p>Ora dichiariamo un oggetto per la web reference, che sarà possibile utilizzare con tutti i sui metodi come qualsiasi altro oggetto:</p>
<p><code>com.w3schools.www.TempConvert MyProxy = new com.w3schools.www.TempConvert();</code></p>
<p><a href="http://www.diplod.it/wp-content/uploads/2010/12/ws5.png"><img class="alignnone size-full wp-image-1172" title="ws5" src="http://www.diplod.it/wp-content/uploads/2010/12/ws5.png" alt="" width="633" height="331" /></a></p>
<p>L’esempio finale completo potrebbe essere una pagine con una textbox che nella quale l’utente scrive la temperatura, un bottone di invio invoca il webservice e il risultato appare in una label. In questo caso il codice della classe sarebbe il seguente:<br />
<code><br />
using System;<br />
using System.Collections.Generic;<br />
using System.Linq;<br />
using System.Web;<br />
using System.Web.UI;<br />
using System.Web.UI.WebControls;<br />
using com.w3schools.www;<br />
public partial class _Default : System.Web.UI.Page{<br />
com.w3schools.www.TempConvert MyProxy = new com.w3schools.www.TempConvert();<br />
protected void Page_Load(object sender, EventArgs e)    { }<br />
protected void Button1_Click(object sender, EventArgs e)    {<br />
Label1.Text = MyProxy.CelsiusToFahrenheit(TextBox1.Text);<br />
}<br />
}<br />
</code></p>
<p>Mentre il codice della pagina il seguente:<br />
<code><br />
&lt;%@ Page Language="C#" AutoEventWireup="true" CodeFile="Default.aspx.cs" Inherits="_Default" %&gt;<br />
&lt;!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"&gt;<br />
&lt;html xmlns="http://www.w3.org/1999/xhtml"&gt;<br />
&lt;head runat="server"&gt;<br />
&lt;title&gt;&lt;/title&gt;<br />
&lt;/head&gt;<br />
&lt;body&gt;<br />
&lt;form id="form1" runat="server"&gt;<br />
&lt;div&gt;<br />
&lt;asp:TextBox ID="TextBox1" runat="server"&gt;&lt;/asp:TextBox&gt;&amp;nbsp;&lt;asp:Button ID="Button1" runat="server" onclick="Button1_Click" Text="Button" /&gt;&lt;br /&gt;<br />
&lt;asp:Label ID="Label1" runat="server" Text="Label"&gt;&lt;/asp:Label&gt;<br />
&lt;/div&gt;<br />
&lt;/form&gt;<br />
&lt;/body&gt;<br />
&lt;/html&gt;<br />
</code></p>
<p>E ora non resta che sbizzarrirsi, una volta imparato <strong>il mestiere va affinato</strong>.</p>
<p>Lascio qualche link per chi i web service li vuole anche costruire:</p>
<ul>
<li><a href="http://www.codeproject.com/KB/java/Invoke_Java_WS_In_CS.aspx" target="_blank">How to create and invoke Java web service</a></li>
<li><a href="http://www.codeproject.com/KB/webservices/myservice.aspx" target="_blank">Your first C# Web Service</a></li>
</ul>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=Q76tOi0U-5A:3j98o7xcblM:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=Q76tOi0U-5A:3j98o7xcblM:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Q76tOi0U-5A:3j98o7xcblM:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/12/21/chiamare-e-consumare-un-web-service-da-una-pagina-aspx-con-c/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Lavorare con le date in javascript: il tool che salva la vita!</title>
		<link>http://www.diplod.it/2010/09/29/lavorare-con-le-date-in-javascript-il-tool-che-salva-la-vita/</link>
		<comments>http://www.diplod.it/2010/09/29/lavorare-con-le-date-in-javascript-il-tool-che-salva-la-vita/#comments</comments>
		<pubDate>Wed, 29 Sep 2010 14:43:22 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[date]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[utility]]></category>
		<category><![CDATA[vb]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1140</guid>
		<description><![CDATA[jsDate. Per chi non vuole impazzire con le classiche funzioni javascript, che sono utili ma non sempre funzionali, esiste questo comodo js da includere nei propri lavori per agire in maniera efficace sulle date. La funzione più importante è sicuramente il DateDiff(), comodissimo per fare somme e differenze al volo.]]></description>
			<content:encoded><![CDATA[<p><a href="http://slingfive.com/pages/code/jsDate/jsDate.html"><strong>jsDate</strong></a>: emulatore delle funzioni native Visual Basic in javascript. Ovvero, come fare somme e differenze, trasformare in diversi formati, ricavare il giorno della settimana o il mese da stringhe che rappresentano date.</p>
<p>Per chi non vuole impazzire con le classiche funzioni javascript, che sono utili ma non sempre funzionali, esiste questo comodo js da includere nei propri lavori per agire in maniera efficace sulle date. La funzione più importante è sicuramente il DateDiff(), comodissimo per fare somme e differenze <em>al volo</em> sulle date.</p>
<p>Ecco un po&#8217; di giochetti che si possono fare grazie a questo script, lo schema esplicativo sottostante è stato preso direttamente dal <a href="http://slingfive.com/pages/code/jsDate/jsDate.html">sito dell&#8217;autore</a>.<br />
<span id="more-1140"></span></p>
<p><script language="javascript" type="text/javascript" src="http://www.diplod.it/wp-content/uploads/2010/09/jsDate.js"></script><br />
<script language="javascript" type="text/javascript" src="http://www.diplod.it/wp-content/uploads/2010/09/jsDate_demo.js"></script> </p>
<div id="params" style="float: left; width: 40%">
<h6>1) Imposta i parametri:</h6>
<p>	<label for="txtDate1"><span>date1</span><br />
<input type="text" id="txtDate1" value="9/2/2005 1:23:45 am" /></label><br />
	<button onclick="oDate1.value = new Date();" title="set to Now">Crea una nuova data</button> </p>
<p>	<label for="txtDate2"><span>date2</span> </p>
<input type="text" id="txtDate2" value="12/5/2009 5:43:21 am" /></label><br />
	<button onclick="oDate2.value = new Date();" title="set to Now">Crea una nuova data</button> </p>
<p>	<label for="selInterval"><span>interval</span> </p>
<select id="selInterval">
<option value=""></option>
<option value="yyyy" selected="selected">yyyy (year)</option>
<option value="q">q &nbsp; &nbsp;(quarter)</option>
<option value="m">m &nbsp; &nbsp;(month)</option>
<option value="y">y &nbsp; &nbsp;(day of year)</option>
<option value="d">d &nbsp; &nbsp;(day)</option>
<option value="w">w &nbsp; &nbsp;(weekday)</option>
<option value="ww">ww &nbsp;&nbsp;(week of year)</option>
<option value="h">h &nbsp; &nbsp;(hour)</option>
<option value="n">n &nbsp; &nbsp;(minute)</option>
<option value="s">s &nbsp; &nbsp;(seconds)</option>
<option value="ms" style="color:red;">ms &nbsp;&nbsp;(milliseconds)</option>
</select>
<p></label> </p>
<p>	<label for="txtNumber"><span>number</span> </p>
<input type="text" id="txtNumber" value="1" /></label> </p>
<p>	<label for="selFirstDayOfWeek"><span>firstDayOfWeek</span> </p>
<select id="selFirstDayOfWeek">
<option value=""></option>
<option value="0">0 : vbUseSystemDayOfWeek (==1)</option>
<option value="1">1 : vbSunday</option>
<option value="2">2 : vbMonday</option>
<option value="3">3 : vbTuesday</option>
<option value="4">4 : vbWednesday</option>
<option value="5">5 : vbThursday</option>
<option value="6">6 : vbFriday</option>
<option value="7">7 : vbSaturday</option>
</select>
<p></label> </p>
<p>	<label for="selNamedFormat"><span>namedFormat</span> </p>
<select id="selNamedFormat">
<option value=""></option>
<option value="0" selected="selected">0 : vbGeneralDate</option>
<option value="1">1 : vbLongDate</option>
<option value="2">2 : vbShortDate</option>
<option value="3">3 : vbLongTime</option>
<option value="4">4 : vbShortTime</option>
</select>
<p></label> </p>
<p>	<label for="txtFormat"><span>format</span> </p>
<input type="text" id="txtFormat" value="ddd mmm d, yyyy" 	title="possible values:</p>
<p>	c, d, dd, ddd, dddd, ddddd, dddddd, m, mm, mmm, mmmm, q, y, yy, yyyy</p>
<p>	h, hh, n, nn, s, ss, t t t t t, AM/PM, am/pm, A/P, a/p, AMPM, timezone, time24, time"/></label><br /> <br />
	<label for="chkAbbreviate"><span>abbreviate</span> </p>
<input type="checkbox" id="chkAbbreviate" value="true" /></label> </p>
</div>
<div id="functions" style="float: right; width: 40%">
<h6>2) Chiama una funzione:</h6>
<div style="display:table;">
	<button id="btnTestIsDate" assocCtlIDs="txtDate1"><b>IsDate</b> (date1)</button><br /> <br />
	<button id="btnTestCDate" assocCtlIDs="txtDate1"><b>CDate</b> (date1)</button><br /> <br />
	<button id="btnTestDateAdd" assocCtlIDs="selInterval,txtNumber,txtDate1"><b>DateAdd</b> (interval, number, date1)</button><br /> <br />
	<button id="btnTestDateDiff" assocCtlIDs="selInterval,txtDate1,txtDate2,selFirstDayOfWeek"><b>DateDiff</b> (interval, date1, date2, <i>firstDayOfWeek</i>)</button><br /> <br />
	<button id="btnTestDatePart" assocCtlIDs="selInterval,txtDate1,selFirstDayOfWeek"><b>DatePart</b> (interval, date1, <i>firstDayOfWeek</i>)</button><br /> <br />
	<button id="btnTestMonthName" assocCtlIDs="txtNumber,chkAbbreviate"><b>MonthName</b> (number, <i>abbreviate</i>)</button><br /> <br />
	<button id="btnTestWeekdayName" assocCtlIDs="txtNumber,chkAbbreviate,selFirstDayOfWeek"><b>WeekdayName</b> (number, <i>abbreviate</i>, <i>firstDayOfWeek</i>)</button><br /> <br />
	<button id="btnTestWeekday" assocCtlIDs="txtNumber,selFirstDayOfWeek"><b>Weekday</b> (number, <i>firstDayOfWeek</i>)</button><br /> <br />
	<button id="btnTestFormatDateTime" assocCtlIDs="txtDate1,selNamedFormat"><b>FormatDateTime</b> (date1, <i>namedFormat</i>)</button><br /> <br />
	<button id="btnTestFormat" assocCtlIDs="txtDate1,txtFormat,selFirstDayOfWeek"><b>Format</b> (date1, <i>format</i>, <i>firstDayOfWeek</i>)</button><br /> 
	</div>
</div>
<p><br clear="all" /> </p>
<h6 style="margin-top:-1em;">3) Ottieni questo risultato:</h6>
<div id="result" style="background: yellow;">&nbsp;</div>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=Trl3tlYl2yQ:aXqNK1YqRQc:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=Trl3tlYl2yQ:aXqNK1YqRQc:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=Trl3tlYl2yQ:aXqNK1YqRQc:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/09/29/lavorare-con-le-date-in-javascript-il-tool-che-salva-la-vita/feed/</wfw:commentRss>
		<slash:comments>2</slash:comments>
		</item>
		<item>
		<title>Componenti Ajax e UI Toolkit per applicazioni web RIA</title>
		<link>http://www.diplod.it/2010/07/19/componenti-ajax-e-ui-toolkit-per-applicazioni-web-ria/</link>
		<comments>http://www.diplod.it/2010/07/19/componenti-ajax-e-ui-toolkit-per-applicazioni-web-ria/#comments</comments>
		<pubDate>Mon, 19 Jul 2010 06:42:17 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Ajax e Javascript]]></category>
		<category><![CDATA[Applicazioni Web]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[.net]]></category>
		<category><![CDATA[ajax]]></category>
		<category><![CDATA[Java]]></category>
		<category><![CDATA[javascript]]></category>
		<category><![CDATA[RIA]]></category>
		<category><![CDATA[toolkit]]></category>
		<category><![CDATA[webdesign]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1087</guid>
		<description><![CDATA[Volete stupire con componenti dinamici pronti all'uso? Creare applicazioni web avanzate non è poi così laborioso, oggi si trovano un sacco di risorse in rete. Ecco una breve panoramica.]]></description>
			<content:encoded><![CDATA[<p style="text-align: center;"><a href="http://www.diplod.it/wp-content/uploads/2010/07/toolkit.png"><img class="size-full wp-image-1130 aligncenter" title="toolkit" src="http://www.diplod.it/wp-content/uploads/2010/07/toolkit.png" alt="" width="415" height="212" /></a></p>
<p><strong>Volete stupire con componenti dinamici pronti all&#8217;uso?</strong> Creare <strong>applicazioni web</strong> avanzate non è poi così laborioso, oggi si trovano un sacco di risorse in rete. Una di queste è il<strong> <a title="DHTMLX" href="http://www.dhtmlx.com/" target="_blank">DHTMLX UI Toolkit</a></strong>, una serie di <strong>librerie javascript</strong> corredate da tantissimi esempi. La documentazione è ciò che fa la differenza: gli script non documentati e con pochi esempi sono quasi inutilizzabili, se non perdendo un sacco di ore per studiarseli. UI Toolkit viene distribuito in uno zip con diverse pagine di pratiche demo.</p>
<p>Per chi lavora in <strong>ambiente .NET</strong> molto interessante è questo <a title="Ajax Control Toolkit" href="http://ajaxcontroltoolkit.codeplex.com/" target="_blank"><strong>Ajax Control Toolkit</strong></a>, un insieme di controlli utilizzabili direttamente in <strong>Visual Studio</strong> con il drag and drop, per costruire form e applicazioni accattivanti. Da Codeplex si possono scaricare anche i sorgenti, corredati da diversi esempi. In <a title="Ajax control toolkit - esempi" href="http://www.asp.net/ajax/ajaxcontroltoolkit/samples/" target="_blank">questa pagina</a> si può avere una panoramica di tutte le funzionalità disponibili, sono davvero parecchie:</p>
<p><span id="more-1087"></span></p>
<ul>
<li><a id="ctl00_SamplesLinks_ctl01_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Accordion/Accordion.aspx">Accordion</a></li>
<li><a id="ctl00_SamplesLinks_ctl02_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/AlwaysVisibleControl/AlwaysVisibleControl.aspx">AlwaysVisibleControl</a></li>
<li><a id="ctl00_SamplesLinks_ctl03_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Animation/Animation.aspx">Animation</a></li>
<li><a id="ctl00_SamplesLinks_ctl04_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/AsyncFileUpload/AsyncFileUpload.aspx">AsyncFileUpload</a></li>
<li><a id="ctl00_SamplesLinks_ctl05_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/AutoComplete/AutoComplete.aspx">AutoComplete</a></li>
<li><a id="ctl00_SamplesLinks_ctl06_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Calendar/Calendar.aspx">Calendar</a></li>
<li><a id="ctl00_SamplesLinks_ctl07_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/CascadingDropDown/CascadingDropDown.aspx">CascadingDropDown</a></li>
<li><a id="ctl00_SamplesLinks_ctl08_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/CollapsiblePanel/CollapsiblePanel.aspx">CollapsiblePanel</a></li>
<li><a id="ctl00_SamplesLinks_ctl09_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ColorPicker/ColorPicker.aspx">ColorPicker</a></li>
<li><a id="ctl00_SamplesLinks_ctl10_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ComboBox/ComboBox.aspx">ComboBox</a></li>
<li><a id="ctl00_SamplesLinks_ctl11_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ConfirmButton/ConfirmButton.aspx">ConfirmButton</a></li>
<li><a id="ctl00_SamplesLinks_ctl12_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/DragPanel/DragPanel.aspx">DragPanel</a></li>
<li><a id="ctl00_SamplesLinks_ctl13_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/DropDown/DropDown.aspx">DropDown</a></li>
<li><a id="ctl00_SamplesLinks_ctl14_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/DropShadow/DropShadow.aspx">DropShadow</a></li>
<li><a id="ctl00_SamplesLinks_ctl15_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/DynamicPopulate/DynamicPopulate.aspx">DynamicPopulate</a></li>
<li><a id="ctl00_SamplesLinks_ctl16_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/FilteredTextBox/FilteredTextBox.aspx">FilteredTextBox</a></li>
<li><a id="ctl00_SamplesLinks_ctl17_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/HoverMenu/HoverMenu.aspx">HoverMenu</a></li>
<li><a id="ctl00_SamplesLinks_ctl18_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/HTMLEditor/HTMLEditor.aspx">HTMLEditor</a></li>
<li><a id="ctl00_SamplesLinks_ctl19_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ListSearch/ListSearch.aspx">ListSearch</a></li>
<li><a id="ctl00_SamplesLinks_ctl20_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/MaskedEdit/MaskedEdit.aspx">MaskedEdit</a></li>
<li><a id="ctl00_SamplesLinks_ctl21_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ModalPopup/ModalPopup.aspx">ModalPopup</a></li>
<li><a id="ctl00_SamplesLinks_ctl22_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/MultiHandleSlider/MultiHandleSlider.aspx">MultiHandleSlider</a></li>
<li><a id="ctl00_SamplesLinks_ctl23_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/MutuallyExclusiveCheckBox/MutuallyExclusiveCheckBox.aspx">MutuallyExclusiveCheckBox</a></li>
<li><a id="ctl00_SamplesLinks_ctl24_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/NoBot/NoBot.aspx">NoBot</a></li>
<li><a id="ctl00_SamplesLinks_ctl25_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/NumericUpDown/NumericUpDown.aspx">NumericUpDown</a></li>
<li><a id="ctl00_SamplesLinks_ctl26_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/PagingBulletedList/PagingBulletedList.aspx">PagingBulletedList</a></li>
<li><a id="ctl00_SamplesLinks_ctl27_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/PasswordStrength/PasswordStrength.aspx">PasswordStrength</a></li>
<li><a id="ctl00_SamplesLinks_ctl28_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/PopupControl/PopupControl.aspx">PopupControl</a></li>
<li><a id="ctl00_SamplesLinks_ctl29_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Rating/Rating.aspx">Rating</a></li>
<li><a id="ctl00_SamplesLinks_ctl30_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ReorderList/ReorderList.aspx">ReorderList</a></li>
<li><a id="ctl00_SamplesLinks_ctl31_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ResizableControl/ResizableControl.aspx">ResizableControl</a></li>
<li><a id="ctl00_SamplesLinks_ctl32_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/RoundedCorners/RoundedCorners.aspx">RoundedCorners</a></li>
<li><a id="ctl00_SamplesLinks_ctl33_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Seadragon/Seadragon.aspx">Seadragon</a></li>
<li><a id="ctl00_SamplesLinks_ctl34_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Slider/Slider.aspx">Slider</a></li>
<li><a id="ctl00_SamplesLinks_ctl35_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/SlideShow/SlideShow.aspx">SlideShow</a></li>
<li><a id="ctl00_SamplesLinks_ctl36_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/Tabs/Tabs.aspx">Tabs</a></li>
<li><a id="ctl00_SamplesLinks_ctl37_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/TextBoxWatermark/TextBoxWatermark.aspx">TextBoxWatermark</a></li>
<li><a id="ctl00_SamplesLinks_ctl38_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ToggleButton/ToggleButton.aspx">ToggleButton</a></li>
<li><a id="ctl00_SamplesLinks_ctl39_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/UpdatePanelAnimation/UpdatePanelAnimation.aspx">UpdatePanelAnimation</a></li>
<li><a id="ctl00_SamplesLinks_ctl40_SamplesLink" href="http://www.asp.net/ajax/ajaxcontroltoolkit/Samples/ValidatorCallout/ValidatorCallout.aspx">ValidatorCallout</a></li>
</ul>
<p>Per chi vuole essere indipendente da javascript e piattaforma tecnologica, esiste questo <strong><a title="Vaddin Toolkit" href="http://vaadin.com/home" target="_blank">Vaadin</a></strong>, tutto basato su <strong>Java</strong>. Quest&#8217;ultimo molto più simile ai più noti framewok come <a title="Mootools" href="http://mootools.net/" target="_blank">Mootools</a> o <a title="JQuery" href="http://jquery.com/" target="_blank">JQuery</a>: dispone di diversi componenti elementari che opportunamente combinati tra loro danno vita ad applicazioni web avanzate.</p>
<p>Da segnalare infine questo <a title="iwebkit" href="http://iwebkit.net/" target="_blank">iWebKit</a>, utile per chi vuole cimentarsi nella realizzazione di siti e applicazioni concepite specificatamente per iPhone.</p>
<p>Risorse di questo tipo ne esistono davvero a bizzeffe, ma <strong>non è facile distinguere</strong> quelle che sono effettivamente utilizzabili <strong>out of the box</strong> da quelle che invece necessitano di altro e magari nascondono limiti tali da sconsigliarne l&#8217;utilizzo. Personalmente ho utilizzato in un ambiente di produzione l&#8217;UI Toolkit di DHTMLX e posso confermare che si tratta di librerie pronte all&#8217;uso, davvero comode e funzionali. Ho intenzione di provare a breve l&#8217;Ajax Control Toolkit per .NET e vi farò sapere le mie considerazioni. <strong>Mi piacerebbe ovviamente sentire le vostre e capire se esistono altri strumenti oltre a quelli citati, che magari avete utilizzato direttamente</strong>.</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=dJItTIsp1tc:-ts8ke1S2Gs:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=dJItTIsp1tc:-ts8ke1S2Gs:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=dJItTIsp1tc:-ts8ke1S2Gs:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/07/19/componenti-ajax-e-ui-toolkit-per-applicazioni-web-ria/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>Leggere e visualizzare file XML con C# (C sharp): qualche esempio</title>
		<link>http://www.diplod.it/2010/07/13/leggere-e-visualizzare-file-xml-con-c-c-sharp-qualche-esempio/</link>
		<comments>http://www.diplod.it/2010/07/13/leggere-e-visualizzare-file-xml-con-c-c-sharp-qualche-esempio/#comments</comments>
		<pubDate>Tue, 13 Jul 2010 12:31:32 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Applicazioni Web]]></category>
		<category><![CDATA[web standards]]></category>
		<category><![CDATA[.net]]></category>
		<category><![CDATA[aspx]]></category>
		<category><![CDATA[c#]]></category>
		<category><![CDATA[csharp]]></category>
		<category><![CDATA[xml]]></category>
		<category><![CDATA[xsd]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1127</guid>
		<description><![CDATA[C# è ormai un linguaggio diffuso, Visual Studio volenti o nolenti è un IDE collaudato e comodo anche per lo sviluppo di applicazioni web. E quando si parla di web, si parla spesso di XML. Leggere i dati di un documento XML è un'operazione semplice e veloce, farli visualizzare su una pagina web è altrettanto rapido, ma è bene sapere alcune nozioni per potersi muovere con tranquillità e sicurezza.]]></description>
			<content:encoded><![CDATA[<p><strong>C#</strong> è ormai un linguaggio diffuso, <strong>Visual Studio</strong> volenti o nolenti è un IDE collaudato e comodo anche per lo sviluppo di applicazioni web. E quando si parla di web, si parla spesso di <strong>XML</strong>.</p>
<p>Leggere i dati di un documento XML è un&#8217;operazione semplice e veloce, farli visualizzare su una pagina web è altrettanto rapido, ma è bene sapere alcune nozioni per potersi muovere con tranquillità e sicurezza.</p>
<p>Andiamo con ordine e vediamo subito un esempio di un file XML che vogliamo trattare:</p>
<p><code>&lt;?xml version="1.0" encoding="ISO-8859-1" ?&gt;<br />
&lt;DataSet&gt;<br />
&lt;data&gt;<br />
&lt;period&gt;2010-06-06&lt;/period&gt;<br />
&lt;logunit id="myID"&gt;Milano&lt;/logunit&gt;<br />
&lt;entered matcode="ABC001"&gt;100&lt;/entered&gt;<br />
&lt;produced matcode="ABC002"&gt;101&lt;/produced&gt;<br />
&lt;delivered matcode="ABC002"&gt;100&lt;/delivered&gt;<br />
&lt;description&gt;Caramelline alla fragola&lt;/description&gt;<br />
&lt;updated&gt;2010-06-06T13:05:21+01:00&lt;/updated&gt;<br />
&lt;note&gt;tante belle cose..&lt;/note&gt;<br />
&lt;/data&gt;<br />
&lt;data&gt;<br />
[..]<br />
&lt;/data&gt;<br />
&lt;/DataSet&gt;</code></p>
<p>Questo file potrebbe rappresentare dei dati produttivi, riguardanti ad esempio i materiali entrati in magazzino, i materiali prodotti e il venduto.</p>
<p>Il modo più rapido e banale per leggere questo file e farlo visualizzare su una pagina ASPX è tramite il seguente codice:</p>
<p><code>DataSet ds = new DataSet();<br />
ds.ReadXml(@"C:\test.xml", XmlReadMode.Auto);<br />
DataView MyDataView = new DataView(ds.Tables[0]);<br />
MyDataGrid.DataSource = MyDataView;<br />
MyDataGrid.DataBind();</code></p>
<p>Il codice non fa altro che creare un nuovo DataSet per contenere i dati che andremo a leggere, leggere il file tramite il metodo ReadXml(), creare una DataView con la tabella creata nel dataset e assegnare quest&#8217;ultima come DataSource per la DataGrid.</p>
<p><span id="more-1127"></span></p>
<p>All&#8217;interno della pagina .aspx ci sarà quindi una DataSource così fatta:</p>
<p><code>&lt;asp:DataGrid id="MyDataGrid" runat="server" &gt;<br />
    &lt;HeaderStyle CssClass="th"&gt;<br />
    &lt;/HeaderStyle&gt;<br />
&lt;/asp:DataGrid&gt;</code></p>
<p>Tralasciamo lo stile attribuito alla testata della datagrid, ciò che è importante in questo caso è solo l&#8217;ID. </p>
<p>Così facendo però ottengo una tabella di questo tipo:</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>period</td>
<td>data_Id</td>
<td>description</td>
<td>updated</td>
<td>note</td>
</tr>
<tr>
<td>2010-06-06</td>
<td>0</td>
<td>Caramelline alla fragola</td>
<td>2010-06-16T13:05:21+01:00</td>
<td>tante belle cose..</td>
</tr>
</tbody>
</table>
<p>E tutti gli altri dati che fine hanno fatto? Sono stati salvati in altre tabelle del DataSet, assieme a tutti gli attributi dell&#8217;xml; queste tabelle avranno come riferimento il <em>data_Id</em> e potrò utilizzarle come meglio credo.</p>
<p>Se infatti cambiamo il primo codice, mettendo una tabella diversa, in questo modo:</p>
<p><code>DataView MyDataView = new DataView(ds.Tables[1]);</code></p>
<p>Verrà visualizzata una pagina con la seguente tabella:</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>id</td>
<td>logunit_Text</td>
<td>data_Id</td>
</tr>
<tr>
<td>MyID</td>
<td>Milano</td>
<td>0</td>
</tr>
</tbody>
</table>
<p>Se cambio e metto la terza tabella:</p>
<p><code>DataView MyDataView = new DataView(ds.Tables[2]);</code></p>
<p>Il risultato sarà:</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>matcode</td>
<td>entered_Text</td>
<td>data_Id</td>
</tr>
<tr>
<td>ABC001</td>
<td>100</td>
<td>0</td>
</tr>
</tbody>
</table>
<p>Mentre per le tabelle successive, avrò questi risultati visualizzati:</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>matcode</td>
<td>produced_Text</td>
<td>data_Id</td>
</tr>
<tr>
<td>ABC002</td>
<td>101</td>
<td>0</td>
</tr>
</tbody>
</table>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>matcode</td>
<td>delivered_Text</td>
<td>data_Id</td>
</tr>
<tr>
<td>ABC002</td>
<td>100</td>
<td>0</td>
</tr>
</tbody>
</table>
<p>Incrociando queste tabelle attraverso il campo <em>data_Id</em> potrei ricavare tutti i dati contenuti nell&#8217;XML, attributi e testi all&#8217;interno dei tag.<br />
Il mio obiettivo era però quello di far visualizzare questi dati senza gli attributi riportati nell&#8217;XML. Ciò che mi interessa sono solo i dati riportati all&#8217;interno dei tag. Vorrei avere un risultato di questo tipo:</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>period</td>
<td>description</td>
<td>updated</td>
<td>note</td>
<td>logunit</td>
<td>entered</td>
<td>produced</td>
<td>delivered</td>
</tr>
<tr>
<td>2010-06-06</td>
<td>Caramelline alla fragola</td>
<td>2010-06-16T13:05:21+01:00</td>
<td>tante belle cose..</td>
<td>Milano</td>
<td>100</td>
<td>101</td>
<td>100</td>
</tr>
</tbody>
</table>
<p>In questo caso potrebbe fare al caso nostro l&#8217; <a title="XML Schema" href="http://www.w3schools.com/schema/default.asp" target="_blank">XML Schema</a>. Si tratta di un file con estensione XSD, che descrive i dati contenuti in un file XML. Ogni file XML può avere uno schema associato che lo descrive. Esistono diversi <strong>tool</strong> che possono <strong>creare un file XSD a partire da un XML</strong>, uno di questi, che trovo molto pratico è <a title="XML 2 XSD" href="http://www.flame-ware.com/products/xml-2-xsd/default.aspx" target="_blank">quello di Flame-Ware</a> completamente on-line. </p>
<p>Il nostro file XML iniziale potrebbe essere descritto da questo XSD, supponendo che tutti i campi siano stringe.</p>
<p><code>&lt;?xml version="1.0"?&gt;<br />
&lt;!-- Generated using Flame-Ware Solutions XML-2-XSD v2.0 at <a href="http://www.flame-ware.com/Products/XML-2-XSD/">http://www.flame-ware.com/Products/XML-2-XSD/</a> --&gt;<br />
&lt;xs:schema id="DataSet" xmlns="" xmlns:xs="<a href="http://www.w3.org/2001/XMLSchema">http://www.w3.org/2001/XMLSchema</a>" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"&gt;<br />
  &lt;xs:element name="DataSet" msdata:IsDataSet="true" msdata:UseCurrentLocale="true"&gt;<br />
    &lt;xs:complexType&gt;<br />
      &lt;xs:choice minOccurs="0" maxOccurs="unbounded"&gt;<br />
        &lt;xs:element name="data"&gt;<br />
          &lt;xs:complexType&gt;<br />
            &lt;xs:sequence&gt;<br />
              &lt;xs:element name="period" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="description" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="updated" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="note" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="logunit" nillable="true" minOccurs="0" maxOccurs="unbounded"&gt;<br />
                &lt;xs:complexType&gt;<br />
                  &lt;xs:simpleContent msdata:ColumnName="logunit_Text" msdata:Ordinal="1"&gt;<br />
                    &lt;xs:extension base="xs:string"&gt;<br />
                      &lt;xs:attribute name="id" type="xs:string" /&gt;<br />
                    &lt;/xs:extension&gt;<br />
                  &lt;/xs:simpleContent&gt;<br />
                &lt;/xs:complexType&gt;<br />
              &lt;/xs:element&gt;<br />
              &lt;xs:element name="entered" nillable="true" minOccurs="0" maxOccurs="unbounded"&gt;<br />
                &lt;xs:complexType&gt;<br />
                  &lt;xs:simpleContent msdata:ColumnName="entered_Text" msdata:Ordinal="1"&gt;<br />
                    &lt;xs:extension base="xs:string"&gt;<br />
                      &lt;xs:attribute name="matcode" type="xs:string" /&gt;<br />
                    &lt;/xs:extension&gt;<br />
                  &lt;/xs:simpleContent&gt;<br />
                &lt;/xs:complexType&gt;<br />
              &lt;/xs:element&gt;<br />
              &lt;xs:element name="produced" nillable="true" minOccurs="0" maxOccurs="unbounded"&gt;<br />
                &lt;xs:complexType&gt;<br />
                  &lt;xs:simpleContent msdata:ColumnName="produced_Text" msdata:Ordinal="1"&gt;<br />
                    &lt;xs:extension base="xs:string"&gt;<br />
                      &lt;xs:attribute name="matcode" type="xs:string" /&gt;<br />
                    &lt;/xs:extension&gt;<br />
                  &lt;/xs:simpleContent&gt;<br />
                &lt;/xs:complexType&gt;<br />
              &lt;/xs:element&gt;<br />
              &lt;xs:element name="delivered" nillable="true" minOccurs="0" maxOccurs="unbounded"&gt;<br />
                &lt;xs:complexType&gt;<br />
                  &lt;xs:simpleContent msdata:ColumnName="delivered_Text" msdata:Ordinal="1"&gt;<br />
                    &lt;xs:extension base="xs:string"&gt;<br />
                      &lt;xs:attribute name="matcode" type="xs:string" /&gt;<br />
                    &lt;/xs:extension&gt;<br />
                  &lt;/xs:simpleContent&gt;<br />
                &lt;/xs:complexType&gt;<br />
              &lt;/xs:element&gt;<br />
            &lt;/xs:sequence&gt;<br />
          &lt;/xs:complexType&gt;<br />
        &lt;/xs:element&gt;<br />
      &lt;/xs:choice&gt;<br />
    &lt;/xs:complexType&gt;<br />
  &lt;/xs:element&gt;<br />
&lt;/xs:schema&gt;</code></p>
<p>Per associare questo schema al file XML, è necessario dichiararlo nell&#8217;intestazione, in questo modo:</p>
<p><code>&lt;?xml version="1.0" encoding="ISO-8859-1" ?&gt;<br />
&lt;DataSet <span style="color: #800000;">xmlns:xsi="</span><a href="http://www.w3.org/2001/XMLSchema-instance"><span style="color: #800000;">http://www.w3.org/2001/XMLSchema-instance</span></a><span style="color: #800000;">"<br />
xsi:noNamespaceSchemaLocation="schema.xsd"</span>&gt;<br />
&lt;data&gt;<br />
&lt;period&gt;2010-06-06&lt;/period&gt;<br />
&lt;logunit id="myID"&gt;Milano&lt;/logunit&gt;<br />
&lt;entered matcode="ABC001"&gt;100&lt;/entered&gt;<br />
&lt;produced matcode="ABC002"&gt;101&lt;/produced&gt;<br />
&lt;delivered matcode="ABC002"&gt;100&lt;/delivered&gt;<br />
&lt;description&gt;Caramelline alla fragola&lt;/description&gt;<br />
&lt;updated&gt;2010-06-06T13:05:21+01:00&lt;/updated&gt;<br />
&lt;note&gt;tante belle cose..&lt;/note&gt;<br />
&lt;/data&gt;<br />
&lt;/DataSet&gt;</code></p>
<p>Così facendo però, se rilanciamo la pagina costruita in precedenza, il risultato sarà identico: un unico dataset con diverse tabelle collegate tra loro dal campo <em>data_Id</em>.</p>
<p>Quindi? La soluzione c&#8217;è. <strong>Dobbiamo solo definire uno schema XSD semplificato all&#8217;interno dell&#8217;XML stesso</strong>. In questo modo:</p>
<p><code>&lt;?xml version="1.0" encoding="ISO-8859-1" ?&gt;<br />
&lt;DataSet&gt;<br />
<span style="color: #800000;">&lt;xs:schema id="NewDataset" xmlns="" xmlns:xs="</span><a href="http://www.w3.org/2001/XMLSchema"><span style="color: #800000;">http://www.w3.org/2001/XMLSchema</span></a><span style="color: #800000;">" xmlns:msdata="urn:schemas-microsoft-com:xml-msdata"&gt;<br />
  &lt;xs:element name="NewDataset" msdata:IsDataSet="true" msdata:UseCurrentLocale="true"&gt;<br />
    &lt;xs:complexType&gt;<br />
      &lt;xs:choice minOccurs="0" maxOccurs="unbounded"&gt;<br />
        &lt;xs:element name="data"&gt;<br />
          &lt;xs:complexType&gt;<br />
            &lt;xs:sequence&gt;<br />
              &lt;xs:element name="period" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="description" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="updated" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="note" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="logunit" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="entered" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="produced" type="xs:string" minOccurs="0" /&gt;<br />
              &lt;xs:element name="delivered" type="xs:string" minOccurs="0" /&gt;<br />
            &lt;/xs:sequence&gt;<br />
          &lt;/xs:complexType&gt;<br />
        &lt;/xs:element&gt;<br />
      &lt;/xs:choice&gt;<br />
    &lt;/xs:complexType&gt;<br />
  &lt;/xs:element&gt;<br />
&lt;/xs:schema&gt;<br />
</span>&lt;data&gt;<br />
&lt;period&gt;2010-06-06&lt;/period&gt;<br />
&lt;logunit id="myID"&gt;Milano&lt;/logunit&gt;<br />
&lt;entered matcode="ABC001"&gt;100&lt;/entered&gt;<br />
&lt;produced matcode="ABC002"&gt;101&lt;/produced&gt;<br />
&lt;delivered matcode="ABC002"&gt;100&lt;/delivered&gt;<br />
&lt;description&gt;Caramelline alla fragola&lt;/description&gt;<br />
&lt;updated&gt;2010-06-06T13:05:21+01:00&lt;/updated&gt;<br />
&lt;note&gt;tante belle cose..&lt;/note&gt;<br />
&lt;/data&gt;<br />
&lt;data&gt;<br />
&lt;period&gt;2010-06-06&lt;/period&gt;<br />
&lt;logunit id="myID"&gt;Milano&lt;/logunit&gt;<br />
&lt;entered matcode="ABC001"&gt;100&lt;/entered&gt;<br />
&lt;produced matcode="ABC002"&gt;101&lt;/produced&gt;<br />
&lt;delivered matcode="ABC002"&gt;100&lt;/delivered&gt;<br />
&lt;description&gt;Caramelline alla fragola&lt;/description&gt;<br />
&lt;updated&gt;2010-06-06T13:05:21+01:00&lt;/updated&gt;<br />
&lt;note&gt;tante belle cose..&lt;/note&gt;<br />
&lt;/data&gt;<br />
&lt;/DataSet&gt;</code></p>
<p>Il <strong>risultato finale</strong> sarà quindi una DataGrid che può essere visualizzata come sotto, utilizzando pari pari il <strong>codice C# definito all&#8217;inizio</strong> di questo articolo.</p>
<table id="MyDataGrid2" border="1" cellspacing="0" rules="all">
<tbody>
<tr>
<td>period</td>
<td>description</td>
<td>updated</td>
<td>note</td>
<td>logunit</td>
<td>entered</td>
<td>produced</td>
<td>delivered</td>
</tr>
<tr>
<td>2010-06-06</td>
<td>Caramelline alla fragola</td>
<td>2010-06-16T13:05:21+01:00</td>
<td>tante belle cose..</td>
<td>Milano</td>
<td>100</td>
<td>101</td>
<td>100</td>
</tr>
</tbody>
</table>
<p>Buon divertimento con l&#8217;XML..</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=TVw5kcX-NBU:E63UtOR_xDE:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=TVw5kcX-NBU:E63UtOR_xDE:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=TVw5kcX-NBU:E63UtOR_xDE:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/07/13/leggere-e-visualizzare-file-xml-con-c-c-sharp-qualche-esempio/feed/</wfw:commentRss>
		<slash:comments>1</slash:comments>
		</item>
		<item>
		<title>Intranet Governance: intervista a Jane McConnel</title>
		<link>http://www.diplod.it/2010/06/02/intranet-governance-intervista-a-jane-mcconnel/</link>
		<comments>http://www.diplod.it/2010/06/02/intranet-governance-intervista-a-jane-mcconnel/#comments</comments>
		<pubDate>Wed, 02 Jun 2010 22:42:44 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[ICT]]></category>
		<category><![CDATA[Web 2.0]]></category>
		<category><![CDATA[Blog]]></category>
		<category><![CDATA[enterprise20]]></category>
		<category><![CDATA[gestionale]]></category>
		<category><![CDATA[intervista]]></category>
		<category><![CDATA[intranet]]></category>
		<category><![CDATA[mcconnel]]></category>
		<category><![CDATA[wiki]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1117</guid>
		<description><![CDATA[Da un po' di tempo sono alle prese con lo sviluppo e la gestione di una intranet concepita per una azienda che ha filiali worldwide, ne ho approfittato per chiedere qualche consiglio a Jane McConnel, speaker dell'Enterprise 2.0 Forum.]]></description>
			<content:encoded><![CDATA[<p><a href="http://netjmc.com/intranet-trends-report/download-sample-pages-purchase-information" target="_blank">Global Intranet Strategies</a> è il report che ogni anni <strong>Jane McConnel</strong> produce dopo aver passato in rassegna diverse intranet aziendali, lo diffonde direttamente dal suo <a title="Jane McConnel" href="http://netjmc.com/blog" target="_blank">blog</a> (Globally Local.. Locally Global). Quest&#8217;anno Jane sarà presente come relatrice all&#8217;<strong><a title="E2.0 forum" href="http://www.enterprise2forum.it/">International Enterprise 2.0 Forum</a></strong>, il 9-10 Giugno a Milano; vista l&#8217;occasione scambiamo con lei qualche battuta. Una chiacchierata sulle modalità di governance e di gestione di una <em>robusta </em>intranet aziendale. Da un po&#8217; di tempo sono alle prese con lo sviluppo e la gestione di una intranet concepita per una azienda che ha filiali worldwide, ne ho approfittato per chiedere qualche consiglio. La <a title="Davide Del Monte Interviews Jane McConnel" href="http://www.enterprise2forum.it/it/node/190" target="_blank">stessa intervista</a>, nella versione inglese, la troverete sul blog dell&#8217;<em>E2.0 Forum</em>.</p>
<p><em><strong>Davide</strong></em><strong>: Che cosa dovrebbe avere una buona intranet?</strong><br />
<em> Jane</em>: Una buona intranet deve avere 3 cose:</p>
<ol>
<li>essere incentrata sull&#8217;utente,</li>
<li>avere una strategia allineata al business</li>
<li>Avere una governance e politiche di gestione integrate al modo con cui viene gestita l&#8217;impresa</li>
</ol>
<p><span id="more-1117"></span></p>
<p><strong><em> Davide</em>: Quali sono le best practices per adottare l&#8217;enterprise 2.0? Esiste una roadmap comune?</strong><br />
<em> Jane</em>: Ma dispiace ma non esistono roadmap comuni e collaudate. Alcune aziende definiscono prima la strategia, poi la implementano. Altre iniziano con sperimentazioni dal basso, poi ufficializzano ciò che funziona. Altri mettono in campo un minimo di strategia e un po&#8217; di sperimentazione dal basso, per poi farne una sintesi!</p>
<p>La chiave del successo è iniziare da ciò che è necessario al business, non dalla tecnologia. Fate progetti pilota dove c&#8217;è allo stesso tempo un bisogno e una sfida.</p>
<p><strong><em>Davide</em>: Wiki e blog dovrebbero essere utilizzati in una intranet? Se si, esiste un approccio da consigliare per spiegare agli utenti qual è il tool migliore da utilizzare , in base ai contenuti da pubblicare e al feedback che si desidera ricevere?</strong><br />
<em>Jane</em>: I Wiki servono per la co-creazione: fare cose assieme, fornendo uno strumenti per  &#8221;la voce del popolo&#8221;. Sono di proprietà del popolo o del singolo gruppo. Sono multi-dimensionali: i contenuti si creano spontaneamente. Potrebbero emergere talvolta anche cose inattese.<br />
I blog servono per fare esprimere una voce individuale, il punto di vista di un team, per condividere l&#8217;esperienza. Si fanno portatori del punto di vista di un singolo o di un gruppo di persone. Sono bi-dimensionali: viene riportato un certo punto di vista o una notizia, mentre tutte le altre persone possono commentare o fare domande.<br />
E&#8217; interessante notare che le mie ricerche degli ultimi anni, condotte per la Global Intranet Strategies survey, evidenziano che solo nell&#8217;ultimo anno i blog hanno assunto rilevanza al pari dei wiki nelle aziende. Entrambi hanno raggiunto il 45 % dell&#8217;utilizzo nell&#8217;inchiesta del 2009, su un campione di circa 300 organizzazioni in tutto il mondo.<br />
Fino all&#8217;anno scorso, i wiki la facevano da padrone. Credo che le società stiano famigliarizzando coi blog. I blog ottengono spesso più visibilità: persone che esprimono punti di vista. Richiedono probabilmente maggior tempo per la gestione rispetto ai wiki, basati sulla collaborazione, cosa che le imprese fanno da diverso tempo.</p>
<p><strong><em>Davide</em>: Connessioni col sistema ERP: è utile averle all&#8217;interno della intranet?</strong><br />
<em>Jane</em>: Assolutamente. Più che utile, è essenziale. E&#8217; la chiave di volta per far sì che la intranet diventi il luogo di lavoro all&#8217;interno dell&#8217;impresa.</p>
<p><strong><em>Davide</em>: Credi che esista una killing application? Si parla spesso di Sharepoint.. Lavoro su Sharepoint da quasi due anni, credo che sia una buona piattaforma per realizzare applicazioni web, molto malleabile per poter mappare i processi di business</strong><br />
<em>Jane</em>: Sharepoint è solo una delle tante soluzioni. Non penso che una soluzione da sola si possa considerare una killer app.</p>
<p><strong><em>Davide</em>: Accesso dall&#8217;esterno e tramite dispositivi mobili: credi che sia un obiettivo primario?</strong><br />
<em>Jane</em>: Non è primario ma è molto importante. E&#8217; uno dei 5 key trends che ho individuato per il 2010.</p>
<p><em><strong>Davide</strong></em><strong>: Qual è il miglior progetto che hai realizzato? Perchè?</strong><br />
<em>Jane</em>: Ce ne sono parecchi! I migliori sono quelli in cui la intranet ha cambiato il modo di lavorare dell&#8217;azienda, e il modo di fare business. La intranet esiste, in estrema sintesi, per servire i clienti. Per clienti, intendo i clienti esterni.<br />
Le intranet aiutano le organizzazioni a lavorare meglio: le aziende lavorano per servire i loro clienti.</p>
<p><strong><em>Davide</em>: Grazie mille per questa intervista Jane, spero di sentire qualche utile consiglio all&#8217;E2.0 Forum!</strong></p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=RpuFgTkK0AQ:t6oUqBSRwmQ:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=RpuFgTkK0AQ:t6oUqBSRwmQ:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=RpuFgTkK0AQ:t6oUqBSRwmQ:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/06/02/intranet-governance-intervista-a-jane-mcconnel/feed/</wfw:commentRss>
		<slash:comments>3</slash:comments>
		</item>
		<item>
		<title>100 mila persone per strada!</title>
		<link>http://www.diplod.it/2010/05/17/100-mila-persone-per-strada/</link>
		<comments>http://www.diplod.it/2010/05/17/100-mila-persone-per-strada/#comments</comments>
		<pubDate>Sun, 16 May 2010 23:20:50 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Fuori Tema]]></category>
		<category><![CDATA[assisi]]></category>
		<category><![CDATA[Informazione]]></category>
		<category><![CDATA[inter]]></category>
		<category><![CDATA[media]]></category>
		<category><![CDATA[pace]]></category>
		<category><![CDATA[perugia]]></category>
		<category><![CDATA[rai]]></category>
		<category><![CDATA[scudetto]]></category>
		<category><![CDATA[stadi]]></category>
		<category><![CDATA[violenza]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1112</guid>
		<description><![CDATA[Domenica italiana. 100.000 persone marciano da Perugia ad Assisi per chiedere a gran voce un mondo di Pace ed uguaglianza sociale; assieme a migliaia di studenti delle scuole italiane e a innumerevoli &#8220;testimoni&#8221; venuti da diverse nazioni del mondo, assieme a Don Ciotti di Libera e all&#8217;AVIS: il tutto mediamente ignorato dai media e dall&#8217;italiano [...]]]></description>
			<content:encoded><![CDATA[<p>Domenica italiana.</p>
<p><a title="per la pace" href="http://www.perlapace.it/index.php?id_article=4352" target="_blank">100.000 persone marciano da Perugia ad Assisi</a> per chiedere a gran voce un mondo di Pace ed uguaglianza sociale; assieme a migliaia di studenti delle scuole italiane e a innumerevoli &#8220;testimoni&#8221; venuti da diverse nazioni del mondo, assieme a Don Ciotti di <a title="Libera" href="http://www.libera.it" target="_blank">Libera </a>e all&#8217;<a title="AVIS" href="http://www.avis.it/" target="_blank">AVIS</a>: il tutto <em>mediamente </em>ignorato dai <em>media </em>e dall&#8217;italiano <em>medio</em>.</p>
<p>100.000 persone si riversano nelle strade di Milano per festeggiare lo scudetto dell&#8217;inter tra petardi, fumogeni e dita <em>medi</em> al cielo, il tutto in diretta RAI e idolatrato dall&#8217;italiano <em>medio</em>; che allo stadio ci vuole il ferro.</p>
<p><object width="480" height="385"><param name="movie" value="http://www.youtube.com/v/HB_lOaEfDfA&#038;hl=it_IT&#038;fs=1&#038;"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/HB_lOaEfDfA&#038;hl=it_IT&#038;fs=1&#038;" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="640" height="385"></embed></object></p>
<p><object width="480" height="385"><param name="movie" value="http://www.youtube.com/v/t9VSzO2BTRg&#038;hl=it_IT&#038;fs=1&#038;"></param><param name="allowFullScreen" value="true"></param><param name="allowscriptaccess" value="always"></param><embed src="http://www.youtube.com/v/t9VSzO2BTRg&#038;hl=it_IT&#038;fs=1&#038;" type="application/x-shockwave-flash" allowscriptaccess="always" allowfullscreen="true" width="480" height="385"></embed></object></p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=hizEt8klsyY:RGgILb5pdXU:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=hizEt8klsyY:RGgILb5pdXU:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=hizEt8klsyY:RGgILb5pdXU:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/05/17/100-mila-persone-per-strada/feed/</wfw:commentRss>
		<slash:comments>0</slash:comments>
		<georss:point featurename="assisi">43.0701666 12.6175185</georss:point>
	</item>
		<item>
		<title>Ricerche Maestre: il design di un motore di ricerca</title>
		<link>http://www.diplod.it/2010/05/06/ricerche-maestre-il-design-di-un-motore-di-ricerca/</link>
		<comments>http://www.diplod.it/2010/05/06/ricerche-maestre-il-design-di-un-motore-di-ricerca/#comments</comments>
		<pubDate>Thu, 06 May 2010 16:36:13 +0000</pubDate>
		<dc:creator>Davide</dc:creator>
				<category><![CDATA[Design]]></category>
		<category><![CDATA[bambini]]></category>
		<category><![CDATA[Google]]></category>
		<category><![CDATA[maestre]]></category>
		<category><![CDATA[ricerche]]></category>
		<category><![CDATA[scuola]]></category>
		<category><![CDATA[webdesign]]></category>

		<guid isPermaLink="false">http://www.diplod.it/?p=1090</guid>
		<description><![CDATA[Ricerche Maestre è un motore di ricerca per bambini, genitori e maestri che seleziona siti scelti da esperti insegnanti della Scuola Primaria. Si possono trovare risorse scolastiche per la scuola elementare e si può navigare all'interno di siti adatti a bambini dai 3 ai 14 anni, cercando contenuti educativi e di svago. La ricerca è immediata ed efficace. Il motore va dritto al bersaglio, tecnologia Google.]]></description>
			<content:encoded><![CDATA[<p><img class="aligncenter size-full wp-image-1105" title="ricmaestre" src="http://www.diplod.it/wp-content/uploads/2010/05/ricmaestre.png" alt="" width="380" height="250" /></p>
<p><a title="Ricerche Maestre" href="http://www.ricerchemaestre.it/" target="_blank">Ricerche Maestre</a> è un <strong>motore di ricerca</strong> per bambini, genitori e maestri che seleziona siti scelti da esperti insegnanti della Scuola Primaria. Si possono trovare risorse scolastiche <strong>per la scuola elementare</strong> e si può navigare all&#8217;interno di siti adatti a bambini dai 3 ai 14 anni, cercando contenuti educativi e di svago. La ricerca è immediata ed efficace. Il motore va dritto al bersaglio, <a title="Google co-op" href="http://www.google.com/cse/" target="_blank">tecnologia Google</a>.</p>
<p>E il <strong>design</strong>? Una paginetta che mi ha dato un sacco di soddisfazioni. Nulla di sconvolgente, ma c&#8217;era una piccola sfida da affrontare: mettere tutto  su una stessa pagina html, dal form di ricerca ai risultati, compresi i testi informativi e di corredo. Con un po&#8217; di javascript, si può.</p>
<p>Innanzi tutto, un <a title="coda slider jquery plugin" href="http://jqueryfordesigners.com/coda-slider-effect/" target="_blank">plugin di jQuery</a> per riprodurre il famoso effetto del <a title="Coda - Panic" href="http://www.panic.com/coda/" target="_blank">sito di Coda</a>. Una valida alternativa potrebbe essere <a title="coda slider javascript" href="http://www.ndoherty.biz/tag/coda-slider/" target="_blank">questo coda-slider</a>, anch&#8217;esso plugin jquery, con una buona documentazione sugli esempi demo. In secondo luogo alcuni div che contengono i risultati di ricerca ed il gioco è fatto!</p>
<p>Questo fantastico effetto è facilmente replicabile, l&#8217;idea è quella di riutilizzarlo per il prossimo tema wordpress, è un&#8217;anteprima!</p>
<p>Insomma, Ricerche Maestre è un motore di ricerca personalizzato a cura del <a href="http://www.albertopiccini.it/">Maestro Alberto Piccini</a>, al quale collaborano <a href="http://xoomer.alice.it/paolalimone/">Paola Limone</a>, <a href="http://maestralidia.netsons.org/">Lidia Pantaleo</a>, <a href="http://scientificando.splinder.com/">Annarita Ruberto</a>, <a href="http://quadernoneblu.splinder.com/">Renato Murelli</a>. Ricerche Maestre al momento indicizza circa 3.000 siti selezionati tra i migliori reperibili in rete, per bambini e famiglie, a carattere divulgativo e informativo, educativi, scolastici e di insegnanti.</p>
<p>Se avete bambini: il luogo giusto per iniziare le esplorazioni della rete!</p>
<div class="feedflare">
<a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:yIl2AUoC8zA"><img src="http://feeds.feedburner.com/~ff/diplod?d=yIl2AUoC8zA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:V_sGLiPBpWU"><img src="http://feeds.feedburner.com/~ff/diplod?i=caAiI1mDT4s:AvfgxKL4__0:V_sGLiPBpWU" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:F7zBnMyn0Lo"><img src="http://feeds.feedburner.com/~ff/diplod?i=caAiI1mDT4s:AvfgxKL4__0:F7zBnMyn0Lo" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:7Q72WNTAKBA"><img src="http://feeds.feedburner.com/~ff/diplod?d=7Q72WNTAKBA" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:dnMXMwOfBR0"><img src="http://feeds.feedburner.com/~ff/diplod?d=dnMXMwOfBR0" border="0"></img></a> <a href="http://feeds.feedburner.com/~ff/diplod?a=caAiI1mDT4s:AvfgxKL4__0:pSxILM_nRGA"><img src="http://feeds.feedburner.com/~ff/diplod?d=pSxILM_nRGA" border="0"></img></a>
</div>]]></content:encoded>
			<wfw:commentRss>http://www.diplod.it/2010/05/06/ricerche-maestre-il-design-di-un-motore-di-ricerca/feed/</wfw:commentRss>
		<slash:comments>9</slash:comments>
		</item>
	</channel>
</rss>
