Microdata Schema org di Template Blogger

Sebuah hal yang menarik, ketika Blogger™ memasukkan format microdata dalam desain default template, namun belum tentu berlaku jika kita serta merta menggantinya dengan template bukan default BLogger™. Microdata — seperti juga microformat & RDFa — bermanfaat untuk menerjemahkan informasi yang disertakan dalam tag HTML dengan cara yang dapat dipahami oleh mesin penelusur. Kemungkinan besar hal ini juga bermanfaat sebagai salah satu variabel dalam memperbaiki struktur blog.

Microdata Schema org di Template Blogger

Sebagian kecil contoh telah kami berikan dalam penerapan navigasi breadcrumbs dengan microdata. Sedangkan secara keseluruhan, saya akan mencoba untuk menguraikan pada posting ini. Perlu menjadi catatan bahwa microdata yang dimaksud merujuk kepada schema.org, seperti Blog, BlogPosting, dan Comment. Kemudian hal-hal yang terkait dengan ‘basa-basi publik’ — rating blog yang dibuat oleh pengelola sendiri — tidak disertakan.

Markah (markup) meta deskripsi blog

Oleh karena meta deskripsi telah dimasukkan dalam blog — tepatnya pada markah <b:include data='blog' name='all-head-content'/> — kemungkinan meta deskripsi microdata berikut kurang bermanfaat. Terkecuali untuk memperkaya cuplikan struktur data. Meta deskripsi dengan microdata ini dapat diletakkan di bawah <body> atau di bawah pengkodean navbar.

<body expr:class='"loading" + data:blog.mobileClass'>
  <b:if cond='data:blog.pageType == &quot;index&quot;'>
    <div itemscope='itemscope' itemtype='http://schema.org/Blog' style='display: none;'>
      <b:if cond='data:blog.pageName == &quot;&quot;'>
        <!-- Add schema.org description on home page -->
        <b:if cond='data:blog.metaDescription'>
          <meta expr:content='data:blog.metaDescription' itemprop='description'/>
        </b:if>
      <b:else/>
        <!-- Avoid duplicate schema.org description on label and search page -->
        <b:if cond='data:blog.searchLabel'>
          &lt;meta content=&quot;Penelusuran arsip <data:blog.title/> berdasarkan label <data:blog.pageName/>&quot; itemprop=&quot;description&quot;/&gt;
        <b:else/>
          &lt;meta content=&quot;Arsip  berdasarkan <data:blog.pageName/>&quot; itemprop=&quot;description&quot;/&gt;
        </b:if>
      </b:if>
    </div><!-- itemscope itemtype='http://schema.org/Blog' -->
  <b:else/>
    <b:if cond='data:blog.pageType == &quot;archive&quot;'>
      <div itemscope='itemscope' itemtype='http://schema.org/Blog' style='display: none;'>
        <!-- Add schema.org description on archive page -->
        &lt;meta content=&quot;Penelusuran arsip <data:blog.title/> berdasarkan bulan <data:blog.pageName/>&quot; itemprop=&quot;description&quot;/&gt;
      </div><!-- itemscope itemtype='http://schema.org/Blog' -->
    <b:else/>
      <div itemscope='itemscope' itemtype='http://schema.org/BlogPosting' style='display: none;'>
        <!-- Add schema.org description on item and static page -->
        <b:if cond='data:blog.metaDescription'>
          <meta expr:content='data:blog.metaDescription' itemprop='description'/>
        </b:if>
      </div><!-- itemscope itemtype='http://schema.org/BlogPosting' -->
    </b:if>
  </b:if>

  …

</body>
Catatan: kode yang diberi warna biru merupakan deskripsi yang akan ditampilkan pada pengujian rich snippets.

Markah schema.org/Blog

Apabila kita mengambil referensi berdasarkan template standar Blogger™, maka skema microdata Blog akan terlihat seperti di bawah ini.

<b:if cond='data:blog.pageType == "index"'>
  <div itemscope='itemscope' itemtype='http://schema.org/Blog' style='display: none;'>
    <meta expr:content='data:blog.title' itemprop='name'/>
    <b:if cond='data:blog.metaDescription'>
      <meta expr:content='data:blog.metaDescription' itemprop='description'/>
    </b:if>
  </div>
</b:if>
Oleh karena alasan tertentu, maka markah itu saya kustomisasi, dimana sebagian diletakkan sebagai deskripsi (sub judul “Markah (markup) meta deskripsi blog”) & sisanya akan dikonfigurasi pada elemen lain, seperti pada elemen pembungkus. Detail akan ditunjukkan pada contoh pengkodean berikut ini.

