Skip to content
This repository was archived by the owner on Mar 13, 2025. It is now read-only.

My Gigs 2nd Week PROD Release #172

Merged
merged 28 commits into from
Aug 10, 2021
Merged
Show file tree
Hide file tree
Changes from 1 commit
Commits
Show all changes
28 commits
Select commit Hold shift + click to select a range
182e489
UI Update finish
LieutenantRoger Jul 24, 2021
4e6396a
adjust duration
LieutenantRoger Jul 24, 2021
aa44583
ui optimize
LieutenantRoger Jul 24, 2021
e013a47
fix remark
LieutenantRoger Jul 24, 2021
f8fec69
field calculation
LieutenantRoger Jul 27, 2021
f2cd91a
agg API update
LieutenantRoger Jul 29, 2021
c0b1932
api adjustment
LieutenantRoger Jul 29, 2021
e995a6f
update swagger
LieutenantRoger Jul 29, 2021
a5fcd04
UI Update
LieutenantRoger Jul 29, 2021
4c918a1
Adjust icon
LieutenantRoger Jul 29, 2021
2389450
Merge branch 'gigs-new-ui' into gigs-filter
LieutenantRoger Jul 30, 2021
6993f97
sort completed and withdrawn
LieutenantRoger Jul 30, 2021
823e313
Merge branch 'gigs-new-ui' into gigs-filter
LieutenantRoger Jul 30, 2021
9e08983
fix: remark tooltip
LieutenantRoger Jul 30, 2021
910927b
cache data done
LieutenantRoger Jul 30, 2021
a66edc9
add badges
LieutenantRoger Jul 31, 2021
df8561a
fix: bucket selection
LieutenantRoger Jul 31, 2021
d4782b6
save page
LieutenantRoger Jul 31, 2021
5c628ec
cache data added
LieutenantRoger Jul 31, 2021
bec1856
restore per page
LieutenantRoger Jul 31, 2021
f075ce0
UI fix
LieutenantRoger Jul 31, 2021
a97504b
fix: empty text
LieutenantRoger Jul 31, 2021
8e81f9c
adjust the height
LieutenantRoger Aug 2, 2021
cb61638
restore ci
LieutenantRoger Aug 3, 2021
f4a6a81
clean up code
LieutenantRoger Aug 3, 2021
55bcac3
Merge pull request #171 from topcoder-platform/gigs-filter
LieutenantRoger Aug 5, 2021
8d922ce
handle unknown status
LieutenantRoger Aug 8, 2021
4d4d5c5
Merge pull request #173 from topcoder-platform/gigs-filter
LieutenantRoger Aug 8, 2021
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
Prev Previous commit
Next Next commit
UI Update
  • Loading branch information
LieutenantRoger committed Jul 29, 2021
commit a5fcd045f70d2915f2cd6ba7d8a26e26aa4e4678
22 changes: 0 additions & 22 deletions src/assets/images/company-logo.svg

This file was deleted.

67 changes: 0 additions & 67 deletions src/containers/MyGigs/JobListing/JobCard/JobDetail/index.jsx

This file was deleted.

71 changes: 0 additions & 71 deletions src/containers/MyGigs/JobListing/JobCard/JobDetail/styles.scss

This file was deleted.

