Skip to content

Commit 97ab53c

Browse files
leecalcotesouvikinator
authored andcommitted
pricing
Signed-off-by: Lee Calcote <[email protected]> Signed-off-by: Souvik Kar Mahapatra <[email protected]>
1 parent 694d838 commit 97ab53c

File tree

6 files changed

+99
-54
lines changed

6 files changed

+99
-54
lines changed

.github/build/features-to-json.js

+22-22
Original file line numberDiff line numberDiff line change
@@ -17,7 +17,7 @@ const headers = [
1717
"Team Designer",
1818
"Team Operator",
1919
"Enterprise",
20-
"Pricing Page",
20+
"Exclude",
2121
"Docs",
2222
];
2323

@@ -36,34 +36,34 @@ async function processCSV() {
3636

3737
const filteredData = rows.map(row => {
3838
try {
39-
const pricingPage = row["Pricing Page"]?.toLowerCase() || "";
39+
const exclude = row["Exclude"]?.toLowerCase();
4040
const hasXTier = [
4141
"Free",
4242
"Team Designer",
4343
"Team Operator",
4444
"Enterprise"]
4545
.some(tier => row[tier]?.trim().toLowerCase() === "x");
46-
const includeRow = hasXTier || (pricingPage && ["x", "X"].includes(pricingPage.toLowerCase()));
46+
// const includeRow = hasXTier && !(exclude && ["x", "X"].includes(exclude.toLowerCase()));
4747

48-
if (!includeRow) return null;
49-
50-
return {
51-
theme: row["Theme"],
52-
categoryOrder: row["Category Order"],
53-
category: row["Category"],
54-
functionOrder: row["Function Order"],
55-
function: row["Function"],
56-
feature: row["Feature"],
57-
subscription_tier: row["Subscription Tier"],
58-
comparison_tiers: {
59-
free: row["Free"],
60-
teamDesigner: row["Team Designer"],
61-
teamOperator: row["Team Operator"],
62-
enterprise: row["Enterprise"],
63-
},
64-
pricing_page: row["Pricing Page"],
65-
docs: row["Docs"]
66-
};
48+
// if (!includeRow) return null;
49+
if (!exclude) {
50+
return {
51+
theme: row["Theme"],
52+
categoryOrder: row["Category Order"],
53+
category: row["Category"],
54+
functionOrder: row["Function Order"],
55+
function: row["Function"],
56+
feature: row["Feature"],
57+
subscription_tier: row["Subscription Tier"],
58+
comparison_tiers: {
59+
free: row["Free"],
60+
teamDesigner: row["Team Designer"],
61+
teamOperator: row["Team Operator"],
62+
enterprise: row["Enterprise"],
63+
},
64+
docs: row["Docs"]
65+
};
66+
}
6767
} catch (error) {
6868
console.error("Error processing row:", row, error);
6969
return null;

src/assets/images/pricing/docs.svg

-7
This file was deleted.

src/sections/Pricing/comparison.js

+38-24
Original file line numberDiff line numberDiff line change
@@ -40,7 +40,7 @@ h2, h5{
4040
vertical-align: middle;
4141
transition: 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
4242
43-
h5{
43+
h5 {
4444
display: flex;
4545
text-align: left;
4646
padding-top: 1rem;
@@ -49,7 +49,9 @@ h2, h5{
4949
}
5050
.price-table tr td:first-child {
5151
border-left: 0 none;
52-
width: 45%;
52+
width: 100%;
53+
justify-content: flex-start;
54+
text-align: left;
5355
}
5456
.price-table tr td:not(:first-child) {
5557
text-align: center;
@@ -101,7 +103,7 @@ h2, h5{
101103
display: inline-block;
102104
border-radius: 64px;
103105
}
104-
.price-table td.price-table-popular {
106+
.price-table th.price-table-popular {
105107
border-top: 3px solid #00b39f;
106108
color: #00b39f;
107109
text-transform: uppercase;
@@ -115,54 +117,59 @@ h2, h5{
115117
transition: 0.8s cubic-bezier(0.2, 0.8, 0.2, 1);
116118
}
117119
118-
.category{
120+
.category {
119121
display: inline-block;
120122
margin: 0 1rem;
121123
}
122124
123-
.icon{
125+
.icon {
124126
height: 4rem;
125127
width: auto;
126128
fill: #00b39f;
127129
display: inline-block;
128130
}
129-
.no-icon{
131+
.no-icon {
130132
height: 1.5rem;
131133
width: auto;
132134
fill: red;
133135
}
134-
.yes-icon{
136+
.yes-icon {
135137
height: 1.5rem;
136138
width: auto;
137139
fill: #00b39f;
138140
}
139-
.toggle-btn{
141+
.toggle-btn {
140142
margin-top: 1rem;
141143
}
142-
.details{
144+
.details {
143145
p {
144146
color: #7A848E;
145147
margin-left: 1.1rem;
146148
}
147149
}
148-
.category-icon{
149-
margin: 0rem auto;
150+
.category-icon {
151+
150152
}
151153
.categories {
152154
display: flex;
155+
width: 100%;
156+
text-align: left;
153157
align-items: center;
154-
margin: 1rem 0;
155-
width: 100%
158+
margin: 1rem auto;
156159
}
157-
.docs {
160+
.docs {
158161
width:1rem;
159162
height:1rem;
160-
& > svg {
161-
background-color:{props => props.theme.whiteZeroFiveToBlackZeroFive};
163+
/* > svg { */
164+
fill: "red";
165+
/* fill:${props => props.theme.whiteZeroFiveToBlackZeroFive};*/
166+
&:hover {
167+
opacity:.5;
162168
}
163-
}
169+
170+
}
164171
165-
.feature-link-container {
172+
.feature-link-container {
166173
display: flex;
167174
align-items: center;
168175
justify-content: space-between;
@@ -177,7 +184,13 @@ h2, h5{
177184
text-decoration: none;
178185
font-size: 0.9rem;
179186
}
180-
187+
.feature-link > svg {
188+
fill: "red";
189+
/* fill:${props => props.theme.whiteZeroFiveToBlackZeroFive};*/
190+
&:hover {
191+
opacity:.5;
192+
}
193+
}
181194
.feature-link:hover {
182195
text-decoration: underline;
183196
}
@@ -193,10 +206,11 @@ const Comparison = () => {
193206
<table className="price-table">
194207
<tbody>
195208
<tr>
196-
<td className="price-blank"></td>
197-
<td className="price-table-popular">Most popular</td>
198-
<td className="price-blank"></td>
199-
<td className="price-blank"></td>
209+
<th className="price-blank"></th>
210+
<th className="price-blank"></th>
211+
<th className="price-table-popular">Most popular</th>
212+
<th className="price-blank"></th>
213+
<th className="price-blank"></th>
200214
</tr>
201215
<tr className="price-table-head">
202216
<td></td>
@@ -209,7 +223,7 @@ const Comparison = () => {
209223
{details.map((x) => (
210224
<>
211225
<tr key={x.id} >
212-
<td className="categories" >
226+
<td className="categories">
213227
<img src={x.icon} height={45} className="category-icon" alt={x.category} />
214228
<h3 className="category">{x.category}</h3></td>
215229
<td></td>

src/sections/Pricing/feature_data.json

+16
Original file line numberDiff line numberDiff line change
@@ -1151,6 +1151,22 @@
11511151
},
11521152
"docs": ""
11531153
},
1154+
{
1155+
"theme": "",
1156+
"categoryOrder": "10",
1157+
"category": "Support and Deployment",
1158+
"functionOrder": "1003",
1159+
"function": "Managed Service Provider",
1160+
"feature": "White Label: Customize the appearance and branding of your engineering platform powered by Layer5 Cloud. \n\nHierarchical user organizations and permissioning. Enforcement of tenancy.",
1161+
"subscription_tier": "Enterprise",
1162+
"comparison_tiers": {
1163+
"free": "",
1164+
"teamDesigner": "",
1165+
"teamOperator": "",
1166+
"enterprise": "x"
1167+
},
1168+
"docs": ""
1169+
},
11541170
{
11551171
"theme": "",
11561172
"categoryOrder": "10",

src/sections/Pricing/generateDetails.js

+1-1
Original file line numberDiff line numberDiff line change
@@ -13,7 +13,7 @@ import Identity from "./icons/identity.svg";
1313
import Support from "./icons/support.svg";
1414
import Catalog from "./icons/catalog.svg";
1515
import Security from "./icons/security.svg";
16-
import { ReactComponent as Docs } from "../../assets/images/pricing/docs.svg";
16+
import Docs from "./icons/docs.js";
1717

1818
function generateDetails(data) {
1919
const categories = [

src/sections/Pricing/icons/docs.js

+22
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,22 @@
1+
import React from "react";
2+
3+
const docsIcon = ({
4+
width = "20px",
5+
height = "20px",
6+
fill = "currentColor",
7+
style = {}
8+
}) => (
9+
<svg
10+
width={width}
11+
height={height}
12+
fill={fill}
13+
viewBox="0 0 256 256"
14+
style={style}
15+
strokeWidth="0"
16+
xmlns="http://www.w3.org/2000/svg"
17+
>
18+
<path d="M44,120H212.07a4,4,0,0,0,4-4V88a8,8,0,0,0-2.34-5.66l-56-56A8,8,0,0,0,152.05,24H56A16,16,0,0,0,40,40v76A4,4,0,0,0,44,120Zm108-76,44,44h-44ZM52,144H36a8,8,0,0,0-8,8v56a8,8,0,0,0,8,8H51.33C71,216,87.55,200.52,88,180.87A36,36,0,0,0,52,144Zm-.49,56H44V160h8a20,20,0,0,1,20,20.77C71.59,191.59,62.35,200,51.52,200Zm170.67-4.28a8.26,8.26,0,0,1-.73,11.09,30,30,0,0,1-21.4,9.19c-17.65,0-32-16.15-32-36s14.36-36,32-36a30,30,0,0,1,21.4,9.19,8.26,8.26,0,0,1,.73,11.09,8,8,0,0,1-11.9.38A14.21,14.21,0,0,0,200.06,160c-8.82,0-16,9-16,20s7.18,20,16,20a14.25,14.25,0,0,0,10.23-4.66A8,8,0,0,1,222.19,195.72ZM128,144c-17.65,0-32,16.15-32,36s14.37,36,32,36,32-16.15,32-36S145.69,144,128,144Zm0,56c-8.83,0-16-9-16-20s7.18-20,16-20,16,9,16,20S136.86,200,128,200Z"></path>
19+
</svg>
20+
);
21+
22+
export default docsIcon;

0 commit comments

Comments
 (0)