smoosic 1.0.28 → 1.0.29

This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
package/build/smoosic.js CHANGED
@@ -378,7 +378,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
378
378
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
379
379
 
380
380
  "use strict";
381
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n/* harmony import */ var _select_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./select.vue */ \"./src/ui/components/dialogs/select.vue\");\n/* harmony import */ var _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./numberInput.vue */ \"./src/ui/components/dialogs/numberInput.vue\");\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./dialogContainer.vue */ \"./src/ui/components/dialogs/dialogContainer.vue\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*@__PURE__*/(0,vue__WEBPACK_IMPORTED_MODULE_0__.defineComponent)({\n __name: 'partInfo',\n props: {\n domId: { type: String, required: true },\n label: { type: String, required: true },\n partInfo: { type: Object, required: true },\n updatePartInfoCb: { type: Function, required: true },\n commitCb: { type: Function, required: true },\n cancelCb: { type: Function, required: true }\n },\n setup(__props, { expose: __expose }) {\n __expose();\n const props = __props;\n const { domId, label, commitCb, cancelCb, updatePartInfoCb } = Object.assign({}, props);\n const partInfo = (0,vue__WEBPACK_IMPORTED_MODULE_0__.reactive)(new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__.SmoPartInfo(props.partInfo));\n const writeBooleanValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n partInfo[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const writeLayoutValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n // no change?\n if (partInfo.layoutManager.globalLayout[attr] === value) {\n return;\n }\n partInfo.layoutManager.globalLayout[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const pageSizes = [\n { label: 'Letter', value: 'letter' },\n { label: 'Legal', value: 'legal' },\n { label: 'Tabloid', value: 'tabloid' },\n { label: 'A4', value: 'a4' },\n { label: 'Custom', value: 'custom' }\n ];\n const predefinedDimensions = {\n 'letter': { width: 816, height: 1056 },\n 'legal': { width: 816, height: 1344 },\n 'tabloid': { width: 1056, height: 1632 },\n 'a4': { width: 794, height: 1123 }\n };\n // Page size is in pixels, but if it matches a preset we just show that.\n // User chooses 'custom' to unlock width/height editing.\n const pageSize = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)('custom');\n const pageChange = () => {\n Object.keys(predefinedDimensions).forEach((key) => {\n const dims = predefinedDimensions[key];\n if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\n dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\n pageSize.value = key;\n }\n });\n };\n const lockDimensions = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n pageChange();\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(pageSize, (newVal) => __awaiter(this, void 0, void 0, function* () {\n if (predefinedDimensions[newVal]) {\n lockDimensions.value = true;\n const dims = predefinedDimensions[newVal];\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n else {\n lockDimensions.value = false;\n }\n yield updatePartInfoCb(partInfo);\n }));\n if (predefinedDimensions[pageSize.value]) {\n lockDimensions.value = true;\n }\n const update = () => __awaiter(this, void 0, void 0, function* () {\n yield updatePartInfoCb(partInfo);\n });\n const includeNext = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n if (partInfo.stavesAfter > 0) {\n includeNext.value = true;\n }\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(includeNext, (newVal, oldVal) => __awaiter(this, void 0, void 0, function* () {\n if (newVal !== oldVal) {\n partInfo.stavesAfter = newVal ? 1 : 0;\n yield updatePartInfoCb(partInfo);\n }\n }));\n const updateLayoutFunc = (param) => {\n const cb = (value) => __awaiter(this, void 0, void 0, function* () {\n yield writeLayoutValue(param, value);\n });\n return cb;\n };\n const getId = (str) => {\n return `${domId}-${str}`;\n };\n const __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp: _select_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"], numberInputApp: _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"], dialogContainer: _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"] };\n Object.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true });\n return __returned__;\n }\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?0a53","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\n\nexport default /*@__PURE__*/_defineComponent({\n  __name: 'partInfo',\n  props: {\n    domId: { type: String, required: true },\n    label: { type: String, required: true },\n    partInfo: { type: Object, required: true },\n    updatePartInfoCb: { type: Function, required: true },\n    commitCb: { type: Function, required: true },\n    cancelCb: { type: Function, required: true }\n  },\n  setup(__props: any, { expose: __expose }) {\n  __expose();\n\r\nconst props = __props;\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n\nconst __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp, numberInputApp, dialogContainer }\nObject.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true })\nreturn __returned__\n}\n\n})","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageChange\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts\n\n}");
381
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n/* harmony import */ var _select_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./select.vue */ \"./src/ui/components/dialogs/select.vue\");\n/* harmony import */ var _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./numberInput.vue */ \"./src/ui/components/dialogs/numberInput.vue\");\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./dialogContainer.vue */ \"./src/ui/components/dialogs/dialogContainer.vue\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*@__PURE__*/(0,vue__WEBPACK_IMPORTED_MODULE_0__.defineComponent)({\n __name: 'partInfo',\n props: {\n domId: { type: String, required: true },\n label: { type: String, required: true },\n partInfo: { type: Object, required: true },\n updatePartInfoCb: { type: Function, required: true },\n commitCb: { type: Function, required: true },\n cancelCb: { type: Function, required: true }\n },\n setup(__props, { expose: __expose }) {\n __expose();\n const props = __props;\n const { domId, label, commitCb, cancelCb, updatePartInfoCb } = Object.assign({}, props);\n const partInfo = (0,vue__WEBPACK_IMPORTED_MODULE_0__.reactive)(new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__.SmoPartInfo(props.partInfo));\n const writeBooleanValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n partInfo[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const writeLayoutValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n // no change?\n if (partInfo.layoutManager.globalLayout[attr] === value) {\n return;\n }\n partInfo.layoutManager.globalLayout[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const pageSizes = [\n { label: 'Letter', value: 'letter' },\n { label: 'Legal', value: 'legal' },\n { label: 'Tabloid', value: 'tabloid' },\n { label: 'A4', value: 'a4' },\n { label: 'Custom', value: 'custom' }\n ];\n const predefinedDimensions = {\n 'letter': { width: 816, height: 1056 },\n 'legal': { width: 816, height: 1344 },\n 'tabloid': { width: 1056, height: 1632 },\n 'a4': { width: 794, height: 1123 }\n };\n // Page size is in pixels, but if it matches a preset we just show that.\n // User chooses 'custom' to unlock width/height editing.\n const pageSize = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)('custom');\n const pageChange = () => {\n Object.keys(predefinedDimensions).forEach((key) => {\n const dims = predefinedDimensions[key];\n if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\n dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\n pageSize.value = key;\n }\n });\n };\n const pageSizeCb = (val) => __awaiter(this, void 0, void 0, function* () {\n const dims = predefinedDimensions[val];\n if (dims) {\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n pageSize.value = val;\n // The watch will trigger the callback\n });\n const lockDimensions = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n pageChange();\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(pageSize, (newVal) => __awaiter(this, void 0, void 0, function* () {\n if (predefinedDimensions[newVal]) {\n lockDimensions.value = true;\n const dims = predefinedDimensions[newVal];\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n else {\n lockDimensions.value = false;\n }\n yield updatePartInfoCb(partInfo);\n }));\n if (predefinedDimensions[pageSize.value]) {\n lockDimensions.value = true;\n }\n const update = () => __awaiter(this, void 0, void 0, function* () {\n yield updatePartInfoCb(partInfo);\n });\n const includeNext = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n if (partInfo.stavesAfter > 0) {\n includeNext.value = true;\n }\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(includeNext, (newVal, oldVal) => __awaiter(this, void 0, void 0, function* () {\n if (newVal !== oldVal) {\n partInfo.stavesAfter = newVal ? 1 : 0;\n yield updatePartInfoCb(partInfo);\n }\n }));\n const updateLayoutFunc = (param) => {\n const cb = (value) => __awaiter(this, void 0, void 0, function* () {\n yield writeLayoutValue(param, value);\n });\n return cb;\n };\n const getId = (str) => {\n return `${domId}-${str}`;\n };\n const __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, pageSizeCb, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp: _select_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"], numberInputApp: _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"], dialogContainer: _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"] };\n Object.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true });\n return __returned__;\n }\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?0a53","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\n\nexport default /*@__PURE__*/_defineComponent({\n  __name: 'partInfo',\n  props: {\n    domId: { type: String, required: true },\n    label: { type: String, required: true },\n    partInfo: { type: Object, required: true },\n    updatePartInfoCb: { type: Function, required: true },\n    commitCb: { type: Function, required: true },\n    cancelCb: { type: Function, required: true }\n  },\n  setup(__props: any, { expose: __expose }) {\n  __expose();\n\r\nconst props = __props;\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n\nconst __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, pageSizeCb, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp, numberInputApp, dialogContainer }\nObject.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true })\nreturn __returned__\n}\n\n})","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"includeNext\" :id=\"getId('includeNext')\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('includeNext')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageSizeCb\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts\n\n}");
382
382
 
383
383
  /***/ },
384
384
 
@@ -807,7 +807,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
807
807
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
808
808
 
809
809
  "use strict";
