From 074c1a4468050463a234674995922921fb40ebff Mon Sep 17 00:00:00 2001 From: jljsj Date: Tue, 19 Nov 2019 15:03:15 +0800 Subject: [PATCH 1/2] update edit history --- .../NavController/HistoryButton.jsx | 39 ++++++-------- .../components/NavController/index.jsx | 7 +-- site/edit/template/layout.jsx | 6 +-- site/shared/localStorage.js | 48 ----------------- site/shared/redux/actionTypes.js | 4 ++ site/shared/redux/actions.js | 15 ++++++ site/shared/redux/reducers/historyEdit.js | 24 +++++++++ site/shared/redux/reducers/index.js | 2 + site/shared/redux/saga.js | 51 +++++++++++++++---- site/shared/utils.js | 2 - .../template/element/Footer1/index.less | 14 ++--- 11 files changed, 112 insertions(+), 100 deletions(-) create mode 100644 site/shared/redux/reducers/historyEdit.js diff --git a/site/edit/template/components/NavController/HistoryButton.jsx b/site/edit/template/components/NavController/HistoryButton.jsx index 53ace233..b39e9da1 100644 --- a/site/edit/template/components/NavController/HistoryButton.jsx +++ b/site/edit/template/components/NavController/HistoryButton.jsx @@ -3,39 +3,33 @@ import { Tooltip, Icon } from 'antd'; import { FormattedMessage } from 'react-intl'; import classnames from 'classnames'; import { connect } from 'react-redux'; - -import { objectEqual } from '../../../../utils'; -import { getHistory, getCurrentData } from '../../../../shared/localStorage'; +import { mapStateToProps } from '../../../../shared/utils'; import * as actions from '../../../../shared/redux/actions'; class HistoryButton extends React.Component { - getCurrentDataIndex = (data) => { - return data.findIndex((item) => { - return objectEqual(item, getCurrentData()); - }); - } + currentHistory = 0; onHistoryClick = (num, e) => { if (e) { e.target.focus(); } - - const history = getHistory(); - const current = this.getCurrentDataIndex(history); - if ((!current && num === -1) || (current >= history.length - 1 && num === 1)) { + const { currentEditData, dispatch, historyEdit: { num: historyNum, history } } = this.props; + const { reRect } = currentEditData || {}; + let currentHistory = historyNum; + currentHistory -= num; + if ((!currentHistory && num === -1) || (currentHistory >= history.length - 1 && num === 1)) { return; } - const currentData = history[current + num]; - - const { reRect, dispatch } = this.props; + dispatch(actions.setCurrentHistoryNum(currentHistory)); + const currentData = history[currentHistory]; dispatch(actions.setTemplateData({ data: currentData.attributes, uid: currentData.id, - date: currentData.date, noHistory: 'handle', })); + if (reRect) { reRect(); } @@ -62,16 +56,15 @@ class HistoryButton extends React.Component { } render() { - const history = getHistory(); - const undoBool = history.length > 1 && this.getCurrentDataIndex(history) > 0; + const { historyEdit: { num: currentHistory, history } } = this.props; + const undoClassName = classnames('undo', { - disabled: !undoBool, + disabled: currentHistory >= history.length - 1, }); - const redoBool = history.length > 1 && history.length - 1 - this.getCurrentDataIndex(history) > 0; const redoClassName = classnames('redo', { - disabled: !redoBool, + disabled: !currentHistory, }); - + console.log(this.props); return ( - + } visible={codeModalShow} diff --git a/site/edit/template/layout.jsx b/site/edit/template/layout.jsx index 0c32ec8f..356584e4 100644 --- a/site/edit/template/layout.jsx +++ b/site/edit/template/layout.jsx @@ -1,5 +1,5 @@ import React from 'react'; -import { Icon, message, Button, Input, Form, notification } from 'antd'; +import { Icon, message, Button, Input, Form } from 'antd'; import { connect } from 'react-redux'; import { FormattedMessage, injectIntl } from 'react-intl'; @@ -31,7 +31,7 @@ class Layout extends React.PureComponent { } componentDidMount() { - notification.open({ + /* notification.open({ placement: 'bottomRight', duration: null, message: this.props.intl.formatMessage({ id: 'app.layout.notification.title' }), @@ -40,7 +40,7 @@ class Layout extends React.PureComponent { {this.props.intl.formatMessage({ id: 'app.layout.notification.content' })} ), - }); + }); */ } componentDidUpdate() { diff --git a/site/shared/localStorage.js b/site/shared/localStorage.js index 8299b7e7..28910b13 100644 --- a/site/shared/localStorage.js +++ b/site/shared/localStorage.js @@ -1,10 +1,5 @@ import store from 'store'; -import { objectEqual } from '../utils'; - -export const LOCAL_STORAGE_HISTORY_KEY = 'ant-design-landing-record'; -export const LOCAL_STORAGE_CURRENT_DATA_KEY = 'ant-design-landing-current'; - /** * Auth */ @@ -55,46 +50,3 @@ export function saveTemplate(template) { export function removeTemplate(tid) { store.remove(tid); } - - -/** - * History - */ - -export const getHistory = () => store.get(LOCAL_STORAGE_HISTORY_KEY, []); - -// TODO: why 30? -export const pushToHistory = (data) => { - const history = getHistory(); - if (history.length >= 15) { - history.shift(); - } - history.push(data); - - store.set(LOCAL_STORAGE_HISTORY_KEY, history); -}; - -export const removeHistoryAfter = (data) => { - const history = getHistory(); - - const index = history.findIndex(c => objectEqual(c, data)); - if (index === -1) { - return; - } - - store.set(LOCAL_STORAGE_HISTORY_KEY, history.slice(0, index + 1)); -}; - -export const resetHistory = () => { - store.set(LOCAL_STORAGE_HISTORY_KEY, []); -}; - -/** - * CurrentData - */ - -export const saveCurrentData = (data) => { - store.set(LOCAL_STORAGE_CURRENT_DATA_KEY, data); -}; - -export const getCurrentData = () => store.get(LOCAL_STORAGE_CURRENT_DATA_KEY, {}); diff --git a/site/shared/redux/actionTypes.js b/site/shared/redux/actionTypes.js index dd31b8da..7a179d3b 100644 --- a/site/shared/redux/actionTypes.js +++ b/site/shared/redux/actionTypes.js @@ -3,6 +3,7 @@ export const CREATE_NEW_TEMPLATE = '[landing] CREATE_NEW_TEMPLATE'; export const SET_TEMPLATE_DATA = '[landing] SET_TEMPLATE_DATA'; export const CHANGE_CHILD = '[landing] CHANGE_CHILD'; export const SET_USER_AND_TEMPLATE_DATA = '[landing] SET_USER_AND_TEMPLATE_DATA'; +export const UPDATE_HISTORY = '[landing] UPDATE_HISTORY'; export const POST_TYPE = { POST_DEFAULT: '[landing] default', @@ -13,5 +14,8 @@ export const POST_TYPE = { SET_EDIT: '[landing] setEdit', SET_MEDIA: '[landing] setMedia', SET_USER: '[landing] setUser', + SET_HISTORY_NUM: '[landing] setHistoryNum', + UPDATE_HISTORY_RE_NUM: '[landing] updateHistoryReNum', + SAVE_HISTORY: '[landing] saveHistory', SET_USERTEMPLATE: '[landing] setUserTemplate', }; diff --git a/site/shared/redux/actions.js b/site/shared/redux/actions.js index 5b1537cd..ec2951b9 100644 --- a/site/shared/redux/actions.js +++ b/site/shared/redux/actions.js @@ -47,3 +47,18 @@ export const setUserData = (data) => { data, }; }; + +// 记录 history 步数; +export const setCurrentHistoryNum = (data) => { + return { + type: POST_TYPE.SET_HISTORY_NUM, + data, + }; +}; +// 删除之前,保存当前的 +export const updateHistoryReNum = (data) => { + return { + type: POST_TYPE.UPDATE_HISTORY_RE_NUM, + data, + }; +}; diff --git a/site/shared/redux/reducers/historyEdit.js b/site/shared/redux/reducers/historyEdit.js new file mode 100644 index 00000000..84ad094d --- /dev/null +++ b/site/shared/redux/reducers/historyEdit.js @@ -0,0 +1,24 @@ +import { POST_TYPE } from '../actionTypes'; + +export default function historyEdit(state, action) { + switch (action.type) { + case POST_TYPE.SET_HISTORY_NUM: + console.log('num', action.data); + return { + ...state, + num: action.data, + }; + case POST_TYPE.UPDATE_HISTORY_RE_NUM: + return { + num: 0, + history: (state.num + ? [action.data, ...state.history.filter((c, i) => i >= state.num && c)] + : [action.data, ...state.history]).filter((c, i) => i < 30 && c), // 只记录30步 + }; + default: + return state || { + num: 0, + history: [], + }; + } +} diff --git a/site/shared/redux/reducers/index.js b/site/shared/redux/reducers/index.js index e9c97981..59e2ff5d 100644 --- a/site/shared/redux/reducers/index.js +++ b/site/shared/redux/reducers/index.js @@ -3,12 +3,14 @@ import templateData from './templateData'; import currentEditData from './currentEditData'; import mediaStateSelect from './mediaStateSelect'; import userIsLogin from './userIsLogin'; +import historyEdit from './historyEdit'; const reducer = combineReducers({ templateData, currentEditData, mediaStateSelect, userIsLogin, + historyEdit, }); export default reducer; diff --git a/site/shared/redux/saga.js b/site/shared/redux/saga.js index 4d36f3cd..7fb426ab 100644 --- a/site/shared/redux/saga.js +++ b/site/shared/redux/saga.js @@ -2,7 +2,7 @@ import { takeEvery, put } from '@redux-saga/core/effects'; import * as r from 'ramda'; -import { GET_USER_DATA, POST_TYPE, CREATE_NEW_TEMPLATE, SET_TEMPLATE_DATA, CHANGE_CHILD, SET_USER_AND_TEMPLATE_DATA } from './actionTypes'; +import { GET_USER_DATA, POST_TYPE, CREATE_NEW_TEMPLATE, SET_TEMPLATE_DATA, CHANGE_CHILD, SET_USER_AND_TEMPLATE_DATA, UPDATE_HISTORY } from './actionTypes'; import * as actions from './actions'; import * as url from '../url'; @@ -18,8 +18,6 @@ let getUserDataErrorCount = 0; function* handleGetUserData(action) { const { data } = action; - ls.resetHistory(); - const { uid: hash, cloneId, previewId } = url.get(); if (previewId) { @@ -70,9 +68,10 @@ function* handleGetUserData(action) { }); // 没进 dataToLocalStorage, 手动 push history; - localTemplate.date = localTemplate.date || Date.now(); - ls.saveCurrentData(localTemplate); - ls.pushToHistory(localTemplate); + yield put({ + type: UPDATE_HISTORY, + data: localTemplate, + }); return; } @@ -88,6 +87,11 @@ function* handleGetUserData(action) { saveTemplateToLocalStorage(DEFAULT_USER_NAME, template); + yield put({ + type: UPDATE_HISTORY, + data: template, + }); + yield put({ type: POST_TYPE.POST_SUCCESS, templateData: ls.getTemplate(uid), @@ -123,6 +127,10 @@ function* handleCreateNewTemplate(action) { const { data } = action; try { const template = yield newTemplate(DEFAULT_USER_NAME, data); + yield put({ + type: UPDATE_HISTORY, + data: template, + }); yield put({ type: POST_TYPE.POST_SUCCESS, templateData: template, @@ -133,9 +141,14 @@ function* handleCreateNewTemplate(action) { } function* handleSetTemplateData(action) { - const { data: { uid: id, data: attributes, date, noHistory } } = action; - - saveTemplateToLocalStorage(DEFAULT_USER_NAME, { id, attributes, date, noHistory }); + const { data: { uid: id, data: attributes, noHistory } } = action; + const data = { id, attributes, noHistory }; + saveTemplateToLocalStorage(DEFAULT_USER_NAME, data); + console.log(noHistory); + yield put({ + type: UPDATE_HISTORY, + data, + }); yield put({ type: POST_TYPE.SET_TEMPLATE, @@ -152,22 +165,38 @@ function* handleChangeChild(action) { function* handleSetUserAndTemplateData(action) { const { data } = action; - - saveTemplateToLocalStorage(DEFAULT_USER_NAME, { + const d = { id: data.templateData.uid, attributes: data.templateData.data, + }; + saveTemplateToLocalStorage(DEFAULT_USER_NAME, d); + yield put({ + type: UPDATE_HISTORY, + data: d, }); + yield put({ type: POST_TYPE.SET_USERTEMPLATE, data, }); } +function* handleUpdateHistory(action, state) { + console.log(action, state); + const { data: template } = action; + const { noHistory } = template; + if (!noHistory) { + delete template.noHistory; + yield put(actions.updateHistoryReNum(template)); + } +} + export default function* () { yield takeEvery(GET_USER_DATA, handleGetUserData); yield takeEvery(CREATE_NEW_TEMPLATE, handleCreateNewTemplate); yield takeEvery(SET_TEMPLATE_DATA, handleSetTemplateData); yield takeEvery(CHANGE_CHILD, handleChangeChild); yield takeEvery(SET_USER_AND_TEMPLATE_DATA, handleSetUserAndTemplateData); + yield takeEvery(UPDATE_HISTORY, handleUpdateHistory); } diff --git a/site/shared/utils.js b/site/shared/utils.js index 4e455f42..3d2a6660 100644 --- a/site/shared/utils.js +++ b/site/shared/utils.js @@ -110,8 +110,6 @@ export function saveTemplateToLocalStorage(uid, template) { if (!templateIdsInLocalStorage.some(anId => anId === id)) { ls.unshiftToUserTemplateIds(uid, id); } - - updateHistory(template); } export function removeTemplate(key) { diff --git a/site/templates/template/element/Footer1/index.less b/site/templates/template/element/Footer1/index.less index 4cf20b2d..71a82b66 100644 --- a/site/templates/template/element/Footer1/index.less +++ b/site/templates/template/element/Footer1/index.less @@ -23,13 +23,13 @@ margin-bottom: 24px; color: @template-text-color; } - >div { - line-height: 24px; - a { - color: @template-footer-text-color; - &:hover { - color: @primary-color; - } + a { + color: @template-footer-text-color; + margin-bottom: 12px; + float: left; + clear: both; + &:hover { + color: @primary-color; } } } From 259a074f9c928e9d6d9f2a302f29ec20cc2ad349 Mon Sep 17 00:00:00 2001 From: jljsj Date: Wed, 20 Nov 2019 21:34:58 +0800 Subject: [PATCH 2/2] update history and editor-list, #156 --- package.json | 2 +- site/edit/en-US.js | 4 +-- .../components/ListComponents/EditorComp.jsx | 3 ++- .../NavController/HistoryButton.jsx | 1 - site/edit/template/layout.jsx | 26 +++++++++++-------- site/edit/zh-CN.js | 4 +-- site/shared/redux/saga.js | 4 +-- 7 files changed, 23 insertions(+), 21 deletions(-) diff --git a/package.json b/package.json index ee258559..67b87646 100644 --- a/package.json +++ b/package.json @@ -1,6 +1,6 @@ { "name": "landing", - "version": "3.0.0", + "version": "3.0.1", "title": "Landing Pages", "description": "site of Landing Pages", "homepage": "http://landing.ant.design/", diff --git a/site/edit/en-US.js b/site/edit/en-US.js index 005f1cab..16857fa0 100644 --- a/site/edit/en-US.js +++ b/site/edit/en-US.js @@ -123,7 +123,7 @@ module.exports = { 'app.login.title': 'This page is locked. Please enter your password.', 'app.login.noPassword': 'If you don\'t know the password, please delete current page or create a new page', 'app.login.new': 'New Page', - 'app.layout.notification.title': '3.0 Release Notes', - 'app.layout.notification.content': '3.0 has been officially released. As we have made some adjustments to some templates, if your previously edited templates can not be displayed, please re-edit the new page.', + 'app.layout.notification.title': 'Editor update description', + 'app.layout.notification.content': 'In order to improve the performance and experience of editing, the style editing is currently triggered by pressing enter or leaving the input box.', }, }; diff --git a/site/edit/template/components/ListComponents/EditorComp.jsx b/site/edit/template/components/ListComponents/EditorComp.jsx index f99cd215..c205ca22 100644 --- a/site/edit/template/components/ListComponents/EditorComp.jsx +++ b/site/edit/template/components/ListComponents/EditorComp.jsx @@ -20,7 +20,7 @@ let funcData = {}; const { ClassName, State, Layout, Font, BackGround, Border, Interface, Margin, Shadow, Transition } = EditorList; class EditorComp extends React.Component { onChange = (cb) => { - const { cssName, currentEditCssString } = cb; + const { cssName, currentEditCssString, isDrag } = cb; const { currentEditData, dispatch, templateData } = this.props; const { id } = currentEditData; const ids = id.split('-'); @@ -43,6 +43,7 @@ class EditorComp extends React.Component { }; newTemplateData.data.style = (newTemplateData.data.style || []).filter(c => c.id !== cb.id); newTemplateData.data.style.push(data); + newTemplateData.noHistory = isDrag; dispatch(actions.setTemplateData(newTemplateData)); } diff --git a/site/edit/template/components/NavController/HistoryButton.jsx b/site/edit/template/components/NavController/HistoryButton.jsx index b39e9da1..0e427f54 100644 --- a/site/edit/template/components/NavController/HistoryButton.jsx +++ b/site/edit/template/components/NavController/HistoryButton.jsx @@ -64,7 +64,6 @@ class HistoryButton extends React.Component { const redoClassName = classnames('redo', { disabled: !currentHistory, }); - console.log(this.props); return (
  • diff --git a/site/edit/template/layout.jsx b/site/edit/template/layout.jsx index 356584e4..5d674fcc 100644 --- a/site/edit/template/layout.jsx +++ b/site/edit/template/layout.jsx @@ -1,5 +1,5 @@ import React from 'react'; -import { Icon, message, Button, Input, Form } from 'antd'; +import { Icon, message, Button, Input, Form, notification } from 'antd'; import { connect } from 'react-redux'; import { FormattedMessage, injectIntl } from 'react-intl'; @@ -31,16 +31,20 @@ class Layout extends React.PureComponent { } componentDidMount() { - /* notification.open({ - placement: 'bottomRight', - duration: null, - message: this.props.intl.formatMessage({ id: 'app.layout.notification.title' }), - description: ( -
    - {this.props.intl.formatMessage({ id: 'app.layout.notification.content' })} -
    - ), - }); */ + const date = new Date(); + const endDate = new Date('2019/11/29 23:59:59'); + if (endDate.getTime() - date.getTime() > 0) { + notification.open({ + placement: 'bottomRight', + duration: 10000, + message: this.props.intl.formatMessage({ id: 'app.layout.notification.title' }), + description: ( +
    + {this.props.intl.formatMessage({ id: 'app.layout.notification.content' })} +
    + ), + }); + } } componentDidUpdate() { diff --git a/site/edit/zh-CN.js b/site/edit/zh-CN.js index 1f095e73..be6799b5 100644 --- a/site/edit/zh-CN.js +++ b/site/edit/zh-CN.js @@ -124,7 +124,7 @@ module.exports = { 'app.login.title': '此页面已加锁,请输入密码。', 'app.login.noPassword': '不知道密码请删除当前面页或新建', 'app.login.new': '新建页面', - 'app.layout.notification.title': '3.0 发布说明', - 'app.layout.notification.content': '3.0 已正式发布,由于我们对有些模板做了调整,如果你以前编辑的模板不能显示,请新建页面重新编辑。', + 'app.layout.notification.title': '编辑器功能更新说明', + 'app.layout.notification.content': '为提高编辑时的性能与体验,目前将样式编辑调整为按回车或离开输入框才触发。', }, }; diff --git a/site/shared/redux/saga.js b/site/shared/redux/saga.js index 7fb426ab..e8a235d4 100644 --- a/site/shared/redux/saga.js +++ b/site/shared/redux/saga.js @@ -144,7 +144,6 @@ function* handleSetTemplateData(action) { const { data: { uid: id, data: attributes, noHistory } } = action; const data = { id, attributes, noHistory }; saveTemplateToLocalStorage(DEFAULT_USER_NAME, data); - console.log(noHistory); yield put({ type: UPDATE_HISTORY, data, @@ -182,8 +181,7 @@ function* handleSetUserAndTemplateData(action) { }); } -function* handleUpdateHistory(action, state) { - console.log(action, state); +function* handleUpdateHistory(action) { const { data: template } = action; const { noHistory } = template; if (!noHistory) {