@sd-angular/core 1.3.175 → 1.3.177

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 (35) hide show
  1. package/api/sd-angular-core-api.metadata.json +1 -1
  2. package/api/src/lib/api.service.d.ts +2 -2
  3. package/autocomplete/sd-angular-core-autocomplete.metadata.json +1 -1
  4. package/bundles/sd-angular-core-api.umd.js +147 -126
  5. package/bundles/sd-angular-core-api.umd.js.map +1 -1
  6. package/bundles/sd-angular-core-api.umd.min.js +1 -1
  7. package/bundles/sd-angular-core-api.umd.min.js.map +1 -1
  8. package/bundles/sd-angular-core-autocomplete.umd.js +1 -1
  9. package/bundles/sd-angular-core-autocomplete.umd.min.js +1 -1
  10. package/bundles/sd-angular-core-autocomplete.umd.min.js.map +1 -1
  11. package/bundles/sd-angular-core-chart.umd.js +1 -1
  12. package/bundles/sd-angular-core-chart.umd.min.js +1 -1
  13. package/bundles/sd-angular-core-chart.umd.min.js.map +1 -1
  14. package/bundles/sd-angular-core-image-preview.umd.js +1 -1
  15. package/bundles/sd-angular-core-image-preview.umd.min.js +1 -1
  16. package/bundles/sd-angular-core-image-preview.umd.min.js.map +1 -1
  17. package/bundles/sd-angular-core-table.umd.js +1 -1
  18. package/bundles/sd-angular-core-table.umd.min.js +1 -1
  19. package/bundles/sd-angular-core-table.umd.min.js.map +1 -1
  20. package/chart/sd-angular-core-chart.metadata.json +1 -1
  21. package/esm2015/api/src/lib/api.service.js +51 -51
  22. package/esm2015/autocomplete/src/lib/autocomplete.component.js +1 -1
  23. package/esm2015/chart/src/lib/chart.component.js +1 -1
  24. package/esm2015/image-preview/src/lib/image-preview/image-preview-sdmodal.component.js +1 -1
  25. package/esm2015/table/src/lib/table.component.js +1 -1
  26. package/fesm2015/sd-angular-core-api.js +50 -50
  27. package/fesm2015/sd-angular-core-api.js.map +1 -1
  28. package/fesm2015/sd-angular-core-autocomplete.js +1 -1
  29. package/fesm2015/sd-angular-core-chart.js +1 -1
  30. package/fesm2015/sd-angular-core-image-preview.js +1 -1
  31. package/fesm2015/sd-angular-core-table.js +1 -1
  32. package/image-preview/sd-angular-core-image-preview.metadata.json +1 -1
  33. package/package.json +1 -1
  34. package/{sd-angular-core-1.3.175.tgz → sd-angular-core-1.3.177.tgz} +0 -0
  35. package/table/sd-angular-core-table.metadata.json +1 -1
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/chart/src/lib/chart.model.ts","../../../../projects/sd-core/chart/src/lib/chart.component.ts","../../../../projects/sd-core/chart/src/lib/chart.module.ts"],"names":["__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__classPrivateFieldGet","receiver","state","kind","has","get","CHART_CONFIG","InjectionToken","SdChart","ref","chartConfiguration","_this","initialized","isLoading","visible","height","loadingStart","_drawTotalOfStackedBar","set","chartType","afterDraw","chartInstance","easing","options","_b","_a","data","datasets","ctx_1","ctx","forEach","dataPoint","index","curLastIndex","curTotal","dataset","setIndex","hidden","type","Number","isNumber","_l","getDatasetMeta","_model","x","textWidth","measureText","toString","width","fillStyle","xTextPosition","font","fillText","defineProperty","prototype","chartOption","pChartOption","renderChart","ngOnInit","ngAfterViewInit","detectChanges","firstRender","setTimeout","chartRef","nativeElement","canvas","getContext","renderPieChart","renderBarChart","renderHorizontalBarChart","renderLineChart","renderStackAreaChart","renderBarLineChart","renderDoughnutChart","option","configuration","responsive","title","display","text","legend","hideLegend","tooltips","callbacks","tooltipItem","datasetLabel","datasetIndex","labels","_c","toVNCurrency","map","backgroundColor","idx","defaultColors","dynamicColor","hover","assign","mode","intersect","chart","Chart","maintainAspectRatio","labelWidth","newwidth","$","chartAreaWrapperExtendRef","css","scales","xAxes","scaleLabel","xTitle","labelString","ticks","callback","xLabel","yAxes","beginAtZero","yLabel","yTitle","fill","_f","_e","_d","stack","plugins","showTotalStack","onClick","event","legendItem","ci","meta","stopPropagation","update","layout","padding","right","stacked","axis","borderColor","_j","_h","_g","lineTension","numberOfBars","filter","leftId","uuid.v4","rightId","position","id","suggestedMin","yStacked","some","yAlign","yRightLabel","yRightTitle","legendPosition","xStacked","dataIndex","yAxisID","order","_k","Math","floor","random","Component","args","selector","template","ChangeDetectorRef","Optional","Inject","Input","ViewChild","NgModule","imports","CommonModule","declarations","exports","providers","Red","Orange","Yellow","Green","Blue","Purple","Grey","Purple700","Purple600","Purple500","Purple400","Purple300","Purple200","Purple100","Purple50","Blue700","Blue600","Blue500","Blue400","Blue300","Blue200","Blue100","Blue50","Green700","Green600","Green500","Green400","Green300","Green200","Green100","Green50","Yellow700","Yellow600","Yellow500","Yellow400","Yellow300","Yellow200","Yellow100","Yellow50","Orange700","Orange600","Orange500","Orange400","Orange300","Orange200","Orange100","Orange50","Red700","Red600","Red500","Red400","Red300","Red200","Red100","Red50","Brown700","Brown600","Brown500","Brown400","Brown300","Brown200","Brown100","Brown50","Gray900","Gray800","Gray700","Gray600","Gray500","Gray400","Gray300","Gray200","Gray100","Gray50","Platinum700","Platinum600","Platinum500","Platinum400","Platinum300","Platinum200","Platinum100","Platinum50","EatsGreen400","FreightBlue400","JumpRed400","Black","White"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import { InjectionToken } from '@angular/core';\r\n\r\nexport const ChartColors = {\r\n Red: 'rgb(255, 99, 132)',\r\n Orange: 'rgb(255, 159, 64)',\r\n Yellow: 'rgb(255, 205, 86)',\r\n Green: 'rgb(75, 192, 192)',\r\n Blue: 'rgb(54, 162, 235)',\r\n Purple: 'rgb(153, 102, 255)',\r\n Grey: 'rgb(201, 203, 207)',\r\n Purple700: '#2E224C',\r\n Purple600: '#453372',\r\n Purple500: '#574191',\r\n Purple400: '#7356BF',\r\n Purple300: '#957FCE',\r\n Purple200: '#C1B4E2',\r\n Purple100: '#E3DDF2',\r\n Purple50: '#F3F1F9',\r\n Blue700: '#0F2C60',\r\n Blue600: '#174291',\r\n Blue500: '#1D53B7',\r\n Blue400: '#276EF1',\r\n Blue300: '#5A90F4',\r\n Blue200: '#9FBFF8',\r\n Blue100: '#D4E2FC',\r\n Blue50: '#EDF3FD',\r\n Green700: '#0D4020',\r\n Green600: '#156A36',\r\n Green500: '#09863D',\r\n Green400: '#21A453',\r\n Green300: '#43BF75',\r\n Green200: '#9EE2B8',\r\n Green100: '#CFF3DD',\r\n Green50: '#F0FAF3',\r\n Yellow700: '#664C1A',\r\n Yellow600: '#997328',\r\n Yellow500: '#C19132',\r\n Yellow400: '#FFC043',\r\n Yellow300: '#FFCF70',\r\n Yellow200: '#FFE3AC',\r\n Yellow100: '#FFF2D9',\r\n Yellow50: '#FFF9EF',\r\n Orange700: '#5F2C14',\r\n Orange600: '#8E421E',\r\n Orange500: '#B45326',\r\n Orange400: '#ED6E33',\r\n Orange300: '#F19063',\r\n Orange200: '#F7BFA5',\r\n Orange100: '#FBE2D6',\r\n Orange50: '#FDF3EE',\r\n Red700: '#541A14',\r\n Red600: '#7F281E',\r\n Red500: '#A13226',\r\n Red400: '#D44333',\r\n Red300: '#DE7063',\r\n Red200: '#ECACA5',\r\n Red100: '#F6D9D6',\r\n Red50: '#FBEFEE',\r\n Brown700: '#3D281E',\r\n Brown600: '#5B3C2D',\r\n Brown500: '#744C39',\r\n Brown400: '#99644C',\r\n Brown300: '#B18976',\r\n Brown200: '#D2BAB0',\r\n Brown100: '#EBE0DB',\r\n Brown50: '#F6F2F0',\r\n Gray900: '#141414',\r\n Gray800: '#1F1F1F',\r\n Gray700: '#333333',\r\n Gray600: '#545454',\r\n Gray500: '#757575',\r\n Gray400: '#AFAFAF',\r\n Gray300: '#CBCBCB',\r\n Gray200: '#E2E2E2',\r\n Gray100: '#EEEEEE',\r\n Gray50: '#F6F6F6',\r\n Platinum700: '#394145',\r\n Platinum600: '#556268',\r\n Platinum500: '#6C7C83',\r\n Platinum400: '#8EA3AD',\r\n Platinum300: '#A1BDCA',\r\n Platinum200: '#CCDFE5',\r\n Platinum100: '#EBF5F7',\r\n Platinum50: '#F4FAFB',\r\n EatsGreen400: '#21A453',\r\n FreightBlue400: '#21A453',\r\n JumpRed400: '#FF0A2D',\r\n Black: '#000000',\r\n White: '#FFFFFF',\r\n};\r\n\r\nexport type SdChartOption = DoughnutChartOption | PieChartOption |\r\n BarChartOption |\r\n HorizontalBarChartOption |\r\n LineChartOption |\r\n StackAreaChartOption |\r\n BarLineChartOption;\r\n\r\ninterface BaseChartOption {\r\n title?: string;\r\n height?: string;\r\n hideLegend?: boolean;\r\n legendPosition?:'left' | 'right' | 'top' | 'bottom' | 'chartArea'\r\n tooltips?: {\r\n label: (params: { datasetLabel?: string, label?: string, value?: number,datasetIndex?:number,dataIndex?:number; }) => string | string[];\r\n };\r\n}\r\n\r\nexport interface PieChartOption extends BaseChartOption {\r\n type: 'pie';\r\n title?: string;\r\n datasets: {\r\n label: string,\r\n value: number,\r\n backgroundColor: string\r\n }[];\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface DoughnutChartOption extends BaseChartOption {\r\n type: 'doughnut';\r\n title?: string;\r\n datasets: {\r\n label: string,\r\n value: number,\r\n backgroundColor: string\r\n }[];\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface BarChartOption extends BaseChartOption {\r\n type: 'bar';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n stack?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface HorizontalBarChartOption extends BaseChartOption {\r\n type: 'horizontalBar';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n stack?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n showTotalStack?:boolean;\r\n}\r\n\r\nexport interface LineChartOption extends BaseChartOption {\r\n type: 'line';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface StackAreaChartOption extends BaseChartOption {\r\n type: 'stackArea';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface BarLineChartOption extends BaseChartOption {\r\n type: 'barline';\r\n xTitle?: string;\r\n xStacked?:boolean;\r\n yTitle?: string;\r\n yStacked?:boolean;\r\n yRightTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n type: 'bar' | 'line',\r\n yAlign?: 'left' | 'right',\r\n label: string;\r\n data: number[];\r\n order?:number;\r\n borderColor?: string;\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string,\r\n yRightLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n showTotalStack?:boolean\r\n}\r\n\r\n\r\nexport interface IChartConfiguration {\r\n defaultColors?: {\r\n backgroundColor?: string,\r\n borderColor?: string\r\n }[];\r\n}\r\n\r\n\r\nexport const CHART_CONFIG = new InjectionToken<IChartConfiguration>('chart.configuration');\r\n","import { Component, OnInit, AfterViewInit, ViewChild, ElementRef, Input, ChangeDetectorRef, Optional, Inject } from '@angular/core';\r\nimport * as Chart from 'chart.js';\r\nimport {\r\n SdChartOption,\r\n BarChartOption,\r\n LineChartOption,\r\n PieChartOption,\r\n BarLineChartOption,\r\n StackAreaChartOption,\r\n HorizontalBarChartOption,\r\n IChartConfiguration,\r\n CHART_CONFIG,\r\n DoughnutChartOption\r\n} from './chart.model';\r\nimport $ from 'jquery';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n selector: 'sd-chart',\r\n templateUrl: './chart.component.html',\r\n styleUrls: ['./chart.component.scss']\r\n})\r\nexport class SdChart implements OnInit, AfterViewInit {\r\n private initialized = false;\r\n private pChartOption: SdChartOption;\r\n isLoading = false;\r\n\r\n @Input() set chartOption(chartOption: SdChartOption) {\r\n this.pChartOption = chartOption;\r\n if (this.initialized) {\r\n this.renderChart();\r\n }\r\n }\r\n\r\n @ViewChild('chart') chartRef: ElementRef;\r\n @ViewChild('chartWrapper') chartWrapperRef: ElementRef;\r\n @ViewChild('chartAxis') chartAxisRef: ElementRef;\r\n @ViewChild('chartAreaWrapperExtend') chartAreaWrapperExtendRef: ElementRef;\r\n chart: Chart;\r\n visible = true;\r\n height = '300px';\r\n private ctx: CanvasRenderingContext2D;\r\n\r\n constructor(\r\n private ref: ChangeDetectorRef,\r\n @Optional() @Inject(CHART_CONFIG) private chartConfiguration: IChartConfiguration\r\n ) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.renderChart(true);\r\n this.initialized = true;\r\n this.ref.detectChanges();\r\n }\r\n\r\n private async renderChart(firstRender?: boolean) {\r\n this.height = this.pChartOption?.height || '300px';\r\n if (!firstRender) {\r\n this.visible = false;\r\n await new Promise(resolve => setTimeout(resolve, 200));\r\n this.visible = true;\r\n }\r\n await new Promise(resolve => setTimeout(resolve, 200));\r\n if (this.chartRef?.nativeElement) {\r\n const canvas = this.chartRef.nativeElement as HTMLCanvasElement;\r\n this.ctx = canvas.getContext('2d');\r\n switch (this.pChartOption.type) {\r\n case 'pie':\r\n this.renderPieChart(this.pChartOption);\r\n break;\r\n case 'bar':\r\n this.renderBarChart(this.pChartOption);\r\n break;\r\n case 'horizontalBar':\r\n this.renderHorizontalBarChart(this.pChartOption);\r\n break;\r\n case 'line':\r\n this.renderLineChart(this.pChartOption);\r\n break;\r\n case 'stackArea':\r\n this.renderStackAreaChart(this.pChartOption);\r\n break;\r\n case 'barline':\r\n this.renderBarLineChart(this.pChartOption);\r\n break;\r\n case 'doughnut':\r\n this.renderDoughnutChart(this.pChartOption);\r\n default:\r\n break;\r\n }\r\n }\r\n }\r\n\r\n private renderPieChart(option: PieChartOption) {\r\n const configuration: Chart.ChartConfiguration = {\r\n type: 'pie',\r\n options: {\r\n responsive: true,\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''}${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.datasets?.map(e => e.label) || [],\r\n datasets: [{\r\n data: option.datasets?.map(e => e.value) || [],\r\n backgroundColor: option.datasets?.map((e, idx) => e.backgroundColor\r\n || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor\r\n || this.dynamicColor) || []\r\n }]\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderDoughnutChart(option:DoughnutChartOption){\r\n const configuration: Chart.ChartConfiguration = {\r\n type: 'doughnut',\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio:false,\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''}${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.datasets?.map(e => e.label) || [],\r\n datasets: [{\r\n data: option.datasets?.map(e => e.value) || [],\r\n backgroundColor: option.datasets?.map((e, idx) => e.backgroundColor\r\n || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor\r\n || this.dynamicColor) || []\r\n }]\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderBarChart(option: BarChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * option.datasets.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * option.datasets.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n }\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'bar',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n data: e.data,\r\n stack: e.stack\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderHorizontalBarChart(option: HorizontalBarChartOption) {\r\n // const labelWidth = option.labelWidth ?? 50;\r\n // if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * option.datasets.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n // }\r\n const plugins:Chart.PluginServiceRegistrationOptions[] = [];\r\n if (option.showTotalStack){\r\n plugins.push(this.#drawTotalOfStackedBar(option.type))\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend,\r\n onClick: (event, legendItem) => {\r\n let index = legendItem.datasetIndex;\r\n let ci = this.chart;\r\n let meta = ci.getDatasetMeta(index);\r\n if (option.showTotalStack){\r\n event.stopPropagation()\r\n } \r\n else{\r\n // See controller.isDatasetVisible comment\r\n meta.hidden = meta.hidden === null ? !ci.data.datasets[index].hidden : null;\r\n \r\n // We hid a dataset ... rerender the chart\r\n ci.update(); \r\n }\r\n },\r\n },\r\n layout:{\r\n padding:{\r\n right:20\r\n }\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || '',\r\n },\r\n stacked:true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n stacked:true,\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n mode:'nearest',\r\n axis:'y',\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'horizontalBar',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n data: e.data,\r\n stack: e.stack\r\n };\r\n return result;\r\n })\r\n },\r\n plugins:plugins\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderLineChart(option: LineChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'line',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n lineTension: 0,\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderStackAreaChart(option: StackAreaChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n \r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n stacked: true,\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'line',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n // fill: e.backgroundColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n lineTension: 0,\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderBarLineChart(option: BarLineChartOption) {\r\n const plugins:Chart.PluginServiceRegistrationOptions[] = [];\r\n if (option.showTotalStack){\r\n plugins.push(this.#drawTotalOfStackedBar(option.type))\r\n }\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n const numberOfBars = option.datasets.filter(e => e.type === 'bar').length;\r\n if (numberOfBars <= 1) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n } else {\r\n // const newwidth = Math.max(option.labels.length * numberOfBars * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * numberOfBars * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n }\r\n const leftId = `I${uuid.v4()}`;\r\n const rightId = `I${uuid.v4()}`;\r\n const yAxes = [{\r\n type: 'linear',\r\n display: true,\r\n position: 'left',\r\n id: leftId,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n suggestedMin: 0,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || '',\r\n },\r\n stacked:!!option.yStacked,\r\n }];\r\n if (option.datasets.some(e => e.yAlign === 'right')) {\r\n yAxes.push({\r\n type: 'linear',\r\n display: true,\r\n position: 'right',\r\n id: rightId,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n suggestedMin: 0,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yRightLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yRightTitle,\r\n labelString: option.yRightTitle || ''\r\n },\r\n stacked:!!option.yStacked,\r\n });\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend,\r\n onClick: (event, legendItem) => {\r\n let index = legendItem.datasetIndex;\r\n let ci = this.chart;\r\n let meta = ci.getDatasetMeta(index);\r\n if (option.showTotalStack){\r\n event.stopPropagation()\r\n } \r\n else{\r\n // See controller.isDatasetVisible comment\r\n meta.hidden = meta.hidden === null ? !ci.data.datasets[index].hidden : null;\r\n \r\n // We hid a dataset ... rerender the chart\r\n ci.update(); \r\n }\r\n },\r\n position: option?.legendPosition ?? 'top'\r\n },\r\n layout:{\r\n padding:10\r\n },\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n stacked: !!option.xStacked\r\n }],\r\n yAxes\r\n },\r\n tooltips: { \r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value,\r\n datasetIndex: tooltipItem.datasetIndex,\r\n dataIndex:tooltipItem.index\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''} ${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n type: e.type,\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n yAxisID: e.yAlign === 'right' ? rightId : leftId,\r\n lineTension: 0,\r\n order:e.order ?? 1\r\n };\r\n return result;\r\n }),\r\n },\r\n plugins: plugins\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n loadingStart = () => {\r\n this.isLoading = true;\r\n }\r\n\r\n private get dynamicColor() {\r\n const r = Math.floor(Math.random() * 255);\r\n const g = Math.floor(Math.random() * 255);\r\n const b = Math.floor(Math.random() * 255);\r\n return 'rgb(' + r + ',' + g + ',' + b + ')';\r\n }\r\n\r\n #drawTotalOfStackedBar = (chartType:'barline' | 'bar' | 'horizontalBar'):Chart.PluginServiceRegistrationOptions => {\r\n return {\r\n afterDraw(chartInstance, easing, options) {\r\n if (chartInstance?.data?.datasets?.length){\r\n const ctx = chartInstance.ctx;\r\n chartInstance.data.datasets[0].data.forEach( (dataPoint,index) => {\r\n let curLastIndex = 0;\r\n let curTotal = 0;\r\n chartInstance.data.datasets.forEach( (dataset,setIndex) => {\r\n if (dataset.data[index] != 0 && (!dataset.hidden) && dataset.type !== 'line'){\r\n curLastIndex = setIndex;\r\n if (Number.isNumber(dataset.data[index])){\r\n curTotal += Number(dataset.data[index]);\r\n }\r\n else curTotal += 0;\r\n }\r\n })\r\n const {x,y} = chartInstance.getDatasetMeta(curLastIndex).data[index]._model;\r\n const textWidth = ctx.measureText(curTotal.toString()).width;\r\n ctx.fillStyle= 'black';\r\n let xTextPosition = (x-textWidth/2 ) - textWidth > 0 ? (x-textWidth/2 ) : 0;\r\n if (index == 0){\r\n xTextPosition = x + 10;\r\n }\r\n else if (index === chartInstance.data.datasets[0].data.length - 1 ){\r\n xTextPosition = x - textWidth - 10;\r\n }\r\n ctx.font = '300 10px'\r\n ctx.fillText(curTotal.toString(), chartType === 'horizontalBar' ? x + 10 : xTextPosition, chartType === 'horizontalBar' ? y : y-10);\r\n });\r\n } \r\n },\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdChart } from './chart.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule\r\n ],\r\n declarations: [\r\n SdChart\r\n ],\r\n exports: [\r\n SdChart\r\n ],\r\n providers: [\r\n ]\r\n})\r\nexport class SdChartModule { }\r\n"]}
1
+ {"version":3,"sources":["../../../../node_modules/tslib/tslib.es6.js","../../../../projects/sd-core/chart/src/lib/chart.model.ts","../../../../projects/sd-core/chart/src/lib/chart.component.ts","../../../../projects/sd-core/chart/src/lib/chart.module.ts"],"names":["__awaiter","thisArg","_arguments","P","generator","Promise","resolve","reject","fulfilled","value","step","next","e","rejected","result","done","then","apply","__generator","body","f","y","t","g","_","label","sent","trys","ops","verb","throw","return","Symbol","iterator","this","n","v","op","TypeError","call","pop","length","push","Object","create","__classPrivateFieldGet","receiver","state","kind","has","get","CHART_CONFIG","InjectionToken","SdChart","ref","chartConfiguration","_this","initialized","isLoading","visible","height","loadingStart","_drawTotalOfStackedBar","set","chartType","afterDraw","chartInstance","easing","options","_b","_a","data","datasets","ctx_1","ctx","forEach","dataPoint","index","curLastIndex","curTotal","dataset","setIndex","hidden","type","Number","isNumber","_l","getDatasetMeta","_model","x","textWidth","measureText","toString","width","fillStyle","xTextPosition","font","fillText","defineProperty","prototype","chartOption","pChartOption","renderChart","ngOnInit","ngAfterViewInit","detectChanges","firstRender","setTimeout","chartRef","nativeElement","canvas","getContext","renderPieChart","renderBarChart","renderHorizontalBarChart","renderLineChart","renderStackAreaChart","renderBarLineChart","renderDoughnutChart","option","configuration","responsive","title","display","text","legend","hideLegend","tooltips","callbacks","tooltipItem","datasetLabel","datasetIndex","labels","_c","toVNCurrency","map","backgroundColor","idx","defaultColors","dynamicColor","hover","assign","mode","intersect","chart","Chart","maintainAspectRatio","labelWidth","newwidth","$","chartAreaWrapperExtendRef","css","scales","xAxes","scaleLabel","xTitle","labelString","ticks","callback","xLabel","yAxes","beginAtZero","yLabel","yTitle","fill","_f","_e","_d","stack","plugins","showTotalStack","onClick","event","legendItem","ci","meta","stopPropagation","update","layout","padding","right","stacked","axis","borderColor","_j","_h","_g","lineTension","numberOfBars","filter","leftId","uuid.v4","rightId","position","id","suggestedMin","yStacked","some","yAlign","yRightLabel","yRightTitle","legendPosition","xStacked","dataIndex","yAxisID","order","_k","Math","floor","random","Component","args","selector","template","ChangeDetectorRef","Optional","Inject","Input","ViewChild","NgModule","imports","CommonModule","declarations","exports","providers","Red","Orange","Yellow","Green","Blue","Purple","Grey","Purple700","Purple600","Purple500","Purple400","Purple300","Purple200","Purple100","Purple50","Blue700","Blue600","Blue500","Blue400","Blue300","Blue200","Blue100","Blue50","Green700","Green600","Green500","Green400","Green300","Green200","Green100","Green50","Yellow700","Yellow600","Yellow500","Yellow400","Yellow300","Yellow200","Yellow100","Yellow50","Orange700","Orange600","Orange500","Orange400","Orange300","Orange200","Orange100","Orange50","Red700","Red600","Red500","Red400","Red300","Red200","Red100","Red50","Brown700","Brown600","Brown500","Brown400","Brown300","Brown200","Brown100","Brown50","Gray900","Gray800","Gray700","Gray600","Gray500","Gray400","Gray300","Gray200","Gray100","Gray50","Platinum700","Platinum600","Platinum500","Platinum400","Platinum300","Platinum200","Platinum100","Platinum50","EatsGreen400","FreightBlue400","JumpRed400","Black","White"],"mappings":"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","sourcesContent":["/*! *****************************************************************************\r\nCopyright (c) Microsoft Corporation.\r\n\r\nPermission to use, copy, modify, and/or distribute this software for any\r\npurpose with or without fee is hereby granted.\r\n\r\nTHE SOFTWARE IS PROVIDED \"AS IS\" AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH\r\nREGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY\r\nAND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT,\r\nINDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM\r\nLOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR\r\nOTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR\r\nPERFORMANCE OF THIS SOFTWARE.\r\n***************************************************************************** */\r\n/* global Reflect, Promise */\r\n\r\nvar extendStatics = function(d, b) {\r\n extendStatics = Object.setPrototypeOf ||\r\n ({ __proto__: [] } instanceof Array && function (d, b) { d.__proto__ = b; }) ||\r\n function (d, b) { for (var p in b) if (Object.prototype.hasOwnProperty.call(b, p)) d[p] = b[p]; };\r\n return extendStatics(d, b);\r\n};\r\n\r\nexport function __extends(d, b) {\r\n if (typeof b !== \"function\" && b !== null)\r\n throw new TypeError(\"Class extends value \" + String(b) + \" is not a constructor or null\");\r\n extendStatics(d, b);\r\n function __() { this.constructor = d; }\r\n d.prototype = b === null ? Object.create(b) : (__.prototype = b.prototype, new __());\r\n}\r\n\r\nexport var __assign = function() {\r\n __assign = Object.assign || function __assign(t) {\r\n for (var s, i = 1, n = arguments.length; i < n; i++) {\r\n s = arguments[i];\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p)) t[p] = s[p];\r\n }\r\n return t;\r\n }\r\n return __assign.apply(this, arguments);\r\n}\r\n\r\nexport function __rest(s, e) {\r\n var t = {};\r\n for (var p in s) if (Object.prototype.hasOwnProperty.call(s, p) && e.indexOf(p) < 0)\r\n t[p] = s[p];\r\n if (s != null && typeof Object.getOwnPropertySymbols === \"function\")\r\n for (var i = 0, p = Object.getOwnPropertySymbols(s); i < p.length; i++) {\r\n if (e.indexOf(p[i]) < 0 && Object.prototype.propertyIsEnumerable.call(s, p[i]))\r\n t[p[i]] = s[p[i]];\r\n }\r\n return t;\r\n}\r\n\r\nexport function __decorate(decorators, target, key, desc) {\r\n var c = arguments.length, r = c < 3 ? target : desc === null ? desc = Object.getOwnPropertyDescriptor(target, key) : desc, d;\r\n if (typeof Reflect === \"object\" && typeof Reflect.decorate === \"function\") r = Reflect.decorate(decorators, target, key, desc);\r\n else for (var i = decorators.length - 1; i >= 0; i--) if (d = decorators[i]) r = (c < 3 ? d(r) : c > 3 ? d(target, key, r) : d(target, key)) || r;\r\n return c > 3 && r && Object.defineProperty(target, key, r), r;\r\n}\r\n\r\nexport function __param(paramIndex, decorator) {\r\n return function (target, key) { decorator(target, key, paramIndex); }\r\n}\r\n\r\nexport function __metadata(metadataKey, metadataValue) {\r\n if (typeof Reflect === \"object\" && typeof Reflect.metadata === \"function\") return Reflect.metadata(metadataKey, metadataValue);\r\n}\r\n\r\nexport function __awaiter(thisArg, _arguments, P, generator) {\r\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\r\n return new (P || (P = Promise))(function (resolve, reject) {\r\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\r\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\r\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\r\n step((generator = generator.apply(thisArg, _arguments || [])).next());\r\n });\r\n}\r\n\r\nexport function __generator(thisArg, body) {\r\n var _ = { label: 0, sent: function() { if (t[0] & 1) throw t[1]; return t[1]; }, trys: [], ops: [] }, f, y, t, g;\r\n return g = { next: verb(0), \"throw\": verb(1), \"return\": verb(2) }, typeof Symbol === \"function\" && (g[Symbol.iterator] = function() { return this; }), g;\r\n function verb(n) { return function (v) { return step([n, v]); }; }\r\n function step(op) {\r\n if (f) throw new TypeError(\"Generator is already executing.\");\r\n while (_) try {\r\n if (f = 1, y && (t = op[0] & 2 ? y[\"return\"] : op[0] ? y[\"throw\"] || ((t = y[\"return\"]) && t.call(y), 0) : y.next) && !(t = t.call(y, op[1])).done) return t;\r\n if (y = 0, t) op = [op[0] & 2, t.value];\r\n switch (op[0]) {\r\n case 0: case 1: t = op; break;\r\n case 4: _.label++; return { value: op[1], done: false };\r\n case 5: _.label++; y = op[1]; op = [0]; continue;\r\n case 7: op = _.ops.pop(); _.trys.pop(); continue;\r\n default:\r\n if (!(t = _.trys, t = t.length > 0 && t[t.length - 1]) && (op[0] === 6 || op[0] === 2)) { _ = 0; continue; }\r\n if (op[0] === 3 && (!t || (op[1] > t[0] && op[1] < t[3]))) { _.label = op[1]; break; }\r\n if (op[0] === 6 && _.label < t[1]) { _.label = t[1]; t = op; break; }\r\n if (t && _.label < t[2]) { _.label = t[2]; _.ops.push(op); break; }\r\n if (t[2]) _.ops.pop();\r\n _.trys.pop(); continue;\r\n }\r\n op = body.call(thisArg, _);\r\n } catch (e) { op = [6, e]; y = 0; } finally { f = t = 0; }\r\n if (op[0] & 5) throw op[1]; return { value: op[0] ? op[1] : void 0, done: true };\r\n }\r\n}\r\n\r\nexport var __createBinding = Object.create ? (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n Object.defineProperty(o, k2, { enumerable: true, get: function() { return m[k]; } });\r\n}) : (function(o, m, k, k2) {\r\n if (k2 === undefined) k2 = k;\r\n o[k2] = m[k];\r\n});\r\n\r\nexport function __exportStar(m, o) {\r\n for (var p in m) if (p !== \"default\" && !Object.prototype.hasOwnProperty.call(o, p)) __createBinding(o, m, p);\r\n}\r\n\r\nexport function __values(o) {\r\n var s = typeof Symbol === \"function\" && Symbol.iterator, m = s && o[s], i = 0;\r\n if (m) return m.call(o);\r\n if (o && typeof o.length === \"number\") return {\r\n next: function () {\r\n if (o && i >= o.length) o = void 0;\r\n return { value: o && o[i++], done: !o };\r\n }\r\n };\r\n throw new TypeError(s ? \"Object is not iterable.\" : \"Symbol.iterator is not defined.\");\r\n}\r\n\r\nexport function __read(o, n) {\r\n var m = typeof Symbol === \"function\" && o[Symbol.iterator];\r\n if (!m) return o;\r\n var i = m.call(o), r, ar = [], e;\r\n try {\r\n while ((n === void 0 || n-- > 0) && !(r = i.next()).done) ar.push(r.value);\r\n }\r\n catch (error) { e = { error: error }; }\r\n finally {\r\n try {\r\n if (r && !r.done && (m = i[\"return\"])) m.call(i);\r\n }\r\n finally { if (e) throw e.error; }\r\n }\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spread() {\r\n for (var ar = [], i = 0; i < arguments.length; i++)\r\n ar = ar.concat(__read(arguments[i]));\r\n return ar;\r\n}\r\n\r\n/** @deprecated */\r\nexport function __spreadArrays() {\r\n for (var s = 0, i = 0, il = arguments.length; i < il; i++) s += arguments[i].length;\r\n for (var r = Array(s), k = 0, i = 0; i < il; i++)\r\n for (var a = arguments[i], j = 0, jl = a.length; j < jl; j++, k++)\r\n r[k] = a[j];\r\n return r;\r\n}\r\n\r\nexport function __spreadArray(to, from, pack) {\r\n if (pack || arguments.length === 2) for (var i = 0, l = from.length, ar; i < l; i++) {\r\n if (ar || !(i in from)) {\r\n if (!ar) ar = Array.prototype.slice.call(from, 0, i);\r\n ar[i] = from[i];\r\n }\r\n }\r\n return to.concat(ar || Array.prototype.slice.call(from));\r\n}\r\n\r\nexport function __await(v) {\r\n return this instanceof __await ? (this.v = v, this) : new __await(v);\r\n}\r\n\r\nexport function __asyncGenerator(thisArg, _arguments, generator) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var g = generator.apply(thisArg, _arguments || []), i, q = [];\r\n return i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i;\r\n function verb(n) { if (g[n]) i[n] = function (v) { return new Promise(function (a, b) { q.push([n, v, a, b]) > 1 || resume(n, v); }); }; }\r\n function resume(n, v) { try { step(g[n](v)); } catch (e) { settle(q[0][3], e); } }\r\n function step(r) { r.value instanceof __await ? Promise.resolve(r.value.v).then(fulfill, reject) : settle(q[0][2], r); }\r\n function fulfill(value) { resume(\"next\", value); }\r\n function reject(value) { resume(\"throw\", value); }\r\n function settle(f, v) { if (f(v), q.shift(), q.length) resume(q[0][0], q[0][1]); }\r\n}\r\n\r\nexport function __asyncDelegator(o) {\r\n var i, p;\r\n return i = {}, verb(\"next\"), verb(\"throw\", function (e) { throw e; }), verb(\"return\"), i[Symbol.iterator] = function () { return this; }, i;\r\n function verb(n, f) { i[n] = o[n] ? function (v) { return (p = !p) ? { value: __await(o[n](v)), done: n === \"return\" } : f ? f(v) : v; } : f; }\r\n}\r\n\r\nexport function __asyncValues(o) {\r\n if (!Symbol.asyncIterator) throw new TypeError(\"Symbol.asyncIterator is not defined.\");\r\n var m = o[Symbol.asyncIterator], i;\r\n return m ? m.call(o) : (o = typeof __values === \"function\" ? __values(o) : o[Symbol.iterator](), i = {}, verb(\"next\"), verb(\"throw\"), verb(\"return\"), i[Symbol.asyncIterator] = function () { return this; }, i);\r\n function verb(n) { i[n] = o[n] && function (v) { return new Promise(function (resolve, reject) { v = o[n](v), settle(resolve, reject, v.done, v.value); }); }; }\r\n function settle(resolve, reject, d, v) { Promise.resolve(v).then(function(v) { resolve({ value: v, done: d }); }, reject); }\r\n}\r\n\r\nexport function __makeTemplateObject(cooked, raw) {\r\n if (Object.defineProperty) { Object.defineProperty(cooked, \"raw\", { value: raw }); } else { cooked.raw = raw; }\r\n return cooked;\r\n};\r\n\r\nvar __setModuleDefault = Object.create ? (function(o, v) {\r\n Object.defineProperty(o, \"default\", { enumerable: true, value: v });\r\n}) : function(o, v) {\r\n o[\"default\"] = v;\r\n};\r\n\r\nexport function __importStar(mod) {\r\n if (mod && mod.__esModule) return mod;\r\n var result = {};\r\n if (mod != null) for (var k in mod) if (k !== \"default\" && Object.prototype.hasOwnProperty.call(mod, k)) __createBinding(result, mod, k);\r\n __setModuleDefault(result, mod);\r\n return result;\r\n}\r\n\r\nexport function __importDefault(mod) {\r\n return (mod && mod.__esModule) ? mod : { default: mod };\r\n}\r\n\r\nexport function __classPrivateFieldGet(receiver, state, kind, f) {\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a getter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot read private member from an object whose class did not declare it\");\r\n return kind === \"m\" ? f : kind === \"a\" ? f.call(receiver) : f ? f.value : state.get(receiver);\r\n}\r\n\r\nexport function __classPrivateFieldSet(receiver, state, value, kind, f) {\r\n if (kind === \"m\") throw new TypeError(\"Private method is not writable\");\r\n if (kind === \"a\" && !f) throw new TypeError(\"Private accessor was defined without a setter\");\r\n if (typeof state === \"function\" ? receiver !== state || !f : !state.has(receiver)) throw new TypeError(\"Cannot write private member to an object whose class did not declare it\");\r\n return (kind === \"a\" ? f.call(receiver, value) : f ? f.value = value : state.set(receiver, value)), value;\r\n}\r\n","import { InjectionToken } from '@angular/core';\r\n\r\nexport const ChartColors = {\r\n Red: 'rgb(255, 99, 132)',\r\n Orange: 'rgb(255, 159, 64)',\r\n Yellow: 'rgb(255, 205, 86)',\r\n Green: 'rgb(75, 192, 192)',\r\n Blue: 'rgb(54, 162, 235)',\r\n Purple: 'rgb(153, 102, 255)',\r\n Grey: 'rgb(201, 203, 207)',\r\n Purple700: '#2E224C',\r\n Purple600: '#453372',\r\n Purple500: '#574191',\r\n Purple400: '#7356BF',\r\n Purple300: '#957FCE',\r\n Purple200: '#C1B4E2',\r\n Purple100: '#E3DDF2',\r\n Purple50: '#F3F1F9',\r\n Blue700: '#0F2C60',\r\n Blue600: '#174291',\r\n Blue500: '#1D53B7',\r\n Blue400: '#276EF1',\r\n Blue300: '#5A90F4',\r\n Blue200: '#9FBFF8',\r\n Blue100: '#D4E2FC',\r\n Blue50: '#EDF3FD',\r\n Green700: '#0D4020',\r\n Green600: '#156A36',\r\n Green500: '#09863D',\r\n Green400: '#21A453',\r\n Green300: '#43BF75',\r\n Green200: '#9EE2B8',\r\n Green100: '#CFF3DD',\r\n Green50: '#F0FAF3',\r\n Yellow700: '#664C1A',\r\n Yellow600: '#997328',\r\n Yellow500: '#C19132',\r\n Yellow400: '#FFC043',\r\n Yellow300: '#FFCF70',\r\n Yellow200: '#FFE3AC',\r\n Yellow100: '#FFF2D9',\r\n Yellow50: '#FFF9EF',\r\n Orange700: '#5F2C14',\r\n Orange600: '#8E421E',\r\n Orange500: '#B45326',\r\n Orange400: '#ED6E33',\r\n Orange300: '#F19063',\r\n Orange200: '#F7BFA5',\r\n Orange100: '#FBE2D6',\r\n Orange50: '#FDF3EE',\r\n Red700: '#541A14',\r\n Red600: '#7F281E',\r\n Red500: '#A13226',\r\n Red400: '#D44333',\r\n Red300: '#DE7063',\r\n Red200: '#ECACA5',\r\n Red100: '#F6D9D6',\r\n Red50: '#FBEFEE',\r\n Brown700: '#3D281E',\r\n Brown600: '#5B3C2D',\r\n Brown500: '#744C39',\r\n Brown400: '#99644C',\r\n Brown300: '#B18976',\r\n Brown200: '#D2BAB0',\r\n Brown100: '#EBE0DB',\r\n Brown50: '#F6F2F0',\r\n Gray900: '#141414',\r\n Gray800: '#1F1F1F',\r\n Gray700: '#333333',\r\n Gray600: '#545454',\r\n Gray500: '#757575',\r\n Gray400: '#AFAFAF',\r\n Gray300: '#CBCBCB',\r\n Gray200: '#E2E2E2',\r\n Gray100: '#EEEEEE',\r\n Gray50: '#F6F6F6',\r\n Platinum700: '#394145',\r\n Platinum600: '#556268',\r\n Platinum500: '#6C7C83',\r\n Platinum400: '#8EA3AD',\r\n Platinum300: '#A1BDCA',\r\n Platinum200: '#CCDFE5',\r\n Platinum100: '#EBF5F7',\r\n Platinum50: '#F4FAFB',\r\n EatsGreen400: '#21A453',\r\n FreightBlue400: '#21A453',\r\n JumpRed400: '#FF0A2D',\r\n Black: '#000000',\r\n White: '#FFFFFF',\r\n};\r\n\r\nexport type SdChartOption = DoughnutChartOption | PieChartOption |\r\n BarChartOption |\r\n HorizontalBarChartOption |\r\n LineChartOption |\r\n StackAreaChartOption |\r\n BarLineChartOption;\r\n\r\ninterface BaseChartOption {\r\n title?: string;\r\n height?: string;\r\n hideLegend?: boolean;\r\n legendPosition?:'left' | 'right' | 'top' | 'bottom' | 'chartArea'\r\n tooltips?: {\r\n label: (params: { datasetLabel?: string, label?: string, value?: number,datasetIndex?:number,dataIndex?:number; }) => string | string[];\r\n };\r\n}\r\n\r\nexport interface PieChartOption extends BaseChartOption {\r\n type: 'pie';\r\n title?: string;\r\n datasets: {\r\n label: string,\r\n value: number,\r\n backgroundColor: string\r\n }[];\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface DoughnutChartOption extends BaseChartOption {\r\n type: 'doughnut';\r\n title?: string;\r\n datasets: {\r\n label: string,\r\n value: number,\r\n backgroundColor: string\r\n }[];\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface BarChartOption extends BaseChartOption {\r\n type: 'bar';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n stack?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface HorizontalBarChartOption extends BaseChartOption {\r\n type: 'horizontalBar';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n stack?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n showTotalStack?:boolean;\r\n}\r\n\r\nexport interface LineChartOption extends BaseChartOption {\r\n type: 'line';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface StackAreaChartOption extends BaseChartOption {\r\n type: 'stackArea';\r\n xTitle?: string;\r\n yTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n label: string;\r\n data: number[];\r\n borderColor?: string,\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n}\r\n\r\nexport interface BarLineChartOption extends BaseChartOption {\r\n type: 'barline';\r\n xTitle?: string;\r\n xStacked?:boolean;\r\n yTitle?: string;\r\n yStacked?:boolean;\r\n yRightTitle?: string;\r\n labels: string[];\r\n datasets: {\r\n type: 'bar' | 'line',\r\n yAlign?: 'left' | 'right',\r\n label: string;\r\n data: number[];\r\n order?:number;\r\n borderColor?: string;\r\n backgroundColor?: string;\r\n }[];\r\n beginAtZero?: boolean;\r\n labelWidth?: number;\r\n ticks?: {\r\n xLabel?: (value: number | string, index: number) => string,\r\n yLabel?: (value: number | string, index: number) => string,\r\n yRightLabel?: (value: number | string, index: number) => string\r\n };\r\n hover?: 'ShowAll';\r\n showTotalStack?:boolean\r\n}\r\n\r\n\r\nexport interface IChartConfiguration {\r\n defaultColors?: {\r\n backgroundColor?: string,\r\n borderColor?: string\r\n }[];\r\n}\r\n\r\n\r\nexport const CHART_CONFIG = new InjectionToken<IChartConfiguration>('chart.configuration');\r\n","import { Component, OnInit, AfterViewInit, ViewChild, ElementRef, Input, ChangeDetectorRef, Optional, Inject } from '@angular/core';\r\nimport * as Chart from 'chart.js';\r\nimport {\r\n SdChartOption,\r\n BarChartOption,\r\n LineChartOption,\r\n PieChartOption,\r\n BarLineChartOption,\r\n StackAreaChartOption,\r\n HorizontalBarChartOption,\r\n IChartConfiguration,\r\n CHART_CONFIG,\r\n DoughnutChartOption\r\n} from './chart.model';\r\nimport $ from 'jquery';\r\nimport * as uuid from 'uuid';\r\n\r\n@Component({\r\n selector: 'sd-chart',\r\n templateUrl: './chart.component.html',\r\n styleUrls: ['./chart.component.scss']\r\n})\r\nexport class SdChart implements OnInit, AfterViewInit {\r\n private initialized = false;\r\n private pChartOption: SdChartOption;\r\n isLoading = false;\r\n\r\n @Input() set chartOption(chartOption: SdChartOption) {\r\n this.pChartOption = chartOption;\r\n if (this.initialized) {\r\n this.renderChart();\r\n }\r\n }\r\n\r\n @ViewChild('chart') chartRef: ElementRef;\r\n @ViewChild('chartWrapper') chartWrapperRef: ElementRef;\r\n @ViewChild('chartAxis') chartAxisRef: ElementRef;\r\n @ViewChild('chartAreaWrapperExtend') chartAreaWrapperExtendRef: ElementRef;\r\n chart: Chart;\r\n visible = true;\r\n height = '300px';\r\n private ctx: CanvasRenderingContext2D;\r\n\r\n constructor(\r\n private ref: ChangeDetectorRef,\r\n @Optional() @Inject(CHART_CONFIG) private chartConfiguration: IChartConfiguration\r\n ) {\r\n }\r\n\r\n ngOnInit() {\r\n }\r\n\r\n ngAfterViewInit() {\r\n this.renderChart(true);\r\n this.initialized = true;\r\n this.ref.detectChanges();\r\n }\r\n\r\n private async renderChart(firstRender?: boolean) {\r\n this.height = this.pChartOption?.height || '300px';\r\n if (!firstRender) {\r\n this.visible = false;\r\n await new Promise(resolve => setTimeout(resolve, 200));\r\n this.visible = true;\r\n }\r\n await new Promise(resolve => setTimeout(resolve, 200));\r\n if (this.chartRef?.nativeElement) {\r\n const canvas = this.chartRef.nativeElement as HTMLCanvasElement;\r\n this.ctx = canvas.getContext('2d');\r\n switch (this.pChartOption.type) {\r\n case 'pie':\r\n this.renderPieChart(this.pChartOption);\r\n break;\r\n case 'bar':\r\n this.renderBarChart(this.pChartOption);\r\n break;\r\n case 'horizontalBar':\r\n this.renderHorizontalBarChart(this.pChartOption);\r\n break;\r\n case 'line':\r\n this.renderLineChart(this.pChartOption);\r\n break;\r\n case 'stackArea':\r\n this.renderStackAreaChart(this.pChartOption);\r\n break;\r\n case 'barline':\r\n this.renderBarLineChart(this.pChartOption);\r\n break;\r\n case 'doughnut':\r\n this.renderDoughnutChart(this.pChartOption);\r\n default:\r\n break;\r\n }\r\n }\r\n }\r\n\r\n private renderPieChart(option: PieChartOption) {\r\n const configuration: Chart.ChartConfiguration = {\r\n type: 'pie',\r\n options: {\r\n responsive: true,\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''}${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.datasets?.map(e => e.label) || [],\r\n datasets: [{\r\n data: option.datasets?.map(e => e.value) || [],\r\n backgroundColor: option.datasets?.map((e, idx) => e.backgroundColor\r\n || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor\r\n || this.dynamicColor) || []\r\n }]\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderDoughnutChart(option:DoughnutChartOption){\r\n const configuration: Chart.ChartConfiguration = {\r\n type: 'doughnut',\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio:false,\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''}${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.datasets?.map(e => e.label) || [],\r\n datasets: [{\r\n data: option.datasets?.map(e => e.value) || [],\r\n backgroundColor: option.datasets?.map((e, idx) => e.backgroundColor\r\n || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor\r\n || this.dynamicColor) || []\r\n }]\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderBarChart(option: BarChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * option.datasets.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * option.datasets.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n }\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'bar',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n data: e.data,\r\n stack: e.stack\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderHorizontalBarChart(option: HorizontalBarChartOption) {\r\n // const labelWidth = option.labelWidth ?? 50;\r\n // if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * option.datasets.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n // }\r\n const plugins:Chart.PluginServiceRegistrationOptions[] = [];\r\n if (option.showTotalStack){\r\n plugins.push(this.#drawTotalOfStackedBar(option.type))\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend,\r\n onClick: (event, legendItem) => {\r\n let index = legendItem.datasetIndex;\r\n let ci = this.chart;\r\n let meta = ci.getDatasetMeta(index);\r\n if (option.showTotalStack){\r\n event.stopPropagation()\r\n } \r\n else{\r\n // See controller.isDatasetVisible comment\r\n meta.hidden = meta.hidden === null ? !ci.data.datasets[index].hidden : null;\r\n \r\n // We hid a dataset ... rerender the chart\r\n ci.update(); \r\n }\r\n },\r\n },\r\n layout:{\r\n padding:{\r\n right:20\r\n }\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || '',\r\n },\r\n stacked:true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n stacked:true,\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n mode:'nearest',\r\n axis:'y',\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'horizontalBar',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n data: e.data,\r\n stack: e.stack\r\n };\r\n return result;\r\n })\r\n },\r\n plugins:plugins\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderLineChart(option: LineChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'line',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n lineTension: 0,\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderStackAreaChart(option: StackAreaChartOption) {\r\n const labelWidth = option.labelWidth ?? 50;\r\n \r\n if (option.datasets.length) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n }],\r\n yAxes: [{\r\n display: true,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n stacked: true,\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || ''\r\n }\r\n }]\r\n },\r\n tooltips: {\r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value\r\n }) || `${datasetLabel} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n type: 'line',\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n label: e.label,\r\n // fill: e.backgroundColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n lineTension: 0,\r\n };\r\n return result;\r\n })\r\n }\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n private renderBarLineChart(option: BarLineChartOption) {\r\n const plugins:Chart.PluginServiceRegistrationOptions[] = [];\r\n if (option.showTotalStack){\r\n plugins.push(this.#drawTotalOfStackedBar(option.type))\r\n }\r\n const labelWidth = option.labelWidth ?? 50;\r\n if (option.datasets.length) {\r\n const numberOfBars = option.datasets.filter(e => e.type === 'bar').length;\r\n if (numberOfBars <= 1) {\r\n // const newwidth = Math.max(option.labels.length * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n } else {\r\n // const newwidth = Math.max(option.labels.length * numberOfBars * labelWidth, $(this.chartWrapperRef.nativeElement).width());\r\n // $(this.chartAreaWrapperExtendRef.nativeElement).width(newwidth);\r\n const newwidth = option.labels.length * numberOfBars * labelWidth;\r\n $(this.chartAreaWrapperExtendRef.nativeElement).css('width', `max(100%,${newwidth}px)`);\r\n }\r\n }\r\n const leftId = `I${uuid.v4()}`;\r\n const rightId = `I${uuid.v4()}`;\r\n const yAxes = [{\r\n type: 'linear',\r\n display: true,\r\n position: 'left',\r\n id: leftId,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n suggestedMin: 0,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yTitle,\r\n labelString: option.yTitle || '',\r\n },\r\n stacked:!!option.yStacked,\r\n }];\r\n if (option.datasets.some(e => e.yAlign === 'right')) {\r\n yAxes.push({\r\n type: 'linear',\r\n display: true,\r\n position: 'right',\r\n id: rightId,\r\n ticks: {\r\n beginAtZero: option.beginAtZero ?? true,\r\n suggestedMin: 0,\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.yRightLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n scaleLabel: {\r\n display: !!option.yRightTitle,\r\n labelString: option.yRightTitle || ''\r\n },\r\n stacked:!!option.yStacked,\r\n });\r\n }\r\n const configuration: Chart.ChartConfiguration = {\r\n options: {\r\n responsive: true,\r\n maintainAspectRatio: false,\r\n legend: {\r\n display: !option.hideLegend,\r\n onClick: (event, legendItem) => {\r\n let index = legendItem.datasetIndex;\r\n let ci = this.chart;\r\n let meta = ci.getDatasetMeta(index);\r\n if (option.showTotalStack){\r\n event.stopPropagation()\r\n } \r\n else{\r\n // See controller.isDatasetVisible comment\r\n meta.hidden = meta.hidden === null ? !ci.data.datasets[index].hidden : null;\r\n \r\n // We hid a dataset ... rerender the chart\r\n ci.update(); \r\n }\r\n },\r\n position: option?.legendPosition ?? 'top'\r\n },\r\n layout:{\r\n padding:10\r\n },\r\n title: {\r\n display: true,\r\n text: option.title\r\n },\r\n scales: {\r\n xAxes: [{\r\n display: true,\r\n scaleLabel: {\r\n display: !!option.xTitle,\r\n labelString: option.xTitle || ''\r\n },\r\n ticks: {\r\n callback: (value: number | string, index: number) => {\r\n return option.ticks?.xLabel(value, index) || (Number.isNumber(value) ? Number.toVNCurrency(value) : value);\r\n }\r\n },\r\n stacked: !!option.xStacked\r\n }],\r\n yAxes\r\n },\r\n tooltips: { \r\n callbacks: {\r\n label: (tooltipItem, data) => {\r\n const datasetLabel = data?.datasets[tooltipItem.datasetIndex]?.label;\r\n const label = data?.labels[tooltipItem.index] as string;\r\n const value = data?.datasets[tooltipItem.datasetIndex]?.data[tooltipItem.index] as number;\r\n return option.tooltips?.label({\r\n datasetLabel,\r\n label,\r\n value,\r\n datasetIndex: tooltipItem.datasetIndex,\r\n dataIndex:tooltipItem.index\r\n }) || `${datasetLabel ? `[${datasetLabel}] ` : ''} ${label} : ${Number.toVNCurrency(value)}`;\r\n }\r\n }\r\n }\r\n },\r\n data: {\r\n labels: option.labels,\r\n datasets: option.datasets.map((e, idx) => {\r\n const dynamicColor = this.dynamicColor;\r\n const result: Chart.ChartDataSets = {\r\n type: e.type,\r\n label: e.label,\r\n fill: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n backgroundColor: e.backgroundColor || this.chartConfiguration?.defaultColors?.[idx]?.backgroundColor || dynamicColor,\r\n borderColor: e.borderColor || this.chartConfiguration?.defaultColors?.[idx]?.borderColor || dynamicColor,\r\n data: e.data,\r\n yAxisID: e.yAlign === 'right' ? rightId : leftId,\r\n lineTension: 0,\r\n order:e.order ?? 1\r\n };\r\n return result;\r\n }),\r\n },\r\n plugins: plugins\r\n };\r\n\r\n if (option.hover === 'ShowAll') {\r\n configuration.options.tooltips = {\r\n ...configuration.options.tooltips,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n configuration.options.hover = {\r\n ...configuration.options.hover,\r\n mode: 'index',\r\n intersect: false\r\n };\r\n }\r\n\r\n this.chart = new Chart(this.ctx, configuration);\r\n this.isLoading = false;\r\n }\r\n\r\n loadingStart = () => {\r\n this.isLoading = true;\r\n }\r\n\r\n private get dynamicColor() {\r\n const r = Math.floor(Math.random() * 255);\r\n const g = Math.floor(Math.random() * 255);\r\n const b = Math.floor(Math.random() * 255);\r\n return 'rgb(' + r + ',' + g + ',' + b + ')';\r\n }\r\n\r\n #drawTotalOfStackedBar = (chartType:'barline' | 'bar' | 'horizontalBar'):Chart.PluginServiceRegistrationOptions => {\r\n return {\r\n afterDraw(chartInstance, easing, options) {\r\n if (chartInstance?.data?.datasets?.length){\r\n const ctx = chartInstance.ctx;\r\n chartInstance.data.datasets[0].data.forEach( (dataPoint,index) => {\r\n let curLastIndex = 0;\r\n let curTotal = 0;\r\n chartInstance.data.datasets.forEach( (dataset,setIndex) => {\r\n if (dataset.data[index] != 0 && (!dataset.hidden) && dataset.type !== 'line'){\r\n curLastIndex = setIndex;\r\n if (Number.isNumber(dataset.data[index])){\r\n curTotal += Number(dataset.data[index]);\r\n }\r\n else curTotal += 0;\r\n }\r\n })\r\n const {x,y} = chartInstance.getDatasetMeta(curLastIndex).data[index]._model;\r\n const textWidth = ctx.measureText(curTotal.toString()).width;\r\n ctx.fillStyle= 'black';\r\n let xTextPosition = (x-textWidth/2 ) - textWidth > 0 ? (x-textWidth/2 ) : 0;\r\n if (index == 0){\r\n xTextPosition = x + 10;\r\n }\r\n else if (index === chartInstance.data.datasets[0].data.length - 1 ){\r\n xTextPosition = x - textWidth - 10;\r\n }\r\n ctx.font = '300 10px'\r\n ctx.fillText(curTotal.toString(), chartType === 'horizontalBar' ? x + 10 : xTextPosition, chartType === 'horizontalBar' ? y : y-10);\r\n });\r\n } \r\n },\r\n }\r\n }\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { SdChart } from './chart.component';\r\n\r\n@NgModule({\r\n imports: [\r\n CommonModule\r\n ],\r\n declarations: [\r\n SdChart\r\n ],\r\n exports: [\r\n SdChart\r\n ],\r\n providers: [\r\n ]\r\n})\r\nexport class SdChartModule { }\r\n"]}
@@ -187,7 +187,7 @@
187
187
  { type: core.Component, args: [{
188
188
  selector: 'sd-image-preview-2',
189
189
  template: "<sd-modal [title]=\"' '\" width=\"90%\" #popup>\r\n <sd-modal-body>\r\n <div class=\"c-image-gallery-box\">\r\n <div class=\"c-content-scroll\">\r\n <div class=\"c-content\">\r\n <div class=\"c-content-cell\">\r\n <img src=\"{{imageCurrent}}\" style=\"width: {{imageCurrentWidth}}px\"/>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class=\"c-toolbar\">\r\n <mat-icon (click)=\"imageGalleryBoxZoomOut()\">zoom_out</mat-icon>\r\n <span><b>{{imageCurrentPercent}}%</b></span>\r\n <mat-icon (click)=\"imageGalleryBoxZoomIn()\">zoom_in</mat-icon>\r\n <span>&nbsp;</span>\r\n <mat-icon (click)=\"imageGalleryBoxPrev()\">navigate_before</mat-icon>\r\n <span><b>{{(imageCurrentIndex + 1)}} / {{imageListTotal}}</b></span>\r\n <mat-icon (click)=\"imageGalleryBoxNext()\">navigate_next</mat-icon>\r\n </div>\r\n\r\n </div>\r\n\r\n </sd-modal-body>\r\n</sd-modal>\r\n",
190
- styles: [".c-image-gallery-box{background:rgba(0,0,0,.54);position:relative}.c-image-gallery-box .c-content-scroll{height:79vh;overflow:auto;width:100%}.c-image-gallery-box .c-content-scroll .c-content{display:table;height:100%;width:100%}.c-image-gallery-box .c-content-scroll .c-content .c-content-cell{display:table-cell;text-align:center;vertical-align:middle}.c-image-gallery-box .c-toolbar{-moz-user-select:none;-webkit-user-select:none;background:rgba(0,0,0,.5);border-radius:4px;bottom:18px;color:#eee;left:0;margin-left:auto;margin-right:auto;padding-top:8px;position:absolute;right:0;text-align:center;user-select:none;width:250px}.c-image-gallery-box .c-toolbar span{margin:0 4px;vertical-align:top}.c-image-gallery-box .c-toolbar mat-icon{cursor:pointer;margin:0 4px}"]
190
+ styles: [".c-image-gallery-box{background:rgba(0,0,0,.54);position:relative}.c-image-gallery-box .c-content-scroll{height:79vh;overflow:auto;width:100%}.c-image-gallery-box .c-content-scroll .c-content{display:table;height:100%;width:100%}.c-image-gallery-box .c-content-scroll .c-content .c-content-cell{display:table-cell;text-align:center;vertical-align:middle}.c-image-gallery-box .c-toolbar{-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;background:rgba(0,0,0,.5);border-radius:4px;bottom:18px;color:#eee;left:0;margin-left:auto;margin-right:auto;padding-top:8px;position:absolute;right:0;text-align:center;user-select:none;width:250px}.c-image-gallery-box .c-toolbar span{margin:0 4px;vertical-align:top}.c-image-gallery-box .c-toolbar mat-icon{cursor:pointer;margin:0 4px}"]
191
191
  },] }