810
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ render: () => (/* binding */ render)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_2 = { class: \"col col-8\" };\nconst _hoisted_3 = [\"placeholder\", \"id\"];\nconst _hoisted_4 = { class: \"col col-4 text-start\" };\nconst _hoisted_5 = [\"id\"];\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_7 = { class: \"col col-8\" };\nconst _hoisted_8 = [\"placeholder\", \"id\"];\nconst _hoisted_9 = { class: \"col col-4 text-start\" };\nconst _hoisted_10 = [\"id\"];\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_12 = { class: \"col col-1\" };\nconst _hoisted_13 = [\"id\"];\nconst _hoisted_14 = { class: \"col col-5\" };\nconst _hoisted_15 = [\"for\"];\nconst _hoisted_16 = { class: \"col col-1\" };\nconst _hoisted_17 = [\"id\"];\nconst _hoisted_18 = { class: \"col col-5\" };\nconst _hoisted_19 = [\"for\"];\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_21 = { class: \"col col-1\" };\nconst _hoisted_22 = [\"id\"];\nconst _hoisted_23 = { class: \"col col-5\" };\nconst _hoisted_24 = [\"for\"];\nconst _hoisted_25 = { class: \"row mb-2\" };\nconst _hoisted_26 = { class: \"col col-6\" };\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_28 = { class: \"col col-4\" };\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_31 = { class: \"col col-4\" };\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_34 = { class: \"col col-4\" };\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" };\nfunction render(_ctx, _cache, $props, $setup, $data, $options) {\n return ((0,vue__WEBPACK_IMPORTED_MODULE_0__.openBlock)(), (0,vue__WEBPACK_IMPORTED_MODULE_0__.createBlock)($setup[\"dialogContainer\"], {\n domId: $setup.domId,\n commitCb: $setup.commitCb,\n cancelCb: $setup.cancelCb,\n label: $setup.label\n }, {\n default: (0,vue__WEBPACK_IMPORTED_MODULE_0__.withCtx)(() => [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_1, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_2, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partName,\n \"aria-label\": \"Part Name\",\n id: $setup.getId('part-name-input'),\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => (($setup.partInfo.partName) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partName]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_4, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-name-label')\n }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_6, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_7, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partAbbreviation,\n \"aria-label\": \"Part Abbreviation\",\n id: $setup.getId('part-abbreviation-input'),\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event) => (($setup.partInfo.partAbbreviation) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partAbbreviation]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_9, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-abbreviation-label')\n }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_11, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_12, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[3] || (_cache[3] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_14, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_16, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n id: $setup.getId('expandMultimeasureRests'),\n onChange: _cache[5] || (_cache[5] = ($event) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_18, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('expandMultimeasureRests')\n }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_20, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_21, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[7] || (_cache[7] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_22), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_23, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_25, [\n _cache[8] || (_cache[8] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_26, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"selectComp\"], {\n domId: $setup.getId('page-size-select'),\n label: '',\n selections: $setup.pageSizes,\n initialValue: $setup.pageSize,\n changeCb: $setup.pageChange\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_27, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_28, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-width-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageWidth'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[9] || (_cache[9] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_29, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-height-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageHeight'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[10] || (_cache[10] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_30, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_31, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('zoom-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('zoomScale'),\n minValue: 0.25,\n maxValue: 8\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[11] || (_cache[11] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_32, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('svg-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('svgScale'),\n minValue: 0.25,\n maxValue: 2\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[12] || (_cache[12] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_33, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_34, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('note-spacing-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n precision: 2,\n changeCb: $setup.updateLayoutFunc('noteSpacing')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[13] || (_cache[13] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_35, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('max-measure-system-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[14] || (_cache[14] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n ], -1 /* CACHED */))\n ])\n ]),\n _: 1 /* STABLE */\n }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c06c","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { vModelText as _vModelText, createElementVNode as _createElementVNode, withDirectives as _withDirectives, vModelCheckbox as _vModelCheckbox, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock } from \"vue\"\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_2 = { class: \"col col-8\" }\nconst _hoisted_3 = [\"placeholder\", \"id\"]\nconst _hoisted_4 = { class: \"col col-4 text-start\" }\nconst _hoisted_5 = [\"id\"]\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_7 = { class: \"col col-8\" }\nconst _hoisted_8 = [\"placeholder\", \"id\"]\nconst _hoisted_9 = { class: \"col col-4 text-start\" }\nconst _hoisted_10 = [\"id\"]\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_12 = { class: \"col col-1\" }\nconst _hoisted_13 = [\"id\"]\nconst _hoisted_14 = { class: \"col col-5\" }\nconst _hoisted_15 = [\"for\"]\nconst _hoisted_16 = { class: \"col col-1\" }\nconst _hoisted_17 = [\"id\"]\nconst _hoisted_18 = { class: \"col col-5\" }\nconst _hoisted_19 = [\"for\"]\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_21 = { class: \"col col-1\" }\nconst _hoisted_22 = [\"id\"]\nconst _hoisted_23 = { class: \"col col-5\" }\nconst _hoisted_24 = [\"for\"]\nconst _hoisted_25 = { class: \"row mb-2\" }\nconst _hoisted_26 = { class: \"col col-6\" }\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_28 = { class: \"col col-4\" }\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_31 = { class: \"col col-4\" }\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_34 = { class: \"col col-4\" }\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" }\n\nexport function render(_ctx: any,_cache: any,$props: any,$setup: any,$data: any,$options: any) {\n  return (_openBlock(), _createBlock($setup[\"dialogContainer\"], {\n    domId: $setup.domId,\n    commitCb: $setup.commitCb,\n    cancelCb: $setup.cancelCb,\n    label: $setup.label\n  }, {\n    default: _withCtx(() => [\n      _createElementVNode(\"div\", _hoisted_1, [\n        _createElementVNode(\"div\", _hoisted_2, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partName,\n            \"aria-label\": \"Part Name\",\n            id: $setup.getId('part-name-input'),\n            \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => (($setup.partInfo.partName) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n            [_vModelText, $setup.partInfo.partName]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_4, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-name-label')\n          }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_6, [\n        _createElementVNode(\"div\", _hoisted_7, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partAbbreviation,\n            \"aria-label\": \"Part Abbreviation\",\n            id: $setup.getId('part-abbreviation-input'),\n            \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event: any) => (($setup.partInfo.partAbbreviation) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n            [_vModelText, $setup.partInfo.partAbbreviation]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_9, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-abbreviation-label')\n          }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_11, [\n        _createElementVNode(\"div\", _hoisted_12, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[3] || (_cache[3] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_14, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n        ]),\n        _createElementVNode(\"div\", _hoisted_16, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event: any) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n            id: $setup.getId('expandMultimeasureRests'),\n            onChange: _cache[5] || (_cache[5] = ($event: any) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n            [_vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_18, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('expandMultimeasureRests')\n          }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_20, [\n        _createElementVNode(\"div\", _hoisted_21, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[7] || (_cache[7] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_22), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_23, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_25, [\n        _cache[8] || (_cache[8] = _createElementVNode(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_26, [\n          _createVNode($setup[\"selectComp\"], {\n            domId: $setup.getId('page-size-select'),\n            label: '',\n            selections: $setup.pageSizes,\n            initialValue: $setup.pageSize,\n            changeCb: $setup.pageChange\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_27, [\n        _createElementVNode(\"div\", _hoisted_28, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-width-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageWidth'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[9] || (_cache[9] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_29, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-height-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageHeight'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[10] || (_cache[10] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_30, [\n        _createElementVNode(\"div\", _hoisted_31, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('zoom-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('zoomScale'),\n            minValue: 0.25,\n            maxValue: 8\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[11] || (_cache[11] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_32, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('svg-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('svgScale'),\n            minValue: 0.25,\n            maxValue: 2\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[12] || (_cache[12] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_33, [\n        _createElementVNode(\"div\", _hoisted_34, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('note-spacing-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n            precision: 2,\n            changeCb: $setup.updateLayoutFunc('noteSpacing')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[13] || (_cache[13] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_35, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('max-measure-system-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[14] || (_cache[14] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n        ], -1 /* CACHED */))\n      ])\n    ]),\n    _: 1 /* STABLE */\n  }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]))\n}","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageChange\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true\n\n}");
810
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ render: () => (/* binding */ render)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_2 = { class: \"col col-8\" };\nconst _hoisted_3 = [\"placeholder\", \"id\"];\nconst _hoisted_4 = { class: \"col col-4 text-start\" };\nconst _hoisted_5 = [\"id\"];\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_7 = { class: \"col col-8\" };\nconst _hoisted_8 = [\"placeholder\", \"id\"];\nconst _hoisted_9 = { class: \"col col-4 text-start\" };\nconst _hoisted_10 = [\"id\"];\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_12 = { class: \"col col-1\" };\nconst _hoisted_13 = [\"id\"];\nconst _hoisted_14 = { class: \"col col-5\" };\nconst _hoisted_15 = [\"for\"];\nconst _hoisted_16 = { class: \"col col-1\" };\nconst _hoisted_17 = [\"id\"];\nconst _hoisted_18 = { class: \"col col-5\" };\nconst _hoisted_19 = [\"for\"];\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_21 = { class: \"col col-1\" };\nconst _hoisted_22 = [\"id\"];\nconst _hoisted_23 = { class: \"col col-5\" };\nconst _hoisted_24 = [\"for\"];\nconst _hoisted_25 = { class: \"row mb-2\" };\nconst _hoisted_26 = { class: \"col col-6\" };\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_28 = { class: \"col col-4\" };\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_31 = { class: \"col col-4\" };\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_34 = { class: \"col col-4\" };\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" };\nfunction render(_ctx, _cache, $props, $setup, $data, $options) {\n return ((0,vue__WEBPACK_IMPORTED_MODULE_0__.openBlock)(), (0,vue__WEBPACK_IMPORTED_MODULE_0__.createBlock)($setup[\"dialogContainer\"], {\n domId: $setup.domId,\n commitCb: $setup.commitCb,\n cancelCb: $setup.cancelCb,\n label: $setup.label\n }, {\n default: (0,vue__WEBPACK_IMPORTED_MODULE_0__.withCtx)(() => [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_1, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_2, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partName,\n \"aria-label\": \"Part Name\",\n id: $setup.getId('part-name-input'),\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => (($setup.partInfo.partName) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partName]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_4, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-name-label')\n }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_6, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_7, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partAbbreviation,\n \"aria-label\": \"Part Abbreviation\",\n id: $setup.getId('part-abbreviation-input'),\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event) => (($setup.partInfo.partAbbreviation) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partAbbreviation]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_9, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-abbreviation-label')\n }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_11, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_12, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[3] || (_cache[3] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_14, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_16, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n id: $setup.getId('expandMultimeasureRests'),\n onChange: _cache[5] || (_cache[5] = ($event) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_18, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('expandMultimeasureRests')\n }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_20, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_21, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event) => (($setup.includeNext) = $event)),\n id: $setup.getId('includeNext')\n }, null, 8 /* PROPS */, _hoisted_22), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.includeNext]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_23, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('includeNext')\n }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_25, [\n _cache[7] || (_cache[7] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_26, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"selectComp\"], {\n domId: $setup.getId('page-size-select'),\n label: '',\n selections: $setup.pageSizes,\n initialValue: $setup.pageSize,\n changeCb: $setup.pageSizeCb\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_27, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_28, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-width-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageWidth'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[8] || (_cache[8] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_29, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-height-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageHeight'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[9] || (_cache[9] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_30, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_31, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('zoom-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('zoomScale'),\n minValue: 0.25,\n maxValue: 8\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[10] || (_cache[10] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_32, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('svg-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('svgScale'),\n minValue: 0.25,\n maxValue: 2\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[11] || (_cache[11] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_33, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_34, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('note-spacing-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n precision: 2,\n changeCb: $setup.updateLayoutFunc('noteSpacing')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[12] || (_cache[12] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_35, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('max-measure-system-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[13] || (_cache[13] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n ], -1 /* CACHED */))\n ])\n ]),\n _: 1 /* STABLE */\n }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c06c","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { vModelText as _vModelText, createElementVNode as _createElementVNode, withDirectives as _withDirectives, vModelCheckbox as _vModelCheckbox, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock } from \"vue\"\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_2 = { class: \"col col-8\" }\nconst _hoisted_3 = [\"placeholder\", \"id\"]\nconst _hoisted_4 = { class: \"col col-4 text-start\" }\nconst _hoisted_5 = [\"id\"]\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_7 = { class: \"col col-8\" }\nconst _hoisted_8 = [\"placeholder\", \"id\"]\nconst _hoisted_9 = { class: \"col col-4 text-start\" }\nconst _hoisted_10 = [\"id\"]\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_12 = { class: \"col col-1\" }\nconst _hoisted_13 = [\"id\"]\nconst _hoisted_14 = { class: \"col col-5\" }\nconst _hoisted_15 = [\"for\"]\nconst _hoisted_16 = { class: \"col col-1\" }\nconst _hoisted_17 = [\"id\"]\nconst _hoisted_18 = { class: \"col col-5\" }\nconst _hoisted_19 = [\"for\"]\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_21 = { class: \"col col-1\" }\nconst _hoisted_22 = [\"id\"]\nconst _hoisted_23 = { class: \"col col-5\" }\nconst _hoisted_24 = [\"for\"]\nconst _hoisted_25 = { class: \"row mb-2\" }\nconst _hoisted_26 = { class: \"col col-6\" }\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_28 = { class: \"col col-4\" }\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_31 = { class: \"col col-4\" }\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_34 = { class: \"col col-4\" }\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" }\n\nexport function render(_ctx: any,_cache: any,$props: any,$setup: any,$data: any,$options: any) {\n  return (_openBlock(), _createBlock($setup[\"dialogContainer\"], {\n    domId: $setup.domId,\n    commitCb: $setup.commitCb,\n    cancelCb: $setup.cancelCb,\n    label: $setup.label\n  }, {\n    default: _withCtx(() => [\n      _createElementVNode(\"div\", _hoisted_1, [\n        _createElementVNode(\"div\", _hoisted_2, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partName,\n            \"aria-label\": \"Part Name\",\n            id: $setup.getId('part-name-input'),\n            \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => (($setup.partInfo.partName) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n            [_vModelText, $setup.partInfo.partName]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_4, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-name-label')\n          }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_6, [\n        _createElementVNode(\"div\", _hoisted_7, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partAbbreviation,\n            \"aria-label\": \"Part Abbreviation\",\n            id: $setup.getId('part-abbreviation-input'),\n            \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event: any) => (($setup.partInfo.partAbbreviation) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n            [_vModelText, $setup.partInfo.partAbbreviation]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_9, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-abbreviation-label')\n          }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_11, [\n        _createElementVNode(\"div\", _hoisted_12, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[3] || (_cache[3] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_14, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n        ]),\n        _createElementVNode(\"div\", _hoisted_16, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event: any) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n            id: $setup.getId('expandMultimeasureRests'),\n            onChange: _cache[5] || (_cache[5] = ($event: any) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n            [_vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_18, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('expandMultimeasureRests')\n          }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_20, [\n        _createElementVNode(\"div\", _hoisted_21, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event: any) => (($setup.includeNext) = $event)),\n            id: $setup.getId('includeNext')\n          }, null, 8 /* PROPS */, _hoisted_22), [\n            [_vModelCheckbox, $setup.includeNext]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_23, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('includeNext')\n          }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_25, [\n        _cache[7] || (_cache[7] = _createElementVNode(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_26, [\n          _createVNode($setup[\"selectComp\"], {\n            domId: $setup.getId('page-size-select'),\n            label: '',\n            selections: $setup.pageSizes,\n            initialValue: $setup.pageSize,\n            changeCb: $setup.pageSizeCb\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_27, [\n        _createElementVNode(\"div\", _hoisted_28, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-width-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageWidth'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[8] || (_cache[8] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_29, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-height-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageHeight'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[9] || (_cache[9] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_30, [\n        _createElementVNode(\"div\", _hoisted_31, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('zoom-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('zoomScale'),\n            minValue: 0.25,\n            maxValue: 8\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[10] || (_cache[10] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_32, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('svg-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('svgScale'),\n            minValue: 0.25,\n            maxValue: 2\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[11] || (_cache[11] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_33, [\n        _createElementVNode(\"div\", _hoisted_34, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('note-spacing-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n            precision: 2,\n            changeCb: $setup.updateLayoutFunc('noteSpacing')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[12] || (_cache[12] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_35, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('max-measure-system-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[13] || (_cache[13] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n        ], -1 /* CACHED */))\n      ])\n    ]),\n    _: 1 /* STABLE */\n  }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]))\n}","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"includeNext\" :id=\"getId('includeNext')\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('includeNext')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageSizeCb\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true\n\n}");
811
811
 
812
812
  /***/ },
813
813
 
@@ -3865,7 +3865,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
3865
3865
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
3866
3866
 
3867
3867
  "use strict";
3868
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SuiPartInfoDialogVue: () => (/* binding */ SuiPartInfoDialogVue)\n/* harmony export */ });\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../smo/xform/selections */ \"./src/smo/xform/selections.ts\");\n/* harmony import */ var _dialog__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dialog */ \"./src/ui/dialogs/dialog.ts\");\n/* harmony import */ var _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../ui/components/dialogs/partInfo.vue */ \"./src/ui/components/dialogs/partInfo.vue\");\n/* harmony import */ var _common__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common */ \"./src/ui/common.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\nconst SuiPartInfoDialogVue = (parameters) => __awaiter(void 0, void 0, void 0, function* () {\n const selector = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelector.default;\n const selection = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelection.measureSelection(parameters.view.score, selector.staff, selector.measure);\n const backup = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(selection.staff.partInfo);\n let current = backup;\n let changed = false;\n const updatePartInfoCb = (partInfo) => __awaiter(void 0, void 0, void 0, function* () {\n changed = true;\n // Since update will change the displayed score, wait for any display change to complete first.\n yield parameters.view.renderer.updatePromise();\n yield parameters.view.updatePartInfo(partInfo);\n // If we are expanding rests, we need to reload the part after setting the \n // part change. So we update the part display a second time with the new value.\n if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests) {\n parameters.view.resetPartView();\n yield parameters.view.refreshViewport();\n }\n current = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(partInfo);\n });\n const commitCb = () => __awaiter(void 0, void 0, void 0, function* () {\n });\n const cancelCb = () => __awaiter(void 0, void 0, void 0, function* () {\n if (changed) {\n yield parameters.view.renderer.updatePromise();\n if (current.expandMultimeasureRests !== backup.expandMultimeasureRests) {\n parameters.view.resetPartView();\n }\n yield parameters.view.updatePartInfo(backup);\n }\n });\n const rootId = (0,_common__WEBPACK_IMPORTED_MODULE_4__.replaceVueRoot)(_common__WEBPACK_IMPORTED_MODULE_4__.modalContainerId);\n const appParams = {\n domId: rootId,\n partInfo: current,\n label: 'Part Properties',\n updatePartInfoCb\n };\n (0,_dialog__WEBPACK_IMPORTED_MODULE_2__.InstallDialog)({\n app: _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n appParams,\n root: rootId,\n dialogParams: parameters,\n commitCb,\n cancelCb\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvZGlhbG9ncy9wYXJ0SW5mby50cyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHc0Q7QUFDaUI7QUFFYjtBQUNTO0FBQ047QUFHdEQsTUFBTSxvQkFBb0IsR0FBRyxDQUFPLFVBQTJCLEVBQUUsRUFBRTtJQUN4RSxNQUFNLFFBQVEsR0FBRyw4REFBVyxDQUFDLE9BQU8sQ0FBQztJQUNyQyxNQUFNLFNBQVMsR0FBRywrREFBWSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBRSxDQUFDO0lBQzFHLE1BQU0sTUFBTSxHQUFHLElBQUksMkRBQVcsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pELElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUNyQixJQUFJLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDcEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFPLFFBQXFCLEVBQUUsRUFBRTtRQUN2RCxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ2YsK0ZBQStGO1FBQy9GLE1BQU0sVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFL0MsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQywyRUFBMkU7UUFDM0UsZ0ZBQWdGO1FBQ2hGLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLFFBQVEsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO1lBQ3pFLFVBQVUsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDaEMsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQzFDLENBQUM7UUFDRCxPQUFPLEdBQUcsSUFBSSwyREFBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxHQUFTLEVBQUU7SUFDNUIsQ0FBQztJQUNELE1BQU0sUUFBUSxHQUFHLEdBQVMsRUFBRTtRQUMxQixJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMvQyxJQUFJLE9BQU8sQ0FBQyx1QkFBdUIsS0FBSyxNQUFNLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztnQkFDdkUsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNsQyxDQUFDO1lBQ0QsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMvQyxDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sTUFBTSxHQUFHLHVEQUFjLENBQUMscURBQWdCLENBQUMsQ0FBQztJQUNoRCxNQUFNLFNBQVMsR0FBRztRQUNoQixLQUFLLEVBQUUsTUFBTTtRQUNiLFFBQVEsRUFBRSxPQUFPO1FBQ2pCLEtBQUssRUFBRSxpQkFBaUI7UUFDeEIsZ0JBQWdCO0tBQ2pCLENBQUM7SUFDRixzREFBYSxDQUFDO1FBQ1osR0FBRyxFQUFFLDJFQUFXO1FBQ2hCLFNBQVM7UUFDVCxJQUFJLEVBQUUsTUFBTTtRQUNaLFlBQVksRUFBRSxVQUFVO1FBQ3hCLFFBQVE7UUFDUixRQUFRO0tBQ1QsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXMiOlsid2VicGFjazovL1Ntby8uL3NyYy91aS9kaWFsb2dzL3BhcnRJbmZvLnRzPzFiMzAiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gW1Ntb29zaWNdKGh0dHBzOi8vZ2l0aHViLmNvbS9BYXJvbkRhdmlkTmV3bWFuL1Ntb29zaWMpXHJcbi8vIENvcHlyaWdodCAoYykgQWFyb24gRGF2aWQgTmV3bWFuIDIwMjEuXHJcbmltcG9ydCB7IFNtb1Njb3JlIH0gZnJvbSAnLi4vLi4vc21vL2RhdGEvc2NvcmUnO1xyXG5pbXBvcnQgeyBTbW9QYXJ0SW5mbyB9IGZyb20gJy4uLy4uL3Ntby9kYXRhL3BhcnRJbmZvJztcclxuaW1wb3J0IHsgU21vU2VsZWN0aW9uLCBTbW9TZWxlY3RvciB9IGZyb20gJy4uLy4uL3Ntby94Zm9ybS9zZWxlY3Rpb25zJztcclxuXHJcbmltcG9ydCB7IFN1aURpYWxvZ1BhcmFtcywgSW5zdGFsbERpYWxvZyB9IGZyb20gJy4vZGlhbG9nJztcclxuaW1wb3J0IHBhcnRJbmZvQXBwIGZyb20gJy4uLy4uL3VpL2NvbXBvbmVudHMvZGlhbG9ncy9wYXJ0SW5mby52dWUnO1xyXG5pbXBvcnQgeyByZXBsYWNlVnVlUm9vdCwgbW9kYWxDb250YWluZXJJZCB9IGZyb20gJy4uL2NvbW1vbic7XHJcblxyXG5kZWNsYXJlIHZhciAkOiBhbnk7XHJcbmV4cG9ydCBjb25zdCBTdWlQYXJ0SW5mb0RpYWxvZ1Z1ZSA9IGFzeW5jIChwYXJhbWV0ZXJzOiBTdWlEaWFsb2dQYXJhbXMpID0+IHtcclxuICBjb25zdCBzZWxlY3RvciA9IFNtb1NlbGVjdG9yLmRlZmF1bHQ7XHJcbiAgY29uc3Qgc2VsZWN0aW9uID0gU21vU2VsZWN0aW9uLm1lYXN1cmVTZWxlY3Rpb24ocGFyYW1ldGVycy52aWV3LnNjb3JlLCBzZWxlY3Rvci5zdGFmZiwgc2VsZWN0b3IubWVhc3VyZSkhO1xyXG4gIGNvbnN0IGJhY2t1cCA9IG5ldyBTbW9QYXJ0SW5mbyhzZWxlY3Rpb24uc3RhZmYucGFydEluZm8pO1xyXG4gIGxldCBjdXJyZW50ID0gYmFja3VwO1xyXG4gIGxldCBjaGFuZ2VkID0gZmFsc2U7XHJcbiAgY29uc3QgdXBkYXRlUGFydEluZm9DYiA9IGFzeW5jIChwYXJ0SW5mbzogU21vUGFydEluZm8pID0+IHtcclxuICAgIGNoYW5nZWQgPSB0cnVlO1xyXG4gICAgLy8gU2luY2UgdXBkYXRlIHdpbGwgY2hhbmdlIHRoZSBkaXNwbGF5ZWQgc2NvcmUsIHdhaXQgZm9yIGFueSBkaXNwbGF5IGNoYW5nZSB0byBjb21wbGV0ZSBmaXJzdC5cclxuICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy5yZW5kZXJlci51cGRhdGVQcm9taXNlKCk7XHJcbiAgICBcclxuICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy51cGRhdGVQYXJ0SW5mbyhwYXJ0SW5mbyk7XHJcbiAgICAvLyBJZiB3ZSBhcmUgZXhwYW5kaW5nIHJlc3RzLCB3ZSBuZWVkIHRvIHJlbG9hZCB0aGUgcGFydCBhZnRlciBzZXR0aW5nIHRoZSBcclxuICAgIC8vIHBhcnQgY2hhbmdlLiAgU28gd2UgdXBkYXRlIHRoZSBwYXJ0IGRpc3BsYXkgYSBzZWNvbmQgdGltZSB3aXRoIHRoZSBuZXcgdmFsdWUuXHJcbiAgICBpZiAoY3VycmVudC5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyAhPT0gcGFydEluZm8uZXhwYW5kTXVsdGltZWFzdXJlUmVzdHMpIHtcclxuICAgICAgcGFyYW1ldGVycy52aWV3LnJlc2V0UGFydFZpZXcoKTtcclxuICAgICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnJlZnJlc2hWaWV3cG9ydCgpO1xyXG4gICAgfVxyXG4gICAgY3VycmVudCA9IG5ldyBTbW9QYXJ0SW5mbyhwYXJ0SW5mbyk7XHJcbiAgfVxyXG5cclxuICBjb25zdCBjb21taXRDYiA9IGFzeW5jICgpID0+IHtcclxuICB9XHJcbiAgY29uc3QgY2FuY2VsQ2IgPSBhc3luYyAoKSA9PiB7XHJcbiAgICBpZiAoY2hhbmdlZCkge1xyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcucmVuZGVyZXIudXBkYXRlUHJvbWlzZSgpO1xyXG4gICAgICBpZiAoY3VycmVudC5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyAhPT0gYmFja3VwLmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzKSB7XHJcbiAgICAgICAgcGFyYW1ldGVycy52aWV3LnJlc2V0UGFydFZpZXcoKTtcclxuICAgICAgfVxyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcudXBkYXRlUGFydEluZm8oYmFja3VwKTtcclxuICAgIH1cclxuICB9XHJcbiAgY29uc3Qgcm9vdElkID0gcmVwbGFjZVZ1ZVJvb3QobW9kYWxDb250YWluZXJJZCk7XHJcbiAgY29uc3QgYXBwUGFyYW1zID0ge1xyXG4gICAgZG9tSWQ6IHJvb3RJZCxcclxuICAgIHBhcnRJbmZvOiBjdXJyZW50LFxyXG4gICAgbGFiZWw6ICdQYXJ0IFByb3BlcnRpZXMnLFxyXG4gICAgdXBkYXRlUGFydEluZm9DYlxyXG4gIH07XHJcbiAgSW5zdGFsbERpYWxvZyh7XHJcbiAgICBhcHA6IHBhcnRJbmZvQXBwLFxyXG4gICAgYXBwUGFyYW1zLFxyXG4gICAgcm9vdDogcm9vdElkLFxyXG4gICAgZGlhbG9nUGFyYW1zOiBwYXJhbWV0ZXJzLFxyXG4gICAgY29tbWl0Q2IsIFxyXG4gICAgY2FuY2VsQ2JcclxuICB9KTtcclxufVxyXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/dialogs/partInfo.ts\n\n}");
3868
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SuiPartInfoDialogVue: () => (/* binding */ SuiPartInfoDialogVue)\n/* harmony export */ });\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../smo/xform/selections */ \"./src/smo/xform/selections.ts\");\n/* harmony import */ var _dialog__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dialog */ \"./src/ui/dialogs/dialog.ts\");\n/* harmony import */ var _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../ui/components/dialogs/partInfo.vue */ \"./src/ui/components/dialogs/partInfo.vue\");\n/* harmony import */ var _common__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common */ \"./src/ui/common.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\nconst SuiPartInfoDialogVue = (parameters) => __awaiter(void 0, void 0, void 0, function* () {\n const selector = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelector.default;\n const selection = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelection.measureSelection(parameters.view.score, selector.staff, selector.measure);\n const backup = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(selection.staff.partInfo);\n let current = backup;\n let changed = false;\n const updatePartInfoCb = (partInfo) => __awaiter(void 0, void 0, void 0, function* () {\n changed = true;\n // Since update will change the displayed score, wait for any display change to complete first.\n yield parameters.view.renderer.updatePromise();\n yield parameters.view.updatePartInfo(partInfo);\n // If we are expanding rests, we need to reload the part after setting the \n // part change. So we update the part display a second time with the new value.\n if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests ||\n current.stavesAfter !== partInfo.stavesAfter) {\n parameters.view.resetPartView();\n yield parameters.view.refreshViewport();\n }\n current = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(partInfo);\n });\n const commitCb = () => __awaiter(void 0, void 0, void 0, function* () {\n });\n const cancelCb = () => __awaiter(void 0, void 0, void 0, function* () {\n if (changed) {\n yield parameters.view.renderer.updatePromise();\n if (current.expandMultimeasureRests !== backup.expandMultimeasureRests) {\n parameters.view.resetPartView();\n }\n yield parameters.view.updatePartInfo(backup);\n }\n });\n const rootId = (0,_common__WEBPACK_IMPORTED_MODULE_4__.replaceVueRoot)(_common__WEBPACK_IMPORTED_MODULE_4__.modalContainerId);\n const appParams = {\n domId: rootId,\n partInfo: current,\n label: 'Part Properties',\n updatePartInfoCb\n };\n (0,_dialog__WEBPACK_IMPORTED_MODULE_2__.InstallDialog)({\n app: _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n appParams,\n root: rootId,\n dialogParams: parameters,\n commitCb,\n cancelCb\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvZGlhbG9ncy9wYXJ0SW5mby50cyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHc0Q7QUFDaUI7QUFFYjtBQUNTO0FBQ047QUFHdEQsTUFBTSxvQkFBb0IsR0FBRyxDQUFPLFVBQTJCLEVBQUUsRUFBRTtJQUN4RSxNQUFNLFFBQVEsR0FBRyw4REFBVyxDQUFDLE9BQU8sQ0FBQztJQUNyQyxNQUFNLFNBQVMsR0FBRywrREFBWSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBRSxDQUFDO0lBQzFHLE1BQU0sTUFBTSxHQUFHLElBQUksMkRBQVcsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pELElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUNyQixJQUFJLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDcEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFPLFFBQXFCLEVBQUUsRUFBRTtRQUN2RCxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ2YsK0ZBQStGO1FBQy9GLE1BQU0sVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFL0MsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQywyRUFBMkU7UUFDM0UsZ0ZBQWdGO1FBQ2hGLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLFFBQVEsQ0FBQyx1QkFBdUI7WUFDdEUsT0FBTyxDQUFDLFdBQVcsS0FBSyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDL0MsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNoQyxNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDMUMsQ0FBQztRQUNELE9BQU8sR0FBRyxJQUFJLDJEQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELE1BQU0sUUFBUSxHQUFHLEdBQVMsRUFBRTtJQUM1QixDQUFDO0lBQ0QsTUFBTSxRQUFRLEdBQUcsR0FBUyxFQUFFO1FBQzFCLElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQy9DLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO2dCQUN2RSxVQUFVLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ2xDLENBQUM7WUFDRCxNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxNQUFNLEdBQUcsdURBQWMsQ0FBQyxxREFBZ0IsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sU0FBUyxHQUFHO1FBQ2hCLEtBQUssRUFBRSxNQUFNO1FBQ2IsUUFBUSxFQUFFLE9BQU87UUFDakIsS0FBSyxFQUFFLGlCQUFpQjtRQUN4QixnQkFBZ0I7S0FDakIsQ0FBQztJQUNGLHNEQUFhLENBQUM7UUFDWixHQUFHLEVBQUUsMkVBQVc7UUFDaEIsU0FBUztRQUNULElBQUksRUFBRSxNQUFNO1FBQ1osWUFBWSxFQUFFLFVBQVU7UUFDeEIsUUFBUTtRQUNSLFFBQVE7S0FDVCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vU21vLy4vc3JjL3VpL2RpYWxvZ3MvcGFydEluZm8udHM/MWIzMCJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBbU21vb3NpY10oaHR0cHM6Ly9naXRodWIuY29tL0Fhcm9uRGF2aWROZXdtYW4vU21vb3NpYylcclxuLy8gQ29weXJpZ2h0IChjKSBBYXJvbiBEYXZpZCBOZXdtYW4gMjAyMS5cclxuaW1wb3J0IHsgU21vU2NvcmUgfSBmcm9tICcuLi8uLi9zbW8vZGF0YS9zY29yZSc7XHJcbmltcG9ydCB7IFNtb1BhcnRJbmZvIH0gZnJvbSAnLi4vLi4vc21vL2RhdGEvcGFydEluZm8nO1xyXG5pbXBvcnQgeyBTbW9TZWxlY3Rpb24sIFNtb1NlbGVjdG9yIH0gZnJvbSAnLi4vLi4vc21vL3hmb3JtL3NlbGVjdGlvbnMnO1xyXG5cclxuaW1wb3J0IHsgU3VpRGlhbG9nUGFyYW1zLCBJbnN0YWxsRGlhbG9nIH0gZnJvbSAnLi9kaWFsb2cnO1xyXG5pbXBvcnQgcGFydEluZm9BcHAgZnJvbSAnLi4vLi4vdWkvY29tcG9uZW50cy9kaWFsb2dzL3BhcnRJbmZvLnZ1ZSc7XHJcbmltcG9ydCB7IHJlcGxhY2VWdWVSb290LCBtb2RhbENvbnRhaW5lcklkIH0gZnJvbSAnLi4vY29tbW9uJztcclxuXHJcbmRlY2xhcmUgdmFyICQ6IGFueTtcclxuZXhwb3J0IGNvbnN0IFN1aVBhcnRJbmZvRGlhbG9nVnVlID0gYXN5bmMgKHBhcmFtZXRlcnM6IFN1aURpYWxvZ1BhcmFtcykgPT4ge1xyXG4gIGNvbnN0IHNlbGVjdG9yID0gU21vU2VsZWN0b3IuZGVmYXVsdDtcclxuICBjb25zdCBzZWxlY3Rpb24gPSBTbW9TZWxlY3Rpb24ubWVhc3VyZVNlbGVjdGlvbihwYXJhbWV0ZXJzLnZpZXcuc2NvcmUsIHNlbGVjdG9yLnN0YWZmLCBzZWxlY3Rvci5tZWFzdXJlKSE7XHJcbiAgY29uc3QgYmFja3VwID0gbmV3IFNtb1BhcnRJbmZvKHNlbGVjdGlvbi5zdGFmZi5wYXJ0SW5mbyk7XHJcbiAgbGV0IGN1cnJlbnQgPSBiYWNrdXA7XHJcbiAgbGV0IGNoYW5nZWQgPSBmYWxzZTtcclxuICBjb25zdCB1cGRhdGVQYXJ0SW5mb0NiID0gYXN5bmMgKHBhcnRJbmZvOiBTbW9QYXJ0SW5mbykgPT4ge1xyXG4gICAgY2hhbmdlZCA9IHRydWU7XHJcbiAgICAvLyBTaW5jZSB1cGRhdGUgd2lsbCBjaGFuZ2UgdGhlIGRpc3BsYXllZCBzY29yZSwgd2FpdCBmb3IgYW55IGRpc3BsYXkgY2hhbmdlIHRvIGNvbXBsZXRlIGZpcnN0LlxyXG4gICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnJlbmRlcmVyLnVwZGF0ZVByb21pc2UoKTtcclxuICAgIFxyXG4gICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnVwZGF0ZVBhcnRJbmZvKHBhcnRJbmZvKTtcclxuICAgIC8vIElmIHdlIGFyZSBleHBhbmRpbmcgcmVzdHMsIHdlIG5lZWQgdG8gcmVsb2FkIHRoZSBwYXJ0IGFmdGVyIHNldHRpbmcgdGhlIFxyXG4gICAgLy8gcGFydCBjaGFuZ2UuICBTbyB3ZSB1cGRhdGUgdGhlIHBhcnQgZGlzcGxheSBhIHNlY29uZCB0aW1lIHdpdGggdGhlIG5ldyB2YWx1ZS5cclxuICAgIGlmIChjdXJyZW50LmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzICE9PSBwYXJ0SW5mby5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyB8fFxyXG4gICAgICBjdXJyZW50LnN0YXZlc0FmdGVyICE9PSBwYXJ0SW5mby5zdGF2ZXNBZnRlcikge1xyXG4gICAgICBwYXJhbWV0ZXJzLnZpZXcucmVzZXRQYXJ0VmlldygpO1xyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcucmVmcmVzaFZpZXdwb3J0KCk7XHJcbiAgICB9XHJcbiAgICBjdXJyZW50ID0gbmV3IFNtb1BhcnRJbmZvKHBhcnRJbmZvKTtcclxuICB9XHJcblxyXG4gIGNvbnN0IGNvbW1pdENiID0gYXN5bmMgKCkgPT4ge1xyXG4gIH1cclxuICBjb25zdCBjYW5jZWxDYiA9IGFzeW5jICgpID0+IHtcclxuICAgIGlmIChjaGFuZ2VkKSB7XHJcbiAgICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy5yZW5kZXJlci51cGRhdGVQcm9taXNlKCk7XHJcbiAgICAgIGlmIChjdXJyZW50LmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzICE9PSBiYWNrdXAuZXhwYW5kTXVsdGltZWFzdXJlUmVzdHMpIHtcclxuICAgICAgICBwYXJhbWV0ZXJzLnZpZXcucmVzZXRQYXJ0VmlldygpO1xyXG4gICAgICB9XHJcbiAgICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy51cGRhdGVQYXJ0SW5mbyhiYWNrdXApO1xyXG4gICAgfVxyXG4gIH1cclxuICBjb25zdCByb290SWQgPSByZXBsYWNlVnVlUm9vdChtb2RhbENvbnRhaW5lcklkKTtcclxuICBjb25zdCBhcHBQYXJhbXMgPSB7XHJcbiAgICBkb21JZDogcm9vdElkLFxyXG4gICAgcGFydEluZm86IGN1cnJlbnQsXHJcbiAgICBsYWJlbDogJ1BhcnQgUHJvcGVydGllcycsXHJcbiAgICB1cGRhdGVQYXJ0SW5mb0NiXHJcbiAgfTtcclxuICBJbnN0YWxsRGlhbG9nKHtcclxuICAgIGFwcDogcGFydEluZm9BcHAsXHJcbiAgICBhcHBQYXJhbXMsXHJcbiAgICByb290OiByb290SWQsXHJcbiAgICBkaWFsb2dQYXJhbXM6IHBhcmFtZXRlcnMsXHJcbiAgICBjb21taXRDYiwgXHJcbiAgICBjYW5jZWxDYlxyXG4gIH0pO1xyXG59XHJcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/dialogs/partInfo.ts\n\n}");
3869
3869
 
3870
3870
  /***/ },
3871
3871
 
package/package.json CHANGED
@@ -1,6 +1,6 @@
1
1
  {
2
2
  "name": "smoosic",
3
- "version": "1.0.28",
3
+ "version": "1.0.29",
4
4
  "devDependencies": {
5
5
  "copy-webpack-plugin": "^12.0.2",
6
6
  "jquery": "^3.6.0",
@@ -26,7 +26,7 @@
26
26
  "xmldom": "^0.6.0"
27
27
  },
28
28
  "main": "build/smoosic.js",
29
- "description": "<sub>[Github site](https://github.com/Smoosic/smoosic) | [source documentation](https://smoosic.github.io/Smoosic/release/docs/modules.html) | [change notes](https://aarondavidnewman.github.io/Smoosic/changes.html) | [application](https://smoosic.github.io/Smoosic/release/html/smoosic.html)<sub>",
29
+ "description": "<sub>[Github site](https://github.com/Smoosic/smoosic) | [source documentation](https://smoosic.github.io/Smoosic/release/docs/modules.html) | [change notes](https://aarondavidnewman.github.io/Smoosic/changes.html) | [demo](https://smoosic.github.io/Smoosic/release/html/smoosic.html)<sub>",
30
30
  "directories": {
31
31
  "test": "tests"
32
32
  },
@@ -378,7 +378,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
378
378
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
379
379
 
380
380
  "use strict";
381
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n/* harmony import */ var _select_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./select.vue */ \"./src/ui/components/dialogs/select.vue\");\n/* harmony import */ var _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./numberInput.vue */ \"./src/ui/components/dialogs/numberInput.vue\");\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./dialogContainer.vue */ \"./src/ui/components/dialogs/dialogContainer.vue\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*@__PURE__*/(0,vue__WEBPACK_IMPORTED_MODULE_0__.defineComponent)({\n __name: 'partInfo',\n props: {\n domId: { type: String, required: true },\n label: { type: String, required: true },\n partInfo: { type: Object, required: true },\n updatePartInfoCb: { type: Function, required: true },\n commitCb: { type: Function, required: true },\n cancelCb: { type: Function, required: true }\n },\n setup(__props, { expose: __expose }) {\n __expose();\n const props = __props;\n const { domId, label, commitCb, cancelCb, updatePartInfoCb } = Object.assign({}, props);\n const partInfo = (0,vue__WEBPACK_IMPORTED_MODULE_0__.reactive)(new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__.SmoPartInfo(props.partInfo));\n const writeBooleanValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n partInfo[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const writeLayoutValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n // no change?\n if (partInfo.layoutManager.globalLayout[attr] === value) {\n return;\n }\n partInfo.layoutManager.globalLayout[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const pageSizes = [\n { label: 'Letter', value: 'letter' },\n { label: 'Legal', value: 'legal' },\n { label: 'Tabloid', value: 'tabloid' },\n { label: 'A4', value: 'a4' },\n { label: 'Custom', value: 'custom' }\n ];\n const predefinedDimensions = {\n 'letter': { width: 816, height: 1056 },\n 'legal': { width: 816, height: 1344 },\n 'tabloid': { width: 1056, height: 1632 },\n 'a4': { width: 794, height: 1123 }\n };\n // Page size is in pixels, but if it matches a preset we just show that.\n // User chooses 'custom' to unlock width/height editing.\n const pageSize = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)('custom');\n const pageChange = () => {\n Object.keys(predefinedDimensions).forEach((key) => {\n const dims = predefinedDimensions[key];\n if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\n dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\n pageSize.value = key;\n }\n });\n };\n const lockDimensions = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n pageChange();\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(pageSize, (newVal) => __awaiter(this, void 0, void 0, function* () {\n if (predefinedDimensions[newVal]) {\n lockDimensions.value = true;\n const dims = predefinedDimensions[newVal];\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n else {\n lockDimensions.value = false;\n }\n yield updatePartInfoCb(partInfo);\n }));\n if (predefinedDimensions[pageSize.value]) {\n lockDimensions.value = true;\n }\n const update = () => __awaiter(this, void 0, void 0, function* () {\n yield updatePartInfoCb(partInfo);\n });\n const includeNext = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n if (partInfo.stavesAfter > 0) {\n includeNext.value = true;\n }\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(includeNext, (newVal, oldVal) => __awaiter(this, void 0, void 0, function* () {\n if (newVal !== oldVal) {\n partInfo.stavesAfter = newVal ? 1 : 0;\n yield updatePartInfoCb(partInfo);\n }\n }));\n const updateLayoutFunc = (param) => {\n const cb = (value) => __awaiter(this, void 0, void 0, function* () {\n yield writeLayoutValue(param, value);\n });\n return cb;\n };\n const getId = (str) => {\n return `${domId}-${str}`;\n };\n const __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp: _select_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"], numberInputApp: _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"], dialogContainer: _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"] };\n Object.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true });\n return __returned__;\n }\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?0a53","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\n\nexport default /*@__PURE__*/_defineComponent({\n  __name: 'partInfo',\n  props: {\n    domId: { type: String, required: true },\n    label: { type: String, required: true },\n    partInfo: { type: Object, required: true },\n    updatePartInfoCb: { type: Function, required: true },\n    commitCb: { type: Function, required: true },\n    cancelCb: { type: Function, required: true }\n  },\n  setup(__props: any, { expose: __expose }) {\n  __expose();\n\r\nconst props = __props;\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n\nconst __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp, numberInputApp, dialogContainer }\nObject.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true })\nreturn __returned__\n}\n\n})","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageChange\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts\n\n}");
381
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ \"default\": () => (__WEBPACK_DEFAULT_EXPORT__)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n/* harmony import */ var _select_vue__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ./select.vue */ \"./src/ui/components/dialogs/select.vue\");\n/* harmony import */ var _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./numberInput.vue */ \"./src/ui/components/dialogs/numberInput.vue\");\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ./dialogContainer.vue */ \"./src/ui/components/dialogs/dialogContainer.vue\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\n\n/* harmony default export */ const __WEBPACK_DEFAULT_EXPORT__ = (/*@__PURE__*/(0,vue__WEBPACK_IMPORTED_MODULE_0__.defineComponent)({\n __name: 'partInfo',\n props: {\n domId: { type: String, required: true },\n label: { type: String, required: true },\n partInfo: { type: Object, required: true },\n updatePartInfoCb: { type: Function, required: true },\n commitCb: { type: Function, required: true },\n cancelCb: { type: Function, required: true }\n },\n setup(__props, { expose: __expose }) {\n __expose();\n const props = __props;\n const { domId, label, commitCb, cancelCb, updatePartInfoCb } = Object.assign({}, props);\n const partInfo = (0,vue__WEBPACK_IMPORTED_MODULE_0__.reactive)(new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_3__.SmoPartInfo(props.partInfo));\n const writeBooleanValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n partInfo[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const writeLayoutValue = (attr, value) => __awaiter(this, void 0, void 0, function* () {\n // no change?\n if (partInfo.layoutManager.globalLayout[attr] === value) {\n return;\n }\n partInfo.layoutManager.globalLayout[attr] = value;\n yield updatePartInfoCb(partInfo);\n });\n const pageSizes = [\n { label: 'Letter', value: 'letter' },\n { label: 'Legal', value: 'legal' },\n { label: 'Tabloid', value: 'tabloid' },\n { label: 'A4', value: 'a4' },\n { label: 'Custom', value: 'custom' }\n ];\n const predefinedDimensions = {\n 'letter': { width: 816, height: 1056 },\n 'legal': { width: 816, height: 1344 },\n 'tabloid': { width: 1056, height: 1632 },\n 'a4': { width: 794, height: 1123 }\n };\n // Page size is in pixels, but if it matches a preset we just show that.\n // User chooses 'custom' to unlock width/height editing.\n const pageSize = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)('custom');\n const pageChange = () => {\n Object.keys(predefinedDimensions).forEach((key) => {\n const dims = predefinedDimensions[key];\n if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\n dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\n pageSize.value = key;\n }\n });\n };\n const pageSizeCb = (val) => __awaiter(this, void 0, void 0, function* () {\n const dims = predefinedDimensions[val];\n if (dims) {\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n pageSize.value = val;\n // The watch will trigger the callback\n });\n const lockDimensions = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n pageChange();\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(pageSize, (newVal) => __awaiter(this, void 0, void 0, function* () {\n if (predefinedDimensions[newVal]) {\n lockDimensions.value = true;\n const dims = predefinedDimensions[newVal];\n partInfo.layoutManager.globalLayout.pageWidth = dims.width;\n partInfo.layoutManager.globalLayout.pageHeight = dims.height;\n }\n else {\n lockDimensions.value = false;\n }\n yield updatePartInfoCb(partInfo);\n }));\n if (predefinedDimensions[pageSize.value]) {\n lockDimensions.value = true;\n }\n const update = () => __awaiter(this, void 0, void 0, function* () {\n yield updatePartInfoCb(partInfo);\n });\n const includeNext = (0,vue__WEBPACK_IMPORTED_MODULE_0__.ref)(false);\n if (partInfo.stavesAfter > 0) {\n includeNext.value = true;\n }\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.watch)(includeNext, (newVal, oldVal) => __awaiter(this, void 0, void 0, function* () {\n if (newVal !== oldVal) {\n partInfo.stavesAfter = newVal ? 1 : 0;\n yield updatePartInfoCb(partInfo);\n }\n }));\n const updateLayoutFunc = (param) => {\n const cb = (value) => __awaiter(this, void 0, void 0, function* () {\n yield writeLayoutValue(param, value);\n });\n return cb;\n };\n const getId = (str) => {\n return `${domId}-${str}`;\n };\n const __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, pageSizeCb, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp: _select_vue__WEBPACK_IMPORTED_MODULE_1__[\"default\"], numberInputApp: _numberInput_vue__WEBPACK_IMPORTED_MODULE_2__[\"default\"], dialogContainer: _dialogContainer_vue__WEBPACK_IMPORTED_MODULE_4__[\"default\"] };\n Object.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true });\n return __returned__;\n }\n}));\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?0a53","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { defineComponent as _defineComponent } from 'vue'\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\n\nexport default /*@__PURE__*/_defineComponent({\n  __name: 'partInfo',\n  props: {\n    domId: { type: String, required: true },\n    label: { type: String, required: true },\n    partInfo: { type: Object, required: true },\n    updatePartInfoCb: { type: Function, required: true },\n    commitCb: { type: Function, required: true },\n    cancelCb: { type: Function, required: true }\n  },\n  setup(__props: any, { expose: __expose }) {\n  __expose();\n\r\nconst props = __props;\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n\nconst __returned__ = { props, domId, label, commitCb, cancelCb, updatePartInfoCb, partInfo, writeBooleanValue, writeLayoutValue, pageSizes, predefinedDimensions, pageSize, pageChange, pageSizeCb, lockDimensions, update, includeNext, updateLayoutFunc, getId, selectComp, numberInputApp, dialogContainer }\nObject.defineProperty(__returned__, '__isScriptSetup', { enumerable: false, value: true })\nreturn __returned__\n}\n\n})","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"includeNext\" :id=\"getId('includeNext')\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('includeNext')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageSizeCb\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=script&setup=true&lang=ts\n\n}");
382
382
 
