mmpSearch/pages/projetos.md

20 KiB
Executable File

layout title permalink
default MMPSearch - Projetos /projetos/

{% assign list_bpm = "" %} {% assign list_plugins = "" %} {% assign list_instruments = "" %} {% assign list_samples = "" %} {% assign list_bassline = "" %} {% assign list_automation = "" %}

{% for p in site.data.all %} {% if p.bpm %}{% assign list_bpm = list_bpm | append: p.bpm | append: "|||" %}{% endif %}

{% for item in p.tags.plugin %}{% if item != "" %}{% assign list_plugins = list_plugins | append: item | append: "|||" %}{% endif %}{% endfor %}

{% if p.tags.bassline %}
    {% for item in p.tags.bassline %}{% if item != "" %}{% assign list_bassline = list_bassline | append: item | append: "|||" %}{% endif %}{% endfor %}
{% endif %}

{% if p.tags.automation %}
    {% for item in p.tags.automation %}{% if item != "" %}{% assign list_automation = list_automation | append: item | append: "|||" %}{% endif %}{% endfor %}
{% endif %}

{% for track in p.tracks %}
    {% if track.instruments %}
        {% for inst in track.instruments %}{% assign list_instruments = list_instruments | append: inst.instrument_name | append: "|||" %}{% endfor %}
    {% elsif track.instrument_name %}
        {% assign list_instruments = list_instruments | append: track.instrument_name | append: "|||" %}
    {% endif %}
    {% if track.sample %}
        {% for smp in track.sample %}{% assign list_samples = list_samples | append: smp.sample_name | append: "|||" %}{% endfor %}
    {% elsif track.sample_name %}
        {% assign list_samples = list_samples | append: track.sample_name | append: "|||" %}
    {% endif %}
{% endfor %}

{% endfor %}

