@sedeh/into-pipes
Version:
Have you ever wanted to transform data in different parts of your application into interactive objects without writing a single line of code?
75 lines • 14.2 kB
JavaScript
import { Component } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class LastUpdateComponent {
constructor() {
this.disabled = false;
this.active = true;
this.validate = (item, newValue) => true;
}
static settingsPatterns() {
return ['lastupdate:false', 'lastupdate:true']; //show icon
}
transform(source, data, args) {
this.source = source;
this.showIcon = (args && args.length > 0 && args[0].length && args[0] === 'true');
}
formatDate() {
const currentDate = new Date();
const minute = 60000; // one minute
const hour = 3600000; // one hour limit
const day = 86400000; // 24 hours limit
const week = 604800000; // 7 days limit
const month = 604800000 * 4; // 7 days limit
const year = 604800000 * 52; // 7 days limit
let result = "";
let diff = currentDate.getTime() - this.source.getTime();
if (diff <= minute) { // up to a minute
result = "seconds ago";
}
else if (diff <= hour) { // up to an hour
let minutes = Math.floor(diff / minute);
let seconds = Math.floor((diff - (minutes * minute)) / 1000);
result = (minutes < 2 ? "a minute" : minutes + " minutes ") + (seconds > 0 ? " and " + seconds + " seconds ago" : " ago");
}
else if (diff <= day) { // up to a day
let hours = Math.floor(diff / hour);
let minutes = Math.floor((diff - (hours * hour)) / minute);
result = (hours < 2 ? "an hour" : hours + " hours ") + (minutes > 0 ? " and " + minutes + " minutes ago" : " ago");
}
else if (diff <= week) { // up to a week
let days = Math.floor(diff / day);
let hours = Math.floor((diff - (days * day)) / hour);
result = (days < 2 ? "a day" : days + " days ") + (hours > 0 ? " and " + hours + " hours ago" : " ago");
}
else if (diff <= month) { // up to a month
let weeks = Math.floor(diff / week);
let days = Math.floor((diff - (weeks * week)) / day);
result = (weeks < 2 ? "a week" : weeks + " weeks ") + (days > 0 ? " and " + days + " days ago" : " ago");
}
else if (diff <= year) { // up to a week
let months = Math.floor(diff / month);
let weeks = Math.floor((diff - (months * month)) / week);
result = (months < 2 ? "a month" : months + " months ") + (weeks > 0 ? " and " + weeks + " weeks ago" : " ago");
}
else {
let years = Math.floor(diff / year);
let months = Math.floor((diff - (years * year)) / month);
result = (years < 2 ? "a year" : years + " years ") + (months > 0 ? " and " + months + " months ago" : " ago");
}
return result;
}
}
LastUpdateComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LastUpdateComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
LastUpdateComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: LastUpdateComponent, selector: "lastupdate-component", ngImport: i0, template: `
<span *ngIf="showIcon" class="fa fa-clock-o" aria-hidden="true"></span>
<span>{{formatDate()}}</span>
`, isInline: true, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px);position:relative}.fa{margin:var(--sedeh-margin, 0 5px)}@media print{:host .fa-clock-o{display:none}}\n"], dependencies: [{ kind: "directive", type: i1.NgIf, selector: "[ngIf]", inputs: ["ngIf", "ngIfThen", "ngIfElse"] }] });
i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LastUpdateComponent, decorators: [{
type: Component,
args: [{ selector: 'lastupdate-component', template: `
<span *ngIf="showIcon" class="fa fa-clock-o" aria-hidden="true"></span>
<span>{{formatDate()}}</span>
`, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px);position:relative}.fa{margin:var(--sedeh-margin, 0 5px)}@media print{:host .fa-clock-o{display:none}}\n"] }]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"lastupdate.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/lastupdate/lastupdate.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, EventEmitter } from '@angular/core';\r\nimport { PipeComponentInterface } from '../common/pipe.component.interface';\r\n\r\n@Component({\r\n    selector: 'lastupdate-component',\r\n    template: `\r\n    <span *ngIf=\"showIcon\" class=\"fa fa-clock-o\" aria-hidden=\"true\"></span>\r\n    <span>{{formatDate()}}</span>\r\n    `,\r\n    styles: [\r\n        `\r\n        :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px);position: relative}\r\n        .fa {margin:var(--sedeh-margin, 0 5px)}\r\n        @media print {\r\n            :host .fa-clock-o {\r\n                display: none;\r\n            }\r\n        }\r\n        `\r\n    ]\r\n})\r\nexport class LastUpdateComponent implements PipeComponentInterface {\r\n    source: any;\r\n\tid!: string;\r\n    name!: string;\r\n    showIcon!: boolean;\r\n\tdisabled = false;\r\n\tactive = true;\r\n\tvalidate = (item: any, newValue: any) => true;\r\n    \r\n    count!: string;\r\n\tonIntoComponentChange!: EventEmitter<any>;\r\n\r\n    static settingsPatterns() {\r\n\t\treturn ['lastupdate:false', 'lastupdate:true']; //show icon\r\n\t}\r\n\ttransform(source: any, data: any, args: any[]) {\r\n        this.source = source;\r\n        this.showIcon = (args && args.length > 0 && args[0].length && args[0] === 'true');\r\n    }\r\n\r\n    formatDate() {\r\n\t\tconst currentDate = new Date();\r\n\t\tconst minute = 60000;// one minute\r\n\t\tconst hour = 3600000;// one hour limit\r\n\t\tconst day = 86400000;// 24 hours limit\r\n\t\tconst week = 604800000;// 7 days limit\r\n\t\tconst month = 604800000*4;// 7 days limit\r\n\t\tconst year = 604800000*52;// 7 days limit\r\n\t\tlet result = \"\";\r\n\r\n\t\tlet diff = currentDate.getTime() - this.source.getTime();\r\n\r\n\t\tif(diff <= minute) {// up to a minute\r\n\t\t\tresult = \"seconds ago\";\r\n\t\t}else if(diff <= hour) {// up to an hour\r\n\t\t\tlet minutes = Math.floor(diff/minute);\r\n\t\t\tlet seconds = Math.floor((diff - (minutes * minute))/1000);\r\n\r\n\t\t\tresult = (minutes < 2 ? \"a minute\" : minutes + \" minutes \") + (seconds > 0 ? \" and \" + seconds + \" seconds ago\" : \" ago\");\r\n\t\t}else if(diff <= day) {// up to a day\r\n\t\t\tlet hours = Math.floor(diff/hour);\r\n\t\t\tlet minutes = Math.floor((diff - (hours * hour))/minute);\r\n\t\t\t\r\n\t\t\tresult = (hours < 2 ? \"an hour\" : hours + \" hours \") + (minutes > 0 ? \" and \" + minutes + \" minutes ago\" : \" ago\");\r\n\t\t}else if(diff <= week) {// up to a week\r\n\t\t\tlet days = Math.floor(diff/day);\r\n\t\t\tlet hours = Math.floor((diff - (days * day))/hour);\r\n\r\n\t\t\tresult = (days < 2 ? \"a day\" : days + \" days \") + (hours > 0 ? \" and \" + hours + \" hours ago\" : \" ago\");\r\n\t\t}else if(diff <= month) {// up to a month\r\n\t\t\tlet weeks = Math.floor(diff/week);\r\n\t\t\tlet days = Math.floor((diff - (weeks * week))/day);\r\n\r\n\t\t\tresult = (weeks < 2 ? \"a week\" : weeks + \" weeks \") + (days > 0 ? \" and \" + days + \" days ago\" : \" ago\");\r\n\t\t}else if(diff <= year) {// up to a week\r\n\t\t\tlet months = Math.floor(diff/month);\r\n\t\t\tlet weeks = Math.floor((diff - (months * month))/week);\r\n\r\n\t\t\tresult = (months < 2 ? \"a month\" : months + \" months \") + (weeks > 0 ? \" and \" + weeks + \" weeks ago\" : \" ago\");\r\n\t\t} else {\r\n\t\t\tlet years = Math.floor(diff/year);\r\n\t\t\tlet months = Math.floor((diff - (years * year))/month);\r\n\r\n\t\t\tresult = (years < 2 ? \"a year\" : years + \" years \") + (months > 0 ? \" and \" + months + \" months ago\" : \" ago\");\r\n\t\t}\r\n\t\treturn result;\r\n\t}\r\n\r\n}\r\n"]}