<div id='content' itemscope='itemscope' itemtype='http://schema.org/Blog'>
  <header id='header-content'>
    <div class='head-wrap'>
      <div id='header-group'>
    <b:section class='header' id='header' maxwidgets='1' showaddelement='no'>
<b:widget id='Header1' locked='true' title='Title Blog (Header)' type='Header'/>
</b:section>
      </div>
      <div id='search'>
      </div>
      <nav id='main-menu'>
      </nav>
    </div>
  </header>

  …

  <footer id='footer-content'>
    <p>&amp;copy; 2012 Aris Asmara diberdayakan oleh Blogger.com</p>
  </footer>
</div>

Kustomisasi properti skema name, url, dan about

Kita dapat memasukkan format microdata melalui tag-tag tertentu, seperti <span> atau meta. Sedangkan properti skema Blog antara lain berisi name, url, dan about dapat dikonfigurasi melalui elemen header blog.

<b:section class='header' id='header' maxwidgets='1' showaddelement='no'>
<b:widget id='Header1' locked='true' title='Title Blog (Header)' type='Header'>
…
<b:includable id='title'>
  <meta expr:content='data:blog.title' itemprop='name'/>
  <meta expr:content='data:blog.homepageUrl' itemprop='url'/>
  <b:if cond='data:blog.url == data:blog.homepageUrl'>
    <data:title/>
  <b:else/>
    <a expr:href='data:blog.homepageUrl'><data:title/></a>
  </b:if>
</b:includable>
<b:includable id='description'>
  <div class='descriptionwrapper'>
    <p class='description'itemprop='about'><span><data:description/></span></p>
  </div>
</b:includable>
…
</b:widget>
</b:section>

Markah schema.org/BlogPosting

Bagi pengguna template default pasti sudah tidak asing lagi dengan markah berikut, karena ia sudah dimasukkan oleh perancang.

<b:includable id='post' var='post'>
  <div class='post hentry' itemprop='blogPost' itemscope='itemscope' itemtype='http://schema.org/BlogPosting'>
    <b:if cond='data:post.thumbnailUrl'>
      <meta expr:content='data:post.thumbnailUrl' itemprop='image_url'/>
    </b:if>
    <meta expr:content='data:blog.blogId' itemprop='blogId'/>
    <meta expr:content='data:post.id' itemprop='postId'/>

    <a expr:name='data:post.id'/>
 
  …
 
</b:includable>
Ketika kita melakukan uji coba terhadap struktur data, terdapat peringatan bahwa properti image_url, blogId, dan postId tidak termasuk dalam skema. Mengapa hal ini terjadi? Setelah kembali melihat beberapa properti yang dapat dimasukkan dalam skema BlogPosting pada schema.org, ternyata tidak satupun properti di atas digolongkan sebagai bagian skema BlogPosting. Oleh karena itu kita dapat menghilangkan atau melakukan konfigurasi ulang terhadap ketiga properti itu. Berikut merupakan konfigurasi untuk properti image_url.

<b:if cond='data:post.thumbnailUrl'>
  <meta expr:content='data:post.thumbnailUrl' itemprop='thumbnailUrl'/>
</b:if>
Catatan: selain properti thumbnailUrl, kita dapat pula menandainya dengan properti image.
Sedangkan properti blogId dan postId — setahu saya — dulu berada pada elemen <post-footer>, tepatnya dalam kode post-author. Mungkin alasan pemindahan tersebut nantinya akan terkait dengan skema struktur data Product (

red: hanya opini saya). Kembali ke pokok utama, untuk sementara properti blogId dan postId dihilangkan dari hirarki skema, namun akan dimasukkan kembali dalam kode post-author dengan konfigurasi sebagai berikut:

<span class='post-author vcard'>
  <b:if cond='data:top.showAuthor'>
    <data:top.authorLabel/>
    <b:if cond='data:post.authorProfileUrl'>
      <span class='fn' itemprop='author' itemscope='itemscope' itemtype='http://schema.org/Person'>
        <meta expr:content='data:blog.blogId' itemprop='owns'/>
        <meta expr:content='data:post.id' itemprop='owns'/>
        <meta expr:content='data:post.authorProfileUrl' itemprop='url'/>
        <a expr:href='data:post.authorProfileUrl' rel='author' title='author profile'>
          <span itemprop='name'><data:post.author/></span>
        </a>
      </span>
    <b:else/>
      <span class='fn' itemprop='author' itemscope='itemscope' itemtype='http://schema.org/Person'>
        <meta expr:content='data:blog.blogId' itemprop='owns'/>
        <meta expr:content='data:post.id' itemprop='owns'/>
        <span itemprop='name'><data:post.author/></span>
      </span>
    </b:if>
  </b:if>
