X-Git-Url: http://git.roojs.org/?p=Pman.Core;a=blobdiff_plain;f=ConvertStyle.php;h=4f52e1016cee579761774899efbaa04e21ed42c7;hp=4d7eca30df6abe9c0060f64b4484721808da60da;hb=refs%2Fheads%2Fwip_alan_T6343_generic_progress_bar_delete;hpb=b4c981cb84ec3b4ca140985d91d233a2e1485b65 diff --git a/ConvertStyle.php b/ConvertStyle.php index 4d7eca30..4f52e101 100644 --- a/ConvertStyle.php +++ b/ConvertStyle.php @@ -18,18 +18,22 @@ class Pman_Core_ConvertStyle extends Pman } function relPath($base, $url) - { + { + if (preg_match('/^(http|https|mailto):/',$url)) { return $url; } + $ui = parse_url($base); + if($ui['host'] == 'localhost'){ + return $ui['scheme'] .'://'.$ui['host']. $ui['path'] . '/'. $url; + } + if (substr($url,0,2) == '//') { return $ui['scheme'] .':' . $url; } - - if (substr($url,0,1) == '/') { return $ui['scheme'] .'://'.$ui['host']. $url; } @@ -48,10 +52,10 @@ class Pman_Core_ConvertStyle extends Pman function checkHeader($url) { - if(strpos($url, 'https') !== false) - { - $this->jerr('accept HTTP url only!'); - } + // if(strpos($url, 'https') !== false) + // { + // $this->jerr('accept HTTP url only!'); + // } $headers = get_headers($url, 1); if(strpos(is_array($headers['Content-Type']) ? $headers['Content-Type'][0] : $headers['Content-Type'], 'text/html') === false) { @@ -62,9 +66,11 @@ class Pman_Core_ConvertStyle extends Pman var $styleSheets = array(); - function convertStyle($url, $file) + function convertStyle($url, $file, $is_url = true) { - if(!empty($url)) + $inLineCss = true; + + if($is_url && !empty($url)) { $host = parse_url($url); require_once 'System.php'; @@ -80,35 +86,20 @@ class Pman_Core_ConvertStyle extends Pman if (!trim(strlen($data))) { $this->jerr("url returned an empty string"); } - // $this->jerr($url); - /*require_once 'HTTP/Request.php'; - $a = new HTTP_Request($url, array( - 'allowRedirects' => true, - 'maxRedirects' => 2, - 'userAgent' => 'Mozilla/5.0 (X11; Linux x86_64) AppleWebKit/537.4 (KHTML, like Gecko) Chrome/22.0.1229.94 Safari/537.4', - )); - $a->sendRequest(); - // if this results in an errorr or redirect.. - // we should log that somewhere.. and display it on the feed... - - $data = $a->getResponseBody(); - */ - - //$this->jerr($data); - - // $data = file_get_contents($url); } - if(file_exists($file)) - { + + if(!$is_url){ $data = file_get_contents($file); } + if(preg_match('/^\s*\s*/', $data)){ + $inLineCss = false; + } + libxml_use_internal_errors (true); $doc = new DOMDocument('1.0', 'UTF-8'); $doc->loadHTML(''.$data); $doc->formatOutput = true; - - $xpath = new DOMXpath($doc); foreach ($xpath->query('//img[@src]') as $img) { @@ -138,20 +129,27 @@ class Pman_Core_ConvertStyle extends Pman if($l->getAttribute('rel') == 'stylesheet'){ $href = $l->getAttribute('href'); - - if (empty($url) && !preg_match("/^http(.*)$/", $href, $matches)) { - // import from file , must use absolutely url - $this->jerr('Please use the absolutely url for link href!'); - } - if (!empty($url)) { - // import from URL + if(!preg_match("/^http(.*)$/", $href, $matches)){ + if(empty($url)){ + $this->jerr('Please use the absolutely url for link href!'); + } $href = $this->relPath($url, $href); } + $this->styleSheets[$href] = $this->replaceImageUrl(file_get_contents($href),$href); } } + + foreach ($xpath->query('//style') as $s){ + $this->styleSheets[] = $this->replaceImageUrl($s->nodeValue, $url); + } + $data = $doc->saveHTML(); + if(!$inLineCss){ + return $data; + } + $htmldoc = new HTML_CSS_InlineStyle($data); if(count($this->styleSheets) > 0){ foreach ($this->styleSheets as $styleSheet){ @@ -165,9 +163,6 @@ class Pman_Core_ConvertStyle extends Pman return "INSTALL TIDY ON SERVER " . $html; } - // finally clean it up... using tidy... - - $html = tidy_repair_string( $html, array(