bookmarklet; if ( !Skin::existsID($skinid) ) { $skinid = $CONF['BookmarkletSkin']; if ( !Skin::existsID($skinid) ) { sendContentType('text/html'); echo _ERROR_SKIN; exit; } } $skin =& $manager->getSkin($skinid, 'AdminActions', 'AdminSkin'); >>>>>>> skinnable-master // check logged-in or pass through $action = requestVar('action'); if ( !$member->isLoggedIn() ) { <<<<<<< HEAD bm_loginAndPassThrough($action); ======= bm_loginAndPassThrough($skin, $action); >>>>>>> skinnable-master exit; } else if ( $action == 'login') { $action = requestVar('nextaction'); } $action = strtolower($action); if ( $action == 'contextmenucode' ) { bm_doContextMenuCode(); exit; } else if ( $action == '' ) { $action = 'add'; } <<<<<<< HEAD // send HTTP 1.1 message header for Content-Type sendContentType('text/html', 'bookmarklet-' . $action); ======= >>>>>>> skinnable-master // check ticket $aActionsNotToCheck = array('login', 'add', 'edit'); if ( !in_array($action, $aActionsNotToCheck) ) { if ( !$manager->checkTicket() ) { bm_doError($skin, _ERROR_BADTICKET); } } // find out what to do switch ( $action ) { // adds the item for real case 'additem': bm_doAddItem($skin); break; // shows the edit item form case 'edit': bm_doEditForm($skin); break; // edits the item for real case 'edititem': bm_doEditItem($skin); break; // on login, 'action' gets changed to 'nextaction' case 'login': bm_doError($skin, 'Something went wrong'); break; // shows the fill in form case 'add': default: bm_doShowForm($skin); break; } function bm_doAddItem($skin) { global $member, $manager, $CONF; $manager->loadClass('ITEM'); $result = Item::createFromRequest(); if ( $result['status'] == 'error' ) { bm_doError($skin, $result['message']); } $blogid = getBlogIDFromItemID($result['itemid']); $blog =& $manager->getBlog($blogid); if ( $result['status'] == 'newcategory' ) { $message = 'Item was added, and a new category was created. Click here to edit the name and description of the category.'; $extrahead = ''; } else { $message = _ITEM_ADDED; $extrahead = ''; } <<<<<<< HEAD bm_message(_ITEM_ADDED, _ITEM_ADDED, $message,$extrahead); ======= bm_message($skin, _ITEM_ADDED, $message,$extrahead); >>>>>>> skinnable-master return; } function bm_doEditItem($skin) { global $member, $manager, $CONF; $itemid = intRequestVar('itemid'); $catid = postVar('catid'); // only allow if user is allowed to alter item if ( !$member->canUpdateItem($itemid, $catid) ) { bm_doError($skin, _ERROR_DISALLOWED); } $body = postVar('body'); $title = postVar('title'); $more = postVar('more'); $closed = intPostVar('closed'); $actiontype = postVar('actiontype'); $draftid = intPostVar('draftid'); // redirect to admin area on delete (has delete confirmation) if ( $actiontype == 'delete' ) { redirect('index.php?action=itemdelete&itemid=' . $itemid); exit; } // create new category if needed (only on edit/changedate) if ( i18n::strpos($catid,'newcat') === 0 ) { // get blogid list($blogid) = sscanf($catid, "newcat-%d"); // create $blog =& $manager->getBlog($blogid); $catid = $blog->createNewCategory(); // show error when sth goes wrong if ( !$catid ) { bm_doError($skin, 'Could not create new category'); } } // only edit action is allowed for bookmarklet edit switch ( $actiontype ) { case 'changedate': $publish = 1; $wasdraft = 0; $timestamp = mktime(intPostVar('hour'), intPostVar('minutes'), 0, intPostVar('month'), intPostVar('day'), intPostVar('year') ); break; case 'edit': $publish = 1; $wasdraft = 0; $timestamp = 0; break; case 'backtodrafts': $publish = 0; $wasdraft = 0; $timestamp = 0; break; default: bm_doError($skin, 'Something went wrong'); } // update item for real Item::update($itemid, $catid, $title, $body, $more, $closed, $wasdraft, $publish, $timestamp); if ( $draftid > 0 ) { Item::delete($draftid); } if ( $result['status'] == 'newcategory' ) { $href = "index.php?action=categoryedit&blogid={$blogid}&catid={$result['catid']}"; $onclick = 'if (event && event.preventDefault) event.preventDefault(); window.open(this.href); return false;'; $title = _BOOKMARKLET_NEW_WINDOW; $aTag = " "; $message = _BOOKMARKLET_NEW_CATEGORY . $aTag . _BOOKMARKLET_NEW_CATEGORY_EDIT . ''; } else { $message = _ITEM_ADDED; } <<<<<<< HEAD return; } function bm_loginAndPassThrough($action='add') ======= // show success message bm_message($skin, _ITEM_ADDED, $message, ''); return; } function bm_loginAndPassThrough($skin, $action='add') >>>>>>> skinnable-master { /* * TODO: これを出力させる $blogid = intRequestVar('blogid'); $itemid = intRequestVar('itemid'); $log_text = requestVar('logtext'); $log_link = requestVar('loglink'); $log_linktitle = requestVar('loglinktitle'); <<<<<<< HEAD echo "\n"; echo "\n"; echo "\n"; echo "Nucleus CMS Bookmarklet\n"; bm_style(); echo "\n"; echo "\n"; echo '