</span>
Catatan: untuk melihat apakah landasan properti tersebut benar atau keliru, mari kita amati pada http://schema.org/Person.

Properti name dan url

<a expr:name='data:post.id'/>
<b:if cond='data:post.title'>
  <h3 class='post-title entry-title' itemprop='name'>
  <b:if cond='data:post.link'>
    <a expr:href='data:post.link'><data:post.title/></a>
  <b:else/>
    <b:if cond='data:post.url'>
      <b:if cond='data:blog.url != data:post.url'>
        <a expr:href='data:post.url'><data:post.title/></a>
      <b:else/>
        <data:post.title/>
      </b:if>
    <b:else/>
      <data:post.title/>
    </b:if>
  </b:if>
  </h3>
</b:if>
Penambahan markah skema BlogPosting pada tag entry-title bisa terdiri dari beberapa versi. Seorang blogger mungkin tetap pada properti tersebut, sedangkan yang lain menambahnya menjadi itemprop='name headline' atau merubahnya menjadi itemprop='headline'. Variasi itu tidak akan menimbulkan pesan peringatan, ketika di uji pada alat rich snippets. Kemudian kita dapat pula menambahkan properti url yang ditunjukkan oleh markah di bawah ini.

<b:if cond='data:post.link'>
  <meta expr:content='data:post.link' itemprop='url'/>
    <a expr:href='data:post.link'><data:post.title/></a>
  <b:else/>
    <b:if cond='data:post.url'>
      <b:if cond='data:blog.url != data:post.url'>
      <meta expr:content='data:post.url' itemprop='url'/>
        <a expr:href='data:post.url'><data:post.title/></a>
      <b:else/>

    …

  </b:if>
Catatan: itemprop='url' tidak akan ditampilkan pada halaman posting, sehingga diperlukan kostumisasi kembali jika ingin memunculkannya. Nah, masalah ini akan dibahas pada penggunaan elemen post-timestamp.

Properti articleBody

Skema BlogPosting dengan properti ini telah terdapat pula pada template standar Blogger™ dengan peletakkan yang unik & menarik.

<b:if cond='data:blog.metaDescription == &quot;&quot;'>
  <!-- Then use the post body as the schema.org description, for good G+/FB snippeting. -->
  <div class='post-body entry-content' expr:id='&quot;post-body-&quot; + data:post.id' itemprop='description articleBody'>
    <data:post.body/>
    <div style='clear: both;'/> <!-- clear for photos floats -->
  </div>
<b:else/>
  <div class='post-body entry-content' expr:id='&quot;post-body-&quot; + data:post.id' itemprop='articleBody'>
    <data:post.body/>
    <div style='clear: both;'/> <!-- clear for photos floats -->
  </div>
</b:if>
Saya rasa ini merupakan terobosan yang sangat baik dari perancang. Konfigurasi pengkodean di atas akan berperan untuk membantu pengelola blog, terutama yang sudah ‘menelurkan’ banyak posting. Apa alasanya? Coba kita perhatikan markah tersebut, penggunaan <b:if cond='data:blog.metaDescription == &quot;&quot;'> dan diiringi dengan itemprop='description articleBody' merupakan kata kunci agar duplikasi meta deskripsi posting tidak terjadi, jika penulis lupa memasukkan deskripsi pada editor posting atau tidak mengaktifkan meta deskripsi dalam setelan pengaturan pada preferensi penelusuran. Arti sederhananya mungkin adalah deskripsi posting akan diterjemahkan secara otomatis, meskipun penulis tidak memasukkannya. Namun jika meta deskripsi posting telah dimasukkan penulis, maka yang akan ditampilkan adalah hasil isian dari penulis posting tersebut.

Properti articleSection

Para blogger yang biasanya menambah beberapa elemen di bawah posting — elemen posting terkait — dapat memanfaatkan markah articleSection. Tetapi ia bukan articleBody, agar lebih jelas akan saya coba contohkan seperti yang ditunjukkan pada pengkodean berikut.