383
383
  /***/ },
384
384
 
@@ -807,7 +807,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
807
807
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
808
808
 
809
809
  "use strict";
810
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ render: () => (/* binding */ render)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_2 = { class: \"col col-8\" };\nconst _hoisted_3 = [\"placeholder\", \"id\"];\nconst _hoisted_4 = { class: \"col col-4 text-start\" };\nconst _hoisted_5 = [\"id\"];\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_7 = { class: \"col col-8\" };\nconst _hoisted_8 = [\"placeholder\", \"id\"];\nconst _hoisted_9 = { class: \"col col-4 text-start\" };\nconst _hoisted_10 = [\"id\"];\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_12 = { class: \"col col-1\" };\nconst _hoisted_13 = [\"id\"];\nconst _hoisted_14 = { class: \"col col-5\" };\nconst _hoisted_15 = [\"for\"];\nconst _hoisted_16 = { class: \"col col-1\" };\nconst _hoisted_17 = [\"id\"];\nconst _hoisted_18 = { class: \"col col-5\" };\nconst _hoisted_19 = [\"for\"];\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_21 = { class: \"col col-1\" };\nconst _hoisted_22 = [\"id\"];\nconst _hoisted_23 = { class: \"col col-5\" };\nconst _hoisted_24 = [\"for\"];\nconst _hoisted_25 = { class: \"row mb-2\" };\nconst _hoisted_26 = { class: \"col col-6\" };\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_28 = { class: \"col col-4\" };\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_31 = { class: \"col col-4\" };\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_34 = { class: \"col col-4\" };\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" };\nfunction render(_ctx, _cache, $props, $setup, $data, $options) {\n return ((0,vue__WEBPACK_IMPORTED_MODULE_0__.openBlock)(), (0,vue__WEBPACK_IMPORTED_MODULE_0__.createBlock)($setup[\"dialogContainer\"], {\n domId: $setup.domId,\n commitCb: $setup.commitCb,\n cancelCb: $setup.cancelCb,\n label: $setup.label\n }, {\n default: (0,vue__WEBPACK_IMPORTED_MODULE_0__.withCtx)(() => [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_1, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_2, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partName,\n \"aria-label\": \"Part Name\",\n id: $setup.getId('part-name-input'),\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => (($setup.partInfo.partName) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partName]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_4, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-name-label')\n }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_6, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_7, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partAbbreviation,\n \"aria-label\": \"Part Abbreviation\",\n id: $setup.getId('part-abbreviation-input'),\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event) => (($setup.partInfo.partAbbreviation) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partAbbreviation]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_9, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-abbreviation-label')\n }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_11, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_12, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[3] || (_cache[3] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_14, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_16, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n id: $setup.getId('expandMultimeasureRests'),\n onChange: _cache[5] || (_cache[5] = ($event) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_18, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('expandMultimeasureRests')\n }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_20, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_21, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[7] || (_cache[7] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_22), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_23, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_25, [\n _cache[8] || (_cache[8] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_26, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"selectComp\"], {\n domId: $setup.getId('page-size-select'),\n label: '',\n selections: $setup.pageSizes,\n initialValue: $setup.pageSize,\n changeCb: $setup.pageChange\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_27, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_28, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-width-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageWidth'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[9] || (_cache[9] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_29, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-height-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageHeight'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[10] || (_cache[10] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_30, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_31, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('zoom-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('zoomScale'),\n minValue: 0.25,\n maxValue: 8\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[11] || (_cache[11] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_32, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('svg-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('svgScale'),\n minValue: 0.25,\n maxValue: 2\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[12] || (_cache[12] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_33, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_34, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('note-spacing-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n precision: 2,\n changeCb: $setup.updateLayoutFunc('noteSpacing')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[13] || (_cache[13] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_35, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('max-measure-system-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[14] || (_cache[14] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n ], -1 /* CACHED */))\n ])\n ]),\n _: 1 /* STABLE */\n }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c06c","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { vModelText as _vModelText, createElementVNode as _createElementVNode, withDirectives as _withDirectives, vModelCheckbox as _vModelCheckbox, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock } from \"vue\"\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_2 = { class: \"col col-8\" }\nconst _hoisted_3 = [\"placeholder\", \"id\"]\nconst _hoisted_4 = { class: \"col col-4 text-start\" }\nconst _hoisted_5 = [\"id\"]\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_7 = { class: \"col col-8\" }\nconst _hoisted_8 = [\"placeholder\", \"id\"]\nconst _hoisted_9 = { class: \"col col-4 text-start\" }\nconst _hoisted_10 = [\"id\"]\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_12 = { class: \"col col-1\" }\nconst _hoisted_13 = [\"id\"]\nconst _hoisted_14 = { class: \"col col-5\" }\nconst _hoisted_15 = [\"for\"]\nconst _hoisted_16 = { class: \"col col-1\" }\nconst _hoisted_17 = [\"id\"]\nconst _hoisted_18 = { class: \"col col-5\" }\nconst _hoisted_19 = [\"for\"]\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_21 = { class: \"col col-1\" }\nconst _hoisted_22 = [\"id\"]\nconst _hoisted_23 = { class: \"col col-5\" }\nconst _hoisted_24 = [\"for\"]\nconst _hoisted_25 = { class: \"row mb-2\" }\nconst _hoisted_26 = { class: \"col col-6\" }\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_28 = { class: \"col col-4\" }\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_31 = { class: \"col col-4\" }\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_34 = { class: \"col col-4\" }\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" }\n\nexport function render(_ctx: any,_cache: any,$props: any,$setup: any,$data: any,$options: any) {\n  return (_openBlock(), _createBlock($setup[\"dialogContainer\"], {\n    domId: $setup.domId,\n    commitCb: $setup.commitCb,\n    cancelCb: $setup.cancelCb,\n    label: $setup.label\n  }, {\n    default: _withCtx(() => [\n      _createElementVNode(\"div\", _hoisted_1, [\n        _createElementVNode(\"div\", _hoisted_2, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partName,\n            \"aria-label\": \"Part Name\",\n            id: $setup.getId('part-name-input'),\n            \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => (($setup.partInfo.partName) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n            [_vModelText, $setup.partInfo.partName]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_4, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-name-label')\n          }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_6, [\n        _createElementVNode(\"div\", _hoisted_7, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partAbbreviation,\n            \"aria-label\": \"Part Abbreviation\",\n            id: $setup.getId('part-abbreviation-input'),\n            \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event: any) => (($setup.partInfo.partAbbreviation) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n            [_vModelText, $setup.partInfo.partAbbreviation]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_9, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-abbreviation-label')\n          }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_11, [\n        _createElementVNode(\"div\", _hoisted_12, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[3] || (_cache[3] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_14, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n        ]),\n        _createElementVNode(\"div\", _hoisted_16, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event: any) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n            id: $setup.getId('expandMultimeasureRests'),\n            onChange: _cache[5] || (_cache[5] = ($event: any) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n            [_vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_18, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('expandMultimeasureRests')\n          }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_20, [\n        _createElementVNode(\"div\", _hoisted_21, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[7] || (_cache[7] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_22), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_23, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_25, [\n        _cache[8] || (_cache[8] = _createElementVNode(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_26, [\n          _createVNode($setup[\"selectComp\"], {\n            domId: $setup.getId('page-size-select'),\n            label: '',\n            selections: $setup.pageSizes,\n            initialValue: $setup.pageSize,\n            changeCb: $setup.pageChange\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_27, [\n        _createElementVNode(\"div\", _hoisted_28, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-width-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageWidth'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[9] || (_cache[9] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_29, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-height-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageHeight'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[10] || (_cache[10] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_30, [\n        _createElementVNode(\"div\", _hoisted_31, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('zoom-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('zoomScale'),\n            minValue: 0.25,\n            maxValue: 8\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[11] || (_cache[11] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_32, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('svg-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('svgScale'),\n            minValue: 0.25,\n            maxValue: 2\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[12] || (_cache[12] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_33, [\n        _createElementVNode(\"div\", _hoisted_34, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('note-spacing-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n            precision: 2,\n            changeCb: $setup.updateLayoutFunc('noteSpacing')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[13] || (_cache[13] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_35, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('max-measure-system-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[14] || (_cache[14] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n        ], -1 /* CACHED */))\n      ])\n    ]),\n    _: 1 /* STABLE */\n  }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]))\n}","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageChange\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true\n\n}");
810
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ render: () => (/* binding */ render)\n/* harmony export */ });\n/* harmony import */ var vue__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! vue */ \"./node_modules/vue/dist/vue.runtime.esm-bundler.js\");\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_2 = { class: \"col col-8\" };\nconst _hoisted_3 = [\"placeholder\", \"id\"];\nconst _hoisted_4 = { class: \"col col-4 text-start\" };\nconst _hoisted_5 = [\"id\"];\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_7 = { class: \"col col-8\" };\nconst _hoisted_8 = [\"placeholder\", \"id\"];\nconst _hoisted_9 = { class: \"col col-4 text-start\" };\nconst _hoisted_10 = [\"id\"];\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_12 = { class: \"col col-1\" };\nconst _hoisted_13 = [\"id\"];\nconst _hoisted_14 = { class: \"col col-5\" };\nconst _hoisted_15 = [\"for\"];\nconst _hoisted_16 = { class: \"col col-1\" };\nconst _hoisted_17 = [\"id\"];\nconst _hoisted_18 = { class: \"col col-5\" };\nconst _hoisted_19 = [\"for\"];\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_21 = { class: \"col col-1\" };\nconst _hoisted_22 = [\"id\"];\nconst _hoisted_23 = { class: \"col col-5\" };\nconst _hoisted_24 = [\"for\"];\nconst _hoisted_25 = { class: \"row mb-2\" };\nconst _hoisted_26 = { class: \"col col-6\" };\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_28 = { class: \"col col-4\" };\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_31 = { class: \"col col-4\" };\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" };\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" };\nconst _hoisted_34 = { class: \"col col-4\" };\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" };\nfunction render(_ctx, _cache, $props, $setup, $data, $options) {\n return ((0,vue__WEBPACK_IMPORTED_MODULE_0__.openBlock)(), (0,vue__WEBPACK_IMPORTED_MODULE_0__.createBlock)($setup[\"dialogContainer\"], {\n domId: $setup.domId,\n commitCb: $setup.commitCb,\n cancelCb: $setup.cancelCb,\n label: $setup.label\n }, {\n default: (0,vue__WEBPACK_IMPORTED_MODULE_0__.withCtx)(() => [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_1, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_2, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partName,\n \"aria-label\": \"Part Name\",\n id: $setup.getId('part-name-input'),\n \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event) => (($setup.partInfo.partName) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partName]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_4, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-name-label')\n }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_6, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_7, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n type: \"text\",\n class: \"form-control\",\n placeholder: $setup.partInfo.partAbbreviation,\n \"aria-label\": \"Part Abbreviation\",\n id: $setup.getId('part-abbreviation-input'),\n \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event) => (($setup.partInfo.partAbbreviation) = $event)),\n onChange: $setup.update\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelText, $setup.partInfo.partAbbreviation]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_9, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", {\n class: \"\",\n id: $setup.getId('part-abbreviation-label')\n }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_11, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_12, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event) => (($setup.partInfo.preserveTextGroups) = $event)),\n id: $setup.getId('preserveText'),\n onChange: _cache[3] || (_cache[3] = ($event) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.preserveTextGroups]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_14, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('preserveText')\n }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_16, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n id: $setup.getId('expandMultimeasureRests'),\n onChange: _cache[5] || (_cache[5] = ($event) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_18, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('expandMultimeasureRests')\n }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_20, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_21, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.withDirectives)((0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"input\", {\n class: \"form-check-input\",\n type: \"checkbox\",\n \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event) => (($setup.includeNext) = $event)),\n id: $setup.getId('includeNext')\n }, null, 8 /* PROPS */, _hoisted_22), [\n [vue__WEBPACK_IMPORTED_MODULE_0__.vModelCheckbox, $setup.includeNext]\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_23, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"label\", {\n class: \"form-check-label\",\n for: $setup.getId('includeNext')\n }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_25, [\n _cache[7] || (_cache[7] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_26, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"selectComp\"], {\n domId: $setup.getId('page-size-select'),\n label: '',\n selections: $setup.pageSizes,\n initialValue: $setup.pageSize,\n changeCb: $setup.pageSizeCb\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n ])\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_27, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_28, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-width-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageWidth'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[8] || (_cache[8] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_29, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('page-height-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('pageHeight'),\n disabled: $setup.lockDimensions\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n ]),\n _cache[9] || (_cache[9] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_30, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_31, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('zoom-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('zoomScale'),\n minValue: 0.25,\n maxValue: 8\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[10] || (_cache[10] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_32, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('svg-scale-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n precision: 0,\n percent: true,\n changeCb: $setup.updateLayoutFunc('svgScale'),\n minValue: 0.25,\n maxValue: 2\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[11] || (_cache[11] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n ], -1 /* CACHED */))\n ]),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_33, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_34, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('note-spacing-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n precision: 2,\n changeCb: $setup.updateLayoutFunc('noteSpacing')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[12] || (_cache[12] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n ], -1 /* CACHED */)),\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", _hoisted_35, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createVNode)($setup[\"numberInputApp\"], {\n domId: $setup.getId('max-measure-system-input'),\n initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n precision: 0,\n changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n ]),\n _cache[13] || (_cache[13] = (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n (0,vue__WEBPACK_IMPORTED_MODULE_0__.createElementVNode)(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n ], -1 /* CACHED */))\n ])\n ]),\n _: 1 /* STABLE */\n }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]));\n}\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,{"version":3,"file":"./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true","mappings":"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","sources":["webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c06c","webpack://Smo/./src/ui/components/dialogs/partInfo.vue?c5ad"],"sourcesContent":["import { vModelText as _vModelText, createElementVNode as _createElementVNode, withDirectives as _withDirectives, vModelCheckbox as _vModelCheckbox, createVNode as _createVNode, withCtx as _withCtx, openBlock as _openBlock, createBlock as _createBlock } from \"vue\"\n\nconst _hoisted_1 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_2 = { class: \"col col-8\" }\nconst _hoisted_3 = [\"placeholder\", \"id\"]\nconst _hoisted_4 = { class: \"col col-4 text-start\" }\nconst _hoisted_5 = [\"id\"]\nconst _hoisted_6 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_7 = { class: \"col col-8\" }\nconst _hoisted_8 = [\"placeholder\", \"id\"]\nconst _hoisted_9 = { class: \"col col-4 text-start\" }\nconst _hoisted_10 = [\"id\"]\nconst _hoisted_11 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_12 = { class: \"col col-1\" }\nconst _hoisted_13 = [\"id\"]\nconst _hoisted_14 = { class: \"col col-5\" }\nconst _hoisted_15 = [\"for\"]\nconst _hoisted_16 = { class: \"col col-1\" }\nconst _hoisted_17 = [\"id\"]\nconst _hoisted_18 = { class: \"col col-5\" }\nconst _hoisted_19 = [\"for\"]\nconst _hoisted_20 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_21 = { class: \"col col-1\" }\nconst _hoisted_22 = [\"id\"]\nconst _hoisted_23 = { class: \"col col-5\" }\nconst _hoisted_24 = [\"for\"]\nconst _hoisted_25 = { class: \"row mb-2\" }\nconst _hoisted_26 = { class: \"col col-6\" }\nconst _hoisted_27 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_28 = { class: \"col col-4\" }\nconst _hoisted_29 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_30 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_31 = { class: \"col col-4\" }\nconst _hoisted_32 = { class: \"col col-4 ms-n4\" }\nconst _hoisted_33 = { class: \"row mb-2 align-items-center\" }\nconst _hoisted_34 = { class: \"col col-4\" }\nconst _hoisted_35 = { class: \"col col-4 ms-n4\" }\n\nexport function render(_ctx: any,_cache: any,$props: any,$setup: any,$data: any,$options: any) {\n  return (_openBlock(), _createBlock($setup[\"dialogContainer\"], {\n    domId: $setup.domId,\n    commitCb: $setup.commitCb,\n    cancelCb: $setup.cancelCb,\n    label: $setup.label\n  }, {\n    default: _withCtx(() => [\n      _createElementVNode(\"div\", _hoisted_1, [\n        _createElementVNode(\"div\", _hoisted_2, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partName,\n            \"aria-label\": \"Part Name\",\n            id: $setup.getId('part-name-input'),\n            \"onUpdate:modelValue\": _cache[0] || (_cache[0] = ($event: any) => (($setup.partInfo.partName) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_3), [\n            [_vModelText, $setup.partInfo.partName]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_4, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-name-label')\n          }, \"Part Name\", 8 /* PROPS */, _hoisted_5)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_6, [\n        _createElementVNode(\"div\", _hoisted_7, [\n          _withDirectives(_createElementVNode(\"input\", {\n            type: \"text\",\n            class: \"form-control\",\n            placeholder: $setup.partInfo.partAbbreviation,\n            \"aria-label\": \"Part Abbreviation\",\n            id: $setup.getId('part-abbreviation-input'),\n            \"onUpdate:modelValue\": _cache[1] || (_cache[1] = ($event: any) => (($setup.partInfo.partAbbreviation) = $event)),\n            onChange: $setup.update\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_8), [\n            [_vModelText, $setup.partInfo.partAbbreviation]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_9, [\n          _createElementVNode(\"span\", {\n            class: \"\",\n            id: $setup.getId('part-abbreviation-label')\n          }, \"Part Abbreviation\", 8 /* PROPS */, _hoisted_10)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_11, [\n        _createElementVNode(\"div\", _hoisted_12, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[2] || (_cache[2] = ($event: any) => (($setup.partInfo.preserveTextGroups) = $event)),\n            id: $setup.getId('preserveText'),\n            onChange: _cache[3] || (_cache[3] = ($event: any) => ($setup.writeBooleanValue('preserveTextGroups', $setup.partInfo.preserveTextGroups)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_13), [\n            [_vModelCheckbox, $setup.partInfo.preserveTextGroups]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_14, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('preserveText')\n          }, \"Preserve Text Groups\", 8 /* PROPS */, _hoisted_15)\n        ]),\n        _createElementVNode(\"div\", _hoisted_16, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[4] || (_cache[4] = ($event: any) => (($setup.partInfo.expandMultimeasureRests) = $event)),\n            id: $setup.getId('expandMultimeasureRests'),\n            onChange: _cache[5] || (_cache[5] = ($event: any) => ($setup.writeBooleanValue('expandMultimeasureRests', $setup.partInfo.expandMultimeasureRests)))\n          }, null, 40 /* PROPS, NEED_HYDRATION */, _hoisted_17), [\n            [_vModelCheckbox, $setup.partInfo.expandMultimeasureRests]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_18, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('expandMultimeasureRests')\n          }, \"Expand Multimeasure Rests\", 8 /* PROPS */, _hoisted_19)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_20, [\n        _createElementVNode(\"div\", _hoisted_21, [\n          _withDirectives(_createElementVNode(\"input\", {\n            class: \"form-check-input\",\n            type: \"checkbox\",\n            \"onUpdate:modelValue\": _cache[6] || (_cache[6] = ($event: any) => (($setup.includeNext) = $event)),\n            id: $setup.getId('includeNext')\n          }, null, 8 /* PROPS */, _hoisted_22), [\n            [_vModelCheckbox, $setup.includeNext]\n          ])\n        ]),\n        _createElementVNode(\"div\", _hoisted_23, [\n          _createElementVNode(\"label\", {\n            class: \"form-check-label\",\n            for: $setup.getId('includeNext')\n          }, \"Include Next Stave\", 8 /* PROPS */, _hoisted_24)\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_25, [\n        _cache[7] || (_cache[7] = _createElementVNode(\"div\", { class: \"col col-3 text-end\" }, \"Page Size\", -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_26, [\n          _createVNode($setup[\"selectComp\"], {\n            domId: $setup.getId('page-size-select'),\n            label: '',\n            selections: $setup.pageSizes,\n            initialValue: $setup.pageSize,\n            changeCb: $setup.pageSizeCb\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\"])\n        ])\n      ]),\n      _createElementVNode(\"div\", _hoisted_27, [\n        _createElementVNode(\"div\", _hoisted_28, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-width-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageWidth,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageWidth'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[8] || (_cache[8] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Width\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_29, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('page-height-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.pageHeight,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('pageHeight'),\n            disabled: $setup.lockDimensions\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\", \"disabled\"])\n        ]),\n        _cache[9] || (_cache[9] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Page Height\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_30, [\n        _createElementVNode(\"div\", _hoisted_31, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('zoom-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.zoomScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('zoomScale'),\n            minValue: 0.25,\n            maxValue: 8\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[10] || (_cache[10] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Zoom Scale (%)\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_32, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('svg-scale-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.svgScale,\n            precision: 0,\n            percent: true,\n            changeCb: $setup.updateLayoutFunc('svgScale'),\n            minValue: 0.25,\n            maxValue: 2\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[11] || (_cache[11] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Size (%)\")\n        ], -1 /* CACHED */))\n      ]),\n      _createElementVNode(\"div\", _hoisted_33, [\n        _createElementVNode(\"div\", _hoisted_34, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('note-spacing-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.noteSpacing,\n            precision: 2,\n            changeCb: $setup.updateLayoutFunc('noteSpacing')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[12] || (_cache[12] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Note Spacing\")\n        ], -1 /* CACHED */)),\n        _createElementVNode(\"div\", _hoisted_35, [\n          _createVNode($setup[\"numberInputApp\"], {\n            domId: $setup.getId('max-measure-system-input'),\n            initialValue: $setup.partInfo.layoutManager.globalLayout.maxMeasureSystem,\n            precision: 0,\n            changeCb: $setup.updateLayoutFunc('maxMeasureSystem')\n          }, null, 8 /* PROPS */, [\"domId\", \"initialValue\", \"changeCb\"])\n        ]),\n        _cache[13] || (_cache[13] = _createElementVNode(\"div\", { class: \"col col-2 fs-7 ms-n4 ps-0 text-start\" }, [\n          _createElementVNode(\"span\", { class: \"form-check-label\" }, \"Measures/System\")\n        ], -1 /* CACHED */))\n      ])\n    ]),\n    _: 1 /* STABLE */\n  }, 8 /* PROPS */, [\"domId\", \"commitCb\", \"cancelCb\", \"label\"]))\n}","<script setup lang=\"ts\">\r\nimport { ref, Ref, watch, reactive } from 'vue';\r\nimport selectComp from './select.vue';\r\nimport numberInputApp from './numberInput.vue';\r\nimport { SelectOption } from '../../common';\r\nimport { SmoPartInfo, SmoPartInfoStringType, SmoPartInfoNumType, SmoPartInfoBooleanType } from '../../../smo/data/partInfo';\r\nimport { GlobalLayoutAttributes, SmoLayoutManager, GlobalLayoutAttributesArray } from '../../../smo/data/scoreModifiers';\r\nimport dialogContainer from './dialogContainer.vue';\r\n\r\ninterface Props {\r\n  domId: string,\r\n  label: string,\r\n  partInfo: SmoPartInfo,\r\n  updatePartInfoCb: (pi: SmoPartInfo) => Promise<void>,\r\n  commitCb: () => Promise<void>,\r\n  cancelCb: () => Promise<void>\r\n}\r\nconst props = defineProps<Props>();\r\nconst { domId, label, commitCb, cancelCb, updatePartInfoCb } = { ...props };\r\nconst partInfo = reactive(new SmoPartInfo(props.partInfo));\r\n\r\nconst writeBooleanValue = async (attr: SmoPartInfoBooleanType, value: boolean) => {\r\n  partInfo[attr] = value;\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst writeLayoutValue = async (attr: GlobalLayoutAttributes, value: number) => {\r\n    // no change?\r\n    if (partInfo.layoutManager.globalLayout[attr] === value) {\r\n      return;\r\n    }\r\n    partInfo.layoutManager.globalLayout[attr] = value;\r\n    await updatePartInfoCb(partInfo);\r\n}\r\nconst pageSizes: SelectOption[] = [\r\n  { label: 'Letter', value: 'letter' },\r\n  { label: 'Legal', value: 'legal' },\r\n  { label: 'Tabloid', value: 'tabloid' },\r\n  { label: 'A4', value: 'a4' },\r\n  { label: 'Custom', value: 'custom' }\r\n];\r\ninterface dimensions {\r\n  width: number,\r\n  height: number\r\n}\r\nconst predefinedDimensions: { [key: string]: dimensions } = {\r\n  'letter': { width: 816, height: 1056 },\r\n  'legal': { width: 816, height: 1344 },\r\n  'tabloid': { width: 1056, height: 1632 },\r\n  'a4': { width: 794, height: 1123 }\r\n};\r\n// Page size is in pixels, but if it matches a preset we just show that.\r\n// User chooses 'custom' to unlock width/height editing.\r\nconst pageSize = ref('custom');\r\n\r\nconst pageChange = () => {\r\n Object.keys(predefinedDimensions).forEach((key) => {\r\n    const dims = predefinedDimensions[key];\r\n    if (dims.width === partInfo.layoutManager.globalLayout.pageWidth &&\r\n      dims.height === partInfo.layoutManager.globalLayout.pageHeight) {\r\n      pageSize.value = key;\r\n    }\r\n  });\r\n};\r\nconst pageSizeCb = async (val: string) => {\r\n  const dims = predefinedDimensions[val];\r\n  if (dims) {\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  }\r\n  pageSize.value = val;\r\n  // The watch will trigger the callback\r\n}\r\nconst lockDimensions = ref(false);\r\npageChange();\r\nwatch (pageSize, async (newVal) => {\r\n  if (predefinedDimensions[newVal]) {\r\n    lockDimensions.value = true;\r\n    const dims = predefinedDimensions[newVal];\r\n    partInfo.layoutManager.globalLayout.pageWidth = dims.width;\r\n    partInfo.layoutManager.globalLayout.pageHeight = dims.height;\r\n  } else {\r\n    lockDimensions.value = false;\r\n  }\r\n  await updatePartInfoCb(partInfo);\r\n});\r\nif (predefinedDimensions[pageSize.value]) {\r\n  lockDimensions.value = true\r\n}\r\nconst update =async () => {\r\n  await updatePartInfoCb(partInfo);\r\n}\r\nconst includeNext = ref(false);\r\nif (partInfo.stavesAfter > 0) {\r\n  includeNext.value = true;\r\n}\r\nwatch (includeNext, async (newVal, oldVal) => {\r\n  if (newVal !== oldVal) {\r\n    partInfo.stavesAfter = newVal ? 1 : 0;\r\n    await updatePartInfoCb(partInfo);\r\n  }\r\n});\r\n\r\ntype numberWriterType = (value: number) => Promise<void>;\r\n\r\nconst updateLayoutFunc = (param: GlobalLayoutAttributes): numberWriterType => {\r\n  const cb = async (value: number) => {\r\n    await writeLayoutValue(param, value);\r\n  }\r\n  return cb;\r\n}\r\n\r\nconst getId = (str: string) => {\r\n  return `${domId}-${str}`;\r\n}\r\n\r\n</script>\r\n<template>\r\n  <dialogContainer :domId=\"domId\" :commitCb=\"commitCb\" :cancelCb=\"cancelCb\" :label=\"label\">\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partName\" aria-label=\"Part Name\"\r\n          :id=\"getId('part-name-input')\" v-model=\"partInfo.partName\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-name-label')\">Part Name</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-8\">\r\n        <input type=\"text\" class=\"form-control\" :placeholder=\"partInfo.partAbbreviation\" aria-label=\"Part Abbreviation\"\r\n          :id=\"getId('part-abbreviation-input')\" v-model=\"partInfo.partAbbreviation\" @change=\"update\">\r\n      </div>\r\n      <div class=\"col col-4 text-start\">\r\n        <span class=\"\" :id=\"getId('part-abbreviation-label')\">Part Abbreviation</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.preserveTextGroups\" :id=\"getId('preserveText')\"\r\n          @change=\"writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('preserveText')\">Preserve Text Groups</label>\r\n      </div>\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"partInfo.expandMultimeasureRests\" :id=\"getId('expandMultimeasureRests')\"\r\n          @change=\"writeBooleanValue('expandMultimeasureRests', partInfo.expandMultimeasureRests)\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('expandMultimeasureRests')\">Expand Multimeasure Rests</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-1\">\r\n        <input class=\"form-check-input\" type=\"checkbox\" v-model=\"includeNext\" :id=\"getId('includeNext')\"></input>\r\n      </div>\r\n      <div class=\"col col-5\">\r\n        <label class=\"form-check-label\" :for=\"getId('includeNext')\">Include Next Stave</label>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2\">\r\n      <div class=\"col col-3 text-end\">Page Size</div>\r\n      <div class=\"col col-6\">\r\n        <selectComp :domId=\"getId('page-size-select')\" :label=\"''\" :selections=\"pageSizes\" :initialValue=\"pageSize\"\r\n          :changeCb=\"pageSizeCb\" />\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('page-width-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageWidth\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageWidth')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Width</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('page-height-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.pageHeight\" :precision=\"0\"\r\n          :changeCb=\"updateLayoutFunc('pageHeight')\" :disabled=\"lockDimensions\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Page Height</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('zoom-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.zoomScale\" :precision=\"0\"\r\n          :percent=true :changeCb=\"updateLayoutFunc('zoomScale')\" :minValue=\"0.25\" :maxValue=\"8\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Zoom Scale (%)</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('svg-scale-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.svgScale\" :precision=\"0\"\r\n          :percent=\"true\" :changeCb=\"updateLayoutFunc('svgScale')\" :minValue=\"0.25\" :maxValue=\"2\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Size (%)</span>\r\n      </div>\r\n    </div>\r\n    <div class=\"row mb-2 align-items-center\">\r\n      <div class=\"col col-4\">\r\n        <numberInputApp :domId=\"getId('note-spacing-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.noteSpacing\" :precision=\"2\"\r\n          :changeCb=\"updateLayoutFunc('noteSpacing')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Note Spacing</span>\r\n      </div>\r\n      <div class=\"col col-4 ms-n4\">\r\n        <numberInputApp :domId=\"getId('max-measure-system-input')\" :initialValue=\"partInfo.layoutManager.globalLayout.maxMeasureSystem\"\r\n          :precision=\"0\" :changeCb=\"updateLayoutFunc('maxMeasureSystem')\" />\r\n      </div>\r\n      <div class=\"col col-2 fs-7 ms-n4 ps-0 text-start\">\r\n        <span class=\"form-check-label\">Measures/System</span>\r\n      </div>\r\n    </div>\r\n  </dialogContainer>\r\n</template>"],"names":[],"ignoreList":[],"sourceRoot":""}\n//# sourceURL=webpack-internal:///./node_modules/ts-loader/index.js??clonedRuleSet-1.use[0]!./node_modules/vue-loader/dist/templateLoader.js??ruleSet[1].rules[2]!./node_modules/vue-loader/dist/index.js??ruleSet[1].rules[6].use[0]!./src/ui/components/dialogs/partInfo.vue?vue&type=template&id=7c417a1c&ts=true\n\n}");
811
811
 
812
812
  /***/ },
813
813
 
@@ -3865,7 +3865,7 @@ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpa
3865
3865
  (__unused_webpack_module, __webpack_exports__, __webpack_require__) {
3866
3866
 
3867
3867
  "use strict";
3868
- eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SuiPartInfoDialogVue: () => (/* binding */ SuiPartInfoDialogVue)\n/* harmony export */ });\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../smo/xform/selections */ \"./src/smo/xform/selections.ts\");\n/* harmony import */ var _dialog__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dialog */ \"./src/ui/dialogs/dialog.ts\");\n/* harmony import */ var _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../ui/components/dialogs/partInfo.vue */ \"./src/ui/components/dialogs/partInfo.vue\");\n/* harmony import */ var _common__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common */ \"./src/ui/common.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\nconst SuiPartInfoDialogVue = (parameters) => __awaiter(void 0, void 0, void 0, function* () {\n const selector = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelector.default;\n const selection = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelection.measureSelection(parameters.view.score, selector.staff, selector.measure);\n const backup = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(selection.staff.partInfo);\n let current = backup;\n let changed = false;\n const updatePartInfoCb = (partInfo) => __awaiter(void 0, void 0, void 0, function* () {\n changed = true;\n // Since update will change the displayed score, wait for any display change to complete first.\n yield parameters.view.renderer.updatePromise();\n yield parameters.view.updatePartInfo(partInfo);\n // If we are expanding rests, we need to reload the part after setting the \n // part change. So we update the part display a second time with the new value.\n if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests) {\n parameters.view.resetPartView();\n yield parameters.view.refreshViewport();\n }\n current = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(partInfo);\n });\n const commitCb = () => __awaiter(void 0, void 0, void 0, function* () {\n });\n const cancelCb = () => __awaiter(void 0, void 0, void 0, function* () {\n if (changed) {\n yield parameters.view.renderer.updatePromise();\n if (current.expandMultimeasureRests !== backup.expandMultimeasureRests) {\n parameters.view.resetPartView();\n }\n yield parameters.view.updatePartInfo(backup);\n }\n });\n const rootId = (0,_common__WEBPACK_IMPORTED_MODULE_4__.replaceVueRoot)(_common__WEBPACK_IMPORTED_MODULE_4__.modalContainerId);\n const appParams = {\n domId: rootId,\n partInfo: current,\n label: 'Part Properties',\n updatePartInfoCb\n };\n (0,_dialog__WEBPACK_IMPORTED_MODULE_2__.InstallDialog)({\n app: _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n appParams,\n root: rootId,\n dialogParams: parameters,\n commitCb,\n cancelCb\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvZGlhbG9ncy9wYXJ0SW5mby50cyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHc0Q7QUFDaUI7QUFFYjtBQUNTO0FBQ047QUFHdEQsTUFBTSxvQkFBb0IsR0FBRyxDQUFPLFVBQTJCLEVBQUUsRUFBRTtJQUN4RSxNQUFNLFFBQVEsR0FBRyw4REFBVyxDQUFDLE9BQU8sQ0FBQztJQUNyQyxNQUFNLFNBQVMsR0FBRywrREFBWSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBRSxDQUFDO0lBQzFHLE1BQU0sTUFBTSxHQUFHLElBQUksMkRBQVcsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pELElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUNyQixJQUFJLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDcEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFPLFFBQXFCLEVBQUUsRUFBRTtRQUN2RCxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ2YsK0ZBQStGO1FBQy9GLE1BQU0sVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFL0MsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQywyRUFBMkU7UUFDM0UsZ0ZBQWdGO1FBQ2hGLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLFFBQVEsQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO1lBQ3pFLFVBQVUsQ0FBQyxJQUFJLENBQUMsYUFBYSxFQUFFLENBQUM7WUFDaEMsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGVBQWUsRUFBRSxDQUFDO1FBQzFDLENBQUM7UUFDRCxPQUFPLEdBQUcsSUFBSSwyREFBVyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3RDLENBQUM7SUFFRCxNQUFNLFFBQVEsR0FBRyxHQUFTLEVBQUU7SUFDNUIsQ0FBQztJQUNELE1BQU0sUUFBUSxHQUFHLEdBQVMsRUFBRTtRQUMxQixJQUFJLE9BQU8sRUFBRSxDQUFDO1lBQ1osTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLFFBQVEsQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUMvQyxJQUFJLE9BQU8sQ0FBQyx1QkFBdUIsS0FBSyxNQUFNLENBQUMsdUJBQXVCLEVBQUUsQ0FBQztnQkFDdkUsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNsQyxDQUFDO1lBQ0QsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxNQUFNLENBQUMsQ0FBQztRQUMvQyxDQUFDO0lBQ0gsQ0FBQztJQUNELE1BQU0sTUFBTSxHQUFHLHVEQUFjLENBQUMscURBQWdCLENBQUMsQ0FBQztJQUNoRCxNQUFNLFNBQVMsR0FBRztRQUNoQixLQUFLLEVBQUUsTUFBTTtRQUNiLFFBQVEsRUFBRSxPQUFPO1FBQ2pCLEtBQUssRUFBRSxpQkFBaUI7UUFDeEIsZ0JBQWdCO0tBQ2pCLENBQUM7SUFDRixzREFBYSxDQUFDO1FBQ1osR0FBRyxFQUFFLDJFQUFXO1FBQ2hCLFNBQVM7UUFDVCxJQUFJLEVBQUUsTUFBTTtRQUNaLFlBQVksRUFBRSxVQUFVO1FBQ3hCLFFBQVE7UUFDUixRQUFRO0tBQ1QsQ0FBQyxDQUFDO0FBQ0wsQ0FBQyIsInNvdXJjZXMiOlsid2VicGFjazovL1Ntby8uL3NyYy91aS9kaWFsb2dzL3BhcnRJbmZvLnRzPzFiMzAiXSwic291cmNlc0NvbnRlbnQiOlsiLy8gW1Ntb29zaWNdKGh0dHBzOi8vZ2l0aHViLmNvbS9BYXJvbkRhdmlkTmV3bWFuL1Ntb29zaWMpXHJcbi8vIENvcHlyaWdodCAoYykgQWFyb24gRGF2aWQgTmV3bWFuIDIwMjEuXHJcbmltcG9ydCB7IFNtb1Njb3JlIH0gZnJvbSAnLi4vLi4vc21vL2RhdGEvc2NvcmUnO1xyXG5pbXBvcnQgeyBTbW9QYXJ0SW5mbyB9IGZyb20gJy4uLy4uL3Ntby9kYXRhL3BhcnRJbmZvJztcclxuaW1wb3J0IHsgU21vU2VsZWN0aW9uLCBTbW9TZWxlY3RvciB9IGZyb20gJy4uLy4uL3Ntby94Zm9ybS9zZWxlY3Rpb25zJztcclxuXHJcbmltcG9ydCB7IFN1aURpYWxvZ1BhcmFtcywgSW5zdGFsbERpYWxvZyB9IGZyb20gJy4vZGlhbG9nJztcclxuaW1wb3J0IHBhcnRJbmZvQXBwIGZyb20gJy4uLy4uL3VpL2NvbXBvbmVudHMvZGlhbG9ncy9wYXJ0SW5mby52dWUnO1xyXG5pbXBvcnQgeyByZXBsYWNlVnVlUm9vdCwgbW9kYWxDb250YWluZXJJZCB9IGZyb20gJy4uL2NvbW1vbic7XHJcblxyXG5kZWNsYXJlIHZhciAkOiBhbnk7XHJcbmV4cG9ydCBjb25zdCBTdWlQYXJ0SW5mb0RpYWxvZ1Z1ZSA9IGFzeW5jIChwYXJhbWV0ZXJzOiBTdWlEaWFsb2dQYXJhbXMpID0+IHtcclxuICBjb25zdCBzZWxlY3RvciA9IFNtb1NlbGVjdG9yLmRlZmF1bHQ7XHJcbiAgY29uc3Qgc2VsZWN0aW9uID0gU21vU2VsZWN0aW9uLm1lYXN1cmVTZWxlY3Rpb24ocGFyYW1ldGVycy52aWV3LnNjb3JlLCBzZWxlY3Rvci5zdGFmZiwgc2VsZWN0b3IubWVhc3VyZSkhO1xyXG4gIGNvbnN0IGJhY2t1cCA9IG5ldyBTbW9QYXJ0SW5mbyhzZWxlY3Rpb24uc3RhZmYucGFydEluZm8pO1xyXG4gIGxldCBjdXJyZW50ID0gYmFja3VwO1xyXG4gIGxldCBjaGFuZ2VkID0gZmFsc2U7XHJcbiAgY29uc3QgdXBkYXRlUGFydEluZm9DYiA9IGFzeW5jIChwYXJ0SW5mbzogU21vUGFydEluZm8pID0+IHtcclxuICAgIGNoYW5nZWQgPSB0cnVlO1xyXG4gICAgLy8gU2luY2UgdXBkYXRlIHdpbGwgY2hhbmdlIHRoZSBkaXNwbGF5ZWQgc2NvcmUsIHdhaXQgZm9yIGFueSBkaXNwbGF5IGNoYW5nZSB0byBjb21wbGV0ZSBmaXJzdC5cclxuICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy5yZW5kZXJlci51cGRhdGVQcm9taXNlKCk7XHJcbiAgICBcclxuICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy51cGRhdGVQYXJ0SW5mbyhwYXJ0SW5mbyk7XHJcbiAgICAvLyBJZiB3ZSBhcmUgZXhwYW5kaW5nIHJlc3RzLCB3ZSBuZWVkIHRvIHJlbG9hZCB0aGUgcGFydCBhZnRlciBzZXR0aW5nIHRoZSBcclxuICAgIC8vIHBhcnQgY2hhbmdlLiAgU28gd2UgdXBkYXRlIHRoZSBwYXJ0IGRpc3BsYXkgYSBzZWNvbmQgdGltZSB3aXRoIHRoZSBuZXcgdmFsdWUuXHJcbiAgICBpZiAoY3VycmVudC5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyAhPT0gcGFydEluZm8uZXhwYW5kTXVsdGltZWFzdXJlUmVzdHMpIHtcclxuICAgICAgcGFyYW1ldGVycy52aWV3LnJlc2V0UGFydFZpZXcoKTtcclxuICAgICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnJlZnJlc2hWaWV3cG9ydCgpO1xyXG4gICAgfVxyXG4gICAgY3VycmVudCA9IG5ldyBTbW9QYXJ0SW5mbyhwYXJ0SW5mbyk7XHJcbiAgfVxyXG5cclxuICBjb25zdCBjb21taXRDYiA9IGFzeW5jICgpID0+IHtcclxuICB9XHJcbiAgY29uc3QgY2FuY2VsQ2IgPSBhc3luYyAoKSA9PiB7XHJcbiAgICBpZiAoY2hhbmdlZCkge1xyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcucmVuZGVyZXIudXBkYXRlUHJvbWlzZSgpO1xyXG4gICAgICBpZiAoY3VycmVudC5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyAhPT0gYmFja3VwLmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzKSB7XHJcbiAgICAgICAgcGFyYW1ldGVycy52aWV3LnJlc2V0UGFydFZpZXcoKTtcclxuICAgICAgfVxyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcudXBkYXRlUGFydEluZm8oYmFja3VwKTtcclxuICAgIH1cclxuICB9XHJcbiAgY29uc3Qgcm9vdElkID0gcmVwbGFjZVZ1ZVJvb3QobW9kYWxDb250YWluZXJJZCk7XHJcbiAgY29uc3QgYXBwUGFyYW1zID0ge1xyXG4gICAgZG9tSWQ6IHJvb3RJZCxcclxuICAgIHBhcnRJbmZvOiBjdXJyZW50LFxyXG4gICAgbGFiZWw6ICdQYXJ0IFByb3BlcnRpZXMnLFxyXG4gICAgdXBkYXRlUGFydEluZm9DYlxyXG4gIH07XHJcbiAgSW5zdGFsbERpYWxvZyh7XHJcbiAgICBhcHA6IHBhcnRJbmZvQXBwLFxyXG4gICAgYXBwUGFyYW1zLFxyXG4gICAgcm9vdDogcm9vdElkLFxyXG4gICAgZGlhbG9nUGFyYW1zOiBwYXJhbWV0ZXJzLFxyXG4gICAgY29tbWl0Q2IsIFxyXG4gICAgY2FuY2VsQ2JcclxuICB9KTtcclxufVxyXG4iXSwibmFtZXMiOltdLCJpZ25vcmVMaXN0IjpbXSwic291cmNlUm9vdCI6IiJ9\n//# sourceURL=webpack-internal:///./src/ui/dialogs/partInfo.ts\n\n}");
3868
+ eval("{__webpack_require__.r(__webpack_exports__);\n/* harmony export */ __webpack_require__.d(__webpack_exports__, {\n/* harmony export */ SuiPartInfoDialogVue: () => (/* binding */ SuiPartInfoDialogVue)\n/* harmony export */ });\n/* harmony import */ var _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__ = __webpack_require__(/*! ../../smo/data/partInfo */ \"./src/smo/data/partInfo.ts\");\n/* harmony import */ var _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__ = __webpack_require__(/*! ../../smo/xform/selections */ \"./src/smo/xform/selections.ts\");\n/* harmony import */ var _dialog__WEBPACK_IMPORTED_MODULE_2__ = __webpack_require__(/*! ./dialog */ \"./src/ui/dialogs/dialog.ts\");\n/* harmony import */ var _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__ = __webpack_require__(/*! ../../ui/components/dialogs/partInfo.vue */ \"./src/ui/components/dialogs/partInfo.vue\");\n/* harmony import */ var _common__WEBPACK_IMPORTED_MODULE_4__ = __webpack_require__(/*! ../common */ \"./src/ui/common.ts\");\nvar __awaiter = (undefined && undefined.__awaiter) || function (thisArg, _arguments, P, generator) {\n function adopt(value) { return value instanceof P ? value : new P(function (resolve) { resolve(value); }); }\n return new (P || (P = Promise))(function (resolve, reject) {\n function fulfilled(value) { try { step(generator.next(value)); } catch (e) { reject(e); } }\n function rejected(value) { try { step(generator[\"throw\"](value)); } catch (e) { reject(e); } }\n function step(result) { result.done ? resolve(result.value) : adopt(result.value).then(fulfilled, rejected); }\n step((generator = generator.apply(thisArg, _arguments || [])).next());\n });\n};\n\n\n\n\n\nconst SuiPartInfoDialogVue = (parameters) => __awaiter(void 0, void 0, void 0, function* () {\n const selector = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelector.default;\n const selection = _smo_xform_selections__WEBPACK_IMPORTED_MODULE_1__.SmoSelection.measureSelection(parameters.view.score, selector.staff, selector.measure);\n const backup = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(selection.staff.partInfo);\n let current = backup;\n let changed = false;\n const updatePartInfoCb = (partInfo) => __awaiter(void 0, void 0, void 0, function* () {\n changed = true;\n // Since update will change the displayed score, wait for any display change to complete first.\n yield parameters.view.renderer.updatePromise();\n yield parameters.view.updatePartInfo(partInfo);\n // If we are expanding rests, we need to reload the part after setting the \n // part change. So we update the part display a second time with the new value.\n if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests ||\n current.stavesAfter !== partInfo.stavesAfter) {\n parameters.view.resetPartView();\n yield parameters.view.refreshViewport();\n }\n current = new _smo_data_partInfo__WEBPACK_IMPORTED_MODULE_0__.SmoPartInfo(partInfo);\n });\n const commitCb = () => __awaiter(void 0, void 0, void 0, function* () {\n });\n const cancelCb = () => __awaiter(void 0, void 0, void 0, function* () {\n if (changed) {\n yield parameters.view.renderer.updatePromise();\n if (current.expandMultimeasureRests !== backup.expandMultimeasureRests) {\n parameters.view.resetPartView();\n }\n yield parameters.view.updatePartInfo(backup);\n }\n });\n const rootId = (0,_common__WEBPACK_IMPORTED_MODULE_4__.replaceVueRoot)(_common__WEBPACK_IMPORTED_MODULE_4__.modalContainerId);\n const appParams = {\n domId: rootId,\n partInfo: current,\n label: 'Part Properties',\n updatePartInfoCb\n };\n (0,_dialog__WEBPACK_IMPORTED_MODULE_2__.InstallDialog)({\n app: _ui_components_dialogs_partInfo_vue__WEBPACK_IMPORTED_MODULE_3__[\"default\"],\n appParams,\n root: rootId,\n dialogParams: parameters,\n commitCb,\n cancelCb\n });\n});\n//# sourceURL=[module]\n//# sourceMappingURL=data:application/json;charset=utf-8;base64,eyJ2ZXJzaW9uIjozLCJmaWxlIjoiLi9zcmMvdWkvZGlhbG9ncy9wYXJ0SW5mby50cyIsIm1hcHBpbmdzIjoiOzs7Ozs7Ozs7Ozs7Ozs7Ozs7QUFHc0Q7QUFDaUI7QUFFYjtBQUNTO0FBQ047QUFHdEQsTUFBTSxvQkFBb0IsR0FBRyxDQUFPLFVBQTJCLEVBQUUsRUFBRTtJQUN4RSxNQUFNLFFBQVEsR0FBRyw4REFBVyxDQUFDLE9BQU8sQ0FBQztJQUNyQyxNQUFNLFNBQVMsR0FBRywrREFBWSxDQUFDLGdCQUFnQixDQUFDLFVBQVUsQ0FBQyxJQUFJLENBQUMsS0FBSyxFQUFFLFFBQVEsQ0FBQyxLQUFLLEVBQUUsUUFBUSxDQUFDLE9BQU8sQ0FBRSxDQUFDO0lBQzFHLE1BQU0sTUFBTSxHQUFHLElBQUksMkRBQVcsQ0FBQyxTQUFTLENBQUMsS0FBSyxDQUFDLFFBQVEsQ0FBQyxDQUFDO0lBQ3pELElBQUksT0FBTyxHQUFHLE1BQU0sQ0FBQztJQUNyQixJQUFJLE9BQU8sR0FBRyxLQUFLLENBQUM7SUFDcEIsTUFBTSxnQkFBZ0IsR0FBRyxDQUFPLFFBQXFCLEVBQUUsRUFBRTtRQUN2RCxPQUFPLEdBQUcsSUFBSSxDQUFDO1FBQ2YsK0ZBQStGO1FBQy9GLE1BQU0sVUFBVSxDQUFDLElBQUksQ0FBQyxRQUFRLENBQUMsYUFBYSxFQUFFLENBQUM7UUFFL0MsTUFBTSxVQUFVLENBQUMsSUFBSSxDQUFDLGNBQWMsQ0FBQyxRQUFRLENBQUMsQ0FBQztRQUMvQywyRUFBMkU7UUFDM0UsZ0ZBQWdGO1FBQ2hGLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLFFBQVEsQ0FBQyx1QkFBdUI7WUFDdEUsT0FBTyxDQUFDLFdBQVcsS0FBSyxRQUFRLENBQUMsV0FBVyxFQUFFLENBQUM7WUFDL0MsVUFBVSxDQUFDLElBQUksQ0FBQyxhQUFhLEVBQUUsQ0FBQztZQUNoQyxNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsZUFBZSxFQUFFLENBQUM7UUFDMUMsQ0FBQztRQUNELE9BQU8sR0FBRyxJQUFJLDJEQUFXLENBQUMsUUFBUSxDQUFDLENBQUM7SUFDdEMsQ0FBQztJQUVELE1BQU0sUUFBUSxHQUFHLEdBQVMsRUFBRTtJQUM1QixDQUFDO0lBQ0QsTUFBTSxRQUFRLEdBQUcsR0FBUyxFQUFFO1FBQzFCLElBQUksT0FBTyxFQUFFLENBQUM7WUFDWixNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsUUFBUSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQy9DLElBQUksT0FBTyxDQUFDLHVCQUF1QixLQUFLLE1BQU0sQ0FBQyx1QkFBdUIsRUFBRSxDQUFDO2dCQUN2RSxVQUFVLENBQUMsSUFBSSxDQUFDLGFBQWEsRUFBRSxDQUFDO1lBQ2xDLENBQUM7WUFDRCxNQUFNLFVBQVUsQ0FBQyxJQUFJLENBQUMsY0FBYyxDQUFDLE1BQU0sQ0FBQyxDQUFDO1FBQy9DLENBQUM7SUFDSCxDQUFDO0lBQ0QsTUFBTSxNQUFNLEdBQUcsdURBQWMsQ0FBQyxxREFBZ0IsQ0FBQyxDQUFDO0lBQ2hELE1BQU0sU0FBUyxHQUFHO1FBQ2hCLEtBQUssRUFBRSxNQUFNO1FBQ2IsUUFBUSxFQUFFLE9BQU87UUFDakIsS0FBSyxFQUFFLGlCQUFpQjtRQUN4QixnQkFBZ0I7S0FDakIsQ0FBQztJQUNGLHNEQUFhLENBQUM7UUFDWixHQUFHLEVBQUUsMkVBQVc7UUFDaEIsU0FBUztRQUNULElBQUksRUFBRSxNQUFNO1FBQ1osWUFBWSxFQUFFLFVBQVU7UUFDeEIsUUFBUTtRQUNSLFFBQVE7S0FDVCxDQUFDLENBQUM7QUFDTCxDQUFDIiwic291cmNlcyI6WyJ3ZWJwYWNrOi8vU21vLy4vc3JjL3VpL2RpYWxvZ3MvcGFydEluZm8udHM/MWIzMCJdLCJzb3VyY2VzQ29udGVudCI6WyIvLyBbU21vb3NpY10oaHR0cHM6Ly9naXRodWIuY29tL0Fhcm9uRGF2aWROZXdtYW4vU21vb3NpYylcclxuLy8gQ29weXJpZ2h0IChjKSBBYXJvbiBEYXZpZCBOZXdtYW4gMjAyMS5cclxuaW1wb3J0IHsgU21vU2NvcmUgfSBmcm9tICcuLi8uLi9zbW8vZGF0YS9zY29yZSc7XHJcbmltcG9ydCB7IFNtb1BhcnRJbmZvIH0gZnJvbSAnLi4vLi4vc21vL2RhdGEvcGFydEluZm8nO1xyXG5pbXBvcnQgeyBTbW9TZWxlY3Rpb24sIFNtb1NlbGVjdG9yIH0gZnJvbSAnLi4vLi4vc21vL3hmb3JtL3NlbGVjdGlvbnMnO1xyXG5cclxuaW1wb3J0IHsgU3VpRGlhbG9nUGFyYW1zLCBJbnN0YWxsRGlhbG9nIH0gZnJvbSAnLi9kaWFsb2cnO1xyXG5pbXBvcnQgcGFydEluZm9BcHAgZnJvbSAnLi4vLi4vdWkvY29tcG9uZW50cy9kaWFsb2dzL3BhcnRJbmZvLnZ1ZSc7XHJcbmltcG9ydCB7IHJlcGxhY2VWdWVSb290LCBtb2RhbENvbnRhaW5lcklkIH0gZnJvbSAnLi4vY29tbW9uJztcclxuXHJcbmRlY2xhcmUgdmFyICQ6IGFueTtcclxuZXhwb3J0IGNvbnN0IFN1aVBhcnRJbmZvRGlhbG9nVnVlID0gYXN5bmMgKHBhcmFtZXRlcnM6IFN1aURpYWxvZ1BhcmFtcykgPT4ge1xyXG4gIGNvbnN0IHNlbGVjdG9yID0gU21vU2VsZWN0b3IuZGVmYXVsdDtcclxuICBjb25zdCBzZWxlY3Rpb24gPSBTbW9TZWxlY3Rpb24ubWVhc3VyZVNlbGVjdGlvbihwYXJhbWV0ZXJzLnZpZXcuc2NvcmUsIHNlbGVjdG9yLnN0YWZmLCBzZWxlY3Rvci5tZWFzdXJlKSE7XHJcbiAgY29uc3QgYmFja3VwID0gbmV3IFNtb1BhcnRJbmZvKHNlbGVjdGlvbi5zdGFmZi5wYXJ0SW5mbyk7XHJcbiAgbGV0IGN1cnJlbnQgPSBiYWNrdXA7XHJcbiAgbGV0IGNoYW5nZWQgPSBmYWxzZTtcclxuICBjb25zdCB1cGRhdGVQYXJ0SW5mb0NiID0gYXN5bmMgKHBhcnRJbmZvOiBTbW9QYXJ0SW5mbykgPT4ge1xyXG4gICAgY2hhbmdlZCA9IHRydWU7XHJcbiAgICAvLyBTaW5jZSB1cGRhdGUgd2lsbCBjaGFuZ2UgdGhlIGRpc3BsYXllZCBzY29yZSwgd2FpdCBmb3IgYW55IGRpc3BsYXkgY2hhbmdlIHRvIGNvbXBsZXRlIGZpcnN0LlxyXG4gICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnJlbmRlcmVyLnVwZGF0ZVByb21pc2UoKTtcclxuICAgIFxyXG4gICAgYXdhaXQgcGFyYW1ldGVycy52aWV3LnVwZGF0ZVBhcnRJbmZvKHBhcnRJbmZvKTtcclxuICAgIC8vIElmIHdlIGFyZSBleHBhbmRpbmcgcmVzdHMsIHdlIG5lZWQgdG8gcmVsb2FkIHRoZSBwYXJ0IGFmdGVyIHNldHRpbmcgdGhlIFxyXG4gICAgLy8gcGFydCBjaGFuZ2UuICBTbyB3ZSB1cGRhdGUgdGhlIHBhcnQgZGlzcGxheSBhIHNlY29uZCB0aW1lIHdpdGggdGhlIG5ldyB2YWx1ZS5cclxuICAgIGlmIChjdXJyZW50LmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzICE9PSBwYXJ0SW5mby5leHBhbmRNdWx0aW1lYXN1cmVSZXN0cyB8fFxyXG4gICAgICBjdXJyZW50LnN0YXZlc0FmdGVyICE9PSBwYXJ0SW5mby5zdGF2ZXNBZnRlcikge1xyXG4gICAgICBwYXJhbWV0ZXJzLnZpZXcucmVzZXRQYXJ0VmlldygpO1xyXG4gICAgICBhd2FpdCBwYXJhbWV0ZXJzLnZpZXcucmVmcmVzaFZpZXdwb3J0KCk7XHJcbiAgICB9XHJcbiAgICBjdXJyZW50ID0gbmV3IFNtb1BhcnRJbmZvKHBhcnRJbmZvKTtcclxuICB9XHJcblxyXG4gIGNvbnN0IGNvbW1pdENiID0gYXN5bmMgKCkgPT4ge1xyXG4gIH1cclxuICBjb25zdCBjYW5jZWxDYiA9IGFzeW5jICgpID0+IHtcclxuICAgIGlmIChjaGFuZ2VkKSB7XHJcbiAgICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy5yZW5kZXJlci51cGRhdGVQcm9taXNlKCk7XHJcbiAgICAgIGlmIChjdXJyZW50LmV4cGFuZE11bHRpbWVhc3VyZVJlc3RzICE9PSBiYWNrdXAuZXhwYW5kTXVsdGltZWFzdXJlUmVzdHMpIHtcclxuICAgICAgICBwYXJhbWV0ZXJzLnZpZXcucmVzZXRQYXJ0VmlldygpO1xyXG4gICAgICB9XHJcbiAgICAgIGF3YWl0IHBhcmFtZXRlcnMudmlldy51cGRhdGVQYXJ0SW5mbyhiYWNrdXApO1xyXG4gICAgfVxyXG4gIH1cclxuICBjb25zdCByb290SWQgPSByZXBsYWNlVnVlUm9vdChtb2RhbENvbnRhaW5lcklkKTtcclxuICBjb25zdCBhcHBQYXJhbXMgPSB7XHJcbiAgICBkb21JZDogcm9vdElkLFxyXG4gICAgcGFydEluZm86IGN1cnJlbnQsXHJcbiAgICBsYWJlbDogJ1BhcnQgUHJvcGVydGllcycsXHJcbiAgICB1cGRhdGVQYXJ0SW5mb0NiXHJcbiAgfTtcclxuICBJbnN0YWxsRGlhbG9nKHtcclxuICAgIGFwcDogcGFydEluZm9BcHAsXHJcbiAgICBhcHBQYXJhbXMsXHJcbiAgICByb290OiByb290SWQsXHJcbiAgICBkaWFsb2dQYXJhbXM6IHBhcmFtZXRlcnMsXHJcbiAgICBjb21taXRDYiwgXHJcbiAgICBjYW5jZWxDYlxyXG4gIH0pO1xyXG59XHJcbiJdLCJuYW1lcyI6W10sImlnbm9yZUxpc3QiOltdLCJzb3VyY2VSb290IjoiIn0=\n//# sourceURL=webpack-internal:///./src/ui/dialogs/partInfo.ts\n\n}");
3869
3869
 
3870
3870
  /***/ },
3871
3871
 
@@ -278,9 +278,8 @@ body.printing .media div.d-flex
278
278
 
279
279
  }
280
280
 
281
- body.printing .workspace-container {
282
- display:none;
283
- }
281
+ body.printing .workspace-container,
282
+ body.printing #top-bar ,
284
283
  body.printing .controls-left,
285
284
  body.printing .control-bar
286
285
  {
@@ -51,6 +51,7 @@ const predefinedDimensions: { [key: string]: dimensions } = {
51
51
  // Page size is in pixels, but if it matches a preset we just show that.
52
52
  // User chooses 'custom' to unlock width/height editing.
53
53
  const pageSize = ref('custom');
54
+
54
55
  const pageChange = () => {
55
56
  Object.keys(predefinedDimensions).forEach((key) => {
56
57
  const dims = predefinedDimensions[key];
@@ -60,6 +61,15 @@ const pageChange = () => {
60
61
  }
61
62
  });
62
63
  };
64
+ const pageSizeCb = async (val: string) => {
65
+ const dims = predefinedDimensions[val];
66
+ if (dims) {
67
+ partInfo.layoutManager.globalLayout.pageWidth = dims.width;
68
+ partInfo.layoutManager.globalLayout.pageHeight = dims.height;
69
+ }
70
+ pageSize.value = val;
71
+ // The watch will trigger the callback
72
+ }
63
73
  const lockDimensions = ref(false);
64
74
  pageChange();
65
75
  watch (pageSize, async (newVal) => {
@@ -142,18 +152,17 @@ const getId = (str: string) => {
142
152
  </div>
143
153
  <div class="row mb-2 align-items-center">
144
154
  <div class="col col-1">
145
- <input class="form-check-input" type="checkbox" v-model="partInfo.preserveTextGroups" :id="getId('preserveText')"
146
- @change="writeBooleanValue('preserveTextGroups', partInfo.preserveTextGroups)"></input>
155
+ <input class="form-check-input" type="checkbox" v-model="includeNext" :id="getId('includeNext')"></input>
147
156
  </div>
148
157
  <div class="col col-5">
149
- <label class="form-check-label" :for="getId('preserveText')">Include Next Stave</label>
158
+ <label class="form-check-label" :for="getId('includeNext')">Include Next Stave</label>
150
159
  </div>
151
160
  </div>
152
161
  <div class="row mb-2">
153
162
  <div class="col col-3 text-end">Page Size</div>
154
163
  <div class="col col-6">
155
164
  <selectComp :domId="getId('page-size-select')" :label="''" :selections="pageSizes" :initialValue="pageSize"
156
- :changeCb="pageChange" />
165
+ :changeCb="pageSizeCb" />
157
166
  </div>
158
167
  </div>
159
168
  <div class="row mb-2 align-items-center">
@@ -23,7 +23,8 @@ export const SuiPartInfoDialogVue = async (parameters: SuiDialogParams) => {
23
23
  await parameters.view.updatePartInfo(partInfo);
24
24
  // If we are expanding rests, we need to reload the part after setting the
25
25
  // part change. So we update the part display a second time with the new value.
26
- if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests) {
26
+ if (current.expandMultimeasureRests !== partInfo.expandMultimeasureRests ||
27
+ current.stavesAfter !== partInfo.stavesAfter) {
27
28
  parameters.view.resetPartView();
28
29
  await parameters.view.refreshViewport();
29
30
  }