' . _LOGIN_PLEASE . "

\n"; echo "
\n"; echo "

\n"; echo _LOGINFORM_NAME . "
\n"; echo _LOGINFORM_PWD . "
\n"; ======= >>>>>>> skinnable-master echo '' . "\n"; echo '' . "\n"; echo '' . "\n"; echo '' . "\n"; echo '' . "\n"; echo "\n"; <<<<<<< HEAD echo '\n"; echo "

\n"; echo "
\n"; echo '

' . _POPUP_CLOSE . "

\n"; echo "\n"; echo "\n"; ======= */ $skin->parse('showlogin'); >>>>>>> skinnable-master return; } function bm_doShowForm($skin) { global $manager, $member; $blogid = intRequestVar('blogid'); $log_text = trim(requestVar('logtext')); $log_link = requestVar('loglink'); $log_linktitle = requestVar('loglinktitle'); if ( !Blog::existsID($blogid) ) { bm_doError($skin, _ERROR_NOSUCHBLOG); } <<<<<<< HEAD else { $blog =& $manager->getBlog($blogid); } if ( !$member->isTeamMember($blogid) ) ======= else if ( !$member->isTeamMember($blogid) ) >>>>>>> skinnable-master { bm_doError($skin, _ERROR_NOTONTEAM); } $blog =& $manager->getBlog($blogid); $logje = ''; if ( $log_text ) { $logje .= '
"' . Entity::hsc($log_text) . '"
' . "\n"; } if ( !$log_linktitle ) { $log_linktitle = $log_link; } if ( $log_link ) { $logje .= '' . Entity::hsc($log_linktitle) . ''; } <<<<<<< HEAD $variables = array(); $variables['body'] = $logje; $variables['title'] = Entity::hsc($log_linktitle); $handler = new PageFactory($blog); $handler->setVariables($variables); $contents = $handler->getTemplateFor('bookmarklet', 'add'); $manager->notify('PreAddItemForm', array('contents' => &$contents, 'blog' => &$blog)); $parser = new Parser($handler); $parser->parse($contents); ======= $item = array(); $item['body'] = $logje; $item['title'] = Entity::hsc($log_linktitle); $data = array( 'blog' => &$blog, 'item' => &$item, 'contents' => &$item ); $manager->notify('PreAddItemForm', $data); if ( $blog->convertBreaks() ) { $item['body'] = removeBreaks($item['body']); } Admin::$blog = &$blog; Admin::$contents = &$item; Admin::$action = 'createitem'; $skin->parse('createitem'); >>>>>>> skinnable-master return; } function bm_doEditForm($skin) { global $member, $manager; $itemid = intRequestVar('itemid'); if ( !$manager->existsItem($itemid, 0, 0) ) { bm_doError($skin, _ERROR_NOSUCHITEM); } else if ( !$member->canAlterItem($itemid) ) { bm_doError($skin, _ERROR_DISALLOWED); } <<<<<<< HEAD $variables =& $manager->getItem($itemid, 1, 1); ======= >>>>>>> skinnable-master $blog =& $manager->getBlog(getBlogIDFromItemID($itemid) ); $item =& $manager->getItem($itemid, 1, 1); <<<<<<< HEAD $manager->notify('PrepareItemForEdit', array('item' => &$variables) ); ======= $data = array( 'blog' => &$blog, 'item' => &$item ); $manager->notify('PrepareItemForEdit', $data); >>>>>>> skinnable-master if ( $blog->convertBreaks() ) { $variables['body'] = removeBreaks($variables['body']); $variables['more'] = removeBreaks($variables['more']); } <<<<<<< HEAD $handler = new PageFactory($blog); $handler->setVariables($variables); $contents = $handler->getTemplateFor('bookmarklet', 'edit'); $parser = new Parser($handler); $parser->parse($contents); return; } ======= Admin::$blog = &$blog; Admin::$contents = &$item; Admin::$action = 'itemedit'; $skin->parse('itemedit'); return;} >>>>>>> skinnable-master function bm_doError($skin, $msg) { bm_message($skin, _ERRORMSG, $msg); die; } function bm_message($skin, $title, $msg, $extrahead = '') { <<<<<<< HEAD echo "\n"; echo "\n"; echo "\n"; echo "{$title}\n"; bm_style(); echo $extrahead . "\n"; echo "\n"; echo "\n"; echo "

{$head}

\n"; echo "

{$msg}

\n"; echo '

' . _POPUP_CLOSE . "

\n"; echo "\n"; echo "\n"; ======= Admin::$extrahead = $extrahead; Admin::$headMess = $msg; $skin->parse('adminerrorpage'); >>>>>>> skinnable-master return; } function bm_doContextMenuCode($width=600, $height=500) { <<<<<<< HEAD echo "\n"; echo "\n"; return; } function bm_doContextMenuCode($width=600, $height=500) { global $CONF; ======= global $CONF; >>>>>>> skinnable-master $blogid = (integer) intGetVar('blogid'); echo "\n"; }