UNPKG

@delon/abc

Version:

Common business components of ng-alain.

167 lines 21.8 kB
import { Injectable, inject } from '@angular/core'; import { DomSanitizer } from '@angular/platform-browser'; import { map, of } from 'rxjs'; import { yn } from '@delon/theme'; import { formatDate } from '@delon/util/date-time'; import { CurrencyService, formatMask } from '@delon/util/format'; import { deepMerge } from '@delon/util/other'; import { NzI18nService } from 'ng-zorro-antd/i18n'; import * as i0 from "@angular/core"; import * as i1 from "@delon/util/config"; export class CellService { constructor(configSrv) { this.nzI18n = inject(NzI18nService); this.currency = inject(CurrencyService); this.dom = inject(DomSanitizer); this.widgets = { date: { type: 'fn', ref: (value, opt) => { return { text: formatDate(value, opt.date.format, this.nzI18n.getDateLocale()) }; } }, mega: { type: 'fn', ref: (value, opt) => { const res = this.currency.mega(value, opt.mega); return { text: res.value, unit: res.unitI18n }; } }, currency: { type: 'fn', ref: (value, opt) => { return { text: this.currency.format(value, opt.currency) }; } }, cny: { type: 'fn', ref: (value, opt) => { return { text: this.currency.cny(value, opt.cny) }; } }, boolean: { type: 'fn', ref: (value, opt) => { return { text: this.dom.bypassSecurityTrustHtml(yn(value, opt.boolean)) }; } }, img: { type: 'fn', ref: value => { return { text: Array.isArray(value) ? value : [value] }; } } }; this.globalOptions = configSrv.merge('cell', { date: { format: 'yyyy-MM-dd HH:mm:ss' }, img: { size: 32 }, default: { text: '-' } }); } registerWidget(key, widget) { this.widgets[key] = { type: 'widget', ref: widget }; } getWidget(key) { return this.widgets[key]; } genType(value, options) { if (options.type != null) return options.type; const typeOf = typeof value; // When is timestamp if (typeOf === 'number' && /^[0-9]{13}$/g.test(value)) return 'date'; if (value instanceof Date || options.date != null) return 'date'; // Auto detection if (options.widget != null) return 'widget'; else if (options.mega != null) return 'mega'; else if (options.currency != null) return 'currency'; else if (options.cny != null) return 'cny'; else if (options.img != null) return 'img'; else if (options.link != null) return 'link'; else if (options.html != null) return 'html'; else if (options.badge != null) return 'badge'; else if (options.tag != null) return 'tag'; else if (options.checkbox != null) return 'checkbox'; else if (options.radio != null) return 'radio'; else if (options.enum != null) return 'enum'; else if (typeOf === 'number') return 'number'; else if (typeOf === 'boolean' || options.boolean != null) return 'boolean'; else return 'string'; } fixOptions(options) { return deepMerge({}, this.globalOptions, options); } get(value, options) { const type = this.genType(value, { ...options }); const opt = this.fixOptions(options); opt.type = type; const isSafeHtml = typeof value === 'object' && typeof value?.getTypeName === 'function' && value?.getTypeName() != null; let res = { result: typeof value === 'object' && !isSafeHtml ? value : { text: value == null ? '' : isSafeHtml ? value : `${value}` }, options: opt }; const widget = this.widgets[type]; if (widget?.type === 'fn') { res.result = widget.ref(value, opt); } return (typeof value === 'function' ? value(value, opt) : of(res.result)).pipe(map(text => { res.result = text; let dictData; switch (type) { case 'badge': dictData = (opt.badge?.data ?? {})[value]; res.result = { color: 'default', ...dictData }; break; case 'tag': dictData = (opt.tag?.data ?? {})[value]; res.result = dictData; break; case 'enum': res.result = { text: (opt.enum ?? {})[value] }; break; case 'html': res.safeHtml = opt.html?.safe; break; case 'string': if (isSafeHtml) res.safeHtml = 'safeHtml'; break; } if ((type === 'badge' || type === 'tag') && dictData?.tooltip != null) { res.options.tooltip = dictData.tooltip; } if (opt.mask != null) { res.result.text = formatMask(res.result.text, opt.mask); } return res; })); } static { this.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: CellService, deps: [{ token: i1.AlainConfigService }], target: i0.ɵɵFactoryTarget.Injectable }); } static { this.ɵprov = i0.ɵɵngDeclareInjectable({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: CellService, providedIn: 'root' }); } } i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "18.0.5", ngImport: i0, type: CellService, decorators: [{ type: Injectable, args: [{ providedIn: 'root' }] }], ctorParameters: () => [{ type: i1.AlainConfigService }] }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"cell.service.js","sourceRoot":"","sources":["../../../../../packages/abc/cell/cell.service.ts"],"names":[],"mappings":"AAAA,OAAO,EAAE,UAAU,EAAQ,MAAM,EAAE,MAAM,eAAe,CAAC;AACzD,OAAO,EAAE,YAAY,EAAE,MAAM,2BAA2B,CAAC;AACzD,OAAO,EAAE,GAAG,EAAc,EAAE,EAAE,MAAM,MAAM,CAAC;AAE3C,OAAO,EAAE,EAAE,EAAE,MAAM,cAAc,CAAC;AAElC,OAAO,EAAE,UAAU,EAAE,MAAM,uBAAuB,CAAC;AACnD,OAAO,EAAE,eAAe,EAAE,UAAU,EAAE,MAAM,oBAAoB,CAAC;AACjE,OAAO,EAAE,SAAS,EAAE,MAAM,mBAAmB,CAAC;AAE9C,OAAO,EAAE,aAAa,EAAE,MAAM,oBAAoB,CAAC;;;AAanD,MAAM,OAAO,WAAW;IA6CtB,YAAY,SAA6B;QA5CxB,WAAM,GAAG,MAAM,CAAC,aAAa,CAAC,CAAC;QAC/B,aAAQ,GAAG,MAAM,CAAC,eAAe,CAAC,CAAC;QACnC,QAAG,GAAG,MAAM,CAAC,YAAY,CAAC,CAAC;QAEpC,YAAO,GAAkC;YAC/C,IAAI,EAAE;gBACJ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAClB,OAAO,EAAE,IAAI,EAAE,UAAU,CAAC,KAAe,EAAE,GAAG,CAAC,IAAK,CAAC,MAAO,EAAE,IAAI,CAAC,MAAM,CAAC,aAAa,EAAE,CAAC,EAAE,CAAC;gBAC/F,CAAC;aACF;YACD,IAAI,EAAE;gBACJ,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAClB,MAAM,GAAG,GAAG,IAAI,CAAC,QAAQ,CAAC,IAAI,CAAC,KAAe,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;oBAC1D,OAAO,EAAE,IAAI,EAAE,GAAG,CAAC,KAAK,EAAE,IAAI,EAAE,GAAG,CAAC,QAAQ,EAAE,CAAC;gBACjD,CAAC;aACF;YACD,QAAQ,EAAE;gBACR,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAClB,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,MAAM,CAAC,KAAe,EAAE,GAAG,CAAC,QAAQ,CAAC,EAAE,CAAC;gBACvE,CAAC;aACF;YACD,GAAG,EAAE;gBACH,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAClB,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,QAAQ,CAAC,GAAG,CAAC,KAAe,EAAE,GAAG,CAAC,GAAG,CAAC,EAAE,CAAC;gBAC/D,CAAC;aACF;YACD,OAAO,EAAE;gBACP,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,CAAC,KAAK,EAAE,GAAG,EAAE,EAAE;oBAClB,OAAO,EAAE,IAAI,EAAE,IAAI,CAAC,GAAG,CAAC,uBAAuB,CAAC,EAAE,CAAC,KAAgB,EAAE,GAAG,CAAC,OAAO,CAAC,CAAC,EAAE,CAAC;gBACvF,CAAC;aACF;YACD,GAAG,EAAE;gBACH,IAAI,EAAE,IAAI;gBACV,GAAG,EAAE,KAAK,CAAC,EAAE;oBACX,OAAO,EAAE,IAAI,EAAE,KAAK,CAAC,OAAO,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,CAAC,KAAK,CAAC,EAAE,CAAC;gBAC1D,CAAC;aACF;SACF,CAAC;QAGA,IAAI,CAAC,aAAa,GAAG,SAAS,CAAC,KAAK,CAAC,MAAM,EAAE;YAC3C,IAAI,EAAE,EAAE,MAAM,EAAE,qBAAqB,EAAE;YACvC,GAAG,EAAE,EAAE,IAAI,EAAE,EAAE,EAAE;YACjB,OAAO,EAAE,EAAE,IAAI,EAAE,GAAG,EAAE;SACvB,CAAE,CAAC;IACN,CAAC;IAED,cAAc,CAAC,GAAW,EAAE,MAAqB;QAC/C,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,EAAE,QAAQ,EAAE,GAAG,EAAE,MAAM,EAAE,CAAC;IACtD,CAAC;IAED,SAAS,CAAC,GAAW;QACnB,OAAO,IAAI,CAAC,OAAO,CAAC,GAAG,CAAC,CAAC;IAC3B,CAAC;IAEO,OAAO,CAAC,KAAc,EAAE,OAAoB;QAClD,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,OAAO,CAAC,IAAI,CAAC;QAE9C,MAAM,MAAM,GAAG,OAAO,KAAK,CAAC;QAC5B,oBAAoB;QACpB,IAAI,MAAM,KAAK,QAAQ,IAAI,cAAc,CAAC,IAAI,CAAC,KAAe,CAAC;YAAE,OAAO,MAAM,CAAC;QAC/E,IAAI,KAAK,YAAY,IAAI,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,MAAM,CAAC;QAEjE,iBAAiB;QACjB,IAAI,OAAO,CAAC,MAAM,IAAI,IAAI;YAAE,OAAO,QAAQ,CAAC;aACvC,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,MAAM,CAAC;aACxC,IAAI,OAAO,CAAC,QAAQ,IAAI,IAAI;YAAE,OAAO,UAAU,CAAC;aAChD,IAAI,OAAO,CAAC,GAAG,IAAI,IAAI;YAAE,OAAO,KAAK,CAAC;aACtC,IAAI,OAAO,CAAC,GAAG,IAAI,IAAI;YAAE,OAAO,KAAK,CAAC;aACtC,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,MAAM,CAAC;aACxC,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,MAAM,CAAC;aACxC,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI;YAAE,OAAO,OAAO,CAAC;aAC1C,IAAI,OAAO,CAAC,GAAG,IAAI,IAAI;YAAE,OAAO,KAAK,CAAC;aACtC,IAAI,OAAO,CAAC,QAAQ,IAAI,IAAI;YAAE,OAAO,UAAU,CAAC;aAChD,IAAI,OAAO,CAAC,KAAK,IAAI,IAAI;YAAE,OAAO,OAAO,CAAC;aAC1C,IAAI,OAAO,CAAC,IAAI,IAAI,IAAI;YAAE,OAAO,MAAM,CAAC;aACxC,IAAI,MAAM,KAAK,QAAQ;YAAE,OAAO,QAAQ,CAAC;aACzC,IAAI,MAAM,KAAK,SAAS,IAAI,OAAO,CAAC,OAAO,IAAI,IAAI;YAAE,OAAO,SAAS,CAAC;;YACtE,OAAO,QAAQ,CAAC;IACvB,CAAC;IAED,UAAU,CAAC,OAAqB;QAC9B,OAAO,SAAS,CAAC,EAAE,EAAE,IAAI,CAAC,aAAa,EAAE,OAAO,CAAC,CAAC;IACpD,CAAC;IAED,GAAG,CAAC,KAAc,EAAE,OAAqB;QACvC,MAAM,IAAI,GAAG,IAAI,CAAC,OAAO,CAAC,KAAK,EAAE,EAAE,GAAG,OAAO,EAAE,CAAC,CAAC;QACjD,MAAM,GAAG,GAAG,IAAI,CAAC,UAAU,CAAC,OAAO,CAAC,CAAC;QACrC,GAAG,CAAC,IAAI,GAAG,IAAI,CAAC;QAChB,MAAM,UAAU,GACd,OAAO,KAAK,KAAK,QAAQ;YACzB,OAAQ,KAAmB,EAAE,WAAW,KAAK,UAAU;YACtD,KAAmB,EAAE,WAAW,EAAE,IAAI,IAAI,CAAC;QAE9C,IAAI,GAAG,GAAmB;YACxB,MAAM,EACJ,OAAO,KAAK,KAAK,QAAQ,IAAI,CAAC,UAAU;gBACtC,CAAC,CAAE,KAAsB;gBACzB,CAAC,CAAC,EAAE,IAAI,EAAE,KAAK,IAAI,IAAI,CAAC,CAAC,CAAC,EAAE,CAAC,CAAC,CAAC,UAAU,CAAC,CAAC,CAAC,KAAK,CAAC,CAAC,CAAC,GAAG,KAAK,EAAE,EAAE;YACpE,OAAO,EAAE,GAAG;SACb,CAAC;QAEF,MAAM,MAAM,GAAG,IAAI,CAAC,OAAO,CAAC,IAAI,CAAC,CAAC;QAClC,IAAI,MAAM,EAAE,IAAI,KAAK,IAAI,EAAE,CAAC;YAC1B,GAAG,CAAC,MAAM,GAAI,MAAM,CAAC,GAAoB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC;QACxD,CAAC;QAED,OAAO,CAAC,OAAO,KAAK,KAAK,UAAU,CAAC,CAAC,CAAE,KAAqB,CAAC,KAAK,EAAE,GAAG,CAAC,CAAC,CAAC,CAAC,EAAE,CAAC,GAAG,CAAC,MAAM,CAAC,CAAC,CAAC,IAAI,CAC7F,GAAG,CAAC,IAAI,CAAC,EAAE;YACT,GAAG,CAAC,MAAM,GAAG,IAAI,CAAC;YAClB,IAAI,QAA0C,CAAC;YAC/C,QAAQ,IAAI,EAAE,CAAC;gBACb,KAAK,OAAO;oBACV,QAAQ,GAAG,CAAC,GAAG,CAAC,KAAK,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,KAAe,CAAC,CAAC;oBACpD,GAAG,CAAC,MAAM,GAAG,EAAE,KAAK,EAAE,SAAS,EAAE,GAAG,QAAQ,EAAE,CAAC;oBAC/C,MAAM;gBACR,KAAK,KAAK;oBACR,QAAQ,GAAG,CAAC,GAAG,CAAC,GAAG,EAAE,IAAI,IAAI,EAAE,CAAC,CAAC,KAAe,CAAC,CAAC;oBAClD,GAAG,CAAC,MAAM,GAAG,QAAwB,CAAC;oBACtC,MAAM;gBACR,KAAK,MAAM;oBACT,GAAG,CAAC,MAAM,GAAG,EAAE,IAAI,EAAE,CAAC,GAAG,CAAC,IAAI,IAAI,EAAE,CAAC,CAAC,KAAe,CAAC,EAAE,CAAC;oBACzD,MAAM;gBACR,KAAK,MAAM;oBACT,GAAG,CAAC,QAAQ,GAAG,GAAG,CAAC,IAAI,EAAE,IAAI,CAAC;oBAC9B,MAAM;gBACR,KAAK,QAAQ;oBACX,IAAI,UAAU;wBAAE,GAAG,CAAC,QAAQ,GAAG,UAAU,CAAC;oBAC1C,MAAM;YACV,CAAC;YACD,IAAI,CAAC,IAAI,KAAK,OAAO,IAAI,IAAI,KAAK,KAAK,CAAC,IAAI,QAAQ,EAAE,OAAO,IAAI,IAAI,EAAE,CAAC;gBACtE,GAAG,CAAC,OAAO,CAAC,OAAO,GAAG,QAAQ,CAAC,OAAO,CAAC;YACzC,CAAC;YACD,IAAI,GAAG,CAAC,IAAI,IAAI,IAAI,EAAE,CAAC;gBACrB,GAAG,CAAC,MAAM,CAAC,IAAI,GAAG,UAAU,CAAC,GAAG,CAAC,MAAM,CAAC,IAAc,EAAE,GAAG,CAAC,IAAI,CAAC,CAAC;YACpE,CAAC;YACD,OAAO,GAAG,CAAC;QACb,CAAC,CAAC,CACH,CAAC;IACJ,CAAC;8GAjJU,WAAW;kHAAX,WAAW,cADE,MAAM;;2FACnB,WAAW;kBADvB,UAAU;mBAAC,EAAE,UAAU,EAAE,MAAM,EAAE","sourcesContent":["import { Injectable, Type, inject } from '@angular/core';\nimport { DomSanitizer } from '@angular/platform-browser';\nimport { map, Observable, of } from 'rxjs';\n\nimport { yn } from '@delon/theme';\nimport { AlainCellConfig, AlainConfigService } from '@delon/util/config';\nimport { formatDate } from '@delon/util/date-time';\nimport { CurrencyService, formatMask } from '@delon/util/format';\nimport { deepMerge } from '@delon/util/other';\nimport type { NzSafeAny } from 'ng-zorro-antd/core/types';\nimport { NzI18nService } from 'ng-zorro-antd/i18n';\n\nimport type {\n  CellFuValue,\n  CellOptions,\n  CellTextResult,\n  CellTextUnit,\n  CellType,\n  CellWidget,\n  CellWidgetFn\n} from './cell.types';\n\n@Injectable({ providedIn: 'root' })\nexport class CellService {\n  private readonly nzI18n = inject(NzI18nService);\n  private readonly currency = inject(CurrencyService);\n  private readonly dom = inject(DomSanitizer);\n  private globalOptions!: AlainCellConfig;\n  private widgets: { [key: string]: CellWidget } = {\n    date: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: formatDate(value as string, opt.date!.format!, this.nzI18n.getDateLocale()) };\n      }\n    },\n    mega: {\n      type: 'fn',\n      ref: (value, opt) => {\n        const res = this.currency.mega(value as number, opt.mega);\n        return { text: res.value, unit: res.unitI18n };\n      }\n    },\n    currency: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.currency.format(value as number, opt.currency) };\n      }\n    },\n    cny: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.currency.cny(value as number, opt.cny) };\n      }\n    },\n    boolean: {\n      type: 'fn',\n      ref: (value, opt) => {\n        return { text: this.dom.bypassSecurityTrustHtml(yn(value as boolean, opt.boolean)) };\n      }\n    },\n    img: {\n      type: 'fn',\n      ref: value => {\n        return { text: Array.isArray(value) ? value : [value] };\n      }\n    }\n  };\n\n  constructor(configSrv: AlainConfigService) {\n    this.globalOptions = configSrv.merge('cell', {\n      date: { format: 'yyyy-MM-dd HH:mm:ss' },\n      img: { size: 32 },\n      default: { text: '-' }\n    })!;\n  }\n\n  registerWidget(key: string, widget: Type<unknown>): void {\n    this.widgets[key] = { type: 'widget', ref: widget };\n  }\n\n  getWidget(key: string): CellWidget | undefined {\n    return this.widgets[key];\n  }\n\n  private genType(value: unknown, options: CellOptions): CellType {\n    if (options.type != null) return options.type;\n\n    const typeOf = typeof value;\n    // When is timestamp\n    if (typeOf === 'number' && /^[0-9]{13}$/g.test(value as string)) return 'date';\n    if (value instanceof Date || options.date != null) return 'date';\n\n    // Auto detection\n    if (options.widget != null) return 'widget';\n    else if (options.mega != null) return 'mega';\n    else if (options.currency != null) return 'currency';\n    else if (options.cny != null) return 'cny';\n    else if (options.img != null) return 'img';\n    else if (options.link != null) return 'link';\n    else if (options.html != null) return 'html';\n    else if (options.badge != null) return 'badge';\n    else if (options.tag != null) return 'tag';\n    else if (options.checkbox != null) return 'checkbox';\n    else if (options.radio != null) return 'radio';\n    else if (options.enum != null) return 'enum';\n    else if (typeOf === 'number') return 'number';\n    else if (typeOf === 'boolean' || options.boolean != null) return 'boolean';\n    else return 'string';\n  }\n\n  fixOptions(options?: CellOptions): CellOptions {\n    return deepMerge({}, this.globalOptions, options);\n  }\n\n  get(value: unknown, options?: CellOptions): Observable<CellTextResult> {\n    const type = this.genType(value, { ...options });\n    const opt = this.fixOptions(options);\n    opt.type = type;\n    const isSafeHtml =\n      typeof value === 'object' &&\n      typeof (value as NzSafeAny)?.getTypeName === 'function' &&\n      (value as NzSafeAny)?.getTypeName() != null;\n\n    let res: CellTextResult = {\n      result:\n        typeof value === 'object' && !isSafeHtml\n          ? (value as CellTextUnit)\n          : { text: value == null ? '' : isSafeHtml ? value : `${value}` },\n      options: opt\n    };\n\n    const widget = this.widgets[type];\n    if (widget?.type === 'fn') {\n      res.result = (widget.ref as CellWidgetFn)(value, opt);\n    }\n\n    return (typeof value === 'function' ? (value as CellFuValue)(value, opt) : of(res.result)).pipe(\n      map(text => {\n        res.result = text;\n        let dictData: { tooltip?: string } | undefined;\n        switch (type) {\n          case 'badge':\n            dictData = (opt.badge?.data ?? {})[value as string];\n            res.result = { color: 'default', ...dictData };\n            break;\n          case 'tag':\n            dictData = (opt.tag?.data ?? {})[value as string];\n            res.result = dictData as CellTextUnit;\n            break;\n          case 'enum':\n            res.result = { text: (opt.enum ?? {})[value as string] };\n            break;\n          case 'html':\n            res.safeHtml = opt.html?.safe;\n            break;\n          case 'string':\n            if (isSafeHtml) res.safeHtml = 'safeHtml';\n            break;\n        }\n        if ((type === 'badge' || type === 'tag') && dictData?.tooltip != null) {\n          res.options.tooltip = dictData.tooltip;\n        }\n        if (opt.mask != null) {\n          res.result.text = formatMask(res.result.text as string, opt.mask);\n        }\n        return res;\n      })\n    );\n  }\n}\n"]}