Instant Articles for WP - Version 3.1.2

Version Description

Download this release

Release Info

Developer philipjohn
Plugin Icon 128x128 Instant Articles for WP
Version 3.1.2
Comparing to
See all releases

Code changes from version 3.1.1 to 3.1.2

Files changed (22) hide show
  1. facebook-instant-articles.php +1 -1
  2. readme.txt +1 -1
  3. vendor/composer/installed.json +6 -6
  4. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/Element.php +18 -1
  5. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/GeoTag.php +4 -1
  6. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/InstantArticle.php +1 -1
  7. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/ChildrenGetter.php +5 -1
  8. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/ElementGetter.php +3 -1
  9. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/FragmentGetter.php +49 -0
  10. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/GetterFactory.php +7 -1
  11. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/MultipleElementsGetter.php +44 -0
  12. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/NextSiblingElementGetter.php +75 -0
  13. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Transformer.php +77 -0
  14. vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Warnings/InvalidSelector.php +12 -4
  15. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/WPTransformerTest.php +21 -1
  16. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp-ia.xml +47 -0
  17. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp-rules.json +90 -2
  18. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp.html +88 -0
  19. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/Example/simple-ia.html +1 -1
  20. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/TransformerTest.php +93 -19
  21. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/instant-article-example-multibyte.html +204 -0
  22. vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/instant-article-example-nonutf8.html +204 -0
facebook-instant-articles.php CHANGED
@@ -4,7 +4,7 @@
4
  * Description: Add support for Instant Articles for Facebook to your WordPress site.
5
  * Author: Automattic, Dekode, Facebook
6
  * Author URI: https://vip.wordpress.com/plugins/instant-articles/
7
- * Version: 3.1.1
8
  * Text Domain: instant-articles
9
  * License: GPLv2
10
  * License URI: http://www.gnu.org/licenses/gpl-2.0.html
4
  * Description: Add support for Instant Articles for Facebook to your WordPress site.
5
  * Author: Automattic, Dekode, Facebook
6
  * Author URI: https://vip.wordpress.com/plugins/instant-articles/
7
+ * Version: 3.1.2
8
  * Text Domain: instant-articles
9
  * License: GPLv2
10
  * License URI: http://www.gnu.org/licenses/gpl-2.0.html
readme.txt CHANGED
@@ -3,7 +3,7 @@ Contributors: trrine, olethomas, bjornjohansen, dekode, automattic, facebook
3
  Tags: instant articles, facebook, mobile
4
  Requires at least: 4.3
5
  Tested up to: 4.6
6
- Stable tag: 3.1.1
7
  License: GPLv2 or later
8
  License URI: http://www.gnu.org/licenses/gpl-2.0.html
9
 
3
  Tags: instant articles, facebook, mobile
4
  Requires at least: 4.3
5
  Tested up to: 4.6
6
+ Stable tag: 3.1.2
7
  License: GPLv2 or later
8
  License URI: http://www.gnu.org/licenses/gpl-2.0.html
9
 
vendor/composer/installed.json CHANGED
@@ -148,17 +148,17 @@
148
  },
