439 lines
16 KiB
JavaScript
439 lines
16 KiB
JavaScript
|
"use strict";
|
|||
|
var __importDefault = (this && this.__importDefault) || function (mod) {
|
|||
|
return (mod && mod.__esModule) ? mod : { "default": mod };
|
|||
|
};
|
|||
|
Object.defineProperty(exports, "__esModule", { value: true });
|
|||
|
exports.parseSubpackagesRootOnce = exports.normalizePagesRoute = exports.removePlatformStyle = exports.validatePages = exports.normalizePagesJson = exports.parsePagesJsonOnce = exports.parsePagesJson = exports.isUniPageSfcFile = exports.isUniPageSetupAndTs = exports.isUniPageFile = void 0;
|
|||
|
const fs_1 = __importDefault(require("fs"));
|
|||
|
const path_1 = __importDefault(require("path"));
|
|||
|
const shared_1 = require("@vue/shared");
|
|||
|
const uni_shared_1 = require("@dcloudio/uni-shared");
|
|||
|
const utils_1 = require("../utils");
|
|||
|
const json_1 = require("./json");
|
|||
|
const utils_2 = require("../vue/utils");
|
|||
|
const vite_1 = require("../vite");
|
|||
|
const constants_1 = require("../constants");
|
|||
|
const theme_1 = require("./theme");
|
|||
|
const manifest_1 = require("./manifest");
|
|||
|
const pagesCacheSet = new Set();
|
|||
|
function isUniPageFile(file, inputDir = process.env.UNI_INPUT_DIR) {
|
|||
|
if (inputDir && path_1.default.isAbsolute(file)) {
|
|||
|
file = (0, utils_1.normalizePath)(path_1.default.relative(inputDir, file));
|
|||
|
}
|
|||
|
return pagesCacheSet.has((0, utils_1.removeExt)(file));
|
|||
|
}
|
|||
|
exports.isUniPageFile = isUniPageFile;
|
|||
|
function isUniPageSetupAndTs(file) {
|
|||
|
const { filename, query } = (0, vite_1.parseVueRequest)(file);
|
|||
|
return !!(query.vue &&
|
|||
|
query.setup &&
|
|||
|
(0, shared_1.hasOwn)(query, 'lang.ts') &&
|
|||
|
constants_1.EXTNAME_VUE_RE.test(filename));
|
|||
|
}
|
|||
|
exports.isUniPageSetupAndTs = isUniPageSetupAndTs;
|
|||
|
function isUniPageSfcFile(file, inputDir = process.env.UNI_INPUT_DIR) {
|
|||
|
return (0, utils_2.isVueSfcFile)(file) && isUniPageFile(file, inputDir);
|
|||
|
}
|
|||
|
exports.isUniPageSfcFile = isUniPageSfcFile;
|
|||
|
/**
|
|||
|
* 小程序平台慎用,因为该解析不支持 subpackages
|
|||
|
* @param inputDir
|
|||
|
* @param platform
|
|||
|
* @param normalize
|
|||
|
* @returns
|
|||
|
*/
|
|||
|
const parsePagesJson = (inputDir, platform, normalize = true) => {
|
|||
|
const jsonStr = fs_1.default.readFileSync(path_1.default.join(inputDir, 'pages.json'), 'utf8');
|
|||
|
if (normalize) {
|
|||
|
return normalizePagesJson(jsonStr, platform);
|
|||
|
}
|
|||
|
return (0, json_1.parseJson)(jsonStr, true);
|
|||
|
};
|
|||
|
exports.parsePagesJson = parsePagesJson;
|
|||
|
/**
|
|||
|
* 该方法解析出来的是不支持 subpackages,会被合并入 pages
|
|||
|
*/
|
|||
|
exports.parsePagesJsonOnce = (0, uni_shared_1.once)(exports.parsePagesJson);
|
|||
|
/**
|
|||
|
* 目前 App 和 H5 使用了该方法
|
|||
|
* @param jsonStr
|
|||
|
* @param platform
|
|||
|
* @param param2
|
|||
|
* @returns
|
|||
|
*/
|
|||
|
function normalizePagesJson(jsonStr, platform, { subpackages, } = { subpackages: false }) {
|
|||
|
let pagesJson = {
|
|||
|
pages: [],
|
|||
|
globalStyle: {
|
|||
|
navigationBar: {},
|
|||
|
},
|
|||
|
};
|
|||
|
// preprocess
|
|||
|
try {
|
|||
|
pagesJson = (0, json_1.parseJson)(jsonStr, true);
|
|||
|
}
|
|||
|
catch (e) {
|
|||
|
console.error(`[vite] Error: pages.json parse failed.\n`, jsonStr, e);
|
|||
|
}
|
|||
|
// pages
|
|||
|
validatePages(pagesJson, jsonStr);
|
|||
|
pagesJson.subPackages = pagesJson.subPackages || pagesJson.subpackages;
|
|||
|
delete pagesJson.subpackages;
|
|||
|
// subpackages
|
|||
|
if (pagesJson.subPackages) {
|
|||
|
if (subpackages) {
|
|||
|
pagesJson.subPackages.forEach(({ pages }) => {
|
|||
|
pages && normalizePages(pages, platform);
|
|||
|
});
|
|||
|
}
|
|||
|
else {
|
|||
|
pagesJson.pages.push(...normalizeSubpackages(pagesJson.subPackages));
|
|||
|
delete pagesJson.subPackages;
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
delete pagesJson.subPackages;
|
|||
|
}
|
|||
|
// pageStyle
|
|||
|
normalizePages(pagesJson.pages, platform);
|
|||
|
// globalStyle
|
|||
|
pagesJson.globalStyle = normalizePageStyle(null, pagesJson.globalStyle, platform);
|
|||
|
// tabBar
|
|||
|
if (pagesJson.tabBar) {
|
|||
|
const tabBar = normalizeTabBar(pagesJson.tabBar, platform);
|
|||
|
if (tabBar) {
|
|||
|
pagesJson.tabBar = tabBar;
|
|||
|
}
|
|||
|
else {
|
|||
|
delete pagesJson.tabBar;
|
|||
|
}
|
|||
|
}
|
|||
|
// 缓存页面列表
|
|||
|
pagesCacheSet.clear();
|
|||
|
pagesJson.pages.forEach((page) => pagesCacheSet.add(page.path));
|
|||
|
const manifestJsonPlatform = (0, manifest_1.getPlatformManifestJsonOnce)();
|
|||
|
if (!manifestJsonPlatform.darkmode) {
|
|||
|
const { pages, globalStyle, tabBar } = (0, theme_1.initTheme)(manifestJsonPlatform, pagesJson);
|
|||
|
(0, shared_1.extend)(pagesJson, { pages, globalStyle, tabBar });
|
|||
|
}
|
|||
|
return pagesJson;
|
|||
|
}
|
|||
|
exports.normalizePagesJson = normalizePagesJson;
|
|||
|
function validatePages(pagesJson, jsonStr) {
|
|||
|
if (!(0, shared_1.isArray)(pagesJson.pages)) {
|
|||
|
pagesJson.pages = [];
|
|||
|
throw new Error(`[uni-app] Error: pages.json->pages parse failed.`);
|
|||
|
}
|
|||
|
else if (!pagesJson.pages.length) {
|
|||
|
throw new Error(`[uni-app] Error: pages.json->pages must contain at least 1 page.`);
|
|||
|
}
|
|||
|
else {
|
|||
|
const pages = [];
|
|||
|
pagesJson.pages.forEach((page) => {
|
|||
|
if (pages.indexOf(page.path) !== -1) {
|
|||
|
throw new Error(`[uni-app] Error: pages.json->${page.path} duplication.`);
|
|||
|
}
|
|||
|
pages.push(page.path);
|
|||
|
});
|
|||
|
}
|
|||
|
}
|
|||
|
exports.validatePages = validatePages;
|
|||
|
function normalizePages(pages, platform) {
|
|||
|
pages.forEach((page) => {
|
|||
|
page.style = normalizePageStyle(page.path, page.style, platform);
|
|||
|
});
|
|||
|
if (platform !== 'app') {
|
|||
|
return;
|
|||
|
}
|
|||
|
const subNVuePages = [];
|
|||
|
// subNVues
|
|||
|
pages.forEach(({ style: { subNVues } }) => {
|
|||
|
if (!(0, shared_1.isArray)(subNVues)) {
|
|||
|
return;
|
|||
|
}
|
|||
|
subNVues.forEach((subNVue) => {
|
|||
|
if (subNVue && subNVue.path) {
|
|||
|
subNVuePages.push({
|
|||
|
path: subNVue.path,
|
|||
|
style: { isSubNVue: true, isNVue: true, navigationBar: {} },
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
});
|
|||
|
if (subNVuePages.length) {
|
|||
|
pages.push(...subNVuePages);
|
|||
|
}
|
|||
|
}
|
|||
|
function normalizeSubpackages(subpackages) {
|
|||
|
const pages = [];
|
|||
|
if ((0, shared_1.isArray)(subpackages)) {
|
|||
|
subpackages.forEach(({ root, pages: subPages }) => {
|
|||
|
if (root && subPages.length) {
|
|||
|
subPages.forEach((subPage) => {
|
|||
|
subPage.path = (0, utils_1.normalizePath)(path_1.default.join(root, subPage.path));
|
|||
|
subPage.style = normalizeSubpackageSubNVues(root, subPage.style);
|
|||
|
pages.push(subPage);
|
|||
|
});
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
return pages;
|
|||
|
}
|
|||
|
function normalizeSubpackageSubNVues(root, style = { navigationBar: {} }) {
|
|||
|
const platformStyle = style['app'] || style['app-plus'];
|
|||
|
if (!platformStyle) {
|
|||
|
return style;
|
|||
|
}
|
|||
|
if ((0, shared_1.isArray)(platformStyle.subNVues)) {
|
|||
|
platformStyle.subNVues.forEach((subNVue) => {
|
|||
|
if (subNVue.path) {
|
|||
|
subNVue.path = (0, utils_1.normalizePath)(path_1.default.join(root, subNVue.path));
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
return style;
|
|||
|
}
|
|||
|
function normalizePageStyle(pagePath, pageStyle, platform) {
|
|||
|
const hasNVue = pagePath &&
|
|||
|
process.env.UNI_INPUT_DIR &&
|
|||
|
fs_1.default.existsSync(path_1.default.join(process.env.UNI_INPUT_DIR, pagePath + '.nvue'))
|
|||
|
? true
|
|||
|
: undefined;
|
|||
|
let isNVue = false;
|
|||
|
if (hasNVue) {
|
|||
|
const hasVue = fs_1.default.existsSync(path_1.default.join(process.env.UNI_INPUT_DIR, pagePath + '.vue'));
|
|||
|
if (hasVue) {
|
|||
|
if (platform === 'app') {
|
|||
|
if (process.env.UNI_NVUE_COMPILER !== 'vue') {
|
|||
|
isNVue = true;
|
|||
|
}
|
|||
|
}
|
|||
|
}
|
|||
|
else {
|
|||
|
isNVue = true;
|
|||
|
}
|
|||
|
}
|
|||
|
if (pageStyle) {
|
|||
|
if (platform === 'h5') {
|
|||
|
(0, shared_1.extend)(pageStyle, pageStyle['app'] || pageStyle['app-plus'], pageStyle['web'] || pageStyle['h5']);
|
|||
|
}
|
|||
|
else if (platform === 'app') {
|
|||
|
(0, shared_1.extend)(pageStyle, pageStyle['app'] || pageStyle['app-plus']);
|
|||
|
}
|
|||
|
else {
|
|||
|
(0, shared_1.extend)(pageStyle, pageStyle[platform]);
|
|||
|
}
|
|||
|
if (['h5', 'app'].includes(platform)) {
|
|||
|
pageStyle.navigationBar = normalizeNavigationBar(pageStyle);
|
|||
|
if (isEnablePullDownRefresh(pageStyle)) {
|
|||
|
pageStyle.enablePullDownRefresh = true;
|
|||
|
pageStyle.pullToRefresh = normalizePullToRefresh(pageStyle);
|
|||
|
}
|
|||
|
if (platform === 'app') {
|
|||
|
pageStyle.disableSwipeBack === true
|
|||
|
? (pageStyle.popGesture = 'none')
|
|||
|
: delete pageStyle.popGesture;
|
|||
|
delete pageStyle.disableSwipeBack;
|
|||
|
}
|
|||
|
}
|
|||
|
pageStyle.isNVue = isNVue;
|
|||
|
removePlatformStyle(pageStyle);
|
|||
|
return pageStyle;
|
|||
|
}
|
|||
|
return { navigationBar: {}, isNVue };
|
|||
|
}
|
|||
|
const navigationBarMaps = {
|
|||
|
navigationBarBackgroundColor: 'backgroundColor',
|
|||
|
navigationBarTextStyle: 'textStyle',
|
|||
|
navigationBarTitleText: 'titleText',
|
|||
|
navigationStyle: 'style',
|
|||
|
titleImage: 'titleImage',
|
|||
|
titlePenetrate: 'titlePenetrate',
|
|||
|
transparentTitle: 'transparentTitle',
|
|||
|
};
|
|||
|
function normalizeNavigationBar(pageStyle) {
|
|||
|
const navigationBar = Object.create(null);
|
|||
|
Object.keys(navigationBarMaps).forEach((name) => {
|
|||
|
if ((0, shared_1.hasOwn)(pageStyle, name)) {
|
|||
|
navigationBar[navigationBarMaps[name]] =
|
|||
|
pageStyle[name];
|
|||
|
delete pageStyle[name];
|
|||
|
}
|
|||
|
});
|
|||
|
navigationBar.type = navigationBar.type || 'default';
|
|||
|
const { titleNView } = pageStyle;
|
|||
|
if ((0, shared_1.isPlainObject)(titleNView)) {
|
|||
|
(0, shared_1.extend)(navigationBar, titleNView);
|
|||
|
delete pageStyle.titleNView;
|
|||
|
}
|
|||
|
else if (titleNView === false) {
|
|||
|
navigationBar.style = 'custom';
|
|||
|
}
|
|||
|
if ((0, shared_1.hasOwn)(navigationBar, 'transparentTitle')) {
|
|||
|
const transparentTitle = navigationBar.transparentTitle;
|
|||
|
if (transparentTitle === 'always') {
|
|||
|
navigationBar.style = 'custom';
|
|||
|
navigationBar.type = 'float';
|
|||
|
}
|
|||
|
else if (transparentTitle === 'auto') {
|
|||
|
navigationBar.type = 'transparent';
|
|||
|
}
|
|||
|
else {
|
|||
|
navigationBar.type = 'default';
|
|||
|
}
|
|||
|
delete navigationBar.transparentTitle;
|
|||
|
}
|
|||
|
if (navigationBar.titleImage && navigationBar.titleText) {
|
|||
|
delete navigationBar.titleText;
|
|||
|
}
|
|||
|
if (!navigationBar.titleColor && (0, shared_1.hasOwn)(navigationBar, 'textStyle')) {
|
|||
|
const textStyle = navigationBar.textStyle;
|
|||
|
if (constants_1.TEXT_STYLE.includes(textStyle)) {
|
|||
|
navigationBar.titleColor = (0, uni_shared_1.normalizeTitleColor)(textStyle);
|
|||
|
}
|
|||
|
else {
|
|||
|
navigationBar.titleColor = navigationBar.textStyle;
|
|||
|
}
|
|||
|
delete navigationBar.textStyle;
|
|||
|
}
|
|||
|
if (pageStyle.navigationBarShadow &&
|
|||
|
pageStyle.navigationBarShadow.colorType) {
|
|||
|
navigationBar.shadowColorType = pageStyle.navigationBarShadow.colorType;
|
|||
|
delete pageStyle.navigationBarShadow;
|
|||
|
}
|
|||
|
const parsedNavigationBar = (0, theme_1.initTheme)((0, manifest_1.getPlatformManifestJsonOnce)(), navigationBar);
|
|||
|
if ((0, shared_1.isArray)(navigationBar.buttons)) {
|
|||
|
navigationBar.buttons = navigationBar.buttons.map((btn) => normalizeNavigationBarButton(btn, navigationBar.type, parsedNavigationBar.titleColor));
|
|||
|
}
|
|||
|
if ((0, shared_1.isPlainObject)(navigationBar.searchInput)) {
|
|||
|
navigationBar.searchInput = normalizeNavigationBarSearchInput(navigationBar.searchInput);
|
|||
|
}
|
|||
|
if (navigationBar.type === 'transparent') {
|
|||
|
navigationBar.coverage = navigationBar.coverage || '132px';
|
|||
|
}
|
|||
|
return navigationBar;
|
|||
|
}
|
|||
|
function normalizeNavigationBarButton(btn, type, titleColor) {
|
|||
|
btn.color = btn.color || titleColor;
|
|||
|
if (!btn.fontSize) {
|
|||
|
btn.fontSize =
|
|||
|
type === 'transparent' || (btn.text && /\\u/.test(btn.text))
|
|||
|
? '22px'
|
|||
|
: '27px';
|
|||
|
}
|
|||
|
else if (/\d$/.test(btn.fontSize)) {
|
|||
|
btn.fontSize += 'px';
|
|||
|
}
|
|||
|
btn.text = btn.text || '';
|
|||
|
return btn;
|
|||
|
}
|
|||
|
function normalizeNavigationBarSearchInput(searchInput) {
|
|||
|
return (0, shared_1.extend)({
|
|||
|
autoFocus: false,
|
|||
|
align: 'center',
|
|||
|
color: '#000',
|
|||
|
backgroundColor: 'rgba(255,255,255,0.5)',
|
|||
|
borderRadius: '0px',
|
|||
|
placeholder: '',
|
|||
|
placeholderColor: '#CCCCCC',
|
|||
|
disabled: false,
|
|||
|
}, searchInput);
|
|||
|
}
|
|||
|
const DEFAULT_TAB_BAR = {
|
|||
|
position: 'bottom',
|
|||
|
color: '#999',
|
|||
|
selectedColor: '#007aff',
|
|||
|
borderStyle: 'black',
|
|||
|
blurEffect: 'none',
|
|||
|
fontSize: '10px',
|
|||
|
iconWidth: '24px',
|
|||
|
spacing: '3px',
|
|||
|
height: uni_shared_1.TABBAR_HEIGHT + 'px',
|
|||
|
};
|
|||
|
function normalizeTabBar(tabBar, platform) {
|
|||
|
const { list, midButton } = tabBar;
|
|||
|
if (!list || !list.length) {
|
|||
|
return;
|
|||
|
}
|
|||
|
tabBar = (0, shared_1.extend)({}, DEFAULT_TAB_BAR, tabBar);
|
|||
|
list.forEach((item) => {
|
|||
|
if (item.iconPath) {
|
|||
|
item.iconPath = normalizeFilepath(item.iconPath);
|
|||
|
}
|
|||
|
if (item.selectedIconPath) {
|
|||
|
item.selectedIconPath = normalizeFilepath(item.selectedIconPath);
|
|||
|
}
|
|||
|
});
|
|||
|
if (midButton && midButton.backgroundImage) {
|
|||
|
midButton.backgroundImage = normalizeFilepath(midButton.backgroundImage);
|
|||
|
}
|
|||
|
tabBar.selectedIndex = 0;
|
|||
|
tabBar.shown = true;
|
|||
|
return tabBar;
|
|||
|
}
|
|||
|
const SCHEME_RE = /^([a-z-]+:)?\/\//i;
|
|||
|
const DATA_RE = /^data:.*,.*/;
|
|||
|
function normalizeFilepath(filepath) {
|
|||
|
const themeConfig = (0, theme_1.normalizeThemeConfigOnce)()['light'] || {};
|
|||
|
if (themeConfig[filepath.replace('@', '')])
|
|||
|
return filepath;
|
|||
|
if (!(SCHEME_RE.test(filepath) || DATA_RE.test(filepath)) &&
|
|||
|
filepath.indexOf('/') !== 0) {
|
|||
|
return (0, uni_shared_1.addLeadingSlash)(filepath);
|
|||
|
}
|
|||
|
return filepath;
|
|||
|
}
|
|||
|
const platforms = ['h5', 'app', 'mp-', 'quickapp', 'web'];
|
|||
|
function removePlatformStyle(pageStyle) {
|
|||
|
Object.keys(pageStyle).forEach((name) => {
|
|||
|
if (platforms.find((prefix) => name.startsWith(prefix))) {
|
|||
|
delete pageStyle[name];
|
|||
|
}
|
|||
|
});
|
|||
|
return pageStyle;
|
|||
|
}
|
|||
|
exports.removePlatformStyle = removePlatformStyle;
|
|||
|
function normalizePagesRoute(pagesJson) {
|
|||
|
const firstPagePath = pagesJson.pages[0].path;
|
|||
|
const tabBarList = (pagesJson.tabBar && pagesJson.tabBar.list) || [];
|
|||
|
return pagesJson.pages.map((pageOptions) => {
|
|||
|
const pagePath = pageOptions.path;
|
|||
|
const isEntry = firstPagePath === pagePath ? true : undefined;
|
|||
|
const tabBarIndex = tabBarList.findIndex((tabBarPage) => tabBarPage.pagePath === pagePath);
|
|||
|
const isTabBar = tabBarIndex !== -1 ? true : undefined;
|
|||
|
let windowTop = 0;
|
|||
|
const meta = (0, shared_1.extend)({
|
|||
|
isQuit: isEntry || isTabBar ? true : undefined,
|
|||
|
isEntry: isEntry || undefined,
|
|||
|
isTabBar: isTabBar || undefined,
|
|||
|
tabBarIndex: isTabBar ? tabBarIndex : undefined,
|
|||
|
windowTop: windowTop || undefined,
|
|||
|
}, pageOptions.style);
|
|||
|
return {
|
|||
|
path: pageOptions.path,
|
|||
|
meta,
|
|||
|
};
|
|||
|
});
|
|||
|
}
|
|||
|
exports.normalizePagesRoute = normalizePagesRoute;
|
|||
|
function isEnablePullDownRefresh(pageStyle) {
|
|||
|
return pageStyle.enablePullDownRefresh || pageStyle.pullToRefresh?.support;
|
|||
|
}
|
|||
|
function normalizePullToRefresh(pageStyle) {
|
|||
|
return pageStyle.pullToRefresh;
|
|||
|
}
|
|||
|
function parseSubpackagesRoot(inputDir, platform) {
|
|||
|
const pagesJson = (0, exports.parsePagesJson)(inputDir, platform, false);
|
|||
|
const subpackages = pagesJson.subPackages || pagesJson.subpackages;
|
|||
|
const roots = [];
|
|||
|
if ((0, shared_1.isArray)(subpackages)) {
|
|||
|
subpackages.forEach(({ root }) => {
|
|||
|
if (root) {
|
|||
|
roots.push(root);
|
|||
|
}
|
|||
|
});
|
|||
|
}
|
|||
|
return roots;
|
|||
|
}
|
|||
|
exports.parseSubpackagesRootOnce = (0, uni_shared_1.once)(parseSubpackagesRoot);
|