diff --git a/frontend/src/views/Dashboard/Setting/Setting.module.css b/frontend/src/views/Dashboard/Setting/Setting.module.css deleted file mode 100644 index 9ba320c..0000000 --- a/frontend/src/views/Dashboard/Setting/Setting.module.css +++ /dev/null @@ -1,127 +0,0 @@ -.main { - width: 100%; - display: flex; - flex-direction: column; -} -.head { - width: 100%; - background-color: #ffffff; - display: flex; - justify-content: space-between; - align-items: center; - margin-top: 36px; - margin-bottom: 34px; -} -.title { - color: #0d1e38; - font-family: 'Rubik-SemiBold', serif; - font-size: 32px; -} -.form-button { - background-color: #6254ff; - border: 1px solid #6254ff; - width: 131px; - height: 47px; - border-radius: 4px; - color: #ffffff; - font-family: 'SourceSansPro-SemiBold', serif; - font-size: 18px; -} - -.form-button:enabled:hover { - cursor: pointer; -} -.form-button:disabled { - background-color: #f0f0f0; - border: 1px solid #f0f0f0; -} -.form-button2 { - background-color: #ffffff; - border: 1px solid #6254ff; - margin-right: 16px; - width: 131px; - height: 47px; - border-radius: 4px; - color: #6254ff; - font-family: 'SourceSansPro-SemiBold', serif; - font-size: 18px; - cursor: pointer; -} -.row1 { - width: calc(100% - 50px); - padding: 0px 25px; - height: 75px; - display: flex; - justify-content: space-between; - align-items: center; - background-color: #ebf3f7; -} -.row2 { - width: calc(100% - 50px); - padding: 0px 25px; - height: 75px; - display: flex; - justify-content: space-between; - align-items: center; - background-color: #ffffff; -} -.form-data { - width: calc(50% - 12.5px); - display: flex; - flex-direction: column; -} -.form-data-2 { - width: 100%; - display: flex; - flex-direction: column; -} -.form-data-description { - margin-bottom: 4px; - font-family: 'SourceSansPro-SemiBold', serif; - font-size: 14px; -} -.form-data-container { - display: flex; - align-items: center; - height: 38px; -} -.form-input { - padding: 10px 10px; - font-family: 'SourceSansPro-Regular', serif; - font-size: 16px; - border-radius: 4px; - background-color: #ffffff; - border: 1px solid #cadbe3; - color: #335065; - width: calc(100% - 22px); -} - -.form-input:focus { - outline: none; -} - -.form-input:placeholder-shown { - background-color: #ffffff; -} -.form-icon { - color: #335065; - width: 22px; - height: 22px; - margin-left: 6px; -} -.form-icon:hover { - cursor: pointer; -} -.form-check{ - color: #008000; - width: 22px; - height: 22px; - margin-left: 6px; - margin-right: 2px; -} -.form-text-check{ - font-family: 'SourceSansPro-Regular', serif; - font-size: 12px; - color: #008000; - user-select: none; -} \ No newline at end of file diff --git a/frontend/src/views/Dashboard/Setting/index.jsx b/frontend/src/views/Dashboard/Setting/index.jsx index a3b7bb0..27bc135 100644 --- a/frontend/src/views/Dashboard/Setting/index.jsx +++ b/frontend/src/views/Dashboard/Setting/index.jsx @@ -2,17 +2,40 @@ import React, { useState, useEffect } from 'react'; import { enqueueSnackbar } from 'notistack'; import { useSelector, useDispatch } from 'react-redux'; import axios from 'axios'; -//styles -import Styles from './Setting.module.css'; //actions import { updateAccount, updateProfile, updatePhone } from './../../../redux/actions/auth'; //icons import { MdOutlineEdit, MdOutlineEditOff } from 'react-icons/md'; import { AiOutlineCheck } from 'react-icons/ai'; -import { GiConfirmed, GiCancel } from 'react-icons/gi'; //components import Modal from './../../../components/Modal'; +const sectionClassName = 'flex w-full flex-col'; +const headerClassName = + 'mt-9 mb-[34px] flex w-full flex-col gap-4 bg-white sm:flex-row sm:items-center sm:justify-between'; +const titleClassName = "font-['Rubik-SemiBold'] text-2xl text-[#0d1e38] sm:text-[32px]"; +const primaryButtonClassName = + "h-[47px] w-[131px] rounded border border-[#6254ff] bg-[#6254ff] font-['SourceSansPro-SemiBold'] text-lg text-white transition-colors enabled:hover:bg-[#5144e5] disabled:border-[#f0f0f0] disabled:bg-[#f0f0f0]"; +const secondaryButtonClassName = + "h-[47px] w-[131px] rounded border border-[#6254ff] bg-white font-['SourceSansPro-SemiBold'] text-lg text-[#6254ff] transition-colors hover:bg-[#f0efff]"; +const rowClassName = + 'grid min-h-[75px] w-full grid-cols-1 gap-4 px-4 py-4 sm:px-[25px] md:grid-cols-2 md:items-center md:py-0'; +const fullRowClassName = + 'grid min-h-[75px] w-full grid-cols-1 gap-4 px-4 py-4 sm:px-[25px] md:items-center md:py-0'; +const fieldClassName = 'flex min-w-0 flex-col'; +const labelClassName = + "mb-1 font-['SourceSansPro-SemiBold'] text-sm text-[#0d1e38]"; +const controlClassName = + "flex min-h-[38px] min-w-0 flex-wrap items-center gap-x-1.5 gap-y-2 font-['SourceSansPro-Regular'] text-base text-[#335065]"; +const inputClassName = + "w-full rounded border border-[#cadbe3] bg-white px-2.5 py-2.5 font-['SourceSansPro-Regular'] text-base text-[#335065] outline-none placeholder:text-[#335065]/60"; +const editIconClassName = 'h-[22px] w-[22px] shrink-0 cursor-pointer text-[#335065]'; +const checkIconClassName = 'h-[22px] w-[22px] shrink-0 text-green-700'; +const checkTextClassName = + "select-none font-['SourceSansPro-Regular'] text-xs text-green-700"; +const inlineButtonClassName = + "rounded border border-[#6254ff] px-3 py-1.5 font-['SourceSansPro-SemiBold'] text-sm text-[#6254ff] transition-colors hover:bg-[#f0efff]"; + const Setting = () => { const { user } = useSelector((state) => state.auth); const dispatch = useDispatch(); @@ -61,6 +84,7 @@ const Setting = () => { e.preventDefault(); }; const handleUpdateProfile = async (e) => { + e.preventDefault(); try { const response = await axios.post('/api/user/update-profile', profile); if (response.data.successful) { @@ -137,14 +161,16 @@ const Setting = () => { return ( <> - +

sssssssssssss

-
-
-

Información de cuenta

+ +
+

Información de cuenta

-
-
-