123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201 |
- {% extends '@WebProfiler/Profiler/layout.html.twig' %}
- {% import _self as helper %}
- {% block toolbar %}
- {% if collector.messages|length > 0 %}
- {% set status_color = collector.exceptionsCount ? 'red' %}
- {% set icon %}
- {{ include('@WebProfiler/Icon/messenger.svg') }}
- <span class="sf-toolbar-value">{{ collector.messages|length }}</span>
- {% endset %}
- {% set text %}
- {% for bus in collector.buses %}
- {% set exceptionsCount = collector.exceptionsCount(bus) %}
- <div class="sf-toolbar-info-piece">
- <b>{{ bus }}</b>
- <span
- title="{{ exceptionsCount }} message(s) with exceptions"
- class="sf-toolbar-status sf-toolbar-status-{{ exceptionsCount ? 'red' }}"
- >
- {{ collector.messages(bus)|length }}
- </span>
- </div>
- {% endfor %}
- {% endset %}
- {{ include('@WebProfiler/Profiler/toolbar_item.html.twig', { link: 'messenger', status: status_color }) }}
- {% endif %}
- {% endblock %}
- {% block menu %}
- <span class="label{{ collector.exceptionsCount ? ' label-status-error' }}{{ collector.messages is empty ? ' disabled' }}">
- <span class="icon">{{ include('@WebProfiler/Icon/messenger.svg') }}</span>
- <strong>Messages</strong>
- {% if collector.exceptionsCount > 0 %}
- <span class="count">
- <span>{{ collector.exceptionsCount }}</span>
- </span>
- {% endif %}
- </span>
- {% endblock %}
- {% block head %}
- {{ parent() }}
- <style>
- .message-item thead th { position: relative; cursor: pointer; user-select: none; padding-right: 35px; }
- .message-item tbody tr td:first-child { width: 170px; }
- .message-item .label { float: right; padding: 1px 5px; opacity: .75; margin-left: 5px; }
- .message-item .toggle-button { position: absolute; right: 6px; top: 6px; opacity: .5; pointer-events: none }
- .message-item .icon svg { height: 24px; width: 24px; }
- .message-item .sf-toggle-off .icon-close, .sf-toggle-on .icon-open { display: none; }
- .message-item .sf-toggle-off .icon-open, .sf-toggle-on .icon-close { display: block; }
- .message-bus .badge.status-some-errors { line-height: 16px; border-bottom: 2px solid #B0413E; }
- .message-item tbody.sf-toggle-content.sf-toggle-visible { display: table-row-group; }
- td.message-bus-dispatch-caller { background: #f1f2f3; }
- .theme-dark td.message-bus-dispatch-caller { background: var(--base-1); }
- </style>
- {% endblock %}
- {% block panel %}
- {% import _self as helper %}
- <h2>Messages</h2>
- {% if collector.messages is empty %}
- <div class="empty">
- <p>No messages have been collected.</p>
- </div>
- {% else %}
- <div class="sf-tabs message-bus">
- <div class="tab">
- {% set messages = collector.messages %}
- {% set exceptionsCount = collector.exceptionsCount %}
- <h3 class="tab-title">All<span class="badge {{ exceptionsCount ? exceptionsCount == messages|length ? 'status-error' : 'status-some-errors' }}">{{ messages|length }}</span></h3>
- <div class="tab-content">
- <p class="text-muted">Ordered list of dispatched messages across all your buses</p>
- {{ helper.render_bus_messages(messages, true) }}
- </div>
- </div>
- {% for bus in collector.buses %}
- <div class="tab message-bus">
- {% set messages = collector.messages(bus) %}
- {% set exceptionsCount = collector.exceptionsCount(bus) %}
- <h3 class="tab-title">{{ bus }}<span class="badge {{ exceptionsCount ? exceptionsCount == messages|length ? 'status-error' : 'status-some-errors' }}">{{ messages|length }}</span></h3>
- <div class="tab-content">
- <p class="text-muted">Ordered list of messages dispatched on the <code>{{ bus }}</code> bus</p>
- {{ helper.render_bus_messages(messages) }}
- </div>
- </div>
- {% endfor %}
- </div>
- {% endif %}
- {% endblock %}
- {% macro render_bus_messages(messages, showBus = false) %}
- {% set discr = random() %}
- {% for dispatchCall in messages %}
- <table class="message-item">
- <thead>
- <tr>
- <th colspan="2" class="sf-toggle"
- data-toggle-selector="#message-item-{{ discr }}-{{ loop.index0 }}-details"
- data-toggle-initial="{{ loop.first ? 'display' }}"
- >
- <span class="dump-inline">{{ profiler_dump(dispatchCall.message.type) }}</span>
- {% if showBus %}
- <span class="label">{{ dispatchCall.bus }}</span>
- {% endif %}
- {% if dispatchCall.exception is defined %}
- <span class="label status-error">exception</span>
- {% endif %}
- <a class="toggle-button">
- <span class="icon icon-close">{{ include('@WebProfiler/images/icon-minus-square.svg') }}</span>
- <span class="icon icon-open">{{ include('@WebProfiler/images/icon-plus-square.svg') }}</span>
- </a>
- </th>
- </tr>
- </thead>
- <tbody id="message-item-{{ discr }}-{{ loop.index0 }}-details" class="sf-toggle-content">
- <tr>
- <td colspan="2" class="message-bus-dispatch-caller">
- <span class="metadata">In
- {% set caller = dispatchCall.caller %}
- {% if caller.line %}
- {% set link = caller.file|file_link(caller.line) %}
- {% if link %}
- <a href="{{ link }}" title="{{ caller.file }}">{{ caller.name }}</a>
- {% else %}
- <abbr title="{{ caller.file }}">{{ caller.name }}</abbr>
- {% endif %}
- {% else %}
- {{ caller.name }}
- {% endif %}
- line <a class="text-small sf-toggle" data-toggle-selector="#sf-trace-{{ discr }}-{{ loop.index0 }}">{{ caller.line }}</a>
- </span>
- <div class="hidden" id="sf-trace-{{ discr }}-{{ loop.index0 }}">
- <div class="trace">
- {{ caller.file|file_excerpt(caller.line)|replace({
- '#DD0000': 'var(--highlight-string)',
- '#007700': 'var(--highlight-keyword)',
- '#0000BB': 'var(--highlight-default)',
- '#FF8000': 'var(--highlight-comment)'
- })|raw }}
- </div>
- </div>
- </td>
- </tr>
- {% if showBus %}
- <tr>
- <td class="text-bold">Bus</td>
- <td>{{ dispatchCall.bus }}</td>
- </tr>
- {% endif %}
- <tr>
- <td class="text-bold">Message</td>
- <td>{{ profiler_dump(dispatchCall.message.value, maxDepth=2) }}</td>
- </tr>
- <tr>
- <td class="text-bold">Envelope stamps <span class="text-muted">when dispatching</span></td>
- <td>
- {% for item in dispatchCall.stamps %}
- {{ profiler_dump(item) }}
- {% else %}
- <span class="text-muted">No items</span>
- {% endfor %}
- </td>
- </tr>
- {% if dispatchCall.stamps_after_dispatch is defined %}
- <tr>
- <td class="text-bold">Envelope stamps <span class="text-muted">after dispatch</span></td>
- <td>
- {% for item in dispatchCall.stamps_after_dispatch %}
- {{ profiler_dump(item) }}
- {% else %}
- <span class="text-muted">No items</span>
- {% endfor %}
- </td>
- </tr>
- {% endif %}
- {% if dispatchCall.exception is defined %}
- <tr>
- <td class="text-bold">Exception</td>
- <td>
- {{ profiler_dump(dispatchCall.exception.value, maxDepth=1) }}
- </td>
- </tr>
- {% endif %}
- </tbody>
- </table>
- {% endfor %}
- {% endmacro %}
|