ionic4-emoji-picker
Version:
Emoji picker with slides and tabs (like emoji picker on Whatsapp) This library was generated with [Angular CLI](https://github.com/angular/angular-cli) version 8.2.14.
173 lines • 15.8 kB
JavaScript
/**
* @fileoverview added by tsickle
* Generated from: lib/ionic4-emoji-picker.component.ts
* @suppress {checkTypes,constantProperty,extraRequire,missingOverride,missingReturn,unusedPrivateMembers,uselessCode} checked by tsc
*/
import * as tslib_1 from "tslib";
import { Component, ViewChild, ElementRef, EventEmitter, Output, Input } from '@angular/core';
import { EMOJIS } from '../data/emoji.data';
import { IonSlides, ModalController } from '@ionic/angular';
var Ionic4EmojiPickerComponent = /** @class */ (function () {
function Ionic4EmojiPickerComponent(modalCtrl) {
this.modalCtrl = modalCtrl;
this.emojiCategories = [];
this.mainEmojiData = EMOJIS;
this.currentEmojiList = [];
this.currentCategoryName = '';
this.isInModal = false; //To determine whether this componet is created using a modal or not
//To determine whether this componet is created using a modal or not
this.selectionEvent = new EventEmitter(); //TO emmit event when an emoji is selected
}
/**
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.ngOnInit = /**
* @return {?}
*/
function () {
this.getEmojiCategories();
};
/**
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.ngAfterViewInit = /**
* @return {?}
*/
function () {
var _this = this;
console.log('ngAfterViewInit');
this.setActiveCategorySlide();
this.slides.ionSlideDidChange.subscribe((/**
* @param {?} data
* @return {?}
*/
function (data) {
console.log('Slide changed data', data);
_this.setActiveCategorySlide();
}));
};
/**
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.getEmojiCategories = /**
* @return {?}
*/
function () {
var _this = this;
this.mainEmojiData.forEach((/**
* @param {?} category
* @return {?}
*/
function (category) {
_this.emojiCategories.push(category);
}));
this.currentCategoryName = this.emojiCategories[0].name;
this.currentEmojiList = this.emojiCategories[0].emojis;
};
/**
* @param {?} selectedEmojiList
* @param {?} categoryIndex
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.categoryChanged = /**
* @param {?} selectedEmojiList
* @param {?} categoryIndex
* @return {?}
*/
function (selectedEmojiList, categoryIndex) {
this.currentEmojiList = selectedEmojiList.emojis;
this.currentCategoryName = selectedEmojiList.name;
this.slides.slideTo(categoryIndex);
this.setActiveCategorySlide();
};
/**
* @param {?} code
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.selectEmoji = /**
* @param {?} code
* @return {?}
*/
function (code) {
/** @type {?} */
var selectionData = {
data: code
};
this.selectionEvent.emit(selectionData);
if (this.isInModal) {
this.modalCtrl.dismiss(selectionData); //Dismiss the modal with data
}
};
/**
* @return {?}
*/
Ionic4EmojiPickerComponent.prototype.setActiveCategorySlide = /**
* @return {?}
*/
function () {
return tslib_1.__awaiter(this, void 0, void 0, function () {
var _this = this;
return tslib_1.__generator(this, function (_a) {
switch (_a.label) {
case 0: return [4 /*yield*/, this.slides.getActiveIndex().then((/**
* @param {?} index
* @return {?}
*/
function (index) {
_this.currentCategoryName = _this.emojiCategories[index].name;
console.log(_this.currentCategoryName);
/** @type {?} */
var categoryDiv = _this.categoryContainer.nativeElement.children.item(index);
_this.categoryContainer.nativeElement.scrollLeft = categoryDiv.offsetLeft - 20;
}))];
case 1:
_a.sent();
return [2 /*return*/];
}
});
});
};
Ionic4EmojiPickerComponent.decorators = [
{ type: Component, args: [{
selector: 'emoji-picker',
template: "<ion-content>\n \n <ion-row>\n <ion-col size=\"12\">\n <!--EMOJI CATEGORIES-->\n\n <div class=\"categoryContainer\" #categoryDiv>\n <div class=\"category\" [class.selectedCategory]=\"currentCategoryName==item.name\" *ngFor=\"let item of emojiCategories;let i=index;\" (click)=\"categoryChanged(item,i)\">\n <p>{{item.icon[0]}}</p>\n <p>{{item.name}}</p>\n </div>\n </div>\n\n </ion-col>\n <ion-col size=\"12\">\n <!--CATEGORY CONTENT-->\n\n <ion-slides #slides pager=\"false\">\n <ion-slide *ngFor=\"let item of emojiCategories\">\n <ion-row>\n <ion-col size=\"1.5\" *ngFor=\"let childItem of item.emojis\" (click)=\"selectEmoji(childItem[0])\">\n <p style=\"margin:1px;\">{{childItem[0]}}</p>\n </ion-col>\n </ion-row>\n </ion-slide>\n </ion-slides>\n \n\n\n </ion-col>\n </ion-row>\n</ion-content>",
styles: [".categoryContainer\n {\n overflow: scroll;\n white-space: nowrap;\n }\n\n .category\n {\n display: inline-block;\n padding: 10px;\n text-align: center;\n }\n \n .selectedCategory\n {\n border-bottom: 2px solid var(--ion-color-primary);\n }"]
}] }
];
/** @nocollapse */
Ionic4EmojiPickerComponent.ctorParameters = function () { return [
{ type: ModalController }
]; };
Ionic4EmojiPickerComponent.propDecorators = {
slides: [{ type: ViewChild, args: ['slides', { static: false },] }],
categoryContainer: [{ type: ViewChild, args: ['categoryDiv', { static: false },] }],
isInModal: [{ type: Input, args: ['isInModal',] }],
selectionEvent: [{ type: Output, args: ['onEmojiSelect',] }]
};
return Ionic4EmojiPickerComponent;
}());
export { Ionic4EmojiPickerComponent };
if (false) {
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.slides;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.categoryContainer;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.emojiCategories;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.mainEmojiData;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.currentEmojiList;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.currentCategoryName;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.isInModal;
/** @type {?} */
Ionic4EmojiPickerComponent.prototype.selectionEvent;
/**
* @type {?}
* @private
*/
Ionic4EmojiPickerComponent.prototype.modalCtrl;
}
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ionic4-emoji-picker.component.js","sourceRoot":"ng://ionic4-emoji-picker/","sources":["lib/ionic4-emoji-picker.component.ts"],"names":[],"mappings":"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","sourcesContent":["import { Component, OnInit, ViewChild, ElementRef, EventEmitter, Output, Input } from '@angular/core';\nimport { EMOJIS } from '../data/emoji.data';\nimport { IonSlides, ModalController } from '@ionic/angular';\n\n@Component({\n  selector: 'emoji-picker',\n  template:`<ion-content>\n \n  <ion-row>\n    <ion-col size=\"12\">\n      <!--EMOJI CATEGORIES-->\n\n      <div class=\"categoryContainer\" #categoryDiv>\n        <div  class=\"category\" [class.selectedCategory]=\"currentCategoryName==item.name\" *ngFor=\"let item of emojiCategories;let i=index;\" (click)=\"categoryChanged(item,i)\">\n          <p>{{item.icon[0]}}</p>\n          <p>{{item.name}}</p>\n        </div>\n      </div>\n\n    </ion-col>\n    <ion-col size=\"12\">\n      <!--CATEGORY CONTENT-->\n\n      <ion-slides #slides pager=\"false\">\n        <ion-slide *ngFor=\"let item of emojiCategories\">\n          <ion-row>\n            <ion-col size=\"1.5\" *ngFor=\"let childItem of item.emojis\" (click)=\"selectEmoji(childItem[0])\">\n              <p style=\"margin:1px;\">{{childItem[0]}}</p>\n            </ion-col>\n          </ion-row>\n        </ion-slide>\n      </ion-slides>\n      \n\n\n    </ion-col>\n  </ion-row>\n</ion-content>`,\n  styles: [`.categoryContainer\n  {\n      overflow: scroll;\n      white-space: nowrap;\n  }\n\n  .category\n  {\n      display: inline-block;\n      padding: 10px;\n      text-align: center;\n  }\n  \n  .selectedCategory\n  {\n      border-bottom: 2px solid var(--ion-color-primary);\n  }`],\n})\nexport class Ionic4EmojiPickerComponent implements OnInit {\n\n\n  @ViewChild('slides',{static:false}) slides:IonSlides;\n  @ViewChild('categoryDiv',{static:false}) categoryContainer:ElementRef;\n  \n  emojiCategories:any[]=[];\n  mainEmojiData=EMOJIS;\n  currentEmojiList:any[]=[];\n  currentCategoryName:string='';\n  \n  @Input('isInModal') isInModal=false; //To determine whether this componet is created using a modal or not\n  @Output('onEmojiSelect') selectionEvent=new EventEmitter(); //TO emmit event when an emoji is selected\n    constructor(private modalCtrl:ModalController) \n    {\n  \n    }\n  \n    ngOnInit() \n    {\n      this.getEmojiCategories();\n    }\n  \n    ngAfterViewInit()\n    {\n      console.log('ngAfterViewInit');\n      this.setActiveCategorySlide();\n      this.slides.ionSlideDidChange.subscribe(data=>\n        {\n          console.log('Slide changed data',data);\n          this.setActiveCategorySlide();\n        })\n    }\n  \n    getEmojiCategories()\n    {\n      this.mainEmojiData.forEach(category=>\n        {\n          this.emojiCategories.push(category);\n        });\n        this.currentCategoryName=this.emojiCategories[0].name;\n        this.currentEmojiList=this.emojiCategories[0].emojis;\n      \n    }\n  \n    categoryChanged(selectedEmojiList,categoryIndex)\n    {\n      this.currentEmojiList=selectedEmojiList.emojis;\n      this.currentCategoryName=selectedEmojiList.name;\n      this.slides.slideTo(categoryIndex);\n      this.setActiveCategorySlide();\n    }\n  \n    selectEmoji(code)\n    {\n      let selectionData={\n        data:code\n      };\n  \n      this.selectionEvent.emit(selectionData);\n      if(this.isInModal)\n      {\n        this.modalCtrl.dismiss(selectionData); //Dismiss the modal with data\n      }\n    }\n    async setActiveCategorySlide()\n    {\n  \n     await this.slides.getActiveIndex().then(index=>\n        {\n          this.currentCategoryName=this.emojiCategories[index].name;\n          console.log(this.currentCategoryName);\n         let categoryDiv=this.categoryContainer.nativeElement.children.item(index); //Ge item at this index\n         this.categoryContainer.nativeElement.scrollLeft=categoryDiv.offsetLeft-20;\n  \n        });\n    \n    }\n  \n\n}\n"]}