VaKeR CYBER ARMY
Logo of a company Server : Apache/2.4.41 (Ubuntu)
System : Linux absol.cf 5.4.0-198-generic #218-Ubuntu SMP Fri Sep 27 20:18:53 UTC 2024 x86_64
User : www-data ( 33)
PHP Version : 7.4.33
Disable Function : pcntl_alarm,pcntl_fork,pcntl_waitpid,pcntl_wait,pcntl_wifexited,pcntl_wifstopped,pcntl_wifsignaled,pcntl_wifcontinued,pcntl_wexitstatus,pcntl_wtermsig,pcntl_wstopsig,pcntl_signal,pcntl_signal_get_handler,pcntl_signal_dispatch,pcntl_get_last_error,pcntl_strerror,pcntl_sigprocmask,pcntl_sigwaitinfo,pcntl_sigtimedwait,pcntl_exec,pcntl_getpriority,pcntl_setpriority,pcntl_async_signals,pcntl_unshare,
Directory :  /var/www/html/webtrees/resources/views/modules/

Upload File :
current_dir [ Writeable ] document_root [ Writeable ]

 

Current File : /var/www/html/webtrees/resources/views/modules/census-assistant.phtml
<?php

declare(strict_types=1);

use Fisharebest\Webtrees\I18N;
use Fisharebest\Webtrees\Individual;
use Fisharebest\Webtrees\View;

/**
 * @var Individual|null $individual
 */

?>

<div class="census-assistant-link" hidden>
    <a href="#">
        <?= I18N::translate('Create a shared note using the census assistant') ?>
    </a>
</div>

<div id="census-assistant" hidden>
    <input type="hidden" name="ca_census" class="census-assistant-class">
    <div class="mb-3">
        <div class="input-group">
            <label class="input-group-text" for="census-assistant-title">
                <?= I18N::translate('Title') ?>
            </label>

            <input class="form-control" id="census-assistant-title" name="ca_title" value="">
        </div>
    </div>

    <div class="row mb-3">
        <div class="col-sm-6">
            <div class="input-group">
                <label class="input-group-text" for="census-assistant-citation">
                    <?= I18N::translate('Citation') ?>
                </label>

                <input class="form-control" id="census-assistant-citation" name="ca_citation">
            </div>
        </div>

        <div class="col-sm-6">
            <div class="input-group">
                <label class="input-group-text" for="census-assistant-place">
                    <?= I18N::translate('Place') ?>
                </label>

                <input class="form-control" id="census-assistant-place" name="ca_place">
            </div>
        </div>
    </div>

    <div class="mb-3">
        <div class="input-group">
            <span class="input-group-text">
                <?= I18N::translate('Individuals') ?>
            </span>

            <?= view('components/select-individual', ['name' => 'census-assistant-individual', 'individual' => $individual, 'tree' => $individual->tree()]) ?>

            <button type="button" class="btn btn-primary census-assistant-add" title="<?= I18N::translate('add') ?>">
                <?= view('icons/add') ?>
            </button>
        </div>
    </div>

    <div class="table-responsive">
        <table class="table table-sm table-borderless small wt-census-assistant-table" id="census-assistant-table">
            <thead class="wt-census-assistant-header"></thead>
            <tbody class="wt-census-assistant-body"></tbody>
        </table>
    </div>

    <div class="mb-3">
        <div class="input-group">
            <label class="input-group-text" for="census-assistant-notes">
                <?= I18N::translate('Comments') ?>
            </label>

            <textarea class="form-control" id="census-assistant-notes" name="ca_notes" rows="3"></textarea>
        </div>
    </div>
</div>

<?php View::push('javascript') ?>
<script>
  // When a census date/place is selected, activate the census-assistant
  function censusAssistantSelect () {
    const select = this;
    const option = select.options[select.selectedIndex];
    const form = select.closest('form');

    form.querySelector('.census-assistant-class').value = option.dataset.wtCensus;

    var censusAssistantLink = document.querySelector('.census-assistant-link');
    var censusAssistant = document.querySelector('#census-assistant');
    var censusOption = this.options[this.selectedIndex];
    var census = censusOption.dataset.wtCensus;
    var censusPlace = censusOption.dataset.wtPlace;
    var censusYear = censusOption.dataset.wtDate.substr(-4);

    if (censusOption.value !== '') {
      censusAssistantLink.removeAttribute('hidden');
    } else {
      censusAssistantLink.setAttribute('hidden', '');
    }

    censusAssistant.setAttribute('hidden', '');
    document.querySelector('.census-assistant-class').value = census;
    document.querySelector('#census-assistant-title').value = censusYear + ' ' + censusPlace + ' - <?= I18N::translate('Census transcript') ?> - <?= strip_tags($individual->fullName()) ?> - <?= I18N::translate('Household') ?>';

    let formData = new FormData();
    formData.append('census', census);
    formData.append('_csrf', document.querySelector('meta[name=csrf]').content);

    const url = <?= json_encode(route('module', ['module' => 'GEDFact_assistant', 'action' => 'CensusHeader', 'tree' => $individual->tree()->name()]), JSON_THROW_ON_ERROR) ?>;
    webtrees.httpPost(url, formData)
      .then(response => response.text())
      .then(function (text) {
        document.querySelector('#census-assistant-table thead').innerHTML = text;
        document.querySelector('#census-assistant-table tbody').innerHTML = '';
      });
  }

  // When the census assistant is activated, show the input fields
  function censusAssistantLink () {
    document.querySelector('.census-selector').setAttribute('hidden', '');
    this.setAttribute('hidden', '');
    document.getElementById('census-assistant').removeAttribute('hidden');
    // Set the current individual as the head of household.
    censusAssistantAdd();

    return false;
  }

  // Add the currently selected individual to the census
  function censusAssistantAdd () {
    var censusSelector = document.querySelector('.census-selector');
    var census = censusSelector.options[censusSelector.selectedIndex].dataset.wtCensus;
    var indi_selector = document.querySelector('#census-assistant-individual');
    var xref = indi_selector.options[indi_selector.selectedIndex].value;
    var headInput = document.querySelector('#census-assistant-table td input');
    var head = headInput === null ? xref : headInput.value;

    let formData = new FormData();
    formData.append('census', census);
    formData.append('_csrf', document.querySelector('meta[name=csrf]').content);
    formData.append('head', head);
    formData.append('xref', xref);

    const url = <?= json_encode(route('module', ['module' => 'GEDFact_assistant', 'action' => 'CensusIndividual', 'tree' => $individual->tree()->name()]), JSON_THROW_ON_ERROR) ?>;

    webtrees.httpPost(url, formData)
      .then(response => response.text())
      .then(function (text) {
        document.querySelector('#census-assistant-table tbody').insertAdjacentHTML('beforeend', text);
        webtrees.resetTomSelect(document.querySelector('#census-assistant-individual').tomselect, '', '');
      });

    return false;
  }

  document.querySelectorAll('.census-selector').forEach(function (el) {
    el.addEventListener('change', censusAssistantSelect);
  });

  document.querySelectorAll('.census-assistant-link').forEach(function (el) {
    el.addEventListener('click', censusAssistantLink);
  });

  document.querySelectorAll('.census-assistant-add').forEach(function (el) {
    el.addEventListener('click', censusAssistantAdd);
  });

  document.querySelectorAll('#census-assistant-table').forEach(function (el) {
    el.addEventListener('click', function (el) {
      if (el.target.matches('.wt-icon-delete')) {
        el.target.closest('tr').remove();
      }
    });
  });
</script>
<?php View::endpush() ?>

VaKeR 2022