UNPKG

@mescius/inputman.comment.angular

Version:

このパッケージには、Angular用の[InputManJS](https://developer.mescius.jp/inputmanjs)コンポーネントが含まれます。

270 lines 35.7 kB
import { ElementRef, Input, Output, EventEmitter, Component, } from "@angular/core"; import { GC } from "../inputman"; import { MethodType, isEmpty, getMethodPrefix, IMCommentCtrl, } from "./common"; import * as i0 from "@angular/core"; export class GcCommentComponent { constructor(ref) { this.editorCreated = new EventEmitter(); this.preprocessError = new EventEmitter(); this.beforeExecuteCommand = new EventEmitter(); this.afterExecuteCommand = new EventEmitter(); this.beforeFirstLoad = new EventEmitter(); this.afterFirstLoad = new EventEmitter(); this.onInitialized = new EventEmitter(); this._container = ref.nativeElement; } ngOnChanges(changes) { if (!this._imGcComment) { return; } Object.keys(changes).forEach((key) => { let currentValue = changes[key].currentValue; this.setValueToIMControl(key, currentValue); }); } setValueToIMControl(key, value) { if (value === undefined) { return; } if (this.isSetAccessor(key)) { this._imGcComment[key] = value; return; } let setter = this.tryGetPropertyOperator(key, MethodType.setter); if (this.hasRealMethod(setter)) { if (this.propDic && this.propDic[key] && this.propDic[key].isPramArr === true) { this._imGcComment[setter].apply(this._imGcComment, value); } else { this._imGcComment[setter](value); } } } hasRealMethod(methodName) { return (this._imGcComment && typeof this._imGcComment[methodName] === "function"); } isSetAccessor(key) { let descriptor = Object.getOwnPropertyDescriptor(this._imGcComment.constructor.prototype, key); if (descriptor && descriptor.set) { return true; } return false; } tryGetPropertyOperator(propertyName, methodType) { let method = ""; if (this.propDic && this.propDic[propertyName]) { method = methodType === MethodType.getter ? this.propDic[propertyName].getter : this.propDic[propertyName].setter; if (!isEmpty(method)) { return method; } } return (getMethodPrefix(methodType) + propertyName[0].toUpperCase() + propertyName.slice(1)); } ngAfterContentInit() { this.initGcComment(); this.bindEvent(); if (this.propDic) { var unSupportWithinConfigProps = Object.keys(this.propDic).filter((p) => this.propDic[p] && this.propDic[p].supportWithinConfig === false); unSupportWithinConfigProps.sort((p1, p2) => { return this.propDic[p1].order - this.propDic[p2].order; }); unSupportWithinConfigProps.forEach((p) => { this.setValueToIMControl(p, this[p]); }); } this._container[IMCommentCtrl] = this._imGcComment; } bindEvent() { if (!this._imGcComment) { return; } this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.EditorCreated, (e) => { this.editorCreated.emit(e); }); this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.PreprocessError, (e) => { this.preprocessError.emit(e); }); this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.BeforeExecuteCommand, (e) => { this.beforeExecuteCommand.emit(e); }); this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.AfterExecuteCommand, (e) => { this.afterExecuteCommand.emit(e); }); this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.BeforeFirstLoad, () => { this.beforeFirstLoad.emit(); }); this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.AfterFirstLoad, () => { this.afterFirstLoad.emit(); }); } ngOnDestroy() { if (this._container != null) { this._container.remove(); this._imGcComment?.destroy?.(); this._imGcComment = null; } } initGcComment() { let element = document.createElement('div'); this.createTemplate(element); this._imGcComment = new GC.InputMan.GcComment(element, this); if (Array.isArray(this.comments)) { this._imGcComment.comments = this.comments; } if (this.stickedComment) { this._imGcComment.stickedComment = this.stickedComment; } this._imGcComment.addEventListener(GC.InputMan.GcCommentEvent.CreateEditor, this.createEditor); this.onInitialized.emit(this._imGcComment); } createTemplate(element) { this._container.innerHTML = ""; this._container.appendChild(element); } getNestedIMControl() { return this._imGcComment; } } GcCommentComponent.ɵfac = i0.ɵɵngDeclareFactory({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCommentComponent, deps: [{ token: i0.ElementRef }], target: i0.ɵɵFactoryTarget.Component }); GcCommentComponent.ɵcmp = i0.ɵɵngDeclareComponent({ minVersion: "14.0.0", version: "15.2.10", type: GcCommentComponent, selector: "gc-comment", inputs: { userInfo: "userInfo", candidateReactionList: "candidateReactionList", candidateReactionListColumns: "candidateReactionListColumns", postTimeFormatter: "postTimeFormatter", updateTimeFormatter: "updateTimeFormatter", showIcon: "showIcon", addCommentEditorPosition: "addCommentEditorPosition", commentMode: "commentMode", header: "header", footer: "footer", headerFooterItems: "headerFooterItems", commentAction: "commentAction", commentInfoAction: "commentInfoAction", commentActionItem: "commentActionItem", commentInfoActionItem: "commentInfoActionItem", commentActionButtonType: "commentActionButtonType", pageSize: "pageSize", loadOnDemand: "loadOnDemand", allowAnonymous: "allowAnonymous", anonymousUserInfo: "anonymousUserInfo", warningMessage: "warningMessage", watermark: "watermark", commentFormatter: "commentFormatter", editorConfig: "editorConfig", avatarType: "avatarType", loadUsersInfoHandler: "loadUsersInfoHandler", loadComments: "loadComments", addNewCommentTo: "addNewCommentTo", keepDraft: "keepDraft", dataSource: "dataSource", loadCommentCount: "loadCommentCount", commentCountFormatter: "commentCountFormatter", loadReactionCount: "loadReactionCount", reactionCountFormatter: "reactionCountFormatter", sortInfo: "sortInfo", createEditor: "createEditor", loadRepliesOnDemand: "loadRepliesOnDemand", replyLevel: "replyLevel", collapseRepliesMode: "collapseRepliesMode", showCurrentUserName: "showCurrentUserName", contextToolbar: "contextToolbar", contextToolbarItem: "contextToolbarItem", loadCommentReplies: "loadCommentReplies", comments: "comments", stickedComment: "stickedComment", copiedLinkDisplayTextFormatter: "copiedLinkDisplayTextFormatter", copiedLinkFormatter: "copiedLinkFormatter", copiedLinkSearchParams: "copiedLinkSearchParams", pastedLinkType: "pastedLinkType", showLinkTypeContextToolbar: "showLinkTypeContextToolbar", loadCommentByLink: "loadCommentByLink", openLinkMode: "openLinkMode", loadStickedComment: "loadStickedComment", showZeroReaction: "showZeroReaction", showOpenReactionListButton: "showOpenReactionListButton" }, outputs: { editorCreated: "editorCreated", preprocessError: "preprocessError", beforeExecuteCommand: "beforeExecuteCommand", afterExecuteCommand: "afterExecuteCommand", beforeFirstLoad: "beforeFirstLoad", afterFirstLoad: "afterFirstLoad", onInitialized: "onInitialized" }, usesOnChanges: true, ngImport: i0, template: `<ng-content></ng-content>`, isInline: true }); i0.ɵɵngDeclareClassMetadata({ minVersion: "12.0.0", version: "15.2.10", ngImport: i0, type: GcCommentComponent, decorators: [{ type: Component, args: [{ selector: "gc-comment", template: `<ng-content></ng-content>`, }] }], ctorParameters: function () { return [{ type: i0.ElementRef }]; }, propDecorators: { userInfo: [{ type: Input }], candidateReactionList: [{ type: Input }], candidateReactionListColumns: [{ type: Input }], postTimeFormatter: [{ type: Input }], updateTimeFormatter: [{ type: Input }], showIcon: [{ type: Input }], addCommentEditorPosition: [{ type: Input }], commentMode: [{ type: Input }], header: [{ type: Input }], footer: [{ type: Input }], headerFooterItems: [{ type: Input }], commentAction: [{ type: Input }], commentInfoAction: [{ type: Input }], commentActionItem: [{ type: Input }], commentInfoActionItem: [{ type: Input }], commentActionButtonType: [{ type: Input }], pageSize: [{ type: Input }], loadOnDemand: [{ type: Input }], allowAnonymous: [{ type: Input }], anonymousUserInfo: [{ type: Input }], warningMessage: [{ type: Input }], watermark: [{ type: Input }], commentFormatter: [{ type: Input }], editorConfig: [{ type: Input }], avatarType: [{ type: Input }], loadUsersInfoHandler: [{ type: Input }], loadComments: [{ type: Input }], addNewCommentTo: [{ type: Input }], keepDraft: [{ type: Input }], dataSource: [{ type: Input }], loadCommentCount: [{ type: Input }], commentCountFormatter: [{ type: Input }], loadReactionCount: [{ type: Input }], reactionCountFormatter: [{ type: Input }], sortInfo: [{ type: Input }], createEditor: [{ type: Input }], loadRepliesOnDemand: [{ type: Input }], replyLevel: [{ type: Input }], collapseRepliesMode: [{ type: Input }], showCurrentUserName: [{ type: Input }], contextToolbar: [{ type: Input }], contextToolbarItem: [{ type: Input }], loadCommentReplies: [{ type: Input }], comments: [{ type: Input }], stickedComment: [{ type: Input }], copiedLinkDisplayTextFormatter: [{ type: Input }], copiedLinkFormatter: [{ type: Input }], copiedLinkSearchParams: [{ type: Input }], pastedLinkType: [{ type: Input }], showLinkTypeContextToolbar: [{ type: Input }], loadCommentByLink: [{ type: Input }], openLinkMode: [{ type: Input }], loadStickedComment: [{ type: Input }], showZeroReaction: [{ type: Input }], showOpenReactionListButton: [{ type: Input }], editorCreated: [{ type: Output }], preprocessError: [{ type: Output }], beforeExecuteCommand: [{ type: Output }], afterExecuteCommand: [{ type: Output }], beforeFirstLoad: [{ type: Output }], afterFirstLoad: [{ type: Output }], onInitialized: [{ type: Output }] } }); //# sourceMappingURL=data:application/json;base64,{"version":3,"file":"GcComment.js","sourceRoot":"","sources":["../../../comment/GcComment.ts"],"names":[],"mappings":"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","sourcesContent":["import {\n    OnChanges,\n    OnDestroy,\n    AfterContentInit,\n    ElementRef,\n    SimpleChanges,\n    Input,\n    Output,\n    EventEmitter,\n    Component,\n} from \"@angular/core\";\nimport { GC } from \"../inputman\";\nimport {\n    MethodType,\n    isEmpty,\n    getMethodPrefix,\n    PropertyDictionary,\n    IMCommentCtrl,\n} from \"./common\";\n\n@Component({\n    selector: \"gc-comment\",\n    template: `<ng-content></ng-content>`,\n})\nexport class GcCommentComponent\n    implements OnChanges, AfterContentInit, OnDestroy\n{\n    protected _container: Element;\n    protected _imGcComment: GC.InputMan.GcComment;\n    protected propDic: PropertyDictionary;\n\n    constructor(ref: ElementRef) {\n        this._container = ref.nativeElement;\n    }\n\n    public ngOnChanges(changes: SimpleChanges): void {\n        if (!this._imGcComment) {\n            return;\n        }\n\n        Object.keys(changes).forEach((key: string) => {\n            let currentValue = changes[key].currentValue;\n            this.setValueToIMControl(key, currentValue);\n        });\n    }\n\n    protected setValueToIMControl(key: string, value: any): void {\n        if (value === undefined) {\n            return;\n        }\n\n        if (this.isSetAccessor(key)) {\n            this._imGcComment[key] = value;\n            return;\n        }\n\n        let setter = this.tryGetPropertyOperator(key, MethodType.setter);\n        if (this.hasRealMethod(setter)) {\n            if (\n                this.propDic &&\n                this.propDic[key] &&\n                this.propDic[key].isPramArr === true\n            ) {\n                this._imGcComment[setter].apply(this._imGcComment, value);\n            } else {\n                this._imGcComment[setter](value);\n            }\n        }\n    }\n\n    private hasRealMethod(methodName: string): boolean {\n        return (\n            this._imGcComment &&\n            typeof this._imGcComment[methodName] === \"function\"\n        );\n    }\n\n    private isSetAccessor(key: string) {\n        let descriptor = Object.getOwnPropertyDescriptor(\n            this._imGcComment.constructor.prototype,\n            key\n        );\n        if (descriptor && descriptor.set) {\n            return true;\n        }\n        return false;\n    }\n\n    private tryGetPropertyOperator(\n        propertyName: string,\n        methodType: MethodType\n    ): string {\n        let method: string = \"\";\n        if (this.propDic && this.propDic[propertyName]) {\n            method =\n                methodType === MethodType.getter\n                    ? this.propDic[propertyName].getter\n                    : this.propDic[propertyName].setter;\n            if (!isEmpty(method)) {\n                return method;\n            }\n        }\n        return (\n            getMethodPrefix(methodType) +\n            propertyName[0].toUpperCase() +\n            propertyName.slice(1)\n        );\n    }\n\n    public ngAfterContentInit(): void {\n        this.initGcComment();\n        this.bindEvent();\n        if (this.propDic) {\n            var unSupportWithinConfigProps = Object.keys(this.propDic).filter(\n                (p) =>\n                    this.propDic[p] &&\n                    this.propDic[p].supportWithinConfig === false\n            );\n            unSupportWithinConfigProps.sort((p1, p2) => {\n                return this.propDic[p1].order - this.propDic[p2].order;\n            });\n\n            unSupportWithinConfigProps.forEach((p) => {\n                this.setValueToIMControl(p, this[p]);\n            });\n        }\n        this._container[IMCommentCtrl] = this._imGcComment;\n    }\n\n    protected bindEvent(): void {\n        if (!this._imGcComment) {\n            return;\n        }\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.EditorCreated,\n            (e) => {\n                this.editorCreated.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.PreprocessError,\n            (e) => {\n                this.preprocessError.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.BeforeExecuteCommand,\n            (e) => {\n                this.beforeExecuteCommand.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.AfterExecuteCommand,\n            (e) => {\n                this.afterExecuteCommand.emit(e);\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.BeforeFirstLoad,\n            () => {\n                this.beforeFirstLoad.emit();\n            }\n        );\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.AfterFirstLoad,\n            () => {\n                this.afterFirstLoad.emit();\n            }\n        );\n    }\n\n    public ngOnDestroy(): void {\n        if (this._container != null) {\n            this._container.remove();\n            this._imGcComment?.destroy?.();\n            this._imGcComment = null;\n        }\n    }\n\n    private initGcComment(): void {\n        let element = document.createElement('div');\n        this.createTemplate(element);\n        this._imGcComment = new GC.InputMan.GcComment(element, this as any);\n        if (Array.isArray(this.comments)) {\n            this._imGcComment.comments = this.comments;\n        }\n        if (this.stickedComment) {\n            this._imGcComment.stickedComment = this.stickedComment;\n        }\n        this._imGcComment.addEventListener(\n            GC.InputMan.GcCommentEvent.CreateEditor,\n            this.createEditor\n        );\n        this.onInitialized.emit(this._imGcComment);\n    }\n\n    private createTemplate(element: HTMLElement) {\n        this._container.innerHTML = \"\";\n        this._container.appendChild(element);\n    }\n\n    public getNestedIMControl(): GC.InputMan.GcComment {\n        return this._imGcComment;\n    }\n\n    @Input()\n    userInfo?: GC.InputMan.UserInfo;\n    @Input()\n    candidateReactionList?: string[];\n    @Input()\n    candidateReactionListColumns?: number;\n    @Input()\n    postTimeFormatter?: GC.InputMan.DateFormatter;\n    @Input()\n    updateTimeFormatter?: GC.InputMan.DateFormatter;\n    @Input()\n    showIcon?: boolean;\n    @Input()\n    addCommentEditorPosition?: GC.InputMan.GcCommentEditorPosition;\n    @Input()\n    commentMode?: GC.InputMan.GcCommentMode;\n    @Input()\n    header?: (string | GC.InputMan.GcCommentHeaderFooterItem)[];\n    @Input()\n    footer?: (string | GC.InputMan.GcCommentHeaderFooterItem)[];\n    @Input()\n    headerFooterItems?: { [key: string]: (gcComment: GC.InputMan.GcComment) => GC.InputMan.IHeaderFooterItem };\n    @Input()\n    commentAction?: (string | GC.InputMan.GcCommentCommentActionItem)[];\n    @Input()\n    commentInfoAction?: (string | GC.InputMan.GcCommentCommentInfoActionItem)[];\n    @Input()\n    commentActionItem?: { [key: string]: GC.InputMan.ICommentActionItem };\n    @Input()\n    commentInfoActionItem?: { [key: string]: GC.InputMan.ICommentInfoActionItem };\n    @Input()\n    commentActionButtonType?: GC.InputMan.GcCommentActionButtonType;\n    @Input()\n    pageSize?: number;\n    @Input()\n    loadOnDemand?: boolean;\n    @Input()\n    allowAnonymous?: boolean;\n    @Input()\n    anonymousUserInfo?: GC.InputMan.UserInfo;\n    @Input()\n    warningMessage?: GC.InputMan.IWarningMessage;\n    @Input()\n    watermark?: GC.InputMan.IWaterMark;\n    @Input()\n    commentFormatter?: GC.InputMan.CommentFormatter;\n    @Input()\n    editorConfig?: GC.InputMan.EditorConfig;\n    @Input()\n    avatarType?: GC.InputMan.GcCommentUserIconType;\n    @Input()\n    loadUsersInfoHandler?: GC.InputMan.LoadUsersCallback;\n    @Input()\n    loadComments?: (args: GC.InputMan.LoadMoreCommentsInfo) => GC.InputMan.LoadCommentsResult;\n    @Input()\n    addNewCommentTo?: GC.InputMan.AddNewCommentPosition;\n    @Input()\n    keepDraft?: boolean;\n    @Input()\n    dataSource?: GC.InputMan.IGcCommentDataSource;\n    @Input()\n    loadCommentCount?: () => number | Promise<number>;\n    @Input()\n    commentCountFormatter?: (n: number) => string | HTMLElement;\n    @Input()\n    loadReactionCount?: () => number | Promise<number>;\n    @Input()\n    reactionCountFormatter?: (n: number) => string | HTMLElement;\n    @Input()\n    sortInfo?: GC.InputMan.SortInfo;\n    @Input()\n    createEditor?: (args: GC.InputMan.CreateEditorArgs) => GC.InputMan.ICommentEditor;\n    @Input()\n    loadRepliesOnDemand?: boolean;\n    @Input()\n    replyLevel?: number;\n    @Input()\n    collapseRepliesMode?: GC.InputMan.GcCommentCollapseRepliesMode;\n    @Input()\n    showCurrentUserName?: boolean;\n    @Input()\n    contextToolbar?: (string | GC.InputMan.GcCommentContextToolbar | GC.InputMan.ContextToolbarOption)[];\n    @Input()\n    contextToolbarItem?: { [key: string]: GC.InputMan.ICommentContextToolbarItem };\n    @Input()\n    loadCommentReplies?: (comment: GC.InputMan.IComment, loadedCount: number) => GC.InputMan.LoadCommentsResult;\n    @Input()\n    comments?: GC.InputMan.IComment[];\n    @Input()\n    stickedComment?: GC.InputMan.IComment;\n    @Input()\n    copiedLinkDisplayTextFormatter?: (comment: GC.InputMan.IComment) => GC.InputMan.ICopiedLinkDisplayTextConfig;\n    @Input()\n    copiedLinkFormatter?: (comment: GC.InputMan.IComment) => string;\n    @Input()\n    copiedLinkSearchParams?: (GC.InputMan.GcCommentLinkSearchParams | GC.InputMan.CustomLinkSearchParam)[];\n    @Input()\n    pastedLinkType?: GC.InputMan.GcCommentPasteLinkType;\n    @Input()\n    showLinkTypeContextToolbar?: boolean;\n    @Input()\n    loadCommentByLink?: (link: string) => Promise<GC.InputMan.LoadCommentByLinkResult>;\n    @Input()\n    openLinkMode?: GC.InputMan.OpenLinkMode;\n    @Input()\n    loadStickedComment?: () => GC.InputMan.IComment | null;\n    @Input()\n    showZeroReaction?: boolean;\n    @Input()\n    showOpenReactionListButton?: boolean;\n    \n    @Output()\n    public editorCreated: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public preprocessError: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public beforeExecuteCommand: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public afterExecuteCommand: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public beforeFirstLoad: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public afterFirstLoad: EventEmitter<object> = new EventEmitter();\n    @Output()\n    public onInitialized: EventEmitter<object> = new EventEmitter();\n}\n"]}