aboutsummaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authoranika-ahluwalia <anika.ahluwalia@gmail.com>2020-08-05 22:25:24 -0500
committeranika-ahluwalia <anika.ahluwalia@gmail.com>2020-08-05 22:25:24 -0500
commitea855ecda2c3df9e5d0881d43e2fdbceb9dccafc (patch)
treef119e93c8e5eccd5a580213efaa18dac47a59c06 /src
parent50ddaaab31351ad277fbd2ebb4405a99a721a536 (diff)
finishing touches on settings
Diffstat (limited to 'src')
-rw-r--r--src/client/util/SettingsManager.scss30
-rw-r--r--src/client/util/SettingsManager.tsx78
2 files changed, 87 insertions, 21 deletions
diff --git a/src/client/util/SettingsManager.scss b/src/client/util/SettingsManager.scss
index 41bce8a1b..2d0fb4e95 100644
--- a/src/client/util/SettingsManager.scss
+++ b/src/client/util/SettingsManager.scss
@@ -30,10 +30,36 @@
}
.settings-username {
- font-size: 14px;
+ font-size: 12px;
padding-right: 15px;
color: black;
- margin-top: 10px;
+ margin-top: 4px;
+ /* right: 135; */
+ position: absolute;
+ left: 235;
+}
+
+.grey-submit {
+ width: 71.1875px;
+ align-self: center;
+ background: #75787c;
+ outline: none;
+ border-radius: 5px;
+ border: 0px;
+ color: #fcfbf7;
+ text-transform: uppercase;
+ letter-spacing: 2px;
+ font-size: 75%;
+ padding: 10px;
+ transition: transform 0.2s;
+ margin: 2px;
+ margin-left: 85px;
+ height: 32px;
+
+ &:hover {
+ cursor: not-allowed;
+ }
+
}
.settings-section {
diff --git a/src/client/util/SettingsManager.tsx b/src/client/util/SettingsManager.tsx
index 68ed32c0f..155c7f60c 100644
--- a/src/client/util/SettingsManager.tsx
+++ b/src/client/util/SettingsManager.tsx
@@ -39,6 +39,9 @@ export default class SettingsManager extends React.Component<{}> {
private new_password_ref = React.createRef<HTMLInputElement>();
private new_confirm_ref = React.createRef<HTMLInputElement>();
+ @observable private curr_password: string = "";
+ @observable private new_password: string = "";
+ @observable private new_confirm: string = "";
@computed get backgroundColor() { return Doc.UserDoc().defaultColor; }
@@ -142,25 +145,44 @@ export default class SettingsManager extends React.Component<{}> {
return true;
}
- private get settingsInterface() {
+ @computed get allowSubmit() {
+ return this.curr_password.length > 3 &&
+ this.new_password.length > 3 &&
+ this.new_confirm.length > 3 && this.new_confirm === this.new_password &&
+ this.new_password !== this.curr_password ? true : false;
+ }
+ @action
+ changeVal = (e: any, pass: string) => {
+ if (pass === "curr") {
+ this.curr_password = e.target.value;
+ } else if (pass === "new") {
+ this.new_password = e.target.value;
+ } else if (pass === "conf") {
+ this.new_confirm = e.target.value;
+ }
+ }
- const passwordContent = <div className="password-content">
+ @computed get passwordContent() {
+ return <div className="password-content">
<div className="password-content-inputs">
- <input className="password-inputs" type="password" placeholder="current password" ref={this.curr_password_ref} />
- <input className="password-inputs" type="password" placeholder="new password" ref={this.new_password_ref} />
- <input className="password-inputs" type="password" placeholder="confirm new password" ref={this.new_confirm_ref} />
+ <input className="password-inputs" type="password" placeholder="current password" onChange={e => this.changeVal(e, "curr")} ref={this.curr_password_ref} />
+ <input className="password-inputs" type="password" placeholder="new password" onChange={e => this.changeVal(e, "new")} ref={this.new_password_ref} />
+ <input className="password-inputs" type="password" placeholder="confirm new password" onChange={e => this.changeVal(e, "conf")} ref={this.new_confirm_ref} />
</div>
<div className="password-content-buttons">
{this.errorText ? <div className="error-text">{this.errorText}</div> : undefined}
{this.successText ? <div className="success-text">{this.successText}</div> : undefined}
- <button className="password-submit" onClick={this.dispatchRequest}>submit</button>
+ {this.allowSubmit ? <button className="password-submit"
+ onClick={this.dispatchRequest}>submit</button> : <div className="grey-submit"> submit </div>}
<a className="password-forgot" style={{ marginLeft: 65, marginTop: -20 }}
href="/forgotPassword">forgot password?</a>
</div>
</div>;
+ }
- const modesContent = <div className="modes-content">
+ @computed get modesContent() {
+ return <div className="modes-content">
<select className="modes-select"
onChange={e => this.changeMode(e)}>
<option key={"Novice"} value={"Novice"} selected={BoolCast(Doc.UserDoc().noviceMode)}>
@@ -177,22 +199,28 @@ export default class SettingsManager extends React.Component<{}> {
/><div className="playground-text">Playground Mode</div>
</div>
</div>;
+ }
- const accountsContent = <div className="accounts-content">
+ @computed get accountsContent() {
+ return <div className="accounts-content">
<button onClick={this.googleAuthorize} value="data">{`Link to Google`}</button>
<button onClick={this.hypothesisAuthorize} value="data">{`Link to Hypothes.is`}</button>
<button onClick={() => GroupManager.Instance.open()}>Manage groups</button>
</div>;
+ }
- const colorBox = <SketchPicker onChange={this.switchColor}
+ @computed get colorBox() {
+ return <SketchPicker onChange={this.switchColor}
presetColors={['#D0021B', '#F5A623', '#F8E71C', '#8B572A', '#7ED321', '#417505',
'#9013FE', '#4A90E2', '#50E3C2', '#B8E986', '#000000', '#4A4A4A', '#9B9B9B',
'#FFFFFF', '#f1efeb', 'transparent']}
color={StrCast(this.backgroundColor)} />;
+ }
- const colorFlyout = <div className="colorFlyout">
+ @computed get colorFlyout() {
+ return <div className="colorFlyout">
<Flyout anchorPoint={anchorPoints.LEFT_TOP}
- content={colorBox}>
+ content={this.colorBox}>
<div>
<div className="colorFlyout-button" style={{ backgroundColor: StrCast(this.backgroundColor) }}
onPointerDown={e => e.stopPropagation()} >
@@ -201,13 +229,15 @@ export default class SettingsManager extends React.Component<{}> {
</div>
</Flyout>
</div>;
+ }
+ @computed get preferencesContent() {
const fontFamilies: string[] = ["Times New Roman", "Arial", "Georgia", "Comic Sans MS", "Tahoma", "Impact", "Crimson Text"];
const fontSizes: string[] = ["7pt", "8pt", "9pt", "10pt", "12pt", "14pt", "16pt", "18pt", "20pt", "24pt", "32pt", "48pt", "72pt"];
const preferencesContent = <div className="preferences-content">
<div className="preferences-color">
- <div className="preferences-color-text">Background Color</div> {colorFlyout}
+ <div className="preferences-color-text">Background Color</div> {this.colorFlyout}
</div>
<div className="preferences-font">
<div className="preferences-font-text">Default Font</div>
@@ -227,15 +257,25 @@ export default class SettingsManager extends React.Component<{}> {
</option>;
})}
</select>
- </div>
+ </div>;
</div>;
+ return preferencesContent;
+ }
+
+
+ @computed private get settingsInterface() {
+
return (<div className="settings-interface">
<div className="settings-top">
<div className="settings-title">Settings</div>
- <div className="settings-username">{Doc.CurrentUserEmail}</div>
+ <div className="settings-username">
+ <div style={{ fontSize: 9 }}> Signed in as: </div>
+ <div> {Doc.CurrentUserEmail}</div>
+ </div>
<button onClick={() => window.location.assign(Utils.prepend("/logout"))}
- style={{ right: 35, position: "absolute" }} >
+ //style={{ right: 35, position: "absolute" }} >
+ style={{ left: 137, position: "absolute" }} >
{CurrentUserUtils.GuestWorkspace ? "Exit" : "Log Out"}
</button>
<div className="close-button" onClick={this.close}>
@@ -245,19 +285,19 @@ export default class SettingsManager extends React.Component<{}> {
<div className="settings-content">
<div className="settings-section">
<div className="settings-section-title">Password</div>
- <div className="settings-section-context">{passwordContent}</div>
+ <div className="settings-section-context">{this.passwordContent}</div>
</div>
<div className="settings-section">
<div className="settings-section-title">Modes</div>
- <div className="settings-section-context">{modesContent}</div>
+ <div className="settings-section-context">{this.modesContent}</div>
</div>
<div className="settings-section">
<div className="settings-section-title">Accounts</div>
- <div className="settings-section-context">{accountsContent}</div>
+ <div className="settings-section-context">{this.accountsContent}</div>
</div>
<div className="settings-section" style={{ paddingBottom: 4 }}>
<div className="settings-section-title">Preferences</div>
- <div className="settings-section-context">{preferencesContent}</div>
+ <div className="settings-section-context">{this.preferencesContent}</div>
</div>
</div>
</div>);