{% assign unique_bpm = list_bpm | split: "|||" | uniq | sort %} {% assign unique_plugins = list_plugins | split: "|||" | uniq | sort %} {% assign unique_instruments = list_instruments | split: "|||" | uniq | sort %} {% assign unique_samples = list_samples | split: "|||" | uniq | sort %} {% assign unique_bassline = list_bassline | split: "|||" | uniq | sort %} {% assign unique_automation = list_automation | split: "|||" | uniq | sort %}


  <div class="columns mb-5 is-vcentered">
      <div class="column">
        <h1 class="title is-3 has-text-grey-dark">Explorar Projetos</h1>
        <p class="subtitle is-6 has-text-grey">Use os filtros laterais para combinar critérios (ex: Bassline Reese + 140 BPM).</p>
      </div>
      <div class="column is-narrow">
         <button id="reset-all-filters" class="button is-danger is-light is-small">
             <span class="icon"><i class="fa-solid fa-rotate-left"></i></span>
             <span>Limpar Todos os Filtros</span>
         </button>
      </div>
  </div>

  <div class="columns">
    
    <div class="column is-3">
        <div class="box p-3" style="background: #fcfcfc; border: 1px solid #eee;">
            
            <div class="filter-group mb-4">
                <p class="menu-label has-text-weight-bold mb-2">BPM</p>
                <div class="field is-grouped is-grouped-multiline">
                    {% for item in unique_bpm %}
                        {% if item != "" %}
                        <div class="control">
                            <label class="checkbox tag is-white" style="border: 1px solid #dbdbdb; cursor: pointer;">
                                <input type="checkbox" class="filter-checkbox" data-category="bpm" value="{{ item }}">
                                {{ item }}
                            </label>
                        </div>
                        {% endif %}
                    {% endfor %}
                </div>
            </div>
            <hr class="my-3">

            <details open>
                <summary class="menu-label has-text-weight-bold mb-2 clickable-summary">Instrumentos</summary>
                <div class="filter-content" style="max-height: 200px; overflow-y: auto;">
                    {% for item in unique_instruments %}
                        {% if item != "" %}
                        <label class="checkbox is-block mb-1 is-size-7">
                            <input type="checkbox" class="filter-checkbox" data-category="instruments" value="{{ item }}">
                            {{ item }}
                        </label>
                        {% endif %}
                    {% endfor %}
                </div>
            </details>
            <hr class="my-3">

            <details>
                <summary class="menu-label has-text-weight-bold mb-2 clickable-summary">Plugins</summary>
                <div class="filter-content" style="max-height: 200px; overflow-y: auto;">
                    {% for item in unique_plugins %}
                        {% if item != "" %}
                        <label class="checkbox is-block mb-1 is-size-7">
                            <input type="checkbox" class="filter-checkbox" data-category="plugins" value="{{ item }}">
                            {{ item }}
                        </label>
                        {% endif %}
                    {% endfor %}
                </div>
            </details>
            <hr class="my-3">

            <details>
                <summary class="menu-label has-text-weight-bold mb-2 clickable-summary">Bassline</summary>
                <div class="filter-content" style="max-height: 200px; overflow-y: auto;">
                    {% for item in unique_bassline %}
                        {% if item != "" %}
                        <label class="checkbox is-block mb-1 is-size-7">
                            <input type="checkbox" class="filter-checkbox" data-category="bassline" value="{{ item }}">
                            {{ item }}
                        </label>
                        {% endif %}
                    {% endfor %}
                </div>
            </details>
            <hr class="my-3">

            <details>
                <summary class="menu-label has-text-weight-bold mb-2 clickable-summary">Automação</summary>
                <div class="filter-content" style="max-height: 200px; overflow-y: auto;">
                    {% for item in unique_automation %}
                        {% if item != "" %}
                        <label class="checkbox is-block mb-1 is-size-7">
                            <input type="checkbox" class="filter-checkbox" data-category="automation" value="{{ item }}">
                            {{ item }}
                        </label>
                        {% endif %}
                    {% endfor %}
                </div>
            </details>
            <hr class="my-3">

            <details>
                <summary class="menu-label has-text-weight-bold mb-2 clickable-summary">Samples</summary>
                <div class="filter-content" style="max-height: 200px; overflow-y: auto;">
                    {% for item in unique_samples %}
                        {% if item != "" %}
                        <label class="checkbox is-block mb-1 is-size-7">
                            <input type="checkbox" class="filter-checkbox" data-category="samples" value="{{ item }}">
                            {{ item | truncate: 25 }}
                        </label>
                        {% endif %}
                    {% endfor %}
                </div>
            </details>

        </div>
    </div>

    <div class="column is-9">
        <div class="notification is-info is-light mb-4 is-hidden" id="results-count-bar">
            Encontrados <span id="visible-count" class="has-text-weight-bold">0</span> projetos.
        </div>

        <div id="project-list" class="columns is-multiline">
            {% for projeto in site.data.all %}

                {% assign project_insts = "" %}
                {% assign project_samples = "" %}
                
                {% for track in projeto.tracks %}
                    {% if track.instruments %}
                        {% for inst in track.instruments %}{% assign project_insts = project_insts | append: inst.instrument_name | append: "," %}{% endfor %}
                    {% elsif track.instrument_name %}
                        {% assign project_insts = project_insts | append: track.instrument_name | append: "," %}
                    {% endif %}

                    {% if track.sample %}
                        {% for smp in track.sample %}{% assign project_samples = project_samples | append: smp.sample_name | append: "," %}{% endfor %}
                    {% elsif track.sample_name %}
                        {% assign project_samples = project_samples | append: track.sample_name | append: "," %}
                    {% endif %}
                {% endfor %}

                <div class="column is-12-mobile is-6-tablet is-4-desktop is-3-widescreen project-item"
                     data-bpm="{{ projeto.bpm }}"
                     data-plugins="{{ projeto.tags.plugin | join: ',' }}"
                     data-bassline="{{ projeto.tags.bassline | join: ',' }}"
                     data-automation="{{ projeto.tags.automation | join: ',' }}"
                     data-instruments="{{ project_insts }}"
                     data-samples="{{ project_samples }}">

                      <div class="card project-card" style="height: 100%; background-color: #f0f8ff; border: 1px solid #cfe8fc; border-radius: 12px; display: flex; flex-direction: column;">
                        {% assign file_url = projeto.file | downcase | replace: ' ', '-' | replace: 'ç', 'c' | replace: 'ã', 'a' | replace: 'á', 'a' | replace: 'â', 'a' | replace: 'é', 'e' | replace: 'ê', 'e' | replace: 'í', 'i' | replace: 'ó', 'o' | replace: 'ô', 'o' | replace: 'õ', 'o' | replace: 'ú', 'u' %}
                        {% assign page_url = '../projetos/' | append: file_url | append: '.html' %}

                        <a href="{{ page_url }}" style="text-decoration: none; flex: 1; display: flex; flex-direction: column;">
                            <div class="card-content has-text-centered p-4" style="flex: 1; display: flex; flex-direction: column;">

                              <div style="width: 50px; height: 50px; background-color: #fff; border-radius: 50%; display: flex; align-items: center; justify-content: center; margin: 0 auto 0.5rem auto; box-shadow: 0 2px 5px rgba(0,0,0,0.05);">
                                <span class="icon" style="color: #3273dc;"><i class="fa-solid fa-music fa-lg"></i></span>
                              </div>

                              <p class="title is-6 mb-2" style="color: #205081; word-break: break-word; font-weight: 700; line-height: 1.2;">
                                {{ projeto.file }}
                              </p>

                              {% if projeto.bpm %}
                                <div class="mb-3">
                                    <span class="tag is-dark is-rounded is-light" style="font-size: 0.7rem; font-weight: bold; border: 1px solid #ccc;">
                                        🎵 {{ projeto.bpm }} BPM
                                    </span>
                                </div>
                              {% else %}
                                <div class="mb-3" style="height: 24px;"></div>
                              {% endif %}
                            </div>
                        </a>

                        <footer class="card-footer" style="border-top: 1px solid #cfe8fc; background-color: #fff; border-radius: 0 0 12px 12px; overflow: hidden;">
                          <a href="#" class="card-footer-item js-open-modal" data-target-url="{{ page_url }}" data-modal-title="Detalhes: {{ projeto.file }}" data-full-btn-text="Ir para Página" data-full-btn-link="{{ page_url }}" style="color: #5b7da3; font-size: 0.8rem; font-weight: 600; border-right: 1px solid #eee; transition: background 0.2s;">Ver</a>
                          {% assign creation_url = '/mmpSearch/creation.html?project=' | append: projeto.file %}
                          {% assign embed_url = creation_url | append: '&embed=true' %}
                          <a href="#" class="card-footer-item js-open-modal" data-target-url="{{ embed_url }}" data-modal-title="Editor: {{ projeto.file }}" data-full-btn-text="Abrir Editor" data-full-btn-link="{{ creation_url }}" style="color: #3273dc; font-size: 0.8rem; font-weight: 600;">Editar</a>
                        </footer>
                      </div>
                </div>
            {% endfor %}
        </div>
        
        <div id="no-results" class="has-text-centered is-hidden mt-6">
            <span class="icon is-large has-text-grey-light"><i class="fa-solid fa-face-frown fa-3x"></i></span>
            <p class="subtitle mt-3 has-text-grey">Nenhum projeto encontrado com essa combinação.</p>
            <button class="button is-small is-info mt-2" onclick="document.getElementById('reset-all-filters').click()">Limpar Filtros</button>
        </div>
    </div>

  </div>
</div>

{% include preview-modal.html %}