Esempio n. 1
0
function display_page_content()
{
    // Double check that the proper columns exist
    $video_id = find_db_column('photos', 'video_id');
    if (!$video_id) {
        echo '<h2 class="system-warning"><span>HCd&gt;CMS says:</span> The Photos table does not have a column called "video_id"</h2>';
    }
    $add_video = requestIdParam() == "add" ? true : false;
    if ($add_video) {
        $video = $videotitle = $videoservice = $videoembed = $videowidth = $videoheight = $videoposter = $attached_item = null;
    } else {
        $video_id = requestIdParam();
        $video = Videos::FindById($video_id);
        $videotitle = $video->get_title();
        $videoservice = $video->service;
        $videoembed = $video->embed;
        $videowidth = $video->width;
        $videoheight = $video->height;
        if ($video_id) {
            $possibleposter = Photos::FindVideoPoster($video_id);
            $videoposter = !empty($possibleposter) ? $possibleposter : null;
        }
    }
    ?>

	<script type="text/javascript">
		$().ready(function() {
			$("#edit_video").validate({
				rules : {
					title: "required", 
					embed: "required"
				},
				messages: {
					title: "Please enter a title for this video", 
					embed: "Please enter an embed code for this video"
				}
			});
		});
	</script>
	
	<div id="edit-header" class="videonav">
		<h1><?php 
    if ($add_video) {
        echo 'Add';
    } else {
        echo 'Edit';
    }
    ?>
 Video</h1>
	</div>
	
	<form method="POST" id="edit_video" enctype="multipart/form-data">
		
		<p class="display_name">
			<label for="title">Video Display Name:</label>
			<?php 
    textField("title", $videotitle, "required: true");
    ?>
<br />
			<span class="hint">This name should match the name you use on the embedding service source (YouTube or Vimeo), but it does not have to.</span>
		</p>
		
		<div class="column half">
    		<p><label for="service">Hosting Service:</label>
    			<select id="service" name="service">
    				<option value="youtube"<?php 
    if (!empty($video)) {
        if ($video->service == 'youtube') {
            echo ' selected';
        }
    }
    ?>
>YouTube</option>
    				<option value="vimeo"<?php 
    if (!empty($video)) {
        if ($video->service == 'vimeo') {
            echo ' selected';
        }
    }
    ?>
>Vimeo</option>
    			</select><br />
    			<span class="hint">Only two are supported at this time &mdash; YouTube is the default service.</span>
    		</p>
    		<p>
    			<label for="embed">Unique ID:</label>
    			<?php 
    textField("embed", $videoembed, "required: true");
    ?>
<br />
    			<span class="hint">The unique identifier is a random string of numbers and letters associated with the file. <br />
    			YouTube example: http://www.youtube.com/embed/<mark>tVUCsnMK18E</mark> <br />
    			Vimeo example: http://player.vimeo.com/video/<mark>72632269</mark> <br />
    			In both cases, we are only interested in the text highlighted.</span>
    		</p>
		</div>
		
		<div class="column half last">
    		<div class="column half">
        		<p>
        		    <label for="width">Video Width:</label>
        		    <?php 
    textField("width", $videowidth);
    ?>
        		</p>
    		</div>
    		<div class="column half last">
        		<p>
        		    <label for="height">Video Height:</label>
        		    <?php 
    textField("height", $videoheight);
    ?>
        		</p>
    		</div>
    		<div class="clearit"></div>
    		<p class="hint">With responsive design, the width may be set to 100% by the templates, so that number may not always be used</p>
    		
    		<?php 
    if ($video_id) {
        ?>
    		<!-- Video poster image -->
    		<p><label for="new_poster">Add/Edit a Poster image:</label>
				<input type="file" name="new_poster" id="new_poster" value="" />
			</p>
			<p class="hint">A poster image may be used by your site to display a link to a pop up video player. </p>
			<?php 
        if (!is_null($videoposter)) {
            echo '<h3>Existing Poster Image</h3>';
            echo '<p><img src="' . $videoposter->getPublicUrl() . '" style="max-width:100%;" alt=""></p>';
        }
        ?>
			<?php 
    }
    ?>
			
		</div>
		<div class="clearleft"></div>
		
<?php 
    // Show an attached Item if there is one.
    if (is_object($video)) {
        $attached_gallery = $video->getGallery();
        $attached_item = is_object($attached_gallery) ? $attached_gallery->get_item() : null;
    }
    if (is_object($attached_item)) {
        $section = array_shift($attached_item->getSections());
        echo '<h2>This video is attached to this Portfolio Item:</h2>';
        echo '<ol id="video_list" class="managelist">';
        echo '<li><a href="' . get_link("admin/portfolio_edit/" . $section->name . "/" . $attached_item->id) . '">' . $attached_item->get_title() . ' <small>EDIT</small></a></li>';
        echo '</ol>';
    }
    ?>
		
		<div id="edit-footer" class="videonav clearfix">
			<div class="column half">
		
				<p>
					<input type="submit" class="submitbutton" name="submit" value="Save Video" /> <br />
					<input type="submit" class="submitbuttonsmall" name="submit" value="Save and Return to List" />
				</p>
				
			</div>
			<div class="column half last">
<?php 
    $user = Users::GetCurrentUser();
    if ($user->has_role() && requestIdParam() != "add") {
        ?>
	
				<p><label for="delete">Delete this video?</label>
					<input name="delete" class="boxes" type="checkbox" value="<?php 
        echo $video->id;
        ?>
" />
					<span class="hint">Check the box and then click &ldquo;Save&rdquo; above to delete this video from the database</span>
				</p>
<?php 
    }
    ?>
			</div>
		</div>
	
	</form>
<?php 
}
Esempio n. 2
0
function initialize_page()
{
    $item = Items::FindById(getRequestVaratIndex(3));
    // get all the sections
    $sections = Sections::FindPublicSections();
    /* get this section
     * We do this mostly for the previous and next item functions. If we dont know what section we are currently inside, 
     * the user may get bounced over to a different place than they started. */
    $sectionname = getRequestVaratIndex(2);
    if ($sectionname != "item_orphan") {
        $section = Sections::FindByName($sectionname);
    }
    // get the associated gallery
    if ($item) {
        $gallery = $item->getGallery();
    }
    // finally, get the post action. Harder to hack if we explicitly check the value this way.
    $post_action = "";
    if (isset($_POST['submit'])) {
        $post_action = $_POST['submit'];
    }
    if ($post_action == "Save Item" || $post_action == "Add Image" || $post_action == "Add Document" || $post_action == "Add or Edit Video" || $post_action == "Save and Return to List") {
        /* 
         * Delete this item and its associated components
         */
        if (isset($_POST['delete'])) {
            // delete $photos and $gallery
            if (is_object($gallery)) {
                $gallery->delete(true);
                $success .= "Gallery and Images Deleted / ";
            }
            /* Documents ... Why not keep them?
            			if ( ITEM_DOCUMENTS ) {
            			    $itemdocuments = $item->findDocuments( 'display_order ASC' );
            			    foreach ( $itemdocuments as $thedoc ) {
               				    $thedoc->delete(true); 
            			    }
            			    $success .= "Documents Deleted / ";
            			}*/
            $item->delete(true);
            $success .= "Item Deleted / ";
            setFlash("<h3>" . substr($success, 0, -3) . "</h3>");
            //$main_portlink = ( DISPLAY_ITEMS_AS_LIST ) ? "admin/portfolio_list/alphabetical" : "admin/portfolio_list";
            //redirect( $main_portlink );
            redirect("admin/portfolio_list");
        } else {
            $item->content = $_POST['item_content'];
            $item->display_name = $_POST['display_name'];
            $previous_name = $item->name;
            $item->name = slug($_POST['display_name']);
            $item->template = 'inherit';
            $item->public = checkboxValue($_POST, 'public');
            $item->date_revised = date('Y-m-d H:i:s');
            // optional fields
            $item->sku = ITEM_SKU ? $_POST['item_sku'] : null;
            $item->taxonomy = ITEM_TAXONOMY ? $_POST['taxonomy'] : null;
            $item->price = ITEM_PRICE ? $_POST['item_price'] : null;
            // SAVE item... uses a MyActiveRecord method
            $item->save();
            $success = "Item Saved / ";
            // synchronize the users section selections only if they are different
            $selected_sections = array();
            $previous_sections = $item->getSections();
            if (isset($_POST['selected_sections'])) {
                $update_sections = false;
                $selected_sections = $_POST['selected_sections'];
                // Problem: If we loop on only the $previous_sections, we may have fewer or more loops than $selected_sections.
                // Compare one to the other.
                if (count($previous_sections) != count($selected_sections)) {
                    // The two do not match, so there has been a change
                    $update_sections = true;
                } else {
                    // In case the two match, let's make sure something is different.
                    foreach ($previous_sections as $sect) {
                        if (!in_array($sect->id, $selected_sections)) {
                            $update_sections = true;
                        }
                    }
                }
                if ($update_sections) {
                    $item->updateSelectedSections($selected_sections);
                    // update the revision dates of sections, too
                    $item->updateSectionRevisionDates();
                }
            }
            /* 
             * Rename the gallery if the slug has changed. 
             * We need the name of the gallery and the name of the slug to be consistent. 
             * If there isn't a gallery – something broke, so – create a new one. 
             */
            if (is_object($gallery) && $previous_name != $item->name) {
                $gallery->slug = "portfolioGal_" . $item->id . "_" . $item->name;
                $gallery->save();
                $success .= "Gallery name changed / ";
            }
            if (!is_object($gallery)) {
                $gallery = MyActiveRecord::Create('Galleries');
                $gallery->name = $_POST['display_name'] . " Gallery";
                $gallery->slug = "portfolioGal_" . $item->id . "_" . slug($_POST['display_name']);
                $gallery->save();
            }
            /* ! Gallery image functions
             */
            if (isset($_FILES['new_photo']) && $_FILES['new_photo']['error'] == 0) {
                // user has added a new file
                $newphoto = MyActiveRecord::Create('Photos', array('caption' => getPostValue("new_photo_caption"), 'gallery_id' => $gallery->id, 'display_order' => 1));
                $newphoto->save();
                $newphoto->save_uploaded_file($_FILES['new_photo']['tmp_name'], $_FILES['new_photo']['name'], true);
                $success .= "New photo uploaded / ";
            }
            /* 
             * Check current captions against previous ones. 
             */
            if (isset($_POST['captions'])) {
                $captions = $_POST['captions'];
                foreach ($captions as $key => $thecaption) {
                    $photo = Photos::FindById($key);
                    if ($photo->caption != $thecaption) {
                        $photo->caption = $thecaption;
                        $photo->save();
                    }
                }
            }
            /* 
             * Check photo display order against previous ones 
             */
            if (isset($_POST['photos_display_order'])) {
                $display_orders = $_POST['photos_display_order'];
                foreach ($display_orders as $key => $display_order) {
                    $photo = Photos::FindById($key);
                    if ($photo->display_order && $photo->display_order != $display_order) {
                        $photo->display_order = $display_order;
                        $photo->save();
                    }
                }
                $success .= "Photo order saved / ";
            }
            /* 
             * Delete a photo from the gallery
             */
            if (isset($_POST['deleted_photos'])) {
                $deleted_ids = $_POST['deleted_photos'];
                foreach ($deleted_ids as $status => $photo_id) {
                    $photo = Photos::FindById($photo_id);
                    $photo->delete(true);
                }
                $success .= "A photo was deleted / ";
            }
            /* 
             * Check to see if we allow Portfolio Thumbs
             */
            if (PORTFOLIOTHUMB_IMAGE) {
                // was a new thumbnail uploaded
                if (is_uploaded_file(realpath($_FILES["thumbnail"]["tmp_name"]))) {
                    if (Upload_and_Save_Image($_FILES["thumbnail"], 'items', 'thumbnail', $item->id, PORTFOLIOTHUMB_IMAGE_MAXWIDTH, PORTFOLIOTHUMB_IMAGE_MAXHEIGHT)) {
                        $success .= "Thumbnail updated / ";
                    }
                }
            }
            /* ! Video functions
             */
            if (ITEM_VIDEOS) {
                // If this gallery has mixed photos AND videos, check the display order again and set each by object type
                if (isset($_POST['galitem_display_order'])) {
                    foreach ($_POST['galitem_display_order'] as $key => $display_order) {
                        $type = $_POST['galitem_type'][$key];
                        $galitem = $type == 'photo' ? Photos::FindById($key) : Videos::FindById($key);
                        if (is_object($galitem)) {
                            //if ( $galitem->display_order && $galitem->display_order != $display_order ) {
                            $galitem->display_order = $display_order;
                            $galitem->save();
                        }
                    }
                }
                // Change the name of a video
                if (isset($_POST['vidnames'])) {
                    $vidnames = $_POST['vidnames'];
                    foreach ($vidnames as $key => $thename) {
                        $video = Videos::FindById($key);
                        if ($video->display_name != $thename) {
                            $video->name = slug($thename);
                            $video->display_name = $thename;
                            $video->save();
                        }
                    }
                    //$success .= "Video name updated / "; // False positive
                }
                // Change the embed code of a video
                if (isset($_POST['vidcodes'])) {
                    $vidnames = $_POST['vidcodes'];
                    foreach ($vidnames as $key => $thecode) {
                        $video = Videos::FindById($key);
                        if ($video->embed != $thecode) {
                            $video->embed = $thecode;
                            $video->save();
                        }
                    }
                    //$success .= "Video embed updated / "; // False positive
                }
                // Add a new Video
                if ($_POST['newvideo'] != '') {
                    $video = MyActiveRecord::Create('Videos');
                    /*
                     * Columns: id, name, title, service, embed, width, height, gallery_id, display_order
                     */
                    $vidtitle = $_POST['newvideo'];
                    $video->name = slug($vidtitle);
                    $video->display_name = $vidtitle;
                    $video->service = $_POST['vidservice'];
                    $video->embed = $_POST['vidembed'];
                    $video->width = $_POST['vidwidth'];
                    $video->height = $_POST['vidheight'];
                    $video->gallery_id = $gallery->id;
                    $video->display_order = count($gallery->get_photos()) + 1;
                    $video->save();
                    $success .= "Video added / ";
                }
                // Remove video association -- Does not delete the video itself
                if (isset($_POST['removevideo'])) {
                    $video = Videos::FindById($_POST['removevideo']);
                    $video->gallery_id = null;
                    $video->save();
                }
            }
            /* ! Document functions
             */
            if (ITEM_DOCUMENTS) {
                // Change the name of a document
                if (isset($_POST['docname'])) {
                    $docnames = $_POST['docname'];
                    foreach ($docnames as $key => $thename) {
                        $document = Documents::FindById($key);
                        if ($document->name != $thename) {
                            $document->name = $thename;
                            $document->save();
                        }
                    }
                }
                // Reorder documents
                if (isset($_POST['document_display_order'])) {
                    $display_orders = $_POST['document_display_order'];
                    foreach ($display_orders as $key => $display_order) {
                        $doc = Documents::FindById($key);
                        if ($doc->display_order != $display_order) {
                            $doc->display_order = $display_order;
                            $doc->save();
                        }
                    }
                }
                // Add a new document
                if (isset($_FILES['new_document']) && $_FILES['new_document']['error'] == 0) {
                    // Set the name equal to the input field or the physical doc name
                    $name = $_POST['new_document_title'] ? $_POST['new_document_title'] : unslug($_FILES['new_document']['name']);
                    $name = substr($name, 0, strrpos($name, "."));
                    // Find the extension. Explode on the period.
                    $extension = substr($_FILES['new_document']['name'], strrpos($_FILES['new_document']['name'], "."));
                    $file_type = substr($extension, 1);
                    // Chop the dot off
                    $filename = slug($name) . $extension;
                    $target_path = SERVER_DOCUMENTS_ROOT . $filename;
                    if (move_uploaded_file($_FILES['new_document']['tmp_name'], $target_path)) {
                        $new_doc = MyActiveRecord::Create('Documents', array('name' => $name, 'filename' => $filename, 'file_type' => $file_type, 'item_id' => $item->id));
                        $new_doc->save();
                        $success .= "Document uploaded and attached / ";
                        if (!chmod($target_path, 0644)) {
                            $success .= "!Warning: Document Permissions not set; this file may not display properly! / ";
                        }
                    } else {
                        $success .= "!WARNING: Document could not be uploaded! / ";
                    }
                } else {
                    echo $_FILES['new_document']['error'];
                }
                // Delete Documents
                if (isset($_POST['deleted_documents'])) {
                    $deleted_ids = $_POST['deleted_documents'];
                    foreach ($deleted_ids as $status => $doc_id) {
                        $doc = Documents::FindById($doc_id);
                        $doc->delete(true);
                    }
                    $success .= "A document was deleted / ";
                }
            }
            setFlash("<h3>" . substr($success, 0, -3) . "</h3>");
            if ($post_action == "Save and Return to List") {
                //$main_portlink = ( DISPLAY_ITEMS_AS_LIST ) ? "admin/portfolio_list/alphabetical" : "admin/portfolio_list";
                //redirect( $main_portlink );
                redirect("admin/portfolio_list");
            } else {
                if ($update_sections) {
                    // Find a new section, the one that has just been assigned...
                    // Breaks into an infinite loop on Windows servers... can we clear the post somehow?
                    $section = Sections::FindById($_POST['selected_sections'][0]);
                }
                redirect("/admin/portfolio_edit/" . $section->name . "/" . $item->id);
            }
        }
    }
}