149
  {
150
  "name": "facebook/facebook-instant-articles-sdk-php",
151
- "version": "v1.4.0",
152
- "version_normalized": "1.4.0.0",
153
  "source": {
154
  "type": "git",
155
  "url": "https://github.com/facebook/facebook-instant-articles-sdk-php.git",
156
- "reference": "c46c25b2d1c4100885383667cde1a863440aff2a"
157
  },
158
  "dist": {
159
  "type": "zip",
160
- "url": "https://api.github.com/repos/facebook/facebook-instant-articles-sdk-php/zipball/c46c25b2d1c4100885383667cde1a863440aff2a",
161
- "reference": "c46c25b2d1c4100885383667cde1a863440aff2a",
162
  "shasum": ""
163
  },
164
  "require": {
@@ -172,7 +172,7 @@
172
  "phpunit/phpunit": "^4.8",
173
  "squizlabs/php_codesniffer": "^2.6.0"
174
  },
175
- "time": "2016-08-13 06:34:04",
176
  "type": "library",
177
  "installation-source": "dist",
178
  "autoload": {
148
  },
149
  {
150
  "name": "facebook/facebook-instant-articles-sdk-php",
151
+ "version": "v1.5.0",
152
+ "version_normalized": "1.5.0.0",
153
  "source": {
154
  "type": "git",
155
  "url": "https://github.com/facebook/facebook-instant-articles-sdk-php.git",
156
+ "reference": "e7ba342acea3106a83210196c952fbbed0f0fe30"
157
  },
158
  "dist": {
159
  "type": "zip",
160
+ "url": "https://api.github.com/repos/facebook/facebook-instant-articles-sdk-php/zipball/e7ba342acea3106a83210196c952fbbed0f0fe30",
161
+ "reference": "e7ba342acea3106a83210196c952fbbed0f0fe30",
162
  "shasum": ""
163
  },
164
  "require": {
172
  "phpunit/phpunit": "^4.8",
173
  "squizlabs/php_codesniffer": "^2.6.0"
174
  },
175
+ "time": "2016-08-26 13:55:03",
176
  "type": "library",
177
  "installation-source": "dist",
178
  "autoload": {
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/Element.php CHANGED
@@ -37,11 +37,28 @@ abstract class Element
37
  $document->formatOutput = $formatted;
38
  $element = $this->toDOMElement($document);
39
  $document->appendChild($element);
40
- $rendered = $doctype.$document->saveXML($element);
41
 
42
  // We can't currently use DOMDocument::saveHTML, because it doesn't produce proper HTML5 markup, so we have to strip CDATA enclosures
43
  // TODO Consider replacing this workaround with a parent class for elements that will be rendered and in this class use the `srcdoc` attribute to output the (escaped) markup
44
  $rendered = preg_replace('/<!\[CDATA\[(.*?)\]\]>/is', '$1', $rendered);
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
45
 
46
  return $rendered;
47
  }
37
  $document->formatOutput = $formatted;
38
  $element = $this->toDOMElement($document);
39
  $document->appendChild($element);
40
+ $rendered = $doctype.$document->saveXML($element, LIBXML_NOEMPTYTAG);
41
 
42
  // We can't currently use DOMDocument::saveHTML, because it doesn't produce proper HTML5 markup, so we have to strip CDATA enclosures
43
  // TODO Consider replacing this workaround with a parent class for elements that will be rendered and in this class use the `srcdoc` attribute to output the (escaped) markup
44
  $rendered = preg_replace('/<!\[CDATA\[(.*?)\]\]>/is', '$1', $rendered);
45
+ // Fix void HTML5 elements (these can't be closed like in XML)
46
+ $rendered = str_replace('></area>', '/>', $rendered);
47
+ $rendered = str_replace('></base>', '/>', $rendered);
48
+ $rendered = str_replace('></br>', '/>', $rendered);
49
+ $rendered = str_replace('></col>', '/>', $rendered);
50
+ $rendered = str_replace('></command>', '/>', $rendered);
51
+ $rendered = str_replace('></embed>', '/>', $rendered);
52
+ $rendered = str_replace('></hr>', '/>', $rendered);
53
+ $rendered = str_replace('></img>', '/>', $rendered);
54
+ $rendered = str_replace('></input>', '/>', $rendered);
55
+ $rendered = str_replace('></keygen>', '/>', $rendered);
56
+ $rendered = str_replace('></link>', '/>', $rendered);
57
+ $rendered = str_replace('></meta>', '/>', $rendered);
58
+ $rendered = str_replace('></param>', '/>', $rendered);
59
+ $rendered = str_replace('></source>', '/>', $rendered);
60
+ $rendered = str_replace('></track>', '/>', $rendered);
61
+ $rendered = str_replace('></wbr>', '/>', $rendered);
62
 
63
  return $rendered;
64
  }
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/GeoTag.php CHANGED
@@ -101,7 +101,10 @@ class GeoTag extends Element
101
 
102
  // Required script field
103
  if ($this->script) {
104
- $element->appendChild($document->createTextNode($this->script));
 
 
 
105
  }
106
 
107
  return $element;
101
 
102
  // Required script field
103
  if ($this->script) {
104
+ // script may contain html entities so import it as CDATA
105
+ $element->appendChild(
106
+ $element->ownerDocument->importNode(new \DOMCdataSection($this->script), true)
107
+ );
108
  }
109
 
110
  return $element;
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Elements/InstantArticle.php CHANGED
@@ -34,7 +34,7 @@ use Facebook\InstantArticles\Validators\Type;
34
 
35
  class InstantArticle extends Element implements Container, InstantArticleInterface
36
  {
37
- const CURRENT_VERSION = '1.4.0';
38
 
39
  /**
40
  * The meta properties that are used on <head>
34
 
35
  class InstantArticle extends Element implements Container, InstantArticleInterface
36
  {
37
+ const CURRENT_VERSION = '1.5.0';
38
 
39
  /**
40
  * The meta properties that are used on <head>
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/ChildrenGetter.php CHANGED
@@ -8,6 +8,9 @@
8
  */
9
  namespace Facebook\InstantArticles\Transformer\Getters;
10
 
 
 
 
11
  class ChildrenGetter extends ElementGetter
12
  {
13
  public function get($node)
@@ -16,7 +19,8 @@ class ChildrenGetter extends ElementGetter
16
  if ($element) {
17
  $fragment = $element->ownerDocument->createDocumentFragment();
18
  foreach ($element->childNodes as $child) {
19
- $fragment->appendChild($child->cloneNode(true));
 
20
  }
21
  if ($fragment->hasChildNodes()) {
22
  return $fragment;
8
  */
9
  namespace Facebook\InstantArticles\Transformer\Getters;
10
 
11
+ use Facebook\InstantArticles\Validators\Type;
12
+ use Facebook\InstantArticles\Transformer\Transformer;
13
+
14
  class ChildrenGetter extends ElementGetter
15
  {
16
  public function get($node)
19
  if ($element) {
20
  $fragment = $element->ownerDocument->createDocumentFragment();
21
  foreach ($element->childNodes as $child) {
22
+ Transformer::markAsProcessed($child);
23
+ $fragment->appendChild(Transformer::cloneNode($child));
24
  }
25
  if ($fragment->hasChildNodes()) {
26
  return $fragment;
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/ElementGetter.php CHANGED
@@ -9,6 +9,7 @@
9
  namespace Facebook\InstantArticles\Transformer\Getters;
10
 
11
  use Facebook\InstantArticles\Validators\Type;
 
12
  use Symfony\Component\CssSelector\CssSelectorConverter;
13
 
14
  class ElementGetter extends AbstractGetter
@@ -53,7 +54,8 @@ class ElementGetter extends AbstractGetter
53
  {
54
  $elements = self::findAll($node, $this->selector);
55
  if (!empty($elements)) {
56
- return $elements->item(0);
 
57
  }
58
  return null;
59
  }
9
  namespace Facebook\InstantArticles\Transformer\Getters;
10
 
11
  use Facebook\InstantArticles\Validators\Type;
12
+ use Facebook\InstantArticles\Transformer\Transformer;
13
  use Symfony\Component\CssSelector\CssSelectorConverter;
14
 
15
  class ElementGetter extends AbstractGetter
54
  {
55
  $elements = self::findAll($node, $this->selector);
56
  if (!empty($elements)) {
57
+ Transformer::markAsProcessed($elements->item(0));
58
+ return Transformer::cloneNode($elements->item(0));
59
  }
60
  return null;
61
  }
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/FragmentGetter.php ADDED
@@ -0,0 +1,49 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <?php
2
+ /**
3
+ * Copyright (c) 2016-present, Facebook, Inc.
4
+ * All rights reserved.
5
+ *
6
+ * This source code is licensed under the license found in the
7
+ * LICENSE file in the root directory of this source tree.
8
+ */
9
+ namespace Facebook\InstantArticles\Transformer\Getters;
10
+
11
+ use Facebook\InstantArticles\Validators\Type;
12
+ use Facebook\InstantArticles\Transformer\Transformer;
13
+ use Symfony\Component\CssSelector\CssSelectorConverter;
14
+
15
+ class FragmentGetter extends AbstractGetter
16
+ {
17
+ /**
18
+ * @var string
19
+ */
20
+ protected $fragment;
21
+
22
+ public function createFrom($properties)
23
+ {
24
+ return $this->withFragment($properties['fragment']);
25
+ }
26
+
27
+ /**
28
+ * @param string $fragment
29
+ *
30
+ * @return $this
31
+ */
32
+ public function withFragment($fragment)
33
+ {
34
+ Type::enforce($fragment, Type::STRING);
35
+ $this->fragment = $fragment;
36
+
37
+ return $this;
38
+ }
39
+
40
+ public function get($node)
41
+ {
42
+ $fragment = $node->ownerDocument->createDocumentFragment();
43
+ $is_valid_markup = @$fragment->appendXML($this->fragment);
44
+ if ($is_valid_markup) {
45
+ return $fragment;
46
+ }
47
+ return null;
48
+ }
49
+ }
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/GetterFactory.php CHANGED
@@ -14,10 +14,13 @@ class GetterFactory
14
  const TYPE_INTEGER_GETTER = 'int';
15
  const TYPE_CHILDREN_GETTER = 'children';
16
  const TYPE_ELEMENT_GETTER = 'element';
 
17
  const TYPE_NEXTSIBLING_GETTER = 'sibling';
 
18
  const TYPE_EXISTS_GETTER = 'exists';
19
  const TYPE_JSON_GETTER = 'json';
20
  const TYPE_XPATH_GETTER = 'xpath';
 
21
 
22
  /**
23
  * Creates an Getter class.
@@ -47,10 +50,13 @@ class GetterFactory
47
  self::TYPE_INTEGER_GETTER => IntegerGetter::getClassName(),
48
  self::TYPE_CHILDREN_GETTER => ChildrenGetter::getClassName(),
49
  self::TYPE_ELEMENT_GETTER => ElementGetter::getClassName(),
 
50
  self::TYPE_NEXTSIBLING_GETTER => NextSiblingGetter::getClassName(),
 
51
  self::TYPE_EXISTS_GETTER => ExistsGetter::getClassName(),
52
  self::TYPE_JSON_GETTER => JSONGetter::getClassName(),
53
- self::TYPE_XPATH_GETTER => XpathGetter::getClassName()
 
54
  ];
55
 
56
  $class = $getter_configuration['type'];
14
  const TYPE_INTEGER_GETTER = 'int';
15
  const TYPE_CHILDREN_GETTER = 'children';
16
  const TYPE_ELEMENT_GETTER = 'element';
17
+ const TYPE_FRAGMENT_GETTER = 'fragment';
18
  const TYPE_NEXTSIBLING_GETTER = 'sibling';
19
+ const TYPE_NEXTSIBLINGELEMENT_GETTER = 'next-sibling-element-of';
20
  const TYPE_EXISTS_GETTER = 'exists';
21
  const TYPE_JSON_GETTER = 'json';
22
  const TYPE_XPATH_GETTER = 'xpath';
23
+ const TYPE_MULTIPLEELEMENTS_GETTER = 'multiple';
24
 
25
  /**
26
  * Creates an Getter class.
50
  self::TYPE_INTEGER_GETTER => IntegerGetter::getClassName(),
51
  self::TYPE_CHILDREN_GETTER => ChildrenGetter::getClassName(),
52
  self::TYPE_ELEMENT_GETTER => ElementGetter::getClassName(),
53
+ self::TYPE_FRAGMENT_GETTER => FragmentGetter::getClassName(),
54
  self::TYPE_NEXTSIBLING_GETTER => NextSiblingGetter::getClassName(),
55
+ self::TYPE_NEXTSIBLINGELEMENT_GETTER => NextSiblingElementGetter::getClassName(),
56
  self::TYPE_EXISTS_GETTER => ExistsGetter::getClassName(),
57
  self::TYPE_JSON_GETTER => JSONGetter::getClassName(),
58
+ self::TYPE_XPATH_GETTER => XpathGetter::getClassName(),
59
+ self::TYPE_MULTIPLEELEMENTS_GETTER => MultipleElementsGetter::getClassName()
60
  ];
61
 
62
  $class = $getter_configuration['type'];
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/MultipleElementsGetter.php ADDED
@@ -0,0 +1,44 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <?php
2
+ /**
3
+ * Copyright (c) 2016-present, Facebook, Inc.
4
+ * All rights reserved.
5
+ *
6
+ * This source code is licensed under the license found in the
7
+ * LICENSE file in the root directory of this source tree.
8
+ */
9
+ namespace Facebook\InstantArticles\Transformer\Getters;
10
+
11
+ use Facebook\InstantArticles\Validators\Type;
12
+ use Facebook\InstantArticles\Transformer\Transformer;
13
+ use Symfony\Component\CssSelector\CssSelectorConverter;
14
+
15
+ class MultipleElementsGetter extends AbstractGetter
16
+ {
17
+ /**
18
+ * @var Getters
19
+ */
20
+ protected $children = [];
21
+
22
+ public function createFrom($properties)
23
+ {
24
+ foreach ($properties['children'] as $getter_configuration) {
25
+ $this->children[] = GetterFactory::create($getter_configuration);
26
+ }
27
+ return $this;
28
+ }
29
+
30
+ public function get($node)
31
+ {
32
+ $fragment = $node->ownerDocument->createDocumentFragment();
33
+ foreach ($this->children as $child) {
34
+ $cloned_node = $child->get($node);
35
+ if (Type::is($cloned_node, 'DOMNode')) {
36
+ $fragment->appendChild($cloned_node);
37
+ }
38
+ }
39
+ if ($fragment->hasChildNodes()) {
40
+ return $fragment;
41
+ }
42
+ return null;
43
+ }
44
+ }
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Getters/NextSiblingElementGetter.php ADDED
@@ -0,0 +1,75 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <?php
2
+ /**
3
+ * Copyright (c) 2016-present, Facebook, Inc.
4
+ * All rights reserved.
5
+ *
6
+ * This source code is licensed under the license found in the
7
+ * LICENSE file in the root directory of this source tree.
8
+ */
9
+ namespace Facebook\InstantArticles\Transformer\Getters;
10
+
11
+ use Facebook\InstantArticles\Validators\Type;
12
+ use Facebook\InstantArticles\Transformer\Transformer;
13
+ use Facebook\InstantArticles\Transformer\Warnings\InvalidSelector;
14
+
15
+ class NextSiblingElementGetter extends ElementGetter
16
+ {
17
+ protected $siblingSelector;
18
+
19
+ /**
20
+ * @param string $siblingSelector
21
+ *
22
+ * @return $this
23
+ */
24
+ public function withSiblingSelector($siblingSelector)
25
+ {
26
+ Type::enforce($siblingSelector, Type::STRING);
27
+ $this->siblingSelector = $siblingSelector;
28
+
29
+ return $this;
30
+ }
31
+
32
+ public function createFrom($properties)
33
+ {
34
+ if (isset($properties['selector'])) {
35
+ $this->withSelector($properties['selector']);
36
+ }
37
+ if (isset($properties['attribute'])) {
38
+ $this->withAttribute($properties['attribute']);
39
+ }
40
+ if (isset($properties['sibling.selector'])) {
41
+ $this->withSiblingSelector($properties['sibling.selector']);
42
+ }
43
+
44
+ return $this;
45
+ }
46
+
47
+ public function get($node)
48
+ {
49
+ Type::enforce($node, 'DOMNode');
50
+ $elements = self::findAll($node, $this->selector);
51
+ if (!empty($elements) && $elements->item(0)) {
52
+ $element = $elements->item(0);
53
+ do {
54
+ $element = $element->nextSibling;
55
+ } while ($element !== null && !Type::is($element, 'DOMElement'));
56
+
57
+ if ($element && Type::is($element, 'DOMElement')) {
58
+ if ($this->siblingSelector) {
59
+ $siblings = self::findAll($element, $this->siblingSelector);
60
+ if (!empty($siblings) && $siblings->item(0)) {
61
+ $siblingElement = $siblings->item(0);
62
+ } else {
63
+ // Returns null because sibling content doesn't match
64
+ return null;
65
+ }
66
+ } else {
67
+ $siblingElement = $element;
68
+ }
69
+ Transformer::markAsProcessed($siblingElement);
70
+ return Transformer::cloneNode($siblingElement);
71
+ }
72
+ }
73
+ return null;
74
+ }
75
+ }
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Transformer.php CHANGED
@@ -46,6 +46,50 @@ class Transformer
46
  */
47
  private $instantArticle;
48
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
49
  /**
50
  * Gets all types a given class is, including itself, parent classes and interfaces.
51
  *
@@ -120,6 +164,36 @@ class Transformer
120
  return $this->instantArticle;
121
  }
122
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
123
  /**
124
  * @param InstantArticle $context
125
  * @param \DOMNode $node
@@ -147,6 +221,9 @@ class Transformer
147
  $current_context = $context;
148
  if ($node->hasChildNodes()) {
149
  foreach ($node->childNodes as $child) {
 
 
 
150
  $matched = false;
151
  $log->debug("===========================");
152
  $log->debug($child->ownerDocument->saveHtml($child));
46
  */
47
  private $instantArticle;
48
 
49
+ /**
50
+ * Flag attribute added to elements processed by a getter, so they
51
+ * are not processed again by other rules.
52
+ */
53
+ const INSTANT_ARTICLES_PARSED_FLAG = 'data-instant-articles-element-processed';
54
+
55
+ /**
56
+ * Clones a node for appending to raw-html containing Elements like Interactive.
57
+ *
58
+ * @param DOMNode $node The node to clone
59
+ * @return DOMNode The cloned node.
60
+ */
61
+ public static function cloneNode($node)
62
+ {
63
+ $clone = $node->cloneNode(true);
64
+ if (Type::is($clone, 'DOMElement') && $clone->hasAttribute(self::INSTANT_ARTICLES_PARSED_FLAG)) {
65
+ $clone->removeAttribute(self::INSTANT_ARTICLES_PARSED_FLAG);
66
+ }
67
+ return $clone;
68
+ }
69
+
70
+ /**
71
+ * Marks a node as processed.
72
+ *
73
+ * @param DOMElement $node The node to clone
74
+ */
75
+ public static function markAsProcessed($node)
76
+ {
77
+ if (Type::is($node, 'DOMElement')) {
78
+ $node->setAttribute(self::INSTANT_ARTICLES_PARSED_FLAG, true);
79
+ }
80
+ }
81
+
82
+ /**
83
+ * Returns whether a node is processed
84
+ *
85
+ * @param DOMNode $node The node to clone
86
+ */
87
+ protected static function isProcessed($node)
88
+ {
89
+ return Type::is($node, 'DOMElement') && $node->getAttribute(self::INSTANT_ARTICLES_PARSED_FLAG);
90
+ }
91
+
92
+
93
  /**
94
  * Gets all types a given class is, including itself, parent classes and interfaces.
95
  *
164
  return $this->instantArticle;
165
  }
166
 
167
+ /**
168
+ * @param InstantArticle $context
169
+ * @param string $content
170
+ *
171
+ * @return mixed
172
+ */
173
+ public function transformString($context, $content, $encoding = "utf-8")
174
+ {
175
+ $libxml_previous_state = libxml_use_internal_errors(true);
176
+ $document = new \DOMDocument('1.0');
177
+ if (function_exists('mb_convert_encoding')) {
178
+ $document->loadHTML(mb_convert_encoding($content, 'HTML-ENTITIES', $encoding));
179
+ } else {
180
+ $log = \Logger::getLogger('facebook-instantarticles-transformer');
181
+ $log->debug(
182
+ 'Your content encoding is "' . $encoding . '" ' .
183
+ 'but your PHP environment does not have mbstring. Trying to load your content with using meta tags.'
184
+ );
185
+ // wrap the content with charset meta tags
186
+ $document->loadHTML(
187
+ '<html><head>' .
188
+ '<meta http-equiv="Content-Type" content="text/html; charset=' . $encoding . '">' .
189
+ '</head><body>' . $content . '</body></html>'
190
+ );
191
+ }
192
+ libxml_clear_errors();
193
+ libxml_use_internal_errors($libxml_previous_state);
194
+ return $this->transform($context, $document);
195
+ }
196
+
197
  /**
198
  * @param InstantArticle $context
199
  * @param \DOMNode $node
221
  $current_context = $context;
222
  if ($node->hasChildNodes()) {
223
  foreach ($node->childNodes as $child) {
224
+ if (self::isProcessed($child)) {
225
+ continue;
226
+ }
227
  $matched = false;
228
  $log->debug("===========================");
229
  $log->debug($child->ownerDocument->saveHtml($child));
vendor/facebook/facebook-instant-articles-sdk-php/src/Facebook/InstantArticles/Transformer/Warnings/InvalidSelector.php CHANGED
@@ -55,11 +55,19 @@ class InvalidSelector
55
  */
56
  public function __toString()
57
  {
58
- $reflection = new \ReflectionClass(get_class($this->context));
59
- $class_name = $reflection->getShortName();
 
 
 
 
60
 
61
- $reflection = new \ReflectionClass(get_class($this->rule));
62
- $rule_name = $reflection->getShortName();
 
 
 
 
63
 
64
  $has_properties = false;
65
  $str_properties = '';
55
  */
56
  public function __toString()
57
  {
58
+ if (isset($this->context)) {
59
+ $reflection = new \ReflectionClass(get_class($this->context));
60
+ $class_name = $reflection->getShortName();
61
+ } else {
62
+ $class_name = 'no context provided';
63
+ }
64
 
65
+ if (isset($this->rule)) {
66
+ $reflection = new \ReflectionClass(get_class($this->rule));
67
+ $rule_name = $reflection->getShortName();
68
+ } else {
69
+ $rule_name = 'no rule provided';
70
+ }
71
 
72
  $has_properties = false;
73
  $str_properties = '';
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/WPTransformerTest.php CHANGED
@@ -73,6 +73,26 @@ class WPTransformerTest extends \PHPUnit_Framework_TestCase
73
 
74
  $this->assertEquals($expected, $result);
75
  // there must be 3 warnings related to <img> inside <li> that is not supported by IA
76
- $this->assertEquals(3, count($transformer->getWarnings()));
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
77
  }
78
  }
73
 
74
  $this->assertEquals($expected, $result);
75
  // there must be 3 warnings related to <img> inside <li> that is not supported by IA
76
+ // And 1 warning related to the getter
77
+ $this->assertEquals(4, count($transformer->getWarnings()));
78
+ }
79
+
80
+ public function testTitleTransformedWithBold()
81
+ {
82
+ $transformer = new Transformer();
83
+ $json_file = file_get_contents(__DIR__ . '/wp-rules.json');
84
+ $transformer->loadRules($json_file);
85
+
86
+ $title_html_string = '<?xml encoding="utf-8" ?><h1>Title <b>in bold</b></h1>';
87
+
88
+ libxml_use_internal_errors(true);
89
+ $document = new \DOMDocument();
90
+ $document->loadHtml($title_html_string);
91
+ libxml_use_internal_errors(false);
92
+
93
+ $header = Header::create();
94
+ $transformer->transform($header, $document);
95
+
96
+ $this->assertEquals('<h1>Title <b>in bold</b></h1>', $header->getTitle()->render());
97
  }
98
  }
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp-ia.xml CHANGED
@@ -146,10 +146,57 @@
146
  <figcaption> Image 3 </figcaption>
147
  </figure>
148
  </figure>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
149
  <figure>
150
  <img src="http://example.com/img.jpg"/>
151
  <figcaption>blue eyes</figcaption>
152
  </figure>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
153
  </article>
154
  </body>
155
  </html>
146
  <figcaption> Image 3 </figcaption>
147
  </figure>
148
  </figure>
149
+ <figure class="op-interactive">
150
+ <iframe class="no-margin">
151
+ <blockquote class="instagram-media" data-instgrm-captioned="" data-instgrm-version="6" style=" background:#FFF; border:0; border-radius:3px; box-shadow:0 0 1px 0 rgba(0,0,0,0.5),0 1px 10px 0 rgba(0,0,0,0.15); margin: 1px; max-width:658px; padding:0; width:99.375%; width:-webkit-calc(100% - 2px); width:calc(100% - 2px);">
152
+ <div style="padding:8px;">
153
+ <div style=" background:#F8F8F8; line-height:0; margin-top:40px; padding:62.5% 0; text-align:center; width:100%;">
154
+ <div style=" background:url(); display:block; height:44px; margin:0 auto -44px; position:relative; top:-22px; width:44px;"></div>
155
+ </div>
156
+ <p style=" margin:8px 0 0 0; padding:0 4px;">
157
+ <a href="https://www.instagram.com/p/BAXbKP1POQe/" style=" color:#000; font-family:Arial,sans-serif; font-size:14px; font-style:normal; font-weight:normal; line-height:17px; text-decoration:none; word-wrap:break-word;" target="_blank">📸 @natthaponwuttipetch</a>
158
+ </p>
159
+ <p style=" color:#c9c8cd; font-family:Arial,sans-serif; font-size:14px; line-height:17px; margin-bottom:0; margin-top:8px; overflow:hidden; padding:8px 0 7px; text-align:center; text-overflow:ellipsis; white-space:nowrap;">
160
+ A photo posted by Ann Hathairat Vidhyaphum (@annvidh) on <time style=" font-family:Arial,sans-serif; font-size:14px; line-height:17px;" datetime="2016-01-10T16:56:06+00:00">Jan 10, 2016 at 8:56am PST</time></p>
161
+ </div>
162
+ </blockquote>
163
+ <script async="" defer="defer" src="//platform.instagram.com/en_US/embeds.js"></script>
164
+ </iframe>
165
+ </figure>
166
  <figure>
167
  <img src="http://example.com/img.jpg"/>
168
  <figcaption>blue eyes</figcaption>
169
  </figure>
170
+ <figure class="op-interactive">
171
+ <iframe class="no-margin">
172
+ <h1>Sibling content</h1>
173
+ <div>sibling body</div></iframe>
174
+ </figure>
175
+ <p>Standard paragraph that <b>shouldn't</b> lie within the interactive block.</p>
176
+ <figure class="op-interactive">
177
+ <iframe class="no-margin">
178
+ <p>Extra markup</p>
179
+ <div class="fb-post" data-href="https://www.facebook.com/some-page/posts/some-post"></div>
180
+ </iframe>
181
+ </figure>
182
+ <figure class="op-slideshow">
183
+ <figure>
184
+ <img src="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-810x471.jpg"/>
185
+ <figcaption>Caption Img 1</figcaption>
186
+ </figure>
187
+ <figure>
188
+ <img src="http://example.com/a-vot-chto-vnutri.jpg"/>
189
+ <figcaption>Alternative text </figcaption>
190
+ </figure>
191
+ <figure>
192
+ <img src="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj.jpg"/>
193
+ <figcaption>Caption img 3</figcaption>
194
+ </figure>
195
+ </figure>
196
+ <figure>
197
+ <img src="http://example.com/image.jpg"/>
198
+ <figcaption>caption</figcaption>
199
+ </figure>
200
  </article>
201
  </body>
202
  </html>
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp-rules.json CHANGED
@@ -120,6 +120,23 @@
120
  }, {
121
  "class": "H2Rule",
122
  "selector" : "h3,h4,h5,h6"
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
123
  }, {
124
  "class": "InteractiveRule",
125
  "selector" : "iframe",
@@ -250,6 +267,24 @@
250
  "attribute": "width"
251
  }
252
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
253
  }, {
254
  "class": "InteractiveInsideParagraphRule",
255
  "selector" : "iframe",
@@ -397,8 +432,10 @@
397
  }, {
398
  "class": "CaptionRule",
399
  "selector" : "figcaption"
400
- },
401
- {
 
 
402
  "class": "ImageRule",
403
  "selector" : "figure",
404
  "properties" : {
@@ -486,6 +523,10 @@
486
  "class": "SlideshowRule",
487
  "selector" : "div.tiled-gallery"
488
  },
 
 
 
 
489
  {
490
  "class": "Compat\\JetpackSlideshowRule",
491
  "selector" : "div.jetpack-slideshow",
@@ -501,6 +542,33 @@
501
  "class": "CaptionRule",
502
  "selector" : "div.tiled-gallery-caption"
503
  },
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
504
 
505
 
506
  {
@@ -513,6 +581,26 @@
513
  "attribute": "src"
514
  }
515
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
516
  }
517
  ]
518
  }
120
  }, {
121
  "class": "H2Rule",
122
  "selector" : "h3,h4,h5,h6"
123
+ }, {
124
+ "class": "InteractiveRule",
125
+ "selector" : "blockquote.instagram-media",
126
+ "properties" : {
127
+ "interactive.iframe" : {
128
+ "type" : "multiple",
129
+ "children": [
130
+ {
131
+ "type": "element",
132
+ "selector": "blockquote"
133
+ }, {
134
+ "type": "next-sibling-element-of",
135
+ "selector": "blockquote"
136
+ }
137
+ ]
138
+ }
139
+ }
140
  }, {
141
  "class": "InteractiveRule",
142
  "selector" : "iframe",
267
  "attribute": "width"
268
  }
269
  }
