Browse Source

Privacy mockup

master
Eduard Kuzmenko 3 years ago
parent
commit
62417fbcb2
  1. 1
      src/components/row.ts
  2. 2
      src/components/sidebarLeft/index.ts
  3. 2
      src/components/sidebarLeft/tabs/privacy/addToGroups.ts
  4. 4
      src/components/sidebarLeft/tabs/privacyAndSecurity.ts
  5. 11
      src/scss/partials/_checkbox.scss
  6. 60
      src/scss/partials/_leftSidebar.scss
  7. 8
      src/scss/style.scss

1
src/components/row.ts

@ -55,6 +55,7 @@ export default class Row {
if(options.icon) { if(options.icon) {
havePadding = true; havePadding = true;
this.title.classList.add('tgico', 'tgico-' + options.icon); this.title.classList.add('tgico', 'tgico-' + options.icon);
this.container.classList.add('row-with-icon');
} }
} }

2
src/components/sidebarLeft/index.ts

@ -419,6 +419,8 @@ export class SettingSection {
if(!options.noDelimiter) { if(!options.noDelimiter) {
const hr = document.createElement('hr'); const hr = document.createElement('hr');
this.container.append(hr); this.container.append(hr);
} else {
this.container.classList.add('no-delimiter');
} }
this.content = this.generateContentElement(); this.content = this.generateContentElement();

2
src/components/sidebarLeft/tabs/privacy/addToGroups.ts

@ -10,7 +10,7 @@ export default class AppPrivacyAddToGroupsTab extends SliderSuperTabEventable {
new PrivacySection({ new PrivacySection({
tab: this, tab: this,
title: 'Who can add me to group chats?', title: 'Who can add me to group chats?',
inputKey: 'inputPrivacyKeyForwards', inputKey: 'inputPrivacyKeyChatInvite',
captions: [caption, caption, caption], captions: [caption, caption, caption],
exceptionTexts: ['Never Allow', 'Always Allow'], exceptionTexts: ['Never Allow', 'Always Allow'],
appendTo: this.scrollable appendTo: this.scrollable

4
src/components/sidebarLeft/tabs/privacyAndSecurity.ts

@ -80,6 +80,8 @@ export default class AppPrivacyAndSecurityTab extends SliderSuperTab {
{ {
const container = section('Privacy'); const container = section('Privacy');
container.classList.add('privacy-navigation-container');
const rowsByKeys: Partial<{ const rowsByKeys: Partial<{
[key in InputPrivacyKey['_']]: Row [key in InputPrivacyKey['_']]: Row
}> = {}; }> = {};
@ -144,7 +146,7 @@ export default class AppPrivacyAndSecurityTab extends SliderSuperTab {
}); });
} }
container.append(numberVisibilityRow.container, lastSeenTimeRow.container, photoVisibilityRow.container, callRow.container, linkAccountRow.container, groupChatsAddRow.container); container.append(numberVisibilityRow.container, lastSeenTimeRow.container, photoVisibilityRow.container,/* callRow.container, */linkAccountRow.container, groupChatsAddRow.container);
} }
} }
} }

11
src/scss/partials/_checkbox.scss

@ -113,7 +113,7 @@
position: relative; position: relative;
text-align: left; text-align: left;
margin: 1.25rem 0; margin: 1.25rem 0;
line-height: 1.5rem; line-height: 1.3125; // omg it centers the text
cursor: pointer; cursor: pointer;
&.hidden-widget { &.hidden-widget {
@ -134,7 +134,7 @@
} }
&::after { &::after {
opacity: 1; transform: translateY(-50%) scale(1);
} }
} }
} }
@ -161,7 +161,7 @@
} }
&::before { &::before {
border: 2px solid #8d969c; border: 2px solid #707579;
border-radius: 50%; border-radius: 50%;
background-color: white; background-color: white;
opacity: 1; opacity: 1;
@ -174,8 +174,9 @@
height: .625rem; height: .625rem;
border-radius: 50%; border-radius: 50%;
background: $button-primary-background; background: $button-primary-background;
opacity: 0; transform: translateY(-50%) scale(0);
transition: opacity .1s ease; transform-origin: center;
transition: transform .1s ease;
} }
/* &-subtitle { /* &-subtitle {

60
src/scss/partials/_leftSidebar.scss

@ -865,7 +865,7 @@
margin: 0; margin: 0;
} }
&:first-child { &:first-child:not(.no-delimiter) {
padding-top: 0; padding-top: 0;
} }
@ -903,14 +903,20 @@
} }
.two-step-verification { .two-step-verification {
.sidebar-left-section-caption { // * main tab verified with mockup .sidebar-left-section { // * main tab verified with mockup
text-align: center; &:first-child { // ! refactor is needed
max-width: 342px; padding-top: 0;
margin-left: auto; }
margin-right: auto;
font-size: 1rem; &-caption {
line-height: 1.3125; text-align: center;
margin-bottom: 1.125rem; max-width: 342px;
margin-left: auto;
margin-right: auto;
font-size: 1rem;
line-height: 1.3125;
margin-bottom: 1.125rem;
}
} }
&-main { &-main {
@ -970,6 +976,42 @@
} }
} }
.privacy-container {
.sidebar-left-section:first-child {
padding-bottom: .1875rem;
}
/* .privacy-navigation-container {
.sidebar-left-section-name + .row {
margin-top: -5px; // ! just to match mockup.
}
} */
}
.privacy-tab {
.sidebar-left-section-caption { // * Last Seen & Online verified with mockup
font-size: 1rem;
line-height: 1.3125;
}
// * just to match mockup
.sidebar-left-section:first-child {
padding-bottom: 1.125rem;
}
form {
padding: .0625rem 0 .125rem;
}
form .row {
&:first-child {
margin-top: 0;
}
margin-top: .125rem;
}
}
.range-setting-selector { .range-setting-selector {
padding: 1rem .875rem; padding: 1rem .875rem;

8
src/scss/style.scss

@ -1092,17 +1092,21 @@ middle-ellipsis-element {
min-height: 3.375rem; min-height: 3.375rem;
margin-top: .5rem; margin-top: .5rem;
position: relative; position: relative;
padding: .5rem .75rem; padding: .6875rem .875rem;
display: flex; display: flex;
flex-direction: column; flex-direction: column;
justify-content: center; justify-content: center;
&-title {
line-height: 1.3125;
}
&-with-padding { &-with-padding {
padding-left: 4.375rem; padding-left: 4.375rem;
.row-title.tgico:before { .row-title.tgico:before {
position: absolute; position: absolute;
left: .75rem; left: .875rem;
font-size: 1.5rem; font-size: 1.5rem;
color: #707579; color: #707579;
} }

Loading…
Cancel
Save