128 changes: 70 additions & 58 deletions src/containers/MyGigs/JobListing/JobCard/index.jsx
Original file line number Diff line number Diff line change
@@ -1,12 +1,12 @@
import React, { useEffect, useRef, useState, useMemo } from "react";
import PT from "prop-types";
import ProgressBar from "./ProgressBar";
import JobDetail from "./JobDetail";
import Ribbon from "../../../../components/Ribbon";
import Button from "../../../../components/Button";
import IconChevronDown from "assets/icons/button-chevron-down.svg";
import ProgressTooltip from "./tooltips/ProgressTooltip";
import NoteTooltip from "./tooltips/NoteTooltip";
import EarnTooltip from "./tooltips/EarnTooltip";
import {
MY_GIG_PHASE_LABEL,
MY_GIG_PHASE_ACTION,
Expand All @@ -15,7 +15,9 @@ import {
MY_GIGS_STATUS_REMARK_TEXT,
} from "../../../../constants";
import { formatMoneyValue } from "../../../../utils";
import { getDateRange } from "../../../../utils/myGig";
import IconNote from "../../../../assets/icons/note.svg";
import IconInfo from "../../../../assets/icons/ribbon-icon.svg";

import "./styles.scss";

Expand Down Expand Up @@ -86,8 +88,49 @@ const JobCard = ({ job }) => {
{job.title}
</a>
</h4>
{job.status == MY_GIGS_JOB_STATUS.COMPLETED && (
<ul styleName="job-items">
<ul styleName="job-items">
<li>
<div styleName="job-item">
{MY_GIGS_JOB_STATUS.COMPLETED === job.status && (
<>
<div styleName="caption">Duration</div>
<div styleName="text">
{getDateRange(job.rbStartDate, job.rbEndDate)}
</div>
</>
)}
{MY_GIGS_JOB_STATUS.COMPLETED !== job.status && (
<>
<div styleName="caption">Payment Range</div>
<div styleName="text">{paymentInfo}</div>
</>
)}
</div>
</li>
<li>
<div styleName="job-item">
{MY_GIGS_JOB_STATUS.COMPLETED === job.status && (
<>
<div styleName="caption">
<span>Total Earnings</span>
<span styleName="earn-tip">
<EarnTooltip>
<IconInfo />
</EarnTooltip>
</span>
</div>
<div styleName="text">{`${job.currency}${job.paymentTotal}`}</div>
</>
)}
{MY_GIGS_JOB_STATUS.COMPLETED !== job.status && (
<>
<div styleName="caption">Location</div>
<div styleName="text">{job.location}</div>
</>
)}
</div>
</li>
{MY_GIGS_JOB_STATUS.COMPLETED !== job.status && (
<li>
<div styleName="job-item">
<div styleName="caption">Duration</div>
Expand All @@ -96,48 +139,24 @@ const JobCard = ({ job }) => {
</div>
</div>
</li>
</ul>
)}
{job.status !== MY_GIGS_JOB_STATUS.COMPLETED && (
<ul styleName="job-items">
<li>
<div styleName="job-item">
<div styleName="caption">Payment Range</div>
<div styleName="text">{paymentInfo}</div>
</div>
</li>
<li>
<div styleName="job-item">
<div styleName="caption">Location</div>
<div styleName="text">{job.location}</div>
</div>
</li>
<li>
<div styleName="job-item">
<div styleName="caption">Duration</div>
<div styleName="text">
{job.duration && `${job.duration} Weeks`}
</div>
)}
<li>
<div styleName="job-item">
<div styleName="caption">Hours</div>
<div styleName="text">
{job.hours && `${job.hours} hours / week`}
</div>
</li>
<li>
<div styleName="job-item">
<div styleName="caption">Hours</div>
<div styleName="text">
{job.hours && `${job.hours} hours / week`}
</div>
</div>
</li>
<li>
<div styleName="job-item">
<div styleName="caption">Working Hours</div>
<div styleName="text">
{job.workingHours && `${job.workingHours} hours`}
</div>
</li>
<li>
<div styleName="job-item">
<div styleName="caption">Working Hours</div>
<div styleName="text">
{job.workingHours && `${job.workingHours} hours`}
</div>
</div>
</li>
</ul>
)}
</div>
</li>
</ul>
</div>
<div
styleName={`right-side stand-by ${!job.phaseAction ? "none" : ""}`}
Expand Down Expand Up @@ -172,6 +191,7 @@ const JobCard = ({ job }) => {
{![
MY_GIGS_JOB_STATUS.JOB_CLOSED,
MY_GIGS_JOB_STATUS.REJECTED_OTHER,
MY_GIGS_JOB_STATUS.COMPLETED,
MY_GIGS_JOB_STATUS.WITHDRAWN,
MY_GIGS_JOB_STATUS.WITHDRAWN_PRESCREEN,
].includes(job.status) && (
Expand All @@ -194,28 +214,20 @@ const JobCard = ({ job }) => {
{![
MY_GIGS_JOB_STATUS.JOB_CLOSED,
MY_GIGS_JOB_STATUS.REJECTED_OTHER,
MY_GIGS_JOB_STATUS.COMPLETED,
MY_GIGS_JOB_STATUS.WITHDRAWN,
MY_GIGS_JOB_STATUS.WITHDRAWN_PRESCREEN,
].includes(job.status) && (
<div
styleName="progress-bar"
style={{ display: expanded ? "" : "none" }}
>
{MY_GIGS_JOB_STATUS.COMPLETED !== job.status && (
<ProgressBar
phases={PHASES_FOR_JOB_STATUS[job.status]}
currentPhase={job.phase}
currentPhaseStatus={job.phaseStatus}
note={job.phaseNote}
/>
)}
{MY_GIGS_JOB_STATUS.COMPLETED === job.status && (
<JobDetail
paymentInfo={paymentInfo}
hours={job.hours}
workingHours={job.workingHours}
/>
)}
<ProgressBar
phases={PHASES_FOR_JOB_STATUS[job.status]}
currentPhase={job.phase}
currentPhaseStatus={job.phaseStatus}
note={job.phaseNote}
/>
</div>
)}
</div>
Expand Down
13 changes: 13 additions & 0 deletions src/containers/MyGigs/JobListing/JobCard/styles.scss
Original file line number Diff line number Diff line change
Expand Up @@ -151,6 +151,19 @@
font-size: $font-size-xs;
color: $tc-gray-70;
line-height: $line-height-xs;

.earn-tip {
position: absolute;
line-height: 24px;

svg {
transform: scale(0.71);

path {
fill: currentColor
}
}
}
}

.text {
Expand Down
Original file line number Diff line number Diff line change
@@ -0,0 +1,25 @@
import React from "react";
import PT from "prop-types";
import Tooltip from "../../../../../../components/Tooltip";

import "./styles.scss";

const EarnTooltip = ({ children }) => {
const Content = () => (
<div styleName="earn-tooltip">
Amount may not reflect any pending payments
</div>
);

return (
<Tooltip overlay={<Content />} placement="bottom">
{children}
</Tooltip>
);
};

EarnTooltip.propTypes = {
children: PT.node,
};

export default EarnTooltip;
Loading