270
+ }, {
271
+ "class": "InteractiveRule",
272
+ "selector" : "div.fb-post",
273
+ "properties" : {
274
+ "interactive.iframe" : {
275
+ "type": "multiple",
276
+ "children": [
277
+ {
278
+ "type": "fragment",
279
+ "fragment": "<p>Extra markup</p>"
280
+ },
281
+ {
282
+ "type" : "element",
283
+ "selector" : "div.fb-post"
284
+ }
285
+ ]
286
+ }
287
+ }
288
  }, {
289
  "class": "InteractiveInsideParagraphRule",
290
  "selector" : "iframe",
432
  }, {
433
  "class": "CaptionRule",
434
  "selector" : "figcaption"
435
+ }, {
436
+ "class": "CaptionRule",
437
+ "selector" : "p.wp-caption-text"
438
+ }, {
439
  "class": "ImageRule",
440
  "selector" : "figure",
441
  "properties" : {
523
  "class": "SlideshowRule",
524
  "selector" : "div.tiled-gallery"
525
  },
526
+ {
527
+ "class": "SlideshowRule",
528
+ "selector" : "div.tiled-gallery"
529
+ },
530
  {
531
  "class": "Compat\\JetpackSlideshowRule",
532
  "selector" : "div.jetpack-slideshow",
542
  "class": "CaptionRule",
543
  "selector" : "div.tiled-gallery-caption"
544
  },
545
+ {
546
+ "class" : "PassThroughRule",
547
+ "selector" : "div.vce-gallery-big"
548
+ },
549
+ {
550
+ "class" : "PassThroughRule",
551
+ "selector" : "div.vce-gallery-small"
552
+ },
553
+ {
554
+ "class" : "IgnoreRule",
555
+ "selector" : "div.vce-gallery-slider"
556
+ },
557
+ {
558
+ "class": "SlideshowImageRule",
559
+ "selector" : "div.big-gallery-item",
560
+ "properties" : {
561
+ "image.url" : {
562
+ "type" : "string",
563
+ "selector" : "img",
564
+ "attribute": "src"
565
+ },
566
+ "caption.title" : {
567
+ "type" : "string",
568
+ "selector" : "figcaption.wp-caption-text"
569
+ }
570
+ }
571
+ },
572
 
573
 
574
  {
581
  "attribute": "src"
582
  }
583
  }