<b:if cond='data:blog.metaDescription == &quot;&quot;'>
  <!-- Then use the post body as the schema.org description, for good G+/FB snippeting. -->
  <div class='post-body entry-content' expr:id='&quot;post-body-&quot; + data:post.id' itemprop='description articleBody'>
    <data:post.body/>
    <div style='clear: both;'/> <!-- clear for photos floats -->
  </div>
  <b:if cond='data:blog.pageType == &quot;item&quot;'>
    <aside class='related-posts' itemprop='articleSection'>
      …
    </aside>
    <div class='clear;'></div>
  </b:if>
<b:else/>
  <div class='post-body entry-content' expr:id='&quot;post-body-&quot; + data:post.id' itemprop='articleBody'>
    <data:post.body/>
    <div style='clear: both;'/> <!-- clear for photos floats -->
  </div>
  <b:if cond='data:blog.pageType == &quot;item&quot;'>
    <aside class='related-posts' itemprop='articleSection'>
      …
    </aside>
    <div class='clear;'></div>
  </b:if>
</b:if>

Properti url dan datePublished pada post-timestamp

Properti ini juga telah ditambahkan oleh perancang template Blogger™. Ketika sebuah halaman posting terbuka, maka judul posting — umumnya — tidak memiliki pranala (link). Oleh karena itu skema microdata dengan properti url dialihkan ke elemen post-timestamp. Dengan catatan pengelola blog belum melakukan perubahan struktur data pada entry-title (post-title).

<span class='post-timestamp'>
  <b:if cond='data:top.showTimestamp'>
    <data:top.timestampLabel/>
    <b:if cond='data:post.url'>
      <meta expr:content='data:post.url' itemprop='url'/>
      <a class='timestamp-link' expr:href='data:post.url' rel='bookmark' title='permanent link'><abbr class='published' expr:title='data:post.timestampISO8601' itemprop='datePublished'><span class='updated'><data:post.timestamp/></span></abbr></a>
    </b:if>
  </b:if>
</span>
Catatan: ada yang merasa aneh pada kode yang berwarna biru? Hal itu hanya ‘latah’ saya untuk menghilangkan peringatan pada alat rich snippets ketika menguji struktur data blog ini.

Properti discussionUrl

Skema properti ini akan muncul jika dan hanya jika pengelola menampilkannya pada halaman indeks, sedangkan pada halaman posting atau halaman statis —biasanya— tidak ditampilkan. Meskipun ditampilkan, maka besar kemungkinan pengkodean dengan menempatkan itemprop='discussionUrl' akan sama pula.

<span class='post-comment-link'>
  <b:if cond='data:blog.pageType != "item"'>
  <b:if cond='data:blog.pageType != "static_page"'>
    <b:if cond='data:post.allowComments'>
      <a class='comment-link' expr:href='data:post.addCommentUrl' expr:onclick='data:post.addCommentOnclick' itemprop='discussionUrl'>
        <data:post.commentLabelFull/>
      </a>
    </b:if>
  </b:if>
  </b:if>
</span>

Properti keywords

Pengkodean dengan markah microdata BlogPosting dengan properti keywords secara sederhana dapat kita letakkan pada elemen post-labels.

<span class='post-labels'>
  <b:if cond='data:post.labels'>
    <data:postLabelsLabel/>
    <b:loop values='data:post.labels' var='label'>
     <a expr:href='data:label.url' rel='tag'><span itemprop='keywords'><data:label.name/></span></a><b:if cond='data:label.isLast != "true"'>,</b:if>
    </b:loop>
  </b:if>
</span>

Markah schema.org/Comment

Oleh karena kebanyakan para blogger menggunakan sistem komentar bersarang (threaded comments), maka konfigurasi hanya akan dilakukan di sekitar daerah judul komentar. Adapun properti yang dimanfaatkan sebagai markup adalah name dan interactionCount khusus pada jumlah komentar yang masuk. Menyisipkan atau memberi markup microdata pada sesi ini dibagi menjadi dua, yakni sebelum ada komentar (comments) & setelah ada komentar (threaded comments).

<b:includable id='comments' var='post'>
  <div class='comments' id='comments' itemprop='comment' itemscope='itemscope' itemtype='http://schema.org/Comment'>
  <b:if cond='data:post.numComments != 0'>
    &lt;meta content=&quot;UserComments: <data:post.numComments/>&quot; itemprop=&quot;interactionCount&quot;/&gt;
  </b:if>
    <a name='comments'/>
    <h4 itemprop='name'><data:post.commentLabelFull/></h4>

  …

  </div>
