@hpcc-js/dgrid 2.34.0 → 3.2.0
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/dist/index.js +482 -30792
- package/dist/index.js.map +1 -1
- package/dist/index.umd.cjs +3 -0
- package/dist/index.umd.cjs.map +1 -0
- package/package.json +35 -37
- package/src/Common.ts +36 -30
- package/src/DBStore.ts +2 -2
- package/src/DatasourceStore.ts +3 -3
- package/src/DatasourceTable.ts +13 -8
- package/src/RowFormatter.ts +2 -2
- package/src/Table.ts +15 -9
- package/src/__package__.ts +2 -2
- package/src/dgrid-shim.ts +12 -0
- package/src/i18n.js +2 -1
- package/src/index.ts +8 -9
- package/types/Common.d.ts +22 -14
- package/types/DBStore.d.ts +1 -2
- package/types/DatasourceStore.d.ts +2 -3
- package/types/DatasourceTable.d.ts +7 -8
- package/types/RowFormatter.d.ts +0 -1
- package/types/Table.d.ts +9 -7
- package/types/__package__.d.ts +2 -3
- package/types/dgrid-shim.d.ts +7 -0
- package/types/index.d.ts +8 -9
- package/dist/index.es6.js +0 -30796
- package/dist/index.es6.js.map +0 -1
- package/dist/index.min.js +0 -341
- package/dist/index.min.js.map +0 -1
- package/types/Common.d.ts.map +0 -1
- package/types/DBStore.d.ts.map +0 -1
- package/types/DatasourceStore.d.ts.map +0 -1
- package/types/DatasourceTable.d.ts.map +0 -1
- package/types/RowFormatter.d.ts.map +0 -1
- package/types/Table.d.ts.map +0 -1
- package/types/__package__.d.ts.map +0 -1
- package/types/__tests__/index.d.ts +0 -2
- package/types/__tests__/index.d.ts.map +0 -1
- package/types/__tests__/test1.d.ts +0 -5
- package/types/__tests__/test1.d.ts.map +0 -1
- package/types/index.d.ts.map +0 -1
- package/types-3.4/Common.d.ts +0 -39
- package/types-3.4/DBStore.d.ts +0 -24
- package/types-3.4/DatasourceStore.d.ts +0 -43
- package/types-3.4/DatasourceTable.d.ts +0 -17
- package/types-3.4/RowFormatter.d.ts +0 -38
- package/types-3.4/Table.d.ts +0 -53
- package/types-3.4/__package__.d.ts +0 -4
- package/types-3.4/__tests__/index.d.ts +0 -2
- package/types-3.4/__tests__/test1.d.ts +0 -5
- package/types-3.4/index.d.ts +0 -9
|
@@ -0,0 +1,3 @@
|
|
|
1
|
+
(function(){"use strict";try{if(typeof document<"u"){var i=document.createElement("style");i.appendChild(document.createTextNode(".dijitTooltip{position:absolute;z-index:2000;display:block;left:0;top:-10000px;overflow:visible;font-family:Verdana,Geneva,sans-serif;font-size:12px}.dijitTooltipContainer{border:solid black 2px;background:#b8b5b5;color:#000;font-size:small}.dijitTooltipFocusNode{padding:2px}.dijitTooltipConnector{position:absolute}.dj_a11y .dijitTooltipConnector,.dijitTooltipData{display:none}.dijitTooltip{background:transparent}.dijitTooltipContainer{background-color:#424242;opacity:1;-ms-filter:none;filter:none;padding:4px 8px;border-radius:3px}.dijitTooltip .dijitTooltipContainer{color:#fff;border:0 none}.dijitTooltipConnector{z-index:2;width:auto;height:auto;opacity:1;-ms-filter:none;filter:none}.dijitTooltipABRight .dijitTooltipConnector{left:auto!important;right:8px}.dijitTooltipBelow{padding-top:4px}.dijitTooltipBelow .dijitTooltipConnector{top:0;left:8px;border-bottom:4px solid #424242;border-left:4px solid transparent;border-right:4px solid transparent;border-top:0}.dijitTooltipAbove{padding-bottom:4px}.dijitTooltipAbove .dijitTooltipConnector{bottom:0;left:8px;border-top:4px solid #424242;border-left:4px solid transparent;border-right:4px solid transparent;border-bottom:0}.dijitTooltipLeft{padding-right:4px}.dijitTooltipLeft .dijitTooltipConnector{right:0;border-left:4px solid #424242;border-bottom:4px solid transparent;border-top:4px solid transparent;border-right:0}.dijitTooltipRight{padding-left:4px}.dijitTooltipRight .dijitTooltipConnector{left:0;border-bottom:4px solid transparent;border-top:4px solid transparent;border-right:4px solid #424242}.dgrid{position:relative;overflow:hidden;border:1px solid #ddd;height:30em;display:block}.dgrid-header{background-color:#eee}.dgrid-header-row{position:absolute;right:17px;left:0}.dgrid-header-scroll{position:absolute;top:0;right:0}.dgrid-footer{position:absolute;bottom:0;width:100%}.dgrid-header-hidden{font-size:0;height:0!important;border-top:none!important;border-bottom:none!important;margin-top:0!important;margin-bottom:0!important;padding-top:0!important;padding-bottom:0!important}.dgrid-footer-hidden{display:none}.dgrid-sortable{cursor:pointer}.dgrid-header,.dgrid-header-row,.dgrid-footer{overflow:hidden;background-color:#eee}.dgrid-row-table{border-collapse:collapse;border:none;table-layout:fixed;empty-cells:show;width:100%;height:100%}.dgrid-cell{padding:3px;text-align:left;overflow:hidden;vertical-align:top;border:1px solid #ddd;border-top-style:none;-webkit-box-sizing:border-box;-moz-box-sizing:border-box;box-sizing:border-box;text-overflow:ellipsis;white-space:nowrap}.dgrid-content{position:relative;height:99%}.dgrid-scroller{overflow-x:auto;overflow-y:scroll;position:absolute;top:0;margin-top:25px;bottom:0;width:100%}.dgrid-preload{font-size:0;line-height:0}.dgrid-loading{position:relative;height:100%}.dgrid-above{position:absolute;bottom:0}.ui-icon{width:12px;height:16px;background-image:url(data:image/png;base64,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)}.dgrid-sort-arrow{background-position:-64px -16px;display:block;float:right;margin:0 4px 0 5px;height:12px}.dgrid-sort-up .dgrid-sort-arrow{background-position:0px -16px}.dgrid-selected{background-color:#bbb}.dgrid-input{width:99%}html.has-mozilla .dgrid .dgrid-row:focus,html.has-mozilla .dgrid .dgrid-cell:focus{outline:1px dotted}html.has-mozilla .dgrid-focus{outline-offset:-1px}.dgrid-scrollbar-measure{width:100px;height:100px;overflow:scroll;position:absolute;top:-9999px}.dgrid-autoheight{height:auto}.dgrid-autoheight .dgrid-scroller{position:relative;overflow-y:hidden}.dgrid-autoheight .dgrid-header-scroll{display:none}.dgrid-autoheight .dgrid-header{right:0}.dgrid-column-set{overflow:hidden;width:100%;position:relative;height:100%;-ms-touch-action:pan-y;touch-action:pan-y}.dgrid-column-set-cell{vertical-align:top;height:100%}.dgrid-column-set-scroller-container{font-size:0;position:absolute;bottom:0}.dgrid-autoheight .dgrid-column-set-scroller-container{position:relative}.dgrid-column-set-scroller{display:inline-block;overflow-x:auto;overflow-y:hidden}.dgrid-column-set-scroller-content{height:1px}.ui-icon-triangle-1-e{background-position:-32px -16px}.ui-icon-triangle-1-se{background-position:-48px -16px}.dgrid-expando-icon{width:16px;height:16px}.dgrid-tree-container{-webkit-transition-duration:.3s;-moz-transition-duration:.3s;-o-transition-duration:.3s;-ms-transition-duration:.3s;transition-duration:.3s;overflow:hidden}.dgrid-tree-container.dgrid-tree-resetting{-webkit-transition-duration:0;-moz-transition-duration:0;-o-transition-duration:0;-ms-transition-duration:0;transition-duration:0}.dgrid-hider-toggle{background-position:0 -192px;background-color:transparent;border:none;cursor:pointer;position:absolute;right:0;top:0}.dgrid-rtl-swap .dgrid-hider-toggle{right:auto;left:0}.dgrid-hider-menu{position:absolute;top:0;right:17px;width:184px;background-color:#fff;border:1px solid #000;z-index:99999;padding:4px;overflow-x:hidden;overflow-y:auto}.dgrid-rtl-swap .dgrid-hider-menu{right:auto;left:17px}.dgrid-hider-menu-row{position:relative;padding:2px}.dgrid-hider-menu-check{position:absolute;top:2px;left:2px;padding:0}.dgrid-hider-menu-label{display:block;padding-left:20px}.dgrid-header .dojoDndTarget .dgrid-cell{display:table-cell}.dgrid-header .dojoDndItemBefore{border-left:2px dotted #000!important}.dgrid-header .dojoDndItemAfter{border-right:2px dotted #000!important}.dgrid-column-resizer{cursor:col-resize;position:absolute;width:2px;background-color:#666;z-index:1000}.dgrid-resize-handle{height:100px;width:0;position:absolute;right:-4px;top:-4px;cursor:col-resize;z-index:999;border-left:5px solid transparent;outline:none}.dgrid-resize-header-container{height:100%}.dgrid-resize-guard{cursor:col-resize;position:absolute;bottom:0;left:0;right:0;top:0}html.has-touch .dgrid-resize-handle{border-left:20px solid transparent}html.has-touch .dgrid-column-resizer{width:2px}.dgrid-resize-header-container{position:relative}.dgrid-header .dgrid-cell{overflow:hidden}.dgrid-spacer-row{height:0}.dgrid-spacer-row th{padding-top:0;padding-bottom:0;border-top:none;border-bottom:none}.dgrid-status{padding:2px}.dgrid-pagination .dgrid-status{float:left}.dgrid-pagination .dgrid-navigation,.dgrid-pagination .dgrid-page-size{float:right}.dgrid-navigation .dgrid-page-link{cursor:pointer;font-weight:700;text-decoration:none;color:inherit;padding:0 4px}.dgrid-first,.dgrid-last,.dgrid-next,.dgrid-previous{font-size:130%}.dgrid-pagination .dgrid-page-disabled{color:#aaa;cursor:default}.dgrid-page-input{margin-top:1px;width:2em;text-align:center}.dgrid-page-size{margin:1px 4px 0}.dgrid-rtl-swap .dgrid-header-row{right:0;left:17px}.dgrid-rtl-swap .dgrid-header-scroll{left:0;right:auto}.dgrid-rtl .dgrid-cell{text-align:right}.dgrid-rtl .dgrid-sort-arrow{float:left;margin:0 5px 0 4px}.dgrid-rtl .ui-icon-triangle-1-e{background-position:-96px -16px}.dgrid-rtl .ui-icon-triangle-1-se{background-position:-80px -16px}.dgrid-rtl .dgrid-pagination .dgrid-status,.dgrid-rtl .dgrid-pagination .dgrid-page-size{float:right}.dgrid-rtl .dgrid-pagination .dgrid-navigation{float:left}.dgrid-rtl.dgrid-autoheight .dgrid-header{left:0}.dgrid_Table .placeholder{border:none;padding:0;overflow:hidden}.dgrid_Table .dgrid-fakeline{border:0px;border-bottom:1px solid rgb(221,221,221);margin:2px -3px}.dgrid_Table .dgrid-sortable .dgrid-sort-arrow.ui-icon{margin:0}")),document.head.appendChild(i)}}catch(o){console.error("vite-plugin-css-injected-by-js",o)}})();
|
|
2
|
+
(function(global,factory){typeof exports=="object"&&typeof module<"u"?factory(exports,require("@hpcc-js/common"),require("@hpcc-js/util")):typeof define=="function"&&define.amd?define(["exports","@hpcc-js/common","@hpcc-js/util"],factory):(global=typeof globalThis<"u"?globalThis:global||self,factory(global["@hpcc-js/dgrid"]={},global["@hpcc-js/common"],global["@hpcc-js/util"]))})(this,function(exports2,common,util){"use strict";var __defProp=Object.defineProperty;var __defNormalProp=(obj,key,value)=>key in obj?__defProp(obj,key,{enumerable:!0,configurable:!0,writable:!0,value}):obj[key]=value;var __publicField=(obj,key,value)=>__defNormalProp(obj,typeof key!="symbol"?key+"":key,value);const PKG_NAME="@hpcc-js/dgrid",PKG_VERSION="3.1.0",BUILD_VERSION="3.2.1";globalThis["@hpcc-js/dgrid-shim"]||console.error('dgrid-shim not loaded, please add `<script src="https://cdn.jsdelivr.net/npm/@hpcc-js/dgrid-shim@2.26.0/dist/index.min.js"><\/script>` or similar to your HTML file');const Deferred=globalThis["@hpcc-js/dgrid-shim"].Deferred,Memory=globalThis["@hpcc-js/dgrid-shim"].Memory,QueryResults=globalThis["@hpcc-js/dgrid-shim"].QueryResults,Grid=globalThis["@hpcc-js/dgrid-shim"].Grid,PagingGrid=globalThis["@hpcc-js/dgrid-shim"].PagingGrid,domConstruct=globalThis["@hpcc-js/dgrid-shim"].domConstruct;function entitiesEncode(str){return String(str).replace(/&/g,"&").replace(/</g,"<").replace(/>/g,">").replace(/"/g,""")}function safeEncode(item){switch(Object.prototype.toString.call(item)){case"[object Undefined]":case"[object Boolean]":case"[object Number]":return item;case"[object String]":return entitiesEncode(item);default:console.warn("Unknown cell type: "+Object.prototype.toString.call(item))}return item}const LINE_SPLITTER="<br><hr class='dgrid-fakeline'>",LINE_SPLITTER2="<br><hr class='dgrid-fakeline' style='visibility: hidden'>";class RowFormatter{constructor(columns,_renderHtml){__publicField(this,"_columns");__publicField(this,"_flattenedColumns",[]);__publicField(this,"_columnIdx",{});__publicField(this,"_formattedRow",{});this._renderHtml=_renderHtml,this._columns=columns,this.flattenColumns(columns)}flattenColumns(columns){for(const column of columns)this.flattenColumn(column)}flattenColumn(column){if(column.children)for(const childColumn of column.children)this.flattenColumn(childColumn);else this._columnIdx[column.field]=this._flattenedColumns.length,this._flattenedColumns.push(column.field)}format(row){return this._formattedRow={},this.formatRow(this._columns,row),this.row()}calcDepth(columns,row){let maxChildDepth=1;for(const column of columns)if(column.children&&row[column.leafID]){let childDepth=0;for(const childRow of row[column.leafID])childDepth+=this.calcDepth(column.children,childRow);maxChildDepth=Math.max(maxChildDepth,childDepth)}return maxChildDepth}formatCell(column,cell,maxChildDepth){if(column.children){let childDepth=0;cell instanceof Array||(cell instanceof Object&&cell.Row instanceof Array?cell=cell.Row:cell=[cell]);for(const row of cell)childDepth=Math.max(childDepth,this.formatRow(column.children,row))}else if(column.isSet&&(cell=JSON.stringify(cell.Item)),this._formattedRow[column.field]===void 0?this._formattedRow[column.field]=""+(cell===void 0?"":this._renderHtml?cell:safeEncode(cell)):(this._formattedRow[column.field]+=LINE_SPLITTER,this._formattedRow[column.field]+=""+(cell===void 0?"":this._renderHtml?cell:safeEncode(cell))),maxChildDepth>1){const paddingArr=[];paddingArr.length=maxChildDepth;const padding=paddingArr.join(LINE_SPLITTER2);this._formattedRow[column.field]+=padding}}formatRow(columns,row=[],rowIdx=0){const maxChildDepth=this.calcDepth(columns,row);for(const column of columns)this.formatCell(column,row[column.leafID],maxChildDepth);return maxChildDepth}row(){const retVal={};for(const column of this._flattenedColumns)retVal[column]=this._formattedRow[column];return retVal}}class DBStore{constructor(db){__publicField(this,"_db");__publicField(this,"Model");__publicField(this,"idProperty");__publicField(this,"_renderHtml",!0);this._db=db}renderHtml(_){this._renderHtml=_}db2Columns(sortable,fields,prefix="",formatter,renderCell){return fields?fields.map((field,idx)=>{const column={label:field.label(),leafID:""+idx,field:prefix+idx,idx,className:"resultGridCell",sortable,isSet:!1};switch(field.type()){case"nested":column.children=this.db2Columns(!1,field.children(),prefix+idx+"_",formatter),column.sortable=!1;break;default:column.formatter=formatter,column.renderCell=renderCell}return column}):[]}columns(sortable,formatter,renderCell){return this.db2Columns(sortable,this._db.fields(),"",formatter,renderCell)}getIdentity(object){return object.__hpcc_id}get(row){return this._db.row(row+1)}_fetchRange(opts){const rowFormatter=new RowFormatter(this.columns(!1),this._renderHtml);return this._db.data().slice(opts.start,opts.end).map((row,idx)=>({...rowFormatter.format(row),__hpcc_id:opts.start+idx,__origRow:row}))}fetchRange(opts){const data=this._fetchRange(opts),retVal=new Deferred;return retVal.totalLength=new Deferred,retVal.resolve(data),retVal.totalLength.resolve(this._db.length()-1),retVal}sort(opts){return this._db.data().sort((l,r)=>{for(const item of opts){const idx=item.property;if(l[idx]===void 0&&r[idx]!==void 0||l[idx]<r[idx])return item.descending?1:-1;if(l[idx]!==void 0&&r[idx]===void 0||l[idx]>r[idx])return item.descending?-1:1}return 0}),this}}class Common extends common.HTMLWidget{constructor(){super();__publicField(this,"_columns",[]);__publicField(this,"_store",new DBStore(this._db));__publicField(this,"_dgridDiv");__publicField(this,"_dgrid");__publicField(this,"_prevPaging");__publicField(this,"_prevSortBy");__publicField(this,"_prevSortByDescending");__publicField(this,"_prevMultiSelect");__publicField(this,"_supressEvents");this._tag="div"}formatSortBy(){const idx=this.columns().indexOf(this.sortBy());return idx>=0?[{property:idx.toString(),descending:this.sortByDescending()}]:void 0}selection(_){var _a;if(!arguments.length){const retVal=[];for(const id in this._dgrid.selection)if(this._dgrid.selection[id]){const storeItem=this._store.get(+id);retVal.push(this.rowToObj(storeItem))}return retVal}this._supressEvents=!0,(_a=this._dgrid)==null||_a.clearSelection();let first=!0;this.data().forEach((row,idx)=>{var _a2,_b;if(_.indexOf(row)>=0){const row2=(_a2=this._dgrid)==null?void 0:_a2.row(idx);row2.element&&first&&(first=!1,row2.element.scrollIntoView()),(_b=this._dgrid)==null||_b.select(idx)}}),this._supressEvents=!1}enter(domNode,element){super.enter(domNode,element),this._dgridDiv=element.append("div").attr("class","flat")}update(domNode,element){super.update(domNode,element),this._store.renderHtml(this.renderHtml()),(!this._dgrid||this._prevPaging!==this.pagination()||this._prevSortBy!==this.sortBy()||this._prevSortByDescending!==this.sortByDescending()||this._prevMultiSelect!==this.multiSelect())&&(this._prevPaging=this.pagination(),this._prevSortBy=this.sortBy(),this._prevSortByDescending=this.sortByDescending(),this._prevMultiSelect=this.multiSelect(),this._dgrid&&(this._dgrid.destroy(),this._dgridDiv=element.append("div").attr("class","flat")),this._dgrid=new(this._prevPaging?PagingGrid:Grid)({columns:this._columns,collection:this._store,sort:this.formatSortBy(),selectionMode:this.multiSelect()?"extended":"single",deselectOnRefresh:!0,cellNavigation:!1,pagingLinks:1,pagingTextBox:!0,previousNextArrows:!0,firstLastArrows:!0,rowsPerPage:this.pageSize(),pageSizeOptions:[1,10,25,50,100,1e3]},this._dgridDiv.node()),this._dgrid.on("dgrid-select",evt=>{this._supressEvents||evt.rows&&evt.rows.length&&evt.rows[0].data&&this.click(this.rowToObj(evt.rows[0].data.__origRow),"",!0,{selection:this.selection()})}),this._dgrid.on("dgrid-deselect",evt=>{this._supressEvents||evt.rows&&evt.rows.length&&evt.rows[0].data&&this.click(this.rowToObj(evt.rows[0].data.__origRow),"",!1,{selection:this.selection()})}),this._dgrid.refresh({})),this._dgrid.noDataMessage=`<span class='dojoxGridNoData'>${this.noDataMessage()}</span>`,this._dgrid.loadingMessage=`<span class='dojoxGridNoData'>${this.loadingMessage()}</span>`,this._dgridDiv.style("width",this.width()+"px").style("height",this.height()-2+"px"),this._dgrid.resize()}exit(domNode,element){delete this._prevPaging,this._dgrid&&(this._dgrid.destroy(),delete this._dgrid),super.exit(domNode,element)}click(row,col,sel,more){}}Common.prototype._class+=" dgrid_Common",Common.prototype.publish("noDataMessage","...empty...","string","No Data Message"),Common.prototype.publish("loadingMessage","loading...","string","Loading Message"),Common.prototype.publish("pagination",!1,"boolean","Enable paging"),Common.prototype.publish("pageSize",25,"number","Page size"),Common.prototype.publish("sortable",!1,"boolean","Enable sorting by column"),Common.prototype.publish("sortBy",null,"set","Default 'sort by' Column ID",function(){return this.columns()},{optional:!0}),Common.prototype.publish("sortByDescending",!1,"boolean","Default 'sort by' descending",void 0,{disable:self2=>!self2.sortBy()}),Common.prototype.publish("multiSelect",!1,"boolean","Multiple Selection"),Common.prototype.publish("renderHtml",!0,"boolean","Render HTML");class DatasourceCache{constructor(datasource){__publicField(this,"_datasource");__publicField(this,"_prevHash");__publicField(this,"_fetchCache",{});this._datasource=datasource}validateCache(){const hash=this.hash();this._prevHash!==hash&&(this._prevHash=hash,this._fetchCache={})}id(){return this._datasource.id()}hash(){return this._datasource.hash()}label(){return this._datasource.label()}outFields(){return this._datasource.outFields()}total(){return this._datasource.total()}fetch(from,count){this.validateCache();const cacheID=`${from}->${count}`;let retVal=this._fetchCache[cacheID];return retVal||(retVal=this._datasource.fetch(from,count),this._fetchCache[cacheID]=retVal),retVal}}class DatasourceStore{constructor(datasource,renderHtml){__publicField(this,"_datasource");__publicField(this,"_columnsIdx",{});__publicField(this,"_columns");__publicField(this,"rowFormatter");this._datasource=new DatasourceCache(datasource),this._columnsIdx={},this._columns=this.db2Columns(this._datasource.outFields()).map((column,idx)=>(this._columnsIdx[column.field]=idx,column)),this.rowFormatter=new RowFormatter(this._columns,renderHtml)}columns(){return this._columns}db2Columns(fields,prefix=""){return fields?fields.map((field,idx)=>{const column={field:prefix+field.id,leafID:field.id,label:field.id,idx,className:"resultGridCell",sortable:!0,isSet:!1};return field.type==="dataset"?column.children=this.db2Columns(field.children,prefix+field.id+"_"):column.formatter=(cell,row)=>{switch(typeof cell){case"string":return cell.replace(/\t/g," ")}return cell},column}):[]}getIdentity(row){return row.__hpcc_id}_request(start,end){return this._datasource?this._datasource.fetch(start,end-start).then(response=>({totalLength:this._datasource.total(),data:response.map((row,idx)=>{const formattedRow=this.rowFormatter.format(row);return formattedRow.__hpcc_id=start+idx,formattedRow.__origRow=row,formattedRow})})):Promise.resolve({totalLength:0,data:[]})}fetchRange(options){const retVal=new Deferred;return this._request(options.start,options.end).then(response=>retVal.resolve(response)),new QueryResults(retVal.then(response=>response.data),{totalLength:retVal.then(response=>response.totalLength)})}}class DatasourceTable extends Common{constructor(){super();__publicField(this,"_prevDatasource")}invalidate(){return delete this._prevDatasource,this}enter(domNode,element){super.enter(domNode,element)}update(domNode,element){super.update(domNode,element)}render(callback){return super.render(w=>{if(this._prevDatasource!==this.datasource())if(this._dgrid.set("collection",new Memory),this._dgrid.set("columns",[]),this._prevDatasource=this.datasource(),this._prevDatasource){const store=new DatasourceStore(this._prevDatasource,this.renderHtml());this._dgrid.set("columns",store.columns()),this._dgrid.set("collection",store),callback&&callback(w)}else callback&&callback(w);else callback&&callback(w)})}click(row,col,sel){}}DatasourceTable.prototype._class+=" dgrid_DatasourceTable",DatasourceTable.prototype.publish("datasource",null,"object","Datasource");class ColumnFormat extends common.PropertyExt{constructor(){super();__publicField(this,"_owner")}owner(_){return arguments.length?(this._owner=_,this):this._owner}valid(){return!!this.column()}formatterFunc(){const defaultFormatter=this._owner.formatterFunc();if(this.valid()&&this.format()){const numberFormatter=common.format(this.format());return function(cell,row){return typeof cell=="number"?numberFormatter(cell):defaultFormatter.call(this,cell,row)}}return defaultFormatter}renderCellFunc(){const defaultRenderCell=this._owner.renderCellFunc(),defaultFormatter=this.formatterFunc();if(this.valid()&&this.paletteID()){const columns=this._owner.columns(),palette=common.Palette.rainbow(this.paletteID()),min=this.min(),max=this.max(),valueColIdx=this.valueColumn()?columns.indexOf(this.valueColumn()):void 0;return function(row,cell,cellElement){defaultRenderCell&&defaultRenderCell.call(this,row,cell,cellElement);const value=valueColIdx?row.__origRow[valueColIdx]:cell,background=palette(value,min,max),cellText=defaultFormatter.call(this,cell,row);common.select(cellElement).style("background",background).style("color",background&&common.Palette.textColor(background)).text((cellText==null?void 0:cellText.html)??cellText??cell)}}return defaultRenderCell}}ColumnFormat.prototype._class+=" dgrid_Table.ColumnFormat",ColumnFormat.prototype.publish("column",null,"set","Column",function(){return this._owner.columns()},{optional:!0}),ColumnFormat.prototype.publish("width",null,"number","Width",null,{optional:!0}),ColumnFormat.prototype.publish("format",null,"string","Format (d3-format)",null,{optional:!0}),ColumnFormat.prototype.publish("paletteID",null,"set","Color palette for this widget",["",...common.Palette.rainbow("default").switch()],{optional:!0}),ColumnFormat.prototype.publish("min",0,"number","Min Value",null,{disable:cf=>!cf.paletteID()}),ColumnFormat.prototype.publish("max",100,"number","Max Value",null,{disable:cf=>!cf.paletteID()}),ColumnFormat.prototype.publish("valueColumn",null,"set","Column",function(){return this._owner.columns()},{optional:!0,disable:cf=>!cf.paletteID()});class Table extends Common{constructor(){super();__publicField(this,"_prevColsHash");__publicField(this,"_prevFieldsHash");__publicField(this,"_colsRefresh",!1);__publicField(this,"_dataRefresh",!1);__publicField(this,"_prevHash")}fields(_){const retVal=super.fields.apply(this,arguments);if(arguments.length){const hash=util.hashSum({_});this._prevFieldsHash!==hash&&(this._prevFieldsHash=hash,this._colsRefresh=!0)}return retVal}columns(_,asDefault){const retVal=super.columns.apply(this,arguments);if(arguments.length){const hash=util.hashSum({_});this._prevColsHash!==hash&&(this._prevColsHash=hash,this._colsRefresh=!0)}return retVal}data(_){const retVal=super.data.apply(this,arguments);return arguments.length&&(this._dataRefresh=!0),retVal}enter(domNode,element){super.enter(domNode,element)}guessWidth(columns,data){const sortablePadding=this.sortable()?12:0;for(const column of columns)if(column.children){let sampleData=[];for(let i=0;i<Math.min(3,data.length);++i)sampleData=sampleData.concat(data[i][column.idx]);this.guessWidth(column.children,sampleData)}else column.width=data.reduce((prevVal,row)=>{const cell=(""+row[column.idx]).trim();return Math.max(prevVal,this.textSize(cell).width)},this.textSize(""+column.label,void 0,void 0,!0).width+sortablePadding)+8}update(domNode,element){super.update(domNode,element);const hash=this.hashSum();if(this._prevHash!==hash&&(this._prevHash=hash,this._colsRefresh=!0),this._colsRefresh){switch(this._columns=this._store.columns(this.sortable(),this.formatterFunc(),this.renderCellFunc()),this.columnWidth()){case"auto":const tenRows=this.data().filter((row,idx)=>idx<10);this.guessWidth(this._columns,tenRows);break}const columns=this.columns();for(const columnFormat of this.columnFormats())if(columnFormat.valid()){const colIdx=columns.indexOf(columnFormat.column());this._columns[colIdx]&&(this._columns[colIdx].hidden=columnFormat.width()===0,this._columns[colIdx].width=columnFormat.width()||this._columns[colIdx].width,this._columns[colIdx].formatter=columnFormat.formatterFunc(),this._columns[colIdx].renderCell=columnFormat.renderCellFunc())}this._dgrid.set("columns",this._columns.filter(col=>!col.hidden)),this._colsRefresh=!1}(this._colsRefresh||this._dataRefresh)&&(this._colsRefresh?this._dgrid.refresh({}):this._dgrid.refresh(),this._colsRefresh=!1,this._dataRefresh=!1)}exit(domNode,element){delete this._prevColsHash,delete this._prevFieldsHash,super.exit(domNode,element)}formatterFunc(){return function(cell,row){switch(typeof cell){case"string":return{html:cell.replace(/\t/g," ").trim()};case"undefined":return""}return cell}}renderCellFunc(){}click(row,col,sel){}}Table.prototype._class+=" dgrid_Table",Table.prototype.publish("columnWidth","auto","set","Default column width",["auto","none"]),Table.prototype.publish("columnFormats",[],"propertyArray","Source Columns",null,{autoExpand:ColumnFormat}),exports2.BUILD_VERSION=BUILD_VERSION,exports2.ColumnFormat=ColumnFormat,exports2.Common=Common,exports2.DBStore=DBStore,exports2.DatasourceCache=DatasourceCache,exports2.DatasourceStore=DatasourceStore,exports2.DatasourceTable=DatasourceTable,exports2.Deferred=Deferred,exports2.Grid=Grid,exports2.Memory=Memory,exports2.PKG_NAME=PKG_NAME,exports2.PKG_VERSION=PKG_VERSION,exports2.PagingGrid=PagingGrid,exports2.QueryResults=QueryResults,exports2.RowFormatter=RowFormatter,exports2.Table=Table,exports2.domConstruct=domConstruct,Object.defineProperty(exports2,Symbol.toStringTag,{value:"Module"})});
|
|
3
|
+
//# sourceMappingURL=index.umd.cjs.map
|
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.umd.cjs","sources":["../src/__package__.ts","../src/dgrid-shim.ts","../src/RowFormatter.ts","../src/DBStore.ts","../src/Common.ts","../src/DatasourceStore.ts","../src/DatasourceTable.ts","../src/Table.ts"],"sourcesContent":["export const PKG_NAME = \"@hpcc-js/dgrid\";\nexport const PKG_VERSION = \"3.1.0\";\nexport const BUILD_VERSION = \"3.2.1\";\n","import type * as dgrid_shim from \"@hpcc-js/dgrid-shim\";\n\nif (!globalThis[\"@hpcc-js/dgrid-shim\"]) {\n console.error(\"dgrid-shim not loaded, please add `<script src=\\\"https://cdn.jsdelivr.net/npm/@hpcc-js/dgrid-shim@2.26.0/dist/index.min.js\\\"></script>` or similar to your HTML file\");\n}\n\nexport const Deferred = globalThis[\"@hpcc-js/dgrid-shim\"].Deferred as typeof dgrid_shim.Deferred;\nexport const Memory = globalThis[\"@hpcc-js/dgrid-shim\"].Memory as typeof dgrid_shim.Memory;\nexport const QueryResults = globalThis[\"@hpcc-js/dgrid-shim\"].QueryResults as typeof dgrid_shim.QueryResults;\nexport const Grid = globalThis[\"@hpcc-js/dgrid-shim\"].Grid as typeof dgrid_shim.Grid;\nexport const PagingGrid = globalThis[\"@hpcc-js/dgrid-shim\"].PagingGrid as typeof dgrid_shim.PagingGrid;\nexport const domConstruct = globalThis[\"@hpcc-js/dgrid-shim\"].domConstruct as typeof dgrid_shim.domConstruct;\n","\nfunction entitiesEncode(str) {\n return String(str).replace(/&/g, \"&\").replace(/</g, \"<\").replace(/>/g, \">\").replace(/\"/g, \""\");\n}\n\nfunction safeEncode(item) {\n switch (Object.prototype.toString.call(item)) {\n case \"[object Undefined]\":\n case \"[object Boolean]\":\n case \"[object Number]\":\n return item;\n case \"[object String]\":\n return entitiesEncode(item);\n default:\n console.warn(\"Unknown cell type: \" + Object.prototype.toString.call(item));\n }\n return item;\n}\n\nconst LINE_SPLITTER = \"<br><hr class='dgrid-fakeline'>\";\nconst LINE_SPLITTER2 = \"<br><hr class='dgrid-fakeline' style='visibility: hidden'>\";\n\nexport interface ColumnType {\n field: string;\n leafID: string;\n label: string;\n idx: number;\n className: string;\n sortable: boolean;\n isSet: boolean;\n width?: number;\n formatter?: CellFormatter;\n renderCell?: CellRenderer;\n children?: ColumnType[];\n}\nexport interface RowType {\n __hpcc_id: number;\n __origRow: any[];\n [colIdx: number]: any;\n}\nexport type CellFormatter = (this: ColumnType, cell: any, row: RowType) => string;\nexport type CellRenderer = (this: ColumnType, row: RowType, cell: any, cellElement: HTMLElement) => HTMLElement | void;\n\nexport class RowFormatter {\n private _columns: ColumnType[];\n private _flattenedColumns = [];\n private _columnIdx = {};\n private _formattedRow = {};\n\n constructor(columns: ColumnType[], protected _renderHtml) {\n this._columns = columns;\n this.flattenColumns(columns);\n }\n\n flattenColumns(columns: ColumnType[]) {\n for (const column of columns) {\n this.flattenColumn(column);\n }\n }\n\n flattenColumn(column: ColumnType) {\n if (column.children) {\n for (const childColumn of column.children) this.flattenColumn(childColumn);\n } else {\n this._columnIdx[column.field] = this._flattenedColumns.length;\n this._flattenedColumns.push(column.field);\n }\n }\n\n format(row) {\n this._formattedRow = {};\n this.formatRow(this._columns, row);\n return this.row();\n }\n\n calcDepth(columns: ColumnType[], row) {\n let maxChildDepth = 1;\n for (const column of columns) {\n if (column.children && row[column.leafID]) {\n let childDepth = 0;\n for (const childRow of row[column.leafID]) {\n if (childRow instanceof Array) {\n }\n childDepth += this.calcDepth(column.children, childRow);\n }\n maxChildDepth = Math.max(maxChildDepth, childDepth);\n }\n }\n return maxChildDepth;\n }\n\n formatCell(column: ColumnType, cell, maxChildDepth) {\n if (column.children) {\n let childDepth = 0;\n if (!(cell instanceof Array)) {\n if (cell instanceof Object && cell.Row instanceof Array) { // Push fix in comms?\n cell = cell.Row;\n } else {\n cell = [cell];\n }\n }\n for (const row of cell) {\n childDepth = Math.max(childDepth, this.formatRow(column.children, row));\n }\n } else {\n if (column.isSet) {\n cell = JSON.stringify(cell.Item);\n }\n if (this._formattedRow[column.field] === undefined) {\n this._formattedRow[column.field] = \"\" + (cell === undefined ? \"\" : (this._renderHtml ? cell : safeEncode(cell)));\n } else {\n this._formattedRow[column.field] += LINE_SPLITTER;\n this._formattedRow[column.field] += \"\" + (cell === undefined ? \"\" : (this._renderHtml ? cell : safeEncode(cell)));\n }\n if (maxChildDepth > 1) {\n const paddingArr = [];\n paddingArr.length = maxChildDepth;\n const padding = paddingArr.join(LINE_SPLITTER2);\n this._formattedRow[column.field] += padding;\n }\n }\n }\n\n formatRow(columns: ColumnType[], row: { [key: string]: any } = [], rowIdx: number = 0) {\n const maxChildDepth = this.calcDepth(columns, row);\n for (const column of columns) {\n this.formatCell(column, row[column.leafID], maxChildDepth);\n }\n return maxChildDepth;\n }\n\n row() {\n const retVal = {};\n for (const column of this._flattenedColumns) {\n retVal[column] = this._formattedRow[column];\n }\n return retVal;\n }\n}\n","import { Database } from \"@hpcc-js/common\";\nimport { Deferred } from \"./dgrid-shim.ts\";\nimport { CellFormatter, CellRenderer, ColumnType, RowFormatter } from \"./RowFormatter.ts\";\n\nexport class DBStore {\n private _db: Database.Grid;\n\n Model: null;\n idProperty: \"__hpcc_id\";\n\n constructor(db: Database.Grid) {\n this._db = db;\n }\n\n protected _renderHtml = true;\n renderHtml(_: boolean) {\n this._renderHtml = _;\n }\n\n db2Columns(sortable: boolean, fields: Database.Field[], prefix = \"\", formatter?: CellFormatter, renderCell?: CellRenderer): ColumnType[] {\n if (!fields) return [];\n return fields.map((field, idx) => {\n const label = field.label();\n const column: ColumnType = {\n label,\n leafID: \"\" + idx,\n field: prefix + idx,\n idx,\n className: \"resultGridCell\",\n sortable,\n isSet: false\n };\n switch (field.type()) {\n case \"nested\":\n column.children = this.db2Columns(false, field.children(), prefix + idx + \"_\", formatter);\n column.sortable = false;\n break;\n default:\n column.formatter = formatter;\n column.renderCell = renderCell;\n }\n return column;\n });\n }\n\n columns(sortable: boolean, formatter?: CellFormatter, renderCell?: CellRenderer) {\n return this.db2Columns(sortable, this._db.fields(), \"\", formatter, renderCell);\n }\n\n getIdentity(object) {\n return object.__hpcc_id;\n }\n\n get(row: number) {\n return this._db.row(row + 1);\n }\n\n _fetchRange(opts: { start: number, end: number }): object[] {\n const rowFormatter = new RowFormatter(this.columns(false), this._renderHtml);\n return this._db.data().slice(opts.start, opts.end).map((row, idx) => {\n const formattedRow: any = rowFormatter.format(row);\n return {\n ...formattedRow,\n __hpcc_id: opts.start + idx,\n __origRow: row\n };\n });\n }\n\n fetchRange(opts: { start: number, end: number }): Promise<object[]> {\n const data = this._fetchRange(opts);\n const retVal: any = new Deferred();\n retVal.totalLength = new Deferred();\n retVal.resolve(data);\n retVal.totalLength.resolve(this._db.length() - 1);\n return retVal;\n }\n\n sort(opts) {\n this._db.data().sort((l, r) => {\n for (const item of opts) {\n const idx = item.property;\n if ((l[idx] === undefined && r[idx] !== undefined) || l[idx] < r[idx]) return item.descending ? 1 : -1;\n if ((l[idx] !== undefined && r[idx] === undefined) || l[idx] > r[idx]) return item.descending ? -1 : 1;\n }\n return 0;\n });\n return this;\n }\n}\n","import { HTMLWidget } from \"@hpcc-js/common\";\nimport { Grid, PagingGrid } from \"./dgrid-shim.ts\";\nimport { DBStore } from \"./DBStore.ts\";\n\nimport \"../src/Common.css\";\n\nexport class Common extends HTMLWidget {\n protected _columns = [];\n protected _store = new DBStore(this._db);\n protected _dgridDiv;\n protected _dgrid;\n protected _prevPaging;\n private _prevSortBy: string;\n private _prevSortByDescending: boolean;\n private _prevMultiSelect: boolean;\n\n constructor() {\n super();\n this._tag = \"div\";\n }\n\n protected formatSortBy(): [{ property: string, descending: boolean }] | undefined {\n const idx = this.columns().indexOf(this.sortBy());\n return idx >= 0 ? [{ property: idx.toString(), descending: this.sortByDescending() }] : undefined;\n }\n\n protected _supressEvents;\n selection(): any[];\n selection(_: any[]): this;\n selection(_?: any[]): any[] | this {\n if (!arguments.length) {\n const retVal = [];\n for (const id in this._dgrid.selection) {\n if (this._dgrid.selection[id]) {\n const storeItem = this._store.get(+id);\n retVal.push(this.rowToObj(storeItem));\n }\n }\n return retVal;\n }\n this._supressEvents = true;\n this._dgrid?.clearSelection();\n let first = true;\n this.data().forEach((row, idx) => {\n if (_.indexOf(row) >= 0) {\n const row = this._dgrid?.row(idx);\n if (row.element && first) {\n first = false;\n row.element.scrollIntoView();\n }\n this._dgrid?.select(idx);\n }\n });\n this._supressEvents = false;\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n this._dgridDiv = element.append(\"div\")\n .attr(\"class\", \"flat\")\n ;\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n\n this._store.renderHtml(this.renderHtml());\n\n if (!this._dgrid || this._prevPaging !== this.pagination() ||\n this._prevSortBy !== this.sortBy() ||\n this._prevSortByDescending !== this.sortByDescending() ||\n this._prevMultiSelect !== this.multiSelect()) {\n\n this._prevPaging = this.pagination();\n this._prevSortBy = this.sortBy();\n this._prevSortByDescending = this.sortByDescending();\n this._prevMultiSelect = this.multiSelect();\n if (this._dgrid) {\n this._dgrid.destroy();\n this._dgridDiv = element.append(\"div\")\n .attr(\"class\", \"flat\")\n ;\n }\n this._dgrid = new (this._prevPaging ? PagingGrid : Grid)({\n columns: this._columns,\n collection: this._store,\n sort: this.formatSortBy(),\n selectionMode: this.multiSelect() ? \"extended\" : \"single\",\n deselectOnRefresh: true,\n cellNavigation: false,\n pagingLinks: 1,\n pagingTextBox: true,\n previousNextArrows: true,\n firstLastArrows: true,\n rowsPerPage: this.pageSize(),\n pageSizeOptions: [1, 10, 25, 50, 100, 1000]\n }, this._dgridDiv.node());\n this._dgrid.on(\"dgrid-select\", (evt) => {\n if (this._supressEvents) return;\n if (evt.rows && evt.rows.length && evt.rows[0].data) {\n this.click(this.rowToObj(evt.rows[0].data.__origRow), \"\", true, { selection: this.selection() });\n }\n });\n this._dgrid.on(\"dgrid-deselect\", (evt) => {\n if (this._supressEvents) return;\n if (evt.rows && evt.rows.length && evt.rows[0].data) {\n this.click(this.rowToObj(evt.rows[0].data.__origRow), \"\", false, { selection: this.selection() });\n }\n });\n this._dgrid.refresh({});\n }\n this._dgrid.noDataMessage = `<span class='dojoxGridNoData'>${this.noDataMessage()}</span>`;\n this._dgrid.loadingMessage = `<span class='dojoxGridNoData'>${this.loadingMessage()}</span>`;\n\n this._dgridDiv\n .style(\"width\", this.width() + \"px\")\n .style(\"height\", this.height() - 2 + \"px\")\n ;\n this._dgrid.resize();\n }\n\n exit(domNode, element) {\n delete this._prevPaging;\n if (this._dgrid) {\n this._dgrid.destroy();\n delete this._dgrid;\n }\n super.exit(domNode, element);\n }\n\n click(row, col, sel, more) {\n }\n}\nCommon.prototype._class += \" dgrid_Common\";\n\nexport interface Common {\n noDataMessage(): string;\n noDataMessage(_: string): this;\n loadingMessage(): string;\n loadingMessage(_: string): this;\n pagination(): boolean;\n pagination(_: boolean): this;\n pageSize(): number;\n pageSize(_: number): this;\n sortable(): boolean;\n sortable(_: boolean): this;\n sortBy(): string;\n sortBy(_: string): this;\n sortByDescending(): boolean;\n sortByDescending(_: boolean): this;\n multiSelect(): boolean;\n multiSelect(_: boolean): this;\n renderHtml(): boolean;\n renderHtml(_: boolean): this;\n}\n\nCommon.prototype.publish(\"noDataMessage\", \"...empty...\", \"string\", \"No Data Message\");\nCommon.prototype.publish(\"loadingMessage\", \"loading...\", \"string\", \"Loading Message\");\nCommon.prototype.publish(\"pagination\", false, \"boolean\", \"Enable paging\");\nCommon.prototype.publish(\"pageSize\", 25, \"number\", \"Page size\");\nCommon.prototype.publish(\"sortable\", false, \"boolean\", \"Enable sorting by column\");\nCommon.prototype.publish(\"sortBy\", null, \"set\", \"Default 'sort by' Column ID\", function (this: Common) { return this.columns(); }, { optional: true });\nCommon.prototype.publish(\"sortByDescending\", false, \"boolean\", \"Default 'sort by' descending\", undefined, { disable: self => !self.sortBy() });\nCommon.prototype.publish(\"multiSelect\", false, \"boolean\", \"Multiple Selection\");\nCommon.prototype.publish(\"renderHtml\", true, \"boolean\", \"Render HTML\");\n\n","import type { DDL2 } from \"@hpcc-js/ddl-shim\";\nimport { Deferred, QueryResults } from \"./dgrid-shim.ts\";\nimport { ColumnType, RowFormatter } from \"./RowFormatter.ts\";\n\nexport interface IDatasource {\n id: () => string;\n hash: () => string;\n label: () => string;\n\n outFields: () => DDL2.IField[];\n total: () => number;\n fetch: (from: number, count: number) => Promise<ReadonlyArray<object>>;\n}\n\nexport class DatasourceCache implements IDatasource {\n protected _datasource: IDatasource;\n _prevHash: string;\n _fetchCache: { [key: string]: Promise<ReadonlyArray<object>> } = {};\n\n constructor(datasource: IDatasource) {\n this._datasource = datasource;\n }\n\n validateCache() {\n const hash = this.hash();\n if (this._prevHash !== hash) {\n this._prevHash = hash;\n this._fetchCache = {};\n }\n }\n\n id() { return this._datasource.id(); }\n hash() { return this._datasource.hash(); }\n label() { return this._datasource.label(); }\n\n outFields() { return this._datasource.outFields(); }\n total() { return this._datasource.total(); }\n fetch(from: number, count: number): Promise<ReadonlyArray<object>> {\n this.validateCache();\n const cacheID = `${from}->${count}`;\n let retVal = this._fetchCache[cacheID];\n if (!retVal) {\n retVal = this._datasource.fetch(from, count);\n this._fetchCache[cacheID] = retVal;\n }\n return retVal;\n }\n}\n\nexport class DatasourceStore {\n _datasource: DatasourceCache;\n _columnsIdx: { [key: string]: number } = {};\n _columns;\n\n private rowFormatter: RowFormatter;\n\n constructor(datasource: IDatasource, renderHtml: boolean) {\n this._datasource = new DatasourceCache(datasource);\n\n this._columnsIdx = {};\n this._columns = this.db2Columns(this._datasource.outFields()).map((column, idx) => {\n this._columnsIdx[column.field] = idx;\n return column;\n });\n this.rowFormatter = new RowFormatter(this._columns, renderHtml);\n }\n\n columns() {\n return this._columns;\n }\n\n db2Columns(fields: DDL2.IField[], prefix = \"\"): ColumnType[] {\n if (!fields) return [];\n return fields.map((field, idx) => {\n const column: ColumnType = {\n field: prefix + field.id,\n leafID: field.id,\n label: field.id,\n idx,\n className: \"resultGridCell\",\n sortable: true,\n isSet: false\n };\n if (field.type === \"dataset\") {\n column.children = this.db2Columns(field.children, prefix + field.id + \"_\");\n } else {\n column.formatter = (cell, row) => {\n switch (typeof cell) {\n case \"string\":\n return cell.replace(/\\t/g, \" \");\n }\n return cell;\n };\n }\n return column;\n });\n }\n\n getIdentity(row) {\n return row.__hpcc_id;\n }\n\n _request(start, end): Promise<{ totalLength: number, data: any[] }> {\n if (!this._datasource) return Promise.resolve({ totalLength: 0, data: [] });\n const retVal = this._datasource.fetch(start, end - start).then(response => {\n return {\n totalLength: this._datasource.total(),\n data: response.map((row, idx) => {\n const formattedRow: any = this.rowFormatter.format(row);\n formattedRow.__hpcc_id = start + idx;\n formattedRow.__origRow = row;\n return formattedRow;\n })\n };\n });\n return retVal;\n }\n\n fetchRange(options): Promise<any[]> {\n const retVal = new Deferred();\n this._request(options.start, options.end).then(response => retVal.resolve(response));\n return new QueryResults(retVal.then(response => response.data), {\n totalLength: retVal.then(response => response.totalLength)\n });\n }\n}\n","import { Widget } from \"@hpcc-js/common\";\nimport { Memory } from \"./dgrid-shim.ts\";\nimport { Common } from \"./Common.ts\";\nimport { DatasourceStore, IDatasource } from \"./DatasourceStore.ts\";\n\nexport class DatasourceTable extends Common {\n _prevDatasource?: IDatasource;\n\n constructor() {\n super();\n }\n\n invalidate(): this {\n delete this._prevDatasource;\n return this;\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n }\n\n update(domNode, element) {\n super.update(domNode, element);\n }\n render(callback?: (w: Widget) => void): this {\n return super.render(w => {\n if (this._prevDatasource !== this.datasource()) {\n this._dgrid.set(\"collection\", new Memory());\n this._dgrid.set(\"columns\", []);\n this._prevDatasource = this.datasource();\n if (this._prevDatasource) {\n const store = new DatasourceStore(this._prevDatasource, this.renderHtml());\n this._dgrid.set(\"columns\", store.columns());\n this._dgrid.set(\"collection\", store);\n if (callback) {\n callback(w);\n }\n } else {\n if (callback) {\n callback(w);\n }\n }\n } else {\n if (callback) {\n callback(w);\n }\n }\n });\n }\n\n click(row, col, sel) {\n }\n}\nDatasourceTable.prototype._class += \" dgrid_DatasourceTable\";\n\nexport interface DatasourceTable {\n datasource(): IDatasource;\n datasource(_: IDatasource): this;\n}\n\nDatasourceTable.prototype.publish(\"datasource\", null, \"object\", \"Datasource\");\n\n","import { Palette, PropertyExt, Field } from \"@hpcc-js/common\";\nimport { hashSum } from \"@hpcc-js/util\";\nimport { format as d3Format } from \"d3-format\";\nimport { select as d3Select } from \"d3-selection\";\nimport { Common } from \"./Common.ts\";\nimport { CellFormatter, CellRenderer, ColumnType, RowType } from \"./RowFormatter.ts\";\n\n// ColumnPalette ---\nexport class ColumnFormat extends PropertyExt {\n _owner: Table;\n\n constructor() {\n super();\n }\n\n owner(): Table;\n owner(_: Table): this;\n owner(_?: Table): Table | this {\n if (!arguments.length) return this._owner;\n this._owner = _;\n return this;\n }\n\n valid(): boolean {\n return !!this.column();\n }\n\n formatterFunc(): CellFormatter | undefined {\n const defaultFormatter = this._owner.formatterFunc();\n if (this.valid() && this.format()) {\n const numberFormatter = d3Format(this.format());\n\n return function (this: ColumnType, cell: any, row: RowType): string {\n if (typeof cell === \"number\")\n return numberFormatter(cell);\n return defaultFormatter.call(this, cell, row);\n };\n }\n return defaultFormatter;\n }\n\n renderCellFunc(): CellRenderer | undefined {\n const defaultRenderCell = this._owner.renderCellFunc();\n const defaultFormatter = this.formatterFunc();\n if (this.valid() && this.paletteID()) {\n const columns = this._owner.columns();\n const palette = Palette.rainbow(this.paletteID());\n const min = this.min();\n const max = this.max();\n const valueColIdx = this.valueColumn() ? columns.indexOf(this.valueColumn()) : undefined;\n return function (this: ColumnType, row: RowType, cell: any, cellElement: HTMLElement): HTMLElement | void {\n if (defaultRenderCell) {\n defaultRenderCell.call(this, row, cell, cellElement);\n }\n const value = valueColIdx ? row.__origRow[valueColIdx] : cell;\n const background = palette(value, min, max);\n const cellText: any = defaultFormatter.call(this, cell, row);\n d3Select(cellElement)\n .style(\"background\", background)\n .style(\"color\", background && Palette.textColor(background))\n .text(cellText?.html ?? cellText ?? cell)\n ;\n };\n }\n return defaultRenderCell;\n }\n}\nColumnFormat.prototype._class += \" dgrid_Table.ColumnFormat\";\n\nexport interface ColumnFormat {\n column(): string;\n column(_: string): this;\n width(): number;\n width(_: number): this;\n format(): string;\n format(_: string): this;\n paletteID(): string;\n paletteID(_: string): this;\n min(): number;\n min(_: number): this;\n max(): number;\n max(_: number): this;\n valueColumn(): string;\n valueColumn(_: string): this;\n}\nColumnFormat.prototype.publish(\"column\", null, \"set\", \"Column\", function (this: ColumnFormat) { return this._owner.columns(); }, { optional: true });\nColumnFormat.prototype.publish(\"width\", null, \"number\", \"Width\", null, { optional: true });\nColumnFormat.prototype.publish(\"format\", null, \"string\", \"Format (d3-format)\", null, { optional: true });\nColumnFormat.prototype.publish(\"paletteID\", null, \"set\", \"Color palette for this widget\", [\"\", ...Palette.rainbow(\"default\").switch()], { optional: true });\nColumnFormat.prototype.publish(\"min\", 0, \"number\", \"Min Value\", null, { disable: (cf: ColumnFormat) => !cf.paletteID() });\nColumnFormat.prototype.publish(\"max\", 100, \"number\", \"Max Value\", null, { disable: (cf: ColumnFormat) => !cf.paletteID() });\nColumnFormat.prototype.publish(\"valueColumn\", null, \"set\", \"Column\", function (this: ColumnFormat) { return this._owner.columns(); }, { optional: true, disable: (cf: ColumnFormat) => !cf.paletteID() });\n\n// Table ---\nexport class Table extends Common {\n private _prevColsHash;\n private _prevFieldsHash;\n _colsRefresh = false;\n _dataRefresh = false;\n\n constructor() {\n super();\n }\n\n fields(): Field[];\n fields(_: Field[]): this;\n fields(_?: Field[]): Field[] | this {\n const retVal = super.fields.apply(this, arguments as any);\n if (arguments.length) {\n const hash = hashSum({ _ });\n if (this._prevFieldsHash !== hash) {\n this._prevFieldsHash = hash;\n this._colsRefresh = true;\n }\n }\n return retVal;\n }\n\n columns(): string[];\n columns(_: string[], asDefault?: boolean): this;\n columns(_?: string[], asDefault?: boolean): string[] | this {\n const retVal = super.columns.apply(this, arguments as any);\n if (arguments.length) {\n const hash = hashSum({ _ });\n if (this._prevColsHash !== hash) {\n this._prevColsHash = hash;\n this._colsRefresh = true;\n }\n }\n return retVal;\n }\n\n data(): any;\n data(_: any): this;\n data(_?: any): any | this {\n const retVal = super.data.apply(this, arguments as any);\n if (arguments.length) {\n this._dataRefresh = true;\n }\n return retVal;\n }\n\n enter(domNode, element) {\n super.enter(domNode, element);\n }\n\n guessWidth(columns, data) {\n const sortablePadding = this.sortable() ? 12 : 0;\n for (const column of columns) {\n if (column.children) {\n let sampleData = [];\n for (let i = 0; i < Math.min(3, data.length); ++i) {\n sampleData = sampleData.concat(data[i][column.idx]);\n }\n this.guessWidth(column.children, sampleData);\n } else {\n column.width = data.reduce((prevVal: number, row) => {\n const cell = (\"\" + row[column.idx]).trim();\n return Math.max(prevVal, this.textSize(cell).width);\n }, this.textSize(\"\" + column.label, undefined, undefined, true).width + sortablePadding) + 8; // +12 for the sort icon, +8 for the cell padding.\n }\n }\n }\n\n _prevHash;\n update(domNode, element) {\n super.update(domNode, element);\n const hash = this.hashSum();\n if (this._prevHash !== hash) {\n this._prevHash = hash;\n this._colsRefresh = true;\n }\n if (this._colsRefresh) {\n this._columns = this._store.columns(this.sortable(), this.formatterFunc(), this.renderCellFunc());\n switch (this.columnWidth()) {\n case \"auto\":\n const tenRows = this.data().filter((row, idx) => idx < 10);\n this.guessWidth(this._columns, tenRows);\n break;\n }\n const columns = this.columns();\n for (const columnFormat of this.columnFormats()) {\n if (columnFormat.valid()) {\n const colIdx = columns.indexOf(columnFormat.column());\n if (this._columns[colIdx]) {\n this._columns[colIdx].hidden = columnFormat.width() === 0;\n this._columns[colIdx].width = columnFormat.width() || this._columns[colIdx].width;\n this._columns[colIdx].formatter = columnFormat.formatterFunc();\n this._columns[colIdx].renderCell = columnFormat.renderCellFunc();\n }\n }\n }\n this._dgrid.set(\"columns\", this._columns.filter(col => !col.hidden));\n this._colsRefresh = false;\n }\n if (this._colsRefresh || this._dataRefresh) {\n if (this._colsRefresh) {\n this._dgrid.refresh({});\n } else {\n this._dgrid.refresh();\n }\n this._colsRefresh = false;\n this._dataRefresh = false;\n }\n }\n\n exit(domNode, element) {\n delete this._prevColsHash;\n delete this._prevFieldsHash;\n super.exit(domNode, element);\n }\n\n // Cell ---\n formatterFunc(): CellFormatter | undefined {\n return function (this: ColumnType, cell: any, row: RowType): string | any {\n switch (typeof cell) {\n case \"string\":\n return {\n html: cell.replace(/\\t/g, \" \").trim()\n };\n case \"undefined\":\n return \"\";\n }\n return cell;\n };\n }\n\n renderCellFunc(): CellRenderer | undefined {\n return undefined; // Undefined will defualt to formatter ---\n }\n\n // Events ---\n click(row, col, sel) {\n }\n}\nTable.prototype._class += \" dgrid_Table\";\n\nexport interface Table {\n columnWidth(): \"auto\" | \"none\";\n columnWidth(_: \"auto\" | \"none\"): this;\n columnFormats(): ColumnFormat[];\n columnFormats(_: ColumnFormat[]): this;\n}\n\nTable.prototype.publish(\"columnWidth\", \"auto\", \"set\", \"Default column width\", [\"auto\", \"none\"]);\nTable.prototype.publish(\"columnFormats\", [], \"propertyArray\", \"Source Columns\", null, { autoExpand: ColumnFormat });\n"],"names":["HTMLWidget","row","_a","self","PropertyExt","d3Format","Palette","d3Select","hashSum"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -1,54 +1,52 @@
|
|
|
1
1
|
{
|
|
2
2
|
"name": "@hpcc-js/dgrid",
|
|
3
|
-
"version": "2.
|
|
3
|
+
"version": "3.2.0",
|
|
4
4
|
"description": "hpcc-js - Viz DGrid",
|
|
5
|
-
"
|
|
6
|
-
"
|
|
7
|
-
"
|
|
8
|
-
"
|
|
9
|
-
|
|
10
|
-
|
|
11
|
-
|
|
12
|
-
|
|
13
|
-
|
|
14
|
-
|
|
15
|
-
]
|
|
16
|
-
}
|
|
5
|
+
"type": "module",
|
|
6
|
+
"main": "./dist/index.umd.cjs",
|
|
7
|
+
"module": "./dist/index.js",
|
|
8
|
+
"exports": {
|
|
9
|
+
".": {
|
|
10
|
+
"types": "./types/index.d.ts",
|
|
11
|
+
"import": "./dist/index.js",
|
|
12
|
+
"require": "./dist/index.umd.cjs"
|
|
13
|
+
},
|
|
14
|
+
"./dist/*": "./dist/*"
|
|
17
15
|
},
|
|
16
|
+
"browser": "./dist/index.umd.cjs",
|
|
17
|
+
"types": "./types/index.d.ts",
|
|
18
18
|
"files": [
|
|
19
19
|
"dist/*",
|
|
20
|
-
"
|
|
21
|
-
"types
|
|
22
|
-
"src/*"
|
|
20
|
+
"src/*",
|
|
21
|
+
"types/*"
|
|
23
22
|
],
|
|
24
23
|
"scripts": {
|
|
25
|
-
"clean": "rimraf --glob lib* types dist *.tsbuildinfo",
|
|
26
|
-
"
|
|
27
|
-
"
|
|
28
|
-
"
|
|
29
|
-
"
|
|
30
|
-
"
|
|
31
|
-
"bundle-watch": "npm run bundle -- -w",
|
|
32
|
-
"minimize": "terser dist/index.js -c -m --source-map \"content='dist/index.js.map',url='index.min.js.map'\" -o dist/index.min.js",
|
|
33
|
-
"gen-legacy-types": "downlevel-dts ./types ./types-3.4",
|
|
34
|
-
"build": "npm run compile-es6 && npm run bundle",
|
|
35
|
-
"watch": "npm-run-all compile-es6 -p compile-es6-watch bundle-watch",
|
|
36
|
-
"stamp": "node ../../node_modules/@hpcc-js/bundle/src/stamp.js",
|
|
24
|
+
"clean": "rimraf --glob lib* types dist *.tsbuildinfo .turbo",
|
|
25
|
+
"bundle": "vite build",
|
|
26
|
+
"bundle-watch": "vite --port 5506",
|
|
27
|
+
"gen-types": "tsc --project tsconfig.json",
|
|
28
|
+
"gen-types-watch": "npm run gen-types -- --watch",
|
|
29
|
+
"build": "run-p gen-types bundle",
|
|
37
30
|
"lint": "eslint ./src",
|
|
31
|
+
"lint-fix": "eslint --fix src/**/*.ts",
|
|
38
32
|
"docs": "typedoc --options tdoptions.json .",
|
|
39
|
-
"
|
|
33
|
+
"test-browser": "vitest run --project browser",
|
|
34
|
+
"test": "vitest run",
|
|
35
|
+
"coverage": "vitest run --coverage",
|
|
36
|
+
"update": "npx --yes npm-check-updates -u -t minor",
|
|
37
|
+
"update-major": "npx --yes npm-check-updates -u"
|
|
40
38
|
},
|
|
41
39
|
"dependencies": {
|
|
42
|
-
"@hpcc-js/common": "^
|
|
43
|
-
"@hpcc-js/
|
|
44
|
-
"@hpcc-js/
|
|
45
|
-
"@hpcc-js/util": "^2.53.0"
|
|
40
|
+
"@hpcc-js/common": "^3.3.0",
|
|
41
|
+
"@hpcc-js/dgrid-shim": "^3.1.0",
|
|
42
|
+
"@hpcc-js/util": "^3.3.0"
|
|
46
43
|
},
|
|
47
44
|
"devDependencies": {
|
|
48
|
-
"@hpcc-js/
|
|
45
|
+
"@hpcc-js/ddl-shim": "^3.0.0",
|
|
46
|
+
"@hpcc-js/esbuild-plugins": "^1.4.0",
|
|
47
|
+
"@testing-library/dom": "10.4.0",
|
|
49
48
|
"d3-format": "^1",
|
|
50
|
-
"d3-selection": "^1"
|
|
51
|
-
"tslib": "2.7.0"
|
|
49
|
+
"d3-selection": "^1"
|
|
52
50
|
},
|
|
53
51
|
"repository": {
|
|
54
52
|
"type": "git",
|
|
@@ -61,5 +59,5 @@
|
|
|
61
59
|
"url": "https://github.com/hpcc-systems/Visualization/issues"
|
|
62
60
|
},
|
|
63
61
|
"homepage": "https://github.com/hpcc-systems/Visualization",
|
|
64
|
-
"gitHead": "
|
|
62
|
+
"gitHead": "145a4d4c8189c70f08e9804e63959d6dd398bd9f"
|
|
65
63
|
}
|
package/src/Common.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { HTMLWidget
|
|
2
|
-
import { Grid, PagingGrid } from "
|
|
3
|
-
import { DBStore } from "./DBStore";
|
|
1
|
+
import { HTMLWidget } from "@hpcc-js/common";
|
|
2
|
+
import { Grid, PagingGrid } from "./dgrid-shim.ts";
|
|
3
|
+
import { DBStore } from "./DBStore.ts";
|
|
4
4
|
|
|
5
5
|
import "../src/Common.css";
|
|
6
6
|
|
|
@@ -19,32 +19,6 @@ export class Common extends HTMLWidget {
|
|
|
19
19
|
this._tag = "div";
|
|
20
20
|
}
|
|
21
21
|
|
|
22
|
-
@publish("...empty...", "string", "No Data Message")
|
|
23
|
-
noDataMessage: publish<this, string>;
|
|
24
|
-
@publish("loading...", "string", "Loading Message")
|
|
25
|
-
loadingMessage: publish<this, string>;
|
|
26
|
-
@publish(false, "boolean", "Enable paging")
|
|
27
|
-
pagination: publish<this, boolean>;
|
|
28
|
-
@publish(25, "number", "Page size")
|
|
29
|
-
pageSize: publish<this, number>;
|
|
30
|
-
@publish(false, "boolean", "Enable sorting by column")
|
|
31
|
-
sortable: publish<this, boolean>;
|
|
32
|
-
@publish(null, "set", "Default 'sort by' Column ID", function () { return this.columns(); }, { optional: true })
|
|
33
|
-
sortBy: publish<this, string>;
|
|
34
|
-
@publish(false, "boolean", "Default 'sort by' descending", null, { disable: self => !self.sortBy() })
|
|
35
|
-
sortByDescending: publish<this, boolean>;
|
|
36
|
-
@publish(false, "boolean", "Multiple Selection")
|
|
37
|
-
multiSelect: publish<this, boolean>;
|
|
38
|
-
@publish(true, "boolean", "Render HTML")
|
|
39
|
-
renderHtml: publish<this, boolean>;
|
|
40
|
-
|
|
41
|
-
// Backward Compatibility
|
|
42
|
-
mulitSelect(): boolean;
|
|
43
|
-
mulitSelect(_?: boolean): this;
|
|
44
|
-
mulitSelect(_?: boolean): this | boolean {
|
|
45
|
-
return this.multiSelect.apply(this, arguments);
|
|
46
|
-
}
|
|
47
|
-
|
|
48
22
|
protected formatSortBy(): [{ property: string, descending: boolean }] | undefined {
|
|
49
23
|
const idx = this.columns().indexOf(this.sortBy());
|
|
50
24
|
return idx >= 0 ? [{ property: idx.toString(), descending: this.sortByDescending() }] : undefined;
|
|
@@ -58,7 +32,7 @@ export class Common extends HTMLWidget {
|
|
|
58
32
|
const retVal = [];
|
|
59
33
|
for (const id in this._dgrid.selection) {
|
|
60
34
|
if (this._dgrid.selection[id]) {
|
|
61
|
-
|
|
35
|
+
const storeItem = this._store.get(+id);
|
|
62
36
|
retVal.push(this.rowToObj(storeItem));
|
|
63
37
|
}
|
|
64
38
|
}
|
|
@@ -158,3 +132,35 @@ export class Common extends HTMLWidget {
|
|
|
158
132
|
}
|
|
159
133
|
}
|
|
160
134
|
Common.prototype._class += " dgrid_Common";
|
|
135
|
+
|
|
136
|
+
export interface Common {
|
|
137
|
+
noDataMessage(): string;
|
|
138
|
+
noDataMessage(_: string): this;
|
|
139
|
+
loadingMessage(): string;
|
|
140
|
+
loadingMessage(_: string): this;
|
|
141
|
+
pagination(): boolean;
|
|
142
|
+
pagination(_: boolean): this;
|
|
143
|
+
pageSize(): number;
|
|
144
|
+
pageSize(_: number): this;
|
|
145
|
+
sortable(): boolean;
|
|
146
|
+
sortable(_: boolean): this;
|
|
147
|
+
sortBy(): string;
|
|
148
|
+
sortBy(_: string): this;
|
|
149
|
+
sortByDescending(): boolean;
|
|
150
|
+
sortByDescending(_: boolean): this;
|
|
151
|
+
multiSelect(): boolean;
|
|
152
|
+
multiSelect(_: boolean): this;
|
|
153
|
+
renderHtml(): boolean;
|
|
154
|
+
renderHtml(_: boolean): this;
|
|
155
|
+
}
|
|
156
|
+
|
|
157
|
+
Common.prototype.publish("noDataMessage", "...empty...", "string", "No Data Message");
|
|
158
|
+
Common.prototype.publish("loadingMessage", "loading...", "string", "Loading Message");
|
|
159
|
+
Common.prototype.publish("pagination", false, "boolean", "Enable paging");
|
|
160
|
+
Common.prototype.publish("pageSize", 25, "number", "Page size");
|
|
161
|
+
Common.prototype.publish("sortable", false, "boolean", "Enable sorting by column");
|
|
162
|
+
Common.prototype.publish("sortBy", null, "set", "Default 'sort by' Column ID", function (this: Common) { return this.columns(); }, { optional: true });
|
|
163
|
+
Common.prototype.publish("sortByDescending", false, "boolean", "Default 'sort by' descending", undefined, { disable: self => !self.sortBy() });
|
|
164
|
+
Common.prototype.publish("multiSelect", false, "boolean", "Multiple Selection");
|
|
165
|
+
Common.prototype.publish("renderHtml", true, "boolean", "Render HTML");
|
|
166
|
+
|
package/src/DBStore.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
1
|
import { Database } from "@hpcc-js/common";
|
|
2
|
-
import { Deferred } from "
|
|
3
|
-
import { CellFormatter, CellRenderer, ColumnType, RowFormatter } from "./RowFormatter";
|
|
2
|
+
import { Deferred } from "./dgrid-shim.ts";
|
|
3
|
+
import { CellFormatter, CellRenderer, ColumnType, RowFormatter } from "./RowFormatter.ts";
|
|
4
4
|
|
|
5
5
|
export class DBStore {
|
|
6
6
|
private _db: Database.Grid;
|
package/src/DatasourceStore.ts
CHANGED
|
@@ -1,6 +1,6 @@
|
|
|
1
|
-
import { DDL2 } from "@hpcc-js/ddl-shim";
|
|
2
|
-
import { Deferred, QueryResults } from "
|
|
3
|
-
import { ColumnType, RowFormatter } from "./RowFormatter";
|
|
1
|
+
import type { DDL2 } from "@hpcc-js/ddl-shim";
|
|
2
|
+
import { Deferred, QueryResults } from "./dgrid-shim.ts";
|
|
3
|
+
import { ColumnType, RowFormatter } from "./RowFormatter.ts";
|
|
4
4
|
|
|
5
5
|
export interface IDatasource {
|
|
6
6
|
id: () => string;
|
package/src/DatasourceTable.ts
CHANGED
|
@@ -1,18 +1,15 @@
|
|
|
1
|
-
import {
|
|
2
|
-
import { Memory } from "
|
|
3
|
-
import { Common } from "./Common";
|
|
4
|
-
import { DatasourceStore, IDatasource } from "./DatasourceStore";
|
|
1
|
+
import { Widget } from "@hpcc-js/common";
|
|
2
|
+
import { Memory } from "./dgrid-shim.ts";
|
|
3
|
+
import { Common } from "./Common.ts";
|
|
4
|
+
import { DatasourceStore, IDatasource } from "./DatasourceStore.ts";
|
|
5
5
|
|
|
6
6
|
export class DatasourceTable extends Common {
|
|
7
|
-
_prevDatasource
|
|
7
|
+
_prevDatasource?: IDatasource;
|
|
8
8
|
|
|
9
9
|
constructor() {
|
|
10
10
|
super();
|
|
11
11
|
}
|
|
12
12
|
|
|
13
|
-
@publish(null, "object", "Datasource")
|
|
14
|
-
datasource: { (): IDatasource; (_: IDatasource): DatasourceTable };
|
|
15
|
-
|
|
16
13
|
invalidate(): this {
|
|
17
14
|
delete this._prevDatasource;
|
|
18
15
|
return this;
|
|
@@ -55,3 +52,11 @@ export class DatasourceTable extends Common {
|
|
|
55
52
|
}
|
|
56
53
|
}
|
|
57
54
|
DatasourceTable.prototype._class += " dgrid_DatasourceTable";
|
|
55
|
+
|
|
56
|
+
export interface DatasourceTable {
|
|
57
|
+
datasource(): IDatasource;
|
|
58
|
+
datasource(_: IDatasource): this;
|
|
59
|
+
}
|
|
60
|
+
|
|
61
|
+
DatasourceTable.prototype.publish("datasource", null, "object", "Datasource");
|
|
62
|
+
|
package/src/RowFormatter.ts
CHANGED
|
@@ -107,10 +107,10 @@ export class RowFormatter {
|
|
|
107
107
|
cell = JSON.stringify(cell.Item);
|
|
108
108
|
}
|
|
109
109
|
if (this._formattedRow[column.field] === undefined) {
|
|
110
|
-
this._formattedRow[column.field] = "" + cell === undefined ? "" : (this._renderHtml ? cell : safeEncode(cell));
|
|
110
|
+
this._formattedRow[column.field] = "" + (cell === undefined ? "" : (this._renderHtml ? cell : safeEncode(cell)));
|
|
111
111
|
} else {
|
|
112
112
|
this._formattedRow[column.field] += LINE_SPLITTER;
|
|
113
|
-
this._formattedRow[column.field] += "" + cell === undefined ? "" : (this._renderHtml ? cell : safeEncode(cell));
|
|
113
|
+
this._formattedRow[column.field] += "" + (cell === undefined ? "" : (this._renderHtml ? cell : safeEncode(cell)));
|
|
114
114
|
}
|
|
115
115
|
if (maxChildDepth > 1) {
|
|
116
116
|
const paddingArr = [];
|
package/src/Table.ts
CHANGED
|
@@ -1,9 +1,9 @@
|
|
|
1
|
-
import { Palette, PropertyExt } from "@hpcc-js/common";
|
|
1
|
+
import { Palette, PropertyExt, Field } from "@hpcc-js/common";
|
|
2
2
|
import { hashSum } from "@hpcc-js/util";
|
|
3
3
|
import { format as d3Format } from "d3-format";
|
|
4
4
|
import { select as d3Select } from "d3-selection";
|
|
5
|
-
import { Common } from "./Common";
|
|
6
|
-
import { CellFormatter, CellRenderer, ColumnType, RowType } from "./RowFormatter";
|
|
5
|
+
import { Common } from "./Common.ts";
|
|
6
|
+
import { CellFormatter, CellRenderer, ColumnType, RowType } from "./RowFormatter.ts";
|
|
7
7
|
|
|
8
8
|
// ColumnPalette ---
|
|
9
9
|
export class ColumnFormat extends PropertyExt {
|
|
@@ -54,7 +54,7 @@ export class ColumnFormat extends PropertyExt {
|
|
|
54
54
|
}
|
|
55
55
|
const value = valueColIdx ? row.__origRow[valueColIdx] : cell;
|
|
56
56
|
const background = palette(value, min, max);
|
|
57
|
-
const cellText = defaultFormatter.call(this, cell, row);
|
|
57
|
+
const cellText: any = defaultFormatter.call(this, cell, row);
|
|
58
58
|
d3Select(cellElement)
|
|
59
59
|
.style("background", background)
|
|
60
60
|
.style("color", background && Palette.textColor(background))
|
|
@@ -102,8 +102,10 @@ export class Table extends Common {
|
|
|
102
102
|
super();
|
|
103
103
|
}
|
|
104
104
|
|
|
105
|
-
fields(
|
|
106
|
-
|
|
105
|
+
fields(): Field[];
|
|
106
|
+
fields(_: Field[]): this;
|
|
107
|
+
fields(_?: Field[]): Field[] | this {
|
|
108
|
+
const retVal = super.fields.apply(this, arguments as any);
|
|
107
109
|
if (arguments.length) {
|
|
108
110
|
const hash = hashSum({ _ });
|
|
109
111
|
if (this._prevFieldsHash !== hash) {
|
|
@@ -114,8 +116,10 @@ export class Table extends Common {
|
|
|
114
116
|
return retVal;
|
|
115
117
|
}
|
|
116
118
|
|
|
117
|
-
columns(
|
|
118
|
-
|
|
119
|
+
columns(): string[];
|
|
120
|
+
columns(_: string[], asDefault?: boolean): this;
|
|
121
|
+
columns(_?: string[], asDefault?: boolean): string[] | this {
|
|
122
|
+
const retVal = super.columns.apply(this, arguments as any);
|
|
119
123
|
if (arguments.length) {
|
|
120
124
|
const hash = hashSum({ _ });
|
|
121
125
|
if (this._prevColsHash !== hash) {
|
|
@@ -126,8 +130,10 @@ export class Table extends Common {
|
|
|
126
130
|
return retVal;
|
|
127
131
|
}
|
|
128
132
|
|
|
133
|
+
data(): any;
|
|
134
|
+
data(_: any): this;
|
|
129
135
|
data(_?: any): any | this {
|
|
130
|
-
const retVal = super.data.apply(this, arguments);
|
|
136
|
+
const retVal = super.data.apply(this, arguments as any);
|
|
131
137
|
if (arguments.length) {
|
|
132
138
|
this._dataRefresh = true;
|
|
133
139
|
}
|
package/src/__package__.ts
CHANGED
|
@@ -1,3 +1,3 @@
|
|
|
1
1
|
export const PKG_NAME = "@hpcc-js/dgrid";
|
|
2
|
-
export const PKG_VERSION = "
|
|
3
|
-
export const BUILD_VERSION = "2.
|
|
2
|
+
export const PKG_VERSION = "3.1.0";
|
|
3
|
+
export const BUILD_VERSION = "3.2.1";
|
|
@@ -0,0 +1,12 @@
|
|
|
1
|
+
import type * as dgrid_shim from "@hpcc-js/dgrid-shim";
|
|
2
|
+
|
|
3
|
+
if (!globalThis["@hpcc-js/dgrid-shim"]) {
|
|
4
|
+
console.error("dgrid-shim not loaded, please add `<script src=\"https://cdn.jsdelivr.net/npm/@hpcc-js/dgrid-shim@2.26.0/dist/index.min.js\"></script>` or similar to your HTML file");
|
|
5
|
+
}
|
|
6
|
+
|
|
7
|
+
export const Deferred = globalThis["@hpcc-js/dgrid-shim"].Deferred as typeof dgrid_shim.Deferred;
|
|
8
|
+
export const Memory = globalThis["@hpcc-js/dgrid-shim"].Memory as typeof dgrid_shim.Memory;
|
|
9
|
+
export const QueryResults = globalThis["@hpcc-js/dgrid-shim"].QueryResults as typeof dgrid_shim.QueryResults;
|
|
10
|
+
export const Grid = globalThis["@hpcc-js/dgrid-shim"].Grid as typeof dgrid_shim.Grid;
|
|
11
|
+
export const PagingGrid = globalThis["@hpcc-js/dgrid-shim"].PagingGrid as typeof dgrid_shim.PagingGrid;
|
|
12
|
+
export const domConstruct = globalThis["@hpcc-js/dgrid-shim"].domConstruct as typeof dgrid_shim.domConstruct;
|
package/src/i18n.js
CHANGED
package/src/index.ts
CHANGED
|
@@ -1,11 +1,10 @@
|
|
|
1
|
-
export * from "./__package__";
|
|
2
|
-
export * from "./Common";
|
|
3
|
-
export * from "./DatasourceStore";
|
|
4
|
-
export * from "./DatasourceTable";
|
|
5
|
-
export * from "./DBStore";
|
|
6
|
-
export * from "./RowFormatter";
|
|
7
|
-
export * from "./Table";
|
|
1
|
+
export * from "./__package__.ts";
|
|
2
|
+
export * from "./Common.ts";
|
|
3
|
+
export * from "./DatasourceStore.ts";
|
|
4
|
+
export * from "./DatasourceTable.ts";
|
|
5
|
+
export * from "./DBStore.ts";
|
|
6
|
+
export * from "./RowFormatter.ts";
|
|
7
|
+
export * from "./Table.ts";
|
|
8
8
|
|
|
9
9
|
// Must be last...
|
|
10
|
-
export { Deferred,
|
|
11
|
-
|
|
10
|
+
export { Deferred, Memory, QueryResults, Grid, PagingGrid, domConstruct } from "./dgrid-shim.ts";
|
package/types/Common.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
|
-
import { HTMLWidget
|
|
2
|
-
import { DBStore } from "./DBStore";
|
|
1
|
+
import { HTMLWidget } from "@hpcc-js/common";
|
|
2
|
+
import { DBStore } from "./DBStore.ts";
|
|
3
3
|
import "../src/Common.css";
|
|
4
4
|
export declare class Common extends HTMLWidget {
|
|
5
5
|
protected _columns: any[];
|
|
@@ -11,17 +11,6 @@ export declare class Common extends HTMLWidget {
|
|
|
11
11
|
private _prevSortByDescending;
|
|
12
12
|
private _prevMultiSelect;
|
|
13
13
|
constructor();
|
|
14
|
-
noDataMessage: publish<this, string>;
|
|
15
|
-
loadingMessage: publish<this, string>;
|
|
16
|
-
pagination: publish<this, boolean>;
|
|
17
|
-
pageSize: publish<this, number>;
|
|
18
|
-
sortable: publish<this, boolean>;
|
|
19
|
-
sortBy: publish<this, string>;
|
|
20
|
-
sortByDescending: publish<this, boolean>;
|
|
21
|
-
multiSelect: publish<this, boolean>;
|
|
22
|
-
renderHtml: publish<this, boolean>;
|
|
23
|
-
mulitSelect(): boolean;
|
|
24
|
-
mulitSelect(_?: boolean): this;
|
|
25
14
|
protected formatSortBy(): [{
|
|
26
15
|
property: string;
|
|
27
16
|
descending: boolean;
|
|
@@ -34,4 +23,23 @@ export declare class Common extends HTMLWidget {
|
|
|
34
23
|
exit(domNode: any, element: any): void;
|
|
35
24
|
click(row: any, col: any, sel: any, more: any): void;
|
|
36
25
|
}
|
|
37
|
-
|
|
26
|
+
export interface Common {
|
|
27
|
+
noDataMessage(): string;
|
|
28
|
+
noDataMessage(_: string): this;
|
|
29
|
+
loadingMessage(): string;
|
|
30
|
+
loadingMessage(_: string): this;
|
|
31
|
+
pagination(): boolean;
|
|
32
|
+
pagination(_: boolean): this;
|
|
33
|
+
pageSize(): number;
|
|
34
|
+
pageSize(_: number): this;
|
|
35
|
+
sortable(): boolean;
|
|
36
|
+
sortable(_: boolean): this;
|
|
37
|
+
sortBy(): string;
|
|
38
|
+
sortBy(_: string): this;
|
|
39
|
+
sortByDescending(): boolean;
|
|
40
|
+
sortByDescending(_: boolean): this;
|
|
41
|
+
multiSelect(): boolean;
|
|
42
|
+
multiSelect(_: boolean): this;
|
|
43
|
+
renderHtml(): boolean;
|
|
44
|
+
renderHtml(_: boolean): this;
|
|
45
|
+
}
|
package/types/DBStore.d.ts
CHANGED
|
@@ -1,5 +1,5 @@
|
|
|
1
1
|
import { Database } from "@hpcc-js/common";
|
|
2
|
-
import { CellFormatter, CellRenderer, ColumnType } from "./RowFormatter";
|
|
2
|
+
import { CellFormatter, CellRenderer, ColumnType } from "./RowFormatter.ts";
|
|
3
3
|
export declare class DBStore {
|
|
4
4
|
private _db;
|
|
5
5
|
Model: null;
|
|
@@ -21,4 +21,3 @@ export declare class DBStore {
|
|
|
21
21
|
}): Promise<object[]>;
|
|
22
22
|
sort(opts: any): this;
|
|
23
23
|
}
|
|
24
|
-
//# sourceMappingURL=DBStore.d.ts.map
|