@toolbox-web/grid 1.30.0 → 1.30.1
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/all.js +1 -1
- package/all.js.map +1 -1
- package/index.js +1 -1
- package/lib/plugins/filtering/index.js +1 -1
- package/lib/plugins/filtering/index.js.map +1 -1
- package/package.json +1 -1
- package/umd/grid.all.umd.js +1 -1
- package/umd/grid.all.umd.js.map +1 -1
- package/umd/plugins/filtering.umd.js +1 -1
- package/umd/plugins/filtering.umd.js.map +1 -1
|
@@ -1,2 +1,2 @@
|
|
|
1
|
-
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("../../core/internal/aria"),require("../../core/plugin/base-plugin"),require("../../core/plugin/expander-column"),require("../../core/internal/virtualization")):"function"==typeof define&&define.amd?define(["exports","../../core/internal/aria","../../core/plugin/base-plugin","../../core/plugin/expander-column","../../core/internal/virtualization"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TbwGridPlugin_filtering={},e.TbwGrid,e.TbwGrid,e.TbwGrid,e.TbwGrid)}(this,function(e,t,r,n,l){"use strict";const i="(Blank)";function a(e){if("number"==typeof e)return e;if(e instanceof Date)return e.getTime();const t=Number(e);if(!isNaN(t))return t;return new Date(e).getTime()}function s(e,t,r=!1,n){if(!t.length)return e;const l=t.map(e=>function(e,t,r){const n=e.field,l=e.operator;if("blank"===l)return e=>{const t=e[n];return null==t||""===t};if("notBlank"===l)return e=>{const t=e[n];return null!=t&&""!==t};if(r&&("notIn"===l||"in"===l)){const t=e.value;if("notIn"===l){if(!Array.isArray(t))return()=>!0;const e=new Set(t);return t=>{const l=r(t[n],t),a=Array.isArray(l)?l:null!=l?[l]:[];return 0===a.length?!e.has(i):!a.some(t=>e.has(t))}}if(!Array.isArray(t))return()=>!1;const a=new Set(t);return e=>{const t=r(e[n],e),l=Array.isArray(t)?t:null!=t?[t]:[];return 0===l.length?a.has(i):l.some(e=>a.has(e))}}if("notIn"===l){if(!Array.isArray(e.value))return()=>!0;const t=new Set(e.value);return e=>{const r=e[n];return null==r||""===r?!t.has(i):!t.has(r)}}if("in"===l){if(!Array.isArray(e.value))return()=>!1;const t=new Set(e.value);return e=>{const r=e[n];return null==r||""===r?t.has(i):t.has(r)}}const s="number"===e.type;if("greaterThan"===l){const t=a(e.value);return s?e=>e[n]>t:e=>{const r=e[n];return null!=r&&a(r)>t}}if("greaterThanOrEqual"===l){const t=a(e.value);return s?e=>e[n]>=t:e=>{const r=e[n];return null!=r&&a(r)>=t}}if("lessThan"===l){const t=a(e.value);return s?e=>e[n]<t:e=>{const r=e[n];return null!=r&&a(r)<t}}if("lessThanOrEqual"===l){const t=a(e.value);return s?e=>e[n]<=t:e=>{const r=e[n];return null!=r&&a(r)<=t}}if("between"===l){const t=a(e.value),r=a(e.valueTo);return s?e=>{const l=e[n];return l>=t&&l<=r}:e=>{const l=e[n];if(null==l)return!1;const i=a(l);return i>=t&&i<=r}}const o=t?String(e.value):String(e.value).toLowerCase();return"contains"===l?t?e=>{const t=e[n];return null!=t&&String(t).includes(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().includes(o)}:"notContains"===l?t?e=>{const t=e[n];return null!=t&&!String(t).includes(o)}:e=>{const t=e[n];return null!=t&&!String(t).toLowerCase().includes(o)}:"equals"===l?t?e=>{const t=e[n];return null!=t&&String(t)===o}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase()===o}:"notEquals"===l?t?e=>{const t=e[n];return null!=t&&String(t)!==o}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase()!==o}:"startsWith"===l?t?e=>{const t=e[n];return null!=t&&String(t).startsWith(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().startsWith(o)}:"endsWith"===l?t?e=>{const t=e[n];return null!=t&&String(t).endsWith(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().endsWith(o)}:()=>!0}(e,r,n?.get(e.field)));return 1===l.length?e.filter(l[0]):e.filter(e=>{for(let t=0;t<l.length;t++)if(!l[t](e))return!1;return!0})}function o(e,t,r){const n=new Set;let l=!1;for(const i of e){const e=i[t];if(r){const t=r(e,i);if(Array.isArray(t)){0===t.length&&(l=!0);for(const e of t)null!=e&&n.add(e)}else null!=t?n.add(t):l=!0}else null!=e&&""!==e?n.add(e):l=!0}return l&&n.add(i),[...n].sort((e,t)=>"number"==typeof e&&"number"==typeof t?e-t:String(e).localeCompare(String(t)))}function c(e){return e?e.toISOString().split("T")[0]:""}function d(e){return e?"string"==typeof e?e:"number"==typeof e?c(new Date(e)):"":""}function u(e,t,r,n,i,a){const{field:s,column:o}=t,c=function(e){if(e){const t=getComputedStyle(e).getPropertyValue("--tbw-filter-item-height");if(t&&t.trim()){const e=parseFloat(t);if(!isNaN(e)&&e>0)return e}}return 28}(e),d=e=>{if(null==e)return"(Blank)";if(o.format&&!o.filterValue){const t=o.format(e,void 0);if(t)return t}return String(e)};r=r.slice().sort((e,t)=>d(e).localeCompare(d(t)));const u=document.createElement("div");u.className="tbw-filter-search";const p=document.createElement("input");p.type="text",p.placeholder="Search...",p.className="tbw-filter-search-input",p.value=a.get(s)??"",u.appendChild(p),e.appendChild(u);const f=document.createElement("div");f.className="tbw-filter-actions";const h=document.createElement("label");h.className="tbw-filter-value-item",h.style.padding="0",h.style.margin="0";const b=document.createElement("input");b.type="checkbox",b.className="tbw-filter-checkbox";const g=document.createElement("span");g.textContent="Select All",h.appendChild(b),h.appendChild(g),f.appendChild(h);const m=new Map;r.forEach(e=>{const t=null==e?"__null__":String(e);m.set(t,!n.has(e))});const v=()=>{const e=[...m.values()],t=e.every(e=>e),r=e.every(e=>!e);b.checked=t,b.indeterminate=!t&&!r};b.addEventListener("change",()=>{const e=b.checked;for(const t of m.keys())m.set(t,e);v(),k()}),v(),e.appendChild(f);const w=document.createElement("div");w.className="tbw-filter-values";const y=document.createElement("div");y.className="tbw-filter-values-spacer",w.appendChild(y);const x=document.createElement("div");x.className="tbw-filter-values-content",w.appendChild(x);let C=[];const S=(e,t)=>{const r=d(e),n=null==e?"__null__":String(e),l=document.createElement("label");l.className="tbw-filter-value-item",l.style.position="absolute",l.style.top=`calc(var(--tbw-filter-item-height, 28px) * ${t})`,l.style.left="0",l.style.right="0",l.style.boxSizing="border-box";const i=document.createElement("input");i.type="checkbox",i.className="tbw-filter-checkbox",i.checked=m.get(n)??!0,i.dataset.value=n,i.addEventListener("change",()=>{m.set(n,i.checked),v()});const a=document.createElement("span");return a.textContent=r,l.appendChild(i),l.appendChild(a),l},k=()=>{const e=C.length,t=w.clientHeight,r=w.scrollTop;if(y.style.height=e*c+"px",l.shouldBypassVirtualization(e,50/3))return x.innerHTML="",x.style.transform="translateY(0px)",void C.forEach((e,t)=>{x.appendChild(S(e,t))});const n=l.computeVirtualWindow({totalRows:e,viewportHeight:t,scrollTop:r,rowHeight:c,overscan:3});x.style.transform=`translateY(${n.offsetY}px)`,x.innerHTML="";for(let l=n.start;l<n.end;l++)x.appendChild(S(C[l],l-n.start))},E=e=>{const t=i.caseSensitive??!1,n=t?e:e.toLowerCase();if(C=r.filter(r=>{const l=d(r),i=t?l:l.toLowerCase();return!e||i.includes(n)}),C.sort((e,t)=>{const r=null==e?"__null__":String(e),n=null==t?"__null__":String(t),l=m.get(r)??!0;return l!==(m.get(n)??!0)?l?-1:1:d(e).localeCompare(d(t))}),0===C.length){y.style.height="0px",x.innerHTML="";const e=document.createElement("div");return e.className="tbw-filter-no-match",e.textContent="No matching values",void x.appendChild(e)}k()};let F;w.addEventListener("scroll",()=>{C.length>0&&k()},{passive:!0}),E(p.value),e.appendChild(w),p.addEventListener("input",()=>{clearTimeout(F),F=setTimeout(()=>{a.set(s,p.value),E(p.value)},i.debounceMs??150)});const T=document.createElement("div");T.className="tbw-filter-buttons";const A=document.createElement("button");A.className="tbw-filter-apply-btn",A.textContent="Apply",A.addEventListener("click",()=>{const e=[];for(const[t,n]of m)if(!n)if("__null__"===t)e.push(null);else{const n=r.find(e=>String(e)===t);e.push(void 0!==n?n:t)}t.applySetFilter(e)}),T.appendChild(A);const N=document.createElement("button");N.className="tbw-filter-clear-btn",N.textContent="Clear Filter",N.addEventListener("click",()=>{t.clearFilter()}),T.appendChild(N),e.appendChild(T)}function p(e,t){if("number"==typeof e)return e;if("string"==typeof e){const r=parseFloat(e);return isNaN(r)?t:r}return t}class f extends r.BaseGridPlugin{static manifest={events:[{type:"filter-applied",description:"Emitted when filter criteria change. Subscribers can react to row visibility changes."}],queries:[{type:"getContextMenuItems",description:"Contributes filter-related items to the header context menu"}]};name="filtering";styles='@layer tbw-plugins{tbw-grid .tbw-quick-filter-input{flex:1;max-width:300px;height:var(--tbw-input-height, 1.75rem);padding:var(--tbw-input-padding, 0 .5rem);border:1px solid var(--tbw-color-border);border-radius:var(--tbw-border-radius);background:var(--tbw-color-bg);color:var(--tbw-color-fg);font-size:var(--tbw-font-size-sm, .8125rem)}tbw-grid .tbw-quick-filter-input:focus{outline:none;border-color:var(--tbw-color-accent)}tbw-grid .header-cell.filtered:before{content:"";position:absolute;top:var(--tbw-spacing-xs, .25rem);right:var(--tbw-spacing-xs, .25rem);width:var(--tbw-indicator-size, .375rem);height:var(--tbw-indicator-size, .375rem);background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border-radius:50%}tbw-grid .tbw-filter-btn{display:var(--tbw-filter-btn-display, inline-flex);visibility:var(--tbw-filter-btn-visibility, visible);align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:2px;margin-left:var(--tbw-spacing-xs, .25rem);opacity:.4;transition:opacity .15s,visibility 0s,display 0s allow-discrete;color:inherit;vertical-align:middle;transition-behavior:allow-discrete}tbw-grid .tbw-filter-btn:hover,tbw-grid .tbw-filter-btn.active{opacity:1;visibility:visible;display:inline-flex}tbw-grid .tbw-filter-btn.active{color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6))}tbw-grid .header-row .cell:hover .tbw-filter-btn,tbw-grid .header-row .cell.filtered .tbw-filter-btn{display:inline-flex;visibility:visible}}';get defaultConfig(){return{debounceMs:300,caseSensitive:!1,trimInput:!0,useWorker:!0}}isFilteringEnabled(){return!1!==this.grid.effectiveConfig?.filterable}isColumnFilterable(e){return!!this.isFilteringEnabled()&&!1!==e.filterable}getFilterValues(){const e=this.grid.effectiveConfig?.columns;if(!e)return;let t;for(const r of e)r.field&&r.filterValue&&(t||(t=new Map),t.set(r.field,r.filterValue));return t}filters=new Map;cachedResult=null;cacheKey=null;cachedInputSpot=null;openPanelField=null;panelElement=null;panelAnchorElement=null;searchText=new Map;excludedValues=new Map;panelAbortController=null;globalStylesInjected=!1;computeSelected(){const e={},t=[];for(const[r,n]of this.filters)if("set"===n.type)if("in"===n.operator&&Array.isArray(n.value))e[r]=n.value;else if("notIn"===n.operator){const e=this.grid.effectiveConfig?.columns?.find(e=>e.field===r);t.push({field:r,filterValue:e?.filterValue})}if(t.length>0){const r=function(e,t){const r=new Map;for(const{field:l,filterValue:i}of t)r.set(l,{values:new Set,hasBlank:!1,hasExtractor:!!i});for(const l of e)for(const{field:e,filterValue:n}of t){const t=r.get(e),i=l[e];if(n){const e=n(i,l);if(Array.isArray(e)){0===e.length&&(t.hasBlank=!0);for(const r of e)null!=r&&t.values.add(r)}else null!=e?t.values.add(e):t.hasBlank=!0}else null!=i&&""!==i?t.values.add(i):t.hasBlank=!0}const n=new Map;for(const[l,{values:a,hasBlank:s}]of r)s&&a.add(i),n.set(l,[...a].sort((e,t)=>"number"==typeof e&&"number"==typeof t?e-t:String(e).localeCompare(String(t))));return n}(this.sourceRows,t);for(const{field:n}of t){const t=this.excludedValues.get(n),l=r.get(n)??[];e[n]=t?l.filter(e=>!t.has(e)):l}}return e}syncExcludedValues(e,t){if(t)if("set"===t.type&&"notIn"===t.operator&&Array.isArray(t.value))this.excludedValues.set(e,new Set(t.value));else if("set"===t.type&&"in"===t.operator&&Array.isArray(t.value)){const r=this.sourceRows;if(!r||0===r.length)return void this.excludedValues.delete(e);const n=t.value,l=new Set(n.map(e=>null==e?i:e)),a=this.getUniqueValues(e),s=new Set(a.filter(e=>!l.has(e)));this.excludedValues.set(e,s)}else"set"===t.type&&this.excludedValues.delete(e);else this.excludedValues.delete(e)}attach(e){super.attach(e),this.injectGlobalStyles()}detach(){this.filters.clear(),this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,this.openPanelField=null,this.panelElement&&(this.panelElement.remove(),this.panelElement=null),this.searchText.clear(),this.excludedValues.clear(),this.panelAbortController?.abort(),this.panelAbortController=null}handleQuery(e){if("getContextMenuItems"===e.type){const t=e.context;if(!t.isHeader)return;const r=t.column;if(!r?.field)return;if(!this.isFilteringEnabled())return;if(!this.isColumnFilterable(r))return;const n=[],l=this.isFieldFiltered(r.field),i=this.filters.size>0;return l&&n.push({id:"filtering/clear-column-filter",label:"Clear Filter",icon:"✕",order:20,action:()=>this.clearFieldFilter(r.field)}),i&&n.push({id:"filtering/clear-all-filters",label:"Clear All Filters",icon:"✕",order:21,disabled:!i,action:()=>this.clearAllFilters()}),n.length>0?n:void 0}}processRows(e){if(!this.filters.size)return e;const t=[...this.filters.values()];if(this.config.filterHandler)return this.cachedResult?this.cachedResult:e;const r=(n=t,JSON.stringify(n.map(e=>({field:e.field,operator:e.operator,value:e.value,valueTo:e.valueTo}))));var n;const l={len:e.length,first:e[0],mid:e[Math.floor(e.length/2)],last:e[e.length-1]},i=null!=this.cachedInputSpot&&l.len===this.cachedInputSpot.len&&l.first===this.cachedInputSpot.first&&l.mid===this.cachedInputSpot.mid&&l.last===this.cachedInputSpot.last;if(this.cacheKey===r&&this.cachedResult&&i)return this.cachedResult;if(!i)for(const[s,o]of this.filters)"set"===o.type&&"in"===o.operator&&this.syncExcludedValues(s,o);const a=s(e,t,this.config.caseSensitive,this.getFilterValues());return this.cachedResult=a,this.cacheKey=r,this.cachedInputSpot=l,a}afterRender(){const e=this.gridElement;if(!e)return;e.querySelectorAll('[part~="header-cell"]').forEach(e=>{const t=e.getAttribute("data-col");if(null===t)return;const r=this.visibleColumns[parseInt(t,10)];if(!r||!this.isColumnFilterable(r))return;if(n.isUtilityColumn(r))return;const l=r.field;if(!l)return;const i=this.filters.has(l);let a=e.querySelector(".tbw-filter-btn");if(a){const t=a.classList.contains("active");if(a.classList.toggle("active",i),e.classList.toggle("filtered",i),i?e.setAttribute("aria-description","Filtered"):e.removeAttribute("aria-description"),t!==i){const e=i?"filterActive":"filter";this.setIcon(a,this.resolveIcon(e))}return}a=document.createElement("button"),a.className="tbw-filter-btn",a.setAttribute("aria-label",`Filter ${r.header??l}`);const s=i?"filterActive":"filter";this.setIcon(a,this.resolveIcon(s)),i&&(a.classList.add("active"),e.classList.add("filtered"),e.setAttribute("aria-description","Filtered")),a.addEventListener("click",e=>{e.stopPropagation(),this.toggleFilterPanel(l,r,a)});const o=e.querySelector(".resize-handle");o?e.insertBefore(a,o):e.appendChild(a)})}setFilter(e,r,n){if(null===r)this.filters.delete(e),this.syncExcludedValues(e,null);else{const t={...r,field:e};this.filters.set(e,t),this.syncExcludedValues(e,t)}if(this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,!n?.silent){this.emit("filter-change",{filters:[...this.filters.values()],filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.();const n=this.grid.effectiveConfig?.columns?.find(t=>t.field===e)?.header??e;t.announce(this.gridElement,null===r?`Filter cleared from ${n}`:`Filter applied on ${n}`)}this.emitPluginEvent("filter-applied",{filters:[...this.filters.values()]}),this.requestRender()}getFilter(e){return this.filters.get(e)}getFilters(){return[...this.filters.values()]}getFilterModel(){return this.getFilters()}setFilterModel(e,t){this.filters.clear(),this.excludedValues.clear();for(const r of e)this.filters.set(r.field,r),this.syncExcludedValues(r.field,r);this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,t?.silent||(this.emit("filter-change",{filters:[...this.filters.values()],filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:[...this.filters.values()]}),this.requestRender()}clearAllFilters(e){this.filters.clear(),this.excludedValues.clear(),this.searchText.clear(),this.applyFiltersInternal(e?.silent),e?.silent||t.announce(this.gridElement,"All filters cleared")}clearFieldFilter(e,r){if(this.filters.delete(e),this.excludedValues.delete(e),this.searchText.delete(e),this.applyFiltersInternal(r?.silent),!r?.silent){const r=this.grid.effectiveConfig?.columns?.find(t=>t.field===e)?.header??e;t.announce(this.gridElement,`Filter cleared from ${r}`)}}isFieldFiltered(e){return this.filters.has(e)}getFilteredRowCount(){return this.cachedResult?.length??this.rows.length}getActiveFilters(){return this.getFilters()}getUniqueValues(e){const t=this.grid.effectiveConfig?.columns?.find(t=>t.field===e),r=t?.filterValue;return o(this.sourceRows,e,r)}getStaleFilters(){const e=[];for(const[t,r]of this.filters){if("set"!==r.type)continue;const n=this.getUniqueValues(t);if("notIn"===r.operator&&Array.isArray(r.value)){const t=new Set(r.value);0===n.filter(e=>!t.has(e)).length&&e.push(r)}else if("in"===r.operator&&Array.isArray(r.value)){const t=new Set(r.value);0===n.filter(e=>t.has(e)).length&&e.push(r)}}return e}getBlankMode(e){const t=this.filters.get(e);return"blank"===t?.operator?"blanksOnly":"notBlank"===t?.operator?"nonBlanksOnly":"all"}toggleBlankFilter(e,t){if("all"===t){const t=this.filters.get(e);if(t?.valueTo&&"object"==typeof t.valueTo){const r=t.valueTo;this.setFilter(e,r)}else this.setFilter(e,null);return}const r=this.filters.get(e),n=r&&"blank"!==r.operator&&"notBlank"!==r.operator?{type:r.type,operator:r.operator,value:r.value,valueTo:r.valueTo}:r?.valueTo;this.setFilter(e,{type:r?.type??"text",operator:"blanksOnly"===t?"blank":"notBlank",value:"",valueTo:n})}copyGridThemeContext(e){const t=this.gridElement;if(!t)return;for(const n of t.classList)n.startsWith("tbw-")||"selecting"===n||e.classList.add(n);const r=t.dataset.theme;r&&(e.dataset.theme=r)}injectGlobalStyles(){if(this.globalStylesInjected)return;if(document.getElementById("tbw-filter-panel-styles"))return void(this.globalStylesInjected=!0);const e=document.createElement("style");e.id="tbw-filter-panel-styles",e.textContent="@layer tbw-plugins{.tbw-filter-panel{position:fixed;background:var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));color:var(--tbw-filter-panel-fg, var(--tbw-color-fg, light-dark(#222222, #eeeeee)));border:1px solid var(--tbw-filter-panel-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-panel-radius, var(--tbw-border-radius, .25rem));box-shadow:0 4px 16px var(--tbw-filter-panel-shadow, var(--tbw-color-shadow, light-dark(rgba(0, 0, 0, .1), rgba(0, 0, 0, .3))));padding:var(--tbw-panel-padding, var(--tbw-spacing-lg, .75rem));z-index:10000;min-width:200px;max-width:280px;max-height:350px;display:flex;flex-direction:column;font-family:var(--tbw-font-family, system-ui, sans-serif);font-size:var(--tbw-font-size, .8125rem);transform-origin:top center}.tbw-filter-panel.tbw-filter-panel-above{transform-origin:bottom center}.tbw-filter-panel.tbw-filter-panel-animated{animation:tbw-filter-panel-enter var(--tbw-animation-duration, .15s) var(--tbw-animation-easing, ease-out)}.tbw-filter-panel.tbw-filter-panel-above.tbw-filter-panel-animated{animation:tbw-filter-panel-enter-above var(--tbw-animation-duration, .15s) var(--tbw-animation-easing, ease-out)}@keyframes tbw-filter-panel-enter{0%{opacity:0;transform:scaleY(.3) translateY(-10px)}to{opacity:1;transform:scaleY(1) translateY(0)}}@keyframes tbw-filter-panel-enter-above{0%{opacity:0;transform:scaleY(.3) translateY(10px)}to{opacity:1;transform:scaleY(1) translateY(0)}}@supports (anchor-name: --test){.tbw-filter-panel{position-anchor:--tbw-filter-anchor;top:anchor(bottom);left:anchor(left);margin-top:4px;position-try-fallbacks:flip-inline,flip-block,flip-block flip-inline}}.tbw-filter-search{margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));min-height:var(--tbw-filter-item-height, 28px)}.tbw-filter-search-input{height:var(--tbw-filter-item-height, 28px);width:100%;padding:var(--tbw-filter-search-padding, var(--tbw-spacing-sm, .375rem) var(--tbw-spacing-md, .5rem));background:var(--tbw-filter-input-bg, var(--tbw-color-bg, transparent));color:inherit;border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-input-radius, var(--tbw-border-radius, .25rem));font-size:inherit;box-sizing:border-box}.tbw-filter-search-input:focus{outline:none;border-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));box-shadow:0 0 0 2px rgba(from var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6)) r g b / 15%)}.tbw-filter-actions{display:flex;padding:var(--tbw-button-padding-sm, .25rem .125rem);margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));border-bottom:1px solid var(--tbw-filter-divider, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));min-height:var(--tbw-filter-item-height, 28px)}.tbw-filter-actions .tbw-filter-value-item{flex:1}.tbw-filter-values{flex:1;overflow-y:auto;margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));max-height:180px;position:relative}.tbw-filter-values-spacer{width:1px}.tbw-filter-values-content{position:absolute;top:0;left:0;right:0}.tbw-filter-value-item{display:flex;align-items:center;gap:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));padding:var(--tbw-button-padding-sm, .25rem .125rem);cursor:pointer;border-radius:3px;height:var(--tbw-filter-item-height, 28px)}.tbw-filter-value-item:hover{background:var(--tbw-filter-hover, var(--tbw-color-row-hover, light-dark(#f0f6ff, #1c1c1c)))}.tbw-filter-checkbox{margin:0;cursor:pointer;accent-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6))}.tbw-filter-no-match{color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));padding:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem)) 0;text-align:center;font-style:italic}.tbw-filter-buttons{display:flex;gap:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));padding-top:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));border-top:1px solid var(--tbw-filter-divider, var(--tbw-color-border, light-dark(#d0d0d4, #454545)))}.tbw-filter-apply-btn{flex:1;padding:var(--tbw-filter-btn-padding, var(--tbw-button-padding, .375rem .75rem));background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));color:var(--tbw-filter-accent-fg, var(--tbw-color-accent-fg, light-dark(#ffffff, #000000)));border:none;border-radius:var(--tbw-border-radius, .25rem);cursor:pointer;font-size:var(--tbw-font-size-sm, .8125rem);font-weight:var(--tbw-filter-btn-font-weight, 500);min-height:var(--tbw-filter-btn-min-height, auto)}.tbw-filter-apply-btn:hover{filter:brightness(.9)}.tbw-filter-clear-btn{flex:1;padding:var(--tbw-filter-btn-padding, var(--tbw-button-padding, .375rem .75rem));background:transparent;color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-border-radius, .25rem);cursor:pointer;font-size:var(--tbw-font-size-sm, .8125rem);font-weight:var(--tbw-filter-btn-font-weight, 500);min-height:var(--tbw-filter-btn-min-height, auto)}.tbw-filter-clear-btn:hover{background:var(--tbw-filter-hover, var(--tbw-color-row-hover, light-dark(#f0f6ff, #1c1c1c)))}.tbw-filter-range-inputs,.tbw-filter-date-range{display:flex;align-items:flex-end;gap:var(--tbw-spacing-sm, .375rem);margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem))}.tbw-filter-range-group,.tbw-filter-date-group{display:flex;flex-direction:column;gap:var(--tbw-spacing-xs, .25rem);flex:1}.tbw-filter-range-label{font-size:var(--tbw-font-size-xs, .75rem);color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)))}.tbw-filter-range-input,.tbw-filter-date-input{width:100%;height:var(--tbw-filter-item-height, 28px);padding:var(--tbw-spacing-xs, .25rem) var(--tbw-spacing-sm, .375rem);background:var(--tbw-filter-input-bg, var(--tbw-color-bg, transparent));color:inherit;border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-input-radius, var(--tbw-border-radius, .25rem));font-size:inherit;box-sizing:border-box}.tbw-filter-range-input:focus,.tbw-filter-date-input:focus{outline:none;border-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));box-shadow:0 0 0 2px rgba(from var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6)) r g b / 15%)}.tbw-filter-range-separator{color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));padding-bottom:var(--tbw-spacing-xs, .25rem)}.tbw-filter-blank-option{display:flex;align-items:center;gap:var(--tbw-spacing-sm, .375rem);padding:var(--tbw-spacing-xs, .25rem) 0;margin-bottom:var(--tbw-spacing-xs, .25rem);font-size:var(--tbw-font-size-sm, .8125rem);cursor:pointer;-webkit-user-select:none;user-select:none}.tbw-filter-blank-checkbox{accent-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));margin:0;cursor:pointer}.tbw-filter-date-range.tbw-filter-disabled,.tbw-filter-range-inputs.tbw-filter-disabled,.tbw-filter-range-slider.tbw-filter-disabled{opacity:.4;pointer-events:none}.tbw-filter-range-slider{position:relative;height:24px;margin:var(--tbw-spacing-md, .5rem) 0 var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem))}.tbw-filter-range-track{position:absolute;top:50%;left:0;right:0;height:4px;background:var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:2px;transform:translateY(-50%)}.tbw-filter-range-fill{position:absolute;top:50%;height:4px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border-radius:2px;transform:translateY(-50%)}.tbw-filter-range-thumb{position:absolute;top:0;width:100%;height:100%;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}.tbw-filter-range-thumb::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border:2px solid var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 1px 3px #0003}.tbw-filter-range-thumb::-moz-range-thumb{width:16px;height:16px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border:2px solid var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 1px 3px #0003}.tbw-filter-range-thumb::-webkit-slider-thumb:hover{transform:scale(1.1)}.tbw-filter-range-thumb::-moz-range-thumb:hover{transform:scale(1.1)}}",document.head.appendChild(e),this.globalStylesInjected=!0}toggleFilterPanel(e,t,r){if(this.openPanelField===e)return void this.closeFilterPanel();this.closeFilterPanel();const n=document.createElement("div");if(n.className="tbw-filter-panel",this.copyGridThemeContext(n),this.isAnimationEnabled&&n.classList.add("tbw-filter-panel-animated"),this.panelElement=n,this.openPanelField=e,this.config.valuesHandler)return n.innerHTML='<div class="tbw-filter-loading">Loading...</div>',document.body.appendChild(n),this.positionPanel(n,r),this.setupPanelCloseHandler(n,r),void this.config.valuesHandler(e,t).then(r=>{this.openPanelField===e&&this.panelElement&&(n.innerHTML="",this.renderPanelContent(e,t,n,r))});const l=o(this.sourceRows,e,t.filterValue);document.body.appendChild(n),this.positionPanel(n,r),this.renderPanelContent(e,t,n,l),this.setupPanelCloseHandler(n,r)}renderPanelContent(e,t,r,n){const l=this.filters.get(e);if("in"===l?.operator&&"set"===l.type&&Array.isArray(l.value)&&!this.excludedValues.has(e)){const t=l.value,r=new Set(t.map(e=>null==e?i:e)),a=new Set(n.filter(e=>!r.has(e)));this.excludedValues.set(e,a)}let a=this.excludedValues.get(e);a||(a=new Set,this.excludedValues.set(e,a));const s=this.searchText.get(e)??"",o={field:e,column:t,uniqueValues:n,excludedValues:a,searchText:s,currentFilter:this.filters.get(e),applySetFilter:(t,r)=>{this.applySetFilter(e,t,r),this.closeFilterPanel()},applyTextFilter:(t,r,n)=>{this.applyTextFilter(e,t,r,n),this.closeFilterPanel()},clearFilter:()=>{this.clearFieldFilter(e),this.closeFilterPanel()},closePanel:()=>this.closeFilterPanel()};let f=!1;if(this.config.filterPanelRenderer&&(this.config.filterPanelRenderer(r,o),f=r.children.length>0),!f&&t.type){const e=this.grid.effectiveConfig.typeDefaults?.[t.type];e?.filterPanelRenderer&&(e.filterPanelRenderer(r,o),f=r.children.length>0)}if(!f){const e=t.type;"number"===e?function(e,t,r,n){const{field:l,column:i}=t,a=i.filterParams,s=i.editorParams,o=r.filter(e=>"number"==typeof e&&!isNaN(e)),c=o.length>0?Math.min(...o):0,d=o.length>0?Math.max(...o):100,u=p(a?.min??s?.min,c),f=p(a?.max??s?.max,d),h=a?.step??s?.step??1,b=n.get(l);let g=u,m=f;const v="blank"===b?.operator;"between"===b?.operator?(g=p(b.value,u),m=p(b.valueTo,f)):"greaterThanOrEqual"===b?.operator?g=p(b.value,u):"lessThanOrEqual"===b?.operator&&(m=p(b.value,f));const w=document.createElement("div");w.className="tbw-filter-range-inputs";const y=document.createElement("div");y.className="tbw-filter-range-group";const x=document.createElement("label");x.textContent="Min",x.className="tbw-filter-range-label";const C=document.createElement("input");C.type="number",C.className="tbw-filter-range-input",C.min=String(u),C.max=String(f),C.step=String(h),C.value=String(g),y.appendChild(x),y.appendChild(C),w.appendChild(y);const S=document.createElement("span");S.className="tbw-filter-range-separator",S.textContent="–",w.appendChild(S);const k=document.createElement("div");k.className="tbw-filter-range-group";const E=document.createElement("label");E.textContent="Max",E.className="tbw-filter-range-label";const F=document.createElement("input");F.type="number",F.className="tbw-filter-range-input",F.min=String(u),F.max=String(f),F.step=String(h),F.value=String(m),k.appendChild(E),k.appendChild(F),w.appendChild(k),e.appendChild(w);const T=document.createElement("div");T.className="tbw-filter-range-slider";const A=document.createElement("div");A.className="tbw-filter-range-track";const N=document.createElement("div");N.className="tbw-filter-range-fill";const P=document.createElement("input");P.type="range",P.className="tbw-filter-range-thumb tbw-filter-range-thumb-min",P.min=String(u),P.max=String(f),P.step=String(h),P.value=String(g);const L=document.createElement("input");L.type="range",L.className="tbw-filter-range-thumb tbw-filter-range-thumb-max",L.min=String(u),L.max=String(f),L.step=String(h),L.value=String(m),T.appendChild(A),T.appendChild(N),T.appendChild(P),T.appendChild(L),e.appendChild(T);const V=document.createElement("label");V.className="tbw-filter-blank-option";const I=document.createElement("input");I.type="checkbox",I.className="tbw-filter-blank-checkbox",I.checked=v;const R=document.createTextNode("Blank");V.appendChild(I),V.appendChild(R);const q=e=>{C.disabled=e,F.disabled=e,P.disabled=e,L.disabled=e,w.classList.toggle("tbw-filter-disabled",e),T.classList.toggle("tbw-filter-disabled",e)};q(v),I.addEventListener("change",()=>{q(I.checked)}),e.appendChild(V);const M=()=>{const e=parseFloat(P.value),t=parseFloat(L.value),r=f-u,n=(e-u)/r*100,l=(t-u)/r*100;N.style.left=`${n}%`,N.style.width=l-n+"%"};P.addEventListener("input",()=>{const e=Math.min(parseFloat(P.value),parseFloat(L.value));P.value=String(e),C.value=String(e),M()}),L.addEventListener("input",()=>{const e=Math.max(parseFloat(L.value),parseFloat(P.value));L.value=String(e),F.value=String(e),M()}),C.addEventListener("input",()=>{let e=parseFloat(C.value)||u;e=Math.max(u,Math.min(e,parseFloat(F.value))),P.value=String(e),M()}),F.addEventListener("input",()=>{let e=parseFloat(F.value)||f;e=Math.min(f,Math.max(e,parseFloat(C.value))),L.value=String(e),M()}),M();const z=document.createElement("div");z.className="tbw-filter-buttons";const B=document.createElement("button");B.className="tbw-filter-apply-btn",B.textContent="Apply",B.addEventListener("click",()=>{if(I.checked)return void t.applyTextFilter("blank","");const e=parseFloat(C.value),r=parseFloat(F.value);t.applyTextFilter("between",e,r)}),z.appendChild(B);const _=document.createElement("button");_.className="tbw-filter-clear-btn",_.textContent="Clear Filter",_.addEventListener("click",()=>{t.clearFilter()}),z.appendChild(_),e.appendChild(z)}(r,o,n,this.filters):"date"===e?function(e,t,r,n){const{field:l,column:i}=t,a=i.filterParams,s=i.editorParams,o=r.filter(e=>e instanceof Date||"string"==typeof e&&!isNaN(Date.parse(e))).map(e=>e instanceof Date?e:new Date(e)).filter(e=>!isNaN(e.getTime())),u=o.length>0?new Date(Math.min(...o.map(e=>e.getTime()))):null,p=o.length>0?new Date(Math.max(...o.map(e=>e.getTime()))):null,f=d(a?.min)||d(s?.min)||c(u),h=d(a?.max)||d(s?.max)||c(p),b=n.get(l);let g="",m="";const v="blank"===b?.operator;"between"===b?.operator?(g=d(b.value)||"",m=d(b.valueTo)||""):"greaterThanOrEqual"===b?.operator?g=d(b.value)||"":"lessThanOrEqual"===b?.operator&&(m=d(b.value)||"");const w=document.createElement("div");w.className="tbw-filter-date-range";const y=document.createElement("div");y.className="tbw-filter-date-group";const x=document.createElement("label");x.textContent="From",x.className="tbw-filter-range-label";const C=document.createElement("input");C.type="date",C.className="tbw-filter-date-input",f&&(C.min=f),h&&(C.max=h),C.value=g,y.appendChild(x),y.appendChild(C),w.appendChild(y);const S=document.createElement("span");S.className="tbw-filter-range-separator",S.textContent="–",w.appendChild(S);const k=document.createElement("div");k.className="tbw-filter-date-group";const E=document.createElement("label");E.textContent="To",E.className="tbw-filter-range-label";const F=document.createElement("input");F.type="date",F.className="tbw-filter-date-input",f&&(F.min=f),h&&(F.max=h),F.value=m,k.appendChild(E),k.appendChild(F),w.appendChild(k),e.appendChild(w);const T=document.createElement("label");T.className="tbw-filter-blank-option";const A=document.createElement("input");A.type="checkbox",A.className="tbw-filter-blank-checkbox",A.checked=v;const N=document.createTextNode("Show only blank");T.appendChild(A),T.appendChild(N);const P=e=>{C.disabled=e,F.disabled=e,w.classList.toggle("tbw-filter-disabled",e)};P(v),A.addEventListener("change",()=>{P(A.checked)}),e.appendChild(T);const L=document.createElement("div");L.className="tbw-filter-buttons";const V=document.createElement("button");V.className="tbw-filter-apply-btn",V.textContent="Apply",V.addEventListener("click",()=>{if(A.checked)return void t.applyTextFilter("blank","");const e=C.value,r=F.value;e&&r?t.applyTextFilter("between",e,r):e?t.applyTextFilter("greaterThanOrEqual",e):r?t.applyTextFilter("lessThanOrEqual",r):t.clearFilter()}),L.appendChild(V);const I=document.createElement("button");I.className="tbw-filter-clear-btn",I.textContent="Clear Filter",I.addEventListener("click",()=>{t.clearFilter()}),L.appendChild(I),e.appendChild(L)}(r,o,n,this.filters):u(r,o,n,a,{caseSensitive:this.config.caseSensitive,debounceMs:this.config.debounceMs},this.searchText)}}setupPanelCloseHandler(e,t){this.panelAbortController=new AbortController,setTimeout(()=>{document.addEventListener("click",r=>{e.contains(r.target)||r.target===t||this.closeFilterPanel()},{signal:this.panelAbortController?.signal})},0)}closeFilterPanel(){const e=this.panelElement;e&&(e.remove(),this.panelElement=null),this.panelAnchorElement&&(this.panelAnchorElement.style.anchorName="",this.panelAnchorElement=null),this.openPanelField=null,this.panelAbortController?.abort(),this.panelAbortController=null}static supportsAnchorPositioning=null;static checkAnchorPositioningSupport(){return null===f.supportsAnchorPositioning&&(f.supportsAnchorPositioning=CSS.supports("anchor-name","--test")),f.supportsAnchorPositioning}positionPanel(e,t){const r=t.closest(".cell")??t;if(r.style.anchorName="--tbw-filter-anchor",this.panelAnchorElement=r,f.checkAnchorPositioningSupport())return void requestAnimationFrame(()=>{const t=e.getBoundingClientRect(),n=r.getBoundingClientRect();t.top<n.top&&e.classList.add("tbw-filter-panel-above")});const n=r.getBoundingClientRect();e.style.position="fixed",e.style.top=`${n.bottom+4}px`,e.style.left=`${n.left}px`,requestAnimationFrame(()=>{const t=e.getBoundingClientRect();t.right>window.innerWidth-8&&(e.style.left=n.right-t.width+"px"),t.bottom>window.innerHeight-8&&(e.style.top=n.top-t.height-4+"px",e.classList.add("tbw-filter-panel-above"))})}applySetFilter(e,t,r){if(this.excludedValues.set(e,new Set(t)),0===t.length)this.filters.delete(e);else{const n=this.filters.get(e);if("in"===n?.operator){const n=this.getUniqueValues(e),l=new Set(t),i=n.filter(e=>!l.has(e));this.filters.set(e,{field:e,type:"set",operator:"in",value:i,...void 0!==r&&{valueTo:r}})}else this.filters.set(e,{field:e,type:"set",operator:"notIn",value:t,...void 0!==r&&{valueTo:r}})}this.applyFiltersInternal()}applyTextFilter(e,t,r,n){this.filters.set(e,{field:e,type:"text",operator:t,value:r,valueTo:n}),this.applyFiltersInternal()}applyFiltersInternal(e){this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null;const t=[...this.filters.values()];if(this.config.filterHandler){this.gridElement.setAttribute("aria-busy","true");const r=this.config.filterHandler(t,this.sourceRows),n=r=>{this.gridElement.removeAttribute("aria-busy"),this.cachedResult=r,this.grid.rows=r,e||(this.emit("filter-change",{filters:t,filteredRowCount:r.length,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:t}),this.requestRender()};return void(r&&"function"==typeof r.then?r.then(n):n(r))}e||(this.emit("filter-change",{filters:t,filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:t}),this.requestRender()}getColumnState(e){if(!this.config.trackColumnState)return;const t=this.filters.get(e);return t?{filter:{type:t.type,operator:t.operator,value:t.value,valueTo:t.valueTo}}:void 0}applyColumnState(e,t){if(!this.config.trackColumnState)return;if(!t.filter)return void this.filters.delete(e);const r={field:e,type:t.filter.type,operator:t.filter.operator,value:t.filter.value,valueTo:t.filter.valueTo};this.filters.set(e,r),this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null}}e.BLANK_FILTER_VALUE=i,e.FilteringPlugin=f,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
|
|
1
|
+
!function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("../../core/internal/aria"),require("../../core/plugin/base-plugin"),require("../../core/plugin/expander-column"),require("../../core/internal/virtualization")):"function"==typeof define&&define.amd?define(["exports","../../core/internal/aria","../../core/plugin/base-plugin","../../core/plugin/expander-column","../../core/internal/virtualization"],t):t((e="undefined"!=typeof globalThis?globalThis:e||self).TbwGridPlugin_filtering={},e.TbwGrid,e.TbwGrid,e.TbwGrid,e.TbwGrid)}(this,function(e,t,r,n,l){"use strict";const i="(Blank)";function a(e){if("number"==typeof e)return e;if(e instanceof Date)return e.getTime();const t=Number(e);if(!isNaN(t))return t;return new Date(e).getTime()}function s(e,t,r=!1,n){if(!t.length)return e;const l=t.map(e=>function(e,t,r){const n=e.field,l=e.operator;if("blank"===l)return e=>{const t=e[n];return null==t||""===t};if("notBlank"===l)return e=>{const t=e[n];return null!=t&&""!==t};if(r&&("notIn"===l||"in"===l)){const t=e.value;if("notIn"===l){if(!Array.isArray(t))return()=>!0;const e=new Set(t);return t=>{const l=r(t[n],t),a=Array.isArray(l)?l:null!=l?[l]:[];return 0===a.length?!e.has(i):!a.some(t=>e.has(t))}}if(!Array.isArray(t))return()=>!1;const a=new Set(t);return e=>{const t=r(e[n],e),l=Array.isArray(t)?t:null!=t?[t]:[];return 0===l.length?a.has(i):l.some(e=>a.has(e))}}if("notIn"===l){if(!Array.isArray(e.value))return()=>!0;const t=new Set(e.value);return e=>{const r=e[n];return null==r||""===r?!t.has(i):!t.has(r)}}if("in"===l){if(!Array.isArray(e.value))return()=>!1;const t=new Set(e.value);return e=>{const r=e[n];return null==r||""===r?t.has(i):t.has(r)}}const s="number"===e.type;if("greaterThan"===l){const t=a(e.value);return s?e=>e[n]>t:e=>{const r=e[n];return null!=r&&a(r)>t}}if("greaterThanOrEqual"===l){const t=a(e.value);return s?e=>e[n]>=t:e=>{const r=e[n];return null!=r&&a(r)>=t}}if("lessThan"===l){const t=a(e.value);return s?e=>e[n]<t:e=>{const r=e[n];return null!=r&&a(r)<t}}if("lessThanOrEqual"===l){const t=a(e.value);return s?e=>e[n]<=t:e=>{const r=e[n];return null!=r&&a(r)<=t}}if("between"===l){const t=a(e.value),r=a(e.valueTo);return s?e=>{const l=e[n];return l>=t&&l<=r}:e=>{const l=e[n];if(null==l)return!1;const i=a(l);return i>=t&&i<=r}}const o=t?String(e.value):String(e.value).toLowerCase();return"contains"===l?t?e=>{const t=e[n];return null!=t&&String(t).includes(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().includes(o)}:"notContains"===l?t?e=>{const t=e[n];return null!=t&&!String(t).includes(o)}:e=>{const t=e[n];return null!=t&&!String(t).toLowerCase().includes(o)}:"equals"===l?t?e=>{const t=e[n];return null!=t&&String(t)===o}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase()===o}:"notEquals"===l?t?e=>{const t=e[n];return null!=t&&String(t)!==o}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase()!==o}:"startsWith"===l?t?e=>{const t=e[n];return null!=t&&String(t).startsWith(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().startsWith(o)}:"endsWith"===l?t?e=>{const t=e[n];return null!=t&&String(t).endsWith(o)}:e=>{const t=e[n];return null!=t&&String(t).toLowerCase().endsWith(o)}:()=>!0}(e,r,n?.get(e.field)));return 1===l.length?e.filter(l[0]):e.filter(e=>{for(let t=0;t<l.length;t++)if(!l[t](e))return!1;return!0})}function o(e,t,r){const n=new Set;let l=!1;for(const i of e){const e=i[t];if(r){const t=r(e,i);if(Array.isArray(t)){0===t.length&&(l=!0);for(const e of t)null!=e&&n.add(e)}else null!=t?n.add(t):l=!0}else null!=e&&""!==e?n.add(e):l=!0}return l&&n.add(i),[...n].sort((e,t)=>"number"==typeof e&&"number"==typeof t?e-t:String(e).localeCompare(String(t)))}function c(e){return e?e.toISOString().split("T")[0]:""}function d(e){return e?"string"==typeof e?e:"number"==typeof e?c(new Date(e)):"":""}function u(e,t,r,n,i,a){const{field:s,column:o}=t,c=function(e){if(e){const t=getComputedStyle(e).getPropertyValue("--tbw-filter-item-height");if(t&&t.trim()){const e=parseFloat(t);if(!isNaN(e)&&e>0)return e}}return 28}(e),d=e=>{if(null==e)return"(Blank)";if(o.format&&!o.filterValue){const t=o.format(e,void 0);if(t)return t}return String(e)};r=r.slice().sort((e,t)=>d(e).localeCompare(d(t)));const u=document.createElement("div");u.className="tbw-filter-search";const p=document.createElement("input");p.type="text",p.placeholder="Search...",p.className="tbw-filter-search-input",p.value=a.get(s)??"",u.appendChild(p),e.appendChild(u);const f=document.createElement("div");f.className="tbw-filter-actions";const h=document.createElement("label");h.className="tbw-filter-value-item",h.style.padding="0",h.style.margin="0";const b=document.createElement("input");b.type="checkbox",b.className="tbw-filter-checkbox";const g=document.createElement("span");g.textContent="Select All",h.appendChild(b),h.appendChild(g),f.appendChild(h);const m=new Map;r.forEach(e=>{const t=null==e?"__null__":String(e);m.set(t,!n.has(e))});const v=()=>{const e=[...m.values()],t=e.every(e=>e),r=e.every(e=>!e);b.checked=t,b.indeterminate=!t&&!r};b.addEventListener("change",()=>{const e=b.checked;for(const t of m.keys())m.set(t,e);v(),k()}),v(),e.appendChild(f);const w=document.createElement("div");w.className="tbw-filter-values";const y=document.createElement("div");y.className="tbw-filter-values-spacer",w.appendChild(y);const x=document.createElement("div");x.className="tbw-filter-values-content",w.appendChild(x);let C=[];const S=(e,t)=>{const r=d(e),n=null==e?"__null__":String(e),l=document.createElement("label");l.className="tbw-filter-value-item",l.style.position="absolute",l.style.top=`calc(var(--tbw-filter-item-height, 28px) * ${t})`,l.style.left="0",l.style.right="0",l.style.boxSizing="border-box";const i=document.createElement("input");i.type="checkbox",i.className="tbw-filter-checkbox",i.checked=m.get(n)??!0,i.dataset.value=n,i.addEventListener("change",()=>{m.set(n,i.checked),v()});const a=document.createElement("span");return a.textContent=r,l.appendChild(i),l.appendChild(a),l},k=()=>{const e=C.length,t=w.clientHeight,r=w.scrollTop;if(y.style.height=e*c+"px",l.shouldBypassVirtualization(e,50/3))return x.innerHTML="",x.style.transform="translateY(0px)",void C.forEach((e,t)=>{x.appendChild(S(e,t))});const n=l.computeVirtualWindow({totalRows:e,viewportHeight:t,scrollTop:r,rowHeight:c,overscan:3});x.style.transform=`translateY(${n.offsetY}px)`,x.innerHTML="";for(let l=n.start;l<n.end;l++)x.appendChild(S(C[l],l-n.start))},E=e=>{const t=i.caseSensitive??!1,n=t?e:e.toLowerCase();if(C=r.filter(r=>{const l=d(r),i=t?l:l.toLowerCase();return!e||i.includes(n)}),C.sort((e,t)=>{const r=null==e?"__null__":String(e),n=null==t?"__null__":String(t),l=m.get(r)??!0;return l!==(m.get(n)??!0)?l?-1:1:d(e).localeCompare(d(t))}),0===C.length){y.style.height="0px",x.innerHTML="";const e=document.createElement("div");return e.className="tbw-filter-no-match",e.textContent="No matching values",void x.appendChild(e)}k()};let F;w.addEventListener("scroll",()=>{C.length>0&&k()},{passive:!0}),E(p.value),e.appendChild(w),p.addEventListener("input",()=>{clearTimeout(F),F=setTimeout(()=>{a.set(s,p.value),E(p.value)},i.debounceMs??150)});const T=document.createElement("div");T.className="tbw-filter-buttons";const A=document.createElement("button");A.className="tbw-filter-apply-btn",A.textContent="Apply",A.addEventListener("click",()=>{const e=[];for(const[t,n]of m)if(!n)if("__null__"===t)e.push(null);else{const n=r.find(e=>String(e)===t);e.push(void 0!==n?n:t)}t.applySetFilter(e)}),T.appendChild(A);const N=document.createElement("button");N.className="tbw-filter-clear-btn",N.textContent="Clear Filter",N.addEventListener("click",()=>{t.clearFilter()}),T.appendChild(N),e.appendChild(T)}function p(e,t){if("number"==typeof e)return e;if("string"==typeof e){const r=parseFloat(e);return isNaN(r)?t:r}return t}class f extends r.BaseGridPlugin{static manifest={events:[{type:"filter-applied",description:"Emitted when filter criteria change. Subscribers can react to row visibility changes."}],queries:[{type:"getContextMenuItems",description:"Contributes filter-related items to the header context menu"}]};name="filtering";styles='@layer tbw-plugins{tbw-grid .tbw-quick-filter-input{flex:1;max-width:300px;height:var(--tbw-input-height, 1.75rem);padding:var(--tbw-input-padding, 0 .5rem);border:1px solid var(--tbw-color-border);border-radius:var(--tbw-border-radius);background:var(--tbw-color-bg);color:var(--tbw-color-fg);font-size:var(--tbw-font-size-sm, .8125rem)}tbw-grid .tbw-quick-filter-input:focus{outline:none;border-color:var(--tbw-color-accent)}tbw-grid .header-cell.filtered:before{content:"";position:absolute;top:var(--tbw-spacing-xs, .25rem);right:var(--tbw-spacing-xs, .25rem);width:var(--tbw-indicator-size, .375rem);height:var(--tbw-indicator-size, .375rem);background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border-radius:50%}tbw-grid .tbw-filter-btn{display:var(--tbw-filter-btn-display, inline-flex);visibility:var(--tbw-filter-btn-visibility, visible);align-items:center;justify-content:center;background:transparent;border:none;cursor:pointer;padding:2px;margin-left:var(--tbw-spacing-xs, .25rem);opacity:.4;transition:opacity .15s,visibility 0s,display 0s allow-discrete;color:inherit;vertical-align:middle;transition-behavior:allow-discrete}tbw-grid .tbw-filter-btn:hover,tbw-grid .tbw-filter-btn.active{opacity:1;visibility:visible;display:inline-flex}tbw-grid .tbw-filter-btn.active{color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6))}tbw-grid .header-row .cell:hover .tbw-filter-btn,tbw-grid .header-row .cell.filtered .tbw-filter-btn{display:inline-flex;visibility:visible}}';get defaultConfig(){return{debounceMs:300,caseSensitive:!1,trimInput:!0,useWorker:!0}}isFilteringEnabled(){return!1!==this.grid.effectiveConfig?.filterable}isColumnFilterable(e){return!!this.isFilteringEnabled()&&!1!==e.filterable}getFilterValues(){const e=this.grid.effectiveConfig?.columns;if(!e)return;let t;for(const r of e)r.field&&r.filterValue&&(t||(t=new Map),t.set(r.field,r.filterValue));return t}filters=new Map;cachedResult=null;cacheKey=null;cachedInputSpot=null;openPanelField=null;panelElement=null;panelAnchorElement=null;searchText=new Map;excludedValues=new Map;panelAbortController=null;globalStylesInjected=!1;computeSelected(){const e={},t=[];for(const[r,n]of this.filters)if("set"===n.type)if("in"===n.operator&&Array.isArray(n.value))e[r]=n.value;else if("notIn"===n.operator){const e=this.grid.effectiveConfig?.columns?.find(e=>e.field===r);t.push({field:r,filterValue:e?.filterValue})}if(t.length>0){const r=function(e,t){const r=new Map;for(const{field:l,filterValue:i}of t)r.set(l,{values:new Set,hasBlank:!1,hasExtractor:!!i});for(const l of e)for(const{field:e,filterValue:n}of t){const t=r.get(e),i=l[e];if(n){const e=n(i,l);if(Array.isArray(e)){0===e.length&&(t.hasBlank=!0);for(const r of e)null!=r&&t.values.add(r)}else null!=e?t.values.add(e):t.hasBlank=!0}else null!=i&&""!==i?t.values.add(i):t.hasBlank=!0}const n=new Map;for(const[l,{values:a,hasBlank:s}]of r)s&&a.add(i),n.set(l,[...a].sort((e,t)=>"number"==typeof e&&"number"==typeof t?e-t:String(e).localeCompare(String(t))));return n}(this.sourceRows,t);for(const{field:n}of t){const t=this.excludedValues.get(n),l=r.get(n)??[];e[n]=t?l.filter(e=>!t.has(e)):l}}return e}syncExcludedValues(e,t){if(t)if("set"===t.type&&"notIn"===t.operator&&Array.isArray(t.value))this.excludedValues.set(e,new Set(t.value));else if("set"===t.type&&"in"===t.operator&&Array.isArray(t.value)){const r=this.sourceRows;if(!r||0===r.length)return void this.excludedValues.delete(e);const n=t.value,l=new Set(n.map(e=>null==e?i:e)),a=this.getUniqueValues(e),s=new Set(a.filter(e=>!l.has(e)));this.excludedValues.set(e,s)}else"set"===t.type&&this.excludedValues.delete(e);else this.excludedValues.delete(e)}attach(e){super.attach(e),this.injectGlobalStyles()}detach(){this.filters.clear(),this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,this.openPanelField=null,this.panelElement&&(this.panelElement.remove(),this.panelElement=null),this.searchText.clear(),this.excludedValues.clear(),this.panelAbortController?.abort(),this.panelAbortController=null}handleQuery(e){if("getContextMenuItems"===e.type){const t=e.context;if(!t.isHeader)return;const r=t.column;if(!r?.field)return;if(!this.isFilteringEnabled())return;if(!this.isColumnFilterable(r))return;const n=[],l=this.isFieldFiltered(r.field),i=this.filters.size>0;return l&&n.push({id:"filtering/clear-column-filter",label:"Clear Filter",icon:"✕",order:20,action:()=>this.clearFieldFilter(r.field)}),i&&n.push({id:"filtering/clear-all-filters",label:"Clear All Filters",icon:"✕",order:21,disabled:!i,action:()=>this.clearAllFilters()}),n.length>0?n:void 0}}processRows(e){if(!this.filters.size)return e;const t=[...this.filters.values()];if(this.config.filterHandler)return this.cachedResult?this.cachedResult:e;const r=(n=t,JSON.stringify(n.map(e=>({field:e.field,operator:e.operator,value:e.value,valueTo:e.valueTo}))));var n;const l={len:e.length,first:e[0],mid:e[Math.floor(e.length/2)],last:e[e.length-1]},i=null!=this.cachedInputSpot&&l.len===this.cachedInputSpot.len&&l.first===this.cachedInputSpot.first&&l.mid===this.cachedInputSpot.mid&&l.last===this.cachedInputSpot.last;if(this.cacheKey===r&&this.cachedResult&&i)return this.cachedResult;if(!i)for(const[s,o]of this.filters)"set"===o.type&&"in"===o.operator&&this.syncExcludedValues(s,o);const a=s(e,t,this.config.caseSensitive,this.getFilterValues());return this.cachedResult=a,this.cacheKey=r,this.cachedInputSpot=l,a}afterRender(){const e=this.gridElement;if(!e)return;e.querySelectorAll('[part~="header-cell"]').forEach(e=>{const t=e.getAttribute("data-col");if(null===t)return;const r=this.visibleColumns[parseInt(t,10)];if(!r||!this.isColumnFilterable(r))return;if(n.isUtilityColumn(r))return;const l=r.field;if(!l)return;const i=this.filters.has(l);let a=e.querySelector(".tbw-filter-btn");if(a){const t=a.classList.contains("active");if(a.classList.toggle("active",i),e.classList.toggle("filtered",i),i?e.setAttribute("aria-description","Filtered"):e.removeAttribute("aria-description"),t!==i){const e=i?"filterActive":"filter";this.setIcon(a,this.resolveIcon(e))}return}a=document.createElement("button"),a.className="tbw-filter-btn",a.setAttribute("aria-label",`Filter ${r.header??l}`);const s=i?"filterActive":"filter";this.setIcon(a,this.resolveIcon(s)),i&&(a.classList.add("active"),e.classList.add("filtered"),e.setAttribute("aria-description","Filtered")),a.addEventListener("click",e=>{e.stopPropagation(),this.toggleFilterPanel(l,r,a)});const o=e.querySelector(".resize-handle");o?e.insertBefore(a,o):e.appendChild(a)})}setFilter(e,r,n){if(null===r)this.filters.delete(e),this.syncExcludedValues(e,null);else{const t={...r,field:e};this.filters.set(e,t),this.syncExcludedValues(e,t)}if(this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,!n?.silent){this.emit("filter-change",{filters:[...this.filters.values()],filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.();const n=this.grid.effectiveConfig?.columns?.find(t=>t.field===e)?.header??e;t.announce(this.gridElement,null===r?`Filter cleared from ${n}`:`Filter applied on ${n}`)}this.emitPluginEvent("filter-applied",{filters:[...this.filters.values()]}),this.requestRender()}getFilter(e){return this.filters.get(e)}getFilters(){return[...this.filters.values()]}getFilterModel(){return this.getFilters()}setFilterModel(e,t){this.filters.clear(),this.excludedValues.clear();for(const r of e)this.filters.set(r.field,r),this.syncExcludedValues(r.field,r);this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null,t?.silent||(this.emit("filter-change",{filters:[...this.filters.values()],filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:[...this.filters.values()]}),this.requestRender()}clearAllFilters(e){this.filters.clear(),this.excludedValues.clear(),this.searchText.clear(),this.applyFiltersInternal(e?.silent),e?.silent||t.announce(this.gridElement,"All filters cleared")}clearFieldFilter(e,r){if(this.filters.delete(e),this.excludedValues.delete(e),this.searchText.delete(e),this.applyFiltersInternal(r?.silent),!r?.silent){const r=this.grid.effectiveConfig?.columns?.find(t=>t.field===e)?.header??e;t.announce(this.gridElement,`Filter cleared from ${r}`)}}isFieldFiltered(e){return this.filters.has(e)}getFilteredRowCount(){return this.cachedResult?.length??this.rows.length}getActiveFilters(){return this.getFilters()}getUniqueValues(e){const t=this.grid.effectiveConfig?.columns?.find(t=>t.field===e),r=t?.filterValue;return o(this.sourceRows,e,r)}getStaleFilters(){const e=[];for(const[t,r]of this.filters){if("set"!==r.type)continue;const n=this.getUniqueValues(t);if("notIn"===r.operator&&Array.isArray(r.value)){const t=new Set(r.value);0===n.filter(e=>!t.has(e)).length&&e.push(r)}else if("in"===r.operator&&Array.isArray(r.value)){const t=new Set(r.value);0===n.filter(e=>t.has(e)).length&&e.push(r)}}return e}getBlankMode(e){const t=this.filters.get(e);return"blank"===t?.operator?"blanksOnly":"notBlank"===t?.operator?"nonBlanksOnly":"all"}toggleBlankFilter(e,t){if("all"===t){const t=this.filters.get(e);if(t?.valueTo&&"object"==typeof t.valueTo){const r=t.valueTo;this.setFilter(e,r)}else this.setFilter(e,null);return}const r=this.filters.get(e),n=r&&"blank"!==r.operator&&"notBlank"!==r.operator?{type:r.type,operator:r.operator,value:r.value,valueTo:r.valueTo}:r?.valueTo;this.setFilter(e,{type:r?.type??"text",operator:"blanksOnly"===t?"blank":"notBlank",value:"",valueTo:n})}copyGridThemeContext(e){const t=this.gridElement;if(!t)return;for(const n of t.classList)n.startsWith("tbw-")||"selecting"===n||e.classList.add(n);const r=t.dataset.theme;r&&(e.dataset.theme=r)}injectGlobalStyles(){if(this.globalStylesInjected)return;if(document.getElementById("tbw-filter-panel-styles"))return void(this.globalStylesInjected=!0);const e=document.createElement("style");e.id="tbw-filter-panel-styles",e.textContent="@layer tbw-plugins{.tbw-filter-panel{position:fixed;background:var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));color:var(--tbw-filter-panel-fg, var(--tbw-color-fg, light-dark(#222222, #eeeeee)));border:1px solid var(--tbw-filter-panel-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-panel-radius, var(--tbw-border-radius, .25rem));box-shadow:0 4px 16px var(--tbw-filter-panel-shadow, var(--tbw-color-shadow, light-dark(rgba(0, 0, 0, .1), rgba(0, 0, 0, .3))));padding:var(--tbw-panel-padding, var(--tbw-spacing-lg, .75rem));z-index:10000;min-width:200px;max-width:280px;max-height:350px;display:flex;flex-direction:column;font-family:var(--tbw-font-family, system-ui, sans-serif);font-size:var(--tbw-font-size, .8125rem);transform-origin:top center}.tbw-filter-panel.tbw-filter-panel-above{transform-origin:bottom center}.tbw-filter-panel.tbw-filter-panel-animated{animation:tbw-filter-panel-enter var(--tbw-animation-duration, .15s) var(--tbw-animation-easing, ease-out)}.tbw-filter-panel.tbw-filter-panel-above.tbw-filter-panel-animated{animation:tbw-filter-panel-enter-above var(--tbw-animation-duration, .15s) var(--tbw-animation-easing, ease-out)}@keyframes tbw-filter-panel-enter{0%{opacity:0;transform:scaleY(.3) translateY(-10px)}to{opacity:1;transform:scaleY(1) translateY(0)}}@keyframes tbw-filter-panel-enter-above{0%{opacity:0;transform:scaleY(.3) translateY(10px)}to{opacity:1;transform:scaleY(1) translateY(0)}}@supports (anchor-name: --test){.tbw-filter-panel{position-anchor:--tbw-filter-anchor;top:anchor(bottom);left:anchor(left);margin-top:4px;position-try-fallbacks:flip-inline,flip-block,flip-block flip-inline}}.tbw-filter-search{margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));min-height:var(--tbw-filter-item-height, 28px)}.tbw-filter-search-input{height:var(--tbw-filter-item-height, 28px);width:100%;padding:var(--tbw-filter-search-padding, var(--tbw-spacing-sm, .375rem) var(--tbw-spacing-md, .5rem));background:var(--tbw-filter-input-bg, var(--tbw-color-bg, transparent));color:inherit;border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-input-radius, var(--tbw-border-radius, .25rem));font-size:inherit;box-sizing:border-box}.tbw-filter-search-input:focus{outline:none;border-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));box-shadow:0 0 0 2px rgba(from var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6)) r g b / 15%)}.tbw-filter-actions{display:flex;padding:var(--tbw-button-padding-sm, .25rem .125rem);margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));border-bottom:1px solid var(--tbw-filter-divider, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));min-height:var(--tbw-filter-item-height, 28px)}.tbw-filter-actions .tbw-filter-value-item{flex:1}.tbw-filter-values{flex:1;overflow-y:auto;margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));max-height:180px;position:relative}.tbw-filter-values-spacer{width:1px}.tbw-filter-values-content{position:absolute;top:0;left:0;right:0}.tbw-filter-value-item{display:flex;align-items:center;gap:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));padding:var(--tbw-button-padding-sm, .25rem .125rem);cursor:pointer;border-radius:3px;height:var(--tbw-filter-item-height, 28px)}.tbw-filter-value-item:hover{background:var(--tbw-filter-hover, var(--tbw-color-row-hover, light-dark(#f0f6ff, #1c1c1c)))}.tbw-filter-checkbox{margin:0;cursor:pointer;accent-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6))}.tbw-filter-no-match{color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));padding:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem)) 0;text-align:center;font-style:italic}.tbw-filter-buttons{display:flex;gap:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));padding-top:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem));border-top:1px solid var(--tbw-filter-divider, var(--tbw-color-border, light-dark(#d0d0d4, #454545)))}.tbw-filter-apply-btn{flex:1;padding:var(--tbw-filter-btn-padding, var(--tbw-button-padding, .375rem .75rem));background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));color:var(--tbw-filter-accent-fg, var(--tbw-color-accent-fg, light-dark(#ffffff, #000000)));border:none;border-radius:var(--tbw-border-radius, .25rem);cursor:pointer;font-size:var(--tbw-font-size-sm, .8125rem);font-weight:var(--tbw-filter-btn-font-weight, 500);min-height:var(--tbw-filter-btn-min-height, auto)}.tbw-filter-apply-btn:hover{filter:brightness(.9)}.tbw-filter-clear-btn{flex:1;padding:var(--tbw-filter-btn-padding, var(--tbw-button-padding, .375rem .75rem));background:transparent;color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-border-radius, .25rem);cursor:pointer;font-size:var(--tbw-font-size-sm, .8125rem);font-weight:var(--tbw-filter-btn-font-weight, 500);min-height:var(--tbw-filter-btn-min-height, auto)}.tbw-filter-clear-btn:hover{background:var(--tbw-filter-hover, var(--tbw-color-row-hover, light-dark(#f0f6ff, #1c1c1c)))}.tbw-filter-range-inputs,.tbw-filter-date-range{display:flex;align-items:flex-end;gap:var(--tbw-spacing-sm, .375rem);margin-bottom:var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem))}.tbw-filter-range-group,.tbw-filter-date-group{display:flex;flex-direction:column;gap:var(--tbw-spacing-xs, .25rem);flex:1}.tbw-filter-range-label{font-size:var(--tbw-font-size-xs, .75rem);color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)))}.tbw-filter-range-input,.tbw-filter-date-input{width:100%;height:var(--tbw-filter-item-height, 28px);padding:var(--tbw-spacing-xs, .25rem) var(--tbw-spacing-sm, .375rem);background:var(--tbw-filter-input-bg, var(--tbw-color-bg, transparent));color:inherit;border:1px solid var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:var(--tbw-filter-input-radius, var(--tbw-border-radius, .25rem));font-size:inherit;box-sizing:border-box}.tbw-filter-range-input:focus,.tbw-filter-date-input:focus{outline:none;border-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));box-shadow:0 0 0 2px rgba(from var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6)) r g b / 15%)}.tbw-filter-range-separator{color:var(--tbw-filter-muted, var(--tbw-color-fg-muted, light-dark(#555555, #aaaaaa)));padding-bottom:var(--tbw-spacing-xs, .25rem)}.tbw-filter-blank-option{display:flex;align-items:center;gap:var(--tbw-spacing-sm, .375rem);padding:var(--tbw-spacing-xs, .25rem) 0;margin-bottom:var(--tbw-spacing-xs, .25rem);font-size:var(--tbw-font-size-sm, .8125rem);cursor:pointer;-webkit-user-select:none;user-select:none}.tbw-filter-blank-checkbox{accent-color:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));margin:0;cursor:pointer}.tbw-filter-date-range.tbw-filter-disabled,.tbw-filter-range-inputs.tbw-filter-disabled,.tbw-filter-range-slider.tbw-filter-disabled{opacity:.4;pointer-events:none}.tbw-filter-range-slider{position:relative;height:24px;margin:var(--tbw-spacing-md, .5rem) 0 var(--tbw-panel-gap, var(--tbw-spacing-md, .5rem))}.tbw-filter-range-track{position:absolute;top:50%;left:0;right:0;height:4px;background:var(--tbw-filter-input-border, var(--tbw-color-border, light-dark(#d0d0d4, #454545)));border-radius:2px;transform:translateY(-50%)}.tbw-filter-range-fill{position:absolute;top:50%;height:4px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border-radius:2px;transform:translateY(-50%)}.tbw-filter-range-thumb{position:absolute;top:0;width:100%;height:100%;background:none;pointer-events:none;-webkit-appearance:none;appearance:none}.tbw-filter-range-thumb::-webkit-slider-thumb{-webkit-appearance:none;appearance:none;width:16px;height:16px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border:2px solid var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 1px 3px #0003}.tbw-filter-range-thumb::-moz-range-thumb{width:16px;height:16px;background:var(--tbw-filter-accent, var(--tbw-color-accent, #3b82f6));border:2px solid var(--tbw-filter-panel-bg, var(--tbw-color-panel-bg, light-dark(#eeeeee, #222222)));border-radius:50%;cursor:pointer;pointer-events:all;box-shadow:0 1px 3px #0003}.tbw-filter-range-thumb::-webkit-slider-thumb:hover{transform:scale(1.1)}.tbw-filter-range-thumb::-moz-range-thumb:hover{transform:scale(1.1)}}",document.head.appendChild(e),this.globalStylesInjected=!0}toggleFilterPanel(e,t,r){if(this.openPanelField===e)return void this.closeFilterPanel();this.closeFilterPanel();const n=document.createElement("div");if(n.className="tbw-filter-panel",this.copyGridThemeContext(n),this.isAnimationEnabled&&n.classList.add("tbw-filter-panel-animated"),this.panelElement=n,this.openPanelField=e,this.config.valuesHandler)return n.innerHTML='<div class="tbw-filter-loading">Loading...</div>',document.body.appendChild(n),this.positionPanel(n,r),this.setupPanelCloseHandler(n,r),void this.config.valuesHandler(e,t).then(r=>{this.openPanelField===e&&this.panelElement&&(n.innerHTML="",this.renderPanelContent(e,t,n,r))});const l=o(this.sourceRows,e,t.filterValue);document.body.appendChild(n),this.positionPanel(n,r),this.renderPanelContent(e,t,n,l),this.setupPanelCloseHandler(n,r)}renderPanelContent(e,t,r,n){const l=this.filters.get(e);if("in"===l?.operator&&"set"===l.type&&Array.isArray(l.value)&&!this.excludedValues.has(e)){const t=l.value,r=new Set(t.map(e=>null==e?i:e)),a=new Set(n.filter(e=>!r.has(e)));this.excludedValues.set(e,a)}let a=this.excludedValues.get(e);a||(a=new Set,this.excludedValues.set(e,a));const s=this.searchText.get(e)??"",o={field:e,column:t,uniqueValues:n,excludedValues:a,searchText:s,currentFilter:this.filters.get(e),applySetFilter:(t,r)=>{this.applySetFilter(e,t,r),this.closeFilterPanel()},applyTextFilter:(t,r,n)=>{this.applyTextFilter(e,t,r,n),this.closeFilterPanel()},clearFilter:()=>{this.clearFieldFilter(e),this.closeFilterPanel()},closePanel:()=>this.closeFilterPanel()};let f=!1;if(this.config.filterPanelRenderer&&(this.config.filterPanelRenderer(r,o),f=r.children.length>0),!f&&t.type){const e=this.grid.effectiveConfig.typeDefaults?.[t.type];e?.filterPanelRenderer&&(e.filterPanelRenderer(r,o),f=r.children.length>0)}if(!f){const e=t.type;"number"===e?function(e,t,r,n){const{field:l,column:i}=t,a=i.filterParams,s=i.editorParams,o=r.filter(e=>"number"==typeof e&&!isNaN(e)),c=o.length>0?Math.min(...o):0,d=o.length>0?Math.max(...o):100,u=p(a?.min??s?.min,c),f=p(a?.max??s?.max,d),h=a?.step??s?.step??1,b=n.get(l);let g=u,m=f;const v="blank"===b?.operator;"between"===b?.operator?(g=p(b.value,u),m=p(b.valueTo,f)):"greaterThanOrEqual"===b?.operator?g=p(b.value,u):"lessThanOrEqual"===b?.operator&&(m=p(b.value,f));const w=document.createElement("div");w.className="tbw-filter-range-inputs";const y=document.createElement("div");y.className="tbw-filter-range-group";const x=document.createElement("label");x.textContent="Min",x.className="tbw-filter-range-label";const C=document.createElement("input");C.type="number",C.className="tbw-filter-range-input",C.min=String(u),C.max=String(f),C.step=String(h),C.value=String(g),y.appendChild(x),y.appendChild(C),w.appendChild(y);const S=document.createElement("span");S.className="tbw-filter-range-separator",S.textContent="–",w.appendChild(S);const k=document.createElement("div");k.className="tbw-filter-range-group";const E=document.createElement("label");E.textContent="Max",E.className="tbw-filter-range-label";const F=document.createElement("input");F.type="number",F.className="tbw-filter-range-input",F.min=String(u),F.max=String(f),F.step=String(h),F.value=String(m),k.appendChild(E),k.appendChild(F),w.appendChild(k),e.appendChild(w);const T=document.createElement("div");T.className="tbw-filter-range-slider";const A=document.createElement("div");A.className="tbw-filter-range-track";const N=document.createElement("div");N.className="tbw-filter-range-fill";const P=document.createElement("input");P.type="range",P.className="tbw-filter-range-thumb tbw-filter-range-thumb-min",P.min=String(u),P.max=String(f),P.step=String(h),P.value=String(g);const L=document.createElement("input");L.type="range",L.className="tbw-filter-range-thumb tbw-filter-range-thumb-max",L.min=String(u),L.max=String(f),L.step=String(h),L.value=String(m),T.appendChild(A),T.appendChild(N),T.appendChild(P),T.appendChild(L),e.appendChild(T);const V=document.createElement("label");V.className="tbw-filter-blank-option";const I=document.createElement("input");I.type="checkbox",I.className="tbw-filter-blank-checkbox",I.checked=v;const R=document.createTextNode("Blank");V.appendChild(I),V.appendChild(R);const q=e=>{C.disabled=e,F.disabled=e,P.disabled=e,L.disabled=e,w.classList.toggle("tbw-filter-disabled",e),T.classList.toggle("tbw-filter-disabled",e)};q(v),I.addEventListener("change",()=>{q(I.checked)}),e.appendChild(V);const M=()=>{const e=parseFloat(P.value),t=parseFloat(L.value),r=f-u,n=(e-u)/r*100,l=(t-u)/r*100;N.style.left=`${n}%`,N.style.width=l-n+"%"};P.addEventListener("input",()=>{const e=Math.min(parseFloat(P.value),parseFloat(L.value));P.value=String(e),C.value=String(e),M()}),L.addEventListener("input",()=>{const e=Math.max(parseFloat(L.value),parseFloat(P.value));L.value=String(e),F.value=String(e),M()}),C.addEventListener("input",()=>{let e=parseFloat(C.value)||u;e=Math.max(u,Math.min(e,parseFloat(F.value))),P.value=String(e),M()}),F.addEventListener("input",()=>{let e=parseFloat(F.value)||f;e=Math.min(f,Math.max(e,parseFloat(C.value))),L.value=String(e),M()}),M();const z=document.createElement("div");z.className="tbw-filter-buttons";const B=document.createElement("button");B.className="tbw-filter-apply-btn",B.textContent="Apply",B.addEventListener("click",()=>{if(I.checked)return void t.applyTextFilter("blank","");const e=parseFloat(C.value),r=parseFloat(F.value);t.applyTextFilter("between",e,r)}),z.appendChild(B);const _=document.createElement("button");_.className="tbw-filter-clear-btn",_.textContent="Clear Filter",_.addEventListener("click",()=>{t.clearFilter()}),z.appendChild(_),e.appendChild(z)}(r,o,n,this.filters):"date"===e?function(e,t,r,n){const{field:l,column:i}=t,a=i.filterParams,s=i.editorParams,o=r.filter(e=>e instanceof Date||"string"==typeof e&&!isNaN(Date.parse(e))).map(e=>e instanceof Date?e:new Date(e)).filter(e=>!isNaN(e.getTime())),u=o.length>0?new Date(Math.min(...o.map(e=>e.getTime()))):null,p=o.length>0?new Date(Math.max(...o.map(e=>e.getTime()))):null,f=d(a?.min)||d(s?.min)||c(u),h=d(a?.max)||d(s?.max)||c(p),b=n.get(l);let g="",m="";const v="blank"===b?.operator;"between"===b?.operator?(g=d(b.value)||"",m=d(b.valueTo)||""):"greaterThanOrEqual"===b?.operator?g=d(b.value)||"":"lessThanOrEqual"===b?.operator&&(m=d(b.value)||"");const w=document.createElement("div");w.className="tbw-filter-date-range";const y=document.createElement("div");y.className="tbw-filter-date-group";const x=document.createElement("label");x.textContent="From",x.className="tbw-filter-range-label";const C=document.createElement("input");C.type="date",C.className="tbw-filter-date-input",f&&(C.min=f),h&&(C.max=h),C.value=g,y.appendChild(x),y.appendChild(C),w.appendChild(y);const S=document.createElement("span");S.className="tbw-filter-range-separator",S.textContent="–",w.appendChild(S);const k=document.createElement("div");k.className="tbw-filter-date-group";const E=document.createElement("label");E.textContent="To",E.className="tbw-filter-range-label";const F=document.createElement("input");F.type="date",F.className="tbw-filter-date-input",f&&(F.min=f),h&&(F.max=h),F.value=m,k.appendChild(E),k.appendChild(F),w.appendChild(k),e.appendChild(w);const T=document.createElement("label");T.className="tbw-filter-blank-option";const A=document.createElement("input");A.type="checkbox",A.className="tbw-filter-blank-checkbox",A.checked=v;const N=document.createTextNode("Show only blank");T.appendChild(A),T.appendChild(N);const P=e=>{C.disabled=e,F.disabled=e,w.classList.toggle("tbw-filter-disabled",e)};P(v),A.addEventListener("change",()=>{P(A.checked)}),e.appendChild(T);const L=document.createElement("div");L.className="tbw-filter-buttons";const V=document.createElement("button");V.className="tbw-filter-apply-btn",V.textContent="Apply",V.addEventListener("click",()=>{if(A.checked)return void t.applyTextFilter("blank","");const e=C.value,r=F.value;e&&r?t.applyTextFilter("between",e,r):e?t.applyTextFilter("greaterThanOrEqual",e):r?t.applyTextFilter("lessThanOrEqual",r):t.clearFilter()}),L.appendChild(V);const I=document.createElement("button");I.className="tbw-filter-clear-btn",I.textContent="Clear Filter",I.addEventListener("click",()=>{t.clearFilter()}),L.appendChild(I),e.appendChild(L)}(r,o,n,this.filters):u(r,o,n,a,{caseSensitive:this.config.caseSensitive,debounceMs:this.config.debounceMs},this.searchText)}}setupPanelCloseHandler(e,t){this.panelAbortController=new AbortController;const{signal:r}=this.panelAbortController;setTimeout(()=>{r.aborted||document.addEventListener("click",r=>{e.contains(r.target)||r.target===t||this.closeFilterPanel()},{signal:r})},0)}closeFilterPanel(){const e=this.panelElement;e&&(e.remove(),this.panelElement=null),this.panelAnchorElement&&(this.panelAnchorElement.style.anchorName="",this.panelAnchorElement=null),this.openPanelField=null,this.panelAbortController?.abort(),this.panelAbortController=null}static supportsAnchorPositioning=null;static checkAnchorPositioningSupport(){return null===f.supportsAnchorPositioning&&(f.supportsAnchorPositioning=CSS.supports("anchor-name","--test")),f.supportsAnchorPositioning}positionPanel(e,t){const r=t.closest(".cell")??t;if(r.style.anchorName="--tbw-filter-anchor",this.panelAnchorElement=r,f.checkAnchorPositioningSupport())return void requestAnimationFrame(()=>{const t=e.getBoundingClientRect(),n=r.getBoundingClientRect();t.top<n.top&&e.classList.add("tbw-filter-panel-above")});const n=r.getBoundingClientRect();e.style.position="fixed",e.style.top=`${n.bottom+4}px`,e.style.left=`${n.left}px`,requestAnimationFrame(()=>{const t=e.getBoundingClientRect();t.right>window.innerWidth-8&&(e.style.left=n.right-t.width+"px"),t.bottom>window.innerHeight-8&&(e.style.top=n.top-t.height-4+"px",e.classList.add("tbw-filter-panel-above"))})}applySetFilter(e,t,r){if(this.excludedValues.set(e,new Set(t)),0===t.length)this.filters.delete(e);else{const n=this.filters.get(e);if("in"===n?.operator){const n=this.getUniqueValues(e),l=new Set(t),i=n.filter(e=>!l.has(e));this.filters.set(e,{field:e,type:"set",operator:"in",value:i,...void 0!==r&&{valueTo:r}})}else this.filters.set(e,{field:e,type:"set",operator:"notIn",value:t,...void 0!==r&&{valueTo:r}})}this.applyFiltersInternal()}applyTextFilter(e,t,r,n){this.filters.set(e,{field:e,type:"text",operator:t,value:r,valueTo:n}),this.applyFiltersInternal()}applyFiltersInternal(e){this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null;const t=[...this.filters.values()];if(this.config.filterHandler){this.gridElement.setAttribute("aria-busy","true");const r=this.config.filterHandler(t,this.sourceRows),n=r=>{this.gridElement.removeAttribute("aria-busy"),this.cachedResult=r,this.grid.rows=r,e||(this.emit("filter-change",{filters:t,filteredRowCount:r.length,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:t}),this.requestRender()};return void(r&&"function"==typeof r.then?r.then(n):n(r))}e||(this.emit("filter-change",{filters:t,filteredRowCount:0,selected:this.computeSelected()}),this.config.trackColumnState&&this.grid.requestStateChange?.()),this.emitPluginEvent("filter-applied",{filters:t}),this.requestRender()}getColumnState(e){if(!this.config.trackColumnState)return;const t=this.filters.get(e);return t?{filter:{type:t.type,operator:t.operator,value:t.value,valueTo:t.valueTo}}:void 0}applyColumnState(e,t){if(!this.config.trackColumnState)return;if(!t.filter)return void this.filters.delete(e);const r={field:e,type:t.filter.type,operator:t.filter.operator,value:t.filter.value,valueTo:t.filter.valueTo};this.filters.set(e,r),this.cachedResult=null,this.cacheKey=null,this.cachedInputSpot=null}}e.BLANK_FILTER_VALUE=i,e.FilteringPlugin=f,Object.defineProperty(e,Symbol.toStringTag,{value:"Module"})});
|
|
2
2
|
//# sourceMappingURL=filtering.umd.js.map
|