</b:includable>
<b:includable id='threaded_comments' var='post'>
  <div class='comments' id='comments' itemprop='comment' itemscope='itemscope' itemtype='http://schema.org/Comment'>
  <b:if cond='data:post.numComments != 0'>
    &lt;meta content=&quot;UserComments: <data:post.numComments/>&quot; itemprop=&quot;interactionCount&quot;/&gt;
  </b:if>
    <a name='comments'/>
    <h4 itemprop='name'><data:post.commentLabelFull/></h4>

  …

  </div>
</b:includable>
Khusus bagi penggunaan komentar tidak bersarang, markup microdata yang dimanfaatkan adalah itemprop='UserComments' dengan tipe schema.org/UserComments. Sedangkan propertinya antara lain: commentText, commentTime, creator, dan replyToUrl serta dapat pula ditambahkan schema.org/Person sebagai bagian di dalam struktur schema.org/comment. Sedangkan penggunaan kode dengan latar berwarna kuning menjelaskan keterkaitan antara markah yang terkandung di dalam masing-masing tipe (itemtype), dimana mereka merupakan satu-kesatuan yang utuh.

Berdasarkan uraian yang sangat panjang di atas, format microdata dapat diterapkan beragam atau tergantung “pemberi markah”. Namun memberi sebuah markup terhadap data atau elemen tidak dapat dilakukan secara sembarangan, karena akan turut berpengaruh dalam menghasilkan markah yang semantik. Hal ini terkait pula dengan posting yang saya beri judul “Microdata pada Blogger.com”, sangat dimungkinkan terdapat kekeliruan atau kesalah-tafsiran, sehingga kritik dan saran sangat dibutuhkan untuk memperbaikinya.

Alat & Bahan bacaan

Berikut alat dan beberapa bahan bacaan yang mungkin akan menambah pengetahuan serta wawasan kita dalam memahami tentang struktur skema microdata.

Sumber : OB Log