584
+ },
585
+
586
+ {
587
+ "class": "InteractiveRule",
588
+ "selector" : "iframe.sibling",
589
+ "properties" : {
590
+ "interactive.iframe" : {
591
+ "type" : "multiple",
592
+ "children": [
593
+ {
594
+ "type": "children",
595
+ "selector": "iframe"
596
+ }, {
597
+ "type": "next-sibling-element-of",
598
+ "selector": "iframe",
599
+ "sibling.selector": "script"
600
+ }
601
+ ]
602
+ }
603
+ }
604
  }
605
  ]
606
  }
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/CMS/wp.html CHANGED
@@ -121,6 +121,20 @@
121
  </div>
122
  <p> <!-- close row -->
123
  </div>
 
 
 
 
 
 
 
 
 
 
 
 
 
 
124
  <p>
125
  <figure style="width: 1280px" class="wp-caption alignnone">
126
  <img src="http://example.com/img.jpg" width="1280" height="740" class />
@@ -128,6 +142,80 @@
128
  <figcaption class="wp-caption-text">blue eyes</figcaption>
129
  </figure>
130
  </p>
 
 
 
 
 
 
131
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
132
  </body>
133
  </html>
121
  </div>
122
  <p> <!-- close row -->
123
  </div>
124
+ <blockquote class="instagram-media" data-instgrm-captioned data-instgrm-version="6" style=" background:#FFF; border:0; border-radius:3px; box-shadow:0 0 1px 0 rgba(0,0,0,0.5),0 1px 10px 0 rgba(0,0,0,0.15); margin: 1px; max-width:658px; padding:0; width:99.375%; width:-webkit-calc(100% - 2px); width:calc(100% - 2px);">
125
+ <div style="padding:8px;">
126
+ <div style=" background:#F8F8F8; line-height:0; margin-top:40px; padding:62.5% 0; text-align:center; width:100%;">
127
+ <div style=" background:url(); display:block; height:44px; margin:0 auto -44px; position:relative; top:-22px; width:44px;"></div>
128
+ </div>
129
+ <p style=" margin:8px 0 0 0; padding:0 4px;">
130
+ <a href="https://www.instagram.com/p/BAXbKP1POQe/" style=" color:#000; font-family:Arial,sans-serif; font-size:14px; font-style:normal; font-weight:normal; line-height:17px; text-decoration:none; word-wrap:break-word;" target="_blank">📸 @natthaponwuttipetch</a>
131
+ </p>
132
+ <p style=" color:#c9c8cd; font-family:Arial,sans-serif; font-size:14px; line-height:17px; margin-bottom:0; margin-top:8px; overflow:hidden; padding:8px 0 7px; text-align:center; text-overflow:ellipsis; white-space:nowrap;">
133
+ A photo posted by Ann Hathairat Vidhyaphum (@annvidh) on <time style=" font-family:Arial,sans-serif; font-size:14px; line-height:17px;" datetime="2016-01-10T16:56:06+00:00">Jan 10, 2016 at 8:56am PST</time>
134
+ </p>
135
+ </div>
136
+ </blockquote>
137
+ <script async defer src="//platform.instagram.com/en_US/embeds.js"></script>
138
  <p>
