Sha256: 46064cf830de22c0b1f61491fc19a6bf1604d646dfea74bb0a536e7f6ba5cb3c

Contents?: true

Size: 1.51 KB

Versions: 250

Compression:

Stored size: 1.51 KB

Contents

import 'codemirror/mode/css/css'
import 'codemirror/mode/dockerfile/dockerfile'
import 'codemirror/mode/htmlmixed/htmlmixed'
import 'codemirror/mode/javascript/javascript'
import 'codemirror/mode/markdown/markdown'
import 'codemirror/mode/nginx/nginx'
import 'codemirror/mode/php/php'
import 'codemirror/mode/ruby/ruby'
import 'codemirror/mode/sass/sass'
import 'codemirror/mode/shell/shell'
import 'codemirror/mode/sql/sql'
import 'codemirror/mode/vue/vue'
import 'codemirror/mode/xml/xml'
import 'codemirror/mode/yaml/yaml'

import { Controller } from '@hotwired/stimulus'
import CodeMirror from 'codemirror'

import { castBoolean } from '../../helpers/cast_boolean'

export default class extends Controller {
  static targets = ['element']

  connect() {
    const options = {
      readOnly: castBoolean(this.elementTarget.dataset.readOnly),
      mode: this.elementTarget.dataset.language,
      theme: this.elementTarget.dataset.theme,
      tabSize: this.elementTarget.dataset.tabSize,
      indentWithTabs: castBoolean(this.elementTarget.dataset.indentWithTabs),
      lineWrapping: castBoolean(this.elementTarget.dataset.lineWrapping),
      lineNumbers: true,
    }

    const vm = this

    setTimeout(() => {
      CodeMirror.fromTextArea(this.elementTarget, options).on('change', (cm) => {
        // Add this innerText change and dispatch an event to allow stimulus to pick up the input event.
        vm.elementTarget.innerText = cm.getValue()
        vm.elementTarget.dispatchEvent(new Event('input'))
      })
    }, 1)
  }
}

Version data entries

250 entries across 250 versions & 1 rubygems

Version Path
avo-2.53.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-2.52.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.9.2 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.9.1 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.8.2 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.9.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.8.1 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.8.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.6.4 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.6.3 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.6.2 app/javascript/js/controllers/fields/code_field_controller.js
avo-2.49.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.6.1 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.6.0 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.8 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.7 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.6 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.6.beta1 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.5 app/javascript/js/controllers/fields/code_field_controller.js
avo-3.5.4 app/javascript/js/controllers/fields/code_field_controller.js