6 Responses to "Microdata Schema org di Template Blogger"

  1. saya heran artikel sebagus dan selengkap ini tidak muncul di halaman pertama... btw penjelasannya sangat membantu mas. oh iya mas sy msh bingung deng tampilan rich snippet yg baru. kali ini sy dpt msh error img_url, blogid dan postid... tolong klo bisa buatkan solusinya dong mas :)

    ReplyDelete
    Replies
    1. cepat kaya

      ,,.,KISAH NYATA ,
      Aslamu alaikum wr wb..Allahu Akbar, Allahu akbar, Allahu akbar
      Bismillahirrahamaninrahim,,senang sekali saya bisa menulis
      dan berbagi kepada teman2 melalui room ini,
      sebelumnya dulu saya adalah seorang pengusaha dibidang property rumah tangga
      dan mencapai kesuksesan yang luar biasa, mobil rumah dan fasilitas lain sudah saya miliki,
      namun namanya cobaan saya sangat percaya kepada semua orang,
      hingga suaatu saat saya ditipu dengan teman saya sendiri dan membawa semua yang saya punya,
      akhirnya saya menaggung utang ke pelanggan saya totalnya 470 juta dan di bank totalnya 800 juta ,
      saya stress dan hamper bunuh diri anak saya 2 orng masih sekolah di smp dan sma,
      istri saya pergi entah kemana dan meninggalkan saya dan anakanaknya ditengah tagihan utang yg menumpuk,
      demi makan sehari hari saya terpaksa jual nasi bungkus keliling dan kue,
      ditengah himpitan ekonomi seperti ini saya bertemu dengan seorang teman
      dan bercerita kepadanya, Alhamdulilah beliau memberikan saran kepada saya.
      dulu katanya dia juga seperti saya stelah bergabung dengan KI KUSUMO hidupnya kembali sukses,
      awalnya saya ragu dan tidak percaya tapi selama satu minggu saya berpikir
      dan melihat langsung hasilnya, `
      saya akhirnya bergabung dan menghubungi KI KUSUMO di No :)-0'8'2-3'3'5'-9'4'7'-8'8'8-:).
      Semua petunjuk AKI saya ikuti dan hanya 3 hari Astagfirullahallazim,
      Alhamdulilah Demi AllAH dan anak saya,
      akhirnya 5M yang saya minta benar benar ada di tangan saya,
      semua utang saya lunas dan sisanya buat modal usaha,
      kini saya kembali sukses terimaksih KI KUSUMO saya tidak akan melupakan jasa AKI.
      JIKA TEMAN TEMAN BERMINAT, YAKIN DAN PERCAYA INSYA ALLAH,
      SAYA SUDAH BUKTIKAN DEMI ALLAH SILAHKAN HUB KI KUSUMO DI :)-0'8'2-3'3'5'-9'4'7'-8'8'8-:)

      ((((((((((((DANA GHAIB)))))))))))))))))

      Pesugihan Instant 5 MILYAR
      Mulai bulan ini (oktober 2015) Kami dari padepokan mengadakan program pesugihan Instant tanpa tumbal,
      serta tanpa resiko. Program ini kami khususkan bagi para pasien yang membutuhan modal usaha yang cukup besar,
      Hutang yang menumpuk (diatas 1 Milyar), Adapun ketentuan mengikuti program ini adalah sebagai berikut :

      Mempunyai Hutang diatas 1 Milyar
      Ingin membuka usaha dengan Modal diatas 1 Milyar
      dll

      Syarat :

      Usia Minimal 21 Tahun
      Berani Ritual (apabila tidak berani, maka bisa diwakilkan kami dan tim)
      Belum pernah melakukan perjanjian pesugihan ditempat lain
      Suci lahir dan batin (wanita tidak boleh mengikuti program ini pada saat datang bulan)
      Harus memiliki Kamar Kosong di rumah anda

      Proses :

      Proses ritual selama 2 hari 2 malam di dalam gua
      Harus siap mental lahir dan batin
      Sanggup Puasa 2 hari 2 malam ( ngebleng)
      Pada malam hari tidak boleh tidur

      Biaya ritual Sebesar 10 Juta dengan rincian sebagai berikut :

      Pengganti tumbal Kambing kendit : 5jt
      Ayam cemani : 2jt
      Minyak Songolangit : 2jt
      bunga, candu, kemenyan, nasi tumpeng, kain kafan dll Sebesar : 1jt

      Prosedur Daftar Ritual ini :

      Kirim Foto anda
      Kirim Data sesuai KTP

      Format : Nama, Alamat, Umur, Nama ibu Kandung, Weton (Hari Lahir), PESUGIHAN 5 MILYAR

      Kirim ke nomor ini : -0'8'2'3'3'5'9'4'7'8'8'8-
      SMS Anda akan Kami balas secepatnya

      Maaf Program ini TERBATAS hanya untuk beberapa Orang saja..

      Delete
  2. MISTERI supranatural jokowi
    http://www.supranaturaljokowi.com/2015/02/di-balik-supranatural-airasia.html
    http://www.supranaturaljokowi.com/2015/02/kisah-nyata-beranak-dalam-kuburan.html
    http://www.supranaturaljokowi.com/2015/02/menikah-dengan-bidadari-cantik-dari.html
    http://www.supranaturaljokowi.com/2015/02/kisah-nyata-hantu-casablanca-jakarta.html
    http://www.supranaturaljokowi.com/2015/02/kisah-nyata-pocong-bangkit-dari-kubur.html

    AMALAN SAKTI
    http://www.supranaturaljokowi.com/2015/03/tawasulan.html
    http://www.supranaturaljokowi.com/2015/02/doa-memohon-hajat-besar.html
    http://www.supranaturaljokowi.com/2015/02/ilmu-walisongo-tanah-jawa.html
    http://www.supranaturaljokowi.com/2015/02/kaya-raya-dengan-membaca-basmallah.html
    http://www.supranaturaljokowi.com/2015/03/amalan-dagang-penarik-banyak-pembeli.html

    SEPUTAR BATU AKIK
    http://www.supranaturaljokowi.com/2015/03/batu-biduri-delima.html
    http://www.supranaturaljokowi.com/2015/03/sejarah-batu-akik-klawing.html
    http://www.supranaturaljokowi.com/2015/03/jenis-jenis-batu-kecubung.html
    http://www.supranaturaljokowi.com/2015/03/ciri-ciri-jenis-batu-ruby-asli.html
    http://www.supranaturaljokowi.com/2015/03/perawatan-batu-akik-bulu-macan-lumajang.html


    . http://bagusbenar.com
    .. http://5antri.blogspot.com
    ... http://www.myselebritis.com
    .... http://www.kuasa-illahi.web.id
    ..... http://www.gadisgoyang.blogspot.com

    ReplyDelete

Komentar yang menyertakan iklan, atau titip link, akan dimasukan ke Folder SPAM.

Untuk pertanyaan di luar Topik Artikel silahkan kik OOT (apabila dipertanyakan di sini, mohon maaf apabila tidak dibalas).