establish base code
This commit is contained in:
commit
c2c8ac74be
37
css/fw-store-embed.css
Normal file
37
css/fw-store-embed.css
Normal file
@ -0,0 +1,37 @@
|
|||||||
|
.fw-store-parent {
|
||||||
|
align-content: center;
|
||||||
|
vertical-align: top;
|
||||||
|
overflow-y: auto;
|
||||||
|
text-align:center;
|
||||||
|
margin:0 auto;
|
||||||
|
max-width: 1000px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.product-tile {
|
||||||
|
align-content: center;
|
||||||
|
vertical-align: top;
|
||||||
|
background: white;
|
||||||
|
display:inline-block;
|
||||||
|
width:200px;
|
||||||
|
margin:0 25px 25px;
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
.product-tile img {
|
||||||
|
max-height: 350px;
|
||||||
|
}
|
||||||
|
|
||||||
|
.image__badges {
|
||||||
|
color: red;
|
||||||
|
justify-content: center;
|
||||||
|
position: absolute;
|
||||||
|
font-weight: bold;
|
||||||
|
margin: auto;
|
||||||
|
}
|
||||||
|
.badge {
|
||||||
|
color: red !important;
|
||||||
|
margin: auto;
|
||||||
|
padding: 60px;
|
||||||
|
font-size: 20px;
|
||||||
|
font-style: italic;
|
||||||
|
}
|
18
fw-store-embed.php
Normal file
18
fw-store-embed.php
Normal file
@ -0,0 +1,18 @@
|
|||||||
|
<?php
|
||||||
|
/**
|
||||||
|
* Plugin Name: Fourthwall Store Embed
|
||||||
|
* Plugin URL: https://cybercove.io/
|
||||||
|
* Description: Embed Fourthwall Store in WordPress
|
||||||
|
* Version: 1.0.0.
|
||||||
|
* Author: Joshua Knapp
|
||||||
|
* Text Domain: fourthwall_text_domain
|
||||||
|
*
|
||||||
|
*/
|
||||||
|
|
||||||
|
include("libs/settings.php");
|
||||||
|
include("libs/shortcode.php");
|
||||||
|
function set_fw_store_embed_css() {
|
||||||
|
wp_enqueue_style('fw-embed-style', plugin_dir_url( __FILE__ ). 'css/fw-store-embed.css', array(),null);
|
||||||
|
}
|
||||||
|
|
||||||
|
add_action( 'wp_enqueue_scripts', 'set_fw_store_embed_css' );
|
87
libs/settings.php
Normal file
87
libs/settings.php
Normal file
@ -0,0 +1,87 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
class fourthwall_settings {
|
||||||
|
|
||||||
|
public function __construct() {
|
||||||
|
|
||||||
|
add_action( 'admin_menu', array( $this, 'add_admin_menu' ) );
|
||||||
|
add_action( 'admin_init', array( $this, 'init_settings' ) );
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function add_admin_menu() {
|
||||||
|
|
||||||
|
add_menu_page(
|
||||||
|
esc_html__( 'Fourthwall Store Embed', 'fourthwall_text_domain' ),
|
||||||
|
esc_html__( 'FourthWall Embed', 'fourthwall_text_domain' ),
|
||||||
|
'manage_options',
|
||||||
|
'fwembed',
|
||||||
|
array( $this, 'fourthwall_page_layout' ),
|
||||||
|
'dashicons-store',
|
||||||
|
10
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function init_settings() {
|
||||||
|
|
||||||
|
register_setting(
|
||||||
|
'fourthwall_settings_group',
|
||||||
|
'fourthwall_settings_name'
|
||||||
|
);
|
||||||
|
|
||||||
|
add_settings_section(
|
||||||
|
'fourthwall_settings_name_section',
|
||||||
|
'',
|
||||||
|
false,
|
||||||
|
'fourthwall_settings_name'
|
||||||
|
);
|
||||||
|
|
||||||
|
add_settings_field(
|
||||||
|
'fourth_url',
|
||||||
|
__( 'Store URL', 'fourthwall_text_domain' ),
|
||||||
|
array( $this, 'render_fourth_url_field' ),
|
||||||
|
'fourthwall_settings_name',
|
||||||
|
'fourthwall_settings_name_section'
|
||||||
|
);
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
public function fourthwall_page_layout() {
|
||||||
|
|
||||||
|
// Check required user capability
|
||||||
|
if ( !current_user_can( 'manage_options' ) ) {
|
||||||
|
wp_die( esc_html__( 'You do not have sufficient permissions to access this page.', 'fourthwall_text_domain' ) );
|
||||||
|
}
|
||||||
|
|
||||||
|
// Admin Page Layout
|
||||||
|
echo '<div class="wrap">' . "\n";
|
||||||
|
echo ' <h1>' . get_admin_page_title() . '</h1>' . "\n";
|
||||||
|
echo ' <form action="options.php" method="post">' . "\n";
|
||||||
|
|
||||||
|
settings_fields( 'fourthwall_settings_group' );
|
||||||
|
do_settings_sections( 'fourthwall_settings_name' );
|
||||||
|
submit_button();
|
||||||
|
|
||||||
|
echo ' </form>' . "\n";
|
||||||
|
echo '</div>' . "\n";
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
function render_fourth_url_field() {
|
||||||
|
|
||||||
|
// Retrieve data from the database.
|
||||||
|
$options = get_option( 'fourthwall_settings_name' );
|
||||||
|
|
||||||
|
// Set default value.
|
||||||
|
$value = isset( $options['fourth_url'] ) ? $options['fourth_url'] : '';
|
||||||
|
|
||||||
|
// Field output.
|
||||||
|
echo '<input type="url" name="fourthwall_settings_name[fourth_url]" class="regular-text fourth_url_field" placeholder="' . esc_attr__( 'https://some-shop.fourthwall.com', 'fourthwall_text_domain' ) . '" value="' . esc_attr( $value ) . '">';
|
||||||
|
echo '<p class="description">' . __( 'The fourth wall URL', 'fourthwall_text_domain' ) . '</p>';
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
}
|
||||||
|
|
||||||
|
new fourthwall_settings;
|
57
libs/shortcode.php
Normal file
57
libs/shortcode.php
Normal file
@ -0,0 +1,57 @@
|
|||||||
|
<?php
|
||||||
|
|
||||||
|
function fwembed_parse_html($url = null) {
|
||||||
|
if ($url === null) {
|
||||||
|
throw new ValueError("Missing URL");
|
||||||
|
}
|
||||||
|
$html = null;
|
||||||
|
$dom = new DOMDocument();
|
||||||
|
@$dom->loadHTML(file_get_contents($url));
|
||||||
|
$dom->documentURI = $url;
|
||||||
|
$divs = $dom->getElementsByTagName('div');
|
||||||
|
foreach ($divs as $div) {
|
||||||
|
if ($div->hasAttribute('data-testid') && $div->getAttribute('data-testid') === 'product') {
|
||||||
|
$xpath = new DOMXPath($dom);
|
||||||
|
|
||||||
|
$tileItem = $xpath->query('.//img[contains(@class, "tile__item--1")
|
||||||
|
and not(contains(@class, "badge"))
|
||||||
|
and not(contains(@class, "tile_options"))
|
||||||
|
and not(contains(@class, "tile__item--2"))]', $div);
|
||||||
|
$tileDesc = $xpath->query('.//*[contains(@class, "tile__description")
|
||||||
|
and not(contains(@class, "badge"))
|
||||||
|
and not(contains(@class, "tile_options"))]', $div);
|
||||||
|
$tileHeading = $xpath->query('.//*[contains(@class, "tile__heading")
|
||||||
|
and not(contains(@class, "badge"))
|
||||||
|
and not(contains(@class, "tile_options"))]', $div);
|
||||||
|
$tilePrices = $xpath->query('.//*[contains(@class, "tile__prices")
|
||||||
|
and not(contains(@class, "badge"))
|
||||||
|
and not(contains(@class, "tile_options"))]', $div);
|
||||||
|
$productHTML = '';
|
||||||
|
if ($tileItem->length > 0) {
|
||||||
|
$productHTML .= $dom->saveHTML($tileItem->item(0));
|
||||||
|
}
|
||||||
|
if ($tileDesc->length > 0) {
|
||||||
|
$productHTML .= $dom->saveHTML($tileDesc->item(0));
|
||||||
|
}
|
||||||
|
if ($tileHeading->length > 0) {
|
||||||
|
$productHTML .= $dom->saveHTML($tileHeading->item(0));
|
||||||
|
}
|
||||||
|
if ($tilePrices->length > 0) {
|
||||||
|
$productHTML .= $dom->saveHTML($tilePrices->item(0));
|
||||||
|
}
|
||||||
|
|
||||||
|
$html = $html . '<div class="product-tile">' . $productHTML . '</div>';
|
||||||
|
}
|
||||||
|
}
|
||||||
|
$html = str_replace('a href="', 'a target="_blank" href="' . $url, $html);
|
||||||
|
return $html;
|
||||||
|
}
|
||||||
|
|
||||||
|
function fwembed_shortcode( $atts ) {
|
||||||
|
$options = get_option( 'fourthwall_settings_name' );
|
||||||
|
$value = isset( $options['fourth_url'] ) ? $options['fourth_url'] : 'https://latinosagainstspookyshit-shop.fourthwall.com';
|
||||||
|
$store_html = fwembed_parse_html($value);
|
||||||
|
$store_render = '<div class="fw-store-parent">' . PHP_EOL . $store_html . PHP_EOL . '</div>';
|
||||||
|
return $store_render;
|
||||||
|
}
|
||||||
|
add_shortcode( 'fourthwall', 'fwembed_shortcode' );
|
Loading…
Reference in New Issue
Block a user