import { createElement, setTooltip, createIcon } from "../../ui";
import { r as lang, nullOrEmpty, escapeHtml, escapeEmoji } from "../../utility";
import { createBox, appendMedia } from "./lib";

let r = lang;

export default class CustomerRecordComment {
    #container;
    #option;
    #enter;
    #message;

    constructor(opt) {
        this.#option = opt ?? {};
        const getText = opt?.getText;
        if (typeof getText === 'function') {
            r = getText;
        }
    }

    get text() { return this.#enter?.value }
    set text(s) {
        const element = this.#enter;
        if (element != null) {
            element.value = s
            s = String(nullOrEmpty(s) ? 0 : val.length) + '/' + String(this.#option.maxLength);
            this.#container.querySelector('.message-bar .prompt-count').innerText = s;
        }
    }

    /**
     * @param {boolean} flag
     */
    set loading(flag) {
        if (this.#container == null) {
            return;
        }
        this.#enter.disabled = flag;
        this.#container.querySelector('.button-send-message').disabled = flag;
    }

    /**
     * @param {boolean} flag
     */
    set readonly(flag) {
        this.#option.readonly = flag;
        if (this.#container == null) {
            return;
        }
        this.#enter.disabled = flag === true;
        this.#container.querySelector('.button-send-message').style.display = flag === true ? 'none' : '';
        this.#container.querySelector('.message-bar .prompt-count').style.display = flag === true ? 'none' : '';
    }

    create() {
        const readonly = this.#option.readonly;
        const container = createBox(
            createElement('div', null,
                createElement('div', div => {
                    div.className = 'title-module';
                    div.innerText = r('P_CR_COMMENTS', 'Comments');
                })
            ),
            [
                createElement('button', button => {
                    button.className = 'roundbtn button-close';
                    button.style.backgroundColor = 'transparent';
                    if (this.#option.hasClose !== true) {
                        button.style.display = 'none';
                        return;
                    }
                    button.appendChild(createIcon('fa-solid', 'times', {
                        fill: '#000'
                    }));
                    button.addEventListener('click', () => {
                        if (typeof this.#option.onClose === 'function') {
                            this.#option.onClose();
                        }
                    })
                })
            ]
        );
        // enter box
        const enter = createElement('textarea', 'ui-text');
        enter.placeholder = r('P_CU_ENTERCOMMENTHERE', 'Enter Comment Here');
        enter.maxLength = this.#option.maxLength ??= 3000;
        enter.addEventListener('input', () => {
            const val = this.text;
            const s = String(nullOrEmpty(val) ? 0 : val.length) + '/' + String(this.#option.maxLength);
            this.#container.querySelector('.message-bar .prompt-count').innerText = s;
        });
        if (readonly === true) {
            enter.disabled = true;
        }
        this.#enter = enter;
        container.appendChild(
            createElement('div', 'message-bar',
                enter,
                createElement('div', div => div.style.textAlign = 'right',
                    createElement('div', 'prompt-count'),
                    createElement('button', button => {
                        button.className = 'roundbtn button-send-message';
                        button.style.backgroundColor = 'rgb(19, 150, 204)';
                        if (readonly === true) {
                            button.style.display = 'none';
                        }
                        button.appendChild(createIcon('fa-solid', 'paper-plane'));
                        // setTooltip(button, r('P_M3_SENDMESSAGE', 'Send Message'));
                        setTooltip(button, r('P_CU_POSTNOTE', 'Post Note'));
                        button.addEventListener('click', () => {
                            if (typeof this.#option.onAddComment === 'function') {
                                this.#option.onAddComment(this.text);
                            }
                        })
                    })
                )
            )
        );

        const message = createElement('div', 'list-bar');
        this.#message = message;
        container.appendChild(message);
        return this.#container = container;
    }

    load(data) {
        const children = [];
        if (data?.length > 0) {
            for (let comment of data) {
                const div = createElement('div', 'item-div');
                // if (sendto !== '') {
                //     sendto = r('P_CU_SENDTO_COLON', 'Send To :') + `\n${sendto}`;
                // }
                div.appendChild(createElement('div', div => {
                    div.className = 'item-poster';
                    div.innerText = comment.UserName;
                }));
                const content = createElement('div', 'item-content');
                const mmsParts = createElement('div', div => div.style.display = 'none');
                content.appendChild(createElement('span', span => span.innerHTML = escapeEmoji(escapeHtml(comment.Comment)), mmsParts));
                if (comment.IsMMS && comment.MMSParts?.length > 0) {
                    mmsParts.style.display = '';
                    for (let kv of comment.MMSParts) {
                        appendMedia(mmsParts, kv.Key, kv.Value);
                    }
                }
                div.append(
                    content,
                    createElement('div', div => {
                        div.className = 'item-time';
                        div.innerText = comment.SubmitLocalDateStr;
                    })
                );
                children.push(div);
            }
            children[0].style.marginTop = '0';
        }
        this.#message.replaceChildren(...children);
        this.#message.scrollTop = this.#message.scrollHeight
        // setTimeout(() => this.#message.scrollTop = this.#message.scrollHeight, 0);
    }
}