Create and Use of Google Maps Webparts

Dit artikel beschrijft de mogelijkheden van een Google Maps webpart in een SharePoint Portal omgeving en hoe deze o.a. gebruikt wordt door het Spaarne Ziekenhuis. Het webpart heeft als doel het inzichtelijk maken van de huisartsen in de regio van het ziekenhuis.

Een dergelijke webpart is niet beschikbaar als standaard voor een MOSS omgeving en  is natuurlijk een leuke uitdaging om te bouwen. Rest de vraag wat heeft men allemaal nodig om dit webpart aantrekkelijk te maken en meerwaarde te geven? Vragen die hierbij naar boven kwamen waren onder andere: hoe kan men de locaties ophalen, wat voor iconen zijn intuïtief voor gebruiker en hoe wordt de plaats aangeven ...

De Vraag van de klant

Het Huisartsen-portaal wordt, onafhankelijk van het ziekenhuis, aangeboden in een eigen,  beveiligde omgeving (conform NEN-normen voor de zorg). Transport van data tussen de praktijken van huisartsen en zorginstellingen vindt plaats via een SSL-verbinding.

Het portaal (gebaseerd op het Microsoft Office SharePoint Server 2007 platform) is ontwikkeld en wordt beheerd door de afdeling ICT van het Spaarne Ziekenhuis.

Het Spaarne Ziekenhuis sponsort de ontwikkeling van dit portaal conform de wensen van de huisartsen, op basis van de bestaande technologie. Door gebruik te maken van al aanwezige techniek en kennis wordt het portaal kostenneutraal aangeboden aan de huisartsen. Het doel van het Spaarne Ziekenhuis ligt in de verbetering van de ketenzorg, waardoor zij haar interne processen verder kan optimaliseren.

Het Google Maps webpart biedt de mogelijkheid om te zien welke huisartsen in een bepaalde regio actief zijn. Daarmee toont het informatie van zorgverleners in de regio, zodat in geval van b.v. vakantie de huisarts de zorg voor een cliënt tijdelijk kan overdragen.

Waar te beginnen?

Het vertrekpunt om een Google Map webpart te bouwen is inzicht krijgen in de werking, en hiermee API, van Google Maps. Google heeft uitgebreide informatie op de volgende site: http://code.google.com/intl/nl-NL/apis/maps/documentation/

Fig. 1: Google Maps documentatie

Er zijn 3 versies van de Google API beschikbaar. Versie 2 is de meest recente productie versie. Versie 3 is een beta-versie en heeft met name voor applicaties voor de mobiele telefoon een aantal leuk features. Dit artikel is gebaseerd op het gebruik van versie 2.

De API's van Google Maps zijn goed gedocumenteerd. In deze documentatie staat ook dat er per website een API key aangevraagd moet worden. Deze aanvraag geldt per root van de site. Aanvragen en registreren van de site gaat via de signup: http://code.google.com/intl/nl-NL/apis/maps/signup.html.

Hiervoor dien je de beschikking te hebben over een Google account (zie figuur 2).

figuur 1

Fig.2: Aanmelden bij  Google Maps

Er zijn vier belangrijke punten waarop gelet moet worden bij het bouwen en deployment van het webpart.

Het eerste is dat het verwijderen of wijzigen van het webpart van/op de portal tot gevolg kan hebben dat er opnieuw een key aangevraagd moet worden. Omdat versie 3 nog in beta is, is daarvoor geen key nodig.

In deze business case wordt er de portal aangeboden via een SSL-verbinding en wordt de kaart opgevraagd in Internet Explorer 8. In deze situatie is een Premium Membership verplicht. Google heeft als doel de maps voor iedereen zichtbaar te maken.

Het derde punt is dat Google Maps voornamelijk werkt met JavaScript, wat voor het webpart inhoudt dat er HTML gerenderd moet worden.

Tenslotte worden plaatsbepalingen binnen een Google Map opgegeven (of uitgelezen) via de latitude- en longitude-coördinaten. Latitude beschrijft de locatie van een plaats op aarde ten Noorden of ten Zuiden van de evenaar, en longitude beschrijft de locatie van een plaats op aarde ten Oosten of ten Westen van een Noord-Zuid lijn (de nul meridiaan).

Tom Tom en andere navigatie apperatuur werken ook met deze gegevens om je naar de juiste plaats te brengen.

Vervolgens ben ik voor de zekerheid nog even op Codeplex gaan kijken of er niet al een kant en klare oplossing was die mij veel ontwikkeltijd zou kunnen schelen. Na het testen van verschillende mogelijkheden kwam ik elke keer met hetzelfde resultaat. Het resultaat was dat er een grijs vlak werd getoond met Google erin maar nergens een Map (dit komt waarschijnlijk omdat er wijzigingen zijn gedaan die niet getest zijn bij Google)?

Omdat de adressen van de huisartsen bekend zijn, kunnen deze coördinaten opgehaald en opgeslagen worden. De coördinaten worden bij het gebruikersprofiel van de huisarts opgeslagen (huisartsen zijn de gebruikers van het portaal).

 

TIP: een goede website om snel de coördinaten te vinden op basis van een adres is http://mygeoposition.com/

Fig. 3: MyGeoPosition levert de coordinaten voor een Google Msps locatie

Het webpart zelf

Het maken van het webpart kan eenvoudig via Visual Studio 2008. Hierbij is het aan te raden om met WSP-Builder te werken. Wanneer je WSP-Builder geïnstalleerd hebt, krijg je de mogelijkheid om projecten aan te maken van het type WSP.

Zo’n  project bestaat uit de volgende elementen:

  • een feature, bestaande uit het manifest (feature.xml) en een elements-file (elements.xml);
  • de webpart definitie (HiszMaps.webpart);
  • de webpart class (de logica).

Het vertrekpunt is het maken van een feature waarmee de webpart geïnstalleerd kan worden. Het voordeel van een feature is o.a. de herbruikbaarheid. Het manifest beschrijft de applicatie (in dit geval het webpart) en geeft aan welke elementen (files) er nodig zijn om het webpart goed te installeren.


