@sd-angular/core 1.3.32 → 1.3.34

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.
Files changed (24) hide show
  1. package/bundles/sd-angular-core-grid-material.umd.js +22 -3
  2. package/bundles/sd-angular-core-grid-material.umd.js.map +1 -1
  3. package/bundles/sd-angular-core-grid-material.umd.min.js +2 -2
  4. package/bundles/sd-angular-core-grid-material.umd.min.js.map +1 -1
  5. package/bundles/sd-angular-core-tab-router.umd.js +3 -1
  6. package/bundles/sd-angular-core-tab-router.umd.js.map +1 -1
  7. package/bundles/sd-angular-core-tab-router.umd.min.js +1 -1
  8. package/bundles/sd-angular-core-tab-router.umd.min.js.map +1 -1
  9. package/esm2015/grid-material/src/lib/components/desktop-cell-view/desktop-cell-view.component.js +2 -2
  10. package/esm2015/grid-material/src/lib/grid-material.component.js +13 -2
  11. package/esm2015/grid-material/src/lib/models/grid-column.model.js +1 -1
  12. package/esm2015/grid-material/src/lib/pipes/cell-view.pipe.js +2 -2
  13. package/esm2015/tab-router/src/lib/components/tab-router-item/tab-router-item.component.js +5 -2
  14. package/fesm2015/sd-angular-core-grid-material.js +14 -3
  15. package/fesm2015/sd-angular-core-grid-material.js.map +1 -1
  16. package/fesm2015/sd-angular-core-tab-router.js +4 -2
  17. package/fesm2015/sd-angular-core-tab-router.js.map +1 -1
  18. package/grid-material/sd-angular-core-grid-material.metadata.json +1 -1
  19. package/grid-material/src/lib/grid-material.component.d.ts +2 -0
  20. package/grid-material/src/lib/models/grid-column.model.d.ts +4 -1
  21. package/grid-material/src/lib/pipes/cell-view.pipe.d.ts +1 -1
  22. package/package.json +1 -1
  23. package/{sd-angular-core-1.3.32.tgz → sd-angular-core-1.3.34.tgz} +0 -0
  24. package/tab-router/sd-angular-core-tab-router.metadata.json +1 -1
@@ -16,7 +16,7 @@ export class SdCellViewPipe {
16
16
  _isMobileOrTablet.set(this, false);
17
17
  __classPrivateFieldSet(this, _isMobileOrTablet, !deviceService.isDesktop());
18
18
  }
