' . t('Use /expression/ to provide regular expressions') . '
';
$s .= '
';
@@ -58,34 +66,66 @@ function showmore_addon_settings_post(&$a,&$b) {
return;
if($_POST['showmore-submit']) {
- set_pconfig(local_user(),'showmore','chars',trim($_POST['showmore-chars']));
+ PConfig::set(local_user(),'showmore','chars',trim($_POST['showmore-chars']));
$enable = ((x($_POST,'showmore-enable')) ? intval($_POST['showmore-enable']) : 0);
$disable = 1-$enable;
- set_pconfig(local_user(),'showmore','disable', $disable);
+ PConfig::set(local_user(),'showmore','disable', $disable);
info( t('Show More Settings saved.') . EOL);
}
}
+function get_body_length($body) {
+ $string = trim($body);
+
+ // DomDocument doesn't like empty strings
+ if(! strlen($string)) {
+ return 0;
+ }
+
+ // We need to get rid of hidden tags (display: none)
+
+ // Get rid of the warning. It would be better to have some valid html as input
+ $dom = @DomDocument::loadHTML($body);
+ $xpath = new DOMXPath($dom);
+
+ /*
+ * Checking any possible syntax of the style attribute with xpath is impossible
+ * So we just get any element with a style attribute, and check them with a regexp
+ */
+ $xr = $xpath->query('//*[@style]');
+ foreach($xr as $node) {
+ if(preg_match('/.*display: *none *;.*/',$node->getAttribute('style'))) {
+ // Hidden, remove it from its parent
+ $node->parentNode->removeChild($node);
+ }
+ }
+ // Now we can get the body of our HTML DomDocument, it contains only what is visible
+ $string = $dom->saveHTML();
+
+ $string = strip_tags($string);
+ return strlen($string);
+}
+
function showmore_prepare_body(&$a,&$b) {
$words = null;
- if(get_pconfig(local_user(),'showmore','disable'))
+ if(PConfig::get(local_user(),'showmore','disable'))
return;
- $chars = (int)get_pconfig(local_user(),'showmore','chars');
+ $chars = (int)PConfig::get(local_user(),'showmore','chars');
if(!$chars)
$chars = 1100;
- if (strlen(strip_tags(trim($b['html']))) > $chars) {
+ if (get_body_length($b['html']) > $chars) {
$found = true;
$shortened = trim(showmore_cutitem($b['html'], $chars))."...";
}
if($found) {
$rnd = random_string(8);
- $b['html'] = ''.$shortened." ".
- ''.sprintf(t('show more')).''.
- '