Sha256: 33acae8df5e0cf526236af7be0f24cf97eee87da3807960681aa8fc953f0fa34

Contents?: true

Size: 860 Bytes

Versions: 96

Compression:

Stored size: 860 Bytes

Contents

import { Controller } from "@hotwired/stimulus"
import { Picker } from 'emoji-mart'


export default class extends Controller {

  static targets = [ "input", "display" ]

  connect() {
    this.visible = false
    this.picker = new Picker({
      data: async () => {
        const response = await fetch(
          'https://cdn.jsdelivr.net/npm/@emoji-mart/data',
        )

        return response.json()
      },
      onEmojiSelect: (emoji) => {
        this.displayTarget.innerHTML = emoji.native
        this.inputTarget.value = emoji.native
        this.element.removeChild(this.picker)
        this.visible = false
      },

    })
  }

  toggle(event) {
    event.preventDefault()
    if (this.visible) {
      this.element.removeChild(this.picker)
    } else {
      this.element.appendChild(this.picker)
    }
    this.visible = !this.visible
  }
}

Version data entries

96 entries across 96 versions & 1 rubygems

Version Path
bullet_train-fields-1.6.25 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.24 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.23 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.22 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.21 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.20 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.19 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.18 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.17 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.16 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.15 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.14 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.13 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.12 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.11 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.10 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.9 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.8 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.7 app/javascript/controllers/fields/emoji_picker_controller.js
bullet_train-fields-1.6.6 app/javascript/controllers/fields/emoji_picker_controller.js