mirror of
https://github.com/naturalcrit/homebrewery.git
synced 2026-01-07 20:42:44 +00:00
split-style-and-metadata moved to helpers.js
This commit is contained in:
@@ -1,39 +1,13 @@
|
|||||||
const React = require('react');
|
const React = require('react');
|
||||||
const { useState, useRef } = React;
|
|
||||||
const _ = require('lodash');
|
const _ = require('lodash');
|
||||||
const Nav = require('naturalcrit/nav/nav.jsx');
|
const Nav = require('naturalcrit/nav/nav.jsx');
|
||||||
const yaml = require('js-yaml');
|
const { splitTextStyleAndMetadata } = require('../../../shared/helpers.js'); // Importing the function from helpers.js
|
||||||
|
|
||||||
const BREWKEY = 'homebrewery-new';
|
const BREWKEY = 'homebrewery-new';
|
||||||
const STYLEKEY = 'homebrewery-new-style';
|
const STYLEKEY = 'homebrewery-new-style';
|
||||||
const METAKEY = 'homebrewery-new-meta';
|
const METAKEY = 'homebrewery-new-meta';
|
||||||
|
|
||||||
const NewBrew = () => {
|
const NewBrew = () => {
|
||||||
|
|
||||||
|
|
||||||
|
|
||||||
const splitTextStyleAndMetadata = (brewContent) => {
|
|
||||||
let updatedBrew = { ...brewContent };
|
|
||||||
updatedBrew.text = updatedBrew.text.replaceAll('\r\n', '\n');
|
|
||||||
if (updatedBrew.text.startsWith('```metadata')) {
|
|
||||||
const index = updatedBrew.text.indexOf('```\n\n');
|
|
||||||
const metadataSection = updatedBrew.text.slice(12, index - 1);
|
|
||||||
const metadata = yaml.load(metadataSection);
|
|
||||||
updatedBrew = {
|
|
||||||
...updatedBrew,
|
|
||||||
..._.pick(metadata, ['title', 'description', 'tags', 'systems', 'renderer', 'theme', 'lang'])
|
|
||||||
};
|
|
||||||
updatedBrew.text = updatedBrew.text.slice(index + 5);
|
|
||||||
}
|
|
||||||
if (updatedBrew.text.startsWith('```css')) {
|
|
||||||
const index = updatedBrew.text.indexOf('```\n\n');
|
|
||||||
updatedBrew.style = updatedBrew.text.slice(7, index - 1);
|
|
||||||
updatedBrew.text = updatedBrew.text.slice(index + 5);
|
|
||||||
}
|
|
||||||
return updatedBrew;
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
const handleFileChange = (e) => {
|
const handleFileChange = (e) => {
|
||||||
const file = e.target.files[0];
|
const file = e.target.files[0];
|
||||||
if (file) {
|
if (file) {
|
||||||
@@ -44,14 +18,13 @@ const NewBrew = () => {
|
|||||||
text: fileContent,
|
text: fileContent,
|
||||||
style: ''
|
style: ''
|
||||||
};
|
};
|
||||||
if(fileContent.startsWith('```metadata')) {
|
if(fileContent.startsWith('```metadata')) {
|
||||||
const updatedBrew = splitTextStyleAndMetadata(newBrew);
|
splitTextStyleAndMetadata(newBrew); // Modify newBrew directly
|
||||||
localStorage.setItem(BREWKEY, updatedBrew.text);
|
localStorage.setItem(BREWKEY, newBrew.text);
|
||||||
localStorage.setItem(STYLEKEY, updatedBrew.style);
|
localStorage.setItem(STYLEKEY, newBrew.style);
|
||||||
localStorage.setItem(METAKEY, JSON.stringify(_.pick(updatedBrew, ['title', 'description', 'tags', 'systems', 'renderer', 'theme', 'lang'])));
|
localStorage.setItem(METAKEY, JSON.stringify(_.pick(newBrew, ['title', 'description', 'tags', 'systems', 'renderer', 'theme', 'lang'])));
|
||||||
|
window.location.href = '/new';
|
||||||
window.location.href = '/new';
|
} else {
|
||||||
} else {
|
|
||||||
alert('This file is invalid, please, enter a valid file');
|
alert('This file is invalid, please, enter a valid file');
|
||||||
}
|
}
|
||||||
};
|
};
|
||||||
|
|||||||
@@ -17,21 +17,8 @@ const asyncHandler = require('express-async-handler');
|
|||||||
|
|
||||||
const { DEFAULT_BREW } = require('./brewDefaults.js');
|
const { DEFAULT_BREW } = require('./brewDefaults.js');
|
||||||
|
|
||||||
const splitTextStyleAndMetadata = (brew)=>{
|
const { splitTextStyleAndMetadata } = require('../shared/helpers.js');
|
||||||
brew.text = brew.text.replaceAll('\r\n', '\n');
|
|
||||||
if(brew.text.startsWith('```metadata')) {
|
|
||||||
const index = brew.text.indexOf('```\n\n');
|
|
||||||
const metadataSection = brew.text.slice(12, index - 1);
|
|
||||||
const metadata = yaml.load(metadataSection);
|
|
||||||
Object.assign(brew, _.pick(metadata, ['title', 'description', 'tags', 'systems', 'renderer', 'theme', 'lang']));
|
|
||||||
brew.text = brew.text.slice(index + 5);
|
|
||||||
}
|
|
||||||
if(brew.text.startsWith('```css')) {
|
|
||||||
const index = brew.text.indexOf('```\n\n');
|
|
||||||
brew.style = brew.text.slice(7, index - 1);
|
|
||||||
brew.text = brew.text.slice(index + 5);
|
|
||||||
}
|
|
||||||
};
|
|
||||||
|
|
||||||
const sanitizeBrew = (brew, accessType)=>{
|
const sanitizeBrew = (brew, accessType)=>{
|
||||||
brew._id = undefined;
|
brew._id = undefined;
|
||||||
|
|||||||
22
shared/helpers.js
Normal file
22
shared/helpers.js
Normal file
@@ -0,0 +1,22 @@
|
|||||||
|
const _ = require('lodash');
|
||||||
|
const yaml = require('js-yaml');
|
||||||
|
|
||||||
|
const splitTextStyleAndMetadata = (brew) => {
|
||||||
|
brew.text = brew.text.replaceAll('\r\n', '\n');
|
||||||
|
if (brew.text.startsWith('```metadata')) {
|
||||||
|
const index = brew.text.indexOf('```\n\n');
|
||||||
|
const metadataSection = brew.text.slice(12, index - 1);
|
||||||
|
const metadata = yaml.load(metadataSection);
|
||||||
|
Object.assign(brew, _.pick(metadata, ['title', 'description', 'tags', 'systems', 'renderer', 'theme', 'lang']));
|
||||||
|
brew.text = brew.text.slice(index + 5);
|
||||||
|
}
|
||||||
|
if (brew.text.startsWith('```css')) {
|
||||||
|
const index = brew.text.indexOf('```\n\n');
|
||||||
|
brew.style = brew.text.slice(7, index - 1);
|
||||||
|
brew.text = brew.text.slice(index + 5);
|
||||||
|
}
|
||||||
|
};
|
||||||
|
|
||||||
|
module.exports = {
|
||||||
|
splitTextStyleAndMetadata
|
||||||
|
};
|
||||||
Reference in New Issue
Block a user