192
192
  ];
193
193
  ImagePreviewSdmodalComponent.ctorParameters = function () { return [
@@ -1,2 +1,2 @@
1
- !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/material/dialog"),require("@angular/material/icon"),require("jquery"),require("@sd-angular/core/modal")):"function"==typeof define&&define.amd?define("@sd-angular/core/image-preview",["exports","@angular/core","@angular/common","@angular/material/dialog","@angular/material/icon","jquery","@sd-angular/core/modal"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self)["sd-angular"]=e["sd-angular"]||{},e["sd-angular"].core=e["sd-angular"].core||{},e["sd-angular"].core["image-preview"]={}),e.ng.core,e.ng.common,e.ng.material.dialog,e.ng.material.icon,e.$,e["sd-angular"].core.modal)}(this,(function(e,t,a,r,i,n,o){"use strict";function l(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(a){if("default"!==a){var r=Object.getOwnPropertyDescriptor(e,a);Object.defineProperty(t,a,r.get?r:{enumerable:!0,get:function(){return e[a]}})}})),t.default=e,Object.freeze(t)}var s=l(n),c=function(){function e(e,t){this.dialogRef=e,this.data=t}return e.prototype.ngOnInit=function(){this.currentImageUrl="string"==typeof this.data.currentImage?this.data.currentImage:this.data.currentImage.previewSrc||this.data.currentImage.src},e.prototype.next=function(){var e=this,t=this.data.images.findIndex((function(t){return(t.previewSrc||t.src)===e.currentImageUrl}));t===this.data.images.length-1?this.currentImageUrl=this.data.images[0].previewSrc||this.data.images[0].src:this.currentImageUrl=this.data.images[t+1].previewSrc||this.data.images[t+1].src},e.prototype.prev=function(){var e=this,t=this.data.images.findIndex((function(t){return(t.previewSrc||t.src)===e.currentImageUrl}));this.currentImageUrl=0===t?this.data.images[this.data.images.length-1].previewSrc||this.data.images[this.data.images.length-1].src:this.data.images[t-1].previewSrc||this.data.images[t-1].src},e}();c.decorators=[{type:t.Component,args:[{selector:"app-image-preview",template:'<h1 mat-dialog-title class="d-flex">\r\n <mat-icon\r\n mat-dialog-close\r\n role="img"\r\n class="mat-icon notranslate material-icons mat-icon-no-color ml-auto"\r\n >close</mat-icon\r\n >\r\n</h1>\r\n<div mat-dialog-content class="h-100 position-relative m-0">\r\n <ng-container *ngIf="data?.images?.length">\r\n <span class="material-icons-outlined position-absolute prev" (click)="prev()">\r\n arrow_back_ios\r\n </span>\r\n <span class="material-icons-outlined position-absolute next" (click)="next()">\r\n arrow_forward_ios\r\n </span>\r\n </ng-container>\r\n <img\r\n [src]="currentImageUrl"\r\n class="image-preview_image"\r\n />\r\n</div>\r\n',styles:[".image-prevew-panel .mat-dialog-container{padding:0}:host{display:flex;flex-direction:column;height:100%}.image-preview_image{-o-object-fit:contain;display:block;height:100%;margin:0 auto;object-fit:contain;width:90%}.material-icons-outlined{cursor:pointer}.material-icons-outlined.prev{left:5px;top:50%;transform:translateY(-50%)}.material-icons-outlined.next{right:5px;top:50%;transform:translateY(-50%)}"]}]}],c.ctorParameters=function(){return[{type:r.MatDialogRef},{type:void 0,decorators:[{type:t.Inject,args:[r.MAT_DIALOG_DATA]}]}]};var g,m=function(){function e(e,t){this.el=e,this.dialog=t,this.images=null}return e.prototype.onClick=function(){var e;e=this.el.nativeElement.src,this.images.length&&this.sdPreviewCurrentIdx>=0&&(e=this.images[this.sdPreviewCurrentIdx]),this.dialog.open(c,{data:{currentImage:e,images:this.images},backdropClass:["image-prevew-backdrop"],panelClass:"image-prevew-panel",width:"600px",maxWidth:"90%",height:"600px",maxHeight:"90%"})},e}();m.decorators=[{type:t.Directive,args:[{selector:"[sdImagePreview]"}]}],m.ctorParameters=function(){return[{type:t.ElementRef},{type:r.MatDialog}]},m.propDecorators={images:[{type:t.Input,args:["sdImagePreview"]}],sdPreviewCurrentIdx:[{type:t.Input}],onClick:[{type:t.HostListener,args:["click"]}]};var d=function(){function e(e,t){var a=this;this.dialogRef=e,this.data=t,this.imageList=[],this.imageOrgWidthList=[],this.imageListTotal=0,this.imageCurrent="",this.imageCurrentIndex=0,this.imageCurrentPercent=100,this.imageCurrentWidth=0,g.set(this,(function(){setTimeout((function(){a.imageList=[],a.imageOrgWidthList=[],s("img[alt=c-image-editor-quill]").each((function(e,t){s(t).parent("a").addClass("c-image-editor-quill-box"),s(t).parent("a").click((function(e){e.preventDefault(),e.stopPropagation();var t=s(e.currentTarget).children("img");a.imageCurrent=s(t).attr("src"),a.imageCurrentIndex=a.imageList.findIndex((function(e){return e===a.imageCurrent})),a.imageCurrentPercent=100,a.imageCurrentWidth=s(t)[0].naturalWidth,a.popup.open()})),a.imageList.push(s(t).attr("src")),a.imageOrgWidthList.push(s(t)[0].naturalWidth),a.imageListTotal=a.imageList.length}))}),100)})),this.imageGalleryBoxPrev=function(){a.imageCurrentIndex>0&&(a.imageCurrentIndex--,a.imageCurrent=a.imageList[a.imageCurrentIndex],a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxNext=function(){a.imageCurrentIndex<a.imageList.length-1&&(a.imageCurrentIndex++,a.imageCurrent=a.imageList[a.imageCurrentIndex],a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxZoomIn=function(){a.imageCurrentPercent<200&&(a.imageCurrentPercent+=10,a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxZoomOut=function(){a.imageCurrentPercent>10&&(a.imageCurrentPercent-=10,a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxCalculateWidth=function(){var e=a.imageOrgWidthList[a.imageCurrentIndex];a.imageCurrentWidth=a.imageCurrentPercent*e/100}}return e.prototype.ngOnInit=function(){},e}();g=new WeakMap,d.decorators=[{type:t.Component,args:[{selector:"sd-image-preview-2",template:'<sd-modal [title]="\' \'" width="90%" #popup>\r\n <sd-modal-body>\r\n <div class="c-image-gallery-box">\r\n <div class="c-content-scroll">\r\n <div class="c-content">\r\n <div class="c-content-cell">\r\n <img src="{{imageCurrent}}" style="width: {{imageCurrentWidth}}px"/>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class="c-toolbar">\r\n <mat-icon (click)="imageGalleryBoxZoomOut()">zoom_out</mat-icon>\r\n <span><b>{{imageCurrentPercent}}%</b></span>\r\n <mat-icon (click)="imageGalleryBoxZoomIn()">zoom_in</mat-icon>\r\n <span>&nbsp;</span>\r\n <mat-icon (click)="imageGalleryBoxPrev()">navigate_before</mat-icon>\r\n <span><b>{{(imageCurrentIndex + 1)}} / {{imageListTotal}}</b></span>\r\n <mat-icon (click)="imageGalleryBoxNext()">navigate_next</mat-icon>\r\n </div>\r\n\r\n </div>\r\n\r\n </sd-modal-body>\r\n</sd-modal>\r\n',styles:[".c-image-gallery-box{background:rgba(0,0,0,.54);position:relative}.c-image-gallery-box .c-content-scroll{height:79vh;overflow:auto;width:100%}.c-image-gallery-box .c-content-scroll .c-content{display:table;height:100%;width:100%}.c-image-gallery-box .c-content-scroll .c-content .c-content-cell{display:table-cell;text-align:center;vertical-align:middle}.c-image-gallery-box .c-toolbar{-moz-user-select:none;-webkit-user-select:none;background:rgba(0,0,0,.5);border-radius:4px;bottom:18px;color:#eee;left:0;margin-left:auto;margin-right:auto;padding-top:8px;position:absolute;right:0;text-align:center;user-select:none;width:250px}.c-image-gallery-box .c-toolbar span{margin:0 4px;vertical-align:top}.c-image-gallery-box .c-toolbar mat-icon{cursor:pointer;margin:0 4px}"]}]}],d.ctorParameters=function(){return[{type:r.MatDialogRef},{type:void 0,decorators:[{type:t.Inject,args:[r.MAT_DIALOG_DATA]}]}]},d.propDecorators={popup:[{type:t.ViewChild,args:[o.SdModal]}]};var u=function(){};u.decorators=[{type:t.NgModule,args:[{declarations:[c,d,m],exports:[m],imports:[a.CommonModule,r.MatDialogModule,i.MatIconModule,o.SdModalModule],entryComponents:[c]}]}],e.SdImagePreviewModule=u,e.ɵa=c,e.ɵb=d,e.ɵc=m,Object.defineProperty(e,"__esModule",{value:!0})}));
1
+ !function(e,t){"object"==typeof exports&&"undefined"!=typeof module?t(exports,require("@angular/core"),require("@angular/common"),require("@angular/material/dialog"),require("@angular/material/icon"),require("jquery"),require("@sd-angular/core/modal")):"function"==typeof define&&define.amd?define("@sd-angular/core/image-preview",["exports","@angular/core","@angular/common","@angular/material/dialog","@angular/material/icon","jquery","@sd-angular/core/modal"],t):t(((e="undefined"!=typeof globalThis?globalThis:e||self)["sd-angular"]=e["sd-angular"]||{},e["sd-angular"].core=e["sd-angular"].core||{},e["sd-angular"].core["image-preview"]={}),e.ng.core,e.ng.common,e.ng.material.dialog,e.ng.material.icon,e.$,e["sd-angular"].core.modal)}(this,(function(e,t,a,r,i,n,o){"use strict";function l(e){if(e&&e.__esModule)return e;var t=Object.create(null);return e&&Object.keys(e).forEach((function(a){if("default"!==a){var r=Object.getOwnPropertyDescriptor(e,a);Object.defineProperty(t,a,r.get?r:{enumerable:!0,get:function(){return e[a]}})}})),t.default=e,Object.freeze(t)}var s=l(n),c=function(){function e(e,t){this.dialogRef=e,this.data=t}return e.prototype.ngOnInit=function(){this.currentImageUrl="string"==typeof this.data.currentImage?this.data.currentImage:this.data.currentImage.previewSrc||this.data.currentImage.src},e.prototype.next=function(){var e=this,t=this.data.images.findIndex((function(t){return(t.previewSrc||t.src)===e.currentImageUrl}));t===this.data.images.length-1?this.currentImageUrl=this.data.images[0].previewSrc||this.data.images[0].src:this.currentImageUrl=this.data.images[t+1].previewSrc||this.data.images[t+1].src},e.prototype.prev=function(){var e=this,t=this.data.images.findIndex((function(t){return(t.previewSrc||t.src)===e.currentImageUrl}));this.currentImageUrl=0===t?this.data.images[this.data.images.length-1].previewSrc||this.data.images[this.data.images.length-1].src:this.data.images[t-1].previewSrc||this.data.images[t-1].src},e}();c.decorators=[{type:t.Component,args:[{selector:"app-image-preview",template:'<h1 mat-dialog-title class="d-flex">\r\n <mat-icon\r\n mat-dialog-close\r\n role="img"\r\n class="mat-icon notranslate material-icons mat-icon-no-color ml-auto"\r\n >close</mat-icon\r\n >\r\n</h1>\r\n<div mat-dialog-content class="h-100 position-relative m-0">\r\n <ng-container *ngIf="data?.images?.length">\r\n <span class="material-icons-outlined position-absolute prev" (click)="prev()">\r\n arrow_back_ios\r\n </span>\r\n <span class="material-icons-outlined position-absolute next" (click)="next()">\r\n arrow_forward_ios\r\n </span>\r\n </ng-container>\r\n <img\r\n [src]="currentImageUrl"\r\n class="image-preview_image"\r\n />\r\n</div>\r\n',styles:[".image-prevew-panel .mat-dialog-container{padding:0}:host{display:flex;flex-direction:column;height:100%}.image-preview_image{-o-object-fit:contain;display:block;height:100%;margin:0 auto;object-fit:contain;width:90%}.material-icons-outlined{cursor:pointer}.material-icons-outlined.prev{left:5px;top:50%;transform:translateY(-50%)}.material-icons-outlined.next{right:5px;top:50%;transform:translateY(-50%)}"]}]}],c.ctorParameters=function(){return[{type:r.MatDialogRef},{type:void 0,decorators:[{type:t.Inject,args:[r.MAT_DIALOG_DATA]}]}]};var g,m=function(){function e(e,t){this.el=e,this.dialog=t,this.images=null}return e.prototype.onClick=function(){var e;e=this.el.nativeElement.src,this.images.length&&this.sdPreviewCurrentIdx>=0&&(e=this.images[this.sdPreviewCurrentIdx]),this.dialog.open(c,{data:{currentImage:e,images:this.images},backdropClass:["image-prevew-backdrop"],panelClass:"image-prevew-panel",width:"600px",maxWidth:"90%",height:"600px",maxHeight:"90%"})},e}();m.decorators=[{type:t.Directive,args:[{selector:"[sdImagePreview]"}]}],m.ctorParameters=function(){return[{type:t.ElementRef},{type:r.MatDialog}]},m.propDecorators={images:[{type:t.Input,args:["sdImagePreview"]}],sdPreviewCurrentIdx:[{type:t.Input}],onClick:[{type:t.HostListener,args:["click"]}]};var d=function(){function e(e,t){var a=this;this.dialogRef=e,this.data=t,this.imageList=[],this.imageOrgWidthList=[],this.imageListTotal=0,this.imageCurrent="",this.imageCurrentIndex=0,this.imageCurrentPercent=100,this.imageCurrentWidth=0,g.set(this,(function(){setTimeout((function(){a.imageList=[],a.imageOrgWidthList=[],s("img[alt=c-image-editor-quill]").each((function(e,t){s(t).parent("a").addClass("c-image-editor-quill-box"),s(t).parent("a").click((function(e){e.preventDefault(),e.stopPropagation();var t=s(e.currentTarget).children("img");a.imageCurrent=s(t).attr("src"),a.imageCurrentIndex=a.imageList.findIndex((function(e){return e===a.imageCurrent})),a.imageCurrentPercent=100,a.imageCurrentWidth=s(t)[0].naturalWidth,a.popup.open()})),a.imageList.push(s(t).attr("src")),a.imageOrgWidthList.push(s(t)[0].naturalWidth),a.imageListTotal=a.imageList.length}))}),100)})),this.imageGalleryBoxPrev=function(){a.imageCurrentIndex>0&&(a.imageCurrentIndex--,a.imageCurrent=a.imageList[a.imageCurrentIndex],a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxNext=function(){a.imageCurrentIndex<a.imageList.length-1&&(a.imageCurrentIndex++,a.imageCurrent=a.imageList[a.imageCurrentIndex],a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxZoomIn=function(){a.imageCurrentPercent<200&&(a.imageCurrentPercent+=10,a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxZoomOut=function(){a.imageCurrentPercent>10&&(a.imageCurrentPercent-=10,a.imageGalleryBoxCalculateWidth())},this.imageGalleryBoxCalculateWidth=function(){var e=a.imageOrgWidthList[a.imageCurrentIndex];a.imageCurrentWidth=a.imageCurrentPercent*e/100}}return e.prototype.ngOnInit=function(){},e}();g=new WeakMap,d.decorators=[{type:t.Component,args:[{selector:"sd-image-preview-2",template:'<sd-modal [title]="\' \'" width="90%" #popup>\r\n <sd-modal-body>\r\n <div class="c-image-gallery-box">\r\n <div class="c-content-scroll">\r\n <div class="c-content">\r\n <div class="c-content-cell">\r\n <img src="{{imageCurrent}}" style="width: {{imageCurrentWidth}}px"/>\r\n </div>\r\n </div>\r\n </div>\r\n\r\n <div class="c-toolbar">\r\n <mat-icon (click)="imageGalleryBoxZoomOut()">zoom_out</mat-icon>\r\n <span><b>{{imageCurrentPercent}}%</b></span>\r\n <mat-icon (click)="imageGalleryBoxZoomIn()">zoom_in</mat-icon>\r\n <span>&nbsp;</span>\r\n <mat-icon (click)="imageGalleryBoxPrev()">navigate_before</mat-icon>\r\n <span><b>{{(imageCurrentIndex + 1)}} / {{imageListTotal}}</b></span>\r\n <mat-icon (click)="imageGalleryBoxNext()">navigate_next</mat-icon>\r\n </div>\r\n\r\n </div>\r\n\r\n </sd-modal-body>\r\n</sd-modal>\r\n',styles:[".c-image-gallery-box{background:rgba(0,0,0,.54);position:relative}.c-image-gallery-box .c-content-scroll{height:79vh;overflow:auto;width:100%}.c-image-gallery-box .c-content-scroll .c-content{display:table;height:100%;width:100%}.c-image-gallery-box .c-content-scroll .c-content .c-content-cell{display:table-cell;text-align:center;vertical-align:middle}.c-image-gallery-box .c-toolbar{-moz-user-select:none;-ms-user-select:none;-webkit-user-select:none;background:rgba(0,0,0,.5);border-radius:4px;bottom:18px;color:#eee;left:0;margin-left:auto;margin-right:auto;padding-top:8px;position:absolute;right:0;text-align:center;user-select:none;width:250px}.c-image-gallery-box .c-toolbar span{margin:0 4px;vertical-align:top}.c-image-gallery-box .c-toolbar mat-icon{cursor:pointer;margin:0 4px}"]}]}],d.ctorParameters=function(){return[{type:r.MatDialogRef},{type:void 0,decorators:[{type:t.Inject,args:[r.MAT_DIALOG_DATA]}]}]},d.propDecorators={popup:[{type:t.ViewChild,args:[o.SdModal]}]};var u=function(){};u.decorators=[{type:t.NgModule,args:[{declarations:[c,d,m],exports:[m],imports:[a.CommonModule,r.MatDialogModule,i.MatIconModule,o.SdModalModule],entryComponents:[c]}]}],e.SdImagePreviewModule=u,e.ɵa=c,e.ɵb=d,e.ɵc=m,Object.defineProperty(e,"__esModule",{value:!0})}));
2
2
  //# sourceMappingURL=sd-angular-core-image-preview.umd.min.js.map
@@ -1 +1 @@
1
- {"version":3,"sources":["../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview.component.ts","../../../../projects/sd-core/image-preview/src/lib/directives/image-preview.directive.ts","../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview-sdmodal.component.ts","../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview.module.ts"],"names":["ImagePreviewComponent","dialogRef","data","this","prototype","ngOnInit","currentImageUrl","currentImage","previewSrc","src","next","_this","currentIdx","images","findIndex","image","length","prev","Component","args","selector","template","MatDialogRef","Inject","MAT_DIALOG_DATA","ImagePreviewDirective","el","dialog","onClick","nativeElement","sdPreviewCurrentIdx","open","backdropClass","panelClass","width","maxWidth","height","maxHeight","Directive","ElementRef","MatDialog","Input","HostListener","ImagePreviewSdmodalComponent","imageList","imageOrgWidthList","imageListTotal","imageCurrent","imageCurrentIndex","imageCurrentPercent","imageCurrentWidth","_initImageSlideShowBox","set","setTimeout","$","each","index","obj","parent","addClass","click","e","preventDefault","stopPropagation","currentImg","currentTarget","children","attr","t","naturalWidth","popup","push","imageGalleryBoxPrev","imageGalleryBoxCalculateWidth","imageGalleryBoxNext","imageGalleryBoxZoomIn","imageGalleryBoxZoomOut","orgWidth","ViewChild","SdModal","NgModule","declarations","exports","imports","CommonModule","MatDialogModule","MatIconModule","SdModalModule","entryComponents"],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { ImagePreview } from '../models/image-preview.model';\r\n\r\nexport interface Data {\r\n currentImage: Partial<ImagePreview> | string;\r\n images: Array<Partial<ImagePreview>>\r\n}\r\n\r\n@Component({\r\n selector: 'app-image-preview',\r\n templateUrl: './image-preview.component.html',\r\n styleUrls: ['./image-preview.component.scss']\r\n})\r\nexport class ImagePreviewComponent implements OnInit {\r\n currentImageUrl: string;\r\n\r\n constructor(\r\n public dialogRef: MatDialogRef<ImagePreviewComponent>,\r\n @Inject(MAT_DIALOG_DATA) public data: Data\r\n ) { }\r\n\r\n ngOnInit(): void {\r\n this.currentImageUrl = typeof this.data.currentImage === 'string' ? this.data.currentImage : this.data.currentImage.previewSrc || this.data.currentImage.src;\r\n }\r\n\r\n next(): void {\r\n const currentIdx = this.data.images.findIndex((image: Partial<ImagePreview> )=> (image.previewSrc || image.src) === this.currentImageUrl);\r\n if(currentIdx === this.data.images.length - 1) {\r\n this.currentImageUrl = (this.data.images[0] as Partial<ImagePreview>).previewSrc || (this.data.images[0] as Partial<ImagePreview>).src\r\n } else {\r\n this.currentImageUrl = (this.data.images[currentIdx + 1] as Partial<ImagePreview>).previewSrc || (this.data.images[currentIdx + 1] as Partial<ImagePreview>).src;\r\n }\r\n }\r\n\r\n prev(): void {\r\n const currentIdx = this.data.images.findIndex((image: Partial<ImagePreview> )=> (image.previewSrc || image.src) === this.currentImageUrl);\r\n if(currentIdx === 0) {\r\n this.currentImageUrl = (this.data.images[this.data.images.length - 1] as Partial<ImagePreview>).previewSrc || (this.data.images[this.data.images.length - 1] as Partial<ImagePreview>).src\r\n } else {\r\n this.currentImageUrl = (this.data.images[currentIdx - 1] as Partial<ImagePreview>).previewSrc || (this.data.images[currentIdx - 1] as Partial<ImagePreview>).src;\r\n }\r\n }\r\n\r\n}\r\n","import { Directive, ElementRef, HostListener, Input } from \"@angular/core\";\r\nimport { MatDialog } from \"@angular/material/dialog\";\r\nimport { ImagePreviewComponent } from \"../image-preview/image-preview.component\";\r\n\r\nexport interface ImagePreview {\r\n extension: string;\r\n file: File;\r\n fileName: string;\r\n previewSrc: string;\r\n src: string;\r\n}\r\n\r\n@Directive({\r\n selector: \"[sdImagePreview]\",\r\n})\r\nexport class ImagePreviewDirective {\r\n @Input(\"sdImagePreview\") images?: Array<Partial<ImagePreview>> | string = null;\r\n @Input() sdPreviewCurrentIdx: number;\r\n\r\n constructor(private el: ElementRef, public dialog: MatDialog) {}\r\n\r\n @HostListener(\"click\") onClick() {\r\n let currentImage: string | Partial<ImagePreview>;\r\n currentImage = this.el.nativeElement.src;\r\n if (this.images.length && this.sdPreviewCurrentIdx >= 0) {\r\n currentImage = this.images[this.sdPreviewCurrentIdx];\r\n }\r\n this.dialog.open(ImagePreviewComponent, {\r\n data: { currentImage, images: this.images },\r\n backdropClass: [\"image-prevew-backdrop\"],\r\n panelClass: \"image-prevew-panel\",\r\n width: \"600px\",\r\n maxWidth: \"90%\",\r\n height: \"600px\",\r\n maxHeight: \"90%\",\r\n });\r\n }\r\n}\r\n","import {Component, Inject, OnInit, ViewChild} from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { ImagePreview } from '../models/image-preview.model';\r\nimport * as $ from 'jquery';\r\nimport {SdModal} from '@sd-angular/core/modal';\r\n\r\nexport interface Data {\r\n currentImage: Partial<ImagePreview> | string;\r\n images: Array<Partial<ImagePreview>>;\r\n}\r\n\r\n@Component({\r\n selector: 'sd-image-preview-2',\r\n templateUrl: './image-preview-sdmodal.component.html',\r\n styleUrls: ['./image-preview-sdmodal.component.scss']\r\n})\r\nexport class ImagePreviewSdmodalComponent implements OnInit {\r\n @ViewChild(SdModal) popup: SdModal;\r\n imageList = [];\r\n imageOrgWidthList = [];\r\n imageListTotal = 0;\r\n imageCurrent = '';\r\n imageCurrentIndex = 0;\r\n imageCurrentPercent = 100;\r\n imageCurrentWidth = 0;\r\n\r\n constructor(\r\n public dialogRef: MatDialogRef<ImagePreviewSdmodalComponent>,\r\n @Inject(MAT_DIALOG_DATA) public data: Data\r\n ) { }\r\n\r\n ngOnInit(): void {\r\n // tslint:disable-next-line:max-line-length\r\n // this.currentImageUrl = typeof this.data.currentImage === 'string' ? this.data.currentImage : this.data.currentImage.previewSrc || this.data.currentImage.src;\r\n }\r\n\r\n #initImageSlideShowBox = () => {\r\n setTimeout(() => {\r\n this.imageList = [];\r\n this.imageOrgWidthList = [];\r\n $('img[alt=c-image-editor-quill]').each((index, obj) => {\r\n $(obj).parent('a').addClass('c-image-editor-quill-box');\r\n $(obj).parent('a').click((e) => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n const currentImg = $(e.currentTarget).children('img');\r\n this.imageCurrent = $(currentImg).attr('src');\r\n this.imageCurrentIndex = this.imageList.findIndex(t => t === this.imageCurrent);\r\n this.imageCurrentPercent = 100;\r\n // @ts-ignore\r\n this.imageCurrentWidth = $(currentImg)[0].naturalWidth;\r\n this.popup.open();\r\n });\r\n this.imageList.push($(obj).attr('src'));\r\n // @ts-ignore\r\n this.imageOrgWidthList.push($(obj)[0].naturalWidth);\r\n this.imageListTotal = this.imageList.length;\r\n });\r\n }, 100);\r\n\r\n }\r\n\r\n imageGalleryBoxPrev = () => {\r\n if (this.imageCurrentIndex > 0) {\r\n this.imageCurrentIndex--;\r\n this.imageCurrent = this.imageList[this.imageCurrentIndex];\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxNext = () => {\r\n if (this.imageCurrentIndex < this.imageList.length - 1) {\r\n this.imageCurrentIndex++;\r\n this.imageCurrent = this.imageList[this.imageCurrentIndex];\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxZoomIn = () => {\r\n if (this.imageCurrentPercent < 200) {\r\n this.imageCurrentPercent += 10;\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxZoomOut = () => {\r\n if (this.imageCurrentPercent > 10) {\r\n this.imageCurrentPercent -= 10;\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxCalculateWidth = () => {\r\n const orgWidth = this.imageOrgWidthList[this.imageCurrentIndex];\r\n this.imageCurrentWidth = this.imageCurrentPercent * orgWidth / 100.0;\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ImagePreviewComponent } from './image-preview.component';\r\nimport { ImagePreviewDirective } from '../directives/image-preview.directive';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport {ImagePreviewSdmodalComponent} from './image-preview-sdmodal.component';\r\nimport {SdModalModule} from '@sd-angular/core/modal';\r\n\r\n@NgModule({\r\n declarations: [ImagePreviewComponent, ImagePreviewSdmodalComponent, ImagePreviewDirective],\r\n exports: [ImagePreviewDirective],\r\n imports: [\r\n CommonModule,\r\n MatDialogModule,\r\n MatIconModule,\r\n SdModalModule\r\n ],\r\n entryComponents: [ImagePreviewComponent]\r\n})\r\nexport class SdImagePreviewModule { }\r\n"]}
1
+ {"version":3,"sources":["../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview.component.ts","../../../../projects/sd-core/image-preview/src/lib/directives/image-preview.directive.ts","../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview-sdmodal.component.ts","../../../../projects/sd-core/image-preview/src/lib/image-preview/image-preview.module.ts"],"names":["ImagePreviewComponent","dialogRef","data","this","prototype","ngOnInit","currentImageUrl","currentImage","previewSrc","src","next","_this","currentIdx","images","findIndex","image","length","prev","Component","args","selector","template","MatDialogRef","Inject","MAT_DIALOG_DATA","ImagePreviewDirective","el","dialog","onClick","nativeElement","sdPreviewCurrentIdx","open","backdropClass","panelClass","width","maxWidth","height","maxHeight","Directive","ElementRef","MatDialog","Input","HostListener","ImagePreviewSdmodalComponent","imageList","imageOrgWidthList","imageListTotal","imageCurrent","imageCurrentIndex","imageCurrentPercent","imageCurrentWidth","_initImageSlideShowBox","set","setTimeout","$","each","index","obj","parent","addClass","click","e","preventDefault","stopPropagation","currentImg","currentTarget","children","attr","t","naturalWidth","popup","push","imageGalleryBoxPrev","imageGalleryBoxCalculateWidth","imageGalleryBoxNext","imageGalleryBoxZoomIn","imageGalleryBoxZoomOut","orgWidth","ViewChild","SdModal","NgModule","declarations","exports","imports","CommonModule","MatDialogModule","MatIconModule","SdModalModule","entryComponents"],"mappings":"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","sourcesContent":["import { Component, Inject, OnInit } from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { ImagePreview } from '../models/image-preview.model';\r\n\r\nexport interface Data {\r\n currentImage: Partial<ImagePreview> | string;\r\n images: Array<Partial<ImagePreview>>\r\n}\r\n\r\n@Component({\r\n selector: 'app-image-preview',\r\n templateUrl: './image-preview.component.html',\r\n styleUrls: ['./image-preview.component.scss']\r\n})\r\nexport class ImagePreviewComponent implements OnInit {\r\n currentImageUrl: string;\r\n\r\n constructor(\r\n public dialogRef: MatDialogRef<ImagePreviewComponent>,\r\n @Inject(MAT_DIALOG_DATA) public data: Data\r\n ) { }\r\n\r\n ngOnInit(): void {\r\n this.currentImageUrl = typeof this.data.currentImage === 'string' ? this.data.currentImage : this.data.currentImage.previewSrc || this.data.currentImage.src;\r\n }\r\n\r\n next(): void {\r\n const currentIdx = this.data.images.findIndex((image: Partial<ImagePreview> )=> (image.previewSrc || image.src) === this.currentImageUrl);\r\n if(currentIdx === this.data.images.length - 1) {\r\n this.currentImageUrl = (this.data.images[0] as Partial<ImagePreview>).previewSrc || (this.data.images[0] as Partial<ImagePreview>).src\r\n } else {\r\n this.currentImageUrl = (this.data.images[currentIdx + 1] as Partial<ImagePreview>).previewSrc || (this.data.images[currentIdx + 1] as Partial<ImagePreview>).src;\r\n }\r\n }\r\n\r\n prev(): void {\r\n const currentIdx = this.data.images.findIndex((image: Partial<ImagePreview> )=> (image.previewSrc || image.src) === this.currentImageUrl);\r\n if(currentIdx === 0) {\r\n this.currentImageUrl = (this.data.images[this.data.images.length - 1] as Partial<ImagePreview>).previewSrc || (this.data.images[this.data.images.length - 1] as Partial<ImagePreview>).src\r\n } else {\r\n this.currentImageUrl = (this.data.images[currentIdx - 1] as Partial<ImagePreview>).previewSrc || (this.data.images[currentIdx - 1] as Partial<ImagePreview>).src;\r\n }\r\n }\r\n\r\n}\r\n","import { Directive, ElementRef, HostListener, Input } from \"@angular/core\";\r\nimport { MatDialog } from \"@angular/material/dialog\";\r\nimport { ImagePreviewComponent } from \"../image-preview/image-preview.component\";\r\n\r\nexport interface ImagePreview {\r\n extension: string;\r\n file: File;\r\n fileName: string;\r\n previewSrc: string;\r\n src: string;\r\n}\r\n\r\n@Directive({\r\n selector: \"[sdImagePreview]\",\r\n})\r\nexport class ImagePreviewDirective {\r\n @Input(\"sdImagePreview\") images?: Array<Partial<ImagePreview>> | string = null;\r\n @Input() sdPreviewCurrentIdx: number;\r\n\r\n constructor(private el: ElementRef, public dialog: MatDialog) {}\r\n\r\n @HostListener(\"click\") onClick() {\r\n let currentImage: string | Partial<ImagePreview>;\r\n currentImage = this.el.nativeElement.src;\r\n if (this.images.length && this.sdPreviewCurrentIdx >= 0) {\r\n currentImage = this.images[this.sdPreviewCurrentIdx];\r\n }\r\n this.dialog.open(ImagePreviewComponent, {\r\n data: { currentImage, images: this.images },\r\n backdropClass: [\"image-prevew-backdrop\"],\r\n panelClass: \"image-prevew-panel\",\r\n width: \"600px\",\r\n maxWidth: \"90%\",\r\n height: \"600px\",\r\n maxHeight: \"90%\",\r\n });\r\n }\r\n}\r\n","import {Component, Inject, OnInit, ViewChild} from '@angular/core';\r\nimport { MatDialogRef, MAT_DIALOG_DATA } from '@angular/material/dialog';\r\nimport { ImagePreview } from '../models/image-preview.model';\r\nimport * as $ from 'jquery';\r\nimport {SdModal} from '@sd-angular/core/modal';\r\n\r\nexport interface Data {\r\n currentImage: Partial<ImagePreview> | string;\r\n images: Array<Partial<ImagePreview>>;\r\n}\r\n\r\n@Component({\r\n selector: 'sd-image-preview-2',\r\n templateUrl: './image-preview-sdmodal.component.html',\r\n styleUrls: ['./image-preview-sdmodal.component.scss']\r\n})\r\nexport class ImagePreviewSdmodalComponent implements OnInit {\r\n @ViewChild(SdModal) popup: SdModal;\r\n imageList = [];\r\n imageOrgWidthList = [];\r\n imageListTotal = 0;\r\n imageCurrent = '';\r\n imageCurrentIndex = 0;\r\n imageCurrentPercent = 100;\r\n imageCurrentWidth = 0;\r\n\r\n constructor(\r\n public dialogRef: MatDialogRef<ImagePreviewSdmodalComponent>,\r\n @Inject(MAT_DIALOG_DATA) public data: Data\r\n ) { }\r\n\r\n ngOnInit(): void {\r\n // tslint:disable-next-line:max-line-length\r\n // this.currentImageUrl = typeof this.data.currentImage === 'string' ? this.data.currentImage : this.data.currentImage.previewSrc || this.data.currentImage.src;\r\n }\r\n\r\n #initImageSlideShowBox = () => {\r\n setTimeout(() => {\r\n this.imageList = [];\r\n this.imageOrgWidthList = [];\r\n $('img[alt=c-image-editor-quill]').each((index, obj) => {\r\n $(obj).parent('a').addClass('c-image-editor-quill-box');\r\n $(obj).parent('a').click((e) => {\r\n e.preventDefault();\r\n e.stopPropagation();\r\n const currentImg = $(e.currentTarget).children('img');\r\n this.imageCurrent = $(currentImg).attr('src');\r\n this.imageCurrentIndex = this.imageList.findIndex(t => t === this.imageCurrent);\r\n this.imageCurrentPercent = 100;\r\n // @ts-ignore\r\n this.imageCurrentWidth = $(currentImg)[0].naturalWidth;\r\n this.popup.open();\r\n });\r\n this.imageList.push($(obj).attr('src'));\r\n // @ts-ignore\r\n this.imageOrgWidthList.push($(obj)[0].naturalWidth);\r\n this.imageListTotal = this.imageList.length;\r\n });\r\n }, 100);\r\n\r\n }\r\n\r\n imageGalleryBoxPrev = () => {\r\n if (this.imageCurrentIndex > 0) {\r\n this.imageCurrentIndex--;\r\n this.imageCurrent = this.imageList[this.imageCurrentIndex];\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxNext = () => {\r\n if (this.imageCurrentIndex < this.imageList.length - 1) {\r\n this.imageCurrentIndex++;\r\n this.imageCurrent = this.imageList[this.imageCurrentIndex];\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxZoomIn = () => {\r\n if (this.imageCurrentPercent < 200) {\r\n this.imageCurrentPercent += 10;\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxZoomOut = () => {\r\n if (this.imageCurrentPercent > 10) {\r\n this.imageCurrentPercent -= 10;\r\n this.imageGalleryBoxCalculateWidth();\r\n }\r\n }\r\n imageGalleryBoxCalculateWidth = () => {\r\n const orgWidth = this.imageOrgWidthList[this.imageCurrentIndex];\r\n this.imageCurrentWidth = this.imageCurrentPercent * orgWidth / 100.0;\r\n }\r\n\r\n}\r\n","import { NgModule } from '@angular/core';\r\nimport { CommonModule } from '@angular/common';\r\nimport { ImagePreviewComponent } from './image-preview.component';\r\nimport { ImagePreviewDirective } from '../directives/image-preview.directive';\r\nimport { MatDialogModule } from '@angular/material/dialog';\r\nimport { MatIconModule } from '@angular/material/icon';\r\nimport {ImagePreviewSdmodalComponent} from './image-preview-sdmodal.component';\r\nimport {SdModalModule} from '@sd-angular/core/modal';\r\n\r\n@NgModule({\r\n declarations: [ImagePreviewComponent, ImagePreviewSdmodalComponent, ImagePreviewDirective],\r\n exports: [ImagePreviewDirective],\r\n imports: [\r\n CommonModule,\r\n MatDialogModule,\r\n MatIconModule,\r\n SdModalModule\r\n ],\r\n entryComponents: [ImagePreviewComponent]\r\n})\r\nexport class SdImagePreviewModule { }\r\n"]}
@@ -2510,7 +2510,7 @@
2510
2510
  animations.transition('expanded <=> collapsed', animations.animate('225ms cubic-bezier(0.4, 0.0, 0.2, 1)')),
2511
2511
  ]),
2512
2512
  ],
2513
- styles: [".text-black400{color:#757575}:host{display:flex;flex-direction:column;height:100%;overflow:auto}:host .c-container{display:flex;flex-direction:column}:host .c-container,:host .c-container .c-table{flex:1;position:relative}:host .c-container .c-table table{border-collapse:separate;width:100%}:host .c-container .c-table table tr.c-first-header.mat-header-row,:host .c-container .c-table table tr.c-second-header.mat-header-row{height:40px}:host .c-container .c-table table tr.c-detail-row{height:0}:host .c-container .c-table table tr.c-row.activated{background-color:#e5ecff}:host .c-container .c-table table tr.c-row.selected{background-color:#eef2ff}:host .c-container .c-table table tr.c-row:not(.selected):not(.activated):hover{background-color:#f5f5f5}:host .c-container .c-table table tr.c-row td{border-bottom-width:0}:host .c-container .c-table table tr.c-row.c-expandable{cursor:pointer}:host .c-container .c-table table tr.c-row.c-expandable:hover{background:#f5f5f5}:host .c-container .c-table table th.mat-header-cell{background-color:#f2f3f4;border-bottom:0!important}:host .c-container .c-table table td.mat-cell,:host .c-container .c-table table td.mat-footer-cell,:host .c-container .c-table table th.mat-header-cell{border-bottom-color:#f2f2f2!important}:host .c-container .c-table .c-th{color:#212121;font-size:14px;font-weight:500;line-height:20px;vertical-align:middle}:host .c-container .c-table .c-td:first{padding-left:10px}:host .c-container .c-loading{align-items:center;background:rgba(0,0,0,.15);bottom:56px;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:2}:host .c-container .c-paginator{align-items:center;background-color:#fff;display:flex;flex-direction:row;justify-content:space-between}:host .c-container .c-paginator .c-action{padding:5px}:host .c-container .c-empty{background-color:#fff;border:none!important;text-align:center}:host .c-container .c-empty mat-icon{font-size:150px;height:auto;margin-bottom:30px;margin-top:30px;opacity:.2;width:auto}:host button.c-btn-add{background-color:#fff;box-shadow:0 2px 4px rgba(47,49,54,.16)}:host mat-icon.c-icon{color:rgba(0,0,0,.54)!important}:host mat-icon.c-icon-add{color:#2962ff!important}:host .lds-ring{display:inline-block;height:40px;position:relative;width:40px}:host .lds-ring div{-webkit-animation:lds-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;animation:lds-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;border:4px solid transparent;border-radius:50%;border-top-color:#cef;box-sizing:border-box;display:block;height:32px;margin:4px;position:absolute;width:32px}:host .lds-ring div:first-child{-webkit-animation-delay:-.45s;animation-delay:-.45s}:host .lds-ring div:nth-child(2){-webkit-animation-delay:-.3s;animation-delay:-.3s}:host .lds-ring div:nth-child(3){-webkit-animation-delay:-.15s;animation-delay:-.15s}@-webkit-keyframes lds-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes lds-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:host ::ng-deep .mat-sort-header-content{display:block;text-align:left;width:100%}:host ::ng-deep .mat-select-arrow{color:#a6a6a6}:host ::ng-deep .mat-sort-header-disabled{background-image:none!important;cursor:default!important;padding-right:0!important}:host ::ng-deep .mat-sort-header-container{align-items:start!important}:host ::ng-deep .mat-sort-header-arrow{margin-top:4px!important}:host ::ng-deep .mat-sort-header{cursor:pointer}:host ::ng-deep .mat-sort-header[aria-sort]{background-position:center right 0;background-repeat:no-repeat;background-size:16px 16px;cursor:pointer;padding-right:24px}:host ::ng-deep .mat-sort-header[aria-sort=none]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z'/%3E%3C/svg%3E\")}:host ::ng-deep .mat-sort-header[aria-sort=ascending]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z'/%3E%3C/svg%3E\")}:host ::ng-deep .mat-sort-header[aria-sort=descending]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z'/%3E%3C/svg%3E\")}"]
2513
+ styles: [".text-black400{color:#757575}:host{display:flex;flex-direction:column;height:100%;overflow:auto}:host .c-container{display:flex;flex-direction:column;min-height:50px}:host .c-container,:host .c-container .c-table{flex:1;position:relative}:host .c-container .c-table table{border-collapse:separate;width:100%}:host .c-container .c-table table tr.c-first-header.mat-header-row,:host .c-container .c-table table tr.c-second-header.mat-header-row{height:40px}:host .c-container .c-table table tr.c-detail-row{height:0}:host .c-container .c-table table tr.c-row.activated{background-color:#e5ecff}:host .c-container .c-table table tr.c-row.selected{background-color:#eef2ff}:host .c-container .c-table table tr.c-row:not(.selected):not(.activated):hover{background-color:#f5f5f5}:host .c-container .c-table table tr.c-row td{border-bottom-width:0}:host .c-container .c-table table tr.c-row.c-expandable{cursor:pointer}:host .c-container .c-table table tr.c-row.c-expandable:hover{background:#f5f5f5}:host .c-container .c-table table th.mat-header-cell{background-color:#f2f3f4;border-bottom:0!important}:host .c-container .c-table table td.mat-cell,:host .c-container .c-table table td.mat-footer-cell,:host .c-container .c-table table th.mat-header-cell{border-bottom-color:#f2f2f2!important}:host .c-container .c-table .c-th{color:#212121;font-size:14px;font-weight:500;line-height:20px;vertical-align:middle}:host .c-container .c-table .c-td:first{padding-left:10px}:host .c-container .c-loading{align-items:center;background:rgba(0,0,0,.15);bottom:56px;display:flex;justify-content:center;left:0;position:absolute;right:0;top:0;z-index:2}:host .c-container .c-paginator{align-items:center;background-color:#fff;display:flex;flex-direction:row;justify-content:space-between}:host .c-container .c-paginator .c-action{padding:5px}:host .c-container .c-empty{background-color:#fff;border:none!important;text-align:center}:host .c-container .c-empty mat-icon{font-size:150px;height:auto;margin-bottom:30px;margin-top:30px;opacity:.2;width:auto}:host button.c-btn-add{background-color:#fff;box-shadow:0 2px 4px rgba(47,49,54,.16)}:host mat-icon.c-icon{color:rgba(0,0,0,.54)!important}:host mat-icon.c-icon-add{color:#2962ff!important}:host .lds-ring{display:inline-block;height:40px;position:relative;width:40px}:host .lds-ring div{-webkit-animation:lds-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;animation:lds-ring 1.2s cubic-bezier(.5,0,.5,1) infinite;border:4px solid transparent;border-radius:50%;border-top-color:#cef;box-sizing:border-box;display:block;height:32px;margin:4px;position:absolute;width:32px}:host .lds-ring div:first-child{-webkit-animation-delay:-.45s;animation-delay:-.45s}:host .lds-ring div:nth-child(2){-webkit-animation-delay:-.3s;animation-delay:-.3s}:host .lds-ring div:nth-child(3){-webkit-animation-delay:-.15s;animation-delay:-.15s}@-webkit-keyframes lds-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}@keyframes lds-ring{0%{transform:rotate(0deg)}to{transform:rotate(1turn)}}:host ::ng-deep .mat-sort-header-content{display:block;text-align:left;width:100%}:host ::ng-deep .mat-select-arrow{color:#a6a6a6}:host ::ng-deep .mat-sort-header-disabled{background-image:none!important;cursor:default!important;padding-right:0!important}:host ::ng-deep .mat-sort-header-container{align-items:start!important}:host ::ng-deep .mat-sort-header-arrow{margin-top:4px!important}:host ::ng-deep .mat-sort-header{cursor:pointer}:host ::ng-deep .mat-sort-header[aria-sort]{background-position:center right 0;background-repeat:no-repeat;background-size:16px 16px;cursor:pointer;padding-right:24px}:host ::ng-deep .mat-sort-header[aria-sort=none]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M12 5.83L15.17 9l1.41-1.41L12 3 7.41 7.59 8.83 9 12 5.83zm0 12.34L8.83 15l-1.41 1.41L12 21l4.59-4.59L15.17 15 12 18.17z'/%3E%3C/svg%3E\")}:host ::ng-deep .mat-sort-header[aria-sort=ascending]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M4 12l1.41 1.41L11 7.83V20h2V7.83l5.58 5.59L20 12l-8-8-8 8z'/%3E%3C/svg%3E\")}:host ::ng-deep .mat-sort-header[aria-sort=descending]{background-image:url(\"data:image/svg+xml,%3Csvg xmlns='http://www.w3.org/2000/svg' height='24px' viewBox='0 0 24 24' width='24px' fill='%23000000'%3E%3Cpath d='M0 0h24v24H0V0z' fill='none'/%3E%3Cpath fill='%237A7A7A' d='M20 12l-1.41-1.41L13 16.17V4h-2v12.17l-5.58-5.59L4 12l8 8 8-8z'/%3E%3C/svg%3E\")}"]
2514
2514
  },] }
2515
2515
  ];
2516
2516
  SdTable.ctorParameters = function () { return [