Het manifest van de feature ziet als volgt uit.

<?xml version="1.0"encoding="utf-8"?>
<Feature xmlns="http://schemas.microsoft.com/sharepoint/"
  Id="D37F0226-5712-44b3-AF52-4E3CADB63A77"
  Version
="0.0.0.1"
  Title="SpaarneZiekenhuis HiszMaps Webpart"
  Description="Toont artsen in een Google Map."
  Scope="Site"
  ImageUrl="SZFeatureImage.gif"
  ImageUrlAltText="SpaarneZiekenhuis Feature"
  Hidden="FALSE">
  <ElementManifests>
  <!-- Verwijzingen naar element-file en webpart-file beide
       in feature directory
à
    <ElementManifest Location="elements.xml" />
    <ElementFile Location="Webparts/HiszMaps.webpart" />
  </ElementManifests>
</Feature>

In dezelfde map als het feature-manifest dient een elements-file geplaatst te worden. Hierin staat aangegeven dat het een webpart is dat in de webpartlijst beschikbaar moet komen. Deze ziet er als volgt uit:

<Elements xmlns="http://schemas.microsoft.com/sharepoint/">
  <Module Name="WebParts" List="113"
    Url="_catalogs/wp" Path="Webparts">
    <File Url="HiszMaps.webpart" Type="GhostableInLibrary">
      <Property Name="Group" Value="SpaarneZiekenhuis" />
    </File>
  </Module>
</Elements>


En als laaste het webpart-file:

<?xmlversion="1.0"encoding="utf-8"?>
<webParts>
  <webPart xmlns="http://schemas.microsoft.com/WebPart/v3">
    <metaData>
      <type name="SpaarneZiekenhuis.Core.WebParts.HiszMaps,
        SpaarneZiekenhuis.Core, Version=1.0.0.0,
        Culture=neutral,PublicKeyToken=11a665981f0e5261" />
      <importErrorMessage>
        Cannot import HiszMaps Web Part.
      </importErrorMessage>
    </metaData>
    <data>
      <properties>
        <property name="Title" type="string">
           HiszMaps Web Part
        </property>
        <property name="Description" type="string">
          Toont artsen in een Google Map.
        </property>
      </properties>
    </data>
  </webPart>
</webParts>

Het webpart-file geeft aan wat de eigenschappen zijn van het webpart en welke assembly deze moet gebruiken (type). Bij de Type Name staat de verwijzing naar de code class,  in dit geval dus “SpaarneZiekenhuis.Core.Webparts.HiszMaps”.

Het totaal plaatje van de feature ziet er nu zo uit:

Fig. 4: Naam van het webpart-file

De Webpart Class

De class Hiszmaps erft over van de System.Web.UI.WebControls.WebParts.WebPart. In de class zijn de volgende properties gedefineerd.

  • apiKey: key die Google nodig heeft om te kunnen valideren;
  • mapWidth: breedte van het webpart in totaal;
  • mapHeight: hoogte  van het webpart in totaal;
  • zoomLevel: dit is in hoeverre de map ingezoomd is tussen 1 en 19;
  • infoWindowHtml: dit is om de HTML van de getoonde ballon aan te kunnen passen;
  • Longitude: de longitude van de beginplek;
  • Latitude: de latitude van de beginplek;
  • MapType: de manier waarop Google de kaart laat zien (road, satelite of hybride).

Indien het mogelijk moet zijn om een van de eigenschapen van het webpart te kunnen wijzigen via het (web)interface, kun je de volgende code gebruiken:

[Personalizable(PersonalizationScope.Shared),
  WebBrowsable(true),
  Category("Hiszmaps"),
  WebDisplayName("google Api key"),
  WebDescription("google api key")]
Public string APIKey
{
  Get {return _apiKey; }
  Set {_apiKey = value; }
}

Uiteindelijk ziet het editor-window er dan zo uit:

Fig. 5: Editen van properties van het webpart

Om de Google Map op het webpart te tonen dient eerst een instantie van het GooglemapControl.GMapControl aangemaakt te worden. In de  CreateChildControls-functie word de class GMapControl aangeroepen en de properties van de GMapControl gevuld. Vervolgens wordt de control toegevoegd aan de controls-collection van de pagina.

Protected override void CreateChildControls()
{
// add map
  GooglemapControl.GMapControl gM = new
  GooglemapControl.GMapControl(MapWidth,MapHeight);
  gM.GoogleMapLicense = APIKey;
  gM.WidthMap = MapWidth;
  gM.HeightMap = MapHeight;
  Width = MapWidth;
  Height = MapHeight;
  gM.Enabled = true;
  gM.InfoWindowHtml = InfoWindowHtml;
  gM.Markers = GetHuisartsAddresses();
  gM.zoomLevel = ZoomLevel;
  gM.mapThemeType = mapThemeType;
  Controls.Add(gM);
  base.CreateChildControls();
}

De eigenschappen van het GMapControl zijn instelbaar, doordat deze via de webparteigenschappen doorgegeven worden. De werking wordt verderop uitgelegd dit artikel.

De volgende eigenschappen zijn van belang voor de GMapControl:

  • GoogleMapLicence: licentie die je aan kunt vragen bij Google (hier een Premium Member licentie);
  • WidthMap: breedte van het Google Map kaartje;
  • HeightMap: hoogte van het Google Map kaartje;
  • Enabled: mogelijkheid om in/uit te zoomen, te scrollen binnen het kaartje;
  • InfoWindowHtml: stukje tekst (in HTML) met informatie over het kaartje;
  • Markers: posities die in het kaartje moet worden aangezet;
  • ZoomLevel: standaard percentage waarop ingezoomd wordt;
  • MapThemeType: manier waarop het kaartje getoond moet worden; hier kan gekozen worden voor Hybrid, Satellite en Normal.

