mmpSearch/pages/projetos.md

27 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="tabs is-centered is-boxed is-medium mb-5">
  {% include sidebar.html %}
</div>

<div class="columns is-vcentered mb-5">
    <div class="column">
      <h1 class="title is-3 has-text-grey-dark">📁 Projetos Disponíveis</h1>
      <p class="subtitle is-6 has-text-grey">
        Busca avançada: Digite termos ou selecione filtros para refinar.
      </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 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="field mb-5">
              <label class="label is-small has-text-grey">Busca Inteligente (IA)</label>
              <div class="control has-icons-left">
                  <input class="input is-small" type="text" id="search-input" placeholder="Nome, plugin, instrumento...">
                  <span class="icon is-small is-left">
                      <i class="fa-solid fa-magnifying-glass"></i>
                  </span>
              </div>
          </div>
          <hr class="my-3">

          <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">
        {% assign project_pages = site.pages | where_exp: "page", "page.path contains 'projetos/'" | sort: "title" %}
        {% for page in project_pages %}
          {% if page.url != '/projetos/' %}
          
            {% assign p_bpm = page.bpm | append: "" %}
            {% assign p_plugins = page.tags.plugin | join: ',' %}
            {% assign p_bassline = page.tags.bassline | join: ',' %}
            {% assign p_automation = page.tags.automation | join: ',' %}
            {% assign p_samples = page.tags.sample | join: ',' %}
            {% assign p_instruments = page.tags.instruments | default: page.tags.instrument | join: ',' %}
            
            {% assign p_name = page.title | default: page.name | downcase %}

            <div class="column is-12-mobile is-6-tablet is-4-desktop is-4-widescreen project-item"
                 data-name="{{ p_name }}"
                 data-bpm="{{ p_bpm }}"
                 data-plugins="{{ p_plugins }}"
                 data-bassline="{{ p_bassline }}"
                 data-automation="{{ p_automation }}"
                 data-instruments="{{ p_instruments }}"
                 data-samples="{{ p_samples }}">

              <div class="card project-card"
                   style="height: 100%; background-color: #f0f8ff; border: 1px solid #cfe8fc; border-radius: 12px; display: flex; flex-direction: column; position: relative;">

                <a href="{{ page.url | relative_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;">
                        {{ page.title | default: page.name | replace: '.html', '' }}
                      </p>

                      {% if page.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;">
                                🎵 {{ page.bpm }} BPM
                            </span>
                        </div>
                      {% else %}
                        <div class="mb-3" style="height: 24px;"></div>
                      {% endif %}

                      <div style="flex: 1;"></div>

                      <div class="mt-auto pt-2" style="width: 100%; border-top: 1px dashed #eef6fc;">

                          {% assign inst_tags = page.tags.instruments | default: page.tags.instrument %}
                          {% if inst_tags and inst_tags.size > 0 %}
                              <details class="category-reveal mb-1" style="width: 100%;">
                                  <summary class="tag is-white summary-btn">
                                      <div class="tag-label"><span>🎸</span> <span class="tag-text">INSTRUMENTS</span></div>
                                      <span class="icon is-small chevron"><i class="fa-solid fa-chevron-down"></i></span>
                                  </summary>
                                  <div class="tags is-centered mt-1 mb-2 px-1" style="gap: 3px;">
                                      {% for tag in inst_tags %}{% if tag != "" %}
                                          <a href="{{ '/instruments/?instrument=' | append: tag | relative_url }}" class="tag is-light is-info clickable-tag">{{ tag | truncate: 18 }}</a>
                                      {% endif %}{% endfor %}
                                  </div>
                              </details>
                          {% endif %}

                          {% if page.tags.plugin and page.tags.plugin.size > 0 %}
                              <details class="category-reveal mb-1" style="width: 100%;">
                                  <summary class="tag is-white summary-btn">
                                      <div class="tag-label"><span>🔌</span> <span class="tag-text">PLUGINS</span></div>
                                      <span class="icon is-small chevron"><i class="fa-solid fa-chevron-down"></i></span>
                                  </summary>
                                  <div class="tags is-centered mt-1 mb-2 px-1" style="gap: 3px;">
                                      {% for tag in page.tags.plugin %}{% if tag != "" %}
                                          <a href="{{ '/plugin/?plugin=' | append: tag | relative_url }}" class="tag is-light is-info clickable-tag">{{ tag | truncate: 18 }}</a>
                                      {% endif %}{% endfor %}
                                  </div>
                              </details>
                          {% endif %}

                          {% if page.tags.bassline and page.tags.bassline.size > 0 %}
                              <details class="category-reveal mb-1" style="width: 100%;">
                                  <summary class="tag is-white summary-btn">
                                      <div class="tag-label"><span>🎹</span> <span class="tag-text">BASSLINE</span></div>
                                      <span class="icon is-small chevron"><i class="fa-solid fa-chevron-down"></i></span>
                                  </summary>
                                  <div class="tags is-centered mt-1 mb-2 px-1" style="gap: 3px;">
                                      {% for tag in page.tags.bassline %}{% if tag != "" %}
                                          <a href="{{ '/bassline/?bassline=' | append: tag | relative_url }}" class="tag is-light is-info clickable-tag">{{ tag | truncate: 18 }}</a>
                                      {% endif %}{% endfor %}
                                  </div>
                              </details>
                          {% endif %}

                          {% if page.tags.automation and page.tags.automation.size > 0 %}
                              <details class="category-reveal mb-1" style="width: 100%;">
                                  <summary class="tag is-white summary-btn">
                                      <div class="tag-label"><span>🎚️</span> <span class="tag-text">AUTOMATION</span></div>
                                      <span class="icon is-small chevron"><i class="fa-solid fa-chevron-down"></i></span>
                                  </summary>
                                  <div class="tags is-centered mt-1 mb-2 px-1" style="gap: 3px;">
                                      {% for tag in page.tags.automation %}{% if tag != "" %}
                                          <a href="{{ '/automation/?automation=' | append: tag | relative_url }}" class="tag is-light is-info clickable-tag">{{ tag | truncate: 18 }}</a>
                                      {% endif %}{% endfor %}
                                  </div>
                              </details>
                          {% endif %}

                          {% if page.tags.sample and page.tags.sample.size > 0 %}
                              <details class="category-reveal mb-1" style="width: 100%;">
                                  <summary class="tag is-white summary-btn">
                                      <div class="tag-label"><span>🎤</span> <span class="tag-text">SAMPLES</span></div>
                                      <span class="icon is-small chevron"><i class="fa-solid fa-chevron-down"></i></span>
                                  </summary>
                                  <div class="tags is-centered mt-1 mb-2 px-1" style="gap: 3px;">
                                      {% for tag in page.tags.sample %}{% if tag != "" %}
                                          <a href="{{ '/sample/?sample=' | append: tag | relative_url }}" class="tag is-light is-info clickable-tag">{{ tag | truncate: 18 }}</a>
                                      {% endif %}{% endfor %}
                                  </div>
                              </details>
                          {% endif %}

                      </div>
                    </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 | relative_url }}"
                     data-modal-title="Detalhes: {{ page.file }}"
                     data-full-btn-text="Ir para Página"
                     data-full-btn-link="{{ page.url | relative_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: page.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: {{ page.file }}"
                     data-full-btn-text="Abrir Editor"
                     data-full-btn-link="{{ creation_url }}"
                     style="color: #3273dc; font-size: 0.8rem; font-weight: 600; transition: background 0.2s;">
                     Editar
                  </a>
                </footer>

              </div>
            </div>
          {% endif %}
        {% 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>

{% include preview-modal.html %}