function htmlOptionsEditorDialogController($scope, $sce, formHelper) {
const vm = this;
vm.defaultValues = {
alias: 'title',
settings: {
container: {
mobile: {
spacing: {
padding: {
t: '4px',
b: '8px',
l: '16px',
r: '24px',
},
margin: {
all: '4px',
},
},
background: {
color: {
color: '#ffe599',
transparent: true,
},
},
border: {
radius: {
tl: 'S',
tr: 'M',
bl: 'M',
br: 'S',
},
width: 'width 2px',
color: '#ffe599',
style: 'Double',
},
effects: {
shadow: 'Auto',
color: '#744700',
opacity: '5%',
},
sizing: {
width: 'Screen',
height: '8px',
},
},
desktop: {
spacing: {
padding: {
t: '4px',
b: '8px',
l: '16px',
r: '24px',
},
margin: {
all: '4px',
},
},
background: {
color: {
color: '#ffe599',
transparent: true,
},
},
border: {
radius: {
tl: 'S',
tr: 'M',
bl: 'M',
br: 'S',
},
width: 'width 2px',
color: '#ffe599',
style: 'Double',
},
effects: {
shadow: 'Auto',
color: '#744700',
opacity: '5%',
},
sizing: {
width: 'Screen',
height: '8px',
},
},
},
text: {
mobile: {
typography: {
family: 'Sans',
size: 'S',
smoothing: true,
italic: true,
weight: '200 (extralight)',
spacing: '-0.05em (tighter)',
lineHeight: '.75rem/12px',
align: 'Center',
color: '#744700',
decoration: 'Underine',
decorationColor: '#16537e',
decorationStyle: 'Double',
thickness: 'From font',
underlineOffset: 'From font',
},
spacing: {
padding: {
t: '4px',
b: '16px',
l: '4px',
r: '4px',
},
margin: {
all: '4px',
},
},
background: {
color: 'Transparent',
},
effects: {
opacity: '5%',
},
sizing: {
width: 'Full',
height: '8px',
},
},
},
icon: {
mobile: {
spacing: {
padding: {
t: '4px',
b: '16px',
l: '8px',
r: '16px',
},
undefined: {
all: 'None',
},
},
background: {
color: 'Current',
},
effects: {
opacity: '10%',
},
sizing: {
width: 'Auto',
height: '4px',
},
svg: {
fill: {
customFill: 'Inherit',
},
stroke: 'width 2px',
width: 1,
},
},
},
image: {
mobile: {
spacing: {
padding: {
t: '8px',
b: '16px',
l: '48px',
r: 'None',
},
margin: {
all: '8px',
},
},
background: {
color: 'Current',
},
border: {
radius: {
tl: 'L',
tr: 'L',
bl: 'S',
br: 'M',
},
width: 'width 0px',
color: '#444444',
style: 'Solid',
},
effects: {
opacity: '5%',
},
sizing: {
width: 'Full',
height: '4px',
},
},
},
},
};
vm.close = close;
vm.submit = submit;
vm.stylingProperties = {};
vm.generateRequestData = generateRequestData;
vm.requestData = {};
function submit(model) {
vm.requestData = generateRequestData();
console.log(vm.requestData);
if (!formHelper.submitForm({ scope: $scope })) {
return;
}
$scope.model.submit(model);
}
function close() {
if ($scope.model && $scope.model.close) {
$scope.model.close();
}
}
// Constants -----------------------------------------------
const paddingValues = [
'None',
'4px',
'8px',
'16px',
'24px',
'32px',
'40px',
'48px',
'64px',
'80px',
'96px',
];
const marginValues = [
'None',
'4px',
'8px',
'16px',
'24px',
'32px',
'40px',
'48px',
'64px',
'80px',
'96px',
];
const radiusValues = ['None', 'S', 'M', 'L', 'XL', 'XXL', 'XXXL', 'Full'];
const borderStyleValues = ['Solid', 'Double', 'Dotted', 'Dashed', 'Wavy'];
const widthSizeValues = [
'Auto',
'Full',
'Screen',
'1/12',
'2/12',
'3/12',
'4/12',
'5/12',
'6/12',
'7/12',
'8/12',
'9/12',
'10/12',
'11/12',
'12/12',
'4px',
'8px',
'16px',
'24px',
'32px',
'40px',
'48px',
'64px',
'80px',
'96px',
'None',
];
const heightSizeValues = [
'Auto',
'4px',
'8px',
'16px',
'24px',
'32px',
'40px',
'48px',
'64px',
'80px',
'96px',
'128px',
'256px',
'None',
];
const borderWidthValues = [
'width 0px',
'width 2px',
'width 4px',
'width 8px',
'width 1px',
'left right 0px',
'left right 2px',
'left right 4px',
'left right 8px',
'left right 1px',
'top bottom 0px',
'top bottom 2px',
'top bottom 4px',
'top bottom 8px',
'top bottom 1px',
'inline start 0px',
'inline start 2px',
'inline start 4px',
'inline start 8px',
'inline start 1px',
'inline end 0px',
'inline end 2px',
'inline end 4px',
'inline end 8px',
'inline end 1px',
'top 0px',
'top 2px',
'top 4px',
'top 8px',
'top 1px',
'right 0px',
'right 2px',
'right 4px',
'right 8px',
'right 1px',
'bottom 0px',
'bottom 2px',
'bottom 4px',
'bottom 8px',
'bottom 1px',
'left 0px',
'left 2px',
'left 4px',
'left 8px',
'left 1px',
];
const gradientDirectionValues = [
'To left',
'To right',
'To bottom',
'To top',
];
const fontSizeValues = [
'XS',
'S',
'M',
'L',
'XL',
'2XL',
'3XL',
'4XL',
'5XL',
'6XL',
'7XL',
'8XL',
'9XL',
];
const fontWeightValues = [
'100 (thin)',
'200 (extralight)',
'300 (light)',
'400 (normal)',
'500 (medium)',
'600 (semibold)',
'700 (bold)',
'800 (extrabold)',
'900 (black)',
];
const letterSpacingValues = [
'Auto',
'-0.05em (tighter)',
'-0.025em (tight)',
'0.025em (wide)',
'0.05em (wider)',
'0.1em (widest)',
];
const lineHeightValues = [
'Auto',
'.75rem/12px',
'1rem/16px',
'1.25rem/20px',
'1.5rem/24px',
'1.75rem/28px',
'2rem/32px',
'2.25rem/36px',
'2.5rem/ 40px',
'1.25 (tight)',
'1.375 (snug)',
'1.5 (normal)',
'1.625 (relaxed)',
'2 (loose)',
];
const textAlignValues = [
'Left',
'Center',
'Right',
'Justify',
'Start',
'End',
];
const textDecorationValues = ['None', 'Underine', 'Overline', 'Line-through'];
const textDecorationStyleValues = [
'Solid',
'Double',
'Dotted',
'Dashed',
'Wavy',
];
const textDecorationThicknessValues = [
'Auto',
'From font',
'0px',
'1px',
'2px',
'4px',
'8px',
];
const textDecorationOffsetValues = textDecorationThicknessValues;
const textTransformValues = [0, 1, 2];
const opacityValues = [
'0',
'5%',
'10%',
'20%',
'25%',
'30%',
'40%',
'50%',
'60%',
'70%',
'75%',
'80%',
'85%',
'90%',
'95%',
'100%',
];
const fontFamilyValues = ['Sans', 'Serif', 'Mono'];
const shadowValues = ['None', 'Auto', 'S', 'M', 'L', 'XL', '2XL', 'Inner'];
const customFillColor = ['None', 'Inherit', 'Current', 'Transparent'];
const containerSettings = {
title: 'Container',
property: 'container',
mobile: [
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
type: 'toggle',
value: false,
show: true,
property: 'padding',
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
property: 'margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Set gradient',
property: 'color',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Transparent',
property: 'transparent',
type: 'toggle',
value: false,
show: true,
},
],
[
{
name: 'From',
property: 'from',
type: 'colorPicker',
value: '',
},
{
name: 'Set From color transparent',
property: 'fromTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'To',
propery: 'to',
type: 'colorPicker',
value: '',
},
{
name: 'Set To color transparent',
property: 'toTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'Direction',
property: 'direction',
type: 'dropdown',
value: '',
items: gradientDirectionValues,
},
],
],
},
],
},
{
title: 'Border',
property: 'border',
settings: [
{
name: 'Set custom radius',
property: 'radius',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Radius All',
property: 'all',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
[
{
name: 'Radius Top Left',
property: 'tl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Top Right',
property: 'tr',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Left',
property: 'bl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Right',
property: 'br',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
],
},
{
name: 'Width',
isOnlyMobile: true,
property: 'width',
type: 'dropdown',
value: '',
items: borderWidthValues,
},
{
name: 'Color',
isOnlyMobile: true,
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Style',
isOnlyMobile: true,
property: 'style',
type: 'dropdown',
value: '',
items: borderStyleValues,
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Shadow',
property: 'shadow',
type: 'dropdown',
value: '',
items: shadowValues,
},
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
],
tablet: [
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
type: 'toggle',
value: false,
show: true,
property: 'padding',
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
property: 'margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Set gradient',
property: 'color',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Transparent',
property: 'transparent',
type: 'toggle',
value: false,
show: true,
},
],
[
{
name: 'From',
property: 'from',
type: 'colorPicker',
value: '',
},
{
name: 'Set From color transparent',
property: 'fromTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'To',
propery: 'to',
type: 'colorPicker',
value: '',
},
{
name: 'Set To color transparent',
property: 'toTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'Direction',
property: 'direction',
type: 'dropdown',
value: '',
items: gradientDirectionValues,
},
],
],
},
],
},
{
title: 'Border',
property: 'border',
settings: [
{
name: 'Set custom radius',
property: 'radius',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Radius All',
property: 'all',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
[
{
name: 'Radius Top Left',
property: 'tl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Top Right',
property: 'tr',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Left',
property: 'bl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Right',
property: 'br',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
],
},
{
name: 'Width',
isOnlyMobile: true,
property: 'width',
type: 'dropdown',
value: '',
items: borderWidthValues,
},
{
name: 'Color',
isOnlyMobile: true,
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Style',
isOnlyMobile: true,
property: 'style',
type: 'dropdown',
value: '',
items: borderStyleValues,
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Shadow',
property: 'shadow',
type: 'dropdown',
value: '',
items: shadowValues,
},
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
],
desctop: [
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
type: 'toggle',
value: false,
show: true,
property: 'padding',
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
property: 'margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Set gradient',
property: 'color',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Transparent',
property: 'transparent',
type: 'toggle',
value: false,
show: true,
},
],
[
{
name: 'From',
property: 'from',
type: 'colorPicker',
value: '',
},
{
name: 'Set From color transparent',
property: 'fromTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'To',
propery: 'to',
type: 'colorPicker',
value: '',
},
{
name: 'Set To color transparent',
property: 'toTransparent',
type: 'toggle',
value: false,
show: true,
},
{
name: 'Direction',
property: 'direction',
type: 'dropdown',
value: '',
items: gradientDirectionValues,
},
],
],
},
],
},
{
title: 'Border',
property: 'border',
settings: [
{
name: 'Set custom radius',
property: 'radius',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Radius All',
property: 'all',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
[
{
name: 'Radius Top Left',
property: 'tl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Top Right',
property: 'tr',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Left',
property: 'bl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Right',
property: 'br',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
],
},
{
name: 'Width',
isOnlyMobile: true,
property: 'width',
type: 'dropdown',
value: '',
items: borderWidthValues,
},
{
name: 'Color',
isOnlyMobile: true,
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Style',
isOnlyMobile: true,
property: 'style',
type: 'dropdown',
value: '',
items: borderStyleValues,
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Shadow',
property: 'shadow',
type: 'dropdown',
value: '',
items: shadowValues,
},
{
name: 'Color',
property: 'color',
type: 'colorPicker',
value: '',
},
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
],
};
const textSettings = {
title: 'Text',
property: 'text',
subSections: [
{
title: 'Typography',
property: 'typography',
settings: [
{
name: 'Font family',
property: 'family',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: fontFamilyValues,
},
{
name: 'Font size',
property: 'size',
type: 'dropdown',
value: '',
items: fontSizeValues,
},
{
name: 'Set antialiased smoothing',
property: 'smoothing',
isOnlyMobile: true,
type: 'toggle',
show: 'true',
value: false,
show: true,
},
{
name: 'Set italic',
property: 'italic',
isOnlyMobile: true,
type: 'toggle',
value: false,
show: true,
},
{
name: 'Weight',
property: 'weight',
type: 'dropdown',
value: '',
items: fontWeightValues,
},
{
name: 'Letter Spacing',
property: 'spacing',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: letterSpacingValues,
},
{
name: 'Line height',
property: 'lineHeight',
type: 'dropdown',
value: '',
items: lineHeightValues,
},
{
name: 'Text align',
property: 'align',
type: 'dropdown',
value: '',
items: textAlignValues,
},
{
name: 'Color',
property: 'color',
isOnlyMobile: true,
type: 'colorPicker',
value: '',
},
{
name: 'Decoration',
property: 'decoration',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: textDecorationValues,
},
{
name: 'Decoration color',
property: 'decorationColor',
isOnlyMobile: true,
type: 'colorPicker',
value: '',
},
{
name: 'Decoration Style',
property: 'decorationStyle',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: textDecorationStyleValues,
},
{
name: 'Text Decoration thickness',
property: 'thickness',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: textDecorationThicknessValues,
},
{
name: 'Text underline offset',
property: 'underlineOffset',
type: 'dropdown',
value: '',
items: textDecorationOffsetValues,
},
{
name: 'Text transform',
property: 'textTransform',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: textTransformValues,
},
],
},
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
property: 'padding',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
property: 'margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Color',
property: 'color',
type: 'dropdown',
value: '',
items: ['Current', 'Transparent'],
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
],
};
const imageSettings = {
title: 'Image',
property: 'image',
subSections: [
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
property: 'padding',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
property: 'margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Color',
property: 'color',
type: 'dropdown',
value: '',
items: ['Current', 'Transparent'],
},
],
},
{
title: 'Border',
property: 'border',
settings: [
{
name: 'Set custom radius',
property: 'radius',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Radius All',
property: 'all',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
[
{
name: 'Radius Top Left',
property: 'tl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Top Right',
property: 'tr',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Left',
property: 'bl',
type: 'dropdown',
value: '',
items: radiusValues,
},
{
name: 'Radius Bottom Right',
property: 'br',
type: 'dropdown',
value: '',
items: radiusValues,
},
],
],
},
{
name: 'Width',
property: 'width',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: borderWidthValues,
},
{
name: 'Color',
property: 'color',
isOnlyMobile: true,
type: 'colorPicker',
value: '',
},
{
name: 'Style',
property: 'style',
isOnlyMobile: true,
type: 'dropdown',
value: '',
items: borderStyleValues,
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
],
};
const iconSettings = {
title: 'Icon',
property: 'icon',
subSections: [
{
title: 'Spacing',
property: 'spacing',
settings: [
{
name: 'Set custom padding',
property: 'padding',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Padding All',
property: 'all',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
[
{
name: 'Padding Top',
property: 't',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Left',
property: 'l',
type: 'dropdown',
value: '',
items: paddingValues,
},
{
name: 'Padding Right',
property: 'r',
type: 'dropdown',
value: '',
items: paddingValues,
},
],
],
},
{
name: 'Set custom margin',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Margin All',
property: 'all',
type: 'dropdown',
value: '',
items: marginValues,
},
],
[
{
name: 'Margin Top',
property: 't',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Bottom',
property: 'b',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Left',
property: 'l',
type: 'dropdown',
value: '',
items: marginValues,
},
{
name: 'Margin Right',
property: 'r',
type: 'dropdown',
value: '',
items: marginValues,
},
],
],
},
],
},
{
title: 'Background',
property: 'background',
isOnlyMobile: true,
settings: [
{
name: 'Color',
property: 'color',
type: 'dropdown',
value: '',
items: ['Current', 'Transparent'],
},
],
},
{
title: 'Effects',
property: 'effects',
isOnlyMobile: true,
settings: [
{
name: 'Opacity',
property: 'opacity',
type: 'dropdown',
value: '',
items: opacityValues,
},
],
},
{
title: 'Sizing',
property: 'sizing',
settings: [
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: widthSizeValues,
},
{
name: 'Height',
property: 'height',
type: 'dropdown',
value: '',
items: heightSizeValues,
},
],
},
{
title: 'SVG',
property: 'svg',
isOnlyMobile: true,
settings: [
{
name: 'Set custom fill',
property: 'fill',
type: 'toggle',
value: false,
show: true,
variants: [
[
{
name: 'Fill',
property: 'fill',
type: 'colorPicker',
value: '',
},
],
[
{
name: 'Fill',
property: 'customFill',
type: 'dropdown',
value: '',
items: customFillColor,
},
],
],
},
{
name: 'Stroke',
property: 'stroke',
type: 'dropdown',
value: '',
items: borderWidthValues,
},
{
name: 'Width',
property: 'width',
type: 'dropdown',
value: '',
items: [0, 1, 2],
},
],
},
],
};
const basicSettings = [
{
name: 'Add Styles for',
type: 'dropdown-add',
id: 'add-subsection',
value: '',
show: vm.defaultValues.alias,
items: [containerSettings],
},
{
name: 'Show preview',
type: 'toggle',
id: 'preview',
show: vm.defaultValues.alias,
value: false,
},
{
name: 'Show defaults',
type: 'toggle',
id: 'defaults',
value: false,
show: vm.defaultValues.alias,
showTooltip: false,
tooltipMessage:
"Show default values for sections. If you don't choose any styles, those styles will be applied.",
},
];
// Constants End -----------------------------------------------
// Additional Styling start -------------------------------------------------------
vm.tabselector = 'mobile';
vm.handleDropDownOpen = handleDropDownOpen;
vm.handleDropDownClose = handleDropDownClose;
vm.selectDropDownValue = selectDropDownValue;
vm.selectSection = selectSection;
vm.addSubsection = addSubsection;
vm.setShowPickersInSection = setShowPickersInSection;
vm.getDropDownValue = getDropDownValue;
vm.mouseOver = mouseOver;
vm.mouseLeave = mouseLeave;
vm.toggle = toggle;
vm.toggleTabShow = toggleTabShow;
vm.getButtonLabel = getButtonLabel;
vm.selectTab = selectTab;
vm.addActiveClass = addActiveClass;
vm.changeColor = changeColor;
vm.tabs = [
{
label: 'Mobile',
settings: basicSettings,
selector: 'mobile',
show: true,
isRemovable: false,
styledSectionsSettings: [],
},
{
label: 'Tablet',
settings: basicSettings,
selector: 'tablet',
show: Object.values(vm.defaultValues.settings).find((el) =>
el.hasOwnProperty('tablet')
),
isRemovable: true,
styledSectionsSettings: [],
},
{
label: 'Desktop',
settings: basicSettings,
selector: 'desktop',
show: Object.values(vm.defaultValues.settings).find((el) =>
el.hasOwnProperty('desktop')
),
isRemovable: true,
styledSectionsSettings: [],
},
];
vm.stylingProperties = {
alias: {
name: 'Section',
type: 'dropdown',
id: 'section',
value: vm.defaultValues.alias ?? '',
show: true,
items: ['Title', 'Pretitle', 'Description'],
},
settings: [containerSettings],
};
function handleDropDownOpen(currentDropDown) {
currentDropDown.dropdownOpen = true;
}
function handleDropDownClose(currentDropDown) {
currentDropDown.dropdownOpen = false;
}
function selectDropDownValue(item, currentSettings, index) {
const currentDropDown = currentSettings[index];
currentDropDown.value = item;
vm.handleDropDownClose(currentDropDown);
}
function changeColor(color, currentSetting) {
const hexColor = color.toHexString();
currentSetting.value = hexColor;
}
function clearEmpties(o) {
for (var k in o) {
if (!o[k] || typeof o[k] !== 'object') {
continue;
}
clearEmpties(o[k]);
if (Object.keys(o[k]).length === 0) {
delete o[k];
}
}
return o;
}
function generateRequestData() {
const requestData = { settings: {}, alias: '' };
vm.stylingProperties.settings.map((tab) => {
let alias = '';
if (tab.settings.length && tab.settings[0].value) {
alias = tab.settings[0].value.toLowerCase();
}
let tmp = {};
if (tab.styledSectionsSettings.length) {
tab.styledSectionsSettings.map((section) => {
tmp[section.property] = {};
section.subSections.forEach((subsection) => {
tmp[section.property][subsection.property] = {};
subsection.settings.forEach((setting) => {
tmp[section.property][subsection.property][setting.property] = {};
if (
setting.value &&
setting.value !== 'Select value' &&
!setting.variants?.length
) {
tmp[section.property][subsection.property][setting.property] =
setting.value;
}
if (setting.variants?.length) {
if (!setting.value) {
setting.variants[0].forEach((variant) => {
if (variant.value !== 'Select value' && variant.value) {
tmp[section.property][subsection.property][
setting.property
][variant.property] = variant.value;
}
});
} else {
setting.variants[1].forEach((variant) => {
if (variant.value !== 'Select value' && variant.value) {
tmp[section.property][subsection.property][
setting.property
][variant.property] = variant.value;
}
});
}
}
});
});
});
}
clearEmpties(tmp);
if (Object.keys(tmp).length) {
requestData.settings[tab.selector] = tmp;
requestData.alias = alias;
}
});
return requestData;
}
function selectSection(item, property) {
property.value = item;
if (property.value !== '') {
vm.stylingProperties.settings.forEach((tab) => {
vm.setShowPickersInSection(
tab.settings,
['add-subsection', 'preview', 'defaults'],
true
);
});
vm.handleDropDownClose(property);
}
}
function addSubsection(item, selectedTab, index) {
const currentDropDown = selectedTab.settings[index];
const selectedSection = currentDropDown.items.indexOf(item);
currentDropDown.items.splice(selectedSection, 1);
selectedTab.styledSectionsSettings.push(item);
vm.handleDropDownClose(currentDropDown);
}
function setShowPickersInSection(settings, ids, show) {
settings.forEach((setting) => {
if (ids.some((id) => id === setting.id)) {
setting.show = show;
}
});
}
function getDropDownValue(currentDropDown) {
console.log(currentDropDown);
if (!currentDropDown.value.length) {
currentDropDown.value = 'Select value';
}
}
function mouseOver(setting) {
setting.showTooltip = true;
}
function mouseLeave(setting) {
setting.showTooltip = false;
}
function toggle(currentSetting) {
if (currentSetting) {
currentSetting.value = !currentSetting.value;
}
}
function toggleTabShow(selectedTab, tabIndex) {
vm.selectTab(selectedTab.selector);
selectedTab.show = !selectedTab.show;
if (selectedTab.show && tabIndex) {
const previousSettings = structuredClone(
vm.stylingProperties.settings[tabIndex - 1].settings
).length
? structuredClone(vm.stylingProperties.settings[tabIndex - 1].settings)
: structuredClone(vm.stylingProperties.settings[0].settings);
const previosStyledSectionsSettings = structuredClone(
vm.stylingProperties.settings[tabIndex - 1].styledSectionsSettings
).length
? structuredClone(
vm.stylingProperties.settings[tabIndex - 1].styledSectionsSettings
)
: structuredClone(
vm.stylingProperties.settings[0].styledSectionsSettings
);
selectedTab.settings = previousSettings;
selectedTab.styledSectionsSettings = previosStyledSectionsSettings;
}
if (!selectedTab.show) {
selectedTab.settings = [];
selectedTab.styledSectionsSettings = [];
vm.selectTab(vm.stylingProperties.settings[0].selector);
}
}
function getButtonLabel(show, tabButton) {
return show ? `Add ${tabButton.label}` : `Remove ${tabButton.label}`;
}
function selectTab(tabSelector) {
vm.tabselector = tabSelector;
}
function addActiveClass(tabSelector) {
if (tabSelector === vm.tabselector) {
return 'activetab';
} else return '';
}
//---------------------------------------------------------------
}
angular
.module('umbraco')
.controller(
'HtmlOptions.EditorDialog.Controller',
htmlOptionsEditorDialogController
);