Om de huisartsenposten te laten zien in de kaart wordt bij gM.Markers de methode Gethuisartsaddresses() aangeroepen. Deze methode geeft een Arraylist terug van alle namen en posities van de huisartsen.

Vervolgens, om de HTML en bijbehorende JavaScript te genereren van het webpart wordt, de Render-functie aangeroepen.

Protected override void Render(HtmlTextWriter writer)
{
  Try
  {
    string str = "";
    writer.Write(str);
    RenderChildren(writer);
    ClientScriptManager csm = Page.ClientScript;
    csm.RegisterStartupScript(this.GetType(), "refreshMap",
      "<script>map.checkResize(); </script>");
  }
  catch (Exception ex)
  {
    //log to file splogger…
  }
}

Door een ClientScriptManager toe te voegen aan de  pagina wordt de uiteindelijke Javascript beschikbaar gemaakt voor de gebruiker.

Nu de webpart-class klaar is kunnen we verder met de GmapControl-class.

GMapControl-class

Bovenaan de class wordt de Control gegenereerd ,in dit geval dus de GmapControl.

De class erft over van de Webcontrol.

[DefaultProperty("Text")]
[ToolboxData
  ("<{0}:GMapControl runat=server></{0}:GMapControl>")]
//generates custom control

Public class GMapControl : WebControl

In deze control worden dezelfde eigenschappen opgenomen als in het webpart, zodat het kaartje met de juiste informatie wordt gegenereerd.

In deze class wordt in een functie het hele script voor de Google Map control opgebouwd. De JavaScript code wordt middels een StringBuilder opgebouwd.

TIP:  string.Format is een goede manier om code goed leesbaar te houden en fouten te voorkomen; let op dat als je de accolade wilt gebruiken in je script dat je ze dan dubbel neerzet, anders gaan ze verloren in het generen van je code

Een Google Map wordt middels een JavaScript- include op het scherm geplaatst. Het script begint met het toevoegen van deze reference-url:

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"<script
    src=""http://maps.google.com/maps?file=api&v=2&key={0}""
    type=""Text/javascript""></script>"
,
  GoogleMapLicense))

Om de map te tonen is het nodig om in de pagina de locatie aan te geven. Dit gebeurt middels een DIV-tag met een bepaalde Id. De Google Map wordt op de locatie van deze DIV-tag getoond.

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"<div
    id=""large-google-map""
    style=""width:{0}px;height:{1}px;""></div>"
,
  WidthMap, HeightMap));

Voor de posities van de adressen (markers) wordt een hidden textbox geplaatst.

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"<input name=""markers"" runat=""server"" 
    id=""markers"" type=""hidden"" value="""">

  <input name=""marks"" runat=""server"" id=""marks""
   type=""hidden"" value="""">
));

Vervolgens wordt een blokje JavaScript gegenereerd waar het Array in een variabele wordt geplaatst. Hiervoor wordt door de profielen van de huisartsen gegaan en de informatie in het array geplaatst.

Script.Append(string.Format(CultureInfo.InvariantCulture,
  <script type=""Text/javascript"">

    //Global variables
    var gmarkers = [];
    var map;
    var data = ["));

//loop trough all the huisartsen for creation
//of the markers

foreach (HuisArtsProfile huisArts in Markers)
{
  Script.Append(string.Format(CultureInfo.InvariantCulture,
    @"{{account:""{0}"", naam:""{1}"", adres:""{2}"",
    postcode:""{3}"", plaats:""{4}"" , tel:""{5}"",

    email:""{6}"", latitude:""{7}"",
    longitude:""{8}""}},"
,
    huisArts.Account,
    huisArts.Name,
    huisArts.Address,
    huisArts.PostalCode,
    huisArts.City,
    huisArts.WorkPhone,
    huisArts.WorkEmail,
    huisArts.Latitude,
    huisArts.Longitude));
}
Script.Append("];");

De volgende stap is het opbouwen van de JavaScript functie GoogleMapLoad(). Dit is een standaard functie die GoogleMaps nodig heeft om de kaart te tonen op de pagina.

Belangrijk is dat de grootte van de nieuwe map wordt meegegeven; als deze namelijk vergeten wordt, is het niet mogelijk de map netjes te centreren. Dit resulteert in een grijze layer en de standaard lokatie (home) wordt niet op de juiste plaats aangegeven:

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"
  function GoogleMapLoad() {{
    if (GBrowserIsCompatible())
    {{
      var map = new GMap2(document.getElementById(""{3}""),
      {{ size: new   GSize({5}, {6}) }});

      var zoomLevel =  parseInt({4});
      var point = new GLatLng(52.325243,4.653537);
      map.setCenter(point,zoomLevel, {7});
      map.addControl(new GMapTypeControl());
      map.addControl(new GLargeMapControl());
      var geocoder = new GClientGeocoder();
      showMarker(map, geocoder, """",
        ""Spaarne Ziekenhuis"", ""Spaarnepoort  1"", """",
        ""Hoofddorp"", """", """",
        52.325243, 4.653537, spaarneicon);

      for(var i = 0; i < data.length; i++)
      {{
        var account = data[i].account;
        var name = data[i].naam;
        //etc..
        showMarker(map, geocoder, account, name, address,
          postalcode, city, phone, email, latitude,
          longitude, icon);
 

      }}
    }};
  }};",
  GoogleMapLicense, //0
  longtitude,//1
  latitude,   //2
  "large-google-map", //3
  zoomLevel, // 4
  WidthMap.ToString(), //5
  HeightMap.ToString(),//6
  mapThemeType));//7

Hier komt ook de referentie terug op basis van het Id naar de DIV-tag, die we eerder hebben toegevoegd.

In deze code word de Showmarker-functie aangeroepen. Dit is een standaard functie van GoogleMaps waar de marker (positieaanduiding) wordt geplaatst. Deze functie wordt voor 2 doeleinden aangeroepen: 1 keer voor het plaatsen van de hoofdvestiging, het Spaarne Ziekenhuis (spaarneIcon), en 1 keer in de array (dus gebeurt bij elke loop) voor het bepalen van de posities van de huisartsenposten, met het huisartsenicoon.

