Последнии сообщения форума
Consolidates editor-insert functionality into slaed.js, improves PDO debug output via template, extends debug-stats across all themes with new lang constants, and migrates icon_name support to default/lite/simple link fragments.
Core changes:
- Editor insert (plugins/system/):
- Remove insert-code.js (413 lines); logic merged into slaed.js
- Add getEditorInsertText() and syncEditorValue() helpers in slaed.js
- Remove editor-action-insert.html fragments from all themes
- PDO class (core/classes/pdo.php):
- Use $tpl for SQL debug output; consolidate getSqlQuery() internals
- Simplify error message format (remove bare <br> tag)
- Language constants (lang/*.php — all 6 languages):
- Add _ERRLOG, _PAGETIME, _MEMUSAGE, _DBQUERY, _DBQTIME
- Debug stats templates (templates/*/fragments/debug-stats.html):
- Use new lang constants instead of hardcoded strings
- Theme templates (default/lite/simple):
- link.html: icon_name support (mirrors admin link.html)
- voting-view.html: minor adjustments
- new.css: CSS updates
- Admin info panel (admin/info/config, admin/info/template — all 5 langs):
- Template and config HTML adjustments
- Misc:
- core/helpers.php, core/security.php, core/classes/template.php: minor fixes
- modules/forum/index.php: minor fix
- index.php: minor fix
- config/global.php, config/local.php: fingerprint update
- docs/TODO.md: removed
Benefits: - Single JS file for editor interactions; no separate insert-code.js loader - Debug stats use translatable constants across all themes - icon_name in link.html is now consistent across all 4 template themes
Technical notes: - editor-action-insert.html deleted from all 4 themes (admin/default/lite/simple) - Backward compatible: link.html callers without icon_name are unaffected
Unified spacing tokens (--sl-space-xs/sm/md/lg) across all sidebar blocks, replaced standalone icon columns with icons embedded inside <a> elements so the full row — icon and label — forms a single clickable target.
Core changes:
- CSS tokens (base.css, theme.css):
- Add --sl-space-xs/sm as canonical spacing tokens; remove --sl-space-xxs
- Sidebar count-row: 3-col grid (icon|label|value) → 2-col (label|value)
- Icons live inside <a>, styled via .sl-block-sidebar-count-label a
- Blocks 3+4 warning color applied to <a> via :has() selector
- Session summary lines: optional icon column (sl-session-line--icon)
- Session rows: geo flag in 20 px icon slot (sl-session-row--icon)
- Admin-block-link: icon inside link, remove separate .sl-admin-block-icon
- Hover/border-radius unified for all block content types
- Templates (link.html, session-row.html, session-summary.html):
link.html: {% if icon_name %}<i class="bi bi-{{ icon_name }}"></i>{% endif %} before label — zero impact on existing calls without icon_name
- session-row.html: geo_html in icon slot, name_link in text column
- session-summary.html: per-category icon_name vars, optional rendering
- dashboard-panel.html: remove redundant sl-dashboard-panel-pad wrapper
- monitor-tooltip-text.html: new fragment for tooltip with BI info icon
- PHP (admin.php, system.php, monitor.php):
- icon_name moved into link array at call site — no intermediate icon_html
- Removed icon-bi.html fragment; icon rendered inline by link.html
- adminblock(): icon_name in admin_link/logout_link arrays
getUserSessionAdminInfo(): geo flag drives 3-col layout; BI icons on summary category lines (shield-check/person-check/robot/eye/people)
- monitor.php getTooltipText(): output via monitor-tooltip-text.html
Benefits: - Icon is semantically part of the link — clickable area covers icon+text - No zoo of micro-fragments; icon_name is a plain string, not rendered HTML - All block types share one hover/spacing rule set - Geo flag symmetrically aligned with category icons in sidebar
Technical notes: - link.html change is additive; callers without icon_name are unaffected - sl-session-row--icon applied only when geo_html is present - --sl-space-xxs removed; 3 px values replaced with --sl-space-xs (4 px)
A :root block with named CSS custom properties is added to base.css and every hardcoded colour, size, and shadow value across base.css, theme.css, and basic-monitor.html is replaced with the corresponding token. No visual changes are intended — this is a pure token-extraction refactor.
Core changes:
- base.css — design token block (:root):
Colour palette: --sl-color-bg/-soft/-muted/-subtle, -border/-border-strong, -text/-text-soft, -muted, -primary (and -hover/-soft/-tint), -success (and -strong/-soft), -danger (and -strong/-soft), -warning (and -strong/-soft), -accent/-accent-soft, -info-soft
- Size tokens: --sl-size-control (28px), -pager (30px), -head (32px), -icon (18px)
- Radius tokens: --sl-radius-control (3px), -panel (4px), -soft (6px)
- Spacing tokens: --sl-space-xs (4px), -sm (6px), -md (8px), -lg (12px)
- Shadow tokens: --sl-shadow-soft, -control, -control-active, -hover-soft
- Typography tokens: --sl-text-shadow-light, -text-shadow-dark
- Focus token: --sl-focus-primary
- base.css — all hardcoded values replaced:
html background gradient, legend, body font colour, h2/h5, links, hr, inputs, blockquote, focus ring, required input colours
- theme.css — all hardcoded values replaced:
Buttons (sl-but-), callout blocks (sl-callout-) now use Bootstrap Icon via font-family bootstrap-icons on ::before; content codes updated to BI
- Status icons, sort arrows, toggle controls, tips, div-grid rows
- Block-sidebar, dashboard-panel, radio-switch, pager, alerts (sl-warn/sl-info)
- Debug sections, preview blocks, menu grid, session summary
- Table, tabs, voting widget, monitor, login shell — complete token migration
- basic-monitor.html:
SVG linearGradient stop-color and path stroke attributes for chart lines (gUp/gDown/gCpu/gRam) replaced with CSS var() references
Benefits: - Single source of truth for all colour decisions; theme changes require only token updates in :root - Enables future dark-mode or white-label overrides via a single :root block - Removes ~300 scattered hex literals from stylesheets
Technical notes: - CSS var() in SVG stop-color is supported in all modern browsers - No Sass/PostCSS required; native CSS custom properties only - Callout ::before now uses BI icon codes (f430, f26a, f33a, f622) replacing Unicode symbols; font-family declaration ensures correct rendering
Regenerated base_fingerprint after template and CSS changes.
Core changes:
- config/local.php:
- base_fingerprint updated to reflect current asset state
Benefits: - Cache invalidation aligned with deployed asset versions
Technical notes: - No runtime behaviour changes
The voting admin edit form is restructured to use toggle-form-block for each answer row, matching the pattern used in fields/rss/replace. getVotingView() gains a forceResult parameter so the admin preview always shows results regardless of vote state or user role.
Core changes:
- modules/voting/admin/index.php:
Table head adds is_col_title flag and explicit class_name for lang/module columns (sl-col-lang, sl-col-module) for fixed-width layout
- Title cell splits into prefix_html (info-tooltip) + has_content_text
Answer input rows replaced with toggle-form-block: each answer pair (body[] text + answer[] number) lives in its own collapsible block; empty answers from index 1 onward are hidden by default
getVotingView() called with forceResult=true so the admin preview is always in result-display mode
- core/system.php — getVotingView():
- New $forceResult parameter (default false)
When true: querylang is bypassed ('1 = 1'), rate forced to 1, result branch always taken, admin edit links suppressed, navigation links (polls, votes, comments) hidden; submit form also suppressed
- toggle_onclick removed from both image-preview calls in getEditorFiles()
- core/admin.php:
toggle_onclick removed from both image-preview calls in getAdminUploadFiles(); image-preview now uses data-sl-toggle-* via the template (set in the preceding template commit)
Benefits: - Admin can preview voting results without casting a vote or ending the poll - Answer fields follow the same expand/collapse UX as fields and rss modules - No toggle_onclick parameters remain in core or voting module
Technical notes: - forceResult=true suppresses is_moder() check and all front-end links; the preview is intentionally read-only and context-free
Module files receive the same safe-text template API migration as the admin modules, plus removal of legacy HideShow() onclick_attr patterns in favour of the data-attribute toggle approach.
Core changes:
- clients/admin/index.php:
- Title cell uses has_content_text / content_text
- clients/index.php:
HideShow call in the info link replaced with data-sl-toggle-control onclick_attr carrying data-* attributes; href changes to '#'
- content/admin/index.php:
- Title cell splits into prefix_html (tooltip) + has_content_text
- media/index.php:
add() URL label toggle changes from onclick="HideShow(...)" to data-sl-toggle-control / data-sl-toggle-effect / data-sl-toggle-duration
- money/admin/index.php:
- Tooltip items for valute labels, comment, browser use has_value_text
- news/admin/index.php:
- Checkbox label_html changed to label_text (auto-escaped)
- rss/admin/index.php:
- Tab system removed; content rendered directly based on $tab value
save() now merges only the active tab's fields into existing $conf['rss'] instead of overwriting the entire config on every save
- Field 1/2 '0' sentinel values normalised to '' for cleaner display
- toggle_onclick replaced with toggle_target_id + is_toggle_block
- search/admin/index.php:
- All getSearchauditTable() cells migrated to has_content_text
- Tooltip item for module label uses has_value_text
- shop/admin/index.php:
- Tooltip items for address, phone, email, note use has_value_text
- Title cells split into prefix_html + has_content_text throughout
- Checkbox label for associated products uses prefix_html + has_content_text
- Label fragment receives prefix_html support for checkbox+text combos
- whois/admin/index.php:
- Comment tooltip item uses has_value_text
Benefits: - Removes ~35 htmlspecialchars() calls scattered across module files - RSS save now preserves unsaved tab's settings correctly - HideShow removed from all active module call sites
Technical notes: - rss/admin tab rendering: UI is now single-page per tab; no JS tab widget
All manual htmlspecialchars() calls in admin module files are replaced by the new has_content_text / content_text, has_value_text / value_text, and has_field_text / field_text template slots. Escaping now happens inside the Mustache fragments at the output boundary instead of in PHP.
Core changes:
- admins.php:
Cell content for name, title, lang columns uses has_content_text; the concatenated htmlspecialchars($name) after info-tooltip moves to a separate content_text slot with prefix_html for the tooltip
- blocks.php:
- filecode() form row for filename uses has_field_text / field_text
- database.php:
- getSqltable() cells for type, table, sql use has_content_text
dump() alert for parse error passes raw $parsed['error'] without manual escaping; the alert fragment handles output encoding
- fields.php / replace.php:
toggle_onclick replaced with toggle_target_id + is_toggle_block to wire the new button toggle; no htmlspecialchars changes (values are constants)
- groups.php:
Tooltip + badge cell splits into prefix_html (tooltip) + content_html (badge); color_attr no longer manually escaped
- scheduler.php:
- nextr, stat, priority cells switch to has_content_text / content_text
- Title cell: info-tooltip moves to prefix_html, title text to content_text
- security.php:
- banlist() tooltip items for IP_CIDR and BANN_REAS use has_value_text
- Ban reason cell uses has_content_text
- config() textarea value_text for dump_skip loses manual htmlspecialchars
Benefits: - Removes ~20 htmlspecialchars() calls from PHP business logic - Escaping is now consistently enforced at template render time - Callers read cleaner: no ENT_QUOTES / ENT_SUBSTITUTE flags in PHP
Technical notes: - Template fragments updated in the preceding commit handle escaping via Mustache {{ }} (auto-escaped) vs {{{ }}} (raw HTML) distinction
Admin stylesheet receives a broad visual consistency pass: icon sizes are unified, form element hover states are added, and new component styles are introduced for the voting widget and the toggle-form-block button.
Core changes:
- base.css:
- Global .bi rule sets font-size: 18px for all Bootstrap Icons
Input/textarea/select get a :hover state: white background, blue-tinted border, subtle box-shadow; disabled inputs excluded
- Focus rule adds explicit border-color alongside the existing box-shadow
- theme.css — icon size unification (16px → 18px):
sl-plus, sl-tip, sl-date/cat/views pseudo-elements, sl-monitor-head, sl-status-compact-left, sl-overview-icon-arr all updated to 18px
- theme.css — toggle-form-block button:
New sl-toggle-form-block-toggle: inline-flex button, green when closed, red when open (.sl-is-open state); scales on hover/focus
- sl-toggle-form-block-title: flexbox layout with gap; title color updated
- sl-toggle-form-block-label: cursor:default, matching line-height
- Label colon suppressed inside toggle-form-block via :not() selector
- theme.css — row-actions trigger:
New sl-row-actions-trigger: 18px inline-flex icon button, purple color, scale transform on hover; .bi inside inherits 18px
- theme.css — table layout:
- sl-col-status width reduced 64px → 52px; sl-col-actions 102px → 72px
- New fixed widths: sl-col-lang 58px, sl-col-module 88px
- th.sl-col-status / th.sl-col-actions padding tightened to 4px
- theme.css — voting widget (sl-vote-*):
Full set of voting result styles: sl-vote-view, sl-vote-title, sl-vote-list, sl-vote-result, sl-vote-result-head, sl-vote-answer, sl-vote-result-meta, sl-vote-meter, sl-vote-progress
- Colour variants 1–5 via sl-vote-meter-N / sl-vote-progress-N
- theme.css — sl-tip refinement:
- Width/height 16px → 18px; font-size 15px → 18px; hover scale 1.08 → 1.12
- Inner div font-size: 14px / line-height: 16px for consistent tooltip text
- sl-plus open state shows minus icon via ::before content override
Benefits: - Visual consistency: all icons at 18px regardless of component context - Input hover feedback matches the rest of the SLAED UI pattern - Voting widget fully styleable without inline CSS
Technical notes: - .bi global rule in base.css takes precedence only where no component rule overrides; component rules that already set font-size are unchanged
Six new template fragments are introduced to support the voting admin redesign and to provide reusable list and AJAX-action primitives.
Core changes:
- comment-action-ajax.html (fragment):
- HTMX-powered action link with hx-get, hx-target, hx-swap attributes
Supports class variants: is_favorite, is_button_blue, is_cart_plus, is_cart_minus; used as the Vote submit button in voting widget
- editor-action-menu.html (fragment):
Alternative row-actions variant using bi icon as trigger span directly without the wrapper nav structure; kept for editor-specific contexts
- list-item.html (fragment):
- Minimal <li> wrapper supporting content_html and nested children_html
- list.html (fragment):
Renders <ul> or <ol> with conditional class variants: sl-list, sl-sublist, sl-sublist-two, login-top (with logged state)
- voting-view.html (fragment):
Single poll answer row: answer text, percentage, vote count, and a <meter> progress bar with colour variant class sl-vote-meter-N
- voting-widget.html (partial):
Full voting widget section: title header, answer list, admin links, submit button, vote/comment footer links; wraps optional <form> tag
Benefits: - Voting result display fully template-driven, no HTML generation in PHP - List and action fragments reduce ad-hoc HTML in module files
Technical notes: - voting-widget.html replaces the HTML previously assembled in getVotingView() inside core/system.php - CSS for sl-vote-* classes is added in the accompanying style commit
Two admin UI patterns are updated to use semantically correct, accessible interactive elements and the new data-attribute toggle API.
Core changes:
- row-actions.html:
Trigger element changes from <span class="sl-but-red">text</span> to <span class="sl-row-actions-trigger" role="button" tabindex="0"> wrapping a Bootstrap icon <i class="bi bi-menu-button-wide-fill">
- Label text moves to title and aria-label attributes for screen readers
- Visual label is now the icon only; text is available on hover/focus
- toggle-form-block.html:
Block element gains data-sl-toggle and data-sl-toggle-default when is_toggle_block is true, enabling JS state tracking
New toggle_target_id path: renders a <button class="sl-plus sl-toggle-form-block-toggle"> with data-sl-toggle-control pointing to the next block, replacing the previous toggle_onclick link pattern
- Existing toggle_onclick link path is preserved as legacy fallback
Label is now wrapped in a <span class="sl-toggle-form-block-label"> for independent styling
Benefits: - Row action trigger is keyboard-navigable without inline onclick - Toggle button communicates expand/collapse semantics to assistive tech - Removes final toggle_onclick usages from active code paths
Technical notes: - toggle_onclick attribute still accepted but only for legacy callers; new callers must use toggle_target_id + is_toggle_block - CSS for sl-row-actions-trigger and sl-toggle-form-block-toggle added in the accompanying style commit





