All Downloads are FREE. Search and download functionalities are using the official Maven repository.

view.statement.js Maven / Gradle / Ivy

let language = 'EN'
let statements = {
  EN: null,
  FR: null
}
let saved = {
  EN: false,
  FR: false
}
let isDirty = {
  EN: false,
  FR: false
}
let editor
const saveButton = document.getElementById('StatementMaker-save')

init()

async function init () {
  editor = await loadMonacoEditor()

  const response = await fetch('/services/statement')
  statements = JSON.parse(await response.text())
  setStatementInput(statements[language])
  refreshPreview()
  saved.EN = statements.EN != null
  saved.FR = statements.FR != null
  updateSaveButton()

  editor.onDidChangeModelContent(event => {
    handleChangeStatementInput()
  })

  window.onbeforeunload = function (e) {
    if (!isDirty.EN && !isDirty.FR) {
      return null
    } else {
      return 'If you leave before saving, your changes will be lost.'
    }
  }
}

function loadMonacoEditor () {
  return new Promise(resolve => {
    require.config({ paths: { vs: 'https://unpkg.com/[email protected]/min/vs' }})
    window.MonacoEnvironment = { getWorkerUrl: () => proxy }

    let proxy = URL.createObjectURL(new Blob([`
      self.MonacoEnvironment = {
        baseUrl: 'https://unpkg.com/[email protected]/min/'
      };
      importScripts('https://unpkg.com/[email protected]/min/vs/base/worker/workerMain.js');
    `], { type: 'text/javascript' }))

    require(['vs/editor/editor.main'], function () {
      const editor = monaco.editor.create(document.getElementById('StatementMaker-input'), {
        value: 'Loading statement...',
        language: 'html',
        theme: 'vs-dark',
        minimap: {
          enabled: false
        },
        wordWrap: 'on'
      })

      window.addEventListener('resize', () => {
        editor.layout()
      })

      resolve(editor)
    })
  })
}

function getStatementInput () {
  return editor.getValue()
}

function setStatementInput (statement) {
  editor.setValue(statement)

  const defaultInsertSpaces = true
  const defaultTabSize = 2
  editor.getModel().detectIndentation(defaultInsertSpaces, defaultTabSize)
}

async function refreshPreview () {
  const response = await fetch('/services/preview-levels', {
    method: 'POST',
    body: JSON.stringify({
      language: language,
      statement: getStatementInput()
    })
  })
  const preview = JSON.parse(await response.text())

  const resultNode = document.getElementById('StatementMaker-preview-result')
  const errorNode = document.getElementById('StatementMaker-preview-error')

  try {
    errorNode.innerText = ''
    resultNode.style.opacity = 1
  } catch (error) {
    errorNode.innerText = error.message
    resultNode.style.opacity = 0.2
  }

  for (let [level, statement] of Object.entries(preview)) {
    const elementId = `StatementMaker-preview-result-${level}`
    let result = document.getElementById(elementId)
    if (!result) {
      result = document.createElement("div")
      result.classList.add('cg-statement')
      result.id = elementId
      if (level !== "level1") {
        result.style.marginTop = '50px'
      }
      resultNode.parentElement.appendChild(result)
    }
    result.innerHTML = statement
  }
}

async function save () {
  saveButton.disabled = true
  await fetch('/services/statement', {
    method: 'PUT',
    body: JSON.stringify({
      language: language,
      statement: getStatementInput()
    })
  })
  saveButton.innerText = 'Saved ' + language
  saved[language] = true
  isDirty[language] = false
}

function handleChangeStatementInput () {
  saveButton.disabled = false
  saveButton.innerText = 'Save'
  refreshPreview()
  saved[language] = false
  isDirty[language] = true
}

function updateSaveButton () {
  if (saved[language]) {
    saveButton.disabled = true
    saveButton.innerText = 'Saved ' + language
  } else {
    saveButton.disabled = false
    saveButton.innerText = 'Save'
  }
}

function changeLanguage (event, tabLanguage) {
  document.querySelectorAll('.StatementMaker-languages button')
    .forEach(button => {
      button.classList.remove('active')
    })

  const clickedElement = event.currentTarget
  clickedElement.classList.add('active')

  statements[language] = getStatementInput()
  language = tabLanguage
  setStatementInput(statements[language])
  updateSaveButton()
}




© 2015 - 2025 Weber Informatics LLC | Privacy Policy