@marvalt/wadapter 2.3.20 → 2.3.22
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/dist/client/wordpress-client.d.ts +33 -0
- package/dist/client/wordpress-client.d.ts.map +1 -1
- package/dist/generators/wordpress/wordpress-generator.d.ts +2 -1
- package/dist/generators/wordpress/wordpress-generator.d.ts.map +1 -1
- package/dist/generators.cjs +27 -0
- package/dist/generators.cjs.map +1 -1
- package/dist/generators.esm.js +27 -0
- package/dist/generators.esm.js.map +1 -1
- package/dist/index.d.ts +120 -2
- package/dist/index.d.ts.map +1 -1
- package/dist/index.esm.js +146 -1
- package/dist/index.esm.js.map +1 -1
- package/dist/index.js +151 -0
- package/dist/index.js.map +1 -1
- package/dist/static/wordpress-static.d.ts +35 -0
- package/dist/static/wordpress-static.d.ts.map +1 -1
- package/dist/utils/theme-styles.d.ts +50 -0
- package/dist/utils/theme-styles.d.ts.map +1 -0
- package/package.json +1 -1
package/dist/index.d.ts
CHANGED
|
@@ -466,6 +466,39 @@ declare class WordPressClient {
|
|
|
466
466
|
site_name?: string;
|
|
467
467
|
site_description?: string;
|
|
468
468
|
}>;
|
|
469
|
+
/**
|
|
470
|
+
* Fetch Theme Styles from custom endpoint
|
|
471
|
+
* @returns Theme customization settings (typography, colors, backgrounds, shadows, layout)
|
|
472
|
+
*/
|
|
473
|
+
getThemeStyles(): Promise<{
|
|
474
|
+
typography?: {
|
|
475
|
+
heading_font_family?: string;
|
|
476
|
+
body_font_family?: string;
|
|
477
|
+
base_font_size?: string;
|
|
478
|
+
line_height?: string;
|
|
479
|
+
};
|
|
480
|
+
colors?: {
|
|
481
|
+
primary?: string;
|
|
482
|
+
secondary?: string;
|
|
483
|
+
text?: string;
|
|
484
|
+
background?: string;
|
|
485
|
+
};
|
|
486
|
+
backgrounds?: {
|
|
487
|
+
image?: string;
|
|
488
|
+
repeat?: string;
|
|
489
|
+
position?: string;
|
|
490
|
+
size?: string;
|
|
491
|
+
};
|
|
492
|
+
shadows?: {
|
|
493
|
+
box_shadow?: string;
|
|
494
|
+
text_shadow?: string;
|
|
495
|
+
};
|
|
496
|
+
layout?: {
|
|
497
|
+
container_max_width?: string;
|
|
498
|
+
wide_container_max_width?: string;
|
|
499
|
+
content_padding?: string;
|
|
500
|
+
};
|
|
501
|
+
}>;
|
|
469
502
|
}
|
|
470
503
|
|
|
471
504
|
/**
|
|
@@ -921,10 +954,40 @@ interface SiteSettings {
|
|
|
921
954
|
site_name?: string;
|
|
922
955
|
site_description?: string;
|
|
923
956
|
}
|
|
957
|
+
interface ThemeStyles {
|
|
958
|
+
typography?: {
|
|
959
|
+
heading_font_family?: string;
|
|
960
|
+
body_font_family?: string;
|
|
961
|
+
base_font_size?: string;
|
|
962
|
+
line_height?: string;
|
|
963
|
+
};
|
|
964
|
+
colors?: {
|
|
965
|
+
primary?: string;
|
|
966
|
+
secondary?: string;
|
|
967
|
+
text?: string;
|
|
968
|
+
background?: string;
|
|
969
|
+
};
|
|
970
|
+
backgrounds?: {
|
|
971
|
+
image?: string;
|
|
972
|
+
repeat?: string;
|
|
973
|
+
position?: string;
|
|
974
|
+
size?: string;
|
|
975
|
+
};
|
|
976
|
+
shadows?: {
|
|
977
|
+
box_shadow?: string;
|
|
978
|
+
text_shadow?: string;
|
|
979
|
+
};
|
|
980
|
+
layout?: {
|
|
981
|
+
container_max_width?: string;
|
|
982
|
+
wide_container_max_width?: string;
|
|
983
|
+
content_padding?: string;
|
|
984
|
+
};
|
|
985
|
+
}
|
|
924
986
|
interface WordPressStaticData {
|
|
925
987
|
generatedAt?: string;
|
|
926
988
|
front_page?: FrontPageMetadata;
|
|
927
989
|
site_settings?: SiteSettings;
|
|
990
|
+
theme_styles?: ThemeStyles;
|
|
928
991
|
posts: WordPressPost[];
|
|
929
992
|
pages: WordPressPage[];
|
|
930
993
|
media: WordPressMedia[];
|
|
@@ -948,6 +1011,11 @@ declare function getFrontpageMetadata(): FrontPageMetadata | undefined;
|
|
|
948
1011
|
* This is set by the generator from WordPress theme mods and options
|
|
949
1012
|
*/
|
|
950
1013
|
declare function getSiteSettings(): SiteSettings | undefined;
|
|
1014
|
+
/**
|
|
1015
|
+
* Get theme styles (typography, colors, backgrounds, shadows, layout) from static data
|
|
1016
|
+
* This is set by the generator from WordPress Customizer settings
|
|
1017
|
+
*/
|
|
1018
|
+
declare function getThemeStyles(): ThemeStyles | undefined;
|
|
951
1019
|
|
|
952
1020
|
/**
|
|
953
1021
|
* @license GPL-3.0-or-later
|
|
@@ -1160,5 +1228,55 @@ declare function getFrontpageSlug(pages?: WordPressPage[], frontPageMetadata?: {
|
|
|
1160
1228
|
slug: string;
|
|
1161
1229
|
} | undefined): string | undefined;
|
|
1162
1230
|
|
|
1163
|
-
|
|
1164
|
-
|
|
1231
|
+
/**
|
|
1232
|
+
* @license GPL-3.0-or-later
|
|
1233
|
+
*
|
|
1234
|
+
* This file is part of the MarVAlt Open SDK.
|
|
1235
|
+
* Copyright (c) 2025 Vibune Pty Ltd.
|
|
1236
|
+
*
|
|
1237
|
+
* This program is free software: you can redistribute it and/or modify
|
|
1238
|
+
* it under the terms of the GNU General Public License as published by
|
|
1239
|
+
* the Free Software Foundation, either version 3 of the License, or
|
|
1240
|
+
* (at your option) any later version.
|
|
1241
|
+
*
|
|
1242
|
+
* This program is distributed in the hope that it will be useful,
|
|
1243
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
1244
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
1245
|
+
* See the GNU General Public License for more details.
|
|
1246
|
+
*/
|
|
1247
|
+
/**
|
|
1248
|
+
* List of popular Google Fonts (for detection and validation)
|
|
1249
|
+
*/
|
|
1250
|
+
declare const GOOGLE_FONTS: readonly ["Montserrat", "Open Sans", "Roboto", "Lato", "Poppins", "Source Sans Pro", "Raleway", "Oswald", "Playfair Display", "Merriweather", "Ubuntu", "Nunito", "Inter", "Work Sans", "Crimson Text", "Libre Baskerville", "PT Sans", "PT Serif", "Dancing Script", "Bebas Neue", "Fira Sans", "Noto Sans", "Noto Serif", "Rubik", "Mukta", "Cabin", "Dosis", "Arimo", "Titillium Web"];
|
|
1251
|
+
/**
|
|
1252
|
+
* Sanitize font name - removes "family" prefix and cleans the name
|
|
1253
|
+
*
|
|
1254
|
+
* @param fontName - Font name to sanitize
|
|
1255
|
+
* @returns Sanitized font name
|
|
1256
|
+
*/
|
|
1257
|
+
declare function sanitizeFontName(fontName: string): string;
|
|
1258
|
+
/**
|
|
1259
|
+
* Format font-family CSS value with quotes and fallback
|
|
1260
|
+
*
|
|
1261
|
+
* @param fontName - Font name to format
|
|
1262
|
+
* @param fallback - Fallback font (default: 'sans-serif')
|
|
1263
|
+
* @returns Formatted font-family CSS value
|
|
1264
|
+
*/
|
|
1265
|
+
declare function formatFontFamily(fontName: string, fallback?: string): string;
|
|
1266
|
+
/**
|
|
1267
|
+
* Load Google Font dynamically via link tag
|
|
1268
|
+
*
|
|
1269
|
+
* @param fontName - Google Font name to load
|
|
1270
|
+
* @param weights - Font weights to load (default: 400, 500, 600, 700)
|
|
1271
|
+
*/
|
|
1272
|
+
declare function loadGoogleFont(fontName: string, weights?: number[]): void;
|
|
1273
|
+
/**
|
|
1274
|
+
* Check if a font name is a Google Font
|
|
1275
|
+
*
|
|
1276
|
+
* @param fontName - Font name to check
|
|
1277
|
+
* @returns True if the font is a Google Font
|
|
1278
|
+
*/
|
|
1279
|
+
declare function isGoogleFont(fontName: string): boolean;
|
|
1280
|
+
|
|
1281
|
+
export { GOOGLE_FONTS, GravityForm, GravityFormsClient, GravityFormsProvider, WordPressClient, WordPressContent, WordPressProvider, buildMenuStructure, buildPageHierarchy, createFormProtectionConfig, createGravityFormsConfig, createWordPressConfig, findPageById, findPageBySlug, formatFontFamily, getActiveForms, getChildPages, getFormById, getFrontpage, getFrontpageMetadata, getFrontpageSlug, getPublishedForms, getRootPages, getSiteSettings, getThemeStyles, getWordPressCategories, getWordPressMedia, getWordPressPages, getWordPressPosts, getWordPressTags, hasGravityFormsStatic, hasWordPressStatic, isGoogleFont, loadGoogleFont, loadGravityFormsData, loadWordPressData, sanitizeFontName, sanitizeHtml, transformWordPressMedia, transformWordPressMediaItems, transformWordPressPage, transformWordPressPages, transformWordPressPost, transformWordPressPosts, useFrontpageSlug, useGravityForms, useGravityFormsConfig, useGravityFormsContext, useWordPress, useWordPressCategories, useWordPressContext, useWordPressMedia, useWordPressPage, useWordPressPages, useWordPressPost, useWordPressPosts, useWordPressTags, validateEmail, validateFormData, validateFormProtectionConfig, validateGravityFormsConfig, validateMaxLength, validateMinLength, validatePhoneNumber, validateRequired, validateUrl, validateWordPressConfig };
|
|
1282
|
+
export type { EmailVerificationData, FormProtectionConfig, FormProtectionResult, FormProtectionValidation, FrontPageMetadata, GravityFormConfirmation, GravityFormField, GravityFormNotification, GravityFormSubmission, GravityFormSubmissionResult, GravityFormsConfig, GravityFormsStaticData, HierarchicalPage, MenuItem, SiteSettings, ThemeStyles, TransformedWordPressMedia, TransformedWordPressPage, TransformedWordPressPost, UseGravityFormsResult, UseWordPressResult, WordPressAuthor, WordPressCategory, WordPressConfig, WordPressMedia, WordPressPage, WordPressPost, WordPressQueryParams, WordPressStaticData, WordPressTag };
|
package/dist/index.d.ts.map
CHANGED
|
@@ -1 +1 @@
|
|
|
1
|
-
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAKH,cAAc,2BAA2B,CAAC;AAC1C,cAAc,uCAAuC,CAAC;AAGtD,cAAc,sCAAsC,CAAC;AAGrD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,cAAc,qCAAqC,CAAC;AACpD,cAAc,wCAAwC,CAAC;AAGvD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAM9C,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AAGxC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC"}
|
|
1
|
+
{"version":3,"file":"index.d.ts","sourceRoot":"","sources":["../src/index.ts"],"names":[],"mappings":"AAAA;;;;;;;;;;;;;;;GAeG;AAKH,cAAc,2BAA2B,CAAC;AAC1C,cAAc,uCAAuC,CAAC;AAGtD,cAAc,sCAAsC,CAAC;AAGrD,cAAc,4BAA4B,CAAC;AAC3C,cAAc,+BAA+B,CAAC;AAC9C,cAAc,gCAAgC,CAAC;AAC/C,OAAO,EAAE,gBAAgB,EAAE,MAAM,qCAAqC,CAAC;AACvE,OAAO,EAAE,WAAW,EAAE,MAAM,gCAAgC,CAAC;AAC7D,cAAc,qCAAqC,CAAC;AACpD,cAAc,wCAAwC,CAAC;AAGvD,cAAc,2BAA2B,CAAC;AAC1C,cAAc,+BAA+B,CAAC;AAM9C,cAAc,mBAAmB,CAAC;AAClC,cAAc,uBAAuB,CAAC;AACtC,cAAc,yBAAyB,CAAC;AAGxC,cAAc,gBAAgB,CAAC;AAC/B,cAAc,oBAAoB,CAAC;AACnC,cAAc,wBAAwB,CAAC;AACvC,cAAc,sBAAsB,CAAC"}
|
package/dist/index.esm.js
CHANGED
|
@@ -262,6 +262,13 @@ class WordPressClient {
|
|
|
262
262
|
async getSettings() {
|
|
263
263
|
return this.makeRequest('/wp-custom/v1/settings');
|
|
264
264
|
}
|
|
265
|
+
/**
|
|
266
|
+
* Fetch Theme Styles from custom endpoint
|
|
267
|
+
* @returns Theme customization settings (typography, colors, backgrounds, shadows, layout)
|
|
268
|
+
*/
|
|
269
|
+
async getThemeStyles() {
|
|
270
|
+
return this.makeRequest('/wp-custom/v1/theme-styles');
|
|
271
|
+
}
|
|
265
272
|
}
|
|
266
273
|
|
|
267
274
|
/**
|
|
@@ -754,6 +761,13 @@ function getFrontpageMetadata() {
|
|
|
754
761
|
function getSiteSettings() {
|
|
755
762
|
return wordpressStaticData?.site_settings;
|
|
756
763
|
}
|
|
764
|
+
/**
|
|
765
|
+
* Get theme styles (typography, colors, backgrounds, shadows, layout) from static data
|
|
766
|
+
* This is set by the generator from WordPress Customizer settings
|
|
767
|
+
*/
|
|
768
|
+
function getThemeStyles() {
|
|
769
|
+
return wordpressStaticData?.theme_styles;
|
|
770
|
+
}
|
|
757
771
|
|
|
758
772
|
/**
|
|
759
773
|
* @license GPL-3.0-or-later
|
|
@@ -2728,5 +2742,136 @@ function validateFormData(formData, rules) {
|
|
|
2728
2742
|
return { isValid, errors };
|
|
2729
2743
|
}
|
|
2730
2744
|
|
|
2731
|
-
|
|
2745
|
+
/**
|
|
2746
|
+
* @license GPL-3.0-or-later
|
|
2747
|
+
*
|
|
2748
|
+
* This file is part of the MarVAlt Open SDK.
|
|
2749
|
+
* Copyright (c) 2025 Vibune Pty Ltd.
|
|
2750
|
+
*
|
|
2751
|
+
* This program is free software: you can redistribute it and/or modify
|
|
2752
|
+
* it under the terms of the GNU General Public License as published by
|
|
2753
|
+
* the Free Software Foundation, either version 3 of the License, or
|
|
2754
|
+
* (at your option) any later version.
|
|
2755
|
+
*
|
|
2756
|
+
* This program is distributed in the hope that it will be useful,
|
|
2757
|
+
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
2758
|
+
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.
|
|
2759
|
+
* See the GNU General Public License for more details.
|
|
2760
|
+
*/
|
|
2761
|
+
/**
|
|
2762
|
+
* List of popular Google Fonts (for detection and validation)
|
|
2763
|
+
*/
|
|
2764
|
+
const GOOGLE_FONTS = [
|
|
2765
|
+
'Montserrat',
|
|
2766
|
+
'Open Sans',
|
|
2767
|
+
'Roboto',
|
|
2768
|
+
'Lato',
|
|
2769
|
+
'Poppins',
|
|
2770
|
+
'Source Sans Pro',
|
|
2771
|
+
'Raleway',
|
|
2772
|
+
'Oswald',
|
|
2773
|
+
'Playfair Display',
|
|
2774
|
+
'Merriweather',
|
|
2775
|
+
'Ubuntu',
|
|
2776
|
+
'Nunito',
|
|
2777
|
+
'Inter',
|
|
2778
|
+
'Work Sans',
|
|
2779
|
+
'Crimson Text',
|
|
2780
|
+
'Libre Baskerville',
|
|
2781
|
+
'PT Sans',
|
|
2782
|
+
'PT Serif',
|
|
2783
|
+
'Dancing Script',
|
|
2784
|
+
'Bebas Neue',
|
|
2785
|
+
'Fira Sans',
|
|
2786
|
+
'Noto Sans',
|
|
2787
|
+
'Noto Serif',
|
|
2788
|
+
'Rubik',
|
|
2789
|
+
'Mukta',
|
|
2790
|
+
'Cabin',
|
|
2791
|
+
'Dosis',
|
|
2792
|
+
'Arimo',
|
|
2793
|
+
'Titillium Web',
|
|
2794
|
+
];
|
|
2795
|
+
/**
|
|
2796
|
+
* Sanitize font name - removes "family" prefix and cleans the name
|
|
2797
|
+
*
|
|
2798
|
+
* @param fontName - Font name to sanitize
|
|
2799
|
+
* @returns Sanitized font name
|
|
2800
|
+
*/
|
|
2801
|
+
function sanitizeFontName(fontName) {
|
|
2802
|
+
if (!fontName)
|
|
2803
|
+
return '';
|
|
2804
|
+
// Remove "family" prefix if present (case insensitive)
|
|
2805
|
+
let cleaned = fontName.replace(/^family\s*/i, '').trim();
|
|
2806
|
+
return cleaned;
|
|
2807
|
+
}
|
|
2808
|
+
/**
|
|
2809
|
+
* Format font-family CSS value with quotes and fallback
|
|
2810
|
+
*
|
|
2811
|
+
* @param fontName - Font name to format
|
|
2812
|
+
* @param fallback - Fallback font (default: 'sans-serif')
|
|
2813
|
+
* @returns Formatted font-family CSS value
|
|
2814
|
+
*/
|
|
2815
|
+
function formatFontFamily(fontName, fallback = 'sans-serif') {
|
|
2816
|
+
if (!fontName)
|
|
2817
|
+
return fallback;
|
|
2818
|
+
const cleaned = sanitizeFontName(fontName);
|
|
2819
|
+
if (!cleaned)
|
|
2820
|
+
return fallback;
|
|
2821
|
+
// If font name contains spaces, wrap in quotes
|
|
2822
|
+
const quotedFont = cleaned.includes(' ') ? `"${cleaned}"` : cleaned;
|
|
2823
|
+
return `${quotedFont}, ${fallback}`;
|
|
2824
|
+
}
|
|
2825
|
+
/**
|
|
2826
|
+
* Load Google Font dynamically via link tag
|
|
2827
|
+
*
|
|
2828
|
+
* @param fontName - Google Font name to load
|
|
2829
|
+
* @param weights - Font weights to load (default: 400, 500, 600, 700)
|
|
2830
|
+
*/
|
|
2831
|
+
function loadGoogleFont(fontName, weights = [400, 500, 600, 700]) {
|
|
2832
|
+
if (typeof document === 'undefined') {
|
|
2833
|
+
// Server-side rendering - skip
|
|
2834
|
+
return;
|
|
2835
|
+
}
|
|
2836
|
+
if (!fontName)
|
|
2837
|
+
return;
|
|
2838
|
+
const cleaned = sanitizeFontName(fontName);
|
|
2839
|
+
if (!cleaned)
|
|
2840
|
+
return;
|
|
2841
|
+
// Check if it's a Google Font
|
|
2842
|
+
const isGoogleFont = GOOGLE_FONTS.some(font => font.toLowerCase() === cleaned.toLowerCase());
|
|
2843
|
+
if (!isGoogleFont) {
|
|
2844
|
+
// Not a Google Font, assume it's a system font or custom font
|
|
2845
|
+
return;
|
|
2846
|
+
}
|
|
2847
|
+
// Check if font is already loaded
|
|
2848
|
+
const fontId = `wp-google-font-${cleaned.toLowerCase().replace(/\s+/g, '-')}`;
|
|
2849
|
+
if (document.getElementById(fontId)) {
|
|
2850
|
+
return; // Already loaded
|
|
2851
|
+
}
|
|
2852
|
+
// Create link element for Google Fonts
|
|
2853
|
+
const link = document.createElement('link');
|
|
2854
|
+
link.id = fontId;
|
|
2855
|
+
link.rel = 'stylesheet';
|
|
2856
|
+
// Build Google Fonts URL with weights
|
|
2857
|
+
const weightsParam = weights.join(';');
|
|
2858
|
+
link.href = `https://fonts.googleapis.com/css2?family=${encodeURIComponent(cleaned)}:wght@${weightsParam}&display=swap`;
|
|
2859
|
+
document.head.appendChild(link);
|
|
2860
|
+
}
|
|
2861
|
+
/**
|
|
2862
|
+
* Check if a font name is a Google Font
|
|
2863
|
+
*
|
|
2864
|
+
* @param fontName - Font name to check
|
|
2865
|
+
* @returns True if the font is a Google Font
|
|
2866
|
+
*/
|
|
2867
|
+
function isGoogleFont(fontName) {
|
|
2868
|
+
if (!fontName)
|
|
2869
|
+
return false;
|
|
2870
|
+
const cleaned = sanitizeFontName(fontName);
|
|
2871
|
+
if (!cleaned)
|
|
2872
|
+
return false;
|
|
2873
|
+
return GOOGLE_FONTS.some(font => font.toLowerCase() === cleaned.toLowerCase());
|
|
2874
|
+
}
|
|
2875
|
+
|
|
2876
|
+
export { GOOGLE_FONTS, GravityForm, GravityFormsClient, GravityFormsProvider, WordPressClient, WordPressContent, WordPressProvider, buildMenuStructure, buildPageHierarchy, createFormProtectionConfig, createGravityFormsConfig, createWordPressConfig, findPageById, findPageBySlug, formatFontFamily, getActiveForms, getChildPages, getFormById, getFrontpage, getFrontpageMetadata, getFrontpageSlug, getPublishedForms, getRootPages, getSiteSettings, getThemeStyles, getWordPressCategories, getWordPressMedia, getWordPressPages, getWordPressPosts, getWordPressTags, hasGravityFormsStatic, hasWordPressStatic, isGoogleFont, loadGoogleFont, loadGravityFormsData, loadWordPressData, sanitizeFontName, sanitizeHtml, transformWordPressMedia, transformWordPressMediaItems, transformWordPressPage, transformWordPressPages, transformWordPressPost, transformWordPressPosts, useFrontpageSlug, useGravityForms, useGravityFormsConfig, useGravityFormsContext, useWordPress, useWordPressCategories, useWordPressContext, useWordPressMedia, useWordPressPage, useWordPressPages, useWordPressPost, useWordPressPosts, useWordPressTags, validateEmail, validateFormData, validateFormProtectionConfig, validateGravityFormsConfig, validateMaxLength, validateMinLength, validatePhoneNumber, validateRequired, validateUrl, validateWordPressConfig };
|
|
2732
2877
|
//# sourceMappingURL=index.esm.js.map
|