19
- transform(value, rowData, column, gridOption, key) {
19
+ transform(value, rowData, column, gridOption) {
20
20
  var _a;
21
21
  return __awaiter(this, void 0, void 0, function* () {
22
22
  const { displayOnEmpty } = gridOption;
@@ -176,4 +176,4 @@ SdCellViewPipe.ctorParameters = () => [
176
176
  { type: SdUtilityService },
177
177
  { type: SdColumnValuesPipe }
178
178
  ];
179
- //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-view.pipe.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/pipes/cell-view.pipe.ts"],"names":[],"mappings":";;AAAA,OAAO,EAAE,IAAI,EAAiB,MAAM,eAAe,CAAC;AACpD,OAAO,EAAE,gBAAgB,EAAE,MAAM,0BAA0B,CAAC;AAC5D,OAAO,EAAE,qBAAqB,EAAE,MAAM,qBAAqB,CAAC;AAI5D,OAAO,EAAE,kBAAkB,EAAE,MAAM,sBAAsB,CAAC;AAI1D,MAAM,OAAO,cAAc;IAOzB,YACE,aAAoC,EAC5B,cAAgC,EAChC,gBAAoC;QADpC,mBAAc,GAAd,cAAc,CAAkB;QAChC,qBAAgB,GAAhB,gBAAgB,CAAoB;QAT9C,qBAAa,EAAE,EAAC;QAChB,qBAAa,2CAAkB,EAAE,EAAC;QAClC,mBAAW,2CAAkB,EAAE,EAAC;QAChC,kBAAU,yCAAgB,EAAE,EAAC;QAC7B,oBAAY,yCAAgB,GAAG,EAAC;QAChC,4BAAoB,KAAK,EAAC;QAKxB,uBAAA,IAAI,qBAAqB,CAAC,aAAa,CAAC,SAAS,EAAE,EAAC;IACtD,CAAC;IACK,SAAS,CACb,KAAU,EACV,OAAY,EACZ,MAA4B,EAC5B,UAAgC,EAChC,GAAW;;;YACX,MAAM,EAAE,cAAc,EAAE,GAAG,UAAU,CAAC;YACtC,MAAM,EAAE,KAAK,EAAE,KAAK,EAAE,OAAO,EAAE,YAAY,EAAE,SAAS,EAAE,GAAG,MAAM,CAAC;YAClE,MAAM,MAAM,GAAe;gBACzB,KAAK,EAAE,IAAI;gBACX,OAAO,EAAE,IAAI;gBACb,OAAO,EAAE;oBACP,KAAK,EAAE,KAAK,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,QAAQ,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC;oBAC7D,KAAK;iBACN;gBACD,KAAK,EAAE,IAAI;aACZ,CAAC;YACF,UAAU;YACV,IAAI,OAAO,CAAC,YAAY,CAAC,KAAK,UAAU,EAAE;gBACxC,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gBAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,YAAY,CAAC,KAAK,EAAE,OAAO,kDAAyB,CAAC;aAC5E;iBAAM;gBACL,IAAI,MAAM,CAAC,IAAI,KAAK,UAAU,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;oBAClF,MAAM,EAAE,aAAa,EAAE,GAAG,MAAM,CAAC;oBACjC,IAAI,aAAa,EAAE;wBACjB,KAAK,GAAG,aAAa,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;qBACvC;iBACF;gBACD,IAAI,OAAO,CAAC,SAAS,CAAC,KAAK,UAAU,EAAE;oBACrC,MAAM,GAAG,GAAG,SAAS,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;oBACtC,IAAI,GAAG,YAAY,OAAO,EAAE;wBAC1B,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,GAAG,CAAC;qBAClC;yBAAM;wBACL,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,GAAG,CAAC;qBAC5B;iBACF;qBAAM;oBACL,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,IAAI,MAAM,CAAC,IAAI,KAAK,UAAU,EAAE;wBACxD,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;wBAC1B,MAAM,OAAO,GAAG,IAAI,CAAC,KAAK,CAAC,CAAC,IAAI,IAAI,EAAE,CAAC,OAAO,EAAE,GAAG,IAAI,IAAI,CAAC,KAAK,CAAC,CAAC,OAAO,EAAE,CAAC,GAAG,IAAI,CAAC,CAAC;wBACtF,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,MAAK,OAAO,IAAI,OAAO,0CAAiB,EAAE;4BACjE,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;4BACjE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;yBACnG;6BAAM,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,MAAK,KAAK,IAAI,OAAO,wCAAe,EAAE;4BACpE,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;4BACjE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;yBACnG;6BAAM,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,MAAK,MAAM,IAAI,OAAO,yCAAgB,EAAE;4BACtE,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;4BACjE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;yBACnG;6BAAM,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,MAAK,QAAQ,IAAI,OAAO,2CAAkB,EAAE;4BAC1E,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;4BACjE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;yBACnG;6BAAM,IAAI,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,MAAK,QAAQ,IAAI,OAAO,2CAAkB,EAAE;4BAC1E,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,cAAc,CAAC,cAAc,CAAC,KAAK,CAAC,CAAC;4BACjE,MAAM,CAAC,OAAO,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,MAAM,CAAC,IAAI,KAAK,MAAM,CAAC,CAAC,CAAC,YAAY,CAAC,CAAC,CAAC,kBAAkB,CAAC,CAAC;yBACnG;6BAAM;4BACL,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,CAAC,CAAC;4BAChD,MAAM,IAAI,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;4BAC3C,MAAM,QAAQ,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;4BAC/C,IAAI,MAAM,CAAC,IAAI,KAAK,UAAU,IAAI,IAAI,IAAI,IAAI,KAAK,OAAO,EAAE;gCAC1D,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,QAAQ,CAAC;gCAChC,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gCAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,4CAA4C,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,qCAAqC,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,YAAY,CAAC,SAAS,CAAC;6BACjL;iCAAM;gCACL,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;6BAC7B;yBACF;qBACF;oBACD,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;wBAC1B,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC,QAAQ,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;qBACtD;oBACD,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,EAAE;wBAC5B,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,IAAI,CAAC,gBAAgB,CAAC,SAAS,CAAC,KAAK,EAAE,MAAM,CAAC,CAAC;qBAC7E;yBAAM,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,IAAI,MAAM,CAAC,QAAQ,CAAC,KAAK,CAAC,EAAE;wBAC7D,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,MAAM,CAAC,YAAY,CAAC,KAAK,CAAC,CAAC;qBACnD;oBACD,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;wBAC1B,MAAM,EAAE,MAAM,EAAE,GAAG,MAAM,CAAC;wBAC1B,IAAI,KAAK,KAAK,SAAS,IAAI,KAAK,KAAK,IAAI,IAAI,KAAK,KAAK,EAAE,EAAE;4BACzD,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,KAAK,KAAK,IAAI,CAAC,CAAC,CAAC,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,aAAa,KAAI,MAAM,CAAC,CAAC,CAAC,CAAC,CAAC,CAAA,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,cAAc,KAAI,OAAO,CAAC,CAAC;yBACjH;6BAAM;4BACL,MAAM,CAAC,OAAO,CAAC,KAAK,GAAG,IAAI,CAAC;yBAC7B;qBACF;iBACF;gBACD,IAAI,cAAc,EAAE;oBAClB,IAAI,MAAM,GAAG,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,CAAC,CAAC;oBACnC,IAAI,OAAO,CAAC,cAAc,CAAC,KAAK,QAAQ,EAAE;wBACxC,MAAM,EAAE,OAAO,EAAE,WAAW,EAAE,GAAG,cAAc,CAAC;wBAChD,MAAM,GAAG,CAAC,IAAI,EAAE,SAAS,EAAE,EAAE,EAAE,GAAG,WAAW,CAAC,CAAC;wBAC/C,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;4BACzC,IAAI,OAAO,CAAC,OAAO,CAAC,KAAK,UAAU,EAAE;gCACnC,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gCAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,OAAO,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;6BAChD;iCAAM;gCACL,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gCAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,0CAA0C,CAAC;6BAClE;yBACF;qBACF;yBAAM;wBACL,IAAI,MAAM,CAAC,QAAQ,CAAC,MAAM,CAAC,OAAO,CAAC,KAAK,CAAC,EAAE;4BACzC,IAAI,OAAO,CAAC,cAAc,CAAC,KAAK,UAAU,EAAE;gCAC1C,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gCAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,cAAc,CAAC,OAAO,EAAE,MAAM,CAAC,CAAC;6BACvD;iCAAM;gCACL,MAAM,CAAC,OAAO,CAAC,OAAO,GAAG,IAAI,CAAC;gCAC9B,MAAM,CAAC,OAAO,CAAC,IAAI,GAAG,0CAA0C,CAAC;6BAClE;yBACF;qBACF;iBACF;aACF;YACD,QAAQ;YACR,IAAI,CAAC,MAAM,CAAC,IAAI,KAAK,QAAQ,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,IAAI,MAAM,CAAC,IAAI,KAAK,QAAQ,CAAC,IAAI,MAAM,CAAC,KAAK,EAAE;gBACtG,MAAM,CAAC,KAAK,GAAG;oBACb,IAAI,EAAE,EAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,CAAA,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS;oBACrD,KAAK,EAAE,MAAM,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC;oBACnC,IAAI,QAAE,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,+CAAjB,MAAM,EAAc,KAAK,EAAE,OAAO,CAAC;iBAC1C,CAAC;aACH;iBAAM,IAAI,MAAM,CAAC,IAAI,KAAK,MAAM,EAAE;gBACjC,MAAM,CAAC,KAAK,GAAG;oBACb,IAAI,EAAE,EAAC,MAAM,aAAN,MAAM,uBAAN,MAAM,CAAE,SAAS,CAAA,CAAC,CAAC,CAAC,OAAO,CAAC,CAAC,CAAC,MAAM,CAAC,SAAS;oBACrD,KAAK,EAAE,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,SAAS,CAAC,CAAC,CAAC,QAAQ;oBACrC,IAAI,EAAE,IAAI;iBACX,CAAC;aACH;YACD,UAAU;YACV,IAAI,OAAO,CAAC,OAAO,CAAC,KAAK,UAAU,EAAE;gBACnC,MAAM,CAAC,OAAO,GAAG,OAAO,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;aAC1C;YACD,YAAY;YACZ,IAAI,OAAO,CAAC,KAAK,CAAC,KAAK,UAAU,EAAE;gBACjC,MAAM,CAAC,KAAK,GAAG,GAAG,EAAE,CAAC,KAAK,CAAC,KAAK,EAAE,OAAO,CAAC,CAAC;aAC5C;YACD,OAAO,MAAM,CAAC;;KACf;;;;YAtJF,IAAI,SAAC;gBACJ,IAAI,EAAE,UAAU;aACjB;;;YAPQ,qBAAqB;YADrB,gBAAgB;YAKhB,kBAAkB","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdCellView } from '../models/grid-cell.model';\r\nimport { SdGridMaterialColumn } from '../models/grid-column.model';\r\nimport { SdGridMaterialOption } from '../models/grid-option.model';\r\nimport { SdColumnValuesPipe } from './column-values.pipe';\r\n@Pipe({\r\n  name: 'cellView'\r\n})\r\nexport class SdCellViewPipe implements PipeTransform {\r\n  #maxSecond = 60;\r\n  #maxMinute = this.#maxSecond * 60;\r\n  #maxHour = this.#maxMinute * 24;\r\n  #maxDay = this.#maxHour * 30;\r\n  #maxMonth = this.#maxHour * 365;\r\n  #isMobileOrTablet = false;\r\n  constructor(\r\n    deviceService: DeviceDetectorService,\r\n    private utilityService: SdUtilityService,\r\n    private columnValuesPipe: SdColumnValuesPipe) {\r\n    this.#isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n  async transform(\r\n    value: any,\r\n    rowData: any,\r\n    column: SdGridMaterialColumn,\r\n    gridOption: SdGridMaterialOption,\r\n    key: string): Promise<SdCellView> {\r\n    const { displayOnEmpty } = gridOption;\r\n    const { align, click, tooltip, htmlTemplate, transform } = column;\r\n    const result: SdCellView = {\r\n      badge: null,\r\n      tooltip: null,\r\n      display: {\r\n        align: align || (column.type === 'number' ? 'right' : 'left'),\r\n        value\r\n      },\r\n      click: null\r\n    };\r\n    // Display\r\n    if (typeof (htmlTemplate) === 'function') {\r\n      result.display.hasHtml = true;\r\n      result.display.html = htmlTemplate(value, rowData, this.#isMobileOrTablet);\r\n    } else {\r\n      if (column.type === 'datetime' || column.type === 'date' || column.type === 'time') {\r\n        const { transformDate } = column;\r\n        if (transformDate) {\r\n          value = transformDate(value, rowData);\r\n        }\r\n      }\r\n      if (typeof (transform) === 'function') {\r\n        const val = transform(value, rowData);\r\n        if (val instanceof Promise) {\r\n          result.display.value = await val;\r\n        } else {\r\n          result.display.value = val;\r\n        }\r\n      } else {\r\n        if (column.type === 'date' || column.type === 'datetime') {\r\n          const { option } = column;\r\n          const seconds = Math.round((new Date().getTime() - new Date(value).getTime()) / 1000);\r\n          if (option?.timeDifferent === 'month' && seconds < this.#maxMonth) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'day' && seconds < this.#maxDay) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'hour' && seconds < this.#maxHour) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'minute' && seconds < this.#maxMinute) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'second' && seconds < this.#maxSecond) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else {\r\n            const date = Date.toFormat(value, 'dd/MM/yyyy');\r\n            const time = Date.toFormat(value, 'HH:mm');\r\n            const dateTime = Date.toFormat(value, 'HH:mm');\r\n            if (column.type === 'datetime' && time && time !== '00:00') {\r\n              result.display.value = dateTime;\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<span class=\"d-block T14R text-black400\">${Date.toFormat(value, 'HH:mm')}</span><span class=\"d-block T14R\">${Date.toFormat(value, 'dd/MM/yyyy')}</span>`;\r\n            } else {\r\n              result.display.value = date;\r\n            }\r\n          }\r\n        }\r\n        if (column.type === 'time') {\r\n          result.display.value = Date.toFormat(value, 'HH:mm');\r\n        }\r\n        if (column.type === 'values') {\r\n          result.display.value = await this.columnValuesPipe.transform(value, column);\r\n        } else if (column.type === 'number' && Number.isNumber(value)) {\r\n          result.display.value = Number.toVNCurrency(value);\r\n        }\r\n        if (column.type === 'bool') {\r\n          const { option } = column;\r\n          if (value !== undefined && value !== null && value !== '') {\r\n            result.display.value = value === true ? (option?.displayOnTrue || 'True') : (option?.displayOnFalse || 'False');\r\n          } else {\r\n            result.display.value = null;\r\n          }\r\n        }\r\n      }\r\n      if (displayOnEmpty) {\r\n        let values = [null, undefined, ''];\r\n        if (typeof (displayOnEmpty) === 'object') {\r\n          const { display, emptyValues } = displayOnEmpty;\r\n          values = [null, undefined, '', ...emptyValues];\r\n          if (values.includes(result.display.value)) {\r\n            if (typeof (display) === 'function') {\r\n              result.display.hasHtml = true;\r\n              result.display.html = display(rowData, column);\r\n            } else {\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<div class=\"T16R text-black400\">--</div>`;\r\n            }\r\n          }\r\n        } else {\r\n          if (values.includes(result.display.value)) {\r\n            if (typeof (displayOnEmpty) === 'function') {\r\n              result.display.hasHtml = true;\r\n              result.display.html = displayOnEmpty(rowData, column);\r\n            } else {\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<div class=\"T16R text-black400\">--</div>`;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n    // Badge\r\n    if ((column.type === 'string' || column.type === 'number' || column.type === 'values') && column.badge) {\r\n      result.badge = {\r\n        type: !column?.badgeType ? 'round' : column.badgeType,\r\n        color: column.badge(value, rowData),\r\n        icon: column?.badgeIcon?.(value, rowData)\r\n      };\r\n    } else if (column.type === 'bool') {\r\n      result.badge = {\r\n        type: !column?.badgeType ? 'round' : column.badgeType,\r\n        color: !!value ? 'success' : 'danger',\r\n        icon: null\r\n      };\r\n    }\r\n    // Tooltip\r\n    if (typeof (tooltip) === 'function') {\r\n      result.tooltip = tooltip(value, rowData);\r\n    }\r\n    // Clickable\r\n    if (typeof (click) === 'function') {\r\n      result.click = () => click(value, rowData);\r\n    }\r\n    return result;\r\n  }\r\n}\r\n"]}
179
+ //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell-view.pipe.js","sourceRoot":"C:/Users/nghiatt15_onemount/Documents/lib-core-ui/projects/sd-core/grid-material/","sources":["src/lib/pipes/cell-view.pipe.ts"],"names":[],"mappings":"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","sourcesContent":["import { Pipe, PipeTransform } from '@angular/core';\r\nimport { SdUtilityService } from '@sd-angular/core/utility';\r\nimport { DeviceDetectorService } from 'ngx-device-detector';\r\nimport { SdCellView } from '../models/grid-cell.model';\r\nimport { SdGridMaterialColumn } from '../models/grid-column.model';\r\nimport { SdGridMaterialOption } from '../models/grid-option.model';\r\nimport { SdColumnValuesPipe } from './column-values.pipe';\r\n@Pipe({\r\n  name: 'cellView'\r\n})\r\nexport class SdCellViewPipe implements PipeTransform {\r\n  #maxSecond = 60;\r\n  #maxMinute = this.#maxSecond * 60;\r\n  #maxHour = this.#maxMinute * 24;\r\n  #maxDay = this.#maxHour * 30;\r\n  #maxMonth = this.#maxHour * 365;\r\n  #isMobileOrTablet = false;\r\n  constructor(\r\n    deviceService: DeviceDetectorService,\r\n    private utilityService: SdUtilityService,\r\n    private columnValuesPipe: SdColumnValuesPipe) {\r\n    this.#isMobileOrTablet = !deviceService.isDesktop();\r\n  }\r\n  async transform(\r\n    value: any,\r\n    rowData: any,\r\n    column: SdGridMaterialColumn,\r\n    gridOption: SdGridMaterialOption): Promise<SdCellView> {\r\n    const { displayOnEmpty } = gridOption;\r\n    const { align, click, tooltip, htmlTemplate, transform } = column;\r\n    const result: SdCellView = {\r\n      badge: null,\r\n      tooltip: null,\r\n      display: {\r\n        align: align || (column.type === 'number' ? 'right' : 'left'),\r\n        value\r\n      },\r\n      click: null\r\n    };\r\n    // Display\r\n    if (typeof (htmlTemplate) === 'function') {\r\n      result.display.hasHtml = true;\r\n      result.display.html = htmlTemplate(value, rowData, this.#isMobileOrTablet);\r\n    } else {\r\n      if (column.type === 'datetime' || column.type === 'date' || column.type === 'time') {\r\n        const { transformDate } = column;\r\n        if (transformDate) {\r\n          value = transformDate(value, rowData);\r\n        }\r\n      }\r\n      if (typeof (transform) === 'function') {\r\n        const val = transform(value, rowData);\r\n        if (val instanceof Promise) {\r\n          result.display.value = await val;\r\n        } else {\r\n          result.display.value = val;\r\n        }\r\n      } else {\r\n        if (column.type === 'date' || column.type === 'datetime') {\r\n          const { option } = column;\r\n          const seconds = Math.round((new Date().getTime() - new Date(value).getTime()) / 1000);\r\n          if (option?.timeDifferent === 'month' && seconds < this.#maxMonth) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'day' && seconds < this.#maxDay) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'hour' && seconds < this.#maxHour) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'minute' && seconds < this.#maxMinute) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else if (option?.timeDifferent === 'second' && seconds < this.#maxSecond) {\r\n            result.display.value = this.utilityService.timeDifference(value);\r\n            result.tooltip = Date.toFormat(value, column.type === 'date' ? 'dd/MM/yyyy' : 'dd/MM/yyyy HH:mm');\r\n          } else {\r\n            const date = Date.toFormat(value, 'dd/MM/yyyy');\r\n            const time = Date.toFormat(value, 'HH:mm');\r\n            const dateTime = Date.toFormat(value, 'HH:mm');\r\n            if (column.type === 'datetime' && time && time !== '00:00') {\r\n              result.display.value = dateTime;\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<span class=\"d-block T14R text-black400\">${Date.toFormat(value, 'HH:mm')}</span><span class=\"d-block T14R\">${Date.toFormat(value, 'dd/MM/yyyy')}</span>`;\r\n            } else {\r\n              result.display.value = date;\r\n            }\r\n          }\r\n        }\r\n        if (column.type === 'time') {\r\n          result.display.value = Date.toFormat(value, 'HH:mm');\r\n        }\r\n        if (column.type === 'values') {\r\n          result.display.value = await this.columnValuesPipe.transform(value, column);\r\n        } else if (column.type === 'number' && Number.isNumber(value)) {\r\n          result.display.value = Number.toVNCurrency(value);\r\n        }\r\n        if (column.type === 'bool') {\r\n          const { option } = column;\r\n          if (value !== undefined && value !== null && value !== '') {\r\n            result.display.value = value === true ? (option?.displayOnTrue || 'True') : (option?.displayOnFalse || 'False');\r\n          } else {\r\n            result.display.value = null;\r\n          }\r\n        }\r\n      }\r\n      if (displayOnEmpty) {\r\n        let values = [null, undefined, ''];\r\n        if (typeof (displayOnEmpty) === 'object') {\r\n          const { display, emptyValues } = displayOnEmpty;\r\n          values = [null, undefined, '', ...emptyValues];\r\n          if (values.includes(result.display.value)) {\r\n            if (typeof (display) === 'function') {\r\n              result.display.hasHtml = true;\r\n              result.display.html = display(rowData, column);\r\n            } else {\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<div class=\"T16R text-black400\">--</div>`;\r\n            }\r\n          }\r\n        } else {\r\n          if (values.includes(result.display.value)) {\r\n            if (typeof (displayOnEmpty) === 'function') {\r\n              result.display.hasHtml = true;\r\n              result.display.html = displayOnEmpty(rowData, column);\r\n            } else {\r\n              result.display.hasHtml = true;\r\n              result.display.html = `<div class=\"T16R text-black400\">--</div>`;\r\n            }\r\n          }\r\n        }\r\n      }\r\n    }\r\n    // Badge\r\n    if ((column.type === 'string' || column.type === 'number' || column.type === 'values') && column.badge) {\r\n      result.badge = {\r\n        type: !column?.badgeType ? 'round' : column.badgeType,\r\n        color: column.badge(value, rowData),\r\n        icon: column?.badgeIcon?.(value, rowData)\r\n      };\r\n    } else if (column.type === 'bool') {\r\n      result.badge = {\r\n        type: !column?.badgeType ? 'round' : column.badgeType,\r\n        color: !!value ? 'success' : 'danger',\r\n        icon: null\r\n      };\r\n    }\r\n    // Tooltip\r\n    if (typeof (tooltip) === 'function') {\r\n      result.tooltip = tooltip(value, rowData);\r\n    }\r\n    // Clickable\r\n    if (typeof (click) === 'function') {\r\n      result.click = () => click(value, rowData);\r\n    }\r\n    return result;\r\n  }\r\n}\r\n"]}
@@ -2,6 +2,7 @@ var _subsctiption;
2
2
  import { __classPrivateFieldGet } from "tslib";
3
3
  import { ChangeDetectionStrategy, ChangeDetectorRef, Component, Input, } from "@angular/core";
4
4
  import { Subscription } from "rxjs";
5
+ import { debounceTime } from "rxjs/operators";
5
6
  import { SdTabRouterService } from "../../services/tab-router.service";
6
7
  export class SdTabRouterItemComponent {
7
8
  constructor(cdRef, tabRouterService) {
@@ -15,7 +16,9 @@ export class SdTabRouterItemComponent {
15
16
  };
16
17
  }
17
18
  ngOnInit() {
18
- __classPrivateFieldGet(this, _subsctiption).add(this.tabRouterService.events.subscribe(() => this.cdRef.markForCheck()));
19
+ __classPrivateFieldGet(this, _subsctiption).add(this.tabRouterService.events.pipe(debounceTime(100)).subscribe(() => {
20
+ this.cdRef.markForCheck();
21
+ }));
19
22
  }
20
23
  ngOnDestroy() {
21
24
  __classPrivateFieldGet(this, _subsctiption).unsubscribe();
@@ -37,4 +40,4 @@ SdTabRouterItemComponent.ctorParameters = () => [
37
40
  SdTabRouterItemComponent.propDecorators = {
38
41
  tab: [{ type: Input }]
39
42
  };
40
- //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvdGFiLXJvdXRlci8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy90YWItcm91dGVyLWl0ZW0vdGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxLQUFLLEdBR04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUdwQyxPQUFPLEVBQUUsa0JBQWtCLEVBQUUsTUFBTSxtQ0FBbUMsQ0FBQztBQVF2RSxNQUFNLE9BQU8sd0JBQXdCO0lBS25DLFlBQ1UsS0FBd0IsRUFDeEIsZ0JBQW9DO1FBRHBDLFVBQUssR0FBTCxLQUFLLENBQW1CO1FBQ3hCLHFCQUFnQixHQUFoQixnQkFBZ0IsQ0FBb0I7UUFKOUMsd0JBQThCLElBQUksWUFBWSxFQUFFLEVBQUM7UUFtQmpELFVBQUssR0FBRyxDQUFDLEtBQVksRUFBRSxFQUFFO1lBQ3ZCLEtBQUssQ0FBQyxjQUFjLEVBQUUsQ0FBQztZQUN2QixLQUFLLENBQUMsZUFBZSxFQUFFLENBQUM7WUFDeEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLEtBQUssQ0FBQyxJQUFJLENBQUMsR0FBRyxDQUFDLENBQUM7UUFDeEMsQ0FBQyxDQUFDO0lBbEJDLENBQUM7SUFFSixRQUFRO1FBQ04sNENBQW1CLEdBQUcsQ0FDcEIsSUFBSSxDQUFDLGdCQUFnQixDQUFDLE1BQU0sQ0FBQyxTQUFTLENBQUMsR0FBRyxFQUFFLENBQzFDLElBQUksQ0FBQyxLQUFLLENBQUMsWUFBWSxFQUFFLENBQzFCLENBQ0YsQ0FBQztJQUNKLENBQUM7SUFFRCxXQUFXO1FBQ1QsNENBQW1CLFdBQVcsRUFBRSxDQUFDO0lBQ25DLENBQUM7Ozs7WUExQkYsU0FBUyxTQUFDO2dCQUNULFFBQVEsRUFBRSxvQkFBb0I7Z0JBQzlCLHd1Q0FBK0M7Z0JBRS9DLGVBQWUsRUFBRSx1QkFBdUIsQ0FBQyxNQUFNOzthQUNoRDs7O1lBaEJDLGlCQUFpQjtZQVNWLGtCQUFrQjs7O2tCQVN4QixLQUFLIiwic291cmNlc0NvbnRlbnQiOlsiaW1wb3J0IHtcclxuICBDaGFuZ2VEZXRlY3Rpb25TdHJhdGVneSxcclxuICBDaGFuZ2VEZXRlY3RvclJlZixcclxuICBDb21wb25lbnQsXHJcbiAgSW5wdXQsXHJcbiAgT25EZXN0cm95LFxyXG4gIE9uSW5pdCxcclxufSBmcm9tIFwiQGFuZ3VsYXIvY29yZVwiO1xyXG5pbXBvcnQgeyBTdWJzY3JpcHRpb24gfSBmcm9tIFwicnhqc1wiO1xyXG5cclxuaW1wb3J0IHsgU2RUYWIgfSBmcm9tIFwiLi4vLi4vbW9kZWxzL3RhYi1yb3V0ZXIubW9kZWxcIjtcclxuaW1wb3J0IHsgU2RUYWJSb3V0ZXJTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL3NlcnZpY2VzL3RhYi1yb3V0ZXIuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwic2QtdGFiLXJvdXRlci1pdGVtXCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi90YWItcm91dGVyLWl0ZW0uY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vdGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC5zY3NzXCJdLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RUYWJSb3V0ZXJJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gIEBJbnB1dCgpIHRhYjogU2RUYWI7XHJcblxyXG4gICNzdWJzY3RpcHRpb246IFN1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb24oKTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGNkUmVmOiBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgIHByaXZhdGUgdGFiUm91dGVyU2VydmljZTogU2RUYWJSb3V0ZXJTZXJ2aWNlXHJcbiAgKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuI3N1YnNjdGlwdGlvbi5hZGQoXHJcbiAgICAgIHRoaXMudGFiUm91dGVyU2VydmljZS5ldmVudHMuc3Vic2NyaWJlKCgpID0+XHJcbiAgICAgICAgdGhpcy5jZFJlZi5tYXJrRm9yQ2hlY2soKVxyXG4gICAgICApXHJcbiAgICApO1xyXG4gIH1cclxuXHJcbiAgbmdPbkRlc3Ryb3koKTogdm9pZCB7XHJcbiAgICB0aGlzLiNzdWJzY3RpcHRpb24udW5zdWJzY3JpYmUoKTtcclxuICB9XHJcblxyXG4gIGNsb3NlID0gKGV2ZW50OiBFdmVudCkgPT4ge1xyXG4gICAgZXZlbnQucHJldmVudERlZmF1bHQoKTtcclxuICAgIGV2ZW50LnN0b3BQcm9wYWdhdGlvbigpO1xyXG4gICAgdGhpcy50YWJSb3V0ZXJTZXJ2aWNlLmNsb3NlKHRoaXMudGFiKTtcclxuICB9O1xyXG59XHJcbiJdfQ==
43
+ //# sourceMappingURL=data:application/json;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoidGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC5qcyIsInNvdXJjZVJvb3QiOiJDOi9Vc2Vycy9uZ2hpYXR0MTVfb25lbW91bnQvRG9jdW1lbnRzL2xpYi1jb3JlLXVpL3Byb2plY3RzL3NkLWNvcmUvdGFiLXJvdXRlci8iLCJzb3VyY2VzIjpbInNyYy9saWIvY29tcG9uZW50cy90YWItcm91dGVyLWl0ZW0vdGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC50cyJdLCJuYW1lcyI6W10sIm1hcHBpbmdzIjoiOztBQUFBLE9BQU8sRUFDTCx1QkFBdUIsRUFDdkIsaUJBQWlCLEVBQ2pCLFNBQVMsRUFDVCxLQUFLLEdBR04sTUFBTSxlQUFlLENBQUM7QUFDdkIsT0FBTyxFQUFFLFlBQVksRUFBRSxNQUFNLE1BQU0sQ0FBQztBQUNwQyxPQUFPLEVBQUUsWUFBWSxFQUFFLE1BQU0sZ0JBQWdCLENBQUM7QUFHOUMsT0FBTyxFQUFFLGtCQUFrQixFQUFFLE1BQU0sbUNBQW1DLENBQUM7QUFRdkUsTUFBTSxPQUFPLHdCQUF3QjtJQUtuQyxZQUNVLEtBQXdCLEVBQ3hCLGdCQUFvQztRQURwQyxVQUFLLEdBQUwsS0FBSyxDQUFtQjtRQUN4QixxQkFBZ0IsR0FBaEIsZ0JBQWdCLENBQW9CO1FBSjlDLHdCQUE4QixJQUFJLFlBQVksRUFBRSxFQUFDO1FBbUJqRCxVQUFLLEdBQUcsQ0FBQyxLQUFZLEVBQUUsRUFBRTtZQUN2QixLQUFLLENBQUMsY0FBYyxFQUFFLENBQUM7WUFDdkIsS0FBSyxDQUFDLGVBQWUsRUFBRSxDQUFDO1lBQ3hCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxLQUFLLENBQUMsSUFBSSxDQUFDLEdBQUcsQ0FBQyxDQUFDO1FBQ3hDLENBQUMsQ0FBQztJQWxCQyxDQUFDO0lBRUosUUFBUTtRQUNOLDRDQUFtQixHQUFHLENBQ3BCLElBQUksQ0FBQyxnQkFBZ0IsQ0FBQyxNQUFNLENBQUMsSUFBSSxDQUFDLFlBQVksQ0FBQyxHQUFHLENBQUMsQ0FBQyxDQUFDLFNBQVMsQ0FBQyxHQUFHLEVBQUU7WUFDbEUsSUFBSSxDQUFDLEtBQUssQ0FBQyxZQUFZLEVBQUUsQ0FBQztRQUM1QixDQUFDLENBQUMsQ0FDSCxDQUFDO0lBQ0osQ0FBQztJQUVELFdBQVc7UUFDVCw0Q0FBbUIsV0FBVyxFQUFFLENBQUM7SUFDbkMsQ0FBQzs7OztZQTFCRixTQUFTLFNBQUM7Z0JBQ1QsUUFBUSxFQUFFLG9CQUFvQjtnQkFDOUIsd3VDQUErQztnQkFFL0MsZUFBZSxFQUFFLHVCQUF1QixDQUFDLE1BQU07O2FBQ2hEOzs7WUFqQkMsaUJBQWlCO1lBVVYsa0JBQWtCOzs7a0JBU3hCLEtBQUsiLCJzb3VyY2VzQ29udGVudCI6WyJpbXBvcnQge1xyXG4gIENoYW5nZURldGVjdGlvblN0cmF0ZWd5LFxyXG4gIENoYW5nZURldGVjdG9yUmVmLFxyXG4gIENvbXBvbmVudCxcclxuICBJbnB1dCxcclxuICBPbkRlc3Ryb3ksXHJcbiAgT25Jbml0LFxyXG59IGZyb20gXCJAYW5ndWxhci9jb3JlXCI7XHJcbmltcG9ydCB7IFN1YnNjcmlwdGlvbiB9IGZyb20gXCJyeGpzXCI7XHJcbmltcG9ydCB7IGRlYm91bmNlVGltZSB9IGZyb20gXCJyeGpzL29wZXJhdG9yc1wiO1xyXG5cclxuaW1wb3J0IHsgU2RUYWIgfSBmcm9tIFwiLi4vLi4vbW9kZWxzL3RhYi1yb3V0ZXIubW9kZWxcIjtcclxuaW1wb3J0IHsgU2RUYWJSb3V0ZXJTZXJ2aWNlIH0gZnJvbSBcIi4uLy4uL3NlcnZpY2VzL3RhYi1yb3V0ZXIuc2VydmljZVwiO1xyXG5cclxuQENvbXBvbmVudCh7XHJcbiAgc2VsZWN0b3I6IFwic2QtdGFiLXJvdXRlci1pdGVtXCIsXHJcbiAgdGVtcGxhdGVVcmw6IFwiLi90YWItcm91dGVyLWl0ZW0uY29tcG9uZW50Lmh0bWxcIixcclxuICBzdHlsZVVybHM6IFtcIi4vdGFiLXJvdXRlci1pdGVtLmNvbXBvbmVudC5zY3NzXCJdLFxyXG4gIGNoYW5nZURldGVjdGlvbjogQ2hhbmdlRGV0ZWN0aW9uU3RyYXRlZ3kuT25QdXNoLFxyXG59KVxyXG5leHBvcnQgY2xhc3MgU2RUYWJSb3V0ZXJJdGVtQ29tcG9uZW50IGltcGxlbWVudHMgT25Jbml0LCBPbkRlc3Ryb3kge1xyXG4gIEBJbnB1dCgpIHRhYjogU2RUYWI7XHJcblxyXG4gICNzdWJzY3RpcHRpb246IFN1YnNjcmlwdGlvbiA9IG5ldyBTdWJzY3JpcHRpb24oKTtcclxuXHJcbiAgY29uc3RydWN0b3IoXHJcbiAgICBwcml2YXRlIGNkUmVmOiBDaGFuZ2VEZXRlY3RvclJlZixcclxuICAgIHByaXZhdGUgdGFiUm91dGVyU2VydmljZTogU2RUYWJSb3V0ZXJTZXJ2aWNlXHJcbiAgKSB7fVxyXG5cclxuICBuZ09uSW5pdCgpOiB2b2lkIHtcclxuICAgIHRoaXMuI3N1YnNjdGlwdGlvbi5hZGQoXHJcbiAgICAgIHRoaXMudGFiUm91dGVyU2VydmljZS5ldmVudHMucGlwZShkZWJvdW5jZVRpbWUoMTAwKSkuc3Vic2NyaWJlKCgpID0+IHtcclxuICAgICAgICB0aGlzLmNkUmVmLm1hcmtGb3JDaGVjaygpO1xyXG4gICAgICB9KVxyXG4gICAgKTtcclxuICB9XHJcblxyXG4gIG5nT25EZXN0cm95KCk6IHZvaWQge1xyXG4gICAgdGhpcy4jc3Vic2N0aXB0aW9uLnVuc3Vic2NyaWJlKCk7XHJcbiAgfVxyXG5cclxuICBjbG9zZSA9IChldmVudDogRXZlbnQpID0+IHtcclxuICAgIGV2ZW50LnByZXZlbnREZWZhdWx0KCk7XHJcbiAgICBldmVudC5zdG9wUHJvcGFnYXRpb24oKTtcclxuICAgIHRoaXMudGFiUm91dGVyU2VydmljZS5jbG9zZSh0aGlzLnRhYik7XHJcbiAgfTtcclxufVxyXG4iXX0=
@@ -1695,7 +1695,9 @@ class SdGridMaterial {
1695
1695
  return;
1696
1696
  }
1697
1697
  if (column.transform) {
1698
- const transform = column.transform(item[column.field], item);
1698
+ const transform = column.transform(item[column.field], item, {
1699
+ isExport: true
1700
+ });
1699
1701
  if (transform instanceof Promise) {
1700
1702
  obj[column.field] = yield transform;
1701
1703
  }
@@ -2243,6 +2245,15 @@ class SdGridMaterial {
2243
2245
  return result;
2244
2246
  });
2245
2247
  }
2248
+ get localItems() {
2249
+ return __classPrivateFieldGet(this, _localItems);
2250
+ }
2251
+ get localGridItems() {
2252
+ return __classPrivateFieldGet(this, _localItems).map(item => {
2253
+ const { editorStatus, editorHandlerRow, editorHandlerColumn, expandDetail, isExpanded, isExpanding, isSelected, originItem, sdId, sdVersion, selectable, actions, groupedActions, sdGroup, temporary } = item, result = __rest(item, ["editorStatus", "editorHandlerRow", "editorHandlerColumn", "expandDetail", "isExpanded", "isExpanding", "isSelected", "originItem", "sdId", "sdVersion", "selectable", "actions", "groupedActions", "sdGroup", "temporary"]);
2254
+ return result;
2255
+ });
2256
+ }
2246
2257
  get isEditing() {
2247
2258
  return this.items.some(e => e.editorStatus !== undefined);
2248
2259
  }
@@ -2442,7 +2453,7 @@ class SdDesktopCellView {
2442
2453
  SdDesktopCellView.decorators = [
2443
2454
  { type: Component, args: [{
2444
2455
  selector: 'sd-desktop-cell-view',
2445
- template: "<ng-container *ngIf=\"item[column.field] | cellView:item:column:gridOption:key | async as view\">\r\n <ng-container *ngIf=\"view.display.hasHtml;else useValue\">\r\n <div *ngIf=\"view.click\" (click)=\"view.click()\" class=\"text-break cursor-pointer\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n <div *ngIf=\"!view.click\" class=\"text-break\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useValue>\r\n <ng-container *ngIf=\"!!view.badge; else noBadge\">\r\n <sd-badge *ngIf=\"view.display.value\" [type]=\"view.badge.type\" [title]=\"view.display.value\" [color]=\"view.badge.color\"\r\n [icon]=\"view.badge.icon\" [tooltip]=\"view.tooltip\" (sdClick)=\"!!view.click && view.click()\"></sd-badge>\r\n </ng-container>\r\n <ng-template #noBadge>\r\n <ng-container *ngIf=\"column.type !== 'children'; else childrenView\">\r\n <div *ngIf=\"column.type !== 'image'\" class=\"text-break\" [class.text-center]=\"view.display.align === 'center'\"\r\n [class.text-right]=\"view.display.align === 'right'\" [matTooltip]=\"view.tooltip\">\r\n <a *ngIf=\"!!view.click\" href=\"javascript:;\" (click)=\"view.click()\">{{view.display.value}}</a>\r\n <ng-container *ngIf=\"!view.click\">{{view.display.value}}\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"view.display.value\" [src]=\"view.display.value\" [width]=\"column.option?.width\"\r\n [height]=\"column.option?.height\" class=\"c-image\" (click)=\"!!view.click && view.click()\"\r\n [class.cursor-pointer]=\"!!view.click\">\r\n <mat-icon *ngIf=\"!view.display.value\" class=\"c-img\" [class.cursor-pointer]=\"!!view.click\"\r\n (click)=\"!!view.click && view.click()\">\r\n image</mat-icon>\r\n </div>\r\n </ng-container>\r\n <ng-template #childrenView>\r\n <sd-desktop-cell-children-view [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n </ng-template>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>",
2456
+ template: "<ng-container *ngIf=\"item[column.field] | cellView:item:column:gridOption | async as view\">\r\n <ng-container *ngIf=\"view.display.hasHtml;else useValue\">\r\n <div *ngIf=\"view.click\" (click)=\"view.click()\" class=\"text-break cursor-pointer\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n <div *ngIf=\"!view.click\" class=\"text-break\" [matTooltip]=\"view.tooltip\"\r\n [class.text-center]=\"view.display.align === 'center'\" [class.text-right]=\"view.display.align === 'right'\"\r\n [innerHTML]=\"view.display.html | safeHtml\">\r\n </div>\r\n </ng-container>\r\n <ng-template #useValue>\r\n <ng-container *ngIf=\"!!view.badge; else noBadge\">\r\n <sd-badge *ngIf=\"view.display.value\" [type]=\"view.badge.type\" [title]=\"view.display.value\" [color]=\"view.badge.color\"\r\n [icon]=\"view.badge.icon\" [tooltip]=\"view.tooltip\" (sdClick)=\"!!view.click && view.click()\"></sd-badge>\r\n </ng-container>\r\n <ng-template #noBadge>\r\n <ng-container *ngIf=\"column.type !== 'children'; else childrenView\">\r\n <div *ngIf=\"column.type !== 'image'\" class=\"text-break\" [class.text-center]=\"view.display.align === 'center'\"\r\n [class.text-right]=\"view.display.align === 'right'\" [matTooltip]=\"view.tooltip\">\r\n <a *ngIf=\"!!view.click\" href=\"javascript:;\" (click)=\"view.click()\">{{view.display.value}}</a>\r\n <ng-container *ngIf=\"!view.click\">{{view.display.value}}\r\n </ng-container>\r\n </div>\r\n <div *ngIf=\"column.type === 'image'\" class=\"align-middle text-center\">\r\n <img *ngIf=\"view.display.value\" [src]=\"view.display.value\" [width]=\"column.option?.width\"\r\n [height]=\"column.option?.height\" class=\"c-image\" (click)=\"!!view.click && view.click()\"\r\n [class.cursor-pointer]=\"!!view.click\">\r\n <mat-icon *ngIf=\"!view.display.value\" class=\"c-img\" [class.cursor-pointer]=\"!!view.click\"\r\n (click)=\"!!view.click && view.click()\">\r\n image</mat-icon>\r\n </div>\r\n </ng-container>\r\n <ng-template #childrenView>\r\n <sd-desktop-cell-children-view [key]=\"key\" [item]=\"item\" [column]=\"column\">\r\n </sd-desktop-cell-children-view>\r\n </ng-template>\r\n </ng-template>\r\n </ng-template>\r\n</ng-container>",
2446
2457
  changeDetection: ChangeDetectionStrategy.OnPush,
2447
2458
  styles: [".text-black400{color:#757575}.c-color-success{color:#4caf50}.c-color-danger{color:#f82c13}.c-image{-o-object-fit:contain;margin:5px 0;object-fit:contain}.c-img{font-size:30px;opacity:.5}.c-img.pointer:hover{opacity:.9}"]
2448
2459
  },] }
@@ -3480,7 +3491,7 @@ class SdCellViewPipe {
3480
3491
  _isMobileOrTablet$1.set(this, false);
3481
3492
  __classPrivateFieldSet(this, _isMobileOrTablet$1, !deviceService.isDesktop());
3482
3493
  }
3483
- transform(value, rowData, column, gridOption, key) {
3494
+ transform(value, rowData, column, gridOption) {
3484
3495
  var _a;
3485
3496
  return __awaiter(this, void 0, void 0, function* () {
3486
3497
  const { displayOnEmpty } = gridOption;