diff --git a/src/Controller/TYPProfileController.php b/src/Controller/TYPProfileController.php --- a/src/Controller/TYPProfileController.php +++ b/src/Controller/TYPProfileController.php @@ -1,154 +1,166 @@ redirect(""); }*/ public function formatPhoneNumber($s) { foreach( explode(",", $s) as $p) { $num_com = null; $num_first = null; $num_second = null; $num_ex = explode("-", trim($p)); for($i = 0; $i < count($num_ex); $i++) { if(($i+1) < count($num_ex)) { $num_first .= $num_ex[$i]; } else { $num_second .= $num_ex[$i]; } } if(empty($num_first)) { $num_first = $num_second; $num_second = null; } if(strlen($num_first) == 9) { $num_com = substr($num_first, 0, 1) . '-'. substr($num_first, 1, 4). '-'. substr($num_first, 5,4); if(!empty($num_second)) { $num_com .= '-'.$num_second; } } else { if(strlen($num_first) < 9) { $num_first .= $num_second; if(strlen($num_first) == 9) { $num_com = substr($num_first, 0, 1) . '-'. substr($num_first, 1, 4). '-'. substr($num_first, 5,4); } elseif(strlen($num_first) == 10){ $num_com = substr($num_first, 0, 2) . '-'. substr($num_first, 2, 4). '-'. substr($num_first, 6,7); }else { $num_com = substr($num_first, 0, 1) . '-'. substr($num_first, 1, 4). '-'. substr($num_first, 5,4).'-'.substr($num_first, 9,strlen($num_first)); } } else { if(strlen($num_first) == 10) { $num_com = substr($num_first, 0, 2) . '-'. substr($num_first, 2, 4). '-'. substr($num_first, 6,7); } else { $num_first .= $num_second; $num_com = substr($num_first, 0, 1) . '-'. substr($num_first, 1, 4). '-'. substr($num_first, 5,4).'-'.substr($num_first, 9,strlen($num_first)); } } } $ps[] = $num_com; } return implode(", ", $ps); } public function formatWorkingHour($s) { foreach( explode(",", $s) as $p) { $ps[] = $p; } return implode(", ", $ps); } protected $data; public function profileTitle($bizid) { $this->data = \Drupal::service("typ.search")->getProfile($bizid ,AUTO); if (!$this->data) return ''; else return $this->data['humanname']; } public function profilePage($bizid){ - $this->data = \Drupal::service("typ.search")->getProfile($bizid ,AUTO); $address_id = ""; $language = \Drupal::languageManager()->getCurrentLanguage()->getId(); $data = $this->data; if (!$data) { return $this->redirect(""); } /*if($data['landingpage'] == ""){ $address_id = $data['addressid']; } if(is_numeric($address_id)){ $result = \Drupal::service('typ.unvservice')->loadListing($data['customerid']); $rs_details = (!empty($result['address'][$data['headingcod']][$address_id]['frontviews']))?$result['address'][$headingcode][$data['headingcod']]['frontviews']:array(); } else { $result = \Drupal::service('typ.unvservice')->loadService($data['customerid']); }*/ $address_id = $data['addressid']; $result = \Drupal::service('typ.unvservice')->loadService($data['customerid']); //(!empty($result['landingpages'][$data['headingcode']]))?$result['landingpages'][$data['headingcode']]:array(); //$type = ''; if($result['customertype'] == 'FL'){ $type = 'FL'; }else{ $result_olc = \Drupal::service('typ.catalog')->listData($data['customerid']); } - $pos = strpos(html_entity_decode($data['proddesc']),"

"); if($pos !== false){ $tempdesc = substr(html_entity_decode(html_entity_decode($data['proddesc']),3)); }else{ $tempdesc = html_entity_decode(html_entity_decode($data['proddesc'])) ; //$tempdesc = $data['proddesc']; } $temp = '

'; $tempdesc = $temp.$tempdesc; $type = $data['customertyp']; if($type == "FL") { $dataproddesct = iconv_substr($tempdesc,0,123,"UTF-8"); $dataproddesct .= '...'; }else{ $dataproddesct = $tempdesc; } if($type != "FL" && !empty($result_olc)){ $olcdata = $result_olc[0]; } if (!empty($data['telno'])) { foreach ($data['telno'] as $t) { $data['_format']['telno'][] = $this->formatPhoneNumber($t); } } if (!empty($data['fax'])) { foreach ($data['fax'] as $t) { $data['_format']['fax'][] = $this->formatPhoneNumber($t); } } + + if($type == "FL"){ + unset($data['_format']['telno']); + $data['_format']['telno'][] = $data['_format']['telno'][0]; + unset($data['fax']); + $data['fax'][] = $data['fax'][0]; + $exp = explode(",", $data['email']); + unset($data['email']); + $data['email'][] = $exp[0]; + }else{ + $exp = explode(",", $data['email']); + $data['email'] = $exp; + } + if (!empty($data['workinghours'])) $data['_format']['workinghours'] = $this->formatWorkingHour($data['workinghours']); - + $display[] = array( '#theme' => 'typ_profile', '#profile' => $data, '#prodescription' => $dataproddesct, '#catalog' => $olcdata, '#type' => $type ); return $display; } } \ No newline at end of file diff --git a/templates/typ-profile.html.twig b/templates/typ-profile.html.twig --- a/templates/typ-profile.html.twig +++ b/templates/typ-profile.html.twig @@ -1,276 +1,279 @@ {% set base_images = 'http://media.yellowpages.co.th/yellowpages'%}

{% if profile.logo %}
{% endif %}

{{ profile.humanname|raw }}

หมวดหมู่ : {{ profile.headingname|raw }}

{% trans %} Address {% endtrans %} {% if profile.location.lat %}
{% else %}
{% endif %} {{ [profile.addr,profile.soi,profile.road,profile.subdistrictname, profile.districtname,profile.cityname,profile.postcode]|join(' ') }}

{% if not profile.telno %}{% else %}{% trans %} Tel {% endtrans %}
{% endif %} {% if not profile.fax %}{% else %}{% trans %} Fax {% endtrans %}
{% endif %} {% if not profile.email %}{% else %}{% trans %} Email {% endtrans %}
{% endif %} {% if not profile.websit %}{% else %}{% trans %} Website {% endtrans %}
{% endif %} {% if not profile.workinghours %}{% else %}{% trans %} Work-Time {% endtrans %}{% endif %}
{% if not profile.telno %} {% else %} {% if type == 'FL' %} {{ profile.telno.0 }}
{% else %} {% for key, tel in profile._format.telno %} {% if loop.last != key+1 %}{{ tel }}{{ " ," }} {% else %}{{ tel }}{% endif %} {% endfor %}
{% endif %} {% endif %} {% if not profile.fax %} {% else %} {% if type == 'FL' %} {{ profile._format.fax.0 }}
{% else %} {% for key, fax in profile._format.fax %} {% if loop.last != key+1 %}{{ fax }}{{ " ," }} {% else %}{{ fax }}{% endif %} {% endfor %}
{% endif %} {% endif %} {% if not profile.email %} {% else %} {% if type == 'FL' %} {{ profile.email }}
{% else %} {% set email = profile.email|split(',') %} {% for key , mail in email %} {% if loop.last != key+1 %}{{ mail }} , {% else %}{{ mail }}
{% endif %} {% endfor %} {% endif %} {% endif %} {% if not profile.websit %} {% else %} {% set website = profile.websit|split(',') %} {% for key , web in website %} {% if loop.last != key+1 %}{{ web }} , {% else %}{{ web }}
{% endif %} {% endfor %} {% endif %} {% if not profile.workinghours %} {% else %} {{ profile._format.workinghours }}
{% endif %}
+ + +
{% if not prodescription %} {% else %}
{% trans %} Product And Service {% endtrans %}

{{ prodescription|raw }}
{% endif %} {% if not profile.brandname %} {% else %}
{% trans %} Banner {% endtrans %} : {{ profile.brandname|replace({"

":" ","

":" "}) }} {% endif %}


{# TAB #} {% if type == 'FL' %}{% else %}
{% if profile.picturet1 %}

{% if profile.picturet1 %} {% endif %} {% if profile.picturet2 %} {% endif %} {% if profile.picturet3 %} {% endif %} {% if profile.picturet4 %} {% endif %} {% if profile.picturet5 %} {% endif %} {% if profile.picturet6 %} {% endif %} {% if profile.picturet7 %} {% endif %} {% if profile.picturet8 %} {% endif %} {% if profile.picturet9 %} {% endif %}
{% endif %} {% if profile.location.lat %} {% endif %} {% if profile.printadst %} {% endif %} {% if profile.promotion %} {% endif %} {% if profile.map %} {% endif %}
{% endif %} {#


#} {#{% if not profile.custname %}#} {#{% else %}#} {#{{ profile.custname|raw }} : แสดงความคิดเห็น#} {#{% endif %}#} {#

#} {# TAB #} {#
#} {##} {#
#} {##} {##} {#{##}#} {#
#} {#
#} {# END TAB #}