Skip to content

Commit

Permalink
Canary -> main (#389)
Browse files Browse the repository at this point in the history
* fix: Will now require community selection before subscription

* feat: Add time to one event page & change image on event card to contain

* fix: fallback for formatting

* Fix: Add Notification for Failed Campaign Subscription API Call

* Bump BUILD_VERSION to 1.0.4

* fixed: Fixed date field changine to text

* Bump BUILD_VERSION to 1.0.5

* Bump BUILD_VERSION to 1.0.6

* Bump BUILD_VERSION to 1.0.7

* Fix: address formatting in AddToGoogleCalendar component

The AddToGoogleCalendar component has been updated to correctly format addresses with state information. The state value is now correctly retrieved and appended to the address string, fixing previous issues where the state data was not properly included.

* Fix: address formatting in AddToGoogleCalendar component

The AddToGoogleCalendar component has been updated to correctly format addresses with state information. The state value is now correctly retrieved and appended to the address string, fixing previous issues where the state data was not properly included.

* Bump BUILD_VERSION to 1.0.8

* scraped static texts on all pages

* got text from modals as well

* added common languages offered

* setting up redux for manual language selection

* hooked dropdown to redux data

* feat: lang selection working with dummy data set. Selection persists too

* whole of homepage now depends on static text object

* interactions, comment box, events and testimonial section all looking good

* one testimonial, one events page 🔥

* several changes json object for static text and testing with dummy translations

* language is now automatically added to apiCall

* fixed bug with comment component translation

* more translations, and tweaks to page json structure

* testimonial form now translated too

* getting started with languages offered page

* still setting up multi select on dropdown. checkbox in dropdown is not checking yet

* removing language works locally

* setup admin lang selector and docked it at the top of campaign edit page

* dropdown for language context on admin side now works with admin selected languages

* remove log

* Now changed to toggles

* removed comments and added translation for fallback text

* removed logs

* edited toggles

* add language back in there

* sort languages

* translated more fallback texts

* translated preview mode & events too

* paused on admin tans for now

* removed comments and limited languages

* now loads language list from api

* better config log

* version number bump

* point to dev

* Bump BUILD_VERSION to 1.1.1

* user language

* remove about

* version number resolution

* upgrade

* Bump BUILD_VERSION to 1.1.4

* en-us

* Bump BUILD_VERSION to 1.1.5

* toggling languages works for admins

* client side loads from toggle list

* dont show ribbon when no list is provided

* dash will be provided if only one enabled language

* fix nav issue

* english cant be toggled, several tweaks to frontend logic

* pre testimonial translations setup for homepage area

* translated more dialogs

* resolved some circular imports

* cp for language selectino modal

* language modal setup with several bug fixes also done

* fixed testimonial form translation & height issues

* now added flags

* Bump BUILD_VERSION to 1.1.6

* squashed conflicts

* Bump BUILD_VERSION to 1.1.7

* added caret

* fixed single and no language logic

* bump

* Bump BUILD_VERSION to 1.1.9

* now looks for language only when data is loaded

* removed logs

* optional lang

* Bump BUILD_VERSION to 1.1.10

* made messenger pull from local storage (#347)

* Bump BUILD_VERSION to 1.1.11

* Prevent language override for admin users

This change ensures that the user language parameter is not appended to the API call when the user is an admin. This avoids any conflict or unintended behavior for admin-level operations, enhancing the robustness of language handling in the messaging API.

* Add optional chaining in various string splitting operations

Refactor the code to use optional chaining for string split operations to ensure error prevention on null or undefined values. This change improves the robustness of the code, particularly for scenarios where split might be called on potentially nullable strings.

* Bump BUILD_VERSION to 1.1.12

* Dev -> Canary (#349)

* scraped static texts on all pages

* got text from modals as well

* added common languages offered

* setting up redux for manual language selection

* hooked dropdown to redux data

* feat: lang selection working with dummy data set. Selection persists too

* whole of homepage now depends on static text object

* interactions, comment box, events and testimonial section all looking good

* one testimonial, one events page 🔥

* several changes json object for static text and testing with dummy translations

* language is now automatically added to apiCall

* fixed bug with comment component translation

* more translations, and tweaks to page json structure

* testimonial form now translated too

* getting started with languages offered page

* still setting up multi select on dropdown. checkbox in dropdown is not checking yet

* removing language works locally

* setup admin lang selector and docked it at the top of campaign edit page

* dropdown for language context on admin side now works with admin selected languages

* remove log

* Now changed to toggles

* removed comments and added translation for fallback text

* removed logs

* edited toggles

* add language back in there

* sort languages

* translated more fallback texts

* translated preview mode & events too

* paused on admin tans for now

* removed comments and limited languages

* now loads language list from api

* better config log

* version number bump

* point to dev

* Bump BUILD_VERSION to 1.1.1

* user language

* remove about

* version number resolution

* upgrade

* Bump BUILD_VERSION to 1.1.4

* en-us

* Bump BUILD_VERSION to 1.1.5

* toggling languages works for admins

* client side loads from toggle list

* dont show ribbon when no list is provided

* dash will be provided if only one enabled language

* fix nav issue

* english cant be toggled, several tweaks to frontend logic

* pre testimonial translations setup for homepage area

* translated more dialogs

* resolved some circular imports

* cp for language selectino modal

* language modal setup with several bug fixes also done

* fixed testimonial form translation & height issues

* now added flags

* Bump BUILD_VERSION to 1.1.6

* squashed conflicts

* Bump BUILD_VERSION to 1.1.7

* added caret

* fixed single and no language logic

* bump

* Bump BUILD_VERSION to 1.1.9

* now looks for language only when data is loaded

* removed logs

* optional lang

* Bump BUILD_VERSION to 1.1.10

* made messenger pull from local storage (#347)

* Bump BUILD_VERSION to 1.1.11

* Prevent language override for admin users

This change ensures that the user language parameter is not appended to the API call when the user is an admin. This avoids any conflict or unintended behavior for admin-level operations, enhancing the robustness of language handling in the messaging API.

* Add optional chaining in various string splitting operations

Refactor the code to use optional chaining for string split operations to ensure error prevention on null or undefined values. This change improves the robustness of the code, particularly for scenarios where split might be called on potentially nullable strings.

* Bump BUILD_VERSION to 1.1.12

---------

Co-authored-by: Version Update Bot <[email protected]>
Co-authored-by: Tahiru Abdullai <[email protected]>

* in the process of setting up custom loading messages to inform user of unsupported languages

* resolved conflict with chosen language that is not supported by campaign

* separating languages from language obj

* initial box now translates

* about only available from english

* capture weird screen dimensions with media queries

* blanket notification now in approuter

* tighter media query

* eventos

* more date objs translated too

* No preferred language should fallback to english

* Bump BUILD_VERSION to 1.1.13

* Fix: Broken community portal link  (#379)

* Add dynamic URL support for community portal

Updated the COMMUNITY_PORTAL_URL to dynamically generate the base URL depending on the environment. Added a utility function `getCommunityPortalBaseURL` to handle this logic.

* Refactor community portal URL logic

Consolidate community portal URLs into a single `BASE_URL` constant. This change simplifies URL management and reduces redundancy in the codebase. The `getCommunityPortalBaseURL` function has been removed and replaced with a cleaner variable definition.

* Fix incorrect branching condition for production environment

The `if (IS_PROD)` condition has been changed to `else if (IS_PROD)` to ensure it is mutually exclusive with previous conditions. This prevents the production URL assignment from being skipped if a prior condition is satisfied.

* Bump BUILD_VERSION to 1.1.14

* fixed other, and doubly sending user language

* filter instead of map

* fixed "other" on sharing modal

* Bump BUILD_VERSION to 1.1.15

* translated comment section

* news letter trans

* translated a few toasts

* remove logs

* Bump BUILD_VERSION to 1.1.16

* Bump BUILD_VERSION to 1.1.17

* spanish continue

* added the link for volunteering

* manual bump

* Bump BUILD_VERSION to 1.1.19

* Dev -> Canary (#384)

* scraped static texts on all pages

* got text from modals as well

* added common languages offered

* setting up redux for manual language selection

* hooked dropdown to redux data

* feat: lang selection working with dummy data set. Selection persists too

* whole of homepage now depends on static text object

* interactions, comment box, events and testimonial section all looking good

* one testimonial, one events page 🔥

* several changes json object for static text and testing with dummy translations

* language is now automatically added to apiCall

* fixed bug with comment component translation

* more translations, and tweaks to page json structure

* testimonial form now translated too

* getting started with languages offered page

* still setting up multi select on dropdown. checkbox in dropdown is not checking yet

* removing language works locally

* setup admin lang selector and docked it at the top of campaign edit page

* dropdown for language context on admin side now works with admin selected languages

* remove log

* Now changed to toggles

* removed comments and added translation for fallback text

* removed logs

* edited toggles

* add language back in there

* sort languages

* translated more fallback texts

* translated preview mode & events too

* paused on admin tans for now

* removed comments and limited languages

* now loads language list from api

* better config log

* version number bump

* point to dev

* Bump BUILD_VERSION to 1.1.1

* user language

* remove about

* version number resolution

* upgrade

* Bump BUILD_VERSION to 1.1.4

* en-us

* Bump BUILD_VERSION to 1.1.5

* toggling languages works for admins

* client side loads from toggle list

* dont show ribbon when no list is provided

* dash will be provided if only one enabled language

* fix nav issue

* english cant be toggled, several tweaks to frontend logic

* pre testimonial translations setup for homepage area

* translated more dialogs

* resolved some circular imports

* cp for language selectino modal

* language modal setup with several bug fixes also done

* fixed testimonial form translation & height issues

* now added flags

* Bump BUILD_VERSION to 1.1.6

* squashed conflicts

* Bump BUILD_VERSION to 1.1.7

* added caret

* fixed single and no language logic

* bump

* Bump BUILD_VERSION to 1.1.9

* now looks for language only when data is loaded

* removed logs

* optional lang

* Bump BUILD_VERSION to 1.1.10

* made messenger pull from local storage (#347)

* Bump BUILD_VERSION to 1.1.11

* Prevent language override for admin users

This change ensures that the user language parameter is not appended to the API call when the user is an admin. This avoids any conflict or unintended behavior for admin-level operations, enhancing the robustness of language handling in the messaging API.

* Add optional chaining in various string splitting operations

Refactor the code to use optional chaining for string split operations to ensure error prevention on null or undefined values. This change improves the robustness of the code, particularly for scenarios where split might be called on potentially nullable strings.

* Bump BUILD_VERSION to 1.1.12

* in the process of setting up custom loading messages to inform user of unsupported languages

* resolved conflict with chosen language that is not supported by campaign

* separating languages from language obj

* initial box now translates

* about only available from english

* capture weird screen dimensions with media queries

* blanket notification now in approuter

* tighter media query

* eventos

* more date objs translated too

* No preferred language should fallback to english

* Bump BUILD_VERSION to 1.1.13

* Fix: Broken community portal link  (#379)

* Add dynamic URL support for community portal

Updated the COMMUNITY_PORTAL_URL to dynamically generate the base URL depending on the environment. Added a utility function `getCommunityPortalBaseURL` to handle this logic.

* Refactor community portal URL logic

Consolidate community portal URLs into a single `BASE_URL` constant. This change simplifies URL management and reduces redundancy in the codebase. The `getCommunityPortalBaseURL` function has been removed and replaced with a cleaner variable definition.

* Fix incorrect branching condition for production environment

The `if (IS_PROD)` condition has been changed to `else if (IS_PROD)` to ensure it is mutually exclusive with previous conditions. This prevents the production URL assignment from being skipped if a prior condition is satisfied.

* Bump BUILD_VERSION to 1.1.14

* fixed other, and doubly sending user language

* filter instead of map

* fixed "other" on sharing modal

* Bump BUILD_VERSION to 1.1.15

* translated comment section

* news letter trans

* translated a few toasts

* remove logs

* Bump BUILD_VERSION to 1.1.16

* Bump BUILD_VERSION to 1.1.17

* spanish continue

* added the link for volunteering

* manual bump

* Bump BUILD_VERSION to 1.1.19

---------

Co-authored-by: frimpongopoku <[email protected]>
Co-authored-by: Version Update Bot <[email protected]>
Co-authored-by: Tahiru Abdullai <[email protected]>
Co-authored-by: Abdullai Tahiru <[email protected]>

* fix: Static texts translation (#385)

* Add notification messages and headers to multiple languages

Included success and error notifications for testimonials and comments in English, Spanish, Portuguese, and French. Added new headers for sections such as "Newsletter," "Getting Started," and "Meet the Coaches" across all supported languages.

* Update coach section title to include static text

Modified the `CoachesSectionWithFilters` component to display the `staticT?.title` in the section title if customization is not available. This ensures a default title is shown even if customization data is missing.

* Use static text variables for user notifications

Replaced hardcoded text strings with static text variables in both CommentComponentForModal.js and Footer.js to improve maintainability and support for internationalization. This ensures that all user-facing text can be easily managed and translated as needed.

* Enhance localization support with static text integration

Improved localization by integrating static text placeholders across multiple pages. This includes adjustments to trigger functions, form notifications, and section titles to utilize static text sources when available.

* Update user testimonial formatting

Modified the format for displaying the user's company name in testimonials to include a static translation key. This ensures the word 'from' can be localized correctly based on user settings.

* Remove TODO comment in Footer.js

Eliminated an outdated TODO comment related to translation help text in the footer component. This will improve code readability and reduce unnecessary clutter.

* Update text property access in components

Modified `CoachesSectionWithFilters.js` and `Footer.js` to access the `text` property of nested objects in the `title` and `description` fields. This ensures the correct text is displayed based on the provided customization or static data.

* Refactor JSON statics structure to improve consistency

Updated the internationalization JSON structure to nest titles and descriptions under 'text' keys. This change ensures a consistent format across multiple sections and languages, enhancing maintainability and readability of the code. Adjusted relevant component render logic to accommodate this new structure.

* Bump BUILD_VERSION to 1.1.20

* Fix static text translation (#386)

* Add notification messages and headers to multiple languages

Included success and error notifications for testimonials and comments in English, Spanish, Portuguese, and French. Added new headers for sections such as "Newsletter," "Getting Started," and "Meet the Coaches" across all supported languages.

* Update coach section title to include static text

Modified the `CoachesSectionWithFilters` component to display the `staticT?.title` in the section title if customization is not available. This ensures a default title is shown even if customization data is missing.

* Use static text variables for user notifications

Replaced hardcoded text strings with static text variables in both CommentComponentForModal.js and Footer.js to improve maintainability and support for internationalization. This ensures that all user-facing text can be easily managed and translated as needed.

* Enhance localization support with static text integration

Improved localization by integrating static text placeholders across multiple pages. This includes adjustments to trigger functions, form notifications, and section titles to utilize static text sources when available.

* Update user testimonial formatting

Modified the format for displaying the user's company name in testimonials to include a static translation key. This ensures the word 'from' can be localized correctly based on user settings.

* Remove TODO comment in Footer.js

Eliminated an outdated TODO comment related to translation help text in the footer component. This will improve code readability and reduce unnecessary clutter.

* Update text property access in components

Modified `CoachesSectionWithFilters.js` and `Footer.js` to access the `text` property of nested objects in the `title` and `description` fields. This ensures the correct text is displayed based on the provided customization or static data.

* Refactor JSON statics structure to improve consistency

Updated the internationalization JSON structure to nest titles and descriptions under 'text' keys. This change ensures a consistent format across multiple sections and languages, enhancing maintainability and readability of the code. Adjusted relevant component render logic to accommodate this new structure.

* Fix comment box trigger in TechnologyFullViewPage

Added a second parameter to the triggerCommentBox function to ensure the modal's static texts are passed correctly. This resolves an issue where the comment box was not displaying all necessary information.

* Bump BUILD_VERSION to 1.1.21

* Add Spanish and Portuguese translations to internationalization

This commit enhances the internationalization feature by adding Spanish and Portuguese translations to various UI elements. These translations cover toasts, forms, loaders, footers, modals, pages, and interactions, enabling a wider audience reach and improving user experience.

* language selector will not show in PROD (#388)

---------

Co-authored-by: frimpongopoku <[email protected]>
Co-authored-by: Tahiru Abdullai <[email protected]>
Co-authored-by: Abdullai Tahiru <[email protected]>
Co-authored-by: Version Update Bot <[email protected]>
  • Loading branch information
5 people authored Sep 4, 2024
1 parent 9eddf4d commit 3b92950
Show file tree
Hide file tree
Showing 67 changed files with 3,560 additions and 622 deletions.
2 changes: 2 additions & 0 deletions .gitignore
Original file line number Diff line number Diff line change
Expand Up @@ -23,3 +23,5 @@ npm-debug.log*
yarn-debug.log*
yarn-error.log*
.idea/
.env.development
.env.development
2 changes: 1 addition & 1 deletion package.json
Original file line number Diff line number Diff line change
Expand Up @@ -3,7 +3,7 @@
"version": "0.1.0",
"private": true,
"scripts": {
"start": "react-scripts start",
"start": "PORT=3002 react-scripts start",
"build": "CI=false react-scripts build",
"build:dev": "NODE_ENV=development REACT_APP_TARGET_ENV=development CI=false react-scripts build",
"build:canary": "NODE_ENV=canary REACT_APP_TARGET_ENV=canary CI=false react-scripts build",
Expand Down
87 changes: 45 additions & 42 deletions src/admin-portal/create-campaign/campaign-details-and-preview.js
Original file line number Diff line number Diff line change
Expand Up @@ -6,12 +6,18 @@ import LandingPage from "../../user-portal/pages/landing-page/LandingPage";
import { FontAwesomeIcon } from "@fortawesome/react-fontawesome";
import { faExternalLink } from "@fortawesome/free-solid-svg-icons";
import { useCampaignContext } from "../../hooks/use-campaign-context";
import ToggleLanguage from "../internationalization/ToggleLanguage";

export function CampaignDetailsAndPreview ({setStep,}) {
export function CampaignDetailsAndPreview({ setStep }) {
const [activeTab, setActiveTab] = useState(campaignPages[0].name);
const [preview, setPreview] = useState(false);

const {campaignDetails,originalCampaignDetails,lists,handleCampaignDetailsChange : setCampaignDetails} = useCampaignContext();
const {
campaignDetails,
originalCampaignDetails,
lists,
handleCampaignDetailsChange: setCampaignDetails,
} = useCampaignContext();

return (
<>
Expand All @@ -20,11 +26,15 @@ export function CampaignDetailsAndPreview ({setStep,}) {
<h4 className="mb-0">{campaignDetails.title}</h4>
</Col>
<div className="text-right col-auto px-4">
{/* <ToggleLanguage campaignId={campaignDetails?.id} /> */}
<ButtonGroup className="mr-2">
<Button variant="primary" onClick={() => {
window.open(`/campaign/${campaignDetails.slug}?preview=true`, "_blank")
}}>
Preview <FontAwesomeIcon icon={faExternalLink}/>
<Button
variant="primary"
onClick={() => {
window.open(`/campaign/${campaignDetails.slug}?preview=true`, "_blank");
}}
>
Preview <FontAwesomeIcon icon={faExternalLink} />
</Button>
</ButtonGroup>
</div>
Expand All @@ -36,18 +46,15 @@ export function CampaignDetailsAndPreview ({setStep,}) {
<Row className="pb-2 overflow-x-auto">
<Col className={"px-4"}>
<div className="nav-tabs-container">
{
campaignPages?.map((page) => (
<div
key={page?.name}
className={classes("nav-tabs-main tab", { "tab-active": activeTab === page?.name })}
onClick={() => setActiveTab(page?.name)}
>
<h5 className={classes("nav-tabs",)}>
{page?.name}
</h5>
</div>
))}
{campaignPages?.map((page) => (
<div
key={page?.name}
className={classes("nav-tabs-main tab", { "tab-active": activeTab === page?.name })}
onClick={() => setActiveTab(page?.name)}
>
<h5 className={classes("nav-tabs")}>{page?.name}</h5>
</div>
))}
</div>
</Col>
</Row>
Expand All @@ -56,33 +63,29 @@ export function CampaignDetailsAndPreview ({setStep,}) {
{/*region Body: Content goes here*/}
<Row className=" pt-4">
<Col className={"px-4"}>
{
campaignPages?.map((tab) => {
return (
activeTab === tab?.name && (
<tab.component
key={tab?.name}
setStep={setStep}
campaignDetails={campaignDetails}
originalCampaignDetails={originalCampaignDetails}
setCampaignDetails={setCampaignDetails}
lists={lists}
/>
)
);
})}
{campaignPages?.map((tab) => {
return (
activeTab === tab?.name && (
<tab.component
key={tab?.name}
setStep={setStep}
campaignDetails={campaignDetails}
originalCampaignDetails={originalCampaignDetails}
setCampaignDetails={setCampaignDetails}
lists={lists}
/>
)
);
})}
</Col>
</Row>

</Col>
{
preview && (
<Col className={"position-relative"}>
<LandingPage campaign={campaignDetails} preview/>
</Col>
)
}
{preview && (
<Col className={"position-relative"}>
<LandingPage campaign={campaignDetails} preview />
</Col>
)}
</Row>
</>
)
);
}
156 changes: 156 additions & 0 deletions src/admin-portal/internationalization/AddOfferedLanguages.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,156 @@
import React, { useEffect, useState } from "react";
import { AdminLayout } from "../../layouts/admin-layout";
import { Container, Row, ToggleButton } from "react-bootstrap";
import { MultiSelect } from "react-multi-select-component";
import { LANGUAGES } from "../../utils/internationalization/languages";
import { useDispatch, useSelector } from "react-redux";
import { loadLanguagesAction, updateOfferedLanguageAction } from "src/redux/actions/actions";
import Button from "src/components/admin-components/Button";
import ToggleSwitch from "src/components/toggle-switch/ToggleSwitch";
import Loading from "src/components/pieces/Loading";
import { apiCall } from "src/api/messenger";
export const getOfferedForThisCampaign = (objFromRedux, id) => {
if (!objFromRedux) return DEFAULT_OFFERED_PER_CAMPAIGN;
return objFromRedux[id];
};

const DEFAULT_OFFERED_PER_CAMPAIGN = [{ label: "English (US)", value: "en-US" }];
function AddOfferedLanguages({ campaignDetails: campaign }) {
const [loading, setLoading] = useState(false);
const [updateLoading, setUpdateLoading] = useState(false);
const [error, setError] = useState("");
const [trackChanges, setChanges] = useState({});
const languages = useSelector((state) => state?.languageList);
languages?.sort((a, b) => a?.name?.localeCompare(b?.name));

// const cOffered = useSelector((state) => state?.campaignOfferedLanguages);
const dispatch = useDispatch();
const campaignId = campaign?.id;

const putLanguageListInRedux = (data) => {
return dispatch(loadLanguagesAction(data));
};

const includeNewLanguage = (key, status) => {
setChanges({ ...trackChanges, [key]: status });
};

const pushChanges = () => {
setUpdateLoading(true);
const body = { campaign_id: campaignId, supported_languages: JSON.stringify(trackChanges) };
apiCall("campaigns.supported_languages.update", body).then((res) => {
setUpdateLoading(false);
if (!res?.success) return console.log("Error Saving Changes: ", res?.error);
putLanguageListInRedux(res?.data);
});
};

const fetchEssentials = () => {
Promise.all([apiCall("campaigns.supported_languages.list", { campaign_id: campaignId })]).then(([langList]) => {
setLoading(false);
if (!langList?.success) {
return setError(langList?.error || "Sorry, could not load list of languages");
}
putLanguageListInRedux(langList?.data);
// updateInRedux(offeredList?.data);
});
};

useEffect(() => {
if (!languages?.length) fetchEssentials();
else setLoading(false);
}, []);

if (error) return <p style={{ width: "100%", textAlign: "center", fontWeight: "bold", color: "#df5555" }}>{error}</p>;
if (loading) return <Loading text="Fetching languages...." />;

return (
// <AdminLayout>
<div style={{ padding: "" }}>
<Row style={{ height: "100vh" }}>
{/* <Row style={{}}> */}
{/* <h3>Add Offered Languages</h3> */}
<p>Add all the translation languages that you want to offer on your campaign site here</p>
<div style={{ height: "100%", marginTop: 20 }}>
{/* <div style={{ marginTop: 20 }}> */}
{/* <MultiSelect
multiple
value={offered}
options={(languages || []).map(([value, label]) => {
return {
value,
label,
};
})}
onChange={(vals) => updateInRedux(vals)}
valueRenderer={(selected, _options) => {
if (selected.length === 0) return "Select languages";
if (selected.length === _options.length) return "All languages selected";
if (selected.length > 5) return `${selected.length} languages Selected`;
return selected
?.map(({ label }) => label)
.join(", ")
.concat(" Selected");
}}
labelledBy="Select"
/> */}

<div
style={{
// height: "100%",
width: "100%",
background: "rgb(248 248 248 / 44%)",
borderRadius: 10,
minHeight: 200,
marginTop: 10,
padding: 30,
}}
>
<div style={{ display: "flex", flexDirection: "row", paddingBottom: 20 }}>
<h5 style={{ display: "inline", color: "#d8d8d8" }}>LANGUAGES</h5>
<h5 style={{ marginLeft: "auto", display: "inline", color: "#d8d8d8" }}>Toggle ON/OFF</h5>
</div>
{languages?.map(({ name: label, code: k, is_active }) => {
const isEnglish = k === "en-US";
return (
<h6
// className="touchable-opacity"
style={{
marginBottom: 15,
paddingBottom: 7,
display: "flex",
flexDirection: "row",
alignItems: "center",
border: "solid 0px #e9e9e9",
borderBottomWidth: 2,
}}
>
{label}

<div style={{ marginLeft: "auto" }}>
{!isEnglish && <ToggleSwitch onChange={(state) => includeNewLanguage(k, state)} ON={is_active} />}
</div>
{/* <span
onClick={() => removeLang(lang?.value)}
style={{ marginLeft: "auto", color: "#c83131", fontSize: 16 }}
>
Remove
</span> */}
</h6>
);
})}
</div>

<div style={{ padding: "20px 00px" }}>
<Button loading={updateLoading} onClick={() => pushChanges()}>
Save
</Button>
</div>
</div>
</Row>
</div>
// </AdminLayout>
);
}

export default AddOfferedLanguages;
40 changes: 40 additions & 0 deletions src/admin-portal/internationalization/ToggleLanguage.js
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
import React from "react";
import { useSelector } from "react-redux";
import { getOfferedForThisCampaign } from "./AddOfferedLanguages";

function ToggleLanguage({ campaignId }) {
const offeredLangs = useSelector((state) => state?.campaignOfferedLanguages);
const content = getOfferedForThisCampaign(offeredLangs, campaignId);

return (
// <div className="l-drop">
<div style={{ display: "inline-flex", flexDirection: "column" }}>
<div className="l-drop">
<select
// value={activeLanguage}
onChange={(e) => {
// const langs = Object.keys(offeredLangs || {});
// const key = e?.target?.value; // languageISO
// const obj = langs.find((k) => k === key);
// setActiveLanguage(obj);
}}
// style={{ textTransform: "uppercase" }}
className="undefault"
>
{/* {Object.entries(offeredLangs || {})?.map(([key, name]) => ( */}
{content?.map(({ label }, key) => (
<option key={key} value={key} style={{ width: "100%" }}>
{/* {smartString(name, 12)} */}
{label}
</option>
))}
</select>
</div>
<small style={{ fontSize: 11, marginTop: 10, color: "grey", textAlign: "center" }}>
Select the language you want to create content in
</small>
</div>
);
}

export default ToggleLanguage;
Loading

0 comments on commit 3b92950

Please sign in to comment.