Posted in php
4
8:54 am, October 7, 2021

views list function for checking what views have been made on the current week

this is related to the views class that i added with monthly week number and yearly views, this is the function that i use to extract the top viewed pages for the week num, month num and year num.

I have found that recently i prefer to pass an array into the functions rather than function variables, im not sure if this is a good idea or not, but it seems to make my functions a lot neater. 

the example below shows the views page running the function from the views class extend. so its seperated into two parts. the formatting is just basic at the moment, i may add a template to the items later. 

One issue is that before each function you need to list the fields_array items otherwise you tend to forget what to pass into the function later on. But it is much neater to do it this way i find, and you can set each item or just leave them out. 

PHP

// on the views page
$views->fields_array = array(); // reset the array each time.
$views->fields_array["order_num"] = date('W');
$views->fields_array["order_type"] = "week_num"; // or... year_num, month_num or week_num
$views->fields_array["max"] = 10; // max items to show.
$views_week_top = $views->views_list();

$page_content .= $views_week_top;

// function within the views extend class
/*
  shows a list of views ordered by the fields array order_by value. for listing top hits per month, week or year.
  $this->fields_array = array(); // reset the array each time.
  $this->fields_array["order_num"] = date('y');
  $this->fields_array["order_type"] = "year_num"; // or... month_num or week_num
  $this->fields_array["max"] = 10; // max items to show.
  */
  public function views_list() {
    global $functions;
    $out = "";
    $db_table_name = $this->db->escapeString($this->db_table_name);
    $order_type = $this->db->escapeString($this->fields_array["order_type"]);
    $order_num = $this->db->escapeString($this->fields_array["order_num"]);
    $max = $this->db->escapeString($this->fields_array["max"]);
    echo $sql = "select * from $db_table_name where
      $order_type = '$order_num'
      order by views desc limit $max
      ";
    $result = $this->db->query($sql);
    $views_total = 0;
    while($row = $result->fetchArray()) {
      foreach($this->load_array as $load_title) {
          //$template->set($load_title, $row[$load_title]);
          // also set the items.. so they can be re-used, if for a single loaded item. this will not work for multiple
          $this->$load_title = $row[$load_title];
          // i think this breaks stuff... it seems to replace things on the view page, so not a good idea
      }
      // now all values should be set so can add the output
      $title_safe = htmlentities($this->title);
      $out .= "<div class='views-list-item'>
        <a href='/view/$this->linked_class/$this->linked_uid/'>$title_safe</a> $this->views
      </div>";
    }
    return $out;
  }

View Statistics
This Week
29
This Month
153
This Year
0

No Items Found.

Add Comment
Type in a Nick Name here
 
Other Items in php
fixing error Call to undefined function simplexml_load_string get the content of a url get the content of a link with php and test if the result is empty php check if url is valid with filter_var php save csv from array to file php export csv from string to browser download convert json string to a php array how to json encode an array in php how to decode xml in php php get file and save it php function to remove the query string from a url using php parse_url function to remove the query string from a url add every value in the load_array array into the out for testing Fix for PHP Warning Trying to get property '*name*' of non-object write the contents of a url into a file with php sqlite fetchArray into another array php return json header and content list_all_array an early stages of list all function that uses an array to pass in main variables replace singular variable assignment with an array loop and variable variables using the $_SERVER['HTTP_REFERER'] to check referring pages timeline class and function php html template class system views list function for checking what views have been made on the current week load array load all items from an array while in a sqlite load sql loop create a 200 character summary from a longer html string using strlen to check the length of a string and do something about it How to record your own page views with PHP, and make them into weekly monthly and yearly charts load from fields array php class function get the current week as a number with php creating embedded php code from a database field test php bundle write check if a file exists with php check if the file is a directory or check if the directory exists in php get the current working directory in php create directory with php create folder with php check if a product already exists by its md5 load random videos module using template PHP/SQLite - Load Random Item split a string into links using the comma extract youtube image from video url simple php ip blocker preg replace clean a string only allow a-zA-Z0-9 characters get last month as a number with php verify the google recapture server php rtrim strip white space or strings from the end of a string get the current month as a number show the difference between two dates in years, months, days, hours and seconds counting the occurrence of words in a multidimensional array write string contents to a file with php unable to access the $_FILES when submitting a form php check column exists in table sqlite
Search Code
Search Code by entering your search text above.
Welcome

This is my test area for webdev. I keep a collection of code snippits here, mostly for my reference. Also if i find a good site, i usually add it here.

Join me on Substack if you want me to send you a collection of the things i have done or found or read for the week. Or follow me on twitter if you prefer, i dont post much but i probably should!

❤👩‍💻🕹

Random Quote
There is no way to happiness. Happiness is the way.
Unknown