139
  <figure style="width: 1280px" class="wp-caption alignnone">
140
  <img src="http://example.com/img.jpg" width="1280" height="740" class />
142
  <figcaption class="wp-caption-text">blue eyes</figcaption>
143
  </figure>
144
  </p>
145
+ <iframe class="sibling">
146
+ <h1>Sibling content</h1>
147
+ <div>sibling body</div></iframe>
148
+ <script src="//sibling.com/brother.js"></script>
149
+ <p>Standard paragraph that <b>shouldn't</b> lie within the interactive block.</p>
150
+ <div class="fb-post" data-href="https://www.facebook.com/some-page/posts/some-post"></div>
151
 
152
+ <div id="gallery-3" class="vce-gallery gallery galleryid-15219 gallery-columns-3 gallery-size-vce-lay-b">
153
+ <div class="vce-gallery-big">
154
+ <div class="big-gallery-item item-0">
155
+ <div class="gallery-icon">
156
+ <a href="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy.jpg"><img width="810" height="471" src="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-810x471.jpg" class="attachment-vce-lay-a size-vce-lay-a" alt="Caption Img 1" srcset="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-810x471.jpg 810w, http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-300x174.jpg 300w, http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-768x447.jpg 768w, http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy.jpg 860w" sizes="(max-width: 810px) 100vw, 810px"></a>
157
+ </div>
158
+ <figcaption class="wp-caption-text gallery-caption">Caption Img 1</figcaption>
159
+ </div>
160
+ <div class="big-gallery-item item-1" style="display:none;">
161
+ <div class="gallery-icon">
162
+ <a href="http://example.com/a-vot-chto-vnutri.jpg">
163
+ <img width="699" height="443" src="http://example.com/a-vot-chto-vnutri.jpg" class="attachment-vce-lay-a size-vce-lay-a" alt="Alternative text" srcset="http://example.com/a-vot-chto-vnutri.jpg 699w, http://example.com/a-vot-chto-vnutri-300x190.jpg 300w" sizes="(max-width: 699px) 100vw, 699px">
164
+ </a>
165
+ </div>
166
+ <figcaption class="wp-caption-text gallery-caption">Alternative text </figcaption>
167
+ </div>
168
+ <div class="big-gallery-item item-2" style="display:none;">
169
+ <div class="gallery-icon">
170
+ <a href="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj.jpg">
171
+ <img width="700" height="467" src="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj.jpg" class="attachment-vce-lay-a size-vce-lay-a" alt="Caption img 3" srcset="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj.jpg 700w, http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj-300x200.jpg 300w" sizes="(max-width: 700px) 100vw, 700px">
172
+ </a>
173
+ </div>
174
+ <figcaption class="wp-caption-text gallery-caption">Caption img 3</figcaption>
175
+ </div>
176
+ </div>
177
+ <div class="vce-gallery-slider owl-carousel owl-theme owl-loaded owl-text-select-on" data-columns="3">
178
+ <div class="owl-stage-outer">
179
+ <div class="owl-stage" style="transform: translate3d(-761px, 0px, 0px); transition: 0s; width: 3551.34px;">
180
+ <div class="owl-item active" style="width: 252.667px; margin-right: 1px;">
181
+ <figure class="gallery-item" data-item="0">
182
+ <div class="gallery-icon landscape">
183
+ <a href="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy.jpg"><img width="375" height="195" src="http://example.com/konservnye-banki-osobenno-lyubyat-yaponcy-375x195.jpg" class="attachment-vce-lay-b size-vce-lay-b" alt="Caption Img 1"></a>
184
+ </div>
185
+ </figure>
186
+ </div>
187
+ <div class="owl-item active" style="width: 252.667px; margin-right: 1px;">
188
+ <figure class="gallery-item" data-item="1">
189
+ <div class="gallery-icon landscape">
190
+ <a href="http://example.com/a-vot-chto-vnutri.jpg"><img width="375" height="195" src="http://example.com/a-vot-chto-vnutri-375x195.jpg" class="attachment-vce-lay-b size-vce-lay-b" alt="Alternative text"></a>
191
+ </div>
192
+ </figure>
193
+ </div>
194
+ <div class="owl-item active" style="width: 252.667px; margin-right: 1px;">
195
+ <figure class="gallery-item" data-item="2">
196
+ <div class="gallery-icon landscape">
197
+ <a href="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj.jpg"><img width="375" height="195" src="http://example.com/brelok-s-bezopasnostyu-vsegda-s-soboj-375x195.jpg" class="attachment-vce-lay-b size-vce-lay-b" alt="Caption img 3"></a>
198
+ </div>
199
+ </figure>
200
+ </div>
201
+ </div>
202
+ </div>
203
+ <div class="owl-controls">
204
+ <div class="owl-nav">
205
+ <div class="owl-prev" style=""><i class="fa fa-angle-left"></i></div>
206
+ <div class="owl-next" style=""><i class="fa fa-angle-right"></i></div>
207
+ </div>
208
+ <div class="owl-dots" style="">
209
+ <div class="owl-dot active"><span></span></div>
210
+ <div class="owl-dot"><span></span></div>
211
+ <div class="owl-dot"><span></span></div>
212
+ </div>
213
+ </div>
214
+ </div>
215
+ </div>
216
+ <div id="attachment_22553" style="width: 800px" class="wp-caption alignnone">
217
+ <img class="wp-image-22553 size-large" src="http://example.com/image.jpg" alt="alt text" width="800" height="552" srcset="http://example.com/image-800.jpg 800w, http://example.com/image-400.jpg 400w, http://example.com/image-768.jpg 768w" sizes="(max-width: 800px) 100vw, 800px" />
218
+ <p class="wp-caption-text">caption</p>
219
+ </div>
220
  </body>