Het ShowMarker()-script voegt de latitude en longitude samen in een nieuwe variable GlatLng. Deze wordt gebruikt om de CreateMarker functie aan te roepen; als deze terugkomt, kan hij toegevoegd worden aan de Map via Map.AddOverlay.

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"function ShowMarker(map,geocoder,account,name,
    address,postalcode,city,phone,email,
    latitude,longitude,icon)

  {{"));

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @" var loc = new GLatLng(latitude, longitude);
  var marker = createMarker(loc,account,name,address,
    postalcode,city,phone,email,icon);

  map.addOverlay(marker);
}}
GoogleMapLoad()
</script>"));

GoogleMapLoad() dient aangeroepen te worden op het moment dat de pagina wordt geladen. Dit wordt aan het einde van het script toegevoegd.

In de CreateMarker-functie wordt de icoon op de juiste positie gegenereerd. Aan de marker kan een event toegevoegd worden. Door een listener toe te voegen aan zo’n event is bekend welke functie moet worden aangeroepen om te reageren op mouseovers van een marker.

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"function CreateMarker(loc,account,name,address,
    postalcode,city,phone,email,icon)

  {{
    var marker = new GMarker(loc,icon);
    GEvent.addListener(marker, ""mouseover"", function()
{{"));

Aan deze mouseover wordt een functie toegevoegd die een Popup-window toont met de informatie die aan het webpart wordt meegeven in de eigenschap "InfoWindowHtml".

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @" var html = ""<b><a
    href='#'>""+name+""</a></b>""+""<br/>""+
    address+""<br/>""
    +postalcode+""<br/>""+city+""<br/>""+phone\n

    marker.openInfoWindowHtml(html);"));
}
Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"}});
return marker;
}}"));

Rest nog de definities van de iconen. De iconen worden opgeslagen in de 12 hive, waardoor deze altijd aanspreekbaar zijn en security-problemen voorkomen worden, waar je ook bent binnen SharePoint:

Script.Append(string.Format(CultureInfo.InvariantCulture,
  @"// create marker icon
  var icon = new GIcon();
  icon.image = ""/_layouts/images/huisarts.png"";

  icon.iconSize = new GSize(30, 30);
  icon.iconAnchor = new GPoint(30, 30);
  icon.infoWindowAnchor = new GPoint(30, 30);

Tenslotte wordt de opgebouwde string teruggegeven aan de HTMLwriter.

output.Write(Script.ToString())

Na het compileren en installeren van het webpart is dit het eindresultaat:

Fig. 6: eindreslutaat

Conclusie

Het is vrij éénvoudig Google Maps te integreren in een SharePoint webpart, en de vraag daarna ziet men dan ook steeds meer toenemen.

De functies die beschreven zijn, maken deel uit van de basisfuncties van Google. Van hieruit is het mogelijk andere functies toe te voegen zoals een routeberekening. Zoals altijd is het van belang dat de JavaScript klopt, anders wordt er niets weergegeven. Dit kan ook resulteren in StringBuilder fouten.

Ik heb ook de tegenhanger van Google Maps gemaakt, namelijk Bing Maps. De structuur is nagenoeg gelijk, en voordeel is dat er hier geen key  benodigd is. Persoonlijk vind ik dat de map ook mooier weergeven wordt. Binnenkort toon ik een voorbeeld van de Bing-map op mijn website.

Commentaar van anderen:
maomao op 30-7-2010 om 6:14

Luxury watches - exudes a new site, Rolex presents the world's wonderful! Replica Rolex is a Swiss watches manufacturer, formerly known as Wilsdorf and Davis Company, by the German (Hans Wilsdof) and the British Davis (Alfred Davis) in a partnership in London in 1905. Polyandry in 1908 by the Hansiweier Division (Hans Wilsdof) Laxiadefen in Switzerland (La Chaux-de-Fonds) Registry was renamed rolex. Best in the world watches.Classic Swiss watches, men watches, watches brand, authentic quality highlights. Creation and production of replica watches are based on a simple and witty invention, Replica Breitling Bvlgari watches Replica Cartier Chanel watches Replica Tag Heuer Replica Omega Replica Ulysse-Nardin this is the "spring", replica watches it can tighten up and store energy, and can slowly release energy to drive the running gear and watch the pointer, to show Time function.Let me into your replica watches, listen to your heartbeat close seo to the arm, montres rolex replica watches Breitling replica Hublot replica Omega replica U-Boat watches the first time with you to be happy ,replica handbags gucci handbags Chanel handbags Balenciaga handbags Burberry handbags Prada handbags like you slept deeply at night, with you every second, let my heart as you countdown, ticking is my prayers replica Handbags Mont Blanc Pen Dunhill Lighter Looking for? To find the cheap replica? let go buy cheap handbags gucci handbags chanel handbags Hermes handbags Hermes handbags replica Hermes Hermes Kelly handbags Miu Miu handbags replica watches replica rolex and more replica watches on sale. You can buy the cheapest replica Rolex cheap rolex Swiss Replica watches Swiss watches Swiss Rolex or Free shipping. We carry all replica handbags brands,knock off handbags replica handbags fake handbags knock off Louis Vuitton Louis Vuitton handbags replica Louis Vuitton handbags replica Louis Vuitton Gucci handbags knock off gucci handbags Prada handbags fake Gucci handbags Hermes handbags Burberry handbags chanel handbags replica Chanel handbags Looking for Cheap and Discount Handbags Designer handbags Louis Vuitton handbags and many more designers Cheap Replica Designer Handbags For Sale! knock off handbags replica handbags replica bags wallets Louis Vuitton handbags of top most designer. replica Louis Vuitton handbags fake Louis Vuitton handbags Gucci handbags Gucci bags replica Gucci handbags Online China replica Goods offer cheapest designer Prada handbags replica Prada handbags Hermes handbags Burberry handbags Chanel handbags replica Chanel handbags most of them are genuine leather Designer handbags Discount handbags cheap handbags replica handbags on sale.Order 2010 Designer Handbags.We have tons of sale replica watches replica handbags keen sale,replica rolex replica watches rolex replica with free shipping.cheap rolex fake rolex rolex watches replica rolex watches Swiss watches Swiss Rolex replica watches replica watches replica handbags replica watches replica watches and Many More Luxury Brand Replica handbags knock off handbags fake handbags knock off Louis Vuitton Louis Vuitton handbags replica Louis Vuitton handbags fake Louis Vuitton handbags Gucci handbags Gucci bags replica Gucci handbags fake Gucci handbags knock off gucci handbags Prada handbags replica Prada handbags Designer handbags Discount handbags replica handbags chanel handbags Finest Workmanship,Quality Guaranteed

Tiffany jewelry op 6-8-2010 om 4:17
Tiffany jewelry manufacturers directory,cheap jewelry - lots of registered importers and exporters. Cheap tiffany jewelry manufacturers, Tiffany & co jewelry suppliers, tiffany jewelry wholesales, Tiffany Watches,exporters, sellers, traders and gold tiffany jewelry Distributors from China and around the world at www.goldtiffanyjewelry.com Tiffany jewelry exporters, Tiffany Accessories, Tiffany Bangles, Tiffany Bracelet, Discont Tiffany Bracelet, Discount Tiffany Cufflinks, Fashion Tiffany Earring, Tiffany Necklaces , Discount Tiffany Necklaces, Tiffany Rings, Tiffany Watches
MBT op 12-8-2010 om 13:30

MBT?are physiological footwear. Here you can enjoy?MBT Shoes ?on any item with free shipping, no tax, us/uk delivery.MBT Sale have a positive effect on the entire body.MBT Fumba Sandalshave been highlighted for MBT Shuguli GTX Shoesthe principle of natural instability. So (Discount)MBT Outlet improves posture and gait, activates the whole body, and reduces stress on joint and back. MBT shoes will give you a unique and rewarding walking experience!?MBT Shoes UK The rocker bottom and calorie burner market has exploded in the last year, with brands like Skechers, Avia, Ryka, Alegria – and more – integrating their own rocker sole technologies that help you burn calories and tone muscle while you engage in your normal daily life.MBT Footwear The originators of this technology, the shoe company that introduced the rocker bottom and developed MBT Panda Sandalstheir patented rocker bottom, MBT Lami Shoes, continues to innovate and offer the luxury version of the rocker bottom shoe. MBT Voi shoes this Spring and Summer are sleek, stylish, high quality and true to their roots as an anti shoe.If you know the MBT shoes, you may be attracted by its great function. Now I can talk about the style of mbt chapa women’s.MBT Shoes OutletThese sneakers with strong seams above, MBT Shoes Clearance the color contrasts and subtle pull on loops and unique patented Masai Sensor, the muscle most important work, if you wear them. MBT shoes are known by most people. MBT trainers were the least expensive best of my knowledge and online. And what is the role of the MBT shoes, why sell it so crazy for you? MBT Tataga Shoes Techology Barefoot was set on the market. And then comes on the market in 1996. MBT TEMBEA Shoes must be accepted so quickly by the people. I think, why it is good for health. It is very important to a distributor and sells MBT Habari Sandals replaced correctly set to go. The sales staff should be MBT M.Walk Shoes sufficient to train the right person, but keep in mind the firm in the ass very closely comfortable on the stage, and should be around the toes. They take some getting used to. This is another important reason to speak to a store and go with a local representative of the MBT Sport Shoes. They offer advice on how to proceed and to submit them. But many of the best of my knowledge MBT Omlin. It is therefore better to choose the best. I think our MBT Sandals business is your best choice.MBT Tariki Shoes MBT Unono SandalsNike Zoom BB low Cheap Nike Hyperize Vibram Five Fingers Shoes Vibram Five Fingers P90X DVD P90X Workout Cheap P90X DVD MBT Sapatu Sandals MBT Imara SandalsTimberland Men Boots sale come in a stunning range of styles and colors in the market.Online purchasing has become increasingly popular because Cheap Timberland Work Boots provides you great convenience and you always can find the cheap timberland chukka boots latest styles there. Plus timberland boots online are mostly sold at lower prices than local stores,and you get to select from the wide range of styles.Treat yourself to a pair of timberland classic boots today!Terrific Timberland Boots. Absolutely impressed. This Timberland is a beautiful, classically designed piece of work, with modern features. Don’t miss this chance!Today,Timberland Boots Sale have been a fashion trend.Be sure to choose Timberlands Shoes that are made of high quality materials which just feel very comfortable.I know that men put comfort and quality first.That’s why Timberland Boots Sale have committed to produce quality footwear.Timberland Work Boots You need a pair of reliable foots for any type of weather,including snowy or rainy days.These boots from Timberland Boots Online are made of premium waterproof leather and recycled rubber sole.The leather has a gradient finish which makes them even more appealing,at least for men with a sense of fashion.Timberland, In 2000,Men Timberland Boots we have not only re-nominate the same year, the United States, New Hampshire, published by business magazine “is located in New Hampshire’s popular listTimberland Men's Custom Boots in, Timberland is on top. It is precisely because there is such a good workplace environment, Timberland products are manufactured in order to have reliable quality and long-beloved. If you are finding for Timberland Boots for men,the our web site will be your best choice.People on the move will certainly emerge a pair of Timberland Men's Roll-Top Boots. But be careful, once you have experienced a positive outdoor experience, Women Timberland Boots you must not imagine being without it. We know how to footwear comfort and timberland boot durability can only come from expensive package. Timberland 6 Inch Boots With timberlands reputation, the quality of their shoes, can earn the average, especially expensive. However, this is definitely worth the price of timberland boots to consider how to resist the normal wear and tear, while providing you extreme comfort, you need to. Find timberland boots get quality shoes if you want them to last.www.officialtimberlands.com Asics Shoes Cheap Asics Shoes Asics Whizzer Lo Onitsuka Mid Runner Onitsuka Tokidoki Mex lo Asics Gel Kinsei 2 Asics Gel Lyte III Asics Gel-Stratus 2.1 Asics Running Shoes Onitsuka Tiger Mexico 66 Onitsuka Tiger Mini Cooper Onitsuka Tiger Olympos Puma Shoes Puma Sneakers Cheap Puma Shoes Puma Speed Cat Puma SF Drift Cat Puma 2010 Sport Shoes

Puma Repli Cat Puma Future Cat Low Puma Speed Cat Big Puma Speed Cat Suede Puma ENGINE Cat Low Puma Basket Brights PUMA SPEED CAT BIG Puma SF Trionfo Low Puma TRIONFO LO L II

Puma Trionfo Low BAYLEE PUMA Lazy insect Puma FUTURE CAT LO ENGINE PUMA BAYLEE FUTURE CAT II Nike Air Max 2010 Cheap Nike Air Max Nike

Air Max On Sale Nike Air Max 87 Nike Air Max 180 Nike Air Max 2003 Nike Air Max 2009 Nike Air Max 360 Nike Air Max 89 Nike Air Max 97 Nike Air Max 95

Air Max Shoes Nike Air Max Ltd Nike Air Max TN Nike Air Max Skyline nike sb dunk nike dunks nike dunk sb shoes nike dunk shoes Air Force 1

Cheap Nike Air Force 1 Nike Air Force 1 Shoes Nike Shox Shoes Nike Shox NZ Nike Shox OZ Nike Shox R3 Nike Shox R4 Nike Shox R4 Torch Nike Shox TL1 Nike Shox Turb

Air Jordan 3 Shoes Air Jordan 1 Shoes Air Jordan 4 Shoes Air Jordan 5 Shoes Air Jordan 6 Shoes Air Jordan 8 Shoes Air Jordan 9 Shoes Air Jordan 10 Shoes Air Jordan 11 Shoes

Air Jordan 12 Shoes Air Jordan 13 Shoes Air Jordan 14 Shoes Air Jordan 17 Shoes Air Jordan 18 Shoes Air Jordan 19 Shoes Air Jordan 23 Shoes Air Jordan 24 New Shoes

as op 13-8-2010 om 5:39
Fashion Week will spread across all five boroughs replica handbags next month, with more than 1,000 chanel handbags stores staying open until 11 p.m. on a Friday night for special events and Gucci handbags shows. The second Fashion's Night Out on Sept for Louis Vuitton handbags and hermes handbags. 10 comes as the September prada handbags runway shows will leave Bryant Park for Lincoln Center for Balenciaga handbags the first time. "I was really happy to see people not in front of a chloe handbags computer screen adding to their cart, but actually getting out and interacting with burberry handbags each other," said designer Marc Jacobs and replica watches, who wore a kilt and sandals to City Hall for rolex watches the announcement. Vogue editor Anna Wintour came up with omega watches the idea for the first Fashion's Night Out last year to promote the industry -Chopard Watches and lead a tribe of fashionistas to Macy's at Bvlgari Watches the Queens Center Mall. Wintour said later she is excited for Vogue's upcoming move to the World Trade Center - but because it's still under construction, "I'm not holding my breath Vacheron Constantin watches."
ChristianLouboutin op 17-8-2010 om 2:54
Christian Louboutin Shoes, Christian Louboutin, Christian Louboutin Shoes, Wedding Shoes, Christian Louboutin Shoes, Christian Louboutin includes recently been produced in a selection with trends, designs, designs and also styles that will need achieved great decide of millions of most women several over the globally. Wedding Shoes, Christian Louboutin, Christian Louboutin Shoes, Wedding Shoes, Discount Christian Louboutin, Louboutin Sale A number of sizes are usually seriously outstanding and simply the rest are special variations among traditional general trends. Louboutin Shoes, Christian Louboutin Discount, Louboutin, Christian Louboutin Sale, Buy Christian Louboutin, Christian Louboutin Pumps, YSL Shoes sandals are known for their own particularly crafte heels, outstanding models and also high-priced and furthermore well highly regarded amongst girls cirlces. Christian Louboutin Sandals, Yves Saint Laurent Shoes, Christian Louboutin Boots, Manolo Blahnik Shoes, Yves Saint Laurent Boots, Miu Miu Shoes Sandals designs are glamorous and sexy, and they are worn by some of the world most beautiful women. Christian Dior Shoes, Christian Louboutin Flats, Christian, Louboutin Shoes, Christian Louboutin Sale, Discount Christian Louboutin Why is everyone infatuated with these red-soled shoes Read on to find out why, and you also find some of the best of Louboutin line. Herve Leger Bandage Dress, Herve Leger Dress, Herve Leger V Neck Dress, Herve Leger Bandage Dress, Herve Leger Dress Most people associate Louboutin shoes with sky-high, stiletto heels, the patent sandals with wedge heels prove that sexy and wearable can go hand-in-hand.
airjordan shoes op 17-8-2010 om 9:16

Air jordan is now one of the most favorite brands of shoes whether you are a Michael Jordan fanatic or not. This particular brand of sneakers provide fashion, comfort and performance at very reasonable prices.cheap jordans Undoubtedly, many fanatics, athletics and even ordinary people prefer Jordan sneakers and would definitely love to hear the latest about this leading brand. This site is dedicated to give you the newest and best Jordan 11 information available online. We provide photos, shoe details, latest releases, prices and upcoming models. Check us out daily and be updated always. As a big fan of Jordan Blase, I never forget Air Jordan Fusion 20 SecKills me on the day in spring! From then on, Air Jordan Countdown is always in my mind. It was on the morning in spring, I went out for shopping with my friends. He is a basket player and admires Jordan 1 very much. When he is free,jordans retro, he just finds anything about Air Jordan 6 Rings, of course including Jordan OL School and other Jordan series. He would become psyched if there is a new Jordan 5 coming out. That day, it was right time that Air Jordan 15 XV was promoted into market. Both of us were appeared for it. I like sports as well, and now I prefer it to any other shoes. So, we believe that Nike Air Jordan Shoes will be your best choice.Jordan 23 with other distinct, the only part Air Jordan Fusion 4 of the same in the fact that AIR JORDAN 4 middle and side mesh tongue design. At this time, the mesh is made of soft plastic, and it is completely transparent! Soles of the feet too! After we clear plastic Air Jordan Fusion 3 soles seen JUMPMAN unique design details! So that we appear to be a very beautiful soles feet design! AIR JORDAN 5 in the heel is still open to use the same way air jordans cushion! The tongue is also used a special reflective material! To make whatever point of tongue in a more dazzling look! Tongue on the transparent plastic buckles made more prominent Jordan 2009 perfect!

 

 

Air Yeezy was designed by Kanye West LV (A excellent natural designer) and produced by Nike Sportswear. It is a wonderful colorway of Air Yeezy model. Air Yeezy is known for its modern design (a modern classic), an original MBT Shoes footwear style, that reflects elements of Nike's sporting past, and remixes them with innovation to deliver a unique shoe. Now Five Fingers Shoes are so hottest among the customer.To find best real Nike Air Yeezy Sneakers from authoriezed Nike Air Yeezy shoes online store: www.airyeezykicks.com cheap wholesale & retail high quality Nike Air Yeezy x Jordan VI for cheap. We pay attention to honesty, credibility, and customer satisfaction. Shop your favourite Nike Air Yeezy for free shipping with us!If you are aonline wholesaler or retalier pls contact us to get more discount! Come on, you never be regret to buy discount Air Yeezy shoes from us! Creative Recreation Black glow in the dark The fashionable Glow In the Dark cheap on sale for men. Kanye West LV made with First Layer Leather which is the best materials. The Sole... Save: 55% off ... more info Air Yeezy lack Pink glow in the dark The fashionable Glow In the Dark cheap on sale for men. Ato Matsumoto made with First Layer Leather which is the best materials. The Sole... Save: 55% off ... more info MBT Walking Shoes Coffee Pink Glow In The Dark The fashionable Nike Air Yeezy Glow In the Dark cheap on sale for men.

Administrator op 21-8-2010 om 9:52
Nowadays, almost all of us want to have every bit of stylishness and grace in our every move, and we wish to acquire all those accessories that can offer us some help to attain this desired elegance and grace. replica Panerai always have utmost importance to make our overall appearance really impressive, and perhaps that’s why there is an ever increasing demand for really elegant and stylish watches. Mobiles are widely used as time-tellers, but still Patek Philippe replica watches have their own importance and they are more used as style-tellers rather than time-tellers. When it comes to stylish rolex GMT replica, replica oris is always at the top in luxury brands and a considerable number of people often look for its different replica Patek Philippe like replica rolex Day-Date II watches, omega watches and replica rolex Masterpiece watches as they reckon them somewhat essential for representing their style and taste in a true way. However, it’s also a fact that a considerable number of people can’t afford to have Rolex original brand of replica watches because of their huge prices. If you can’t afford an original rolex Datejust watches, nothing to be worried about as you have many other options in the form of Hublot replica watches. You can easily find replicas of almost all well known brands and it’s not hard to get one that is according to your style and taste. All these louis Vuitton watches have their own specific charm and elegance, but Rolex replica Daytona is a Croum watches that seems to serve all sort of customers best. This montblanc replica has all the grace and stylishness which you can see in the original model of this replica rolex Day Date and the only thing which seems to make the difference is the price tag of the maurice Lacroix replica, otherwise, none can tell what the difference between an original bvlgari watches and a replica one. It’s not all about style and look, as Ebel replica watches has all the features and functions which you can see in the original replica Montblanc. The demand for this Glashutte watches is on increase with every passing day and now many customers want to have this bvlgari replica looking at its stylishness and grace. There are several factors behind the growing popularity of the Christian Dior watches and the biggest factor in this connection is its original-like appearance. Some customers have been found saying that the Rolex Daytona replica seems to surpass the grace and stylishness of the original brand.In fact, just like other rolex watches, the rolex Masterpiece replica watches serves as an emblem of high quality materials and technicians’ dexterity. The only thing which seems to make the difference is the price tag of this replica Concord. Many customers don’t believe that they can get such a nice Alain Silberstein replica watches with amazingly lower price tags. Because of their low price tags and original-like look and feel, a large number of customers want to have these maurice Lacroix replica watches. Now even some well-off customers seem to prefer these omega replica watches to the original brands, as they say why buy original Gucci replica watches when these replicas can offer you all. There are many who often seem to explore the www to find out their desired Rolex replica. If you are also one of them, you are at right place now as we offer you what you will not find anywhere else whether it’s about quality or variety of the replica Longines. Whether you are looking for a Vacheron Constantin replica or some Concord watches, we can offer you what you are looking for.
GHT op 24-8-2010 om 4:55
LRH20100824

There are many men to choose Cheap Lacoste Shoes for his fame and service which is famous with the world people.Countries' leaders like to wear Locaste Shoes.On 4th of August, Western media quoted the Lebanese and Arab Mens Lacoste Shoes TV stations reported that Iran - President Mahmoud Ahmadinejad's team that day was in Iran bomb attacks, several people were injured, Mahmoud Ahmadinejad, I survived.The leader wears the style shoe of 2010 Lacoste Shoes.

sfs op 25-8-2010 om 8:18

Are you still confusing about choosing presents for your friends?Do you know where we can buy Replica Watches value for money?replica watches What kind of Replica Watches will be a nice gift?Linkreplica is absolutely a place worth to go.We prepare various style of Replica Watches Swiss Watches for our customers such as rolex Submariner replica Bell & Ross Breitling watches,you can buy cheap replica rolex with top quality to your customers,they are the perfect gifts to enhance your relationships.Linkreplica aim to provide best watches and service.Once you have a lifetime honor,Replica Breitling you will enjoy the honorable fashion all the time!Watch is a angel who records time.replica rolexOne superior swiss rolex is the symbol of high taste.Some name-brand watches even spend few years to build their brand.People have already acquainted watches not as before,like the advertisement of Patek Philippe,"No one can own Patek Philippe,we just keep it for our next generations.Watches have become kind of lineage,culture,fantastic culture.Linkreplica will take you into the new watch world,replica watches let you experience the magical culture of watches.Welcome to the most professional watch shop which specialise in selling Replica Tag Heuer U-boat Watches replica U-boat.You can buy excellent Chanel watches Replica Eberhard & Co Replica Hublot with reasonable prices here.Autumn is approching,it is the season of love and joy,the time of giving and caring.Send your warm wishes to the people dear to you.My favorite brand watches are Replica Omega replica Bvlgari,I strongly recommand those two to all you of at here. Replica Eberhard & Co Replica HublotReplica IWC are graceful and luxurious accessories for people.They are affordable for you.Welcome to our online store to select rolex Submariner Breitling Bentley replica Bvlgari from our site would be a wise choice.

sfs op 25-8-2010 om 8:19
We offer thousands of replica handbags,for example Louis Vuitton handbags Prada handbags Chanel handbags.Designer handbags is not only a fashion trend,but also a symbol of social status and an acceptability of one's identity.All the latest infomation of hermes handbags Miu Miu handbags Versace Handbags will be updated on our site frequently.You can also share your feelings of shopping on our site at here.replica handbagsWhat kind of replica handbags you like best Burberry handbags Chanel handbags or Mulberry handbags?Unexpected cheap prices and 1:1 mirror image quality,you can enjoy the biggest benefits from our site.We also do wholesale replica Louis Vuitton Gucci handbags Prada handbags Bottega Veneta handbags.No matter what kind of replica handbags fake handbags you like to order,if your order quantity above 5 pieces,replica handbagsthen you can enjoy our wholesale price.Everyone has right and obligation to improve himself in his own part.If you want to be more perfect,then start from your appearance and make up.Jimmy Choo Handbags Chloe Handbags thomas wylde Handbags are hotsellers on our site recently.If you don't want to out of fashio,then please feel free to browse our site and choose your favorite replica handbags.Versace Handbags Miu Miu handbags and Balenciaga handbags are available,too.We have a huge amount of Dior Handbags Versace Handbags Miu Miu handbags in stock postion.
zz zz op 26-8-2010 om 5:14
Compared to the total value of armament sales that happens in a year it is the fashion industry that generates more money globally; and not without reason. It is consumerism at its best - promoting certain looks on the ramps, and producing the products that go with those looks, call it fashion and it sells like there is no tomorrow. The role of fashion, miumiu replica handbagscheap Jimmy Choo handbagsbally replica handbagsdesigner replica handbagsGiverchy handbagsmiumiu handbagscheap designer bagshermes handbagscoach handbagsloewe replicaloewe replica handbagslouis Vuitton handbagsreplica Loewe handbagsreplica Christian Dior handbagscoach replica, food, health and womens magazines in our daily lives and the focus of advertisements all are more consumerism oriented than being consumer oriented. Yet, Gucci handbags there is no decline to mans love and appreciation of beauty and all connected forms. A causal shopper for lipstick or eye shade is bombarded with options and ideas that confusion is what prevails over the choice of colors, shades and textures. More over, balenciaga replica handbags its trends and life are so very temporal what is in today wont be long before its out, giving way to a new in. Yet there is no underestimating the power of the fashion conscious buyer of eyeliner or haute couture dinner wear or the producer of the Louis Vuitton leather designer bags or its exact luella replica handbags maker. Everybody who thinks or acts trendy has got to be in the midst of fashion and fads. There is no denying that. As much as clothes speak a language the accessories that accompany your clothing like the wholesale handbags you use, foot wear, underwear, keychains, watches, eye wear also can speak loads about how fashion conscious you are. While men have always been intrigued and fascinated with the secret contents of a womans replica Balenciaga handbags, women find it the perfect companion to hold their cosmetic collections and utilities, while some use it to hide their dirty little secrets. Dont ask me why Paris Hilton or Kate Moss or Lindsay Lohan But the womans cheap Giverchy handbags in spite of its various forms, shapes, sizes and purposes has been a fashion statement as much as its is a womans companion. The womans toiletry cheap Loewe handbags, is without doubt, expected to be trendy, labeled and must cost the moon and two other planets combined. In todays world, hand bad, shoulder marni replica or clutch replica Versace handbags, Louis Vuitton clearly defines what fashion stands for. And when the best celebrities in the world carry theirfendi handbags to the Oscars, we their fans like to imitate them at our local parties, how big or small. But not all of us can afford to buy such expensive brands such as Luis Vuitton. Well! If it is worth it, is not fashionable to discuss now. As much as we would like to imitate our favorite celebrities we can also imitate their products because there are expensive looking exact replica Mulberry handbagsof your favorite rich and famous brands and that too at really cheap prices. Beautifully monogrammed louis Vuitton replica handbags of Luis Vuitton in the most popular latest trends and designs are available at fashionoriginal.com. Costing you a minute fraction of what the original costs, these cheap Mulberry handbags can create a stir if matched with the right clothing and occasion. Mens collection of cheap Armani handbags come in brown and black leather in a variety of sizes and shapes. celine replica are made on the same size and design specifications of the original. anya Hindmarch replica handbags not only are cheap but are stylish fashion statements for any occasion. You never know who is carrying a Jimmy Choo handbags and who a original.
Geef feedback:

CAPTCHA image
Vul de bovenstaande code hieronder in
Verzend Commentaar