Uname: Linux p3plzcpnl499967.prod.phx3.secureserver.net 4.18.0-553.54.1.lve.el8.x86_64 #1 SMP Wed Jun 4 13:01:13 UTC 2025 x86_64
Software: Apache
PHP version: 8.2.30 [ PHP INFO ] PHP os: Linux
Server Ip: 208.109.40.231
Your Ip: 216.73.216.26
User: nayff91c5tsx (10005085) | Group: nayff91c5tsx (10005085)
Safe Mode: OFF
Disable Function:
NONE

name : DynamicCsv.php
<?php

namespace FluentFormPro\Components\DynamicField;

use FluentForm\Framework\Helpers\ArrayHelper as Arr;

if (!defined('ABSPATH')) {
    exit; // Exit if accessed directly.
}

class DynamicCsv
{
    protected $source = 'dynamic_csv';
    public function __construct()
    {
        add_filter('fluentform/dynamic_field_sources', [$this, 'addDynamicCsvOnSource']);
        add_filter('fluentform/dynamic_field_filter_get_result' . $this->source, [$this, 'getResult'], 10, 2);
    }

    public function addDynamicCsvOnSource($sources) {
        $sources[$this->source] = __('Dynamic CSV', 'fluentformpro');
        return $sources;
    }

    public function getResult($_, $config)
    {
        $csvUrl = Arr::get($config, 'csv_url', '');
        $csvUrl = sanitize_url($csvUrl);
        if (!$csvUrl) {
            throw new \Exception('invalid error');
        }
        if (!class_exists('CSVParser')) {
            require_once(FLUENTFORMPRO_DIR_PATH . 'libs/CSVParser/CSVParser.php');
        }
        $csvParser = new \CSVParser;
        $content = @file_get_contents($csvUrl);
        if (!$content) {
            throw new \Exception(__('Invalid url', 'fluentformpro'));
        }

        $csvParser->load_data($content);
        $csvDelimiter = Arr::get($config, 'csv_delimiter');
        if ('comma' == $csvDelimiter) {
            $csvDelimiter = ",";
        } elseif ('semicolon' == $csvDelimiter) {
            $csvDelimiter = ";";
        } else {
            $csvDelimiter = $csvParser->find_delimiter();
        }
        $result = $csvParser->parse($csvDelimiter);

        if(!$result) {
            throw new \Exception(__('Empty data', 'fluentformpro'));
        }
        $headers = array_shift($result);
        $limit = (int)Arr::get($config, 'result_limit');
        if ($limit && $limit < count($result)) {
            $result = array_slice($result, 0, $limit);
        }

        $value = sanitize_text_field(Arr::get($config, 'template_value.value', "{{$headers[0]}}"));
        $label = sanitize_text_field(Arr::get($config, 'template_label.value', "{{$headers[0]}}"));
        if (!$value) {
            return [];
        }
        $validOptions = [];
        $uniqueResult = 'yes' === Arr::get($config, 'unique_result');
        $uniqueValueSet = [];
        foreach ($result as $key  => $row) {
            if (count($headers) !== count($row)) {
                continue;
            }
            $result[$key] = array_combine($headers, $row);

            // Replace placeholders in value
            $valueResult = $this->replacePlaceholders($value, $result[$key]);
            if (!is_string($value)) {
                continue;
            }
            $valueResult = esc_attr($valueResult);
            if (!$valueResult) {
                continue;
            }
            // Replace placeholders in label
            $labelResult = $this->replacePlaceholders($label, $result[$key]);

            // Use value result as label if label result is not a string or empty
            if (!is_string($labelResult)) {
                $labelResult = $valueResult;
            }
            $labelResult = esc_html($labelResult);
            if (!$labelResult) {
                $labelResult = $valueResult;
            }
            // Check for duplicate values and skip if found
            if ($uniqueResult && in_array($valueResult, $uniqueValueSet)) {
                continue;
            }
            $validOptions[] = ['id' => $key, 'label' => $labelResult, 'value' => $valueResult];
            $uniqueValueSet[] = $valueResult;
        }

        return [
            'result_counts'  => [
                'total' => count($result),
                'valid' => count($validOptions),
            ],
            'valid_options'  => $validOptions,
            'all_options'    => $result,
        ];
    }

    protected function replacePlaceholders($string, $row)
    {
        return preg_replace_callback('/\{([^\}]+)\}/', function ($matches) use ($row) {
            return isset($row[$matches[1]]) ? trim($row[$matches[1]]) : '';
        }, $string);
    }
}
© 2026 GrazzMean