221
  </html>
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/Example/simple-ia.html CHANGED
@@ -28,7 +28,7 @@
28
  <p>Curabitur vulputate odio eu justo <i>venenatis</i>, a pretium orci placerat. Nam sed neque quis eros vestibulum mattis. Donec vitae mi egestas, laoreet massa et, fringilla libero.</p>
29
  <figure class="op-interactive">
30
  <iframe>
31
- <iframe width="620" height="349" src="https://www.youtube.com/embed/s1tN0ggNreA?feature=oembed" frameborder="0" allowfullscreen=""/>
32
  </iframe>
33
  </figure>
34
  <figure class="op-interactive">
28
  <p>Curabitur vulputate odio eu justo <i>venenatis</i>, a pretium orci placerat. Nam sed neque quis eros vestibulum mattis. Donec vitae mi egestas, laoreet massa et, fringilla libero.</p>
29
  <figure class="op-interactive">
30
  <iframe>
31
+ <iframe width="620" height="349" src="https://www.youtube.com/embed/s1tN0ggNreA?feature=oembed" frameborder="0" allowfullscreen=""></iframe>
32
  </iframe>
33
  </figure>
34
  <figure class="op-interactive">
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/TransformerTest.php CHANGED
@@ -39,6 +39,51 @@ class TransformerTest extends \PHPUnit_Framework_TestCase
39
  );
40
  }
41
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
42
  public function testSelfTransformerContent()
43
  {
44
  $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
@@ -64,6 +109,54 @@ class TransformerTest extends \PHPUnit_Framework_TestCase
64
  $this->assertEquals($html_file, $result);
65
  }
66
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
67
  public function testTransformerAddAndGetRules()
68
  {
69
  $transformer = new Transformer();
@@ -93,23 +186,4 @@ class TransformerTest extends \PHPUnit_Framework_TestCase
93
  $transformer->resetRules();
94
  $this->assertEquals([], $transformer->getRules());
95
  }
96
-
97
- public function testTitleTransformedWithBold()
98
- {
99
- $transformer = new Transformer();
100
- $json_file = file_get_contents(__DIR__ . '/CMS/wp-rules.json');
101
- $transformer->loadRules($json_file);
102
-
103
- $title_html_string = '<?xml encoding="utf-8" ?><h1>Title <b>in bold</b></h1>';
104
-
105
- libxml_use_internal_errors(true);
106
- $document = new \DOMDocument();
107
- $document->loadHtml($title_html_string);
108
- libxml_use_internal_errors(false);
109
-
110
- $header = Header::create();
111
- $transformer->transform($header, $document);
112
-
113
- $this->assertEquals('<h1>Title <b>in bold</b></h1>', $header->getTitle()->render());
114
- }
115
  }
39
  );
40
  }
41
 
42
+ public function testTransformString()
43
+ {
44
+ $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
45
+
46
+ $instant_article = InstantArticle::create();
47
+ $transformer = new Transformer();
48
+ $transformer->loadRules($json_file);
49
+
50
+ $title_html_string = '<h1>Title String</h1>';
51
+ $header = Header::create();
52
+ $transformer->transformString($header, $title_html_string);
53
+
54
+ $this->assertEquals('<h1>Title String</h1>', $header->getTitle()->render());
55
+ }
56
+
57
+ public function testTransformStringWithMultibyteUTF8Content()
58
+ {
59
+ $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
60
+
61
+ $instant_article = InstantArticle::create();
62
+ $transformer = new Transformer();
63
+ $transformer->loadRules($json_file);
64
+
65
+ $title_html_string = '<h1>Test:あÖÄÜöäü</h1>';
66
+ $header = Header::create();
67
+ $transformer->transformString($header, $title_html_string);
68
+
69
+ $this->assertEquals('<h1>Test:あÖÄÜöäü</h1>', $header->getTitle()->render());
70
+ }
71
+
72
+ public function testTransformStringWithMultibyteNonUTF8Content()
73
+ {
74
+ $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
75
+
76
+ $instant_article = InstantArticle::create();
77
+ $transformer = new Transformer();
78
+ $transformer->loadRules($json_file);
79
+
80
+ $title_html_string = mb_convert_encoding('<h1>Test:あÖÄÜöäü</h1>', 'euc-jp', 'utf-8');
81
+ $header = Header::create();
82
+ $transformer->transformString($header, $title_html_string, 'euc-jp');
83
+
84
+ $this->assertEquals('<h1>Test:あÖÄÜöäü</h1>', $header->getTitle()->render());
85
+ }
86
+
87
  public function testSelfTransformerContent()
88
  {
89
  $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
109
  $this->assertEquals($html_file, $result);
110
  }
111
 
112
+ public function testSelfTransformerMultibyteContent()
113
+ {
114
+ $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
115
+
116
+ $instant_article = InstantArticle::create();
117
+ $transformer = new Transformer();
118
+ $transformer->loadRules($json_file);
119
+
120
+ $html_file = file_get_contents(__DIR__ . '/instant-article-example-multibyte.html');
121
+
122
+ $transformer->transformString($instant_article, $html_file, 'utf-8');
123
+ $instant_article->withCanonicalURL('http://foo.com/article.html');
124
+ $instant_article->addMetaProperty('op:generator:version', '1.0.0');
125
+ $instant_article->addMetaProperty('op:generator:transformer:version', '1.0.0');
126
+ $result = $instant_article->render('', true)."\n";
127
+
128
+ // some fragments are written as html entities even after transformed so
129
+ // noralize all strings to html entities and compare them.
130
+ $this->assertEquals(
131
+ mb_convert_encoding($html_file, 'HTML-ENTITIES', 'utf-8'),
132
+ mb_convert_encoding($result, 'HTML-ENTITIES', 'utf-8')
133
+ );
134
+ }
135
+
136
+ public function testSelfTransformerNonUTF8Content()
137
+ {
138
+ $json_file = file_get_contents('src/Facebook/InstantArticles/Parser/instant-articles-rules.json');
139
+
140
+ $instant_article = InstantArticle::create();
141
+ $transformer = new Transformer();
142
+ $transformer->loadRules($json_file);
143
+
144
+ $html_file = file_get_contents(__DIR__ . '/instant-article-example-nonutf8.html');
145
+
146
+ $transformer->transformString($instant_article, $html_file, 'euc-jp');
147
+ $instant_article->withCanonicalURL('http://foo.com/article.html');
148
+ $instant_article->addMetaProperty('op:generator:version', '1.0.0');
149
+ $instant_article->addMetaProperty('op:generator:transformer:version', '1.0.0');
150
+ $result = $instant_article->render('', true)."\n";
151
+
152
+ // some fragments are written as html entities even after transformed so
153
+ // noralize all strings to html entities and compare them.
154
+ $this->assertEquals(
155
+ mb_convert_encoding($html_file, 'HTML-ENTITIES', 'euc-jp'),
156
+ mb_convert_encoding($result, 'HTML-ENTITIES', 'utf-8')
157
+ );
158
+ }
159
+
160
  public function testTransformerAddAndGetRules()
