Remember the "The Word Editor"!? Here's the script responsible that implements it's end-to-end functionalities that allows for writing changes via the user interface to a user's forked repository.
The Functional Breakdown
The Word Editor empowered by the script should perform two (2) functions, taking some certain steps
- Write New Word - basically to add new word to the dictionary; does this in the following steps...
- Get an already established word template (.md) file
- Fill template placeholder with collected word
titleandcontentto create a word.mdx file in the appropriate words directorysrc/pages/browse - and commit the change to an established change branch/ref on the user's forked repository
- Edit/Update Existing Words - modify existing word in the dictionary, it does this in the following steps...
- Get an existing word from the user's fork of jargons.dev (looking in the words directory
src/pages/browse) - Parse its content and make necessary edits
- and and commit the change to an established change branch/ref on the user's forked repository
- Get an existing word from the user's fork of jargons.dev (looking in the words directory
The breakdown inspired creation of the following helper and utility functions.
-
writeNewWord- a function that accepts the wordtitleandcontentamongst others, leveraging the user's GitHub authenticated instance, it perform a write operation i.e. writing a new file (word.mdx) to a fork of jargons.dev on the user's account on their behalf through the "PUT /repos/{owner}/{repo}/contents/{path}" endpoint. -
getExistingWord- a function that simply retrieves the content of an existing word file on the user's forked repository, with the aim of availing it for edit. It does this by taking the word as argument and concatenates it in thepathparam (examplesrc/pages/browse/${normalizeAsUrl(word)}.mdx) of the request it makes to the endpoint "GET /repos/{owner}/{repo}/contents/{path}"; It is important to state that I had to make a few adjustments to the returned data from this helper for consumption reason, the adjustments are as followed- Added
titleproperty: theresponse.dataobject which comes from the query to the endpoint "GET /repos/{owner}/{repo}/contents/{path}" doesn't have atitleproperty (this is the word itself); -
Added
content_decodedproperty: theresponse.data.contentproperty holds the main content of the retrieved word, BUT it comes in a "base64" format; so I thought it'd be nice if the functional avails it in the consumption-ready format which can be use immediately without the need to convert at consumption. These I did with code below...
const { content, ...responseData } = response.data; return { title: word, content, content_decoded: Buffer.from(content, "base64").toString("utf-8"), ...responseData };
- Added
updateExistingWord- with an initial name ofeditExistingWordand changed to current name in jargonsdev/jargons.dev#34, this function performs similar operation with thewriteNewWordbut it over-writes existing word content in a specific file by replacing the file with another file with updated content. This is also done via user's account on their behalf through the "PUT /repos/{owner}/{repo}/contents/{path}" endpoint.writeFileContent- this helper as implied in its name does one thing โ it writes file content for words which is submitted in requests made by bothwriteNewWordandupdateExistingWordto the GitHub API, it does this by taking a word title and content (i.e. word definition) as variable and generates a content from a template avail to it replacing placeholder contents in it.
The PR
feat: implement `word-editor` script
#18
This Pull request implement the word-editor script; the primary functionality of this script is to allowing adding new word, retrieve and update existing word which are individual .mdx files residing in the src/pages/browse directory of the project. This script avails us of all the helper functions required to perform this operations.
- Implemented the
writeNewWordfunction - this function takes 3 params namely theuserOctokit,forkedRepoDetails, and theword; it leverages theuserOctokitinstance to perform a write operation i.e. writing a new file (newWord.mdx) to a fork of our project on the user's account on behalf of the user through the"PUT /repos/{owner}/{repo}/contents/{path}"endpoint - Impelemented the
getExistingWordfunction - this function helps retrieve data of existing words in the fork of our project on the user's account by calling the"GET /repos/{owner}/{repo}/contents/{path}"endpoint; it returns an object which carries the following properties that we are mostly interested in...-
title- title of the the existing word - this infact is a custom appended data to theresponse.datafrom the call made to the endpoint -
path- path to the existing word file -
sha- unique SHA of the existing word
-
- Implemented the
editExistingWordfunction - this function takes 3 params namely theuserOctokit,forkedRepoDetails, and theword(holds the properties:path,sha,titleandcontent); it leverages theuserOctokitinstance to perform a edit operation i.e. updating the existing file on a fork of our project on the user's account on behalf of the user through thesame"PUT /repos/{owner}/{repo}/contents/{path}"endpoint - Implemented
writeFileContenthelper function - this function help write a content for our dictionary word file generating them from another added constant in thesrc/lib/template/word.md.js
too lazy to record a screencast for this one ๐, but trust me ๐ค the shit works ๐ฎโ๐จ
Top comments (0)