Платформа ЦРНП "Мирокод" для разработки проектов
https://git.mirocod.ru
You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
49 lines
1.1 KiB
49 lines
1.1 KiB
import Vue from 'vue'; |
|
import {svgs} from '../svg.js'; |
|
|
|
export const vueDelimiters = ['${', '}']; |
|
|
|
let vueEnvInited = false; |
|
export function initVueEnv() { |
|
if (vueEnvInited) return; |
|
vueEnvInited = true; |
|
|
|
const isProd = window.config.runModeIsProd; |
|
Vue.config.productionTip = false; |
|
Vue.config.devtools = !isProd; |
|
} |
|
|
|
let vueSvgInited = false; |
|
export function initVueSvg() { |
|
if (vueSvgInited) return; |
|
vueSvgInited = true; |
|
|
|
// register svg icon vue components, e.g. <octicon-repo size="16"/> |
|
for (const [name, htmlString] of Object.entries(svgs)) { |
|
const template = htmlString |
|
.replace(/height="[0-9]+"/, 'v-bind:height="size"') |
|
.replace(/width="[0-9]+"/, 'v-bind:width="size"'); |
|
|
|
Vue.component(name, { |
|
props: { |
|
size: { |
|
type: String, |
|
default: '16', |
|
}, |
|
}, |
|
template, |
|
}); |
|
} |
|
} |
|
|
|
export function initVueApp(el, opts = {}) { |
|
if (typeof el === 'string') { |
|
el = document.querySelector(el); |
|
} |
|
if (!el) return null; |
|
|
|
return new Vue(Object.assign({ |
|
el, |
|
delimiters: vueDelimiters, |
|
}, opts)); |
|
}
|
|
|