From 468bc55ada06979e53b1d03b040b2dfe6beaf017 Mon Sep 17 00:00:00 2001 From: Christian Cleberg Date: Wed, 31 May 2023 20:58:43 -0500 Subject: initial commit --- LICENSE | 24 ++++++++++ README.md | 5 ++ index.php | 112 ++++++++++++++++++++++++++++++++++++++++++++ src/View/class-template.php | 39 +++++++++++++++ templates/template.html | 37 +++++++++++++++ 5 files changed, 217 insertions(+) create mode 100644 LICENSE create mode 100644 README.md create mode 100644 index.php create mode 100644 src/View/class-template.php create mode 100644 templates/template.html diff --git a/LICENSE b/LICENSE new file mode 100644 index 0000000..68a49da --- /dev/null +++ b/LICENSE @@ -0,0 +1,24 @@ +This is free and unencumbered software released into the public domain. + +Anyone is free to copy, modify, publish, use, compile, sell, or +distribute this software, either in source code form or as a compiled +binary, for any purpose, commercial or non-commercial, and by any +means. + +In jurisdictions that recognize copyright laws, the author or authors +of this software dedicate any and all copyright interest in the +software to the public domain. We make this dedication for the benefit +of the public at large and to the detriment of our heirs and +successors. We intend this dedication to be an overt act of +relinquishment in perpetuity of all present and future rights to this +software under copyright law. + +THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, +EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF +MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. +IN NO EVENT SHALL THE AUTHORS BE LIABLE FOR ANY CLAIM, DAMAGES OR +OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, +ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR +OTHER DEALINGS IN THE SOFTWARE. + +For more information, please refer to diff --git a/README.md b/README.md new file mode 100644 index 0000000..de3700d --- /dev/null +++ b/README.md @@ -0,0 +1,5 @@ +# hn + +[hn](https://hn.cleberg.net) is a simple front-end alternative for Hacker News. +hn focuses on the links shared on Hacker News, currently leaving out an options +to login or view comments. diff --git a/index.php b/index.php new file mode 100644 index 0000000..f5f7438 --- /dev/null +++ b/index.php @@ -0,0 +1,112 @@ + + * @param string $api_url The API endpoint to use for extraction + * @param string $inline_title The

title to use in the HTML + * @return string $html_output The formatted HTML result of stories from the API + */ +function get_stories($api_url, $inline_title) +{ + $response_raw = file_get_contents($api_url); + $response = json_decode($response_raw, true); + + $html_output = '

' . $inline_title . '

'; + + for ($i = 0; $i < count($response); $i++) { + $sub_url = 'https://hacker-news.firebaseio.com/v0/item/' . $response[$i] . '.json'; + $sub_response_raw = file_get_contents($sub_url); + $sub_response = json_decode($sub_response_raw, true); + + $html = '
' . $sub_response['title'] . ''; + $html .= '

by '; + $html .= $sub_response['by'] . ' | ' . $sub_response['score'] . ' points

'; + $html_output .= $html; + } + + return $html_output; +} + +/** + * Send formatted HTML results to the user via a template + * + * @access public + * @author cmc + * @param string $page_url Canoncial URL for HTML header + * @param string $page_description Page description for HTML header + * @param string $page_title Page title for HTML header + * @param string $page_content Page content to display in
+ */ +function echo_html(string $page_url, string $page_description, string $page_title, string $page_content) { + include_once '_classes/template.php'; + + $template = new HN\View\Template( + $page_url, + $page_description, + $page_title, + $page_content + ); + + $template->echo_template(); +} + +// EOF diff --git a/src/View/class-template.php b/src/View/class-template.php new file mode 100644 index 0000000..ea75648 --- /dev/null +++ b/src/View/class-template.php @@ -0,0 +1,39 @@ + + */ +class Template +{ + public function __construct(string $canonical_url, string $page_description, string $page_title, string $content_col) + { + $this->canonical_url = $canonical_url; + $this->description = $page_description; + $this->title = $page_title; + $this->content = $content_col; + $this->current_year = date("Y"); + } + + public function echo_template() + { + // Get the template file + $template_file = 'templates/template.html'; + $page = file_get_contents($template_file); + + // Replace the template variables + $page = str_replace('{page_title}', $this->title, $page); + $page = str_replace('{page_description}', $this->description, $page); + $page = str_replace('{canonical_url}', $this->canonical_url, $page); + $page = str_replace('{content}', $this->content, $page); + $page = str_replace('{current_year}', $this->current_year, $page); + + // Echo the filled-out template + echo $page; + } +} + +// EOF diff --git a/templates/template.html b/templates/template.html new file mode 100644 index 0000000..638562a --- /dev/null +++ b/templates/template.html @@ -0,0 +1,37 @@ + + + + + {page_title} + + + + + + + + + + + +
+ + {content} +
+ + + + + + -- cgit v1.2.3-70-g09d2