@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?
125 lines • 18.3 kB
JavaScript
import { Component, EventEmitter } from '@angular/core';
import * as i0 from "@angular/core";
import * as i1 from "@angular/common";
export class LikeComponent {
constructor() {
this.thumbs = "";
this.disabled = false;
this.active = true;
this.validate = (item, newValue) => true;
this.onIntoComponentChange = new EventEmitter();
}
static settingsPatterns() {
return ['like:true:true::true', 'like:true:false::true']; //show count, state, source attribute key, up/down
}
transform(source, data, args) {
this.source = source;
this.data = data;
this.showCount = (args && args.length > 0 && args[0].length && args[0] === 'true');
this.thumbsup = (args && args.length > 1 && args[1].length && args[1] === 'true');
this.key = (args && args.length > 2) ? args[2] : "";
this.thumbs = this.thumbsup ? "thumbs-up-items" : "thumbs-down-items";
this.selected = (this.getItem(this.data[this.key]) !== null);
}
keyup(event) {
const code = event.which;
if (code === 13 && !this.disabled) {
event.target.click();
}
}
addItem(id) {
const saved = localStorage.getItem(this.thumbs);
if (saved) {
const savedItems = JSON.parse(saved);
savedItems.push(id);
localStorage.setItem(this.thumbs, JSON.stringify(savedItems));
}
else {
localStorage.setItem(this.thumbs, JSON.stringify([id]));
}
this.source++;
}
removeItem(id) {
const saved = localStorage.getItem(this.thumbs);
if (saved) {
const savedItems = JSON.parse(saved);
const i = savedItems.indexOf(id);
savedItems.splice(i, 1);
localStorage.setItem(this.thumbs, JSON.stringify(savedItems));
this.source--;
}
}
getItem(id) {
const saved = localStorage.getItem(this.thumbs);
let found = null;
if (saved) {
const savedItems = JSON.parse(saved);
const i = savedItems.indexOf(id);
found = i < 0 ? null : savedItems[i];
}
return found;
}
formatterSource() {
let result = this.source;
if (this.source > 1000) {
result = (this.source / 1000).toFixed(1) + " k";
}
return result;
}
toggleCount(event) {
event.stopPropagation();
event.preventDefault();
if (!this.disabled && this.validate(this.data, !this.source)) {
this.selected = !this.selected;
if (this.selected) {
const existing = this.getItem(this.data[this.key]);
if (!existing) {
this.addItem(this.data[this.key]);
}
}
else {
this.removeItem(this.data[this.key]);
}
this.onIntoComponentChange.emit({
id: this.id,
name: this.name,
value: this.source,
type: "change",
item: this.data,
selected: this.selected,
action: this.thumbs
});
}
}
}
LikeComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: LikeComponent, deps: [], target: i0.ɵɵFactoryTarget.Component });
LikeComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: LikeComponent, selector: "like-component", ngImport: i0, template: `
<a
id='like-{{id}}'
tabindex="{{active ? 0 : -1}}"
class="like"
[class.selected]="selected"
[class.disabled]="disabled"
(keyup)="keyup($event)"
(click)='toggleCount($event)'>
<span class="fa fa-thumbs-up" *ngIf="thumbsup" aria-hidden="true"></span>
<span class="fa fa-thumbs-down" *ngIf="!thumbsup" aria-hidden="true"></span>
<span class="counts" *ngIf="showCount" [textContent]="formatterSource()"></span>
</a>`, isInline: true, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px);position:relative}.like{cursor:pointer}.like.disabled{cursor:default;pointer-events:none}.like.disabled .fa{color:var(--sedeh-disabled-color, #888)}.like .counts{margin-left:var(--sedeh-margin-left, 5px)}.like .fa{margin:0}.like:focus{outline:none}.like:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.like.selected .counts,.like.selected .fa{color:var(--sedeh-sected-color, green)}:host .like:hover,.like:hover .fa,.like:hover .fa.selected{opacity:var(--sedeh-hover-opacity, .5)}:host .like.disabled:hover,.like.disabled:hover .fa,.like.disabled:hover .fa.selected{color:var(--sedeh-disabled-color, #888)}\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: LikeComponent, decorators: [{
type: Component,
args: [{ selector: 'like-component', template: `
<a
id='like-{{id}}'
tabindex="{{active ? 0 : -1}}"
class="like"
[class.selected]="selected"
[class.disabled]="disabled"
(keyup)="keyup($event)"
(click)='toggleCount($event)'>
<span class="fa fa-thumbs-up" *ngIf="thumbsup" aria-hidden="true"></span>
<span class="fa fa-thumbs-down" *ngIf="!thumbsup" aria-hidden="true"></span>
<span class="counts" *ngIf="showCount" [textContent]="formatterSource()"></span>
</a>`, styles: [":host{display:table;float:left;min-height:var(--sedeh-min-height, 25px);position:relative}.like{cursor:pointer}.like.disabled{cursor:default;pointer-events:none}.like.disabled .fa{color:var(--sedeh-disabled-color, #888)}.like .counts{margin-left:var(--sedeh-margin-left, 5px)}.like .fa{margin:0}.like:focus{outline:none}.like:focus .fa{zoom:1.1;right:var(--sedeh-shift-right, 0);position:relative;color:var(--sedeh-focus-color, darkblue)}.like.selected .counts,.like.selected .fa{color:var(--sedeh-sected-color, green)}:host .like:hover,.like:hover .fa,.like:hover .fa.selected{opacity:var(--sedeh-hover-opacity, .5)}:host .like.disabled:hover,.like.disabled:hover .fa,.like.disabled:hover .fa.selected{color:var(--sedeh-disabled-color, #888)}\n"] }]
}] });
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"like.component.js","sourceRoot":"","sources":["../../../../../projects/into-pipes/src/lib/like/like.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: 'like-component',\r\n    template: `\r\n    <a \r\n        id='like-{{id}}' \r\n        tabindex=\"{{active ? 0 : -1}}\" \r\n        class=\"like\" \r\n        [class.selected]=\"selected\" \r\n        [class.disabled]=\"disabled\" \r\n        (keyup)=\"keyup($event)\" \r\n        (click)='toggleCount($event)'>\r\n        <span class=\"fa fa-thumbs-up\" *ngIf=\"thumbsup\" aria-hidden=\"true\"></span>\r\n        <span class=\"fa fa-thumbs-down\" *ngIf=\"!thumbsup\" aria-hidden=\"true\"></span>\r\n        <span class=\"counts\" *ngIf=\"showCount\" [textContent]=\"formatterSource()\"></span>\r\n    </a>`,\r\n    styles: [\r\n        `\r\n        :host {display:table;float:left;min-height: var(--sedeh-min-height, 25px);position: relative}\r\n        .like {cursor: pointer;}\r\n        .like.disabled {cursor: default;pointer-events: none}\r\n        .like.disabled .fa{color: var(--sedeh-disabled-color, #888);}\r\n        .like .counts{margin-left: var(--sedeh-margin-left, 5px);}\r\n        .like .fa {margin: 0;}\r\n        .like:focus{outline: none;}\r\n        .like:focus .fa{zoom: 1.1;right: var(--sedeh-shift-right, 0);position: relative;color: var(--sedeh-focus-color, darkblue);}\r\n        .like.selected .counts, .like.selected .fa {color: var(--sedeh-sected-color, green);}\r\n        :host .like:hover, .like:hover .fa, .like:hover .fa.selected{opacity: var(--sedeh-hover-opacity, 0.5);}\r\n        :host .like.disabled:hover, .like.disabled:hover .fa, .like.disabled:hover .fa.selected{color: var(--sedeh-disabled-color, #888);}\r\n        `\r\n    ]\r\n})\r\nexport class LikeComponent implements PipeComponentInterface {\r\n  source: any;\r\n  id!: string;\r\n  data: any;\r\n\tname!: string;\r\n  showCount!: boolean;\r\n  thumbsup!: boolean;\r\n  selected!: boolean;\r\n  key!: string;\r\n  thumbs = \"\";\r\n  disabled = false;\r\n  active = true;\r\n  validate = (item: any, newValue: any) => true;\r\n\r\n\tonIntoComponentChange = new EventEmitter();\r\n\r\n  static settingsPatterns() {\r\n    return ['like:true:true::true', 'like:true:false::true']; //show count, state, source attribute key, up/down\r\n  }\r\n  transform(source: any, data: any, args: any[]) {\r\n    this.source = source;\r\n    this.data = data;\r\n    this.showCount = (args && args.length > 0 && args[0].length && args[0] === 'true');\r\n    this.thumbsup = (args && args.length > 1 && args[1].length && args[1] === 'true');\r\n    this.key = (args && args.length > 2) ? args[2] : \"\";\r\n    this.thumbs = this.thumbsup ? \"thumbs-up-items\" : \"thumbs-down-items\";\r\n    this.selected = (this.getItem(this.data[this.key]) !== null);\r\n  }\r\n  keyup(event: any) {\r\n    const code = event.which;\r\n\r\n    if (code === 13 && !this.disabled) {\r\n      event.target.click();\r\n    }\r\n  }\r\n  private addItem(id: string) {\r\n    const saved = localStorage.getItem(this.thumbs);\r\n    if (saved) {\r\n      const savedItems = JSON.parse(saved);\r\n      savedItems.push(id);\r\n      localStorage.setItem(this.thumbs, JSON.stringify(savedItems));\r\n    } else {\r\n      localStorage.setItem(this.thumbs, JSON.stringify([id]));\r\n    }\r\n    this.source ++;\r\n  }\r\n  private removeItem(id: string) {\r\n    const saved = localStorage.getItem(this.thumbs);\r\n    if (saved) {\r\n      const savedItems = JSON.parse(saved);\r\n      const i = savedItems.indexOf(id);\r\n      savedItems.splice(i, 1);\r\n\r\n      localStorage.setItem(this.thumbs, JSON.stringify(savedItems));\r\n      this.source --;\r\n    }\r\n  }\r\n  private getItem(id: string) {\r\n    const saved = localStorage.getItem(this.thumbs);\r\n    let found = null;\r\n\r\n    if (saved) {\r\n      const savedItems: any[] = JSON.parse(saved);\r\n      const i = savedItems.indexOf(id);\r\n\r\n      found = i < 0 ? null : savedItems[i];\r\n    }\r\n    return found;\r\n  }\r\n  formatterSource() {\r\n    let result = this.source;\r\n    if (this.source > 1000) {\r\n      result = (this.source/1000).toFixed(1) + \" k\"\r\n    }\r\n    return result;\r\n  }\r\n  toggleCount(event: any) {\r\n    event.stopPropagation();\r\n    event.preventDefault();\r\n    \r\n    if (!this.disabled && this.validate(this.data, !this.source)) {\r\n      this.selected = !this.selected;\r\n      if (this.selected) {\r\n        const existing = this.getItem(this.data[this.key]);\r\n        if (!existing) {\r\n          this.addItem(this.data[this.key]);\r\n        }\r\n      } else {\r\n        this.removeItem(this.data[this.key]);\r\n      }\r\n      this.onIntoComponentChange.emit({\r\n        id: this.id,\r\n        name: this.name,\r\n        value: this.source,\r\n        type: \"change\",\r\n        item: this.data,\r\n        selected: this.selected,\r\n        action: this.thumbs\r\n      });\r\n    }\r\n  }\r\n}"]}