From 16c038aa2fd0b95a2da43c4af465840a1e52757b Mon Sep 17 00:00:00 2001 From: Maxim Kadushkin Date: Wed, 16 Dec 2020 00:18:16 +0300 Subject: [PATCH] [SSE mobile] correct cell editor --- .../mobile/src/less/app.less | 1 + .../mobile/src/less/celleditor.less | 79 +++++++++++++++++++ .../spreadsheeteditor/mobile/src/page/app.jsx | 14 ---- .../mobile/src/page/main.jsx | 15 +++- .../mobile/src/view/CellEditor.jsx | 30 ++++++- 5 files changed, 120 insertions(+), 19 deletions(-) create mode 100644 apps/spreadsheeteditor/mobile/src/less/celleditor.less diff --git a/apps/spreadsheeteditor/mobile/src/less/app.less b/apps/spreadsheeteditor/mobile/src/less/app.less index 8660dc330..00f6e282f 100644 --- a/apps/spreadsheeteditor/mobile/src/less/app.less +++ b/apps/spreadsheeteditor/mobile/src/less/app.less @@ -11,6 +11,7 @@ @import './icons-ios.less'; @import './icons-material.less'; @import './icons-common.less'; +@import './celleditor.less'; .page[data-name='home'] { .page-content { diff --git a/apps/spreadsheeteditor/mobile/src/less/celleditor.less b/apps/spreadsheeteditor/mobile/src/less/celleditor.less new file mode 100644 index 000000000..fbb524834 --- /dev/null +++ b/apps/spreadsheeteditor/mobile/src/less/celleditor.less @@ -0,0 +1,79 @@ + +@cellEditorHeight: 30px; +@cellEditorExpandedHeight: 70px; +@contentBackColor: #fff; +@gray-light: #f1f1f1; + +#idx-celleditor { + display: flex; + + height: @cellEditorHeight; + min-height: @cellEditorHeight; + background-color: @contentBackColor; + + &.expanded { + min-height: @cellEditorExpandedHeight; + //height: @cellEditorExpandedHeight; + transition: min-height .1s; + } + + &:after { + content: ''; + position: absolute; + background-color: var(--f7-navbar-border-color, var(--f7-bars-border-color)); + display: block; + z-index: 15; + top: auto; + right: auto; + bottom: 0; + left: 0; + height: 1px; + width: 100%; + transform-origin: 50% 100%; + transform: scaleY(calc(1 / var(--f7-device-pixel-ratio))); + } + + #box-cell-name { + background-color: var(--f7-navbar-bg-color); + } + + #ce-cell-content { + padding: 3px 3px; + line-height: 1.428571429; + color: #000; + vertical-align: middle; + background-color: @contentBackColor; + min-height: @cellEditorHeight; + height: 100%; + width: 100%; + } + + .caret { + &::after { + content: ''; + position: absolute; + top: 8px; + left: 6px; + width: 8px; + height: 8px; + background-color: transparent; + border: solid 1px black; + border-bottom: none; + border-right: none; + + transition: transform 0.2s ease; + transform: rotate(-135deg); + } + + width: 30px; + height: 16px; + } + + &.expanded { + .caret { + &::after { + transform: rotate(45deg) translate(3px, 3px); + } + } + } +} diff --git a/apps/spreadsheeteditor/mobile/src/page/app.jsx b/apps/spreadsheeteditor/mobile/src/page/app.jsx index 1e94000e5..73d2b5329 100644 --- a/apps/spreadsheeteditor/mobile/src/page/app.jsx +++ b/apps/spreadsheeteditor/mobile/src/page/app.jsx @@ -34,20 +34,6 @@ export default class extends React.Component { {/* Your main view, should have "view-main" class */} - {/* Top Navbar */} - - {/*
*/} - - - - - - this.handleClickToOpenOptions('edit')}> - this.handleClickToOpenOptions('coauth')}> - this.handleClickToOpenOptions('settings')}> - -
- {/**/}
diff --git a/apps/spreadsheeteditor/mobile/src/page/main.jsx b/apps/spreadsheeteditor/mobile/src/page/main.jsx index f38826548..0d648d522 100644 --- a/apps/spreadsheeteditor/mobile/src/page/main.jsx +++ b/apps/spreadsheeteditor/mobile/src/page/main.jsx @@ -48,7 +48,20 @@ export default class MainPage extends Component { render() { return ( - {/**/} + {/* Top Navbar */} + + {/*
*/} + + + + + + this.handleClickToOpenOptions('edit')}> + this.handleClickToOpenOptions('coauth')}> + this.handleClickToOpenOptions('settings')}> + +
+ {/* Page content */} {/*{*/} diff --git a/apps/spreadsheeteditor/mobile/src/view/CellEditor.jsx b/apps/spreadsheeteditor/mobile/src/view/CellEditor.jsx index 17f225209..68d939427 100644 --- a/apps/spreadsheeteditor/mobile/src/view/CellEditor.jsx +++ b/apps/spreadsheeteditor/mobile/src/view/CellEditor.jsx @@ -1,10 +1,32 @@ -import React from 'react'; -import { Input, View } from 'framework7-react'; +import React, { useState } from 'react'; +import { Input, View, Button, Link } from 'framework7-react'; + +const viewStyle = { + height: 30 +}; + +const contentStyle = { + flexGrow: 1 +}; const CellEditorView = props => { - return - + const [expanded, setExpanded] = useState(false); + + const expandClick = e => { + setExpanded(!expanded); + }; + + return +
+ F(x) +
+
+ +
+
+ +
; };