161
  {
162
  $transformer = new Transformer();
186
  $transformer->resetRules();
187
  $this->assertEquals([], $transformer->getRules());
188
  }
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
189
  }
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/instant-article-example-multibyte.html ADDED
@@ -0,0 +1,204 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <html>
2
+ <head>
3
+ <link rel="canonical" href="http://foo.com/article.html"/>
4
+ <meta charset="utf-8"/>
5
+ <meta property="op:generator" content="facebook-instant-articles-sdk-php"/>
6
+ <meta property="op:generator:version" content="1.0.0"/>
7
+ <meta property="op:generator:transformer" content="facebook-instant-articles-sdk-php"/>
8
+ <meta property="op:generator:transformer:version" content="1.0.0"/>
9
+ <meta property="op:markup_version" content="v1.0"/>
10
+ </head>
11
+ <body>
12
+ <article>
13
+ <header>
14
+ <figure>
15
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
16
+ <figcaption><h1>イメージ名</h1>テキストノード<cite>イメージキャプション</cite></figcaption>
17
+ </figure>
18
+ <h1>ビッグトップ <b>タイトル</b></h1>
19
+ <h2>スモール <b>サブタイトル</b></h2>
20
+ <time class="op-published" datetime="1984-08-14T19:30:00+00:00">August 14th, 7:30pm</time>
21
+ <time class="op-modified" datetime="2016-02-10T10:00:00+00:00">February 10th, 10:00am</time>
22
+ <address><a href="#" title="Title of author">著者名</a>
23
+ 著者に関する詳しい情報
24
+ さらなる詳細
25
+ </address>
26
+ <address><a href="http://facebook.com/author" rel="facebook">FB上の著者</a>
27
+ facebook内の著者情報
28
+ </address>
29
+ <address><a title="PHP Programmer">開発者</a>
30
+ </address>
31
+ <h3 class="op-kicker">記事のキッカー</h3>
32
+ <ul class="op-sponsors">
33
+ <li>
34
+ <a href="http://facebook.com/my-sponsor" rel="facebook"></a>
35
+ </li>
36
+ </ul>
37
+ </header>
38
+ <p>パラグラフ内のテキストのテストです。</p>
39
+ <figure data-feedback="fb:likes">
40
+ <img src="http://mydomain.com/path/to/img.jpg"/>
41
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
42
+ <source src="http://foo.com/mp3"/>
43
+ </audio>
44
+ </figure>
45
+ <figure data-feedback="fb:comments">
46
+ <img src="http://mydomain.com/path/to/img.jpg"/>
47
+ <script type="application/json" class="op-geotag">
48
+ {
49
+ "type": "Feature",
50
+ "geometry": {
51
+ "type": "Point",
52
+ "coordinates": [23.166667, 89.216667]
53
+ },
54
+ "properties": {
55
+ "title": "バングラデシュ ジョソール県",
56
+ "radius": 750000,
57
+ "pivot": true,
58
+ "style": "satellite",
59
+ }
60
+ }
61
+ </script>
62
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
63
+ <source src="http://foo.com/mp3"/>
64
+ </audio>
65
+ </figure>
66
+ <figure data-feedback="fb:likes,fb:comments">
67
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
68
+ <figcaption><h1>イメージ名</h1>テキストノード<cite>イメージキャプション</cite></figcaption>
69
+ </figure>
70
+ <p>第2段落内のテキストのテストです。</p>
71
+ <figure class="op-slideshow">
72
+ <figure>
73
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
74
+ </figure>
75
+ <figure>
76
+ <img src="https://jpeg.org/images/jpegls-home2.jpg"/>
77
+ </figure>
78
+ <figure>
79
+ <img src="https://jpeg.org/images/jpegls-home3.jpg"/>
80
+ </figure>
81
+ <figcaption><h1>イメージ名</h1>テキストノード<cite>イメージキャプション</cite></figcaption>
82
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
83
+ <source src="http://foo.com/mp3"/>
84
+ </audio>
85
+ </figure>
86
+ <ol>
87
+ <li>最初のリスト項目</li>
88
+ <li>パラグラフ</li>
89
+ <li>spanタグ</li>
90
+ <li>div内のテキスト?</li>
91
+ <li>li上のその他の <a href="#">段落</a></li>
92
+ <li>最後のリスト項目</li>
93
+ </ol>
94
+ <p>段落内のテキストのテストです。</p>
95
+ <figure class="op-interactive">
96
+ <iframe src="http://example.com/custom-interactive" class="column-width" height="60">
97
+ <h1>カスタムコード</h1>
98
+ <script>alert("テスト");</script></iframe>
99
+ <figcaption>このグラフィックは素晴らしい。</figcaption>
100
+ </figure>
101
+ <figure class="op-ad">
102
+ <iframe src="http://foo.com"></iframe>
103
+ </figure>
104
+ <blockquote>blockquoteは記事の中で<b>magic</b>を作ります。</blockquote>
105
+ <figure class="op-map">
106
+ <script type="application/json" class="op-geotag">
107
+ {
108
+ "type": "Feature",
109
+ "geometry":
110
+ {
111
+ "type": "Point",
112
+ "coordinates": [23.166667, 89.216667]
113
+ },
114
+ "properties":
115
+ {
116
+ "title": "バングラデシュ ジョソール県",
117
+ "radius": 750000,
118
+ "pivot": true,
119
+ "style": "satellite",
120
+ }
121
+ }
122
+ </script>
123
+ <figcaption class="op-vertical-above"><h1 class="op-vertical-above op-center">キャプション用タイトル</h1><h2 class="op-vertical-below op-right">キャプション用サブタイトル</h2>
124
+
125
+
126
+ <cite class="op-vertical-center op-left">キャプション内のクレジット</cite></figcaption>
127
+ <audio title="audio title" autoplay="autoplay" muted="muted">
128
+ <source src="http://foo.com/mp3"/>
129
+ </audio>
130
+ </figure>
131
+ <aside>
132
+ 私たちはどこで成長させるか、何を成長させるか、どうやって成長させるか、について、もっと効率的になれるはずです。
133
+ <cite>フルーツストカンパニー</cite></aside>
134
+ <p>第2段落内のテキストのテストです。</p>
135
+ <figure class="op-tracker">
136
+ <iframe>
137
+ <h1>カスタムコード</h1>
138
+ <script>alert("テスト");</script></iframe>
139
+ </figure>
140
+ <figure class="op-tracker">
141
+ <iframe>
142
+ <h1>トラッカー用スクリプト</h1>
143
+ <div><script>alert("テスト");</script></div>
144
+ </iframe>
145
+ </figure>
146
+ <figure class="op-interactive">
147
+ <iframe class="no-margin">
148
+ <h1>ソーシャル埋め込み用カスタムコード</h1>
149
+ <script>alert("テスト");</script></iframe>
150
+ </figure>
151
+ <figure data-mode="fullscreen" data-feedback="fb:likes,fb:comments">
152
+ <video data-fb-disable-autoplay="data-fb-disable-autoplay" controls="controls">
153
+ <source src="http://mydomain.com/path/to/video.mp4" type="video/mp4"/>
154
+ </video>
155
+ <figcaption class="op-vertical-below"><h1>ビデオタイトル</h1>
156
+
157
+ <cite>属性ソース</cite></figcaption>
158
+ <script type="application/json" class="op-geotag">
159
+ {
160
+ "type": "Feature",
161
+ "geometry": {
162
+ "type": "Point",
163
+ "coordinates": [ [23.166667, 89.216667], [23.166667, 89.216667] ]
164
+ },
165
+ "properties": {
166
+ "title": "バングラデシュ ジョソール県",
167
+ "radius": 750000,
168
+ "pivot": true,
169
+ "style": "satellite",
170
+ }
171
+ }
172
+ </script>
173
+ </figure>
174
+ <ul class="op-related-articles" title="The related ones in the middle">
175
+ <li>
176
+ <a href="http://example.com/article.html"></a>
177
+ </li>
178
+ <li data-sponsored="true">
179
+ <a href="http://example.com/sponsored-article.html"></a>
180
+ </li>
181
+ <li>
182
+ <a href="http://example.com/another-article.html"></a>
183
+ </li>
184
+ </ul>
185
+ <footer>
186
+ <aside>
187
+ <p><a href="http://facebook.com/author" rel="facebook">著者</a>へのクレジット情報</p>
188
+ <p>クレジットとしてのパラグラフ</p>
189
+ </aside>
190
+ <ul class="op-related-articles" title="The related ones in the footer">
191
+ <li>
192
+ <a href="http://example.com/article.html"></a>
193
+ </li>
194
+ <li data-sponsored="true">
195
+ <a href="http://example.com/sponsored-article.html"></a>
196
+ </li>
197
+ <li>
198
+ <a href="http://example.com/another-article.html"></a>
199
+ </li>
200
+ </ul>
201
+ </footer>
202
+ </article>
203
+ </body>
204
+ </html>
vendor/facebook/facebook-instant-articles-sdk-php/tests/Facebook/InstantArticles/Transformer/instant-article-example-nonutf8.html ADDED
@@ -0,0 +1,204 @@
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
1
+ <html>
2
+ <head>
3
+ <link rel="canonical" href="http://foo.com/article.html"/>
4
+ <meta charset="euc-jp"/>
5
+ <meta property="op:generator" content="facebook-instant-articles-sdk-php"/>
6
+ <meta property="op:generator:version" content="1.0.0"/>
7
+ <meta property="op:generator:transformer" content="facebook-instant-articles-sdk-php"/>
8
+ <meta property="op:generator:transformer:version" content="1.0.0"/>
9
+ <meta property="op:markup_version" content="v1.0"/>
10
+ </head>
11
+ <body>
12
+ <article>
13
+ <header>
14
+ <figure>
15
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
16
+ <figcaption><h1>���᡼��̾</h1>�ƥ����ȥΡ���<cite>���᡼������ץ����</cite></figcaption>
17
+ </figure>
18
+ <h1>�ӥå��ȥå� <b>�����ȥ�</b></h1>
19
+ <h2>���⡼�� <b>���֥����ȥ�</b></h2>
20
+ <time class="op-published" datetime="1984-08-14T19:30:00+00:00">August 14th, 7:30pm</time>
21
+ <time class="op-modified" datetime="2016-02-10T10:00:00+00:00">February 10th, 10:00am</time>
22
+ <address><a href="#" title="Title of author">����̾</a>
23
+ ���Ԥ˴ؤ���ܤ�������
24
+ ����ʤ�ܺ�
25
+ </address>
26
+ <address><a href="http://facebook.com/author" rel="facebook">FB�������</a>
27
+ facebook������Ծ���
28
+ </address>
29
+ <address><a title="PHP Programmer">��ȯ��</a>
30
+ </address>
31
+ <h3 class="op-kicker">�����Υ��å���</h3>
32
+ <ul class="op-sponsors">
33
+ <li>
34
+ <a href="http://facebook.com/my-sponsor" rel="facebook"></a>
35
+ </li>
36
+ </ul>
37
+ </header>
38
+ <p>�ѥ饰�����Υƥ����ȤΥƥ��ȤǤ���</p>
39
+ <figure data-feedback="fb:likes">
40
+ <img src="http://mydomain.com/path/to/img.jpg"/>
41
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
42
+ <source src="http://foo.com/mp3"/>
43
+ </audio>
44
+ </figure>
45
+ <figure data-feedback="fb:comments">
46
+ <img src="http://mydomain.com/path/to/img.jpg"/>
47
+ <script type="application/json" class="op-geotag">
48
+ {
49
+ "type": "Feature",
50
+ "geometry": {
51
+ "type": "Point",
52
+ "coordinates": [23.166667, 89.216667]
53
+ },
54
+ "properties": {
55
+ "title": "�Х󥰥�ǥ��塡���祽���븩",
56
+ "radius": 750000,
57
+ "pivot": true,
58
+ "style": "satellite",
59
+ }
60
+ }
61
+ </script>
62
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
63
+ <source src="http://foo.com/mp3"/>
64
+ </audio>
65
+ </figure>
66
+ <figure data-feedback="fb:likes,fb:comments">
67
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
68
+ <figcaption><h1>���᡼��̾</h1>�ƥ����ȥΡ���<cite>���᡼������ץ����</cite></figcaption>
69
+ </figure>
70
+ <p>��2������Υƥ����ȤΥƥ��ȤǤ���</p>
71
+ <figure class="op-slideshow">
72
+ <figure>
73
+ <img src="https://jpeg.org/images/jpegls-home.jpg"/>
74
+ </figure>
75
+ <figure>
76
+ <img src="https://jpeg.org/images/jpegls-home2.jpg"/>
77
+ </figure>
78
+ <figure>
79
+ <img src="https://jpeg.org/images/jpegls-home3.jpg"/>
80
+ </figure>
81
+ <figcaption><h1>���᡼��̾</h1>�ƥ����ȥΡ���<cite>���᡼������ץ����</cite></figcaption>
82
+ <audio title="&#x30AA;&#x30FC;&#x30C7;&#x30A3;&#x30AA;&#x30BF;&#x30A4;&#x30C8;&#x30EB;" autoplay="autoplay" muted="muted">
83
+ <source src="http://foo.com/mp3"/>
84
+ </audio>
85
+ </figure>
86
+ <ol>
87
+ <li>�ǽ�Υꥹ�ȹ���</li>
88
+ <li>�ѥ饰���</li>
89
+ <li>span����</li>
90
+ <li>div��Υƥ����ȡ�</li>
91
+ <li>li��Τ���¾�� <a href="#">����</a></li>
92
+ <li>�Ǹ�Υꥹ�ȹ���</li>
93
+ </ol>
94
+ <p>������Υƥ����ȤΥƥ��ȤǤ���</p>
95
+ <figure class="op-interactive">
96
+ <iframe src="http://example.com/custom-interactive" class="column-width" height="60">
97
+ <h1>�������ॳ����</h1>
98
+ <script>alert("�ƥ���");</script></iframe>
99
+ <figcaption>���Υ���ե��å��������餷����</figcaption>
100
+ </figure>
101
+ <figure class="op-ad">
102
+ <iframe src="http://foo.com"></iframe>
103
+ </figure>
104
+ <blockquote>blockquote�ϵ��������<b>magic</b>����ޤ���</blockquote>
105
+ <figure class="op-map">
106
+ <script type="application/json" class="op-geotag">
107
+ {
108
+ "type": "Feature",
109
+ "geometry":
110
+ {
111
+ "type": "Point",
112
+ "coordinates": [23.166667, 89.216667]
113
+ },
114
+ "properties":
115
+ {
116
+ "title": "�Х󥰥�ǥ��塡���祽���븩",
117
+ "radius": 750000,
118
+ "pivot": true,
119
+ "style": "satellite",
120
+ }
121
+ }
122
+ </script>
123
+ <figcaption class="op-vertical-above"><h1 class="op-vertical-above op-center">����ץ�����ѥ����ȥ�</h1><h2 class="op-vertical-below op-right">����ץ�����ѥ��֥����ȥ�</h2>
124
+
125
+
126
+ <cite class="op-vertical-center op-left">����ץ������Υ��쥸�å�</cite></figcaption>
127
+ <audio title="audio title" autoplay="autoplay" muted="muted">
128
+ <source src="http://foo.com/mp3"/>
129
+ </audio>
130
+ </figure>
131
+ <aside>
132
+ �䤿���Ϥɤ�����Ĺ�����뤫��������Ĺ�����뤫���ɤ���ä���Ĺ�����뤫���ˤĤ��ơ���äȸ�ΨŪ�ˤʤ��Ϥ��Ǥ���
133
+ <cite>�ե롼�ĥ��ȥ���ѥˡ�</cite></aside>
134
+ <p>��2������Υƥ����ȤΥƥ��ȤǤ���</p>
135
+ <figure class="op-tracker">
136
+ <iframe>
137
+ <h1>�������ॳ����</h1>
138
+ <script>alert("�ƥ���");</script></iframe>
139
+ </figure>
140
+ <figure class="op-tracker">
141
+ <iframe>
142
+ <h1>�ȥ�å����ѥ�����ץ�</h1>
143
+ <div><script>alert("�ƥ���");</script></div>
144
+ </iframe>
145
+ </figure>
146
+ <figure class="op-interactive">
147
+ <iframe class="no-margin">
148
+ <h1>����������������ѥ������ॳ����</h1>
149
+ <script>alert("�ƥ���");</script></iframe>
150
+ </figure>
151
+ <figure data-mode="fullscreen" data-feedback="fb:likes,fb:comments">
152
+ <video data-fb-disable-autoplay="data-fb-disable-autoplay" controls="controls">
153
+ <source src="http://mydomain.com/path/to/video.mp4" type="video/mp4"/>
154
+ </video>
155
+ <figcaption class="op-vertical-below"><h1>�ӥǥ������ȥ�</h1>
156
+
157
+ <cite>°��������</cite></figcaption>
158
+ <script type="application/json" class="op-geotag">
159
+ {
160
+ "type": "Feature",
161
+ "geometry": {
162
+ "type": "Point",
163
+ "coordinates": [ [23.166667, 89.216667], [23.166667, 89.216667] ]
164
+ },
165
+ "properties": {
166
+ "title": "�Х󥰥�ǥ��塡���祽���븩",
167
+ "radius": 750000,
168
+ "pivot": true,
169
+ "style": "satellite",
170
+ }
171
+ }
172
+ </script>
173
+ </figure>
174
+ <ul class="op-related-articles" title="The related ones in the middle">
175
+ <li>
176
+ <a href="http://example.com/article.html"></a>
177
+ </li>
178
+ <li data-sponsored="true">
179
+ <a href="http://example.com/sponsored-article.html"></a>
180
+ </li>
181
+ <li>
182
+ <a href="http://example.com/another-article.html"></a>
183
+ </li>
184
+ </ul>
185
+ <footer>
186
+ <aside>
187
+ <p><a href="http://facebook.com/author" rel="facebook">����</a>�ؤΥ��쥸�åȾ���</p>
188
+ <p>���쥸�åȤȤ��ƤΥѥ饰���</p>
189
+ </aside>
190
+ <ul class="op-related-articles" title="The related ones in the footer">
191
+ <li>
192
+ <a href="http://example.com/article.html"></a>
193
+ </li>
194
+ <li data-sponsored="true">
195
+ <a href="http://example.com/sponsored-article.html"></a>
196
+ </li>
197
+ <li>
198
+ <a href="http://example.com/another-article.html"></a>
199
+ </li>
200
+ </ul>
201
+ </footer>
202
+ </article>
203
+ </body>
204
+ </html>