'Link to RSS Feed', 'description' => 'Outputs a link to the RSS feed.' ]; } public function defineProperties() { return [ 'feedBurnerAddress' => [ 'title' => 'Feed Burner Address', 'description' => 'This is the address to the feedburner feed: http://feeds.feedburner.com/feed_address. If left blank, the link will just be to your RSS file: http://yourblog.com/rss.xml', 'default' => '', 'type' => 'string' ], 'defaultText' => [ 'title' => 'Default Link Text', 'description' => 'This is the default link text. It is used for the RSS link. For example: RSS.', 'default' => 'RSS', 'type' => 'string' ], 'iconClass' => [ 'title' => 'Icon Class(es)', 'description' => 'This is the icon class(es). It is used for the RSS link. . If left blank, the link will just display the default link text.', 'default' => '', 'type' => 'string' ] ]; } public function onRun() { $this->posts = $this->page['posts'] = $this->loadPosts(); $this->feedBurnerAddress = $this->page['feedBurnerAddress'] = $this->property('feedBurnerAddress'); $this->defaultText = $this->page['defaultText'] = $this->property('defaultText'); $this->iconClass = $this->page['iconClass'] = $this->property('iconClass'); $this->defaultRssLink = $this->page['defaultRssLink'] = Settings::get('link') . "/rss.xml"; $this->feedBurnerLink = $this->page['feedBurnerLink'] = "http://feeds.feedburner.com/" . $this->feedBurnerAddress; } protected function loadPosts() { $posts = Db::table('rainlab_blog_posts') ->orderBy('published_at', 'desc') ->where('published', '=', '1') ->get(); return $posts; } }